import { Effect, Reducer } from '@umijs/max'; import { queryCurrent, query as queryUsers } from '@/services/user'; export interface CurrentUser { avatar?: string; name?: string; title?: string; group?: string; signature?: string; tags?: { key: string; label: string; }[]; userid?: string; unreadCount?: number; } export interface UserModelState { currentUser?: CurrentUser; menuData?: any[]; pathKeyMap?: Map; } export interface UserModelType { namespace: 'user'; state: UserModelState; effects: { fetch: Effect; fetchCurrent: Effect; }; reducers: { saveCurrentUser: Reducer; changeNotifyCount: Reducer; saveMenuData: Reducer; }; } const UserModel: UserModelType = { namespace: 'user', state: { currentUser: {}, menuData: [], pathKeyMap: new Map(), }, effects: { *fetch(_, { call, put }) { const response = yield call(queryUsers); yield put({ type: 'save', payload: response, }); }, *fetchCurrent(_, { call, put }) { const response = yield call(queryCurrent); yield put({ type: 'saveCurrentUser', payload: response, }); }, }, reducers: { saveCurrentUser(state, action) { return { ...state, currentUser: action.payload || {}, }; }, saveMenuData(state, action) { const menuData = action.payload || []; const pathKeyMap = new Map(); // 将menuData转换为pathKeyMap 递归处理 const convertToPathKeyMap = (menuData: any[]) => { menuData.forEach((item: any) => { const path = item.path ? item.path.toLowerCase() : ''; pathKeyMap.set(path, {name: item.name, icon: item.icon}); if (item.children) { convertToPathKeyMap(item.children); } }); }; convertToPathKeyMap(menuData); pathKeyMap.set('/dashboard', { name: '首页' }); return { ...state, menuData: action.payload || [], pathKeyMap, }; }, changeNotifyCount( state = { currentUser: {}, }, action, ) { return { ...state, currentUser: { ...state.currentUser, notifyCount: action.payload.totalCount, unreadCount: action.payload.unreadCount, }, }; }, }, }; export default UserModel;