app.ts 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. import { defineStore } from 'pinia'
  2. import { store } from '../index'
  3. import { setCssVar, humpToUnderline } from '@/utils'
  4. import { ElMessage } from 'element-plus'
  5. import { useCache } from '@/hooks/web/useCache'
  6. const { wsCache } = useCache()
  7. type LayoutType = 'classic' | 'topLeft' | 'top' | 'cutMenu'
  8. type ThemeTypes = {
  9. elColorPrimary?: string
  10. leftMenuBorderColor?: string
  11. leftMenuBgColor?: string
  12. leftMenuBgLightColor?: string
  13. leftMenuBgActiveColor?: string
  14. leftMenuCollapseBgActiveColor?: string
  15. leftMenuTextColor?: string
  16. leftMenuTextActiveColor?: string
  17. logoTitleTextColor?: string
  18. logoBorderColor?: string
  19. topHeaderBgColor?: string
  20. topHeaderTextColor?: string
  21. topHeaderHoverColor?: string
  22. topToolBorderColor?: string
  23. }
  24. interface AppState {
  25. breadcrumb: boolean
  26. breadcrumbIcon: boolean
  27. collapse: boolean
  28. uniqueOpened: boolean
  29. hamburger: boolean
  30. screenfull: boolean
  31. size: boolean
  32. locale: boolean
  33. tagsView: boolean
  34. tagsViewIcon: boolean
  35. logo: boolean
  36. fixedHeader: boolean
  37. greyMode: boolean
  38. pageLoading: boolean
  39. layout: LayoutType
  40. title: string
  41. userInfo: string
  42. isDark: boolean
  43. currentSize: ElememtPlusSize
  44. sizeMap: ElememtPlusSize[]
  45. mobile: boolean
  46. footer: boolean
  47. theme: ThemeTypes
  48. }
  49. export const useAppStore = defineStore('app', {
  50. state: (): AppState => {
  51. return {
  52. userInfo: 'userInfo', // 登录信息存储字段-建议每个项目换一个字段,避免与其他项目冲突
  53. sizeMap: ['default', 'large', 'small'],
  54. mobile: false, // 是否是移动端
  55. title: import.meta.env.VITE_APP_TITLE, // 标题
  56. pageLoading: false, // 路由跳转loading
  57. breadcrumb: true, // 面包屑
  58. breadcrumbIcon: true, // 面包屑图标
  59. collapse: false, // 折叠菜单
  60. uniqueOpened: true, // 是否只保持一个子菜单的展开
  61. hamburger: true, // 折叠图标
  62. screenfull: true, // 全屏图标
  63. size: true, // 尺寸图标
  64. locale: true, // 多语言图标
  65. tagsView: true, // 标签页
  66. tagsViewIcon: true, // 是否显示标签图标
  67. logo: true, // logo
  68. fixedHeader: true, // 固定toolheader
  69. footer: true, // 显示页脚
  70. greyMode: false, // 是否开始灰色模式,用于特殊悼念日
  71. layout: wsCache.get('layout') || 'classic', // layout布局
  72. isDark: wsCache.get('isDark') || false, // 是否是暗黑模式
  73. currentSize: wsCache.get('default') || 'default', // 组件尺寸
  74. theme: wsCache.get('theme') || {
  75. // 主题色
  76. elColorPrimary: '#409eff',
  77. // 左侧菜单边框颜色
  78. leftMenuBorderColor: 'inherit',
  79. // 左侧菜单背景颜色
  80. leftMenuBgColor: '#001529',
  81. // 左侧菜单浅色背景颜色
  82. leftMenuBgLightColor: '#0f2438',
  83. // 左侧菜单选中背景颜色
  84. leftMenuBgActiveColor: 'var(--el-color-primary)',
  85. // 左侧菜单收起选中背景颜色
  86. leftMenuCollapseBgActiveColor: 'var(--el-color-primary)',
  87. // 左侧菜单字体颜色
  88. leftMenuTextColor: '#bfcbd9',
  89. // 左侧菜单选中字体颜色
  90. leftMenuTextActiveColor: '#fff',
  91. // logo字体颜色
  92. logoTitleTextColor: '#fff',
  93. // logo边框颜色
  94. logoBorderColor: 'inherit',
  95. // 头部背景颜色
  96. topHeaderBgColor: '#fff',
  97. // 头部字体颜色
  98. topHeaderTextColor: 'inherit',
  99. // 头部悬停颜色
  100. topHeaderHoverColor: '#f6f6f6',
  101. // 头部边框颜色
  102. topToolBorderColor: '#eee'
  103. }
  104. }
  105. },
  106. getters: {
  107. getBreadcrumb(): boolean {
  108. return this.breadcrumb
  109. },
  110. getBreadcrumbIcon(): boolean {
  111. return this.breadcrumbIcon
  112. },
  113. getCollapse(): boolean {
  114. return this.collapse
  115. },
  116. getUniqueOpened(): boolean {
  117. return this.uniqueOpened
  118. },
  119. getHamburger(): boolean {
  120. return this.hamburger
  121. },
  122. getScreenfull(): boolean {
  123. return this.screenfull
  124. },
  125. getSize(): boolean {
  126. return this.size
  127. },
  128. getLocale(): boolean {
  129. return this.locale
  130. },
  131. getTagsView(): boolean {
  132. return this.tagsView
  133. },
  134. getTagsViewIcon(): boolean {
  135. return this.tagsViewIcon
  136. },
  137. getLogo(): boolean {
  138. return this.logo
  139. },
  140. getFixedHeader(): boolean {
  141. return this.fixedHeader
  142. },
  143. getGreyMode(): boolean {
  144. return this.greyMode
  145. },
  146. getPageLoading(): boolean {
  147. return this.pageLoading
  148. },
  149. getLayout(): LayoutType {
  150. return this.layout
  151. },
  152. getTitle(): string {
  153. return this.title
  154. },
  155. getUserInfo(): string {
  156. return this.userInfo
  157. },
  158. getIsDark(): boolean {
  159. return this.isDark
  160. },
  161. getCurrentSize(): ElememtPlusSize {
  162. return this.currentSize
  163. },
  164. getSizeMap(): ElememtPlusSize[] {
  165. return this.sizeMap
  166. },
  167. getMobile(): boolean {
  168. return this.mobile
  169. },
  170. getTheme(): ThemeTypes {
  171. return this.theme
  172. },
  173. getFooter(): boolean {
  174. return this.footer
  175. }
  176. },
  177. actions: {
  178. setBreadcrumb(breadcrumb: boolean) {
  179. this.breadcrumb = breadcrumb
  180. },
  181. setBreadcrumbIcon(breadcrumbIcon: boolean) {
  182. this.breadcrumbIcon = breadcrumbIcon
  183. },
  184. setCollapse(collapse: boolean) {
  185. this.collapse = collapse
  186. },
  187. setUniqueOpened(uniqueOpened: boolean) {
  188. this.uniqueOpened = uniqueOpened
  189. },
  190. setHamburger(hamburger: boolean) {
  191. this.hamburger = hamburger
  192. },
  193. setScreenfull(screenfull: boolean) {
  194. this.screenfull = screenfull
  195. },
  196. setSize(size: boolean) {
  197. this.size = size
  198. },
  199. setLocale(locale: boolean) {
  200. this.locale = locale
  201. },
  202. setTagsView(tagsView: boolean) {
  203. this.tagsView = tagsView
  204. },
  205. setTagsViewIcon(tagsViewIcon: boolean) {
  206. this.tagsViewIcon = tagsViewIcon
  207. },
  208. setLogo(logo: boolean) {
  209. this.logo = logo
  210. },
  211. setFixedHeader(fixedHeader: boolean) {
  212. this.fixedHeader = fixedHeader
  213. },
  214. setGreyMode(greyMode: boolean) {
  215. this.greyMode = greyMode
  216. },
  217. setPageLoading(pageLoading: boolean) {
  218. this.pageLoading = pageLoading
  219. },
  220. setLayout(layout: LayoutType) {
  221. if (this.mobile && layout !== 'classic') {
  222. ElMessage.warning('移动端模式下不支持切换其他布局')
  223. return
  224. }
  225. this.layout = layout
  226. wsCache.set('layout', this.layout)
  227. },
  228. setTitle(title: string) {
  229. this.title = title
  230. },
  231. setIsDark(isDark: boolean) {
  232. this.isDark = isDark
  233. if (this.isDark) {
  234. document.documentElement.classList.add('dark')
  235. document.documentElement.classList.remove('light')
  236. } else {
  237. document.documentElement.classList.add('light')
  238. document.documentElement.classList.remove('dark')
  239. }
  240. wsCache.set('isDark', this.isDark)
  241. },
  242. setCurrentSize(currentSize: ElememtPlusSize) {
  243. this.currentSize = currentSize
  244. wsCache.set('currentSize', this.currentSize)
  245. },
  246. setMobile(mobile: boolean) {
  247. this.mobile = mobile
  248. },
  249. setTheme(theme: ThemeTypes) {
  250. this.theme = Object.assign(this.theme, theme)
  251. wsCache.set('theme', this.theme)
  252. },
  253. setCssVarTheme() {
  254. for (const key in this.theme) {
  255. setCssVar(`--${humpToUnderline(key)}`, this.theme[key])
  256. }
  257. },
  258. setFooter(footer: boolean) {
  259. this.footer = footer
  260. }
  261. }
  262. })
  263. export const useAppStoreWithOut = () => {
  264. return useAppStore(store)
  265. }