This commit is contained in:
2024-01-16 19:59:54 +08:00
parent 7b68496aa1
commit b1d6d8c175
8 changed files with 102 additions and 5 deletions

View File

@@ -117,7 +117,7 @@ const App = (props: AppProps) => {
{!responsive.isMobile && checkLogin(auth.permissions) && (
<SiderCustom collapsed={collapsed} />
)}
<ThemePicker />
{/* <ThemePicker /> */}
<Layout
className={classNames('app_layout', { 'app_layout-mobile': responsive.isMobile })}
>

View File

@@ -35,6 +35,7 @@ import Home from './visualize/Home';
import UserManage from './management/UserManage';
import BlankPage from './management/BlankPage';
import StationInfo from './station/StationInfo';
import PredictInfo from './station/PredictInfo';
const WysiwygBundle = Loadable({
// 按需加载富文本配置
@@ -75,4 +76,5 @@ export default {
UserManage,
BlankPage,
StationInfo,
PredictInfo,
} as any;

View File

@@ -0,0 +1,30 @@
import { Tabs, Select, Image } from 'antd';
import React from 'react';
import predict from './predict.png';
const durationSelect = () => {
const options = [
{ value: '15', label: '15min' },
{ value: '30', label: '30min' },
{ value: '60', label: '60min' },
];
return <Select defaultValue="15" style={{ width: 120 }} options={options} />;
};
const StationInfo = () => {
return (
<Tabs defaultActiveKey="1" tabBarExtraContent={durationSelect()}>
<Tabs.TabPane tab="FS8" key="1">
<Image style={{ maxWidth: '90%' }} src={predict} />
</Tabs.TabPane>
<Tabs.TabPane tab="FT10" key="2">
<Image style={{ maxWidth: '90%' }} src={predict} />
</Tabs.TabPane>
<Tabs.TabPane tab="ST11" key="3">
<Image style={{ maxWidth: '98%' }} src={predict} />
</Tabs.TabPane>
</Tabs>
);
};
export default StationInfo;

View File

@@ -1,4 +1,4 @@
import { Card } from 'antd';
import { Card, Image } from 'antd';
import React from 'react';
type StationInfoProps = {
@@ -7,10 +7,61 @@ type StationInfoProps = {
const StationInfo = (props: StationInfoProps) => {
console.log(props.query.param1);
const stationPics: Map<string, Array<string>> = new Map([
[
'F3',
[
'https://upload.wikimedia.org/wikipedia/commons/thumb/c/c2/Exit_2_of_Qiaojiahu_Station%2C_Xuzhou_Metro.jpg/1280px-Exit_2_of_Qiaojiahu_Station%2C_Xuzhou_Metro.jpg',
'https://pic.baike.soso.com/ugc/baikepic2/0/20191116064847-556402123_jpeg_1280_960_113270.jpg/0_90',
],
],
[
'FS8',
[
'https://upload.wikimedia.org/wikipedia/commons/3/39/Interchange_tunnel_to_Line_1%27s_platform_at_end_of_Line_2_platform_of_Pengchengguangchang_Station%2C_Xuzhou_Metro.jpg',
'https://upload.wikimedia.org/wikipedia/commons/4/49/Exit_9_of_Pengchengguangchang_Station%2C_Xuzhou_Metro.jpg',
],
],
]);
const images = stationPics.get(props.query.station) || [];
const errorImg =
'';
if (props.query == undefined || props.query.station == undefined) {
return (
<div>
<Card title="站点信息">
<p></p>
</Card>
</div>
);
}
return (
<div>
<Card title="站点信息">
<p>{props.query.t}</p>
<Card title={props.query.station + ' 站点信息'}>
<p>
xx站是一个现代化的地铁站便便xx站不仅是徐州市民的重要交通枢纽
</p>
<p> {props.query.station}</p>
<p> xx省 xx市 xx区 xx路 xxx号</p>
<p>{Math.floor(Math.random() * 5) + 1}</p>
<p>: {Math.floor(Math.random() * 100)}</p>
<p>: {Math.floor(Math.random() * 100)}</p>
<p>:</p>
{images.length > 0 ? (
images.map((url, index) => (
<Image
width={200}
key={index}
src={url}
alt={'Image ' + (index + 1)}
fallback={errorImg}
/>
))
) : (
<p></p>
)}
</Card>
</div>
);

Binary file not shown.

After

Width:  |  Height:  |  Size: 95 KiB

View File

@@ -11,7 +11,7 @@ import React from 'react';
const Copyright = () => {
return (
<div>
react-admin ©{new Date().getFullYear()} Created by yezihaohao@yezi.haohao@foxmail.com
{/* react-admin ©{new Date().getFullYear()} Created by yezihaohao@yezi.haohao@foxmail.com */}
</div>
);
};

View File

@@ -157,10 +157,17 @@ const menus: {
icon: 'bars',
component: 'StationInfo',
},
{
key: '/app/predict',
title: '人流预测',
icon: 'bars',
component: 'PredictInfo',
},
{
key: '/app/manage',
title: '管理',
icon: 'bars',
showAuth: 'auth/admin',
subs: [
{
key: '/app/manage/user',

View File

@@ -34,6 +34,13 @@ const CRouter = (props: CRouterProps) => {
}
return permit ? requireAuth(permit, component) : component;
};
const showAuth = (permit: any, component: React.ReactElement) => {
const permits = getPermits();
if (!permits || !permits.includes(permit)) return null;
return component;
};
const createMenu = (r: IFMenu) => {
const route = (r: IFMenuBase) => {
const Component = r.component && AllComponents[r.component];