feat: 新增主题颜色设置

Former-commit-id: a9f1be702a7ea211dbda0204d99f38142bf8ba5d
This commit is contained in:
haoxr
2023-01-21 16:44:38 +08:00
parent d12cb8c600
commit 141fd1da9a

View File

@@ -19,6 +19,21 @@ function changeLayout(layout: string) {
window.document.body.setAttribute('layout', settingsStore.layout); window.document.body.setAttribute('layout', settingsStore.layout);
} }
// 主题颜色
const themeColors = ref<string[]>([
'#409EFF',
'#304156',
'#11a983',
'#13c2c2',
'#6959CD',
'#f5222d'
]);
function changeThemeColor(color: string) {
document.documentElement.style.setProperty('--el-color-primary', color);
settingsStore.changeSetting({ key: 'layout', value: color });
}
onMounted(() => { onMounted(() => {
window.document.body.setAttribute('layout', settingsStore.layout); window.document.body.setAttribute('layout', settingsStore.layout);
}); });
@@ -27,7 +42,21 @@ onMounted(() => {
<template> <template>
<div class="settings-container"> <div class="settings-container">
<h3 class="text-base font-bold">项目配置</h3> <h3 class="text-base font-bold">项目配置</h3>
<el-divider /> <el-divider>主题</el-divider>
<div class="flex justify-center" @click.stop>
<el-switch
v-model="isDark"
@change="toggleDark"
inline-prompt
:active-icon="Moon"
:inactive-icon="Sunny"
active-color="var(--el-fill-color-dark)"
inactive-color="var(--el-color-primary)"
/>
</div>
<el-divider>界面设置</el-divider>
<div class="py-[8px] flex justify-between"> <div class="py-[8px] flex justify-between">
<span class="text-xs">开启 Tags-View</span> <span class="text-xs">开启 Tags-View</span>
<el-switch v-model="settingsStore.tagsView" /> <el-switch v-model="settingsStore.tagsView" />
@@ -43,21 +72,19 @@ onMounted(() => {
<el-switch v-model="settingsStore.sidebarLogo" /> <el-switch v-model="settingsStore.sidebarLogo" />
</div> </div>
<el-divider>主题</el-divider> <el-divider>主题颜色</el-divider>
<div class="flex justify-center" @click.stop> <ul class="w-full space-x-2 flex justify-center py-2">
<el-switch <li
v-model="isDark" class="inline-block w-[30px] h-[30px] cursor-pointer"
@change="toggleDark" v-for="(color, index) in themeColors"
inline-prompt :key="index"
:active-icon="Moon" :style="{ background: color }"
:inactive-icon="Sunny" @click="changeThemeColor(color)"
active-color="var(--el-fill-color-dark)" ></li>
inactive-color="var(--el-color-primary)" </ul>
/>
</div>
<el-divider>导航栏布局</el-divider> <el-divider>导航设置</el-divider>
<ul class="layout"> <ul class="layout">
<el-tooltip content="左侧模式" placement="bottom"> <el-tooltip content="左侧模式" placement="bottom">
@@ -109,7 +136,6 @@ onMounted(() => {
justify-content: space-around; justify-content: space-around;
width: 100%; width: 100%;
height: 50px; height: 50px;
padding: 0;
&-item { &-item {
width: 18%; width: 18%;