simpo-component-library 3.6.130 → 3.6.131

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.
Files changed (31) hide show
  1. package/esm2022/lib/ecommerce/sections/authentication-required/authentication-required.component.mjs +55 -6
  2. package/esm2022/lib/ecommerce/sections/new-collection/new-collection.component.mjs +1 -3
  3. package/esm2022/lib/ecommerce/sections/order-details/order-details.component.mjs +3 -2
  4. package/esm2022/lib/ecommerce/sections/product-desc/product-desc.component.mjs +24 -6
  5. package/esm2022/lib/ecommerce/sections/small-product-listing/small-product-listing.component.mjs +3 -3
  6. package/esm2022/lib/ecommerce/sections/store-list/store-list.component.mjs +3 -3
  7. package/esm2022/lib/ecommerce/sections/store-page/store-page.component.mjs +10 -10
  8. package/esm2022/lib/ecommerce/sections/user-basic-info/user-basic-info.component.mjs +3 -2
  9. package/esm2022/lib/sections/appointment-form/appointment-form.component.mjs +54 -68
  10. package/esm2022/lib/sections/header-section/header-section.component.mjs +3 -3
  11. package/esm2022/lib/services/rest.service.mjs +9 -4
  12. package/fesm2022/simpo-component-library.mjs +157 -99
  13. package/fesm2022/simpo-component-library.mjs.map +1 -1
  14. package/lib/directive/background-directive.d.ts +1 -1
  15. package/lib/directive/button-directive.directive.d.ts +1 -1
  16. package/lib/directive/color.directive.d.ts +1 -1
  17. package/lib/ecommerce/sections/authentication-required/authentication-required.component.d.ts +13 -3
  18. package/lib/ecommerce/sections/new-collection/new-collection.component.d.ts +1 -1
  19. package/lib/ecommerce/sections/product-desc/product-desc.component.d.ts +2 -2
  20. package/lib/ecommerce/sections/store-list/store-list.component.d.ts +1 -1
  21. package/lib/ecommerce/sections/store-page/store-page.component.d.ts +2 -2
  22. package/lib/sections/appointment-form/appointment-form.component.d.ts +6 -2
  23. package/lib/sections/banner-grid-section/banner-grid-section.component.d.ts +1 -1
  24. package/lib/sections/contact-us/contact-us.component.d.ts +1 -1
  25. package/lib/sections/header-section/header-section.component.d.ts +1 -1
  26. package/lib/sections/moving-text/moving-text.component.d.ts +1 -1
  27. package/lib/sections/pricing-section/pricing-section.component.d.ts +1 -1
  28. package/package.json +1 -1
  29. package/simpo-component-library-3.6.131.tgz +0 -0
  30. package/src/lib/styles/global-styles.css +2 -2
  31. package/simpo-component-library-3.6.130.tgz +0 -0
@@ -103,11 +103,12 @@ export class OrderDetailsComponent {
103
103
  submitReview(item) {
104
104
  console.log(item);
105
105
  let payload = {
106
- userId: this.storageService.getUser()?.userId,
106
+ userId: this.storageService.getUser()?.userId ?? "",
107
107
  businessId: localStorage.getItem('businessId') ?? "",
108
108
  productId: item.itemId,
109
109
  rating: item.rating,
110
110
  review: item.review,
111
+ orderId: this.orderDetailData?.userOrderId ?? "",
111
112
  userName: this.storageService.getUser()?.contact.name
112
113
  };
113
114
  this.restService.addReviewToProduct(payload).subscribe({
@@ -151,4 +152,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImpor
151
152
  }], goBackEmitter: [{
152
153
  type: Output
153
154
  }] } });
154
- //# 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\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  ],\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  ) { }\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\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  submitReview(item: any) {\r\n    console.log(item);\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      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","<ng-container *ngIf=\"!isLoading\">\r\n    <section class=\"d-flex justify-content-between main-section\" [style.width.vw]=\"isMobile ? '100' : '65'\"\r\n        style=\"margin: auto;\" [attr.style]=\"customClass\">\r\n        <div class=\"left\" [style.width.%]=\"isMobile ? '90' : '70'\">\r\n            <h1 class=\"fs-3 fw-normal mb-3 d-flex align-items-center onlyDesktop position-relative\"\r\n                style=\"left: -35px;\">\r\n                <mat-icon style=\"cursor: pointer;\" (click)=\"goBack()\">keyboard_arrow_left</mat-icon>\r\n                <span>Order Details</span>\r\n            </h1>\r\n            <div class=\"d-flex justify-content-between align-items-end orderNum\">\r\n                <div class=\"d-flex flex-column\">\r\n                    <span class=\"fs-5\">Order {{ orderDetailData?.orderNum }}</span>\r\n                    <span class=\"fs-6\">{{ orderDetailData?.createdTimeStamp | date: 'medium' }}, {{\r\n                        orderDetailData?.brandOrderDetails?.[0]?.orderedItems.length }} items | <span\r\n                            [innerHTML]=\"currency\"></span>\r\n                        {{orderDetailData?.brandOrderDetails?.[0]?.billDetails?.totalGrossValue}}</span>\r\n                </div>\r\n                <span class=\"fw-bold fs-5\">{{orderDetailData?.brandOrderDetails?.[0]?.businessName | titlecase}}</span>\r\n            </div>\r\n            <ng-container *ngIf=\"!isMobile\">\r\n                <ng-container *ngTemplateOutlet=\"timelineContainer\"></ng-container>\r\n            </ng-container>\r\n            <div>\r\n                <div *ngFor=\"let item of orderDetailData?.brandOrderDetails[0]?.orderedItems\" class=\"d-flex mb-2\"\r\n                    style=\"gap: 10px; width: 100%;\">\r\n                    <img loading=\"lazy\" onerror=\"this.src='https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\"\r\n                        [src]=\"item.imgUrl\" alt=\"\" style=\"height: 85px;width: 85px; border-radius: 5px;\">\r\n                    <div class=\"d-flex flex-column justify-content-center\" style=\"gap: 6px; width: 89%;\">\r\n                        <span class=\"fs-6\">{{item.itemName}}</span>\r\n                        <!-- <span class=\"fs-6\">Size: XS</span> -->\r\n                        <div class=\"d-flex justify-content-between fs-6\">\r\n                            <span>{{item.quantity}} X <span [innerHTML]=\"currency\"></span> <span\r\n                                    class=\"fw-bold\">{{(item.discountedPrice) | number: '1.0-2'}}</span></span>\r\n                            <span> <span [innerHTML]=\"currency\"></span> <span class=\"fw-bold\">{{(item.discountedPrice *\r\n                                    item.quantity) | number: '1.0-2'}}</span></span>\r\n                        </div>\r\n                        <div class=\"review-rating d-flex justify-content-between flex-column\">\r\n                            <div class=\"w-75\">\r\n                                <p-rating [(ngModel)]=\"item.rating\" [cancel]=\"false\" [readonly]=\"false\" />\r\n                                <div class=\"message w-100\">\r\n                                    <div class=\"f-13\">Add a Detailed Review</div>\r\n                                    <textarea class=\"w-100 br-6 f-13\" [(ngModel)]=\"item.review\"></textarea>\r\n                                </div>\r\n                            </div>\r\n                            <div class=\"d-flex align-items-end\">\r\n                                <div (click)=\"submitReview(item)\" class=\"d-flex align-items-end f-16 fw-800\">Submit</div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <ng-container *ngIf=\"isMobile\">\r\n                <ng-container *ngTemplateOutlet=\"timelineContainer\"></ng-container>\r\n            </ng-container>\r\n            <div class=\"fs-6 mt-25\">\r\n                <div class=\"d-flex justify-content-between my-2\">\r\n                    <span class=\"fw-normal\">Item Total</span>\r\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\r\n                        {{orderDetailData?.billDetails?.totalNetValue | number:'1.0-2'}}</span>\r\n                </div>\r\n                <div class=\"d-flex justify-content-between my-2\" *ngIf=\"orderDetailData?.billDetails?.discountAmount\">\r\n                    <span class=\"fw-normal\">Discount</span>\r\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\r\n                        {{orderDetailData?.billDetails?.discountAmount | number:'1.0-2'}}</span>\r\n                </div>\r\n                <div class=\"d-flex justify-content-between my-2\">\r\n                    <span class=\"fw-normal\">Total Tax</span>\r\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\r\n                        {{orderDetailData?.billDetails?.discountAmount ?\r\n                        orderDetailData?.billDetails?.totalTaxAfterDiscount :\r\n                        orderDetailData?.billDetails?.totalTax | number:'1.0-2'}}</span>\r\n                </div>\r\n\r\n                <div class=\"d-flex justify-content-between my-2\">\r\n                    <span>Delivery</span>\r\n                    <span>FREE</span>\r\n                </div>\r\n\r\n                <div class=\"d-flex justify-content-between my-2\">\r\n                    <span class=\"fw-normal\">Grand Total</span>\r\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\r\n                        {{orderDetailData?.billDetails?.discountAmount ? (orderDetailData?.billDetails?.totalNetValue -\r\n                        orderDetailData?.billDetails?.discountAmount +\r\n                        orderDetailData?.billDetails?.totalTaxAfterDiscount) :\r\n                        orderDetailData?.billDetails?.totalGrossValue | number:'1.0-2'}}</span>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"\" style=\"width: 28%;\" [style.width.%]=\"isMobile ? '90' : '28'\">\r\n            <div class=\"right\">\r\n                <h1 class=\"mb-3 fs-5\">User Details</h1>\r\n                <div class=\"my-2 fs-6\">\r\n                    <span style=\"margin-right: 10px;\">Name:</span>\r\n                    <span class=\"fw-bold pl-2\">{{orderDetailData?.addressDetails?.receiverName}}</span>\r\n                </div>\r\n                <div class=\"my-2 fs-6\">\r\n                    <span style=\"margin-right: 10px\">Phone:</span>\r\n                    <span class=\"fw-bold pl-2\">{{ orderDetailData?.addressDetails?.receiverPhone }}</span>\r\n                </div>\r\n                <div class=\"my-2 fs-6\">\r\n                    <span style=\"margin-right: 10px\">Address:</span>\r\n                    <span class=\"fw-bold pl-2\">{{ orderAddress }}</span>\r\n                </div>\r\n                <div class=\"my-2 fs-6\">\r\n                    <span style=\"margin-right: 10px\">Payment:</span>\r\n                    <span class=\"fw-bold pl-2\">Manual Payment</span>\r\n                </div>\r\n                <a (click)=\"trackOrder()\" class=\"track-order\" *ngIf=\"orderDetailData?.orderTrackingLink\">Track Order\r\n                </a>\r\n            </div>\r\n        </div>\r\n    </section>\r\n</ng-container>\r\n\r\n<ng-template #timelineContainer>\r\n    <hr />\r\n    <div class=\"timeline\">\r\n        <p-timeline [value]=\"orderTimiline\">\r\n            <ng-template pTemplate=\"content\" let-event>\r\n                <div class=\"d-flex time-line\">\r\n                    <mat-icon style=\"margin-right: 10px;\">{{ event.icon }}</mat-icon>\r\n                    <div class=\"d-flex flex-column ml-2\">\r\n                        <span class=\"fw-normal fs-6\">{{ event.name?.replaceAll(\"_\", \" \") }}</span>\r\n                        <div class=\"fs-6 \">{{event.desc?.replaceAll(\"_\", \" \")}}</div>\r\n                        <!-- <div class=\"action-btn\">\r\n                            <button *ngIf=\"canCancelOrder\">Cancel Order</button>\r\n                        </div> -->\r\n                    </div>\r\n                </div>\r\n            </ng-template>\r\n        </p-timeline>\r\n    </div>\r\n    <hr />\r\n</ng-template>\r\n\r\n<ngx-skeleton-loader *ngIf=\"isLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\r\n    width: '100%',\r\n    height: '40vh',\r\n    'border-radius': '10px',\r\n    'position': 'relative',\r\n    'right': '5px'\r\n  }\">\r\n</ngx-skeleton-loader>"]}
155
+ //# 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\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  ],\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  ) { }\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\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  submitReview(item: any) {\r\n    console.log(item);\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      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","<ng-container *ngIf=\"!isLoading\">\r\n    <section class=\"d-flex justify-content-between main-section\" [style.width.vw]=\"isMobile ? '100' : '65'\"\r\n        style=\"margin: auto;\" [attr.style]=\"customClass\">\r\n        <div class=\"left\" [style.width.%]=\"isMobile ? '90' : '70'\">\r\n            <h1 class=\"fs-3 fw-normal mb-3 d-flex align-items-center onlyDesktop position-relative\"\r\n                style=\"left: -35px;\">\r\n                <mat-icon style=\"cursor: pointer;\" (click)=\"goBack()\">keyboard_arrow_left</mat-icon>\r\n                <span>Order Details</span>\r\n            </h1>\r\n            <div class=\"d-flex justify-content-between align-items-end orderNum\">\r\n                <div class=\"d-flex flex-column\">\r\n                    <span class=\"fs-5\">Order {{ orderDetailData?.orderNum }}</span>\r\n                    <span class=\"fs-6\">{{ orderDetailData?.createdTimeStamp | date: 'medium' }}, {{\r\n                        orderDetailData?.brandOrderDetails?.[0]?.orderedItems.length }} items | <span\r\n                            [innerHTML]=\"currency\"></span>\r\n                        {{orderDetailData?.brandOrderDetails?.[0]?.billDetails?.totalGrossValue}}</span>\r\n                </div>\r\n                <span class=\"fw-bold fs-5\">{{orderDetailData?.brandOrderDetails?.[0]?.businessName | titlecase}}</span>\r\n            </div>\r\n            <ng-container *ngIf=\"!isMobile\">\r\n                <ng-container *ngTemplateOutlet=\"timelineContainer\"></ng-container>\r\n            </ng-container>\r\n            <div>\r\n                <div *ngFor=\"let item of orderDetailData?.brandOrderDetails[0]?.orderedItems\" class=\"d-flex mb-2\"\r\n                    style=\"gap: 10px; width: 100%;\">\r\n                    <img loading=\"lazy\" onerror=\"this.src='https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\"\r\n                        [src]=\"item.imgUrl\" alt=\"\" style=\"height: 85px;width: 85px; border-radius: 5px;\">\r\n                    <div class=\"d-flex flex-column justify-content-center\" style=\"gap: 6px; width: 89%;\">\r\n                        <span class=\"fs-6\">{{item.itemName}}</span>\r\n                        <!-- <span class=\"fs-6\">Size: XS</span> -->\r\n                        <div class=\"d-flex justify-content-between fs-6\">\r\n                            <span>{{item.quantity}} X <span [innerHTML]=\"currency\"></span> <span\r\n                                    class=\"fw-bold\">{{(item.discountedPrice) | number: '1.0-2'}}</span></span>\r\n                            <span> <span [innerHTML]=\"currency\"></span> <span class=\"fw-bold\">{{(item.discountedPrice *\r\n                                    item.quantity) | number: '1.0-2'}}</span></span>\r\n                        </div>\r\n                        <div class=\"review-rating d-flex justify-content-between flex-column\">\r\n                            <div class=\"w-75\">\r\n                                <p-rating [(ngModel)]=\"item.rating\" [cancel]=\"false\" [readonly]=\"false\" />\r\n                                <div class=\"message w-100\">\r\n                                    <div class=\"f-13\">Add a Detailed Review</div>\r\n                                    <textarea class=\"w-100 br-6 f-13\" [(ngModel)]=\"item.review\"></textarea>\r\n                                </div>\r\n                            </div>\r\n                            <div class=\"d-flex align-items-end\">\r\n                                <div (click)=\"submitReview(item)\" class=\"d-flex align-items-end f-16 fw-800\">Submit</div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <ng-container *ngIf=\"isMobile\">\r\n                <ng-container *ngTemplateOutlet=\"timelineContainer\"></ng-container>\r\n            </ng-container>\r\n            <div class=\"fs-6 mt-25\">\r\n                <div class=\"d-flex justify-content-between my-2\">\r\n                    <span class=\"fw-normal\">Item Total</span>\r\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\r\n                        {{orderDetailData?.billDetails?.totalNetValue | number:'1.0-2'}}</span>\r\n                </div>\r\n                <div class=\"d-flex justify-content-between my-2\" *ngIf=\"orderDetailData?.billDetails?.discountAmount\">\r\n                    <span class=\"fw-normal\">Discount</span>\r\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\r\n                        {{orderDetailData?.billDetails?.discountAmount | number:'1.0-2'}}</span>\r\n                </div>\r\n                <div class=\"d-flex justify-content-between my-2\">\r\n                    <span class=\"fw-normal\">Total Tax</span>\r\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\r\n                        {{orderDetailData?.billDetails?.discountAmount ?\r\n                        orderDetailData?.billDetails?.totalTaxAfterDiscount :\r\n                        orderDetailData?.billDetails?.totalTax | number:'1.0-2'}}</span>\r\n                </div>\r\n\r\n                <div class=\"d-flex justify-content-between my-2\">\r\n                    <span>Delivery</span>\r\n                    <span>FREE</span>\r\n                </div>\r\n\r\n                <div class=\"d-flex justify-content-between my-2\">\r\n                    <span class=\"fw-normal\">Grand Total</span>\r\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\r\n                        {{orderDetailData?.billDetails?.discountAmount ? (orderDetailData?.billDetails?.totalNetValue -\r\n                        orderDetailData?.billDetails?.discountAmount +\r\n                        orderDetailData?.billDetails?.totalTaxAfterDiscount) :\r\n                        orderDetailData?.billDetails?.totalGrossValue | number:'1.0-2'}}</span>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"\" style=\"width: 28%;\" [style.width.%]=\"isMobile ? '90' : '28'\">\r\n            <div class=\"right\">\r\n                <h1 class=\"mb-3 fs-5\">User Details</h1>\r\n                <div class=\"my-2 fs-6\">\r\n                    <span style=\"margin-right: 10px;\">Name:</span>\r\n                    <span class=\"fw-bold pl-2\">{{orderDetailData?.addressDetails?.receiverName}}</span>\r\n                </div>\r\n                <div class=\"my-2 fs-6\">\r\n                    <span style=\"margin-right: 10px\">Phone:</span>\r\n                    <span class=\"fw-bold pl-2\">{{ orderDetailData?.addressDetails?.receiverPhone }}</span>\r\n                </div>\r\n                <div class=\"my-2 fs-6\">\r\n                    <span style=\"margin-right: 10px\">Address:</span>\r\n                    <span class=\"fw-bold pl-2\">{{ orderAddress }}</span>\r\n                </div>\r\n                <div class=\"my-2 fs-6\">\r\n                    <span style=\"margin-right: 10px\">Payment:</span>\r\n                    <span class=\"fw-bold pl-2\">Manual Payment</span>\r\n                </div>\r\n                <a (click)=\"trackOrder()\" class=\"track-order\" *ngIf=\"orderDetailData?.orderTrackingLink\">Track Order\r\n                </a>\r\n            </div>\r\n        </div>\r\n    </section>\r\n</ng-container>\r\n\r\n<ng-template #timelineContainer>\r\n    <hr />\r\n    <div class=\"timeline\">\r\n        <p-timeline [value]=\"orderTimiline\">\r\n            <ng-template pTemplate=\"content\" let-event>\r\n                <div class=\"d-flex time-line\">\r\n                    <mat-icon style=\"margin-right: 10px;\">{{ event.icon }}</mat-icon>\r\n                    <div class=\"d-flex flex-column ml-2\">\r\n                        <span class=\"fw-normal fs-6\">{{ event.name?.replaceAll(\"_\", \" \") }}</span>\r\n                        <div class=\"fs-6 \">{{event.desc?.replaceAll(\"_\", \" \")}}</div>\r\n                        <!-- <div class=\"action-btn\">\r\n                            <button *ngIf=\"canCancelOrder\">Cancel Order</button>\r\n                        </div> -->\r\n                    </div>\r\n                </div>\r\n            </ng-template>\r\n        </p-timeline>\r\n    </div>\r\n    <hr />\r\n</ng-template>\r\n\r\n<ngx-skeleton-loader *ngIf=\"isLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\r\n    width: '100%',\r\n    height: '40vh',\r\n    'border-radius': '10px',\r\n    'position': 'relative',\r\n    'right': '5px'\r\n  }\">\r\n</ngx-skeleton-loader>"]}