Skip to content

Commit

Permalink
Use computed props from useDarkMode
Browse files Browse the repository at this point in the history
  • Loading branch information
dhruvkb committed Sep 3, 2024
1 parent 4eafee9 commit 6dc18b5
Showing 1 changed file with 7 additions and 31 deletions.
38 changes: 7 additions & 31 deletions frontend/src/components/VThemeSelect/VThemeSelect.vue
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,9 @@ light, dark and system.
-->

<script setup lang="ts">
import { useI18n } from "#imports"
import { useI18n, useDarkMode } from "#imports"

import { computed, type ComputedRef } from "vue"
import { usePreferredColorScheme } from "@vueuse/core"

import { useUiStore } from "~/stores/ui"

Expand All @@ -16,15 +15,6 @@ import VSelectField, {
type Choice,
} from "~/components/VSelectField/VSelectField.vue"

/**
* `ActualColorMode` is the evaluated form of `ColorMode`.
*
* It's value is the same as `ColorMode` for light and dark color modes
* but for the system color mode, it evaluates to either depending on
* the user's system theme.
*/
type ActualColorMode = "light" | "dark"

const i18n = useI18n({ useScope: "global" })
const uiStore = useUiStore()

Expand All @@ -45,37 +35,23 @@ const colorMode = computed({
},
})

/**
* Get the user's preferred color scheme at the OS level. If the user
* has not set an OS level preference, we fall back to light mode.
*/
const preferredColorScheme: ComputedRef<ActualColorMode> = computed(() => {
const pref = usePreferredColorScheme()
return pref.value === "no-preference" ? "light" : pref.value
})

/**
* Get the user's preferred color scheme at the app level. If the user
* has set the color mode to "system", we fall back to the OS level
* preference.
*/
const actualColorMode: ComputedRef<ActualColorMode> = computed(() =>
colorMode.value === "system" ? preferredColorScheme.value : colorMode.value
)
const darkMode = useDarkMode()

/**
* The icon always reflects the actual theme applied to the site.
* Therefore, it must be based on the value of `actualColorMode`.
* Therefore, it must be based on the value of `effectiveColorMode`.
*/
const currentThemeIcon = computed(() => THEME_ICON_NAME[actualColorMode.value])
const currentThemeIcon = computed(
() => THEME_ICON_NAME[darkMode.effectiveColorMode.value]
)

/**
* The choices are computed because the text for the color mode choice
* "system" is dynamic and reflects the user's preferred color scheme at
* the OS-level.
*/
const choices: ComputedRef<Choice[]> = computed(() => {
const systemText = `${i18n.t(`theme.choices.system`)} (${THEME_TEXT[preferredColorScheme.value]})`
const systemText = `${i18n.t(`theme.choices.system`)} (${THEME_TEXT[darkMode.osColorMode.value]})`
return [
{ key: "light", text: THEME_TEXT.light },
{ key: "dark", text: THEME_TEXT.dark },
Expand Down

0 comments on commit 6dc18b5

Please sign in to comment.