1
0
mirror of https://github.com/ZeroCatDev/Classworks.git synced 2026-05-13 19:35:07 +00:00
Classworks/src/components/settings/cards/ThemeSettingsCard.vue
2026-04-17 13:49:52 +00:00

77 lines
1.6 KiB
Vue

<template>
<settings-card
icon="mdi-palette"
title="主题设置"
>
<v-list>
<v-list-item>
<template #prepend>
<v-icon
class="mr-3"
icon="mdi-theme-light-dark"
/>
</template>
<v-list-item-title>主题模式</v-list-item-title>
<v-list-item-subtitle>选择明亮或暗黑主题</v-list-item-subtitle>
<template #append>
<v-btn-toggle
v-model="localTheme"
color="primary"
density="comfortable"
>
<v-btn value="light">
<v-icon
class="mr-2"
icon="mdi-white-balance-sunny"
/>
明亮
</v-btn>
<v-btn value="dark">
<v-icon
class="mr-2"
icon="mdi-moon-waning-crescent"
/>
暗黑
</v-btn>
</v-btn-toggle>
</template>
</v-list-item>
</v-list>
</settings-card>
</template>
<script>
import SettingsCard from '@/components/SettingsCard.vue';
import {getSetting, setSetting} from '@/utils/settings';
import {useTheme} from 'vuetify';
export default {
name: 'ThemeSettingsCard',
components: {SettingsCard},
setup() {
const theme = useTheme();
return {theme};
},
data() {
return {
localTheme: getSetting('theme.mode')
};
},
watch: {
localTheme(newValue) {
setSetting('theme.mode', newValue);
this.updateTheme(newValue);
}
},
methods: {
updateTheme(mode) {
this.theme.global.name.value = mode;
}
}
};
</script>