vue-vben-admin/src/layouts/default/setting/handler.ts

136 lines
3.8 KiB
TypeScript
Raw Normal View History

2020-11-24 22:59:29 +08:00
import { HandlerEnum } from './enum';
import {
updateColorWeak,
updateGrayMode,
updateHeaderBgColor,
updateSidebarBgColor,
2020-12-21 22:20:01 +08:00
} from '/@/logics/theme';
2020-11-10 22:45:39 +08:00
import { appStore } from '/@/store/modules/app';
import { ProjectConfig } from '/@/types/config';
export function baseHandler(event: HandlerEnum, value: any) {
const config = handler(event, value);
appStore.commitProjectConfigState(config);
}
export function handler(event: HandlerEnum, value: any): DeepPartial<ProjectConfig> {
switch (event) {
case HandlerEnum.CHANGE_LAYOUT:
const { mode, type, split } = value;
const splitOpt = split === undefined ? { split } : {};
2020-11-24 22:59:29 +08:00
2020-11-10 22:45:39 +08:00
return {
menuSetting: {
mode,
type,
collapsed: false,
show: true,
2020-12-17 00:20:29 +08:00
hidden: false,
2020-11-10 22:45:39 +08:00
...splitOpt,
},
};
case HandlerEnum.MENU_HAS_DRAG:
2020-11-25 22:28:58 +08:00
return { menuSetting: { canDrag: value } };
2020-11-10 22:45:39 +08:00
case HandlerEnum.MENU_ACCORDION:
2020-11-24 22:59:29 +08:00
return { menuSetting: { accordion: value } };
2020-11-10 22:45:39 +08:00
case HandlerEnum.MENU_TRIGGER:
2020-11-24 22:59:29 +08:00
return { menuSetting: { trigger: value } };
2020-11-10 22:45:39 +08:00
case HandlerEnum.MENU_TOP_ALIGN:
2020-11-24 22:59:29 +08:00
return { menuSetting: { topMenuAlign: value } };
2020-11-10 22:45:39 +08:00
case HandlerEnum.MENU_COLLAPSED:
2020-11-24 22:59:29 +08:00
return { menuSetting: { collapsed: value } };
2020-11-10 22:45:39 +08:00
case HandlerEnum.MENU_WIDTH:
2020-11-24 22:59:29 +08:00
return { menuSetting: { menuWidth: value } };
2020-11-10 22:45:39 +08:00
case HandlerEnum.MENU_SHOW_SIDEBAR:
2020-11-24 22:59:29 +08:00
return { menuSetting: { show: value } };
2020-11-10 22:45:39 +08:00
case HandlerEnum.MENU_THEME:
updateSidebarBgColor(value);
2020-11-24 22:59:29 +08:00
return { menuSetting: { bgColor: value } };
2020-11-10 22:45:39 +08:00
case HandlerEnum.MENU_SPLIT:
2020-11-24 22:59:29 +08:00
return { menuSetting: { split: value } };
2020-12-21 23:38:16 +08:00
case HandlerEnum.MENU_CLOSE_MIX_SIDEBAR_ON_CHANGE:
return { menuSetting: { closeMixSidebarOnChange: value } };
2020-11-24 22:59:29 +08:00
case HandlerEnum.MENU_FIXED:
return { menuSetting: { fixed: value } };
2020-11-25 00:43:33 +08:00
// ============transition==================
2020-11-10 22:45:39 +08:00
case HandlerEnum.OPEN_PAGE_LOADING:
2020-11-24 22:59:29 +08:00
appStore.commitPageLoadingState(false);
2020-11-25 00:43:33 +08:00
return { transitionSetting: { openPageLoading: value } };
case HandlerEnum.ROUTER_TRANSITION:
return { transitionSetting: { basicTransition: value } };
2020-11-24 22:59:29 +08:00
2020-11-10 22:45:39 +08:00
case HandlerEnum.OPEN_ROUTE_TRANSITION:
2020-11-25 00:43:33 +08:00
return { transitionSetting: { enable: value } };
2020-11-24 22:59:29 +08:00
2020-11-25 00:43:33 +08:00
case HandlerEnum.OPEN_PROGRESS:
return { transitionSetting: { openNProgress: value } };
// ============root==================
2020-11-24 22:59:29 +08:00
2020-11-10 22:45:39 +08:00
case HandlerEnum.LOCK_TIME:
2020-11-24 22:59:29 +08:00
return { lockTime: value };
2020-11-10 22:45:39 +08:00
case HandlerEnum.FULL_CONTENT:
2020-11-24 22:59:29 +08:00
return { fullContent: value };
2020-11-10 22:45:39 +08:00
case HandlerEnum.CONTENT_MODE:
2020-11-24 22:59:29 +08:00
return { contentMode: value };
2020-11-10 22:45:39 +08:00
case HandlerEnum.SHOW_BREADCRUMB:
2020-11-24 22:59:29 +08:00
return { showBreadCrumb: value };
2020-11-10 22:45:39 +08:00
case HandlerEnum.SHOW_BREADCRUMB_ICON:
2020-11-24 22:59:29 +08:00
return { showBreadCrumbIcon: value };
2020-11-10 22:45:39 +08:00
case HandlerEnum.GRAY_MODE:
updateGrayMode(value);
2020-11-24 22:59:29 +08:00
return { grayMode: value };
case HandlerEnum.SHOW_FOOTER:
return { showFooter: value };
2020-11-10 22:45:39 +08:00
case HandlerEnum.COLOR_WEAK:
updateColorWeak(value);
2020-11-24 22:59:29 +08:00
return { colorWeak: value };
2020-11-10 22:45:39 +08:00
case HandlerEnum.SHOW_LOGO:
2020-11-24 22:59:29 +08:00
return { showLogo: value };
// ============tabs==================
2020-11-10 22:45:39 +08:00
case HandlerEnum.TABS_SHOW_QUICK:
2020-11-24 22:59:29 +08:00
return { multiTabsSetting: { showQuick: value } };
2020-11-10 22:45:39 +08:00
case HandlerEnum.TABS_SHOW:
2020-11-24 22:59:29 +08:00
return { multiTabsSetting: { show: value } };
2020-12-15 00:13:23 +08:00
case HandlerEnum.TABS_SHOW_REDO:
return { multiTabsSetting: { showRedo: value } };
2020-11-24 22:59:29 +08:00
// ============header==================
2020-11-10 22:45:39 +08:00
case HandlerEnum.HEADER_THEME:
updateHeaderBgColor(value);
2020-11-24 22:59:29 +08:00
return { headerSetting: { bgColor: value } };
2020-12-10 23:58:11 +08:00
case HandlerEnum.HEADER_SEARCH:
return { headerSetting: { showSearch: value } };
2020-11-10 22:45:39 +08:00
case HandlerEnum.HEADER_FIXED:
2020-11-24 22:59:29 +08:00
return { headerSetting: { fixed: value } };
2020-11-10 22:45:39 +08:00
case HandlerEnum.HEADER_SHOW:
2020-11-24 22:59:29 +08:00
return { headerSetting: { show: value } };
2020-11-10 22:45:39 +08:00
default:
return {};
}
}