/* * @Description: * @Author: leizhe * @Date: 2022-01-13 10:47:32 * @LastEditTime: 2022-03-25 10:29:20 * @LastEditors: leizhe */ /* eslint-disable indent */ import { Button, Spin } from 'antd'; import React, { useState, useEffect } from 'react'; import styles from '../dimensionsConfig.less'; import { GetSchemaInfoList } from '@/services/webConfig/api'; import AddModal from './AddModal'; import Cards from './components/card'; const VectorData = props => { const [treeLoading, setTreeLoading] = useState(false); // 弹窗显示 const [tileData, setTileData] = useState([]); // 页面初始化数据 const [visible, setVisible] = useState(false); // 弹窗 const [flag, setFlag] = useState(0); // 状态更新 const [type, setType] = useState(''); // 弹窗类型 const [formObj, setFormObj] = useState({}); const onSubmit = prop => { setVisible(false); setFlag(flag + 1); }; const onDeletebaseMap = value => { setFlag(flag + 1); }; const handleAdd = () => { setType('schemeAdd'); setVisible(true); }; useEffect(() => { renderTile(); }, [flag]); // 获取瓦片数据配置数据 const renderTile = () => { setTreeLoading(true); GetSchemaInfoList().then(res => { if (res.msg === 'Ok') { setTreeLoading(false); setTileData(res.data); } else { setTreeLoading(false); } }); }; return ( <> <Spin tip="loading..." spinning={treeLoading}> <div> <div className={styles.tileBtn}> <Button type="primary" onClick={() => { handleAdd(); }} > 新增 </Button> </div> <div style={{ height: 'calc(100vh - 230px)', overflow: 'scroll' }}> <div className={styles.cardsList}> {tileData && tileData.length ? tileData.map((item, index) => { return ( <div className={styles.cardItem} key={index} span={5} offset={2} style={{ marginBottom: '1rem' }} > <Cards item={item} deletebaseMaps={onDeletebaseMap} /> </div> ); }) : ''} </div> </div> <AddModal visible={visible} onCancel={() => setVisible(false)} callBackSubmit={onSubmit} type={type} formObj={formObj} /> </div> </Spin> </> ); }; export default VectorData;