add-material.vue 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. <template>
  2. <div>
  3. <el-dialog
  4. :title="!id ? '新增': display ? '详情' : '新增或修改'"
  5. width="50%"
  6. :close-on-click-modal="false"
  7. :visible.sync="visible">
  8. <el-form :model="dataForm" :rules="dataRule" ref="dataForm" label-width="100px">
  9. <el-form-item label="物品名称" prop="materialName">
  10. <el-input v-model="dataForm.materialName" :disabled="display" placeholder="物品名称"></el-input>
  11. </el-form-item>
  12. <el-form-item label="型号及规格" prop="specification">
  13. <el-input v-model="dataForm.specification" :disabled="display" placeholder="型号及规格"></el-input>
  14. </el-form-item>
  15. <el-form-item label="采购类别" prop="purchaseType">
  16. <el-select
  17. v-model="dataForm.purchaseType"
  18. :disabled="display"
  19. remote
  20. placeholder="请选择">
  21. <el-option
  22. v-for="item in optionsType"
  23. :key="item.code"
  24. :label="item.value"
  25. :value="item.code">
  26. </el-option>
  27. </el-select>
  28. </el-form-item>
  29. <el-form-item label="数量" prop="cnt">
  30. <el-input-number v-model="dataForm.cnt" :disabled="display" :min="1"/>
  31. </el-form-item>
  32. <el-form-item label="单位" prop="unitName">
  33. <el-input v-model="dataForm.unitName" :disabled="display" placeholder="单位"></el-input>
  34. </el-form-item>
  35. <el-form-item label="采购期限" prop="deadline">
  36. <el-date-picker
  37. v-model="dataForm.deadline"
  38. value-format="yyyy-MM-dd"
  39. type="date">
  40. </el-date-picker>
  41. </el-form-item>
  42. <el-form-item label="批次号/用途" prop="batchNumber">
  43. <el-input v-model="dataForm.batchNumber" :disabled="display" placeholder="批次号/用途"></el-input>
  44. </el-form-item>
  45. <el-form-item label="备注" prop="notes">
  46. <el-input type="textarea" v-model="dataForm.notes" :disabled="display" placeholder="备注"></el-input>
  47. </el-form-item>
  48. </el-form>
  49. <span slot="footer">
  50. <el-button @click="visible = false">取消</el-button>
  51. <el-button v-if="!display" type="primary" @click="dataFormSubmit()">确定</el-button>
  52. </span>
  53. </el-dialog>
  54. </div>
  55. </template>
  56. <script>
  57. import { getDictList } from '@/api/dict'
  58. export default {
  59. name: 'add-material',
  60. data () {
  61. return {
  62. visible: false,
  63. display: false,
  64. dataList: [],
  65. transferData: {},
  66. dataForm: {},
  67. id: 0,
  68. optionsType: [], // 采购类别
  69. dataRule: {
  70. materialName: [{ required: true, message: '物品名称不能为空', trigger: 'blur' }],
  71. specification: [{ required: true, message: '型号及规格不能为空', trigger: 'blur' }],
  72. unitName: [{ required: true, message: '单位不能为空', trigger: 'blur' }],
  73. purchaseType: [{ required: true, message: '请选择采购类别', trigger: 'change' }],
  74. deadline: [{ required: true, message: '请选择采购期限', trigger: 'change' }],
  75. batchNumber: [{ required: true, message: '批次号不能为空', trigger: 'blur' }]
  76. }
  77. }
  78. },
  79. methods: {
  80. async init (id, display, transferData, optionsType) {
  81. if (optionsType) {
  82. this.optionsType = optionsType
  83. } else {
  84. this.getTypeList()
  85. }
  86. this.dataForm = {
  87. cnt: 1
  88. }
  89. this.visible = true
  90. this.id = id || Math.round(Math.random() * 1000000)
  91. this.display = display
  92. if (!id) return
  93. this.dataForm = transferData
  94. },
  95. // 获取采购类别字典
  96. getTypeList () {
  97. getDictList({type: 'purchase_type'}).then(({data}) => {
  98. if (data) {
  99. this.optionsType = data
  100. }
  101. })
  102. },
  103. // 表单提交
  104. dataFormSubmit () {
  105. this.$refs['dataForm'].validate((valid) => {
  106. if (valid) {
  107. this.dataForm.detailId = this.id
  108. this.visible = false
  109. this.$emit('addItem', this.dataForm)
  110. }
  111. })
  112. }
  113. }
  114. }
  115. </script>
  116. <style scoped>
  117. </style>