import Footer from '@/components/Footer'; import RightContent from '@/components/RightContent'; import { SettingDrawer } from '@ant-design/pro-components'; import { history, Link, matchRoutes } from '@umijs/max'; import defaultSettings from '../config/defaultSettings'; import { queryCurrentUser, getMenu } from './services/login'; import TagView from '@/components/TagView'; import SiderMenu from '@/components/SiderMenu'; import * as Ant4Icons from '@ant-design/icons'; import { createElement } from 'react'; const { LinkOutlined } = Ant4Icons; const isDev = process.env.NODE_ENV === 'development'; const loginPath = '/user/login'; /** * @see https://umijs.org/zh-CN/plugins/plugin-initial-state * */ function strToHump(str) { let strArr = str.split('-'); for (let i = 0; i < strArr.length; i++) { strArr[i] = strArr[i].charAt(0).toUpperCase() + strArr[i].substr(1); } let res = strArr.join(''); return res + 'Outlined'; } export async function getInitialState() { console.log(history); let token = localStorage.getItem('TOKENES'); const fetchUserInfo = async () => { try { const msg = await queryCurrentUser(); return msg.data; } catch (error) { // history.push(loginPath); } return undefined; }; // 如果是登录页面,不执行 const getmenuData = async () => { try { const res = await getMenu(); return res.data; } catch (error) { message.error(res.msg); } return undefined; }; // 如果是登录页面,不执行 if (history.location.pathname !== loginPath && token) { console.log(3); const currentUserData = await fetchUserInfo(); let menuData; if (currentUserData?.data?.username) { console.log(1); menuData = await getmenuData(); } return { fetchUserInfo, currentUser: currentUserData?.data, settings: defaultSettings, newMenu: menuData, getmenuData, collapsed: false, }; } return { fetchUserInfo, settings: defaultSettings, getmenuData, collapsed: false, tagList: [], }; } // ProLayout 支持的api https://procomponents.ant.design/components/layout export const layout = ({ initialState, setInitialState }) => { let token = localStorage.getItem('TOKENES'); return { disableContentMargin: false, waterMarkProps: { content: initialState?.currentUser?.name, }, collapsed: initialState.collapsed, onCollapse: (cols) => { setInitialState((s) => ({ ...s, collapsed: cols })); }, footerRender: () =>