themeConfig.ts 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. import { defineStore } from 'pinia';
  2. /**
  3. * 布局配置
  4. * 修复:https://gitee.com/lyt-top/vue-next-admin/issues/I567R1,感谢@lanbao123
  5. * 2020.05.28 by lyt 优化。开发时配置不生效问题
  6. * 修改配置时:
  7. * 1、需要每次都清理 `window.localStorage` 浏览器永久缓存
  8. * 2、或者点击布局配置最底部 `一键恢复默认` 按钮即可看到效果
  9. */
  10. export const useThemeConfig = defineStore('themeConfig', {
  11. state: (): ThemeConfigState => ({
  12. themeConfig: {
  13. // 是否开启布局配置抽屉
  14. isDrawer: false,
  15. /**
  16. * 全局主题
  17. */
  18. // 默认 primary 主题颜色
  19. // primary: '#409eff',
  20. primary: '#3875F6',
  21. // 是否开启深色模式
  22. isIsDark: false,
  23. /**
  24. * 顶栏设置
  25. */
  26. // 默认顶栏导航背景颜色
  27. topBar: '#ffffff',
  28. // 默认顶栏导航字体颜色
  29. topBarColor: '#606266',
  30. // 是否开启顶栏背景颜色渐变
  31. isTopBarColorGradual: false,
  32. /**
  33. * 菜单设置
  34. */
  35. // 默认菜单导航背景颜色
  36. // menuBar: '#334054',
  37. menuBar: '#1e1b4b',
  38. // 默认菜单导航字体颜色
  39. // menuBarColor: '#eaeaea',
  40. menuBarColor: '#EBEDF0',
  41. // 默认菜单高亮背景色
  42. // menuBarActiveColor: 'rgba(0, 0, 0, 0.2)',
  43. menuBarActiveColor: '',
  44. // 是否开启菜单背景颜色渐变
  45. isMenuBarColorGradual: false,
  46. /**
  47. * 分栏设置
  48. */
  49. // 默认分栏菜单背景颜色
  50. columnsMenuBar: '#334054',
  51. // 默认分栏菜单字体颜色
  52. columnsMenuBarColor: '#e6e6e6',
  53. // 是否开启分栏菜单背景颜色渐变
  54. isColumnsMenuBarColorGradual: false,
  55. // 是否开启分栏菜单鼠标悬停预加载(预览菜单)
  56. isColumnsMenuHoverPreload: false,
  57. /**
  58. * 界面设置
  59. */
  60. // 是否开启菜单水平折叠效果
  61. isCollapse: false,
  62. // 是否开启菜单手风琴效果
  63. isUniqueOpened: true,
  64. // 是否开启固定 Header
  65. isFixedHeader: false,
  66. // 初始化变量,用于更新菜单 el-scrollbar 的高度,请勿删除
  67. isFixedHeaderChange: false,
  68. // 是否开启经典布局分割菜单(仅经典布局生效)
  69. isClassicSplitMenu: false,
  70. // 是否开启自动锁屏
  71. isLockScreen: false,
  72. // 开启自动锁屏倒计时(s/秒)
  73. lockScreenTime: 30,
  74. /**
  75. * 界面显示
  76. */
  77. // 是否开启侧边栏 Logo
  78. isShowLogo: true,
  79. // 初始化变量,用于 el-scrollbar 的高度更新,请勿删除
  80. isShowLogoChange: false,
  81. // 是否开启 Breadcrumb,强制经典、横向布局不显示
  82. isBreadcrumb: true,
  83. // 是否开启 Tagsview
  84. isTagsview: true,
  85. // 是否开启 Breadcrumb 图标
  86. isBreadcrumbIcon: true,
  87. // 是否开启 Tagsview 图标
  88. isTagsviewIcon: true,
  89. // 是否开启 TagsView 缓存
  90. isCacheTagsView: true,
  91. // 是否开启 TagsView 拖拽
  92. isSortableTagsView: true,
  93. // 是否开启 TagsView 共用
  94. isShareTagsView: false,
  95. // 是否开启 Footer 底部版权信息
  96. isFooter: true,
  97. // 是否开启灰色模式
  98. isGrayscale: false,
  99. // 是否开启色弱模式
  100. isInvert: false,
  101. // 是否开启水印
  102. isWartermark: false,
  103. // 水印文案
  104. wartermarkText: '',
  105. /**
  106. * 其它设置
  107. */
  108. // Tagsview 风格:可选值"<tags-style-one|tags-style-four|tags-style-five>",默认 tags-style-five
  109. // 定义的值与 `/src/layout/navBars/tagsView/tagsView.vue` 中的 class 同名
  110. tagsStyle: 'tags-style-five',
  111. // 主页面切换动画:可选值"<slide-right|slide-left|opacitys>",默认 slide-right
  112. animation: 'slide-right',
  113. // 分栏高亮风格:可选值"<columns-round|columns-card>",默认 columns-round
  114. columnsAsideStyle: 'columns-round',
  115. // 分栏布局风格:可选值"<columns-horizontal|columns-vertical>",默认 columns-horizontal
  116. columnsAsideLayout: 'columns-vertical',
  117. /**
  118. * 布局切换
  119. * 注意:为了演示,切换布局时,颜色会被还原成默认,代码位置:/@/layout/navBars/breadcrumb/setings.vue
  120. * 中的 `initSetLayoutChange(设置布局切换,重置主题样式)` 方法
  121. */
  122. // 布局切换:可选值"<defaults|classic|transverse|columns>",默认 defaults
  123. layout: 'defaults',
  124. /**
  125. * 后端控制路由
  126. */
  127. // 是否开启后端控制路由
  128. isRequestRoutes: true,
  129. /**
  130. * 全局网站标题 / 副标题
  131. */
  132. // 网站主标题(菜单导航、浏览器当前网页标题)
  133. globalTitle: 'AnsjerAMS',
  134. // 网站副标题(登录页顶部文字)
  135. globalViceTitle: 'AnsjerAMS',
  136. // 网站副标题(登录页顶部文字)
  137. globalViceTitleMsg: '企业级快速开发平台',
  138. // 默认初始语言,可选值"<zh-cn|en|zh-tw>",默认 zh-cn
  139. globalI18n: 'zh-cn',
  140. // 默认全局组件大小,可选值"<large|'default'|small>",默认 'large'
  141. globalComponentSize: 'default',
  142. },
  143. }),
  144. actions: {
  145. setThemeConfig(data: ThemeConfigState) {
  146. this.themeConfig = data.themeConfig;
  147. },
  148. },
  149. });