index.vue 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. <template>
  2. <z-paging ref="paging" v-model="list" paging-class="paging-btm-shadow" bgColor="#f7f7f7" safe-area-inset-bottom>
  3. <template #top>
  4. <ut-navbar title="选择操作地块" :fixed="false"></ut-navbar>
  5. </template>
  6. <view class="startline-title pl-24 ml-24 mb-16">基地信息</view>
  7. <view class="pd-26 bg-#fff mb-20">
  8. <view class="border-#AFDDBB pd-26 pb-10 pt-10 bg-#FBFDFB p-rtv">
  9. <!-- 标签显示:GAP和三无一全 -->
  10. <view v-if="+modeValue?.gapFlag || +modeValue?.swyqRes" class="pt-8 pb-8 d-flex pr-20 pl-20" style="width: max-content; margin-top: -10rpx; margin-left: -26rpx; background: linear-gradient(90deg, #5eba75, #c6e391); border-bottom-right-radius: 88rpx">
  11. <view v-if="+modeValue?.gapFlag && !+modeValue?.swyqRes" class="c-#fff f-s-24 f-w-6">获评{{ modeValue?.medicineName }}GAP基地</view>
  12. <view v-if="+modeValue?.swyqRes && !+modeValue?.gapFlag" class="c-#fff f-s-24 f-w-6">获评{{ modeValue?.swyqMedicineName }}三无一全基地</view>
  13. <view v-if="+modeValue?.gapFlag && +modeValue?.swyqRes" class="c-#fff f-s-24 f-w-6">获评{{ modeValue?.medicineName }}GAP基地和{{ modeValue?.swyqMedicineName }}三无一全基地</view>
  14. </view>
  15. <view class="c-#333 f-s-34 f-w-5 pt-8 pb-8 pr-16">{{ modeValue?.baseName }}</view>
  16. <view class="pt-8 pb-8">
  17. <text class="c-#666 f-s-28">基地面积:</text>
  18. <text class="c-#333 f-s-28 f-w-5">{{ modeValue?.gapInfo?.area }}{{ modeValue?.gapInfo?.areaUnit }}</text>
  19. </view>
  20. <view class="pt-8 pb-8">
  21. <text class="c-#666 f-s-28">基地地址:</text>
  22. <text class="c-#333 f-s-28 f-w-5">{{ modeValue?.gapInfo?.adcodeName }}{{ modeValue?.gapInfo?.address }}</text>
  23. </view>
  24. </view>
  25. </view>
  26. <view class="startline-title pl-24 ml-24 mb-16">请选择所操作的地块</view>
  27. <view class="pd-24">
  28. <ut-search ref="searchRef" v-model="keyword" @search="changeSeach" margin="0" :border="false" placeholder="搜索地块名称" bgColor="#fff" height="86rpx" borderRadius="10rpx"></ut-search>
  29. <view class="pd-20"></view>
  30. <up-checkbox-group v-model="checkboxValue">
  31. <view class="d-flex w-100% j-sb b-radius bg-#fff mb-20 pd-24" v-for="(item, index) in lands" :key="index" :name="item?.id">
  32. <view class="flex1 ov-hd">
  33. <view class="ov-hd tx-ov d-flex a-c">
  34. <view class="c-primary f-s-24 f-w-5 mr-10 bg-#EBF6EE pd4-4-6-4-6 b-radius" style="font-style: italic">{{ Number(index) + 1 < 10 ? '0' + (Number(index) + 1) : Number(index) + 1 }}</view>
  35. <view class="c-#333 f-w-5 f-s-34 tx-ov ov-hd">{{ item?.landName }}</view>
  36. </view>
  37. <view class="d-flex a-c">
  38. <view class="w-50%">
  39. <text class="c-#666 f-s-28 mr-5">{{ item?.area }}</text>
  40. <text class="c-#666 f-s-24 tx-ov ov-hd">{{ item?.areaUnit }}</text>
  41. </view>
  42. <view class="w-50%">
  43. <text class="c-#666 f-s-28 f-w-5 mr-5">负责人:</text>
  44. <text class="c-#666 f-s-24 tx-ov ov-hd">{{ item?.contactName }}</text>
  45. </view>
  46. </view>
  47. </view>
  48. <view class="d-flex j-c a-c">
  49. <view class="">
  50. <up-checkbox activeColor="#37A954" label="" :name="item?.id" shape="circle"></up-checkbox>
  51. </view>
  52. </view>
  53. </view>
  54. </up-checkbox-group>
  55. </view>
  56. <template #bottom>
  57. <view class="pd-24 bg-#fff">
  58. <view class="b-radius bg-#fff d-flex a-c j-sb">
  59. <view class="d-flex c-primary f-s-26">
  60. <text>已选择:</text>
  61. <text>{{ checkboxValue.length }}</text>
  62. <text>个地块</text>
  63. </view>
  64. <view class="d-flex a-c">
  65. <view class="c-#333 f-s-28 mr-10">全选</view>
  66. <up-checkbox usedAlone activeColor="#37A954" :checked="isAllSelected" @change="handleSelectAll"></up-checkbox>
  67. </view>
  68. </view>
  69. <view class="d-flex gap-20">
  70. <up-button @click="cancel()">取消</up-button>
  71. <up-button type="primary" @click="save()">确认选择</up-button>
  72. </view>
  73. </view>
  74. </template>
  75. </z-paging>
  76. </template>
  77. <script lang="ts" setup>
  78. import { ref, computed } from 'vue';
  79. import { useClientRequest } from '@/utils/request';
  80. const paging = ref();
  81. const list = ref([]);
  82. //基地信息
  83. const modeValue = ref();
  84. const keyword = ref('');
  85. //地块信息
  86. const lands = ref<any>([]);
  87. const changeSeach = async () => {
  88. const res = await useClientRequest.get('/plt-api/app/baseLandInfo/pageList', { baseId: modeValue.value?.id, keyword: keyword.value });
  89. lands.value = res?.rows;
  90. // 搜索时清空选中状态
  91. checkboxValue.value = [];
  92. };
  93. const checkboxValue = ref<string[]>([]);
  94. const handleSelectAll = () => {
  95. if (isAllSelected.value) {
  96. checkboxValue.value = []; // 全选状态下点击 → 清空
  97. } else {
  98. checkboxValue.value = lands.value.map((item: any) => item.id); // 非全选状态下点击 → 全选
  99. }
  100. };
  101. const isAllSelected = computed(() => {
  102. console.log(checkboxValue.value.length === lands.value.length);
  103. return lands.value.length > 0 && checkboxValue.value.length === lands.value.length;
  104. });
  105. onLoad(async (options: any) => {
  106. const res = await useClientRequest.get(`/plt-api/app/base/getInfoAllById/${options?.baseId}`);
  107. modeValue.value = res?.data?.baseInfo;
  108. lands.value = res?.data?.landInfoList;
  109. // 初始选中状态为空
  110. checkboxValue.value = [];
  111. });
  112. const cancel = () => {
  113. uni.navigateBack({
  114. delta: 1,
  115. });
  116. };
  117. // 确认选择
  118. const save = () => {
  119. if (checkboxValue.value.length === 0) {
  120. return uni.showToast({
  121. title: '请选择地块',
  122. icon: 'none',
  123. });
  124. }
  125. const data = checkboxValue.value.map((id) => lands.value.find((item) => item.id === id));
  126. // 我希望这个能返回 data: { medicineName: string; swyqMedicineName: string; checkBox: any[]; data: any[]; aloneChecked: boolean; baseName: string; area?: string; gapFlag: number; swyqRes: number; areaUnit: string; adcodeName: string; address: string })
  127. uni.$emit('updatelands', {
  128. baseName: modeValue.value?.baseName,
  129. area: modeValue.value?.gapInfo?.area,
  130. gapFlag: modeValue.value?.gapFlag,
  131. swyqRes: modeValue.value?.swyqRes,
  132. areaUnit: modeValue.value?.gapInfo?.areaUnit,
  133. adcodeName: modeValue.value?.gapInfo?.adcodeName,
  134. address: modeValue.value?.gapInfo?.address,
  135. aloneChecked: isAllSelected.value,
  136. swyqMedicineName: modeValue.value?.swyqMedicineName,
  137. medicineName: modeValue.value?.medicineName,
  138. checkBox: checkboxValue.value,
  139. data: data,
  140. });
  141. uni.navigateBack({
  142. delta: 1,
  143. });
  144. };
  145. onUnload(() => {
  146. uni.$off('updatelands');
  147. });
  148. </script>