add-material.vue 3.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  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="name">
  10. <el-input v-model="dataForm.name" :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="cnt">
  16. <el-input-number v-model="dataForm.cnt" :disabled="display" :min="1"/>
  17. </el-form-item>
  18. <el-form-item label="单位" prop="unitName">
  19. <el-input v-model="dataForm.unitName" :disabled="display" placeholder="单位"></el-input>
  20. </el-form-item>
  21. <el-form-item label="不含税单价" prop="price">
  22. <el-input-number v-model="dataForm.price" :disabled="display" :precision="1" :step="1" :min="0"/>
  23. </el-form-item>
  24. <el-form-item label="含税单价" prop="taxPrice">
  25. <el-input-number v-model="dataForm.taxPrice" :disabled="display" :precision="1" :step="1" :min="0"/>
  26. </el-form-item>
  27. <el-form-item label="含税总价" prop="taxAmount">
  28. <span>{{ (dataForm.cnt*dataForm.taxPrice).toFixed(2) }}</span>
  29. </el-form-item>
  30. <el-form-item label="税率" prop="taxRateVal">
  31. <el-input-number :step="1" :min="0" v-model="dataForm.taxRateVal" :disabled="display"/>
  32. %
  33. </el-form-item>
  34. <el-form-item label="备注" prop="notes">
  35. <el-input type="textarea" v-model="dataForm.notes" :disabled="display" placeholder="备注"></el-input>
  36. </el-form-item>
  37. </el-form>
  38. <span slot="footer" class="dialog-footer">
  39. <el-button @click="visible = false">取消</el-button>
  40. <el-button v-if="!display" type="primary" @click="dataFormSubmit()">确定</el-button>
  41. </span>
  42. </el-dialog>
  43. </div>
  44. </template>
  45. <script>
  46. export default {
  47. name: 'add-material',
  48. data () {
  49. return {
  50. visible: false,
  51. display: false,
  52. dataList: [],
  53. transferData: {},
  54. dataForm: {},
  55. id: 0,
  56. taxRateVal: 0,
  57. dataRule: {
  58. name: [{ required: true, message: '物品名称不能为空', trigger: 'blur' }],
  59. specification: [{ required: true, message: '型号及规格不能为空', trigger: 'blur' }],
  60. unitName: [{ required: true, message: '单位不能为空', trigger: 'blur' }]
  61. }
  62. }
  63. },
  64. methods: {
  65. async init (id, display, transferData) {
  66. this.dataForm = {
  67. cnt: 1,
  68. price: 0,
  69. taxPrice: 0,
  70. taxRateVal: 0
  71. }
  72. this.visible = true
  73. this.id = id || Math.round(Math.random() * 1000000)
  74. this.display = display
  75. if (!id) return
  76. this.dataForm = transferData
  77. this.dataForm.taxRateVal = this.dataForm.taxRate ? (Number(this.dataForm.taxRate * 100)).toFixed(0) : 0
  78. },
  79. // 表单提交
  80. dataFormSubmit () {
  81. this.$refs['dataForm'].validate((valid) => {
  82. if (valid) {
  83. this.dataForm.detailId = this.id
  84. this.dataForm.taxAmount = (this.dataForm.cnt * this.dataForm.taxPrice).toFixed(2)
  85. this.dataForm.taxRate = this.dataForm.taxRateVal ? (Number(this.dataForm.taxRateVal / 100)).toFixed(2) : 0
  86. this.visible = false
  87. this.$emit('addItem', this.dataForm)
  88. }
  89. })
  90. }
  91. }
  92. }
  93. </script>
  94. <style scoped>
  95. </style>