123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 |
- /**
- * Ant Design Pro v4 use `@ant-design/pro-layout` to handle Layout.
- * You can view component api by:
- * https://github.com/ant-design/ant-design-pro-layout
- */
- import type {
- MenuDataItem,
- BasicLayoutProps as ProLayoutProps,
- Settings,
- } from '@ant-design/pro-layout';
- import ProLayout, { SettingDrawer } from '@ant-design/pro-layout';
- import React, { useEffect, useMemo, useRef } from 'react';
- import type { Dispatch } from 'umi';
- import { Link, useIntl, connect, history } from 'umi';
- import { Result, Button } from 'antd';
- import Authorized from '@/utils/Authorized';
- import RightContent from '@/components/GlobalHeader/RightContent';
- import type { ConnectState } from '@/models/connect';
- import { getMatchMenu } from '@umijs/route-utils';
- import { BASE_URL } from '@/utils/eventkey';
- const noMatch = (
- <Result
- status={403}
- title="403"
- subTitle="Sorry, you are not authorized to access this page."
- extra={
- <Button type="primary">
- <Link to="/user/login">Go Login</Link>
- </Button>
- }
- />
- );
- export type BasicLayoutProps = {
- breadcrumbNameMap: Record<string, MenuDataItem>;
- route: ProLayoutProps['route'] & {
- authority: string[];
- };
- settings: Settings;
- dispatch: Dispatch;
- } & ProLayoutProps;
- export type BasicLayoutContext = { [K in 'location']: BasicLayoutProps[K] } & {
- breadcrumbNameMap: Record<string, MenuDataItem>;
- };
- /**
- * use Authorized check all menu item
- */
- const menuDataRender = (menuList: MenuDataItem[]): MenuDataItem[] =>
- menuList.map((item) => {
- const localItem = {
- ...item,
- children: item.children ? menuDataRender(item.children) : undefined,
- };
- return Authorized.check(item.authority, localItem, null) as MenuDataItem;
- });
- const defaultFooterDom = (
- // <DefaultFooter
- // copyright={`${new Date().getFullYear()} 蚂蚁集团体验技术部出品`}
- // links={[
- // {
- // key: 'Ant Design Pro',
- // title: 'Ant Design Pro',
- // href: 'https://pro.ant.design',
- // blankTarget: true,
- // },
- // {
- // key: 'github',
- // title: <GithubOutlined />,
- // href: 'https://github.com/ant-design/ant-design-pro',
- // blankTarget: true,
- // },
- // {
- // key: 'Ant Design',
- // title: 'Ant Design',
- // href: 'https://ant.design',
- // blankTarget: true,
- // },
- // ]}
- // />
- <span></span>
- );
- const BasicLayout: React.FC<BasicLayoutProps> = (props) => {
- const {
- dispatch,
- children,
- settings,
- location = {
- pathname: '/',
- },
- } = props;
- const menuDataRef = useRef<MenuDataItem[]>([]);
- useEffect(() => {
- console.log('hello');
- if (!window.localStorage.getItem('token')) {
- if (process.env.NODE_ENV === 'development') {
- window.location.href = `${BASE_URL}/#/user/login`;
- } else {
- const { origin } = window.location;
- window.location.href = `${origin}/tieba-admin/#/user/login`;
- }
- }
- // if (dispatch) {
- // dispatch({
- // type: 'user/fetchCurrent',
- // });
- // }
- }, []);
- /**
- * init variables
- */
- const handleMenuCollapse = (payload: boolean): void => {
- if (dispatch) {
- dispatch({
- type: 'global/changeLayoutCollapsed',
- payload,
- });
- }
- }; // get children authority
- const authorized = useMemo(
- () =>
- getMatchMenu(location.pathname || '/', menuDataRef.current).pop() || {
- authority: undefined,
- },
- [location.pathname],
- );
- const { formatMessage } = useIntl();
- return (
- <>
- <ProLayout
- menu={{ locale: false }}
- // logo={logo}
- formatMessage={formatMessage}
- {...props}
- {...settings}
- onCollapse={handleMenuCollapse}
- onMenuHeaderClick={() => history.push('/')}
- menuItemRender={(menuItemProps, defaultDom) => {
- if (
- menuItemProps.isUrl ||
- !menuItemProps.path ||
- location.pathname === menuItemProps.path
- ) {
- return defaultDom;
- }
- return <Link to={menuItemProps.path}>{defaultDom}</Link>;
- }}
- breadcrumbRender={(routers = []) => [
- {
- path: '/',
- breadcrumbName: formatMessage({
- id: 'menu.home',
- }),
- },
- ...routers,
- ]}
- itemRender={(route, params, routes, paths) => {
- const first = routes.indexOf(route) === 0;
- return first ? (
- <Link to={paths.join('/')}>{route.breadcrumbName}</Link>
- ) : (
- <span>{route.breadcrumbName}</span>
- );
- }}
- footerRender={() => defaultFooterDom}
- menuDataRender={menuDataRender}
- rightContentRender={() => <RightContent />}
- postMenuData={(menuData) => {
- menuDataRef.current = menuData || [];
- return menuData || [];
- }}
- >
- <Authorized authority={authorized!.authority} noMatch={noMatch}>
- {children}
- </Authorized>
- </ProLayout>
- <SettingDrawer
- settings={settings}
- onSettingChange={(config) =>
- dispatch({
- type: 'settings/changeSetting',
- payload: config,
- })
- }
- />
- </>
- );
- };
- export default connect(({ global, settings }: ConnectState) => ({
- collapsed: global.collapsed,
- settings,
- }))(BasicLayout);
|