simpo-component-library 3.6.486 → 3.6.487

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.
@@ -6,7 +6,7 @@ import { FormsModule } from '@angular/forms';
6
6
  import { MatFormFieldModule } from "@angular/material/form-field";
7
7
  import { MatDatepickerModule } from "@angular/material/datepicker";
8
8
  import * as i0 from "@angular/core";
9
- import * as i1 from "@simpo-ui/services/rest.service";
9
+ import * as i1 from "../../../../services/rest.service";
10
10
  import * as i2 from "../../../../services/events.service";
11
11
  import * as i3 from "@angular/material/dialog";
12
12
  import * as i4 from "@angular/material/snack-bar";
@@ -406,4 +406,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
406
406
  type: HostListener,
407
407
  args: ['document:click']
408
408
  }] } });
409
- //# 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 } 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 { RestService } from '@simpo-ui/services/rest.service';\r\nimport { MatSnackBar } from '@angular/material/snack-bar';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { EventsService } from '../../../../services/events.service';\r\n\r\n@Component({\r\n  selector: 'simpo-appointment-booking',\r\n  standalone: true,\r\n  imports: [CdkDragPlaceholder, CommonModule, MatIcon, MatFormFieldModule, MatDatepickerModule, FormsModule],\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 matDialog: MatDialog,\r\n    private snackBar: MatSnackBar\r\n  ) {\r\n\r\n  }\r\n  ngOnInit() {\r\n    this.getAllServices();\r\n  }\r\n  @HostListener('document:click')\r\n  closeOnOutsideClick() {\r\n    this.showCalendar = false;\r\n  }\r\n  accessedTabs = {\r\n    serviceListing: false,\r\n    locationListing: false,\r\n    staffListing: false\r\n  }\r\n\r\n  businessName = localStorage.getItem('bName') ?? \"\";\r\n  businessId: string = 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  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\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: Date) {\r\n    this.selectedDate = date;\r\n    this.selectedDateStr = this.formatDate(date);\r\n    this.showCalendar = false;\r\n    this.getAvailableSlots();\r\n  }\r\n  private formatDate(d: Date): string {\r\n    const dd = String(d.getDate()).padStart(2, '0');\r\n    const mm = String(d.getMonth() + 1).padStart(2, '0');\r\n    const yyyy = d.getFullYear();\r\n    return `${dd}-${mm}-${yyyy}`;\r\n  }\r\n\r\n  selectService(service: any) {\r\n    service.selected = true;\r\n    if (this.selectedService) {\r\n      this.selectedService.selected = false;\r\n    }\r\n    this.selectedService = service\r\n    this.activeButton = this.selectedService ? true : false;\r\n  }\r\n  selectLocation(location: any) {\r\n    location.selected = true;\r\n    if (this.selectedLocation) {\r\n      this.selectedLocation.selected = false;\r\n    }\r\n    this.activeButton = true;\r\n    this.selectedLocation = location;\r\n  }\r\n  selectedStaff: any;\r\n  selectStaff(staff: any) {\r\n    this.selectedStaff = staff;\r\n    this.activeButton = true;\r\n  }\r\n  nextStep() {\r\n    if (this.selectedTab === 'serviceListing') {\r\n      this.activeButton = this.selectedLocation ? true : false;\r\n      this.accessedTabs.serviceListing = true;\r\n      if (!this.activeButton) {\r\n        this.getAllLocations();\r\n      }\r\n      else {\r\n        if (this.accessedTabs.locationListing) {\r\n          this.selectedTab = 'locationListing';\r\n          this.barWidth = '29.28';\r\n        }\r\n        else if (this.accessedTabs.staffListing) {\r\n          this.selectedTab = 'staffListing';\r\n          this.barWidth = '43.57';\r\n        }\r\n        else {\r\n          this.selectedTab = 'dateSelection';\r\n          this.barWidth = '58.57';\r\n        }\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'locationListing') {\r\n      this.activeButton = this.selectedStaff ? true : false;\r\n      this.accessedTabs.locationListing = true;\r\n      if (!this.activeButton) {\r\n        this.getAllStaff();\r\n\r\n      }\r\n      else {\r\n        if (this.accessedTabs.staffListing) {\r\n          this.selectedTab = 'staffListing';\r\n          this.barWidth = '43.57';\r\n        }\r\n        else {\r\n          this.selectedTab = 'dateSelection';\r\n          this.barWidth = '58.57';\r\n        }\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'staffListing') {\r\n      this.accessedTabs.staffListing = true;\r\n      this.selectedTab = 'dateSelection';\r\n      this.barWidth = '58.57';\r\n      if (!this.activeButton)\r\n        this.getAvailableSlots();\r\n    }\r\n    else if (this.selectedTab === 'dateSelection') {\r\n      this.activeButton = this.selectedDateStr && this.selectedTime ? true : false\r\n      this.selectedTab = 'contactDetails';\r\n      this.barWidth = '70.57'\r\n    }\r\n    else if (this.selectedTab === 'contactDetails') {\r\n      this.checkRequiredValues();\r\n      this.selectedTab = 'paymentTab';\r\n      this.barWidth = '85.57'\r\n    }\r\n  }\r\n  previousStep() {\r\n    this.activeButton = true;\r\n    if (this.selectedTab === 'locationListing') {\r\n      if (this.accessedTabs.serviceListing) {\r\n        this.selectedTab = 'serviceListing';\r\n        this.barWidth = '14.28';\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'staffListing') {\r\n      if (this.accessedTabs.locationListing) {\r\n        this.selectedTab = 'locationListing';\r\n        this.barWidth = '29.28';\r\n      }\r\n      else if (this.accessedTabs.serviceListing) {\r\n        this.selectedTab = 'serviceListing';\r\n        this.barWidth = '14.28';\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'dateSelection') {\r\n      if (this.accessedTabs.staffListing) {\r\n        this.selectedTab = 'staffListing';\r\n        this.barWidth = '43.57';\r\n      }\r\n      else if (this.accessedTabs.locationListing) {\r\n        this.selectedTab = 'locationListing';\r\n        this.barWidth = '29.28';\r\n      }\r\n      else if (this.accessedTabs.serviceListing) {\r\n        this.selectedTab = 'serviceListing';\r\n        this.barWidth = '14.28';\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'contactDetails') {\r\n      this.selectedTab = 'dateSelection';\r\n      this.barWidth = '58.57'\r\n    }\r\n    else if (this.selectedTab === 'paymentTab') {\r\n      this.selectedTab = 'contactDetails';\r\n      this.barWidth = '70.57';\r\n    }\r\n  }\r\n  serviceData: any[] = [];\r\n  getAllServices() {\r\n    let servicePayload: any = {\r\n      businessId: this.businessId ?? \"\",\r\n      pageNo: 0,\r\n      size: 100\r\n    }\r\n    this.restService.getAllAppointmentService(servicePayload).subscribe(\r\n      (res: any) => {\r\n        if (res.content.length > 0) {\r\n          this.serviceData = res.content.filter((service: any) => service.active === true);\r\n          this.serviceData.forEach(service => service.selected = false);\r\n          console.log(this.serviceData)\r\n          if (this.serviceData.length === 1 && !this.activeButton) {\r\n            this.selectedService = this.serviceData[0];\r\n            this.getAllLocations();\r\n          }\r\n          else {\r\n            this.selectedTab = 'serviceListing';\r\n            this.barWidth = '14.28';\r\n          }\r\n        }\r\n      },\r\n      (error) => {\r\n        // Handle errors gracefully\r\n      }\r\n    );\r\n  }\r\n  locationData: any[] = [];\r\n  getAllLocations() {\r\n    this.loader = true;\r\n    this.locationData = [];\r\n    let payload = { businessId: this.businessId ?? \"\" }\r\n    this.restService.getAllStores(payload).subscribe(\r\n      (res: any) => {\r\n        if (res.data.data.length > 0) {\r\n          let locations = res.data.data.filter((store: any) => { return store.status === 'ACTIVE' });\r\n          locations.forEach((location: any) => {\r\n            if (this.selectedService.storeIds.includes(location.id)) {\r\n              location.selected = false;\r\n              this.locationData.push(location);\r\n            }\r\n          })\r\n          if (this.locationData.length === 1 && !this.activeButton) {\r\n            this.selectedLocation = this.locationData[0];\r\n            this.loader = false;\r\n            this.getAllStaff();\r\n          }\r\n          else {\r\n            this.loader = false;\r\n            this.selectedTab = 'locationListing';\r\n            this.barWidth = '29.28';\r\n          }\r\n        }\r\n      },\r\n      (error) => {\r\n        // Handle errors gracefully\r\n      }\r\n    );\r\n  }\r\n  staffPayload: any = {\r\n    serviceId: '',\r\n    storeId: '',\r\n    businessId: ''\r\n  }\r\n  staffData: any[] = [];\r\n  getAllStaff() {\r\n    this.loader = true;\r\n    this.staffPayload.storeId = this.selectedLocation?.id ?? \"\";\r\n    this.staffPayload.serviceId = this.selectedService?.serviceId ? this.selectedService.serviceId : '';\r\n    this.staffPayload.businessId = this.businessId ?? \"\";\r\n    this.restService.getAllStaff(this.staffPayload).subscribe(\r\n      (res: any) => {\r\n        if (res.length > 0) {\r\n          this.staffData = res.filter((staff: any) => staff.active === true);\r\n          if (this.staffData.length === 1 && !this.activeButton) {\r\n            this.loader = false;\r\n            this.selectedTab = 'dateSelection';\r\n            this.barWidth = '58.57';\r\n            this.selectedStaff = this.staffData[0];\r\n            this.getAvailableSlots();\r\n          }\r\n          else if (this.staffData.length > 1) {\r\n            this.loader = false;\r\n            this.selectedTab = 'staffListing';\r\n            this.barWidth = '43.57';\r\n          }\r\n        }\r\n      },\r\n      (error) => {\r\n        // Handle errors gracefully\r\n      }\r\n    );\r\n  }\r\n  convertTo24Hour(time: string): string {\r\n    const [hourMin, modifierRaw] = time.split(' ');\r\n    const modifier = modifierRaw.toUpperCase(); // \"AM\" or \"PM\"\r\n    let [hours, minutes] = hourMin.split(':').map(Number);\r\n\r\n    if (modifier === 'PM' && hours < 12) {\r\n      hours += 12;\r\n    }\r\n    if (modifier === 'AM' && hours === 12) {\r\n      hours = 0;\r\n    }\r\n\r\n    const hh = hours.toString().padStart(2, '0');\r\n    const mm = minutes.toString().padStart(2, '0');\r\n    return `${hh}:${mm} ${modifier}`;\r\n  }\r\n  slotsPayload: any = {\r\n    storeId: \"\",\r\n    serviceId: \"\",\r\n    businessId: \"\",\r\n    bookingDate: \"\"\r\n  }\r\n  locationTiming: any[] = [];\r\n  loader: boolean = false;\r\n  getAvailableSlots() {\r\n    this.loader = false;\r\n    this.locationTiming = [];\r\n    this.slotsPayload.storeId = this.selectedLocation?.id ?? \"\";\r\n    this.slotsPayload.serviceId = this.selectedService?.serviceId ? this.selectedService.serviceId : '';\r\n    this.slotsPayload.businessId = this.businessId ?? \"\";\r\n    const date = this.selectedDate ?? new Date();\r\n    this.selectedDateStr = this.formatDate(date);\r\n    const yyyy = date.getFullYear();\r\n    const mm = String(date.getMonth() + 1).padStart(2, '0');\r\n    const dd = String(date.getDate()).padStart(2, '0');\r\n\r\n    this.slotsPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;\r\n\r\n    if (this.selectedStaff)\r\n      this.slotsPayload.staffId = this.selectedStaff.staffId;\r\n    this.restService.getBookingSlots(this.slotsPayload).subscribe((res: any) => {\r\n      res.forEach((time: any) => {\r\n        this.locationTiming.push({ selected: false, value: this.convertTo24Hour(time) });\r\n      })\r\n    })\r\n  }\r\n  selectedTime: any\r\n  selectTimeSlot(time: any) {\r\n    time.selected = true;\r\n    if (this.selectedTime) {\r\n      this.selectedTime.selected = false;\r\n    }\r\n    this.selectedTime = time;\r\n    this.activeButton = true;\r\n  }\r\n  checkRequiredValues() {\r\n    if (this.appointmentPayload.customerDetail.name && this.appointmentPayload.customerDetail.email && this.appointmentPayload.customerDetail.phoneNumber) {\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  }\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  }\r\n  checkPayment() {\r\n    // if (this.selectedService?.depositAmount?.depositRequired) {\r\n    //   this.paymentBookingAppointment();\r\n    // } else {\r\n    //   this.createAppointment();\r\n    // }\r\n    this.createAppointment();\r\n  }\r\n  apiStatus: boolean = false;\r\n  createAppointment() {\r\n    const date = this.selectedDate ?? new Date();\r\n    const yyyy = date.getFullYear();\r\n    const mm = String(date.getMonth() + 1).padStart(2, '0');\r\n    const dd = String(date.getDate()).padStart(2, '0');\r\n    this.appointmentPayload.staffDetail.id = this.selectedStaff.staffId;\r\n    this.appointmentPayload.staffDetail.name = this.selectedStaff.staffName;\r\n    this.appointmentPayload.storeId = this.selectedLocation.id;\r\n    this.appointmentPayload.serviceDetail.id = this.selectedService.serviceId;\r\n    this.appointmentPayload.serviceDetail.name = this.selectedService.name;\r\n    this.appointmentPayload.startTime = this.selectedTime.value.slice(0, 5);\r\n    this.appointmentPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;\r\n    this.restService.bookAppointmentV2(this.appointmentPayload).subscribe((res: any) => {\r\n      this.snackBar.open('Appointment booked successfully', 'close', { duration: 2000 })\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.snackBar.open('Failed to book appointment', 'close', { duration: 2000 })\r\n      }\r\n    )\r\n  }\r\n  paymentBookingAppointment() {\r\n    const date = this.selectedDate ?? new Date();\r\n    const yyyy = date.getFullYear();\r\n    const mm = String(date.getMonth() + 1).padStart(2, '0');\r\n    const dd = String(date.getDate()).padStart(2, '0');\r\n    this.appointmentPayload.staffDetail.id = this.selectedStaff.staffId;\r\n    this.appointmentPayload.staffDetail.name = this.selectedStaff.staffName;\r\n    this.appointmentPayload.storeId = this.selectedLocation.id;\r\n    this.appointmentPayload.serviceDetail.id = this.selectedService.serviceId;\r\n    this.appointmentPayload.serviceDetail.name = this.selectedService.name;\r\n    this.appointmentPayload.startTime = this.selectedTime.value.slice(0, 5);\r\n    this.appointmentPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;\r\n    this.restService.paymentForAppointment(this.appointmentPayload).subscribe((res: any) => {\r\n      this._eventService.cashFreeEvent.emit(res.data);\r\n    },\r\n      (error: any) => {\r\n        this.snackBar.open('Failed to book appointment please select another time slot', 'close', { duration: 2000 })\r\n        this.loader = false;\r\n      }\r\n    )\r\n\r\n  }\r\n  goBack() {\r\n    this.matDialog.closeAll();\r\n  }\r\n}\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>Back to My Bookings</span>\r\n            </div>\r\n            <div class=\"header-title\">\r\n                <h1>Book New Appointment</h1>\r\n                <p>{{businessName ?? \"N/A\" }}</p>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"progress-bar\">\r\n            <div class=\"progress-fill\" [style.width]=\"barWidth + '%'\"></div>\r\n        </div>\r\n    </div>\r\n    <div class=\"main_body w-100 d-flex justify-content-center\"><ng-container *ngIf=\"selectedTab === 'serviceListing'\">\r\n            <ng-container *ngTemplateOutlet=\"serviceListing\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab === 'locationListing'\">\r\n            <ng-container *ngTemplateOutlet=\"locationListing\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab === 'staffListing'\">\r\n            <ng-container *ngTemplateOutlet=\"staffListing\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab === 'dateSelection'\">\r\n            <ng-container *ngTemplateOutlet=\"dateSelection\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab==='contactDetails'\">\r\n            <ng-container *ngTemplateOutlet=\"contactDetails\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab==='paymentTab'\">\r\n            <ng-container *ngTemplateOutlet=\"paymentTab\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab==='statusTemplate'\">\r\n            <ng-container *ngTemplateOutlet=\"statusTemplate\"></ng-container>\r\n        </ng-container>\r\n    </div>\r\n    <div class=\"main_footer d-flex justify-content-center align-items-center\" *ngIf=\"selectedTab!=='statusTemplate'\">\r\n        <div class=\"footer-buttons\">\r\n            <span class=\"back-footer-btn cursor-pointer\" (click)=\"previousStep()\">Back</span>\r\n            <button class=\"continue-btn\" [disabled]=\"!activeButton\" (click)=\"nextStep()\"\r\n                *ngIf=\"selectedTab!='paymentTab'\">{{!loader ? 'Continue' : 'Loading...'}}</button>\r\n            <button class=\"complete_booking cursor-pointer\" *ngIf=\"selectedTab==='paymentTab'\"\r\n                (click)=\"checkPayment()\">Complete Booking</button>\r\n        </div>\r\n    </div>\r\n</section>\r\n<ng-template #serviceListing>\r\n    <div class=\"w-60 service_section\">\r\n        <div class=\"service-selection\">\r\n            <h2>Select a Service</h2>\r\n            <p>Choose the service you'd like to book</p>\r\n\r\n            <div class=\"services-grid\">\r\n                <ng-container *ngFor=\"let service of serviceData\">\r\n                    <div class=\"\" (click)=\"selectService(service)\"\r\n                        [ngClass]=\"{ 'service-card-selected' : service?.selected, 'service-card': !service?.selected }\">\r\n                        <div class=\" service-header\">\r\n                            <div class=\"service-icon\"><mat-icon>person_outline</mat-icon></div>\r\n                            <div class=\"service-info\">\r\n                                <div class=\"service-title\">{{service?.name ? service?.name : 'N/A'}}</div>\r\n                                <div class=\"service-category\">Wellness</div>\r\n                            </div>\r\n                            <div>\r\n                                <div class=\"service-price\">₹{{service?.priceDetails?.price ?\r\n                                    service?.priceDetails?.price : 'N/A' }}</div>\r\n                                <div class=\"service-duration\">{{service?.duration ? service?.duration : 'N/A'}} min\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div class=\"service-description\">\r\n                            {{service?.description ? service?.description : 'N/A'}}\r\n                        </div>\r\n                        <div class=\"home-visit\" *ngIf=\"service?.homeAppointmentAvailable\"><img\r\n                                src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/982126c1758628863129furniture_16406103.png\">Home\r\n                            Visit Available</div>\r\n                    </div>\r\n                </ng-container>\r\n\r\n                <!-- <div class=\"service-card\">\r\n                    <div class=\"service-header\">\r\n                        <div class=\"service-icon\">👤</div>\r\n                        <div class=\"service-info\">\r\n                            <div class=\"service-title\">General Consultation</div>\r\n                            <div class=\"service-category\">Medical</div>\r\n                        </div>\r\n                        <div>\r\n                            <div class=\"service-price\">₹800</div>\r\n                            <div class=\"service-duration\">30 min</div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"service-description\">\r\n                        Comprehensive health consultation\r\n                    </div>\r\n                </div>\r\n\r\n                <div class=\"service-card\">\r\n                    <div class=\"service-header\">\r\n                        <div class=\"service-icon\">🧠</div>\r\n                        <div class=\"service-info\">\r\n                            <div class=\"service-title\">Mental Health Counseling</div>\r\n                            <div class=\"service-category\">Mental Health</div>\r\n                        </div>\r\n                        <div>\r\n                            <div class=\"service-price\">₹1500</div>\r\n                            <div class=\"service-duration\">45 min</div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"service-description\">\r\n                        Professional psychological support\r\n                    </div>\r\n                    <div class=\"home-visit\">Home Visit Available</div>\r\n                </div>\r\n\r\n                <div class=\"service-card\">\r\n                    <div class=\"service-header\">\r\n                        <div class=\"service-icon\">✂</div>\r\n                        <div class=\"service-info\">\r\n                            <div class=\"service-title\">Hair Cut & Styling</div>\r\n                            <div class=\"service-category\">Beauty</div>\r\n                        </div>\r\n                        <div>\r\n                            <div class=\"service-price\">₹1200</div>\r\n                            <div class=\"service-duration\">45 min</div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"service-description\">\r\n                        Professional hair cutting and styling\r\n                    </div>\r\n                    <div class=\"home-visit\">Home Visit Available</div>\r\n                </div> -->\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #locationListing>\r\n    <div class=\"location_header\">\r\n        <div class=\"header flex-column align-items-start\">\r\n            <h1>Choose Location</h1>\r\n            <p>Select where you'd like to receive the service</p>\r\n        </div>\r\n\r\n        <div class=\"location-list\">\r\n            <ng-container *ngFor=\"let location of locationData\">\r\n                <div (click)=\"selectLocation(location)\"\r\n                    [ngClass]=\"{ 'location-card-selected' : location?.selected, 'location-card': !location?.selected }\">\r\n                    <div class=\"location-content\">\r\n                        <div class=\"location-info\">\r\n                            <div class=\"location-icon\"><img\r\n                                    src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/427226c1758629157758store_3171510.png\">\r\n                            </div>\r\n                            <div class=\"location-details\">\r\n                                <div class=\"d-flex justify-content-between align-items-center\">\r\n                                    <h3>{{location?.storeName ? location?.storeName : 'N/A'}}</h3>\r\n                                    <div class=\"distance\"><mat-icon>location_on</mat-icon> 2.3 km</div>\r\n                                </div>\r\n                                <p>{{location?.addressDetails?.addressLine}}, {{location?.addressDetails?.city}},\r\n                                    {{location?.addressDetails?.state}} {{location?.pincode}}</p>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </ng-container>\r\n            <!-- <div class=\"location-card\">\r\n                <div class=\"location-content\">\r\n                    <div class=\"location-info\">\r\n                        <div class=\"location-icon branch-icon\"></div>\r\n                        <div class=\"location-details\">\r\n                            <h3>Branch Clinic</h3>\r\n                            <p>456 Care Avenue, Health Zone, Mumbai 400015</p>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"distance\">5.8 km</div>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"location-card\">\r\n                <div class=\"location-content\">\r\n                    <div class=\"location-info\">\r\n                        <div class=\"location-icon home-icon\"></div>\r\n                        <div class=\"location-details\">\r\n                            <h3>Home Visit</h3>\r\n                            <p>Your Location</p>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"distance\">0 km</div>\r\n                </div>\r\n            </div> -->\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #staffListing>\r\n    <div class=\"w-60 overflow-hidden\">\r\n        <div class=\"d-flex w-100 h-100\">\r\n            <div class=\"w-100\">\r\n                <!-- Header Section -->\r\n                <div class=\"staff-header mb-3\">\r\n                    <h1 class=\"mb-1\">Select Staff Member</h1>\r\n                    <p class=\"staff-subtitle mb-0\">Choose your preferred professional</p>\r\n                </div>\r\n\r\n                <!-- Staff Cards -->\r\n                <div class=\"d-flex flex-column gap-4 staff-list\">\r\n                    <ng-container *ngFor=\"let staff of staffData\">\r\n                        <div class=\" staff-card card rounded-3 p-4\" (click)=\"selectStaff(staff)\">\r\n                            <div class=\"d-flex align-items-start justify-content-between\">\r\n                                <div class=\"d-flex align-items-start flex-grow-1\">\r\n                                    <div\r\n                                        class=\"staff-avatar rounded-circle d-flex align-items-center justify-content-center me-4\">\r\n                                        {{staff?.staffName.slice(0,3).toUpperCase()}}\r\n                                    </div>\r\n                                    <div class=\"staff-details flex-grow-1\">\r\n                                        <h3 class=\"staff-name\">{{staff?.staffName ? staff?.staffName : 'N/A'}}</h3>\r\n                                        <p class=\"staff-specialty\">General Medicine</p>\r\n                                        <p class=\"staff-description mb-0\">Experienced physician with 10+ years in\r\n                                            general\r\n                                            medicine and wellness care.</p>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"rating-section\">\r\n                                    <div class=\"star-rating d-flex align-items-center\">\r\n                                        <span class=\"star-icon\"></span>\r\n                                        <span class=\"rating-number\">4.9</span>\r\n                                    </div>\r\n                                    <div class=\"review-count\">156 reviews</div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </ng-container>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #dateSelection>\r\n    <div class=\"w-60\">\r\n        <div class=\"row justify-content-center h-100\">\r\n            <div class=\"col-12 h-100\">\r\n                <div class=\"datetime-header mb-2\">\r\n                    <h1 class=\"mb-3\">Select Date & Time</h1>\r\n                    <p class=\"datetime-subtitle mb-0\">Choose when you'd like your appointment</p>\r\n                </div>\r\n\r\n                <!-- Main Content -->\r\n                <div class=\"d-flex gap-4 main_container\">\r\n                    <!-- Left Column - Date Selection -->\r\n                    <div class=\"w-50\">\r\n                        <div class=\"section-card card rounded-3 p-4 h-100\">\r\n                            <h3 class=\"section-title\">Select Date</h3>\r\n\r\n                            <div class=\"date-picker-container d-flex align-items-center\"\r\n                                (click)=\"$event.stopPropagation()\">\r\n                                <input type=\"text\" class=\"form-control date-input border-0 rounded-2\"\r\n                                    placeholder=\"dd-mm-yyyy\" [value]=\"selectedDateStr\" readonly\r\n                                    (click)=\"toggleCalendar($event)\">\r\n\r\n                                <mat-icon class=\"ms-2\" (click)=\"toggleCalendar($event)\">calendar_today</mat-icon>\r\n                            </div>\r\n                            <div class=\"position-relative\" (click)=\"$event.stopPropagation()\">\r\n                                <div class=\"datepicker-popover\" *ngIf=\"showCalendar\">\r\n                                    <mat-calendar [(selected)]=\"selectedDate\" (selectedChange)=\"onDateSelected($event)\">\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=\"w-50\">\r\n                        <div class=\"section-card card h-100 rounded-3 p-4\">\r\n                            <h3 class=\"section-title\">Available Times</h3>\r\n\r\n                            <!-- Time Slots Grid -->\r\n                            <div class=\"row g-2 mb-4 overflow-scroll\">\r\n                                <div class=\"col-4\" *ngFor=\"let time of locationTiming\">\r\n                                    <div class=\"time-slot rounded-2\" [class.selected]=\"time.selected\"\r\n                                        (click)=\"selectTimeSlot(time)\">{{time ?\r\n                                        time?.value.slice(0,5) : 'N/A'}}</div>\r\n                                </div>\r\n                            </div>\r\n\r\n                            <!-- Waitlist Section -->\r\n                            <div class=\"waitlist-section rounded-3\">\r\n                                <div class=\"d-flex align-items-start\">\r\n                                    <div class=\"d-flex h-100 justify-content-between flex-column\"><span\r\n                                            class=\"waitlist-icon check-icon\"></span>\r\n                                        <input class=\"form-check-input\" type=\"checkbox\" value=\"\" id=\"flexCheckChecked\">\r\n                                    </div>\r\n                                    <div>\r\n                                        <div class=\"waitlist-title\">No slots available?</div>\r\n                                        <div class=\"waitlist-description\">\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\r\n</ng-template>\r\n<ng-template #contactDetails>\r\n    <div class=\"w-60\">\r\n        <div class=\"d-flex\">\r\n            <div class=\"h-100 w-100\">\r\n                <!-- Header Section -->\r\n                <div class=\"contact-header mb-2\">\r\n                    <h1 class=\"mb-0\">Contact Details</h1>\r\n                    <p class=\"contact-subtitle mb-0\">Provide your contact information</p>\r\n                </div>\r\n\r\n                <!-- Form Sections -->\r\n                <div class=\"d-flex gap-3 details_container flex-column w-100\">\r\n                    <!-- Left Column - Personal Information -->\r\n                    <div class=\"d-flex gap-4\">\r\n                        <div class=\"w-50\">\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()\">\r\n                                </div>\r\n\r\n                                <!-- Email Address -->\r\n                                <div class=\"mb-4\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Email Address\r\n                                        <span class=\"required-asterisk\">*</span>\r\n                                    </label>\r\n                                    <input type=\"email\" class=\"form-control form-input rounded-2\"\r\n                                        [(ngModel)]=\"appointmentPayload.customerDetail.email\"\r\n                                        (ngModelChange)=\"checkRequiredValues()\">\r\n                                </div>\r\n\r\n                                <!-- Phone Number -->\r\n                                <div class=\"mb-0\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Phone Number\r\n                                        <span class=\"required-asterisk\">*</span>\r\n                                    </label>\r\n                                    <input type=\"tel\" class=\"form-control form-input rounded-2\"\r\n                                        [(ngModel)]=\"appointmentPayload.customerDetail.phoneNumber\"\r\n                                        (ngModelChange)=\"checkRequiredValues()\">\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <!-- Right Column - Home Visit Details -->\r\n                        <div class=\"w-50\">\r\n                            <div class=\"form-section card rounded-3 p-4 h-100\">\r\n                                <h3 class=\"section-title\">Home Visit Details</h3>\r\n\r\n                                <!-- Home Address -->\r\n                                <div class=\"mb-4\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Home Address\r\n                                    </label>\r\n                                    <textarea class=\"form-control form-textarea rounded-2\"\r\n                                        placeholder=\"Enter your complete address\"></textarea>\r\n                                </div>\r\n\r\n                                <!-- Special Instructions -->\r\n                                <div class=\"mb-0\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Special Instructions\r\n                                    </label>\r\n                                    <textarea class=\"form-control form-textarea rounded-2\"\r\n                                        placeholder=\"Any special instructions for the professional (optional)\"></textarea>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"policies-container\">\r\n                        <!-- Header -->\r\n                        <h2 class=\"policies-title\">Policies & Terms</h2>\r\n\r\n                        <!-- Policy Items -->\r\n                        <div class=\"policy-items-container d-flex flex-column gap-3\">\r\n                            <!-- Cancellation Policy -->\r\n                            <div class=\"policy-item d-flex justify-content-between align-items-center\"\r\n                                (click)=\"showCancellationPolicy = !showCancellationPolicy\">\r\n                                <h3 class=\"policy-title\">Cancellation Policy</h3>\r\n                                <div class=\"policy-arrow d-flex align-items-center justify-content-center\"><mat-icon\r\n                                        *ngIf=\"!showCancellationPolicy\">keyboard_arrow_right</mat-icon>\r\n                                    <mat-icon *ngIf=\"showCancellationPolicy\">keyboard_arrow_down</mat-icon>\r\n                                </div>\r\n                            </div>\r\n                            <div class=\"cancellation_policies d-flex flex-column gap-2 fw-500\"\r\n                                *ngIf=\"showCancellationPolicy\">\r\n                                <span>&#8226; Free cancellation up to 24 hours before appointment</span>\r\n                                <span>&#8226; 50% charge for cancellations within 24 hours</span>\r\n                                <span>&#8226; No refund for no-shows</span>\r\n                                <span>&#8226; Emergency cancellations will be reviewed case by case</span>\r\n                            </div>\r\n\r\n                            <!-- Rescheduling Policy -->\r\n                            <div class=\"policy-item d-flex justify-content-between align-items-center\"\r\n                                (click)=\"showReducingPolicy = !showReducingPolicy\">\r\n                                <h3 class=\"policy-title\">Rescheduling Policy</h3>\r\n                                <div class=\"policy-arrow d-flex align-items-center justify-content-center\"><mat-icon\r\n                                        *ngIf=\"!showReducingPolicy\">keyboard_arrow_right</mat-icon>\r\n                                    <mat-icon *ngIf=\"showReducingPolicy\">keyboard_arrow_down</mat-icon>\r\n                                </div>\r\n                            </div>\r\n                            <div class=\"cancellation_policies d-flex flex-column gap-2 fw-500\"\r\n                                *ngIf=\"showReducingPolicy\">\r\n                                <span>&#8226; Free cancellation up to 24 hours before appointment</span>\r\n                                <span>&#8226; 50% charge for cancellations within 24 hours</span>\r\n                                <span>&#8226; No refund for no-shows</span>\r\n                                <span>&#8226; Emergency cancellations will be reviewed case by case</span>\r\n                            </div>\r\n                        </div>\r\n\r\n                        <!-- Acceptance Section -->\r\n                        <div class=\"acceptance-section\">\r\n                            <div class=\"custom-checkbox\"></div>\r\n                            <p class=\"acceptance-text\">\r\n                                I understand and accept the cancellation & rescheduling policies and\r\n                                <a href=\"#\" class=\"terms-link\">Terms & Conditions<span\r\n                                        class=\"external-link-icon\"></span></a>\r\n                            </p>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #paymentTab>\r\n    <div class=\"w-60\">\r\n        <div class=\"w-100 h-100\">\r\n            <div class=\"w-100 d-flex justify-content-center align-items-center flex-column\">\r\n                <!-- Header Section -->\r\n                <div class=\"payment-header mb-3 w-100\">\r\n                    <h1 class=\"mb-0\">Payment & Confirmation</h1>\r\n                    <p class=\"payment-subtitle mb-0\">Review your booking and complete payment</p>\r\n                </div>\r\n\r\n                <!-- Booking Summary Card -->\r\n                <div class=\"booking-summary-card w-50\">\r\n                    <h2 class=\"summary-title\">Booking Summary</h2>\r\n\r\n                    <!-- Service -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Service</div>\r\n                        <div class=\"summary-value\">{{selectedService?.name ? selectedService?.name : 'N/A'}}</div>\r\n                    </div>\r\n\r\n                    <!-- Professional -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Professional</div>\r\n                        <div class=\"summary-value\">{{selectedStaff?.staffName ? selectedStaff?.staffName : 'N/A'}}</div>\r\n                    </div>\r\n\r\n                    <!-- Location -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Location</div>\r\n                        <div class=\"summary-value\">{{selectedLocation?.storeName ? selectedLocation?.storeName : 'N/A'}}\r\n                        </div>\r\n                    </div>\r\n\r\n                    <!-- Date & Time -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Date & Time</div>\r\n                        <div class=\"summary-value\">{{selectedDate ? (selectedDate | date : 'shortData') :\r\n                            (selectedDateStr ? (selectedDateStr) : 'N/A')}} at\r\n                            15:30</div>\r\n                    </div>\r\n\r\n                    <!-- Duration -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Duration</div>\r\n                        <div class=\"summary-value\">{{selectedService?.duration ? selectedService?.duration : 'N/A'}}\r\n                            minutes</div>\r\n                    </div>\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Tax Percent</div>\r\n                        <div class=\"summary-value\">{{selectedService?.priceDetails?.taxPercent ?\r\n                            selectedService?.priceDetails?.taxPercent : 'N/A'}}%</div>\r\n                    </div>\r\n                    <!-- Total -->\r\n                    <div class=\"summary-row total-row\">\r\n                        <div class=\"summary-label\">Total</div>\r\n                        <div class=\"summary-value\">\r\n                            <span class=\"currency-symbol\">₹</span>{{selectedService?.priceDetails?.price ?\r\n                            selectedService?.priceDetails?.price : 'N/A'}}\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #statusTemplate>\r\n    <div class=\"booking-confirmation\">\r\n        <!-- Success Icon -->\r\n        <div class=\"success-icon\">\r\n            <div class=\"checkmark-circle\">\r\n                <img src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/881293c1758695578518success.gif\"\r\n                    class=\"w-100 h-100\" *ngIf=\"apiStatus\">\r\n                <img src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/325000c1758695564518fail.gif\"\r\n                    class=\"w-100 h-100\" *ngIf=\"!apiStatus\">\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Main Content -->\r\n        <div class=\"confirmation-content\">\r\n            <h1 class=\"confirmation-title\">{{apiStatus ? 'Booking Confirmed!' : 'Booking Failed'}}</h1>\r\n            <p class=\"confirmation-message\">\r\n                {{apiStatus ? 'Your appointment has been successfully booked.':'Failed to book you appointment. Please\r\n                try again later'}}\r\n            </p>\r\n\r\n            <!-- Details Card -->\r\n            <div class=\"d-flex w-100 align-items-center justify-content-center\" *ngIf=\"apiStatus\">\r\n                <div class=\"details-card\">\r\n                    <h3 class=\"details-title\">Appointment Details</h3>\r\n\r\n                    <div class=\"details-row\">\r\n                        <span class=\"detail-label\">Service</span>\r\n                        <span class=\"detail-value\">{{appointmentPayload.serviceDetail?.name ?\r\n                            appointmentPayload.serviceDetail?.name : 'N/A'}}</span>\r\n                    </div>\r\n\r\n                    <div class=\"details-row\">\r\n                        <span class=\"detail-label\">Professional</span>\r\n                        <span class=\"detail-value\">{{appointmentPayload.staffDetail?.name ?\r\n                            appointmentPayload.staffDetail?.name : 'N/A'}}</span>\r\n                    </div>\r\n                    <div class=\"details-row\">\r\n                        <span class=\"detail-label\">Date & Time</span>\r\n                        <span class=\"detail-value\">{{appointmentPayload.bookingDate ?\r\n                            appointmentPayload.bookingDate.slice(0,8) :\r\n                            'N/A'}} at\r\n                            {{appointmentPayload.startTime ? appointmentPayload.startTime : 'N/A'}}</span>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n\r\n\r\n            <!-- Action Buttons -->\r\n            <!-- <div class=\"action-buttons\">\r\n                <button class=\"btn btn-outline\">View My Bookings</button>\r\n                <button class=\"btn btn-primary\">Back to Admin</button>\r\n            </div> -->\r\n        </div>\r\n    </div>\r\n</ng-template>"]}
409
+ //# 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 } 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 { RestService } from '../../../../services/rest.service';\r\nimport { MatSnackBar } from '@angular/material/snack-bar';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { EventsService } from '../../../../services/events.service';\r\n\r\n@Component({\r\n  selector: 'simpo-appointment-booking',\r\n  standalone: true,\r\n  imports: [CdkDragPlaceholder, CommonModule, MatIcon, MatFormFieldModule, MatDatepickerModule, FormsModule],\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 matDialog: MatDialog,\r\n    private snackBar: MatSnackBar\r\n  ) {\r\n\r\n  }\r\n  ngOnInit() {\r\n    this.getAllServices();\r\n  }\r\n  @HostListener('document:click')\r\n  closeOnOutsideClick() {\r\n    this.showCalendar = false;\r\n  }\r\n  accessedTabs = {\r\n    serviceListing: false,\r\n    locationListing: false,\r\n    staffListing: false\r\n  }\r\n\r\n  businessName = localStorage.getItem('bName') ?? \"\";\r\n  businessId: string = 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  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\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: Date) {\r\n    this.selectedDate = date;\r\n    this.selectedDateStr = this.formatDate(date);\r\n    this.showCalendar = false;\r\n    this.getAvailableSlots();\r\n  }\r\n  private formatDate(d: Date): string {\r\n    const dd = String(d.getDate()).padStart(2, '0');\r\n    const mm = String(d.getMonth() + 1).padStart(2, '0');\r\n    const yyyy = d.getFullYear();\r\n    return `${dd}-${mm}-${yyyy}`;\r\n  }\r\n\r\n  selectService(service: any) {\r\n    service.selected = true;\r\n    if (this.selectedService) {\r\n      this.selectedService.selected = false;\r\n    }\r\n    this.selectedService = service\r\n    this.activeButton = this.selectedService ? true : false;\r\n  }\r\n  selectLocation(location: any) {\r\n    location.selected = true;\r\n    if (this.selectedLocation) {\r\n      this.selectedLocation.selected = false;\r\n    }\r\n    this.activeButton = true;\r\n    this.selectedLocation = location;\r\n  }\r\n  selectedStaff: any;\r\n  selectStaff(staff: any) {\r\n    this.selectedStaff = staff;\r\n    this.activeButton = true;\r\n  }\r\n  nextStep() {\r\n    if (this.selectedTab === 'serviceListing') {\r\n      this.activeButton = this.selectedLocation ? true : false;\r\n      this.accessedTabs.serviceListing = true;\r\n      if (!this.activeButton) {\r\n        this.getAllLocations();\r\n      }\r\n      else {\r\n        if (this.accessedTabs.locationListing) {\r\n          this.selectedTab = 'locationListing';\r\n          this.barWidth = '29.28';\r\n        }\r\n        else if (this.accessedTabs.staffListing) {\r\n          this.selectedTab = 'staffListing';\r\n          this.barWidth = '43.57';\r\n        }\r\n        else {\r\n          this.selectedTab = 'dateSelection';\r\n          this.barWidth = '58.57';\r\n        }\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'locationListing') {\r\n      this.activeButton = this.selectedStaff ? true : false;\r\n      this.accessedTabs.locationListing = true;\r\n      if (!this.activeButton) {\r\n        this.getAllStaff();\r\n\r\n      }\r\n      else {\r\n        if (this.accessedTabs.staffListing) {\r\n          this.selectedTab = 'staffListing';\r\n          this.barWidth = '43.57';\r\n        }\r\n        else {\r\n          this.selectedTab = 'dateSelection';\r\n          this.barWidth = '58.57';\r\n        }\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'staffListing') {\r\n      this.accessedTabs.staffListing = true;\r\n      this.selectedTab = 'dateSelection';\r\n      this.barWidth = '58.57';\r\n      if (!this.activeButton)\r\n        this.getAvailableSlots();\r\n    }\r\n    else if (this.selectedTab === 'dateSelection') {\r\n      this.activeButton = this.selectedDateStr && this.selectedTime ? true : false\r\n      this.selectedTab = 'contactDetails';\r\n      this.barWidth = '70.57'\r\n    }\r\n    else if (this.selectedTab === 'contactDetails') {\r\n      this.checkRequiredValues();\r\n      this.selectedTab = 'paymentTab';\r\n      this.barWidth = '85.57'\r\n    }\r\n  }\r\n  previousStep() {\r\n    this.activeButton = true;\r\n    if (this.selectedTab === 'locationListing') {\r\n      if (this.accessedTabs.serviceListing) {\r\n        this.selectedTab = 'serviceListing';\r\n        this.barWidth = '14.28';\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'staffListing') {\r\n      if (this.accessedTabs.locationListing) {\r\n        this.selectedTab = 'locationListing';\r\n        this.barWidth = '29.28';\r\n      }\r\n      else if (this.accessedTabs.serviceListing) {\r\n        this.selectedTab = 'serviceListing';\r\n        this.barWidth = '14.28';\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'dateSelection') {\r\n      if (this.accessedTabs.staffListing) {\r\n        this.selectedTab = 'staffListing';\r\n        this.barWidth = '43.57';\r\n      }\r\n      else if (this.accessedTabs.locationListing) {\r\n        this.selectedTab = 'locationListing';\r\n        this.barWidth = '29.28';\r\n      }\r\n      else if (this.accessedTabs.serviceListing) {\r\n        this.selectedTab = 'serviceListing';\r\n        this.barWidth = '14.28';\r\n      }\r\n    }\r\n    else if (this.selectedTab === 'contactDetails') {\r\n      this.selectedTab = 'dateSelection';\r\n      this.barWidth = '58.57'\r\n    }\r\n    else if (this.selectedTab === 'paymentTab') {\r\n      this.selectedTab = 'contactDetails';\r\n      this.barWidth = '70.57';\r\n    }\r\n  }\r\n  serviceData: any[] = [];\r\n  getAllServices() {\r\n    let servicePayload: any = {\r\n      businessId: this.businessId ?? \"\",\r\n      pageNo: 0,\r\n      size: 100\r\n    }\r\n    this.restService.getAllAppointmentService(servicePayload).subscribe(\r\n      (res: any) => {\r\n        if (res.content.length > 0) {\r\n          this.serviceData = res.content.filter((service: any) => service.active === true);\r\n          this.serviceData.forEach(service => service.selected = false);\r\n          console.log(this.serviceData)\r\n          if (this.serviceData.length === 1 && !this.activeButton) {\r\n            this.selectedService = this.serviceData[0];\r\n            this.getAllLocations();\r\n          }\r\n          else {\r\n            this.selectedTab = 'serviceListing';\r\n            this.barWidth = '14.28';\r\n          }\r\n        }\r\n      },\r\n      (error) => {\r\n        // Handle errors gracefully\r\n      }\r\n    );\r\n  }\r\n  locationData: any[] = [];\r\n  getAllLocations() {\r\n    this.loader = true;\r\n    this.locationData = [];\r\n    let payload = { businessId: this.businessId ?? \"\" }\r\n    this.restService.getAllStores(payload).subscribe(\r\n      (res: any) => {\r\n        if (res.data.data.length > 0) {\r\n          let locations = res.data.data.filter((store: any) => { return store.status === 'ACTIVE' });\r\n          locations.forEach((location: any) => {\r\n            if (this.selectedService.storeIds.includes(location.id)) {\r\n              location.selected = false;\r\n              this.locationData.push(location);\r\n            }\r\n          })\r\n          if (this.locationData.length === 1 && !this.activeButton) {\r\n            this.selectedLocation = this.locationData[0];\r\n            this.loader = false;\r\n            this.getAllStaff();\r\n          }\r\n          else {\r\n            this.loader = false;\r\n            this.selectedTab = 'locationListing';\r\n            this.barWidth = '29.28';\r\n          }\r\n        }\r\n      },\r\n      (error) => {\r\n        // Handle errors gracefully\r\n      }\r\n    );\r\n  }\r\n  staffPayload: any = {\r\n    serviceId: '',\r\n    storeId: '',\r\n    businessId: ''\r\n  }\r\n  staffData: any[] = [];\r\n  getAllStaff() {\r\n    this.loader = true;\r\n    this.staffPayload.storeId = this.selectedLocation?.id ?? \"\";\r\n    this.staffPayload.serviceId = this.selectedService?.serviceId ? this.selectedService.serviceId : '';\r\n    this.staffPayload.businessId = this.businessId ?? \"\";\r\n    this.restService.getAllStaff(this.staffPayload).subscribe(\r\n      (res: any) => {\r\n        if (res.length > 0) {\r\n          this.staffData = res.filter((staff: any) => staff.active === true);\r\n          if (this.staffData.length === 1 && !this.activeButton) {\r\n            this.loader = false;\r\n            this.selectedTab = 'dateSelection';\r\n            this.barWidth = '58.57';\r\n            this.selectedStaff = this.staffData[0];\r\n            this.getAvailableSlots();\r\n          }\r\n          else if (this.staffData.length > 1) {\r\n            this.loader = false;\r\n            this.selectedTab = 'staffListing';\r\n            this.barWidth = '43.57';\r\n          }\r\n        }\r\n      },\r\n      (error) => {\r\n        // Handle errors gracefully\r\n      }\r\n    );\r\n  }\r\n  convertTo24Hour(time: string): string {\r\n    const [hourMin, modifierRaw] = time.split(' ');\r\n    const modifier = modifierRaw.toUpperCase(); // \"AM\" or \"PM\"\r\n    let [hours, minutes] = hourMin.split(':').map(Number);\r\n\r\n    if (modifier === 'PM' && hours < 12) {\r\n      hours += 12;\r\n    }\r\n    if (modifier === 'AM' && hours === 12) {\r\n      hours = 0;\r\n    }\r\n\r\n    const hh = hours.toString().padStart(2, '0');\r\n    const mm = minutes.toString().padStart(2, '0');\r\n    return `${hh}:${mm} ${modifier}`;\r\n  }\r\n  slotsPayload: any = {\r\n    storeId: \"\",\r\n    serviceId: \"\",\r\n    businessId: \"\",\r\n    bookingDate: \"\"\r\n  }\r\n  locationTiming: any[] = [];\r\n  loader: boolean = false;\r\n  getAvailableSlots() {\r\n    this.loader = false;\r\n    this.locationTiming = [];\r\n    this.slotsPayload.storeId = this.selectedLocation?.id ?? \"\";\r\n    this.slotsPayload.serviceId = this.selectedService?.serviceId ? this.selectedService.serviceId : '';\r\n    this.slotsPayload.businessId = this.businessId ?? \"\";\r\n    const date = this.selectedDate ?? new Date();\r\n    this.selectedDateStr = this.formatDate(date);\r\n    const yyyy = date.getFullYear();\r\n    const mm = String(date.getMonth() + 1).padStart(2, '0');\r\n    const dd = String(date.getDate()).padStart(2, '0');\r\n\r\n    this.slotsPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;\r\n\r\n    if (this.selectedStaff)\r\n      this.slotsPayload.staffId = this.selectedStaff.staffId;\r\n    this.restService.getBookingSlots(this.slotsPayload).subscribe((res: any) => {\r\n      res.forEach((time: any) => {\r\n        this.locationTiming.push({ selected: false, value: this.convertTo24Hour(time) });\r\n      })\r\n    })\r\n  }\r\n  selectedTime: any\r\n  selectTimeSlot(time: any) {\r\n    time.selected = true;\r\n    if (this.selectedTime) {\r\n      this.selectedTime.selected = false;\r\n    }\r\n    this.selectedTime = time;\r\n    this.activeButton = true;\r\n  }\r\n  checkRequiredValues() {\r\n    if (this.appointmentPayload.customerDetail.name && this.appointmentPayload.customerDetail.email && this.appointmentPayload.customerDetail.phoneNumber) {\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  }\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  }\r\n  checkPayment() {\r\n    // if (this.selectedService?.depositAmount?.depositRequired) {\r\n    //   this.paymentBookingAppointment();\r\n    // } else {\r\n    //   this.createAppointment();\r\n    // }\r\n    this.createAppointment();\r\n  }\r\n  apiStatus: boolean = false;\r\n  createAppointment() {\r\n    const date = this.selectedDate ?? new Date();\r\n    const yyyy = date.getFullYear();\r\n    const mm = String(date.getMonth() + 1).padStart(2, '0');\r\n    const dd = String(date.getDate()).padStart(2, '0');\r\n    this.appointmentPayload.staffDetail.id = this.selectedStaff.staffId;\r\n    this.appointmentPayload.staffDetail.name = this.selectedStaff.staffName;\r\n    this.appointmentPayload.storeId = this.selectedLocation.id;\r\n    this.appointmentPayload.serviceDetail.id = this.selectedService.serviceId;\r\n    this.appointmentPayload.serviceDetail.name = this.selectedService.name;\r\n    this.appointmentPayload.startTime = this.selectedTime.value.slice(0, 5);\r\n    this.appointmentPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;\r\n    this.restService.bookAppointmentV2(this.appointmentPayload).subscribe((res: any) => {\r\n      this.snackBar.open('Appointment booked successfully', 'close', { duration: 2000 })\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.snackBar.open('Failed to book appointment', 'close', { duration: 2000 })\r\n      }\r\n    )\r\n  }\r\n  paymentBookingAppointment() {\r\n    const date = this.selectedDate ?? new Date();\r\n    const yyyy = date.getFullYear();\r\n    const mm = String(date.getMonth() + 1).padStart(2, '0');\r\n    const dd = String(date.getDate()).padStart(2, '0');\r\n    this.appointmentPayload.staffDetail.id = this.selectedStaff.staffId;\r\n    this.appointmentPayload.staffDetail.name = this.selectedStaff.staffName;\r\n    this.appointmentPayload.storeId = this.selectedLocation.id;\r\n    this.appointmentPayload.serviceDetail.id = this.selectedService.serviceId;\r\n    this.appointmentPayload.serviceDetail.name = this.selectedService.name;\r\n    this.appointmentPayload.startTime = this.selectedTime.value.slice(0, 5);\r\n    this.appointmentPayload.bookingDate = `${yyyy}-${mm}-${dd}T00:00:00.000Z`;\r\n    this.restService.paymentForAppointment(this.appointmentPayload).subscribe((res: any) => {\r\n      this._eventService.cashFreeEvent.emit(res.data);\r\n    },\r\n      (error: any) => {\r\n        this.snackBar.open('Failed to book appointment please select another time slot', 'close', { duration: 2000 })\r\n        this.loader = false;\r\n      }\r\n    )\r\n\r\n  }\r\n  goBack() {\r\n    this.matDialog.closeAll();\r\n  }\r\n}\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>Back to My Bookings</span>\r\n            </div>\r\n            <div class=\"header-title\">\r\n                <h1>Book New Appointment</h1>\r\n                <p>{{businessName ?? \"N/A\" }}</p>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"progress-bar\">\r\n            <div class=\"progress-fill\" [style.width]=\"barWidth + '%'\"></div>\r\n        </div>\r\n    </div>\r\n    <div class=\"main_body w-100 d-flex justify-content-center\"><ng-container *ngIf=\"selectedTab === 'serviceListing'\">\r\n            <ng-container *ngTemplateOutlet=\"serviceListing\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab === 'locationListing'\">\r\n            <ng-container *ngTemplateOutlet=\"locationListing\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab === 'staffListing'\">\r\n            <ng-container *ngTemplateOutlet=\"staffListing\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab === 'dateSelection'\">\r\n            <ng-container *ngTemplateOutlet=\"dateSelection\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab==='contactDetails'\">\r\n            <ng-container *ngTemplateOutlet=\"contactDetails\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab==='paymentTab'\">\r\n            <ng-container *ngTemplateOutlet=\"paymentTab\"></ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"selectedTab==='statusTemplate'\">\r\n            <ng-container *ngTemplateOutlet=\"statusTemplate\"></ng-container>\r\n        </ng-container>\r\n    </div>\r\n    <div class=\"main_footer d-flex justify-content-center align-items-center\" *ngIf=\"selectedTab!=='statusTemplate'\">\r\n        <div class=\"footer-buttons\">\r\n            <span class=\"back-footer-btn cursor-pointer\" (click)=\"previousStep()\">Back</span>\r\n            <button class=\"continue-btn\" [disabled]=\"!activeButton\" (click)=\"nextStep()\"\r\n                *ngIf=\"selectedTab!='paymentTab'\">{{!loader ? 'Continue' : 'Loading...'}}</button>\r\n            <button class=\"complete_booking cursor-pointer\" *ngIf=\"selectedTab==='paymentTab'\"\r\n                (click)=\"checkPayment()\">Complete Booking</button>\r\n        </div>\r\n    </div>\r\n</section>\r\n<ng-template #serviceListing>\r\n    <div class=\"w-60 service_section\">\r\n        <div class=\"service-selection\">\r\n            <h2>Select a Service</h2>\r\n            <p>Choose the service you'd like to book</p>\r\n\r\n            <div class=\"services-grid\">\r\n                <ng-container *ngFor=\"let service of serviceData\">\r\n                    <div class=\"\" (click)=\"selectService(service)\"\r\n                        [ngClass]=\"{ 'service-card-selected' : service?.selected, 'service-card': !service?.selected }\">\r\n                        <div class=\" service-header\">\r\n                            <div class=\"service-icon\"><mat-icon>person_outline</mat-icon></div>\r\n                            <div class=\"service-info\">\r\n                                <div class=\"service-title\">{{service?.name ? service?.name : 'N/A'}}</div>\r\n                                <div class=\"service-category\">Wellness</div>\r\n                            </div>\r\n                            <div>\r\n                                <div class=\"service-price\">₹{{service?.priceDetails?.price ?\r\n                                    service?.priceDetails?.price : 'N/A' }}</div>\r\n                                <div class=\"service-duration\">{{service?.duration ? service?.duration : 'N/A'}} min\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div class=\"service-description\">\r\n                            {{service?.description ? service?.description : 'N/A'}}\r\n                        </div>\r\n                        <div class=\"home-visit\" *ngIf=\"service?.homeAppointmentAvailable\"><img\r\n                                src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/982126c1758628863129furniture_16406103.png\">Home\r\n                            Visit Available</div>\r\n                    </div>\r\n                </ng-container>\r\n\r\n                <!-- <div class=\"service-card\">\r\n                    <div class=\"service-header\">\r\n                        <div class=\"service-icon\">👤</div>\r\n                        <div class=\"service-info\">\r\n                            <div class=\"service-title\">General Consultation</div>\r\n                            <div class=\"service-category\">Medical</div>\r\n                        </div>\r\n                        <div>\r\n                            <div class=\"service-price\">₹800</div>\r\n                            <div class=\"service-duration\">30 min</div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"service-description\">\r\n                        Comprehensive health consultation\r\n                    </div>\r\n                </div>\r\n\r\n                <div class=\"service-card\">\r\n                    <div class=\"service-header\">\r\n                        <div class=\"service-icon\">🧠</div>\r\n                        <div class=\"service-info\">\r\n                            <div class=\"service-title\">Mental Health Counseling</div>\r\n                            <div class=\"service-category\">Mental Health</div>\r\n                        </div>\r\n                        <div>\r\n                            <div class=\"service-price\">₹1500</div>\r\n                            <div class=\"service-duration\">45 min</div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"service-description\">\r\n                        Professional psychological support\r\n                    </div>\r\n                    <div class=\"home-visit\">Home Visit Available</div>\r\n                </div>\r\n\r\n                <div class=\"service-card\">\r\n                    <div class=\"service-header\">\r\n                        <div class=\"service-icon\">✂</div>\r\n                        <div class=\"service-info\">\r\n                            <div class=\"service-title\">Hair Cut & Styling</div>\r\n                            <div class=\"service-category\">Beauty</div>\r\n                        </div>\r\n                        <div>\r\n                            <div class=\"service-price\">₹1200</div>\r\n                            <div class=\"service-duration\">45 min</div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"service-description\">\r\n                        Professional hair cutting and styling\r\n                    </div>\r\n                    <div class=\"home-visit\">Home Visit Available</div>\r\n                </div> -->\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #locationListing>\r\n    <div class=\"location_header\">\r\n        <div class=\"header flex-column align-items-start\">\r\n            <h1>Choose Location</h1>\r\n            <p>Select where you'd like to receive the service</p>\r\n        </div>\r\n\r\n        <div class=\"location-list\">\r\n            <ng-container *ngFor=\"let location of locationData\">\r\n                <div (click)=\"selectLocation(location)\"\r\n                    [ngClass]=\"{ 'location-card-selected' : location?.selected, 'location-card': !location?.selected }\">\r\n                    <div class=\"location-content\">\r\n                        <div class=\"location-info\">\r\n                            <div class=\"location-icon\"><img\r\n                                    src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/427226c1758629157758store_3171510.png\">\r\n                            </div>\r\n                            <div class=\"location-details\">\r\n                                <div class=\"d-flex justify-content-between align-items-center\">\r\n                                    <h3>{{location?.storeName ? location?.storeName : 'N/A'}}</h3>\r\n                                    <div class=\"distance\"><mat-icon>location_on</mat-icon> 2.3 km</div>\r\n                                </div>\r\n                                <p>{{location?.addressDetails?.addressLine}}, {{location?.addressDetails?.city}},\r\n                                    {{location?.addressDetails?.state}} {{location?.pincode}}</p>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </ng-container>\r\n            <!-- <div class=\"location-card\">\r\n                <div class=\"location-content\">\r\n                    <div class=\"location-info\">\r\n                        <div class=\"location-icon branch-icon\"></div>\r\n                        <div class=\"location-details\">\r\n                            <h3>Branch Clinic</h3>\r\n                            <p>456 Care Avenue, Health Zone, Mumbai 400015</p>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"distance\">5.8 km</div>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"location-card\">\r\n                <div class=\"location-content\">\r\n                    <div class=\"location-info\">\r\n                        <div class=\"location-icon home-icon\"></div>\r\n                        <div class=\"location-details\">\r\n                            <h3>Home Visit</h3>\r\n                            <p>Your Location</p>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"distance\">0 km</div>\r\n                </div>\r\n            </div> -->\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #staffListing>\r\n    <div class=\"w-60 overflow-hidden\">\r\n        <div class=\"d-flex w-100 h-100\">\r\n            <div class=\"w-100\">\r\n                <!-- Header Section -->\r\n                <div class=\"staff-header mb-3\">\r\n                    <h1 class=\"mb-1\">Select Staff Member</h1>\r\n                    <p class=\"staff-subtitle mb-0\">Choose your preferred professional</p>\r\n                </div>\r\n\r\n                <!-- Staff Cards -->\r\n                <div class=\"d-flex flex-column gap-4 staff-list\">\r\n                    <ng-container *ngFor=\"let staff of staffData\">\r\n                        <div class=\" staff-card card rounded-3 p-4\" (click)=\"selectStaff(staff)\">\r\n                            <div class=\"d-flex align-items-start justify-content-between\">\r\n                                <div class=\"d-flex align-items-start flex-grow-1\">\r\n                                    <div\r\n                                        class=\"staff-avatar rounded-circle d-flex align-items-center justify-content-center me-4\">\r\n                                        {{staff?.staffName.slice(0,3).toUpperCase()}}\r\n                                    </div>\r\n                                    <div class=\"staff-details flex-grow-1\">\r\n                                        <h3 class=\"staff-name\">{{staff?.staffName ? staff?.staffName : 'N/A'}}</h3>\r\n                                        <p class=\"staff-specialty\">General Medicine</p>\r\n                                        <p class=\"staff-description mb-0\">Experienced physician with 10+ years in\r\n                                            general\r\n                                            medicine and wellness care.</p>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"rating-section\">\r\n                                    <div class=\"star-rating d-flex align-items-center\">\r\n                                        <span class=\"star-icon\"></span>\r\n                                        <span class=\"rating-number\">4.9</span>\r\n                                    </div>\r\n                                    <div class=\"review-count\">156 reviews</div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </ng-container>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #dateSelection>\r\n    <div class=\"w-60\">\r\n        <div class=\"row justify-content-center h-100\">\r\n            <div class=\"col-12 h-100\">\r\n                <div class=\"datetime-header mb-2\">\r\n                    <h1 class=\"mb-3\">Select Date & Time</h1>\r\n                    <p class=\"datetime-subtitle mb-0\">Choose when you'd like your appointment</p>\r\n                </div>\r\n\r\n                <!-- Main Content -->\r\n                <div class=\"d-flex gap-4 main_container\">\r\n                    <!-- Left Column - Date Selection -->\r\n                    <div class=\"w-50\">\r\n                        <div class=\"section-card card rounded-3 p-4 h-100\">\r\n                            <h3 class=\"section-title\">Select Date</h3>\r\n\r\n                            <div class=\"date-picker-container d-flex align-items-center\"\r\n                                (click)=\"$event.stopPropagation()\">\r\n                                <input type=\"text\" class=\"form-control date-input border-0 rounded-2\"\r\n                                    placeholder=\"dd-mm-yyyy\" [value]=\"selectedDateStr\" readonly\r\n                                    (click)=\"toggleCalendar($event)\">\r\n\r\n                                <mat-icon class=\"ms-2\" (click)=\"toggleCalendar($event)\">calendar_today</mat-icon>\r\n                            </div>\r\n                            <div class=\"position-relative\" (click)=\"$event.stopPropagation()\">\r\n                                <div class=\"datepicker-popover\" *ngIf=\"showCalendar\">\r\n                                    <mat-calendar [(selected)]=\"selectedDate\" (selectedChange)=\"onDateSelected($event)\">\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=\"w-50\">\r\n                        <div class=\"section-card card h-100 rounded-3 p-4\">\r\n                            <h3 class=\"section-title\">Available Times</h3>\r\n\r\n                            <!-- Time Slots Grid -->\r\n                            <div class=\"row g-2 mb-4 overflow-scroll\">\r\n                                <div class=\"col-4\" *ngFor=\"let time of locationTiming\">\r\n                                    <div class=\"time-slot rounded-2\" [class.selected]=\"time.selected\"\r\n                                        (click)=\"selectTimeSlot(time)\">{{time ?\r\n                                        time?.value.slice(0,5) : 'N/A'}}</div>\r\n                                </div>\r\n                            </div>\r\n\r\n                            <!-- Waitlist Section -->\r\n                            <div class=\"waitlist-section rounded-3\">\r\n                                <div class=\"d-flex align-items-start\">\r\n                                    <div class=\"d-flex h-100 justify-content-between flex-column\"><span\r\n                                            class=\"waitlist-icon check-icon\"></span>\r\n                                        <input class=\"form-check-input\" type=\"checkbox\" value=\"\" id=\"flexCheckChecked\">\r\n                                    </div>\r\n                                    <div>\r\n                                        <div class=\"waitlist-title\">No slots available?</div>\r\n                                        <div class=\"waitlist-description\">\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\r\n</ng-template>\r\n<ng-template #contactDetails>\r\n    <div class=\"w-60\">\r\n        <div class=\"d-flex\">\r\n            <div class=\"h-100 w-100\">\r\n                <!-- Header Section -->\r\n                <div class=\"contact-header mb-2\">\r\n                    <h1 class=\"mb-0\">Contact Details</h1>\r\n                    <p class=\"contact-subtitle mb-0\">Provide your contact information</p>\r\n                </div>\r\n\r\n                <!-- Form Sections -->\r\n                <div class=\"d-flex gap-3 details_container flex-column w-100\">\r\n                    <!-- Left Column - Personal Information -->\r\n                    <div class=\"d-flex gap-4\">\r\n                        <div class=\"w-50\">\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()\">\r\n                                </div>\r\n\r\n                                <!-- Email Address -->\r\n                                <div class=\"mb-4\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Email Address\r\n                                        <span class=\"required-asterisk\">*</span>\r\n                                    </label>\r\n                                    <input type=\"email\" class=\"form-control form-input rounded-2\"\r\n                                        [(ngModel)]=\"appointmentPayload.customerDetail.email\"\r\n                                        (ngModelChange)=\"checkRequiredValues()\">\r\n                                </div>\r\n\r\n                                <!-- Phone Number -->\r\n                                <div class=\"mb-0\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Phone Number\r\n                                        <span class=\"required-asterisk\">*</span>\r\n                                    </label>\r\n                                    <input type=\"tel\" class=\"form-control form-input rounded-2\"\r\n                                        [(ngModel)]=\"appointmentPayload.customerDetail.phoneNumber\"\r\n                                        (ngModelChange)=\"checkRequiredValues()\">\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <!-- Right Column - Home Visit Details -->\r\n                        <div class=\"w-50\">\r\n                            <div class=\"form-section card rounded-3 p-4 h-100\">\r\n                                <h3 class=\"section-title\">Home Visit Details</h3>\r\n\r\n                                <!-- Home Address -->\r\n                                <div class=\"mb-4\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Home Address\r\n                                    </label>\r\n                                    <textarea class=\"form-control form-textarea rounded-2\"\r\n                                        placeholder=\"Enter your complete address\"></textarea>\r\n                                </div>\r\n\r\n                                <!-- Special Instructions -->\r\n                                <div class=\"mb-0\">\r\n                                    <label class=\"form-label d-flex align-items-center\">\r\n                                        Special Instructions\r\n                                    </label>\r\n                                    <textarea class=\"form-control form-textarea rounded-2\"\r\n                                        placeholder=\"Any special instructions for the professional (optional)\"></textarea>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"policies-container\">\r\n                        <!-- Header -->\r\n                        <h2 class=\"policies-title\">Policies & Terms</h2>\r\n\r\n                        <!-- Policy Items -->\r\n                        <div class=\"policy-items-container d-flex flex-column gap-3\">\r\n                            <!-- Cancellation Policy -->\r\n                            <div class=\"policy-item d-flex justify-content-between align-items-center\"\r\n                                (click)=\"showCancellationPolicy = !showCancellationPolicy\">\r\n                                <h3 class=\"policy-title\">Cancellation Policy</h3>\r\n                                <div class=\"policy-arrow d-flex align-items-center justify-content-center\"><mat-icon\r\n                                        *ngIf=\"!showCancellationPolicy\">keyboard_arrow_right</mat-icon>\r\n                                    <mat-icon *ngIf=\"showCancellationPolicy\">keyboard_arrow_down</mat-icon>\r\n                                </div>\r\n                            </div>\r\n                            <div class=\"cancellation_policies d-flex flex-column gap-2 fw-500\"\r\n                                *ngIf=\"showCancellationPolicy\">\r\n                                <span>&#8226; Free cancellation up to 24 hours before appointment</span>\r\n                                <span>&#8226; 50% charge for cancellations within 24 hours</span>\r\n                                <span>&#8226; No refund for no-shows</span>\r\n                                <span>&#8226; Emergency cancellations will be reviewed case by case</span>\r\n                            </div>\r\n\r\n                            <!-- Rescheduling Policy -->\r\n                            <div class=\"policy-item d-flex justify-content-between align-items-center\"\r\n                                (click)=\"showReducingPolicy = !showReducingPolicy\">\r\n                                <h3 class=\"policy-title\">Rescheduling Policy</h3>\r\n                                <div class=\"policy-arrow d-flex align-items-center justify-content-center\"><mat-icon\r\n                                        *ngIf=\"!showReducingPolicy\">keyboard_arrow_right</mat-icon>\r\n                                    <mat-icon *ngIf=\"showReducingPolicy\">keyboard_arrow_down</mat-icon>\r\n                                </div>\r\n                            </div>\r\n                            <div class=\"cancellation_policies d-flex flex-column gap-2 fw-500\"\r\n                                *ngIf=\"showReducingPolicy\">\r\n                                <span>&#8226; Free cancellation up to 24 hours before appointment</span>\r\n                                <span>&#8226; 50% charge for cancellations within 24 hours</span>\r\n                                <span>&#8226; No refund for no-shows</span>\r\n                                <span>&#8226; Emergency cancellations will be reviewed case by case</span>\r\n                            </div>\r\n                        </div>\r\n\r\n                        <!-- Acceptance Section -->\r\n                        <div class=\"acceptance-section\">\r\n                            <div class=\"custom-checkbox\"></div>\r\n                            <p class=\"acceptance-text\">\r\n                                I understand and accept the cancellation & rescheduling policies and\r\n                                <a href=\"#\" class=\"terms-link\">Terms & Conditions<span\r\n                                        class=\"external-link-icon\"></span></a>\r\n                            </p>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #paymentTab>\r\n    <div class=\"w-60\">\r\n        <div class=\"w-100 h-100\">\r\n            <div class=\"w-100 d-flex justify-content-center align-items-center flex-column\">\r\n                <!-- Header Section -->\r\n                <div class=\"payment-header mb-3 w-100\">\r\n                    <h1 class=\"mb-0\">Payment & Confirmation</h1>\r\n                    <p class=\"payment-subtitle mb-0\">Review your booking and complete payment</p>\r\n                </div>\r\n\r\n                <!-- Booking Summary Card -->\r\n                <div class=\"booking-summary-card w-50\">\r\n                    <h2 class=\"summary-title\">Booking Summary</h2>\r\n\r\n                    <!-- Service -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Service</div>\r\n                        <div class=\"summary-value\">{{selectedService?.name ? selectedService?.name : 'N/A'}}</div>\r\n                    </div>\r\n\r\n                    <!-- Professional -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Professional</div>\r\n                        <div class=\"summary-value\">{{selectedStaff?.staffName ? selectedStaff?.staffName : 'N/A'}}</div>\r\n                    </div>\r\n\r\n                    <!-- Location -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Location</div>\r\n                        <div class=\"summary-value\">{{selectedLocation?.storeName ? selectedLocation?.storeName : 'N/A'}}\r\n                        </div>\r\n                    </div>\r\n\r\n                    <!-- Date & Time -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Date & Time</div>\r\n                        <div class=\"summary-value\">{{selectedDate ? (selectedDate | date : 'shortData') :\r\n                            (selectedDateStr ? (selectedDateStr) : 'N/A')}} at\r\n                            15:30</div>\r\n                    </div>\r\n\r\n                    <!-- Duration -->\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Duration</div>\r\n                        <div class=\"summary-value\">{{selectedService?.duration ? selectedService?.duration : 'N/A'}}\r\n                            minutes</div>\r\n                    </div>\r\n                    <div class=\"summary-row\">\r\n                        <div class=\"summary-label\">Tax Percent</div>\r\n                        <div class=\"summary-value\">{{selectedService?.priceDetails?.taxPercent ?\r\n                            selectedService?.priceDetails?.taxPercent : 'N/A'}}%</div>\r\n                    </div>\r\n                    <!-- Total -->\r\n                    <div class=\"summary-row total-row\">\r\n                        <div class=\"summary-label\">Total</div>\r\n                        <div class=\"summary-value\">\r\n                            <span class=\"currency-symbol\">₹</span>{{selectedService?.priceDetails?.price ?\r\n                            selectedService?.priceDetails?.price : 'N/A'}}\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template #statusTemplate>\r\n    <div class=\"booking-confirmation\">\r\n        <!-- Success Icon -->\r\n        <div class=\"success-icon\">\r\n            <div class=\"checkmark-circle\">\r\n                <img src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/881293c1758695578518success.gif\"\r\n                    class=\"w-100 h-100\" *ngIf=\"apiStatus\">\r\n                <img src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/325000c1758695564518fail.gif\"\r\n                    class=\"w-100 h-100\" *ngIf=\"!apiStatus\">\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Main Content -->\r\n        <div class=\"confirmation-content\">\r\n            <h1 class=\"confirmation-title\">{{apiStatus ? 'Booking Confirmed!' : 'Booking Failed'}}</h1>\r\n            <p class=\"confirmation-message\">\r\n                {{apiStatus ? 'Your appointment has been successfully booked.':'Failed to book you appointment. Please\r\n                try again later'}}\r\n            </p>\r\n\r\n            <!-- Details Card -->\r\n            <div class=\"d-flex w-100 align-items-center justify-content-center\" *ngIf=\"apiStatus\">\r\n                <div class=\"details-card\">\r\n                    <h3 class=\"details-title\">Appointment Details</h3>\r\n\r\n                    <div class=\"details-row\">\r\n                        <span class=\"detail-label\">Service</span>\r\n                        <span class=\"detail-value\">{{appointmentPayload.serviceDetail?.name ?\r\n                            appointmentPayload.serviceDetail?.name : 'N/A'}}</span>\r\n                    </div>\r\n\r\n                    <div class=\"details-row\">\r\n                        <span class=\"detail-label\">Professional</span>\r\n                        <span class=\"detail-value\">{{appointmentPayload.staffDetail?.name ?\r\n                            appointmentPayload.staffDetail?.name : 'N/A'}}</span>\r\n                    </div>\r\n                    <div class=\"details-row\">\r\n                        <span class=\"detail-label\">Date & Time</span>\r\n                        <span class=\"detail-value\">{{appointmentPayload.bookingDate ?\r\n                            appointmentPayload.bookingDate.slice(0,8) :\r\n                            'N/A'}} at\r\n                            {{appointmentPayload.startTime ? appointmentPayload.startTime : 'N/A'}}</span>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n\r\n\r\n            <!-- Action Buttons -->\r\n            <!-- <div class=\"action-buttons\">\r\n                <button class=\"btn btn-outline\">View My Bookings</button>\r\n                <button class=\"btn btn-primary\">Back to Admin</button>\r\n            </div> -->\r\n        </div>\r\n    </div>\r\n</ng-template>"]}