details.vue 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  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"></uni-nav-bar>
  5. <view class="list_box">
  6. <u-list @scrolltolower="scrolltolower">
  7. <view v-for="(item,index) in List" :key="index" class="card_box">
  8. <workOrderBom :item='item'></workOrderBom>
  9. </view>
  10. </u-list>
  11. </view>
  12. <view class="bottom-wrapper">
  13. <view class="btn_box" @click="save">一键报工</view>
  14. </view>
  15. </view>
  16. </template>
  17. <script>
  18. import workOrderBom from './components/workOrderBom.vue'
  19. import {
  20. workorderList
  21. } from '@/api/pda/workOrder.js'
  22. import {
  23. batchSave
  24. } from '@/api/pda/picking.js'
  25. export default {
  26. components: {
  27. workOrderBom
  28. },
  29. data() {
  30. return {
  31. title: '',
  32. idsList: [],
  33. List: [],
  34. }
  35. },
  36. onLoad(options) {
  37. this.title = options.taskName ? options.taskName + '-投料' : '投料'
  38. let queryArray = decodeURIComponent(options.arr);
  39. this.idsList = JSON.parse(queryArray);
  40. this.getList()
  41. },
  42. onShow() {
  43. uni.$off("setSelectList");
  44. uni.$on("setSelectList", (selectList, id) => {
  45. console.log(selectList)
  46. this.List.forEach(m => {
  47. if (m.workOrderId == id) {
  48. this.$set(m, 'instanceList', selectList)
  49. }
  50. })
  51. });
  52. },
  53. methods: {
  54. scrolltolower() {},
  55. save() {
  56. let _arr = []
  57. _arr = this.List.map(m => {
  58. m.workOrderId = m.id
  59. delete m.id
  60. return {
  61. ...m
  62. }
  63. })
  64. batchSave(_arr).then(res => {
  65. uni.navigateTo({
  66. url: `/pages/pda/picking/index/index?pickStatus=1`,
  67. });
  68. })
  69. },
  70. getList() {
  71. workorderList(this.idsList).then(res => {
  72. this.List = res.map(m => {
  73. m.workOrderId = m.id
  74. delete m.id
  75. return {
  76. ...m
  77. }
  78. })
  79. })
  80. },
  81. addPicking(id, list) {
  82. const storageKey = Date.now() + "";
  83. uni.setStorageSync(storageKey, list || []);
  84. uni.navigateTo({
  85. url: `/pages/pda/workOrder/search/index?id=${id}&storageKey=${storageKey}`
  86. })
  87. },
  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. </style>