| | |
| | | :isVisible.sync="isVisibleDialog" |
| | | :width="width" |
| | | > |
| | | <h5 class="subTitle text--center mb-30">預約成功</h5> |
| | | <p class="smTxt">今天 10:00</p> |
| | | <div class="dialogInfo"> |
| | | <p>姓名:王聰明</p> |
| | | <p>電話:0912345678</p> |
| | | <p>Email:</p> |
| | | <p>性別 :男性</p> |
| | | <p>年齡:26-30</p> |
| | | <p>職業:一般職業</p> |
| | | <p>需求:保單健檢/規劃、紅利保單相關</p> |
| | | <p>連絡時段一:星期一,星期日 18:00~21:00</p> |
| | | <div v-if="appointmentDetail"> |
| | | <h5 class="subTitle text--center mb-30">預約成功</h5> |
| | | <p class="smTxt">{{appointmentDetail.appointmentDate | formatDate}}</p> |
| | | <div class="dialogInfo"> |
| | | <p>姓名:{{appointmentDetail.name}}</p> |
| | | <p>電話:{{appointmentDetail.phone}}</p> |
| | | <p>Email:{{appointmentDetail.email}}</p> |
| | | <p>性別:{{gender}}</p> |
| | | <p>年齡:{{appointmentDetail.age}}</p> |
| | | <p>職業:{{appointmentDetail.job}}</p> |
| | | <p>需求:{{appointmentDetail.requirement.replace(',', '、')}}</p> |
| | | <p |
| | | v-for="(item, index) in hopeContactTime" |
| | | :key="index" |
| | | >連絡時段{{index + 1 | formatNumber}}:{{item}}</p> |
| | | </div> |
| | | </div> |
| | | </Ui-Dialog> |
| | | </div> |
| | |
| | | |
| | | <script lang="ts"> |
| | | import { Vue, Component, Prop, Emit } from 'nuxt-property-decorator'; |
| | | import { Consultants } from '~/assets/ts/api/consultant'; |
| | | import { AppointmentDetail, Consultants, getAppointmentDetail } from '~/assets/ts/api/consultant'; |
| | | import { isLogin } from '~/assets/ts/auth'; |
| | | import { isMobileDevice } from '~/assets/ts/device'; |
| | | |
| | | @Component |
| | | @Component({ |
| | | filters: { |
| | | formatNumber(index: number) { |
| | | if (index) { |
| | | const upperNumber = ['零', '一', '二', '三', '四', '五', '六', '七', '八', '九', '十'] |
| | | return upperNumber[index]; |
| | | } |
| | | } |
| | | } |
| | | }) |
| | | export default class ConsultantCard extends Vue { |
| | | @Prop() agentInfo!: Consultants; |
| | | isVisibleDialog = false; |
| | | width: string = ''; |
| | | appointmentDetail: AppointmentDetail = { |
| | | id: 0, |
| | | phone: '', |
| | | email: '', |
| | | contactType: '', |
| | | gender: '', |
| | | age: '', |
| | | job: '', |
| | | requirement: '', |
| | | communicateStatus: '', |
| | | hopeContactTime: '', |
| | | otherRequirement: '', |
| | | appointmentDate: new Date(), |
| | | agentNo: '', |
| | | customerId: 0, |
| | | name: '' |
| | | }; |
| | | |
| | | get gender() { |
| | | if (this.appointmentDetail.gender) { |
| | | return this.appointmentDetail.gender === 'male' ? '男性' : '女性'; |
| | | } |
| | | return '' |
| | | } |
| | | get contactTxt() { |
| | | if (this.agentInfo.contactStatus === 'contacted') { |
| | | return '已聯絡' |
| | | } else if (this.agentInfo.contactStatus === 'reserved') { |
| | | return '已預約' |
| | | } else { |
| | | return '進行預約' |
| | | } |
| | | if (this.agentInfo.contactStatus === 'reserved') { |
| | | return '已預約' |
| | | } |
| | | return '進行預約' |
| | | } |
| | | |
| | | get updateTime() { |
| | | return isLogin() ? this.agentInfo.updateTime : ''; |
| | | } |
| | | |
| | | get hopeContactTime() { |
| | | const contactList = this.appointmentDetail.hopeContactTime |
| | | .split("'").map(item => item.slice(0, item.length - 1)); |
| | | return contactList.filter(item => !!item) |
| | | } |
| | | reserveCommunication() { |
| | | const contactStatus = this.agentInfo.contactStatus; |
| | | if (contactStatus !== 'reserved' && contactStatus !== 'contacted') { |
| | | isLogin() ? this.$router.push(`/questionnaire/${this.agentInfo.agentNo}`) : this.$router.push('/login'); |
| | | if (!contactStatus || contactStatus === 'picked') { |
| | | isLogin() |
| | | ? this.$router.push(`/questionnaire/${this.agentInfo.agentNo}`) |
| | | : this.$router.push('/login'); |
| | | } else { |
| | | this.openPopUp(); |
| | | } |
| | | } |
| | | |
| | | openPopUp() { |
| | | getAppointmentDetail(this.agentInfo.latestAppointmentId).then(res => { |
| | | this.appointmentDetail = res.data; |
| | | this.width = isMobileDevice() ? '80%' : ''; |
| | | this.isVisibleDialog = true; |
| | | } |
| | | }); |
| | | } |
| | | |
| | | @Emit('removeAgent') removeAgent() { |
| | |
| | | font-size: 20px; |
| | | } |
| | | |
| | | </style> |
| | | </style> |