mirror of
https://github.com/acepanel/panel.git
synced 2026-02-04 06:47:20 +08:00
* Initial plan * feat: 支持隐藏菜单和自定义Logo长期保存 - 后端:在 SettingPanel 结构体中添加 HiddenMenu 和 CustomLogo 字段 - 后端:在 GetPanel 和 UpdatePanel 方法中处理新字段的获取和保存 - 后端:修改 Panel 接口返回 hidden_menu 和 custom_logo 给前端初始化 - 前端:在基本设置页面添加隐藏菜单和自定义 Logo 设置项 - 前端:从侧边栏设置组件中移除弹窗,只保留菜单折叠按钮 - 前端:初始化时从服务端获取并应用隐藏菜单和自定义 Logo 设置 - 前端:调整 store 的 persist 配置,不再将这两个设置保存到本地存储 Co-authored-by: devhaozi <115467771+devhaozi@users.noreply.github.com> * 代码审查完成 Co-authored-by: devhaozi <115467771+devhaozi@users.noreply.github.com> * feat: 优化样式 --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: devhaozi <115467771+devhaozi@users.noreply.github.com> Co-authored-by: 耗子 <haozi@loli.email>
66 lines
1.8 KiB
Go
66 lines
1.8 KiB
Go
import type { NDateLocale, NLocale } from 'naive-ui'
|
|
import { darkTheme, dateEnUS, dateJaJP, dateZhCN, dateZhTW, enUS, jaJP, zhCN, zhTW } from 'naive-ui'
|
|
import type { BuiltInGlobalTheme } from 'naive-ui/es/themes/interface'
|
|
|
|
import { defaultSettings } from './helpers'
|
|
|
|
type ThemeState = Theme.Setting
|
|
|
|
const locales: Record<string, { locale: NLocale; dateLocale: NDateLocale }> = {
|
|
en: { locale: enUS, dateLocale: dateEnUS },
|
|
zh_CN: { locale: zhCN, dateLocale: dateZhCN },
|
|
zh_TW: { locale: zhTW, dateLocale: dateZhTW },
|
|
ja_JP: { locale: jaJP, dateLocale: dateJaJP }
|
|
}
|
|
|
|
export const useThemeStore = defineStore('theme', {
|
|
state: (): ThemeState => defaultSettings(),
|
|
getters: {
|
|
naiveTheme(): BuiltInGlobalTheme | undefined {
|
|
return this.darkMode ? darkTheme : undefined
|
|
},
|
|
naiveLocale(): NLocale {
|
|
return locales[this.locale].locale
|
|
},
|
|
naiveDateLocale(): NDateLocale {
|
|
return locales[this.locale].dateLocale
|
|
}
|
|
},
|
|
actions: {
|
|
setIsMobile(isMobile: boolean) {
|
|
this.isMobile = isMobile
|
|
},
|
|
/** 设置暗黑模式 */
|
|
setDarkMode(darkMode: boolean) {
|
|
this.darkMode = darkMode
|
|
},
|
|
/** 切换/关闭 暗黑模式 */
|
|
toggleDarkMode() {
|
|
this.darkMode = !this.darkMode
|
|
},
|
|
/** 切换/关闭 折叠侧边栏 */
|
|
toggleCollapsed() {
|
|
this.sider.collapsed = !this.sider.collapsed
|
|
},
|
|
/** 设置 折叠侧边栏 */
|
|
setCollapsed(collapsed: boolean) {
|
|
this.sider.collapsed = collapsed
|
|
},
|
|
/** 设置语言 */
|
|
setLocale(locale: string) {
|
|
this.locale = locale
|
|
},
|
|
/** 设置名称 */
|
|
setName(name: string) {
|
|
this.name = name
|
|
},
|
|
/** 设置 Logo */
|
|
setLogo(logo: string) {
|
|
this.logo = logo
|
|
}
|
|
},
|
|
persist: {
|
|
pick: ['isMobile', 'darkMode', 'sider', 'header', 'tab', 'locale', 'name']
|
|
}
|
|
})
|