pickWorkCard.vue 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. <template>
  2. <view>
  3. <checkbox-group
  4. v-for="(item, index) in list"
  5. :key="index"
  6. @change="(e) => selectVal(e, item, index)"
  7. >
  8. <label>
  9. <view class="card_box" @click="openDetails(item.status, item)">
  10. <view class="item_box rx-bc">
  11. <view class="rx-sc">
  12. <view class="round">{{ index + 1 }}</view>
  13. <view class="orderId">{{ item.code }} </view>
  14. </view>
  15. <view class="status" :class="[item.status != 0 ? 'FAA' : '']">
  16. {{
  17. item.status == 0
  18. ? "未领料"
  19. : item.status == 1
  20. ? "领料中"
  21. : item.status == 2
  22. ? "已出库"
  23. : ""
  24. }}</view
  25. >
  26. </view>
  27. <view class="item_box rx-bc">
  28. <view class="item_one rx-sc">
  29. <view class="lable">关联工单号:</view>
  30. <view>{{ item.joinWorkOrderCode }}</view>
  31. </view>
  32. </view>
  33. <view class="item_box rx-bc">
  34. <view class="item_one perce50 rx-sc">
  35. <view class="lable">领料人:</view>
  36. <view class="gylx">{{ item.executorName }}</view>
  37. </view>
  38. <view class="item_one perce50 rx-sc">
  39. <view>关联审核人:</view>
  40. <view class="gylx">{{ item.joinReviewerName }}</view>
  41. </view>
  42. </view>
  43. <view class="item_box rx-bc">
  44. <view class="item_one rx-sc">
  45. <view class="lable">领料仓库:</view>
  46. <view>{{ item.joinWarehouseName }}</view>
  47. </view>
  48. </view>
  49. <view class="item_box rx-bc">
  50. <view class="item_one rx-sc">
  51. <view class="lable">类型:</view>
  52. <view class="gylx" v-if="item.type == 1">自建领料</view>
  53. <view class="gylx" v-if="item.type == 2">工单领料</view>
  54. <view class="gylx" v-if="item.type == 3">委外领料</view>
  55. </view>
  56. </view>
  57. <view class="item_box rx-sc">
  58. <view class="item_one rx-sc">
  59. <view class="lable">领料时间:</view>
  60. <view>{{ item.createTime }}</view>
  61. </view>
  62. </view>
  63. </view>
  64. </label>
  65. </checkbox-group>
  66. </view>
  67. </template>
  68. <script>
  69. export default {
  70. props: {
  71. list: {
  72. type: Array,
  73. default: () => [],
  74. },
  75. },
  76. data() {
  77. return {
  78. statusList: {
  79. 4: "待生产",
  80. 5: "生产中",
  81. 6: "已完成",
  82. 7: "已延期",
  83. 8: "待下达",
  84. },
  85. };
  86. },
  87. created() {
  88. console.log(this.list, "领料单数据");
  89. },
  90. methods: {
  91. selectVal(e, val, index) {
  92. this.list[index].checked = !this.list[index].checked;
  93. },
  94. openDetails(pickStatus, item) {
  95. if (pickStatus == 1 || pickStatus == 2) {
  96. let url = "/pages/pda/picking/bill/index";
  97. url += `?item=${JSON.stringify(item)}&status=${pickStatus}`;
  98. uni.navigateTo({
  99. url,
  100. });
  101. // let url = `/pages/pda/picking/bill/index?id=${id}&status=${pickStatus}`;
  102. // uni.navigateTo({
  103. // url,
  104. // });
  105. }
  106. },
  107. },
  108. };
  109. </script>
  110. <style lang="scss" scoped>
  111. .card_box {
  112. width: 750rpx;
  113. padding: 16rpx 24rpx;
  114. box-sizing: border-box;
  115. border-bottom: 2rpx solid #e1e1e1;
  116. .item_box {
  117. margin-top: 10rpx;
  118. .round {
  119. width: 40rpx;
  120. height: 40rpx;
  121. line-height: 40rpx;
  122. border-radius: 50%;
  123. background: $theme-color;
  124. color: #fff;
  125. text-align: center;
  126. font-size: 20rpx;
  127. margin-right: 10px;
  128. }
  129. .orderId {
  130. color: #000;
  131. font-family: PingFang HK;
  132. font-size: 28rpx;
  133. font-style: normal;
  134. font-weight: 600;
  135. margin-left: 16rpx;
  136. margin-top: 8rpx;
  137. }
  138. .item_one {
  139. width: 100%;
  140. font-size: 26rpx;
  141. font-style: normal;
  142. font-weight: 400;
  143. line-height: 38rpx;
  144. word-wrap: break-word;
  145. }
  146. .gylx {
  147. color: $theme-color;
  148. }
  149. .perce50 {
  150. width: 50%;
  151. }
  152. .status {
  153. font-size: 26rpx;
  154. &.FAA {
  155. color: #ffa929;
  156. }
  157. }
  158. /deep/ .uni-checkbox-input-checked {
  159. background-color: $theme-color !important;
  160. border-color: $theme-color !important;
  161. }
  162. }
  163. }
  164. </style>