130 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			130 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <section id="content">
 | |
|     <div id="content-header">
 | |
|       <router-link to="/maintenanceVisits" class="button" id="maintenanceVisits-button">
 | |
|         <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="active-page-name">Maintenance visits</h1>
 | |
|       </router-link>
 | |
|        
 | |
|        
 | |
|        
 | |
|        
 | |
|        
 | |
|        
 | |
|        
 | |
|        
 | |
|        
 | |
|        
 | |
|        
 | |
|        
 | |
|        
 | |
|        
 | |
|        
 | |
|        
 | |
|       <router-link to="/productionOrders" class="button" id="productionOrders-button">
 | |
|         <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="page-name">Production orders</h1>
 | |
|       </router-link>
 | |
|     </div>
 | |
|     <div id="content-body">
 | |
|       <ClientSearch />
 | |
|       <MaintenanceVisitsTemplateTable />
 | |
|       <MaintenanceVisitsTemplateTableNoClient />
 | |
|       <MaintenanceVisitsTemplate />
 | |
|       <TemplateChecklist />
 | |
|       <TemplateSearch />
 | |
|       <MaintenanceVisitsInstanceTable />
 | |
|       <MaintenanceVisitsInstance />
 | |
|       <InstanceChecklist />
 | |
|     </div>
 | |
|   </section>
 | |
| </template>
 | |
|       
 | |
|       
 | |
| <script setup>
 | |
| import { ref } from 'vue';
 | |
| 
 | |
| import ClientSearch from "../components/ClientSearch.vue";
 | |
| import MaintenanceVisitsTemplateTable from "../components/server/MaintenanceVisitsTemplateTable.vue";
 | |
| import MaintenanceVisitsTemplateTableNoClient from "../components/server/MaintenanceVisitsTemplateTableNoClient.vue";
 | |
| import MaintenanceVisitsTemplate from "../components/server/MaintenanceVisitsTemplate.vue";
 | |
| import TemplateChecklist from "../components/server/TemplateChecklist.vue";
 | |
| import TemplateSearch from "../components/TemplateSearch.vue";
 | |
| import MaintenanceVisitsInstanceTable from "../components/server/MaintenanceVisitsInstanceTable.vue";
 | |
| import MaintenanceVisitsInstance from "../components/server/MaintenanceVisitsInstance.vue";
 | |
| import InstanceChecklist from "../components/server/InstanceChecklist.vue";
 | |
| 
 | |
| definePageMeta({
 | |
|   layout: 'default'
 | |
| })
 | |
| 
 | |
| const darkMode = ref(true)
 | |
| </script>
 | |
|     
 | |
| <script>
 | |
| export default {
 | |
|   name: "MaintenanceVisitsPage",
 | |
| }
 | |
| </script>
 | |
|         
 | |
|         
 | |
|         
 | |
| <style scoped>
 | |
| * {
 | |
|   box-sizing: border-box;
 | |
| }
 | |
| 
 | |
| 
 | |
| #content {
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   float: left;
 | |
|   justify-content: stretch;
 | |
|   align-items: stretch;
 | |
|   width: 100%;
 | |
|   flex-grow: 1;
 | |
|   gap: 0.625rem;
 | |
|   padding: 0 1.25rem;
 | |
| }
 | |
| 
 | |
| #content-header {
 | |
|   display: flex;
 | |
|   flex-direction: row;
 | |
|   justify-content: center;
 | |
|   align-items: center;
 | |
|   width: 100%;
 | |
|   height: 3.125rem;
 | |
| }
 | |
| 
 | |
| #page-name {
 | |
|   letter-spacing: 5%;
 | |
|   font: 400 1.5rem/125% Overpass, -apple-system, Roboto, Helvetica,
 | |
|     sans-serif;
 | |
| }
 | |
| 
 | |
| #active-page-name {
 | |
|   letter-spacing: 5%;
 | |
|   font: 400 1.5rem/125% Overpass, -apple-system, Roboto, Helvetica,
 | |
|     sans-serif;
 | |
|   text-decoration: underline;
 | |
| }
 | |
| 
 | |
| .button {
 | |
|   text-decoration: none;
 | |
| }
 | |
| 
 | |
| .h1-darkmode {
 | |
|   color: #fff;
 | |
| }
 | |
| 
 | |
| .h1-lightmode {
 | |
|   color: #000;
 | |
| }
 | |
| 
 | |
| #content-body {
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   width: 100%;
 | |
|   gap: 1.25rem;
 | |
|   margin-bottom: 0.625rem;
 | |
|   border-radius: 0.625rem;
 | |
| }
 | |
| </style> |