details.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446
  1. <template>
  2. <view class="content-box">
  3. <uni-nav-bar
  4. fixed="true"
  5. statusBar="true"
  6. left-icon="back"
  7. :title="title"
  8. background-color="#F7F9FA"
  9. color="#000"
  10. @clickLeft="back"
  11. >
  12. </uni-nav-bar>
  13. <view class="list_box">
  14. <u-list @scrolltolower="scrolltolower" v-if="taskType != 5">
  15. <view class="card_box" v-for="(objData, index) in list" :key="index">
  16. <view class="rx-bc title_card">
  17. <view>{{ index + 1 }}</view>
  18. <view>报工时间: {{ objData.workReportInfo.executorTime }}</view>
  19. </view>
  20. <workOrderBom
  21. :item="objData"
  22. v-if="objData"
  23. :isDetails="true"
  24. :isReportWork="true"
  25. ></workOrderBom>
  26. <paramBom
  27. v-if="objData.paramDetailList.length != 0"
  28. :list="objData.paramDetailList"
  29. ></paramBom>
  30. <!-- // 报工信息 -->
  31. <jobBom
  32. :item="objData"
  33. v-if="objData.notFormedList"
  34. :palletList="objData.palletList"
  35. :notFormed="objData.notFormedList"
  36. :isDetails="true"
  37. ></jobBom>
  38. <deviceBom
  39. v-if="objData.equipmentList.length != 0"
  40. :list="objData.equipmentList"
  41. ></deviceBom>
  42. <modelBom
  43. v-if="objData.modelList.length != 0"
  44. :list="objData.modelList"
  45. >
  46. </modelBom>
  47. <inspectionBom
  48. :semiProductList="objData.semiProductList"
  49. :isDetails="true"
  50. v-if="
  51. Object.prototype.hasOwnProperty.call(
  52. objData,
  53. 'semiProductList'
  54. ) &&
  55. objData.semiProductList.length &&
  56. taskType == 3
  57. "
  58. >
  59. </inspectionBom>
  60. <sampleBom
  61. :item="objData.quality"
  62. v-if="objData.quality && taskType == 2"
  63. :workReportInfo="objData.workReportInfo"
  64. :isDetails="true"
  65. ></sampleBom>
  66. <palletBom
  67. v-if="objData.palletList.length != 0"
  68. :palletList="objData.palletList"
  69. :isDetails="true"
  70. >
  71. </palletBom>
  72. <revolvingDiskBom
  73. v-if="objData.revolvingDiskList.length > 0"
  74. pattern="job"
  75. :revolvingDiskList="objData.revolvingDiskList"
  76. ></revolvingDiskBom>
  77. <oneJobBom
  78. v-if="
  79. objData.instanceList &&
  80. objData.instanceList.length != 0 &&
  81. taskType != 6
  82. "
  83. :list="objData.instanceList"
  84. :item="objData"
  85. :isDetails="true"
  86. >
  87. </oneJobBom>
  88. <!-- <!- 报工详情- 扫码报工fff -->
  89. <semiProductJobBom
  90. v-if="
  91. objData.semiProductList &&
  92. objData.semiProductList.length != 0 &&
  93. taskType != 6 &&
  94. objData.singleReport == 1
  95. "
  96. :list="objData.semiProductList"
  97. :item="objData"
  98. :isDetails="true"
  99. >
  100. </semiProductJobBom>
  101. <batchProductJobBom
  102. v-if="
  103. objData.product &&
  104. objData.product.length != 0 &&
  105. taskType != 6 &&
  106. objData.singleReport == 0 &&
  107. clientEnvironmentId != 3
  108. "
  109. :list="objData.product"
  110. :item="objData"
  111. :isDetails="true"
  112. >
  113. </batchProductJobBom>
  114. <batchProductJobBom
  115. v-if="
  116. objData.product &&
  117. objData.product.length != 0 &&
  118. taskType == 6 &&
  119. objData.singleReport == 0 &&
  120. clientEnvironmentId != 3
  121. "
  122. :item="objData"
  123. :list="objData.product"
  124. :isDetails="true"
  125. >
  126. </batchProductJobBom>
  127. <semiProductJobBomPL
  128. v-if="
  129. objData.semiProductList &&
  130. objData.semiProductList.length != 0 &&
  131. taskType != 6 &&
  132. taskType != 3 &&
  133. objData.singleReport == 0 &&
  134. clientEnvironmentId == 3
  135. "
  136. :list="objData.semiProductList"
  137. :item="objData"
  138. :isDetails="true"
  139. >
  140. </semiProductJobBomPL>
  141. <oneJobQualityBom
  142. v-if="
  143. objData.semiProductList &&
  144. objData.semiProductList.length != 0 &&
  145. taskType == 6 &&
  146. clientEnvironmentId == 3 &&
  147. objData.singleReport == 1
  148. "
  149. :list="objData.semiProductList"
  150. :item="objData"
  151. :isDetails="true"
  152. ></oneJobQualityBom>
  153. <oneJobQualityBomPL
  154. v-if="
  155. taskType == 6 &&
  156. clientEnvironmentId == 3 &&
  157. objData.singleReport == 0
  158. "
  159. :list="objData.semiProductList"
  160. :item="objData"
  161. :isDetails="true"
  162. ></oneJobQualityBomPL>
  163. <byProductBom
  164. v-if="objData.productRecycleList.length != 0"
  165. :list="objData.productRecycleList"
  166. :isDetails="true"
  167. >
  168. </byProductBom>
  169. <turnoverBom
  170. v-if="objData.turnover.length != 0"
  171. :list="objData.turnover"
  172. :wordItem="objData"
  173. pattern="job"
  174. :isDetails="true"
  175. >
  176. </turnoverBom>
  177. <aridRegion
  178. v-if="objData.aridRegionList.length != 0"
  179. :list="objData.aridRegionList"
  180. :remainingTime="0"
  181. :isType="true"
  182. ></aridRegion>
  183. <view v-if="objData.packInfo">
  184. <packingTgBom
  185. v-if="
  186. objData.packInfo &&
  187. objData.packInfo.pickOutInList &&
  188. objData.packInfo.pickOutInList != 0 &&
  189. taskType == 4 &&
  190. clientEnvironmentId == 3
  191. "
  192. :list="objData.packInfo.pickOutInList"
  193. :isWarehousing="true"
  194. :isDetails="true"
  195. :item="objData"
  196. >
  197. </packingTgBom>
  198. <!-- //包装扫码 -->
  199. <view v-else>
  200. <view v-if="clientEnvironmentId != 2">
  201. <!-- <packingBom
  202. v-if="taskType == 4 && clientEnvironmentId != 3 && objData"
  203. :packInfo="objData.packInfo"
  204. >
  205. </packingBom> -->
  206. <!-- :taskId="taskId"
  207. :workOrderId="id"
  208. :objData="objData"
  209. ref="packRef"
  210. v-if="taskType == 4 && clientEnvironmentId != 3 && objData"
  211. :categoryId="categoryId" -->
  212. <newPackingBomDetails
  213. v-if="taskType == 4 && clientEnvironmentId != 3 && objData"
  214. :taskId="objData.currentTaskDiagram.taskId"
  215. :objData="objData"
  216. :categoryId="objData.workOrderId"
  217. >
  218. </newPackingBomDetails>
  219. </view>
  220. <packingQtBom
  221. v-else
  222. :list="objData.packInfo.pickOutInList"
  223. :isWarehousing="true"
  224. :isDetails="true"
  225. :item="objData"
  226. >
  227. </packingQtBom>
  228. </view>
  229. </view>
  230. </view>
  231. </u-list>
  232. <u-list @scrolltolower="scrolltolower" v-if="taskType == 5">
  233. <view class="card_box" v-for="(objData, index) in list" :key="index">
  234. <view class="rx-bc title_card">
  235. <view>{{ index + 1 }}</view>
  236. <view>报工时间: {{ objData.createTime }}</view>
  237. </view>
  238. <workOrderBom2
  239. :item="objData"
  240. v-if="objData"
  241. :isDetails="true"
  242. ></workOrderBom2>
  243. <!-- <detailsBom
  244. v-if="objData.detailList.length != 0"
  245. :detailList="objData.detailList"
  246. ></detailsBom> -->
  247. <detailsBatchBom
  248. v-if="objData.detailList.length != 0"
  249. :detailList="objData.detailList"
  250. ></detailsBatchBom>
  251. </view>
  252. </u-list>
  253. <view v-if="list.length == 0">
  254. <view style="margin-top: 20vh">
  255. <u-empty iconSize="150" textSize="32" text="暂无报工详情"> </u-empty>
  256. </view>
  257. </view>
  258. </view>
  259. </view>
  260. </template>
  261. <script>
  262. import { listWorkReport, listApplystorage } from "@/api/pda/workOrder.js";
  263. import workOrderBom from "../../feeding/components/workOrderBom.vue";
  264. import deviceBom from "../../feeding/components/deviceBom.vue";
  265. import modelBom from "../../feeding/components/modelBom.vue";
  266. import jobBom from "../../jobBooking/components/jobBom.vue";
  267. import oneJobBom from "../../jobBooking/components/oneJobBom.vue";
  268. import semiProductJobBom from "../../jobBooking/components/semiProductJobBom.vue";
  269. import semiProductJobBomPL from "../../jobBooking/components/semiProductJobBomPL.vue";
  270. import oneJobQualityBom from "../../jobBooking/components/oneJobQualityBom.vue";
  271. import oneJobQualityBomPL from "../../jobBooking/components/oneJobQualityBomPL.vue";
  272. import byProductBom from "../../jobBooking/components/byProductBom";
  273. import turnoverBom from "../../jobBooking/components/turnoverBom.vue";
  274. import aridRegion from "../../feeding/components/aridRegion.vue";
  275. import paramBom from "../../feeding/components/paramBom.vue";
  276. import inspectionBom from "../../sample/components/inspectionBom.vue";
  277. import sampleBom from "../../sample/components/sampleBom.vue";
  278. import palletBom from "../../feeding/components/palletBom.vue";
  279. import revolvingDiskBom from "../../feeding/components/revolvingDiskBom.vue";
  280. import packingTgBom from "../../jobBooking/components/packingTgBom.vue";
  281. import packingBom from "../../jobBooking/components/packingBomDetails.vue";
  282. import newPackingBomDetails from "../../jobBooking/components/newPackingBomDetails.vue";
  283. import packingQtBom from "../../jobBooking/components/packingQtBom.vue";
  284. import batchProductJobBom from "../../jobBooking/components/batchProductJobBom.vue";
  285. //
  286. import detailsBom from "../../warehousing/components/detailsBom.vue";
  287. import detailsBatchBom from "../../warehousing/components/detailsBatchBom.vue";
  288. import workOrderBom2 from "../../warehousing/components/workOrderBom.vue";
  289. export default {
  290. components: {
  291. workOrderBom,
  292. deviceBom,
  293. modelBom,
  294. jobBom,
  295. oneJobBom,
  296. semiProductJobBom,
  297. semiProductJobBomPL,
  298. oneJobQualityBom,
  299. oneJobQualityBomPL,
  300. packingQtBom,
  301. byProductBom,
  302. turnoverBom,
  303. aridRegion,
  304. paramBom,
  305. inspectionBom,
  306. sampleBom,
  307. palletBom,
  308. revolvingDiskBom,
  309. packingTgBom,
  310. packingBom,
  311. detailsBom,
  312. workOrderBom2,
  313. batchProductJobBom,
  314. newPackingBomDetails,
  315. detailsBatchBom,
  316. },
  317. data() {
  318. return {
  319. workOrderId: null,
  320. taskId: null,
  321. list: [],
  322. taskType: 1,
  323. clientEnvironmentId:
  324. uni.getStorageSync("userInfo") &&
  325. uni.getStorageSync("userInfo").clientEnvironmentId, // *1 主环境-601环境 2 soll-索尔环境 3 tg-碳谷环境
  326. };
  327. },
  328. onLoad(options) {
  329. this.title = options.taskName ? options.taskName + "-报工详情" : "报工详情";
  330. this.workOrderId = options.id;
  331. this.taskId = options.taskId;
  332. this.taskType = options.taskType;
  333. this.getList();
  334. },
  335. methods: {
  336. getList() {
  337. let param = {
  338. workOrderId: this.workOrderId,
  339. taskId: this.taskId,
  340. };
  341. let URL = this.taskType == 5 ? listApplystorage : listWorkReport;
  342. URL(param).then((res) => {
  343. this.list = res;
  344. });
  345. },
  346. scrolltolower() {},
  347. },
  348. };
  349. </script>
  350. <style lang="scss" scoped>
  351. .content-box {
  352. height: 100vh;
  353. overflow: hidden;
  354. display: flex;
  355. flex-direction: column;
  356. }
  357. .list_box {
  358. flex: 1;
  359. overflow: hidden;
  360. padding: 4rpx 0;
  361. .u-list {
  362. height: 100% !important;
  363. }
  364. .card_box {
  365. padding: 16rpx;
  366. }
  367. }
  368. .bottom-wrapper {
  369. .btn_box {
  370. width: 750rpx;
  371. height: 88rpx;
  372. line-height: 88rpx;
  373. background: $theme-color;
  374. text-align: center;
  375. font-size: 36rpx;
  376. font-style: normal;
  377. font-weight: 400;
  378. color: #fff;
  379. }
  380. }
  381. .operate_box {
  382. padding: 10rpx 160rpx;
  383. /deep/ .u-button {
  384. width: 160rpx;
  385. }
  386. }
  387. .title_card {
  388. height: 70rpx;
  389. width: 100%;
  390. background: #157a2c;
  391. font-size: 30rpx;
  392. color: #fff;
  393. line-height: 70rpx;
  394. padding: 0 22rpx;
  395. box-sizing: border-box;
  396. }
  397. </style>