| | |
| | | title-gutter="12" |
| | | title-scroll |
| | | > |
| | | <ProTabPane :title="`全部`" :pane-key="MineHireType.All"></ProTabPane> |
| | | <ProTabPane :title="`进行中`" :pane-key="MineHireType.InProgress"></ProTabPane> |
| | | <ProTabPane :title="`待验收`" :pane-key="MineHireType.WaitCheck"></ProTabPane> |
| | | <ProTabPane :title="`已完成`" :pane-key="MineHireType.Finished"></ProTabPane> |
| | | <ProTabPane :title="`全部`" :pane-key="0"></ProTabPane> |
| | | <ProTabPane :title="`进行中`" :pane-key="10"></ProTabPane> |
| | | <ProTabPane :title="`待验收`" :pane-key="20"></ProTabPane> |
| | | <ProTabPane :title="`已完成`" :pane-key="30"></ProTabPane> |
| | | </ProTabs> |
| | | <InfiniteLoading |
| | | scrollViewClassName="common-infinite-scroll-list home-list" |
| | |
| | | :key="queryState.mineHireType" |
| | | > |
| | | <template #renderItem="{ item }"> |
| | | <TaskCard> |
| | | <TaskCard @click="goTaskDetail(item)"> |
| | | <template #actions> |
| | | <div class="task-card-actions-text" :style="{ color: MineHireTypeColor[10] }"> |
| | | {{ MineHireTypeText[10] }} |
| | | <div class="task-card-actions-text" :style="{ color: TaskStatusColor[10] }"> |
| | | {{ TaskStatusText[10] }} |
| | | </div> |
| | | </template> |
| | | </TaskCard> |
| | |
| | | <script setup lang="ts"> |
| | | import { TaskCard, ProTabs, ProTabPane } from '@12333/components'; |
| | | import { useUserStore } from '@/stores/modules/user'; |
| | | import { MineHireType, MineHireTypeColor, MineHireTypeText } from './constants'; |
| | | import { TaskStatusText, TaskStatusColor, TaskStatus } from '@/constants'; |
| | | import { useInfiniteLoading } from '@12333/hooks'; |
| | | import { OrderInputType } from '@12333/constants'; |
| | | import * as orderServices from '@12333/services/api/Order'; |
| | | import Taro from '@tarojs/taro'; |
| | | |
| | | defineOptions({ |
| | | name: 'InnerPage', |
| | | }); |
| | | |
| | | const queryState = reactive({ |
| | | mineHireType: MineHireType.All, |
| | | mineHireType: TaskStatus.All, |
| | | }); |
| | | |
| | | const userStore = useUserStore(); |
| | |
| | | rows: 20, |
| | | page: pageParam, |
| | | orderInput: [ |
| | | queryState.mineHireType === MineHireType.All |
| | | queryState.mineHireType === TaskStatus.All |
| | | ? { property: 'isRecommend', order: OrderInputType.Desc } |
| | | : { property: 'lastShelfTime', order: OrderInputType.Desc }, |
| | | ], |
| | |
| | | queryKey: ['orderServices/getFrontOrderList', queryState], |
| | | } |
| | | ); |
| | | |
| | | function goTaskDetail(item: API.FrontOrderList) { |
| | | Taro.navigateTo({ |
| | | url: `${RouterPath.taskDetail}?id=${item.id}`, |
| | | }); |
| | | } |
| | | </script> |
| | | |
| | | <style lang="scss"> |
| | | @import '@/styles/common.scss'; |
| | | |
| | | .task-card-actions-text { |
| | | font-size: 24px; |
| | | line-height: 42px; |
| | | .mineHire-page-wrapper { |
| | | .task-card-actions-text { |
| | | font-size: 24px; |
| | | line-height: 42px; |
| | | } |
| | | } |
| | | </style> |