109 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			109 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <section id="content">
 | |
|     <div id="content-header">
 | |
|       <router-link to="/solutions" class="button" id="solutions-button" @click="defaultSolutionPage()">
 | |
|         <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="page-name">Solutions</h1>
 | |
|       </router-link>
 | |
|     </div>
 | |
|     <div id="content-body">
 | |
|       <CustomerSearch v-if="onSolutionlist || onCustomerSolutionlist" />
 | |
|       <SolutionTable v-if="onSolutionlist" />
 | |
|       <SolutionTableNoCustomer v-if="onCustomerSolutionlist" />
 | |
|       <Solution v-if="onSolution" />
 | |
|       <SolutionChecklist v-if="onSolution" />
 | |
|     </div>
 | |
|   </section>
 | |
| </template>
 | |
| 
 | |
| <script setup>
 | |
| import { ref } from 'vue';
 | |
| 
 | |
| import CustomerSearch from "../components/CustomerSearch.vue";
 | |
| import SolutionTable from "../components/server/SolutionTable.vue";
 | |
| import SolutionTableNoCustomer from "../components/server/SolutionTableNoCustomer.vue";
 | |
| import Solution from "../components/server/Solution.vue";
 | |
| import SolutionChecklist from "../components/server/SolutionChecklist.vue";
 | |
| import { useStore } from 'vuex';
 | |
| import { computed } from 'vue';
 | |
| 
 | |
| const store = useStore();
 | |
| const onSolutionlist = computed(() => store.state.onSolutionlist);
 | |
| const onCustomerSolutionlist = computed(() => store.state.onCustomerSolutionlist);
 | |
| const onSolution = computed(() => store.state.onSolution);
 | |
| 
 | |
| definePageMeta({
 | |
|   layout: 'default',
 | |
|   title: 'Solutions'
 | |
| })
 | |
| 
 | |
| const defaultSolutionPage = () => {
 | |
|   store.commit('resetStore');
 | |
|   store.commit('changeToSolutionlist')
 | |
| }
 | |
| 
 | |
| const darkMode = ref(true)
 | |
| </script>
 | |
| 
 | |
| <script>
 | |
| export default {
 | |
|   name: "AssetPage",
 | |
| }
 | |
| </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;
 | |
|   text-decoration: underline;
 | |
| }
 | |
| 
 | |
| .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;
 | |
| }
 | |
| 
 | |
| .button {
 | |
|   text-decoration: none;
 | |
| }
 | |
| </style> |