From 6999f1f04fc3ce40359c156bf008c70ee19fabf8 Mon Sep 17 00:00:00 2001
From: wupengfei <834520024@qq.com>
Date: 星期日, 19 十月 2025 19:56:08 +0800
Subject: [PATCH] feat: 1.2.0.1

---
 apps/cMiniApp/src/pages/home/index.vue |   80 ++++++++++++++++------------------------
 1 files changed, 32 insertions(+), 48 deletions(-)

diff --git a/apps/cMiniApp/src/pages/home/index.vue b/apps/cMiniApp/src/pages/home/index.vue
index d6483eb..d0097eb 100644
--- a/apps/cMiniApp/src/pages/home/index.vue
+++ b/apps/cMiniApp/src/pages/home/index.vue
@@ -16,17 +16,17 @@
           ></BlSearchbar>
         </div>
         <div class="city-btn" @click="goCitySelect">
-          <Location2 :size="16" />
+          <img :src="IconLocaltion" class="city-btn-icon" />
           <div class="city-btn-text">{{ locationCity }}</div>
         </div>
       </div>
-      <div class="home-banner-wrapper">
+      <!-- <div class="home-banner-wrapper">
         <nut-swiper :auto-play="3000">
           <nut-swiper-item v-for="(item, index) in list" :key="index">
             <img :src="item" class="banner-img" draggable="false" />
           </nut-swiper-item>
         </nut-swiper>
-      </div>
+      </div> -->
     </div>
     <ProTabs
       v-model="queryState.orderType"
@@ -44,7 +44,7 @@
         <Menu>
           <MenuItem title="绛涢��" ref="selectItem">
             <HomeQueryMenuView
-              v-model:gender="queryState.gender"
+              v-model:query="queryMenuState"
               @close="handleMenuSelectClose"
             ></HomeQueryMenuView>
           </MenuItem>
@@ -57,7 +57,7 @@
       :key="queryState.orderType"
     >
       <template #renderItem="{ item }">
-        <TaskCard @click="goTaskDetail(item)" />
+        <TaskCard @click="goTaskDetail(item)" v-bind="item" />
       </template>
     </InfiniteLoading>
   </PageLayoutWithBg>
@@ -65,34 +65,32 @@
 
 <script setup lang="ts">
 import { useUser } from '@/hooks';
-import { useUserStore } from '@/stores/modules/user';
-import { RectDown, Location2 } from '@nutui/icons-vue-taro';
 import Taro from '@tarojs/taro';
-import { LocationUtils, trim } from '@12333/utils';
+import { setLocationCity } from '@/utils';
 import _ from 'lodash';
 import IconLogo from '@/assets/home/icon-logo.png';
-import { useInfiniteLoading } from '@12333/hooks';
-import { OrderInputType, Gender } from '@12333/constants';
-import * as orderServices from '@12333/services/api/Order';
 import { TaskCard, ProTabs, ProTabPane } from '@12333/components';
-import { HomeOrderType } from './constants';
 import HomeQueryMenuView from './HomeQueryMenuView.vue';
+import IconLocaltion from '@/assets/task/icon-localtion.png';
+import { useAllAreaList, useTaskList, HomeOrderType } from '@12333/hooks';
+import { useAccessLogin } from '@/hooks';
 
 const { locationCity } = useUser();
 
-const searchValue = ref('');
+const { findAreaCodeFromName } = useAllAreaList();
 
-const queryState = reactive({
-  searchValueTrim: '',
-  orderType: HomeOrderType.Recommend,
-  gender: '' as any as Gender,
+const { searchValue, queryState, handleSearch, infiniteLoadingProps, queryMenuState } = useTaskList(
+  {
+    cityCode: computed(() => findAreaCodeFromName(locationCity.value)),
+    enabled: computed(() => !!findAreaCodeFromName(locationCity.value)),
+  }
+);
+
+onMounted(async () => {
+  try {
+    await setLocationCity();
+  } catch (error) {}
 });
-
-const handleSearch = _.debounce(function () {
-  queryState.searchValueTrim = trim(searchValue.value);
-}, 300);
-
-const userStore = useUserStore();
 
 function goCitySelect() {
   Taro.navigateTo({
@@ -107,40 +105,21 @@
   'https://storage.360buyimg.com/jdc-article/fristfabu.jpg',
 ]);
 
-const { infiniteLoadingProps } = useInfiniteLoading(
-  ({ pageParam }) => {
-    let params: API.FrontOrderListInput = {
-      pageModel: {
-        rows: 20,
-        page: pageParam,
-        orderInput: [
-          queryState.orderType === HomeOrderType.Recommend
-            ? { property: 'isRecommend', order: OrderInputType.Desc }
-            : { property: 'lastShelfTime', order: OrderInputType.Desc },
-        ],
-      },
-    };
-
-    return orderServices.getFrontOrderList(params, {
-      showLoading: false,
-    });
-  },
-  {
-    queryKey: ['orderServices/getFrontOrderList', queryState],
-  }
-);
-
 const selectItem = ref();
 
 function handleMenuSelectClose() {
   selectItem.value?.toggle?.();
 }
 
-function goTaskDetail(item: API.FrontOrderList) {
+function goTaskDetail(item: API.GetTaskInfosQueryResultItem) {
   Taro.navigateTo({
-    url: `${RouterPath.taskDetail}?id=${item.id}`,
+    url: `${RouterPath.taskDetail}?id=${item.id}&from=apply`,
   });
 }
+
+const goTaskApply = useAccessLogin((item: API.GetTaskInfosQueryResultItem) => {
+  console.log('item: ', item);
+});
 </script>
 
 <style lang="scss">
@@ -171,6 +150,11 @@
       padding-left: 36px;
       color: boleGetCssVar('text-color', 'primary');
 
+      .city-btn-icon {
+        width: 40px;
+        height: 40px;
+      }
+
       .city-btn-text {
         max-width: 200px;
         @include ellipsis;

--
Gitblit v1.9.1