|  |  |  | 
|---|
|  |  |  | <template> | 
|---|
|  |  |  | <PageLayout class="mine-page-wrapper" :need-auth="false"> | 
|---|
|  |  |  | <PageLayoutWithBg class="mine-page-wrapper" title="我的" :need-auth="false"> | 
|---|
|  |  |  | <template #navigationBar> | 
|---|
|  |  |  | <TransparentNavigationBar | 
|---|
|  |  |  | title="个人中心" | 
|---|
|  |  |  | 
|---|
|  |  |  | <UserHomeTopView :showUserHomePageBtn="isLogin" :showOperation="isLogin"> | 
|---|
|  |  |  | <template #avatar> | 
|---|
|  |  |  | <div class="mine-avatar-wrapper" @click="goLogin"> | 
|---|
|  |  |  | <UserAvatar :size="60" class="mine-avatar" /> | 
|---|
|  |  |  | <UserAvatar :size="52" class="mine-avatar" /> | 
|---|
|  |  |  | <div class="user-info" v-if="isLogin"> | 
|---|
|  |  |  | <div class="user-info-item">{{ userDetail?.userName ?? '' }}</div> | 
|---|
|  |  |  | <div class="user-info-item2" v-if="isCertified"> | 
|---|
|  |  |  | {{ userDetail?.customerName ?? '' }} | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="user-info-unCertified" v-else @click.stop="goAuthentication"> | 
|---|
|  |  |  | <img :src="IconUnCertified" class="user-info-unCertified-icon" /> | 
|---|
|  |  |  | <div class="user-info-unCertified-text">未认证</div> | 
|---|
|  |  |  | <div class="user-info-item">{{ userDetail?.name ?? '' }}</div> | 
|---|
|  |  |  | <div class="user-info-auth"> | 
|---|
|  |  |  | <div class="user-info-auth-item"> | 
|---|
|  |  |  | <div class="user-info-unCertified"> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | class="user-info-unCertified-text" | 
|---|
|  |  |  | v-if="userDetail?.realStatus === EnumPersonalUserRealStatus.UnReal" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | 未认证 | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="user-info-unCertified-text" v-else> | 
|---|
|  |  |  | {{ EnumUserRealMethodText[userDetail?.realMethod] | 
|---|
|  |  |  | }}{{ EnumPersonalUserRealStatusText[userDetail?.realStatus] }} | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | class="user-info-unCertified-btn" | 
|---|
|  |  |  | @click.stop="goAuthentication" | 
|---|
|  |  |  | v-if=" | 
|---|
|  |  |  | userDetail?.realStatus === EnumPersonalUserRealStatus.UnReal || | 
|---|
|  |  |  | userDetail?.realStatus === EnumPersonalUserRealStatus.Fail | 
|---|
|  |  |  | " | 
|---|
|  |  |  | > | 
|---|
|  |  |  | 立即认证 | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <!-- <div class="user-info-unCertified" v-else> | 
|---|
|  |  |  | <img :src="IconAuth" class="user-info-unCertified-icon" /> | 
|---|
|  |  |  | <div class="user-info-unCertified-text"> | 
|---|
|  |  |  | {{ EnumUserRealMethodText[userDetail?.realMethod] }}{{ EnumPersonalUserRealStatusText[userDetail?.realStatus] }} | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> --> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="mine-go-login" v-else>去登录</div> | 
|---|
|  |  |  | 
|---|
|  |  |  | </UserHomeTopView> | 
|---|
|  |  |  | </ContentView> | 
|---|
|  |  |  | <ContentScrollView v-if="isLogin" class="mine-content-scroll-view"> | 
|---|
|  |  |  | <div class="mine-id-menu-wrapper"> | 
|---|
|  |  |  | <img :src="IconLamp" class="mine-id-menu-icon" /> | 
|---|
|  |  |  | <div class="mine-id-menu-text"> | 
|---|
|  |  |  | 您当前的身份为{{ MatchMakingIdentityEnumText[matchMakingIdentity] }} | 
|---|
|  |  |  | <List class="mine-list-wrapper mine-balance"> | 
|---|
|  |  |  | <div class="mine-balance-content"> | 
|---|
|  |  |  | <div class="mine-balance-content-item"> | 
|---|
|  |  |  | <div class="mine-balance-content-item-title">我的收益</div> | 
|---|
|  |  |  | <div class="mine-balance-content-item-money income"> | 
|---|
|  |  |  | ¥{{ toThousand(userDetail?.incomeCount ?? 0) }} | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="mine-balance-content-item"> | 
|---|
|  |  |  | <div class="mine-balance-content-item-title">待结算</div> | 
|---|
|  |  |  | <div class="mine-balance-content-item-money settlement"> | 
|---|
|  |  |  | ¥{{ toThousand(userDetail?.waitSettlement ?? 0) }} | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="mine-balance-content-item"> | 
|---|
|  |  |  | <div class="mine-balance-content-item-title">已发放</div> | 
|---|
|  |  |  | <div class="mine-balance-content-item-money withdraw"> | 
|---|
|  |  |  | ¥{{ toThousand(userDetail?.releaseedCount ?? 0) }} | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="mine-id-menu-btn" @click="goPage(RouterPath.toggleMatchMakingIdentity)"> | 
|---|
|  |  |  | 切换身份 | 
|---|
|  |  |  | <div class="mine-balance-btn" @click="goMineWallet"> | 
|---|
|  |  |  | 进入我的钱包 | 
|---|
|  |  |  | <img :src="IconArrow" class="mine-balance-btn-icon" /> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="mine-menu-list"> | 
|---|
|  |  |  | <div class="mine-menu-list-item" @click="goBusinessManagement"> | 
|---|
|  |  |  | <img :src="IconMenuBusiness" class="mine-menu-list-item-icon" /> | 
|---|
|  |  |  | <div class="mine-menu-list-item-text">业务管理</div> | 
|---|
|  |  |  | </List> | 
|---|
|  |  |  | <List class="mine-list-wrapper mine-order-list"> | 
|---|
|  |  |  | <div class="mine-order-list-title"> | 
|---|
|  |  |  | <div class="mine-order-list-title-text">我的订单</div> | 
|---|
|  |  |  | <img :src="IconArrow" class="mine-order-list-title-icon" /> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="mine-menu-list-item" @click="goTradeChatRecord"> | 
|---|
|  |  |  | <img :src="IconMenuContact" class="mine-menu-list-item-icon" /> | 
|---|
|  |  |  | <div class="mine-menu-list-item-text">联系记录</div> | 
|---|
|  |  |  | <div class="mine-order-list-content"> | 
|---|
|  |  |  | <nut-badge | 
|---|
|  |  |  | class="mine-order-list-item" | 
|---|
|  |  |  | top="8" | 
|---|
|  |  |  | :value="userDetail?.taskCount ?? 0" | 
|---|
|  |  |  | @click="goMineSign" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <img :src="IconOrderSign" class="mine-order-list-icon" /> | 
|---|
|  |  |  | <div class="mine-order-list-text">已报名</div> | 
|---|
|  |  |  | </nut-badge> | 
|---|
|  |  |  | <nut-badge | 
|---|
|  |  |  | class="mine-order-list-item" | 
|---|
|  |  |  | top="8" | 
|---|
|  |  |  | :value="userDetail?.inProcessTaskCount ?? 0" | 
|---|
|  |  |  | @click="goMineHire" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <img :src="IconOrderHire" class="mine-order-list-icon" /> | 
|---|
|  |  |  | <div class="mine-order-list-text">任务中</div> | 
|---|
|  |  |  | </nut-badge> | 
|---|
|  |  |  | <nut-badge | 
|---|
|  |  |  | class="mine-order-list-item" | 
|---|
|  |  |  | top="8" | 
|---|
|  |  |  | :value="userDetail?.hirePassTaskCount ?? 0" | 
|---|
|  |  |  | @click="goMineHired" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <img :src="IconOrderHire" class="mine-order-list-icon" /> | 
|---|
|  |  |  | <div class="mine-order-list-text">已录用</div> | 
|---|
|  |  |  | </nut-badge> | 
|---|
|  |  |  | <!-- <nut-badge | 
|---|
|  |  |  | class="mine-order-list-item" | 
|---|
|  |  |  | top="8" | 
|---|
|  |  |  | :value="userDetail?.hirePassTaskCount ?? 0" | 
|---|
|  |  |  | @click="goMineHire" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <img :src="IconOrderHire" class="mine-order-list-icon" /> | 
|---|
|  |  |  | <div class="mine-order-list-text">已安排</div> | 
|---|
|  |  |  | </nut-badge> | 
|---|
|  |  |  | <nut-badge | 
|---|
|  |  |  | class="mine-order-list-item" | 
|---|
|  |  |  | top="8" | 
|---|
|  |  |  | :value="userDetail?.hireRefuseTaskCount ?? 0" | 
|---|
|  |  |  | @click="goMineCancel" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <img :src="IconOrderCancel" class="mine-order-list-icon" /> | 
|---|
|  |  |  | <div class="mine-order-list-text">已取消</div> | 
|---|
|  |  |  | </nut-badge> --> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <List class="mine-setting-list"> | 
|---|
|  |  |  | <ListItem :icon="IconMessage" title="消息" @click="goMessage"> | 
|---|
|  |  |  | <template #extra> | 
|---|
|  |  |  | <nut-badge | 
|---|
|  |  |  | :value="myMessageCount.unReadCount ?? 0" | 
|---|
|  |  |  | class="mine-setting-badge" | 
|---|
|  |  |  | :hidden="!myMessageCount.unReadCount" | 
|---|
|  |  |  | ></nut-badge> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </ListItem> | 
|---|
|  |  |  | </List> | 
|---|
|  |  |  | <List class="mine-list-wrapper mine-setting-list"> | 
|---|
|  |  |  | <ListItem :icon="IconCollect" title="我收藏的任务" @click="goMineCollectTask"></ListItem> | 
|---|
|  |  |  | <ListItem :icon="IconAgreement" title="协议签约" @click="goMineAgreementSign"></ListItem> | 
|---|
|  |  |  | <ListItem :icon="IconServices" title="人工客服" @click="goMineService"></ListItem> | 
|---|
|  |  |  | <ListItem :icon="IconSetting" title="设置" @click="goSetting"></ListItem> | 
|---|
|  |  |  | <!-- <ListItem :icon="IconRecruit" title="我要招人/用人" @click="goSetting"></ListItem> --> | 
|---|
|  |  |  | </List> | 
|---|
|  |  |  | </ContentScrollView> | 
|---|
|  |  |  | </PageLayout> | 
|---|
|  |  |  | </PageLayoutWithBg> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <script setup lang="ts"> | 
|---|
|  |  |  | import { | 
|---|
|  |  |  | PageLayout, | 
|---|
|  |  |  | TransparentNavigationBar, | 
|---|
|  |  |  | ContentScrollView, | 
|---|
|  |  |  | UserHomeTopView, | 
|---|
|  |  |  | } from '@/components'; | 
|---|
|  |  |  | import IconUnCertified from '@/assets/mine/icon-unCertified.png'; | 
|---|
|  |  |  | import IconLamp from '@/assets/mine/icon-lamp.png'; | 
|---|
|  |  |  | import IconMenuBusiness from '@/assets/mine/icon-menu-business.png'; | 
|---|
|  |  |  | import IconMenuContact from '@/assets/mine/icon-menu-contact.png'; | 
|---|
|  |  |  | import { TransparentNavigationBar, ContentScrollView, UserHomeTopView } from '@/components'; | 
|---|
|  |  |  | import IconArrow from '@/assets/setting/icon-arrow.png'; | 
|---|
|  |  |  | import IconSetting from '@/assets/mine/icon-setting.png'; | 
|---|
|  |  |  | import IconMessage from '@/assets/mine/icon-message.png'; | 
|---|
|  |  |  | import { useUser, useIsLogin, useGoLogin, useMyMessageCount } from '@/hooks'; | 
|---|
|  |  |  | import IconCollect from '@/assets/mine/icon-collect.png'; | 
|---|
|  |  |  | import IconAgreement from '@/assets/mine/icon-agreement.png'; | 
|---|
|  |  |  | import IconRecruit from '@/assets/mine/icon-recruit.png'; | 
|---|
|  |  |  | import IconOrderSign from '@/assets/mine/icon-order-sign.png'; | 
|---|
|  |  |  | import IconOrderHire from '@/assets/mine/icon-order-hire.png'; | 
|---|
|  |  |  | import IconOrderCancel from '@/assets/mine/icon-order-cancel.png'; | 
|---|
|  |  |  | import IconAuth from '@/assets/mine/icon-auth.png'; | 
|---|
|  |  |  | import IconServices from '@/assets/mine/icon-services.png'; | 
|---|
|  |  |  | import { useUser, useIsLogin, useGoLogin } from '@/hooks'; | 
|---|
|  |  |  | import Taro from '@tarojs/taro'; | 
|---|
|  |  |  | import { RouterPath, OssAssets } from '@/constants'; | 
|---|
|  |  |  | import { MatchMakingIdentityEnumText, MatchMakingIdentityEnum } from '@12333/constants'; | 
|---|
|  |  |  | import { | 
|---|
|  |  |  | EnumUserRealMethodText, | 
|---|
|  |  |  | EnumPersonalUserRealStatusText, | 
|---|
|  |  |  | EnumPersonalUserRealStatus, | 
|---|
|  |  |  | } from '@12333/constants'; | 
|---|
|  |  |  | import { List, ListItem } from '@12333/components'; | 
|---|
|  |  |  | import { useSystemStore } from '@/stores/modules/system'; | 
|---|
|  |  |  | import PageLayoutWithBg from '@/components/Layout/PageLayoutWithBg.vue'; | 
|---|
|  |  |  | import { toThousand } from '@12333/utils'; | 
|---|
|  |  |  | import { useIntervalFn } from 'senin-mini/hooks'; | 
|---|
|  |  |  | import { useQuery } from '@tanstack/vue-query'; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const { userDetail, isCertified, matchMakingIdentity } = useUser(); | 
|---|
|  |  |  | const { userDetail, isCertified, updateUserInfo } = useUser(); | 
|---|
|  |  |  | const isLogin = useIsLogin(); | 
|---|
|  |  |  | const systemStore = useSystemStore(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const { goLoginFn } = useGoLogin(); | 
|---|
|  |  |  | const bgHeight = computed(() => 133 + systemStore.navHeight); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | useQuery({ | 
|---|
|  |  |  | queryKey: ['updateUserInfo'], | 
|---|
|  |  |  | queryFn: () => {}, | 
|---|
|  |  |  | enabled: computed( | 
|---|
|  |  |  | () => isLogin.value && userDetail.value?.realStatus === EnumPersonalUserRealStatus.Checking | 
|---|
|  |  |  | ), | 
|---|
|  |  |  | refetchInterval: 5000, | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Taro.useDidShow(() => { | 
|---|
|  |  |  | if (isLogin.value) { | 
|---|
|  |  |  | updateUserInfo(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | function goLogin() { | 
|---|
|  |  |  | if (!isLogin.value) { | 
|---|
|  |  |  | 
|---|
|  |  |  | goPage(RouterPath.setting); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | function goMessage() { | 
|---|
|  |  |  | goPage(RouterPath.messageList); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | function goBusinessManagement() { | 
|---|
|  |  |  | if (matchMakingIdentity.value === MatchMakingIdentityEnum.Employing) { | 
|---|
|  |  |  | goPage(RouterPath.orderManage); | 
|---|
|  |  |  | } else if (matchMakingIdentity.value === MatchMakingIdentityEnum.Contributors) { | 
|---|
|  |  |  | goPage(RouterPath.resourceManage); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Taro.showShareMenu({ | 
|---|
|  |  |  | showShareItems: ['shareAppMessage'], | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Taro.useShareAppMessage((res) => { | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | title: `${userDetail.value?.contacter}名片`, | 
|---|
|  |  |  | path: `${RouterPath.userHomePage}?userId=${userDetail.value?.userId}`, | 
|---|
|  |  |  | imageUrl: userDetail.value?.avatarUrl, | 
|---|
|  |  |  | // title: `${userDetail.value?.contacter}名片`, | 
|---|
|  |  |  | // path: `${RouterPath.userHomePage}?userId=${userDetail.value?.userId}`, | 
|---|
|  |  |  | // imageUrl: userDetail.value?.avatarUrl, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const { myMessageCount } = useMyMessageCount(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | function goAuthentication() { | 
|---|
|  |  |  | goPage(RouterPath.authenticationHome); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | function goMineSign() { | 
|---|
|  |  |  | goPage(RouterPath.mineSign); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | function goMineHire() { | 
|---|
|  |  |  | goPage(RouterPath.mineHire); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | function goMineCancel() { | 
|---|
|  |  |  | goPage(RouterPath.mineCancel); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | function goMineHired() { | 
|---|
|  |  |  | goPage(RouterPath.mineHired); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | function goMineCollectTask() { | 
|---|
|  |  |  | goPage(RouterPath.mineCollectTask); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | function goMineAgreementSign() { | 
|---|
|  |  |  | goPage(RouterPath.mineAgreementSign); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | function goTradeChatRecord() { | 
|---|
|  |  |  | goPage(RouterPath.tradeChatRecord); | 
|---|
|  |  |  | function goMineWallet() { | 
|---|
|  |  |  | goPage(RouterPath.mineWallet); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | function goMineService() { | 
|---|
|  |  |  | Taro.openCustomerServiceChat({ | 
|---|
|  |  |  | extInfo: { | 
|---|
|  |  |  | url: 'https://work.weixin.qq.com/kfid/kfcd24e0c60fd91099', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | corpId: 'wwc84cb8e0525c772f', | 
|---|
|  |  |  | fail: () => { | 
|---|
|  |  |  | Taro.showToast({ | 
|---|
|  |  |  | title: '请稍后再试', | 
|---|
|  |  |  | icon: 'none', | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | </script> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | .mine-setting-badge { | 
|---|
|  |  |  | margin-right: 20px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .mine-setting-list { | 
|---|
|  |  |  | .pro-list-item-icon { | 
|---|
|  |  |  | width: 48px; | 
|---|
|  |  |  | height: 48px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | </style> | 
|---|