App.ts 2.2 KB
Newer Older
V
vben 已提交
1 2 3 4
/**
 * Application configuration
 */

陈文彬 已提交
5
import type { ProjectConfig } from '/@/types/config';
V
vben 已提交
6
import type { App } from 'vue';
陈文彬 已提交
7 8 9 10 11 12 13 14
import { computed, ref } from 'vue';

import { ThemeModeEnum } from '/@/enums/appEnum';
import { PROJ_CFG_KEY } from '/@/enums/cacheEnum';

import projectSetting from '/@/settings/projectSetting';
import { getLocal } from '/@/utils/helper/persistent';
import { isUnDef, isNull } from '/@/utils/is';
15 16 17 18 19 20
import {
  updateGrayMode,
  updateColorWeak,
  updateHeaderBgColor,
  updateSidebarBgColor,
} from '/@/setup/theme';
陈文彬 已提交
21 22

import { appStore } from '/@/store/modules/app';
V
vben 已提交
23
import { deepMerge } from '/@/utils';
陈文彬 已提交
24

V
vben 已提交
25
// Used to share global app instances
V
vben 已提交
26
let app: App;
V
vben 已提交
27

V
vben 已提交
28 29 30 31 32 33 34 35
export function setApp(_app: App): void {
  app = _app;
}

export function getApp(): App {
  return app;
}

V
vben 已提交
36
// TODO Theme switching
陈文彬 已提交
37 38 39 40 41 42 43 44 45 46 47 48 49 50
export function useThemeMode(mode: ThemeModeEnum) {
  const modeRef = ref(mode);
  const html = document.documentElement;
  const clsList = html.classList;

  const change = () => {
    clsList.contains(mode) ? clsList.remove(mode) : clsList.add(mode);
  };
  return {
    runChangeThemeMode: change,
    mode: computed(() => modeRef.value),
  };
}

V
vben 已提交
51
// Initial project configuration
V
vben 已提交
52
export function initAppConfigStore() {
陈文彬 已提交
53
  let projCfg: ProjectConfig = getLocal(PROJ_CFG_KEY) as ProjectConfig;
V
vben 已提交
54 55
  projCfg = deepMerge(projectSetting, projCfg || {});

陈文彬 已提交
56
  try {
V
vben 已提交
57 58 59 60 61 62
    const {
      colorWeak,
      grayMode,
      headerSetting: { bgColor: headerBgColor } = {},
      menuSetting: { bgColor } = {},
    } = projCfg;
陈文彬 已提交
63 64 65 66 67 68 69
    // if (
    //   themeColor !== primaryColor &&
    //   themeColor &&
    //   process.env.VUE_APP_USE_THEME_REPLACER !== 'TRUE'
    // ) {
    //   updateTheme(themeColor);
    // }
70
    headerBgColor && updateHeaderBgColor(headerBgColor);
V
vben 已提交
71
    bgColor && updateSidebarBgColor(bgColor);
陈文彬 已提交
72 73 74 75 76 77 78 79
    grayMode && updateGrayMode(grayMode);
    colorWeak && updateColorWeak(colorWeak);
  } catch (error) {
    console.log(error);
  }
  appStore.commitProjectConfigState(projCfg);
}

V
vben 已提交
80 81
// antdv Config Provider
export function getConfigProvider() {
陈文彬 已提交
82 83 84 85 86 87 88 89 90 91
  function transformCellText({ text }: { text: string }) {
    if (isNull(text) || isUnDef(text)) {
      return ' - ';
    }
    return text;
  }
  return {
    transformCellText,
  };
}