import { HandlerEnum, tabsThemeOptions} from './enum'; import { updateHeaderBgColor, updateSidebarBgColor } from '/@/logics/theme/updateBackground'; import { updateColorWeak } from '/@/logics/theme/updateColorWeak'; import { updateGrayMode } from '/@/logics/theme/updateGrayMode'; import { useAppStore } from '/@/store/modules/app'; import { ProjectConfig } from '/#/config'; import { changeTheme } from '/@/logics/theme'; import { updateDarkTheme } from '/@/logics/theme/dark'; import { useRootSetting } from '/@/hooks/setting/useRootSetting'; import { MenuModeEnum, MenuTypeEnum } from '/@/enums/menuEnum'; import { getConfigByMenuType } from '../../../utils/getConfigByMenuType'; import { isObject } from '/@/utils/is'; import { ThemeEnum } from '/@/enums/appEnum'; import { APP__THEME__COLOR } from '/@/enums/cacheEnum'; /** * 2024-04-07 * liaozhiyang * 切换导航栏模式都走这个方法,每个模式都会有固定的顶部和菜单颜色搭配。暗黑模式则不走固定搭配 * */ export function layoutHandler(event: HandlerEnum, value: any) { const isHTopMenu = isObject(value) && value.type == MenuTypeEnum.TOP_MENU && value.mode == MenuModeEnum.HORIZONTAL; const isMixMenu = isObject(value) && value.type == MenuTypeEnum.MIX && value.mode == MenuModeEnum.INLINE; const isMixSidebarMenu = isObject(value) && value.type == MenuTypeEnum.MIX_SIDEBAR && value.mode == MenuModeEnum.INLINE; const appStore = useAppStore(); const darkMode = appStore.getDarkMode === ThemeEnum.DARK; // 根据菜单类型动态获取主题色 const {themeColor: dynamicThemeColor, headerBgColor, sideBgColor } = getConfigByMenuType(value.type); if (isHTopMenu) { baseHandler(event, value); baseHandler(HandlerEnum.HEADER_THEME, headerBgColor); baseHandler(HandlerEnum.CHANGE_THEME_COLOR, dynamicThemeColor); if (darkMode) { updateHeaderBgColor(); updateSidebarBgColor(); } baseHandler(HandlerEnum.TABS_THEME, tabsThemeOptions[1].value); } else if (isMixMenu) { baseHandler(event, value); baseHandler(HandlerEnum.HEADER_THEME, headerBgColor); baseHandler(HandlerEnum.MENU_THEME, sideBgColor); if (darkMode) { updateHeaderBgColor(); updateSidebarBgColor(); } // 顶部混合导航模式使用动态主题色 baseHandler(HandlerEnum.CHANGE_THEME_COLOR, dynamicThemeColor); baseHandler(HandlerEnum.TABS_THEME, tabsThemeOptions[1].value); } else if (isMixSidebarMenu) { baseHandler(event, value); baseHandler(HandlerEnum.CHANGE_THEME_COLOR, dynamicThemeColor); baseHandler(HandlerEnum.HEADER_THEME, headerBgColor); baseHandler(HandlerEnum.MENU_THEME, sideBgColor); if (darkMode) { updateHeaderBgColor(); updateSidebarBgColor(); } baseHandler(HandlerEnum.TABS_THEME, tabsThemeOptions[1].value); } else { baseHandler(event, value); baseHandler(HandlerEnum.HEADER_THEME, headerBgColor); baseHandler(HandlerEnum.MENU_THEME, sideBgColor); if (darkMode) { updateHeaderBgColor(); updateSidebarBgColor(); } baseHandler(HandlerEnum.CHANGE_THEME_COLOR, dynamicThemeColor); baseHandler(HandlerEnum.TABS_THEME, tabsThemeOptions[1].value); } // 代码逻辑说明: 【QQYUN-13600】默认顶部混合导航模式且启用顶部左侧导航,切换到其他模式时导航刷新后菜单样式混乱 if (isMixMenu) { baseHandler(HandlerEnum.MENU_SPLIT, true); } else { baseHandler(HandlerEnum.MENU_SPLIT, false); } } export function baseHandler(event: HandlerEnum, value: any) { const appStore = useAppStore(); const config = handler(event, value); appStore.setProjectConfig(config); if (event === HandlerEnum.CHANGE_THEME) { updateHeaderBgColor(); updateSidebarBgColor(); } } export function handler(event: HandlerEnum, value: any): DeepPartial { const appStore = useAppStore(); const { getThemeColor, getDarkMode } = useRootSetting(); switch (event) { case HandlerEnum.CHANGE_LAYOUT: const { mode, type, split } = value; const splitOpt = split === undefined ? { split } : {}; return { menuSetting: { mode, type, collapsed: false, show: true, hidden: false, ...splitOpt, }, }; case HandlerEnum.CHANGE_THEME_COLOR: if (getThemeColor.value === value) { return {}; } // 代码逻辑说明: 【QQYUN-8925】系统主题颜色(供页面加载使用) localStorage.setItem(APP__THEME__COLOR, value); changeTheme(value); return { themeColor: value }; case HandlerEnum.CHANGE_THEME: if (getDarkMode.value === value) { return {}; } updateDarkTheme(value); return {}; case HandlerEnum.MENU_HAS_DRAG: return { menuSetting: { canDrag: value } }; case HandlerEnum.MENU_ACCORDION: return { menuSetting: { accordion: value } }; case HandlerEnum.MENU_TRIGGER: return { menuSetting: { trigger: value } }; case HandlerEnum.MENU_TOP_ALIGN: return { menuSetting: { topMenuAlign: value } }; case HandlerEnum.MENU_COLLAPSED: return { menuSetting: { collapsed: value } }; case HandlerEnum.MENU_WIDTH: return { menuSetting: { menuWidth: value } }; case HandlerEnum.MENU_SHOW_SIDEBAR: return { menuSetting: { show: value } }; case HandlerEnum.MENU_COLLAPSED_SHOW_TITLE: return { menuSetting: { collapsedShowTitle: value } }; case HandlerEnum.MENU_THEME: updateSidebarBgColor(value); return { menuSetting: { bgColor: value } }; case HandlerEnum.MENU_SPLIT: return { menuSetting: { split: value } }; case HandlerEnum.MENU_CLOSE_MIX_SIDEBAR_ON_CHANGE: return { menuSetting: { closeMixSidebarOnChange: value } }; case HandlerEnum.MENU_FIXED: return { menuSetting: { fixed: value } }; case HandlerEnum.MENU_TRIGGER_MIX_SIDEBAR: return { menuSetting: { mixSideTrigger: value } }; case HandlerEnum.MENU_FIXED_MIX_SIDEBAR: return { menuSetting: { mixSideFixed: value } }; // ============transition================== case HandlerEnum.OPEN_PAGE_LOADING: appStore.setPageLoading(false); return { transitionSetting: { openPageLoading: value } }; case HandlerEnum.ROUTER_TRANSITION: return { transitionSetting: { basicTransition: value } }; case HandlerEnum.OPEN_ROUTE_TRANSITION: return { transitionSetting: { enable: value } }; case HandlerEnum.OPEN_PROGRESS: return { transitionSetting: { openNProgress: value } }; // ============root================== case HandlerEnum.LOCK_TIME: return { lockTime: value }; case HandlerEnum.FULL_CONTENT: return { fullContent: value }; case HandlerEnum.CONTENT_MODE: return { contentMode: value }; case HandlerEnum.SHOW_BREADCRUMB: return { showBreadCrumb: value }; case HandlerEnum.SHOW_BREADCRUMB_ICON: return { showBreadCrumbIcon: value }; case HandlerEnum.GRAY_MODE: updateGrayMode(value); return { grayMode: value }; case HandlerEnum.SHOW_FOOTER: return { showFooter: value }; case HandlerEnum.COLOR_WEAK: updateColorWeak(value); return { colorWeak: value }; // 代码逻辑说明: 【QQYUN-10952】AI助手支持通过设置来配置是否显示 case HandlerEnum.AI_ICON_SHOW: return { aiIconShow: value }; case HandlerEnum.SHOW_LOGO: return { showLogo: value }; // ============tabs================== case HandlerEnum.TABS_SHOW_QUICK: return { multiTabsSetting: { showQuick: value } }; case HandlerEnum.TABS_SHOW: return { multiTabsSetting: { show: value } }; case HandlerEnum.TABS_SHOW_REDO: return { multiTabsSetting: { showRedo: value } }; case HandlerEnum.TABS_SHOW_FOLD: return { multiTabsSetting: { showFold: value } }; case HandlerEnum.TABS_THEME: return { multiTabsSetting: { theme: value } }; // ============header================== case HandlerEnum.HEADER_THEME: updateHeaderBgColor(value); return { headerSetting: { bgColor: value } }; case HandlerEnum.HEADER_SEARCH: return { headerSetting: { showSearch: value } }; case HandlerEnum.HEADER_FIXED: return { headerSetting: { fixed: value } }; case HandlerEnum.HEADER_SHOW: return { headerSetting: { show: value } }; default: return {}; } }