| | |
| | | <script setup lang="ts"> |
| | | import { MyTaskCard, ProTabs, ProTabPane, Calendar } from '@12333/components'; |
| | | import Taro from '@tarojs/taro'; |
| | | import { EnumTaskCheckReceiveStatus } from '@12333/constants'; |
| | | import { useInfiniteLoading, useTaskList } from '@12333/hooks'; |
| | | import * as taskCheckReceiveServices from '@12333/services/apiV2/taskCheckReceive'; |
| | | import { EnumTaskCheckReceiveStatus, EnumTaskCheckReceiveMethod } from '@12333/constants'; |
| | | import { useCheckReceiveTasks } from '@12333/hooks'; |
| | | import dayjs from 'dayjs'; |
| | | |
| | | defineOptions({ |
| | | name: 'InnerPage', |
| | | }); |
| | | |
| | | const queryState = reactive({ |
| | | date: dayjs().toDate(), |
| | | checkReceiveStatus: EnumTaskCheckReceiveStatus.WaitSubmit, |
| | | }); |
| | | |
| | | const { infiniteLoadingProps } = useInfiniteLoading( |
| | | ({ pageParam }) => { |
| | | let params: API.GetCheckReceiveTasksQuery = { |
| | | pageModel: { |
| | | rows: 20, |
| | | page: pageParam, |
| | | }, |
| | | date: dayjs(queryState.date).format('YYYY-MM-DD'), |
| | | checkReceiveStatus: queryState.checkReceiveStatus, |
| | | }; |
| | | |
| | | return taskCheckReceiveServices.getCheckReceiveTasks(params, { |
| | | showLoading: false, |
| | | }); |
| | | }, |
| | | { |
| | | queryKey: ['taskCheckReceiveServices/getCheckReceiveTasks', queryState], |
| | | } |
| | | ); |
| | | const { queryState, infiniteLoadingProps } = useCheckReceiveTasks(); |
| | | |
| | | function goSubmitTaskDetail(item: API.GetCheckReceiveTasksQueryResultItem) { |
| | | Taro.navigateTo({ |
| | | url: `${RouterPath.taskCheckDetail}?taskId=${item.id}`, |
| | | }); |
| | | if ( |
| | | item.checkReceiveMethod === EnumTaskCheckReceiveMethod.CheckIn && |
| | | dayjs(queryState.date).isBefore(dayjs()) |
| | | ) { |
| | | Taro.navigateTo({ |
| | | url: `${RouterPath.taskUserSubmitCheckHistories}?id=${item.id}&date=${dayjs( |
| | | queryState.date |
| | | ).format('YYYY-MM-DD')}`, |
| | | }); |
| | | } else { |
| | | Taro.navigateTo({ |
| | | url: `${RouterPath.taskCheckDetail}?id=${item.id}&date=${dayjs(queryState.date).format( |
| | | 'YYYY-MM-DD' |
| | | )}&checkReceiveStatus=${queryState.checkReceiveStatus}`, |
| | | }); |
| | | } |
| | | } |
| | | </script> |