simpo-component-library 3.6.500 → 3.6.501
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/ecommerce/sections/verify-payment/verify-payment.component.mjs +47 -1
- package/esm2022/lib/sections/appointment-form/appointment-booking/appointment-booking/appointment-booking.component.mjs +3 -2
- package/esm2022/lib/services/rest.service.mjs +4 -1
- package/fesm2022/simpo-component-library.mjs +51 -1
- package/fesm2022/simpo-component-library.mjs.map +1 -1
- package/lib/ecommerce/sections/authentication-required/authentication-required.component.d.ts +1 -1
- package/lib/ecommerce/sections/product-desc/product-desc.component.d.ts +1 -1
- package/lib/ecommerce/sections/schemes/schemes.component.d.ts +1 -1
- package/lib/ecommerce/sections/verify-payment/verify-payment.component.d.ts +2 -0
- package/lib/elements/link-editor/link-editor.component.d.ts +1 -1
- package/lib/sections/pricing-section/pricing-section.component.d.ts +1 -1
- package/lib/services/rest.service.d.ts +1 -0
- package/package.json +1 -1
- package/simpo-component-library-3.6.501.tgz +0 -0
@@ -416,7 +416,8 @@ export class AppointmentBookingComponent {
|
|
416
416
|
this.appointmentPayload.startTime = this.selectedTime.value.slice(0, 5);
|
417
417
|
this.appointmentPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;
|
418
418
|
this.restService.paymentForAppointment(this.appointmentPayload).subscribe((res) => {
|
419
|
-
this._eventService.cashFreeEvent.emit({ data: { orderSignature: res.
|
419
|
+
this._eventService.cashFreeEvent.emit({ data: { orderSignature: res.orderSignature } });
|
420
|
+
localStorage.setItem('appointmentPaymentId', res.pgOrderId);
|
420
421
|
}, (error) => {
|
421
422
|
this.loader = false;
|
422
423
|
this.messageService.add({ severity: 'error', summary: 'Payment Failed', detail: error.message });
|
@@ -449,4 +450,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
449
450
|
type: HostListener,
|
450
451
|
args: ['document:click']
|
451
452
|
}] } });
|
452
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"appointment-booking.component.js","sourceRoot":"","sources":["../../../../../../../../projects/simpo-ui/src/lib/sections/appointment-form/appointment-booking/appointment-booking/appointment-booking.component.ts","../../../../../../../../projects/simpo-ui/src/lib/sections/appointment-form/appointment-booking/appointment-booking/appointment-booking.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, Input } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CdkDragPlaceholder } from \"@angular/cdk/drag-drop\";\r\nimport { MatIcon } from \"@angular/material/icon\";\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatFormFieldModule } from \"@angular/material/form-field\";\r\nimport { MatDatepickerModule } from \"@angular/material/datepicker\";\r\nimport { MatNativeDateModule } from '@angular/material/core';\r\nimport { RestService } from '../../../../services/rest.service';\r\nimport { EventsService } from '../../../../services/events.service';\r\nimport { Router } from '@angular/router';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { BannerContentModel, BannerSectionModel } from '../../appointment-form.model';\r\nimport { BackgroundModel, BannerStylesModel } from '../../../../styles/style.model';\r\nimport { LettersOnlyDirective } from '../../../../directive/letters-only.directive';\r\nimport { NumbersOnlyDirective } from '../../../../directive/numbers-only.directive';\r\nimport { ToastModule } from \"primeng/toast\";\r\nimport { MessageService } from 'primeng/api';\r\n@Component({\r\n  selector: 'simpo-appointment-booking',\r\n  standalone: true,\r\n  imports: [CdkDragPlaceholder, CommonModule, MatIcon, MatFormFieldModule, MatDatepickerModule, FormsModule, MatNativeDateModule, MatInputModule, LettersOnlyDirective, NumbersOnlyDirective, ToastModule],\r\n  providers: [MessageService],\r\n  templateUrl: './appointment-booking.component.html',\r\n  styleUrl: './appointment-booking.component.css'\r\n})\r\nexport class AppointmentBookingComponent {\r\n  constructor(\r\n    private restService: RestService,\r\n    private _eventService: EventsService,\r\n    private readonly router: Router,\r\n    private readonly messageService: MessageService\r\n  ) {\r\n\r\n  }\r\n  @Input() data?: BannerSectionModel;\r\n  @Input() index?: number;\r\n  content?: BannerContentModel;\r\n  @Input() edit?: boolean;\r\n  @Input() delete?: boolean;\r\n  @Input() customClass?: string;\r\n  @Input() nextComponentColor?: BackgroundModel;\r\n  styles?: BannerStylesModel;\r\n  ngOnInit() {\r\n    this.getAllServices();\r\n    this.getScreenSize();\r\n  }\r\n  screenWidth: number = 0;\r\n  @HostListener(\"window: resize\", [\"$event\"])\r\n  getScreenSize() {\r\n    this.screenWidth = window.innerWidth;\r\n  }\r\n  @HostListener('document:click')\r\n  closeOnOutsideClick() {\r\n    this.showCalendar = false;\r\n  }\r\n  accessedTabs = {\r\n    serviceListing: false,\r\n    locationListing: false,\r\n    staffListing: false\r\n  }\r\n\r\n  businessName = localStorage.getItem('bName') ?? \"24K Bazaar\";\r\n  businessId: string = localStorage.getItem('bId') ?? \"1f095216-7c00-6cab-9045-ff9c70e1c641\";\r\n  activeButton: boolean = false;\r\n  selectedTab: string = '';\r\n  barWidth: string = '';\r\n  showCancellationPolicy: boolean = false;\r\n  showReducingPolicy: boolean = false;\r\n  selectedService: any = {};\r\n  selectedLocation: any;\r\n  Object = Object;\r\n  showCalendar = false;\r\n  selectedDate: Date | null = null;\r\n  selectedDateStr = '';\r\n  userDetails = {\r\n    name: '',\r\n    email: '',\r\n    mobileNumber: ''\r\n  }\r\n  dateFilter = (d: Date | null): boolean => {\r\n    const date = (d || new Date());\r\n    const today = new Date();\r\n    today.setHours(0, 0, 0, 0);\r\n    return date.getTime() >= today.getTime();\r\n  }\r\n  toggleCalendar(event?: Event) {\r\n    if (event) event.stopPropagation();\r\n    this.showCalendar = !this.showCalendar;\r\n  }\r\n\r\n  onDateSelected(date: any) {\r\n    this.selectedTime = {};\r\n    this.activeButton = false;\r\n    this.selectedDate = date;\r\n    this.selectedDateStr = this.formatDate(date);\r\n    this.showCalendar = false;\r\n    this.getAvailableSlots();\r\n  }\r\n  private formatDate(d: Date): string {\r\n    const dd = String(d.getDate()).padStart(2, '0');\r\n    const mm = String(d.getMonth() + 1).padStart(2, '0');\r\n    const yyyy = d.getFullYear();\r\n    return `${dd}-${mm}-${yyyy}`;\r\n  }\r\n\r\n  selectService(service: any) {\r\n    service.selected = true;\r\n    if (this.selectedService) {\r\n      this.selectedService.selected = false;\r\n    }\r\n    this.selectedService = service\r\n    this.activeButton = this.selectedService ? true : false;\r\n  }\r\n  selectLocation(location: any) {\r\n    location.selected = true;\r\n    if (this.selectedLocation) {\r\n      this.selectedLocation.selected = false;\r\n    }\r\n    this.activeButton = true;\r\n    this.selectedLocation = location;\r\n  }\r\n  selectedStaff: any;\r\n  selectStaff(staff: any) {\r\n    this.selectedStaff = staff;\r\n    this.activeButton = true;\r\n  }\r\n  nextStep() {\r\n    if (this.selectedTab === 'serviceListing') {\r\n      this.activeButton = this.selectedLocation ? true : false;\r\n      this.accessedTabs.serviceListing = true;\r\n      if (!this.activeButton) {\r\n        this.getAllLocations();\r\n      }\r\n      else {\r\n        if (this.accessedTabs.locationListing) {\r\n          this.selectedTab = 'locationListing';\r\n          this.barWidth = '29.28';\r\n        }\r\n        else if (this.accessedTabs.staffListing) {\r\n          this.selectedTab = 'staffListing';\r\n          this.barWidth = '43.57';\r\n        }\r\n        else {\r\n          this.selectedTab = 'dateSelection';\r\n          this.barWidth = '58.57';\r\n        }\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'locationListing') {\r\n      this.activeButton = this.selectedStaff ? true : false;\r\n      this.accessedTabs.locationListing = true;\r\n      if (!this.activeButton) {\r\n        this.getAllStaff();\r\n\r\n      }\r\n      else {\r\n        if (this.accessedTabs.staffListing) {\r\n          this.selectedTab = 'staffListing';\r\n          this.barWidth = '43.57';\r\n        }\r\n        else {\r\n          this.selectedTab = 'dateSelection';\r\n          this.barWidth = '58.57';\r\n        }\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'staffListing') {\r\n      this.accessedTabs.staffListing = true;\r\n      this.selectedTab = 'dateSelection';\r\n      this.barWidth = '58.57';\r\n      if (!this.activeButton)\r\n        this.getAvailableSlots();\r\n    }\r\n    else if (this.selectedTab === 'dateSelection') {\r\n      this.activeButton = this.appointmentPayload.customerDetail.name && this.appointmentPayload.customerDetail.email && this.appointmentPayload.customerDetail.phoneNumber.length === 10 ? true : false\r\n      this.selectedTab = 'contactDetails';\r\n      this.barWidth = '70.57'\r\n    }\r\n    else if (this.selectedTab === 'contactDetails') {\r\n      this.checkRequiredValues();\r\n      this.selectedTab = 'paymentTab';\r\n      this.barWidth = '85.57'\r\n    }\r\n  }\r\n  previousStep() {\r\n    this.activeButton = true;\r\n    if (this.selectedTab === 'locationListing') {\r\n      if (this.accessedTabs.serviceListing) {\r\n        this.selectedTab = 'serviceListing';\r\n        this.barWidth = '14.28';\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'staffListing') {\r\n      if (this.accessedTabs.locationListing) {\r\n        this.selectedTab = 'locationListing';\r\n        this.barWidth = '29.28';\r\n      }\r\n      else if (this.accessedTabs.serviceListing) {\r\n        this.selectedTab = 'serviceListing';\r\n        this.barWidth = '14.28';\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'dateSelection') {\r\n      if (this.accessedTabs.staffListing) {\r\n        this.selectedTab = 'staffListing';\r\n        this.barWidth = '43.57';\r\n      }\r\n      else if (this.accessedTabs.locationListing) {\r\n        this.selectedTab = 'locationListing';\r\n        this.barWidth = '29.28';\r\n      }\r\n      else if (this.accessedTabs.serviceListing) {\r\n        this.selectedTab = 'serviceListing';\r\n        this.barWidth = '14.28';\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'contactDetails') {\r\n      this.selectedTab = 'dateSelection';\r\n      this.barWidth = '58.57'\r\n    }\r\n    else if (this.selectedTab === 'paymentTab') {\r\n      this.selectedTab = 'contactDetails';\r\n      this.barWidth = '70.57';\r\n    }\r\n  }\r\n  serviceData: any[] = [];\r\n  getAllServices() {\r\n    let servicePayload: any = {\r\n      businessId: this.businessId ?? \"\",\r\n      pageNo: 0,\r\n      size: 100\r\n    }\r\n    this.restService.getAllAppointmentService(servicePayload).subscribe(\r\n      (res: any) => {\r\n        if (res.content.length > 0) {\r\n          this.serviceData = res.content.filter((service: any) => service.active === true);\r\n          this.serviceData.forEach(service => service.selected = false);\r\n          // console.log(this.serviceData)\r\n          if (this.serviceData.length === 1 && !this.activeButton) {\r\n            this.selectedService = this.serviceData[0];\r\n            this.getAllLocations();\r\n          }\r\n          else {\r\n            this.selectedTab = 'serviceListing';\r\n            this.barWidth = '14.28';\r\n          }\r\n        }\r\n      },\r\n      (error) => {\r\n        // Handle errors gracefully\r\n      }\r\n    );\r\n  }\r\n  locationData: any[] = [];\r\n  getAllLocations() {\r\n    this.loader = true;\r\n    this.locationData = [];\r\n    let payload = { businessId: this.businessId ?? \"\" }\r\n    this.restService.getAllStores(payload).subscribe(\r\n      (res: any) => {\r\n        if (res.data.data.length > 0) {\r\n          let locations = res.data.data.filter((store: any) => { return store.status === 'ACTIVE' });\r\n          locations.forEach((location: any) => {\r\n            if (this.selectedService.storeIds.includes(location.id)) {\r\n              location.selected = false;\r\n              this.locationData.push(location);\r\n            }\r\n          })\r\n          if (this.locationData.length === 1 && !this.activeButton) {\r\n            this.selectedLocation = this.locationData[0];\r\n            this.loader = false;\r\n            this.getAllStaff();\r\n          }\r\n          else {\r\n            this.loader = false;\r\n            this.selectedTab = 'locationListing';\r\n            this.barWidth = '29.28';\r\n          }\r\n        }\r\n      },\r\n      (error) => {\r\n        // Handle errors gracefully\r\n      }\r\n    );\r\n  }\r\n  staffPayload: any = {\r\n    serviceId: '',\r\n    storeId: '',\r\n    businessId: ''\r\n  }\r\n  staffData: any[] = [];\r\n  getAllStaff() {\r\n    this.loader = true;\r\n    this.staffPayload.storeId = this.selectedLocation?.id ?? \"\";\r\n    this.staffPayload.serviceId = this.selectedService?.serviceId ? this.selectedService.serviceId : '';\r\n    this.staffPayload.businessId = this.businessId ?? \"\";\r\n    this.restService.getAllStaff(this.staffPayload).subscribe(\r\n      (res: any) => {\r\n        if (res.length > 0) {\r\n          this.staffData = res.filter((staff: any) => staff.active === true);\r\n          if (this.staffData.length === 1 && !this.activeButton) {\r\n            this.loader = false;\r\n            this.selectedTab = 'dateSelection';\r\n            this.barWidth = '58.57';\r\n            this.selectedStaff = this.staffData[0];\r\n            this.getAvailableSlots();\r\n          }\r\n          else if (this.staffData.length > 1) {\r\n            this.loader = false;\r\n            this.selectedTab = 'staffListing';\r\n            this.barWidth = '43.57';\r\n          }\r\n        }\r\n      },\r\n      (error) => {\r\n        // Handle errors gracefully\r\n      }\r\n    );\r\n  }\r\n  convertTo24Hour(time: string): string {\r\n    const [hourMin, modifierRaw] = time.split(' ');\r\n    const modifier = modifierRaw.toUpperCase(); // \"AM\" or \"PM\"\r\n    let [hours, minutes] = hourMin.split(':').map(Number);\r\n\r\n    if (modifier === 'PM' && hours < 12) {\r\n      hours += 12;\r\n    }\r\n    if (modifier === 'AM' && hours === 12) {\r\n      hours = 0;\r\n    }\r\n\r\n    const hh = hours.toString().padStart(2, '0');\r\n    const mm = minutes.toString().padStart(2, '0');\r\n    return `${hh}:${mm} ${modifier}`;\r\n  }\r\n  slotsPayload: any = {\r\n    storeId: \"\",\r\n    serviceId: \"\",\r\n    businessId: \"\",\r\n    bookingDate: \"\"\r\n  }\r\n  locationTiming: any[] = [];\r\n  loader: boolean = false;\r\n  getAvailableSlots() {\r\n    this.loader = false;\r\n    this.locationTiming = [];\r\n    this.slotsPayload.storeId = this.selectedLocation?.id ?? \"\";\r\n    this.slotsPayload.serviceId = this.selectedService?.serviceId ? this.selectedService.serviceId : '';\r\n    this.slotsPayload.businessId = this.businessId ?? \"\";\r\n    const date = this.selectedDate ?? new Date();\r\n    this.selectedDateStr = this.formatDate(date);\r\n    const yyyy = date.getFullYear();\r\n    const mm = String(date.getMonth() + 1).padStart(2, '0');\r\n    const dd = String(date.getDate()).padStart(2, '0');\r\n\r\n    this.slotsPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;\r\n\r\n    if (this.selectedStaff)\r\n      this.slotsPayload.staffId = this.selectedStaff.staffId;\r\n    this.restService.getBookingSlots(this.slotsPayload).subscribe((res: any) => {\r\n      res.forEach((time: any) => {\r\n        this.locationTiming.push({ selected: false, value: this.convertTo24Hour(time) });\r\n      })\r\n    })\r\n  }\r\n  selectedTime: any\r\n  selectTimeSlot(time: any) {\r\n    time.selected = true;\r\n    if (this.selectedTime) {\r\n      this.selectedTime.selected = false;\r\n    }\r\n    this.selectedTime = time;\r\n    this.activeButton = true;\r\n  }\r\n  checkRequiredValues() {\r\n    if (this.appointmentPayload.customerDetail.name && this.appointmentPayload.customerDetail.email && this.appointmentPayload.customerDetail.phoneNumber.length === 10) {\r\n      this.activeButton = true;\r\n      // console.log(this.selectedService, this.selectedLocation, this.selectedStaff, this.selectedDate, this.selectedTime, this.userDetails)\r\n    }\r\n    else {\r\n      this.activeButton = false;\r\n    }\r\n  }\r\n  appointmentPayload: any = {\r\n    staffDetail: {\r\n      id: '',\r\n      name: ''\r\n    },\r\n    bookingDate: '',\r\n    startTime: '',\r\n    customerDetail: {\r\n      name: '',\r\n      phoneNumber: '',\r\n      email: ''\r\n    },\r\n    serviceDetail: {\r\n      id: '',\r\n      name: ''\r\n    },\r\n    storeId: '',\r\n    businessId: this.businessId,\r\n    businessName: this.businessName\r\n  }\r\n  checkPayment() {\r\n    const request_form = localStorage.getItem(\"REQUEST_FROM\");\r\n    if (request_form === 'ECOMMERCE') {\r\n      this.createAppointment();\r\n    }\r\n    else {\r\n      if (this.selectedService?.depositAmount?.depositRequired) {\r\n        this.paymentBookingAppointment();\r\n      } else {\r\n        this.createAppointment();\r\n      }\r\n    }\r\n    // this.createAppointment();\r\n  }\r\n  apiStatus: boolean = false;\r\n  createAppointment() {\r\n    const date = this.selectedDate ?? new Date();\r\n    const yyyy = date.getFullYear();\r\n    const mm = String(date.getMonth() + 1).padStart(2, '0');\r\n    const dd = String(date.getDate()).padStart(2, '0');\r\n    this.appointmentPayload.staffDetail.id = this.selectedStaff.staffId;\r\n    this.appointmentPayload.staffDetail.name = this.selectedStaff.staffName;\r\n    this.appointmentPayload.storeId = this.selectedLocation.id;\r\n    this.appointmentPayload.serviceDetail.id = this.selectedService.serviceId;\r\n    this.appointmentPayload.serviceDetail.name = this.selectedService.name;\r\n    this.appointmentPayload.startTime = this.selectedTime.value.slice(0, 5);\r\n    this.appointmentPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;\r\n    this.restService.bookAppointmentV2(this.appointmentPayload).subscribe((res: any) => {\r\n      this.selectedTab = 'statusTemplate';\r\n      this.barWidth = '100';\r\n      this.apiStatus = true;\r\n    },\r\n      (error: any) => {\r\n        this.apiStatus = false;\r\n      }\r\n    )\r\n  }\r\n  paymentBookingAppointment() {\r\n    const date = this.selectedDate ?? new Date();\r\n    const yyyy = date.getFullYear();\r\n    const mm = String(date.getMonth() + 1).padStart(2, '0');\r\n    const dd = String(date.getDate()).padStart(2, '0');\r\n    this.appointmentPayload.staffDetail.id = this.selectedStaff.staffId;\r\n    this.appointmentPayload.staffDetail.name = this.selectedStaff.staffName;\r\n    this.appointmentPayload.storeId = this.selectedLocation.id;\r\n    this.appointmentPayload.serviceDetail.id = this.selectedService.serviceId;\r\n    this.appointmentPayload.serviceDetail.name = this.selectedService.name;\r\n    this.appointmentPayload.startTime = this.selectedTime.value.slice(0, 5);\r\n    this.appointmentPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;\r\n    this.restService.paymentForAppointment(this.appointmentPayload).subscribe(\r\n      (res: any) => {\r\n        this._eventService.cashFreeEvent.emit({ data: { orderSignature: res.pgOrderId } });\r\n      },\r\n      (error: any) => {\r\n        this.loader = false;\r\n        this.messageService.add({ severity: 'error', summary: 'Payment Failed', detail: error.message });\r\n      }\r\n    )\r\n\r\n  }\r\n  goBack() {\r\n  }\r\n}\r\n","<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"\r\n    [showTransformOptions]=\"screenWidth < 475 ? 'translateY(-100%)' : ''\"></p-toast>\r\n<section class=\"main_section\">\r\n    <div class=\"main_header\">\r\n        <div class=\"header d-flex justify-content-between align-items-center\">\r\n            <div class=\"back-btn d-flex justify-content-center align-items-center cursor-pointer gap-2 mb-3\"\r\n                (click)=\"goBack()\">\r\n                <mat-icon>keyboard_backspace</mat-icon><span *ngIf=\"screenWidth > 475\">Back to My Bookings</span>\r\n            </div>\r\n            <div class=\"header-title\">\r\n                <h1>Book New Appointment</h1>\r\n                <p>{{businessName ?? \"N/A\" }}</p>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"progress-bar\">\r\n            <div class=\"progress-fill\" [style.width]=\"barWidth + '%'\"></div>\r\n        </div>\r\n    </div>\r\n    <div class=\"main_body w-100 d-flex justify-content-center\"><ng-container *ngIf=\"selectedTab === 'serviceListing'\">\r\n            <ng-container *ngTemplateOutlet=\"serviceListing\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab === 'locationListing'\">\r\n            <ng-container *ngTemplateOutlet=\"locationListing\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab === 'staffListing'\">\r\n            <ng-container *ngTemplateOutlet=\"staffListing\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab === 'dateSelection'\">\r\n            <ng-container *ngTemplateOutlet=\"dateSelection\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab==='contactDetails'\">\r\n            <ng-container *ngTemplateOutlet=\"contactDetails\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab==='paymentTab'\">\r\n            <ng-container *ngTemplateOutlet=\"paymentTab\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab==='statusTemplate'\">\r\n            <ng-container *ngTemplateOutlet=\"statusTemplate\"></ng-container>\r\n        </ng-container>\r\n    </div>\r\n    <div class=\"main_footer d-flex justify-content-center align-items-center\" *ngIf=\"selectedTab!=='statusTemplate'\">\r\n        <div class=\"footer-buttons\">\r\n            <span class=\"back-footer-btn cursor-pointer\" (click)=\"previousStep()\">Back</span>\r\n            <button class=\"continue-btn\" [disabled]=\"!activeButton\" (click)=\"nextStep()\"\r\n                *ngIf=\"selectedTab!='paymentTab'\">{{!loader ? 'Continue' : 'Loading...'}}</button>\r\n            <button class=\"complete_booking cursor-pointer d-flex justify-content-evenly align-items-center\"\r\n                *ngIf=\"selectedTab==='paymentTab'\" (click)=\"checkPayment()\"><img\r\n                    src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/304012c1753440087996Background.png\">Complete\r\n                Booking</button>\r\n        </div>\r\n    </div>\r\n</section>\r\n<ng-template #serviceListing>\r\n    <div class=\"w-60 service_section\">\r\n        <div class=\"service-selection\">\r\n            <h2>Select a Service</h2>\r\n            <p>Choose the service you'd like to book</p>\r\n\r\n            <div class=\"services-grid\">\r\n                <ng-container *ngFor=\"let service of serviceData\">\r\n                    <div class=\"\" (click)=\"selectService(service)\"\r\n                        [ngClass]=\"{ 'service-card-selected' : service?.selected, 'service-card': !service?.selected }\">\r\n                        <div class=\" service-header\">\r\n                            <div class=\"service-icon\"><mat-icon>person_outline</mat-icon></div>\r\n                            <div class=\"service-info\">\r\n                                <div class=\"service-title\">{{service?.name ? service?.name : 'N/A'}}</div>\r\n                                <div class=\"service-category\">Wellness</div>\r\n                            </div>\r\n                            <div>\r\n                                <div class=\"service-price\">₹{{service?.priceDetails?.price ?\r\n                                    service?.priceDetails?.price : 'N/A' }}</div>\r\n                                <div class=\"service-duration\">{{service?.duration ? service?.duration : 'N/A'}} min\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div class=\"service-description\">\r\n                            {{service?.description ? service?.description : 'N/A'}}\r\n                        </div>\r\n                        <div class=\"home-visit\" *ngIf=\"service?.homeAppointmentAvailable\"><img\r\n                                src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/982126c1758628863129furniture_16406103.png\">Home\r\n                            Visit Available</div>\r\n                    </div>\r\n                </ng-container>\r\n\r\n                <!-- <div class=\"service-card\">\r\n                    <div class=\"service-header\">\r\n                        <div class=\"service-icon\">👤</div>\r\n                        <div class=\"service-info\">\r\n                            <div class=\"service-title\">General Consultation</div>\r\n                            <div class=\"service-category\">Medical</div>\r\n                        </div>\r\n                        <div>\r\n                            <div class=\"service-price\">₹800</div>\r\n                            <div class=\"service-duration\">30 min</div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"service-description\">\r\n                        Comprehensive health consultation\r\n                    </div>\r\n                </div>\r\n\r\n                <div class=\"service-card\">\r\n                    <div class=\"service-header\">\r\n                        <div class=\"service-icon\">🧠</div>\r\n                        <div class=\"service-info\">\r\n                            <div class=\"service-title\">Mental Health Counseling</div>\r\n                            <div class=\"service-category\">Mental Health</div>\r\n                        </div>\r\n                        <div>\r\n                            <div class=\"service-price\">₹1500</div>\r\n                            <div class=\"service-duration\">45 min</div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"service-description\">\r\n                        Professional psychological support\r\n                    </div>\r\n                    <div class=\"home-visit\">Home Visit Available</div>\r\n                </div>\r\n\r\n                <div class=\"service-card\">\r\n                    <div class=\"service-header\">\r\n                        <div class=\"service-icon\">✂</div>\r\n                        <div class=\"service-info\">\r\n                            <div class=\"service-title\">Hair Cut & Styling</div>\r\n                            <div class=\"service-category\">Beauty</div>\r\n                        </div>\r\n                        <div>\r\n                            <div class=\"service-price\">₹1200</div>\r\n                            <div class=\"service-duration\">45 min</div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"service-description\">\r\n                        Professional hair cutting and styling\r\n                    </div>\r\n                    <div class=\"home-visit\">Home Visit Available</div>\r\n                </div> -->\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #locationListing>\r\n    <div class=\"location_section\">\r\n        <div class=\"header flex-column align-items-start\">\r\n            <h1>Choose Location</h1>\r\n            <p>Select where you'd like to receive the service</p>\r\n        </div>\r\n\r\n        <div class=\"location-list\">\r\n            <ng-container *ngFor=\"let location of locationData\">\r\n                <div (click)=\"selectLocation(location)\"\r\n                    [ngClass]=\"{ 'location-card-selected' : location?.selected, 'location-card': !location?.selected }\">\r\n                    <div class=\"location-content\">\r\n                        <div class=\"location-info\">\r\n                            <div class=\"location-icon\"><img\r\n                                    src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/427226c1758629157758store_3171510.png\">\r\n                            </div>\r\n                            <div class=\"location-details\">\r\n                                <div class=\"d-flex justify-content-between align-items-center\">\r\n                                    <h3>{{location?.storeName ? location?.storeName : 'N/A'}}</h3>\r\n                                    <div class=\"distance\"><mat-icon>location_on</mat-icon> 2.3 km</div>\r\n                                </div>\r\n                                <p>{{location?.addressDetails?.addressLine}}, {{location?.addressDetails?.city}},\r\n                                    {{location?.addressDetails?.state}} {{location?.pincode}}</p>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </ng-container>\r\n            <!-- <div class=\"location-card\">\r\n                <div class=\"location-content\">\r\n                    <div class=\"location-info\">\r\n                        <div class=\"location-icon branch-icon\"></div>\r\n                        <div class=\"location-details\">\r\n                            <h3>Branch Clinic</h3>\r\n                            <p>456 Care Avenue, Health Zone, Mumbai 400015</p>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"distance\">5.8 km</div>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"location-card\">\r\n                <div class=\"location-content\">\r\n                    <div class=\"location-info\">\r\n                        <div class=\"location-icon home-icon\"></div>\r\n                        <div class=\"location-details\">\r\n                            <h3>Home Visit</h3>\r\n                            <p>Your Location</p>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"distance\">0 km</div>\r\n                </div>\r\n            </div> -->\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #staffListing>\r\n    <div class=\"w-60 overflow-hidden\">\r\n        <div class=\"d-flex w-100 h-100\">\r\n            <div class=\"w-100\">\r\n                <!-- Header Section -->\r\n                <div class=\"staff-header mb-3\">\r\n                    <h1 class=\"mb-1\">Select Staff Member</h1>\r\n                    <p class=\"staff-subtitle mb-0\">Choose your preferred professional</p>\r\n                </div>\r\n\r\n                <!-- Staff Cards -->\r\n                <div class=\"d-flex flex-column gap-4 staff-list\">\r\n                    <ng-container *ngFor=\"let staff of staffData\">\r\n                        <div class=\" staff-card card rounded-3 p-4\" (click)=\"selectStaff(staff)\">\r\n                            <div class=\"d-flex align-items-start justify-content-between\">\r\n                                <div class=\"d-flex align-items-start flex-grow-1\">\r\n                                    <div\r\n                                        class=\"staff-avatar rounded-circle d-flex align-items-center justify-content-center me-4\">\r\n                                        {{staff?.staffName.slice(0,3).toUpperCase()}}\r\n                                    </div>\r\n                                    <div class=\"staff-details flex-grow-1\">\r\n                                        <h3 class=\"staff-name\">{{staff?.staffName ? staff?.staffName : 'N/A'}}</h3>\r\n                                        <p class=\"staff-specialty\">General Medicine</p>\r\n                                        <p class=\"staff-description mb-0\">Experienced physician with 10+ years in\r\n                                            general\r\n                                            medicine and wellness care.</p>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"rating-section\">\r\n                                    <div class=\"star-rating d-flex align-items-center\">\r\n                                        <span class=\"star-icon\"></span>\r\n                                        <span class=\"rating-number\">4.9</span>\r\n                                    </div>\r\n                                    <div class=\"review-count\">156 reviews</div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </ng-container>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #dateSelection>\r\n    <div class=\"w-60 date_section\">\r\n        <div class=\"row justify-content-center h-100\">\r\n            <div class=\"col-12 h-100\">\r\n                <div class=\"datetime-header mb-2\">\r\n                    <h1 class=\"mb-3\">Select Date & Time</h1>\r\n                    <p class=\"datetime-subtitle mb-0\">Choose when you'd like your appointment</p>\r\n                </div>\r\n\r\n                <!-- Main Content -->\r\n                <div class=\"d-flex gap-4 main_container\">\r\n                    <!-- Left Column - Date Selection -->\r\n                    <div [ngClass]=\"{'w-50' : screenWidth > 475 , 'w-100':screenWidth < 475}\">\r\n                        <div class=\"section-card card rounded-3 p-4 h-100\">\r\n                            <h3 class=\"section-title\">Select Date</h3>\r\n\r\n                            <div class=\"date-picker-container d-flex align-items-center\"\r\n                                (click)=\"$event.stopPropagation()\">\r\n                                <input type=\"text\" class=\"form-control date-input border-0 rounded-2\"\r\n                                    placeholder=\"dd-mm-yyyy\" [value]=\"selectedDateStr\" readonly\r\n                                    (click)=\"toggleCalendar($event)\">\r\n\r\n                                <mat-icon class=\"ms-2\" (click)=\"toggleCalendar($event)\">calendar_today</mat-icon>\r\n                            </div>\r\n                            <div class=\"position-relative\" (click)=\"$event.stopPropagation()\">\r\n                                <div class=\"datepicker-popover\" *ngIf=\"showCalendar\">\r\n                                    <mat-calendar [(selected)]=\"selectedDate\" [dateFilter]=\"dateFilter\"\r\n                                        (selectedChange)=\"onDateSelected($event)\" class=\"datepicker-calendar\">\r\n                                    </mat-calendar>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n\r\n                    <!-- Right Column - Time Selection -->\r\n                    <div class=\"time_selection\" [ngClass]=\"{'w-50' : screenWidth > 475 , 'w-100':screenWidth < 475}\">\r\n                        <div class=\"section-card card h-100 rounded-3 p-4\">\r\n                            <h3 class=\"section-title\">Available Times</h3>\r\n\r\n                            <!-- Time Slots Grid -->\r\n                            <div class=\"row g-2 mb-4 overflow-scroll\">\r\n                                <div class=\"col-4\" *ngFor=\"let time of locationTiming\">\r\n                                    <div class=\"time-slot rounded-2\" [class.selected]=\"time.selected\"\r\n                                        (click)=\"selectTimeSlot(time)\">{{time ?\r\n                                        time?.value.slice(0,5) : 'N/A'}}</div>\r\n                                </div>\r\n                            </div>\r\n\r\n                            <!-- Waitlist Section -->\r\n                            <div class=\"waitlist-section rounded-3\">\r\n                                <div class=\"d-flex align-items-start\">\r\n                                    <div class=\"d-flex h-100 justify-content-between flex-column\">\r\n                                        <div class=\"waitlist-title d-flex align-items-center gap-2\"><span\r\n                                                class=\"waitlist-icon check-icon\"></span>No\r\n                                            slots available?</div>\r\n                                        <div class=\"waitlist-description d-flex align-items-center gap-2\">\r\n                                            <input class=\"form-check-input cursor-pointer\" type=\"checkbox\"\r\n                                                id=\"flexCheckChecked\">\r\n                                            Add me to the waitlist for earlier\r\n                                            availability\r\n                                        </div>\r\n                                    </div>\r\n                                    <div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n\r\n</ng-template>\r\n<ng-template #contactDetails>\r\n    <div class=\"w-60 contact_section\">\r\n        <div class=\"d-flex\" [ngClass]=\"{'h-100':screenWidth < 475}\">\r\n            <div class=\"h-100 w-100\">\r\n                <!-- Header Section -->\r\n                <div class=\"contact-header mb-2\">\r\n                    <h1 class=\"mb-0\">Contact Details</h1>\r\n                    <p class=\"contact-subtitle mb-0\">Provide your contact information</p>\r\n                </div>\r\n\r\n                <!-- Form Sections -->\r\n                <div class=\"d-flex gap-3 details_container flex-column w-100\">\r\n                    <!-- Left Column - Personal Information -->\r\n                    <div class=\"d-flex gap-4\">\r\n                        <div\r\n                            [ngClass]=\"{'w-50' : selectedService?.homeAppointmentAvailable, 'w-100' : !selectedService?.homeAppointmentAvailable}\">\r\n                            <div class=\"form-section card rounded-3 p-4 h-100\">\r\n                                <h3 class=\"section-title\">Personal Information</h3>\r\n\r\n                                <!-- Full Name -->\r\n                                <div class=\"mb-4\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Full Name\r\n                                        <span class=\"required-asterisk\">*</span>\r\n                                    </label>\r\n                                    <input type=\"text\" class=\"form-control form-input rounded-2\"\r\n                                        [(ngModel)]=\"appointmentPayload.customerDetail.name\"\r\n                                        (ngModelChange)=\"checkRequiredValues()\" simpoLettersOnly>\r\n                                </div>\r\n\r\n                                <!-- Email Address -->\r\n                                <div class=\"mb-4\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Email Address\r\n                                        <span class=\"required-asterisk\">*</span>\r\n                                    </label>\r\n                                    <input type=\"email\" class=\"form-control form-input rounded-2\"\r\n                                        [(ngModel)]=\"appointmentPayload.customerDetail.email\"\r\n                                        (ngModelChange)=\"checkRequiredValues()\">\r\n                                </div>\r\n\r\n                                <!-- Phone Number -->\r\n                                <div class=\"mb-0\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Phone Number\r\n                                        <span class=\"required-asterisk\">*</span>\r\n                                    </label>\r\n                                    <input type=\"tel\" class=\"form-control  rounded-2\"\r\n                                        [(ngModel)]=\"appointmentPayload.customerDetail.phoneNumber\"\r\n                                        (ngModelChange)=\"checkRequiredValues()\" simpoNumbersOnly\r\n                                        [ngClass]=\"{'mobile_number' : appointmentPayload.customerDetail.phoneNumber.length != 10}\">\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <!-- Right Column - Home Visit Details -->\r\n                        <div class=\"w-50\" *ngIf=\"selectedService?.homeAppointmentAvailable\">\r\n                            <div class=\"form-section card rounded-3 p-4 h-100\">\r\n                                <h3 class=\"section-title\">Home Visit Details</h3>\r\n\r\n                                <!-- Home Address -->\r\n                                <div class=\"mb-4\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Home Address\r\n                                    </label>\r\n                                    <textarea class=\"form-control form-textarea rounded-2\"\r\n                                        placeholder=\"Enter your complete address\"></textarea>\r\n                                </div>\r\n\r\n                                <!-- Special Instructions -->\r\n                                <div class=\"mb-0\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Special Instructions\r\n                                    </label>\r\n                                    <textarea class=\"form-control form-textarea rounded-2\"\r\n                                        placeholder=\"Any special instructions for the professional (optional)\"></textarea>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"policies-container\">\r\n                        <!-- Header -->\r\n                        <h2 class=\"policies-title\">Policies & Terms</h2>\r\n\r\n                        <!-- Policy Items -->\r\n                        <div class=\"policy-items-container d-flex flex-column gap-3\">\r\n                            <!-- Cancellation Policy -->\r\n                            <div class=\"policy-item d-flex justify-content-between align-items-center\"\r\n                                (click)=\"showCancellationPolicy = !showCancellationPolicy\">\r\n                                <h3 class=\"policy-title\">Cancellation Policy</h3>\r\n                                <div class=\"policy-arrow d-flex align-items-center justify-content-center\"><mat-icon\r\n                                        *ngIf=\"!showCancellationPolicy\">keyboard_arrow_right</mat-icon>\r\n                                    <mat-icon *ngIf=\"showCancellationPolicy\">keyboard_arrow_down</mat-icon>\r\n                                </div>\r\n                            </div>\r\n                            <div class=\"cancellation_policies d-flex flex-column gap-2 fw-500\"\r\n                                *ngIf=\"showCancellationPolicy\">\r\n                                <span>&#8226; Free cancellation up to 24 hours before appointment</span>\r\n                                <span>&#8226; 50% charge for cancellations within 24 hours</span>\r\n                                <span>&#8226; No refund for no-shows</span>\r\n                                <span>&#8226; Emergency cancellations will be reviewed case by case</span>\r\n                            </div>\r\n\r\n                            <!-- Rescheduling Policy -->\r\n                            <div class=\"policy-item d-flex justify-content-between align-items-center\"\r\n                                (click)=\"showReducingPolicy = !showReducingPolicy\">\r\n                                <h3 class=\"policy-title\">Rescheduling Policy</h3>\r\n                                <div class=\"policy-arrow d-flex align-items-center justify-content-center\"><mat-icon\r\n                                        *ngIf=\"!showReducingPolicy\">keyboard_arrow_right</mat-icon>\r\n                                    <mat-icon *ngIf=\"showReducingPolicy\">keyboard_arrow_down</mat-icon>\r\n                                </div>\r\n                            </div>\r\n                            <div class=\"cancellation_policies d-flex flex-column gap-2 fw-500\"\r\n                                *ngIf=\"showReducingPolicy\">\r\n                                <span>&#8226; Free cancellation up to 24 hours before appointment</span>\r\n                                <span>&#8226; 50% charge for cancellations within 24 hours</span>\r\n                                <span>&#8226; No refund for no-shows</span>\r\n                                <span>&#8226; Emergency cancellations will be reviewed case by case</span>\r\n                            </div>\r\n                        </div>\r\n\r\n                        <!-- Acceptance Section -->\r\n                        <div class=\"acceptance-section\">\r\n                            <input type=\"checkbox\" class=\"custom-checkbox\">\r\n                            <p class=\"acceptance-text\">\r\n                                I understand and accept the cancellation & rescheduling policies and\r\n                                <a href=\"#\" class=\"terms-link\">Terms & Conditions<span\r\n                                        class=\"external-link-icon\"></span></a>\r\n                            </p>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #paymentTab>\r\n    <div class=\"w-60 payment_section\">\r\n        <div class=\"w-100 h-100\">\r\n            <div class=\"w-100 d-flex justify-content-center align-items-center flex-column\">\r\n                <!-- Header Section -->\r\n                <div class=\"payment-header mb-3 w-100\">\r\n                    <h1 class=\"mb-0\">Payment & Confirmation</h1>\r\n                    <p class=\"payment-subtitle mb-0\">Review your booking and complete payment</p>\r\n                </div>\r\n\r\n                <!-- Booking Summary Card -->\r\n                <div class=\"booking-summary-card\" [ngClass]=\"{'w-100' : screenWidth < 475,'w-50':screenWidth > 475}\">\r\n                    <h2 class=\"summary-title\">Booking Summary</h2>\r\n\r\n                    <!-- Service -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Service</div>\r\n                        <div class=\"summary-value\">{{selectedService?.name ? selectedService?.name : 'N/A'}}</div>\r\n                    </div>\r\n\r\n                    <!-- Professional -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Professional</div>\r\n                        <div class=\"summary-value\">{{selectedStaff?.staffName ? selectedStaff?.staffName : 'N/A'}}</div>\r\n                    </div>\r\n\r\n                    <!-- Location -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Location</div>\r\n                        <div class=\"summary-value\">{{selectedLocation?.storeName ? selectedLocation?.storeName : 'N/A'}}\r\n                        </div>\r\n                    </div>\r\n\r\n                    <!-- Date & Time -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Date & Time</div>\r\n                        <div class=\"summary-value\">{{selectedDateStr ? (selectedDateStr) : 'N/A'}} at\r\n                            15:30</div>\r\n                    </div>\r\n\r\n                    <!-- Duration -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Duration</div>\r\n                        <div class=\"summary-value\">{{selectedService?.duration ? selectedService?.duration : 'N/A'}}\r\n                            minutes</div>\r\n                    </div>\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Tax Percent</div>\r\n                        <div class=\"summary-value\">{{selectedService?.priceDetails?.taxPercent ?\r\n                            selectedService?.priceDetails?.taxPercent : 'N/A'}}%</div>\r\n                    </div>\r\n                    <!-- Total -->\r\n                    <div class=\"summary-row total-row\">\r\n                        <div class=\"summary-label\">Total</div>\r\n                        <div class=\"summary-value\">\r\n                            <span class=\"currency-symbol\">₹</span>{{selectedService?.priceDetails?.price ?\r\n                            selectedService?.priceDetails?.price : 'N/A'}}\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #statusTemplate>\r\n    <div class=\"booking-confirmation\">\r\n        <!-- Success Icon -->\r\n        <div class=\"success-icon\">\r\n            <div class=\"checkmark-circle\">\r\n                <img src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/881293c1758695578518success.gif\"\r\n                    class=\"w-100 h-100\" *ngIf=\"apiStatus\">\r\n                <img src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/325000c1758695564518fail.gif\"\r\n                    class=\"w-100 h-100\" *ngIf=\"!apiStatus\">\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Main Content -->\r\n        <div class=\"confirmation-content\">\r\n            <h1 class=\"confirmation-title\">{{apiStatus ? 'Booking Confirmed!' : 'Booking Failed'}}</h1>\r\n            <p class=\"confirmation-message\">\r\n                {{apiStatus ? 'Your appointment has been successfully booked.':'Failed to book you appointment. Please\r\n                try again later'}}\r\n            </p>\r\n\r\n            <!-- Details Card -->\r\n            <div class=\"d-flex w-100 align-items-center justify-content-center\" *ngIf=\"apiStatus\">\r\n                <div class=\"details-card\">\r\n                    <h3 class=\"details-title\">Appointment Details</h3>\r\n\r\n                    <div class=\"details-row\">\r\n                        <span class=\"detail-label\">Service</span>\r\n                        <span class=\"detail-value\">{{appointmentPayload.serviceDetail?.name ?\r\n                            appointmentPayload.serviceDetail?.name : 'N/A'}}</span>\r\n                    </div>\r\n\r\n                    <div class=\"details-row\">\r\n                        <span class=\"detail-label\">Professional</span>\r\n                        <span class=\"detail-value\">{{appointmentPayload.staffDetail?.name ?\r\n                            appointmentPayload.staffDetail?.name : 'N/A'}}</span>\r\n                    </div>\r\n                    <div class=\"details-row\">\r\n                        <span class=\"detail-label\">Date & Time</span>\r\n                        <span class=\"detail-value\">{{appointmentPayload.bookingDate ?\r\n                            appointmentPayload.bookingDate.slice(0,8) :\r\n                            'N/A'}} at\r\n                            {{appointmentPayload.startTime ? appointmentPayload.startTime : 'N/A'}}</span>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n\r\n\r\n            <!-- Action Buttons -->\r\n            <!-- <div class=\"action-buttons\">\r\n                <button class=\"btn btn-outline\">View My Bookings</button>\r\n                <button class=\"btn btn-primary\">Back to Admin</button>\r\n            </div> -->\r\n        </div>\r\n    </div>\r\n</ng-template>"]}
|
453
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"appointment-booking.component.js","sourceRoot":"","sources":["../../../../../../../../projects/simpo-ui/src/lib/sections/appointment-form/appointment-booking/appointment-booking/appointment-booking.component.ts","../../../../../../../../projects/simpo-ui/src/lib/sections/appointment-form/appointment-booking/appointment-booking/appointment-booking.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, Input } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CdkDragPlaceholder } from \"@angular/cdk/drag-drop\";\r\nimport { MatIcon } from \"@angular/material/icon\";\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatFormFieldModule } from \"@angular/material/form-field\";\r\nimport { MatDatepickerModule } from \"@angular/material/datepicker\";\r\nimport { MatNativeDateModule } from '@angular/material/core';\r\nimport { RestService } from '../../../../services/rest.service';\r\nimport { EventsService } from '../../../../services/events.service';\r\nimport { Router } from '@angular/router';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { BannerContentModel, BannerSectionModel } from '../../appointment-form.model';\r\nimport { BackgroundModel, BannerStylesModel } from '../../../../styles/style.model';\r\nimport { LettersOnlyDirective } from '../../../../directive/letters-only.directive';\r\nimport { NumbersOnlyDirective } from '../../../../directive/numbers-only.directive';\r\nimport { ToastModule } from \"primeng/toast\";\r\nimport { MessageService } from 'primeng/api';\r\n@Component({\r\n  selector: 'simpo-appointment-booking',\r\n  standalone: true,\r\n  imports: [CdkDragPlaceholder, CommonModule, MatIcon, MatFormFieldModule, MatDatepickerModule, FormsModule, MatNativeDateModule, MatInputModule, LettersOnlyDirective, NumbersOnlyDirective, ToastModule],\r\n  providers: [MessageService],\r\n  templateUrl: './appointment-booking.component.html',\r\n  styleUrl: './appointment-booking.component.css'\r\n})\r\nexport class AppointmentBookingComponent {\r\n  constructor(\r\n    private restService: RestService,\r\n    private _eventService: EventsService,\r\n    private readonly router: Router,\r\n    private readonly messageService: MessageService\r\n  ) {\r\n\r\n  }\r\n  @Input() data?: BannerSectionModel;\r\n  @Input() index?: number;\r\n  content?: BannerContentModel;\r\n  @Input() edit?: boolean;\r\n  @Input() delete?: boolean;\r\n  @Input() customClass?: string;\r\n  @Input() nextComponentColor?: BackgroundModel;\r\n  styles?: BannerStylesModel;\r\n  ngOnInit() {\r\n    this.getAllServices();\r\n    this.getScreenSize();\r\n  }\r\n  screenWidth: number = 0;\r\n  @HostListener(\"window: resize\", [\"$event\"])\r\n  getScreenSize() {\r\n    this.screenWidth = window.innerWidth;\r\n  }\r\n  @HostListener('document:click')\r\n  closeOnOutsideClick() {\r\n    this.showCalendar = false;\r\n  }\r\n  accessedTabs = {\r\n    serviceListing: false,\r\n    locationListing: false,\r\n    staffListing: false\r\n  }\r\n\r\n  businessName = localStorage.getItem('bName') ?? \"24K Bazaar\";\r\n  businessId: string = localStorage.getItem('bId') ?? \"1f095216-7c00-6cab-9045-ff9c70e1c641\";\r\n  activeButton: boolean = false;\r\n  selectedTab: string = '';\r\n  barWidth: string = '';\r\n  showCancellationPolicy: boolean = false;\r\n  showReducingPolicy: boolean = false;\r\n  selectedService: any = {};\r\n  selectedLocation: any;\r\n  Object = Object;\r\n  showCalendar = false;\r\n  selectedDate: Date | null = null;\r\n  selectedDateStr = '';\r\n  userDetails = {\r\n    name: '',\r\n    email: '',\r\n    mobileNumber: ''\r\n  }\r\n  dateFilter = (d: Date | null): boolean => {\r\n    const date = (d || new Date());\r\n    const today = new Date();\r\n    today.setHours(0, 0, 0, 0);\r\n    return date.getTime() >= today.getTime();\r\n  }\r\n  toggleCalendar(event?: Event) {\r\n    if (event) event.stopPropagation();\r\n    this.showCalendar = !this.showCalendar;\r\n  }\r\n\r\n  onDateSelected(date: any) {\r\n    this.selectedTime = {};\r\n    this.activeButton = false;\r\n    this.selectedDate = date;\r\n    this.selectedDateStr = this.formatDate(date);\r\n    this.showCalendar = false;\r\n    this.getAvailableSlots();\r\n  }\r\n  private formatDate(d: Date): string {\r\n    const dd = String(d.getDate()).padStart(2, '0');\r\n    const mm = String(d.getMonth() + 1).padStart(2, '0');\r\n    const yyyy = d.getFullYear();\r\n    return `${dd}-${mm}-${yyyy}`;\r\n  }\r\n\r\n  selectService(service: any) {\r\n    service.selected = true;\r\n    if (this.selectedService) {\r\n      this.selectedService.selected = false;\r\n    }\r\n    this.selectedService = service\r\n    this.activeButton = this.selectedService ? true : false;\r\n  }\r\n  selectLocation(location: any) {\r\n    location.selected = true;\r\n    if (this.selectedLocation) {\r\n      this.selectedLocation.selected = false;\r\n    }\r\n    this.activeButton = true;\r\n    this.selectedLocation = location;\r\n  }\r\n  selectedStaff: any;\r\n  selectStaff(staff: any) {\r\n    this.selectedStaff = staff;\r\n    this.activeButton = true;\r\n  }\r\n  nextStep() {\r\n    if (this.selectedTab === 'serviceListing') {\r\n      this.activeButton = this.selectedLocation ? true : false;\r\n      this.accessedTabs.serviceListing = true;\r\n      if (!this.activeButton) {\r\n        this.getAllLocations();\r\n      }\r\n      else {\r\n        if (this.accessedTabs.locationListing) {\r\n          this.selectedTab = 'locationListing';\r\n          this.barWidth = '29.28';\r\n        }\r\n        else if (this.accessedTabs.staffListing) {\r\n          this.selectedTab = 'staffListing';\r\n          this.barWidth = '43.57';\r\n        }\r\n        else {\r\n          this.selectedTab = 'dateSelection';\r\n          this.barWidth = '58.57';\r\n        }\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'locationListing') {\r\n      this.activeButton = this.selectedStaff ? true : false;\r\n      this.accessedTabs.locationListing = true;\r\n      if (!this.activeButton) {\r\n        this.getAllStaff();\r\n\r\n      }\r\n      else {\r\n        if (this.accessedTabs.staffListing) {\r\n          this.selectedTab = 'staffListing';\r\n          this.barWidth = '43.57';\r\n        }\r\n        else {\r\n          this.selectedTab = 'dateSelection';\r\n          this.barWidth = '58.57';\r\n        }\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'staffListing') {\r\n      this.accessedTabs.staffListing = true;\r\n      this.selectedTab = 'dateSelection';\r\n      this.barWidth = '58.57';\r\n      if (!this.activeButton)\r\n        this.getAvailableSlots();\r\n    }\r\n    else if (this.selectedTab === 'dateSelection') {\r\n      this.activeButton = this.appointmentPayload.customerDetail.name && this.appointmentPayload.customerDetail.email && this.appointmentPayload.customerDetail.phoneNumber.length === 10 ? true : false\r\n      this.selectedTab = 'contactDetails';\r\n      this.barWidth = '70.57'\r\n    }\r\n    else if (this.selectedTab === 'contactDetails') {\r\n      this.checkRequiredValues();\r\n      this.selectedTab = 'paymentTab';\r\n      this.barWidth = '85.57'\r\n    }\r\n  }\r\n  previousStep() {\r\n    this.activeButton = true;\r\n    if (this.selectedTab === 'locationListing') {\r\n      if (this.accessedTabs.serviceListing) {\r\n        this.selectedTab = 'serviceListing';\r\n        this.barWidth = '14.28';\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'staffListing') {\r\n      if (this.accessedTabs.locationListing) {\r\n        this.selectedTab = 'locationListing';\r\n        this.barWidth = '29.28';\r\n      }\r\n      else if (this.accessedTabs.serviceListing) {\r\n        this.selectedTab = 'serviceListing';\r\n        this.barWidth = '14.28';\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'dateSelection') {\r\n      if (this.accessedTabs.staffListing) {\r\n        this.selectedTab = 'staffListing';\r\n        this.barWidth = '43.57';\r\n      }\r\n      else if (this.accessedTabs.locationListing) {\r\n        this.selectedTab = 'locationListing';\r\n        this.barWidth = '29.28';\r\n      }\r\n      else if (this.accessedTabs.serviceListing) {\r\n        this.selectedTab = 'serviceListing';\r\n        this.barWidth = '14.28';\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'contactDetails') {\r\n      this.selectedTab = 'dateSelection';\r\n      this.barWidth = '58.57'\r\n    }\r\n    else if (this.selectedTab === 'paymentTab') {\r\n      this.selectedTab = 'contactDetails';\r\n      this.barWidth = '70.57';\r\n    }\r\n  }\r\n  serviceData: any[] = [];\r\n  getAllServices() {\r\n    let servicePayload: any = {\r\n      businessId: this.businessId ?? \"\",\r\n      pageNo: 0,\r\n      size: 100\r\n    }\r\n    this.restService.getAllAppointmentService(servicePayload).subscribe(\r\n      (res: any) => {\r\n        if (res.content.length > 0) {\r\n          this.serviceData = res.content.filter((service: any) => service.active === true);\r\n          this.serviceData.forEach(service => service.selected = false);\r\n          // console.log(this.serviceData)\r\n          if (this.serviceData.length === 1 && !this.activeButton) {\r\n            this.selectedService = this.serviceData[0];\r\n            this.getAllLocations();\r\n          }\r\n          else {\r\n            this.selectedTab = 'serviceListing';\r\n            this.barWidth = '14.28';\r\n          }\r\n        }\r\n      },\r\n      (error) => {\r\n        // Handle errors gracefully\r\n      }\r\n    );\r\n  }\r\n  locationData: any[] = [];\r\n  getAllLocations() {\r\n    this.loader = true;\r\n    this.locationData = [];\r\n    let payload = { businessId: this.businessId ?? \"\" }\r\n    this.restService.getAllStores(payload).subscribe(\r\n      (res: any) => {\r\n        if (res.data.data.length > 0) {\r\n          let locations = res.data.data.filter((store: any) => { return store.status === 'ACTIVE' });\r\n          locations.forEach((location: any) => {\r\n            if (this.selectedService.storeIds.includes(location.id)) {\r\n              location.selected = false;\r\n              this.locationData.push(location);\r\n            }\r\n          })\r\n          if (this.locationData.length === 1 && !this.activeButton) {\r\n            this.selectedLocation = this.locationData[0];\r\n            this.loader = false;\r\n            this.getAllStaff();\r\n          }\r\n          else {\r\n            this.loader = false;\r\n            this.selectedTab = 'locationListing';\r\n            this.barWidth = '29.28';\r\n          }\r\n        }\r\n      },\r\n      (error) => {\r\n        // Handle errors gracefully\r\n      }\r\n    );\r\n  }\r\n  staffPayload: any = {\r\n    serviceId: '',\r\n    storeId: '',\r\n    businessId: ''\r\n  }\r\n  staffData: any[] = [];\r\n  getAllStaff() {\r\n    this.loader = true;\r\n    this.staffPayload.storeId = this.selectedLocation?.id ?? \"\";\r\n    this.staffPayload.serviceId = this.selectedService?.serviceId ? this.selectedService.serviceId : '';\r\n    this.staffPayload.businessId = this.businessId ?? \"\";\r\n    this.restService.getAllStaff(this.staffPayload).subscribe(\r\n      (res: any) => {\r\n        if (res.length > 0) {\r\n          this.staffData = res.filter((staff: any) => staff.active === true);\r\n          if (this.staffData.length === 1 && !this.activeButton) {\r\n            this.loader = false;\r\n            this.selectedTab = 'dateSelection';\r\n            this.barWidth = '58.57';\r\n            this.selectedStaff = this.staffData[0];\r\n            this.getAvailableSlots();\r\n          }\r\n          else if (this.staffData.length > 1) {\r\n            this.loader = false;\r\n            this.selectedTab = 'staffListing';\r\n            this.barWidth = '43.57';\r\n          }\r\n        }\r\n      },\r\n      (error) => {\r\n        // Handle errors gracefully\r\n      }\r\n    );\r\n  }\r\n  convertTo24Hour(time: string): string {\r\n    const [hourMin, modifierRaw] = time.split(' ');\r\n    const modifier = modifierRaw.toUpperCase(); // \"AM\" or \"PM\"\r\n    let [hours, minutes] = hourMin.split(':').map(Number);\r\n\r\n    if (modifier === 'PM' && hours < 12) {\r\n      hours += 12;\r\n    }\r\n    if (modifier === 'AM' && hours === 12) {\r\n      hours = 0;\r\n    }\r\n\r\n    const hh = hours.toString().padStart(2, '0');\r\n    const mm = minutes.toString().padStart(2, '0');\r\n    return `${hh}:${mm} ${modifier}`;\r\n  }\r\n  slotsPayload: any = {\r\n    storeId: \"\",\r\n    serviceId: \"\",\r\n    businessId: \"\",\r\n    bookingDate: \"\"\r\n  }\r\n  locationTiming: any[] = [];\r\n  loader: boolean = false;\r\n  getAvailableSlots() {\r\n    this.loader = false;\r\n    this.locationTiming = [];\r\n    this.slotsPayload.storeId = this.selectedLocation?.id ?? \"\";\r\n    this.slotsPayload.serviceId = this.selectedService?.serviceId ? this.selectedService.serviceId : '';\r\n    this.slotsPayload.businessId = this.businessId ?? \"\";\r\n    const date = this.selectedDate ?? new Date();\r\n    this.selectedDateStr = this.formatDate(date);\r\n    const yyyy = date.getFullYear();\r\n    const mm = String(date.getMonth() + 1).padStart(2, '0');\r\n    const dd = String(date.getDate()).padStart(2, '0');\r\n\r\n    this.slotsPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;\r\n\r\n    if (this.selectedStaff)\r\n      this.slotsPayload.staffId = this.selectedStaff.staffId;\r\n    this.restService.getBookingSlots(this.slotsPayload).subscribe((res: any) => {\r\n      res.forEach((time: any) => {\r\n        this.locationTiming.push({ selected: false, value: this.convertTo24Hour(time) });\r\n      })\r\n    })\r\n  }\r\n  selectedTime: any\r\n  selectTimeSlot(time: any) {\r\n    time.selected = true;\r\n    if (this.selectedTime) {\r\n      this.selectedTime.selected = false;\r\n    }\r\n    this.selectedTime = time;\r\n    this.activeButton = true;\r\n  }\r\n  checkRequiredValues() {\r\n    if (this.appointmentPayload.customerDetail.name && this.appointmentPayload.customerDetail.email && this.appointmentPayload.customerDetail.phoneNumber.length === 10) {\r\n      this.activeButton = true;\r\n      // console.log(this.selectedService, this.selectedLocation, this.selectedStaff, this.selectedDate, this.selectedTime, this.userDetails)\r\n    }\r\n    else {\r\n      this.activeButton = false;\r\n    }\r\n  }\r\n  appointmentPayload: any = {\r\n    staffDetail: {\r\n      id: '',\r\n      name: ''\r\n    },\r\n    bookingDate: '',\r\n    startTime: '',\r\n    customerDetail: {\r\n      name: '',\r\n      phoneNumber: '',\r\n      email: ''\r\n    },\r\n    serviceDetail: {\r\n      id: '',\r\n      name: ''\r\n    },\r\n    storeId: '',\r\n    businessId: this.businessId,\r\n    businessName: this.businessName\r\n  }\r\n  checkPayment() {\r\n    const request_form = localStorage.getItem(\"REQUEST_FROM\");\r\n    if (request_form === 'ECOMMERCE') {\r\n      this.createAppointment();\r\n    }\r\n    else {\r\n      if (this.selectedService?.depositAmount?.depositRequired) {\r\n        this.paymentBookingAppointment();\r\n      } else {\r\n        this.createAppointment();\r\n      }\r\n    }\r\n    // this.createAppointment();\r\n  }\r\n  apiStatus: boolean = false;\r\n  createAppointment() {\r\n    const date = this.selectedDate ?? new Date();\r\n    const yyyy = date.getFullYear();\r\n    const mm = String(date.getMonth() + 1).padStart(2, '0');\r\n    const dd = String(date.getDate()).padStart(2, '0');\r\n    this.appointmentPayload.staffDetail.id = this.selectedStaff.staffId;\r\n    this.appointmentPayload.staffDetail.name = this.selectedStaff.staffName;\r\n    this.appointmentPayload.storeId = this.selectedLocation.id;\r\n    this.appointmentPayload.serviceDetail.id = this.selectedService.serviceId;\r\n    this.appointmentPayload.serviceDetail.name = this.selectedService.name;\r\n    this.appointmentPayload.startTime = this.selectedTime.value.slice(0, 5);\r\n    this.appointmentPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;\r\n    this.restService.bookAppointmentV2(this.appointmentPayload).subscribe((res: any) => {\r\n      this.selectedTab = 'statusTemplate';\r\n      this.barWidth = '100';\r\n      this.apiStatus = true;\r\n    },\r\n      (error: any) => {\r\n        this.apiStatus = false;\r\n      }\r\n    )\r\n  }\r\n  paymentBookingAppointment() {\r\n    const date = this.selectedDate ?? new Date();\r\n    const yyyy = date.getFullYear();\r\n    const mm = String(date.getMonth() + 1).padStart(2, '0');\r\n    const dd = String(date.getDate()).padStart(2, '0');\r\n    this.appointmentPayload.staffDetail.id = this.selectedStaff.staffId;\r\n    this.appointmentPayload.staffDetail.name = this.selectedStaff.staffName;\r\n    this.appointmentPayload.storeId = this.selectedLocation.id;\r\n    this.appointmentPayload.serviceDetail.id = this.selectedService.serviceId;\r\n    this.appointmentPayload.serviceDetail.name = this.selectedService.name;\r\n    this.appointmentPayload.startTime = this.selectedTime.value.slice(0, 5);\r\n    this.appointmentPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;\r\n    this.restService.paymentForAppointment(this.appointmentPayload).subscribe(\r\n      (res: any) => {\r\n        this._eventService.cashFreeEvent.emit({ data: { orderSignature: res.orderSignature } });\r\n        localStorage.setItem('appointmentPaymentId', res.pgOrderId);\r\n      },\r\n      (error: any) => {\r\n        this.loader = false;\r\n        this.messageService.add({ severity: 'error', summary: 'Payment Failed', detail: error.message });\r\n      }\r\n    )\r\n\r\n  }\r\n  goBack() {\r\n  }\r\n}\r\n","<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"\r\n    [showTransformOptions]=\"screenWidth < 475 ? 'translateY(-100%)' : ''\"></p-toast>\r\n<section class=\"main_section\">\r\n    <div class=\"main_header\">\r\n        <div class=\"header d-flex justify-content-between align-items-center\">\r\n            <div class=\"back-btn d-flex justify-content-center align-items-center cursor-pointer gap-2 mb-3\"\r\n                (click)=\"goBack()\">\r\n                <mat-icon>keyboard_backspace</mat-icon><span *ngIf=\"screenWidth > 475\">Back to My Bookings</span>\r\n            </div>\r\n            <div class=\"header-title\">\r\n                <h1>Book New Appointment</h1>\r\n                <p>{{businessName ?? \"N/A\" }}</p>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"progress-bar\">\r\n            <div class=\"progress-fill\" [style.width]=\"barWidth + '%'\"></div>\r\n        </div>\r\n    </div>\r\n    <div class=\"main_body w-100 d-flex justify-content-center\"><ng-container *ngIf=\"selectedTab === 'serviceListing'\">\r\n            <ng-container *ngTemplateOutlet=\"serviceListing\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab === 'locationListing'\">\r\n            <ng-container *ngTemplateOutlet=\"locationListing\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab === 'staffListing'\">\r\n            <ng-container *ngTemplateOutlet=\"staffListing\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab === 'dateSelection'\">\r\n            <ng-container *ngTemplateOutlet=\"dateSelection\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab==='contactDetails'\">\r\n            <ng-container *ngTemplateOutlet=\"contactDetails\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab==='paymentTab'\">\r\n            <ng-container *ngTemplateOutlet=\"paymentTab\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab==='statusTemplate'\">\r\n            <ng-container *ngTemplateOutlet=\"statusTemplate\"></ng-container>\r\n        </ng-container>\r\n    </div>\r\n    <div class=\"main_footer d-flex justify-content-center align-items-center\" *ngIf=\"selectedTab!=='statusTemplate'\">\r\n        <div class=\"footer-buttons\">\r\n            <span class=\"back-footer-btn cursor-pointer\" (click)=\"previousStep()\">Back</span>\r\n            <button class=\"continue-btn\" [disabled]=\"!activeButton\" (click)=\"nextStep()\"\r\n                *ngIf=\"selectedTab!='paymentTab'\">{{!loader ? 'Continue' : 'Loading...'}}</button>\r\n            <button class=\"complete_booking cursor-pointer d-flex justify-content-evenly align-items-center\"\r\n                *ngIf=\"selectedTab==='paymentTab'\" (click)=\"checkPayment()\"><img\r\n                    src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/304012c1753440087996Background.png\">Complete\r\n                Booking</button>\r\n        </div>\r\n    </div>\r\n</section>\r\n<ng-template #serviceListing>\r\n    <div class=\"w-60 service_section\">\r\n        <div class=\"service-selection\">\r\n            <h2>Select a Service</h2>\r\n            <p>Choose the service you'd like to book</p>\r\n\r\n            <div class=\"services-grid\">\r\n                <ng-container *ngFor=\"let service of serviceData\">\r\n                    <div class=\"\" (click)=\"selectService(service)\"\r\n                        [ngClass]=\"{ 'service-card-selected' : service?.selected, 'service-card': !service?.selected }\">\r\n                        <div class=\" service-header\">\r\n                            <div class=\"service-icon\"><mat-icon>person_outline</mat-icon></div>\r\n                            <div class=\"service-info\">\r\n                                <div class=\"service-title\">{{service?.name ? service?.name : 'N/A'}}</div>\r\n                                <div class=\"service-category\">Wellness</div>\r\n                            </div>\r\n                            <div>\r\n                                <div class=\"service-price\">₹{{service?.priceDetails?.price ?\r\n                                    service?.priceDetails?.price : 'N/A' }}</div>\r\n                                <div class=\"service-duration\">{{service?.duration ? service?.duration : 'N/A'}} min\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div class=\"service-description\">\r\n                            {{service?.description ? service?.description : 'N/A'}}\r\n                        </div>\r\n                        <div class=\"home-visit\" *ngIf=\"service?.homeAppointmentAvailable\"><img\r\n                                src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/982126c1758628863129furniture_16406103.png\">Home\r\n                            Visit Available</div>\r\n                    </div>\r\n                </ng-container>\r\n\r\n                <!-- <div class=\"service-card\">\r\n                    <div class=\"service-header\">\r\n                        <div class=\"service-icon\">👤</div>\r\n                        <div class=\"service-info\">\r\n                            <div class=\"service-title\">General Consultation</div>\r\n                            <div class=\"service-category\">Medical</div>\r\n                        </div>\r\n                        <div>\r\n                            <div class=\"service-price\">₹800</div>\r\n                            <div class=\"service-duration\">30 min</div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"service-description\">\r\n                        Comprehensive health consultation\r\n                    </div>\r\n                </div>\r\n\r\n                <div class=\"service-card\">\r\n                    <div class=\"service-header\">\r\n                        <div class=\"service-icon\">🧠</div>\r\n                        <div class=\"service-info\">\r\n                            <div class=\"service-title\">Mental Health Counseling</div>\r\n                            <div class=\"service-category\">Mental Health</div>\r\n                        </div>\r\n                        <div>\r\n                            <div class=\"service-price\">₹1500</div>\r\n                            <div class=\"service-duration\">45 min</div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"service-description\">\r\n                        Professional psychological support\r\n                    </div>\r\n                    <div class=\"home-visit\">Home Visit Available</div>\r\n                </div>\r\n\r\n                <div class=\"service-card\">\r\n                    <div class=\"service-header\">\r\n                        <div class=\"service-icon\">✂</div>\r\n                        <div class=\"service-info\">\r\n                            <div class=\"service-title\">Hair Cut & Styling</div>\r\n                            <div class=\"service-category\">Beauty</div>\r\n                        </div>\r\n                        <div>\r\n                            <div class=\"service-price\">₹1200</div>\r\n                            <div class=\"service-duration\">45 min</div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"service-description\">\r\n                        Professional hair cutting and styling\r\n                    </div>\r\n                    <div class=\"home-visit\">Home Visit Available</div>\r\n                </div> -->\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #locationListing>\r\n    <div class=\"location_section\">\r\n        <div class=\"header flex-column align-items-start\">\r\n            <h1>Choose Location</h1>\r\n            <p>Select where you'd like to receive the service</p>\r\n        </div>\r\n\r\n        <div class=\"location-list\">\r\n            <ng-container *ngFor=\"let location of locationData\">\r\n                <div (click)=\"selectLocation(location)\"\r\n                    [ngClass]=\"{ 'location-card-selected' : location?.selected, 'location-card': !location?.selected }\">\r\n                    <div class=\"location-content\">\r\n                        <div class=\"location-info\">\r\n                            <div class=\"location-icon\"><img\r\n                                    src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/427226c1758629157758store_3171510.png\">\r\n                            </div>\r\n                            <div class=\"location-details\">\r\n                                <div class=\"d-flex justify-content-between align-items-center\">\r\n                                    <h3>{{location?.storeName ? location?.storeName : 'N/A'}}</h3>\r\n                                    <div class=\"distance\"><mat-icon>location_on</mat-icon> 2.3 km</div>\r\n                                </div>\r\n                                <p>{{location?.addressDetails?.addressLine}}, {{location?.addressDetails?.city}},\r\n                                    {{location?.addressDetails?.state}} {{location?.pincode}}</p>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </ng-container>\r\n            <!-- <div class=\"location-card\">\r\n                <div class=\"location-content\">\r\n                    <div class=\"location-info\">\r\n                        <div class=\"location-icon branch-icon\"></div>\r\n                        <div class=\"location-details\">\r\n                            <h3>Branch Clinic</h3>\r\n                            <p>456 Care Avenue, Health Zone, Mumbai 400015</p>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"distance\">5.8 km</div>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"location-card\">\r\n                <div class=\"location-content\">\r\n                    <div class=\"location-info\">\r\n                        <div class=\"location-icon home-icon\"></div>\r\n                        <div class=\"location-details\">\r\n                            <h3>Home Visit</h3>\r\n                            <p>Your Location</p>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"distance\">0 km</div>\r\n                </div>\r\n            </div> -->\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #staffListing>\r\n    <div class=\"w-60 overflow-hidden\">\r\n        <div class=\"d-flex w-100 h-100\">\r\n            <div class=\"w-100\">\r\n                <!-- Header Section -->\r\n                <div class=\"staff-header mb-3\">\r\n                    <h1 class=\"mb-1\">Select Staff Member</h1>\r\n                    <p class=\"staff-subtitle mb-0\">Choose your preferred professional</p>\r\n                </div>\r\n\r\n                <!-- Staff Cards -->\r\n                <div class=\"d-flex flex-column gap-4 staff-list\">\r\n                    <ng-container *ngFor=\"let staff of staffData\">\r\n                        <div class=\" staff-card card rounded-3 p-4\" (click)=\"selectStaff(staff)\">\r\n                            <div class=\"d-flex align-items-start justify-content-between\">\r\n                                <div class=\"d-flex align-items-start flex-grow-1\">\r\n                                    <div\r\n                                        class=\"staff-avatar rounded-circle d-flex align-items-center justify-content-center me-4\">\r\n                                        {{staff?.staffName.slice(0,3).toUpperCase()}}\r\n                                    </div>\r\n                                    <div class=\"staff-details flex-grow-1\">\r\n                                        <h3 class=\"staff-name\">{{staff?.staffName ? staff?.staffName : 'N/A'}}</h3>\r\n                                        <p class=\"staff-specialty\">General Medicine</p>\r\n                                        <p class=\"staff-description mb-0\">Experienced physician with 10+ years in\r\n                                            general\r\n                                            medicine and wellness care.</p>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"rating-section\">\r\n                                    <div class=\"star-rating d-flex align-items-center\">\r\n                                        <span class=\"star-icon\"></span>\r\n                                        <span class=\"rating-number\">4.9</span>\r\n                                    </div>\r\n                                    <div class=\"review-count\">156 reviews</div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </ng-container>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #dateSelection>\r\n    <div class=\"w-60 date_section\">\r\n        <div class=\"row justify-content-center h-100\">\r\n            <div class=\"col-12 h-100\">\r\n                <div class=\"datetime-header mb-2\">\r\n                    <h1 class=\"mb-3\">Select Date & Time</h1>\r\n                    <p class=\"datetime-subtitle mb-0\">Choose when you'd like your appointment</p>\r\n                </div>\r\n\r\n                <!-- Main Content -->\r\n                <div class=\"d-flex gap-4 main_container\">\r\n                    <!-- Left Column - Date Selection -->\r\n                    <div [ngClass]=\"{'w-50' : screenWidth > 475 , 'w-100':screenWidth < 475}\">\r\n                        <div class=\"section-card card rounded-3 p-4 h-100\">\r\n                            <h3 class=\"section-title\">Select Date</h3>\r\n\r\n                            <div class=\"date-picker-container d-flex align-items-center\"\r\n                                (click)=\"$event.stopPropagation()\">\r\n                                <input type=\"text\" class=\"form-control date-input border-0 rounded-2\"\r\n                                    placeholder=\"dd-mm-yyyy\" [value]=\"selectedDateStr\" readonly\r\n                                    (click)=\"toggleCalendar($event)\">\r\n\r\n                                <mat-icon class=\"ms-2\" (click)=\"toggleCalendar($event)\">calendar_today</mat-icon>\r\n                            </div>\r\n                            <div class=\"position-relative\" (click)=\"$event.stopPropagation()\">\r\n                                <div class=\"datepicker-popover\" *ngIf=\"showCalendar\">\r\n                                    <mat-calendar [(selected)]=\"selectedDate\" [dateFilter]=\"dateFilter\"\r\n                                        (selectedChange)=\"onDateSelected($event)\" class=\"datepicker-calendar\">\r\n                                    </mat-calendar>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n\r\n                    <!-- Right Column - Time Selection -->\r\n                    <div class=\"time_selection\" [ngClass]=\"{'w-50' : screenWidth > 475 , 'w-100':screenWidth < 475}\">\r\n                        <div class=\"section-card card h-100 rounded-3 p-4\">\r\n                            <h3 class=\"section-title\">Available Times</h3>\r\n\r\n                            <!-- Time Slots Grid -->\r\n                            <div class=\"row g-2 mb-4 overflow-scroll\">\r\n                                <div class=\"col-4\" *ngFor=\"let time of locationTiming\">\r\n                                    <div class=\"time-slot rounded-2\" [class.selected]=\"time.selected\"\r\n                                        (click)=\"selectTimeSlot(time)\">{{time ?\r\n                                        time?.value.slice(0,5) : 'N/A'}}</div>\r\n                                </div>\r\n                            </div>\r\n\r\n                            <!-- Waitlist Section -->\r\n                            <div class=\"waitlist-section rounded-3\">\r\n                                <div class=\"d-flex align-items-start\">\r\n                                    <div class=\"d-flex h-100 justify-content-between flex-column\">\r\n                                        <div class=\"waitlist-title d-flex align-items-center gap-2\"><span\r\n                                                class=\"waitlist-icon check-icon\"></span>No\r\n                                            slots available?</div>\r\n                                        <div class=\"waitlist-description d-flex align-items-center gap-2\">\r\n                                            <input class=\"form-check-input cursor-pointer\" type=\"checkbox\"\r\n                                                id=\"flexCheckChecked\">\r\n                                            Add me to the waitlist for earlier\r\n                                            availability\r\n                                        </div>\r\n                                    </div>\r\n                                    <div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n\r\n</ng-template>\r\n<ng-template #contactDetails>\r\n    <div class=\"w-60 contact_section\">\r\n        <div class=\"d-flex\" [ngClass]=\"{'h-100':screenWidth < 475}\">\r\n            <div class=\"h-100 w-100\">\r\n                <!-- Header Section -->\r\n                <div class=\"contact-header mb-2\">\r\n                    <h1 class=\"mb-0\">Contact Details</h1>\r\n                    <p class=\"contact-subtitle mb-0\">Provide your contact information</p>\r\n                </div>\r\n\r\n                <!-- Form Sections -->\r\n                <div class=\"d-flex gap-3 details_container flex-column w-100\">\r\n                    <!-- Left Column - Personal Information -->\r\n                    <div class=\"d-flex gap-4\">\r\n                        <div\r\n                            [ngClass]=\"{'w-50' : selectedService?.homeAppointmentAvailable, 'w-100' : !selectedService?.homeAppointmentAvailable}\">\r\n                            <div class=\"form-section card rounded-3 p-4 h-100\">\r\n                                <h3 class=\"section-title\">Personal Information</h3>\r\n\r\n                                <!-- Full Name -->\r\n                                <div class=\"mb-4\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Full Name\r\n                                        <span class=\"required-asterisk\">*</span>\r\n                                    </label>\r\n                                    <input type=\"text\" class=\"form-control form-input rounded-2\"\r\n                                        [(ngModel)]=\"appointmentPayload.customerDetail.name\"\r\n                                        (ngModelChange)=\"checkRequiredValues()\" simpoLettersOnly>\r\n                                </div>\r\n\r\n                                <!-- Email Address -->\r\n                                <div class=\"mb-4\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Email Address\r\n                                        <span class=\"required-asterisk\">*</span>\r\n                                    </label>\r\n                                    <input type=\"email\" class=\"form-control form-input rounded-2\"\r\n                                        [(ngModel)]=\"appointmentPayload.customerDetail.email\"\r\n                                        (ngModelChange)=\"checkRequiredValues()\">\r\n                                </div>\r\n\r\n                                <!-- Phone Number -->\r\n                                <div class=\"mb-0\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Phone Number\r\n                                        <span class=\"required-asterisk\">*</span>\r\n                                    </label>\r\n                                    <input type=\"tel\" class=\"form-control  rounded-2\"\r\n                                        [(ngModel)]=\"appointmentPayload.customerDetail.phoneNumber\"\r\n                                        (ngModelChange)=\"checkRequiredValues()\" simpoNumbersOnly\r\n                                        [ngClass]=\"{'mobile_number' : appointmentPayload.customerDetail.phoneNumber.length != 10}\">\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <!-- Right Column - Home Visit Details -->\r\n                        <div class=\"w-50\" *ngIf=\"selectedService?.homeAppointmentAvailable\">\r\n                            <div class=\"form-section card rounded-3 p-4 h-100\">\r\n                                <h3 class=\"section-title\">Home Visit Details</h3>\r\n\r\n                                <!-- Home Address -->\r\n                                <div class=\"mb-4\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Home Address\r\n                                    </label>\r\n                                    <textarea class=\"form-control form-textarea rounded-2\"\r\n                                        placeholder=\"Enter your complete address\"></textarea>\r\n                                </div>\r\n\r\n                                <!-- Special Instructions -->\r\n                                <div class=\"mb-0\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Special Instructions\r\n                                    </label>\r\n                                    <textarea class=\"form-control form-textarea rounded-2\"\r\n                                        placeholder=\"Any special instructions for the professional (optional)\"></textarea>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"policies-container\">\r\n                        <!-- Header -->\r\n                        <h2 class=\"policies-title\">Policies & Terms</h2>\r\n\r\n                        <!-- Policy Items -->\r\n                        <div class=\"policy-items-container d-flex flex-column gap-3\">\r\n                            <!-- Cancellation Policy -->\r\n                            <div class=\"policy-item d-flex justify-content-between align-items-center\"\r\n                                (click)=\"showCancellationPolicy = !showCancellationPolicy\">\r\n                                <h3 class=\"policy-title\">Cancellation Policy</h3>\r\n                                <div class=\"policy-arrow d-flex align-items-center justify-content-center\"><mat-icon\r\n                                        *ngIf=\"!showCancellationPolicy\">keyboard_arrow_right</mat-icon>\r\n                                    <mat-icon *ngIf=\"showCancellationPolicy\">keyboard_arrow_down</mat-icon>\r\n                                </div>\r\n                            </div>\r\n                            <div class=\"cancellation_policies d-flex flex-column gap-2 fw-500\"\r\n                                *ngIf=\"showCancellationPolicy\">\r\n                                <span>&#8226; Free cancellation up to 24 hours before appointment</span>\r\n                                <span>&#8226; 50% charge for cancellations within 24 hours</span>\r\n                                <span>&#8226; No refund for no-shows</span>\r\n                                <span>&#8226; Emergency cancellations will be reviewed case by case</span>\r\n                            </div>\r\n\r\n                            <!-- Rescheduling Policy -->\r\n                            <div class=\"policy-item d-flex justify-content-between align-items-center\"\r\n                                (click)=\"showReducingPolicy = !showReducingPolicy\">\r\n                                <h3 class=\"policy-title\">Rescheduling Policy</h3>\r\n                                <div class=\"policy-arrow d-flex align-items-center justify-content-center\"><mat-icon\r\n                                        *ngIf=\"!showReducingPolicy\">keyboard_arrow_right</mat-icon>\r\n                                    <mat-icon *ngIf=\"showReducingPolicy\">keyboard_arrow_down</mat-icon>\r\n                                </div>\r\n                            </div>\r\n                            <div class=\"cancellation_policies d-flex flex-column gap-2 fw-500\"\r\n                                *ngIf=\"showReducingPolicy\">\r\n                                <span>&#8226; Free cancellation up to 24 hours before appointment</span>\r\n                                <span>&#8226; 50% charge for cancellations within 24 hours</span>\r\n                                <span>&#8226; No refund for no-shows</span>\r\n                                <span>&#8226; Emergency cancellations will be reviewed case by case</span>\r\n                            </div>\r\n                        </div>\r\n\r\n                        <!-- Acceptance Section -->\r\n                        <div class=\"acceptance-section\">\r\n                            <input type=\"checkbox\" class=\"custom-checkbox\">\r\n                            <p class=\"acceptance-text\">\r\n                                I understand and accept the cancellation & rescheduling policies and\r\n                                <a href=\"#\" class=\"terms-link\">Terms & Conditions<span\r\n                                        class=\"external-link-icon\"></span></a>\r\n                            </p>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #paymentTab>\r\n    <div class=\"w-60 payment_section\">\r\n        <div class=\"w-100 h-100\">\r\n            <div class=\"w-100 d-flex justify-content-center align-items-center flex-column\">\r\n                <!-- Header Section -->\r\n                <div class=\"payment-header mb-3 w-100\">\r\n                    <h1 class=\"mb-0\">Payment & Confirmation</h1>\r\n                    <p class=\"payment-subtitle mb-0\">Review your booking and complete payment</p>\r\n                </div>\r\n\r\n                <!-- Booking Summary Card -->\r\n                <div class=\"booking-summary-card\" [ngClass]=\"{'w-100' : screenWidth < 475,'w-50':screenWidth > 475}\">\r\n                    <h2 class=\"summary-title\">Booking Summary</h2>\r\n\r\n                    <!-- Service -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Service</div>\r\n                        <div class=\"summary-value\">{{selectedService?.name ? selectedService?.name : 'N/A'}}</div>\r\n                    </div>\r\n\r\n                    <!-- Professional -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Professional</div>\r\n                        <div class=\"summary-value\">{{selectedStaff?.staffName ? selectedStaff?.staffName : 'N/A'}}</div>\r\n                    </div>\r\n\r\n                    <!-- Location -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Location</div>\r\n                        <div class=\"summary-value\">{{selectedLocation?.storeName ? selectedLocation?.storeName : 'N/A'}}\r\n                        </div>\r\n                    </div>\r\n\r\n                    <!-- Date & Time -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Date & Time</div>\r\n                        <div class=\"summary-value\">{{selectedDateStr ? (selectedDateStr) : 'N/A'}} at\r\n                            15:30</div>\r\n                    </div>\r\n\r\n                    <!-- Duration -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Duration</div>\r\n                        <div class=\"summary-value\">{{selectedService?.duration ? selectedService?.duration : 'N/A'}}\r\n                            minutes</div>\r\n                    </div>\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Tax Percent</div>\r\n                        <div class=\"summary-value\">{{selectedService?.priceDetails?.taxPercent ?\r\n                            selectedService?.priceDetails?.taxPercent : 'N/A'}}%</div>\r\n                    </div>\r\n                    <!-- Total -->\r\n                    <div class=\"summary-row total-row\">\r\n                        <div class=\"summary-label\">Total</div>\r\n                        <div class=\"summary-value\">\r\n                            <span class=\"currency-symbol\">₹</span>{{selectedService?.priceDetails?.price ?\r\n                            selectedService?.priceDetails?.price : 'N/A'}}\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #statusTemplate>\r\n    <div class=\"booking-confirmation\">\r\n        <!-- Success Icon -->\r\n        <div class=\"success-icon\">\r\n            <div class=\"checkmark-circle\">\r\n                <img src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/881293c1758695578518success.gif\"\r\n                    class=\"w-100 h-100\" *ngIf=\"apiStatus\">\r\n                <img src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/325000c1758695564518fail.gif\"\r\n                    class=\"w-100 h-100\" *ngIf=\"!apiStatus\">\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Main Content -->\r\n        <div class=\"confirmation-content\">\r\n            <h1 class=\"confirmation-title\">{{apiStatus ? 'Booking Confirmed!' : 'Booking Failed'}}</h1>\r\n            <p class=\"confirmation-message\">\r\n                {{apiStatus ? 'Your appointment has been successfully booked.':'Failed to book you appointment. Please\r\n                try again later'}}\r\n            </p>\r\n\r\n            <!-- Details Card -->\r\n            <div class=\"d-flex w-100 align-items-center justify-content-center\" *ngIf=\"apiStatus\">\r\n                <div class=\"details-card\">\r\n                    <h3 class=\"details-title\">Appointment Details</h3>\r\n\r\n                    <div class=\"details-row\">\r\n                        <span class=\"detail-label\">Service</span>\r\n                        <span class=\"detail-value\">{{appointmentPayload.serviceDetail?.name ?\r\n                            appointmentPayload.serviceDetail?.name : 'N/A'}}</span>\r\n                    </div>\r\n\r\n                    <div class=\"details-row\">\r\n                        <span class=\"detail-label\">Professional</span>\r\n                        <span class=\"detail-value\">{{appointmentPayload.staffDetail?.name ?\r\n                            appointmentPayload.staffDetail?.name : 'N/A'}}</span>\r\n                    </div>\r\n                    <div class=\"details-row\">\r\n                        <span class=\"detail-label\">Date & Time</span>\r\n                        <span class=\"detail-value\">{{appointmentPayload.bookingDate ?\r\n                            appointmentPayload.bookingDate.slice(0,8) :\r\n                            'N/A'}} at\r\n                            {{appointmentPayload.startTime ? appointmentPayload.startTime : 'N/A'}}</span>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n\r\n\r\n            <!-- Action Buttons -->\r\n            <!-- <div class=\"action-buttons\">\r\n                <button class=\"btn btn-outline\">View My Bookings</button>\r\n                <button class=\"btn btn-primary\">Back to Admin</button>\r\n            </div> -->\r\n        </div>\r\n    </div>\r\n</ng-template>"]}
|