details.vue 12 KB

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