initAppConfig.ts 2.1 KB

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