details.vue 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288
  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">
  5. </uni-nav-bar>
  6. <view class="list_box">
  7. <u-list @scrolltolower="scrolltolower" v-if='taskType != 5'>
  8. <view class="card_box" v-for="(objData, index) in list" :key='index'>
  9. <view class="rx-bc title_card">
  10. <view>{{ index + 1 }}</view>
  11. <view>报工时间: {{ objData.createTime }}</view>
  12. </view>
  13. <workOrderBom :item='objData' v-if='objData' :isDetails='true'></workOrderBom>
  14. <!-- // 报工信息 -->
  15. <jobBom :item='objData' v-if="objData.notFormedList" :palletList='objData.palletList'
  16. :notFormed='objData.notFormedList' :isDetails='true'></jobBom>
  17. <deviceBom v-if='objData.equipmentList.length != 0' :list='objData.equipmentList'></deviceBom>
  18. <modelBom v-if='objData.modelList.length != 0' :list='objData.modelList'>
  19. </modelBom>
  20. <inspectionBom :semiProductList='objData.semiProductList' :isDetails='true'
  21. v-if='Object.prototype.hasOwnProperty.call(objData, "semiProductList") && objData.semiProductList.length && taskType == 3'>
  22. </inspectionBom>
  23. <sampleBom :item='objData.quality' v-if='objData.quality && taskType == 2'
  24. :workReportInfo='objData.workReportInfo' :isDetails='true'></sampleBom>
  25. <palletBom v-if="objData.palletList.length != 0" :palletList='objData.palletList' :isDetails='true'>
  26. </palletBom>
  27. <revolvingDiskBom v-if="objData.revolvingDiskList.length > 0" pattern='job'
  28. :revolvingDiskList="objData.revolvingDiskList"></revolvingDiskBom>
  29. <oneJobBom v-if='objData.instanceList && objData.instanceList.length != 0 && taskType != 6'
  30. :list='objData.instanceList' :item='objData' :isDetails='true'> </oneJobBom>
  31. <semiProductJobBom
  32. v-if='objData.semiProductList && objData.semiProductList.length != 0 && taskType != 6 && objData.singleReport == 1'
  33. :list='objData.semiProductList' :item='objData' :isDetails='true'> </semiProductJobBom>
  34. <semiProductJobBomPL
  35. v-if='objData.semiProductList && objData.semiProductList.length != 0 && taskType != 6 && taskType != 3 && objData.singleReport == 0'
  36. :list='objData.semiProductList' :item='objData' :isDetails='true'> </semiProductJobBomPL>
  37. <oneJobQualityBom
  38. v-if='objData.semiProductList && objData.semiProductList.length != 0 && taskType == 6 && clientEnvironmentId == 3 && objData.singleReport == 1'
  39. :list='objData.semiProductList' :item='objData' :isDetails='true'></oneJobQualityBom>
  40. <oneJobQualityBomPL v-if='taskType == 6 && clientEnvironmentId == 3 && objData.singleReport == 0'
  41. :list='objData.semiProductList' :item='objData' :isDetails='true'></oneJobQualityBomPL>
  42. <byProductBom v-if='objData.productRecycleList.length != 0' :list='objData.productRecycleList'
  43. :isDetails='true'>
  44. </byProductBom>
  45. <turnoverBom v-if='objData.turnover.length != 0' :list='objData.turnover' :wordItem='objData'
  46. pattern='job' :isDetails='true'>
  47. </turnoverBom>
  48. <aridRegion v-if='objData.aridRegionList.length != 0' :list='objData.aridRegionList'
  49. :remainingTime='0' :isType='true'></aridRegion>
  50. <packingTgBom
  51. v-if='objData.packInfo && objData.packInfo.pickOutInList && objData.packInfo.pickOutInList != 0 && taskType == 4 && clientEnvironmentId == 3'
  52. :list='objData.packInfo.pickOutInList' :isWarehousing='true' :isDetails="true" :item='objData'>
  53. </packingTgBom>
  54. <!-- //包装扫码 -->
  55. <view v-if="clientEnvironmentId != 2">
  56. <!-- <packingBom :taskId='taskId' :workOrderId='id' :objData='objData' ref="packRef"
  57. v-if='taskType == 4 && clientEnvironmentId != 3 && objData' :categoryId="categoryId">
  58. </packingBom> -->
  59. <packingBom v-if='taskType == 4 && clientEnvironmentId != 3 && objData' :packInfo="objData.packInfo">
  60. </packingBom>
  61. </view>
  62. </view>
  63. </u-list>
  64. <u-list @scrolltolower="scrolltolower" v-if='taskType == 5'>
  65. <view class="card_box" v-for="(objData, index) in list" :key='index'>
  66. <view class="rx-bc title_card">
  67. <view>{{ index + 1 }}</view>
  68. <view>报工时间: {{ objData.createTime }}</view>
  69. </view>
  70. <workOrderBom2 :item='objData' v-if='objData' :isDetails='true'></workOrderBom2>
  71. <detailsBom v-if='objData.detailList.length != 0' :detailList='objData.detailList'></detailsBom>
  72. </view>
  73. </u-list>
  74. <view v-if='list.length == 0'>
  75. <view style='margin-top: 20vh;'>
  76. <u-empty iconSize='150' textSize='32' text='暂无报工详情'>
  77. </u-empty>
  78. </view>
  79. </view>
  80. </view>
  81. </view>
  82. </template>
  83. <script>
  84. import {
  85. listWorkReport,
  86. listApplystorage,
  87. } from '@/api/pda/workOrder.js'
  88. import workOrderBom from '../../feeding/components/workOrderBom.vue'
  89. import deviceBom from '../../feeding/components/deviceBom.vue'
  90. import modelBom from '../../feeding/components/modelBom.vue'
  91. import jobBom from '../../jobBooking/components/jobBom.vue'
  92. import oneJobBom from '../../jobBooking/components/oneJobBom.vue'
  93. import semiProductJobBom from '../../jobBooking/components/semiProductJobBom.vue'
  94. import semiProductJobBomPL from '../../jobBooking/components/semiProductJobBomPL.vue'
  95. import oneJobQualityBom from '../../jobBooking/components/oneJobQualityBom.vue'
  96. import oneJobQualityBomPL from '../../jobBooking/components/oneJobQualityBomPL.vue'
  97. import byProductBom from '../../jobBooking/components/byProductBom'
  98. import turnoverBom from '../../jobBooking/components/turnoverBom.vue'
  99. import aridRegion from '../../feeding/components/aridRegion.vue'
  100. import paramBom from '../../feeding/components/paramBom.vue'
  101. import inspectionBom from '../../sample/components/inspectionBom.vue'
  102. import sampleBom from '../../sample/components/sampleBom.vue'
  103. import palletBom from '../../feeding/components/palletBom.vue'
  104. import revolvingDiskBom from '../../feeding/components/revolvingDiskBom.vue'
  105. import packingTgBom from '../../jobBooking/components/packingTgBom.vue'
  106. import packingBom from '../../jobBooking/components/packingBomDetails.vue'
  107. //
  108. import detailsBom from '../../warehousing/components/detailsBom.vue'
  109. import workOrderBom2 from '../../warehousing/components/workOrderBom.vue'
  110. export default {
  111. components: {
  112. workOrderBom,
  113. deviceBom,
  114. modelBom,
  115. jobBom,
  116. oneJobBom,
  117. semiProductJobBom,
  118. semiProductJobBomPL,
  119. oneJobQualityBom,
  120. oneJobQualityBomPL,
  121. byProductBom,
  122. turnoverBom,
  123. aridRegion,
  124. paramBom,
  125. inspectionBom,
  126. sampleBom,
  127. palletBom,
  128. revolvingDiskBom,
  129. packingTgBom,
  130. packingBom,
  131. detailsBom,
  132. workOrderBom2
  133. },
  134. data() {
  135. return {
  136. workOrderId: null,
  137. taskId: null,
  138. list: [],
  139. taskType: 1,
  140. clientEnvironmentId: uni.getStorageSync("userInfo") && uni.getStorageSync("userInfo")
  141. .clientEnvironmentId, // *1 主环境-601环境 2 soll-索尔环境 3 tg-碳谷环境
  142. }
  143. },
  144. onLoad(options) {
  145. this.title = options.taskName ? options.taskName + '-报工详情' : '报工详情'
  146. this.workOrderId = options.id
  147. this.taskId = options.taskId
  148. this.taskType = options.taskType
  149. this.getList()
  150. },
  151. methods: {
  152. getList() {
  153. let param = {
  154. workOrderId: this.workOrderId,
  155. taskId: this.taskId
  156. }
  157. let URL = this.taskType == 5 ? listApplystorage : listWorkReport
  158. URL(param).then(res => {
  159. this.list = res
  160. })
  161. },
  162. scrolltolower() { }
  163. }
  164. }
  165. </script>
  166. <style lang="scss" scoped>
  167. .content-box {
  168. height: 100vh;
  169. overflow: hidden;
  170. display: flex;
  171. flex-direction: column;
  172. }
  173. .list_box {
  174. flex: 1;
  175. overflow: hidden;
  176. padding: 4rpx 0;
  177. .u-list {
  178. height: 100% !important;
  179. }
  180. .card_box {
  181. padding: 16rpx;
  182. }
  183. }
  184. .bottom-wrapper {
  185. .btn_box {
  186. width: 750rpx;
  187. height: 88rpx;
  188. line-height: 88rpx;
  189. background: $theme-color;
  190. text-align: center;
  191. font-size: 36rpx;
  192. font-style: normal;
  193. font-weight: 400;
  194. color: #fff;
  195. }
  196. }
  197. .operate_box {
  198. padding: 10rpx 160rpx;
  199. /deep/ .u-button {
  200. width: 160rpx;
  201. }
  202. }
  203. .title_card {
  204. height: 70rpx;
  205. width: 100%;
  206. background: #157A2C;
  207. font-size: 30rpx;
  208. color: #fff;
  209. line-height: 70rpx;
  210. padding: 0 22rpx;
  211. box-sizing: border-box;
  212. }
  213. </style>