OvertimeForm.vue 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  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-input-number
  19. :min="0"
  20. :formatter="value => `${value}小时`"
  21. :parser="value => value.replace('小时', '')"
  22. v-decorator="['extrahours', {rules: [{required: true, message: '要求时间不能为空'}]}]"/>
  23. </a-form-item>
  24. </a-form>
  25. <template slot="footer">
  26. <a-button :loading="confirmLoading" type="primary" @click="save()">提交</a-button>
  27. </template>
  28. </a-modal>
  29. </template>
  30. <script>
  31. import pick from 'lodash.pick'
  32. import { overtimeFillGatherTask } from '@/api/fill/task'
  33. export default {
  34. name: 'BaseFillGather',
  35. data () {
  36. return {
  37. confirmLoading: false,
  38. form: this.$form.createForm(this),
  39. visible: false
  40. // 下拉框map
  41. }
  42. },
  43. created () {
  44. },
  45. methods: {
  46. base (record) {
  47. console.log(record)
  48. this.visible = true
  49. const { form: { setFieldsValue } } = this
  50. // 日期处理
  51. this.$nextTick(() => {
  52. setFieldsValue(Object.assign(pick(record, [
  53. 'id'
  54. ])))
  55. })
  56. },
  57. save () {
  58. const { form: { validateFieldsAndScroll } } = this
  59. this.confirmLoading = true
  60. validateFieldsAndScroll((errors, values) => {
  61. if (errors) {
  62. this.confirmLoading = false
  63. return
  64. }
  65. console.log(values)
  66. overtimeFillGatherTask(values).then(res => {
  67. this.handleCancel()
  68. })
  69. // 日期处理
  70. })
  71. },
  72. handleCancel () {
  73. this.visible = false
  74. this.$emit('ok')
  75. }
  76. }
  77. }
  78. </script>
  79. <style lang="less" scoped>
  80. </style>