mirror of
https://github.com/m-xlsea/ruoyi-plus-soybean.git
synced 2025-09-24 07:49:47 +08:00
refactor(hooks): 状态管理模块拆分
This commit is contained in:
91
src/interface/theme.ts
Normal file
91
src/interface/theme.ts
Normal file
@ -0,0 +1,91 @@
|
||||
import { EnumAnimate, EnumNavMode, EnumNavTheme } from '@/enum';
|
||||
|
||||
export interface ThemeSettings {
|
||||
/** 深色模式 */
|
||||
darkMode: boolean;
|
||||
/** 主题颜色 */
|
||||
themeColor: string;
|
||||
/** 主题颜色列表 */
|
||||
themeColorList: string[];
|
||||
/** 其他颜色 */
|
||||
otherColor: OtherColor;
|
||||
/** 导航样式 */
|
||||
navStyle: NavStyle;
|
||||
/** 菜单样式 */
|
||||
menuStyle: MenuStyle;
|
||||
/** 头部样式 */
|
||||
headerStyle: HeaderStyle;
|
||||
/** 多标签样式 */
|
||||
multiTabStyle: MultiTabStyle;
|
||||
/** 面包屑样式 */
|
||||
crumbsStyle: CrumbsStyle;
|
||||
/** 页面样式 */
|
||||
pageStyle: PageStyle;
|
||||
}
|
||||
|
||||
interface OtherColor {
|
||||
/** 信息 */
|
||||
info: string;
|
||||
/** 成功 */
|
||||
success: string;
|
||||
/** 警告 */
|
||||
warning: string;
|
||||
/** 错误 */
|
||||
error: string;
|
||||
}
|
||||
|
||||
export type NavMode = keyof typeof EnumNavMode;
|
||||
|
||||
type NavTheme = keyof typeof EnumNavTheme;
|
||||
|
||||
interface NavStyle {
|
||||
/** 导航模式 */
|
||||
mode: NavMode;
|
||||
/** 导航主题 */
|
||||
theme: NavTheme;
|
||||
}
|
||||
|
||||
interface HeaderStyle {
|
||||
/** 顶部高度 */
|
||||
height: number;
|
||||
/** 背景颜色 */
|
||||
bgColor: string;
|
||||
/** 固定顶部 */
|
||||
fixed: boolean;
|
||||
/** 显示重载按钮 */
|
||||
showReload: boolean;
|
||||
}
|
||||
|
||||
interface MenuStyle {
|
||||
/** 菜单宽度 */
|
||||
width: number;
|
||||
/** 菜单折叠时的宽度 */
|
||||
collapsedWidth: number;
|
||||
/** 固定菜单 */
|
||||
fixed: boolean;
|
||||
/** 分割菜单 */
|
||||
splitMenu: boolean;
|
||||
}
|
||||
|
||||
interface MultiTabStyle {
|
||||
/** 多标签可见 */
|
||||
visible: boolean;
|
||||
/** 背景颜色 */
|
||||
bgColor: string;
|
||||
}
|
||||
|
||||
interface CrumbsStyle {
|
||||
/** 面包屑可见 */
|
||||
visible: boolean;
|
||||
/** 显示图标 */
|
||||
showIcon: boolean;
|
||||
}
|
||||
|
||||
type AnimateType = keyof typeof EnumAnimate;
|
||||
|
||||
interface PageStyle {
|
||||
/** 页面是否开启动画 */
|
||||
animate: boolean;
|
||||
/** 动画类型 */
|
||||
animateType: AnimateType;
|
||||
}
|
Reference in New Issue
Block a user