taskForm.vue 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  1. <template>
  2. <view class="">
  3. <u-sticky offset-top="50">
  4. <u-subsection fontSize='25' mode='subsection' :list="list" :current="curNow" @change="sectionChange"
  5. activeColor='#157A2C'></u-subsection>
  6. </u-sticky>
  7. <view v-show='curNow===0'>
  8. <u--form style="margin: 0 20px;" labelPosition="left" :model="form" ref="uForm" labelWidth='140rpx'>
  9. <u-form-item label="订单编号" prop="orderNo" borderBottom>
  10. <u--input style="width: 100%;" disabled v-model="form.orderNo"></u--input>
  11. </u-form-item>
  12. <u-form-item label="合同名称" prop="contractName" borderBottom>
  13. <u--input style="width: 100%;" disabled v-model="form.contractName"></u--input>
  14. </u-form-item>
  15. <u-form-item label="采购计划名称" prop="purchasePlanName" borderBottom>
  16. <u--input style="width: 100%;" disabled v-model="form.purchasePlanName"></u--input>
  17. </u-form-item>
  18. <u-form-item label="项目名称" prop="projectName" borderBottom>
  19. <u--input style="width: 100%;" disabled v-model="form.projectName"></u--input>
  20. </u-form-item>
  21. <u-form-item label="需求部门" prop="requireDeptName" borderBottom>
  22. <u--input style="width: 100%;" disabled v-model="form.requireDeptName"></u--input>
  23. </u-form-item>
  24. <u-form-item label="需求人" prop="requireUserName" borderBottom>
  25. <u--input style="width: 100%;" disabled v-model="form.requireUserName"></u--input>
  26. </u-form-item>
  27. <u-form-item label="需求类型" prop="sourceTypeName" borderBottom>
  28. <u--input style="width: 100%;" disabled v-model="form.sourceTypeName"></u--input>
  29. </u-form-item>
  30. <u-form-item label="采购订单类型" prop="purchaseTypeName" borderBottom>
  31. <u--input style="width: 100%;" disabled v-model="form.purchaseTypeName"></u--input>
  32. </u-form-item>
  33. <u-form-item label="应付金额" prop="payAmount" borderBottom>
  34. <u--input style="width: 100%;" disabled v-model="form.payAmount"></u--input>
  35. </u-form-item>
  36. <u-form-item label="订单总金额" prop="totalAmount" borderBottom>
  37. <u--input style="width: 100%;" disabled v-model="form.totalAmount"></u--input>
  38. </u-form-item>
  39. <u-form-item label="附件" prop="orderFiles" borderBottom>
  40. <fileMain v-model="form.orderFiles" type="view"></fileMain>
  41. </u-form-item>
  42. </u--form>
  43. </view>
  44. <view v-show='curNow===1'>
  45. <u--form style="margin: 0 20px;" labelPosition="left" :model="form" ref="uForm" labelWidth='140rpx'>
  46. <u-form-item label="采购方名称" prop="partaName" borderBottom>
  47. <u--input style="width: 100%;" disabled v-model="form.partaName"></u--input>
  48. </u-form-item>
  49. <u-form-item label="采购方信用代码" prop="partaUnifiedSocialCreditCode" borderBottom>
  50. <u--input style="width: 100%;" disabled v-model="form.partaUnifiedSocialCreditCode"></u--input>
  51. </u-form-item>
  52. <u-form-item label="采购方联系人" prop="partaLinkName" borderBottom>
  53. <u--input style="width: 100%;" disabled v-model="form.partaLinkName"></u--input>
  54. </u-form-item>
  55. <u-form-item label="采购方电话" prop="partaTel" borderBottom>
  56. <u--input style="width: 100%;" disabled v-model="form.partaTel"></u--input>
  57. </u-form-item>
  58. <u-form-item label="采购方传真" prop="partaFax" borderBottom>
  59. <u--input style="width: 100%;" disabled v-model="form.partaFax"></u--input>
  60. </u-form-item>
  61. <u-form-item label="采购方Email" prop="partaEmail" borderBottom>
  62. <u--input style="width: 100%;" disabled v-model="form.partaEmail"></u--input>
  63. </u-form-item>
  64. <u-form-item label="采购方地址" prop="partaAddress" borderBottom>
  65. <u--input style="width: 100%;" disabled v-model="form.partaAddress"></u--input>
  66. </u-form-item>
  67. <u-form-item label="供应商名称" prop="partbName" borderBottom>
  68. <u--input style="width: 100%;" disabled :value='`${form.partbName}`'></u--input>
  69. </u-form-item>
  70. <u-form-item label="供应商信用代码" prop="partbUnifiedSocialCreditCode" borderBottom>
  71. <u--input style="width: 100%;" disabled v-model="form.partbUnifiedSocialCreditCode"></u--input>
  72. </u-form-item>
  73. <u-form-item label="供应商联系人" prop="partbLinkName" borderBottom>
  74. <u--input style="width: 100%;" disabled v-model="form.partbLinkName"></u--input>
  75. </u-form-item>
  76. <u-form-item label="供应商电话" prop="partbTel" borderBottom>
  77. <u--input style="width: 100%;" disabled v-model="form.partbTel"></u--input>
  78. </u-form-item>
  79. <u-form-item label="供应商传真" prop="partbFax" borderBottom>
  80. <u--input style="width: 100%;" disabled v-model="form.partbFax"></u--input>
  81. </u-form-item>
  82. <u-form-item label="供应商Email" prop="partbEmail" borderBottom>
  83. <u--input style="width: 100%;" disabled v-model="form.partbEmail"></u--input>
  84. </u-form-item>
  85. <u-form-item label="供应商地址" prop="partbAddress" borderBottom>
  86. <u--input style="width: 100%;" disabled v-model="form.partbAddress"></u--input>
  87. </u-form-item>
  88. </u--form>
  89. </view>
  90. <view v-show='curNow===2'>
  91. <u-sticky offset-top="100">
  92. <u-tag
  93. :text="`总计: ${form.totalAmount&&form.totalAmount} 应付金额: ${form.payAmount&&form.payAmount}`"
  94. size="large" type="success"></u-tag>
  95. </u-sticky>
  96. <view v-for="(item,index) in form['productList']" :key="index">
  97. <u--form style="margin: 0 20px;" labelPosition="left" :model="form" ref="uForm" labelWidth='140rpx'>
  98. <u-row v-for="(key,index1) in tableField" :key="index1">
  99. <u-col :span="12">
  100. <u-form-item :label="key.label" prop="categoryName" borderBottom>
  101. <u--input style="width: 100%;" :title='item[key.field]' disabled
  102. v-model="item[key.field]"></u--input>
  103. </u-form-item>
  104. </u-col>
  105. </u-row>
  106. </u--form>
  107. <u-gap height="40" bgColor="#f0f0f0"></u-gap>
  108. </view>
  109. </view>
  110. <view v-show='curNow===3'>
  111. <view v-for="(item,index) in form['receiptPaymentList']" :key="index">
  112. <u--form style="margin: 0 20px;" labelPosition="left" :model="form" ref="uForm" labelWidth='140rpx'>
  113. <u-row v-for="(key,index1) in feeTableField" :key="index1">
  114. <u-col :span="12">
  115. <u-form-item :label="key.label" prop="categoryName" borderBottom>
  116. <u--input style="width: 100%;" :title='item[key.field]' disabled
  117. v-model="item[key.field]"></u--input>
  118. </u-form-item>
  119. </u-col>
  120. </u-row>
  121. </u--form>
  122. <u-gap height="40" bgColor="#f0f0f0"></u-gap>
  123. </view>
  124. </view>
  125. </view>
  126. </template>
  127. <script>
  128. import {
  129. purchaseOrderGetByIdAPI
  130. } from '@/api/wt/index.js'
  131. import fileMain from "@/pages/doc/index.vue"
  132. import {transactionMethodsOp,shippingModeOp,shippingModePurchaseOp, pricingWayList, levelList, quoteTypeOp} from '@/enum/dict.js'
  133. export default {
  134. components: {
  135. fileMain
  136. },
  137. props: {
  138. businessId: {
  139. default: ''
  140. },
  141. taskDefinitionKey: {
  142. default: ''
  143. },
  144. },
  145. computed: {
  146. shippingModeOptions() {
  147. return this.form.type == 2 ? shippingModePurchaseOp : shippingModeOp;
  148. },
  149. feeTableField() {
  150. return [{
  151. label: '期数',
  152. field: 'issueNumber',
  153. },
  154. {
  155. label: '款项类型',
  156. field: 'typeName',
  157. },
  158. {
  159. label: '款项名称',
  160. field: 'moneyName',
  161. },
  162. {
  163. label: '比例(%)',
  164. field: 'ratio',
  165. },
  166. {
  167. label: this.form.type == 2 ? '计划付款金额(元)' : '计划收款金额(元)',
  168. field: 'price',
  169. },
  170. {
  171. label: this.form.type == 2 ? '计划付款日期' : '计划收款日期',
  172. field: 'deadLine',
  173. },
  174. {
  175. label: '说明',
  176. field: 'remark',
  177. }
  178. ]
  179. },
  180. },
  181. data() {
  182. return {
  183. form: {},
  184. tableField: [{
  185. label: '类型',
  186. field: 'productCategoryName',
  187. }, {
  188. label: '名称',
  189. field: 'productName',
  190. },
  191. {
  192. label: '编码',
  193. field: 'productCode',
  194. },
  195. {
  196. field: 'specification',
  197. label: '规格',
  198. },
  199. {
  200. field: 'modelType',
  201. label: '型号',
  202. },
  203. {
  204. field: 'colorKey',
  205. label: '颜色',
  206. },
  207. {
  208. field: 'productBrand',
  209. label: '牌号',
  210. },
  211. {
  212. label: '供应商代号',
  213. field: 'supplierMark',
  214. },
  215. {
  216. label: '单价',
  217. field: 'singlePrice',
  218. },
  219. {
  220. label: '数量',
  221. field: 'totalCount',
  222. },
  223. {
  224. label: '采购总金额',
  225. field: 'totalPrice',
  226. },
  227. ],
  228. list: ['订单信息', '基本信息', '产品清单', '付款计划'],
  229. curNow: 0
  230. }
  231. },
  232. async mounted() {
  233. await this.getDetailData(this.businessId);
  234. },
  235. methods: {
  236. sectionChange(index) {
  237. this.curNow = index;
  238. },
  239. async getDetailData(id) {
  240. const data = await purchaseOrderGetByIdAPI(id);
  241. this.form = data;
  242. }
  243. }
  244. }
  245. </script>
  246. <style>
  247. </style>