initAppConfig.ts 2.5 KB

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