应用层PC端前端服务

formateCourtDialog.vue 4.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. <template>
  2. <div>
  3. <!-- 组庭界面 -->
  4. <el-dialog
  5. title="组庭建议"
  6. :visible="showformateCourt"
  7. v-if="showformateCourt"
  8. @close="cancel"
  9. destroy-on-close
  10. center
  11. >
  12. <el-form label-width="150px" v-if="!noArbitrator">
  13. <el-form-item label="是否同意组庭:">
  14. <el-radio-group v-model="isAgreePendTral">
  15. <el-radio :label="1">是</el-radio>
  16. <el-radio :label="0">否</el-radio>
  17. </el-radio-group>
  18. </el-form-item>
  19. </el-form>
  20. <el-tag type="warning" v-if="noArbitrator"
  21. >当前案件未指定仲裁员,请先指定仲裁员!</el-tag
  22. >
  23. <p></p>
  24. <!-- <el-form ref="form"> -->
  25. <!-- v-if="isAgreePendTral == 0 || noArbitrator" -->
  26. <div style="display: inline-flex; margin-bottom: 8px">
  27. <div v-if="isAgreePendTral == 0">
  28. 请选择仲裁员
  29. </div>
  30. <div v-if="isAgreePendTral == 1 && formateCourtData.arbitratorName">
  31. 当前案件仲裁员
  32. </div>
  33. </div>
  34. <div v-if="isAgreePendTral == 1 && formateCourtData.arbitratorName" class="nowarbitrator">
  35. <el-tag size="medium">
  36. {{ formateCourtData.arbitratorName }}
  37. </el-tag>
  38. </div>
  39. <div v-if="noArbitrator || isAgreePendTral == 0">
  40. <el-form>
  41. <el-form-item label="仲裁员:">
  42. <el-select placeholder="请选择仲裁员" @change="changeArbitor" v-model="Arbitor">
  43. <el-option v-for="item in dataList" :key="item.value" :label="item.nickName" :value="item.userId"></el-option>
  44. </el-select>
  45. </el-form-item>
  46. </el-form>
  47. </div>
  48. <div slot="footer" class="dialog-footer">
  49. <el-button
  50. type="primary"
  51. @click="submitForm"
  52. :disabled="noArbitrator && isAgreePendTral == 0"
  53. class="endbutton"
  54. ><span>确 定</span></el-button
  55. >
  56. <el-button @click="cancel" class="endbutton1"
  57. ><span>取 消</span></el-button
  58. >
  59. </div>
  60. </el-dialog>
  61. </div>
  62. </template>
  63. <script>
  64. import { arbitrAtor, pendTralCheck } from "@/api/formationCourt/formationCourt";
  65. export default {
  66. props: ["showformateCourt", "formateCourtData", "queryParams"],
  67. data() {
  68. return {
  69. dataList: [],
  70. queryParams1: {
  71. pageNum: 1,
  72. pageSize: 10,
  73. },
  74. arbitrators: [],
  75. isAgreePendTral: 1,
  76. paramsdata: {},
  77. noArbitrator: false,
  78. Arbitor: ""
  79. };
  80. },
  81. created() {
  82. this.getarbitrAtor();
  83. },
  84. watch: {
  85. showformateCourt(val){
  86. if(val){
  87. this.isAgreePendTral = 1;
  88. }
  89. },
  90. formateCourtData: {
  91. handler(val) {
  92. if (val.arbitratorName == null) {
  93. this.noArbitrator = true;
  94. } else {
  95. this.noArbitrator = false;
  96. }
  97. },
  98. },
  99. },
  100. methods: {
  101. // 获取仲裁员信息
  102. getarbitrAtor() {
  103. arbitrAtor({}).then((res) => {
  104. this.dataList = res.rows;
  105. });
  106. },
  107. changeArbitor(val) {
  108. this.arbitrators = [];
  109. this.dataList.forEach((item) => {
  110. if (item.userId == val) {
  111. this.arbitrators.push({
  112. id: item.userId,
  113. arbitratorName: item.nickName,
  114. });
  115. }
  116. })
  117. },
  118. // 确认
  119. submitForm() {
  120. if (this.noArbitrator) {
  121. this.paramsdata = {
  122. id: this.formateCourtData.id,
  123. arbitrators: this.arbitrators,
  124. };
  125. } else {
  126. if (this.isAgreePendTral == 0) {
  127. this.paramsdata = {
  128. isAgreePendTral: 0,
  129. id: this.formateCourtData.id,
  130. arbitrators: this.arbitrators,
  131. };
  132. } else {
  133. this.paramsdata = {
  134. isAgreePendTral: 1,
  135. id: this.formateCourtData.id,
  136. };
  137. }
  138. }
  139. pendTralCheck(this.paramsdata).then((res) => {
  140. this.cancel();
  141. this.$modal.msgSuccess("组庭成功");
  142. this.$emit("getcaseApply", this.queryParams);
  143. });
  144. // }
  145. },
  146. // 取消
  147. cancel() {
  148. this.$emit("cancelcourtDialog");
  149. this.arbitrators = [];
  150. },
  151. },
  152. };
  153. </script>
  154. <style lang="scss" scoped>
  155. ::v-deep .el-dialog {
  156. background: #ffffff;
  157. border-radius: 20px;
  158. }
  159. .endbutton {
  160. width: 124px;
  161. height: 37px;
  162. background: #0072ff;
  163. border-radius: 19px;
  164. span {
  165. width: 32px;
  166. height: 15px;
  167. font-size: 16px;
  168. font-family: Microsoft YaHei;
  169. font-weight: 400;
  170. color: #ffffff;
  171. }
  172. }
  173. .endbutton1 {
  174. width: 124px;
  175. height: 37px;
  176. background: #ffffff;
  177. border: 1px solid #d0d0d0;
  178. border-radius: 19px;
  179. span {
  180. width: 31px;
  181. height: 13px;
  182. font-size: 16px;
  183. font-family: Microsoft YaHei;
  184. font-weight: 400;
  185. color: #959595;
  186. }
  187. }
  188. .infoIcon {
  189. width: 4px;
  190. // height: 17px;
  191. background-color: #0072ff;
  192. margin-right: 5px;
  193. }
  194. .nowarbitrator {
  195. margin-left: 4%;
  196. }
  197. </style>