newPackingBomDetails.vue 36 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285
  1. <template>
  2. <view>
  3. <view>
  4. <view class="col userInp" style="display: flex; align-items: center">
  5. <text class="label lable150 rx-cc">是否拆包</text>
  6. <text
  7. v-if="objData.packInfo.isUnpack == '1'"
  8. style="color: green; font-size: 12px; margin-left: 15px"
  9. >是</text
  10. >
  11. <text
  12. style="color: green; font-size: 12px; margin-left: 15px"
  13. v-if="objData.packInfo.isNewUnpack == '1'"
  14. >手动拆包</text
  15. >
  16. <text v-else style="color: green; font-size: 12px; margin-left: 15px"
  17. >否</text
  18. >
  19. </view>
  20. </view>
  21. <view
  22. v-if="
  23. warehouseId != 1 &&
  24. objData.packInfo.isUnpack == '1' &&
  25. objData.packInfo.isNewUnpack != 1
  26. "
  27. >
  28. <view class="title_box rx-bc">
  29. <view class="name">包装信息</view>
  30. </view>
  31. <view class="col userInp" style="display: flex; align-items: center">
  32. <text class="label lable150 rx-cc">规格选择:</text>
  33. <!-- multiple -->
  34. <view>{{ objData.packInfo ? objData.packInfo.specText : "" }}</view>
  35. </view>
  36. <view class="col userInp" style="display: flex; align-items: center">
  37. <text class="label lable150 rx-cc">包装选择:</text>
  38. <!-- multiple -->
  39. <zxz-uni-data-select
  40. :localdata="warehouseSpecTypeList"
  41. v-model="warehouseId"
  42. @change="changeWarehouseType"
  43. disabled
  44. ></zxz-uni-data-select>
  45. </view>
  46. <view v-if="warehouseId != 1">
  47. <view v-for="(item, i) in DispositionList" :key="i">
  48. <view class="title_box rx-bc">
  49. <!-- 最小包装单元 -->
  50. <view class="name">{{ item.titel }}</view>
  51. <!-- <view class="btn_box rx-bc" @click="handCancelPacking">
  52. 重置打包
  53. </view> -->
  54. </view>
  55. <view class="material">
  56. <view class="content_table">
  57. <view class="item">
  58. <view class="lable rx-cc">包装总数 </view>
  59. <view class="content content_num">
  60. <input
  61. class="uni-input"
  62. v-model="formedNumLast"
  63. type="number"
  64. disabled
  65. @input="changeinput"
  66. />
  67. <view class="unit">{{ item.packageUnit }}</view>
  68. </view>
  69. </view>
  70. <view class="item rx-sc">
  71. <view class="rx ww55">
  72. <view class="lable lable150 rx-cc">{{ item.titel }}单元</view>
  73. <view class="content content_num">
  74. <input
  75. class="uni-input"
  76. v-model="item.packageCell"
  77. disabled
  78. />
  79. <view style="max-width: 100rpx; font-size: 24rpx">{{
  80. item.packageUnit
  81. }}</view>
  82. </view>
  83. </view>
  84. <view class="rx ww45">
  85. <view class="rx-cc ww80">
  86. /<view style="max-width: 100rpx; font-size: 24rpx">{{
  87. item.conversionUnit
  88. }}</view>
  89. </view>
  90. <view class="content rx-sc">
  91. <!-- <zxz-uni-data-select :localdata="unitList" v-model="unit" dataValue='Key'
  92. format='{Value}' dataKey="Key" filterable :clear='false'></zxz-uni-data-select> -->
  93. <!-- <view class="penalize" @click="handleSplit">确认</view> -->
  94. </view>
  95. </view>
  96. </view>
  97. </view>
  98. <view class="content_table2" v-if="item.splitList.length">
  99. <view class="head row rx-sc">
  100. <view class="item ww10">序号</view>
  101. <view class="item ww15">数量</view>
  102. <view class="item ww20">类型</view>
  103. <view class="item ww20">包装层级</view>
  104. <!-- <view class="item ww20">计量数</view> -->
  105. <view class="item ww40">包装编码</view>
  106. <!-- <view class="item ww10 jsColor" @click="calculation()" v-if="clientEnvironmentId != 3">计算</view>
  107. <view class="item ww10" v-if="clientEnvironmentId == 3"></view> -->
  108. </view>
  109. <view class="table">
  110. <u-list
  111. @scrolltolower="scrolltolower"
  112. class="z_list"
  113. style="height: 100% !important"
  114. >
  115. <view
  116. class="tr row rx-sc"
  117. v-for="(it, idx) in item.splitList"
  118. :key="idx"
  119. >
  120. <view class="item ww10 rx-cc">{{ idx + 1 }}</view>
  121. <view class="item ww15 rx-sc">
  122. <view> {{ it.feedQuantity }}</view>
  123. </view>
  124. <view class="item ww20 rx-sc">
  125. <view v-if="it.rootCategoryLevelId == 2">在制品</view>
  126. <view v-else-if="it.rootCategoryLevelId == 23"
  127. >半成品</view
  128. >
  129. <view v-else-if="it.rootCategoryLevelId == 9">产品</view>
  130. <view v-else-if="it.rootCategoryLevelId == 28">废品</view>
  131. <view v-else>{{ "" }}</view>
  132. </view>
  133. <view class="item ww20 rx-cc">
  134. <view v-if="it.packingType == 4">外包装</view>
  135. <view v-else-if="it.packingType == 2">最小包装</view>
  136. <view v-else-if="it.packingType == 3">内包装</view>
  137. <view v-else>计量</view>
  138. </view>
  139. <view class="item ww40">
  140. {{ it.packingCode }}
  141. </view>
  142. </view>
  143. </u-list>
  144. </view>
  145. </view>
  146. </view>
  147. </view>
  148. </view>
  149. </view>
  150. <view v-if="warehouseId != 1 && objData.packInfo.isNewUnpack == 1">
  151. <view class="title_box rx-bc">
  152. <view class="name">包装信息</view>
  153. </view>
  154. <view class="col userInp" style="display: flex; align-items: center">
  155. <text class="label lable150 rx-cc">规格选择:</text>
  156. <!-- multiple -->
  157. <text style="font-size: 12px; margin-left: 15px">
  158. {{ objData.packInfo ? objData.packInfo.specText : "" }}</text
  159. >
  160. </view>
  161. <view v-if="warehouseId != 1">
  162. <view v-for="(item, i) in DispositionList" :key="i">
  163. <view class="material">
  164. <view class="content_table">
  165. <view class="item">
  166. <view class="lable rx-cc">总数</view>
  167. <view class="content content_num">
  168. <span>{{ item.formedNumLast }}</span>
  169. <view class="unit">{{ item.packageUnit }}</view>
  170. </view>
  171. </view>
  172. </view>
  173. </view>
  174. <view class="title_box rx-bc">
  175. <view class="name">最小包装</view>
  176. </view>
  177. <view class="material">
  178. <view class="content_table">
  179. <view class="item">
  180. <view class="lable rx-cc lable150">包装总数 </view>
  181. <view class="content content_num">
  182. <span>{{ item.minimumFormedNumLast }}</span>
  183. <view class="unit">{{ item.minimumConversionUnit }}</view>
  184. </view>
  185. </view>
  186. <view class="item rx-sc">
  187. <view class="rx ww55">
  188. <view class="lable lable150 rx-cc">最小包装单元</view>
  189. <view class="content content_num">
  190. <span>{{ item.minimumPackageCell }}</span>
  191. <view class="unit">{{ item.minimumPackageUnit }}</view>
  192. /
  193. <view class="unit">{{ item.minimumConversionUnit }}</view>
  194. </view>
  195. </view>
  196. </view>
  197. </view>
  198. <view class="title_box rx-bc">
  199. <view class="name">内包装</view>
  200. </view>
  201. <view class="content_table">
  202. <view class="item">
  203. <view class="lable rx-cc lable150">包装总数 </view>
  204. <view class="content content_num">
  205. <span>{{ item.withinFormedNumLast }}</span>
  206. <view class="unit">{{ item.withinConversionUnit }}</view>
  207. </view>
  208. </view>
  209. <view class="item rx-sc">
  210. <view class="rx ww55">
  211. <view class="lable lable150 rx-cc">内包装单元</view>
  212. <view class="content content_num">
  213. <span>{{ item.withinPackageCell }}</span>
  214. <view class="unit">{{ item.withinPackageUnit }}</view>
  215. /
  216. <view class="unit">{{ item.withinConversionUnit }}</view>
  217. </view>
  218. </view>
  219. </view>
  220. </view>
  221. <view class="title_box rx-bc">
  222. <view class="name">外包装</view>
  223. </view>
  224. <view class="content_table">
  225. <view class="item">
  226. <view class="lable rx-cc lable150">包装总数 </view>
  227. <view class="content content_num">
  228. <span>{{ item.outsideFormedNumLast }}</span>
  229. <view class="unit">{{ item.outsideConversionUnit }}</view>
  230. </view>
  231. </view>
  232. <view class="item rx-sc">
  233. <view class="rx ww55">
  234. <view class="lable lable150 rx-cc">外包装单元</view>
  235. <view class="content content_num">
  236. <span>{{ item.outsidePackageCell }}</span>
  237. <view class="unit">{{ item.outsidePackageUnit }}</view>
  238. /
  239. <view class="unit">{{ item.outsideConversionUnit }}</view>
  240. </view>
  241. </view>
  242. </view>
  243. </view>
  244. <view class="content_table2" v-if="item.splitList.length">
  245. <view class="head row rx-sc">
  246. <view class="item ww10">序号</view>
  247. <view class="item ww15">数量</view>
  248. <view class="item ww20">类型</view>
  249. <view class="item ww20">包装规格</view>
  250. <!-- <view class="item ww20">计量数</view> -->
  251. <view class="item ww40">包装编码</view>
  252. <!-- <view class="item ww10 jsColor" @click="calculation()" v-if="clientEnvironmentId != 3">计算</view>
  253. <view class="item ww10" v-if="clientEnvironmentId == 3"></view> -->
  254. </view>
  255. <view class="table">
  256. <u-list
  257. @scrolltolower="scrolltolower"
  258. class="z_list"
  259. style="height: 100% !important"
  260. >
  261. <view
  262. class="tr row rx-sc"
  263. v-for="(it, idx) in item.splitList"
  264. :key="idx"
  265. >
  266. <view class="item ww10 rx-cc">{{ idx + 1 }}</view>
  267. <view class="item ww15 rx-sc">
  268. <view> {{ it.feedQuantity }}</view>
  269. </view>
  270. <view class="item ww20 rx-sc">
  271. <view v-if="it.rootCategoryLevelId == 2">在制品</view>
  272. <view v-else-if="it.rootCategoryLevelId == 23"
  273. >半成品</view
  274. >
  275. <view v-else-if="it.rootCategoryLevelId == 9">产品</view>
  276. <view v-else-if="it.rootCategoryLevelId == 28">废品</view>
  277. <view v-else>{{ "" }}</view>
  278. </view>
  279. <view class="item ww20 rx-cc">
  280. <view>{{ it.extInfo.packageDisposition }}</view>
  281. </view>
  282. <view class="item ww40">
  283. {{ it.packingCode }}
  284. </view>
  285. </view>
  286. </u-list>
  287. </view>
  288. </view>
  289. </view>
  290. </view>
  291. </view>
  292. </view>
  293. <SearchPopup mode="center" v-if="show">
  294. <template v-slot:list>
  295. <view class="search_list">
  296. <u-form
  297. labelPosition="left"
  298. :model="formData"
  299. labelWidth="180"
  300. labelAlign="left"
  301. class="baseForm"
  302. >
  303. <u-form-item
  304. label="外包装数:"
  305. class="required-form"
  306. borderBottom
  307. prop="assetType"
  308. >
  309. <input
  310. class="uni-input"
  311. v-model="formData.wPackNum"
  312. style="width: 280rpx"
  313. placeholder="外包装数"
  314. />
  315. / {{ splitList[0].unit }}
  316. </u-form-item>
  317. </u-form>
  318. </view>
  319. </template>
  320. <template v-slot:operate>
  321. <view class="operate_box rx-bc">
  322. <u-button
  323. size="small"
  324. class="u-reset-button"
  325. @click="calculationClose()"
  326. >
  327. 取消
  328. </u-button>
  329. <u-button
  330. type="success"
  331. size="small"
  332. class="u-reset-button"
  333. @click="calculationReset()"
  334. >
  335. 重置
  336. </u-button>
  337. <u-button
  338. type="success"
  339. size="small"
  340. class="u-reset-button"
  341. @click="calculationSave()"
  342. >
  343. 确定
  344. </u-button>
  345. </view>
  346. </template>
  347. </SearchPopup>
  348. </view>
  349. </template>
  350. <script>
  351. import { getByCode } from "@/api/pda/common.js";
  352. import {
  353. cancelPacking,
  354. packingReport,
  355. getPackingReport,
  356. packingReportRepeat,
  357. packageDisposition,
  358. getPackingReportRepeat,
  359. getPackingList,
  360. } from "@/api/pda/workOrder.js";
  361. import SearchPopup from "../../components/searchPopup.vue";
  362. export default {
  363. components: {
  364. SearchPopup,
  365. },
  366. props: {
  367. categoryId: {
  368. type: String,
  369. default: "",
  370. },
  371. objData: {
  372. type: Object,
  373. default: () => {},
  374. },
  375. taskId: {
  376. type: String,
  377. default: "",
  378. },
  379. workOrderId: {
  380. type: String,
  381. default: "",
  382. },
  383. },
  384. data() {
  385. return {
  386. formedNumLast: 0,
  387. quantity: "",
  388. unit: "",
  389. Usertype: "", // 规格
  390. unitList: [],
  391. resObj: {},
  392. splitList: [],
  393. localdataList: [],
  394. newDispositionList: [],
  395. withinQuantity: "", //内包装数量
  396. withinUnit: "", //内包装单位
  397. outsideQuantity: "", //外包装数量
  398. outsideUnit: "", //外包装单位
  399. timeout: null,
  400. packUnit: null,
  401. temporaryNum: 0,
  402. temporaryCount: 0,
  403. temporaryList: [],
  404. packTwoList: [],
  405. DispositionList: [],
  406. selectList: [],
  407. text: "",
  408. value: "",
  409. minimumPackage: [], // 最小包装
  410. withinPackage: [], // 内包装
  411. minimumUnit: "",
  412. outsidePackage: [], //外包装
  413. newCategoryId: "",
  414. warehouseId: 2,
  415. warehouseSpecTypeList: [
  416. {
  417. text: "按计量",
  418. value: 1,
  419. },
  420. {
  421. text: "最小包装",
  422. value: 2,
  423. },
  424. {
  425. text: "内包装",
  426. value: 3,
  427. },
  428. {
  429. text: "外包装",
  430. value: 4,
  431. },
  432. ],
  433. show: false,
  434. formData: {
  435. wPackNum: null,
  436. },
  437. clientEnvironmentId:
  438. uni.getStorageSync("userInfo") &&
  439. uni.getStorageSync("userInfo").clientEnvironmentId,
  440. };
  441. },
  442. created() {
  443. // this.formedNumLast = this.objData.product[0].feedQuantity;
  444. console.log(this.objData, "我是阿打啥啊电话");
  445. // this.byCode();
  446. // this.packageDispositionFn();
  447. if (this.objData.packInfo) {
  448. this.warehouseId = this.objData.packInfo.tier;
  449. if (this.objData.packInfo.isUnpack == "1") {
  450. this.DispositionList.push({
  451. titel: "最小包装",
  452. splitList: this.objData.packInfo.minimumPackage,
  453. packageCell: this.objData.packInfo.minimumPackageCell,
  454. packageUnit: this.objData.packInfo.minimumPackageUnit,
  455. conversionUnit: this.objData.packInfo.minimumConversionUnit,
  456. });
  457. } else if (this.objData.packInfo.isNewUnpack == 1) {
  458. this.DispositionList.push({
  459. titel: "",
  460. splitList:
  461. this.objData.packInfo.minimumPackage.length != 0
  462. ? this.objData.packInfo.minimumPackage
  463. : this.objData.packInfo.withinPackage.length != 0
  464. ? this.objData.packInfo.withinPackage
  465. : this.objData.packInfo.outsidePackage.length != 0
  466. ? this.objData.packInfo.outsidePackage
  467. : [],
  468. minimumPackageCell: this.objData.packInfo.minimumPackageCell,
  469. minimumPackageUnit: this.objData.packInfo.minimumPackageUnit,
  470. minimumConversionUnit: this.objData.packInfo.minimumConversionUnit,
  471. minimumFormedNumLast: this.objData.packInfo.minimumFormedNumLast,
  472. withinPackageCell: this.objData.packInfo.withinPackageCell,
  473. withinPackageUnit: this.objData.packInfo.withinPackageUnit,
  474. withinConversionUnit: this.objData.packInfo.withinConversionUnit,
  475. withinFormedNumLast: this.objData.packInfo.withinFormedNumLast,
  476. outsidePackageCell: this.objData.packInfo.outsidePackageCell,
  477. outsidePackageUnit: this.objData.packInfo.outsidePackageUnit,
  478. outsideConversionUnit: this.objData.packInfo.outsideConversionUnit,
  479. outsideFormedNumLast: this.objData.packInfo.outsideFormedNumLast,
  480. formedNumLast: this.objData.formingNum,
  481. packageUnit: this.objData.unit,
  482. });
  483. }
  484. // this.formedNumLast = this.objData.packInfo.minimumPackage.reduce(
  485. // (acc, pro) => {
  486. // return pro.feedQuantity ? acc + Number(pro.feedQuantity) : acc;
  487. // },
  488. // 0
  489. // );
  490. }
  491. if (this.objData.product && this.objData.product.length != 0) {
  492. this.formedNumLast = this.objData.product.reduce((acc, pro) => {
  493. return pro.feedQuantity ? acc + Number(pro.feedQuantity) : acc;
  494. }, 0);
  495. }
  496. if (
  497. this.objData.semiProductList &&
  498. this.objData.semiProductList.length != 0
  499. ) {
  500. this.formedNumLast = this.objData.semiProductList.reduce((acc, pro) => {
  501. return pro.feedQuantity ? acc + Number(pro.feedQuantity) : acc;
  502. }, 0);
  503. }
  504. // this.getPackingDetails()
  505. // this.getPackingDetailsTwo()
  506. },
  507. methods: {
  508. // 输入数量变化
  509. changeinput(e) {
  510. clearTimeout(this.timeout);
  511. // 设置新的定时器
  512. this.timeout = setTimeout(() => {
  513. this.formedNumLast = e.detail.value;
  514. this.initFn(this.selectList);
  515. }, 500); // 500毫秒后触发
  516. },
  517. changeUserType(e) {
  518. console.log(e);
  519. this.text = e.text;
  520. this.value = e.value;
  521. this.selectList = e.arr;
  522. this.initFn(e.arr);
  523. },
  524. groupBy(arr, key) {
  525. return arr.reduce((acc, obj) => {
  526. const groupKey = obj[key];
  527. if (!acc[groupKey]) {
  528. acc[groupKey] = [];
  529. }
  530. console.log();
  531. acc[groupKey].push(obj);
  532. return acc;
  533. }, {});
  534. },
  535. async packageDispositionFn() {
  536. console.log(this.categoryId, "555555555555");
  537. let that = this;
  538. const res = await packageDisposition(this.categoryId);
  539. if (res.length) {
  540. res.shift();
  541. let data = JSON.parse(JSON.stringify(res));
  542. let list = this.groupBy(data, "code");
  543. this.localdataList = [];
  544. Object.entries(list).forEach(([key, value]) => {
  545. let obj = {
  546. text: value[0].name,
  547. arr: value,
  548. value: key,
  549. };
  550. this.localdataList.push(obj);
  551. });
  552. this.Usertype = this.localdataList[0].value;
  553. this.text = this.localdataList[0].text;
  554. this.value = this.localdataList[0].value;
  555. // res.map((v) => {
  556. // v.splitList = [];
  557. // });
  558. // // this.newDispositionList = res;
  559. // if (this.warehouseId == 2) {
  560. // this.newDispositionList = [res[0]];
  561. // } else if (this.warehouseId == 3) {
  562. // this.newDispositionList = [res[1]];
  563. // } else if (this.warehouseId == 4) {
  564. // this.newDispositionList = [res[2]];
  565. // }
  566. // this.selectList = res;
  567. // this.initFn(this.localdataList[0].arr);
  568. // this.listFn(this.localdataList[0].arr);
  569. }
  570. },
  571. initFn(v) {
  572. if (v.length) {
  573. this.withinQuantity = v[1].packageCell; //内包装数量
  574. this.withinUnit = v[1].conversionUnit; //内包装单位
  575. this.outsideQuantity = v[2].packageCell; //外包装数量
  576. this.outsideUnit = v[2].conversionUnit; //外包装单位
  577. this.minimumUnit = v[0].conversionUnit;
  578. }
  579. console.log("几次", v);
  580. this.handleSplit(v[0]);
  581. },
  582. async listFn(res) {
  583. let {
  584. minimumPackage,
  585. withinQuantity,
  586. outsidePackage,
  587. outsideQuantity,
  588. withinPackage,
  589. } = res;
  590. // let textList = ["最小包装", "内包装", "外包装"];
  591. // let arr = [
  592. // { list: minimumPackage },
  593. // { list: withinPackage, num: withinQuantity },
  594. // { list: outsidePackage, num: outsideQuantity },
  595. // ];
  596. let textList = [];
  597. let arr = [];
  598. if (this.warehouseId == 2) {
  599. textList.push("最小包装");
  600. arr.push({ list: minimumPackage });
  601. } else if (this.warehouseId == 3) {
  602. textList.push("内包装");
  603. arr.push({ list: withinPackage, num: withinQuantity });
  604. } else if (this.warehouseId == 4) {
  605. textList.push("外包装");
  606. arr.push({ list: outsidePackage, num: outsideQuantity });
  607. }
  608. this.minimumPackage = minimumPackage; // 最小包装
  609. this.withinPackage = withinPackage; // 内包装
  610. this.outsidePackage = outsidePackage; //外包装
  611. // this.newDispositionList.map((v, i) => {
  612. // v.splitList = arr[i].list;
  613. // v.titel = textList[i];
  614. // if (i == 0) {
  615. // v.formedNumLast = this.formedNumLast;
  616. // } else {
  617. // v.formedNumLast = arr[i].num;
  618. // }
  619. // });
  620. this.newDispositionList.map((v, i) => {
  621. v.splitList = arr[0].list;
  622. v.titel = textList[0];
  623. if (i == 0) {
  624. v.formedNumLast = this.formedNumLast;
  625. } else {
  626. v.formedNumLast = arr.num;
  627. }
  628. });
  629. this.$nextTick(() => {
  630. console.log(this.DispositionList, "我是啥来着");
  631. this.$set(this, "DispositionList", this.newDispositionList);
  632. });
  633. },
  634. sunNum(v, i) {
  635. let _this = this;
  636. this.$nextTick(() => {
  637. switch (i) {
  638. case 0:
  639. console.log(_this.formedNumLast);
  640. return _this.formedNumLast;
  641. case 1:
  642. return v.splitList.length || 0;
  643. case 2:
  644. return v.splitList.length || 0;
  645. }
  646. });
  647. },
  648. byCode() {
  649. getByCode("packing_unit").then((res) => {
  650. this.unitList = [];
  651. res.forEach((obj, index) => {
  652. for (let key in obj) {
  653. if (obj.hasOwnProperty(key)) {
  654. // 确保key是对象自身的属性
  655. this.unitList.push({
  656. Key: `${key}`,
  657. Value: ` ${obj[key]}`,
  658. });
  659. }
  660. }
  661. });
  662. });
  663. },
  664. getPackingDetails() {
  665. let param = {
  666. workOrderId: this.workOrderId,
  667. taskId: this.taskId,
  668. tier: 1,
  669. };
  670. getPackingReport(param).then((res) => {
  671. this.splitList = res.detailList;
  672. this.formedNumLast = res.totalQuantity;
  673. this.quantity = res.quantity;
  674. this.unit = res.unit;
  675. });
  676. },
  677. handCancelPacking() {
  678. uni.showModal({
  679. title: `是否清空包装?`,
  680. content: "",
  681. confirmText: "确认",
  682. success: () => {
  683. let param = {
  684. workOrderId: this.workOrderId,
  685. taskId: this.taskId,
  686. };
  687. cancelPacking(param).then((res) => {
  688. this.getPackingDetails();
  689. this.getPackingDetailsTwo();
  690. });
  691. },
  692. });
  693. },
  694. // 第一次调用
  695. handleSplit(v) {
  696. if (this.splitList.length) {
  697. uni.showToast({
  698. title: "产品已分包",
  699. icon: "none",
  700. });
  701. return false;
  702. }
  703. // if (!this.formedNumLast) {
  704. // uni.showToast({
  705. // title: '包装总数数量不能为空',
  706. // icon: 'none'
  707. // })
  708. // return false
  709. // }
  710. if (!v.packageCell) {
  711. uni.showToast({
  712. title: "内包装单元数量不能为空",
  713. icon: "none",
  714. });
  715. return false;
  716. }
  717. if (!v.packageUnit) {
  718. uni.showToast({
  719. title: "请选择包装单位",
  720. icon: "none",
  721. });
  722. return false;
  723. }
  724. let param = {
  725. workOrderId: this.workOrderId, //工单id
  726. taskId: this.taskId,
  727. tier: this.warehouseId,
  728. totalQuantity: this.formedNumLast, //总数量
  729. quantity: v.packageCell, //数量
  730. unit: v.packageUnit, //单位
  731. minimumUnit: this.minimumUnit, //最小包装单位
  732. withinQuantity: this.withinQuantity, //内包装数量
  733. withinUnit: this.withinUnit, //内包装单位
  734. outsideQuantity: this.outsideQuantity, //外包装数量
  735. outsideUnit: this.outsideUnit, //外包装单位
  736. packageUnit: v.conversionUnit,
  737. };
  738. // packingReport(param).then((res) => {
  739. // this.listFn(res);
  740. // });
  741. if (this.warehouseId != 1) {
  742. getPackingList(param).then((res) => {
  743. this.listFn(res);
  744. });
  745. }
  746. // getPackingList(param).then((res) => {
  747. // this.listFn(res);
  748. // });
  749. },
  750. handleCheck(idx, it) {
  751. if (it.quantity <= 0) {
  752. uni.showToast({
  753. icon: "none",
  754. title: "数量为空不能勾选",
  755. });
  756. return false;
  757. }
  758. this.$set(this.splitList[idx], "check", it.check ? 0 : 1);
  759. this.temporaryList = [];
  760. this.temporaryList = this.splitList.filter((e) => {
  761. return e.check == 1;
  762. });
  763. this.temporaryNum = 0;
  764. this.temporaryCount = 0;
  765. if (this.temporaryList.length > 0) {
  766. this.temporaryList.forEach((e) => {
  767. this.temporaryNum = this.temporaryNum + 1;
  768. this.temporaryCount = this.temporaryCount + Number(e.quantity);
  769. });
  770. }
  771. },
  772. handclose(it) {
  773. this.splitList.forEach((f) => {
  774. if (f.computeSize == it.computeSize) {
  775. f.check = 0;
  776. }
  777. });
  778. this.temporaryList = [];
  779. this.temporaryList = this.splitList.filter((e) => {
  780. return e.check == 1;
  781. });
  782. },
  783. getPackingDetailsTwo(v) {
  784. console.log(v);
  785. let param = {
  786. totalQuantity: v.formedNumLast,
  787. quantity: v.packageCell,
  788. unit: v.conversionUnit,
  789. workOrderId: this.workOrderId,
  790. taskId: this.taskId,
  791. tier: 2,
  792. };
  793. getPackingReportRepeat(param).then((res) => {
  794. resolve(res.detailList);
  795. });
  796. },
  797. handlePack(v, s) {
  798. let _arr = [];
  799. _arr = s.map((m) => {
  800. return {
  801. ...m,
  802. isChecked: 1,
  803. };
  804. });
  805. console.log(_arr, "123");
  806. let param = {
  807. detailList: _arr,
  808. quantity: v.temporaryCount,
  809. totalQuantity: v.formedNumLast,
  810. unit: v.packageUnit,
  811. taskId: this.taskId,
  812. workOrderId: this.workOrderId,
  813. tier: 2,
  814. };
  815. return new Promise((resolve, reject) => {
  816. packingReportRepeat(param).then((res) => {
  817. console.log(res);
  818. // this.temporaryList = []
  819. this.getPackingDetails();
  820. // this.getPackingDetailsTwo()
  821. });
  822. });
  823. },
  824. scrolltolower() {},
  825. getData() {
  826. let _packingReportMarginList = [];
  827. _packingReportMarginList = this.splitList.filter((e) => {
  828. return !e.parentId;
  829. });
  830. console.log(this.DispositionList);
  831. // let packInfo = {
  832. // this.DispositionList[0]
  833. // specText: this.text,
  834. // specValue: this.value,
  835. // minimumPackage: this.minimumPackage, // 最小包装
  836. // minimumPackageCell: this.DispositionList[0].packageCell, // 最小包装
  837. // minimumPackageUnit: this.DispositionList[0].packageUnit, // 最小包装单位
  838. // minimumConversionUnit: this.DispositionList[0].conversionUnit, // 最小包装单位
  839. // minimumFormedNumLast: this.DispositionList[0].formedNumLast, // 总包装数量
  840. // withinPackage: this.withinPackage, // 内包装
  841. // withinPackageCell: this.DispositionList[1].packageCell, // 最小包装名称
  842. // withinPackageUnit: this.DispositionList[1].packageUnit, // 最小包装单位
  843. // withinConversionUnit: this.DispositionList[1].conversionUnit, // 最小包装单位
  844. // withinFormedNumLast: this.DispositionList[1].formedNumLast, // 总包装数量
  845. // // packingReportList: this.packTwoList,
  846. // // packingReportMarginList: _packingReportMarginList,
  847. // outsidePackage: this.outsidePackage, //外包装
  848. // outsidePackageCell: this.DispositionList[2].packageCell, // 最小包装名称
  849. // outsidePackageUnit: this.DispositionList[2].packageUnit, // 最小包装单位
  850. // outsideConversionUnit: this.DispositionList[2].conversionUnit, // 最小包装单位
  851. // outsideFormedNumLast: this.DispositionList[2].formedNumLast, // 总包装数量
  852. // };
  853. let packInfo = {};
  854. if (this.warehouseId == 2) {
  855. if (this.DispositionList && this.DispositionList.length != 0) {
  856. packInfo = {
  857. // this.DispositionList[0]
  858. specText: this.span,
  859. specValue: this.value,
  860. minimumPackage: this.minimumPackage, // 最小包装
  861. tier: this.warehouseId,
  862. minimumPackageCell: this.DispositionList[0].packageCell, // 最小包装
  863. minimumPackageUnit: this.DispositionList[0].packageUnit, // 最小包装单位
  864. minimumConversionUnit: this.DispositionList[0].conversionUnit, // 最小包装单位
  865. minimumFormedNumLast: this.DispositionList[0].formedNumLast, // 总包装数量
  866. };
  867. } else {
  868. packInfo = {};
  869. }
  870. } else if (this.warehouseId == 3) {
  871. if (this.DispositionList && this.DispositionList.length != 0) {
  872. packInfo = {
  873. withinPackage: this.withinPackage, // 内包装
  874. tier: this.warehouseId,
  875. withinPackageCell: this.DispositionList[0].packageCell, // 最小包装名称
  876. withinPackageUnit: this.DispositionList[0].packageUnit, // 最小包装单位
  877. withinConversionUnit: this.DispositionList[0].conversionUnit, // 最小包装单位
  878. withinFormedNumLast: this.DispositionList[0].formedNumLast,
  879. };
  880. } else {
  881. packInfo = {};
  882. } // 总包装数量
  883. } else if (this.warehouseId == 4) {
  884. if (this.DispositionList && this.DispositionList.length != 0) {
  885. packInfo = {
  886. outsidePackage: this.outsidePackage, //外包装
  887. tier: this.warehouseId,
  888. outsidePackageCell: this.DispositionList[0].packageCell, // 最小包装名称
  889. outsidePackageUnit: this.DispositionList[0].packageUnit, // 最小包装单位
  890. outsideConversionUnit: this.DispositionList[0].conversionUnit, // 最小包装单位
  891. outsideFormedNumLast: this.DispositionList[0].formedNumLast,
  892. }; // 总包装数量
  893. } else {
  894. packInfo = {};
  895. }
  896. }
  897. return packInfo;
  898. },
  899. calculation() {
  900. this.show = true;
  901. },
  902. calculationSave() {
  903. let count = this.splitList.filter((item) => item.isChecked != 1).length;
  904. if (this.formData.wPackNum <= count && count != 0) {
  905. for (let i = 0; i < this.formData.wPackNum; i++) {
  906. this.splitList[i].check = 1;
  907. }
  908. this.handleCheck(0, 0);
  909. this.calculationClose();
  910. } else {
  911. if (count != 0) {
  912. for (let i = 0; i < count; i++) {
  913. this.splitList[i].check = 1;
  914. }
  915. this.handleCheck(0, 0);
  916. this.calculationClose();
  917. }
  918. uni.showToast({
  919. icon: "none",
  920. title: "外包装数超出内包装条数",
  921. });
  922. }
  923. },
  924. calculationClose() {
  925. this.show = false;
  926. },
  927. calculationReset() {
  928. this.formData.wPackNum = null;
  929. this.splitList.forEach((f) => {
  930. f.check = null;
  931. });
  932. this.temporaryList = [];
  933. this.show = false;
  934. },
  935. changeWarehouseType() {
  936. this.packageDispositionFn();
  937. },
  938. },
  939. };
  940. </script>
  941. <style lang="scss" scoped>
  942. .title_box {
  943. margin-top: 20rpx;
  944. .ww20 {
  945. width: 20%;
  946. }
  947. .name {
  948. font-size: 28rpx;
  949. font-style: normal;
  950. font-weight: 400;
  951. color: $theme-color;
  952. padding-left: 20rpx;
  953. position: relative;
  954. &:before {
  955. position: absolute;
  956. content: "";
  957. left: 0rpx;
  958. top: 0rpx;
  959. bottom: 0rpx;
  960. width: 4rpx;
  961. height: 28rpx;
  962. background: $theme-color;
  963. margin: auto;
  964. }
  965. }
  966. .btn_box {
  967. color: $theme-color;
  968. }
  969. }
  970. .material {
  971. margin-top: 10rpx;
  972. .content_table {
  973. width: 100%;
  974. border: 2rpx solid $border-color;
  975. .item {
  976. display: flex;
  977. border-bottom: 2rpx solid $border-color;
  978. .lable {
  979. width: 132rpx;
  980. text-align: center;
  981. background-color: #f7f9fa;
  982. font-size: 26rpx;
  983. border-right: 2rpx solid $border-color;
  984. flex-shrink: 0;
  985. }
  986. .lable220 {
  987. width: 220rpx !important;
  988. font-size: 24rpx;
  989. }
  990. .lable150 {
  991. width: 156rpx !important;
  992. font-size: 24rpx;
  993. }
  994. .ww80 {
  995. width: 80rpx;
  996. }
  997. .content {
  998. width: 518rpx;
  999. min-height: 64rpx;
  1000. font-size: 28rpx;
  1001. line-height: 28rpx;
  1002. font-style: normal;
  1003. font-weight: 400;
  1004. // padding: 18rpx 8rpx;
  1005. box-sizing: border-box;
  1006. word-wrap: break-word;
  1007. flex-grow: 1 !important;
  1008. .unit {
  1009. padding: 0 4rpx;
  1010. font-size: 24rpx;
  1011. color: #404446;
  1012. }
  1013. }
  1014. &:last-child {
  1015. border-bottom: none;
  1016. }
  1017. }
  1018. .ww55 {
  1019. width: 55%;
  1020. }
  1021. .ww45 {
  1022. width: 45%;
  1023. }
  1024. }
  1025. }
  1026. .content_table2 {
  1027. width: 100%;
  1028. margin-top: 16rpx;
  1029. .row {
  1030. width: 100%;
  1031. .item {
  1032. color: #404446;
  1033. font-size: 28rpx;
  1034. padding-left: 12rpx;
  1035. }
  1036. .color157 {
  1037. color: $theme-color;
  1038. }
  1039. .ww30 {
  1040. width: 30%;
  1041. }
  1042. .ww50 {
  1043. width: 50%;
  1044. }
  1045. .ww90 {
  1046. width: 90%;
  1047. }
  1048. .ww15 {
  1049. width: 15%;
  1050. }
  1051. .ww10 {
  1052. width: 10%;
  1053. }
  1054. .ww30 {
  1055. width: 30%;
  1056. }
  1057. .ww20 {
  1058. width: 20%;
  1059. }
  1060. .ww40 {
  1061. width: 40%;
  1062. }
  1063. .jsColor {
  1064. color: $theme-color;
  1065. font-size: 20rpx;
  1066. }
  1067. }
  1068. .head {
  1069. height: 64rpx;
  1070. background: #f7f9fa;
  1071. border-top: 2rpx solid #e3e5e5;
  1072. border-left: 2rpx solid #e3e5e5;
  1073. .item {
  1074. height: 64rpx;
  1075. line-height: 64rpx;
  1076. border-right: 2rpx solid #e3e5e5;
  1077. box-sizing: border-box;
  1078. }
  1079. }
  1080. .tr {
  1081. border-top: 2rpx solid #e3e5e5;
  1082. border-left: 2rpx solid #e3e5e5;
  1083. .item {
  1084. font-size: 24rpx;
  1085. min-height: 64rpx;
  1086. display: flex;
  1087. align-items: center;
  1088. border-right: 2rpx solid #e3e5e5;
  1089. box-sizing: border-box;
  1090. white-space: normal;
  1091. word-break: break-all;
  1092. }
  1093. &:last-child {
  1094. border-bottom: 2rpx solid #e3e5e5;
  1095. }
  1096. }
  1097. }
  1098. .label {
  1099. display: flex;
  1100. height: 70rpx;
  1101. width: 86px !important;
  1102. font-size: 13px;
  1103. align-items: center;
  1104. justify-content: center;
  1105. background-color: #f7f9fa;
  1106. }
  1107. .content_num {
  1108. display: flex;
  1109. align-items: center;
  1110. padding: 0 4rpx;
  1111. /deep/ .uni-input-input {
  1112. border: 2rpx solid #f0f8f2;
  1113. background: #f0f8f2;
  1114. color: $theme-color;
  1115. }
  1116. }
  1117. .penalize {
  1118. width: 86rpx;
  1119. line-height: 60rpx;
  1120. background: $theme-color;
  1121. font-size: 24rpx;
  1122. text-align: center;
  1123. color: #fff;
  1124. }
  1125. .check {
  1126. width: 30rpx;
  1127. height: 30rpx;
  1128. }
  1129. .z_list {
  1130. max-height: 500rpx;
  1131. }
  1132. .search_list {
  1133. min-height: 100rpx;
  1134. width: 80vw;
  1135. /deep/ .baseForm {
  1136. padding: 0 20rpx;
  1137. }
  1138. }
  1139. .operate_box {
  1140. padding: 10rpx 32rpx;
  1141. /deep/ .u-button {
  1142. width: 30%;
  1143. }
  1144. }
  1145. </style>