#
Junjie
2024-10-17 d835d1b51f832889929cdf69010034a30ef44d02
zy-asrs-flow/src/App.jsx
@@ -1,5 +1,5 @@
import React from 'react';
import { Footer, Question, SelectLang, AvatarDropdown, AvatarName, Brightness } from '@/components';
import { Footer, Question, SelectLang, AvatarDropdown, AvatarName, Brightness, LayoutSwitch, FullScreen } from '@/components';
import { LinkOutlined } from '@ant-design/icons';
import { SettingDrawer } from '@ant-design/pro-components';
import { history, Link } from '@umijs/max';
@@ -8,7 +8,7 @@
import { getRemoteMenu, getRoutersInfo, getUserInfo, setRemoteMenu, patchRouteWithRemoteMenus } from './services/route';
import { getToken, setToken } from '@/utils/token-util'
import { TOKEN_HEADER_NAME, TOKEN_STORE_NAME } from '@/config/setting';
import { API_BASE_URL } from '@/config/setting'
import { API_BASE_URL, API_TIMEOUT } from '@/config/setting'
import { message } from 'antd';
import logo from '../public/img/logo.png'
@@ -85,18 +85,29 @@
// 优先级 layout > config > defaultSetting
export const layout = ({ initialState, setInitialState }) => {
  const [darkMode, setDarkMode] = React.useState(() => {
    return JSON.parse(localStorage.getItem('darkMode')) || true;
    const storedValue = localStorage.getItem('darkMode');
    return storedValue !== null ? JSON.parse(storedValue) : false;
  });
  const [layoutMode, setLayoutMode] = React.useState(() => {
    const storedValue = localStorage.getItem('layoutMode');
    return storedValue !== null ? JSON.parse(storedValue) : true;
  });
  const [fullScreen, setFullScreen] = React.useState(false);
  React.useEffect(() => {
    localStorage.setItem('darkMode', JSON.stringify(darkMode));
  }, [darkMode]);
    localStorage.setItem('layoutMode', JSON.stringify(layoutMode));
  }, [darkMode, layoutMode]);
  return {
    actionsRender: () => [
      <Brightness darkMode={darkMode} setDarkMode={setDarkMode} />,
      // <Question key="doc" />,
      // <SelectLang key="SelectLang" />
      <SelectLang key="SelectLang" />,
      <FullScreen fullScreen={fullScreen} setFullScreen={setFullScreen} />,
      <LayoutSwitch layoutMode={layoutMode} setLayoutMode={setLayoutMode} />,
      <Brightness darkMode={darkMode} setDarkMode={setDarkMode} />,
    ],
    avatarProps: {
      src: initialState?.currentUser?.avatar,
@@ -187,7 +198,7 @@
      );
    },
    ...initialState?.settings,
    layout: 'top',  // layout 的菜单模式,side:右侧导航,top:顶部导航
    layout: layoutMode ? 'top' : 'mix',  // layout 的菜单模式,side:右侧导航,top:顶部导航
    // contentStyle: () => {  //    layout 的内容区 style
    //   return 
    // },
@@ -220,7 +231,7 @@
export const request = {
  baseURL: API_BASE_URL,
  ...errorConfig,
  timeout: 60000,
  timeout: API_TIMEOUT * 1000,
  // 前置守卫
  requestInterceptors: [
    (url, options) => {