levelSettingAdd.vue 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. <template>
  2. <el-dialog
  3. width="980px"
  4. title="新增"
  5. :visible.sync="addVisible"
  6. :before-close="onClose"
  7. append-to-body
  8. >
  9. <el-form
  10. class="elForm"
  11. ref="elForm"
  12. label-position="top"
  13. :model="forms"
  14. :inline="false"
  15. label-width="100px"
  16. >
  17. <el-row>
  18. <el-col :span="24">
  19. <el-form-item
  20. label="考级类型"
  21. :rules="[{ required: true, message: '请选择考级类型' }]"
  22. prop="degreeType"
  23. class="el-from-type"
  24. >
  25. <el-radio-group v-model="forms.degreeType" @input="onTypeChange">
  26. <el-radio label="GRADE">考级</el-radio>
  27. <el-radio label="THEORY">乐理</el-radio>
  28. </el-radio-group>
  29. </el-form-item>
  30. </el-col>
  31. </el-row>
  32. <el-row :gutter="10">
  33. <el-col :span="5" v-if="forms.degreeType === 'GRADE'">
  34. <el-form-item
  35. label="声部"
  36. :rules="[{ required: true, message: '请选择声部' }]"
  37. prop="subjectId"
  38. >
  39. <el-select
  40. style="width: 100% !important;"
  41. v-model="forms.subjectId"
  42. clearable
  43. filterable
  44. placeholder="请选择声部"
  45. >
  46. <el-option
  47. v-for="item in selects.subjects"
  48. :key="item.id"
  49. :label="item.name"
  50. :value="item.id"
  51. ></el-option>
  52. </el-select>
  53. </el-form-item>
  54. </el-col>
  55. <el-col :span="forms.degreeType === 'GRADE' ? 19 : 24">
  56. <el-row :gutter="10">
  57. <el-col
  58. :span="7"
  59. class="el-form-item is-required el-form-item--medium el-form-title"
  60. >
  61. <label class="el-form-item__label">级别</label>
  62. </el-col>
  63. <el-col
  64. :span="7"
  65. class="el-form-item is-required el-form-item--medium el-form-title"
  66. >
  67. <label class="el-form-item__label">报考金额</label>
  68. </el-col>
  69. <el-col
  70. :span="7"
  71. class="el-form-item is-required el-form-item--medium el-form-title"
  72. >
  73. <label class="el-form-item__label">是否上传证书</label>
  74. </el-col>
  75. </el-row>
  76. <el-row
  77. :gutter="10"
  78. v-for="(item, index) in forms.domains"
  79. :key="index"
  80. >
  81. <el-col :span="7">
  82. <el-form-item
  83. :rules="[{ required: true, message: '请选择级别' }]"
  84. :prop="'domains.' + index + '.level'"
  85. >
  86. <el-select
  87. style="width: 100% !important;"
  88. v-model="item.level"
  89. clearable
  90. filterable
  91. placeholder="请选择级别"
  92. >
  93. <el-option
  94. v-for="item in degreeLevel"
  95. :key="item.value"
  96. :value="item.value"
  97. :label="item.text"
  98. ></el-option>
  99. </el-select>
  100. </el-form-item>
  101. </el-col>
  102. <el-col :span="7">
  103. <el-form-item
  104. :rules="[{ required: true, message: '请输入报考金额' }]"
  105. :prop="'domains.' + index + '.fee'"
  106. >
  107. <el-input
  108. @keyup.native="keyupEvent"
  109. v-model="item.fee"
  110. maxlength="8"
  111. placeholder="请输入报考金额"
  112. ></el-input> </el-form-item
  113. ></el-col>
  114. <el-col :span="7">
  115. <el-form-item
  116. :rules="[{ required: true, message: '请选择是否上传证书' }]"
  117. :prop="'domains.' + index + '.credentials'"
  118. >
  119. <el-select
  120. style="width: 100% !important;"
  121. v-model="item.credentials"
  122. clearable
  123. placeholder="请选择是否上传证书"
  124. >
  125. <el-option :value="false" label="无需上传"></el-option>
  126. <el-option :value="true" label="需上传"></el-option>
  127. </el-select>
  128. </el-form-item>
  129. </el-col>
  130. <el-col :span="3">
  131. <div class="btnGroup" style="display: inline-block">
  132. <el-button
  133. icon="el-icon-plus"
  134. circle
  135. @click="onAdd()"
  136. ></el-button>
  137. <el-button
  138. icon="el-icon-minus"
  139. circle
  140. :disabled="forms.domains.length <= 1 ? true : false"
  141. @click="onRemove(item)"
  142. ></el-button>
  143. </div>
  144. </el-col>
  145. </el-row>
  146. </el-col>
  147. </el-row>
  148. </el-form>
  149. <div slot="footer" class="dialog-footer">
  150. <el-button @click="onClose()">取 消</el-button>
  151. <el-button type="primary" @click="onSubmit">确 定</el-button>
  152. </div>
  153. </el-dialog>
  154. </template>
  155. <script>
  156. import {
  157. degreeLevel,
  158. degreeTheory,
  159. degreeLevelFeeSave
  160. } from "../levelManageApi";
  161. export default {
  162. name: "levelSettingAdd",
  163. data() {
  164. return {
  165. degreeLevel: [],
  166. addVisible: false,
  167. forms: {
  168. degreeType: "GRADE", // theory
  169. subjectId: null,
  170. domains: [
  171. {
  172. level: null,
  173. fee: null,
  174. credentials: null
  175. }
  176. ]
  177. }
  178. };
  179. },
  180. mounted() {
  181. this.degreeLevel = degreeLevel;
  182. },
  183. methods: {
  184. onClose() {
  185. this.$refs.elForm && this.$refs.elForm.resetFields();
  186. this.forms.type = "GRADE";
  187. this.forms.domains = [
  188. {
  189. level: null,
  190. fee: null,
  191. credentials: null
  192. }
  193. ];
  194. this.addVisible = false;
  195. },
  196. onTypeChange(val) {
  197. // 当前考级类型变化时,重置表单验证状态
  198. if (val === "THEORY") {
  199. this.degreeLevel = degreeTheory;
  200. } else if (val === "GRADE") {
  201. this.degreeLevel = degreeLevel;
  202. }
  203. this.forms.domains = [
  204. {
  205. level: null,
  206. fee: null,
  207. credentials: null
  208. }
  209. ];
  210. this.forms.subjectId = null;
  211. this.$refs.elForm && this.$refs.elForm.clearValidate();
  212. },
  213. onAdd() {
  214. this.forms.domains.push({
  215. level: null,
  216. fee: null,
  217. credentials: null
  218. });
  219. },
  220. onRemove(item) {
  221. let index = this.forms.domains.indexOf(item);
  222. if (index !== -1) {
  223. this.forms.domains.splice(index, 1);
  224. }
  225. },
  226. onSubmit() {
  227. this.$refs.elForm.validate(async res => {
  228. if (!res) return;
  229. try {
  230. const domains = this.forms.domains;
  231. domains.forEach(item => {
  232. item.degreeType = this.forms.degreeType;
  233. if (this.forms.degreeType === "GRADE") {
  234. item.subjectId = this.forms.subjectId;
  235. }
  236. });
  237. console.log(domains, "domains");
  238. await degreeLevelFeeSave(domains);
  239. this.$message.success("添加成功");
  240. this.updateVisible = false;
  241. this.onClose();
  242. this.$emit("getList");
  243. } catch {}
  244. });
  245. },
  246. openDialog() {
  247. this.addVisible = true;
  248. }
  249. }
  250. };
  251. </script>
  252. <style lang="scss" scoped>
  253. ::v-deep .el-form-item__label {
  254. padding: 0;
  255. }
  256. .el-form-title {
  257. margin: 0 !important;
  258. }
  259. .el-from-type {
  260. display: flex;
  261. ::v-deep .el-form-item__label {
  262. width: 100px !important;
  263. }
  264. }
  265. .btnGroup {
  266. .el-button + .el-button {
  267. margin-left: 5px;
  268. }
  269. }
  270. </style>