sales_detail.vue 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298
  1. <template>
  2. <div class="detail-container">
  3. <el-page-header @back="goBack" content="详情"></el-page-header>
  4. <div id="printMe">
  5. <div class="main-title">
  6. <div class="title">出库单信息</div>
  7. </div>
  8. <div class="diy-table-1">
  9. <el-row :gutter="0">
  10. <el-col :span="8" class="item">
  11. <div class="label">出库单号</div>
  12. <div class="value">{{ detailData.id }}</div>
  13. </el-col>
  14. <el-col :span="8" class="item">
  15. <div class="label">单据日期</div>
  16. <div class="value">{{ detailData.orderTime }}</div>
  17. </el-col>
  18. <el-col :span="8" class="item">
  19. <div class="label">单据状态</div>
  20. <div class="value">
  21. {{ detailData.examineStatus | statusFilter }}
  22. </div>
  23. </el-col>
  24. <el-col :span="8" class="item">
  25. <div class="label">发货单号</div>
  26. <div class="value">{{ detailData.orderNo }}</div>
  27. </el-col>
  28. <el-col :span="16" class="item">
  29. <div class="label">经销商</div>
  30. <div class="value">{{ detailData.customerName }}</div>
  31. </el-col>
  32. <el-col :span="8" class="item">
  33. <div class="label">仓库</div>
  34. <div class="value">{{ detailData.correspondName }}</div>
  35. </el-col>
  36. <el-col :span="16" class="item">
  37. <div class="label">备注</div>
  38. <div class="value">{{ detailData.remark }}</div>
  39. </el-col>
  40. </el-row>
  41. </div>
  42. <div class="main-title">
  43. <div class="title">货品信息</div>
  44. </div>
  45. <div class="table">
  46. <el-table
  47. :data="detailData.saleOrderData"
  48. element-loading-text="Loading"
  49. border
  50. fit
  51. highlight-current-row
  52. stripe
  53. max-height="400"
  54. show-summary
  55. :summary-method="$getSummaries"
  56. >
  57. <el-table-column
  58. align="center"
  59. label="序号"
  60. type="index"
  61. width="50"
  62. ></el-table-column>
  63. <el-table-column
  64. align="center"
  65. label="销售订单号"
  66. prop="mainOrderId"
  67. min-width="180"
  68. show-overflow-tooltip
  69. >
  70. <template slot-scope="scope">
  71. {{
  72. scope.row.orderType == "TRADE" || scope.row.orderType == "HOME"
  73. ? scope.row.enginOrderNo
  74. : scope.row.mainOrderId
  75. }}
  76. </template>
  77. </el-table-column>
  78. <el-table-column
  79. align="center"
  80. label="物料编码"
  81. prop="materialCode"
  82. min-width="120"
  83. show-overflow-tooltip
  84. ></el-table-column>
  85. <el-table-column
  86. align="center"
  87. label="产品编码"
  88. prop="materialOldNumber"
  89. min-width="120"
  90. show-overflow-tooltip
  91. ></el-table-column>
  92. <el-table-column
  93. align="center"
  94. label="产品名称"
  95. prop="materialName"
  96. min-width="160"
  97. show-overflow-tooltip
  98. ></el-table-column>
  99. <el-table-column
  100. align="center"
  101. label="规格型号"
  102. prop="specification"
  103. min-width="160"
  104. show-overflow-tooltip
  105. ></el-table-column>
  106. <el-table-column
  107. align="center"
  108. label="单位"
  109. prop="unit"
  110. min-width="100"
  111. show-overflow-tooltip
  112. ></el-table-column>
  113. <el-table-column
  114. align="right"
  115. label="数量"
  116. prop="refundableQty"
  117. min-width="100"
  118. show-overflow-tooltip
  119. >
  120. <template slot-scope="scope">
  121. <template v-if="edit">
  122. <el-input
  123. size="mini"
  124. class="input"
  125. v-model="scope.row.refundableQty"
  126. placeholder="请输入数量"
  127. ></el-input>
  128. </template>
  129. <template v-else>
  130. {{ scope.row.refundableQty }}
  131. </template>
  132. </template>
  133. </el-table-column>
  134. <!-- <el-table-column align="right" label="单价" prop="price" min-width="100" show-overflow-tooltip>
  135. <template slot-scope="scope">
  136. {{ scope.row.price | numToFixed }}
  137. </template>
  138. </el-table-column>
  139. <el-table-column align="right" label="订单金额" prop="payAmount" min-width="100" show-overflow-tooltip>
  140. <template slot-scope="scope">
  141. {{ scope.row.payAmount | numToFixed }}
  142. </template>
  143. </el-table-column> -->
  144. <el-table-column
  145. align="left"
  146. label="表头备注"
  147. prop="headerRemark"
  148. min-width="160"
  149. show-overflow-tooltip
  150. ></el-table-column>
  151. <!-- <el-table-column align="left" label="发货申请备注" prop="remark" min-width="160" show-overflow-tooltip></el-table-column> -->
  152. <el-table-column
  153. align="left"
  154. label="表体备注"
  155. prop="invoiceRemark"
  156. min-width="160"
  157. show-overflow-tooltip
  158. ></el-table-column>
  159. <el-table-column
  160. align="left"
  161. label="表头业务员"
  162. prop="k3ServiceName"
  163. min-width="100"
  164. show-overflow-tooltip
  165. ></el-table-column>
  166. <el-table-column
  167. align="left"
  168. label="表体业务员"
  169. prop="serviceName"
  170. min-width="100"
  171. show-overflow-tooltip
  172. ></el-table-column>
  173. </el-table>
  174. </div>
  175. <div class="main-title">
  176. <div class="title">审批记录</div>
  177. </div>
  178. <div class="diy-table-1">
  179. <el-row :gutter="0">
  180. <el-col :xs="12" :sm="12" :lg="12" class="item">
  181. <div class="label">审批人</div>
  182. <div class="value">{{ detailData.approvalName }}</div>
  183. </el-col>
  184. <el-col :xs="12" :sm="12" :lg="12" class="item">
  185. <div class="label">制单人</div>
  186. <div class="value">{{ detailData.createBy }}</div>
  187. </el-col>
  188. <el-col :xs="12" :sm="12" :lg="12" class="item">
  189. <div class="label">审批结果</div>
  190. <div class="value">
  191. {{ detailData.examineStatus | statusFilter }}
  192. </div>
  193. </el-col>
  194. <el-col :xs="12" :sm="12" :lg="12" class="item">
  195. <div class="label">审批时间</div>
  196. <div class="value">{{ detailData.approvalTime }}</div>
  197. </el-col>
  198. <el-col :xs="24" :sm="24" :lg="24" class="item">
  199. <div class="label">审批说明</div>
  200. <div class="value">{{ detailData.approvalRemark }}</div>
  201. </el-col>
  202. </el-row>
  203. </div>
  204. </div>
  205. <div style="margin: 10px" v-if="edit">
  206. <el-button type="primary" @click="updateNum">保存</el-button>
  207. </div>
  208. </div>
  209. </template>
  210. <script>
  211. import print from "vue-print-nb";
  212. import { getDetail, updateNum } from "@/api/supply/sales";
  213. export default {
  214. name: "SalesDetail",
  215. componentName: "SalesDetail",
  216. props: ["listItem", "edit"],
  217. directives: {
  218. print,
  219. },
  220. filters: {
  221. statusFilter(val) {
  222. const statusList = [
  223. { label: "已保存", value: "SAVE" },
  224. { label: "待审核", value: "WAIT" },
  225. { label: "审核通过", value: "OK" },
  226. // { label: '审核驳回', value: 'FAIL' },,
  227. ];
  228. let obj = statusList.find((o) => o.value == val);
  229. return obj ? obj.label : "";
  230. },
  231. },
  232. data() {
  233. return {
  234. printObj: {
  235. id: "printMe",
  236. },
  237. detailData: {},
  238. };
  239. },
  240. created() {
  241. this.getDetail();
  242. },
  243. methods: {
  244. // 返回列表
  245. goBack() {
  246. this.$emit("backListFormDetail");
  247. this.$parent.edit = false;
  248. },
  249. updateNum() {
  250. this.detailData.saleOrderData.forEach((item) => {
  251. item.invoiceNum = +item.refundableQty;
  252. });
  253. updateNum({
  254. ...this.detailData,
  255. }).then((res) => {
  256. this.$successMsg("修改成功");
  257. this.$parent.edit = false;
  258. this.goBack();
  259. this.$parent.getList();
  260. });
  261. },
  262. // 获取详情
  263. getDetail() {
  264. getDetail({ id: this.listItem.id }).then((res) => {
  265. if (res.data.saleOrderData) {
  266. res.data.saleOrderData.forEach((item) => {
  267. item.sums1 = ["refundableQty"];
  268. item.sums2 = ["payAmount", "price"];
  269. });
  270. }
  271. this.detailData = res.data;
  272. });
  273. },
  274. },
  275. };
  276. </script>
  277. <style scoped lang="scss">
  278. .detail-container {
  279. width: 100%;
  280. height: 100%;
  281. .input {
  282. ::v-deep .el-input__inner {
  283. text-align: right !important;
  284. }
  285. }
  286. }
  287. </style>