BaseFormSb.vue 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. <template>
  2. <a-modal
  3. :title="modalTitle"
  4. :width="850"
  5. :visible="visible"
  6. :confirmLoading="confirmLoading"
  7. @cancel="handleCancel"
  8. >
  9. <a-form :form="form">
  10. <a-form-item v-show="false" >
  11. <a-input v-decorator="['id']" type="hidden"/>
  12. </a-form-item>
  13. <a-form-item v-show="false" >
  14. <a-input v-decorator="['sbId']" type="hidden"/>
  15. </a-form-item>
  16. <a-form-item v-show="false" >
  17. <a-input v-decorator="['sbPartId']" type="hidden"/>
  18. </a-form-item>
  19. <a-form-item v-show="false" >
  20. <a-input v-decorator="['spareId']" type="hidden"/>
  21. </a-form-item>
  22. <a-form-item v-show="false" >
  23. <a-input v-decorator="['oldSpareId']" type="hidden"/>
  24. </a-form-item>
  25. <a-row class="form-row" :gutter="BaseTool.Constant.row.gutter">
  26. <a-col :lg="12" :md="24" :sm="24">
  27. <a-form-item
  28. label="选择备件"
  29. :labelCol="BaseTool.Constant.labelCol"
  30. :wrapperCol="BaseTool.Constant.wrapperCol"
  31. >
  32. <a-input
  33. style="width: 70%"
  34. disabled
  35. v-decorator="['spareName', {rules: [{required: true, message: '备件不能为空'}]}]" />
  36. <a-button style="width: 30%" type="primary" @click="handleSpareSelect">选择</a-button>
  37. </a-form-item>
  38. </a-col>
  39. <a-col :lg="12" :md="24" :sm="24">
  40. <a-form-item
  41. label="维护部位"
  42. :labelCol="BaseTool.Constant.labelCol"
  43. :wrapperCol="BaseTool.Constant.wrapperCol"
  44. >
  45. <a-input
  46. disabled
  47. style="width: 80%"
  48. v-decorator="['sbPartName', {rules: [{required: false, message: '维护部位不能为空'}]}]"/>
  49. <a-button type="primary" style="width: 20%" @click="handlePartSelect">选择</a-button>
  50. </a-form-item>
  51. </a-col>
  52. <a-col :lg="12" :md="24" :sm="24">
  53. <a-form-item
  54. label="更换周期"
  55. :labelCol="BaseTool.Constant.labelCol"
  56. :wrapperCol="BaseTool.Constant.wrapperCol"
  57. style="margin-bottom:0;"
  58. >
  59. <!-- 解决校验问题 -->
  60. <a-form-item :style="{ display: 'inline-block', width: '60%' }">
  61. <a-input-number
  62. :min="1"
  63. style="width: 100%"
  64. v-decorator="['period', {initialValue: 500,rules: [{required: true, message: '更换周期不能为空'}]}]"/>
  65. </a-form-item>
  66. <a-form-item
  67. :style="{ display: 'inline-block', width: '40%' }"
  68. >
  69. <a-select
  70. v-decorator="['periodType', {initialValue: 6,rules: [{required: true, message: '周期类型不能为空'}]}]"
  71. placeholder="请选择">
  72. <a-select-option
  73. v-for="(label,value) in periodTypeMap"
  74. :key="value"
  75. :label="label"
  76. :value="parseInt(value)">{{ label }}
  77. </a-select-option>
  78. </a-select>
  79. </a-form-item>
  80. </a-form-item>
  81. </a-col>
  82. <a-col :lg="12" :md="24" :sm="24">
  83. <a-form-item
  84. label="数量"
  85. :labelCol="BaseTool.Constant.labelCol"
  86. :wrapperCol="BaseTool.Constant.wrapperCol"
  87. >
  88. <a-input-number
  89. style="width: 100%"
  90. :min="0"
  91. :step="1"
  92. :formatter="BaseTool.Amount.formatter"
  93. :parser="BaseTool.Amount.parser"
  94. v-decorator="['num', {initialValue:1, rules: [{required: true, message: '数量不能为空'}]}]" />
  95. </a-form-item>
  96. </a-col>
  97. </a-row>
  98. </a-form>
  99. <spare-part-info-select-modal :type="'checkbox'" ref="spareSelectModal" @selected="handleSpareSelected"/>
  100. <part-info-select-modal ref="partInfoSelectModal" @selected="handlePartSelected"/>
  101. <template slot="footer">
  102. <a-button :loading="confirmLoading" type="primary" @click="save()">保存</a-button>
  103. </template>
  104. </a-modal>
  105. </template>
  106. <script>
  107. import pick from 'lodash.pick'
  108. import { addSbModelBom, updateSbModelBom, deleteSbModelBoms } from '@/api/sb/modelbom'
  109. import SparePartInfoSelectModal from '@/views/sqarepartmanage/sparepartinfo/modules/SparePartInfoSelectModal'
  110. import PartInfoSelectModal from '@/views/part/info/modules/PartInfoSelectModal'
  111. export default {
  112. name: 'BaseSbModel',
  113. data () {
  114. return {
  115. confirmLoading: false,
  116. sbId: null,
  117. spareId: null,
  118. modalTitle: null,
  119. form: this.$form.createForm(this),
  120. visible: false,
  121. // 下拉框map,
  122. enableMap: {},
  123. statusMap: {},
  124. sbTypeTreeData: [],
  125. typeMap: {},
  126. periodTypeMap: {}
  127. }
  128. },
  129. components: {
  130. SparePartInfoSelectModal,
  131. PartInfoSelectModal
  132. },
  133. created () {
  134. // 下拉框map
  135. this.depreciationTypeMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SBINFO_DEPRECIATIONTYPE)
  136. this.levelMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SBINFO_LEVEL)
  137. this.statusMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SB_MODEL_RECOMMEND)
  138. this.unitMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SBINFO_UNIT)
  139. this.enableMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.YES_NO)
  140. this.typeMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.CHECK_STANDARD_TYPE)
  141. this.useTypeMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SB_UES_TYPE)
  142. this.periodTypeMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.CHECK_PLAN_PERIOD_TYPE)
  143. },
  144. methods: {
  145. base (record) {
  146. this.visible = true
  147. if (this.BaseTool.Object.isBlank(record.id)) {
  148. this.sbId = record.sbId
  149. this.modalTitle = '添加'
  150. const { form: { setFieldsValue } } = this
  151. // 日期处理
  152. this.$nextTick(() => {
  153. setFieldsValue(Object.assign({
  154. 'sbId': record.sbId
  155. }))
  156. })
  157. return
  158. }
  159. this.modalTitle = '编辑'
  160. record.oldSpareId = record.spareId
  161. const { form: { setFieldsValue } } = this
  162. record.spareName = record.name
  163. // 日期处理
  164. this.$nextTick(() => {
  165. setFieldsValue(Object.assign(pick(record, [
  166. 'id',
  167. 'sbId',
  168. 'sbPartId',
  169. 'spareId',
  170. 'sbPartName',
  171. 'spareName',
  172. 'period',
  173. 'periodType',
  174. 'num',
  175. 'oldSpareId'
  176. ])))
  177. })
  178. },
  179. handleCancel (values) {
  180. this.visible = false
  181. this.confirmLoading = false
  182. this.form.resetFields()
  183. if (this.BaseTool.Object.isNotBlank(values)) {
  184. this.$emit('ok', values)
  185. }
  186. },
  187. save () {
  188. const { form: { validateFieldsAndScroll } } = this
  189. this.confirmLoading = true
  190. validateFieldsAndScroll((errors, values) => {
  191. if (errors) {
  192. this.confirmLoading = false
  193. return
  194. }
  195. if (this.BaseTool.String.isBlank(values.id)) {
  196. addSbModelBom(values)
  197. .then((response) => {
  198. this.$message.info('添加成功')
  199. this.handleCancel(values)
  200. }).catch(() => {
  201. this.confirmLoading = false
  202. })
  203. } else {
  204. updateSbModelBom(values)
  205. .then(() => {
  206. this.handleCancel(values)
  207. }).catch(() => {
  208. this.confirmLoading = false
  209. })
  210. }
  211. })
  212. },
  213. handleSpareSelect () {
  214. this.$refs.spareSelectModal.base({})
  215. },
  216. handleSpareSelected (record, keys, rows) {
  217. const [ key ] = keys
  218. const [ row ] = rows
  219. const { form: { setFieldsValue } } = this
  220. // 日期处理
  221. this.$nextTick(() => {
  222. setFieldsValue(Object.assign({
  223. 'spareId': key,
  224. 'spareName': row.name
  225. }))
  226. })
  227. },
  228. handleDel () {
  229. const data = [...this.data]
  230. let ids = []
  231. ids = this.selectedRows.map(item => item.bomId)
  232. // 调取删除接口,批量删除
  233. this.confirmLoading = true
  234. deleteSbModelBoms(ids)
  235. .then(() => {
  236. this.data = data.filter(item => !this.selectedRowKeys.includes(item.id))
  237. this.handleCancel()
  238. this.$message.info('删除成功')
  239. }).catch(() => {
  240. this.confirmLoading = false
  241. })
  242. },
  243. handlePartSelect () {
  244. const sbId = this.form.getFieldValue('sbId')
  245. this.$refs.partInfoSelectModal.base({ sbId })
  246. },
  247. handlePartSelected (keys, rows) {
  248. const [ key ] = keys
  249. const [ row ] = rows
  250. const { form: { setFieldsValue } } = this
  251. this.$nextTick(() => {
  252. setFieldsValue(Object.assign({
  253. 'sbPartId': key,
  254. 'sbPartName': row.name
  255. }))
  256. })
  257. }
  258. }
  259. }
  260. </script>