|  |  |  | import { createStore as create } from 'vuex'; | 
					
						
							|  |  |  | import { Styles, Size } from '../config'; | 
					
						
							|  |  |  | import { getByCodes, getMenus, logout, getActions } from '../api/public'; | 
					
						
							|  |  |  | import { mapping } from '../api/role'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export class State { | 
					
						
							|  |  |  |   dict = { | 
					
						
							|  |  |  |     active_status: { | 
					
						
							|  |  |  |       A: '启用', | 
					
						
							|  |  |  |       B: '禁用', | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  |   roles = {}; | 
					
						
							|  |  |  |   menus = []; | 
					
						
							|  |  |  |   roleRefresh = true; | 
					
						
							|  |  |  |   style = Styles.plain; | 
					
						
							|  |  |  |   size = Size.normal; | 
					
						
							|  |  |  |   actions = []; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export class Actions { | 
					
						
							|  |  |  |   getDictMap = ({ state, commit }, codes) => { | 
					
						
							|  |  |  |     if (codes == null) { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     const arr: Array<any> = []; | 
					
						
							|  |  |  |     for (let i = 0; i < codes.length; i++) { | 
					
						
							|  |  |  |       const code = codes[i]; | 
					
						
							|  |  |  |       state.dict[code] || arr.push(code); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (arr.length == 0) { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     getByCodes({ codes: arr.join() }).then((rsp: any) => { | 
					
						
							|  |  |  |       if (rsp) { | 
					
						
							|  |  |  |         for (let i = 0; i < arr.length; i++) { | 
					
						
							|  |  |  |           const key = arr[i]; | 
					
						
							|  |  |  |           const dict = {}; | 
					
						
							|  |  |  |           if (rsp[key]) { | 
					
						
							|  |  |  |             rsp[key].forEach((item) => { | 
					
						
							|  |  |  |               dict[item.code] = item.name; | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           commit('updateDict', [key, dict]); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  |   getRoleMap = ({ state, commit }) => { | 
					
						
							|  |  |  |     state.roleRefresh && | 
					
						
							|  |  |  |       mapping().then((rsp) => { | 
					
						
							|  |  |  |         commit('updateState', ['roles', rsp]); | 
					
						
							|  |  |  |         commit('updateState', ['roleRefresh', false]); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  |   getMenus = ({ state, commit }) => { | 
					
						
							|  |  |  |     getMenus().then((rsp) => commit('updateState', ['menus', rsp])); | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  |   getMyActions = ({ state, commit }, content) => { | 
					
						
							|  |  |  |     getActions(content).then((rsp) => commit('updateState', ['actions', rsp])); | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  |   login = (store) => { | 
					
						
							|  |  |  |     const { state, commit } = store; | 
					
						
							|  |  |  |     state.size.headHeight = state.size.head + 'px'; | 
					
						
							|  |  |  |     state.size.asideWidth = state.size.aside + 'px'; | 
					
						
							|  |  |  |     commit('initSize'); | 
					
						
							|  |  |  |     this.getMenus(store); | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export class Mutations { | 
					
						
							|  |  |  |   updateState = (state, param) => { | 
					
						
							|  |  |  |     state[param[0]] = param[1]; | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  |   initSize = (state, param) => { | 
					
						
							|  |  |  |     const size = state.size; | 
					
						
							|  |  |  |     const aside = parseInt(size.asideWidth); | 
					
						
							|  |  |  |     const head = parseInt(size.headHeight); | 
					
						
							|  |  |  |     const mainPad = parseInt(size.mainPad); | 
					
						
							|  |  |  |     const searchRow = parseInt(size.searchRowHeight); | 
					
						
							|  |  |  |     const searchRowPad = parseInt(size.searchRowPad); | 
					
						
							|  |  |  |     const headRightWidth = parseInt(size.headRightWidth); | 
					
						
							|  |  |  |     if (param) { | 
					
						
							|  |  |  |       size.height = param[0]; | 
					
						
							|  |  |  |       size.width = param[1]; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     size.mainHeight = Math.floor(size.height - head) + 'px'; | 
					
						
							|  |  |  |     size.tableHeight = size.height - 2 * (mainPad + searchRowPad) - 3 - searchRow - head; | 
					
						
							|  |  |  |     size.pTableHeight = size.tableHeight - size.pageHeight; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     size.headLeftWidth = size.width - aside - headRightWidth - 20 + 'px'; | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  |   updateDict = (state, param) => { | 
					
						
							|  |  |  |     state.dict[param[0]] = param[1]; | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export class Getters { | 
					
						
							|  |  |  |   menuIconSize = (state) => { | 
					
						
							|  |  |  |     return state.size.menuIconSize; | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export interface StoreOptions { | 
					
						
							|  |  |  |   state?: State; | 
					
						
							|  |  |  |   getters?: Getters; | 
					
						
							|  |  |  |   actions?; | 
					
						
							|  |  |  |   mutations?: Mutations; | 
					
						
							|  |  |  |   modules?; | 
					
						
							|  |  |  |   plugins?; | 
					
						
							|  |  |  |   strict?: boolean; | 
					
						
							|  |  |  |   devtools?: boolean; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const createStore = (options) => { | 
					
						
							|  |  |  |   return create(options); | 
					
						
							|  |  |  | }; |