|  |  |  | 
|---|
|  |  |  | <FlexJobCard | 
|---|
|  |  |  | :name="item.name" | 
|---|
|  |  |  | :age="item.age" | 
|---|
|  |  |  | :genderType="item.genderType" | 
|---|
|  |  |  | :gender="item.gender" | 
|---|
|  |  |  | :avatar="setOSSLink(item.avatar)" | 
|---|
|  |  |  | :isReal="item.isReal" | 
|---|
|  |  |  | :personalIdentityContent="item.personalIdentityContent" | 
|---|
|  |  |  | :educationalBackgroundContent="item.educationalBackgroundContent" | 
|---|
|  |  |  | :taskCount="item.taskCount" | 
|---|
|  |  |  | :workSeniority="item.workSeniority" | 
|---|
|  |  |  | :workExperience="item.workExperience" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <template #footerLeft> | 
|---|
|  |  |  | <div class="flexJob-card-footer-text">{{ FlexTaskWorkerHireEnum[item.hireStatus] }}</div> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | class="flexJob-card-footer-text" | 
|---|
|  |  |  | :style="{ color: EnumTaskUserHireStatusColor[item.hireStatus] }" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | {{ EnumTaskUserHireStatusText[item.hireStatus] }} | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | <template #footerRight> | 
|---|
|  |  |  | <nut-button type="primary" @click="goToJobDetail(item.userId)">查看详情</nut-button> | 
|---|
|  |  |  | <nut-button type="primary" @click.stop="goToJobDetail(item)">查看详情</nut-button> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </FlexJobCard> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <script setup lang="ts"> | 
|---|
|  |  |  | import { OrderInputType } from '@12333/constants'; | 
|---|
|  |  |  | import { EnumTaskUserHireStatusText, EnumTaskUserHireStatusColor } from '@12333/constants'; | 
|---|
|  |  |  | import { RouterPath } from '@/constants'; | 
|---|
|  |  |  | import { FlexTaskWorkerHireEnum } from '@/constants/task'; | 
|---|
|  |  |  | import { useInfiniteLoading } from '@12333/hooks'; | 
|---|
|  |  |  | import * as flexWorkerServices from '@12333/services/api/FlexWorker'; | 
|---|
|  |  |  | import { useTaskUserList } from '@12333/hooks'; | 
|---|
|  |  |  | import { FlexJobCard } from '@12333/components'; | 
|---|
|  |  |  | import Taro from '@tarojs/taro'; | 
|---|
|  |  |  | import { setOSSLink } from '@12333/utils'; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | defineOptions({ | 
|---|
|  |  |  | name: 'SignList', | 
|---|
|  |  |  | 
|---|
|  |  |  | // const props = withDefaults(defineProps<Props>(), {}); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const router = Taro.useRouter(); | 
|---|
|  |  |  | const taskId = router.params?.taskId ?? ''; | 
|---|
|  |  |  | const id = router.params?.id ?? ''; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const { infiniteLoadingProps } = useInfiniteLoading( | 
|---|
|  |  |  | ({ pageParam }) => { | 
|---|
|  |  |  | let params: API.GetFlexTaskWorkerApplyListInput = { | 
|---|
|  |  |  | flexTaskId: taskId, | 
|---|
|  |  |  | pageModel: { | 
|---|
|  |  |  | rows: 20, | 
|---|
|  |  |  | page: pageParam, | 
|---|
|  |  |  | orderInput: [{ property: 'creationTime', order: OrderInputType.Desc }], | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | const { infiniteLoadingProps } = useTaskUserList({ | 
|---|
|  |  |  | id: id, | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return flexWorkerServices.getFlexTaskWorkerApplyList(params, { | 
|---|
|  |  |  | showLoading: false, | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | queryKey: ['flexWorkerServices/getFlexTaskWorkerApplyList'], | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | function goToJobDetail(id: string) { | 
|---|
|  |  |  | function goToJobDetail(item: API.GetTaskUsersQueryResultItem) { | 
|---|
|  |  |  | Taro.navigateTo({ | 
|---|
|  |  |  | url: `${RouterPath.flexJobDetailFromTask}?id=${id}`, | 
|---|
|  |  |  | url: `${RouterPath.flexJobDetailFromTask}?enterpriseEmployeeId=${item.enterpriseEmployeeId}&id=${item.id}&taskInfoId=${id}`, | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | </script> | 
|---|