DispatchForm.vue 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. <template>
  2. <a-modal
  3. title="转派"
  4. :width="800"
  5. :visible="visible"
  6. :confirmLoading="confirmLoading"
  7. @cancel="handleCancel"
  8. >
  9. <a-form :form="form">
  10. <a-form-item>
  11. <a-input v-decorator="['id']" type="hidden"/>
  12. </a-form-item>
  13. <a-form-item
  14. label="巡检人"
  15. :labelCol="BaseTool.Constant.labelCol"
  16. :wrapperCol="BaseTool.Constant.wrapperCol"
  17. >
  18. <a-select v-decorator="['anotherChecker', {rules: [{required: true, message: '巡检人不能为空'}]}]">
  19. <a-select-option
  20. v-for="item in ipqcMap"
  21. :key="item.userId"
  22. :label="item.realName"
  23. :value="item.userId">
  24. {{ item.realName }}
  25. </a-select-option>
  26. </a-select>
  27. </a-form-item>
  28. <a-form-item
  29. label="要求时间"
  30. :labelCol="BaseTool.Constant.labelCol"
  31. :wrapperCol="BaseTool.Constant.wrapperCol"
  32. >
  33. <a-input-number
  34. :min="0"
  35. :formatter="value => `${value}小时`"
  36. :parser="value => value.replace('小时', '')"
  37. v-decorator="['requireHour', {rules: [{required: true, message: '要求时间不能为空'}]}]"/>
  38. </a-form-item>
  39. </a-form>
  40. <template slot="footer">
  41. <a-button :loading="confirmLoading" type="primary" @click="save()">提交</a-button>
  42. </template>
  43. </a-modal>
  44. </template>
  45. <script>
  46. import pick from 'lodash.pick'
  47. import { getQueryUser } from '@/api/fill/gather'
  48. import { dispatchFillGatherTask } from '@/api/fill/task'
  49. import RowList from '@/components/custom/RowList.vue'
  50. export default {
  51. components: { RowList },
  52. name: 'BaseFillGather',
  53. data () {
  54. return {
  55. confirmLoading: false,
  56. form: this.$form.createForm(this),
  57. visible: false,
  58. // 下拉框map
  59. ipqcMap: {}
  60. }
  61. },
  62. created () {
  63. this.getUser()
  64. },
  65. methods: {
  66. base (record) {
  67. console.log(record)
  68. this.visible = true
  69. const { form: { setFieldsValue } } = this
  70. // 日期处理
  71. this.$nextTick(() => {
  72. setFieldsValue(Object.assign(pick(record, [
  73. 'id'
  74. ])))
  75. })
  76. },
  77. getUser () {
  78. getQueryUser(this.DictCache.VALUE.QUERY_ROLE_TYPE.IPQC).then(res => {
  79. this.ipqcMap = res.data
  80. })
  81. },
  82. save () {
  83. const { form: { validateFieldsAndScroll } } = this
  84. this.confirmLoading = true
  85. validateFieldsAndScroll((errors, values) => {
  86. if (errors) {
  87. this.confirmLoading = false
  88. return
  89. }
  90. console.log(values)
  91. dispatchFillGatherTask(values).then(res => {
  92. this.handleCancel()
  93. })
  94. // 日期处理
  95. })
  96. },
  97. handleCancel () {
  98. this.visible = false
  99. this.$emit('ok')
  100. }
  101. }
  102. }
  103. </script>
  104. <style lang="less" scoped>
  105. </style>