details.vue 35 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178
  1. <template>
  2. <div>
  3. <el-card shadow="never">
  4. <div>
  5. <div class="content-detail">
  6. <header-title title="基本信息" size="16px"></header-title>
  7. <div class="mt20">
  8. <el-form label-width="120px">
  9. <el-col :span="8">
  10. <el-form-item label="入库单:">
  11. <span>{{ infoData?.bizNo?.toString() }}</span>
  12. </el-form-item>
  13. </el-col>
  14. <el-col :span="8">
  15. <el-form-item label="入库物品类型:">
  16. <span>{{ handleAssetType(extInfo?.assetType) }}</span>
  17. </el-form-item>
  18. </el-col>
  19. <el-col :span="8">
  20. <el-form-item label="入库场景:">
  21. <span>{{ getSceneState(infoData.bizType) }}</span>
  22. </el-form-item>
  23. </el-col>
  24. <el-col :span="8">
  25. <el-form-item label="关联订单:">
  26. <span>{{ extInfo.documentSource }}</span>
  27. </el-form-item>
  28. </el-col>
  29. <el-col :span="8">
  30. <el-form-item label="权属部门:">
  31. <span>{{ extInfo.deptName }}</span>
  32. </el-form-item>
  33. </el-col>
  34. <el-col :span="8">
  35. <el-form-item label="入库登记人:">
  36. <span>{{ extInfo.createUserName }}</span>
  37. </el-form-item>
  38. </el-col>
  39. <el-col :span="8">
  40. <el-form-item label="入库时间:">
  41. <span>{{ infoData.storageTime }}</span>
  42. </el-form-item>
  43. </el-col>
  44. <el-col :span="8">
  45. <el-form-item label="状态:">
  46. <span>{{ stepsTitle }}</span>
  47. </el-form-item>
  48. </el-col>
  49. <el-col :span="8">
  50. <el-form-item label="审核人:">
  51. <span>{{ infoData.verifyName }}</span>
  52. </el-form-item>
  53. </el-col>
  54. <el-col :span="8">
  55. <el-form-item label="客户:">
  56. <span>{{ infoData.clientName }}</span>
  57. </el-form-item>
  58. </el-col>
  59. <el-col :span="8">
  60. <el-form-item label="供应商:">
  61. <span>{{ extInfo.supplierName }}</span>
  62. </el-form-item>
  63. </el-col>
  64. <el-col :span="8">
  65. <el-form-item label="供应商代号:">
  66. <template v-if="bizType == 2">{{
  67. extInfo.supplierMark
  68. }}</template>
  69. <template v-if="bizType != 2">{{
  70. extInfo.supplierCode
  71. }}</template>
  72. </el-form-item>
  73. </el-col>
  74. <!-- <el-col :span="8">
  75. <el-form-item label="产地:">
  76. <span>{{ extInfo.provenance }}</span>
  77. </el-form-item>
  78. </el-col> -->
  79. <!-- <el-col :span="8">
  80. <el-form-item label="送货人:">
  81. <span>{{ infoData.fromUser }}</span>
  82. </el-form-item>
  83. </el-col>
  84. <el-col :span="8">
  85. <el-form-item label="送货人联系方式:">
  86. <span>{{ extInfo.deliveryPhone }}</span>
  87. </el-form-item>
  88. </el-col> -->
  89. <el-col :span="8" v-if="isUpload">
  90. <el-form-item prop="qualityFile" label="回执附件">
  91. <fileMain v-model="qualityFile" />
  92. </el-form-item>
  93. </el-col>
  94. <el-col v-else :span="8">
  95. <el-form-item label="附件:">
  96. <fileMain v-model="infoData.qualityFile" type="view" />
  97. <!-- <el-link
  98. type="primary"
  99. v-for="item in infoData.qualityFile"
  100. @click="download(item)"
  101. :key="item.name"
  102. >{{ item.name }}</el-link
  103. > -->
  104. </el-form-item>
  105. </el-col>
  106. <el-col :span="24">
  107. <el-form-item label="备注:">
  108. <span>{{ infoData.remark }}</span>
  109. </el-form-item>
  110. </el-col>
  111. </el-form>
  112. </div>
  113. </div>
  114. <div class="content-detail mt20">
  115. <header-title title="产品信息" size="16px"></header-title>
  116. <el-table
  117. ref="productListTable"
  118. :data="productList"
  119. tooltip-effect="dark"
  120. :max-height="300"
  121. :header-cell-style="rowClass"
  122. border
  123. >
  124. <el-table-column label="序号" type="index" width="50">
  125. </el-table-column>
  126. <el-table-column
  127. v-if="isIds"
  128. minWidth="150"
  129. label="入库单号"
  130. prop="bizNo"
  131. align="center"
  132. :show-overflow-tooltip="true"
  133. ></el-table-column>
  134. <el-table-column
  135. label="仓库"
  136. prop="warehouseName"
  137. :show-overflow-tooltip="true"
  138. >
  139. </el-table-column>
  140. <el-table-column
  141. label="编码"
  142. prop="categoryCode"
  143. align="center"
  144. :show-overflow-tooltip="true"
  145. ></el-table-column>
  146. <el-table-column
  147. label="名称"
  148. align="center"
  149. prop="categoryName"
  150. :show-overflow-tooltip="true"
  151. ></el-table-column>
  152. <el-table-column
  153. v-if="clientEnvironmentId == 4"
  154. label="级别"
  155. prop="level"
  156. align="center"
  157. >
  158. </el-table-column>
  159. <el-table-column
  160. label="型号"
  161. align="center"
  162. prop="categoryModel"
  163. :show-overflow-tooltip="true"
  164. ></el-table-column>
  165. <el-table-column
  166. label="规格"
  167. align="center"
  168. prop="specification"
  169. :show-overflow-tooltip="true"
  170. ></el-table-column>
  171. <el-table-column
  172. label="牌号"
  173. align="center"
  174. prop="brandNum"
  175. :show-overflow-tooltip="true"
  176. ></el-table-column>
  177. <el-table-column
  178. v-for="(item, index) in newColumns"
  179. :label="item.label"
  180. :align="item.align"
  181. :prop="item.prop"
  182. :show-overflow-tooltip="item.showOverflowTooltip"
  183. ></el-table-column>
  184. <el-table-column
  185. label="批次号"
  186. prop="batchNo"
  187. align="center"
  188. :show-overflow-tooltip="true"
  189. >
  190. </el-table-column>
  191. <el-table-column
  192. label="数量"
  193. v-if="clientEnvironmentId == 3"
  194. prop="packingQuantity"
  195. align="center"
  196. >
  197. <template slot-scope="{ row, $index }">
  198. {{ row.packingQuantity }} {{ row.packingUnit }}
  199. </template>
  200. </el-table-column>
  201. <el-table-column
  202. v-else
  203. label="数量"
  204. prop="packingQuantity"
  205. width="80"
  206. ></el-table-column>
  207. <el-table-column
  208. v-if="clientEnvironmentId == 3"
  209. label="最小包装单元"
  210. align="center"
  211. width="120"
  212. prop="minPackingQuantity"
  213. >
  214. <template slot-scope="{ row, $index }">
  215. {{ row.minPackingQuantity }} {{ row.measureUnit }} /{{
  216. row.packingUnit
  217. }}
  218. </template>
  219. </el-table-column>
  220. <el-table-column
  221. v-else
  222. label="单位"
  223. prop="packingUnit"
  224. ></el-table-column>
  225. <el-table-column
  226. label="允许拆包"
  227. prop="isUnpack"
  228. width="100"
  229. align="center"
  230. >
  231. <template slot-scope="{ row }">
  232. {{ row.isUnpack == 1 ? '是' : '否' }}
  233. </template>
  234. </el-table-column>
  235. <el-table-column
  236. label="计量数量"
  237. prop="measureQuantity"
  238. :show-overflow-tooltip="true"
  239. ></el-table-column>
  240. <el-table-column
  241. label="计量单位"
  242. prop="measureUnit"
  243. ></el-table-column>
  244. <el-table-column
  245. label="重量"
  246. prop="weight"
  247. align="center"
  248. :show-overflow-tooltip="true"
  249. >
  250. </el-table-column>
  251. <el-table-column
  252. label="重量单位"
  253. prop="weightUnit"
  254. align="center"
  255. :show-overflow-tooltip="true"
  256. >
  257. </el-table-column>
  258. <el-table-column
  259. label="生产要求"
  260. align="center"
  261. width="200"
  262. prop="productionRequirements"
  263. :show-overflow-tooltip="true"
  264. ></el-table-column>
  265. <el-table-column label="机型" prop="modelKey" width="200">
  266. </el-table-column>
  267. <el-table-column label="颜色" prop="colorKey" width="200">
  268. </el-table-column>
  269. <el-table-column
  270. label="单价"
  271. prop="unitPrice"
  272. align="center"
  273. v-if="isPrice == 1"
  274. >
  275. <template slot-scope="{ row }">
  276. <template>
  277. {{ row.unitPrice ? row.unitPrice + '/元' : '' }}
  278. </template>
  279. </template>
  280. </el-table-column>
  281. <el-table-column
  282. label="金额"
  283. align="center"
  284. prop="totalMoney"
  285. v-if="isPrice == 1"
  286. :show-overflow-tooltip="true"
  287. >
  288. <template slot-scope="{ row, $index }">
  289. {{ row.totalMoney ? row.totalMoney : 0 }}
  290. </template>
  291. </el-table-column>
  292. <el-table-column
  293. v-if="clientEnvironmentId == 4"
  294. label="采购原因"
  295. align="center"
  296. prop="purpose"
  297. :show-overflow-tooltip="true"
  298. ></el-table-column>
  299. <el-table-column
  300. label="供应商"
  301. prop="supplierName"
  302. :show-overflow-tooltip="true"
  303. >
  304. </el-table-column>
  305. <el-table-column
  306. label="供应商代号"
  307. prop="supplierCode"
  308. width="120"
  309. :show-overflow-tooltip="true"
  310. >
  311. </el-table-column>
  312. <el-table-column
  313. label="产地"
  314. align="center"
  315. prop="provenance"
  316. v-if="bizType == 2"
  317. :show-overflow-tooltip="true"
  318. width="120"
  319. >
  320. <template slot-scope="{ row, $index }">
  321. {{
  322. row.provenance &&
  323. row.provenance
  324. .map((item) => getDictValue('产地', item))
  325. .join(',')
  326. }}
  327. </template>
  328. </el-table-column>
  329. <el-table-column
  330. label="生产日期"
  331. prop="detailProductionDate"
  332. :show-overflow-tooltip="true"
  333. >
  334. </el-table-column>
  335. <el-table-column
  336. label="采购日期"
  337. prop="detailPurchaseDate"
  338. :show-overflow-tooltip="true"
  339. >
  340. </el-table-column>
  341. <el-table-column
  342. label="失效日期"
  343. prop="detailExpireDate"
  344. :show-overflow-tooltip="true"
  345. >
  346. </el-table-column>
  347. </el-table>
  348. </div>
  349. <div class="mt20">
  350. <header-title :title="`包装明细`" size="16px"></header-title>
  351. <el-table
  352. ref="showPackingListTable"
  353. :data="showPackingList"
  354. tooltip-effect="dark"
  355. :max-height="300"
  356. :row-class-name="tableRowClassName"
  357. :header-cell-style="rowClass"
  358. border
  359. v-el-table-infinite-scroll="pickingHandleScroll"
  360. >
  361. <el-table-column label="序号" type="index" width="50">
  362. </el-table-column>
  363. <el-table-column
  364. label="批次号"
  365. prop="batchNo"
  366. width="80"
  367. :show-overflow-tooltip="true"
  368. ></el-table-column>
  369. <el-table-column
  370. label="包装编码"
  371. prop="packageNo"
  372. width="130"
  373. :show-overflow-tooltip="true"
  374. ></el-table-column>
  375. <el-table-column
  376. label="名称"
  377. prop="categoryName"
  378. width="120"
  379. :show-overflow-tooltip="true"
  380. ></el-table-column>
  381. <el-table-column
  382. label="编码"
  383. prop="categoryCode"
  384. width="120"
  385. :show-overflow-tooltip="true"
  386. ></el-table-column>
  387. <el-table-column
  388. label="型号"
  389. prop="categoryModel"
  390. width="80"
  391. :show-overflow-tooltip="true"
  392. ></el-table-column>
  393. <el-table-column
  394. label="规格"
  395. prop="specification"
  396. width="80"
  397. :show-overflow-tooltip="true"
  398. ></el-table-column>
  399. <el-table-column
  400. label="牌号"
  401. prop="brandNum"
  402. width="80"
  403. :show-overflow-tooltip="true"
  404. ></el-table-column>
  405. <!-- <el-table-column label="编码" prop="categoryCode" :show-overflow-tooltip="true"></el-table-column>
  406. <el-table-column label="名称" prop="categoryName" :show-overflow-tooltip="true"></el-table-column>
  407. <el-table-column label="批次号" prop="batchNo" :show-overflow-tooltip="true"></el-table-column> -->
  408. <el-table-column
  409. label="发货条码"
  410. prop="barcodes"
  411. :show-overflow-tooltip="true"
  412. ></el-table-column>
  413. <el-table-column
  414. label="包装数量"
  415. prop="packingQuantity"
  416. :show-overflow-tooltip="true"
  417. ></el-table-column>
  418. <el-table-column
  419. label="包装单位"
  420. prop="packingUnit"
  421. :show-overflow-tooltip="true"
  422. ></el-table-column>
  423. <el-table-column
  424. label="计量数量"
  425. prop="measureQuantity"
  426. :show-overflow-tooltip="true"
  427. ></el-table-column>
  428. <el-table-column
  429. label="计量单位"
  430. prop="measureUnit"
  431. :show-overflow-tooltip="true"
  432. ></el-table-column>
  433. <el-table-column
  434. label="物料代号"
  435. prop="materielDesignation"
  436. :show-overflow-tooltip="true"
  437. >
  438. </el-table-column>
  439. <el-table-column
  440. label="客户代号"
  441. prop="clientCode"
  442. :show-overflow-tooltip="true"
  443. >
  444. <template slot-scope="{ row, $index }">
  445. <span v-if="bizType != 2">{{ row?.clientCode }}</span>
  446. <span v-if="bizType == 2">{{ row?.customerMark }}</span>
  447. </template>
  448. </el-table-column>
  449. <el-table-column
  450. label="刻码"
  451. prop="engrave"
  452. :show-overflow-tooltip="true"
  453. >
  454. </el-table-column>
  455. <el-table-column
  456. label="重量"
  457. prop="weight"
  458. :show-overflow-tooltip="true"
  459. >
  460. </el-table-column>
  461. <el-table-column
  462. label="重量单位"
  463. prop="weightUnit"
  464. :show-overflow-tooltip="true"
  465. >
  466. </el-table-column>
  467. <el-table-column label="机型" prop="modelKey" width="200">
  468. </el-table-column>
  469. <el-table-column label="颜色" prop="colorKey" width="200">
  470. </el-table-column>
  471. <el-table-column
  472. label="供应商"
  473. prop="supplierName"
  474. :show-overflow-tooltip="true"
  475. >
  476. </el-table-column>
  477. <el-table-column
  478. label="供应商代号"
  479. prop="supplierCode"
  480. width="120"
  481. :show-overflow-tooltip="true"
  482. >
  483. </el-table-column>
  484. <el-table-column
  485. label="质检结果"
  486. prop="result"
  487. :show-overflow-tooltip="true"
  488. >
  489. <template slot-scope="{ row }">
  490. <span>{{ qualityResults[row.result] }}</span>
  491. </template>
  492. </el-table-column>
  493. <el-table-column
  494. label="质检状态"
  495. prop="status"
  496. :show-overflow-tooltip="true"
  497. >
  498. <template slot-scope="{ row }">
  499. <span>{{ qualityStatus[row.status] }}</span>
  500. </template>
  501. </el-table-column>
  502. <el-table-column
  503. label="仓库"
  504. prop="warehouseName"
  505. :show-overflow-tooltip="true"
  506. >
  507. </el-table-column>
  508. <el-table-column
  509. label="货区"
  510. prop="areaName"
  511. :show-overflow-tooltip="true"
  512. >
  513. </el-table-column>
  514. <el-table-column
  515. label="货架"
  516. prop="goodsShelfName"
  517. :show-overflow-tooltip="true"
  518. >
  519. </el-table-column>
  520. <el-table-column
  521. label="货位"
  522. prop="goodsAllocationName"
  523. :show-overflow-tooltip="true"
  524. >
  525. </el-table-column>
  526. <el-table-column
  527. label="生产日期"
  528. prop="productionDate"
  529. :show-overflow-tooltip="true"
  530. >
  531. </el-table-column>
  532. <el-table-column
  533. label="采购日期"
  534. prop="purchaseDate"
  535. :show-overflow-tooltip="true"
  536. >
  537. </el-table-column>
  538. <el-table-column
  539. label="失效日期"
  540. prop="expireDate"
  541. :show-overflow-tooltip="true"
  542. >
  543. </el-table-column>
  544. </el-table>
  545. </div>
  546. <!-- <div class="mt20" v-if="bizType != '2'">
  547. <header-title :title="`物料明细`" size="16px"> </header-title>
  548. <el-table
  549. ref="multipleTable"
  550. :data="showMaterialList"
  551. tooltip-effect="dark"
  552. :max-height="300"
  553. :row-class-name="tableRowClassName"
  554. :header-cell-style="rowClass"
  555. border
  556. style="width: 100%"
  557. stripe
  558. height="300px"
  559. v-el-table-infinite-scroll="materielHandleScroll"
  560. >
  561. <el-table-column label="序号" type="index" width="50">
  562. </el-table-column>
  563. <el-table-column
  564. label="编码"
  565. prop="categoryCode"
  566. :show-overflow-tooltip="true"
  567. ></el-table-column>
  568. <el-table-column
  569. label="名称"
  570. prop="categoryName"
  571. :show-overflow-tooltip="true"
  572. ></el-table-column>
  573. <el-table-column label="批次号" prop="batchNo"></el-table-column>
  574. <el-table-column
  575. label="物料编码"
  576. prop="materialCode"
  577. :show-overflow-tooltip="true"
  578. ></el-table-column>
  579. <el-table-column
  580. label="发货条码"
  581. prop="barcodes"
  582. :show-overflow-tooltip="true"
  583. ></el-table-column>
  584. <el-table-column
  585. label="计价方式"
  586. prop="pricingWay"
  587. :show-overflow-tooltip="true"
  588. >
  589. <template slot-scope="{ row, $index }">
  590. <span v-if="row.pricingWay == 1">数量</span>
  591. <span v-if="row.pricingWay == 2">重量</span>
  592. </template>
  593. </el-table-column>
  594. <el-table-column
  595. label="计量数量"
  596. prop="measureQuantity"
  597. ></el-table-column>
  598. <el-table-column
  599. label="计量单位"
  600. prop="measureUnit"
  601. ></el-table-column>
  602. <el-table-column label="物料代号" prop="materielDesignation">
  603. </el-table-column>
  604. <el-table-column label="客户代号" prop="clientCode">
  605. <template slot-scope="{ row, $index }">
  606. <span v-if="bizType != 2">{{ row?.clientCode }}</span>
  607. <span v-if="bizType == 2">{{ row?.customerMark }}</span>
  608. </template>
  609. </el-table-column>
  610. <el-table-column label="刻码" prop="engrave"> </el-table-column>
  611. <el-table-column width="100" label="重量" prop="weight">
  612. </el-table-column>
  613. <el-table-column label="重量单位" prop="weightUnit">
  614. </el-table-column>
  615. <el-table-column label="质检结果" prop="result" width="120">
  616. <template slot-scope="{ row }">
  617. <span>{{ qualityResults[row.result] }}</span>
  618. </template>
  619. </el-table-column>
  620. <el-table-column label="质检状态" prop="status" width="120">
  621. <template slot-scope="{ row }">
  622. <span>{{ qualityStatus[row.status] }}</span>
  623. </template>
  624. </el-table-column>
  625. </el-table>
  626. </div>-->
  627. </div>
  628. </el-card>
  629. </div>
  630. </template>
  631. <script>
  632. import elTableInfiniteScroll from 'el-table-infinite-scroll';
  633. // import fileUpload from '@/BIZComponents/addDoc/index.vue';
  634. import { getFile } from '@/api/system/file/index.js';
  635. import storageApi from '@/api/warehouseManagement';
  636. import { allCategoryLevel } from '@/api/classifyManage';
  637. import {
  638. useDictLabel,
  639. sceneState,
  640. qualityStatus,
  641. qualityResults
  642. } from '@/utils/dict/index';
  643. import { mapGetters, mapActions } from 'vuex';
  644. import { parameterGetByCode } from '@/api/main/index.js';
  645. export default {
  646. directives: {
  647. 'el-table-infinite-scroll': elTableInfiniteScroll
  648. },
  649. // components: { fileUpload },
  650. props: {
  651. bizType: {
  652. type: String,
  653. default: ''
  654. },
  655. businessId: {
  656. type: String,
  657. default: ''
  658. },
  659. isUpload: {
  660. type: Boolean,
  661. default: false
  662. },
  663. isInterior: {
  664. type: Boolean,
  665. default: false
  666. },
  667. isIds: {
  668. //多个入库单ID
  669. type: Boolean,
  670. default: false
  671. }
  672. },
  673. data() {
  674. return {
  675. newColumns: [], // 动态表头
  676. qualityFile: [], // 回执附件
  677. qualityStatus, // 质检状态 0未检 1已检
  678. qualityResults, // 质检结果 0无 1合格 2不合格
  679. productList: [], // 产品列表
  680. showPackingList: [], // 展示的包装列表
  681. packingList: [], // 包装列表
  682. showMaterialList: [], // 展示物料列表
  683. materialList: [], // 物料列表
  684. extInfo: {}, // 扩展信息
  685. pageSize: 20,
  686. pickingPageNum: 1,
  687. materielPageNum: 1,
  688. codeList: [],
  689. infoData: {},
  690. stepsTitle: '已完成',
  691. stepsStatus: 'success',
  692. active: 0,
  693. isPrice: 1
  694. };
  695. },
  696. watch: {
  697. 'infoData.verifyStatus': {
  698. immediate: true,
  699. handler(val) {
  700. if (val == 0) {
  701. this.active = 1;
  702. this.stepsTitle = '未审核';
  703. this.stepsStatus = 'wait';
  704. } else if (val == 1) {
  705. this.active = 2;
  706. this.stepsTitle = '审核中';
  707. this.stepsStatus = 'process';
  708. } else if (val == 2) {
  709. this.active = 2;
  710. this.stepsTitle = '审核通过';
  711. this.stepsStatus = 'success';
  712. } else if (val == 3) {
  713. this.active = 2;
  714. this.stepsTitle = '驳回';
  715. this.stepsStatus = 'error';
  716. }
  717. }
  718. },
  719. businessId(val) {
  720. if (val) {
  721. this._getInfo(val);
  722. }
  723. }
  724. },
  725. computed: {
  726. ...mapGetters(['getDictValue']),
  727. clientEnvironmentId() {
  728. return this.$store.state.user.info.clientEnvironmentId;
  729. }
  730. },
  731. mounted() {
  732. this.getFieldModel();
  733. this.requestDict('类型用途');
  734. this.requestDict('产地');
  735. this.getAllCategoryType();
  736. this._getInfo(this.businessId);
  737. },
  738. created() {
  739. //仓库出入库是否显示金额(0:不显示 1:显示)
  740. parameterGetByCode({
  741. code: 'wms_price'
  742. }).then((res) => {
  743. this.isPrice = res.value;
  744. });
  745. },
  746. methods: {
  747. // 获取动态表头
  748. getFieldModel() {
  749. storageApi.fieldModel({ fieldModel: 't_main_category' }).then((res) => {
  750. let newRes = res.map((m) => {
  751. return {
  752. prop: 'extField.' + m.prop,
  753. label: m.label,
  754. align: 'center',
  755. showOverflowTooltip: true
  756. };
  757. });
  758. this.newColumns = [...newRes];
  759. });
  760. },
  761. //获取回执附件
  762. getQualityFile() {
  763. return { qualityFile: this.qualityFile, id: this.infoData.id };
  764. },
  765. pickingHandleScroll() {
  766. console.log('---------pickingHandleScroll------------');
  767. if (this.showPackingList.length < this.packingList.length) {
  768. if (this.packingList.length > this.pageSize) {
  769. this.pickingPageNum += 1;
  770. }
  771. this.pickingFetchData();
  772. }
  773. },
  774. pickingFetchData() {
  775. const start = (this.pickingPageNum - 1) * this.pageSize;
  776. const end = start + this.pageSize;
  777. this.showPackingList = this.showPackingList.concat(
  778. this.packingList.slice(start, end)
  779. );
  780. },
  781. materielHandleScroll() {
  782. console.log('---------materielHandleScroll------------');
  783. if (this.showMaterialList.length < this.materialList.length) {
  784. if (this.materialList.length > this.pageSize) {
  785. this.materielPageNum += 1;
  786. }
  787. this.materielFetchData();
  788. }
  789. },
  790. materielFetchData() {
  791. const start = (this.materielPageNum - 1) * this.pageSize;
  792. const end = start + this.pageSize;
  793. this.showMaterialList = this.showMaterialList.concat(
  794. this.materialList.slice(start, end)
  795. );
  796. console.log(this.showMaterialList);
  797. },
  798. ...mapActions('dict', ['requestDict']),
  799. getSceneState: useDictLabel(sceneState),
  800. handleAssetType(r) {
  801. if (r) {
  802. let arr = r.split(',');
  803. const filteredData = this.codeList.filter((item) =>
  804. arr.includes(item.dictCode)
  805. );
  806. return filteredData.map((item) => item.dictValue).join(',');
  807. }
  808. // const code = this.codeList.find((item) => item.dictCode == r);
  809. // return code?.dictValue;
  810. },
  811. tableRowClassName({ row, rowIndex }) {
  812. console.log(row);
  813. if (row.result == 2) {
  814. return 'warning-row';
  815. } else {
  816. return '';
  817. }
  818. },
  819. rowClass({ row, column, rowIndex, columnIndex }) {
  820. if (rowIndex === 1) {
  821. return {
  822. display: 'none',
  823. background: '#EEEEEE'
  824. };
  825. }
  826. return { background: '#0000' };
  827. },
  828. async getAllCategoryType() {
  829. const { data } = await allCategoryLevel();
  830. this.codeList = data.map((item) => {
  831. return { dictCode: item.id, dictValue: item.name };
  832. });
  833. },
  834. async _getInfo(id) {
  835. if (!id) return;
  836. let res = null;
  837. let resAll = null;
  838. if (this.isInterior) {
  839. res = await storageApi.getInboundDetailsById(id);
  840. } else if (this.isIds) {
  841. resAll = await storageApi.getInboundDetailsByIds(id);
  842. } else {
  843. res = await storageApi.getInfoBySourceBizNo(id);
  844. }
  845. console.log(
  846. 'idsssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssss',
  847. this.isIds
  848. );
  849. if (this.isIds) {
  850. res = JSON.parse(JSON.stringify(resAll[0]));
  851. this.extInfo = resAll[0].extInfo;
  852. res['outInDetailList'] = [];
  853. resAll.forEach((item) => {
  854. item.outInDetailList.forEach((val) => {
  855. val['bizNo'] = item.bizNo;
  856. res['outInDetailList'].push(val);
  857. });
  858. });
  859. res['bizNo'] = resAll.map((item) => item.bizNo);
  860. this.infoData = res;
  861. console.log('resAll---------------', resAll);
  862. } else {
  863. this.infoData = res;
  864. this.extInfo = res.extInfo;
  865. console.log(
  866. res,
  867. 'resresresresresresresresresresresresresresresresresresresresres2222'
  868. );
  869. }
  870. console.log('===', res);
  871. this.productList = res.outInDetailList.map(
  872. (productItem, productIndex) => {
  873. // if (this.isIds) {
  874. // productItem['bizNo'] = res.bizNo[productIndex];
  875. // }
  876. return {
  877. ...productItem,
  878. outInDetailRecordRequestList:
  879. productItem.outInDetailRecordRequestList.map((packingItem) => {
  880. return {
  881. ...packingItem,
  882. categoryName: productItem.categoryName,
  883. categoryCode: productItem.categoryCode,
  884. supplierCode: productItem.supplierCode,
  885. supplierName: productItem.supplierName,
  886. materialDetailList: packingItem.materialDetailList.map(
  887. (materialItem) => {
  888. return {
  889. ...materialItem,
  890. categoryName: productItem.categoryName,
  891. categoryCode: productItem.categoryCode
  892. };
  893. }
  894. )
  895. };
  896. })
  897. };
  898. }
  899. );
  900. // 获取包装维度数据
  901. const arr = [];
  902. for (const key in this.productList) {
  903. for (const k in this.productList[key].outInDetailRecordRequestList) {
  904. arr.push({
  905. ...this.productList[key].outInDetailRecordRequestList[k]
  906. });
  907. }
  908. }
  909. this.packingList = arr;
  910. // 获取物料维度数据
  911. let iArr = [];
  912. arr.forEach((item) => {
  913. item.materialDetailList.forEach((ele) => {
  914. iArr.push({ ...ele });
  915. });
  916. });
  917. this.materialList = iArr;
  918. console.log(this.packingList);
  919. console.log(this.materialList);
  920. this.pickingFetchData();
  921. this.materielFetchData();
  922. console.log(this.productList, 'this.productList');
  923. },
  924. download(row) {
  925. if (row.storePath) {
  926. getFile({ objectName: row.storePath }, row.name);
  927. }
  928. }
  929. }
  930. };
  931. </script>
  932. <style lang="scss" scoped>
  933. ::v-deep .warning-row {
  934. color: red;
  935. }
  936. ::v-deep .page-title {
  937. border-bottom: none;
  938. }
  939. ::v-deep .page-title-div {
  940. width: 100%;
  941. }
  942. .stepsStatus {
  943. width: 40%;
  944. margin: 0 auto;
  945. }
  946. .el-form-item {
  947. margin-bottom: 10px;
  948. }
  949. .p20 {
  950. padding: 20px;
  951. }
  952. .flex {
  953. display: flex;
  954. }
  955. .title {
  956. justify-content: space-between;
  957. border-bottom: 1px solid #ccc;
  958. padding-bottom: 5px;
  959. span {
  960. font-size: 16px;
  961. }
  962. .col {
  963. padding-left: 40px;
  964. font-size: 14px;
  965. color: #aaaaaa;
  966. }
  967. }
  968. .degree {
  969. margin-right: 10px;
  970. padding: 0px 15px;
  971. color: #fff;
  972. font-size: 13px;
  973. line-height: 23px;
  974. border-radius: 23px;
  975. display: flex;
  976. align-items: center;
  977. justify-content: space-between;
  978. span {
  979. width: 5px;
  980. height: 5px;
  981. border-radius: 100%;
  982. margin-right: 6px;
  983. background-color: #fff;
  984. }
  985. }
  986. .red {
  987. background-color: rgb(163, 0, 20);
  988. }
  989. .blue {
  990. background-color: #1989fa;
  991. }
  992. .createdInfo {
  993. justify-content: space-around;
  994. margin-top: 10px;
  995. font-size: 14px;
  996. .col {
  997. color: #6e6e6e;
  998. padding-right: 10px;
  999. }
  1000. }
  1001. .mt40 {
  1002. margin-top: 40px;
  1003. }
  1004. .custSteps {
  1005. margin-top: 20px;
  1006. margin-left: 70px;
  1007. .box {
  1008. width: 158px;
  1009. border: 1px solid #ccc;
  1010. padding: 10px;
  1011. flex-direction: row;
  1012. flex-wrap: wrap;
  1013. // justify-content: space-between;
  1014. font-size: 12px;
  1015. color: #9e9e9e;
  1016. .x {
  1017. width: 20px;
  1018. height: 15px;
  1019. margin-right: 5px;
  1020. }
  1021. .q {
  1022. background-color: #d0e4d5;
  1023. }
  1024. .b {
  1025. background-color: #1989fa;
  1026. }
  1027. .g {
  1028. background-color: #157a2c;
  1029. }
  1030. .r {
  1031. background-color: #a30014;
  1032. }
  1033. .a {
  1034. align-items: center;
  1035. margin-bottom: 10px;
  1036. }
  1037. .mr10 {
  1038. margin-right: 10px;
  1039. }
  1040. .mb0 {
  1041. margin-bottom: 0;
  1042. }
  1043. }
  1044. .stepsInfo {
  1045. // flex: 1;
  1046. width: 483px;
  1047. }
  1048. }
  1049. .mt20 {
  1050. margin-top: 20px;
  1051. }
  1052. .content-detail {
  1053. overflow: hidden;
  1054. }
  1055. .executor {
  1056. font-size: 14px;
  1057. .col {
  1058. color: #6e6e6e;
  1059. padding-right: 10px;
  1060. }
  1061. }
  1062. .result {
  1063. justify-content: space-around;
  1064. }
  1065. .mr20 {
  1066. margin-right: 20px;
  1067. }
  1068. .details {
  1069. font-size: 14px;
  1070. margin-bottom: 10px;
  1071. }
  1072. .customSteps {
  1073. margin-top: 40px;
  1074. font-size: 14px;
  1075. margin-left: 80px;
  1076. .time {
  1077. font-size: 12px;
  1078. color: #6e6e6e;
  1079. margin-right: 20px;
  1080. position: relative;
  1081. &::after {
  1082. content: '';
  1083. width: 1px;
  1084. height: 100%;
  1085. background-color: #157a2c;
  1086. position: absolute;
  1087. right: -26px;
  1088. }
  1089. }
  1090. .flex:last-child {
  1091. .time {
  1092. &::after {
  1093. display: none;
  1094. }
  1095. }
  1096. }
  1097. .round {
  1098. margin-right: 20px;
  1099. width: 10px;
  1100. height: 10px;
  1101. border-radius: 100%;
  1102. background-color: #157a2c;
  1103. position: relative;
  1104. span {
  1105. position: absolute;
  1106. top: 50%;
  1107. left: 50%;
  1108. width: 4px;
  1109. height: 4px;
  1110. background-color: #fff;
  1111. border-radius: 100%;
  1112. transform: translate(-2px, -2px);
  1113. }
  1114. }
  1115. .text {
  1116. .info {
  1117. margin-top: 10px;
  1118. width: 955px;
  1119. background-color: #f0f3f3;
  1120. overflow: hidden;
  1121. padding: 10px;
  1122. margin-bottom: 10px;
  1123. }
  1124. }
  1125. }
  1126. .switch_left li {
  1127. border-right: 1px solid rgba(222, 222, 222, 1);
  1128. border-left: 1px solid rgba(222, 222, 222, 1);
  1129. }
  1130. </style>