mirror of
				https://github.com/woodpecker-ci/woodpecker.git
				synced 2025-10-22 05:09:46 +00:00 
			
		
		
		
	Update theme on system color mode change (#3296)
Currently, when theme `auto` is set and the system theme changes, users need to reload the site themselves. This PR adds an even listener which listens for such changes and reloads the theme automatically in the background. --------- Co-authored-by: Anbraten <anton@ju60.de>
This commit is contained in:
		| @@ -1,7 +1,11 @@ | |||||||
| import { useColorMode } from '@vueuse/core'; | import { useColorMode } from '@vueuse/core'; | ||||||
| import { watch } from 'vue'; | import { watch } from 'vue'; | ||||||
|  |  | ||||||
| const { store: storeTheme, state: resolvedTheme } = useColorMode({ | const { | ||||||
|  |   store: storeTheme, | ||||||
|  |   state: resolvedTheme, | ||||||
|  |   system: systemTheme, | ||||||
|  | } = useColorMode({ | ||||||
|   storageKey: 'woodpecker:theme', |   storageKey: 'woodpecker:theme', | ||||||
| }); | }); | ||||||
|  |  | ||||||
| @@ -19,9 +23,7 @@ function updateTheme() { | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| watch(storeTheme, updateTheme); | watch([storeTheme, systemTheme], updateTheme, { immediate: true }); | ||||||
|  |  | ||||||
| updateTheme(); |  | ||||||
|  |  | ||||||
| export function useTheme() { | export function useTheme() { | ||||||
|   return { |   return { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user