From 68f41dad70cc9c90b87258d91300576d7f5682e7 Mon Sep 17 00:00:00 2001 From: liuwh <964324856@qq.com> Date: Sat, 14 Sep 2024 15:58:38 +0800 Subject: [PATCH] Merge branch 'master' of http://120.79.193.119:9090/r/gzzfw/frontEnd/gzDyh into master --- gz-customerSystem/src/views/register/visit/preview.jsx | 480 ++++++++++++++++++++++++++--------------------------------- 1 files changed, 211 insertions(+), 269 deletions(-) diff --git a/gz-customerSystem/src/views/register/visit/preview.jsx b/gz-customerSystem/src/views/register/visit/preview.jsx index 254c18a..d908672 100644 --- a/gz-customerSystem/src/views/register/visit/preview.jsx +++ b/gz-customerSystem/src/views/register/visit/preview.jsx @@ -2,130 +2,23 @@ * @Author: dminyi 1301963064@qq.com * @Date: 2024-08-13 15:19:57 * @LastEditors: dminyi 1301963064@qq.com - * @LastEditTime: 2024-09-04 15:00:02 + * @LastEditTime: 2024-09-12 11:42:43 * @FilePath: \gzDyh\gz-customerSystem\src\views\basicInformation\organization\preview.jsx * @Description: 预览信息 */ -import React, { useState } from "react"; +import React, { useState, useEffect } 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' +import FileTable from "../matterDetail/FileTable"; +import { link } from '@/assets/images'; +import PreviewImage from '@/components/PreviewImage'; const Preview = (props) => { - const [filesCheck, setFilesCheck] = useState(false); - const [apply, setApply] = useState(false); - const [visible, setVisible] = useState(false); + const [data, setData] = useState({}) - const fakeData1 = [ - { - id: 1, - 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 表示系列案 - // 更多字段... - }, - { - 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> - ) - }, - // 更多列配置... - ]; - - + useEffect(() => { + console.log(props.data); 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 === "非法人组织"); @@ -136,168 +29,217 @@ 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') + setData({ + applyData, + agentData, + company, + respondentData, + applyData1, + agentData1, + company1, + respondentData1 + }) + }, [props.data]) + return ( + <div style={{ ...props.style }}> + <Col span={24} style={{ display: 'flex', alignItems: 'center', marginBottom: '8px' }}> + <Space size='small'> + <div className='MediationInfo-subTitle' style={{ marginTop: '-7px' }}></div><h4>当事人信息</h4> + </Space> + </Col> + <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> + {/* ApplyDialog 只有在 applyData 存在且不为空时才渲染 */} + {data.applyData && data.applyData.length > 0 ? ( + <ApplyDialog applyDialog={data.applyData} /> + ) : null} + {/* AgentDialog 只有在 agentData 存在且不为空时才渲染 */} + {data.agentData && data.agentData.length > 0 ? ( + <AgentDialog agentDialog={data.agentData} /> + ) : null} + {/* Respondent 只有在 respondentData 存在且不为空时才渲染 */} + {data.respondentData && data.respondentData.length > 0 ? ( + <Respondent respondent={data.respondentData} /> + ) : null} + {data.company && data.company.length > 0 ? ( + <Company company={data.company} /> + ) : null} - return ( - <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><h4>当事人信息</h4> - </Space> + <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> + {data.applyData1 && data.applyData1.length > 0 ? ( + <ApplyDialog applyDialog={data.applyData1} /> + ) : null} + + {data.agentData1 && data.agentData1.length > 0 ? ( + <AgentDialog agentDialog={data.agentData1} /> + ) : null} + + {data.respondentData1 && data.respondentData1.length > 0 ? ( + <Respondent respondent={data.respondentData1} /> + ) : null} + + {data.company1 && data.company1.length > 0 ? ( + <Company company={data.company1} /> + ) : null} + <Col span={24} style={{ display: 'flex', alignItems: 'center', marginBottom: '8px' }}> + <Space size='small'> + <div className='MediationInfo-subTitle' style={{ marginTop: '-7px' }}></div><h4>纠纷基本情况</h4> + </Space> + </Col> + <Row gutter={[16, 16]}> + {props.isDoc && + <> + <Col span={8}> + <div><div className="title-text">事项状态</div></div> + <div style={{ color: '#1A6FB8' }}>{props.data?.statusName || '-'}</div> </Col> - <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> - {/* ApplyDialog 只有在 applyData 存在且不为空时才渲染 */} - {applyData && applyData.length > 0 ? ( - <ApplyDialog applyDialog={applyData} /> - ) : null} - - {/* 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> - {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><h4>纠纷基本情况</h4> - </Space> + <Col span={16}> + <div><div className="title-text">事项编号</div></div> + <div>{props.data?.caseRef || '-'}</div> </Col> - <Row gutter={[16, 16]}> - <Col span={8}> - <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>{props.data?.visitTime || '-'}</div> - </Col> - <Col span={8}> - <div ><div className="title-text">来访人数(人)</div></div> - <div>{props.data?.visitPeopleNum || '-'}</div> - </Col> - <Col span={8}> - <div ><div className="title-text">纠纷类型</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>{props.data?.occurTime || '-'}</div> - </Col> - <Col span={8}> - <div ><div className="title-text">纠纷发生地点</div></div> - <div>{props.data?.addr || '-'}</div> - </Col> - <Col span={8}> - <div ><div className="title-text">问题属地</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>{props.data?.peopleNum || '-'}</div> - </Col> - <Col span={8}> - <div ><div className="title-text">涉及金额(元)</div></div> - <div>{$$.thousands(props.data?.amount) || '-'}</div> - </Col> - <Col span={8}> - <div ><div className="title-text">事项来源</div></div> - <div>大厅来访</div> - </Col> - <Col span={16}> - <div ><div className="title-text">来访形式</div></div> - <div>来访</div> - </Col> - <Col span={24}> - <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></div> - <div>{props.data?.caseClaim || '-'}</div> - </Col> - <Col span={16}> - <div className="title"><div className="title-text">是否重大矛盾纠纷</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: '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 /> + </> + } + <Col span={8}> + <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>{props.data?.visitTime || '-'}</div> + </Col> + <Col span={8}> + <div ><div className="title-text">来访人数(人)</div></div> + <div>{props.data?.visitPeopleNum || '-'}</div> + </Col> + <Col span={8}> + <div ><div className="title-text">纠纷类型</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>{props.data?.occurTime || '-'}</div> + </Col> + <Col span={8}> + <div ><div className="title-text">纠纷发生地点</div></div> + <div>{props.data?.addr || '-'}</div> + </Col> + <Col span={8}> + <div ><div className="title-text">问题属地</div></div> + <div> + {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>{props.data?.peopleNum || '-'}</div> + </Col> + <Col span={8}> + <div ><div className="title-text">涉及金额(元)</div></div> + <div>{$$.thousands(props.data?.amount) || '-'}</div> + </Col> + <Col span={8}> + <div ><div className="title-text">事项来源</div></div> + <div>{props.data?.canalName}</div> + </Col> + <Col span={16}> + <div ><div className="title-text">来访形式</div></div> + <div>来访</div> + </Col> + <Col span={24}> + <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></div> + <div>{props.data?.caseClaim || '-'}</div> + </Col> + <Col span={16}> + <div className="title"><div className="title-text">是否重大矛盾纠纷</div></div> + <div>{props.data?.majorStatus === 1 ? '是' : '否'}</div> + </Col> + </Row> + {props.transactResult && <> + <Col span={24} style={{ display: 'flex', alignItems: 'center', marginBottom: '16px', marginTop: '20px' }}> + <Space size='small'> + <div className='MediationInfo-subTitle' style={{ marginTop: '-7px' }}></div><h4>办理结果</h4> + </Space> + </Col> + <table border="1" align="center" cellpadding="8" className="table" > + <tr> + <th bgcolor="#F7F8FA" className="table-title" width="120">化解结果</th> + <td width='380'>{props.transactResult.mediResultName || '-'}</td> + <th bgcolor="#F7F8FA" className="table-title" width="120">经办人</th> + <td width='380'>{props.transactResult.mediator || '-'}</td> + </tr> + <tr> + <th bgcolor="#F7F8FA" className="table-title">承办部门</th> + <td>{props.transactResult.mediateUnitName || '-'}</td> + <th bgcolor="#F7F8FA" className="table-title">配合部门</th> + <td>{props.transactResult.applyAssistUnitName || '-'}</td> + </tr> + <tr> + <th bgcolor="#F7F8FA" className="table-title" width="120">受理时间</th> + <td width='380'>{$$.minuteFormat(props.transactResult?.acceptTime) || '-'}</td> + <th bgcolor="#F7F8FA" className="table-title" width="120">办结时间</th> + <td width='380'>{$$.minuteFormat(props.transactResult?.closeTime) || '-'}</td> + </tr> + <tr> + <th bgcolor="#F7F8FA" className="table-title" width="120">办理意见</th> + <td width='380' colspan='3'>{props.transactResult?.windupContent || '-'}</td> + </tr> + <tr> + <th bgcolor="#F7F8FA" className="table-title" width="120">协议要点</th> + <td width='380' colspan='3'>{props.transactResult?.agreeContent || '-'}</td> + </tr> + <tr> + <th bgcolor="#F7F8FA" className="table-title" width="120">结案意见</th> + <td width='380' colspan='3'>{props.transactResult?.windupContent || '-'}</td> + </tr> + <tr> + <th bgcolor="#F7F8FA" className="table-title" width="120">协议文书</th> + <td colspan='3'> + {props.transactResult?.fileInfoBaseDTOList?.map((item, index) => { + console.log(item); + return <div style={{ display: 'inline-block' }}> + <PreviewImage name={item.name} src={item.showUrl} /> + {index !== props.transactResult?.fileInfoBaseDTOList.length - 1 && <>,</>} </div> - - {/* </div> */} - </Modal> - - - - </div> - ) + })} + </td> + </tr> + </table> + </>} + <Col span={24} style={{ display: 'flex', alignItems: 'center', marginBottom: '8px', marginTop: '20px' }}> + <Space size='small'> + <div className='MediationInfo-subTitle' style={{ marginTop: '-7px' }}></div><h4>事件材料</h4> + </Space> + </Col> + <FileTable mainId={props.mainId} fileInfoList={props.data?.fileInfoList} isReview={true} /> + </div> + ) } export default Preview \ No newline at end of file -- Gitblit v1.8.0