import React, { PureComponent } from 'react'; import { Spin } from 'antd'; import { enquireScreen } from 'enquire-js'; import { connect } from 'dva'; import BasicLayout from './BasicLayout'; import { getMenuData } from '../common/menu'; /** * 根据菜单取得重定向地址. */ const MenuData = getMenuData(); const getRedirectData = () => { const redirectData = []; const getRedirect = (item) => { if (item && item.children) { if (item.children[0] && item.children[0].path) { redirectData.push({ from: `${item.path}`, to: `${item.children[0].path}`, }); item.children.forEach((children) => { getRedirect(children); }); } } }; MenuData.forEach(getRedirect); return redirectData; }; const redirectData = getRedirectData(); class LodingPage extends PureComponent { state = { loading: true, isMobile: false, }; componentDidMount() { enquireScreen((mobile) => { this.setState({ isMobile: mobile, }); }); this.props.dispatch({ type: 'user/fetchCurrent', }); const urlParams = new URL(window.location.href); const settingString = urlParams.searchParams.get('setting'); if (settingString) { const setting = {}; settingString.split(';').forEach((keyValue) => { const [key, value] = keyValue.split(':'); setting[key] = value; }); this.props.dispatch({ type: 'setting/changeSetting', payload: setting, }); } this.hideLoading(); } hideLoading() { this.setState({ loading: false, }); } render() { if (this.state.loading) { return (
); } return ( ); } } export default connect()(LodingPage);