reimbursementInvoiceForm.vue 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. <template>
  2. <el-dialog
  3. :title="title"
  4. :close-on-click-modal="false"
  5. v-dialogDrag
  6. :visible.sync="visible">
  7. <el-form size="small" :model="inputForm" ref="inputForm" @keyup.enter.native="doSubmit()"
  8. label-width="80px" v-loading="loading" :class="method==='viewInvoice'?'readonly':''" :disabled="method==='viewInvoice'" @submit.native.prevent>
  9. <el-row :gutter="15">
  10. <el-col :span="12">
  11. <el-form-item label="业务编号" prop="businessCode" :rules="[{max: 50, message: '最大长度不能超过50个字符', trigger: 'blur'}]">
  12. <el-input v-model="inputForm.businessCode" placeholder="业务编号" :disabled="true"></el-input>
  13. </el-form-item>
  14. </el-col>
  15. <el-col :span="12">
  16. <el-form-item label="业务类型" prop="businessType" :rules="[{max: 50, message: '最大长度不能超过50个字符', trigger: 'blur'}]">
  17. <el-input v-model="inputForm.businessType" placeholder="业务类型" :disabled="true"></el-input>
  18. </el-form-item>
  19. </el-col>
  20. <el-col :span="12">
  21. <el-form-item label="发票代码" prop="invoiceCode" :rules=" [{required: true, message: '发票代码不能为空', trigger: 'blur'}]">
  22. <el-input v-model="inputForm.invoiceCode" placeholder="发票代码" :disabled="true"></el-input>
  23. </el-form-item>
  24. </el-col>
  25. <el-col :span="12">
  26. <el-form-item label="发票号码" prop="invoiceNumber" :rules=" [{required: true, message: '发票号码不能为空', trigger: 'blur'}]">
  27. <el-input v-model="inputForm.invoiceNumber" placeholder="发票号码" :disabled="true"></el-input>
  28. </el-form-item>
  29. </el-col>
  30. <el-col :span="12">
  31. <el-form-item label="购方企业名称" prop="firmName" :rules="[{max: 50, message: '最大长度不能超过50个字符', trigger: 'blur'}]">
  32. <el-input v-model="inputForm.firmName" placeholder="购方企业名称" :disabled="true"></el-input>
  33. </el-form-item>
  34. </el-col>
  35. <el-col :span="12">
  36. <el-form-item label="开票日期" prop="makeTime"
  37. :rules="[
  38. {required: true, message:'收款日期不能为空', trigger:'blur'}
  39. ]">
  40. <el-date-picker
  41. style="width: 100%;"
  42. v-model="inputForm.makeTime"
  43. type="datetime"
  44. value-format="yyyy-MM-dd HH:mm:ss"
  45. :disabled="true"
  46. placeholder="选择日期时间">
  47. </el-date-picker>
  48. </el-form-item>
  49. </el-col>
  50. <el-col :span="12">
  51. <el-form-item label="商品名称" prop="name" :rules="[{max: 50, message: '最大长度不能超过50个字符', trigger: 'blur'}]">
  52. <el-input v-model="inputForm.name" placeholder="商品名称" :disabled="true"></el-input>
  53. </el-form-item>
  54. </el-col>
  55. <el-col :span="12">
  56. <el-form-item label="金额" prop="money" :rules="[{max: 50, message: '最大长度不能超过50个字符', trigger: 'blur'}]">
  57. <el-input v-model="inputForm.money" placeholder="金额" :disabled="true"></el-input>
  58. </el-form-item>
  59. </el-col>
  60. <el-col :span="12">
  61. <el-form-item label="税额" prop="tax" :rules="[{max: 50, message: '最大长度不能超过50个字符', trigger: 'blur'}]">
  62. <el-input v-model="inputForm.tax" placeholder="税额" :disabled="true"></el-input>
  63. </el-form-item>
  64. </el-col>
  65. <el-col :span="12">
  66. <el-form-item label="收入" prop="income" :rules="[{max: 50, message: '最大长度不能超过50个字符', trigger: 'blur'}]">
  67. <el-input v-model="inputForm.income" placeholder="收入" :disabled="true"></el-input>
  68. </el-form-item>
  69. </el-col>
  70. <el-col :span="12">
  71. <el-form-item label="项目经理" prop="proposer" :rules="[{max: 50, message: '最大长度不能超过50个字符', trigger: 'blur'}]">
  72. <el-input v-model="inputForm.proposer" placeholder="项目经理" :disabled="true"></el-input>
  73. </el-form-item>
  74. </el-col>
  75. <el-col :span="12">
  76. <el-form-item label="部门" prop="partner" :rules="[{max: 50, message: '最大长度不能超过50个字符', trigger: 'blur'}]">
  77. <el-input v-model="inputForm.partner" placeholder="部门" :disabled="true"></el-input>
  78. </el-form-item>
  79. </el-col>
  80. <el-col :span="12">
  81. <el-form-item label="收款日期" prop="gatheringTime"
  82. :rules="[
  83. {required: true, message:'收款日期不能为空', trigger:'blur'}
  84. ]">
  85. <el-date-picker
  86. style="width: 100%;"
  87. v-model="inputForm.gatheringTime"
  88. type="datetime"
  89. value-format="yyyy-MM-dd HH:mm:ss"
  90. placeholder="选择日期时间">
  91. </el-date-picker>
  92. </el-form-item>
  93. </el-col>
  94. </el-row>
  95. </el-form>
  96. <span slot="footer" class="dialog-footer">
  97. <el-button size="small" @click="visible = false" icon="el-icon-circle-close">关闭</el-button>
  98. <el-button size="small" v-if="method != 'viewInvoice'" type="primary" @click="doSubmit()" icon="el-icon-circle-check" v-noMoreClick>确定</el-button>
  99. </span>
  100. </el-dialog>
  101. </template>
  102. <script>
  103. import ReimbursementSys from '@/api/reimbursementSys/reimbursementSysService'
  104. export default {
  105. data () {
  106. return {
  107. title: '',
  108. method: '',
  109. visible: false,
  110. loading: false,
  111. inputForm: {
  112. id: '',
  113. parent: {
  114. id: ''
  115. },
  116. businessCode: '', // 业务编号
  117. invoiceCode: '', // 发票代码
  118. invoiceNumber: '', // 发票号码
  119. firmName: '', // 购方企业名称
  120. makeTime: '', // 开票日期
  121. name: '', // 商品名称
  122. money: '', // 金额
  123. tax: '', // 税额
  124. income: '', // 收入
  125. proposer: '', // 申请人
  126. partner: '', // 合伙人
  127. businessType: '', // 业务类型
  128. gatheringTime: '' // 收款日期
  129. }
  130. }
  131. },
  132. reimbursementSys: null,
  133. created () {
  134. this.reimbursementSys = new ReimbursementSys()
  135. },
  136. methods: {
  137. init (method, obj) {
  138. this.method = method
  139. if (method === 'editInvoice') {
  140. this.title = '修改发票信息'
  141. } else if (method === 'viewInvoice') {
  142. this.title = '查看发票信息'
  143. }
  144. this.visible = true
  145. this.$nextTick(() => {
  146. this.$refs['inputForm'].resetFields()
  147. this.inputForm.id = obj.id
  148. this.inputForm.parent.id = obj.parent.id
  149. this.inputForm.parent.name = obj.parent.name
  150. if (method === 'editInvoice' || method === 'viewInvoice') { // 修改或者查看
  151. this.loading = true
  152. this.reimbursementSys.queryInvoiceById(this.inputForm.id).then(({data}) => {
  153. this.inputForm = this.recover(this.inputForm, data)
  154. this.loading = false
  155. })
  156. }
  157. })
  158. },
  159. // 表单提交
  160. doSubmit () {
  161. this.$refs['inputForm'].validate((valid) => {
  162. if (valid) {
  163. this.loading = true
  164. this.reimbursementSys.saveInvoice(this.inputForm).then(({data}) => {
  165. this.loading = false
  166. this.$message({
  167. message: '操作成功',
  168. type: 'success',
  169. duration: 1500
  170. })
  171. this.visible = false
  172. this.$emit('refreshDataList')
  173. }).catch(() => {
  174. this.loading = false
  175. })
  176. }
  177. })
  178. }
  179. }
  180. }
  181. </script>