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.
This repo is archived. You can view files and clone it, but cannot push or open issues/pull-requests.
 
 
 
 
 
 

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 {}
}
}