123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- <!-- Copyright (C) 2012-2024 Zammad Foundation, https://zammad-foundation.org/ -->
- <script setup lang="ts">
- import { storeToRefs } from 'pinia'
- import { computed, ref } from 'vue'
- import CommonPopoverMenuItem, {
- type Props,
- } from '#desktop/components/CommonPopoverMenu/CommonPopoverMenuItem.vue'
- import ThemeSwitch from '#desktop/components/ThemeSwitch/ThemeSwitch.vue'
- import type { ThemeSwitchInstance } from '#desktop/components/ThemeSwitch/types.ts'
- import { useThemeStore } from '#desktop/stores/theme.ts'
- defineProps<Props>()
- const themeSwitch = ref<ThemeSwitchInstance>()
- const cycleThemeSwitchValue = () => {
- themeSwitch.value?.cycleValue()
- }
- const themeStore = useThemeStore()
- const { updateTheme } = themeStore
- const { currentTheme } = storeToRefs(themeStore)
- const modelTheme = computed({
- get: () => currentTheme.value,
- set: (theme) => updateTheme(theme),
- })
- </script>
- <template>
- <CommonPopoverMenuItem
- v-bind="{ ...$props, ...$attrs }"
- @click="cycleThemeSwitchValue"
- />
- <div class="flex items-center px-2">
- <ThemeSwitch
- ref="themeSwitch"
- v-model="modelTheme"
- class="hover:outline-blue-300 focus:outline-blue-600 hover:focus:outline-blue-600 dark:hover:outline-blue-950 dark:focus:outline-blue-900 dark:hover:focus:outline-blue-900"
- size="small"
- />
- </div>
- </template>
|