simpo-component-library 3.6.199 → 3.6.202

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.
@@ -133,7 +133,7 @@ export class OrderDetailsComponent {
133
133
  productId: item.itemId,
134
134
  rating: item.rating,
135
135
  review: item.review,
136
- images: item.reviewImages,
136
+ productImages: item.reviewImages,
137
137
  orderId: this.orderDetailData?.userOrderId ?? "",
138
138
  userName: this.storageService.getUser()?.contact.name
139
139
  };
@@ -206,4 +206,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
206
206
  }], goBackEmitter: [{
207
207
  type: Output
208
208
  }] } });
209
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"order-details.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/order-details/order-details.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/order-details/order-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { SimpoComponentModule } from '../../../components/index';\r\nimport { TimelineModule } from 'primeng/timeline';\r\nimport { EventsService } from '../../../services/events.service';\r\nimport { ProfileStylesModal } from '../user-profile/user-profile.modal';\r\nimport { BUSINESS_CONSTANTS } from '../../../constants/business.constant';\r\nimport { PanelModule } from 'primeng/panel';\r\nimport { RatingModule } from 'primeng/rating';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { StorageServiceService } from '../../../services/storage.service';\r\nimport { RestService } from '../../../services/rest.service';\r\nimport { MessageService } from 'primeng/api';\r\nimport { BackgroundDirective } from '../../../directive/background-directive';\r\nimport { ImageUplaodService } from '../../../services/image-upload-service.service';\r\n\r\n@Component({\r\n  selector: 'simpo-order-details',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    SimpoComponentModule,\r\n    TimelineModule,\r\n    MatIcon,\r\n    PanelModule,\r\n    RatingModule,\r\n    FormsModule,\r\n    BackgroundDirective\r\n  ],\r\n  templateUrl: './order-details.component.html',\r\n  styleUrl: './order-details.component.css'\r\n})\r\nexport class OrderDetailsComponent implements OnInit {\r\n  @Input() responseData?: any;\r\n  @Input() data?: any;\r\n  @Input() index?: number;\r\n  @Input() edit?: boolean;\r\n  @Input() delete?: boolean;\r\n  @Input() customClass?: string;\r\n  @Input(\"orderDetailData\") orderDetailData: any;\r\n  @Output() goBackEmitter: EventEmitter<void> = new EventEmitter<void>();\r\n  isLoading: boolean = false;\r\n  styles?: ProfileStylesModal;\r\n\r\n  constructor(\r\n    private readonly _eventService: EventsService,\r\n    private storageService: StorageServiceService,\r\n    private restService: RestService,\r\n    private messageService: MessageService,\r\n    private imageUploadService: ImageUplaodService\r\n  ) { }\r\n\r\n  public orderTimiline: any = [];\r\n\r\n  ngOnInit(): void {\r\n    this.styles = this.data?.styles;\r\n    this.orderTimiline = this.orderDetailData?.brandOrderDetails?.[0]?.timeLineList?.map((timeline: any) => {\r\n      return {\r\n        icon: this.getIcon(timeline.orderStatus),\r\n        name: timeline.title,\r\n        desc: timeline.body\r\n      }\r\n    })\r\n\r\n    this._eventService.showLoadingScreen.subscribe((response) => {\r\n      this.isLoading = response;\r\n    })\r\n\r\n    this.orderDetailData?.brandOrderDetails[0]?.orderedItems?.forEach((item: any) => {\r\n      if (item.review.length > 0)\r\n        item.showReview = true;\r\n      else\r\n        item.showReview = false;\r\n    })\r\n  }\r\n\r\n  private getIcon(type: \"ORDER_PLACED\" | \"ORDER_CONFIRMED\" | \"DISPATCHED\" | \"IN_TRANSIT\" | \"OUT_FOR_DELIVERY\" | \"DELIVERED\" | \"CANCELLED\") {\r\n    switch (type) {\r\n      case \"ORDER_PLACED\":\r\n      case \"ORDER_CONFIRMED\":\r\n        return \"widgets\";\r\n      case \"DISPATCHED\":\r\n      case \"IN_TRANSIT\":\r\n      case \"OUT_FOR_DELIVERY\":\r\n        return \"local_shipping\";\r\n      case \"DELIVERED\":\r\n        return \"inbox\";\r\n      case \"CANCELLED\":\r\n        return \"cancel\";\r\n    }\r\n  }\r\n  goBack() {\r\n    this.goBackEmitter.emit();\r\n  }\r\n\r\n  get getCardBGColor() {\r\n    return this.getComplementColor(this.styles?.background.color ?? \"#00000\");\r\n  }\r\n  get isMobile() {\r\n    return window.innerWidth <= 475;\r\n  }\r\n  getSupportingColor(bgColor: string): string {\r\n    return this.getComplementColor(bgColor);\r\n  }\r\n  private getComplementColor(hexColor: string) {\r\n\r\n    if (hexColor.length <= 4)\r\n      hexColor = this.convertHEX(hexColor);\r\n\r\n    hexColor = hexColor.replace(/^#/, '');\r\n\r\n    let r = parseInt(hexColor.substring(0, 2), 16);\r\n    let g = parseInt(hexColor.substring(2, 4), 16);\r\n    let b = parseInt(hexColor.substring(4, 6), 16);\r\n\r\n    r = 255 - r;\r\n    g = 255 - g;\r\n    b = 255 - b;\r\n\r\n    let compHex = `#${r.toString(16).padStart(2, '0')}${g.toString(16).padStart(2, '0')}${b.toString(16).padStart(2, '0')}`;\r\n\r\n    return compHex.toUpperCase();\r\n  }\r\n  private convertHEX(hexColor: string) {\r\n    hexColor = hexColor.replace(/^#/, '');\r\n    let color = \"#\";\r\n    for (let i = 0; i < 3; i++)\r\n      color += (hexColor[i] + hexColor[i + 1]);\r\n    return color;\r\n  }\r\n\r\n  get currency(): string {\r\n    return BUSINESS_CONSTANTS.CURRENCY;\r\n  }\r\n  get canCancelOrder(): boolean {\r\n    return this.orderTimiline?.length == 1;\r\n  }\r\n  get orderAddress(): string {\r\n    return this.orderDetailData?.addressDetails?.addressLine1 + ', ' + this.orderDetailData?.addressDetails?.addressLine2 + ', ' + this.orderDetailData?.addressDetails?.localityName + ', ' + this.orderDetailData?.addressDetails?.cityName + ', ' + this.orderDetailData?.addressDetails?.stateName;\r\n  }\r\n\r\n  trackOrder() {\r\n    window.open(this.orderDetailData?.orderTrackingLink, '_blank');\r\n  }\r\n  productReview: number = 0\r\n  async submitReview(item: any) {\r\n    if (!item.rating || item.rating < 1) {\r\n      this.messageService.add({ severity: 'error', summary: 'Review', detail: 'Please give a rating to the product' });\r\n      return;\r\n    }\r\n\r\n    if(item.reviewImages) {\r\n      for(let uploadedImage of item.reviewImages) {\r\n        if (uploadedImage.file) {\r\n          const fileUrl: any =\r\n            await this.imageUploadService.uploadFileInAWS(\r\n              uploadedImage.file,\r\n              'library-media'\r\n            );\r\n          uploadedImage.imgUrl = fileUrl\r\n        }\r\n\r\n      }\r\n    }\r\n\r\n    let payload = {\r\n      userId: this.storageService.getUser()?.userId ?? \"\",\r\n      businessId: localStorage.getItem('businessId') ?? \"\",\r\n      productId: item.itemId,\r\n      rating: item.rating,\r\n      review: item.review,\r\n      images: item.reviewImages,\r\n      orderId: this.orderDetailData?.userOrderId ?? \"\",\r\n      userName: this.storageService.getUser()?.contact.name\r\n    }\r\n    this.restService.addReviewToProduct(payload).subscribe({\r\n      next: (response) => {\r\n        this.messageService.add({ severity: 'success', summary: 'Review', detail: 'Review Added Successfully' });\r\n      },\r\n      error: (error) => {\r\n        this.messageService.add({ severity: 'error', summary: 'Review', detail: 'Adding Review Caused error' });\r\n      }\r\n    })\r\n  }\r\n\r\n  sectionsVisible = {\r\n    billDetails: true,\r\n    deliveryDetails: false,\r\n    timeline: false\r\n  };\r\n  toggleSection(section: keyof typeof this.sectionsVisible) {\r\n    this.sectionsVisible[section] = !this.sectionsVisible[section];\r\n  }\r\n\r\nuploadImage(ev: any, item: any) {\r\n  const files = ev.target?.files;\r\n\r\n  if (!files || files.length === 0) {\r\n    console.warn('No files found in input');\r\n    return;\r\n  }\r\n\r\n  // Ensure uploadedImages array exists\r\n  if (!item.reviewImages) {\r\n    item.reviewImages = [];\r\n  }\r\n\r\n  for (let fileData of files) {\r\n    const reader = new FileReader();\r\n\r\n    reader.onload = (response: any) => {\r\n      item.reviewImages.push({\r\n        imgUrl: response.target.result,\r\n        file: fileData\r\n      });\r\n    };\r\n\r\n    reader.onerror = (err) => {\r\n      console.error('FileReader error:', err);\r\n    };\r\n\r\n    reader.readAsDataURL(fileData);\r\n  }\r\n}\r\n}\r\n","<ng-container *ngIf=\"!isLoading\">\r\n    <div class=\"container-fluid\" [attr.style]=\"customClass\">\r\n\r\n        <!-- Header Section -->\r\n        <div class=\"row\" *ngIf=\"!isMobile\">\r\n            <div class=\"col-12\">\r\n                <div class=\"d-flex align-items-center gap-3\">\r\n                    <mat-icon (click)=\"goBack()\">keyboard_backspace</mat-icon>\r\n                    <h3 class=\"fw-bold text-dark mb-0\">{{ orderDetailData?.orderNum }}</h3>\r\n                </div>\r\n                <div class=\"d-flex flex-wrap gap-2 mb-2\">\r\n                    <span class=\"d-flex align-items-center text-muted\">\r\n                        <mat-icon class=\"fs-5 d-flex align-items-center justify-content-start\">schedule</mat-icon>\r\n                        <small>{{ orderDetailData?.createdTimeStamp | date: 'dd MMM yyyy' }}</small>\r\n                    </span>\r\n                    <span class=\"d-flex align-items-center text-muted\">\r\n                        <mat-icon class=\"fs-5 d-flex align-items-center justify-content-center\">shopping_bag</mat-icon>\r\n                        <small>{{ orderDetailData?.brandOrderDetails?.[0]?.orderedItems.length }}\r\n                            items</small>\r\n                    </span>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Mobile Header -->\r\n        <div class=\"card border-0 shadow-sm mb-3\" *ngIf=\"isMobile\">\r\n            <div class=\"card-body d-flex justify-content-between align-items-center py-3\">\r\n                <h2 class=\"h4 mb-0 fw-semibold\">{{ orderDetailData?.orderNum }}</h2>\r\n                <div></div>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"row g-4\">\r\n            <!-- Left Column -->\r\n            <div class=\"col-12\" [ngClass]=\"{'col-lg-8': !isMobile}\">\r\n\r\n                <!-- Timeline for Desktop -->\r\n\r\n                <!-- Items Section -->\r\n                <div class=\"card border-0 shadow-sm mb-4\">\r\n                    <div class=\"card-header py-3\" [simpoBackground]=\"styles?.background\" [id]=\"data?.id\">\r\n                        <h4 class=\"h5 mb-0 d-flex align-items-center gap-2 f-16\">\r\n                            <mat-icon>shopping_cart</mat-icon>\r\n                            Ordered Items\r\n                        </h4>\r\n                    </div>\r\n                    <div class=\"card-body p-4 scroll-45\">\r\n                        <div class=\"row g-3\">\r\n                            <div class=\"col-12\"\r\n                                *ngFor=\"let item of orderDetailData?.brandOrderDetails[0]?.orderedItems\">\r\n                                <div class=\"h-100\">\r\n                                    <div class=\"card-body p-3\">\r\n                                        <div class=\"row align-items-start\">\r\n                                            <div class=\"col-auto position-relative\">\r\n                                                <img loading=\"lazy\"\r\n                                                    onerror=\"this.src='https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\"\r\n                                                    [src]=\"item.imgUrl\" alt=\"{{ item.itemName }}\"\r\n                                                    class=\"rounded shadow-sm\"\r\n                                                    style=\"width: 85px; height: 85px; object-fit: cover;\">\r\n                                            </div>\r\n                                            <div class=\"col\">\r\n                                                <h4 class=\"h6 fw-semibold text-dark\">{{ item.itemName }}</h4>\r\n\r\n                                                <div class=\"row\">\r\n                                                    <div class=\"col-6 text-start\" *ngIf=\"!isMobile\">\r\n                                                        <div class=\"fw-bold\">\r\n                                                            <span [innerHTML]=\"currency\"></span>{{\r\n                                                            (item.discountedPrice | number: '1.0-2') + ' x ' +\r\n                                                            item.quantity }}\r\n                                                        </div>\r\n                                                    </div>\r\n                                                    <div class=\"col-md-6 col-sm-12 text-end text-nowrap\">\r\n                                                        <div class=\" p-2\">\r\n                                                            <div class=\"fw-bold\">\r\n                                                                <span [innerHTML]=\"currency\"></span>{{\r\n                                                                (item.discountedPrice * item.quantity) | number: '1.0-2'\r\n                                                                }}\r\n                                                            </div>\r\n                                                        </div>\r\n                                                    </div>\r\n                                                </div>\r\n                                                <!-- Review Section -->\r\n                                                <div>\r\n                                                    <div class=\"mb-1\">\r\n                                                        <p-rating [(ngModel)]=\"item.rating\" [cancel]=\"false\"\r\n                                                            [readonly]=\"false\" />\r\n                                                    </div>\r\n\r\n                                                    <div class=\"add-detail-review f-13 cursor-pointer\"\r\n                                                        (click)=\"item.showReview = !item.showReview\">Add Detailed Review\r\n                                                    </div>\r\n\r\n                                                    <div *ngIf=\"item.showReview\">\r\n                                                        <div class=\"mb-1\">\r\n                                                            <textarea class=\"form-control border-2\"\r\n                                                                [(ngModel)]=\"item.review\" rows=\"3\"></textarea>\r\n                                                        </div>\r\n                                                        <div class=\"review-img\">\r\n                                                          <img [src]=\"img.imgUrl\" alt=\"\" *ngFor=\"let img of item?.reviewImages ?? []\"\r\n                                                            >\r\n                                                          <div class=\"add-review-img\"  (click)=\"reviewFileInput.click()\" [ngClass]=\"{'w-100': (item?.reviewImages?.length ?? 0) == 0}\">\r\n                                                            <mat-icon>add</mat-icon> {{(item?.reviewImages?.length ?? 0) == 0 ? 'Add Images' : ''}}\r\n                                                          </div>\r\n                                                          <input  type=\"file\" name=\"myfile\" multiple hidden\r\n                                                            accept=\"image/jpg,image/jpeg,image/gif,image/png,application/pdf,image/x-eps\"\r\n                                                            (change)=\"uploadImage($event, item)\" class=\"pc-btn\"\r\n                                                            #reviewFileInput />\r\n                                                        </div>\r\n\r\n                                                        <div class=\"w-100 text-end p-2 sbt-btn f-13 cursor-pointer\"\r\n                                                            (click)=\"submitReview(item)\">\r\n                                                            Submit\r\n                                                        </div>\r\n                                                    </div>\r\n                                                </div>\r\n                                            </div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n\r\n                <!-- Timeline for Mobile -->\r\n                <ng-container *ngIf=\"isMobile\">\r\n                    <ng-container *ngTemplateOutlet=\"timelineContainer\"></ng-container>\r\n                </ng-container>\r\n            </div>\r\n\r\n            <!-- Right Column -->\r\n            <div class=\"col-12 scroll-60\" [ngClass]=\"{'col-lg-4': !isMobile}\">\r\n\r\n                <!-- Bill Details -->\r\n                <div class=\"card border-0 shadow-sm mb-4\">\r\n                    <div class=\"card-header py-3 cursor-pointer\" [simpoBackground]=\"styles?.background\" [id]=\"data?.id\"\r\n                        (click)=\"toggleSection('billDetails')\">\r\n                        <h4 class=\"h5 mb-0 d-flex align-items-center justify-content-between f-16\">\r\n                            <div class=\"d-flex align-items-center gap-2\">\r\n                                <mat-icon>receipt</mat-icon>\r\n                                Bill Details\r\n                            </div>\r\n                            <mat-icon class=\"transition-transform\" [class.rotate-180]=\"!sectionsVisible.billDetails\">\r\n                                expand_less\r\n                            </mat-icon>\r\n                        </h4>\r\n                    </div>\r\n                    <div class=\"card-body p-4\" [class.d-none]=\"!sectionsVisible.billDetails\">\r\n                        <div class=\"d-flex justify-content-between align-items-center py-2 border-bottom\">\r\n                            <span class=\"text-muted\">Item Total</span>\r\n                            <span class=\"fw-semibold h6 mb-0\">\r\n                                <span [innerHTML]=\"currency\"></span>{{ orderDetailData?.billDetails?.totalNetValue |\r\n                                number:'1.0-2' }}\r\n                            </span>\r\n                        </div>\r\n\r\n                        <div class=\"d-flex justify-content-between align-items-center py-2 border-bottom\"\r\n                            *ngIf=\"orderDetailData?.billDetails?.discountAmount\">\r\n                            <span class=\"d-flex align-items-center gap-2 text-muted\">\r\n                                Discount\r\n                            </span>\r\n                            <span class=\"fw-semibold text-success h6 mb-0\">\r\n                                -<span [innerHTML]=\"currency\"></span>{{ orderDetailData?.billDetails?.discountAmount |\r\n                                number:'1.0-2' }}\r\n                            </span>\r\n                        </div>\r\n\r\n                        <div class=\"d-flex justify-content-between align-items-center py-2 border-bottom\">\r\n                            <span class=\"text-muted\">Total Tax</span>\r\n                            <span class=\"fw-semibold h6 mb-0\">\r\n                                <span [innerHTML]=\"currency\"></span>{{ orderDetailData?.billDetails?.discountAmount ?\r\n                                orderDetailData?.billDetails?.totalTaxAfterDiscount :\r\n                                orderDetailData?.billDetails?.totalTax | number:'1.0-2' }}\r\n                            </span>\r\n                        </div>\r\n\r\n                        <div class=\"d-flex justify-content-between align-items-center py-2 border-bottom\">\r\n                            <span class=\"d-flex align-items-center gap-2 text-muted\">\r\n                                Delivery\r\n                            </span>\r\n                            <span class=\"fw-bold text-success h6 mb-0\">FREE</span>\r\n                        </div>\r\n\r\n                        <div class=\"d-flex justify-content-between align-items-center py-3 mt-3  rounded px-3\">\r\n                            <span class=\"fw-bold h5 mb-0 text-dark\">Grand Total</span>\r\n                            <span class=\"fw-bold h4 mb-0 \">\r\n                                <span [innerHTML]=\"currency\"></span>{{ orderDetailData?.billDetails?.discountAmount ?\r\n                                (orderDetailData?.billDetails?.totalNetValue -\r\n                                orderDetailData?.billDetails?.discountAmount +\r\n                                orderDetailData?.billDetails?.totalTaxAfterDiscount) :\r\n                                orderDetailData?.billDetails?.totalGrossValue | number:'1.0-2' }}\r\n                            </span>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n\r\n                <!-- Customer Details -->\r\n                <div class=\"card border-0 shadow-sm mb-4\">\r\n                    <div class=\"card-header py-3 cursor-pointer\" [simpoBackground]=\"styles?.background\" [id]=\"data?.id\"\r\n                        (click)=\"toggleSection('deliveryDetails')\">\r\n                        <h4 class=\"h5 mb-0 d-flex align-items-center justify-content-between f-16\">\r\n                            <div class=\"d-flex align-items-center gap-2\">\r\n                                <mat-icon>person</mat-icon>\r\n                                Delivery Details\r\n                            </div>\r\n                            <mat-icon class=\"transition-transform\"\r\n                                [class.rotate-180]=\"!sectionsVisible.deliveryDetails\">\r\n                                expand_less\r\n                            </mat-icon>\r\n                        </h4>\r\n                    </div>\r\n                    <div class=\"card-body p-4\" [class.d-none]=\"!sectionsVisible.deliveryDetails\">\r\n                        <div class=\"mb-3\">\r\n                            <div class=\"d-flex align-items-center gap-3 p-2 bg-light rounded\">\r\n                                <div>\r\n                                    <small class=\"text-muted d-block\">Name</small>\r\n                                    <span class=\"fw-semibold\">{{ orderDetailData?.addressDetails?.receiverName }}</span>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"mb-3\">\r\n                            <div class=\"d-flex align-items-center gap-3 p-2 bg-light rounded\">\r\n                                <div>\r\n                                    <small class=\"text-muted d-block\">Phone</small>\r\n                                    <span class=\"fw-semibold\">{{ orderDetailData?.addressDetails?.receiverPhone\r\n                                        }}</span>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"mb-3\">\r\n                            <div class=\"d-flex align-items-start gap-3 p-2 bg-light rounded\">\r\n                                <div>\r\n                                    <small class=\"text-muted d-block\">Address</small>\r\n                                    <span class=\"fw-semibold\">{{ orderAddress }}</span>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"mb-3\">\r\n                            <div class=\"d-flex align-items-center gap-3 p-2 bg-light rounded\">\r\n                                <div>\r\n                                    <small class=\"text-muted d-block\">Payment</small>\r\n                                    <span class=\"fw-semibold\">Manual Payment</span>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n\r\n                        <!-- Track Order Button -->\r\n                        <div class=\"text-center mt-4\" *ngIf=\"orderDetailData?.orderTrackingLink\">\r\n                            <button\r\n                                class=\"btn btn-primary w-100 d-flex align-items-center justify-content-center gap-2 py-2\"\r\n                                (click)=\"trackOrder()\">\r\n                                <mat-icon>location_searching</mat-icon>\r\n                                Track Order\r\n                            </button>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n\r\n                <!-- Timeline Section for Desktop -->\r\n                <div class=\"card border-0 shadow-sm mb-4\" *ngIf=\"!isMobile\">\r\n                    <div class=\"card-header py-3 cursor-pointer\" (click)=\"toggleSection('timeline')\"\r\n                        [simpoBackground]=\"styles?.background\" [id]=\"data?.id\">\r\n                        <h4 class=\"h5 mb-0 d-flex align-items-center justify-content-between f-16\r\n\r\n    \">\r\n                            <div class=\"d-flex align-items-center gap-2\">\r\n                                <mat-icon>timeline</mat-icon>\r\n                                Order Timeline\r\n                            </div>\r\n                            <mat-icon class=\"transition-transform\" [class.rotate-180]=\"!sectionsVisible.timeline\">\r\n                                expand_less\r\n                            </mat-icon>\r\n                        </h4>\r\n                    </div>\r\n                    <div class=\"card-body p-4\" [class.d-none]=\"!sectionsVisible.timeline\">\r\n                        <p-timeline [value]=\"orderTimiline\">\r\n                            <ng-template pTemplate=\"content\" let-event>\r\n                                <div class=\"d-flex align-items-start gap-3 py-3\">\r\n                                    <div class=\"rounded-circle p-2 d-flex align-items-center justify-content-center\"\r\n                                        style=\"width: 40px; height: 40px;\" [simpoBackground]=\"styles?.background\"\r\n                                        [id]=\"data?.id\">\r\n                                        <mat-icon class=\"fs-6 d-flex align-items-center justify-content-center\">{{\r\n                                            event.icon }}</mat-icon>\r\n                                    </div>\r\n                                    <div class=\"flex-grow-1\">\r\n                                        <h6 class=\"fw-semibold text-dark mb-1\">{{ event.name?.replaceAll(\"_\", \" \") |\r\n                                            titlecase }}</h6>\r\n                                        <p class=\"text-muted mb-0 small\">{{ event.desc?.replaceAll(\"_\", \" \") }}</p>\r\n                                    </div>\r\n                                </div>\r\n                            </ng-template>\r\n                        </p-timeline>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n\r\n        </div>\r\n    </div>\r\n</ng-container>\r\n\r\n<!-- Timeline Template -->\r\n<ng-template #timelineContainer>\r\n    <div class=\"card border-0 shadow-sm mb-4\">\r\n        <div class=\"card-header bg-warning text-dark py-2 f-16\">\r\n            <h4 class=\"h5 mb-0 d-flex align-items-center gap-2\">\r\n                <mat-icon>timeline</mat-icon>\r\n                Order Timeline\r\n            </h4>\r\n        </div>\r\n        <div class=\"card-body p-4\">\r\n            <p-timeline [value]=\"orderTimiline\">\r\n                <ng-template pTemplate=\"content\" let-event>\r\n                    <div class=\"d-flex align-items-start gap-3 py-3\">\r\n                        <div class=\"bg-primary rounded-circle p-2 d-flex align-items-center justify-content-center\"\r\n                            style=\"width: 40px; height: 40px;\">\r\n                            <mat-icon class=\"text-white fs-6 d-flex align-items-center justify-content-center\">{{\r\n                                event.icon }}</mat-icon>\r\n                        </div>\r\n                        <div class=\"flex-grow-1\">\r\n                            <h6 class=\"fw-semibold text-dark mb-1\">{{ event.name?.replaceAll(\"_\", \" \") | titlecase }}\r\n                            </h6>\r\n                            <p class=\"text-muted mb-0 small\">{{ event.desc?.replaceAll(\"_\", \" \") | titlecase }}</p>\r\n                        </div>\r\n                    </div>\r\n                </ng-template>\r\n            </p-timeline>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- Loading Skeleton -->\r\n<div class=\"container-fluid py-4\" *ngIf=\"isLoading\">\r\n    <div class=\"row\">\r\n        <div class=\"col-12\">\r\n            <ngx-skeleton-loader count=\"1\" appearance=\"circle\" [theme]=\"{\r\n                width: '100%',\r\n                height: '60vh',\r\n                'border-radius': '12px',\r\n                'margin': '20px 0'\r\n            }\"></ngx-skeleton-loader>\r\n        </div>\r\n    </div>\r\n</div>\r\n"]}
209
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"order-details.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/order-details/order-details.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/order-details/order-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { SimpoComponentModule } from '../../../components/index';\r\nimport { TimelineModule } from 'primeng/timeline';\r\nimport { EventsService } from '../../../services/events.service';\r\nimport { ProfileStylesModal } from '../user-profile/user-profile.modal';\r\nimport { BUSINESS_CONSTANTS } from '../../../constants/business.constant';\r\nimport { PanelModule } from 'primeng/panel';\r\nimport { RatingModule } from 'primeng/rating';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { StorageServiceService } from '../../../services/storage.service';\r\nimport { RestService } from '../../../services/rest.service';\r\nimport { MessageService } from 'primeng/api';\r\nimport { BackgroundDirective } from '../../../directive/background-directive';\r\nimport { ImageUplaodService } from '../../../services/image-upload-service.service';\r\n\r\n@Component({\r\n  selector: 'simpo-order-details',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    SimpoComponentModule,\r\n    TimelineModule,\r\n    MatIcon,\r\n    PanelModule,\r\n    RatingModule,\r\n    FormsModule,\r\n    BackgroundDirective\r\n  ],\r\n  templateUrl: './order-details.component.html',\r\n  styleUrl: './order-details.component.css'\r\n})\r\nexport class OrderDetailsComponent implements OnInit {\r\n  @Input() responseData?: any;\r\n  @Input() data?: any;\r\n  @Input() index?: number;\r\n  @Input() edit?: boolean;\r\n  @Input() delete?: boolean;\r\n  @Input() customClass?: string;\r\n  @Input(\"orderDetailData\") orderDetailData: any;\r\n  @Output() goBackEmitter: EventEmitter<void> = new EventEmitter<void>();\r\n  isLoading: boolean = false;\r\n  styles?: ProfileStylesModal;\r\n\r\n  constructor(\r\n    private readonly _eventService: EventsService,\r\n    private storageService: StorageServiceService,\r\n    private restService: RestService,\r\n    private messageService: MessageService,\r\n    private imageUploadService: ImageUplaodService\r\n  ) { }\r\n\r\n  public orderTimiline: any = [];\r\n\r\n  ngOnInit(): void {\r\n    this.styles = this.data?.styles;\r\n    this.orderTimiline = this.orderDetailData?.brandOrderDetails?.[0]?.timeLineList?.map((timeline: any) => {\r\n      return {\r\n        icon: this.getIcon(timeline.orderStatus),\r\n        name: timeline.title,\r\n        desc: timeline.body\r\n      }\r\n    })\r\n\r\n    this._eventService.showLoadingScreen.subscribe((response) => {\r\n      this.isLoading = response;\r\n    })\r\n\r\n    this.orderDetailData?.brandOrderDetails[0]?.orderedItems?.forEach((item: any) => {\r\n      if (item.review.length > 0)\r\n        item.showReview = true;\r\n      else\r\n        item.showReview = false;\r\n    })\r\n  }\r\n\r\n  private getIcon(type: \"ORDER_PLACED\" | \"ORDER_CONFIRMED\" | \"DISPATCHED\" | \"IN_TRANSIT\" | \"OUT_FOR_DELIVERY\" | \"DELIVERED\" | \"CANCELLED\") {\r\n    switch (type) {\r\n      case \"ORDER_PLACED\":\r\n      case \"ORDER_CONFIRMED\":\r\n        return \"widgets\";\r\n      case \"DISPATCHED\":\r\n      case \"IN_TRANSIT\":\r\n      case \"OUT_FOR_DELIVERY\":\r\n        return \"local_shipping\";\r\n      case \"DELIVERED\":\r\n        return \"inbox\";\r\n      case \"CANCELLED\":\r\n        return \"cancel\";\r\n    }\r\n  }\r\n  goBack() {\r\n    this.goBackEmitter.emit();\r\n  }\r\n\r\n  get getCardBGColor() {\r\n    return this.getComplementColor(this.styles?.background.color ?? \"#00000\");\r\n  }\r\n  get isMobile() {\r\n    return window.innerWidth <= 475;\r\n  }\r\n  getSupportingColor(bgColor: string): string {\r\n    return this.getComplementColor(bgColor);\r\n  }\r\n  private getComplementColor(hexColor: string) {\r\n\r\n    if (hexColor.length <= 4)\r\n      hexColor = this.convertHEX(hexColor);\r\n\r\n    hexColor = hexColor.replace(/^#/, '');\r\n\r\n    let r = parseInt(hexColor.substring(0, 2), 16);\r\n    let g = parseInt(hexColor.substring(2, 4), 16);\r\n    let b = parseInt(hexColor.substring(4, 6), 16);\r\n\r\n    r = 255 - r;\r\n    g = 255 - g;\r\n    b = 255 - b;\r\n\r\n    let compHex = `#${r.toString(16).padStart(2, '0')}${g.toString(16).padStart(2, '0')}${b.toString(16).padStart(2, '0')}`;\r\n\r\n    return compHex.toUpperCase();\r\n  }\r\n  private convertHEX(hexColor: string) {\r\n    hexColor = hexColor.replace(/^#/, '');\r\n    let color = \"#\";\r\n    for (let i = 0; i < 3; i++)\r\n      color += (hexColor[i] + hexColor[i + 1]);\r\n    return color;\r\n  }\r\n\r\n  get currency(): string {\r\n    return BUSINESS_CONSTANTS.CURRENCY;\r\n  }\r\n  get canCancelOrder(): boolean {\r\n    return this.orderTimiline?.length == 1;\r\n  }\r\n  get orderAddress(): string {\r\n    return this.orderDetailData?.addressDetails?.addressLine1 + ', ' + this.orderDetailData?.addressDetails?.addressLine2 + ', ' + this.orderDetailData?.addressDetails?.localityName + ', ' + this.orderDetailData?.addressDetails?.cityName + ', ' + this.orderDetailData?.addressDetails?.stateName;\r\n  }\r\n\r\n  trackOrder() {\r\n    window.open(this.orderDetailData?.orderTrackingLink, '_blank');\r\n  }\r\n  productReview: number = 0\r\n  async submitReview(item: any) {\r\n    if (!item.rating || item.rating < 1) {\r\n      this.messageService.add({ severity: 'error', summary: 'Review', detail: 'Please give a rating to the product' });\r\n      return;\r\n    }\r\n\r\n    if(item.reviewImages) {\r\n      for(let uploadedImage of item.reviewImages) {\r\n        if (uploadedImage.file) {\r\n          const fileUrl: any =\r\n            await this.imageUploadService.uploadFileInAWS(\r\n              uploadedImage.file,\r\n              'library-media'\r\n            );\r\n          uploadedImage.imgUrl = fileUrl\r\n        }\r\n\r\n      }\r\n    }\r\n\r\n    let payload = {\r\n      userId: this.storageService.getUser()?.userId ?? \"\",\r\n      businessId: localStorage.getItem('businessId') ?? \"\",\r\n      productId: item.itemId,\r\n      rating: item.rating,\r\n      review: item.review,\r\n      productImages: item.reviewImages,\r\n      orderId: this.orderDetailData?.userOrderId ?? \"\",\r\n      userName: this.storageService.getUser()?.contact.name\r\n    }\r\n    this.restService.addReviewToProduct(payload).subscribe({\r\n      next: (response) => {\r\n        this.messageService.add({ severity: 'success', summary: 'Review', detail: 'Review Added Successfully' });\r\n      },\r\n      error: (error) => {\r\n        this.messageService.add({ severity: 'error', summary: 'Review', detail: 'Adding Review Caused error' });\r\n      }\r\n    })\r\n  }\r\n\r\n  sectionsVisible = {\r\n    billDetails: true,\r\n    deliveryDetails: false,\r\n    timeline: false\r\n  };\r\n  toggleSection(section: keyof typeof this.sectionsVisible) {\r\n    this.sectionsVisible[section] = !this.sectionsVisible[section];\r\n  }\r\n\r\nuploadImage(ev: any, item: any) {\r\n  const files = ev.target?.files;\r\n\r\n  if (!files || files.length === 0) {\r\n    console.warn('No files found in input');\r\n    return;\r\n  }\r\n\r\n  // Ensure uploadedImages array exists\r\n  if (!item.reviewImages) {\r\n    item.reviewImages = [];\r\n  }\r\n\r\n  for (let fileData of files) {\r\n    const reader = new FileReader();\r\n\r\n    reader.onload = (response: any) => {\r\n      item.reviewImages.push({\r\n        imgUrl: response.target.result,\r\n        file: fileData\r\n      });\r\n    };\r\n\r\n    reader.onerror = (err) => {\r\n      console.error('FileReader error:', err);\r\n    };\r\n\r\n    reader.readAsDataURL(fileData);\r\n  }\r\n}\r\n}\r\n","<ng-container *ngIf=\"!isLoading\">\r\n    <div class=\"container-fluid\" [attr.style]=\"customClass\">\r\n\r\n        <!-- Header Section -->\r\n        <div class=\"row\" *ngIf=\"!isMobile\">\r\n            <div class=\"col-12\">\r\n                <div class=\"d-flex align-items-center gap-3\">\r\n                    <mat-icon (click)=\"goBack()\">keyboard_backspace</mat-icon>\r\n                    <h3 class=\"fw-bold text-dark mb-0\">{{ orderDetailData?.orderNum }}</h3>\r\n                </div>\r\n                <div class=\"d-flex flex-wrap gap-2 mb-2\">\r\n                    <span class=\"d-flex align-items-center text-muted\">\r\n                        <mat-icon class=\"fs-5 d-flex align-items-center justify-content-start\">schedule</mat-icon>\r\n                        <small>{{ orderDetailData?.createdTimeStamp | date: 'dd MMM yyyy' }}</small>\r\n                    </span>\r\n                    <span class=\"d-flex align-items-center text-muted\">\r\n                        <mat-icon class=\"fs-5 d-flex align-items-center justify-content-center\">shopping_bag</mat-icon>\r\n                        <small>{{ orderDetailData?.brandOrderDetails?.[0]?.orderedItems.length }}\r\n                            items</small>\r\n                    </span>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Mobile Header -->\r\n        <div class=\"card border-0 shadow-sm mb-3\" *ngIf=\"isMobile\">\r\n            <div class=\"card-body d-flex justify-content-between align-items-center py-3\">\r\n                <h2 class=\"h4 mb-0 fw-semibold\">{{ orderDetailData?.orderNum }}</h2>\r\n                <div></div>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"row g-4\">\r\n            <!-- Left Column -->\r\n            <div class=\"col-12\" [ngClass]=\"{'col-lg-8': !isMobile}\">\r\n\r\n                <!-- Timeline for Desktop -->\r\n\r\n                <!-- Items Section -->\r\n                <div class=\"card border-0 shadow-sm mb-4\">\r\n                    <div class=\"card-header py-3\" [simpoBackground]=\"styles?.background\" [id]=\"data?.id\">\r\n                        <h4 class=\"h5 mb-0 d-flex align-items-center gap-2 f-16\">\r\n                            <mat-icon>shopping_cart</mat-icon>\r\n                            Ordered Items\r\n                        </h4>\r\n                    </div>\r\n                    <div class=\"card-body p-4 scroll-45\">\r\n                        <div class=\"row g-3\">\r\n                            <div class=\"col-12\"\r\n                                *ngFor=\"let item of orderDetailData?.brandOrderDetails[0]?.orderedItems\">\r\n                                <div class=\"h-100\">\r\n                                    <div class=\"card-body p-3\">\r\n                                        <div class=\"row align-items-start\">\r\n                                            <div class=\"col-auto position-relative\">\r\n                                                <img loading=\"lazy\"\r\n                                                    onerror=\"this.src='https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\"\r\n                                                    [src]=\"item.imgUrl\" alt=\"{{ item.itemName }}\"\r\n                                                    class=\"rounded shadow-sm\"\r\n                                                    style=\"width: 85px; height: 85px; object-fit: cover;\">\r\n                                            </div>\r\n                                            <div class=\"col\">\r\n                                                <h4 class=\"h6 fw-semibold text-dark\">{{ item.itemName }}</h4>\r\n\r\n                                                <div class=\"row\">\r\n                                                    <div class=\"col-6 text-start\" *ngIf=\"!isMobile\">\r\n                                                        <div class=\"fw-bold\">\r\n                                                            <span [innerHTML]=\"currency\"></span>{{\r\n                                                            (item.discountedPrice | number: '1.0-2') + ' x ' +\r\n                                                            item.quantity }}\r\n                                                        </div>\r\n                                                    </div>\r\n                                                    <div class=\"col-md-6 col-sm-12 text-end text-nowrap\">\r\n                                                        <div class=\" p-2\">\r\n                                                            <div class=\"fw-bold\">\r\n                                                                <span [innerHTML]=\"currency\"></span>{{\r\n                                                                (item.discountedPrice * item.quantity) | number: '1.0-2'\r\n                                                                }}\r\n                                                            </div>\r\n                                                        </div>\r\n                                                    </div>\r\n                                                </div>\r\n                                                <!-- Review Section -->\r\n                                                <div>\r\n                                                    <div class=\"mb-1\">\r\n                                                        <p-rating [(ngModel)]=\"item.rating\" [cancel]=\"false\"\r\n                                                            [readonly]=\"false\" />\r\n                                                    </div>\r\n\r\n                                                    <div class=\"add-detail-review f-13 cursor-pointer\"\r\n                                                        (click)=\"item.showReview = !item.showReview\">Add Detailed Review\r\n                                                    </div>\r\n\r\n                                                    <div *ngIf=\"item.showReview\">\r\n                                                        <div class=\"mb-1\">\r\n                                                            <textarea class=\"form-control border-2\"\r\n                                                                [(ngModel)]=\"item.review\" rows=\"3\"></textarea>\r\n                                                        </div>\r\n                                                        <div class=\"review-img\">\r\n                                                          <img [src]=\"img.imgUrl\" alt=\"\" *ngFor=\"let img of item?.reviewImages ?? []\"\r\n                                                            >\r\n                                                          <div class=\"add-review-img\"  (click)=\"reviewFileInput.click()\" [ngClass]=\"{'w-100': (item?.reviewImages?.length ?? 0) == 0}\">\r\n                                                            <mat-icon>add</mat-icon> {{(item?.reviewImages?.length ?? 0) == 0 ? 'Add Images' : ''}}\r\n                                                          </div>\r\n                                                          <input  type=\"file\" name=\"myfile\" multiple hidden\r\n                                                            accept=\"image/jpg,image/jpeg,image/gif,image/png,application/pdf,image/x-eps\"\r\n                                                            (change)=\"uploadImage($event, item)\" class=\"pc-btn\"\r\n                                                            #reviewFileInput />\r\n                                                        </div>\r\n\r\n                                                        <div class=\"w-100 text-end p-2 sbt-btn f-13 cursor-pointer\"\r\n                                                            (click)=\"submitReview(item)\">\r\n                                                            Submit\r\n                                                        </div>\r\n                                                    </div>\r\n                                                </div>\r\n                                            </div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n\r\n                <!-- Timeline for Mobile -->\r\n                <ng-container *ngIf=\"isMobile\">\r\n                    <ng-container *ngTemplateOutlet=\"timelineContainer\"></ng-container>\r\n                </ng-container>\r\n            </div>\r\n\r\n            <!-- Right Column -->\r\n            <div class=\"col-12 scroll-60\" [ngClass]=\"{'col-lg-4': !isMobile}\">\r\n\r\n                <!-- Bill Details -->\r\n                <div class=\"card border-0 shadow-sm mb-4\">\r\n                    <div class=\"card-header py-3 cursor-pointer\" [simpoBackground]=\"styles?.background\" [id]=\"data?.id\"\r\n                        (click)=\"toggleSection('billDetails')\">\r\n                        <h4 class=\"h5 mb-0 d-flex align-items-center justify-content-between f-16\">\r\n                            <div class=\"d-flex align-items-center gap-2\">\r\n                                <mat-icon>receipt</mat-icon>\r\n                                Bill Details\r\n                            </div>\r\n                            <mat-icon class=\"transition-transform\" [class.rotate-180]=\"!sectionsVisible.billDetails\">\r\n                                expand_less\r\n                            </mat-icon>\r\n                        </h4>\r\n                    </div>\r\n                    <div class=\"card-body p-4\" [class.d-none]=\"!sectionsVisible.billDetails\">\r\n                        <div class=\"d-flex justify-content-between align-items-center py-2 border-bottom\">\r\n                            <span class=\"text-muted\">Item Total</span>\r\n                            <span class=\"fw-semibold h6 mb-0\">\r\n                                <span [innerHTML]=\"currency\"></span>{{ orderDetailData?.billDetails?.totalNetValue |\r\n                                number:'1.0-2' }}\r\n                            </span>\r\n                        </div>\r\n\r\n                        <div class=\"d-flex justify-content-between align-items-center py-2 border-bottom\"\r\n                            *ngIf=\"orderDetailData?.billDetails?.discountAmount\">\r\n                            <span class=\"d-flex align-items-center gap-2 text-muted\">\r\n                                Discount\r\n                            </span>\r\n                            <span class=\"fw-semibold text-success h6 mb-0\">\r\n                                -<span [innerHTML]=\"currency\"></span>{{ orderDetailData?.billDetails?.discountAmount |\r\n                                number:'1.0-2' }}\r\n                            </span>\r\n                        </div>\r\n\r\n                        <div class=\"d-flex justify-content-between align-items-center py-2 border-bottom\">\r\n                            <span class=\"text-muted\">Total Tax</span>\r\n                            <span class=\"fw-semibold h6 mb-0\">\r\n                                <span [innerHTML]=\"currency\"></span>{{ orderDetailData?.billDetails?.discountAmount ?\r\n                                orderDetailData?.billDetails?.totalTaxAfterDiscount :\r\n                                orderDetailData?.billDetails?.totalTax | number:'1.0-2' }}\r\n                            </span>\r\n                        </div>\r\n\r\n                        <div class=\"d-flex justify-content-between align-items-center py-2 border-bottom\">\r\n                            <span class=\"d-flex align-items-center gap-2 text-muted\">\r\n                                Delivery\r\n                            </span>\r\n                            <span class=\"fw-bold text-success h6 mb-0\">FREE</span>\r\n                        </div>\r\n\r\n                        <div class=\"d-flex justify-content-between align-items-center py-3 mt-3  rounded px-3\">\r\n                            <span class=\"fw-bold h5 mb-0 text-dark\">Grand Total</span>\r\n                            <span class=\"fw-bold h4 mb-0 \">\r\n                                <span [innerHTML]=\"currency\"></span>{{ orderDetailData?.billDetails?.discountAmount ?\r\n                                (orderDetailData?.billDetails?.totalNetValue -\r\n                                orderDetailData?.billDetails?.discountAmount +\r\n                                orderDetailData?.billDetails?.totalTaxAfterDiscount) :\r\n                                orderDetailData?.billDetails?.totalGrossValue | number:'1.0-2' }}\r\n                            </span>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n\r\n                <!-- Customer Details -->\r\n                <div class=\"card border-0 shadow-sm mb-4\">\r\n                    <div class=\"card-header py-3 cursor-pointer\" [simpoBackground]=\"styles?.background\" [id]=\"data?.id\"\r\n                        (click)=\"toggleSection('deliveryDetails')\">\r\n                        <h4 class=\"h5 mb-0 d-flex align-items-center justify-content-between f-16\">\r\n                            <div class=\"d-flex align-items-center gap-2\">\r\n                                <mat-icon>person</mat-icon>\r\n                                Delivery Details\r\n                            </div>\r\n                            <mat-icon class=\"transition-transform\"\r\n                                [class.rotate-180]=\"!sectionsVisible.deliveryDetails\">\r\n                                expand_less\r\n                            </mat-icon>\r\n                        </h4>\r\n                    </div>\r\n                    <div class=\"card-body p-4\" [class.d-none]=\"!sectionsVisible.deliveryDetails\">\r\n                        <div class=\"mb-3\">\r\n                            <div class=\"d-flex align-items-center gap-3 p-2 bg-light rounded\">\r\n                                <div>\r\n                                    <small class=\"text-muted d-block\">Name</small>\r\n                                    <span class=\"fw-semibold\">{{ orderDetailData?.addressDetails?.receiverName }}</span>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"mb-3\">\r\n                            <div class=\"d-flex align-items-center gap-3 p-2 bg-light rounded\">\r\n                                <div>\r\n                                    <small class=\"text-muted d-block\">Phone</small>\r\n                                    <span class=\"fw-semibold\">{{ orderDetailData?.addressDetails?.receiverPhone\r\n                                        }}</span>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"mb-3\">\r\n                            <div class=\"d-flex align-items-start gap-3 p-2 bg-light rounded\">\r\n                                <div>\r\n                                    <small class=\"text-muted d-block\">Address</small>\r\n                                    <span class=\"fw-semibold\">{{ orderAddress }}</span>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"mb-3\">\r\n                            <div class=\"d-flex align-items-center gap-3 p-2 bg-light rounded\">\r\n                                <div>\r\n                                    <small class=\"text-muted d-block\">Payment</small>\r\n                                    <span class=\"fw-semibold\">Manual Payment</span>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n\r\n                        <!-- Track Order Button -->\r\n                        <div class=\"text-center mt-4\" *ngIf=\"orderDetailData?.orderTrackingLink\">\r\n                            <button\r\n                                class=\"btn btn-primary w-100 d-flex align-items-center justify-content-center gap-2 py-2\"\r\n                                (click)=\"trackOrder()\">\r\n                                <mat-icon>location_searching</mat-icon>\r\n                                Track Order\r\n                            </button>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n\r\n                <!-- Timeline Section for Desktop -->\r\n                <div class=\"card border-0 shadow-sm mb-4\" *ngIf=\"!isMobile\">\r\n                    <div class=\"card-header py-3 cursor-pointer\" (click)=\"toggleSection('timeline')\"\r\n                        [simpoBackground]=\"styles?.background\" [id]=\"data?.id\">\r\n                        <h4 class=\"h5 mb-0 d-flex align-items-center justify-content-between f-16\r\n\r\n    \">\r\n                            <div class=\"d-flex align-items-center gap-2\">\r\n                                <mat-icon>timeline</mat-icon>\r\n                                Order Timeline\r\n                            </div>\r\n                            <mat-icon class=\"transition-transform\" [class.rotate-180]=\"!sectionsVisible.timeline\">\r\n                                expand_less\r\n                            </mat-icon>\r\n                        </h4>\r\n                    </div>\r\n                    <div class=\"card-body p-4\" [class.d-none]=\"!sectionsVisible.timeline\">\r\n                        <p-timeline [value]=\"orderTimiline\">\r\n                            <ng-template pTemplate=\"content\" let-event>\r\n                                <div class=\"d-flex align-items-start gap-3 py-3\">\r\n                                    <div class=\"rounded-circle p-2 d-flex align-items-center justify-content-center\"\r\n                                        style=\"width: 40px; height: 40px;\" [simpoBackground]=\"styles?.background\"\r\n                                        [id]=\"data?.id\">\r\n                                        <mat-icon class=\"fs-6 d-flex align-items-center justify-content-center\">{{\r\n                                            event.icon }}</mat-icon>\r\n                                    </div>\r\n                                    <div class=\"flex-grow-1\">\r\n                                        <h6 class=\"fw-semibold text-dark mb-1\">{{ event.name?.replaceAll(\"_\", \" \") |\r\n                                            titlecase }}</h6>\r\n                                        <p class=\"text-muted mb-0 small\">{{ event.desc?.replaceAll(\"_\", \" \") }}</p>\r\n                                    </div>\r\n                                </div>\r\n                            </ng-template>\r\n                        </p-timeline>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n\r\n        </div>\r\n    </div>\r\n</ng-container>\r\n\r\n<!-- Timeline Template -->\r\n<ng-template #timelineContainer>\r\n    <div class=\"card border-0 shadow-sm mb-4\">\r\n        <div class=\"card-header bg-warning text-dark py-2 f-16\">\r\n            <h4 class=\"h5 mb-0 d-flex align-items-center gap-2\">\r\n                <mat-icon>timeline</mat-icon>\r\n                Order Timeline\r\n            </h4>\r\n        </div>\r\n        <div class=\"card-body p-4\">\r\n            <p-timeline [value]=\"orderTimiline\">\r\n                <ng-template pTemplate=\"content\" let-event>\r\n                    <div class=\"d-flex align-items-start gap-3 py-3\">\r\n                        <div class=\"bg-primary rounded-circle p-2 d-flex align-items-center justify-content-center\"\r\n                            style=\"width: 40px; height: 40px;\">\r\n                            <mat-icon class=\"text-white fs-6 d-flex align-items-center justify-content-center\">{{\r\n                                event.icon }}</mat-icon>\r\n                        </div>\r\n                        <div class=\"flex-grow-1\">\r\n                            <h6 class=\"fw-semibold text-dark mb-1\">{{ event.name?.replaceAll(\"_\", \" \") | titlecase }}\r\n                            </h6>\r\n                            <p class=\"text-muted mb-0 small\">{{ event.desc?.replaceAll(\"_\", \" \") | titlecase }}</p>\r\n                        </div>\r\n                    </div>\r\n                </ng-template>\r\n            </p-timeline>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- Loading Skeleton -->\r\n<div class=\"container-fluid py-4\" *ngIf=\"isLoading\">\r\n    <div class=\"row\">\r\n        <div class=\"col-12\">\r\n            <ngx-skeleton-loader count=\"1\" appearance=\"circle\" [theme]=\"{\r\n                width: '100%',\r\n                height: '60vh',\r\n                'border-radius': '12px',\r\n                'margin': '20px 0'\r\n            }\"></ngx-skeleton-loader>\r\n        </div>\r\n    </div>\r\n</div>\r\n"]}