You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
181 lines
5.2 KiB
181 lines
5.2 KiB
/* eslint-disable no-case-declarations */ |
|
import { HandlerEnum } 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 type { ProjectConfig } from '@/types/config' |
|
import { changeTheme } from '@/logics/theme' |
|
import { updateDarkTheme } from '@/logics/theme/dark' |
|
import { useRootSetting } from '@/hooks/setting/useRootSetting' |
|
|
|
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<ProjectConfig> { |
|
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 {} |
|
|
|
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 } |
|
|
|
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_ICON: |
|
return { multiTabsSetting: { showIcon: value } } |
|
|
|
case HandlerEnum.TABS_SHOW_REDO: |
|
return { multiTabsSetting: { showRedo: value } } |
|
|
|
case HandlerEnum.TABS_SHOW_FOLD: |
|
return { multiTabsSetting: { showFold: value } } |
|
|
|
case HandlerEnum.TABS_AUTO_COLLAPSE: |
|
return { multiTabsSetting: { autoCollapse: 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 {} |
|
} |
|
}
|
|
|