simpo-component-library 3.6.526 → 3.6.527

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.
@@ -464,7 +464,7 @@ export class AppointmentBookingComponent {
464
464
  this.router.navigate(['/admin/appointments/list-appointments']);
465
465
  }
466
466
  else {
467
- this.router.navigate(['/home']);
467
+ this.router.navigate(['']);
468
468
  }
469
469
  }
470
470
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AppointmentBookingComponent, deps: [{ token: i1.RestService }, { token: i2.EventsService }, { token: i3.Router }, { token: i4.MessageService }], target: i0.ɵɵFactoryTarget.Component }); }
@@ -492,4 +492,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
492
492
  type: HostListener,
493
493
  args: ['document:click']
494
494
  }] } });
495
- //# 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  skeletonLoader: boolean = false;\r\n  businessName = localStorage.getItem('businessName') ? localStorage.getItem('businessName') : (localStorage.getItem('bName') ? localStorage.getItem('bName') : '');\r\n  businessId: any = localStorage.getItem('businessId') ? localStorage.getItem('businessId') : (localStorage.getItem('bId') ? localStorage.getItem('bId') : '');\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  homeAddress: string = '';\r\n  instructions: string = '';\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 && service.serviceId != this.selectedService.serviceId) {\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 && location.id != this.selectedLocation.id) {\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    staff.selected = true;\r\n    if (this.selectedStaff && staff.staffId != this.selectedStaff.staffId) {\r\n      this.selectedStaff.selected = false;\r\n    }\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      //     if (this.selectedLocation && this.selectedService)\r\n      //       this.getAvailableSlots();\r\n      //   }\r\n      // }\r\n      this.getAllLocations();\r\n    }\r\n    else if (this.selectedTab === 'locationListing') {\r\n      this.activeButton = true;\r\n      this.accessedTabs.locationListing = true;\r\n      // if (!this.activeButton) {\r\n      //   this.getAllStaff();\r\n\r\n      // }\r\n      this.getAllStaff();\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      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.loader = false;\r\n    if (this.selectedTab != 'serviceListing') {\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          this.selectedLocation = null;\r\n        }\r\n      }\r\n      else if (this.selectedTab === 'staffListing') {\r\n        this.selectedStaff = null;\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  }\r\n  serviceData: any[] = [];\r\n  getAllServices() {\r\n    this.skeletonLoader = true\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.skeletonLoader = false;\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) {\r\n            this.selectedLocation = this.locationData[0];\r\n            this.loader = false;\r\n            this.accessedTabs.locationListing = 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            this.accessedTabs.locationListing = true;\r\n          }\r\n        }\r\n        else {\r\n          this.messageService.add({ severity: 'error', summary: 'No Location', detail: 'No Location added for selected service' });\r\n          this.loader = false;\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.activeButton = 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 && staff.bookingAllowed);\r\n          this.staffData.forEach(staff => staff.selected = false);\r\n          if (this.staffData.length === 1) {\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            this.accessedTabs.staffListing = false;\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            this.accessedTabs.staffListing = true;\r\n          }\r\n        }\r\n        else {\r\n          this.messageService.add({ severity: 'error', summary: 'No Staff Present', detail: 'No Staff present for selected service' });\r\n          this.loader = false;\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.activeButton = false;\r\n    this.skeletonLoader = true;\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    this.slotsPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;\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: time });\r\n        this.skeletonLoader = false;\r\n      })\r\n      if (res.length <= 0) {\r\n        this.messageService.add({ severity: 'error', summary: 'Booking Failed', detail: 'Unable to fetch available slots. Please try again later' });\r\n      }\r\n    },\r\n      (error: any) => {\r\n        this.messageService.add({ severity: 'error', summary: 'Unable to fetch slots', detail: error.error.message });\r\n        this.loader = false;\r\n      })\r\n  }\r\n  isProcessing: boolean = false;\r\n  selectedTime: any\r\n  selectTimeSlot(time: any) {\r\n    time.selected = true;\r\n    if (this.selectedTime && time.value != this.selectedTime.value) {\r\n      this.selectedTime.selected = false;\r\n    }\r\n    this.selectedTime = time;\r\n    this.activeButton = true;\r\n  }\r\n  termsAndConditions: boolean = false;\r\n  checkRequiredValues() {\r\n    if (this.appointmentPayload.customerDetail.name && this.appointmentPayload.customerDetail.email.includes('@') && this.appointmentPayload.customerDetail.phoneNumber.length === 10 && this.termsAndConditions) {\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    this.isProcessing = true;\r\n    const request_form = localStorage.getItem(\"REQUEST_FROM\");\r\n    if (request_form === 'ECOMMERCE') {\r\n      this.createAppointment();\r\n      this.isProcessing = false;\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.convertTo24Hour(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        this.messageService.add({ severity: 'error', summary: 'Booking Failed', detail: error.error.message });\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.convertTo24Hour(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        localStorage.setItem('appointmentPaymentId', res.pgOrderId);\r\n        this.isProcessing = false;  \r\n        this._eventService.cashFreeEvent.emit({ data: { orderSignature: res.orderSignature } });\r\n      },\r\n      (error: any) => {\r\n        this.loader = false;\r\n        this.messageService.add({ severity: 'error', summary: 'Payment Failed', detail: error.error.message });\r\n      }\r\n    )\r\n\r\n  }\r\n  goBack() {\r\n    if (localStorage.getItem(\"REQUEST_FROM\") === 'ECOMMERCE') {\r\n      this.router.navigate(['/admin/appointments/list-appointments'])\r\n    }\r\n    else {\r\n      this.router.navigate(['/home'])\r\n    }\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 Home</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 *ngIf=\"!skeletonLoader\">\r\n                <ng-container *ngTemplateOutlet=\"serviceListing\"></ng-container>\r\n            </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            [ngStyle]=\"{'justify-content': selectedTab != 'serviceListing' ? 'space-between' : 'end'}\">\r\n            <span class=\"back-footer-btn cursor-pointer\" (click)=\"previousStep()\"\r\n                *ngIf=\"selectedTab != 'serviceListing'\">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=\"cursor-pointer d-flex justify-content-evenly align-items-center\"\r\n                *ngIf=\"selectedTab==='paymentTab'\" (click)=\"checkPayment()\" [disabled]=\"isProcessing\"\r\n                [ngClass]=\"{'pay-now-btn' : selectedService?.depositAmount?.depositRequired,'complete_booking' : !selectedService?.depositAmount?.depositRequired}\">\r\n                <img src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/304012c1753440087996Background.png\">\r\n                {{selectedService?.depositAmount?.depositRequired ? 'Pay Now' : 'Complete Booking'}}\r\n            </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>\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\" *ngIf=\"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 staff-listing\">\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>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=\"card rounded-3 p-3\" (click)=\"selectStaff(staff)\"\r\n                            [ngClass]=\"{ 'staff-card-selected' : staff?.selected, 'staff-card': !staff?.selected }\">\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>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 justify-content-between\"\r\n                                (click)=\"$event.stopPropagation()\">\r\n                                <input type=\"text\" class=\"date-input border-0 rounded-2\" placeholder=\"dd-mm-yyyy\"\r\n                                    [value]=\"selectedDateStr\" readonly (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                                <ng-container *ngIf=\"!skeletonLoader ;else slotsLoader\">\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 : 'N/A'}}</div>\r\n                                    </div>\r\n                                </ng-container>\r\n                                <ng-template #slotsLoader>\r\n                                    <!-- Time Slot Grid Skeleton Loader HTML -->\r\n                                    <div class=\"time-slot-grid\">\r\n                                        <!-- Row 1 -->\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n\r\n                                        <!-- Row 2 -->\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n\r\n                                        <!-- Row 3 -->\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n\r\n                                        <!-- Row 4 -->\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n\r\n                                        <!-- Row 5 -->\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n\r\n                                        <!-- Row 6 -->\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                    </div>\r\n\r\n                                </ng-template>\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 overflow-hidden\">\r\n        <div class=\"d-flex h-100\">\r\n            <div class=\"h-100 w-100\">\r\n                <!-- Header Section -->\r\n                <div class=\"contact-header mb-2\">\r\n                    <h1>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                                        pattern=\"^[a-z0-9._%+-]+@[a-z0-9.-]+\\.[a-z]{2,4}$\">\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\" [(ngModel)]=\"homeAddress\"></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)\"\r\n                                        [(ngModel)]=\"instructions\"></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 *ngFor=\"let policy of selectedService?.cancellationPolicy\">&#8226;\r\n                                    {{policy}}</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 *ngFor=\"let policy of selectedService?.reschedulePolicy\">&#8226; {{policy}}</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\" [(ngModel)]=\"termsAndConditions\"\r\n                                (ngModelChange)=\"checkRequiredValues()\">\r\n                            <p class=\"acceptance-text\">\r\n                                I understand and accept the cancellation & rescheduling policies and\r\n                                <span class=\"terms-link\">Terms & Conditions<span\r\n                                        class=\"external-link-icon\"></span></span>\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>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\" *ngIf=\"selectedStaff?.staffName\">\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                            {{selectedTime ? selectedTime.value : 'N/A'}}</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 : 0}}%</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?.totalPrice ?\r\n                            selectedService?.priceDetails?.totalPrice : '0'}}\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\" *ngIf=\"appointmentPayload?.staffDetail?.name\">\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,10) :\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>\r\n<ng-template #skeletonLoader *ngIf=\"skeletonLoader\">\r\n    <!-- Service Skeleton Loader HTML -->\r\n    <div class=\"service-grid\">\r\n        <!-- Skeleton Card 1 -->\r\n        <div class=\"service-card skeleton-card\">\r\n            <div class=\"service-header\">\r\n                <div class=\"skeleton skeleton-icon\"></div>\r\n                <div class=\"service-content\">\r\n                    <div class=\"skeleton skeleton-title\"></div>\r\n                    <div class=\"skeleton skeleton-price\"></div>\r\n                    <div class=\"skeleton skeleton-duration\"></div>\r\n                </div>\r\n            </div>\r\n            <div class=\"skeleton skeleton-category\"></div>\r\n            <div class=\"skeleton skeleton-description\"></div>\r\n            <div class=\"skeleton skeleton-badge\"></div>\r\n        </div>\r\n\r\n        <!-- Skeleton Card 2 -->\r\n        <div class=\"service-card skeleton-card\">\r\n            <div class=\"service-header\">\r\n                <div class=\"skeleton skeleton-icon\"></div>\r\n                <div class=\"service-content\">\r\n                    <div class=\"skeleton skeleton-title\"></div>\r\n                    <div class=\"skeleton skeleton-price\"></div>\r\n                    <div class=\"skeleton skeleton-duration\"></div>\r\n                </div>\r\n            </div>\r\n            <div class=\"skeleton skeleton-category\"></div>\r\n            <div class=\"skeleton skeleton-description\"></div>\r\n            <div class=\"skeleton skeleton-badge\"></div>\r\n        </div>\r\n\r\n        <!-- Skeleton Card 3 -->\r\n        <div class=\"service-card skeleton-card\">\r\n            <div class=\"service-header\">\r\n                <div class=\"skeleton skeleton-icon\"></div>\r\n                <div class=\"service-content\">\r\n                    <div class=\"skeleton skeleton-title\"></div>\r\n                    <div class=\"skeleton skeleton-price\"></div>\r\n                    <div class=\"skeleton skeleton-duration\"></div>\r\n                </div>\r\n            </div>\r\n            <div class=\"skeleton skeleton-category\"></div>\r\n            <div class=\"skeleton skeleton-description\"></div>\r\n            <div class=\"skeleton skeleton-badge\"></div>\r\n        </div>\r\n\r\n        <!-- Skeleton Card 4 -->\r\n        <div class=\"service-card skeleton-card\">\r\n            <div class=\"service-header\">\r\n                <div class=\"skeleton skeleton-icon\"></div>\r\n                <div class=\"service-content\">\r\n                    <div class=\"skeleton skeleton-title\"></div>\r\n                    <div class=\"skeleton skeleton-price\"></div>\r\n                    <div class=\"skeleton skeleton-duration\"></div>\r\n                </div>\r\n            </div>\r\n            <div class=\"skeleton skeleton-category\"></div>\r\n            <div class=\"skeleton skeleton-description\"></div>\r\n            <div class=\"skeleton skeleton-badge\"></div>\r\n        </div>\r\n\r\n        <!-- Skeleton Card 5 -->\r\n        <div class=\"service-card skeleton-card\">\r\n            <div class=\"service-header\">\r\n                <div class=\"skeleton skeleton-icon\"></div>\r\n                <div class=\"service-content\">\r\n                    <div class=\"skeleton skeleton-title\"></div>\r\n                    <div class=\"skeleton skeleton-price\"></div>\r\n                    <div class=\"skeleton skeleton-duration\"></div>\r\n                </div>\r\n            </div>\r\n            <div class=\"skeleton skeleton-category\"></div>\r\n            <div class=\"skeleton skeleton-description\"></div>\r\n            <div class=\"skeleton skeleton-badge\"></div>\r\n        </div>\r\n\r\n        <!-- Skeleton Card 6 -->\r\n        <div class=\"service-card skeleton-card\">\r\n            <div class=\"service-header\">\r\n                <div class=\"skeleton skeleton-icon\"></div>\r\n                <div class=\"service-content\">\r\n                    <div class=\"skeleton skeleton-title\"></div>\r\n                    <div class=\"skeleton skeleton-price\"></div>\r\n                    <div class=\"skeleton skeleton-duration\"></div>\r\n                </div>\r\n            </div>\r\n            <div class=\"skeleton skeleton-category\"></div>\r\n            <div class=\"skeleton skeleton-description\"></div>\r\n            <div class=\"skeleton skeleton-badge\"></div>\r\n        </div>\r\n    </div>\r\n</ng-template>"]}
495
+ //# 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  skeletonLoader: boolean = false;\r\n  businessName = localStorage.getItem('businessName') ? localStorage.getItem('businessName') : (localStorage.getItem('bName') ? localStorage.getItem('bName') : '');\r\n  businessId: any = localStorage.getItem('businessId') ? localStorage.getItem('businessId') : (localStorage.getItem('bId') ? localStorage.getItem('bId') : '');\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  homeAddress: string = '';\r\n  instructions: string = '';\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 && service.serviceId != this.selectedService.serviceId) {\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 && location.id != this.selectedLocation.id) {\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    staff.selected = true;\r\n    if (this.selectedStaff && staff.staffId != this.selectedStaff.staffId) {\r\n      this.selectedStaff.selected = false;\r\n    }\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      //     if (this.selectedLocation && this.selectedService)\r\n      //       this.getAvailableSlots();\r\n      //   }\r\n      // }\r\n      this.getAllLocations();\r\n    }\r\n    else if (this.selectedTab === 'locationListing') {\r\n      this.activeButton = true;\r\n      this.accessedTabs.locationListing = true;\r\n      // if (!this.activeButton) {\r\n      //   this.getAllStaff();\r\n\r\n      // }\r\n      this.getAllStaff();\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      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.loader = false;\r\n    if (this.selectedTab != 'serviceListing') {\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          this.selectedLocation = null;\r\n        }\r\n      }\r\n      else if (this.selectedTab === 'staffListing') {\r\n        this.selectedStaff = null;\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  }\r\n  serviceData: any[] = [];\r\n  getAllServices() {\r\n    this.skeletonLoader = true\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.skeletonLoader = false;\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) {\r\n            this.selectedLocation = this.locationData[0];\r\n            this.loader = false;\r\n            this.accessedTabs.locationListing = 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            this.accessedTabs.locationListing = true;\r\n          }\r\n        }\r\n        else {\r\n          this.messageService.add({ severity: 'error', summary: 'No Location', detail: 'No Location added for selected service' });\r\n          this.loader = false;\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.activeButton = 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 && staff.bookingAllowed);\r\n          this.staffData.forEach(staff => staff.selected = false);\r\n          if (this.staffData.length === 1) {\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            this.accessedTabs.staffListing = false;\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            this.accessedTabs.staffListing = true;\r\n          }\r\n        }\r\n        else {\r\n          this.messageService.add({ severity: 'error', summary: 'No Staff Present', detail: 'No Staff present for selected service' });\r\n          this.loader = false;\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.activeButton = false;\r\n    this.skeletonLoader = true;\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    this.slotsPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;\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: time });\r\n        this.skeletonLoader = false;\r\n      })\r\n      if (res.length <= 0) {\r\n        this.messageService.add({ severity: 'error', summary: 'Booking Failed', detail: 'Unable to fetch available slots. Please try again later' });\r\n      }\r\n    },\r\n      (error: any) => {\r\n        this.messageService.add({ severity: 'error', summary: 'Unable to fetch slots', detail: error.error.message });\r\n        this.loader = false;\r\n      })\r\n  }\r\n  isProcessing: boolean = false;\r\n  selectedTime: any\r\n  selectTimeSlot(time: any) {\r\n    time.selected = true;\r\n    if (this.selectedTime && time.value != this.selectedTime.value) {\r\n      this.selectedTime.selected = false;\r\n    }\r\n    this.selectedTime = time;\r\n    this.activeButton = true;\r\n  }\r\n  termsAndConditions: boolean = false;\r\n  checkRequiredValues() {\r\n    if (this.appointmentPayload.customerDetail.name && this.appointmentPayload.customerDetail.email.includes('@') && this.appointmentPayload.customerDetail.phoneNumber.length === 10 && this.termsAndConditions) {\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    this.isProcessing = true;\r\n    const request_form = localStorage.getItem(\"REQUEST_FROM\");\r\n    if (request_form === 'ECOMMERCE') {\r\n      this.createAppointment();\r\n      this.isProcessing = false;\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.convertTo24Hour(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        this.messageService.add({ severity: 'error', summary: 'Booking Failed', detail: error.error.message });\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.convertTo24Hour(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        localStorage.setItem('appointmentPaymentId', res.pgOrderId);\r\n        this.isProcessing = false;  \r\n        this._eventService.cashFreeEvent.emit({ data: { orderSignature: res.orderSignature } });\r\n      },\r\n      (error: any) => {\r\n        this.loader = false;\r\n        this.messageService.add({ severity: 'error', summary: 'Payment Failed', detail: error.error.message });\r\n      }\r\n    )\r\n\r\n  }\r\n  goBack() {\r\n    if (localStorage.getItem(\"REQUEST_FROM\") === 'ECOMMERCE') {\r\n      this.router.navigate(['/admin/appointments/list-appointments'])\r\n    }\r\n    else {\r\n      this.router.navigate([''])\r\n    }\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 Home</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 *ngIf=\"!skeletonLoader\">\r\n                <ng-container *ngTemplateOutlet=\"serviceListing\"></ng-container>\r\n            </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            [ngStyle]=\"{'justify-content': selectedTab != 'serviceListing' ? 'space-between' : 'end'}\">\r\n            <span class=\"back-footer-btn cursor-pointer\" (click)=\"previousStep()\"\r\n                *ngIf=\"selectedTab != 'serviceListing'\">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=\"cursor-pointer d-flex justify-content-evenly align-items-center\"\r\n                *ngIf=\"selectedTab==='paymentTab'\" (click)=\"checkPayment()\" [disabled]=\"isProcessing\"\r\n                [ngClass]=\"{'pay-now-btn' : selectedService?.depositAmount?.depositRequired,'complete_booking' : !selectedService?.depositAmount?.depositRequired}\">\r\n                <img src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/304012c1753440087996Background.png\">\r\n                {{selectedService?.depositAmount?.depositRequired ? 'Pay Now' : 'Complete Booking'}}\r\n            </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>\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\" *ngIf=\"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 staff-listing\">\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>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=\"card rounded-3 p-3\" (click)=\"selectStaff(staff)\"\r\n                            [ngClass]=\"{ 'staff-card-selected' : staff?.selected, 'staff-card': !staff?.selected }\">\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>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 justify-content-between\"\r\n                                (click)=\"$event.stopPropagation()\">\r\n                                <input type=\"text\" class=\"date-input border-0 rounded-2\" placeholder=\"dd-mm-yyyy\"\r\n                                    [value]=\"selectedDateStr\" readonly (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                                <ng-container *ngIf=\"!skeletonLoader ;else slotsLoader\">\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 : 'N/A'}}</div>\r\n                                    </div>\r\n                                </ng-container>\r\n                                <ng-template #slotsLoader>\r\n                                    <!-- Time Slot Grid Skeleton Loader HTML -->\r\n                                    <div class=\"time-slot-grid\">\r\n                                        <!-- Row 1 -->\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n\r\n                                        <!-- Row 2 -->\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n\r\n                                        <!-- Row 3 -->\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n\r\n                                        <!-- Row 4 -->\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n\r\n                                        <!-- Row 5 -->\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n\r\n                                        <!-- Row 6 -->\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                        <div class=\"skeleton-time-slot\"></div>\r\n                                    </div>\r\n\r\n                                </ng-template>\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 overflow-hidden\">\r\n        <div class=\"d-flex h-100\">\r\n            <div class=\"h-100 w-100\">\r\n                <!-- Header Section -->\r\n                <div class=\"contact-header mb-2\">\r\n                    <h1>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                                        pattern=\"^[a-z0-9._%+-]+@[a-z0-9.-]+\\.[a-z]{2,4}$\">\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\" [(ngModel)]=\"homeAddress\"></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)\"\r\n                                        [(ngModel)]=\"instructions\"></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 *ngFor=\"let policy of selectedService?.cancellationPolicy\">&#8226;\r\n                                    {{policy}}</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 *ngFor=\"let policy of selectedService?.reschedulePolicy\">&#8226; {{policy}}</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\" [(ngModel)]=\"termsAndConditions\"\r\n                                (ngModelChange)=\"checkRequiredValues()\">\r\n                            <p class=\"acceptance-text\">\r\n                                I understand and accept the cancellation & rescheduling policies and\r\n                                <span class=\"terms-link\">Terms & Conditions<span\r\n                                        class=\"external-link-icon\"></span></span>\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>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\" *ngIf=\"selectedStaff?.staffName\">\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                            {{selectedTime ? selectedTime.value : 'N/A'}}</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 : 0}}%</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?.totalPrice ?\r\n                            selectedService?.priceDetails?.totalPrice : '0'}}\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\" *ngIf=\"appointmentPayload?.staffDetail?.name\">\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,10) :\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>\r\n<ng-template #skeletonLoader *ngIf=\"skeletonLoader\">\r\n    <!-- Service Skeleton Loader HTML -->\r\n    <div class=\"service-grid\">\r\n        <!-- Skeleton Card 1 -->\r\n        <div class=\"service-card skeleton-card\">\r\n            <div class=\"service-header\">\r\n                <div class=\"skeleton skeleton-icon\"></div>\r\n                <div class=\"service-content\">\r\n                    <div class=\"skeleton skeleton-title\"></div>\r\n                    <div class=\"skeleton skeleton-price\"></div>\r\n                    <div class=\"skeleton skeleton-duration\"></div>\r\n                </div>\r\n            </div>\r\n            <div class=\"skeleton skeleton-category\"></div>\r\n            <div class=\"skeleton skeleton-description\"></div>\r\n            <div class=\"skeleton skeleton-badge\"></div>\r\n        </div>\r\n\r\n        <!-- Skeleton Card 2 -->\r\n        <div class=\"service-card skeleton-card\">\r\n            <div class=\"service-header\">\r\n                <div class=\"skeleton skeleton-icon\"></div>\r\n                <div class=\"service-content\">\r\n                    <div class=\"skeleton skeleton-title\"></div>\r\n                    <div class=\"skeleton skeleton-price\"></div>\r\n                    <div class=\"skeleton skeleton-duration\"></div>\r\n                </div>\r\n            </div>\r\n            <div class=\"skeleton skeleton-category\"></div>\r\n            <div class=\"skeleton skeleton-description\"></div>\r\n            <div class=\"skeleton skeleton-badge\"></div>\r\n        </div>\r\n\r\n        <!-- Skeleton Card 3 -->\r\n        <div class=\"service-card skeleton-card\">\r\n            <div class=\"service-header\">\r\n                <div class=\"skeleton skeleton-icon\"></div>\r\n                <div class=\"service-content\">\r\n                    <div class=\"skeleton skeleton-title\"></div>\r\n                    <div class=\"skeleton skeleton-price\"></div>\r\n                    <div class=\"skeleton skeleton-duration\"></div>\r\n                </div>\r\n            </div>\r\n            <div class=\"skeleton skeleton-category\"></div>\r\n            <div class=\"skeleton skeleton-description\"></div>\r\n            <div class=\"skeleton skeleton-badge\"></div>\r\n        </div>\r\n\r\n        <!-- Skeleton Card 4 -->\r\n        <div class=\"service-card skeleton-card\">\r\n            <div class=\"service-header\">\r\n                <div class=\"skeleton skeleton-icon\"></div>\r\n                <div class=\"service-content\">\r\n                    <div class=\"skeleton skeleton-title\"></div>\r\n                    <div class=\"skeleton skeleton-price\"></div>\r\n                    <div class=\"skeleton skeleton-duration\"></div>\r\n                </div>\r\n            </div>\r\n            <div class=\"skeleton skeleton-category\"></div>\r\n            <div class=\"skeleton skeleton-description\"></div>\r\n            <div class=\"skeleton skeleton-badge\"></div>\r\n        </div>\r\n\r\n        <!-- Skeleton Card 5 -->\r\n        <div class=\"service-card skeleton-card\">\r\n            <div class=\"service-header\">\r\n                <div class=\"skeleton skeleton-icon\"></div>\r\n                <div class=\"service-content\">\r\n                    <div class=\"skeleton skeleton-title\"></div>\r\n                    <div class=\"skeleton skeleton-price\"></div>\r\n                    <div class=\"skeleton skeleton-duration\"></div>\r\n                </div>\r\n            </div>\r\n            <div class=\"skeleton skeleton-category\"></div>\r\n            <div class=\"skeleton skeleton-description\"></div>\r\n            <div class=\"skeleton skeleton-badge\"></div>\r\n        </div>\r\n\r\n        <!-- Skeleton Card 6 -->\r\n        <div class=\"service-card skeleton-card\">\r\n            <div class=\"service-header\">\r\n                <div class=\"skeleton skeleton-icon\"></div>\r\n                <div class=\"service-content\">\r\n                    <div class=\"skeleton skeleton-title\"></div>\r\n                    <div class=\"skeleton skeleton-price\"></div>\r\n                    <div class=\"skeleton skeleton-duration\"></div>\r\n                </div>\r\n            </div>\r\n            <div class=\"skeleton skeleton-category\"></div>\r\n            <div class=\"skeleton skeleton-description\"></div>\r\n            <div class=\"skeleton skeleton-badge\"></div>\r\n        </div>\r\n    </div>\r\n</ng-template>"]}