implemented mode change
This commit is contained in:
		| @ -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; | ||||
|  | ||||
		Reference in New Issue
	
	Block a user