details.vue 14 KB

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