import { connect } from 'react-redux'; import './protable.less' import { Card, Button, Popconfirm, Badge, Col, Row, DatePicker, Input } from 'antd'; import ProTable from '@ant-design/pro-table'; // import { Badge, Button } from 'antd'; import React, { useEffect, useState } from 'react'; // @ts-ignore import styles from './protable.less'; const DetailList = (props) => { const { patrolName } = props; const [tableListDataSource, setTableListDataSource] = useState([]); const columns = [ { title: '问题编号', key: 'num', dataIndex: 'num', align: 'center' }, { title: '所属道路', key: 'road', dataIndex: 'road', align: 'center' }, { title: '所在路段', key: 'address', dataIndex: 'address', align: 'center' }, { title: '缺陷名称', key: 'name', dataIndex: 'name', align: 'center' }, { title: '巡查人', width: 100, key: 'patrolName', dataIndex: 'patrolName', align: 'center' }, { title: '上报时间', key: 'createdAt', dataIndex: 'createdAt', valueType: 'dateTime', align: 'center' }, { title: '操作', width: 200, key: 'option', valueType: 'option', align: 'center', render: () => [, ] }, ]; useEffect(() => { const source = []; for (let i = 0; i < 25; i += 1) { source.push({ num: `${i + 1}`, road: `成华大道${i + 2}`, address: `二仙桥${i + 3}`, name: `缺失内容${i + 4}`, patrolName: patrolName, createdAt: Date.now() - Math.floor(Math.random() * 10000), key: i, }); } setTableListDataSource(source); }, [patrolName]); return ( ); }; const patrolNameListDataSource = []; for (let i = 0; i < 10; i += 1) { patrolNameListDataSource.push({ patrolName: `老大爷${i}`, }); } const PatrolNameList = (props) => { const { onChange, patrolName } = props; const columns = [ { title: '巡更人员', key: 'patrolName', dataIndex: 'patrolName', align: 'center' }, ]; return (
{ // 表单搜索项会从 params 传入,传递给后端接口。 console.log(params, sorter, filter); return Promise.resolve({ data: patrolNameListDataSource, success: true, }); }} rowKey="patrolName" rowClassName={(record) => { return record.patrolName === patrolName ? styles['split-row-select-active'] : ''; }} // toolbar={{ // search: { // onSearch: (value) => { // alert(value); // }, // }, // }} toolBarRender={() => [ ]} options={false} pagination={false} search={false} onRow={(record) => { return { onClick: () => { if (record.patrolName) { onChange(record.patrolName); } }, }; }} />
); }; const PatrolTable = () => { const [patrolName, setPatrolName] = useState('老大爷0'); const { RangePicker } = DatePicker; const tabList = [ { key: 'tab1', tab: '巡更', }, { key: 'tab2', tab: '巡更轨迹查询', }, ]; const contentList = { tab1: [
] }; const [activeTabKey1, setActiveTabKey1] = useState('tab1'); const onTab1Change = (key) => { setActiveTabKey1(key); }; return (
setPatrolName(searchPatrolName)} patrolName={patrolName} /> { onTab1Change(key); }} > { activeTabKey1 == 'tab1' ?
: '' } {contentList[activeTabKey1]}
); }; function mapStateToProps(state) { const { auth, depMessage } = state; const pakData = (dep) => { return dep.map((d) => { return { title: d.name, value: d.id, // children: d.type >= 2 ? [] : pakData(d.subordinate) children: pakData(d.subordinate) } }) } let depData = pakData(depMessage.data || []) return { user: auth.user, depMessage: depMessage.data || [], depLoading: depMessage.isRequesting, depData, }; } export default connect(mapStateToProps)(PatrolTable);