app.ts 7.3 KB

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