146 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			146 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <section id="content">
 | |
|     <div id="content-header">
 | |
|       <router-link to="/maintenanceVisits" class="button" id="maintenanceVisits-button"
 | |
|         @click="defaultMasterChecklistPage()">
 | |
|         <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"
 | |
|         @click="defaultMasterChecklistPage()">
 | |
|         <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="page-name">Production orders</h1>
 | |
|       </router-link>
 | |
|     </div>
 | |
|     <div id="content-body">
 | |
|       <CustomerSearch v-if="onTemplatelist || onCustomerTemplatelist" />
 | |
|       <MaintenanceVisitsTemplateTable v-if="onTemplatelist" />
 | |
|       <MaintenanceVisitsTemplateTableNoCustomer v-if="onCustomerTemplatelist" />
 | |
|       <MaintenanceVisitsTemplate v-if="onTemplate" />
 | |
|       <TemplateChecklistMVT v-if="onTemplate" />
 | |
|       <TemplateSearch v-if="onInstancelist" />
 | |
|       <MaintenanceVisitsInstanceTable v-if="onInstancelist" />
 | |
|       <MaintenanceVisitsInstance v-if="onInstance" />
 | |
|       <InstanceChecklist v-if="onInstance" />
 | |
|     </div>
 | |
|   </section>
 | |
| </template>
 | |
|       
 | |
|       
 | |
| <script setup>
 | |
| import { ref } from 'vue';
 | |
| 
 | |
| import CustomerSearch from "../components/CustomerSearch.vue";
 | |
| import MaintenanceVisitsTemplateTable from "../components/server/MaintenanceVisitsTemplateTable.vue";
 | |
| import MaintenanceVisitsTemplateTableNoCustomer from "../components/server/MaintenanceVisitsTemplateTableNoCustomer.vue";
 | |
| import MaintenanceVisitsTemplate from "../components/server/MaintenanceVisitsTemplate.vue";
 | |
| import TemplateChecklistMVT from "../components/server/TemplateChecklistMVT.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";
 | |
| import { useStore } from 'vuex';
 | |
| import { computed } from 'vue';
 | |
| 
 | |
| const store = useStore();
 | |
| const onTemplatelist = computed(() => store.state.onTemplatelist);
 | |
| const onCustomerTemplatelist = computed(() => store.state.onCustomerTemplatelist);
 | |
| const onTemplate = computed(() => store.state.onTemplate);
 | |
| const onInstancelist = computed(() => store.state.onInstancelist);
 | |
| const onInstance = computed(() => store.state.onInstance);
 | |
| 
 | |
| definePageMeta({
 | |
|   layout: 'default'
 | |
| })
 | |
| 
 | |
| const darkMode = ref(true)
 | |
| 
 | |
| const defaultMasterChecklistPage = () => {
 | |
|   store.commit('resetStore');
 | |
|   store.commit('changeToTemplatelist')
 | |
| }
 | |
| </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> |