From e978022eaa03c076b18c851a7c0852402e80fd1c Mon Sep 17 00:00:00 2001 From: zhangyongtian <1181606322@qq.com> Date: Fri, 06 Sep 2024 16:38:42 +0800 Subject: [PATCH] feat: 识别文字 --- gz-customerSystem/src/views/register/visit/preview.jsx | 389 +++++++++++++++++++++++++++---------------------------- 1 files changed, 191 insertions(+), 198 deletions(-) diff --git a/gz-customerSystem/src/views/register/visit/preview.jsx b/gz-customerSystem/src/views/register/visit/preview.jsx index 5529934..254c18a 100644 --- a/gz-customerSystem/src/views/register/visit/preview.jsx +++ b/gz-customerSystem/src/views/register/visit/preview.jsx @@ -2,70 +2,33 @@ * @Author: dminyi 1301963064@qq.com * @Date: 2024-08-13 15:19:57 * @LastEditors: dminyi 1301963064@qq.com - * @LastEditTime: 2024-08-14 12:07:21 + * @LastEditTime: 2024-09-04 15:00:02 * @FilePath: \gzDyh\gz-customerSystem\src\views\basicInformation\organization\preview.jsx * @Description: 预览信息 */ -import React from "react"; +import React, { useState } from "react"; import { Row, Col, Space } from 'antd'; import { person, question, link } from '../../../assets/images' import '../index.less'; import TableView from '../../../components/TableView'; +import { Modal } from '@arco-design/web-react'; +import NewFileCheck from '../../filesCheck/newFileCheck'; +import * as $$ from '../../../utils/utility'; +import { ApplyDialog, AgentDialog, Respondent, Company } from './component/previewTable' - - -const Preview = () => { - - const fakeColumns = [ - { - title: '序号', - dataIndex: 'caseNo', - key: 'caseNo', - }, - { - title: '材料类型', - dataIndex: 'judicNo', - key: 'judicNo', - }, - { - title: '材料数量', - dataIndex: 'perClassName', - key: 'perClassName', - }, - { - title: '材料名称', - dataIndex: 'perClassName', - key: 'perClassName', - }, - { - title: '上传时间', - dataIndex: 'perClassName', - key: 'perClassName', - }, - { - title: '操作', - dataIndex: 'perClassName', - key: 'perClassName', - render: (text) => ( - <div style={{ display: 'flex', color: '#1A6FB8', gap: '16px' }}> - <div>查看</div> - <div>删除</div> - <div>下载</div> - <div>上传</div> - </div> - ) - }, - // 更多列配置... - ]; +const Preview = (props) => { + const [filesCheck, setFilesCheck] = useState(false); + const [apply, setApply] = useState(false); + const [visible, setVisible] = useState(false); const fakeData1 = [ { id: 1, caseNo: 'A20230101', - judicNo: 'J20230101', - perClassName: '自然人', - inputUserName: '张三', - mediateUserName: '李四', + judicNo: '申请材料', + perClassName: '李晓明的纠纷化解申请表、身份证...', + inputUserName: '0', + mediateUserName: '2024-7-12 12:00', judgeName: '王五', mediator: '赵六', handlerUserName: '钱七', @@ -80,16 +43,110 @@ serieStatus: '1', // 1 表示非系列案,2 表示系列案 // 更多字段... }, + { + id: 2, + caseNo: 'A20230101', + judicNo: '证据材料', + perClassName: '李晓明的纠纷化解申请表、身份证...', + inputUserName: '0', + mediateUserName: '2024-7-12 12:00', + judgeName: '王五', + mediator: '赵六', + handlerUserName: '钱七', + returnUserName: '孙八', + expireTime: '2023-08-10T08:00:00.000Z', + processName: '进行中', + otherMediator: '周九', + canalName: '网络', + judicResult: '通过', + assistName: '吴十', + mediTypeName: '民事调解', + serieStatus: '1', // 1 表示非系列案,2 表示系列案 + // 更多字段... + }, + // 更多数据... ]; + + // 列配置 + const fakeColumns = [ + { + title: '序号', + dataIndex: 'caseNo', + key: 'caseNo', + width: 100, + render: (text, record, index) => <span>{index + 1}</span>, + }, + { + title: '材料类型', + dataIndex: 'judicNo', + key: 'judicNo', + width: 60, + + }, + { + title: '材料数量', + dataIndex: 'inputUserName', + key: 'perClassName', + width: 180, + render: (text) => ( + <> + {text}份 + </> + ) + + }, + { + title: '材料名称', + dataIndex: 'perClassName', + key: 'perClassName', + width: 180, + + }, + { + title: '上传时间', + dataIndex: 'mediateUserName', + key: 'mediateUserName', + width: 180, + + }, + { + title: '操作', + dataIndex: 'perClassName', + key: 'perClassName', + width: 200, + render: (text) => ( + <div style={{ display: 'flex', color: '#1A6FB8', gap: '16px' }}> + <div onClick={() => setFilesCheck(true)}>查看</div> + <div>下载</div> + </div> + ) + }, + // 更多列配置... + ]; + + + const applyData = props.data?.fakeData?.filter(item => item.perTypeName === "申请方当事人" && item.perClassName === "自然人"); + const agentData = props.data?.fakeData?.filter(item => item.perTypeName === "申请方代理人"); + const company = props.data?.fakeData?.filter(item => item.perTypeName === "申请方当事人" && item.perClassName === "非法人组织"); + const respondentData = props.data?.fakeData?.filter(item => item.perTypeName === "申请方当事人" && item.perClassName === "法人"); + + const applyData1 = props.data?.fakeData?.filter(item => item.perTypeName === "被申请方当事人" && item.perClassName === "自然人"); + const agentData1 = props.data?.fakeData?.filter(item => item.perTypeName === "被申请方代理人"); + const company1 = props.data?.fakeData?.filter(item => item.perTypeName === "被申请方当事人" && item.perClassName === "非法人组织"); + const respondentData1 = props.data?.fakeData?.filter(item => item.perTypeName === "被申请方当事人" && item.perClassName === "法人"); + + console.log(props.data, 'props.data') + + return ( - <div style={{ backgroundColor: '#ffff', margin: '8px 16px 0px 16px', padding: '12px 18px 16px 16px' }}> - <Col span={24} style={{ display: 'flex', alignItems: 'center', marginBottom: '4px' }}> + <div style={{ backgroundColor: '#ffff', margin: '8px 8px 0px 16px', padding: '12px 18px 16px 16px', height: 'calc(100vh - 228px)', overflowY: 'scroll', ...props.style }}> + <Col span={24} style={{ display: 'flex', alignItems: 'center', marginBottom: '8px' }}> <Space size='small'> - <div className='MediationInfo-subTitle' style={{ marginTop: '-9px' }}></div><h5>当事人信息</h5> + <div className='MediationInfo-subTitle' style={{ marginTop: '-9px' }}></div><h4>当事人信息</h4> </Space> </Col> <div style={{ marginBottom: '8px' }}>申请方</div> @@ -98,180 +155,99 @@ <div className="line middle-line"></div> <div className="line right-line"></div> </div> - <table border="1" align="center" cellpadding="8" className="table"> - <tr> - <th bgcolor="#F7F8FA" className="table-title" width="120">姓名</th> - <td width='300'><div style={{ display: 'flex' }}><div>豪豪豪</div><div style={{ color: '#1A6FB8', padding: '0px 8px', border: '1px solid #1A6FB8', borderRadius: '4px', fontSize: '14px', marginLeft: '8px', height: '22px', display: 'flex', alignItems: 'center' }}>自然人</div></div></td> - <th bgcolor="#F7F8FA" className="table-title" width="120">联系方式</th> - <td width='300'>19</td> - <th bgcolor="#F7F8FA" className="table-title" width='140'>性别</th> - <td>汉</td> - <td rowspan="4" width="112" height='147' style={{ padding: '0px' }}> - <img border="0" src={person} alt="" style={{ width: '100%', height: '100%' }} /> - </td> - </tr> - <tr> - <th bgcolor="#F7F8FA" className="table-title">证件类型</th> - <td>19970000</td> - <th bgcolor="#F7F8FA" className="table-title">证件号码</th> - <td>团员</td> - <th bgcolor="#F7F8FA" className="table-title">民族</th> - <td>本科</td> - </tr> - <tr> - <th bgcolor="#F7F8FA" className="table-title">联系地址</th> - <td>网络工程</td> - <th bgcolor="#F7F8FA" className="table-title">户籍地址</th> - <td>淮南师范学院</td> - <th bgcolor="#F7F8FA" className="table-title" rowspan="2" >是否有个人极端倾向</th> - <td rowspan="2" >237483</td> - </tr> - <tr> - <th bgcolor="#F7F8FA" className="table-title">工作单位</th> - <td>玩,拆,装</td> - <th bgcolor="#F7F8FA" className="table-title">身份证明材料</th> - <td> - <a href="your-link-here.html" target="_blank"> - <img src={link} alt="" style={{ width: '12px', marginRight: '4px', marginTop: '-5px' }} />李晓明身份证明材料.pdf - </a> - </td> - </tr> - </table> - <table border="1" align="center" cellpadding="8" className="table" style={{ marginTop: '20px', marginBottom: '20px' }}> - <tr> - <th bgcolor="#F7F8FA" className="table-title" width="120">姓名</th> - <td width='300'>豪豪豪</td> - <th bgcolor="#F7F8FA" className="table-title" width="120">联系方式</th> - <td width='300'>19</td> - <th bgcolor="#F7F8FA" className="table-title" width="140">性别</th> - <td>汉</td> - <td rowspan="4" width="112" height='147' style={{ padding: '0px' }}> - <img border="0" src={person} alt="" style={{ width: '100%', height: '100%' }} /> - </td> - </tr> - <tr> - <th bgcolor="#F7F8FA" className="table-title">证件类型</th> - <td>19970000</td> - <th bgcolor="#F7F8FA" className="table-title">证件号码</th> - <td>团员</td> - <th bgcolor="#F7F8FA" className="table-title">民族</th> - <td>本科</td> - </tr> - <tr> - <th bgcolor="#F7F8FA" className="table-title">联系地址</th> - <td>网络工程</td> - <th bgcolor="#F7F8FA" className="table-title">户籍地址</th> - <td>淮南师范学院</td> - <th bgcolor="#F7F8FA" className="table-title" >是否有个人极端倾向</th> - <td>237483</td> - </tr> - <tr> - <th bgcolor="#F7F8FA" className="table-title">工作单位</th> - <td>玩,拆,装</td> - <th bgcolor="#F7F8FA" className="table-title">委托关系</th> - <td>皖</td> - <th bgcolor="#F7F8FA" className="table-title">委托类型</th> - <td>皖</td> - </tr> - <tr> - <th bgcolor="#F7F8FA" className="table-title">代理对象</th> - <td>玩,拆,装</td> - <th bgcolor="#F7F8FA" className="table-title">身份证明材料</th> - <td> - <a href="your-link-here.html" target="_blank"> - <img src={link} alt="" style={{ width: '12px', marginRight: '4px', marginTop: '-5px' }} />李晓明身份证明材料.pdf - </a> - </td> - <th bgcolor="#F7F8FA" className="table-title">代理人授权委托书</th> - <td> - <a href="your-link-here.html" target="_blank"> - <img src={link} alt="" style={{ width: '12px', marginRight: '4px', marginTop: '-5px' }} />李晓明身份证明材料.pdf - </a> - </td> - </tr> + {/* ApplyDialog 只有在 applyData 存在且不为空时才渲染 */} + {applyData && applyData.length > 0 ? ( + <ApplyDialog applyDialog={applyData} /> + ) : null} - </table> + {/* AgentDialog 只有在 agentData 存在且不为空时才渲染 */} + {agentData && agentData.length > 0 ? ( + <AgentDialog agentDialog={agentData} /> + ) : null} + + {/* Respondent 只有在 respondentData 存在且不为空时才渲染 */} + {respondentData && respondentData.length > 0 ? ( + <Respondent respondent={respondentData} /> + ) : null} + + {company && company.length > 0 ? ( + <Company company={company} /> + ) : null} + <div style={{ marginBottom: '8px' }}>被申请方</div> <div className="line-container" style={{ marginBottom: '20px' }}> <div className="line left-line"></div> <div className="line middle-line"></div> <div className="line right-line"></div> </div> - <table border="1" align="center" cellpadding="8" className="table" style={{ marginTop: '20px', marginBottom: '20px' }}> - <tr> - <th bgcolor="#F7F8FA" className="table-title">企业名称</th> - <td>豪豪豪</td> - <th bgcolor="#F7F8FA" className="table-title">联系方式</th> - <td>19</td> - <th bgcolor="#F7F8FA" className="table-title">企业所在地</th> - <td>汉</td> - </tr> - <tr> - <th bgcolor="#F7F8FA" className="table-title">企业类型</th> - <td>19970000</td> - <th bgcolor="#F7F8FA" className="table-title">法定代表人</th> - <td>团员</td> - <th bgcolor="#F7F8FA" className="table-title">统一社会信用代码</th> - <td>本科</td> - </tr> - <tr> - <th bgcolor="#F7F8FA" className="table-title">住所</th> - <td>网络工程</td> - <th bgcolor="#F7F8FA" className="table-title">企业登记材料</th> - <td> - <a href="your-link-here.html" target="_blank"> - <img src={link} alt="" style={{ width: '12px', marginRight: '4px', marginTop: '-5px' }} />李晓明身份证明材料.pdf - </a> - </td> - <th bgcolor="#F7F8FA" className="table-title" >法定代表人身份证明材料</th> - <td> - <a href="your-link-here.html" target="_blank"> - <img src={link} alt="" style={{ width: '12px', marginRight: '4px', marginTop: '-5px' }} />李晓明身份证明材料.pdf - </a> - </td> - </tr> - </table> - <Col span={24} style={{ display: 'flex', alignItems: 'center', marginBottom: '4px' }}> + {applyData1 && applyData1.length > 0 ? ( + <ApplyDialog applyDialog={applyData1} /> + ) : null} + + {agentData1 && agentData1.length > 0 ? ( + <AgentDialog agentDialog={agentData1} /> + ) : null} + + {respondentData1 && respondentData1.length > 0 ? ( + <Respondent respondent={respondentData1} /> + ) : null} + + {company1 && company1.length > 0 ? ( + <Company company={company1} /> + ) : null} + <Col span={24} style={{ display: 'flex', alignItems: 'center', marginBottom: '8px' }}> <Space size='small'> - <div className='MediationInfo-subTitle' style={{ marginTop: '-9px' }}></div><h5>纠纷基本情况</h5> + <div className='MediationInfo-subTitle' style={{ marginTop: '-9px' }}></div><h4>纠纷基本情况</h4> </Space> </Col> <Row gutter={[16, 16]}> <Col span={8}> - <div className="title"><div className="title-text">事项等级</div><img src={question} alt="" style={{ width: '14px', height: '14px', marginTop: '4px', marginLeft: '4px' }} /></div> - <div>3级</div> + <div className="title"> + <div className="title-text">事项等级</div> + </div> + <div style={{ display: 'flex' }}><div style={{ backgroundColor: '#00B42A', marginRight: '4px', borderRadius: '4px' }}><div style={{ color: '#FFFFFF', padding: '0px 6px' }}>{props.data?.caseLevel || '-'}</div></div>级</div> </Col> <Col span={8}> <div><div className="title-text">来访时间</div></div> - <div>2024-7-12 10:00</div> + <div>{props.data?.visitTime || '-'}</div> </Col> <Col span={8}> <div ><div className="title-text">来访人数(人)</div></div> - <div>2</div> + <div>{props.data?.visitPeopleNum || '-'}</div> </Col> <Col span={8}> <div ><div className="title-text">纠纷类型</div></div> - <div>市场监管/金融纠纷</div> + <div> + {props.data?.caseTypeFirstName ? + `${props.data.caseTypeFirstName}/${props.data.caseTypeName}` + : '-' + } + </div> </Col> <Col span={8}> <div ><div className="title-text">纠纷发生时间</div></div> - <div>2024-7-11</div> + <div>{props.data?.occurTime || '-'}</div> </Col> <Col span={8}> <div ><div className="title-text">纠纷发生地点</div></div> - <div>广州市天河区中山七路康王柏德来商业城</div> + <div>{props.data?.addr || '-'}</div> </Col> <Col span={8}> <div ><div className="title-text">问题属地</div></div> - <div>广州市/天河区/棠下街道</div> + <div> + {props.data?.queProvName ? + `${props.data.queProvName}/${props.data.queCityName}/${props.data.queAreaName}/${props.data.queRoadName}` + : '-' + } + </div> </Col> <Col span={8}> <div ><div className="title-text">涉及人数(人)</div></div> - <div>2</div> + <div>{props.data?.peopleNum || '-'}</div> </Col> <Col span={8}> <div ><div className="title-text">涉及金额(元)</div></div> - <div>20,000</div> + <div>{$$.thousands(props.data?.amount) || '-'}</div> </Col> <Col span={8}> <div ><div className="title-text">事项来源</div></div> @@ -282,27 +258,44 @@ <div>来访</div> </Col> <Col span={24}> - <div className="title"><div className="title-text">事项概况</div><img src={question} alt="" style={{ width: '14px', height: '14px', marginTop: '4px', marginLeft: '4px' }} /></div> - <div>张先生与李先生是多年的朋友关系。2023年4月,李先生因生意周转需要向张先生借款人民币20万元,并口头承诺于一年内还清。出于信任,张先生未要求签订书面借条或借款合同。然而,到了2024年4月,李先生并未如约归还借款。张先生多次通过电话、微信等方式催促还款,但李先生先是拖延,后干脆以各种理由拒绝偿还,甚至声称该笔款项属于赠予而非借款,这使得张先生感到十分无奈。 </div> + <div className="title"><div className="title-text">事项概况</div></div> + <div>{props.data?.caseDes || '-'} </div> </Col> <Col span={24}> - <div className="title"><div className="title-text">事项申请</div><img src={question} alt="" style={{ width: '14px', height: '14px', marginTop: '4px', marginLeft: '4px' }} /></div> - <div>张先生与李先生是多年的朋友关系。2023年4月,李先生因生意周转需要向张先生借款人民币20万元,并口头承诺于一年内还清。出于信任,张先生未要求签订书面借条或借款合同。然而,到了2024年4月,李先生并未如约归还借款。张先生多次通过电话、微信等方式催促还款,但李先生先是拖延,后干脆以各种理由拒绝偿还,甚至声称该笔款项属于赠予而非借款,这使得张先生感到十分无奈。 </div> + <div className="title"><div className="title-text">事项申请</div></div> + <div>{props.data?.caseClaim || '-'}</div> </Col> <Col span={16}> <div className="title"><div className="title-text">是否重大矛盾纠纷</div></div> - <div>否</div> + <div>{props.data?.majorStatus === 1 ? '是' : '否'}</div> </Col> </Row> + <Col span={24} style={{ display: 'flex', alignItems: 'center', marginBottom: '8px', marginTop: '20px' }}> + <Space size='small'> + <div className='MediationInfo-subTitle' style={{ marginTop: '-9px' }}></div><h4>事件材料</h4> + </Space> + </Col> + <TableView columns={fakeColumns} dataSource={fakeData1} size="small" rowKey="id" bordered={true} - style={{ marginBottom: '60px' }} + style={{ marginBottom: '65px' }} /> + <Modal style={{ width: '1200px' }} visible={filesCheck} onCancel={() => setFilesCheck(false)} footer={null} title='查看事件材料' centered> + {/* <div className="mediationWindow-modal-main" style={{ display: 'flex' }}> */} + <div style={{ marginTop: '-16px' }}> + <NewFileCheck /> + </div> + + {/* </div> */} + </Modal> + + + </div> ) } -- Gitblit v1.8.0