drawer.vue 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296
  1. <template>
  2. <view class="mainBox">
  3. <uni-nav-bar background-color="#157A2C" color="#fff" fixed="true" statusBar="true" left-icon="back" title="订单详情"
  4. @clickLeft="back">
  5. </uni-nav-bar>
  6. <myCard :item="form" :columns="columns"></myCard>
  7. <view class="item">
  8. <view class="card">
  9. <view>
  10. <view class="lable">订单数量</view>
  11. <view>{{orderNoCountData.saleOrderNumber}}</view>
  12. </view>
  13. <view>
  14. <view class="lable">订单总金额</view>
  15. <view>{{orderNoCountData.totalAmountSaleOrder}}</view>
  16. </view>
  17. <view>
  18. <view class="lable">应收款</view>
  19. <view>{{orderNoCountData.receivable}}</view>
  20. </view>
  21. <view>
  22. <view class="lable">
  23. 发货数量</view>
  24. <view>{{orderNoCountData.sendNumber}}</view>
  25. </view>
  26. <view>
  27. <view class="lable">
  28. 退货数量</view>
  29. <view>{{orderNoCountData.returnNumber}}</view>
  30. </view>
  31. <view>
  32. <view class="lable">
  33. 退货金额</view>
  34. <view>{{orderNoCountData.returnAmount}}</view>
  35. </view>
  36. </view>
  37. </view>
  38. <u-sticky bgColor="#fff" :customNavHeight="88">
  39. <u-tabs :list="list1" @change="change" :current="current"></u-tabs>
  40. </u-sticky>
  41. <info ref="infoRef" :isDrawer="true" v-show="current==0"></info>
  42. <produceList v-show="current==1" ref="produceListRef" :pricingWay="form.pricingWay"
  43. :contractId="form.contractId" :columns="produceLisTcolumns">
  44. </produceList>
  45. </view>
  46. </template>
  47. <script>
  48. import produceList from "../../components/produceList.vue"
  49. import info from "./info.vue"
  50. import {
  51. getSaleOrderDetail,
  52. queryOrderNoCount
  53. } from '@/api/saleManage/saleorder'
  54. import myCard from '../../components/myCard.vue'
  55. export default {
  56. components: {
  57. produceList,
  58. info,
  59. myCard
  60. },
  61. data() {
  62. return {
  63. columns: [
  64. [{
  65. label: '编码:',
  66. prop: 'orderNo',
  67. type: 'title',
  68. className: 'perce100',
  69. }],
  70. [{
  71. label: '产品名称:',
  72. prop: 'productNames',
  73. className: 'perce100',
  74. }],
  75. [{
  76. label: '项目名称:',
  77. prop: 'projectName'
  78. }, {
  79. label: '客户名称:',
  80. prop: 'partaName'
  81. }],
  82. [{
  83. label: '合同名称:',
  84. prop: 'contractName',
  85. }, {
  86. label: '销售类型:',
  87. prop: 'saleTypeName',
  88. }],
  89. ],
  90. produceLisTcolumns: [
  91. [{
  92. label: '产品名称:',
  93. prop: 'productName',
  94. type: 'title',
  95. className: 'perce100',
  96. }],
  97. [{
  98. label: '编码:',
  99. prop: 'productCode'
  100. }, {
  101. label: '牌号:',
  102. prop: 'productBrand'
  103. }],
  104. [{
  105. label: '规格:',
  106. prop: 'specification'
  107. }, {
  108. label: '型号:',
  109. prop: 'modelType'
  110. }],
  111. [{
  112. label: '数量:',
  113. prop: 'totalCount',
  114. slot: 'totalCount',
  115. }, {
  116. label: '计量单位:',
  117. prop: 'measuringUnit',
  118. }],
  119. [{
  120. label: '单价:',
  121. prop: 'singlePrice',
  122. slot: 'singlePrice',
  123. }, {
  124. label: '折让单价:',
  125. formatter: (item) => {
  126. return (item.discountSinglePrice ?
  127. Number(item.discountSinglePrice).toFixed(2) :
  128. '') + '元';
  129. }
  130. }],
  131. [{
  132. label: '合计:',
  133. prop: 'totalPrice',
  134. formatter: (item) => {
  135. return (item.totalPrice || '') + '元';
  136. }
  137. }, {
  138. label: '折让合计:',
  139. formatter: (item) => {
  140. return (item.discountTotalPrice ?
  141. Number(item.discountTotalPrice).toFixed(2) :
  142. '') + '元';
  143. }
  144. }],
  145. [{
  146. label: '客户代号:',
  147. prop: 'customerMark',
  148. slot: 'customerMark',
  149. }],
  150. [{
  151. label: '单重:',
  152. prop: 'singleWeight',
  153. slot: 'singleWeight',
  154. }, {
  155. label: '总重:',
  156. prop: 'totalWeight',
  157. }],
  158. [{
  159. label: '客户期望交期:',
  160. prop: 'customerExpectDeliveryDeadline',
  161. slot: 'customerExpectDeliveryDeadline',
  162. className: 'perce100',
  163. }],
  164. [{
  165. label: '质保期:',
  166. prop: 'guaranteePeriod',
  167. slot: 'guaranteePeriod',
  168. }, {
  169. label: '单位:',
  170. prop: 'guaranteePeriodUnitCode',
  171. slot: 'guaranteePeriodUnitCode',
  172. }],
  173. [{
  174. label: '操作:',
  175. prop: 'action',
  176. type: 'action',
  177. className: 'perce100',
  178. }],
  179. ],
  180. current: 0,
  181. list1: [{
  182. name: '详细信息',
  183. }, {
  184. name: '产品清单',
  185. }],
  186. form: {
  187. id: '',
  188. contractId: '',
  189. orderFiles: [],
  190. contractName: '',
  191. salesDeptName: '',
  192. pricingWay: 1,
  193. payAmount: '',
  194. generatePurchase: 0,
  195. generateProduce: 0,
  196. generateProject: 0,
  197. projectName: '',
  198. projectId: '',
  199. receiveAddress: '',
  200. remark: '',
  201. saleType: '',
  202. saleTypeName: '',
  203. totalAmount: '',
  204. settlementMode: '4',
  205. settlementModeName: '分期付款',
  206. partaUnifiedSocialCreditCode: '',
  207. partbUnifiedSocialCreditCode: '',
  208. partaAddress: '',
  209. partaEmail: '',
  210. partaFax: '',
  211. partaId: '',
  212. partaLinkId: '',
  213. partaLinkName: '',
  214. partaName: '',
  215. partaTel: '',
  216. partbAddress: '',
  217. partbEmail: '',
  218. partbFax: '',
  219. partbId: '',
  220. partbLinkId: '',
  221. partbLinkName: '',
  222. partbName: '',
  223. partbTel: '',
  224. needProduce: 1
  225. },
  226. orderNoCountData: {
  227. saleOrderNumber: '', //订单数量
  228. totalAmountSaleOrder: '', //订单总金额
  229. sendNumber: '', //发货数量
  230. receivable: '', //应收款
  231. returnNumber: '', //退货数量
  232. returnAmount: '' //退货金额
  233. }
  234. }
  235. },
  236. onLoad(data) {
  237. getSaleOrderDetail(data.id).then(async res => {
  238. this.form = res
  239. this.form.contractId = this.form.contractId || '11'
  240. this.$nextTick(() => {
  241. this.$refs.infoRef.init(res)
  242. this.$refs.produceListRef.init(res.productList)
  243. })
  244. this.orderNoCountData = await queryOrderNoCount(res.orderNo)
  245. })
  246. },
  247. methods: {
  248. change(data) {
  249. this.current = data.index
  250. // console.log(data,'current')
  251. },
  252. }
  253. }
  254. </script>
  255. <style lang="scss" scoped>
  256. .item {
  257. padding: 16rpx 32rpx;
  258. .card {
  259. padding: 16rpx 32rpx;
  260. margin-top: 32rpx;
  261. display: flex;
  262. flex-wrap: wrap;
  263. height: 200rpx;
  264. border-radius: 12rpx;
  265. border: 1px solid #cbcbcb;
  266. >view {
  267. font-size: 26rpx;
  268. width: 33%;
  269. .lable {
  270. color: #999;
  271. margin-bottom: 10rpx;
  272. }
  273. }
  274. }
  275. }
  276. </style>