implemented mode change
This commit is contained in:
		| @ -4,20 +4,22 @@ | ||||
|         <pre :class="['data', darkMode ? 'pre-darkmode' : 'pre-lightmode']">{{ asset.assetName }}</pre> | ||||
|     </section> | ||||
| </template> | ||||
|      | ||||
|      | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const chosenAssetId = computed(() => store.state.chosenAssetId); | ||||
|  | ||||
| const asset = ref({}); | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
|  | ||||
| // get config item from id | ||||
| const getItemById = async () => { | ||||
| @ -31,19 +33,38 @@ const getItemById = async () => { | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getItemById(); | ||||
| }); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getItemById(); | ||||
| }); | ||||
| </script> | ||||
|    | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|     name: "AssetSearch", | ||||
| }; | ||||
| </script>  | ||||
|    | ||||
|      | ||||
| </script> | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .asset-search { | ||||
|     display: flex; | ||||
| @ -103,5 +124,4 @@ export default { | ||||
|     background-color: #EBEBEB; | ||||
|     color: #000; | ||||
| } | ||||
| </style> | ||||
|      | ||||
| </style> | ||||
| @ -9,16 +9,18 @@ | ||||
| </template> | ||||
|  | ||||
| <script setup> | ||||
| import { ref, watch } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const filtered = computed(() => store.state.filtered); | ||||
| const filteredTerm = computed(() => store.state.filteredByCustomer); | ||||
| const customerFilter = ref(store.state.filteredByCustomer); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
|  | ||||
| // update filtered term | ||||
| const updateFilterTerm = () => { | ||||
| @ -39,6 +41,29 @@ const filterList = () => { | ||||
|  | ||||
| watch(filteredTerm, updateFilterTerm) | ||||
| watch(filtered, checkFiltered) | ||||
|  | ||||
| const getSession = async () => { | ||||
|   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|   if (loggedInUserDarkModeBool == 1) { | ||||
|     darkMode.value = true; | ||||
|   } else { | ||||
|     darkMode.value = false; | ||||
|   } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|   if (process.client) { | ||||
|     return localStorage.getItem(item) | ||||
|   } else { | ||||
|     return undefined | ||||
|   } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|   await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
|  | ||||
| @ -6,7 +6,8 @@ | ||||
|         value="My Maintenance Visits"> | ||||
|       <input :class="[darkMode ? 'input-darkmode' : 'input-lightmode']" type="button" id="production-orders" | ||||
|         value="My Production Orders"> | ||||
|       <input :class="[darkMode ? 'input-darkmode' : 'input-lightmode']" type="button" id="solutions" value="My Solutions"> | ||||
|       <input :class="[darkMode ? 'input-darkmode' : 'input-lightmode']" type="button" id="solutions" | ||||
|         value="My Solutions"> | ||||
|       <input :class="[darkMode ? 'input-darkmode' : 'input-lightmode']" type="button" id="issue-slips" | ||||
|         value="My Issue Slips"> | ||||
|     </div> | ||||
| @ -15,18 +16,46 @@ | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref(''); | ||||
|  | ||||
| const getSession = async () => { | ||||
|   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|   if (loggedInUserDarkModeBool == 1) { | ||||
|     darkMode.value = true; | ||||
|   } else { | ||||
|     darkMode.value = false; | ||||
|   } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|   if (process.client) { | ||||
|     return localStorage.getItem(item) | ||||
|   } else { | ||||
|     return undefined | ||||
|   } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|   await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|   name: "Dashboard", | ||||
| }; | ||||
| </script>  | ||||
|    | ||||
|    | ||||
| </script> | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .dashboard { | ||||
|   display: flex; | ||||
|  | ||||
| @ -1,129 +1,153 @@ | ||||
| <template> | ||||
|     <section :class="['employee-search', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|       <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Employee</div> | ||||
|       <pre v-if="!filtered" | ||||
|         :class="['data', 'pre-customer', darkMode ? 'pre-darkmode' : 'pre-lightmode']">{{ employeeFilter }}</pre> | ||||
|       <input v-if="filtered" v-model="employeeFilter" @change="filterList()" | ||||
|         :class="['data', 'input-customer', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|     </section> | ||||
|   </template> | ||||
|    | ||||
|   <script setup> | ||||
|   import { ref, watch } from 'vue'; | ||||
|   import { useStore } from 'vuex'; | ||||
|   import { computed } from 'vue'; | ||||
|    | ||||
|   const store = useStore(); | ||||
|   const filtered = computed(() => store.state.filtered); | ||||
|   const filteredTerm = computed(() => store.state.filteredByCustomer); | ||||
|   const employeeFilter = ref(store.state.filteredByCustomer); | ||||
|    | ||||
|   const darkMode = ref(true) | ||||
|    | ||||
|   // update filtered term | ||||
|   const updateFilterTerm = () => { | ||||
|     employeeFilter.value = filteredTerm.value | ||||
|   <section :class="['employee-search', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|     <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Employee</div> | ||||
|     <pre v-if="!filtered" | ||||
|       :class="['data', 'pre-customer', darkMode ? 'pre-darkmode' : 'pre-lightmode']">{{ employeeFilter }}</pre> | ||||
|     <input v-if="filtered" v-model="employeeFilter" @change="filterList()" | ||||
|       :class="['data', 'input-customer', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|   </section> | ||||
| </template> | ||||
|  | ||||
| <script setup> | ||||
| import { ref, watch, onMounted } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const filtered = computed(() => store.state.filtered); | ||||
| const filteredTerm = computed(() => store.state.filteredByCustomer); | ||||
| const employeeFilter = ref(store.state.filteredByCustomer); | ||||
|  | ||||
| const darkMode = ref(''); | ||||
|  | ||||
| // update filtered term | ||||
| const updateFilterTerm = () => { | ||||
|   employeeFilter.value = filteredTerm.value | ||||
| } | ||||
|  | ||||
| const checkFiltered = () => { | ||||
|   if (!filtered.value) { | ||||
|     employeeFilter.value = '' | ||||
|     filterList(); | ||||
|   } | ||||
|    | ||||
|   const checkFiltered = () => { | ||||
|     if (!filtered.value) { | ||||
|       employeeFilter.value = '' | ||||
|       filterList(); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // update the filtered term in the store | ||||
| const filterList = () => { | ||||
|   store.commit('updateFilterbyCustomer', employeeFilter.value); | ||||
| } | ||||
|  | ||||
| watch(filteredTerm, updateFilterTerm) | ||||
| watch(filtered, checkFiltered) | ||||
|  | ||||
| const getSession = async () => { | ||||
|   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|   if (loggedInUserDarkModeBool == 1) { | ||||
|     darkMode.value = true; | ||||
|   } else { | ||||
|     darkMode.value = false; | ||||
|   } | ||||
|    | ||||
|   // update the filtered term in the store | ||||
|   const filterList = () => { | ||||
|     store.commit('updateFilterbyCustomer', employeeFilter.value); | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|   if (process.client) { | ||||
|     return localStorage.getItem(item) | ||||
|   } else { | ||||
|     return undefined | ||||
|   } | ||||
|    | ||||
|   watch(filteredTerm, updateFilterTerm) | ||||
|   watch(filtered, checkFiltered) | ||||
|   </script> | ||||
|    | ||||
|   <script> | ||||
|   export default { | ||||
|     name: "EmployeeSearch", | ||||
|   }; | ||||
|   </script> | ||||
|    | ||||
|   <style scoped> | ||||
|   .employee-search { | ||||
|     display: flex; | ||||
|     align-items: center; | ||||
|     padding: 0.625em 1.875em; | ||||
|     gap: 1.25em; | ||||
|     width: 30.125em; | ||||
|     height: 3.125em; | ||||
|     box-shadow: 0.25em 0.25em 0.25em rgba(0, 0, 0, 0.25); | ||||
|     border-radius: 0.625em; | ||||
|   } | ||||
|    | ||||
|   .section-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
|   } | ||||
|    | ||||
|   .section-lightmode { | ||||
|     background-color: #fff; | ||||
|   } | ||||
|    | ||||
|   .label { | ||||
|     width: 2.5625em; | ||||
|     height: 1.875em; | ||||
|     font-family: "Overpass"; | ||||
|     font-style: normal; | ||||
|     font-weight: 400; | ||||
|     font-size: 0.875em; | ||||
|     line-height: 1.875; | ||||
|     letter-spacing: 0.05em; | ||||
|   } | ||||
|    | ||||
|   .label-darkmode { | ||||
|     color: #FFFFFF; | ||||
|   } | ||||
|    | ||||
|   .label-lightmode { | ||||
|     color: #000; | ||||
|   } | ||||
|    | ||||
|   .data { | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
|     align-items: flex-start; | ||||
|     padding: 0 0.625rem; | ||||
|     border-radius: 0.3125rem; | ||||
|     box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset; | ||||
|     letter-spacing: 5%; | ||||
|     font: 400 0.75rem/250% Overpass, sans-serif; | ||||
|   } | ||||
|    | ||||
|   .pre-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
|   } | ||||
|    | ||||
|   .pre-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
|     color: #000; | ||||
|   } | ||||
|    | ||||
|   .input-customer { | ||||
|     border: none; | ||||
|     margin-left: 1rem; | ||||
|   } | ||||
|    | ||||
|   .pre-customer { | ||||
|     margin-left: 1rem; | ||||
|   } | ||||
|    | ||||
|   .data-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
|   } | ||||
|    | ||||
|   .data-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
|     color: #000; | ||||
|   } | ||||
|   </style> | ||||
|    | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|   await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|   name: "EmployeeSearch", | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style scoped> | ||||
| .employee-search { | ||||
|   display: flex; | ||||
|   align-items: center; | ||||
|   padding: 0.625em 1.875em; | ||||
|   gap: 1.25em; | ||||
|   width: 30.125em; | ||||
|   height: 3.125em; | ||||
|   box-shadow: 0.25em 0.25em 0.25em rgba(0, 0, 0, 0.25); | ||||
|   border-radius: 0.625em; | ||||
| } | ||||
|  | ||||
| .section-darkmode { | ||||
|   background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .section-lightmode { | ||||
|   background-color: #fff; | ||||
| } | ||||
|  | ||||
| .label { | ||||
|   width: 2.5625em; | ||||
|   height: 1.875em; | ||||
|   font-family: "Overpass"; | ||||
|   font-style: normal; | ||||
|   font-weight: 400; | ||||
|   font-size: 0.875em; | ||||
|   line-height: 1.875; | ||||
|   letter-spacing: 0.05em; | ||||
| } | ||||
|  | ||||
| .label-darkmode { | ||||
|   color: #FFFFFF; | ||||
| } | ||||
|  | ||||
| .label-lightmode { | ||||
|   color: #000; | ||||
| } | ||||
|  | ||||
| .data { | ||||
|   display: flex; | ||||
|   flex-direction: row; | ||||
|   align-items: flex-start; | ||||
|   padding: 0 0.625rem; | ||||
|   border-radius: 0.3125rem; | ||||
|   box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset; | ||||
|   letter-spacing: 5%; | ||||
|   font: 400 0.75rem/250% Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .pre-darkmode { | ||||
|   background-color: #212121; | ||||
|   color: #fff; | ||||
| } | ||||
|  | ||||
| .pre-lightmode { | ||||
|   background-color: #EBEBEB; | ||||
|   color: #000; | ||||
| } | ||||
|  | ||||
| .input-customer { | ||||
|   border: none; | ||||
|   margin-left: 1rem; | ||||
| } | ||||
|  | ||||
| .pre-customer { | ||||
|   margin-left: 1rem; | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|   background-color: #212121; | ||||
|   color: #fff; | ||||
| } | ||||
|  | ||||
| .data-lightmode { | ||||
|   background-color: #EBEBEB; | ||||
|   color: #000; | ||||
| } | ||||
| </style> | ||||
| @ -9,16 +9,18 @@ | ||||
| </template> | ||||
|  | ||||
| <script setup> | ||||
| import { ref, watch } from 'vue'; | ||||
| import { ref, watch, onMounted } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const filtered = computed(() => store.state.filtered); | ||||
| const filteredTerm = computed(() => store.state.filteredByCustomer); | ||||
| const issueStateFilter = ref(store.state.filteredByCustomer); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
|  | ||||
| // update filtered term | ||||
| const updateFilterTerm = () => { | ||||
| @ -39,6 +41,29 @@ const filterList = () => { | ||||
|  | ||||
| watch(filteredTerm, updateFilterTerm) | ||||
| watch(filtered, checkFiltered) | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
|  | ||||
| @ -49,7 +49,7 @@ | ||||
|  | ||||
| <script setup> | ||||
| // import { useRouter } from 'vue-router'; | ||||
| import { ref, onBeforeUnmount } from 'vue'; | ||||
| import { ref, onBeforeUnmount, onMounted } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../clientsideConfig.js'; | ||||
| import { useStore } from 'vuex'; | ||||
| @ -58,7 +58,7 @@ const store = useStore(); | ||||
|  | ||||
| const { signIn } = useAuth() | ||||
| // const router = useRouter(); | ||||
| const darkMode = ref(true); | ||||
| const darkMode = ref(''); | ||||
| const isError = ref(false); | ||||
| const showPassword = ref(false); | ||||
| const errorMsg = ref(''); | ||||
| @ -120,6 +120,7 @@ const handleLogin = async () => { | ||||
|       setItem('logged-in-user-adminBool', response.data.adminBool) | ||||
|       setItem('logged-in-user-technicianBool', response.data.technicianBool) | ||||
|       setItem('logged-in-user-readerBool', response.data.readerBool) | ||||
|       setItem('logged-in-user-darkMode', response.data.darkModeBool) | ||||
|       setTimeout(() => { | ||||
|       }, 500); | ||||
|       store.commit('setLocalStorageChanged'); | ||||
| @ -187,7 +188,25 @@ const handleLogin = async () => { | ||||
| //   } | ||||
| // } | ||||
|  | ||||
| const getSession = async () => { | ||||
|   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|   if (loggedInUserDarkModeBool == 1) { | ||||
|     darkMode.value = true; | ||||
|   } else { | ||||
|     darkMode.value = false; | ||||
|   } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|   if (process.client) { | ||||
|     return localStorage.getItem(item) | ||||
|   } else { | ||||
|     return undefined | ||||
|   } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|   getSession(); | ||||
|   document.addEventListener('keyup', handleKeyUp); | ||||
|   document.getElementById('username-input').value = ''; | ||||
|   document.getElementById('password-input').value = ''; | ||||
|  | ||||
| @ -13,16 +13,44 @@ | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref(''); | ||||
|  | ||||
| const getSession = async () => { | ||||
|   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|   if (loggedInUserDarkModeBool == 1) { | ||||
|     darkMode.value = true; | ||||
|   } else { | ||||
|     darkMode.value = false; | ||||
|   } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|   if (process.client) { | ||||
|     return localStorage.getItem(item) | ||||
|   } else { | ||||
|     return undefined | ||||
|   } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|   await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|   name: "QuickAccess", | ||||
| }; | ||||
| </script>  | ||||
| </script> | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
|  | ||||
| @ -4,21 +4,49 @@ | ||||
|     <pre :class="['data', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Template name</pre> | ||||
|   </section> | ||||
| </template> | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref(''); | ||||
|  | ||||
| const getSession = async () => { | ||||
|   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|   if (loggedInUserDarkModeBool == 1) { | ||||
|     darkMode.value = true; | ||||
|   } else { | ||||
|     darkMode.value = false; | ||||
|   } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|   if (process.client) { | ||||
|     return localStorage.getItem(item) | ||||
|   } else { | ||||
|     return undefined | ||||
|   } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|   await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|   name: "TemplateSearch", | ||||
| }; | ||||
| </script>  | ||||
| </script> | ||||
|  | ||||
|  | ||||
|    | ||||
| <style scoped> | ||||
| .template-search { | ||||
|   display: flex; | ||||
| @ -78,5 +106,4 @@ export default { | ||||
|   background-color: #EBEBEB; | ||||
|   color: #000; | ||||
| } | ||||
| </style> | ||||
|    | ||||
| </style> | ||||
| @ -350,13 +350,15 @@ | ||||
| </template> | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenIssueSlipId = computed(() => store.state.chosenIssueSlipId); | ||||
| const addBool = computed(() => store.state.new); | ||||
| @ -388,7 +390,7 @@ const newIngressBillDate = ref(''); | ||||
| const newEgressDate = ref(''); | ||||
| const newEgressBillDate = ref(''); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref('') | ||||
| const issueSlip = ref({}); | ||||
|  | ||||
| // get issue slip from id | ||||
| @ -545,7 +547,27 @@ const addIssueSlip = async () => { | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
|     getIssueSlipById(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| @ -1,7 +1,7 @@ | ||||
| <template> | ||||
|     <section v-if="!addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 v-if="!editable" :class="['asset-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">{{ | ||||
|             item.assetName }}</h2> | ||||
|         item.assetName }}</h2> | ||||
|         <input v-if="editable" v-model="item.assetName" @change="updateConfigItem()" | ||||
|             :class="['data', 'asset-name-input', darkMode ? 'h2-darkmode' : 'h2-lightmode', darkMode ? 'h2-input-darkmode' : 'h2-input-lightmode', 'input']"> | ||||
|         <div class="asset-data"> | ||||
| @ -144,7 +144,7 @@ | ||||
|         </div> | ||||
|     </section> | ||||
| </template> | ||||
|      | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| @ -153,12 +153,15 @@ import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
|  | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenAssetId = computed(() => store.state.chosenAssetId); | ||||
| const deleteBool = computed(() => store.state.deleteBool); | ||||
| const addBool = computed(() => store.state.new); | ||||
|  | ||||
| const darkMode = ref(true); | ||||
| const darkMode = ref(''); | ||||
| const item = ref({}); | ||||
| const customer = ref({}); | ||||
| const configItems = ref([]); | ||||
| @ -331,11 +334,30 @@ const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     }, 1500); | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteAsset); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getItemById(); | ||||
|     getConfigItems(); | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteAsset); | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
|     await getItemById(); | ||||
|     triggerBackendCallsWithDelay(getConfigItems); | ||||
|     triggerBackendCallsWithDelay(getCustomers); | ||||
| }); | ||||
| </script> | ||||
| @ -345,8 +367,8 @@ export default { | ||||
|     name: "Asset", | ||||
| } | ||||
| </script> | ||||
|        | ||||
|        | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .information { | ||||
|     display: flex; | ||||
|  | ||||
| @ -24,7 +24,7 @@ | ||||
|                     <td | ||||
|                         :class="['Solution', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Solution-darkmode' : 'Solution-lightmode']"> | ||||
|                         <nuxt-link to="/solutions" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||
|                             @click="goToChosenSolution(sol.primaryID)"> | ||||
|                             {{ sol.solutionName }} | ||||
|                         </nuxt-link> | ||||
| @ -45,6 +45,8 @@ import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const chosenAssetId = computed(() => store.state.chosenAssetId); | ||||
| const searchable = computed(() => store.state.searchable); | ||||
| const filtered = computed(() => store.state.filtered); | ||||
| @ -55,7 +57,7 @@ const asset = ref({}); | ||||
| const solutions = ref([]); | ||||
| const solutionsBySol = ref([]); | ||||
| const solutionsByType = ref([]); | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref('') | ||||
|  | ||||
| //get all solutions from the chosen asset | ||||
| const getSolutions = async () => { | ||||
| @ -114,18 +116,18 @@ const searchSolution = async () => { | ||||
|  | ||||
| //get all solutions based on the searched solution name | ||||
| const filterSolutionByType = async () => { | ||||
|         if (typeSearchFilter.value === '') { | ||||
|             await getSolutions(); | ||||
|         } else { | ||||
|             try { | ||||
|                 const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedSolutionsByType/${typeSearchFilter.value}`); | ||||
|                 solutionsByType.value = response.data; | ||||
|                 solutions.value = filterObjectsWithMatchingIds(solutions.value, solutionsByType.value); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
|             } | ||||
|     if (typeSearchFilter.value === '') { | ||||
|         await getSolutions(); | ||||
|     } else { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedSolutionsByType/${typeSearchFilter.value}`); | ||||
|             solutionsByType.value = response.data; | ||||
|             solutions.value = filterObjectsWithMatchingIds(solutions.value, solutionsByType.value); | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| const filterObjectsWithMatchingIds = (arr1, arr2) => { | ||||
|     return arr1.filter(obj1 => { | ||||
| @ -136,7 +138,27 @@ const filterObjectsWithMatchingIds = (arr1, arr2) => { | ||||
| watch(searchable, updateSearchTerm); | ||||
| watch(filtered, updateFilterTerm); | ||||
|  | ||||
| onMounted(() => { | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
|     getItemById(); | ||||
| }); | ||||
| </script> | ||||
| @ -181,6 +203,14 @@ export default { | ||||
|     letter-spacing: 0.05em; | ||||
| } | ||||
|  | ||||
| .nuxt-link-darkmode { | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .nuxt-link-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
| @ -244,7 +274,6 @@ export default { | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .tr-head-darkmode { | ||||
|  | ||||
| @ -32,7 +32,7 @@ | ||||
|                     <td | ||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         <nuxt-link to="/assets" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||
|                             @click="goToChosenAsset(item.primaryID)"> | ||||
|                             {{ item.assetName }} | ||||
|                         </nuxt-link> | ||||
| @ -49,7 +49,7 @@ | ||||
|         </table> | ||||
|     </div> | ||||
| </template> | ||||
|    | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| @ -59,6 +59,9 @@ import { computed } from 'vue'; | ||||
|  | ||||
| // get accesss to the store | ||||
| const store = useStore() | ||||
|  | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const goToChosenAsset = (id) => { | ||||
|     store.commit('setChosenAsset', id); | ||||
|     store.commit('changeToAsset'); | ||||
| @ -67,7 +70,7 @@ const customerFilter = computed(() => store.state.filteredByCustomer); | ||||
| const assetSearchable = computed(() => store.state.searchable); | ||||
|  | ||||
| const assetSearchFilter = ref(''); | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref('') | ||||
| const configItemList = ref([]); | ||||
|  | ||||
| // update search term | ||||
| @ -114,10 +117,29 @@ const searchConfigItem = async () => { | ||||
|     } | ||||
| } | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(customerFilter, getConfigItems); | ||||
| watch(assetSearchable, updateSearchTerm); | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
|     await getConfigItems(); | ||||
| }); | ||||
| </script> | ||||
| @ -126,9 +148,9 @@ onMounted(async () => { | ||||
| export default { | ||||
|     name: "AssetTable", | ||||
| }; | ||||
| </script>     | ||||
|      | ||||
|      | ||||
| </script> | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
| @ -336,6 +358,13 @@ th { | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
| } | ||||
|  | ||||
| .nuxt-link-darkmode { | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .nuxt-link-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -44,29 +44,55 @@ | ||||
|       </div> | ||||
|     </div> | ||||
|     <div class="notes"> | ||||
|       <pre  :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Notes:</pre> | ||||
|       <pre :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Notes:</pre> | ||||
|       <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes">...</pre> | ||||
|     </div> | ||||
|   </section> | ||||
| </template> | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref('') | ||||
|  | ||||
| const getSession = async () => { | ||||
|   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|   if (loggedInUserDarkModeBool == 1) { | ||||
|     darkMode.value = true; | ||||
|   } else { | ||||
|     darkMode.value = false; | ||||
|   } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|   if (process.client) { | ||||
|     return localStorage.getItem(item) | ||||
|   } else { | ||||
|     return undefined | ||||
|   } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|   await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|   name: "Customer", | ||||
| }; | ||||
| </script>    | ||||
|      | ||||
|      | ||||
| </script> | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
|  | ||||
|  | ||||
| section { | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
| @ -75,9 +101,15 @@ section { | ||||
|   box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
|   align-items: stretch; | ||||
|   justify-content: center; | ||||
| }  | ||||
| .section-darkmode { background-color: #2c2c2c; } | ||||
| .section-lightmode { background-color: #ffffff; } | ||||
| } | ||||
|  | ||||
| .section-darkmode { | ||||
|   background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .section-lightmode { | ||||
|   background-color: #ffffff; | ||||
| } | ||||
|  | ||||
|  | ||||
| .title { | ||||
| @ -85,9 +117,15 @@ section { | ||||
|   letter-spacing: 0.05rem; | ||||
|   text-decoration-line: underline; | ||||
|   font: italic 400 1rem/1.875rem Overpass, sans-serif; | ||||
| }  | ||||
| .title-darkmode { color: #ffffff; }  | ||||
| .title-lightmode { color: #000000; } | ||||
| } | ||||
|  | ||||
| .title-darkmode { | ||||
|   color: #ffffff; | ||||
| } | ||||
|  | ||||
| .title-lightmode { | ||||
|   color: #000000; | ||||
| } | ||||
|  | ||||
|  | ||||
| .data-field { | ||||
| @ -98,9 +136,15 @@ section { | ||||
|   align-items: center; | ||||
|   justify-content: flex-start; | ||||
|   gap: 1.25rem; | ||||
| }  | ||||
| .data-field#customer-id { padding: 0.625rem 1.875rem; } | ||||
| .data-field#street-name { flex: 3; }  | ||||
| } | ||||
|  | ||||
| .data-field#customer-id { | ||||
|   padding: 0.625rem 1.875rem; | ||||
| } | ||||
|  | ||||
| .data-field#street-name { | ||||
|   flex: 3; | ||||
| } | ||||
|  | ||||
| .label { | ||||
|   letter-spacing: 0.03rem; | ||||
| @ -110,8 +154,14 @@ section { | ||||
| pre { | ||||
|   margin: 0; | ||||
| } | ||||
| .pre-darkmode { color: #ffffff; }  | ||||
| .pre-lightmode { color: #000000; } | ||||
|  | ||||
| .pre-darkmode { | ||||
|   color: #ffffff; | ||||
| } | ||||
|  | ||||
| .pre-lightmode { | ||||
|   color: #000000; | ||||
| } | ||||
|  | ||||
| .data { | ||||
|   display: flex; | ||||
| @ -124,15 +174,17 @@ pre { | ||||
|   justify-content: flex-start; | ||||
|   letter-spacing: 5%; | ||||
|   font: 400 0.75rem/250% Overpass, sans-serif; | ||||
| }  | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|   background-color: #212121; | ||||
|   color: #ffffff; | ||||
| }  | ||||
| } | ||||
|  | ||||
| .data-lightmode { | ||||
|   background-color: #ebebeb; | ||||
|   color: #000000; | ||||
| }  | ||||
| } | ||||
|  | ||||
|  | ||||
| .customer-data { | ||||
| @ -145,7 +197,8 @@ pre { | ||||
|   gap: 0.625rem | ||||
| } | ||||
|  | ||||
| .contact, .address { | ||||
| .contact, | ||||
| .address { | ||||
|   display: flex; | ||||
|   flex: auto; | ||||
|   flex-direction: column; | ||||
| @ -159,8 +212,13 @@ pre { | ||||
|   font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .h3-darkmode { color: #ffffff; }  | ||||
| .h3-lightmode { color: #000000; } | ||||
| .h3-darkmode { | ||||
|   color: #ffffff; | ||||
| } | ||||
|  | ||||
| .h3-lightmode { | ||||
|   color: #000000; | ||||
| } | ||||
|  | ||||
|  | ||||
| .street-address { | ||||
| @ -180,6 +238,8 @@ pre { | ||||
|   justify-content: center; | ||||
|   gap: 0.625rem; | ||||
| } | ||||
| #notes { align-self: stretch; } | ||||
|  | ||||
| #notes { | ||||
|   align-self: stretch; | ||||
| } | ||||
| </style> | ||||
| @ -1,143 +1,193 @@ | ||||
| <template> | ||||
|     <section :class="[darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|       <pre :class="['title', darkMode ? 'title-darkmode' : 'title-lightmode']">Department name</pre> | ||||
|       <div class="data-group"> | ||||
|         <div class="data-field" id="id"> | ||||
|             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">ID:</pre> | ||||
|             <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|         </div> | ||||
|         <div class="data-field" id="customer-id"> | ||||
|             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer ID:</pre> | ||||
|             <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|         </div> | ||||
|         <div class="data-field" id="head"> | ||||
|             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Head:</pre> | ||||
|             <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|         </div> | ||||
|   <section :class="[darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|     <pre :class="['title', darkMode ? 'title-darkmode' : 'title-lightmode']">Department name</pre> | ||||
|     <div class="data-group"> | ||||
|       <div class="data-field" id="id"> | ||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">ID:</pre> | ||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|       </div> | ||||
|       <div class="notes"> | ||||
|             <pre  :class="['area-title', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Notes:</pre> | ||||
|             <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes">...</pre> | ||||
|       <div class="data-field" id="customer-id"> | ||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer ID:</pre> | ||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|       </div> | ||||
|     </section> | ||||
|       <div class="data-field" id="head"> | ||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Head:</pre> | ||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|       </div> | ||||
|     </div> | ||||
|     <div class="notes"> | ||||
|       <pre :class="['area-title', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Notes:</pre> | ||||
|       <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes">...</pre> | ||||
|     </div> | ||||
|   </section> | ||||
| </template> | ||||
|    | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref('') | ||||
|  | ||||
| const getSession = async () => { | ||||
|   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|   if (loggedInUserDarkModeBool == 1) { | ||||
|     darkMode.value = true; | ||||
|   } else { | ||||
|     darkMode.value = false; | ||||
|   } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|   if (process.client) { | ||||
|     return localStorage.getItem(item) | ||||
|   } else { | ||||
|     return undefined | ||||
|   } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|   await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
| name: "CustomerDepartment", | ||||
|   name: "CustomerDepartment", | ||||
| }; | ||||
| </script>    | ||||
| </script> | ||||
|  | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
|  | ||||
| * {  | ||||
| box-sizing: border-box; | ||||
| margin: 0;  | ||||
| * { | ||||
|   box-sizing: border-box; | ||||
|   margin: 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| section { | ||||
| display: flex; | ||||
| flex-direction: column; | ||||
| padding: 1.25rem 1.875rem; | ||||
| border-radius: 0.625rem; | ||||
| box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| align-items: stretch; | ||||
| justify-content: center; | ||||
| }  | ||||
| .section-darkmode { background-color: #2c2c2c; } | ||||
| .section-lightmode { background-color: #ffffff; } | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|   padding: 1.25rem 1.875rem; | ||||
|   border-radius: 0.625rem; | ||||
|   box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
|   align-items: stretch; | ||||
|   justify-content: center; | ||||
| } | ||||
|  | ||||
| .section-darkmode { | ||||
|   background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .section-lightmode { | ||||
|   background-color: #ffffff; | ||||
| } | ||||
|  | ||||
|  | ||||
| .title { | ||||
| padding: 1.25rem 0; | ||||
| letter-spacing: 0.04rem; | ||||
| text-decoration-line: underline; | ||||
| font: italic 400 1rem/1.875rem Overpass, sans-serif; | ||||
| }  | ||||
| .title-darkmode { color: #ffffff; }  | ||||
| .title-lightmode { color: #000000; } | ||||
|   padding: 1.25rem 0; | ||||
|   letter-spacing: 0.04rem; | ||||
|   text-decoration-line: underline; | ||||
|   font: italic 400 1rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .title-darkmode { | ||||
|   color: #ffffff; | ||||
| } | ||||
|  | ||||
| .title-lightmode { | ||||
|   color: #000000; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| .data-group { | ||||
| display: flex; | ||||
| flex: auto; | ||||
| width: 100%; | ||||
| flex-direction: row; | ||||
| padding: 0.625rem 0; | ||||
| align-items: center; | ||||
| justify-content: stretch; | ||||
|   display: flex; | ||||
|   flex: auto; | ||||
|   width: 100%; | ||||
|   flex-direction: row; | ||||
|   padding: 0.625rem 0; | ||||
|   align-items: center; | ||||
|   justify-content: stretch; | ||||
| } | ||||
|  | ||||
|  | ||||
| .data-field { | ||||
| display: flex; | ||||
| flex: auto; | ||||
| width: 30%; | ||||
| flex-direction: row; | ||||
| padding: 0.8rem 1.875rem; | ||||
| align-items: center; | ||||
| justify-content: flex-start; | ||||
| gap: 1.25rem; | ||||
| }  | ||||
| #head { width: 40%; } | ||||
|  | ||||
| .label { | ||||
| letter-spacing: 0.02rem; | ||||
| font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|   display: flex; | ||||
|   flex: auto; | ||||
|   width: 30%; | ||||
|   flex-direction: row; | ||||
|   padding: 0.8rem 1.875rem; | ||||
|   align-items: center; | ||||
|   justify-content: flex-start; | ||||
|   gap: 1.25rem; | ||||
| } | ||||
|  | ||||
| .pre-darkmode { color: #ffffff; }  | ||||
| .pre-lightmode { color: #000000; } | ||||
| #head { | ||||
|   width: 40%; | ||||
| } | ||||
|  | ||||
| .label { | ||||
|   letter-spacing: 0.02rem; | ||||
|   font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .pre-darkmode { | ||||
|   color: #ffffff; | ||||
| } | ||||
|  | ||||
| .pre-lightmode { | ||||
|   color: #000000; | ||||
| } | ||||
|  | ||||
| .data { | ||||
| display: flex; | ||||
| flex-direction: row; | ||||
| padding: 0 0.625rem; | ||||
| border-radius: 0.3125rem; | ||||
| box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset; | ||||
| background-color: #212121; | ||||
| align-items: center; | ||||
| justify-content: flex-start; | ||||
| letter-spacing: 0.02rem; | ||||
| font: 400 0.75rem/1.875rem Overpass, sans-serif; | ||||
| }  | ||||
|   display: flex; | ||||
|   flex-direction: row; | ||||
|   padding: 0 0.625rem; | ||||
|   border-radius: 0.3125rem; | ||||
|   box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset; | ||||
|   background-color: #212121; | ||||
|   align-items: center; | ||||
|   justify-content: flex-start; | ||||
|   letter-spacing: 0.02rem; | ||||
|   font: 400 0.75rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
| background-color: #212121; | ||||
| color: #ffffff; | ||||
| }  | ||||
|   background-color: #212121; | ||||
|   color: #ffffff; | ||||
| } | ||||
|  | ||||
| .data-lightmode { | ||||
| background-color: #ebebeb; | ||||
| color: #000000; | ||||
| }  | ||||
|   background-color: #ebebeb; | ||||
|   color: #000000; | ||||
| } | ||||
|  | ||||
|  | ||||
| .notes { | ||||
| display: flex; | ||||
| flex: auto; | ||||
| flex-direction: column; | ||||
| padding: 1.25rem 1.875rem 0.625rem; | ||||
| align-items: flex-start; | ||||
| justify-content: center; | ||||
| gap: 0.625rem; | ||||
|   display: flex; | ||||
|   flex: auto; | ||||
|   flex-direction: column; | ||||
|   padding: 1.25rem 1.875rem 0.625rem; | ||||
|   align-items: flex-start; | ||||
|   justify-content: center; | ||||
|   gap: 0.625rem; | ||||
| } | ||||
|  | ||||
| .area-title { | ||||
| letter-spacing: 0.03rem; | ||||
| font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|   letter-spacing: 0.03rem; | ||||
|   font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| #notes { align-self: stretch; } | ||||
|  | ||||
| #notes { | ||||
|   align-self: stretch; | ||||
| } | ||||
| </style> | ||||
| @ -1,38 +1,81 @@ | ||||
|  | ||||
| <template> | ||||
|     <section :class="['data', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Employees:</div> | ||||
|         <table class="data-table" id="customer-employee-table"> | ||||
|             <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> | ||||
|                 <th :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']">ID</th> | ||||
|                 <th :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">Name</th> | ||||
|                 <th :class="['JobTitle', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'JobTitle-darkmode' : 'JobTitle-lightmode']">Job Title</th> | ||||
|                 <th :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']">Pronouns</th> | ||||
|                 <th | ||||
|                     :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||
|                     ID</th> | ||||
|                 <th | ||||
|                     :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                     Name</th> | ||||
|                 <th | ||||
|                     :class="['JobTitle', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'JobTitle-darkmode' : 'JobTitle-lightmode']"> | ||||
|                     Job Title</th> | ||||
|                 <th | ||||
|                     :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']"> | ||||
|                     Pronouns</th> | ||||
|             </tr> | ||||
|             <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                 <td :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']">...</td> | ||||
|                 <td :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">...</td> | ||||
|                 <td :class="['JobTitle', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'JobTitle-darkmode' : 'JobTitle-lightmode']">...</td> | ||||
|                 <td :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']">...</td> | ||||
|                 <td | ||||
|                     :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||
|                     ...</td> | ||||
|                 <td | ||||
|                     :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                     ...</td> | ||||
|                 <td | ||||
|                     :class="['JobTitle', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'JobTitle-darkmode' : 'JobTitle-lightmode']"> | ||||
|                     ...</td> | ||||
|                 <td | ||||
|                     :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']"> | ||||
|                     ...</td> | ||||
|             </tr> | ||||
|         </table> | ||||
|     </section> | ||||
| </template> | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref('') | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|   name: "CustomerDepartmentEmployeeList", | ||||
|     name: "CustomerDepartmentEmployeeList", | ||||
| }; | ||||
| </script>    | ||||
| </script> | ||||
|  | ||||
|  | ||||
|    | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
| @ -44,8 +87,14 @@ export default { | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
| .section-darkmode { background-color: #2c2c2c; } | ||||
| .section-lightmode { background-color: #ffffff; } | ||||
|  | ||||
| .section-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .section-lightmode { | ||||
|     background-color: #ffffff; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -55,8 +104,14 @@ export default { | ||||
|     text-decoration-line: underline; | ||||
|     font: 400 1rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
| .label-darkmode { color: #ffffff; } | ||||
| .label-lightmode { color: #000000; } | ||||
|  | ||||
| .label-darkmode { | ||||
|     color: #ffffff; | ||||
| } | ||||
|  | ||||
| .label-lightmode { | ||||
|     color: #000000; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -81,14 +136,22 @@ export default { | ||||
|     border-top: none; | ||||
|     border-bottom: 0.0625rem solid #000000; | ||||
| } | ||||
|  | ||||
| .tr-head-lightmode { | ||||
|     border-top: none; | ||||
|     border-bottom: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
| .tr-darkmode { border-top: 0.0625rem solid #000000; } | ||||
| .tr-lightmode { border-top: 0.0625rem solid #8e8e8e; } | ||||
|  | ||||
| th, td { | ||||
| .tr-darkmode { | ||||
|     border-top: 0.0625rem solid #000000; | ||||
| } | ||||
|  | ||||
| .tr-lightmode { | ||||
|     border-top: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| th, | ||||
| td { | ||||
|     height: 1.875rem; | ||||
|     width: 35%; | ||||
|     padding: 0; | ||||
| @ -97,21 +160,36 @@ th, td { | ||||
|     letter-spacing: 0.02rem; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
| th { font: 700 0.875rem/1.875rem Overpass, sans-serif; } | ||||
| .th-darkmode, .td-darkmode {  | ||||
|  | ||||
| th { | ||||
|     font: 700 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .th-darkmode, | ||||
| .td-darkmode { | ||||
|     color: #ffffff; | ||||
|     border-right: 0.0625rem solid #000000; | ||||
| } | ||||
| .th-lightmode, .td-lightmode {  | ||||
|  | ||||
| .th-lightmode, | ||||
| .td-lightmode { | ||||
|     color: #000000; | ||||
|     border-right: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| .ID { width: 20%; } | ||||
| .Pronouns { width: 10%; } | ||||
| .ID { | ||||
|     width: 20%; | ||||
| } | ||||
|  | ||||
| .Pronouns-darkmode { border-right: none; } | ||||
| .Pronouns-lightmode { border-right: none; } | ||||
| .Pronouns { | ||||
|     width: 10%; | ||||
| } | ||||
|  | ||||
| .Pronouns-darkmode { | ||||
|     border-right: none; | ||||
| } | ||||
|  | ||||
| .Pronouns-lightmode { | ||||
|     border-right: none; | ||||
| } | ||||
| </style> | ||||
| @ -18,9 +18,37 @@ | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref('') | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
|  | ||||
| @ -56,7 +56,7 @@ | ||||
|       </div> | ||||
|     </div> | ||||
|     <div class="notes"> | ||||
|       <pre  :class="['area-title', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Notes:</pre> | ||||
|       <pre :class="['area-title', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Notes:</pre> | ||||
|       <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes">...</pre> | ||||
|     </div> | ||||
|   </section> | ||||
| @ -65,24 +65,51 @@ | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref('') | ||||
|  | ||||
| const getSession = async () => { | ||||
|   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|   if (loggedInUserDarkModeBool == 1) { | ||||
|     darkMode.value = true; | ||||
|   } else { | ||||
|     darkMode.value = false; | ||||
|   } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|   if (process.client) { | ||||
|     return localStorage.getItem(item) | ||||
|   } else { | ||||
|     return undefined | ||||
|   } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|   await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|   name: "CustomerEmployee", | ||||
| }; | ||||
| </script>    | ||||
|    | ||||
|    | ||||
|    | ||||
| <style scoped> | ||||
| </script> | ||||
|  | ||||
| * {  | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| * { | ||||
|   box-sizing: border-box; | ||||
|   margin: 0;  | ||||
|   margin: 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -94,9 +121,15 @@ section { | ||||
|   box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
|   align-items: stretch; | ||||
|   justify-content: center; | ||||
| }  | ||||
| .section-darkmode { background-color: #2c2c2c; } | ||||
| .section-lightmode { background-color: #ffffff; } | ||||
| } | ||||
|  | ||||
| .section-darkmode { | ||||
|   background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .section-lightmode { | ||||
|   background-color: #ffffff; | ||||
| } | ||||
|  | ||||
|  | ||||
| .title { | ||||
| @ -104,9 +137,15 @@ section { | ||||
|   letter-spacing: 0.04rem; | ||||
|   text-decoration-line: underline; | ||||
|   font: italic 400 1rem/1.875rem Overpass, sans-serif; | ||||
| }  | ||||
| .title-darkmode { color: #ffffff; }  | ||||
| .title-lightmode { color: #000000; } | ||||
| } | ||||
|  | ||||
| .title-darkmode { | ||||
|   color: #ffffff; | ||||
| } | ||||
|  | ||||
| .title-lightmode { | ||||
|   color: #000000; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -119,13 +158,18 @@ section { | ||||
|   align-items: center; | ||||
|   justify-content: stretch; | ||||
| } | ||||
|  | ||||
| #personal-data { | ||||
|   flex-direction: column; | ||||
|   align-items: stretch; | ||||
|   justify-content: center; | ||||
|   gap: 0.625rem; | ||||
| } | ||||
| #full-name, #other { padding: 0; } | ||||
|  | ||||
| #full-name, | ||||
| #other { | ||||
|   padding: 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| .data-field { | ||||
| @ -137,17 +181,33 @@ section { | ||||
|   align-items: center; | ||||
|   justify-content: flex-start; | ||||
|   gap: 1.25rem; | ||||
| }  | ||||
| #first-name, #last-name, #department, #job-title, #phone { width: 40%; } | ||||
| #preferred-name, #mail { width: 60%; } | ||||
| } | ||||
|  | ||||
| #first-name, | ||||
| #last-name, | ||||
| #department, | ||||
| #job-title, | ||||
| #phone { | ||||
|   width: 40%; | ||||
| } | ||||
|  | ||||
| #preferred-name, | ||||
| #mail { | ||||
|   width: 60%; | ||||
| } | ||||
|  | ||||
| .label { | ||||
|   letter-spacing: 0.02rem; | ||||
|   font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .pre-darkmode { color: #ffffff; }  | ||||
| .pre-lightmode { color: #000000; } | ||||
| .pre-darkmode { | ||||
|   color: #ffffff; | ||||
| } | ||||
|  | ||||
| .pre-lightmode { | ||||
|   color: #000000; | ||||
| } | ||||
|  | ||||
| .data { | ||||
|   display: flex; | ||||
| @ -160,15 +220,17 @@ section { | ||||
|   justify-content: flex-start; | ||||
|   letter-spacing: 0.02rem; | ||||
|   font: 400 0.75rem/1.875rem Overpass, sans-serif; | ||||
| }  | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|   background-color: #212121; | ||||
|   color: #ffffff; | ||||
| }  | ||||
| } | ||||
|  | ||||
| .data-lightmode { | ||||
|   background-color: #ebebeb; | ||||
|   color: #000000; | ||||
| }  | ||||
| } | ||||
|  | ||||
|  | ||||
| .notes { | ||||
| @ -186,6 +248,7 @@ section { | ||||
|   font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| #notes { align-self: stretch; } | ||||
|  | ||||
| #notes { | ||||
|   align-self: stretch; | ||||
| } | ||||
| </style> | ||||
| @ -3,35 +3,79 @@ | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Employees:</div> | ||||
|         <table class="data-table" id="customer-employee-table"> | ||||
|             <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> | ||||
|                 <th :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']">ID</th> | ||||
|                 <th :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">Name</th> | ||||
|                 <th :class="['Department', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Department-darkmode' : 'Department-lightmode']">Department / Job Title</th> | ||||
|                 <th :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']">Pronouns</th> | ||||
|                 <th | ||||
|                     :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||
|                     ID</th> | ||||
|                 <th | ||||
|                     :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                     Name</th> | ||||
|                 <th | ||||
|                     :class="['Department', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Department-darkmode' : 'Department-lightmode']"> | ||||
|                     Department / Job Title</th> | ||||
|                 <th | ||||
|                     :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']"> | ||||
|                     Pronouns</th> | ||||
|             </tr> | ||||
|             <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                 <td :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']">...</td> | ||||
|                 <td :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">...</td> | ||||
|                 <td :class="['Department', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Department-darkmode' : 'Department-lightmode']">...</td> | ||||
|                 <td :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']">...</td> | ||||
|                 <td | ||||
|                     :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||
|                     ...</td> | ||||
|                 <td | ||||
|                     :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                     ...</td> | ||||
|                 <td | ||||
|                     :class="['Department', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Department-darkmode' : 'Department-lightmode']"> | ||||
|                     ...</td> | ||||
|                 <td | ||||
|                     :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']"> | ||||
|                     ...</td> | ||||
|             </tr> | ||||
|         </table> | ||||
|     </section> | ||||
| </template> | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref('') | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|   name: "CustomerEmployeeList", | ||||
|     name: "CustomerEmployeeList", | ||||
| }; | ||||
| </script>    | ||||
| </script> | ||||
|  | ||||
|  | ||||
|    | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
| @ -43,8 +87,14 @@ export default { | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
| .section-darkmode { background-color: #2c2c2c; } | ||||
| .section-lightmode { background-color: #ffffff; } | ||||
|  | ||||
| .section-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .section-lightmode { | ||||
|     background-color: #ffffff; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -54,8 +104,14 @@ export default { | ||||
|     text-decoration-line: underline; | ||||
|     font: 400 1rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
| .label-darkmode { color: #ffffff; } | ||||
| .label-lightmode { color: #000000; } | ||||
|  | ||||
| .label-darkmode { | ||||
|     color: #ffffff; | ||||
| } | ||||
|  | ||||
| .label-lightmode { | ||||
|     color: #000000; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -80,14 +136,22 @@ export default { | ||||
|     border-top: none; | ||||
|     border-bottom: 0.0625rem solid #000000; | ||||
| } | ||||
|  | ||||
| .tr-head-lightmode { | ||||
|     border-top: none; | ||||
|     border-bottom: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
| .tr-darkmode { border-top: 0.0625rem solid #000000; } | ||||
| .tr-lightmode { border-top: 0.0625rem solid #8e8e8e; } | ||||
|  | ||||
| th, td { | ||||
| .tr-darkmode { | ||||
|     border-top: 0.0625rem solid #000000; | ||||
| } | ||||
|  | ||||
| .tr-lightmode { | ||||
|     border-top: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| th, | ||||
| td { | ||||
|     height: 1.875rem; | ||||
|     width: 35%; | ||||
|     padding: 0; | ||||
| @ -96,21 +160,36 @@ th, td { | ||||
|     letter-spacing: 0.02rem; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
| th { font: 700 0.875rem/1.875rem Overpass, sans-serif; } | ||||
| .th-darkmode, .td-darkmode {  | ||||
|  | ||||
| th { | ||||
|     font: 700 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .th-darkmode, | ||||
| .td-darkmode { | ||||
|     color: #ffffff; | ||||
|     border-right: 0.0625rem solid #000000; | ||||
| } | ||||
| .th-lightmode, .td-lightmode {  | ||||
|  | ||||
| .th-lightmode, | ||||
| .td-lightmode { | ||||
|     color: #000000; | ||||
|     border-right: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| .ID { width: 20%; } | ||||
| .Pronouns { width: 10%; } | ||||
| .ID { | ||||
|     width: 20%; | ||||
| } | ||||
|  | ||||
| .Pronouns-darkmode { border-right: none; } | ||||
| .Pronouns-lightmode { border-right: none; } | ||||
| .Pronouns { | ||||
|     width: 10%; | ||||
| } | ||||
|  | ||||
| .Pronouns-darkmode { | ||||
|     border-right: none; | ||||
| } | ||||
|  | ||||
| .Pronouns-lightmode { | ||||
|     border-right: none; | ||||
| } | ||||
| </style> | ||||
| @ -2,29 +2,60 @@ | ||||
|   <section :class="['quick-access', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|     <h2 :class="['heading', darkMode ? 'heading-darkmode' : 'heading-lightmode']">Quick Access</h2> | ||||
|     <div class="shortcuts"> | ||||
|       <input :class="[darkMode ? 'input-darkmode' : 'input-lightmode']" type="button" id="maintenance-visits" value="Maintenance Visits"> | ||||
|       <input :class="[darkMode ? 'input-darkmode' : 'input-lightmode']" type="button" id="production-orders" value="Production Orders"> | ||||
|       <input :class="[darkMode ? 'input-darkmode' : 'input-lightmode']" type="button" id="maintenance-visits" | ||||
|         value="Maintenance Visits"> | ||||
|       <input :class="[darkMode ? 'input-darkmode' : 'input-lightmode']" type="button" id="production-orders" | ||||
|         value="Production Orders"> | ||||
|       <input :class="[darkMode ? 'input-darkmode' : 'input-lightmode']" type="button" id="issue-slips" value="Assets"> | ||||
|       <input :class="[darkMode ? 'input-darkmode' : 'input-lightmode']" type="button" id="solutions" value="Solutions"> | ||||
|       <input :class="[darkMode ? 'input-darkmode' : 'input-lightmode']" type="button" id="issue-slips" value="Issue Slips"> | ||||
|       <input :class="[darkMode ? 'input-darkmode' : 'input-lightmode']" type="button" id="issue-slips" | ||||
|         value="Issue Slips"> | ||||
|     </div> | ||||
|   </section> | ||||
| </template> | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref('') | ||||
|  | ||||
| const getSession = async () => { | ||||
|   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|   if (loggedInUserDarkModeBool == 1) { | ||||
|     darkMode.value = true; | ||||
|   } else { | ||||
|     darkMode.value = false; | ||||
|   } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|   if (process.client) { | ||||
|     return localStorage.getItem(item) | ||||
|   } else { | ||||
|     return undefined | ||||
|   } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|   await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|   name: "Asset", | ||||
| }; | ||||
| </script>     | ||||
|      | ||||
|      | ||||
| </script> | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .quick-access { | ||||
|   display: flex; | ||||
|  | ||||
| @ -23,12 +23,40 @@ | ||||
|         </table> | ||||
|     </section> | ||||
| </template> | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref('') | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| @ -36,8 +64,8 @@ export default { | ||||
|     name: "CustomerTable", | ||||
| }; | ||||
| </script> | ||||
|    | ||||
|      | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
| @ -94,7 +122,8 @@ export default { | ||||
|     border-top: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| th, td { | ||||
| th, | ||||
| td { | ||||
|     height: 1.875rem; | ||||
|     text-align: left; | ||||
|     padding: 0; | ||||
| @ -102,11 +131,13 @@ th, td { | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .th-darkmode, .td-darkmode { | ||||
| .th-darkmode, | ||||
| .td-darkmode { | ||||
|     color: #ffffff; | ||||
| } | ||||
|  | ||||
| .th-lightmode, .td-lightmode { | ||||
| .th-lightmode, | ||||
| .td-lightmode { | ||||
|     color: #000000; | ||||
| } | ||||
|  | ||||
| @ -128,4 +159,5 @@ th { | ||||
|  | ||||
| .Name { | ||||
|     width: 60%; | ||||
| }</style> | ||||
| } | ||||
| </style> | ||||
| @ -138,12 +138,14 @@ import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenEmployeeId = computed(() => store.state.chosenEmployeeId); | ||||
| const deleteBool = computed(() => store.state.deleteBool); | ||||
| const addBool = computed(() => store.state.new); | ||||
|  | ||||
| const darkMode = ref(true); | ||||
| const darkMode = ref(''); | ||||
| const employee = ref({}); | ||||
|  | ||||
| const newUsername = ref(''); | ||||
| @ -287,8 +289,28 @@ const validatePostcode = (postcode) => { | ||||
|  | ||||
| watch(deleteBool, confirmDeleteEmployee); | ||||
|  | ||||
| onMounted(() => { | ||||
|     getEmployeeById(); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
|     await getEmployeeById(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
|  | ||||
| @ -48,13 +48,15 @@ | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenEmployeeId = computed(() => store.state.chosenEmployeeId); | ||||
| const addBool = computed(() => store.state.new); | ||||
| @ -68,7 +70,7 @@ const newAddressEmp = computed(() => store.state.newAddressEmp); | ||||
| const newCityEmp = computed(() => store.state.newCityEmp); | ||||
| const newPostcodeEmp = computed(() => store.state.newPostcodeEmp); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref('') | ||||
| const employee = ref({}); | ||||
| const adminBoolean = ref(false); | ||||
| const technicianBoolean = ref(false); | ||||
| @ -76,6 +78,7 @@ const readerBoolean = ref(false); | ||||
| const newAdminBool = ref(false); | ||||
| const newTechnicianBool = ref(false); | ||||
| const newReaderBool = ref(false); | ||||
| const newDarkModeBool = ref(false); | ||||
| const employees = ref([]); | ||||
|  | ||||
|  | ||||
| @ -149,6 +152,7 @@ const update = async () => { | ||||
|                 adminBool: employee.value.adminBool, | ||||
|                 technicianBool: employee.value.technicianBool, | ||||
|                 readerBool: employee.value.readerBool, | ||||
|                 darkModeBool: employee.value.darkModeBool, | ||||
|             } | ||||
|         ); | ||||
|     } catch (err) { | ||||
| @ -245,6 +249,7 @@ const addEmployee = async () => { | ||||
|                 adminBool: newAdminBool.value, | ||||
|                 technicianBool: newTechnicianBool.value, | ||||
|                 readerBool: newReaderBool.value, | ||||
|                 darkModeBool: newDarkModeBool.value, | ||||
|             }); | ||||
|         store.commit('resetStore'); | ||||
|         store.commit('changeToEmployeelist'); | ||||
| @ -303,7 +308,27 @@ const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     }, 1000); | ||||
| } | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(() => { | ||||
|     getSession(); | ||||
|     triggerBackendCallsWithDelay(getEmployeeById); | ||||
|     triggerBackendCallsWithDelay(getEmployees); | ||||
| }); | ||||
|  | ||||
| @ -11,12 +11,11 @@ | ||||
|                         Username</th> | ||||
|                     <th :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode']">ID</th> | ||||
|                 </tr> | ||||
|                 <tr v-for="u in userList" :key="u.id" | ||||
|                     :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']"> | ||||
|                 <tr v-for="u in userList" :key="u.id" :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']"> | ||||
|                     <td | ||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         <nuxt-link to="/employees" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||
|                             @click="goToChosenEmployee(u.id)"> | ||||
|                             {{ u.fullName }} | ||||
|                         </nuxt-link> | ||||
| @ -24,7 +23,7 @@ | ||||
|                     <td | ||||
|                         :class="['Username', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Username-darkmode' : 'Username-lightmode']"> | ||||
|                         <nuxt-link to="/employees" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||
|                             @click="goToChosenEmployee(u.id)"> | ||||
|                             {{ u.username }} | ||||
|                         </nuxt-link> | ||||
| @ -45,13 +44,15 @@ import { computed } from 'vue'; | ||||
|  | ||||
| // get accesss to the store | ||||
| const store = useStore() | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const goToChosenEmployee = (id) => { | ||||
|     store.commit('setChosenEmployee', id); | ||||
|     store.commit('changeToEmployee'); | ||||
| }; | ||||
| const employeeFilter = computed(() => store.state.filteredByCustomer); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref('') | ||||
| const userList = ref([]); | ||||
|  | ||||
| //get all users | ||||
| @ -81,7 +82,27 @@ const getFilteredUsersByUser = async () => { | ||||
|  | ||||
| watch(employeeFilter, getEmployees); | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getEmployees(); | ||||
| }); | ||||
| </script> | ||||
| @ -223,6 +244,13 @@ th { | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
| } | ||||
|  | ||||
| .nuxt-link-darkmode { | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .nuxt-link-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -1,7 +1,8 @@ | ||||
| <template> | ||||
|     <section v-if="hardwareBoolean && !addBool" | ||||
|         :class="['hardware-information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'div-darkmode' : 'div-lightmode']" id="hardware">Hardware specifications:</div> | ||||
|         <div :class="['label', darkMode ? 'div-darkmode' : 'div-lightmode']" id="hardware">Hardware specifications: | ||||
|         </div> | ||||
|         <div class="asset-data"> | ||||
|             <div class="model-CPU"> | ||||
|                 <div class="data-field" id="model"> | ||||
| @ -55,7 +56,8 @@ | ||||
|         </div> | ||||
|     </section> | ||||
|     <section v-if="addBool" :class="['hardware-information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'div-darkmode' : 'div-lightmode']" id="hardware">Hardware specifications:</div> | ||||
|         <div :class="['label', darkMode ? 'div-darkmode' : 'div-lightmode']" id="hardware">Hardware specifications: | ||||
|         </div> | ||||
|         <div class="asset-data"> | ||||
|             <div class="model-CPU"> | ||||
|                 <div class="data-field" id="model"> | ||||
| @ -101,16 +103,18 @@ | ||||
|         </div> | ||||
|     </section> | ||||
| </template> | ||||
|      | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenAssetId = computed(() => store.state.chosenAssetId); | ||||
| const addBool = computed(() => store.state.new); | ||||
| @ -123,7 +127,7 @@ const newRAM = ref(''); | ||||
| const newStorageConfiguration = ref(''); | ||||
| const newMiscellaneous = ref(''); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref('') | ||||
| const item = ref({}); | ||||
| const hardwareBoolean = ref(false) | ||||
|  | ||||
| @ -155,7 +159,7 @@ const updateAsset = () => { | ||||
|         RAM: newRAM.value, | ||||
|         storageConfig: newStorageConfiguration.value, | ||||
|         miscellaneous: newMiscellaneous.value, | ||||
|     };  | ||||
|     }; | ||||
|     store.commit('updateHardwareComponent', asset); | ||||
| } | ||||
|  | ||||
| @ -204,8 +208,28 @@ const updateConfigItem = async () => { | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getItemById(); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getItemById(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| @ -213,9 +237,9 @@ onMounted(() => { | ||||
| export default { | ||||
|     name: "HardwareSpecifications", | ||||
| }; | ||||
| </script>    | ||||
| </script> | ||||
|  | ||||
|  | ||||
|        | ||||
| <style scoped> | ||||
| .hardware-information { | ||||
|     display: flex; | ||||
|  | ||||
| @ -38,21 +38,49 @@ | ||||
|         </table> | ||||
|     </div> | ||||
| </template> | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref('') | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|     name: "InstanceChecklist", | ||||
| }; | ||||
| </script>   | ||||
|      | ||||
|      | ||||
|      | ||||
| </script> | ||||
|  | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
|  | ||||
| @ -89,12 +89,14 @@ import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenIssueId = computed(() => store.state.chosenIssueId); | ||||
| const deleteBool = computed(() => store.state.deleteBool); | ||||
| const addBool = computed(() => store.state.new); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
| const issue = ref({}); | ||||
| const issues = ref([]); | ||||
|  | ||||
| @ -207,9 +209,28 @@ const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteIssue); | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(() => { | ||||
|     getIssueById(); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
|     await getIssueById(); | ||||
|     triggerBackendCallsWithDelay(getIssues); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| @ -112,12 +112,14 @@ import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenIssueSlipId = computed(() => store.state.chosenIssueSlipId); | ||||
| const deleteBool = computed(() => store.state.deleteBool); | ||||
| const addBool = computed(() => store.state.new); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
| const issueSlip = ref({}); | ||||
| const customer = ref({}); | ||||
| const productionOrders = ref([]); | ||||
| @ -279,11 +281,30 @@ const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     }, 1500); | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteIssueSlip); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getIssueSlipById(); | ||||
|     getProductionOrders(); | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteIssueSlip); | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getIssueSlipById(); | ||||
|     await getProductionOrders(); | ||||
|     triggerBackendCallsWithDelay(getCustomers); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| @ -32,7 +32,7 @@ | ||||
|                     <td | ||||
|                         :class="['ID', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||
|                         <nuxt-link to="/issueSlips" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||
|                             @click="goToChosenIssueSlip(issueSlip.primaryID)"> | ||||
|                             {{ issueSlip.primaryID }} | ||||
|                         </nuxt-link> | ||||
| @ -60,6 +60,8 @@ import { computed } from 'vue'; | ||||
|  | ||||
| // get accesss to the store | ||||
| const store = useStore() | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const goToChosenIssueSlip = (id) => { | ||||
|     store.commit('setChosenIssueSlip', id); | ||||
|     store.commit('changeToIssueSlip'); | ||||
| @ -69,7 +71,7 @@ const customerFilter = computed(() => store.state.filteredByCustomer); | ||||
| const searchable = computed(() => store.state.searchable); | ||||
|  | ||||
| const issueSlipSearchFilter = ref(''); | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref('') | ||||
| const issueSlips = ref([]); | ||||
|  | ||||
| // update search term | ||||
| @ -119,8 +121,27 @@ const searchIssueSlip = async () => { | ||||
| watch(customerFilter, getIssueSlips); | ||||
| watch(searchable, updateSearchTerm); | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getIssueSlips(); | ||||
| }); | ||||
| </script> | ||||
| @ -154,9 +175,16 @@ export default { | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
| } | ||||
|  | ||||
| .nuxt-link-darkmode { | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .nuxt-link-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .issue-slip-search { | ||||
|     display: flex; | ||||
|     align-items: center; | ||||
|  | ||||
| @ -25,7 +25,7 @@ | ||||
|                     <td | ||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         <nuxt-link to="/issueItems" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||
|                             @click="goToChosenIssue(issue.primaryID)"> | ||||
|                             {{ issue.name }} | ||||
|                         </nuxt-link> | ||||
| @ -53,6 +53,8 @@ import { computed } from 'vue'; | ||||
|  | ||||
| // get accesss to the store | ||||
| const store = useStore() | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const goToChosenIssue = (id) => { | ||||
|     store.commit('setChosenIssue', id); | ||||
|     store.commit('changeToIssueItem'); | ||||
| @ -62,7 +64,7 @@ const stateFilter = computed(() => store.state.filteredByCustomer); | ||||
| const searchable = computed(() => store.state.searchable); | ||||
|  | ||||
| const issueSearchFilter = ref(''); | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
| const issues = ref([]); | ||||
|  | ||||
| // update search term | ||||
| @ -113,7 +115,27 @@ const searchIssue = async () => { | ||||
| watch(stateFilter, getIssues); | ||||
| watch(searchable, updateSearchTerm); | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getIssues(); | ||||
| }); | ||||
| </script> | ||||
| @ -178,9 +200,16 @@ export default { | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
| } | ||||
|  | ||||
| .nuxt-link-darkmode { | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .nuxt-link-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .issue-search { | ||||
|     display: flex; | ||||
|     align-items: center; | ||||
|  | ||||
| @ -8,8 +8,8 @@ | ||||
|             <div class="variantOf"> | ||||
|                 <div class="data-field" id="variantOf"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Variant of:</pre> | ||||
|                     <pre | ||||
|                         :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']"><nuxt-link to="/issueItems" id="nuxt-link" class="button" @click="goToChosenIssue(issue.primaryID)">{{ nameOfVariant }}</nuxt-link></pre> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']"><nuxt-link to="/issueItems" id="nuxt-link" :class="['button', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||
|  @click="goToChosenIssue(issue.primaryID)">{{ nameOfVariant }}</nuxt-link></pre> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="info"> | ||||
| @ -59,6 +59,8 @@ import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenIssueId = computed(() => store.state.chosenIssueId); | ||||
| const chosenIssueVariantId = computed(() => store.state.chosenIssueVariantId); | ||||
| @ -172,11 +174,30 @@ const getIssueById = async () => { | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteIssueVariant); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getIssueVariantById(); | ||||
|     getIssueById(); | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteIssueVariant); | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getIssueVariantById(); | ||||
|     await getIssueById(); | ||||
|     triggerBackendCallsWithDelay(getIssueVariants); | ||||
| }); | ||||
|  | ||||
| @ -378,6 +399,13 @@ export default { | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
| } | ||||
|  | ||||
| .nuxt-link-darkmode { | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .nuxt-link-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
| </style> | ||||
| @ -24,7 +24,7 @@ | ||||
|                     <td v-if="!editable" | ||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         <nuxt-link to="/issueItems" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||
|                             @click="goToChosenIssueVariant(issueVar.primaryID)"> | ||||
|                             {{ issueVar.name }} | ||||
|                         </nuxt-link> | ||||
| @ -185,7 +185,7 @@ const newAmount = computed(() => store.state.newAmountII); | ||||
| const newProperties = computed(() => store.state.newPropertiesII); | ||||
| const chosenIssueId = computed(() => store.state.chosenIssueId); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
| const addRow = ref(false); | ||||
| const issueVariants = ref([]) | ||||
| const issue = ref({}) | ||||
| @ -411,9 +411,27 @@ const getAllIssues = async () => { | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getIssueVariantsById(); | ||||
|     getIssueById(); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getIssueVariantsById(); | ||||
|     await getIssueById(); | ||||
|     triggerBackendCallsWithDelay(getAllIssues); | ||||
| }); | ||||
| </script> | ||||
| @ -739,6 +757,13 @@ th { | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
| } | ||||
|  | ||||
| .nuxt-link-darkmode { | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .nuxt-link-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
| </style> | ||||
| @ -69,12 +69,40 @@ | ||||
|         </div> | ||||
|     </section> | ||||
| </template> | ||||
|      | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref(''); | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| @ -82,8 +110,8 @@ export default { | ||||
|     name: "MaintenanceVisitsInstance", | ||||
| }; | ||||
| </script> | ||||
|        | ||||
|        | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .information { | ||||
|     display: flex; | ||||
|  | ||||
| @ -43,22 +43,50 @@ | ||||
|         </table> | ||||
|     </div> | ||||
| </template> | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref(''); | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|     name: "MaintenanceVisitsInstanceTable", | ||||
| }; | ||||
| </script>   | ||||
|      | ||||
|      | ||||
|      | ||||
| </script> | ||||
|  | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
|  | ||||
| @ -103,12 +103,14 @@ import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenMVTId = computed(() => store.state.chosenMVTId); | ||||
| const deleteBool = computed(() => store.state.deleteBool); | ||||
| const addBool = computed(() => store.state.new); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
| const mvt = ref({}); | ||||
| const customers = ref([]); | ||||
| const customer = ref({}); | ||||
| @ -265,10 +267,29 @@ const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     }, 1500); | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteMVT); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getMVTById(); | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteMVT); | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getMVTById(); | ||||
|     triggerBackendCallsWithDelay(getMaintenanceVisitTemplates); | ||||
|     triggerBackendCallsWithDelay(getCustomers); | ||||
| }); | ||||
|  | ||||
| @ -32,10 +32,11 @@ | ||||
|                     <td | ||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         <nuxt-link to="/maintenanceVisits" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||
|                             @click="goToChosenMVT(template.checklistID)"> | ||||
|                             {{ template.name }} | ||||
|                         </nuxt-link></td> | ||||
|                         </nuxt-link> | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['ID', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||
|                         {{ template.checklistID }}</td> | ||||
| @ -48,8 +49,8 @@ | ||||
|         </table> | ||||
|     </div> | ||||
| </template> | ||||
|    | ||||
|    | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| @ -59,6 +60,8 @@ import { computed } from 'vue'; | ||||
|  | ||||
| // get accesss to the store | ||||
| const store = useStore() | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const goToChosenMVT = (id) => { | ||||
|     store.commit('setChosenMVT', id); | ||||
|     store.commit('changeToTemplate'); | ||||
| @ -68,7 +71,7 @@ const customerFilter = computed(() => store.state.filteredByCustomer); | ||||
| const searchable = computed(() => store.state.searchable); | ||||
| const mvtSearchFilter = ref(''); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
| const maintenanceVisitTemplates = ref([]); | ||||
|  | ||||
| //get all maintenance visit templates | ||||
| @ -115,10 +118,29 @@ const getFilteredMVTByCustomer = async () => { | ||||
|     } | ||||
| } | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(searchable, updateSearchTerm); | ||||
| watch(customerFilter, getMaintenanceVisitTemplates); | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getMaintenanceVisitTemplates(); | ||||
| }); | ||||
| </script> | ||||
| @ -127,10 +149,10 @@ onMounted(async () => { | ||||
| export default { | ||||
|     name: "MaintenanceVisitsTemplateTable", | ||||
| }; | ||||
| </script>   | ||||
|      | ||||
|      | ||||
|      | ||||
| </script> | ||||
|  | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
| @ -176,9 +198,16 @@ export default { | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
| } | ||||
|  | ||||
| .nuxt-link-darkmode { | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .nuxt-link-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .dataInput { | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
|  | ||||
| @ -70,16 +70,18 @@ | ||||
|         <button :class="[darkMode ? 'saveNewItem-darkmode' : 'saveNewItem-lightmode']" @click="addItem()">Save</button> | ||||
|     </section> | ||||
| </template> | ||||
|      | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenAssetId = computed(() => store.state.chosenAssetId); | ||||
| const addBool = computed(() => store.state.new); | ||||
| @ -106,7 +108,7 @@ const newSoftware = computed(() => store.state.newSoftware); | ||||
| const newVersion = computed(() => store.state.newVersion); | ||||
| const newLicense = computed(() => store.state.newLicense); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
| const item = ref({}); | ||||
| const networkBoolean = ref(false); | ||||
| const inputIPv4 = ref(''); | ||||
| @ -356,7 +358,27 @@ const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     }, 1000); | ||||
| } | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(() => { | ||||
|     getSession(); | ||||
|     triggerBackendCallsWithDelay(getItemById); | ||||
|     triggerBackendCallsWithDelay(getConfigItems); | ||||
| }); | ||||
| @ -366,9 +388,9 @@ onMounted(() => { | ||||
| export default { | ||||
|     name: "NetworkSpecifications", | ||||
| }; | ||||
| </script>           | ||||
|        | ||||
|        | ||||
| </script> | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .network-information { | ||||
|     display: flex; | ||||
|  | ||||
| @ -147,6 +147,8 @@ import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const addBool = computed(() => store.state.new); | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenIssueSlipId = computed(() => store.state.chosenIssueSlipId); | ||||
| @ -159,7 +161,7 @@ const newPrice = ref(''); | ||||
| const newComment = ref(''); | ||||
|  | ||||
| const newOIs = reactive([]); | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
|  | ||||
| // delete new todo row | ||||
| const deleteNewRow = () => { | ||||
| @ -274,12 +276,32 @@ const deleteOrderingInfo = async (id) => { | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     }  | ||||
|     } | ||||
|     await getOIById(); | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getOIById(); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getOIById(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
|  | ||||
| @ -19,7 +19,8 @@ | ||||
|             <div class="additional"> | ||||
|                 <div class="templateDescription"> | ||||
|                     <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Template description:</h3> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="templateDescription">...</pre> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" | ||||
|                         id="templateDescription">...</pre> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="additional"> | ||||
| @ -75,21 +76,49 @@ | ||||
|         </div> | ||||
|     </section> | ||||
| </template> | ||||
|      | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref(''); | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|     name: "ProductionOrdersInstance", | ||||
| }; | ||||
| </script>  | ||||
|        | ||||
|        | ||||
| </script> | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .information { | ||||
|     display: flex; | ||||
|  | ||||
| @ -49,21 +49,49 @@ | ||||
|         </table> | ||||
|     </div> | ||||
| </template> | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const darkMode = ref(''); | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|     name: "ProductionOrdersInstanceTable", | ||||
| }; | ||||
| </script>    | ||||
|      | ||||
|      | ||||
| </script> | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
|  | ||||
| @ -109,12 +109,14 @@ import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenPOTId = computed(() => store.state.chosenPOTId); | ||||
| const deleteBool = computed(() => store.state.deleteBool); | ||||
| const addBool = computed(() => store.state.new); | ||||
|  | ||||
| const darkMode = ref(true); | ||||
| const darkMode = ref(''); | ||||
| const pot = ref({}); | ||||
| const customers = ref([]); | ||||
| const customer = ref({}); | ||||
| @ -270,11 +272,30 @@ const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     }, 1500); | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeletePOT); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getPOTById(); | ||||
|     getProductionOrderTemplates(); | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeletePOT); | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getPOTById(); | ||||
|     await getProductionOrderTemplates(); | ||||
|     triggerBackendCallsWithDelay(getCustomers); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| @ -29,7 +29,7 @@ | ||||
|                     <td | ||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         <nuxt-link to="/productionOrders" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||
|                             @click="goToChosenPOT(template.templateID)"> | ||||
|                             {{ template.name }} | ||||
|                         </nuxt-link> | ||||
| @ -43,8 +43,8 @@ | ||||
|         </table> | ||||
|     </div> | ||||
| </template> | ||||
|    | ||||
|    | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| @ -54,6 +54,8 @@ import { computed } from 'vue'; | ||||
|  | ||||
| // get accesss to the store | ||||
| const store = useStore() | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const goToChosenPOT = (id) => { | ||||
|     store.commit('setChosenPOT', id); | ||||
|     store.commit('changeToTemplate'); | ||||
| @ -63,7 +65,7 @@ const customerFilter = computed(() => store.state.filteredByCustomer); | ||||
| const searchable = computed(() => store.state.searchable); | ||||
|  | ||||
| const potSearchFilter = ref(''); | ||||
| const darkMode = ref(true); | ||||
| const darkMode = ref(''); | ||||
| const productionOrderTemplates = ref([]); | ||||
|  | ||||
| //get all productionOrder templates | ||||
| @ -110,10 +112,29 @@ const getFilteredPOTByCustomer = async () => { | ||||
|     } | ||||
| } | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(customerFilter, getProductionOrderTemplates); | ||||
| watch(searchable, updateSearchTerm); | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getProductionOrderTemplates(); | ||||
| }); | ||||
| </script> | ||||
| @ -122,9 +143,9 @@ onMounted(async () => { | ||||
| export default { | ||||
|     name: "ProductionOrdersTemplateTable", | ||||
| }; | ||||
| </script>  | ||||
|      | ||||
|      | ||||
| </script> | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .section-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
| @ -179,9 +200,16 @@ export default { | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
| } | ||||
|  | ||||
| .nuxt-link-darkmode { | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .nuxt-link-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .table-row { | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
|  | ||||
| @ -14,7 +14,8 @@ | ||||
|                                 Version</th> | ||||
|                             <th :class="['License', darkMode ? 'th-darkmode' : 'th-lightmode']">License</th> | ||||
|                         </tr> | ||||
|                         <tr v-if="editable" :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                         <tr v-if="editable" :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" | ||||
|                             id="row-1"> | ||||
|                             <td | ||||
|                                 :class="['Software', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Software-darkmode' : 'Software-lightmode']"> | ||||
|                                 <input type="text" v-model="item.software" @change="updateConfigItem()" | ||||
| @ -30,7 +31,8 @@ | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr v-if="!editable" :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                         <tr v-if="!editable" :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" | ||||
|                             id="row-1"> | ||||
|                             <td | ||||
|                                 :class="['Software', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Software-darkmode' : 'Software-lightmode']"> | ||||
|                                 {{ item.software }}</td> | ||||
| @ -80,15 +82,17 @@ | ||||
|         </div> | ||||
|     </section> | ||||
| </template> | ||||
|      | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenAssetId = computed(() => store.state.chosenAssetId); | ||||
| const addBool = computed(() => store.state.new); | ||||
| @ -98,7 +102,7 @@ const newSoftware = ref(''); | ||||
| const newVersion = ref(''); | ||||
| const newLicense = ref(''); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
| const item = ref({}); | ||||
| const softwareBoolean = ref(false) | ||||
|  | ||||
| @ -176,8 +180,28 @@ const updateConfigItem = async () => { | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getItemById(); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getItemById(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| @ -185,9 +209,9 @@ onMounted(() => { | ||||
| export default { | ||||
|     name: "SoftwareSpecifications", | ||||
| }; | ||||
| </script>       | ||||
|        | ||||
|        | ||||
| </script> | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .software-information { | ||||
|     display: flex; | ||||
|  | ||||
| @ -142,12 +142,14 @@ import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenSolutionId = computed(() => store.state.chosenSolutionId); | ||||
| const deleteBool = computed(() => store.state.deleteBool); | ||||
| const addBool = computed(() => store.state.new); | ||||
|  | ||||
| const darkMode = ref(true); | ||||
| const darkMode = ref(''); | ||||
| const sol = ref({}); | ||||
| const customer = ref({}); | ||||
| const solutions = ref([]); | ||||
| @ -338,12 +340,31 @@ const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     }, 1500); | ||||
| } | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteSolution); | ||||
| watch(customerChanged, getSolutionById); | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(() => { | ||||
|     getSolutionById(); | ||||
|     getSolutions(); | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getSolutionById(); | ||||
|     await getSolutions(); | ||||
|     triggerBackendCallsWithDelay(getCustomers); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| @ -150,6 +150,8 @@ import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const addBool = computed(() => store.state.new); | ||||
| const editable = computed(() => store.state.editable); | ||||
|  | ||||
| @ -168,7 +170,7 @@ const chosenSolId = computed(() => store.state.chosenSolutionId); | ||||
| const customerChanged = computed(() => store.state.customerChanged); | ||||
| const changedCustomerId = computed(() => store.state.changedCustomerId); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
| const addRow = ref(false); | ||||
| const configItemList = ref([]); | ||||
| const solutions = ref([]); | ||||
| @ -419,11 +421,30 @@ const deleteSolTodo = async (id) => { | ||||
|     await getSolutionTodosById(); | ||||
| } | ||||
|  | ||||
| watch(customerChanged, getSolutionById); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getSolutionTodosById(); | ||||
|     getSolutionById(); | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(customerChanged, getSolutionById); | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getSolutionTodosById(); | ||||
|     await getSolutionById(); | ||||
|     triggerBackendCallsWithDelay(getAllSolutions); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| @ -31,7 +31,7 @@ | ||||
|                     <td | ||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         <nuxt-link to="/solutions" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||
|                             @click="goToChosenSolution(sol.primaryID)"> | ||||
|                             {{ sol.solutionName }} | ||||
|                         </nuxt-link> | ||||
| @ -51,7 +51,7 @@ | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js'; | ||||
| import { useStore } from 'vuex'; | ||||
| @ -59,6 +59,8 @@ import { computed } from 'vue'; | ||||
|  | ||||
| // get accesss to the store | ||||
| const store = useStore() | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const goToChosenSolution = (id) => { | ||||
|     store.commit('setChosenSolution', id); | ||||
|     store.commit('changeToSolution'); | ||||
| @ -68,7 +70,7 @@ const customerFilter = computed(() => store.state.filteredByCustomer); | ||||
| const searchable = computed(() => store.state.searchable); | ||||
|  | ||||
| const solutionSearchFilter = ref(''); | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
| const solutions = ref([]); | ||||
|  | ||||
| // update search term | ||||
| @ -115,11 +117,29 @@ const searchSolution = async () => { | ||||
|     } | ||||
| } | ||||
|  | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(customerFilter, getSolutions); | ||||
| watch(searchable, updateSearchTerm); | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getSolutions(); | ||||
| }); | ||||
| </script> | ||||
| @ -256,9 +276,16 @@ th { | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
| } | ||||
|  | ||||
| .nuxt-link-darkmode { | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .nuxt-link-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .customerLabel { | ||||
|     width: 5.5625em; | ||||
|     height: 1.875em; | ||||
|  | ||||
| @ -42,16 +42,18 @@ | ||||
|                         <input type="text" v-model="todo.task" @change="updatePOTTodo(todo)" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> {{ todo.comments | ||||
|                     }}</td> | ||||
|                     <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> <input type="text" | ||||
|                             v-model="todo.comments" @change="updatePOTTodo(todo)" | ||||
|                     <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> {{ | ||||
|         todo.comments | ||||
|     }}</td> | ||||
|                     <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> <input | ||||
|                             type="text" v-model="todo.comments" @change="updatePOTTodo(todo)" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> <button | ||||
|                             :class="[darkMode ? 'deletePOTTodos-darkmode' : 'deletePOTTodos-lightmode']" | ||||
|                             @click="deletePOTTodo(todo.primaryID)">-</button> | ||||
|                     </td> | ||||
|                 </tr> | ||||
|                 <tr v-if="editable && addRow" :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                 <tr v-if="editable && addRow" :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" | ||||
|                     id="row-1"> | ||||
|                     <td | ||||
|                         :class="['Step', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Step-darkmode' : 'Step-lightmode']"> | ||||
|                         {{ newStepTodo }} | ||||
| @ -141,7 +143,7 @@ | ||||
|         <button :class="[darkMode ? 'saveNewPOT-darkmode' : 'saveNewPOT-lightmode']" @click="addPOT()">Save</button> | ||||
|     </section> | ||||
| </template> | ||||
|    | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| @ -151,6 +153,8 @@ import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const addBool = computed(() => store.state.new); | ||||
| const editable = computed(() => store.state.editable); | ||||
|  | ||||
| @ -166,7 +170,7 @@ const chosenPOTId = computed(() => store.state.chosenPOTId); | ||||
| const customerChanged = computed(() => store.state.customerChanged); | ||||
| const changedCustomerId = computed(() => store.state.changedCustomerId); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
| const addRow = ref(false); | ||||
| const configItemList = ref([]); | ||||
| const productionOrderTemplates = ref([]); | ||||
| @ -189,7 +193,7 @@ const deleteNewRow = () => { | ||||
| const deletePOTTodoFromNewTodos = (index) => { | ||||
|     newTodos.splice(index, 1); | ||||
|     newTodos.forEach((todo, i) => { | ||||
|         todo.rowID = i  | ||||
|         todo.rowID = i | ||||
|     }) | ||||
| } | ||||
|  | ||||
| @ -411,15 +415,34 @@ const deletePOTTodo = async (id) => { | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     }  | ||||
|     } | ||||
|     await getPOTTodosById(); | ||||
| } | ||||
|  | ||||
| watch(customerChanged, getPOTById); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getPOTTodosById(); | ||||
|     getPOTById(); | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(customerChanged, getPOTById); | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getPOTTodosById(); | ||||
|     await getPOTById(); | ||||
|     triggerBackendCallsWithDelay(getProductionOrderTemplates); | ||||
| }); | ||||
| </script> | ||||
| @ -428,9 +451,9 @@ onMounted(() => { | ||||
| export default { | ||||
|     name: "TemplateChecklist", | ||||
| }; | ||||
| </script>  | ||||
|    | ||||
|      | ||||
| </script> | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
|  | ||||
| @ -42,16 +42,18 @@ | ||||
|                         <input type="text" v-model="todo.task" @change="updateMVTTodo(todo)" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> {{ todo.commets | ||||
|                     }}</td> | ||||
|                     <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> <input type="text" | ||||
|                             v-model="todo.commets" @change="updateMVTTodo(todo)"  | ||||
|                     <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> {{ | ||||
|         todo.commets | ||||
|     }}</td> | ||||
|                     <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> <input | ||||
|                             type="text" v-model="todo.commets" @change="updateMVTTodo(todo)" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> <button | ||||
|                             :class="[darkMode ? 'deleteMvtTodos-darkmode' : 'deleteMvtTodos-lightmode']" | ||||
|                             @click="deleteMVTTodo(todo.primaryID)">-</button> | ||||
|                     </td> | ||||
|                 </tr> | ||||
|                 <tr v-if="editable && addRow" :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                 <tr v-if="editable && addRow" :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" | ||||
|                     id="row-1"> | ||||
|                     <td | ||||
|                         :class="['Step', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Step-darkmode' : 'Step-lightmode']"> | ||||
|                         {{ newStepTodo }} | ||||
| @ -141,7 +143,7 @@ | ||||
|         <button :class="[darkMode ? 'saveNewMVT-darkmode' : 'saveNewMVT-lightmode']" @click="addMVT()">Save</button> | ||||
|     </section> | ||||
| </template> | ||||
|    | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| @ -153,6 +155,8 @@ import { computed } from 'vue'; | ||||
| // Vue.use(VueInputAutowidth); | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const addBool = computed(() => store.state.new); | ||||
| const editable = computed(() => store.state.editable); | ||||
|  | ||||
| @ -168,7 +172,7 @@ const chosenMVTId = computed(() => store.state.chosenMVTId); | ||||
| const customerChanged = computed(() => store.state.customerChanged); | ||||
| const changedCustomerId = computed(() => store.state.changedCustomerId); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const darkMode = ref(''); | ||||
| const addRow = ref(false); | ||||
| const configItemList = ref([]); | ||||
| const maintenanceVisitTemplates = ref([]); | ||||
| @ -417,11 +421,30 @@ const deleteMVTTodo = async (id) => { | ||||
|     await getMvtTodosById(); | ||||
| } | ||||
|  | ||||
| watch(customerChanged, getMVTById); | ||||
| const getSession = async () => { | ||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool == 1) { | ||||
|         darkMode.value = true; | ||||
|     } else { | ||||
|         darkMode.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getMvtTodosById(); | ||||
|     getMVTById(); | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(customerChanged, getMVTById); | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     getSession(); | ||||
|     await getMvtTodosById(); | ||||
|     await getMVTById(); | ||||
|     triggerBackendCallsWithDelay(getMaintenanceVisitTemplates); | ||||
| }); | ||||
| </script> | ||||
| @ -430,9 +453,9 @@ onMounted(() => { | ||||
| export default { | ||||
|     name: "TemplateChecklist", | ||||
| }; | ||||
| </script>  | ||||
|    | ||||
|      | ||||
| </script> | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
|  | ||||
| @ -1,38 +1,43 @@ | ||||
| <template> | ||||
|     <section :class="['userAccount', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 :class="['heading', darkMode ? 'heading-darkmode' : 'heading-lightmode']">Account:</h2> | ||||
|     <section :class="['userAccount', loggedInUserDarkModeBoolean ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 :class="['heading', loggedInUserDarkModeBoolean ? 'heading-darkmode' : 'heading-lightmode']">Account:</h2> | ||||
|         <div class="userData"> | ||||
|             <div class="username-email"> | ||||
|                 <div class="data-field" id="username"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Username:</pre> | ||||
|                     <pre | ||||
|                         :class="['label', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">Username:</pre> | ||||
|                     <pre v-if="!editable" | ||||
|                         :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ loggedInUserUsername }}</pre> | ||||
|                         :class="['data', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']">{{ loggedInUserUsername }}</pre> | ||||
|                     <input v-if="editable" v-model="loggedInUserUsername" @change="updateUsername()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                         :class="['data', 'input', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                 </div> | ||||
|                 <div class="data-field" id="email"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Email:</pre> | ||||
|                     <pre :class="['label', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">Email:</pre> | ||||
|                     <pre v-if="!editable" | ||||
|                         :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ loggedInUserEmail }}</pre> | ||||
|                         :class="['data', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']">{{ loggedInUserEmail }}</pre> | ||||
|                     <input v-if="editable" v-model="loggedInUserEmail" @change="updateUser()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                         :class="['data', 'input', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                 </div> | ||||
|                 <input v-if="editable" :class="[darkMode ? 'input-darkmode' : '', !darkMode ? 'input-lightmode' : '',]" | ||||
|                 <input v-if="editable" | ||||
|                     :class="[loggedInUserDarkModeBoolean ? 'input-darkmode' : '', !loggedInUserDarkModeBoolean ? 'input-lightmode' : '',]" | ||||
|                     type="button" id="changePassword" value="Change Password" @click="changePassword"> | ||||
|             </div> | ||||
|             <div v-if="changePasswordBool && editable" class="password"> | ||||
|                 <div class="data-field" id="password"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">New Password:</pre> | ||||
|                     <pre | ||||
|                         :class="['label', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">New Password:</pre> | ||||
|                     <input v-if="editable" v-model="loggedInUserNewPassword" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                         :class="['data', 'input', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                 </div> | ||||
|                 <div class="data-field" id="passwordRepeated"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Repeat:</pre> | ||||
|                     <pre | ||||
|                         :class="['label', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">Repeat:</pre> | ||||
|                     <input v-if="editable" v-model="loggedInUserNewPasswordRepeated" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                         :class="['data', 'input', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                 </div> | ||||
|                 <input :class="[darkMode ? 'input-darkmode' : '', !darkMode ? 'input-lightmode' : '',]" type="button" | ||||
|                     id="savePassword" value="Save Password" @click="savePassword"> | ||||
|                 <input | ||||
|                     :class="[loggedInUserDarkModeBoolean ? 'input-darkmode' : '', !loggedInUserDarkModeBoolean ? 'input-lightmode' : '',]" | ||||
|                     type="button" id="savePassword" value="Save Password" @click="savePassword"> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
| @ -40,13 +45,15 @@ | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const changePasswordBool = ref(false); | ||||
|  | ||||
| @ -65,10 +72,10 @@ const loggedInUserTechnicianBool = ref(''); | ||||
| const loggedInUserReaderBool = ref(''); | ||||
| const loggedInUserNewPassword = ref(''); | ||||
| const loggedInUserNewPasswordRepeated = ref(''); | ||||
| const loggedInUserDarkModeBool = ref(''); | ||||
| const loggedInUserDarkModeBoolean = ref(''); | ||||
| const employees = ref([]); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| const changePassword = () => { | ||||
|     changePasswordBool.value = !changePasswordBool.value | ||||
|     loggedInUserNewPassword.value = ''; | ||||
| @ -116,6 +123,12 @@ const getSession = async () => { | ||||
|     loggedInUserAdminBool.value = getItem('logged-in-user-adminBool'); | ||||
|     loggedInUserTechnicianBool.value = getItem('logged-in-user-technicianBool'); | ||||
|     loggedInUserReaderBool.value = getItem('logged-in-user-readerBool'); | ||||
|     loggedInUserDarkModeBool.value = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool.value == 1) { | ||||
|         loggedInUserDarkModeBoolean.value = true; | ||||
|     } else { | ||||
|         loggedInUserDarkModeBoolean.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
| @ -175,6 +188,7 @@ const updateUser = async () => { | ||||
|                 adminBool: loggedInUserAdminBool.value, | ||||
|                 technicianBool: loggedInUserTechnicianBool.value, | ||||
|                 readerBool: loggedInUserReaderBool.value, | ||||
|                 darkModeBool: loggedInUserDarkModeBoolean.value, | ||||
|             } | ||||
|         ) | ||||
|         setItem('logged-in-user-username', loggedInUserUsername.value) | ||||
| @ -184,8 +198,15 @@ const updateUser = async () => { | ||||
|         setItem('logged-in-user-address', loggedInUserAddress.value) | ||||
|         setItem('logged-in-user-city', loggedInUserCity.value) | ||||
|         setItem('logged-in-user-postcode', loggedInUserPostcode.value) | ||||
|         if (loggedInUserDarkModeBoolean.value) { | ||||
|             loggedInUserDarkModeBool.value = 1; | ||||
|         } else { | ||||
|             loggedInUserDarkModeBool.value = 0; | ||||
|         } | ||||
|         setItem('logged-in-user-darkMode', loggedInUserDarkModeBool.value) | ||||
|         getSession(); | ||||
|         store.commit('setLocalStorageChanged'); | ||||
|         store.commit('toggleUpdateDarkMode'); | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| @ -226,6 +247,8 @@ const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     }, 1000); | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
|     await triggerBackendCallsWithDelay(getEmployees); | ||||
|  | ||||
| @ -1,36 +1,142 @@ | ||||
| <template> | ||||
|     <section :class="['userAppearance', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|     <section :class="['userAppearance', loggedInUserDarkModeBoolean ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div class="userData"> | ||||
|             <div class="data-field" id="mode"> | ||||
|                 <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Mode:</pre> | ||||
|                 <pre :class="['smallLabel', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Lightmode</pre> | ||||
|                 <Toggle v-model="darkMode" id="toggleAppearance" /> | ||||
|                 <pre :class="['smallLabel', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Darkmode</pre> | ||||
|                 <pre :class="['label', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">Mode:</pre> | ||||
|                 <pre | ||||
|                     :class="['smallLabel', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">Lightmode</pre> | ||||
|                 <Toggle v-model="loggedInUserDarkModeBoolean" id="toggleAppearance" /> | ||||
|                 <pre | ||||
|                     :class="['smallLabel', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">Darkmode</pre> | ||||
|             </div> | ||||
|             <div class="data-field" id="language"> | ||||
|                 <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Language:</pre> | ||||
|                 <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                 <pre :class="['label', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">Language:</pre> | ||||
|                 <pre :class="['data', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
| </template> | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import Toggle from '@vueform/toggle' | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Toggle from '@vueform/toggle'; | ||||
| import { useStore } from 'vuex'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js' | ||||
|  | ||||
| const store = useStore(); | ||||
|  | ||||
| const loggedInUserId = ref(''); | ||||
| const loggedInUserUsername = ref(''); | ||||
| const loggedInUserRegistered = ref(''); | ||||
| const loggedInUserLastLogin = ref(''); | ||||
| const loggedInUserFullName = ref(''); | ||||
| const loggedInUserEmail = ref(''); | ||||
| const loggedInUserPhonenumber = ref(''); | ||||
| const loggedInUserAddress = ref(''); | ||||
| const loggedInUserCity = ref(''); | ||||
| const loggedInUserPostcode = ref(''); | ||||
| const loggedInUserAdminBool = ref(''); | ||||
| const loggedInUserTechnicianBool = ref(''); | ||||
| const loggedInUserReaderBool = ref(''); | ||||
| const loggedInUserDarkModeBool = ref(''); | ||||
| const loggedInUserDarkModeBoolean = ref(true); | ||||
|  | ||||
| function setItem(item, value) { | ||||
|     if (process.client) { | ||||
|         localStorage.setItem(item, value) | ||||
|         return true | ||||
|     } else { | ||||
|         return false | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
|         return localStorage.getItem(item) | ||||
|     } else { | ||||
|         return undefined | ||||
|     } | ||||
| } | ||||
|  | ||||
| //update data | ||||
| const updateUser = async () => { | ||||
|     try { | ||||
|         await Axios.put( | ||||
|             `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateEmployee`, | ||||
|             { | ||||
|                 id: loggedInUserId.value, | ||||
|                 username: loggedInUserUsername.value, | ||||
|                 fullName: loggedInUserFullName.value, | ||||
|                 email: loggedInUserEmail.value, | ||||
|                 phonenumber: loggedInUserPhonenumber.value, | ||||
|                 address: loggedInUserAddress.value, | ||||
|                 city: loggedInUserCity.value, | ||||
|                 postcode: loggedInUserPostcode.value, | ||||
|                 adminBool: loggedInUserAdminBool.value, | ||||
|                 technicianBool: loggedInUserTechnicianBool.value, | ||||
|                 readerBool: loggedInUserReaderBool.value, | ||||
|                 darkModeBool: loggedInUserDarkModeBoolean.value, | ||||
|             } | ||||
|         ) | ||||
|         setItem('logged-in-user-username', loggedInUserUsername.value) | ||||
|         setItem('logged-in-user-fullName', loggedInUserFullName.value) | ||||
|         setItem('logged-in-user-email', loggedInUserEmail.value) | ||||
|         setItem('logged-in-user-phonenumber', loggedInUserPhonenumber.value) | ||||
|         setItem('logged-in-user-address', loggedInUserAddress.value) | ||||
|         setItem('logged-in-user-city', loggedInUserCity.value) | ||||
|         setItem('logged-in-user-postcode', loggedInUserPostcode.value) | ||||
|         if (loggedInUserDarkModeBoolean.value) { | ||||
|             loggedInUserDarkModeBool.value = 1; | ||||
|         } else { | ||||
|             loggedInUserDarkModeBool.value = 0; | ||||
|         } | ||||
|         setItem('logged-in-user-darkMode', loggedInUserDarkModeBool.value) | ||||
|         getSession(); | ||||
|         store.commit('setLocalStorageChanged'); | ||||
|         store.commit('toggleUpdateDarkMode'); | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| const getSession = async () => { | ||||
|     loggedInUserId.value = getItem('logged-in-user-id'); | ||||
|     loggedInUserUsername.value = getItem('logged-in-user-username'); | ||||
|     loggedInUserRegistered.value = getItem('logged-in-user-registered'); | ||||
|     loggedInUserLastLogin.value = getItem('logged-in-user-lastLogin'); | ||||
|     loggedInUserFullName.value = getItem('logged-in-user-fullName'); | ||||
|     loggedInUserEmail.value = getItem('logged-in-user-email'); | ||||
|     loggedInUserPhonenumber.value = getItem('logged-in-user-phonenumber'); | ||||
|     loggedInUserAddress.value = getItem('logged-in-user-address'); | ||||
|     loggedInUserCity.value = getItem('logged-in-user-city'); | ||||
|     loggedInUserPostcode.value = getItem('logged-in-user-postcode'); | ||||
|     loggedInUserAdminBool.value = getItem('logged-in-user-adminBool'); | ||||
|     loggedInUserTechnicianBool.value = getItem('logged-in-user-technicianBool'); | ||||
|     loggedInUserReaderBool.value = getItem('logged-in-user-readerBool'); | ||||
|     loggedInUserDarkModeBool.value = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool.value == 1) { | ||||
|         loggedInUserDarkModeBoolean.value = true; | ||||
|     } else { | ||||
|         loggedInUserDarkModeBoolean.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(loggedInUserDarkModeBoolean, updateUser) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
| }); | ||||
| </script> | ||||
|    | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|     name: "UserAppearance", | ||||
| }; | ||||
| </script>  | ||||
|      | ||||
| <style src="@vueform/toggle/themes/default.css"></style>    | ||||
|      | ||||
| </script> | ||||
|  | ||||
| <style src="@vueform/toggle/themes/default.css"></style> | ||||
|  | ||||
| <style scoped> | ||||
| .userAppearance { | ||||
|     display: flex; | ||||
|  | ||||
| @ -1,60 +1,68 @@ | ||||
| <template> | ||||
|     <section :class="['userProfile', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 :class="['heading', darkMode ? 'heading-darkmode' : 'heading-lightmode']">Profile:</h2> | ||||
|     <section :class="['userProfile', loggedInUserDarkModeBoolean ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 :class="['heading', loggedInUserDarkModeBoolean ? 'heading-darkmode' : 'heading-lightmode']">Profile:</h2> | ||||
|         <div class="userData"> | ||||
|             <div class="rectangle-container"> | ||||
|                 <div :class="['rectangle', darkMode ? 'rectangle-darkmode' : 'rectangle-lightmode']"></div> | ||||
|                 <div :class="['rectangle', loggedInUserDarkModeBoolean ? 'rectangle-darkmode' : 'rectangle-lightmode']"> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="fullname-registered-lastLogin"> | ||||
|                 <div class="data-field" id="fullName"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Full name:</pre> | ||||
|                     <pre | ||||
|                         :class="['label', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">Full name:</pre> | ||||
|                     <pre v-if="!editable" | ||||
|                         :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ loggedInUserFullName }}</pre> | ||||
|                         :class="['data', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']">{{ loggedInUserFullName }}</pre> | ||||
|                     <input v-if="editable" v-model="loggedInUserFullName" @change="updateUser()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                         :class="['data', 'input', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                 </div> | ||||
|                 <div class="data-field" id="registered"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Registered:</pre> | ||||
|                     <pre | ||||
|                         :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']"> {{ loggedInUserRegistered }}</pre> | ||||
|                         :class="['label', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">Registered:</pre> | ||||
|                     <pre | ||||
|                         :class="['data', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']"> {{ loggedInUserRegistered }}</pre> | ||||
|                 </div> | ||||
|                 <div class="data-field" id="lastLogin"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Last login:</pre> | ||||
|                     <pre | ||||
|                         :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']"> {{ loggedInUserLastLogin }}</pre> | ||||
|                         :class="['label', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">Last login:</pre> | ||||
|                     <pre | ||||
|                         :class="['data', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']"> {{ loggedInUserLastLogin }}</pre> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="info"> | ||||
|                 <div class="city-phonenumber"> | ||||
|                     <div class="data-field" id="city"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">City:</pre> | ||||
|                         <pre | ||||
|                             :class="['label', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">City:</pre> | ||||
|                         <pre v-if="!editable" | ||||
|                             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ loggedInUserCity }}</pre> | ||||
|                             :class="['data', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']">{{ loggedInUserCity }}</pre> | ||||
|                         <input v-if="editable" v-model="loggedInUserCity" @change="updateUser()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             :class="['data', 'input', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                     <div class="data-field" id="phonenumber"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Phonenumber:</pre> | ||||
|                         <pre | ||||
|                             :class="['label', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">Phonenumber:</pre> | ||||
|                         <pre v-if="!editable" | ||||
|                             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ loggedInUserPhonenumber }}</pre> | ||||
|                             :class="['data', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']">{{ loggedInUserPhonenumber }}</pre> | ||||
|                         <input v-if="editable" v-model="loggedInUserPhonenumber" @change="updateUser()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             :class="['data', 'input', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                 </div> | ||||
|                 <div class="postcode-address"> | ||||
|                     <div class="data-field" id="postcode"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Postcode:</pre> | ||||
|                         <pre | ||||
|                             :class="['label', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">Postcode:</pre> | ||||
|                         <pre v-if="!editable" | ||||
|                             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ loggedInUserPostcode }}</pre> | ||||
|                             :class="['data', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']">{{ loggedInUserPostcode }}</pre> | ||||
|                         <input v-if="editable" v-model="loggedInUserPostcode" @change="updateUser()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             :class="['data', 'input', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                     <div class="data-field" id="address"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Address:</pre> | ||||
|                         <pre | ||||
|                             :class="['label', loggedInUserDarkModeBoolean ? 'pre-darkmode' : 'pre-lightmode']">Address:</pre> | ||||
|                         <pre v-if="!editable" | ||||
|                             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ loggedInUserAddress }}</pre> | ||||
|                             :class="['data', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']">{{ loggedInUserAddress }}</pre> | ||||
|                         <input v-if="editable" v-model="loggedInUserAddress" @change="updateUser()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             :class="['data', 'input', loggedInUserDarkModeBoolean ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </div> | ||||
| @ -64,13 +72,15 @@ | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import { ref, watch, onMounted } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const modeChanged = computed(() => store.state.updateDarkMode); | ||||
|  | ||||
| const editable = computed(() => store.state.editable); | ||||
| const loggedInUserId = ref(''); | ||||
| const loggedInUserUsername = ref(''); | ||||
| @ -85,6 +95,8 @@ const loggedInUserPostcode = ref(''); | ||||
| const loggedInUserAdminBool = ref(''); | ||||
| const loggedInUserTechnicianBool = ref(''); | ||||
| const loggedInUserReaderBool = ref(''); | ||||
| const loggedInUserDarkModeBool = ref(''); | ||||
| const loggedInUserDarkModeBoolean = ref(''); | ||||
|  | ||||
| function getItem(item) { | ||||
|     if (process.client) { | ||||
| @ -108,23 +120,27 @@ const getSession = async () => { | ||||
|     loggedInUserAdminBool.value = getItem('logged-in-user-adminBool'); | ||||
|     loggedInUserTechnicianBool.value = getItem('logged-in-user-technicianBool'); | ||||
|     loggedInUserReaderBool.value = getItem('logged-in-user-readerBool'); | ||||
|     loggedInUserDarkModeBool.value = getItem('logged-in-user-darkMode'); | ||||
|     if (loggedInUserDarkModeBool.value == 1) { | ||||
|         loggedInUserDarkModeBoolean.value = true; | ||||
|     } else { | ||||
|         loggedInUserDarkModeBoolean.value = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| //update data | ||||
| const updateUser = async () => { | ||||
|     if (loggedInUserFullName.value.length === 0) { | ||||
|     if (loggedInUserFullName.value.length == 0) { | ||||
|         alert("Please add a valid name!"); | ||||
|         loggedInUserFullName.value = getItem('logged-in-user-fullName'); | ||||
|         return; | ||||
|     } | ||||
|     if (loggedInUserCity.value.length === 0) { | ||||
|     if (loggedInUserCity.value.length == 0) { | ||||
|         alert("Please add a city!"); | ||||
|         loggedInUserCity.value = getItem('logged-in-user-city'); | ||||
|         return; | ||||
|     } | ||||
|     if (loggedInUserAddress.value.length === 0) { | ||||
|     if (loggedInUserAddress.value.length == 0) { | ||||
|         alert("Please add an address!"); | ||||
|         loggedInUserAddress.value = getItem('logged-in-user-address'); | ||||
|         return; | ||||
| @ -139,7 +155,7 @@ const updateUser = async () => { | ||||
|         loggedInUserPostcode.value = getItem('logged-in-user-postcode'); | ||||
|         return; | ||||
|     } | ||||
|     if ((loggedInUserPhonenumber.value.length === 0) && (loggedInUserEmail.value.length === 0)) { | ||||
|     if ((loggedInUserPhonenumber.value.length == 0) && (loggedInUserEmail.value.length == 0)) { | ||||
|         alert("Please add a phonenumber or an email!"); | ||||
|         loggedInUserPhonenumber.value = getItem('logged-in-user-phonenumber'); | ||||
|         loggedInUserEmail.value = getItem('logged-in-user-email') | ||||
| @ -160,6 +176,7 @@ const updateUser = async () => { | ||||
|                 adminBool: loggedInUserAdminBool.value, | ||||
|                 technicianBool: loggedInUserTechnicianBool.value, | ||||
|                 readerBool: loggedInUserReaderBool.value, | ||||
|                 darkModeBool: loggedInUserDarkModeBoolean.value, | ||||
|             } | ||||
|         ) | ||||
|         setItem('logged-in-user-username', loggedInUserUsername.value) | ||||
| @ -169,6 +186,12 @@ const updateUser = async () => { | ||||
|         setItem('logged-in-user-address', loggedInUserAddress.value) | ||||
|         setItem('logged-in-user-city', loggedInUserCity.value) | ||||
|         setItem('logged-in-user-postcode', loggedInUserPostcode.value) | ||||
|         if (loggedInUserDarkModeBoolean.value) { | ||||
|             loggedInUserDarkModeBool.value = 1; | ||||
|         } else { | ||||
|             loggedInUserDarkModeBool.value = 0; | ||||
|         } | ||||
|         setItem('logged-in-user-darkMode', loggedInUserDarkModeBool.value) | ||||
|         getSession(); | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
| @ -176,12 +199,12 @@ const updateUser = async () => { | ||||
| } | ||||
|  | ||||
| function setItem(item, value) { | ||||
|   if (process.client) { | ||||
|     localStorage.setItem(item, value) | ||||
|     return true | ||||
|   } else { | ||||
|     return false | ||||
|   } | ||||
|     if (process.client) { | ||||
|         localStorage.setItem(item, value) | ||||
|         return true | ||||
|     } else { | ||||
|         return false | ||||
|     } | ||||
| } | ||||
|  | ||||
| // to validate the phonenumber | ||||
| @ -208,6 +231,8 @@ const validatePostcode = (postcode) => { | ||||
|     return postcodeRegex.test(postcode); | ||||
| } | ||||
|  | ||||
| watch(modeChanged, getSession) | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSession(); | ||||
| }); | ||||
|  | ||||
		Reference in New Issue
	
	Block a user