From 095037371c10be43d507e009b260a08e28e3e78a Mon Sep 17 00:00:00 2001
From: zhangyongtian <1181606322@qq.com>
Date: Tue, 03 Sep 2024 11:31:37 +0800
Subject: [PATCH] Merge branch 'master' of http://120.79.193.119:9090/r/gzzfw/frontEnd/gzDyh

---
 gz-customerSystem/src/views/register/handleFeedback/component/CaseResult.jsx |  547 +++++++++++++++++++++++++++++++++---------------------
 1 files changed, 334 insertions(+), 213 deletions(-)

diff --git a/gz-customerSystem/src/views/register/handleFeedback/component/CaseResult.jsx b/gz-customerSystem/src/views/register/handleFeedback/component/CaseResult.jsx
index 54ca216..81483be 100644
--- a/gz-customerSystem/src/views/register/handleFeedback/component/CaseResult.jsx
+++ b/gz-customerSystem/src/views/register/handleFeedback/component/CaseResult.jsx
@@ -2,16 +2,17 @@
  * @Author: dminyi 1301963064@qq.com
  * @Date: 2024-09-02 14:49:13
  * @LastEditors: dminyi 1301963064@qq.com
- * @LastEditTime: 2024-09-02 19:44:37
+ * @LastEditTime: 2024-09-02 20:52:05
  * @FilePath: \gzDyh\gz-customerSystem\src\views\register\handleFeedback\component\CaseResult.jsx
  * @Description: 结案申请
  */
 import React, { useState } from 'react';
 import { Modal, Form, Select, Upload, Input } from '@arco-design/web-react';
-import { Col, Space, Button } from 'antd';
+import { Col, Space, Button, Tooltip, Radio } from 'antd';
 import DocumentScanner from './FileUpLoad'
 import { scan } from '@/assets/images/icon'
-import { tip } from '@/assets/images'
+import { tip, question1 } from '@/assets/images'
+import { NoHandleReason } from '../../visit/component/levelDetail'
 
 const FormItem = Form.Item;
 
@@ -25,6 +26,8 @@
   const [selectedTab1, setSelectedTab1] = useState('1'); // 默认选中第一个 tab
   const [fileTip, setFileTip] = useState('0');
   const [value, setValue] = useState(1)
+  const [noHandleReason, setNoHandleReason] = useState(false);
+  const [radioValue, setRadioValue] = useState(1)
 
 
   const tabs = [
@@ -61,6 +64,11 @@
     setScanFile(false);
   };
 
+  const onChange = (e) => {
+    console.log('radio checked', e.target.value);
+    setRadioValue(e.target.value);
+  };
+
 
   return (
     <>
@@ -83,232 +91,345 @@
             </div>
           ))}
         </div>
-        <Form
-          layout='vertical'
-          scrollToFirstError={true}
-          requiredSymbol={false}
-          initialValues={{
-            caseLevel: 1,
-          }} //默认值
-        >
-          <Col span={8}>
-            <FormItem
-              label={<div style={{ display: 'flex' }}>
-                达成的协议类型
-              </div>
-              }
-              field='caseLevel'
+        {selectedTab === '1' &&
+          <Form
+            layout='vertical'
+            scrollToFirstError={true}
+            requiredSymbol={false}
+            initialValues={{
+              caseLevel: 1,
+            }} //默认值
+          >
+            <Col span={8}>
+              <FormItem
+                label={<div style={{ display: 'flex' }}>
+                  达成的协议类型
+                </div>
+                }
+                field='caseLevel'
 
-            >
-              <Select options={agreement} onChange={(v) => { setValue(v); console.log(typeof v, 'vvv') }}>
-              </Select>
-            </FormItem>
-          </Col>
-          {value === 1 &&
-            <>
-              <Col span={24}>
-                <FormItem
-                  label={
-                    <>
-                      <div style={{ display: 'flex' }}>
-                        协议要点
-                        <div className="must" style={{ marginLeft: '4px' }}>必填</div>
-                        <img src={scan} alt="" style={{ marginRight: '-2px', marginLeft: '8px' }} />
-                        <div style={{ marginLeft: '8px', color: '#1A6FB8', fontSize: '14px', cursor: 'pointer' }} onClick={() => setScanFile(true)}>识别材料</div>
-                      </div>
-                      <div className='caseResult-tips'>
-                        <img src={tip} alt='' style={{ width: '16px', marginRight: '8px' }} />
-                        <span>协议要点应尽量简洁,当事人大厅来访或小程序线上反映问题时,可在小程序中查看到填写的协议要点内容</span>
-                      </div>
-                    </>
-                  }
-                  field='caseDes'
-                  rules={[{ message: '请填写事项概况', required: true }]}
-                >
-                  <div className='caseResult-textarea'>公共模板1:调解成功口头协议</div>
-                  <Input.TextArea
-                    rows={5}
-                    maxLength={{ length: 200, errorOnly: true }}
-                    showWordLimit
-                    wrapperStyle={{ width: '100%' }}
-                    value='根据纠纷化解人员的协调,当事人双方同意如下调解协议:
-                            [简要说明协议第一条]
-                            [简要说明协议第二条]
-                            [……]
-                            本口头调解协议由纠纷化解人员记录,并已告知双方当事人。双方当事人确认无误。'
-                  />
-                </FormItem>
-              </Col>
-              <Col span={24}>
-                <FormItem
-                  label={
-                    <>
-                      <div style={{ display: 'flex' }}>
-                        结案意见
-                        <div className="must" style={{ marginLeft: '4px' }}>必填</div>
-                      </div>
-                    </>
-                  }
-                  field='caseDes'
-                  rules={[{ message: '请填写事项概况', required: true }]}
-                >
-                  <div className='tabs1' >
-                    {tabs1.map((tab) => (
-                      <div
-                        key={tab.index}
-                        style={{
-                          color: selectedTab1 === tab.index ? 'rgba(26,111,184,1)' : 'rgba(0,0,0,0.45)',
-                          border: `1px solid ${selectedTab1 === tab.index ? 'rgba(26,111,184,1)' : 'rgba(229,230,235,1)'}`,
-                          borderRadius: '2px',
-                          cursor: 'pointer',
-                          padding: '0px 8px',
-                        }}
-                        onClick={() => handleTabChange1(tab.index)}
-                      >
-                        {tab.label}
-                      </div>
-                    ))}
-                  </div>
+              >
+                <Select options={agreement} onChange={(v) => { setValue(v); console.log(typeof v, 'vvv') }}>
+                </Select>
+              </FormItem>
+            </Col>
+            {value === 1 &&
+              <>
+                <Col span={24}>
+                  <FormItem
+                    label={
+                      <>
+                        <div style={{ display: 'flex' }}>
+                          协议要点
+                          <div className="must" style={{ marginLeft: '4px' }}>必填</div>
+                          <img src={scan} alt="" style={{ marginRight: '-2px', marginLeft: '8px' }} />
+                          <div style={{ marginLeft: '8px', color: '#1A6FB8', fontSize: '14px', cursor: 'pointer' }} onClick={() => setScanFile(true)}>识别材料</div>
+                        </div>
+                        <div className='caseResult-tips'>
+                          <img src={tip} alt='' style={{ width: '16px', marginRight: '8px' }} />
+                          <span>协议要点应尽量简洁,当事人大厅来访或小程序线上反映问题时,可在小程序中查看到填写的协议要点内容</span>
+                        </div>
+                      </>
+                    }
+                    field='caseDes'
+                    rules={[{ message: '请填写事项概况', required: true }]}
+                  >
+                    <div className='caseResult-textarea'>公共模板1:调解成功口头协议</div>
+                    <Input.TextArea
+                      rows={5}
+                      maxLength={{ length: 200, errorOnly: true }}
+                      showWordLimit
+                      wrapperStyle={{ width: '100%' }}
+                      value='根据纠纷化解人员的协调,当事人双方同意如下调解协议:
+                                  [简要说明协议第一条]
+                                  [简要说明协议第二条]
+                                  [……]
+                                  本口头调解协议由纠纷化解人员记录,并已告知双方当事人。双方当事人确认无误。'
+                    />
+                  </FormItem>
+                </Col>
+                <Col span={24}>
+                  <FormItem
+                    label={
+                      <>
+                        <div style={{ display: 'flex' }}>
+                          结案意见
+                          <div className="must" style={{ marginLeft: '4px' }}>必填</div>
+                        </div>
+                      </>
+                    }
+                    field='caseDes'
+                    rules={[{ message: '请填写事项概况', required: true }]}
+                  >
+                    <div className='tabs1' >
+                      {tabs1.map((tab) => (
+                        <div
+                          key={tab.index}
+                          style={{
+                            color: selectedTab1 === tab.index ? 'rgba(26,111,184,1)' : 'rgba(0,0,0,0.45)',
+                            border: `1px solid ${selectedTab1 === tab.index ? 'rgba(26,111,184,1)' : 'rgba(229,230,235,1)'}`,
+                            borderRadius: '2px',
+                            cursor: 'pointer',
+                            padding: '0px 8px',
+                          }}
+                          onClick={() => handleTabChange1(tab.index)}
+                        >
+                          {tab.label}
+                        </div>
+                      ))}
+                    </div>
 
-                  <Input.TextArea
-                    rows={5}
-                    wrapperStyle={{ width: '100%' }}
-                    value='鉴于以上协议内容已经双方确认,并认为该协议内容公平合理,能够妥善解决双方的纠纷。建议双方当事人按照协议内容执行,以实现纠纷的最终解决。'
-                  />
-                </FormItem>
-              </Col>
+                    <Input.TextArea
+                      rows={5}
+                      wrapperStyle={{ width: '100%' }}
+                      value='鉴于以上协议内容已经双方确认,并认为该协议内容公平合理,能够妥善解决双方的纠纷。建议双方当事人按照协议内容执行,以实现纠纷的最终解决。'
+                    />
+                  </FormItem>
+                </Col>
 
-            </>
+              </>
 
-          }
-          {value === 2 &&
-            <>
-              <Col span={24}>
-                <FormItem
-                  label={
-                    <>
-                      <div style={{ display: 'flex' }}>
-                        协议附件
-                        <div className="must" style={{ marginLeft: '4px' }}>必填</div>
-                      </div>
-                      <div className='caseResult-tips'>
-                        <img src={tip} alt='' style={{ width: '16px', marginRight: '8px' }} />
-                        <span>如通过人民调解工作成功化解纠纷事项,建议上传签字盖章后的人民调解协议书</span>
-                      </div>
-                    </>
-                  }
-                  field='caseDes'
-                  rules={[{ message: '请填写事项概况', required: true }]}
-                >
-                  <Upload
-                    drag
-                    multiple
-                    accept='image/*'
-                    action='/'
-                    height={158}
-                    onDrop={(e) => {
-                    }}
-                    onChange={(v) => {
-                      setFileTip((prevLength) => {
-                        if (v.length > 0) {
-                          console.log(v, 'vvvvvvv');
+            }
+            {value === 2 &&
+              <>
+                <Col span={24}>
+                  <FormItem
+                    label={
+                      <>
+                        <div style={{ display: 'flex' }}>
+                          协议文书
+                          <div className="must" style={{ marginLeft: '4px' }}>必填</div>
+                        </div>
+                        <div className='caseResult-tips'>
+                          <img src={tip} alt='' style={{ width: '16px', marginRight: '8px' }} />
+                          <span>如通过人民调解工作成功化解纠纷事项,建议上传签字盖章后的人民调解协议书</span>
+                        </div>
+                      </>
+                    }
+                    field='caseDes'
+                    rules={[{ message: '请填写事项概况', required: true }]}
+                  >
+                    <Upload
+                      drag
+                      multiple
+                      accept='image/*'
+                      action='/'
+                      height={158}
+                      onDrop={(e) => {
+                      }}
+                      onChange={(v) => {
+                        setFileTip((prevLength) => {
+                          if (v.length > 0) {
+                            console.log(v, 'vvvvvvv');
+                            return v.length;
+                          }
                           return v.length;
-                        }
-                        return v.length;
-                      });
-                    }}
-                    tip='支持png、 jpg、excel、word、pdf等格式的文件上传,每次上传大小不超过10M'
-                  />
+                        });
+                      }}
+                      tip='支持png、 jpg、excel、word、pdf等格式的文件上传,每次上传大小不超过10M'
+                    />
 
 
-                </FormItem>
-              </Col>
-              <Col span={24}>
-                <FormItem
-                  label={
-                    <>
-                      <div style={{ display: 'flex' }}>
-                        协议要点
-                        <div className="must" style={{ marginLeft: '4px' }}>必填</div>
-                        <img src={scan} alt="" style={{ marginRight: '-2px', marginLeft: '8px' }} />
-                        <div style={{ marginLeft: '8px', color: '#1A6FB8', fontSize: '14px', cursor: 'pointer' }} onClick={() => setScanFile(true)}>识别材料</div>
-                      </div>
-                      <div className='caseResult-tips'>
-                        <img src={tip} alt='' style={{ width: '16px', marginRight: '8px' }} />
-                        <span>协议要点应尽量简洁,当事人大厅来访或小程序线上反映问题时,可在小程序中查看到填写的协议要点内容</span>
-                      </div>
-                    </>
-                  }
-                  field='caseDes'
-                  rules={[{ message: '请填写事项概况', required: true }]}
-                >
-                  <div className='caseResult-textarea'>公共模板1:调解成功口头协议</div>
-                  <Input.TextArea
-                    rows={5}
-                    maxLength={{ length: 200, errorOnly: true }}
-                    showWordLimit
-                    wrapperStyle={{ width: '100%' }}
-                    value='根据纠纷化解人员的协调,当事人双方同意如下调解协议:
-                            [简要说明协议第一条]
-                            [简要说明协议第二条]
-                            [……]
-                            本口头调解协议由纠纷化解人员记录,并已告知双方当事人。双方当事人确认无误。'
-                  />
-                </FormItem>
-              </Col>
-              <Col span={24}>
-                <FormItem
-                  label={
-                    <>
-                      <div style={{ display: 'flex' }}>
-                        结案意见
-                        <div className="must" style={{ marginLeft: '4px' }}>必填</div>
-                      </div>
-                    </>
-                  }
-                  field='caseDes'
-                  rules={[{ message: '请填写事项概况', required: true }]}
-                >
-                  <div className='tabs1' >
-                    {tabs1.map((tab) => (
-                      <div
-                        key={tab.index}
-                        style={{
-                          color: selectedTab1 === tab.index ? 'rgba(26,111,184,1)' : 'rgba(0,0,0,0.45)',
-                          border: `1px solid ${selectedTab1 === tab.index ? 'rgba(26,111,184,1)' : 'rgba(229,230,235,1)'}`,
-                          borderRadius: '2px',
-                          cursor: 'pointer',
-                          padding: '0px 8px',
-                        }}
-                        onClick={() => handleTabChange1(tab.index)}
-                      >
-                        {tab.label}
-                      </div>
-                    ))}
-                  </div>
+                  </FormItem>
+                </Col>
+                <Col span={24}>
+                  <FormItem
+                    label={
+                      <>
+                        <div style={{ display: 'flex' }}>
+                          协议要点
+                          <div className="must" style={{ marginLeft: '4px' }}>必填</div>
+                          <img src={scan} alt="" style={{ marginRight: '-2px', marginLeft: '8px' }} />
+                          <div style={{ marginLeft: '8px', color: '#1A6FB8', fontSize: '14px', cursor: 'pointer' }} onClick={() => setScanFile(true)}>识别材料</div>
+                        </div>
+                        <div className='caseResult-tips'>
+                          <img src={tip} alt='' style={{ width: '16px', marginRight: '8px' }} />
+                          <span>协议要点应尽量简洁,当事人大厅来访或小程序线上反映问题时,可在小程序中查看到填写的协议要点内容</span>
+                        </div>
+                      </>
+                    }
+                    field='caseDes'
+                    rules={[{ message: '请填写事项概况', required: true }]}
+                  >
+                    <div className='caseResult-textarea'>公共模板1:调解成功口头协议</div>
+                    <Input.TextArea
+                      rows={5}
+                      maxLength={{ length: 200, errorOnly: true }}
+                      showWordLimit
+                      wrapperStyle={{ width: '100%' }}
+                      value='根据纠纷化解人员的协调,当事人双方同意如下调解协议:
+                                  [简要说明协议第一条]
+                                  [简要说明协议第二条]
+                                  [……]
+                                  本口头调解协议由纠纷化解人员记录,并已告知双方当事人。双方当事人确认无误。'
+                    />
+                  </FormItem>
+                </Col>
+                <Col span={24}>
+                  <FormItem
+                    label={
+                      <>
+                        <div style={{ display: 'flex' }}>
+                          结案意见
+                          <div className="must" style={{ marginLeft: '4px' }}>必填</div>
+                        </div>
+                      </>
+                    }
+                    field='caseDes'
+                    rules={[{ message: '请填写事项概况', required: true }]}
+                  >
+                    <div className='tabs1' >
+                      {tabs1.map((tab) => (
+                        <div
+                          key={tab.index}
+                          style={{
+                            color: selectedTab1 === tab.index ? 'rgba(26,111,184,1)' : 'rgba(0,0,0,0.45)',
+                            border: `1px solid ${selectedTab1 === tab.index ? 'rgba(26,111,184,1)' : 'rgba(229,230,235,1)'}`,
+                            borderRadius: '2px',
+                            cursor: 'pointer',
+                            padding: '0px 8px',
+                          }}
+                          onClick={() => handleTabChange1(tab.index)}
+                        >
+                          {tab.label}
+                        </div>
+                      ))}
+                    </div>
 
-                  <Input.TextArea
-                    rows={5}
-                    wrapperStyle={{ width: '100%' }}
-                    value='鉴于以上协议内容已经双方确认,并认为该协议内容公平合理,能够妥善解决双方的纠纷。建议双方当事人按照协议内容执行,以实现纠纷的最终解决。'
-                  />
-                </FormItem>
-              </Col>
+                    <Input.TextArea
+                      rows={5}
+                      wrapperStyle={{ width: '100%' }}
+                      value='鉴于以上协议内容已经双方确认,并认为该协议内容公平合理,能够妥善解决双方的纠纷。建议双方当事人按照协议内容执行,以实现纠纷的最终解决。'
+                    />
+                  </FormItem>
+                </Col>
 
-            </>
+              </>
 
-          }
-          <Space style={{ marginBottom: '16px' }}>
-            <Button type='primary'>提交</Button>
-            <Button type='outline' style={{ color: '#1A6FB8', border: '1px solid #1A6FB8' }}>保存</Button>
-          </Space>
-        </Form>
+            }
+            <Space style={{ marginBottom: '16px' }}>
+              <Button type='primary'>提交</Button>
+              <Button type='outline' style={{ color: '#1A6FB8', border: '1px solid #1A6FB8' }}>保存</Button>
+            </Space>
+          </Form>
+        }
+        {selectedTab === '2' &&
+          <Form
+            layout='vertical'
+            requiredSymbol={false}
+            scrollToFirstError={true}
+            initialValues={{
+              caseLevel: 3,
+            }}//默认值
+          >
+            <Col span={24}>
+              <FormItem
+                label={<div style={{ display: 'flex' }}>
+                  无法化解理由
+                  <Tooltip onClick={() => setNoHandleReason(true)}>
+                    <img src={question1} alt="" style={{ width: '13px', height: '13px', margin: '4px 4px 0px 4px' }} />
+                  </Tooltip>
+                  <div className="must" style={{ marginLeft: '4px' }}>必填</div>
+                </div>
+                }
+                field='caseDes'
+                rules={[{ message: '请填写事项概况', required: true }]}
+              >
+                <table border="1" align="center" cellpadding="8" className="table">
+                  <tr>
+                    <th bgcolor="#F7F8FA" className="table-title" width="120">调解过程中提供的解决方案</th>
+                    <td>
+                      <Input.TextArea
+                        showWordLimit
+                        rows={3}
+                        placeholder='请完整描述事项概况,应具备5要素:发生时间+发生地点+人物情况+事项起因+事项经过'
+                        wrapperStyle={{ width: '100%' }}
+                      />
+                    </td>
+                  </tr>
+                  <tr>
+                    <th bgcolor="#F7F8FA" className="table-title">调解过程中的主要分歧点</th>
+                    <td>
+                      <Input.TextArea
+                        showWordLimit
+                        rows={3}
+                        placeholder='请完整描述事项概况,应具备5要素:发生时间+发生地点+人物情况+事项起因+事项经过'
+                        wrapperStyle={{ width: '100%' }}
+                      />
+                    </td>
+                  </tr>
+                  <tr>
+                    <th bgcolor="#F7F8FA" className="table-title">最终难以调和的原因</th>
+                    <td>
+                      <Input.TextArea
+                        showWordLimit
+                        rows={3}
+                        placeholder='请完整描述事项概况,应具备5要素:发生时间+发生地点+人物情况+事项起因+事项经过'
+                        wrapperStyle={{ width: '100%' }}
+                      />
+                    </td>
+                  </tr>
+                </table>
+              </FormItem>
+            </Col>
+            <Col span={24}>
+              <FormItem
+                label={
+                  <>
+                    <div style={{ display: 'flex' }}>
+                      结案意见
+                      <div className="must" style={{ marginLeft: '4px' }}>必填</div>
+                    </div>
+                  </>
+                }
+                field='caseDes'
+                rules={[{ message: '请填写事项概况', required: true }]}
+              >
+                <div className='caseResult-textarea'>公共模板1:化解不成功结案意见范本</div>
+                <Input.TextArea
+                  rows={5}
+                  wrapperStyle={{ width: '100%' }}
+                  value='鉴于以上协议内容已经双方确认,并认为该协议内容公平合理,能够妥善解决双方的纠纷。建议双方当事人按照协议内容执行,以实现纠纷的最终解决。'
+                />
+              </FormItem>
+            </Col>
+            <Col span={24}>
+              <FormItem
+                label='是否转诉讼案件'
+                field='caseDes'
+              >
+                <Radio.Group onChange={onChange} value={radioValue}>
+                  <Space direction="vertical">
+                    <Radio value={1}>否</Radio>
+                    <Radio value={2}>是</Radio>
+                  </Space>
+                </Radio.Group>
+              </FormItem>
+            </Col>
+            <Col span={24}>
+              <FormItem
+                label='是否转诉诉讼案号讼案件'
+                field='caseDes'
+              >
+                <Input style={{ width: 350 }} placeholder='请输入法院立案号' />
+              </FormItem>
+            </Col>
+            <Space style={{ marginBottom: '16px' }}>
+              <Button type='primary'>提交</Button>
+              <Button type='outline' style={{ color: '#1A6FB8', border: '1px solid #1A6FB8' }}>保存</Button>
+            </Space>
+          </Form>
+        }
       </Modal>
       <DocumentScanner
         visible={scanFile}
         onConfirm={handleConfirm}
         onCancel={handleCancel}
       />
+      <NoHandleReason
+        visible={noHandleReason}
+        onClose={() => setNoHandleReason(false)}
+      />
     </>
   )
 }

--
Gitblit v1.8.0