CheckAndEditModel.vue 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  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="deptId">
  12. <a-tree-select
  13. v-model="model.deptId"
  14. :show-search="true"
  15. allow-clear
  16. tree-default-expand-all
  17. style="width: 100%"
  18. :tree-data="treeData"
  19. tree-node-filter-prop="label"
  20. :replace-fields="{children:'children', title:'label', key:'id', value: 'id' }"
  21. />
  22. </a-form-model-item>
  23. <a-form-model-item label="线别" prop="lineId">
  24. <j-list-select-tag
  25. v-model="model.lineId"
  26. dict-code="line"
  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="zzh">
  43. <a-input v-model="model.zzh" />
  44. </a-form-model-item>
  45. <a-form-model-item label="公里标" prop="glb">
  46. <a-input v-model="model.glb" />
  47. </a-form-model-item>
  48. <a-form-model-item label="线岔号" prop="xch">
  49. <a-input v-model="model.xch" />
  50. </a-form-model-item>
  51. </a-form-model>
  52. </j-modal>
  53. </template>
  54. <script>
  55. import { getAction, httpAction } from '@/api/request'
  56. import JModal from '@/components/JModal'
  57. export default {
  58. name: 'CheckAndEditModel',
  59. components: {
  60. JModal
  61. },
  62. data() {
  63. return {
  64. treeData: [],
  65. labelCol: { span: 4 },
  66. wrapperCol: { span: 19 },
  67. dataSource: [],
  68. title: '',
  69. visible: false,
  70. isCheck: false,
  71. model: {},
  72. validatorRules: {
  73. deptId: [{ required: true, message: '请选择' }],
  74. lineId: [{ required: true, message: '请选择' }],
  75. stationId: [{ required: true, message: '请选择' }],
  76. xingbie: [{ required: true, message: '请选择' }],
  77. zzh: [{ required: true, message: '请输入' }],
  78. glb: [{ required: true, message: '请输入' }],
  79. xch: [{ required: true, message: '请输入' }]
  80. },
  81. url: {
  82. add: '/business/catenary/bus/jcxc/add',
  83. edit: '/business/catenary/bus/jcxc/update',
  84. tree: '/system/dept/treeSelect'
  85. }
  86. }
  87. },
  88. created() {
  89. this.loadTree()
  90. },
  91. methods: {
  92. loadTree() {
  93. this.treeData = []
  94. getAction(this.url.tree).then((res) => {
  95. if (res.code === 200) {
  96. this.treeData = res.data
  97. }
  98. })
  99. },
  100. add() {
  101. this.model = {}
  102. this.visible = true
  103. },
  104. edit(record) {
  105. this.model = Object.assign({}, record)
  106. this.visible = true
  107. },
  108. close(isSubmit) {
  109. if (isSubmit) {
  110. this.checkData()
  111. } else {
  112. this.visible = false
  113. }
  114. },
  115. checkData() {
  116. this.$refs.form.validate(valid => {
  117. if (valid) {
  118. this.saveData()
  119. } else {
  120. return false
  121. }
  122. })
  123. },
  124. saveData() {
  125. let url, type
  126. if (!this.model.id) {
  127. url = this.url.add
  128. type = 'post'
  129. } else {
  130. url = this.url.edit
  131. type = 'put'
  132. }
  133. httpAction(url, this.model, type).then((res) => {
  134. if (res.code === 200) {
  135. this.$message.success(res.msg)
  136. this.$emit('ok')
  137. this.visible = false
  138. } else {
  139. console.log(res)
  140. }
  141. })
  142. }
  143. }
  144. }
  145. </script>