details.vue 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  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">
  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. <deviceBom v-if='objData.equipmentList.length != 0' :list='objData.equipmentList'></deviceBom>
  15. <modelBom v-if='objData.modelList.length != 0' :list='objData.modelList'>
  16. </modelBom>
  17. <jobBom :item='objData' :palletList='objData.palletList' :notFormed='objData.notFormedList'
  18. :isDetails='true'></jobBom>
  19. <oneJobBom v-if='objData.instanceList && objData.instanceList.length != 0' :list='objData.instanceList' :item='objData' :isDetails='true'> </oneJobBom>
  20. <byProductBom v-if='objData.productRecycleList.length != 0 ' :list='objData.productRecycleList'
  21. :isDetails='true'>
  22. </byProductBom>
  23. <turnoverBom v-if='objData.turnover.length != 0' :list='objData.turnover' :wordItem='objData'
  24. pattern='job' :isDetails='true'>
  25. </turnoverBom>
  26. <aridRegion v-if='objData.aridRegionList.length != 0' :list='objData.aridRegionList'
  27. :remainingTime='0' :isType='true'></aridRegion>
  28. </view>
  29. <view v-if='list.length == 0'>
  30. <view style='margin-top: 20vh;'>
  31. <u-empty iconSize='150' textSize='32' text='暂无报工详情'>
  32. </u-empty>
  33. </view>
  34. </view>
  35. </u-list>
  36. </view>
  37. </view>
  38. </template>
  39. <script>
  40. import {
  41. listWorkReport,
  42. } from '@/api/pda/workOrder.js'
  43. import workOrderBom from '../../feeding/components/workOrderBom.vue'
  44. import deviceBom from '../../feeding/components/deviceBom.vue'
  45. import modelBom from '../../feeding/components/modelBom.vue'
  46. import jobBom from '../../jobBooking/components/jobBom.vue'
  47. import oneJobBom from '../../jobBooking/components/oneJobBom.vue'
  48. import byProductBom from '../../jobBooking/components/byProductBom'
  49. import turnoverBom from '../../jobBooking/components/turnoverBom.vue'
  50. import aridRegion from '../../feeding/components/aridRegion.vue'
  51. import paramBom from '../../feeding/components/paramBom.vue'
  52. export default {
  53. components: {
  54. workOrderBom,
  55. deviceBom,
  56. modelBom,
  57. jobBom,
  58. oneJobBom,
  59. byProductBom,
  60. turnoverBom,
  61. aridRegion,
  62. paramBom,
  63. },
  64. data() {
  65. return {
  66. workOrderId: null,
  67. taskId: null,
  68. list: []
  69. }
  70. },
  71. onLoad(options) {
  72. this.title = options.taskName ? options.taskName + '-报工详情' : '报工详情'
  73. this.workOrderId = options.id
  74. this.taskId = options.taskId
  75. this.getList()
  76. },
  77. methods: {
  78. getList() {
  79. let param = {
  80. workOrderId: this.workOrderId,
  81. taskId: this.taskId
  82. }
  83. listWorkReport(param).then(res => {
  84. this.list = res
  85. })
  86. },
  87. scrolltolower() {}
  88. }
  89. }
  90. </script>
  91. <style lang="scss" scoped>
  92. .content-box {
  93. height: 100vh;
  94. overflow: hidden;
  95. display: flex;
  96. flex-direction: column;
  97. }
  98. .list_box {
  99. flex: 1;
  100. overflow: hidden;
  101. padding: 4rpx 0;
  102. .u-list {
  103. height: 100% !important;
  104. }
  105. .card_box {
  106. padding: 16rpx 24rpx;
  107. }
  108. }
  109. .bottom-wrapper {
  110. .btn_box {
  111. width: 750rpx;
  112. height: 88rpx;
  113. line-height: 88rpx;
  114. background: $theme-color;
  115. text-align: center;
  116. font-size: 36rpx;
  117. font-style: normal;
  118. font-weight: 400;
  119. color: #fff;
  120. }
  121. }
  122. .operate_box {
  123. padding: 10rpx 160rpx;
  124. /deep/ .u-button {
  125. width: 160rpx;
  126. }
  127. }
  128. .title_card {
  129. height: 70rpx;
  130. width: 100%;
  131. background: #157A2C;
  132. font-size: 30rpx;
  133. color: #fff;
  134. line-height: 70rpx;
  135. padding: 0 22rpx;
  136. box-sizing: border-box;
  137. }
  138. </style>