From ccbe1710b9c52b0ca23150b0a9ca763da6e1223c Mon Sep 17 00:00:00 2001
From: dminyi <1301963064@qq.com>
Date: Thu, 12 Sep 2024 15:43:22 +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 |  499 ++++++++++++++++++++++++-------------------------------
 1 files changed, 220 insertions(+), 279 deletions(-)

diff --git a/gz-customerSystem/src/views/register/visit/preview.jsx b/gz-customerSystem/src/views/register/visit/preview.jsx
index 13644b1..4d96783 100644
--- a/gz-customerSystem/src/views/register/visit/preview.jsx
+++ b/gz-customerSystem/src/views/register/visit/preview.jsx
@@ -2,301 +2,242 @@
  * @Author: dminyi 1301963064@qq.com
  * @Date: 2024-08-13 15:19:57
  * @LastEditors: dminyi 1301963064@qq.com
- * @LastEditTime: 2024-09-03 17:02:58
+ * @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 } from './component/previewTable'
+import { ApplyDialog, AgentDialog, Respondent, Company } from './component/previewTable'
+import FileTable from "../matterDetail/FileTable";
+import { link } from '@/assets/images';
 
 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 表示系列案
-            // 更多字段...
-        },
+  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 === "非法人组织");
+    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 === "法人");
 
-    // 列配置
-    const fakeColumns = [
-        {
-            title: '序号',
-            dataIndex: 'caseNo',
-            key: 'caseNo',
-            width: 100,
-            render: (text, record, index) => <span>{index + 1}</span>,
-        },
-        {
-            title: '材料类型',
-            dataIndex: 'judicNo',
-            key: 'judicNo',
-            width: 60,
+    setData({
+      applyData,
+      agentData,
+      company,
+      respondentData,
+      applyData1,
+      agentData1,
+      company1,
+      respondentData1
+    })
+  }, [props.data])
 
-        },
-        {
-            title: '材料数量',
-            dataIndex: 'inputUserName',
-            key: 'perClassName',
-            width: 180,
-            render: (text) => (
-                <>
-                    {text}份
-                </>
-            )
+  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}
 
-        },
-        {
-            title: '材料名称',
-            dataIndex: 'perClassName',
-            key: 'perClassName',
-            width: 180,
+      {/* AgentDialog 只有在 agentData 存在且不为空时才渲染 */}
+      {data.agentData && data.agentData.length > 0 ? (
+        <AgentDialog agentDialog={data.agentData} />
+      ) : null}
 
-        },
-        {
-            title: '上传时间',
-            dataIndex: 'mediateUserName',
-            key: 'mediateUserName',
-            width: 180,
+      {/* Respondent 只有在 respondentData 存在且不为空时才渲染 */}
+      {data.respondentData && data.respondentData.length > 0 ? (
+        <Respondent respondent={data.respondentData} />
+      ) : null}
 
-        },
-        {
-            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>
-            )
-        },
-        // 更多列配置...
-    ];
+      {data.company && data.company.length > 0 ? (
+        <Company company={data.company} />
+      ) : null}
 
-    const applyDialog = [
-        {
-            trueName: '李四',
-            perClassName: '高级',
-            phone: '13700137000',
-            sex: '女',
-            certiTypeName: '护照',
-            certiNo: 'G12345678',
-            nationName: '满',
-            addr: '上海市浦东新区某公寓2号楼2单元202室',
-            placeAddr: '上海市黄浦区某路3号',
-            extreme: '否',
-            workUnit: '上海某金融公司',
-            person: '/path/to/anotherPerson.jpg', // 这应该是图片的实际路径
-            link: '/path/to/anotherLink.png',     // 这应该是链接图标的实际路径
+      <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>
+            <Col span={16}>
+              <div><div className="title-text">事项编号</div></div>
+              <div>{props.data?.caseRef || '-'}</div>
+            </Col>
+          </>
         }
-        // 可以根据需要添加更多的对象来模拟更多条目的数据
-    ];
-
-    const agentDialog = [
-        {
-            trueName: '王五',
-            perClassName: '自然人',
-            phone: '13600136000',
-            sex: '男',
-            certiTypeName: '身份证',
-            certiNo: '110101199501012345',
-            nationName: '汉',
-            addr: '广州市天河区某大厦A座501室',
-            placeAddr: '广州市越秀区某街4号',
-            extreme: '否',
-            workUnit: '广州某贸易公司',
-            agentRelateName: '配偶',
-            agentTypeName: '法定代理人',
-            perTypeName: '成年人',
-            person: '/path/to/person.jpg', // 应该是图片的实际路径
-            link: '/path/to/link.png',     // 应该是链接图标的实际路径
-        },
-    ];
-
-    const respondent = [
-        {
-            orgaType: '广东好又多贸易有限公司',
-            perClassName: '企业法人',
-            phone: '020-12345678',
-            address: '广州市天河区珠江新城花城大道66号',
-            companyType: '有限责任公司',
-            legalPerson: '江照月',
-            creditCode: '914401011234567890',
-            president: '广州市天河区珠江新城花城大道66号A座20层',
-            link: '/path/to/link.png', // 应该是链接图标的实际路径
-        },
-    ];
-
-
-
-
-    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>
-            </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 applyDialog={applyDialog} />
-            <AgentDialog agentDialog={agentDialog} />
-            <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>
-            <Respondent respondent={respondent} />
-            <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>
-            <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' }}>3</div></div>级</div>
-                </Col>
-                <Col span={8}>
-                    <div><div className="title-text">来访时间</div></div>
-                    <div>2024-7-12 10:00</div>
-                </Col>
-                <Col span={8}>
-                    <div ><div className="title-text">来访人数(人)</div></div>
-                    <div>2</div>
-                </Col>
-                <Col span={8}>
-                    <div ><div className="title-text">纠纷类型</div></div>
-                    <div>市场监管/金融纠纷</div>
-                </Col>
-                <Col span={8}>
-                    <div ><div className="title-text">纠纷发生时间</div></div>
-                    <div>2024-7-11</div>
-                </Col>
-                <Col span={8}>
-                    <div ><div className="title-text">纠纷发生地点</div></div>
-                    <div>广州市天河区中山七路康王柏德来商业城</div>
-                </Col>
-                <Col span={8}>
-                    <div ><div className="title-text">问题属地</div></div>
-                    <div>广州市/天河区/棠下街道</div>
-                </Col>
-                <Col span={8}>
-                    <div ><div className="title-text">涉及人数(人)</div></div>
-                    <div>2</div>
-                </Col>
-                <Col span={8}>
-                    <div ><div className="title-text">涉及金额(元)</div></div>
-                    <div>{$$.thousands(20000)}</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>张先生与李先生是多年的朋友关系。2023年4月,李先生因生意周转需要向张先生借款人民币20万元,并口头承诺于一年内还清。出于信任,张先生未要求签订书面借条或借款合同。然而,到了2024年4月,李先生并未如约归还借款。张先生多次通过电话、微信等方式催促还款,但李先生先是拖延,后干脆以各种理由拒绝偿还,甚至声称该笔款项属于赠予而非借款,这使得张先生感到十分无奈。 </div>
-                </Col>
-                <Col span={24}>
-                    <div className="title"><div className="title-text">事项申请</div></div>
-                    <div>张先生与李先生是多年的朋友关系。2023年4月,李先生因生意周转需要向张先生借款人民币20万元,并口头承诺于一年内还清。出于信任,张先生未要求签订书面借条或借款合同。然而,到了2024年4月,李先生并未如约归还借款。张先生多次通过电话、微信等方式催促还款,但李先生先是拖延,后干脆以各种理由拒绝偿还,甚至声称该笔款项属于赠予而非借款,这使得张先生感到十分无奈。 </div>
-                </Col>
-                <Col span={16}>
-                    <div className="title"><div className="title-text">是否重大矛盾纠纷</div></div>
-                    <div>否</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 />
-                </div>
-
-                {/* </div> */}
-            </Modal>
-
-
-
-        </div>
-    )
+        <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>{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) => {
+                return <a href="your-link-here.html" target="_blank">
+                  <img src={link} alt="" className="title-file" />{item.trueName}
+                  {index !== props.transactResult.fileInfoBaseDTOList.length - 1 && <>,</>}
+                </a>
+              })}
+            </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