应用层PC端前端服务

paymentdetailsDialog.vue 10KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354
  1. <template>
  2. <div>
  3. <el-dialog
  4. :title="title"
  5. :visible="openDialog"
  6. width="1000px"
  7. @close="cancel"
  8. :destroy-on-close="true"
  9. >
  10. <el-descriptions title="案件信息" border style="margin-bottom: 30px">
  11. <el-descriptions-item label="案件编号">{{
  12. form.caseNum
  13. }}</el-descriptions-item>
  14. <el-descriptions-item label="案件标的">{{
  15. form.caseSubjectAmount
  16. }}</el-descriptions-item>
  17. <el-descriptions-item label="借款开始日期">{{
  18. form.loanStartDate
  19. }}</el-descriptions-item>
  20. <el-descriptions-item label="借款结束日期">{{
  21. form.loanEndDate
  22. }}</el-descriptions-item>
  23. <el-descriptions-item label="合同编号">{{
  24. form.contractNumber
  25. }}</el-descriptions-item>
  26. <el-descriptions-item label="申请人主张欠本金">{{
  27. form.claimPrinciOwed
  28. }}</el-descriptions-item>
  29. <el-descriptions-item label="申请人主张欠利息">{{
  30. form.claimInterestOwed
  31. }}</el-descriptions-item>
  32. <el-descriptions-item label="申请人主张违约金">{{
  33. form.claimLiquidDamag
  34. }}</el-descriptions-item>
  35. <el-descriptions-item label="申请人案件证据资料">
  36. <p
  37. @click="toFile(index, 2)"
  38. v-for="(item, index) in applicantFileArr"
  39. :key="index"
  40. >
  41. <a href="#">{{ item }}</a>
  42. </p>
  43. </el-descriptions-item>
  44. <el-descriptions-item label="被申请人案件证据资料">
  45. <p
  46. v-for="(item, index) in respondentFileArr"
  47. :key="index"
  48. @click="toFile(index, 6)"
  49. >
  50. <a href="#">{{ item }}</a>
  51. </p>
  52. </el-descriptions-item>
  53. <el-descriptions-item label="裁决书附件">
  54. <p
  55. v-for="(item, index) in awardFileArr"
  56. :key="index"
  57. @click="toFile(index, 3)"
  58. >
  59. <a href="#">{{ item }}</a>
  60. </p>
  61. </el-descriptions-item>
  62. </el-descriptions>
  63. <el-form
  64. ref="form"
  65. :model="arbitrateRecord"
  66. label-width="300px"
  67. label-position="left"
  68. :rules="rules"
  69. :disabled="flag == 3"
  70. >
  71. <el-form-item
  72. label="经庭审质证,对各方提供的证据认定如下"
  73. prop="evidenDetermi"
  74. >
  75. <el-input
  76. type="textarea"
  77. autosize
  78. :disabled="flag == 2 || flag == 1"
  79. placeholder="请输入内容"
  80. v-model="arbitrateRecord.evidenDetermi"
  81. />
  82. </el-form-item>
  83. <el-form-item
  84. label="仲裁庭经审理查明(写明仲裁庭认定的事实)"
  85. prop="factDetermi"
  86. >
  87. <el-input
  88. type="textarea"
  89. autosize
  90. :disabled="flag == 2 || flag == 1"
  91. placeholder="请输入内容"
  92. v-model="arbitrateRecord.factDetermi"
  93. />
  94. </el-form-item>
  95. <el-form-item label="综上所述" prop="caseSketch">
  96. <el-input
  97. type="textarea"
  98. autosize
  99. :disabled="flag == 2 || flag == 1"
  100. placeholder="请输入内容"
  101. v-model="arbitrateRecord.caseSketch"
  102. />
  103. </el-form-item>
  104. <el-form-item label="本庭认为" prop="arbitrateThink">
  105. <el-input
  106. type="textarea"
  107. autosize
  108. :disabled="flag == 2 || flag == 1"
  109. placeholder="请输入内容"
  110. v-model="arbitrateRecord.arbitrateThink"
  111. />
  112. </el-form-item>
  113. <el-form-item label="裁决如下" prop="rulingFollows">
  114. <el-input
  115. type="textarea"
  116. autosize
  117. :disabled="flag == 2 || flag == 1"
  118. placeholder="请输入内容"
  119. v-model="arbitrateRecord.rulingFollows"
  120. />
  121. </el-form-item>
  122. <el-form-item label="核验裁决书意见:" prop="verificaOpinion">
  123. <el-input
  124. type="textarea"
  125. autosize
  126. :disabled="flag == 2"
  127. placeholder="请输入内容"
  128. v-model="arbitrateRecord.verificaOpinion"
  129. />
  130. </el-form-item>
  131. <el-form-item
  132. label="审核裁决书意见:"
  133. prop="checkOpinion"
  134. v-if="flag == 2"
  135. >
  136. <el-input
  137. type="textarea"
  138. autosize
  139. placeholder="请输入内容"
  140. v-model="arbitrateRecord.checkOpinion"
  141. />
  142. </el-form-item>
  143. </el-form>
  144. <!-- 画布 -->
  145. <h4 v-if="flag == 3">签名区域</h4>
  146. <div class="esign" v-if="flag == 3">
  147. <vue-esign ref="esign" :width="900" :height="300" bgColor="#ffffff" />
  148. </div>
  149. <!-- 清除画布 -->
  150. <el-button v-if="flag == 3" type="info" @click="handleReset"
  151. >清除画布</el-button
  152. >
  153. <div slot="footer" class="dialog-footer">
  154. <el-button type="primary" @click="submitForm(0)" v-if="flag == 1"
  155. >提 交</el-button
  156. >
  157. <el-button type="primary" @click="submitForm(1)" v-if="flag == 2"
  158. >同 意</el-button
  159. >
  160. <el-button type="danger" @click="submitForm(2)" v-if="flag == 2"
  161. >驳 回</el-button
  162. >
  163. <el-button type="primary" @click="submitForm(3)" v-if="flag == 3"
  164. >提 交</el-button
  165. >
  166. <el-button @click="cancel">取 消</el-button>
  167. </div>
  168. </el-dialog>
  169. </div>
  170. </template>
  171. <script>
  172. import {
  173. verificationArbitrateRecord,
  174. checkArbitrateRecord,
  175. } from "@/api/awardManagement/awardManagement";
  176. export default {
  177. props: ["openDialog", "title", "flag", "detailform"],
  178. data() {
  179. return {
  180. // key: value
  181. form: {},
  182. arbitrateRecord: {},
  183. // 表单校验
  184. rules: {
  185. evidenDetermi: [
  186. {
  187. required: true,
  188. message: "不能为空",
  189. trigger: "blur",
  190. },
  191. ],
  192. factDetermi: [
  193. {
  194. required: true,
  195. message: "不能为空",
  196. trigger: "blur",
  197. },
  198. ],
  199. caseSketch: [
  200. {
  201. required: true,
  202. message: "不能为空",
  203. trigger: "blur",
  204. },
  205. ],
  206. arbitrateThink: [
  207. {
  208. required: true,
  209. message: "不能为空",
  210. trigger: "blur",
  211. },
  212. ],
  213. rulingFollows: [
  214. {
  215. required: true,
  216. message: "不能为空",
  217. trigger: "blur",
  218. },
  219. ],
  220. verificaOpinion: [
  221. {
  222. required: true,
  223. message: "意见不能为空",
  224. trigger: "blur",
  225. },
  226. ],
  227. checkOpinion: [
  228. {
  229. required: true,
  230. message: "意见不能为空",
  231. trigger: "blur",
  232. },
  233. ],
  234. },
  235. applicantFileArr: [], //申请人
  236. applicantPathArr: [], //申请人
  237. respondentFileArr: [], //被申请人
  238. respondenPathArr: [], //被申请人
  239. awardFileArr: [], //裁决书
  240. awardPathArr: [], //裁决书
  241. };
  242. },
  243. watch: {
  244. detailform: {
  245. handler(val) {
  246. if (val) {
  247. (this.applicantFileArr = []), //申请人
  248. (this.applicantPathArr = []), //申请人
  249. (this.respondentFileArr = []), //被申请人
  250. (this.respondenPathArr = []), //被申请人
  251. (this.awardFileArr = []), //裁决书
  252. (this.awardPathArr = []), //裁决书
  253. setTimeout(() => {
  254. this.form = this.detailform;
  255. this.arbitrateRecord = this.form.arbitrateRecord;
  256. this.evidenceFile(this.form);
  257. }, 1000);
  258. }
  259. },
  260. },
  261. },
  262. methods: {
  263. // 申请人裁决书
  264. evidenceFile(val) {
  265. if (val) {
  266. val.caseAttachList.forEach((item) => {
  267. if (item.annexType == 2) {
  268. this.applicantFileArr.push(item.annexName);
  269. this.applicantPathArr.push(item.annexPath);
  270. } else if (item.annexType == 6) {
  271. this.respondentFileArr.push(item.annexName);
  272. this.respondenPathArr.push(item.annexPath);
  273. } else if (item.annexType == 3) {
  274. this.awardFileArr.push(item.annexName);
  275. this.awardPathArr.push(item.annexPath);
  276. }
  277. });
  278. }
  279. },
  280. // 预览文件
  281. toFile(index, val) {
  282. let headPath = window.location.origin + "/API";
  283. if (val == 2) {
  284. window.open(headPath + this.applicantPathArr[index], "_blank");
  285. } else if (val == 6) {
  286. window.open(headPath + this.respondenPathArr[index], "_blank");
  287. } else if (val == 3) {
  288. window.open(headPath + this.awardPathArr[index], "_blank");
  289. }
  290. },
  291. // 校验裁决书
  292. verificationArbitrateRecordFn(parms) {
  293. verificationArbitrateRecord(parms).then((res) => {
  294. this.cancel();
  295. this.$emit("updataList");
  296. this.$message("成功");
  297. });
  298. },
  299. //审核裁决书
  300. checkArbitrateRecordFn(parms) {
  301. checkArbitrateRecord(parms).then((res) => {
  302. this.cancel();
  303. this.$emit("updataList");
  304. this.$message("成功");
  305. });
  306. },
  307. submitForm(parms) {
  308. this.$refs["form"].validate((valid) => {
  309. if (valid) {
  310. if (parms == 0) {
  311. this.verificationArbitrateRecordFn({
  312. id: this.form.id,
  313. arbitrateRecord: this.arbitrateRecord,
  314. });
  315. } else if (parms == 1) {
  316. this.checkArbitrateRecordFn({
  317. id: this.form.id,
  318. agreeOrNotCheck: 1,
  319. arbitrateRecord: this.arbitrateRecord,
  320. });
  321. } else if (parms == 2) {
  322. this.checkArbitrateRecordFn({
  323. id: this.form.id,
  324. agreeOrNotCheck: 2,
  325. arbitrateRecord: this.arbitrateRecord,
  326. });
  327. }
  328. }
  329. });
  330. },
  331. cancel() {
  332. this.$emit("cancelpaymentdetails");
  333. },
  334. // 清除画布
  335. handleReset() {
  336. this.$refs["esign"].reset(); //清空画布
  337. },
  338. },
  339. };
  340. </script>
  341. <style lang="scss" scoped>
  342. ::v-deep .el-dialog {
  343. border-radius: 30px;
  344. }
  345. .esign {
  346. border: 1px solid;
  347. }
  348. a {
  349. color: blue;
  350. }
  351. </style>