调解系统PC端服务

confirmMediation.vue 6.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  1. <template>
  2. <div>
  3. <el-dialog
  4. title="确认调解书"
  5. v-if="confirmTionVisable"
  6. :visible="confirmTionVisable"
  7. @close="cancel"
  8. width="800px"
  9. append-to-body
  10. :destroy-on-close="true"
  11. center
  12. >
  13. <el-form ref="form" :model="formData" label-width="180px">
  14. <div class="caseInfo">案件信息:</div>
  15. <el-row>
  16. <el-col :span="12">
  17. <el-form-item label="案件编号:" prop="caseNum">
  18. <el-input v-model="formData.caseNum" placeholder="请输入案件编号" :disabled="true" />
  19. </el-form-item>
  20. </el-col>
  21. <el-col :span="12">
  22. <el-form-item label="申请人:" prop="affiliate.applicationOrganName">
  23. <el-input v-model="formData.affiliate.applicationOrganName" :disabled="true" />
  24. </el-form-item>
  25. </el-col>
  26. <el-col :span="12">
  27. <el-form-item label="被申请人:" prop="respondentName">
  28. <el-input v-model="formData.affiliate.respondentName" :disabled="true" />
  29. </el-form-item>
  30. </el-col>
  31. <el-col :span="12">
  32. <el-form-item label="案件标的:" prop="caseSubjectAmount">
  33. <el-input
  34. v-model="formData.caseSubjectAmount"
  35. placeholder="请输入案件标的"
  36. :disabled="true"
  37. />
  38. </el-form-item>
  39. </el-col>
  40. <el-col :span="12">
  41. <el-form-item label="调解费用:" prop="feePayable">
  42. <el-input v-model="formData.feePayable" placeholder="请输入仲裁费用" :disabled="true" />
  43. </el-form-item>
  44. </el-col>
  45. <el-col :span="12">
  46. <el-form-item label="调解员:" prop="mediatorName">
  47. <el-input v-model="formData.mediatorName" placeholder="请输入" :disabled="true" />
  48. </el-form-item>
  49. </el-col>
  50. <el-col :span="12">
  51. <el-form-item label="调解书:">
  52. <div v-for="(item, index) in formData.caseAttachList" :key="index" v-if="item.annexType==7">
  53. <div style="color: blue;cursor: pointer;" @click="fileDetil(item.annexPath)">{{
  54. item.annexName }}</div>
  55. </div>
  56. </el-form-item>
  57. </el-col>
  58. </el-row>
  59. <div class="payupload">
  60. <span>上传修改后调解书</span>
  61. <div class="uploadBtn">
  62. <el-upload
  63. class="upload-demo"
  64. ref="upload"
  65. :action="UploadUrl()"
  66. :headers="headers"
  67. :data="filedata"
  68. :on-preview="handlePreview"
  69. :on-remove="handleRemove"
  70. :on-change="beforeUpload"
  71. :on-success="handlSuccess"
  72. :file-list="fileList"
  73. >
  74. <el-button slot="trigger" size="small" type="primary">选取文件</el-button>
  75. <!-- <el-button style="margin-left: 10px;" size="small" type="success" @click="submitUpload">上传到服务器</el-button> -->
  76. <div slot="tip" class="el-upload__tip">只能上传word文件</div>
  77. </el-upload>
  78. </div>
  79. </div>
  80. </el-form>
  81. <div slot="footer" class="dialog-footer">
  82. <el-button @click="cancel" class="endbutton1" round>
  83. <span>取 消</span>
  84. </el-button>
  85. <el-button @click="submitMediator" type="primary" class="endbutton1" round>
  86. <span>确 认</span>
  87. </el-button>
  88. </div>
  89. </el-dialog>
  90. </div>
  91. </template>
  92. <script>
  93. import { casePay, confirmPayDig } from "@/api/pay/pay";
  94. import { caseApplicationSelectById,confirmMediation } from "@/api/caseManagement/caseManagement.js";
  95. import { getToken } from "@/utils/auth";
  96. export default {
  97. props: ["confirmTionVisable", "queryParams", "confirmTionData"],
  98. data() {
  99. return {
  100. fileList: [],
  101. formData: {
  102. affiliate: {}
  103. },
  104. fileURL: window.location.origin + "/API",
  105. annexId:null,
  106. headers: {
  107. Authorization: "Bearer " + getToken()
  108. },
  109. filedata: {
  110. annexType: 7
  111. }
  112. };
  113. },
  114. methods: {
  115. /** 获取案件详情信息 */
  116. caseApplicationSelectByIdFn(data) {
  117. caseApplicationSelectById(data).then(res => {
  118. this.formData = res.data;
  119. });
  120. },
  121. /** 查看申请书 */
  122. fileDetil(val) {
  123. window.open(this.fileURL + val)
  124. },
  125. UploadUrl() {
  126. return window.location.origin + "/API/common/upload";
  127. },
  128. beforeUpload(flie, fileList) {
  129. this.fileList = fileList;
  130. },
  131. // 文件上传成功
  132. handlSuccess(res, file) {
  133. this.annexId = res.annexId;
  134. },
  135. submitMediator() {
  136. confirmMediation({
  137. caseAppliId: this.confirmTionData.id,
  138. caseFlowId: this.confirmTionData.caseFlowId,
  139. annexId: this.annexId
  140. }).then(res => {
  141. this.$modal.msgSuccess("成功");
  142. this.cancel();
  143. this.$emit("getList", this.queryParams);
  144. });
  145. },
  146. handleRemove(file, fileList) {},
  147. handlePreview(file) {},
  148. cancel() {
  149. this.$emit("cancelConfirmTion");
  150. }
  151. },
  152. watch: {
  153. confirmTionVisable(val) {
  154. if (val) {
  155. this.annexId = '';
  156. this.caseApplicationSelectByIdFn({
  157. id: this.confirmTionData.id
  158. });
  159. }
  160. }
  161. }
  162. };
  163. </script>
  164. <style lang="scss" scoped>
  165. .payType {
  166. height: 80px;
  167. line-height: 80px;
  168. display: flex;
  169. .icon-weixinzhifu {
  170. font-size: 24px;
  171. color: #27a56f;
  172. margin-right: 15px;
  173. }
  174. .icon-zhifubao {
  175. font-size: 24px;
  176. color: #1d76cc;
  177. }
  178. }
  179. .paySelectType {
  180. margin-top: 20px;
  181. margin-bottom: 20px;
  182. }
  183. .payupload {
  184. display: flex;
  185. .uploadBtn {
  186. margin-left: 20px;
  187. }
  188. }
  189. .payImg {
  190. width: 100%;
  191. display: flex;
  192. justify-content: center;
  193. }
  194. .payTitle {
  195. margin-top: 20px;
  196. width: 100%;
  197. text-align: center;
  198. }
  199. ::v-deep .el-dialog {
  200. width: 800px;
  201. background: #ffffff;
  202. border-radius: 20px;
  203. }
  204. .endbutton {
  205. width: 154px;
  206. height: 37px;
  207. background: #ffffff;
  208. border: 1px solid #d0d0d0;
  209. border-radius: 19px;
  210. span {
  211. width: 31px;
  212. height: 13px;
  213. font-size: 16px;
  214. font-family: Microsoft YaHei;
  215. font-weight: 400;
  216. color: #959595;
  217. }
  218. }
  219. </style>