| | |
| | | </div> |
| | | |
| | | </el-dialog> |
| | | |
| | | <PopUpFrame |
| | | :isOpen.sync="isShowSuccessAlert"> |
| | | <div class="text--middle invite-review"> |
| | | <div class="mb-30 mt-10">已發送約訪通知</div> |
| | | <div class="text--primary text--middle cursor--pointer text--underline" @click="closeAllDialog " :size="'250px'">我知道了</div> |
| | | </div> |
| | | </PopUpFrame> |
| | | </div> |
| | | </template> |
| | | <script lang="ts"> |
| | | import { Vue, Component, Prop, PropSync, Emit } from 'nuxt-property-decorator'; |
| | | import { Vue, Component, Prop, PropSync, Emit, namespace } from 'nuxt-property-decorator'; |
| | | |
| | | import appointmentService from '~/shared/services/appointment.service'; |
| | | import { Appointment, ToInformAppointment } from '~/shared/models/appointment.model'; |
| | | import { ContactStatus } from '~/shared/models/enum/contact-status'; |
| | | |
| | | const appointmentStore = namespace('appointment.store'); |
| | | |
| | | @Component |
| | | export default class InterviewMsg extends Vue { |
| | | |
| | | @appointmentStore.Action |
| | | getMyAppointmentList!: () => Promise<Appointment[]>; |
| | | |
| | | |
| | | @appointmentStore.Action |
| | | updateMyAppointmentList!:(appointment: Appointment) => Appointment[]; |
| | | |
| | | @appointmentStore.Action |
| | | updateAppointmentDetail!: (appointmentId: number) => Promise<Appointment>; |
| | | |
| | | @appointmentStore.State |
| | | appointmentDetail!: Appointment; |
| | | |
| | | @PropSync('isVisible') |
| | | dialogVisible!: boolean; |
| | | |
| | |
| | | return; |
| | | } |
| | | |
| | | interviewTxt = ""; |
| | | interviewTime = ''; |
| | | interviewTime = ''; |
| | | interviewTxt = ''; |
| | | isShowSuccessAlert = false; |
| | | |
| | | contactStatus = ContactStatus; |
| | | |
| | | ////////////////////////////////////////////////////////////////////// |
| | | |
| | |
| | | message : this.interviewTxt, |
| | | phone : this.client?.phone, |
| | | }; |
| | | |
| | | appointmentService.informAppointment(appointmentInformation).then((_) => { |
| | | // TODO: close dialog after confirm success msg drawer (assign to Helen)[Tomas, 2022/1/17 11:21]; |
| | | this.dialogVisible = false; |
| | | this.isShowSuccessAlert = true ; |
| | | const updatedAppointment = { |
| | | ...this.appointmentDetail, |
| | | communicateStatus: this.contactStatus.CONTACTED, |
| | | }; |
| | | this.updateMyAppointmentList(updatedAppointment); |
| | | this.updateAppointmentDetail(updatedAppointment.id); |
| | | }); |
| | | } |
| | | |
| | | closeAllDialog() { |
| | | this.isShowSuccessAlert = false ; |
| | | this.dialogVisible = false; |
| | | this.getMyAppointmentList(); |
| | | } |
| | | |
| | | } |
| | |
| | | display: flex; |
| | | justify-content: center; |
| | | } |
| | | |
| | | .invite-review{ |
| | | display: flex; |
| | | flex-direction: column; |
| | | align-items: center; |
| | | } |
| | | </style> |