| | |
| | | <el-col :xs="22" :sm="23"> |
| | | <el-row type="flex"> |
| | | <el-col class="flex_column" :xs="5" :sm="3"> |
| | | <img class="avator" :src="agentInfo.img" alt=""> |
| | | <div class="star">{{agentInfo.satisfaction}}</div> |
| | | </el-col> |
| | | <el-col class="flex_column" :xs="10" :sm="15"> |
| | | <div class="smTxt_bold name">{{agentInfo.name}}</div> |
| | | <div class="tagStyle"> |
| | | <span |
| | | class="tagTxt" |
| | | v-for="(tag, index) in agentInfo.tags" :key="index">#{{tag}}</span> |
| | | <UiAvatar |
| | | :size="50" |
| | | :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> |
| | | <div class="delete" @click="removeAgent">移除</div> |
| | | </el-col> |
| | | <el-col :xs="10" :sm="15"> |
| | | <div class="smTxt_bold name">{{agentInfo.name}}</div> |
| | | <div class="professionals"> |
| | | <span |
| | | class="professionalsTxt" |
| | | v-for="(expertise, index) in expertises" |
| | | :key="index" |
| | | >#{{expertise}}</span> |
| | | </div> |
| | | <div |
| | | class="delete" |
| | | v-if="agentInfo.contactStatus === 'picked' |
| | | || !agentInfo.contactStatus" |
| | | @click="removeAgent" |
| | | >移除</div> |
| | | </el-col> |
| | | <el-col class="flex_column" :xs="9" :sm="6"> |
| | | <el-button |
| | | class="smTxt_bold outline_btn" |
| | | @click="reserveCommunication" |
| | | :class="{'reservedBtn': agentInfo.reserve}" |
| | | >{{ agentInfo.reserve ? '已預約' : '進行預約'}}</el-button> |
| | | <div class="time">今天 10:00 加入</div> |
| | | :class="agentInfo.contactStatus + 'Btn'" |
| | | >{{ contactTxt }}</el-button> |
| | | <div class="updateTime" v-if="updateTime">{{updateTime | formatDate}}</div> |
| | | </el-col> |
| | | </el-row> |
| | | </el-col> |
| | | </el-row> |
| | | |
| | | <Ui-Dialog |
| | | :isVisible.sync="isVisibleDialog" |
| | | :width="width" |
| | | > |
| | | <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, Watch } from 'nuxt-property-decorator'; |
| | | import { Agents } from '~/plugins/api/home'; |
| | | 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 |
| | | export default class ConsultantCard extends Vue { |
| | | @Prop() agentInfo!: Agents; |
| | | |
| | | reserveCommunication() { |
| | | if (!this.agentInfo.reserve) { |
| | | this.$router.push('/communication/myDemand') |
| | | @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; |
| | | } |
| | | |
| | | @Emit('removeAgent') removeAgent() { |
| | | return this.agentInfo.id; |
| | | 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 '已聯絡' |
| | | } |
| | | 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)); |
| | | return contactList.filter(item => !!item) |
| | | } |
| | | reserveCommunication() { |
| | | const contactStatus = this.agentInfo.contactStatus; |
| | | 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; |
| | | }); |
| | | } |
| | | |
| | | removeAgent() { |
| | | this.removeFromMyConsultantList(this.agentInfo.agentNo).then((removeOk) => { |
| | | console.log('removeOk?', removeOk); |
| | | }); |
| | | } |
| | | |
| | | showAgentDetail(agentNo: string): void { |
| | | this.$router.push(`/agentInfo/${agentNo}`); |
| | | } |
| | | } |
| | | </script> |
| | |
| | | margin: auto 0; |
| | | } |
| | | |
| | | .avator { |
| | | width: 50px; |
| | | height: 50px; |
| | | border-radius: 50px ; |
| | | } |
| | | |
| | | .star { |
| | | .satisfaction { |
| | | font-size: 12px; |
| | | font-weight: bold; |
| | | |
| | | &:before { |
| | | content: '\2605'; |
| | | color: $PRIMARY_RED; |
| | | margin: 5px; |
| | | } |
| | | margin-top: 5px; |
| | | } |
| | | |
| | | .tagStyle { |
| | | .professionals { |
| | | height: 20px; |
| | | overflow: hidden; |
| | | white-space: nowrap; |
| | | text-overflow: ellipsis; |
| | | .tagTxt { |
| | | margin: 5px 0 10px 0; |
| | | |
| | | .professionalsTxt { |
| | | font-size: 12px; |
| | | font-weight: bold; |
| | | margin-right: 5px; |
| | |
| | | |
| | | .reservedBtn { |
| | | color: $SKY_BLUE; |
| | | cursor: auto; |
| | | border-color: $SKY_BLUE; |
| | | |
| | | &:hover { |
| | | color: $SKY_BLUE; |
| | | border-color: $SKY_BLUE; |
| | | background-color: $PRIMARY_WHITE; |
| | | &:focus { |
| | | color: $PRIMARY_WHITE; |
| | | background-color: $SKY_BLUE; |
| | | opacity: 0.5; |
| | | } |
| | | } |
| | | |
| | | .time { |
| | | .contactedBtn { |
| | | color: $GREEN; |
| | | border-color: $GREEN; |
| | | |
| | | &:focus { |
| | | color: $PRIMARY_WHITE; |
| | | background-color: $GREEN; |
| | | opacity: 0.5; |
| | | } |
| | | } |
| | | |
| | | .updateTime { |
| | | font-size: 12px; |
| | | font-weight: bold; |
| | | color: #707070; |
| | |
| | | justify-content: space-between; |
| | | } |
| | | |
| | | </style> |
| | | .dialogInfo { |
| | | font-size: 20px; |
| | | } |
| | | |
| | | </style> |