| | |
| | | <template> |
| | | <ProTabs |
| | | v-model="queryState.mineAgreementSignType" |
| | | v-model="queryState.userSignContractStatus" |
| | | name="home-tab" |
| | | :showPaneContent="false" |
| | | class="home-tabs" |
| | |
| | | title-scroll |
| | | > |
| | | <ProTabPane :title="`全部`" :pane-key="0"></ProTabPane> |
| | | <ProTabPane :title="`待签约`" :pane-key="10"></ProTabPane> |
| | | <ProTabPane :title="`生效中`" :pane-key="20"></ProTabPane> |
| | | <ProTabPane :title="`已终止`" :pane-key="30"></ProTabPane> |
| | | <ProTabPane :title="`待签约`" :pane-key="EnumTaskUserSignContractStatus.Wait"></ProTabPane> |
| | | <ProTabPane :title="`生效中`" :pane-key="EnumTaskUserSignContractStatus.Effect"></ProTabPane> |
| | | <ProTabPane :title="`已终止`" :pane-key="EnumTaskUserSignContractStatus.Stop"></ProTabPane> |
| | | </ProTabs> |
| | | <InfiniteLoading |
| | | scrollViewClassName="common-infinite-scroll-list home-list" |
| | | v-bind="infiniteLoadingProps" |
| | | :key="queryState.mineAgreementSignType" |
| | | :key="queryState.userSignContractStatus" |
| | | > |
| | | <template #renderItem="{ item }"> |
| | | <MineAgreementSignCard @click="goDetail"> </MineAgreementSignCard> |
| | | <MineAgreementSignCard |
| | | :enterpriseName="item.enterpriseName" |
| | | :userSignContractStatus="item.userSignContractStatus" |
| | | @click="goDetail(item)" |
| | | > |
| | | </MineAgreementSignCard> |
| | | </template> |
| | | </InfiniteLoading> |
| | | </template> |
| | |
| | | <script setup lang="ts"> |
| | | import { MineAgreementSignCard, ProTabs, ProTabPane } from '@12333/components'; |
| | | import { useUserStore } from '@/stores/modules/user'; |
| | | import { TaskStatus } from '@/constants'; |
| | | import { useInfiniteLoading } from '@12333/hooks'; |
| | | import { EnumPagedListOrder } from '@12333/constants'; |
| | | import * as taskServices from '@12333/services/apiV2/task'; |
| | | import { EnumPagedListOrder, EnumTaskUserSignContractStatus } from '@12333/constants'; |
| | | import * as enterpriseEmployeeServices from '@12333/services/apiV2/enterpriseEmployee'; |
| | | import Taro from '@tarojs/taro'; |
| | | |
| | | defineOptions({ |
| | |
| | | }); |
| | | |
| | | const queryState = reactive({ |
| | | mineAgreementSignType: TaskStatus.All, |
| | | userSignContractStatus: 0 as any as EnumTaskUserSignContractStatus, |
| | | }); |
| | | |
| | | const userStore = useUserStore(); |
| | | |
| | | const { infiniteLoadingProps } = useInfiniteLoading( |
| | | ({ pageParam }) => { |
| | | let params: API.GetFlexTaskListInput = { |
| | | let params: API.GetPersonalUserElectronSignsQuery = { |
| | | pageModel: { |
| | | rows: 20, |
| | | page: pageParam, |
| | | orderInput: [{ property: 'id', order: EnumPagedListOrder.Desc }], |
| | | }, |
| | | userSignContractStatus: queryState.userSignContractStatus, |
| | | }; |
| | | |
| | | return taskServices.getPersonalHireTaskInfos(params, { |
| | | return enterpriseEmployeeServices.getPersonalUserElectronSigns(params, { |
| | | showLoading: false, |
| | | }); |
| | | }, |
| | | { |
| | | queryKey: ['taskServices/getPersonalHireTaskInfos', queryState], |
| | | queryKey: ['enterpriseEmployeeServices/getPersonalUserElectronSigns', queryState], |
| | | } |
| | | ); |
| | | |
| | | function goDetail() { |
| | | function goDetail(row: API.GetPersonalUserElectronSignsQueryResultItem) { |
| | | Taro.navigateTo({ |
| | | url: RouterPath.mineAgreementSignDetail, |
| | | url: `${RouterPath.mineAgreementSignDetail}?id=${row.id}`, |
| | | }); |
| | | } |
| | | </script> |