/* eslint-disable no-nested-ternary */ /* * @Description: * @Author: leizhe * @Date: 2022-04-06 11:39:53 * @LastEditTime: 2022-05-18 14:36:11 * @LastEditors: leizhe */ import React, { useState, useEffect } from 'react'; import { Button, Descriptions, Input, Card, Spin, Divider, Message, Tabs, Table, Space, Tooltip, Modal, Form, notification, message, Image, Pagination, } from 'antd'; import { FormOutlined, DeleteOutlined, PlusOutlined, DownloadOutlined, UploadOutlined, SyncOutlined, PlusSquareFilled, CloudUploadOutlined, } from '@ant-design/icons'; import { List, deleteByID, DownLoadSketchPadType, Export, CaseTemplate, } from '@/services/ModelFileManage/api'; import styles from './ModelFileManage.less'; import EditModal from './EditModal'; import ImportModal from './ImportModal'; const ModelFileManage = () => { const [searchWord, setSearchWord] = useState(''); // 关键字 const [tableData, setTableData] = useState(''); const [tableLoading, setTableLoading] = useState(false); const [pickItem, setPickItem] = useState(''); const [selectedRowKeys, setSelectedRowKeys] = useState([]); const [selectColor, setSelectColor] = useState({}); // 当前选中颜色,操作时设置 const [showSearchStyle, setShowSearchStyle] = useState(false); // 是否显示模糊查询样式 const { Search } = Input; const [total, setTotal] = useState(); const [pageSize, setPageSize] = useState(20); const [currentPage, setCurrentPage] = useState(1); const [deleteVisible, setDeleteVisible] = useState(false); const [multDeleteVisible, setMultDeleteVisible] = useState(false); const [editVisible, setEditVisible] = useState(false); const [flag, setFlag] = useState(0); const [importVisible, setImportVisible] = useState(false); const [keepId, setKeepId] = useState([]); const [upgradeVisible, setUpgradeVisible] = useState(false); const setRowClassName = record => record.userID === selectColor.userID ? styles.clickRowStyle : ''; useEffect(() => { setSelectedRowKeys([]); setTableLoading(true); List({ version: '全部', pageIndex: 1, pageSize: 20 }).then(res => { setTableLoading(false); if (res.say.statusCode === '0000') { console.log(res.getMe); setTableData(res.getMe); setTotal(res.totalRcdNum); // let aa = []; // if (res.getMe.length > 0) { // res.getMe.map(i => { // aa.push(i.id); // }); // } // console.log(aa); // setKeepId(aa); } }); }, [flag]); useEffect(() => { List({ version: '全部' }).then(res => { setTableLoading(false); if (res.say.statusCode === '0000') { console.log(res.getMe); setTableData(res.getMe); setTotal(res.totalRcdNum); let aa = []; if (res.getMe.length > 0) { res.getMe.map(i => { aa.push(i.id); }); } console.log(aa); setKeepId(aa); } }); }, []); const columns = [ { title: '序号', dataIndex: 'ID', align: 'center', key: 'ID', width: 200, render: (text, record, index) => ( <span>{`${currentPage * pageSize + index + 1 - pageSize}`}</span> ), }, { title: '画板名称', dataIndex: 'name', align: 'center', key: 'name', render: item => searchStyle(item), }, { title: '画板类型', dataIndex: 'templet', align: 'center', key: 'templet', render: (text, record, index) => ( <span> {record.templet ? ( <span style={{ backgroundColor: '#cfcf71', width: '47px', height: '23px', display: 'inline-block', borderRadius: '5px', color: 'white', }} > 样品 </span> ) : record.isTemplate ? ( <span style={{ backgroundColor: '#95c6f3', width: '47px', height: '23px', display: 'inline-block', borderRadius: '5px', color: 'white', }} > 案例 </span> ) : ( <span style={{ backgroundColor: '#dda8a8', width: '47px', height: '23px', display: 'inline-block', borderRadius: '5px', color: 'white', }} > 普通 </span> )} </span> ), }, { title: '图像', dataIndex: 'thumbnailURL', align: 'center', key: 'thumbnailURL', render: text => ( <Image src={window.location.origin + `/Publish/Web/File/Sketch/Preview/${text}`} height="50px" /> ), }, { title: '操作', key: 'action', width: 200, align: 'center', render: record => ( <Space size="middle"> <Tooltip title="编辑"> <FormOutlined onClick={() => onedit(record)} style={{ fontSize: '16px', color: '#1890FF' }} /> </Tooltip> {record.isTemplate && !record.templet ? ( <Tooltip title="升级产品"> <CloudUploadOutlined onClick={() => onupgrade(record)} style={{ fontSize: '16px', color: '#1890FF' }} /> </Tooltip> ) : ( <></> )} <Tooltip title="删除"> <DeleteOutlined onClick={() => ondelete(record)} style={{ fontSize: '16px', color: '#e86060' }} /> </Tooltip> </Space> ), }, ]; const onedit = e => { console.log(e); setPickItem(e); setEditVisible(true); }; const onupgrade = e => { console.log(e); setPickItem(e); setUpgradeVisible(true); }; const ondelete = e => { console.log(e); setPickItem(e); setDeleteVisible(true); }; // 复选框 const rowSelection = { selectedRowKeys, onChange: (RowKeys, Rows) => { setSelectedRowKeys(RowKeys); }, }; // 模糊查询匹配的样式 const searchStyle = val => { let n; if (showSearchStyle) { n = val.replace(new RegExp(searchWord, 'g'), `<span style='color:red'>${searchWord}</span>`); } else { n = val; } return <div dangerouslySetInnerHTML={{ __html: n }} />; }; const submitSearchUser = () => { setSelectedRowKeys([]); setTableLoading(true); List({ version: '全部', // pageIndex: currentPage, // pageSize: pageSize, queryInfo: searchWord, }).then(res => { setTableLoading(false); if (res.say.statusCode === '0000') { setShowSearchStyle(true); setTableData(res.getMe); setTotal(res.totalRcdNum); } }); }; const handleSearch = e => { setSearchWord(e.target.value); }; // 监听分页 const paginationChange = (page, pageSizes) => { setCurrentPage(page); setPageSize(pageSizes); setSelectedRowKeys([]); setTableLoading(true); List({ version: '全部', pageIndex: page, pageSize: pageSizes, queryInfo: searchWord }).then( res => { setTableLoading(false); if (res.say.statusCode === '0000') { setTableData(res.getMe); setTotal(res.totalRcdNum); } }, ); }; const clearSearchWord = () => { setSearchWord(''); setSelectedRowKeys([]); setTableLoading(true); List({ version: '全部', pageIndex: currentPage, pageSize: pageSize, queryInfo: '', }).then(res => { setTableLoading(false); if (res.say.statusCode === '0000') { setTableData(res.getMe); setTotal(res.totalRcdNum); } }); }; const deleteData = () => { deleteByID({ ids: pickItem.id }).then(res => { if (res.statusCode === '0000') { setDeleteVisible(false); notification.success({ message: '删除成功', duration: 2, }); setFlag(flag + 1); } else { notification.error({ message: '删除失败', description: res.info, }); } }); }; const multDeleteData = () => { setMultDeleteVisible(true); }; const multDelete = () => { deleteByID({ ids: selectedRowKeys.toString() }).then(res => { if (res.statusCode === '0000') { setMultDeleteVisible(false); notification.success({ message: '删除成功', duration: 2, }); setFlag(flag + 1); } else { notification.error({ message: '删除失败', description: res.info, }); } }); }; const ExportData = () => { if (selectedRowKeys.length == 0) { message.warning('请先选择导出的数据'); } else { window.location.href = Export({ ids: selectedRowKeys.toString() }); } }; const MultExportData = () => { window.location.href = Export({ ids: keepId.toString() }); }; const onImportSubmit = () => { setImportVisible(false); setFlag(flag + 1); }; const importFile = () => { setImportVisible(true); }; const upgrade = () => { CaseTemplate({ ids: pickItem.id }).then(res => { if (res.statusCode === '0000') { setUpgradeVisible(false); notification.success({ message: '升级成功', duration: 2, }); setFlag(flag + 1); } else { notification.error({ message: '升级失败', description: res.info, }); } }); }; const onEditSubmit = () => { setImportVisible(false); setFlag(flag + 1); }; return ( <div className={styles.base_container}> <Card style={{ width: '100%', height: 'calc(100vh - 130px)' }}> <div style={{ height: '41px', display: 'flex', justifyContent: 'space-between', alignItems: 'center', }} > <div> <span style={{ width: '200px', display: 'inline-block' }}> (已选{selectedRowKeys.length}条/共{total}条) </span> <span style={{ lineHeight: '32px' }}>画板检索:</span> <Search style={{ width: 260 }} placeholder="请输入画板名称" onSearch={submitSearchUser} onChange={e => handleSearch(e)} enterButton value={searchWord} /> <Button type="primary" icon={<SyncOutlined />} onClick={clearSearchWord} style={{ marginLeft: '20px' }} > 重置 </Button> </div> <div> <Button type="primary" icon={<DeleteOutlined />} onClick={multDeleteData} style={{ marginLeft: '20px' }} > 删除 </Button> <Button type="primary" icon={<UploadOutlined />} onClick={importFile} style={{ marginLeft: '20px' }} > 导入 </Button> <Button type="primary" icon={<DownloadOutlined />} onClick={ExportData} style={{ marginLeft: '20px' }} > 导出 </Button> <Button type="primary" icon={<DownloadOutlined />} onClick={MultExportData} style={{ marginLeft: '20px' }} > 导出全部 </Button> </div> </div> <div style={{ marginTop: '10px' }}> <Table rowSelection={{ type: 'checkbox', ...rowSelection, }} rowClassName={setRowClassName} size="small" rowKey={record => record.id} bordered onRow={record => ({ // onDoubleClick: event => { // event.stopPropagation(); // editEventType(record); // }, // 双击 onClick: e => { setSelectColor(record); }, })} columns={columns} dataSource={tableData} loading={tableLoading} scroll={{ x: 'max-content', y: 'calc(100vh - 270px)' }} pagination={false} /> </div> <Pagination style={{ float: 'right', marginTop: '10px' }} total={total} showTotal={(aa, range) => `第${range[0]}-${range[1]} 条/共 ${total} 条`} defaultPageSize={pageSize} defaultCurrent={1} pageSizeOptions={[10, 20, 40, 100]} current={currentPage} onChange={paginationChange} size="small" showQuickJumper /> </Card> <Modal visible={deleteVisible} onCancel={() => setDeleteVisible(false)} title="删除" okText="确认" cancelText="取消" onOk={deleteData} > <span>是否删除该数据</span> </Modal> <Modal visible={multDeleteVisible} onCancel={() => setMultDeleteVisible(false)} title="批量删除" okText="确认" cancelText="取消" onOk={multDelete} > <span>是否批量删除所选数据</span> </Modal> <EditModal visible={editVisible} onCancel={() => setEditVisible(false)} pickItem={pickItem} callBackSubmit={onImportSubmit} /> <ImportModal visible={importVisible} onCancel={() => setImportVisible(false)} callBackSubmit={onEditSubmit} /> <Modal visible={upgradeVisible} onCancel={() => setUpgradeVisible(false)} title="升级产品" okText="确认" cancelText="取消" onOk={upgrade} > <span>是否升级为样品</span> </Modal> </div> ); }; export default ModelFileManage;