import { Environment } from '@/environments/environment'; /** * 添加部门成员 * * @param state * @param codelists */ export const addDepartmentPersonnel = (state: any, departmentPersonnel: Array<any>) => { state.departmentPersonnel = []; state.departmentPersonnel = [...departmentPersonnel]; } /** * 添加代码表 * * @param state * @param codelists */ export const addCodeLists = (state: any, codelists: any) => { state.codelists = []; state.codelists = [...codelists]; } /** * 添加本地应用数据 * * @param state * @param localdata */ export const addLocalData = (state: any, localdata: any = {}) => { Object.assign(state.localdata, localdata); localStorage.setItem('localdata',JSON.stringify(state.localdata)); } /** * 添加应用数据 * * @param state * @param localdata */ export const addAppData = (state: any, appdata: string) => { state.appdata = appdata; } /** * 修改应用数据 * * @param state * @param localdata */ export const updateAppData = (state: any, appdata: string) => { state.appdata = appdata; } /** * 更新代码表值 * * @param state * @param param1 */ export const updateCodeList = (state: any, { srfkey, items }: { srfkey: string, items: any[] }) => { const index = state.codelists.findIndex((_codelist: any) => Object.is(_codelist.srfkey, srfkey)); if (index === -1) { console.log(`${srfkey} ---- 代码表不存在`); return; } state.codelists[index].items = [...items]; } /** * 修改主题 * * @param state * @param val */ export const setCurrentSelectTheme = (state: any, val: any) => { state.selectTheme = val; } /** * 修改字体 * * @param state * @param val */ export const setCurrentSelectFont = (state: any, val: any) => { state.selectFont = val; } /** * 重置分页导航数据 * * @param state */ export const resetRootStateData = (state: any) => { state.pageTagList = []; state.pageMetas = []; state.historyPathList = []; } /** * 添加导航页面 * * @param state * @param arg */ export const addPage = (state: any, arg: any) => { if (!arg) { return; } // 视图类型为REDIRECTVIEW和NOTAB的视图不添加缓存 if(Object.is(arg.meta.viewType, 'REDIRECTVIEW') || Object.is(arg.meta.viewType, 'NOTAB')){ return; }else if (Object.is(arg.meta.viewType, 'APPINDEX')) { window.sessionStorage.setItem(Environment.AppName, arg.fullPath); } else { const page: any = {}; const pageMeta: any = {}; Object.assign(page, arg); Object.assign(pageMeta, page.meta, { info: null }); const index = state.pageTagList.findIndex((tag: any) => Object.is(tag.fullPath, page.fullPath)); if (index < 0) { state.pageTagList.push(page); state.pageMetas.push(pageMeta); } else { const index2 = state.historyPathList.indexOf(page.fullPath); if (index2 >= 0) { state.historyPathList.splice(index2, 1); } } state.historyPathList.push(page.fullPath); } } /** * 删除导航页面 * * @param state * @param arg */ export const deletePage = (state: any, arg: any) => { let delPage: any = null; if (isNaN(arg)) { const index = state.pageTagList.findIndex((page: any) => Object.is(page.fullPath, arg)); if (index >= 0) { delPage = state.pageTagList[index]; state.pageTagList.splice(index, 1); state.pageMetas.splice(index, 1); } } else { delPage = state.pageTagList[arg]; state.pageTagList.splice(arg, 1); state.pageMetas.splice(arg, 1); } const index = state.historyPathList.findIndex((path: any) => Object.is(path, delPage.fullPath)); if (index >= 0) { state.historyPathList.splice(index, 1); } } /** * 设置导航页面 * * @param state * @param arg */ export const setCurPage = (state: any, arg: any) => { let page: any = null; if (isNaN(arg)) { const index = state.pageTagList.findIndex((page: any) => Object.is(page.fullPath, arg)); if (index >= 0) { page = state.pageTagList[index]; } } else { page = state.pageTagList[arg]; } if (page) { const index = state.historyPathList.findIndex((path: any) => Object.is(path, page.fullPath)); if (index >= 0) { state.historyPathList.splice(index, 1); state.historyPathList.push(page.fullPath); } } } /** * 设置导航页面标题 * * @param state * @param param1 */ export const setCurPageCaption = (state: any, { route, caption, info }: { route: any, caption: string | null, info: string | null }) => { if (route) { const index = state.pageTagList.findIndex((page: any) => Object.is(page.fullPath, route.fullPath)); if (index >= 0) { state.pageMetas[index].caption = caption; state.pageMetas[index].info = info; } } } /** * 添加当前视图视图标识 * * @param state * @param param1 */ export const addCurPageViewtag = (state: any, { fullPath, viewtag }: { fullPath: string, viewtag: string }) => { const index = state.pageTagList.findIndex((page: any) => Object.is(page.fullPath, fullPath)); if (index >= 0) { state.pageTagList[index].viewtag = viewtag; } } /** * 删除所有导航页面 * * @param state */ export const removeAllPage = (state: any) => { if (state.pageTagList.length > 0) { state.pageMetas = []; state.pageTagList = []; state.historyPathList = []; } } /** * 删除其他导航页面 * * @param state */ export const removeOtherPage = (state: any) => { if (state.historyPathList.length > 0) { const curPath = state.historyPathList[state.historyPathList.length - 1]; const index = state.pageTagList.findIndex((page: any) => Object.is(page.fullPath, curPath)); if (index >= 0) { const page = state.pageTagList[index]; const meta: any = {}; Object.assign(meta, page.meta); state.pageTagList = []; state.pageMetas = []; state.historyPathList = []; state.historyPathList.push(page.fullPath); state.pageTagList.push(page); state.pageMetas.push(meta); } } } /** * 更新 z-index * * @param state * @param zIndex */ export const updateZIndex = (state: any, zIndex: number) => { state.zIndex = zIndex; } /** * 设置视图split * * @param state * @param {viewSplit: number, viewUID: string} */ export const setViewSplit = (state: any, args: {viewSplit: number,viewUID:string}) => { state.viewSplit[args.viewUID] = args.viewSplit; } /** * 添加单位数据 * * @param state * @param args */ export const addOrgData = (state: any, args: {srfkey: string,orgData: any}) => { if(args && args.srfkey && args.orgData){ state.orgDataMap[args.srfkey] = JSON.parse(JSON.stringify(args.orgData)); } } /** * 添加部门数据 * * @param state * @param args */ export const addDepData = (state: any, args: {srfkey: string,depData: any}) => { if(args && args.srfkey && args.depData){ state.depDataMap[args.srfkey] = JSON.parse(JSON.stringify(args.depData)); } } /** * 添加视图信息 * * @param state * @param args */ export const addViewMessage = (state: any, args: { tag: string, id: any }) => { if(args && args.tag && args.id) { state.viewMessage[args.tag] = args.id; } }