| | |
| | | <el-col :xs="22" :sm="23"> |
| | | <el-row type="flex"> |
| | | <el-col class="flex_column" :xs="5" :sm="3"> |
| | | <el-avatar |
| | | <UiAvatar |
| | | :size="50" |
| | | :src="agentInfo.img" |
| | | class="cursor--pointer" |
| | | @click.native="showAgentDetail(agentInfo.agentNo);" |
| | | ></el-avatar> |
| | | :fileName="avatarFileName" |
| | | @click.native="showAgentDetail(agentInfo.agentNo)" |
| | | ></UiAvatar> |
| | | <div class="satisfaction"> |
| | | <i class="icon-star pam-icon icon--yellow satisfaction"></i> |
| | | <span>{{agentInfo.avgScore }}</span> |
| | |
| | | <div class="professionals"> |
| | | <span |
| | | class="professionalsTxt" |
| | | v-for="(expertise, index) in agentInfo.expertise" |
| | | v-for="(expertise, index) in expertises" |
| | | :key="index" |
| | | >#{{expertise}}</span> |
| | | </div> |
| | | <div |
| | | class="delete" |
| | | v-if="agentInfo.contactStatus !== 'reserved' |
| | | || agentInfo.contactStatus !== 'contacted'" |
| | | v-if="agentInfo.contactStatus === 'picked' |
| | | || !agentInfo.contactStatus" |
| | | @click="removeAgent" |
| | | >移除</div> |
| | | </el-col> |
| | |
| | | @click="reserveCommunication" |
| | | :class="agentInfo.contactStatus + 'Btn'" |
| | | >{{ contactTxt }}</el-button> |
| | | <div class="updateTime">{{updateTime}}</div> |
| | | <div class="updateTime" v-if="updateTime">{{updateTime | formatDate}}</div> |
| | | </el-col> |
| | | </el-row> |
| | | </el-col> |
| | |
| | | :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> |
| | | </template> |
| | | |
| | | <script lang="ts"> |
| | | import { Vue, Component, Prop, Emit } from 'nuxt-property-decorator'; |
| | | import { Consultants } from '~/assets/ts/api/consultant'; |
| | | import { Vue, Component, Prop, Emit, Action } from 'nuxt-property-decorator'; |
| | | import { Consultants, getAppointmentDetail } from '~/assets/ts/api/consultant'; |
| | | import { AppointmentDetail } from '~/assets/ts/models/AppointmentDetail'; |
| | | 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 { |
| | | @Action removeFromMyConsultantList!: (agentNo: string) => Promise<boolean>; |
| | | |
| | | @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 avatarFileName() { |
| | | return this.agentInfo.img ? this.agentInfo.img : this.agentInfo.image; |
| | | } |
| | | |
| | | get expertises() { |
| | | return this.agentInfo.expertise ? this.agentInfo.expertise : this.agentInfo.expertises; |
| | | } |
| | | 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() { |
| | | const newDate = new Date(this.agentInfo.updateTime); |
| | | let year = newDate.getFullYear(); |
| | | let month = newDate.getMonth() + 1; |
| | | let date = newDate.getDate(); |
| | | let hours = newDate.getHours(); |
| | | let minutes = newDate.getMinutes(); |
| | | return isLogin() ? `${year}/${month}/${date} ${hours} : ${minutes}` : '' |
| | | return isLogin() ? this.agentInfo.updateTime : ''; |
| | | } |
| | | |
| | | get hopeContactTime() { |
| | | const contactList = this.appointmentDetail.hopeContactTime |
| | | .split("'").map(item => item.slice(0, item.length)); |
| | | 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.width = isMobileDevice() ? '80%' : ''; |
| | | this.isVisibleDialog = true; |
| | | this.openPopUp(); |
| | | } |
| | | } |
| | | |
| | | @Emit('removeAgent') removeAgent() { |
| | | return this.agentInfo.agentNo; |
| | | openPopUp() { |
| | | getAppointmentDetail(this.agentInfo.latestAppointmentId).then(res => { |
| | | this.appointmentDetail = res.data; |
| | | this.width = isMobileDevice() ? '80%' : ''; |
| | | this.isVisibleDialog = true; |
| | | }); |
| | | } |
| | | |
| | | removeAgent() { |
| | | this.removeFromMyConsultantList(this.agentInfo.agentNo).then((removeOk) => { |
| | | console.log('removeOk?', removeOk); |
| | | }); |
| | | } |
| | | |
| | | showAgentDetail(agentNo: string): void { |
| | |
| | | font-size: 20px; |
| | | } |
| | | |
| | | </style> |
| | | </style> |