initAppConfig.ts 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. /**
  2. * Application configuration
  3. */
  4. import type { ProjectConfig } from '/#/config';
  5. import { PROJ_CFG_KEY } from '/@/enums/cacheEnum';
  6. import projectSetting from '/@/settings/projectSetting';
  7. import {
  8. updateTextColor,
  9. updateBorderColor,
  10. updateHeaderBgColor,
  11. updateSidebarBgColor,
  12. updateComponentBgColor,
  13. updateAppContentBgColor,
  14. } from '/@/logics/theme/updateBackground';
  15. import { updateColorWeak } from '/@/logics/theme/updateColorWeak';
  16. import { updateGrayMode } from '/@/logics/theme/updateGrayMode';
  17. import { updateDarkTheme } from '/@/logics/theme/dark';
  18. import { useAppStore } from '/@/store/modules/app';
  19. import { useLocaleStore } from '/@/store/modules/locale';
  20. import { getCommonStoragePrefix, getStorageShortName } from '/@/utils/env';
  21. import { Persistent } from '/@/utils/cache/persistent';
  22. import { deepMerge } from '/@/utils';
  23. import { ThemeEnum } from '/@/enums/appEnum';
  24. // Initial project configuration
  25. export function initAppConfigStore() {
  26. const localeStore = useLocaleStore();
  27. const appStore = useAppStore();
  28. let projCfg: ProjectConfig = Persistent.getLocal(PROJ_CFG_KEY) as ProjectConfig;
  29. projCfg = deepMerge(projectSetting, projCfg || {});
  30. const darkMode = appStore.getDarkMode;
  31. const {
  32. colorWeak,
  33. grayMode,
  34. headerSetting: { bgColor: headerBgColor } = {},
  35. menuSetting: { bgColor } = {},
  36. } = projCfg;
  37. try {
  38. grayMode && updateGrayMode(grayMode);
  39. colorWeak && updateColorWeak(colorWeak);
  40. } catch (error) {
  41. console.log(error);
  42. }
  43. appStore.setProjectConfig(projCfg);
  44. // init dark mode
  45. updateDarkTheme(darkMode);
  46. updateTextColor();
  47. updateBorderColor();
  48. updateComponentBgColor();
  49. updateAppContentBgColor();
  50. if (darkMode === ThemeEnum.DARK) {
  51. updateHeaderBgColor();
  52. updateSidebarBgColor();
  53. } else {
  54. headerBgColor && updateHeaderBgColor(headerBgColor);
  55. bgColor && updateSidebarBgColor(bgColor);
  56. }
  57. // init store
  58. localeStore.initLocale();
  59. setTimeout(() => {
  60. clearObsoleteStorage();
  61. }, 16);
  62. }
  63. /**
  64. * As the version continues to iterate, there will be more and more cache keys stored in localStorage.
  65. * This method is used to delete useless keys
  66. */
  67. export function clearObsoleteStorage() {
  68. const commonPrefix = getCommonStoragePrefix();
  69. const shortPrefix = getStorageShortName();
  70. [localStorage, sessionStorage].forEach((item: Storage) => {
  71. Object.keys(item).forEach((key) => {
  72. if (key && key.startsWith(commonPrefix) && !key.startsWith(shortPrefix)) {
  73. item.removeItem(key);
  74. }
  75. });
  76. });
  77. }