details.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711
  1. <template>
  2. <view class="content-box">
  3. <uni-nav-bar fixed="true" statusBar="true" left-icon="back" :title="title" background-color="#F7F9FA"
  4. color="#000" @clickLeft="back" right-icon="scan" @clickRight="handlScanCode"></uni-nav-bar>
  5. <view class="list_box">
  6. <u-list @scrolltolower="scrolltolower">
  7. <view v-for="(item,index) in List" :key="index" class="card_box">
  8. <workOrderBom :item='item' @handleScan='handleScan'></workOrderBom>
  9. <paramBom v-if='item.paramDetailList.length != 0' :list='item.paramDetailList'></paramBom>
  10. <deviceBom v-if='item.equipmentList.length != 0' :workOrderId='item.workOrderId'
  11. :list='item.equipmentList' @scanIt='scanIt'></deviceBom>
  12. <productsBom v-if="item.product != null && item.product != '{}'" :productsObj="item.product">
  13. </productsBom>
  14. <modelBom v-if='item.modelList.length != 0' :workOrderId='item.workOrderId' :list='item.modelList'
  15. @scanIt='scanIt'>
  16. </modelBom>
  17. <instanceBom v-if='item.instanceList.length != 0' :workOrderId='item.workOrderId'
  18. :list='item.instanceList' :equipmentList="item.equipmentList"
  19. :currentTaskDiagram="item.currentTaskDiagram"></instanceBom>
  20. <semiProductBom v-if='item.semiProductList.length != 0' :workOrderId='item.workOrderId'
  21. :list='item.semiProductList' :equipmentList="item.equipmentList"
  22. :currentTaskDiagram="item.currentTaskDiagram"></semiProductBom>
  23. <turnoverBom v-if='item.turnover.length != 0' :list='item.turnover' :wordItem='item' pattern='feed'
  24. @handleScan='handleScan' @handleDel='handleDel'></turnoverBom>
  25. <aridRegion v-if='item.aridRegionList.length != 0' :list='item.aridRegionList'
  26. @handleScan='handleScan'></aridRegion>
  27. <palletBom v-if='item.palletList.length != 0' :palletList='item.palletList'></palletBom>
  28. <revolvingDiskBom v-if="item.revolvingDiskList.length != 0"
  29. :revolvingDiskList="item.revolvingDiskList"></revolvingDiskBom>
  30. <packingBom v-if='item.packingList.length != 0' :list='item.packingList'></packingBom>
  31. <view class='flex_btn' @click="openDetails(item.workOrderId)">出库单</view>
  32. <view :class="[ idsList.length == 1 ? 'operate_box' :'operate_box2'] ">
  33. <u-button size="small" class="u-reset-button" type="success"
  34. @click="handAdd(item.workOrderId)">手动添加</u-button>
  35. <u-button size="small" class="u-reset-button" type="success"
  36. @click="scanIt(item.workOrderId)">扫一扫</u-button>
  37. </view>
  38. </view>
  39. </u-list>
  40. </view>
  41. <view class="bottom-wrapper">
  42. <view class="btn_box" @click="save(1)">缓存</view>
  43. <view class="btn_box" @click="save(2)">一键投料</view>
  44. </view>
  45. </view>
  46. </template>
  47. <script>
  48. import workOrderBom from './components/workOrderBom.vue'
  49. import deviceBom from './components/deviceBom.vue'
  50. import modelBom from './components/modelBom.vue'
  51. import instanceBom from './components/instanceBom.vue'
  52. import semiProductBom from './components/semiProductBom'
  53. import aridRegion from './components/aridRegion'
  54. import paramBom from './components/paramBom.vue'
  55. import turnoverBom from './components/turnoverBom.vue'
  56. import packingBom from './components/packingBom.vue'
  57. import productsBom from './components/productsBom.vue'
  58. import palletBom from './components/palletBom'
  59. import revolvingDiskBom from './components/revolvingDiskBom'
  60. import {
  61. workorderList,
  62. getByCode,
  63. scanLedger,
  64. feedSaveCache,
  65. feedGetCache
  66. } from '@/api/pda/workOrder.js'
  67. import {
  68. batchSave
  69. } from '@/api/pda/feeding.js'
  70. export default {
  71. components: {
  72. workOrderBom,
  73. deviceBom,
  74. modelBom,
  75. instanceBom,
  76. semiProductBom,
  77. aridRegion,
  78. paramBom,
  79. turnoverBom,
  80. packingBom,
  81. productsBom,
  82. palletBom,
  83. revolvingDiskBom,
  84. },
  85. data() {
  86. return {
  87. title: '',
  88. idsList: [],
  89. List: [],
  90. taskId: null,
  91. clientEnvironmentId: null,
  92. }
  93. },
  94. onLoad(options) {
  95. this.title = options.taskName ? options.taskName + '-投料' : '投料'
  96. let queryArray = decodeURIComponent(options.arr);
  97. this.idsList = JSON.parse(queryArray);
  98. this.taskId = options.taskId
  99. this.taskName = options.taskName
  100. this.getList()
  101. this.clientEnvironmentId = uni.getStorageSync("userInfo") && uni.getStorageSync("userInfo").clientEnvironmentId
  102. },
  103. onShow() {
  104. uni.$off("setSelectList");
  105. uni.$on("setSelectList", (selectList, id) => {
  106. this.List.forEach(m => {
  107. if (m.workOrderId == id) {
  108. let modelList = [] // 模具
  109. let instanceList = [] // 投料
  110. let aridRegionList = [] // 干燥区
  111. let equipmentList = [] // 生产设备
  112. let palletList = [] // 舟皿
  113. let revolvingDiskList = [] // 周转盘
  114. let semiProductList = [] // 半成品
  115. let turnover = [] //周转车
  116. selectList.forEach(f => {
  117. if (f.rootCategoryLevelId == 4) {
  118. equipmentList = equipmentList.concat(f)
  119. }
  120. if (f.rootCategoryLevelId == 5) {
  121. modelList = modelList.concat(f)
  122. } else if (f.rootCategoryLevelId == 1) {
  123. instanceList = instanceList.concat(f)
  124. } else if (f.rootCategoryLevelId == 11) {
  125. aridRegionList = aridRegionList.concat(f)
  126. } else if (f.rootCategoryLevelId == 7) {
  127. turnover = turnover.concat(f)
  128. } else if (f.rootCategoryLevelId == 8) {
  129. palletList = palletList.concat(f)
  130. } else if (f.rootCategoryLevelId == 26) {
  131. revolvingDiskList = revolvingDiskList.concat(f)
  132. } else if ([23, 2, 9, 28].includes(Number(f.rootCategoryLevelId))) {
  133. semiProductList = semiProductList.concat(f)
  134. }
  135. })
  136. this.$set(m, 'modelList', modelList)
  137. this.$set(m, 'instanceList', instanceList)
  138. this.$set(m, 'aridRegionList', aridRegionList)
  139. this.$set(m, 'equipmentList', equipmentList)
  140. this.$set(m, 'turnover', turnover)
  141. this.$set(m, 'palletList', palletList)
  142. this.$set(m, 'revolvingDiskList', revolvingDiskList)
  143. this.$set(m, 'semiProductList', semiProductList)
  144. }
  145. })
  146. });
  147. },
  148. methods: {
  149. scrolltolower() {},
  150. async save(type) {
  151. this.List.forEach(f => {
  152. f.instanceList.forEach(e => {
  153. if (Object.prototype.hasOwnProperty.call(e, 'type')) {
  154. e.extInfo['type'] = e.type
  155. }
  156. e.extInfo['isConsumable'] = e.isConsumable
  157. })
  158. })
  159. const isCache = await this.checkCache(type)
  160. if (!isCache) {
  161. return false
  162. }
  163. batchSave(this.List).then(res => {
  164. uni.redirectTo({
  165. url: `/pages/pda/feeding/index/index?feedStatus=1`,
  166. });
  167. })
  168. },
  169. checkCache(type) {
  170. uni.hideLoading();
  171. return new Promise((resolve) => {
  172. if (type == 1) {
  173. feedSaveCache(this.List).then(rr => {
  174. uni.showToast({
  175. title: `已经缓存`,
  176. icon: 'none'
  177. })
  178. })
  179. resolve(false)
  180. } else if (type == 2) {
  181. resolve(true)
  182. }
  183. })
  184. },
  185. getList() {
  186. workorderList({
  187. ids: this.idsList,
  188. taskId: this.taskId
  189. }).then(res => {
  190. this.List = res.map(m => {
  191. m.workOrderId = m.id
  192. m.instanceList = [] // 物料
  193. m.equipmentList = [] // 设备
  194. m.modelList = [] // 模具
  195. m.aridRegionList = [] // 干燥区
  196. m.packingList = [] // 包装
  197. m.palletList = [] // 舟皿
  198. m.revolvingDiskList = [] // 周转盘
  199. m.semiProductList = [] //半成品
  200. if (m.pickOutInList.length > 0) {
  201. m.pickOutInList.forEach(f => {
  202. if (f.rootCategoryLevelId == 1) {
  203. m.instanceList.push(f)
  204. } else if (f.rootCategoryLevelId == 4) {
  205. m.modelList.push(f)
  206. } else if (f.rootCategoryLevelId == 5) {
  207. m.modelList.push(f)
  208. } else if (f.rootCategoryLevelId == 11) {
  209. m.aridRegionList.push(f)
  210. } else if (f.rootCategoryLevelId == 13) {
  211. m.packingList.push(f)
  212. } else if (f.rootCategoryLevelId == 8) {
  213. m.palletList.push(f)
  214. } else if (f.rootCategoryLevelId == 26) {
  215. m.revolvingDiskList.push(f)
  216. } else if ([23, 2, 9, 28].includes(Number(f
  217. .rootCategoryLevelId))) {
  218. m.semiProductList.push(f)
  219. }
  220. })
  221. }
  222. // 处理字段
  223. m.quality == '' ? m.quality = {} : ''
  224. if (!Object.prototype.hasOwnProperty.call(m, 'product')) {
  225. m.product = '{}'
  226. }
  227. delete m.id
  228. if (this.taskId) {
  229. m.taskId = this.taskId
  230. m.taskName = this.taskName
  231. }
  232. return {
  233. ...m
  234. }
  235. })
  236. }).finally(() => {
  237. this.getCacheFn()
  238. })
  239. },
  240. handleScan(id, type) {
  241. console.log(id)
  242. console.log(type)
  243. // this.scanData('SCJHGD20240117002', type, id)
  244. // return false
  245. uni.scanCode({
  246. success: (res) => {
  247. this.scanData(res.result, type, id)
  248. }
  249. })
  250. },
  251. scanData(result, type, id) {
  252. if (type == 'wordOrder') {
  253. let isFals = this.List.some(m => m.code == result)
  254. if (isFals) {
  255. uni.showToast({
  256. title: '工单已存在',
  257. icon: 'none'
  258. })
  259. return false
  260. }
  261. getByCode(result).then(res => {
  262. let _arr = this.List
  263. _arr.forEach((e, index) => {
  264. if (e.workOrderId == id && res) {
  265. _arr[index] = res
  266. }
  267. })
  268. this.List = _arr
  269. this.$forceUpdate()
  270. })
  271. }
  272. },
  273. scanIt(id) {
  274. uni.scanCode({
  275. success: (res) => {
  276. this.scanItData(res.result, id)
  277. }
  278. })
  279. },
  280. scanItData(result, id) {
  281. scanLedger(result).then(res => {
  282. let _arr = []
  283. if (res.length == 1 && res[0].rootCategoryLevelId == 4) { // 设备
  284. _arr = this.List
  285. _arr.forEach((e, index) => {
  286. if (e.workOrderId == id) {
  287. _arr[index].equipmentList = _arr[index].equipmentList.concat(res)
  288. }
  289. })
  290. this.List = _arr
  291. this.$forceUpdate()
  292. } else if (res.length >= 1 && res[0].rootCategoryLevelId == 5) { // 模具
  293. _arr = this.List
  294. _arr.forEach((e, index) => {
  295. if (e.workOrderId == id) {
  296. _arr[index].modelList = res
  297. }
  298. })
  299. this.List = _arr
  300. this.$forceUpdate()
  301. } else if (res.length >= 1 && ['1'].includes(res[0].rootCategoryLevelId)) { // 物料
  302. _arr = this.List
  303. _arr.forEach((e, index) => {
  304. if (e.workOrderId == id) {
  305. _arr[index].instanceList = _arr[index].instanceList.concat(res)
  306. }
  307. })
  308. this.List = _arr
  309. this.$forceUpdate()
  310. } else if (res.length >= 1 && res[0].rootCategoryLevelId == 11) { // 干燥区
  311. _arr = this.List
  312. _arr.forEach((e, index) => {
  313. if (e.workOrderId == id) {
  314. let isFals = _arr[index].aridRegionList.some(m => m.code == res[0]
  315. .aridRegionList[0].code)
  316. if (isFals) {
  317. uni.showToast({
  318. title: '干燥区已存在',
  319. icon: 'none'
  320. })
  321. return false
  322. }
  323. let _obj = res[0].aridRegionList[0]
  324. if (_obj.status == 0) {
  325. _obj['name'] = res[0].name
  326. _obj['region'] = res[0].extInfo.region
  327. _arr[index].aridRegionList = _arr[index].aridRegionList.concat(res[0]
  328. .aridRegionList)
  329. } else {
  330. uni.showToast({
  331. title: '干燥区已占用',
  332. icon: 'none'
  333. })
  334. }
  335. }
  336. })
  337. this.List = _arr
  338. this.$forceUpdate()
  339. } else if (res.length >= 1 && res[0].rootCategoryLevelId == 7) { // 周转车
  340. _arr = this.List
  341. _arr.forEach((e, index) => {
  342. if (e.workOrderId == id) {
  343. let isFals = _arr[index].turnover.some(m => m.code == res[0].code)
  344. if (isFals) {
  345. uni.showToast({
  346. title: '周转车已存在',
  347. icon: 'none'
  348. })
  349. return false
  350. }
  351. _arr.forEach((e, index) => {
  352. if (e.workOrderId == id) {
  353. _arr[index].turnover = _arr[index].turnover.concat(res)
  354. }
  355. })
  356. this.List = _arr
  357. this.$forceUpdate()
  358. }
  359. })
  360. }
  361. })
  362. },
  363. // 全部扫一扫
  364. handlScanCode() {
  365. uni.scanCode({
  366. success: (res) => {
  367. this.scanItAllData(res.result)
  368. }
  369. })
  370. },
  371. scanItAllData(result) {
  372. scanLedger(result).then(res => {
  373. let _arr = []
  374. if (res.length == 1 && res[0].rootCategoryLevelId == 4) { // 设备
  375. _arr = this.List
  376. _arr.forEach((e, index) => {
  377. res['extInfo'].fixCode = res.fixCode
  378. e.equipmentList = e.equipmentList.concat(res)
  379. })
  380. this.List = _arr
  381. this.$forceUpdate()
  382. } else if (res.length >= 1 && res[0].rootCategoryLevelId == 5) { // 模具
  383. _arr = this.List
  384. _arr.forEach((e, index) => {
  385. e.modelList = res
  386. })
  387. this.List = _arr
  388. this.$forceUpdate()
  389. } else if (res.length >= 1 && ['1'].includes(res[0].rootCategoryLevelId)) {
  390. _arr = this.List
  391. _arr.forEach((e, index) => {
  392. e.instanceList = e.instanceList.concat(res)
  393. })
  394. this.List = _arr
  395. this.$forceUpdate()
  396. }
  397. })
  398. },
  399. getCacheFn() {
  400. let parma = {
  401. workOrderIds: this.idsList,
  402. taskId: this.taskId
  403. }
  404. feedGetCache(parma).then(res => {
  405. if (res.length == 0) {
  406. return false
  407. }
  408. let objList = res[0].extInfo.objList
  409. this.List.forEach(f => {
  410. objList.forEach(o => {
  411. if (f.workOrderId == o.workOrderId && f.taskId == o.taskId) {
  412. f['instanceList'] = o.instanceList || []
  413. f['equipmentList'] = o.equipmentList || []
  414. f['modelList'] = o.modelList || []
  415. f['aridRegionList'] = o.aridRegionList || []
  416. f['packingList'] = o.packingList || []
  417. f['palletList'] = o.palletList || []
  418. f['instanceList'] = o.instanceList || []
  419. f['revolvingDiskList'] = o.revolvingDiskList || []
  420. f['semiProductList'] = o.semiProductList || []
  421. this.$forceUpdate()
  422. }
  423. })
  424. })
  425. })
  426. },
  427. handAdd(id) {
  428. const storageKey = Date.now() + "";
  429. uni.setStorageSync(storageKey, this.List || []);
  430. uni.navigateTo({
  431. url: `/pages/pda/workOrder/search/index?id=${id}&storageKey=${storageKey}&isType=feed&taskId=${this.taskId}`
  432. })
  433. },
  434. openDetails(id) {
  435. const storageKey = Date.now() + "";
  436. uni.setStorageSync(storageKey, this.List || []);
  437. let url = `/pages/pda/feeding/single?id=${id}&taskId=${this.taskId}&storageKey=${storageKey}`
  438. uni.navigateTo({
  439. url
  440. })
  441. },
  442. },
  443. }
  444. </script>
  445. <style lang="scss" scoped>
  446. .content-box {
  447. height: 100vh;
  448. overflow: hidden;
  449. display: flex;
  450. flex-direction: column;
  451. }
  452. .list_box {
  453. flex: 1;
  454. overflow: hidden;
  455. padding: 4rpx 0;
  456. .u-list {
  457. height: 100% !important;
  458. }
  459. .card_box {
  460. padding: 16rpx;
  461. }
  462. }
  463. .bottom-wrapper {
  464. width: 100%;
  465. display: flex;
  466. align-items: center;
  467. justify-content: space-around;
  468. .btn_box {
  469. width: 50%;
  470. height: 88rpx;
  471. line-height: 88rpx;
  472. background: $theme-color;
  473. text-align: center;
  474. font-size: 36rpx;
  475. font-style: normal;
  476. font-weight: 400;
  477. color: #fff;
  478. &:first-child {
  479. border-right: 2rpx solid #fff;
  480. }
  481. }
  482. }
  483. .operate_box {
  484. position: fixed;
  485. right: 0;
  486. top: 400rpx;
  487. /deep/ .u-button {
  488. margin-top: 20rpx;
  489. width: 150rpx;
  490. border-radius: 22rpx 0 0 22rpx;
  491. opacity: 0.6;
  492. }
  493. }
  494. .operate_box2 {
  495. display: flex;
  496. /deep/ .u-button {
  497. margin-top: 20rpx;
  498. width: 150rpx;
  499. }
  500. }
  501. .flex_btn {
  502. position: fixed;
  503. right: 0;
  504. bottom: 160rpx;
  505. width: 140rpx;
  506. height: 66rpx;
  507. line-height: 66rpx;
  508. border-radius: 22rpx 0 0 22rpx;
  509. background: $theme-color;
  510. text-align: center;
  511. font-size: 22rpx;
  512. font-style: normal;
  513. font-weight: 400;
  514. color: #fff;
  515. opacity: 0.6;
  516. }
  517. </style>