Close #99: Implement dark theme
This commit is contained in:
		| @ -1,10 +1,10 @@ | ||||
| <template> | ||||
|   <div class="mt-3 flex"> | ||||
|     <div class="flex-1"> | ||||
|       <button v-if="currentPage < 5" @click="nextPage" class="bg-gray-100 hover:bg-gray-200 px-2 rounded border-gray-200 border font-mono text-gray-500"><</button> | ||||
|       <button v-if="currentPage < 5" @click="nextPage" class="bg-gray-100 hover:bg-gray-200 text-gray-500 border border-gray-200 px-2 rounded font-mono dark:bg-gray-700 dark:text-gray-200 dark:border-gray-500 dark:hover:bg-gray-600"><</button> | ||||
|     </div> | ||||
|     <div class="flex-1 text-right"> | ||||
|       <button v-if="currentPage > 1" @click="previousPage" class="bg-gray-100 hover:bg-gray-200 px-2 rounded border-gray-200 border font-mono text-gray-500">></button> | ||||
|       <button v-if="currentPage > 1" @click="previousPage" class="bg-gray-100 hover:bg-gray-200 text-gray-500 border border-gray-200 px-2 rounded font-mono dark:bg-gray-700 dark:text-gray-200 dark:border-gray-500 dark:hover:bg-gray-600">></button> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| @ -1,8 +1,8 @@ | ||||
| <template> | ||||
|   <div class='service px-3 py-3 border-l border-r border-t rounded-none hover:bg-gray-100' v-if="data"> | ||||
|   <div class='service px-3 py-3 border-l border-r border-t rounded-none hover:bg-gray-100 dark:hover:bg-gray-700 dark:border-gray-500' v-if="data"> | ||||
|     <div class='flex flex-wrap mb-2'> | ||||
|       <div class='w-3/4'> | ||||
|         <router-link :to="generatePath()" class="font-bold hover:text-blue-800 hover:underline" title="View detailed service health"> | ||||
|         <router-link :to="generatePath()" class="font-bold hover:text-blue-800 hover:underline dark:hover:text-blue-400" title="View detailed service health"> | ||||
|           {{ data.name }} | ||||
|         </router-link> | ||||
|         <span v-if="data.results && data.results.length" class='text-gray-500 font-light'> | {{ data.results[data.results.length - 1].hostname }}</span> | ||||
| @ -132,8 +132,6 @@ export default { | ||||
|   border-bottom-left-radius: 3px; | ||||
|   border-bottom-right-radius: 3px; | ||||
|   border-bottom-width: 3px; | ||||
|   border-color: #dee2e6; | ||||
|   border-style: solid; | ||||
| } | ||||
|  | ||||
| .status-over-time { | ||||
|  | ||||
| @ -1,8 +1,8 @@ | ||||
| <template> | ||||
|   <div :class="services.length === 0 ? 'mt-3' : 'mt-4'"> | ||||
|     <slot v-if="name !== 'undefined'"> | ||||
|       <div class="service-group pt-2 border" @click="toggleGroup"> | ||||
|         <h5 class='font-mono text-gray-400 text-xl font-medium pb-2 px-3'> | ||||
|       <div class="service-group pt-2 border dark:bg-gray-800 dark:border-gray-500" @click="toggleGroup"> | ||||
|         <h5 class='font-mono text-gray-400 text-xl font-medium pb-2 px-3 dark:text-gray-200 dark:hover:text-gray-500 dark:border-gray-500'> | ||||
|           <span v-if="healthy" class='text-green-600'>✓</span> | ||||
|           <span v-else class='text-yellow-400'>~</span> | ||||
|           {{ name }} | ||||
| @ -96,6 +96,6 @@ export default { | ||||
| } | ||||
|  | ||||
| .service-group h5:hover { | ||||
|   color: #1b1e21 !important; | ||||
|   color: #1b1e21; | ||||
| } | ||||
| </style> | ||||
| @ -1,17 +1,23 @@ | ||||
| <template> | ||||
|   <div id="settings"> | ||||
|     <div class="flex bg-gray-200 rounded border border-gray-300 shadow"> | ||||
|       <div class="text-sm text-gray-600 rounded-xl py-1 px-2"> | ||||
|         ↻ | ||||
|     <div class="flex"> | ||||
|       <div class="flex bg-gray-200 border-gray-300 rounded border shadow dark:text-gray-200 dark:bg-gray-800 dark:border-gray-500"> | ||||
|         <div class="text-xs text-gray-600 rounded-xl py-1 px-2 dark:text-gray-200"> | ||||
|           ↻ | ||||
|         </div> | ||||
|         <select class="text-center text-gray-500 text-xs dark:text-gray-200 dark:bg-gray-800 border-r border-l border-gray-300 dark:border-gray-500" id="refresh-rate" ref="refreshInterval" @change="handleChangeRefreshInterval"> | ||||
|           <option value="10" :selected="refreshInterval === 10">10s</option> | ||||
|           <option value="30" :selected="refreshInterval === 30">30s</option> | ||||
|           <option value="60" :selected="refreshInterval === 60">1m</option> | ||||
|           <option value="120" :selected="refreshInterval === 120">2m</option> | ||||
|           <option value="300" :selected="refreshInterval === 300">5m</option> | ||||
|           <option value="600" :selected="refreshInterval === 600">10m</option> | ||||
|         </select> | ||||
|         <button @click="toggleDarkMode" class="text-xs p-1"> | ||||
|           <slot v-if="darkMode">☀</slot> | ||||
|           <slot v-else>🌙</slot> | ||||
|         </button> | ||||
|       </div> | ||||
|       <select class="text-center text-gray-500 text-sm" id="refresh-rate" ref="refreshInterval" @change="handleChangeRefreshInterval"> | ||||
|         <option value="10" :selected="refreshInterval === 10">10s</option> | ||||
|         <option value="30" :selected="refreshInterval === 30">30s</option> | ||||
|         <option value="60" :selected="refreshInterval === 60">1m</option> | ||||
|         <option value="120" :selected="refreshInterval === 120">2m</option> | ||||
|         <option value="300" :selected="refreshInterval === 300">5m</option> | ||||
|         <option value="600" :selected="refreshInterval === 600">10m</option> | ||||
|       </select> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
| @ -36,6 +42,24 @@ export default { | ||||
|       this.refreshData(); | ||||
|       clearInterval(this.refreshIntervalHandler); | ||||
|       this.setRefreshInterval(this.$refs.refreshInterval.value); | ||||
|     }, | ||||
|     toggleDarkMode() { | ||||
|       if (localStorage.theme === 'dark') { | ||||
|         localStorage.theme = 'light'; | ||||
|       } else { | ||||
|         localStorage.theme = 'dark'; | ||||
|       } | ||||
|       this.applyTheme(); | ||||
|     }, | ||||
|     applyTheme() { | ||||
|       console.log(localStorage.theme, 'theme' in localStorage); | ||||
|       if (localStorage.theme === 'dark' || (!('theme' in localStorage) && window.matchMedia('(prefers-color-scheme: dark)').matches)) { | ||||
|         this.darkMode = true; | ||||
|         document.documentElement.classList.add('dark'); | ||||
|       } else { | ||||
|         this.darkMode = false; | ||||
|         document.documentElement.classList.remove('dark'); | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   created() { | ||||
| @ -43,6 +67,8 @@ export default { | ||||
|       this.refreshInterval = 60; | ||||
|     } | ||||
|     this.setRefreshInterval(this.refreshInterval); | ||||
|     // dark mode | ||||
|     this.applyTheme(); | ||||
|   }, | ||||
|   unmounted() { | ||||
|     clearInterval(this.refreshIntervalHandler); | ||||
| @ -51,6 +77,7 @@ export default { | ||||
|     return { | ||||
|       refreshInterval: sessionStorage.getItem('gatus:refresh-interval') < 10 ? 60 : parseInt(sessionStorage.getItem('gatus:refresh-interval')), | ||||
|       refreshIntervalHandler: 0, | ||||
|       darkMode: false | ||||
|     } | ||||
|   }, | ||||
| } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user