From f6efc465e8f5633313afc8da54c17988722073eb Mon Sep 17 00:00:00 2001
From: zhangyongtian <1181606322@qq.com>
Date: Sat, 14 Sep 2024 15:55:07 +0800
Subject: [PATCH] fix: 审核页面逻辑调整、滚动调整

---
 gz-customerSystem/src/views/register/handleFeedback/component/CaseResult.jsx |  263 ++++++++++++++++++++++++++--------------------------
 1 files changed, 133 insertions(+), 130 deletions(-)

diff --git a/gz-customerSystem/src/views/register/handleFeedback/component/CaseResult.jsx b/gz-customerSystem/src/views/register/handleFeedback/component/CaseResult.jsx
index f5c29ad..a2a9fd8 100644
--- a/gz-customerSystem/src/views/register/handleFeedback/component/CaseResult.jsx
+++ b/gz-customerSystem/src/views/register/handleFeedback/component/CaseResult.jsx
@@ -2,11 +2,12 @@
  * @Author: dminyi 1301963064@qq.com
  * @Date: 2024-09-02 14:49:13
  * @LastEditors: dminyi 1301963064@qq.com
- * @LastEditTime: 2024-09-09 22:14:40
+ * @LastEditTime: 2024-09-12 12:03:56
  * @FilePath: \gzDyh\gz-customerSystem\src\views\register\handleFeedback\component\CaseResult.jsx
  * @Description: 结案申请
  */
 import React, { useState, useRef } from 'react';
+import { useNavigate } from 'react-router-dom';
 import { Modal, Form, Select, Upload, Input } from '@arco-design/web-react';
 import { Col, Space, Button, Tooltip, Radio, Row } from 'antd';
 import DocumentScanner from '../../matterDetail/FileUpLoad'
@@ -18,7 +19,10 @@
 import * as $$ from '@/utils/utility';
 const appUrl = $$.appUrl;
 
+
 const FormItem = Form.Item;
+const TextArea = Input.TextArea;
+
 
 function windupApplyApi(data) {
   return $$.ax.request({ url: `caseTask/windupApply`, type: 'post', service: 'mediate', data });
@@ -26,8 +30,12 @@
 
 
 
-const CaseResult = ({ visible = false, handleOnCancel, caseResultId, caseId ,caseTaskId}) => {
+const CaseResult = ({ visible = false, handleOnCancel, caseResultId, caseId, caseTaskId }) => {
   const formRef = useRef();
+  const [selectedTemplate, setSelectedTemplate] = useState();
+  const [selectedTemplate1, setSelectedTemplate1] = useState();
+  const [selectedTemplate2, setSelectedTemplate2] = useState();
+  const navigate = useNavigate();
   const formRefWrite = useRef();
   const failRef = useRef();
   const [selectedTab, setSelectedTab] = useState('1'); // 默认选中第一个 tab
@@ -75,10 +83,38 @@
     setScanFile(false);
   };
 
-  const onChange = (e) => {
-    console.log('radio checked', e.target.value);
-    setRadioValue(e.target.value);
-  };
+  const handleTemplate = (type) => {
+    setSelectedTemplate(type);
+    if (type === 1) {
+      formRef.current.setFieldValue('windupContent', '双方当事人于xx时间xx地址已达成xx协议,纠纷已化解。')
+    } else {
+      formRef.current.setFieldValue('windupContent', '')
+    }
+  }
+
+  const handleTemplate1 = (type) => {
+    setSelectedTemplate1(type);
+    if (type === 1) {
+      formRef.current.setFieldValue('agreeContent', '根据纠纷化解人员的协调,当事人双方同意如下调解协议:[简要说明协议第一条][简要说明协议第二条][……]本口头调解协议由纠纷化解人员记录,并已告知双方当事人。双方当事人确认无误。')
+    }
+  }
+
+  const handleTemplate2 = (type) => {
+    setSelectedTemplate2(type);
+    if (type === 1) {
+      formRefWrite.current.setFieldValue('windupContent', '双方当事人于xx时间xx地址已达成xx协议,纠纷已化解。')
+    } else {
+      formRefWrite.current.setFieldValue('windupContent', '')
+    }
+  }
+
+  const handleTemplate3 = (type) => {
+    if (type === 1) {
+      failRef.current.setFieldValue('windupContent', '经过多次调解,尽管纠纷化解人员尽最大努力帮助双方找到解决方案,但由于以下原因,当事人双方未能达成一致意见:[详细说明化解未成功的原因之一][详细说明化解未成功的原因之二][……][……]鉴于上述情况,纠纷化解人员认为目前无法通过调解方式解决双方的争议,建议双方考虑采取其他合法途径解决纠纷。')
+    } else {
+      failRef.current.setFieldValue('windupContent', '')
+    }
+  }
 
   const handleSubmit = () => {
     if (value === 1) {
@@ -110,15 +146,32 @@
   }
 
   const windupApply = async (submitData) => {
+    console.log(
+      {
+        mediResultName: selectedTab === '1' ? '化解成功' : '化解不成功',
+        mediResult: selectedTab === '1' ? '22_00025-1' : '22_00025-2',
+        agreeType: selectedTab === '1' ? '24_00003-1' : '24_00003-2',
+        agreeTypeName: value === 1 ? '口头协议' : '书面协议',
+        caseTaskId: caseTaskId,
+        caseId: caseId,
+        caseResultId: caseResultId,
+        ...submitData
+      }, 'windupApplyData'
+    )
     const res = await windupApplyApi({
+      mediResultName: selectedTab === '1' ? '化解成功' : '化解不成功',
+      mediResult: selectedTab === '1' ? '22_00025-1' : '22_00025-2',
+      agreeType: selectedTab === '1' ? '24_00003-1' : '24_00003-2',
+      agreeTypeName: value === 1 ? '口头协议' : '书面协议',
       caseTaskId: caseTaskId,
-      caseId:caseId,
-      caseResultId:caseResultId,
+      caseId: caseId,
+      caseResultId: caseResultId,
       ...submitData
     })
     if (res.type) {
       $$.infoSuccess({ content: '提交成功' });
-      handleOnCancel()
+      handleOnCancel();
+      navigate('/mediate/visit/visitWorkBench')
     }
   }
 
@@ -160,7 +213,7 @@
             scrollToFirstError={true}
             requiredSymbol={false}
             initialValues={{
-              agreeType: 1,
+              agreeType: 2,
             }} //默认值
           >
             <Col span={8}>
@@ -185,72 +238,62 @@
                   scrollToFirstError={true}
                 >
                   <Row>
-                    <Col span={24}>
+                    <Col span={24} style={{ position: 'relative' }}>
                       <FormItem
-                        label={
+                        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 className="must">必填</div>
                             </div>
                             <div className='caseResult-tips'>
-                              <img src={tip} alt='' style={{ width: '16px', marginRight: '8px' }} />
+                              <img src={tip} alt='' style={{ width: '16px', marginRight: '8px',marginTop: '-5px' }} />
                               <span>协议要点应尽量简洁,当事人大厅来访或小程序线上反映问题时,可在小程序中查看到填写的协议要点内容</span>
                             </div>
-                            <div className='modeMore'>
-                              <div className='caseResult-textarea'>公共模板1:调解成功口头协议</div>
-                              <div style={{ color: '#1A6FB8' }} onClick={() => setMode(!mode)}>更多模板</div>
+                            <div style={{ position: 'absolute', display: 'flex ', top: '79px', zIndex: 1 }}>
+                              <div
+                                className={`myTag ${selectedTemplate1 === 1 ? 'highlighted' : ''}`} // 条件样式
+                                style={{ marginRight: '22px' }}
+                                onClick={() => handleTemplate1(1)}
+                              >
+                                公共模板:调解成功口头协议
+                              </div>
                             </div>
                           </>
-                        }
+                        )}
                         field='agreeContent'
                       >
-                        <Input.TextArea
-                          rows={5}
-                          maxLength={{ length: 200, errorOnly: true }}
-                          showWordLimit
-                          wrapperStyle={{ width: '100%' }}
+                        <TextArea
+                          autoSize={{ minRows: 4, maxRows: 8 }}
+                          placeholder='请填写'
+                          style={{ marginTop: '40px' }}
                         />
                       </FormItem>
                     </Col>
-                    <Col span={24}>
+                    <Col span={24} style={{ position: 'relative' }}>
+                      <div style={{ position: 'absolute', display: 'flex', top: '28px', zIndex: 1 }}>
+                        <div
+                          className={`myTag ${selectedTemplate === 1 ? 'highlighted' : ''}`} // 条件样式
+                          style={{ marginRight: '22px' }}
+                          onClick={() => handleTemplate(1)}
+                        >
+                          公共模板:化解成功结案意见范本
+                        </div>
+                        <div
+                          className={`myTag ${selectedTemplate === 2 ? 'highlighted' : ''}`} // 条件样式
+                          onClick={() => handleTemplate(2)}
+                        >
+                          个人模板:化解成功结案意见范本(完整版)
+                        </div>
+                      </div>
                       <FormItem
-                        label={
-                          <>
-                            <div style={{ display: 'flex' }}>
-                              结案意见
-                              <div className="must" style={{ marginLeft: '4px' }}>必填</div>
-                            </div>
-                            <div className='modeMore'>
-                              <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>
-                              <div style={{ color: '#1A6FB8' }} onClick={() => setMode(!mode)}>更多模板</div>
-
-                            </div>
-                          </>
-                        }
+                        label={(<div style={{ display: 'flex' }}>结案意见<div className="must">必填</div></div>)}
                         field='windupContent'
                       >
-                        <Input.TextArea
-                          rows={5}
-                          wrapperStyle={{ width: '100%' }}
+                        <TextArea
+                          autoSize={{ minRows: 4, maxRows: 8 }}
+                          placeholder='请填写'
+                          style={{ marginTop: '35px' }}
                         />
                       </FormItem>
                     </Col>
@@ -290,68 +333,37 @@
                             action: `${appUrl.fileUrl}/${appUrl.sys}/api/web/fileInfo/upload?mainId=${caseId}&ownerId=${caseResultId}&ownerType=22_00018-302`,
                           }}
                           field='file'
-                          label='代理人委托书'
+                          label=''
                           // editData={props.editData}
                           ownerType='22_00018-302'
                         />
                       </FormItem>
                     </Col>
-                    <Col span={24}>
+                    <Col span={24} style={{ position: 'relative' }}>
+                      <div style={{ position: 'absolute', display: 'flex', top: '28px', zIndex: 1 }}>
+                        <div
+                          className={`myTag ${selectedTemplate2 === 1 ? 'highlighted' : ''}`} // 条件样式
+                          style={{ marginRight: '22px' }}
+                          onClick={() => handleTemplate2(1)}
+                        >
+                          公共模板:化解成功结案意见范本
+                        </div>
+                        <div
+                          className={`myTag ${selectedTemplate2 === 2 ? 'highlighted' : ''}`} // 条件样式
+                          onClick={() => handleTemplate2(2)}
+                        >
+                          个人模板:化解成功结案意见范本(完整版)
+                        </div>
+                      </div>
+
                       <FormItem
-                        label={
-                          <>
-                            <div style={{ display: 'flex' }}>
-                              结案意见
-                              <div className="must" style={{ marginLeft: '4px' }}>必填</div>
-                            </div>
-                            <div className='modeMore'>
-                              <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>
-                              <div style={{ color: '#1A6FB8' }} onClick={() => setMode(!mode)}>更多模板</div>
-
-                            </div>
-
-                          </>
-                        }
+                        label={(<div style={{ display: 'flex' }}>结案意见<div className="must">必填</div></div>)}
                         field='windupContent'
-                        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='鉴于以上协议内容已经双方确认,并认为该协议内容公平合理,能够妥善解决双方的纠纷。建议双方当事人按照协议内容执行,以实现纠纷的最终解决。'
+                        <TextArea
+                          autoSize={{ minRows: 4, maxRows: 8 }}
+                          placeholder='请填写'
+                          style={{ marginTop: '35px' }}
                         />
                       </FormItem>
                     </Col>
@@ -441,27 +453,18 @@
                 </tr>
               </table>
             </Col>
-            <Col span={24}>
+            <Col span={24} style={{ position: 'relative' }}>
+              <div style={{ position: 'absolute', display: 'flex ', top: '28px', zIndex: 1 }}>
+                <div className='myTag' style={{ marginRight: '22px' }} onClick={() => { handleTemplate3(1) }}>公共模板:化解不成功结案意见范本</div>
+              </div>
               <FormItem
-                label={
-                  <>
-                    <div style={{ display: 'flex' }}>
-                      结案意见
-                      <div className="must" style={{ marginLeft: '4px' }}>必填</div>
-                    </div>
-                    <div className='modeMore'>
-                      <div className='caseResult-textarea'>公共模板:化解不成功结案意见范本</div>
-                      <div style={{ color: '#1A6FB8' }} onClick={() => setMode(!mode)}>更多模板</div>
-                    </div>
-                  </>
-                }
+                label={(<div style={{ display: 'flex' }}>结案意见<div className="must">必填</div></div>)}
                 field='windupContent'
-                rules={[{ message: '请填写事项概况', required: true }]}
               >
-                <Input.TextArea
-                  rows={5}
-                  wrapperStyle={{ width: '100%' }}
-                  value='鉴于以上协议内容已经双方确认,并认为该协议内容公平合理,能够妥善解决双方的纠纷。建议双方当事人按照协议内容执行,以实现纠纷的最终解决。'
+                <TextArea
+                  autoSize={{ minRows: 4, maxRows: 8 }}
+                  placeholder='请填写'
+                  style={{ marginTop: '35px' }}
                 />
               </FormItem>
             </Col>

--
Gitblit v1.8.0