logo点击五次后弹出:
/**
* Ant Design Pro v4 use `@ant-design/pro-layout` to handle Layout.
*
* @see You can view component api by: https://github.com/ant-design/ant-design-pro-layout
*/
import { Card, Input,Layout, message, Modal } from 'antd';
import { UploadOutlined } from '@ant-design/icons';
const { Footer } = Layout;
import type {
MenuDataItem,
BasicLayoutProps as ProLayoutProps,
Settings,
} from '@ant-design/pro-layout';
import ProLayout, { SettingDrawer } from '@ant-design/pro-layout';
import React, { useState, 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 { postLogoInfo, queryRenders, postReportInfo } from "@/services/user";
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) => {
// if(item.name == "Alarm"){
// item.unaccessible = true
// }
const localItem = {
...item,
children: item.children ? menuDataRender(item.children) : undefined,
};
return Authorized.check(item.authority, localItem, null) as MenuDataItem;
});
// const defaultFooterDom = (
// <DefaultFooter
// copyright={`2021 深圳金信诺高新技术股份有限公司出品`}
// 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,
// // },
// ]}
// />
// );
const BasicLayout: React.FC<BasicLayoutProps> = (props) => {
const [isSettingsModalVisible, setIsSettingsModalVisible] = useState(false);
const [logoClickCount, setLogoClickCount] = useState(0);
//const [logoData, seLogoData] = useState("");
const [logoData, seLogoData] = useState("");
const [isSettingsMode, setIsSettingsMode] = useState(false);
const [reportFrequency, setReportFrequency] = useState('');
const fileInputRef = useRef(null);
const {
dispatch,
children,
settings,
location = {
pathname: '/',
},
} = props;
const menuDataRef = useRef<MenuDataItem[]>([]);
useEffect(() => {
console.log("+=====++++=======")
getLogoInfo();
if (dispatch) {
dispatch({
type: 'user/fetchCurrent',
});
}
}, []);
/** Init variables */
const getLogoInfo = async () => {
const res = await queryRenders();
seLogoData(res?.data?.value);
}
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();
const onChange = e => {
setLogoClickCount((prevCount) => {
const newCount = prevCount + 1;
// 达到五次点击后显示Modal窗口
if (newCount === 5) {
setIsSettingsModalVisible(true);
return 0; // 重置点击次数
}
return newCount;
});
/* e.stopPropagation();
const input = document.createElement('input');
input.setAttribute('type', 'file');
input.setAttribute('multiple', true);
input.setAttribute('style', 'display:none');
input.addEventListener('change', handleInputChange);
document.body.appendChild(input);
input.click();*/
};
// 控制Modal关闭
const handleModalClose = () => {
setIsSettingsModalVisible(false);
};
// 在这里处理表单提交事件
const handleFormSubmit = (values) => {
console.log('Received values from form: ', values);
// 在这里可以进行设置参数和更换头像的逻辑处理
if (values.reportFrequency != ""){
console.log('xxxxxxxxxxxxxxxxxxxxxxxxx: ', values.reportFrequency)
postReportInfo(values.reportFrequency);
}
handleModalClose(); // 提交后关闭Modal
};
// 处理 logo 点击事件
const handleLogoClick = () => {
setLogoClickCount(prevCount => {
const newCount = prevCount + 1;
// 如果达到五次点击,启用设置模式
if (newCount === 5) {
toggleSettingsMode(true);
}
return newCount;
});
};
// 切换设置模式
const toggleSettingsMode = (enable) => {
setIsSettingsMode(enable);
// 重置logo点击次数
setLogoClickCount(0);
};
const handleInputChange = e => {
const files = e.target.files;
const reader = new FileReader();
reader.readAsDataURL(files[0]);
reader.onload = () => {
const base64Str = reader.result;
postLogoInfo(base64Str);
seLogoData(base64Str);
history.go(0);
};
};
// 定义键盘事件处理程序以启动设置模式
const handleKeyDown = (event) => {
if (event.ctrlKey && event.shiftKey && event.key === 'k') {
toggleSettingsMode(true);
}
};
// 连接和断开键盘事件处理程序
useEffect(() => {
window.addEventListener('keydown', handleKeyDown);
// 当组件卸载时不要忘记清除
return () => window.removeEventListener('keydown', handleKeyDown);
}, []);
return (
<div
// style={{sss
// height: '200vh',
// }}
>
<ProLayout
logo={logoData}
formatMessage={formatMessage}
{...props}
{...settings}
onCollapse={handleMenuCollapse}
onMenuHeaderClick={handleLogoClick}
/*
onMenuHeaderClick={() => history.push('/Monitor/Dashboard')}
*/
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={(router = {}) => {
// if (router.component) {
// return <Link to={router.path}>{router.breadcrumbName}</Link>
// }
// return router.breadcrumbName
// }}
// itemRender={(route, params, routes, paths) => {
// const first = routes.indexOf(route) === 0;
// return first ? (
// <Link to={paths.join(route.path)}>{route.breadcrumbName}</Link>
// ) : (
// <span>{route.breadcrumbName}</span>
// );
// }}
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={() => {
if (settings.footerRender || settings.footerRender === undefined) {
return (<Footer style={{ textAlign: 'center' }}>Copyright © 2020-2023 Kingsignal Technology Co., Ltd. All rights reserved.</Footer>)
// defaultFooterDom
// (<Footer style={{ textAlign: 'center'}}>Copyright © 2021 LEAX Arkivator Telecom. All rights reserved.</Footer>)
}
return null;
}}
menuDataRender={menuDataRender}
rightContentRender={() => <RightContent />}
postMenuData={(menuData) => {
menuDataRef.current = menuData || [];
return menuData || [];
}}
// waterMarkProps={{
// content: 'Ant Design Pro',
// fontColor: 'rgba(24,144,255,0.15)',
// }}
>
<Authorized authority={authorized!.authority} noMatch={noMatch}>
{children}
</Authorized>
</ProLayout>
<Modal
title="Edit Logo or Set Report Frequency"
visible={isSettingsMode}
onCancel={() => setIsSettingsMode(false)}
onOk={() => handleFormSubmit({
logo: logoData,
reportFrequency: reportFrequency
})}
>
<Card bordered={false}>
{logoData && <img src={logoData} alt="Preview Logo" style={{ height: '100px', marginBottom: '10px' }} />}
<br></br>
<input
type="file"
onChange={handleInputChange}
style={{ display: 'none' }}
ref={fileInputRef}
/>
<Button
type="primary"
icon={<UploadOutlined />}
onClick={() => fileInputRef.current && fileInputRef.current.click()}
>
Change Logo
</Button>
<p></p>
<Input
placeholder="Report Frequency"
value={reportFrequency}
onChange={(e) => setReportFrequency(e.target.value)}
/>
</Card>
</Modal>
<SettingDrawer
settings={settings}
onSettingChange={(config) =>
dispatch({
type: 'settings/changeSetting',
payload: config,
})
}
/>
</div>
);
};
export default connect(({ global, settings }: ConnectState) => ({
collapsed: global.collapsed,
settings,
}))(BasicLayout);