CheckAndEditModel.vue 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. <template>
  2. <j-modal
  3. :title="title"
  4. :width="700"
  5. :visible="visible"
  6. :mask-closable="false"
  7. cancel-text="关闭"
  8. @close="close"
  9. >
  10. <a-form-model ref="form" :label-col="labelCol" :wrapper-col="wrapperCol" :rules="validatorRules" :model="model">
  11. <a-form-model-item label="线别" prop="lineId">
  12. <j-list-select-tag
  13. v-model="model.lineId"
  14. dict-code="line"
  15. />
  16. </a-form-model-item>
  17. <a-form-model-item label="车间" prop="deptId">
  18. <a-tree-select
  19. v-model="model.deptId"
  20. :show-search="true"
  21. allow-clear
  22. tree-default-expand-all
  23. style="width: 100%"
  24. :tree-data="treeData"
  25. tree-node-filter-prop="label"
  26. :replace-fields="{children:'children', title:'label', key:'id', value: 'id' }"
  27. />
  28. </a-form-model-item>
  29. <a-form-model-item label="站场区间" prop="stationId">
  30. <j-list-select-tag
  31. v-model="model.stationId"
  32. dict-code="station"
  33. />
  34. </a-form-model-item>
  35. <a-form-model-item label="行别" prop="xingbie">
  36. <j-dict-select-tag
  37. v-model="model.xingbie"
  38. type="radioButton"
  39. dict-code="xingbie"
  40. />
  41. </a-form-model-item>
  42. <a-form-model-item label="附加类型" prop="fjlx">
  43. <j-dict-select-tag
  44. v-model="model.fjlx"
  45. dict-code="fjlx"
  46. />
  47. </a-form-model-item>
  48. <a-form-model-item label="起始杆号" prop="qsgh">
  49. <a-input v-model="model.qsgh" />
  50. </a-form-model-item>
  51. <a-form-model-item label="起始公里标" prop="qsglb">
  52. <a-input v-model="model.qsglb" />
  53. </a-form-model-item>
  54. </a-form-model>
  55. </j-modal>
  56. </template>
  57. <script>
  58. import { httpAction, getAction } from '@/api/request'
  59. import JModal from '@/components/JModal'
  60. export default {
  61. name: 'CheckAndEditModel',
  62. components: {
  63. JModal
  64. },
  65. data() {
  66. return {
  67. treeData: [],
  68. labelCol: { span: 4 },
  69. wrapperCol: { span: 19 },
  70. dataSource: [],
  71. title: '',
  72. visible: false,
  73. isCheck: false,
  74. model: {},
  75. validatorRules: {
  76. lineId: [{ required: true, message: '请选择' }],
  77. deptId: [{ required: true, message: '请选择' }],
  78. stationId: [{ required: true, message: '请选择' }],
  79. xingbie: [{ required: true, message: '请选择' }],
  80. fjlx: [{ required: true, message: '请选择' }],
  81. qsgh: [{ required: true, message: '请输入' }],
  82. qsglb: [{ required: true, message: '请输入' }]
  83. },
  84. url: {
  85. add: '/business/catenary/bus/fjxgmd/add',
  86. edit: '/business/catenary/bus/fjxgmd/update',
  87. tree: '/system/dept/treeSelect'
  88. }
  89. }
  90. },
  91. created() {
  92. this.loadTree()
  93. },
  94. methods: {
  95. loadTree() {
  96. this.treeData = []
  97. getAction(this.url.tree).then((res) => {
  98. if (res.code === 200) {
  99. this.treeData = res.data
  100. }
  101. })
  102. },
  103. add() {
  104. this.model = {}
  105. this.visible = true
  106. },
  107. edit(record) {
  108. this.model = Object.assign({}, record)
  109. this.visible = true
  110. },
  111. close(isSubmit) {
  112. if (isSubmit) {
  113. this.checkData()
  114. } else {
  115. this.visible = false
  116. }
  117. },
  118. checkData() {
  119. this.$refs.form.validate(valid => {
  120. if (valid) {
  121. this.saveData()
  122. } else {
  123. return false
  124. }
  125. })
  126. },
  127. saveData() {
  128. let url, type
  129. if (!this.model.id) {
  130. url = this.url.add
  131. type = 'post'
  132. } else {
  133. url = this.url.edit
  134. type = 'put'
  135. }
  136. httpAction(url, this.model, type).then((res) => {
  137. if (res.code === 200) {
  138. this.$message.success(res.msg)
  139. this.$emit('ok')
  140. this.visible = false
  141. } else {
  142. console.log(res)
  143. }
  144. })
  145. }
  146. }
  147. }
  148. </script>