app.ts 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. import type { ProjectConfig, HeaderSetting, MenuSetting, TransitionSetting, MultiTabsSetting } from '/#/config';
  2. import type { BeforeMiniState } from '/#/store';
  3. import { defineStore } from 'pinia';
  4. import { store } from '/@/store';
  5. import { ThemeEnum } from '/@/enums/appEnum';
  6. import { APP_DARK_MODE_KEY_, PROJ_CFG_KEY } from '/@/enums/cacheEnum';
  7. import { Persistent } from '/@/utils/cache/persistent';
  8. import { darkMode } from '/@/settings/designSetting';
  9. import { resetRouter } from '/@/router';
  10. import { deepMerge } from '/@/utils';
  11. interface AppState {
  12. darkMode?: ThemeEnum;
  13. // Page loading status
  14. pageLoading: boolean;
  15. // project config
  16. projectConfig: ProjectConfig | null;
  17. // When the window shrinks, remember some states, and restore these states when the window is restored
  18. beforeMiniInfo: BeforeMiniState;
  19. // 页面跳转临时参数存储
  20. messageHrefParams: any;
  21. widthScale: number;
  22. heightScale: number;
  23. }
  24. let timeId: TimeoutHandle;
  25. export const useAppStore = defineStore({
  26. id: 'app',
  27. state: (): AppState => ({
  28. darkMode: undefined,
  29. pageLoading: false,
  30. projectConfig: Persistent.getLocal(PROJ_CFG_KEY),
  31. beforeMiniInfo: {},
  32. messageHrefParams: {},
  33. widthScale: 1,
  34. heightScale: 1,
  35. }),
  36. getters: {
  37. getPageLoading(): boolean {
  38. return this.pageLoading;
  39. },
  40. getDarkMode(): 'light' | 'dark' | 'vent1' | string {
  41. return this.darkMode || localStorage.getItem(APP_DARK_MODE_KEY_) || darkMode;
  42. },
  43. getBeforeMiniInfo(): BeforeMiniState {
  44. return this.beforeMiniInfo;
  45. },
  46. getProjectConfig(): ProjectConfig {
  47. return this.projectConfig || ({} as ProjectConfig);
  48. },
  49. getHeaderSetting(): HeaderSetting {
  50. return this.getProjectConfig.headerSetting;
  51. },
  52. getMenuSetting(): MenuSetting {
  53. return this.getProjectConfig.menuSetting;
  54. },
  55. getTransitionSetting(): TransitionSetting {
  56. return this.getProjectConfig.transitionSetting;
  57. },
  58. getMultiTabsSetting(): MultiTabsSetting {
  59. return this.getProjectConfig.multiTabsSetting;
  60. },
  61. getMessageHrefParams(): any {
  62. return this.messageHrefParams;
  63. },
  64. getWidthScale(): number {
  65. return this.widthScale;
  66. },
  67. getHeightScale(): number {
  68. return this.heightScale;
  69. },
  70. },
  71. actions: {
  72. setPageLoading(loading: boolean): void {
  73. this.pageLoading = loading;
  74. },
  75. setDarkMode(mode: ThemeEnum): void {
  76. this.darkMode = mode;
  77. localStorage.setItem(APP_DARK_MODE_KEY_, mode);
  78. },
  79. setBeforeMiniInfo(state: BeforeMiniState): void {
  80. this.beforeMiniInfo = state;
  81. },
  82. setProjectConfig(config: DeepPartial<ProjectConfig>): void {
  83. this.projectConfig = deepMerge(this.projectConfig || {}, config);
  84. Persistent.setLocal(PROJ_CFG_KEY, this.projectConfig);
  85. },
  86. async resetAllState() {
  87. resetRouter();
  88. Persistent.clearAll();
  89. },
  90. async setPageLoadingAction(loading: boolean): Promise<void> {
  91. if (loading) {
  92. clearTimeout(timeId);
  93. // Prevent flicker
  94. timeId = setTimeout(() => {
  95. this.setPageLoading(loading);
  96. }, 50);
  97. } else {
  98. this.setPageLoading(loading);
  99. clearTimeout(timeId);
  100. }
  101. },
  102. setMessageHrefParams(params: any): void {
  103. this.messageHrefParams = params;
  104. },
  105. setWidthScale(scale: number) {
  106. this.widthScale = scale;
  107. },
  108. setHeightScale(scale: number) {
  109. this.heightScale = scale;
  110. },
  111. },
  112. });
  113. // Need to be used outside the setup
  114. export function useAppStoreWithOut() {
  115. return useAppStore(store);
  116. }