2
0
mirror of https://github.com/acepanel/panel.git synced 2026-02-04 06:47:20 +08:00
Files
panel/web/src/store/modules/theme/index.ts
Copilot f2d3911266 feat: 支持隐藏菜单和自定义Logo长期保存 (#1200)
* 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>
2026-01-09 05:49:09 +08:00

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']
}
})