|  |  |  | 
|---|
|  |  |  | <template> | 
|---|
|  |  |  | <div class="task-check-card-wrapper"> | 
|---|
|  |  |  | <div class="task-check-card-wrapper" @click.stop="emit('checkReceive')"> | 
|---|
|  |  |  | <TaskCheckPersonalView | 
|---|
|  |  |  | class="task-check-card-view" | 
|---|
|  |  |  | :avatarUrl="avatarUrl" | 
|---|
|  |  |  | :avatar="avatar" | 
|---|
|  |  |  | :name="name" | 
|---|
|  |  |  | :genderType="genderType" | 
|---|
|  |  |  | :isRealName="isRealName" | 
|---|
|  |  |  | :contactPhone="contactPhone" | 
|---|
|  |  |  | :gender="gender" | 
|---|
|  |  |  | :isReal="isReal" | 
|---|
|  |  |  | :contactPhoneNumber="contactPhoneNumber" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <template #actions> | 
|---|
|  |  |  | <nut-button | 
|---|
|  |  |  | v-if="checkAcceptStatus === FlexTaskCheckAcceptStatusEnum.Wait" | 
|---|
|  |  |  | type="primary" | 
|---|
|  |  |  | class="task-check-card-phone-btn" | 
|---|
|  |  |  | >验收</nut-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div v-else class="task-check-card-phone-status" :style="{ color: Colors.Success }"> | 
|---|
|  |  |  | {{ FlexTaskCheckAcceptStatusEnumText[checkAcceptStatus] }} | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <template v-if="checkReceiveMethod === EnumTaskCheckReceiveMethod.CheckIn"> | 
|---|
|  |  |  | <nut-button | 
|---|
|  |  |  | v-if="!checkInTime" | 
|---|
|  |  |  | type="primary" | 
|---|
|  |  |  | class="task-check-card-phone-btn" | 
|---|
|  |  |  | @click.stop="emit('checkInOrOut', CheckInOrOutEventEnum.CheckIn)" | 
|---|
|  |  |  | >签到</nut-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <nut-button | 
|---|
|  |  |  | v-else-if="!checkOutTime" | 
|---|
|  |  |  | type="primary" | 
|---|
|  |  |  | class="task-check-card-phone-btn" | 
|---|
|  |  |  | @click.stop="emit('checkInOrOut', CheckInOrOutEventEnum.CheckOut)" | 
|---|
|  |  |  | >签出</nut-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div v-else class="task-check-card-phone-status" :style="{ color: Colors.Success }"> | 
|---|
|  |  |  | {{ EnumTaskCheckReceiveStatusText[checkReceiveStatus] }} | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | <template v-else> | 
|---|
|  |  |  | <nut-button | 
|---|
|  |  |  | v-if="checkReceiveStatus === EnumTaskCheckReceiveStatus.WaitCheckReceive" | 
|---|
|  |  |  | type="primary" | 
|---|
|  |  |  | class="task-check-card-phone-btn" | 
|---|
|  |  |  | >验收</nut-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div v-else class="task-check-card-phone-status" :style="{ color: Colors.Success }"> | 
|---|
|  |  |  | {{ EnumTaskCheckReceiveStatusText[checkReceiveStatus] }} | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </TaskCheckPersonalView> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <script setup lang="ts"> | 
|---|
|  |  |  | import TaskCheckPersonalView from './TaskCheckPersonalView.vue'; | 
|---|
|  |  |  | import { Colors, Gender } from '@12333/constants'; | 
|---|
|  |  |  | import { | 
|---|
|  |  |  | FlexTaskCheckAcceptStatusEnum, | 
|---|
|  |  |  | FlexTaskCheckAcceptStatusEnumText, | 
|---|
|  |  |  | } from '@12333/constants/task'; | 
|---|
|  |  |  | Colors, | 
|---|
|  |  |  | EnumUserGender, | 
|---|
|  |  |  | EnumTaskCheckReceiveStatus, | 
|---|
|  |  |  | EnumTaskCheckReceiveStatusText, | 
|---|
|  |  |  | EnumTaskCheckReceiveMethod, | 
|---|
|  |  |  | } from '@12333/constants'; | 
|---|
|  |  |  | import { CheckInOrOutEventEnum } from '../constants'; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | defineOptions({ | 
|---|
|  |  |  | name: 'TaskCheckCard', | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | type Props = { | 
|---|
|  |  |  | avatarUrl?: string; | 
|---|
|  |  |  | avatar?: string; | 
|---|
|  |  |  | name?: string; | 
|---|
|  |  |  | genderType?: Gender; | 
|---|
|  |  |  | isRealName?: boolean; | 
|---|
|  |  |  | contactPhone?: string; | 
|---|
|  |  |  | checkAcceptStatus?: API.FlexTaskCheckAcceptStatusEnum; | 
|---|
|  |  |  | gender?: EnumUserGender; | 
|---|
|  |  |  | isReal?: boolean; | 
|---|
|  |  |  | contactPhoneNumber?: string; | 
|---|
|  |  |  | checkReceiveStatus?: EnumTaskCheckReceiveStatus; | 
|---|
|  |  |  | /** 签到时间 */ | 
|---|
|  |  |  | checkInTime?: string; | 
|---|
|  |  |  | /** 签出时间 */ | 
|---|
|  |  |  | checkOutTime?: string; | 
|---|
|  |  |  | checkReceiveMethod?: EnumTaskCheckReceiveMethod; | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const props = withDefaults(defineProps<Props>(), {}); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const emit = defineEmits<{ | 
|---|
|  |  |  | (e: 'checkReceive'): void; | 
|---|
|  |  |  | (e: 'checkInOrOut', ev: CheckInOrOutEventEnum): void; | 
|---|
|  |  |  | }>(); | 
|---|
|  |  |  | </script> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <style lang="scss"> | 
|---|