simpo-component-library 3.6.132 → 3.6.134

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.
@@ -13,7 +13,6 @@ export class ButtonEditorDirective {
13
13
  this.HIGHLIGHT_BORDER = '3px solid #283E90';
14
14
  }
15
15
  ngOnInit() {
16
- console.log(this.buttonId, this.sectionId, this.buttonStyle, this.backgroundInfo);
17
16
  if (this.appButtonEditor) {
18
17
  this.el.nativeElement.style.border = this.buttonStyle?.type == 'Outline' ? `2px solid ${this.backgroundInfo?.accentColor}` : 'unset';
19
18
  this.setupEventListeners();
@@ -95,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
95
94
  }], buttonId: [{
96
95
  type: Input
97
96
  }] } });
98
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-editor.directive.js","sourceRoot":"","sources":["../../../../../projects/simpo-ui/src/lib/directive/button-editor.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, Input, Renderer2 } from '@angular/core';\nimport { BackgroundModel, Button, ButtonStyleModel } from '../styles/style.model';\nimport { MatDialog } from '@angular/material/dialog';\nimport { LinkEditorComponent } from '../elements/link-editor/link-editor.component';\nimport { debounceTime, filter, fromEvent, Subscription } from 'rxjs';\n\n@Directive({\n  selector: 'button[appButtonEditor]',\n  standalone: true\n})\nexport class ButtonEditorDirective {\n  @Input() appButtonEditor: boolean = false;\n  @Input() buttonData?: Button;\n  @Input() buttonStyle?: ButtonStyleModel;\n  @Input() backgroundInfo?: BackgroundModel;\n  @Input() sectionId?: string = '';\n  @Input() buttonId: string = '';\n\n  private mouseEnterSub?: Subscription;\n  private mouseLeaveSub?: Subscription;\n  private clickSub?: Subscription;\n  private readonly HIGHLIGHT_BORDER = '3px solid #283E90';\n\n  constructor(private el: ElementRef, private matDialog: MatDialog) { }\n\n  ngOnInit() {\n    console.log(this.buttonId, this.sectionId, this.buttonStyle, this.backgroundInfo);\n    if (this.appButtonEditor) {\n      this.el.nativeElement.style.border = this.buttonStyle?.type == 'Outline' ? `2px solid ${this.backgroundInfo?.accentColor}` : 'unset';\n      this.setupEventListeners();\n    } else {\n      this.el.nativeElement.style.border = this.buttonStyle?.type == 'Outline' ? `2px solid ${this.backgroundInfo?.accentColor}` : 'unset';\n    }\n  }\n\n  ngOnChanges() {\n    this.cleanup();\n    if (this.appButtonEditor) {\n      this.setupEventListeners();\n    }\n  }\n\n  private setupEventListeners() {\n    this.mouseEnterSub = fromEvent(this.el.nativeElement, 'mouseenter')\n      .pipe(debounceTime(100))\n      .subscribe(() => {\n        this.el.nativeElement.style.border = this.HIGHLIGHT_BORDER;\n      });\n\n    this.mouseLeaveSub = fromEvent(this.el.nativeElement, 'mouseleave')\n      .pipe(debounceTime(100))\n      .subscribe(() => {\n        this.el.nativeElement.style.border = this.buttonStyle?.type == 'Outline' ? `2px solid ${this.backgroundInfo?.accentColor}` : 'unset';\n      });\n    this.clickSub = fromEvent(this.el.nativeElement, 'click')\n      .pipe(\n        filter(() => !this.matDialog.openDialogs.length)\n      )\n      .subscribe(() => {\n        this.matDialog.open(LinkEditorComponent, {\n          panelClass: 'link-editor',\n          data: {\n            linkData: this.buttonData ?? {},\n            type: \"BUTTON\",\n            buttonStyle: this.buttonStyle ?? {},\n            backgroundInfo: this.backgroundInfo ?? {},\n            buttonId: (this.sectionId + this.buttonId) ,\n          }\n        });\n      });\n  }\n\n  private cleanup() {\n    if (this.mouseEnterSub) {\n      this.mouseEnterSub.unsubscribe();\n      this.mouseEnterSub = undefined;\n    }\n\n    if (this.mouseLeaveSub) {\n      this.mouseLeaveSub.unsubscribe();\n      this.mouseLeaveSub = undefined;\n    }\n\n    if (this.clickSub) {\n      this.clickSub.unsubscribe();\n      this.clickSub = undefined;\n    }\n\n    // Reset styles when cleaning up\n    this.el.nativeElement.style.border = '';\n  }\n\n  ngOnDestroy() {\n    this.cleanup();\n  }\n\n}\n"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-editor.directive.js","sourceRoot":"","sources":["../../../../../projects/simpo-ui/src/lib/directive/button-editor.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, Input, Renderer2 } from '@angular/core';\nimport { BackgroundModel, Button, ButtonStyleModel } from '../styles/style.model';\nimport { MatDialog } from '@angular/material/dialog';\nimport { LinkEditorComponent } from '../elements/link-editor/link-editor.component';\nimport { debounceTime, filter, fromEvent, Subscription } from 'rxjs';\n\n@Directive({\n  selector: 'button[appButtonEditor]',\n  standalone: true\n})\nexport class ButtonEditorDirective {\n  @Input() appButtonEditor: boolean = false;\n  @Input() buttonData?: Button;\n  @Input() buttonStyle?: ButtonStyleModel;\n  @Input() backgroundInfo?: BackgroundModel;\n  @Input() sectionId?: string = '';\n  @Input() buttonId: string = '';\n\n  private mouseEnterSub?: Subscription;\n  private mouseLeaveSub?: Subscription;\n  private clickSub?: Subscription;\n  private readonly HIGHLIGHT_BORDER = '3px solid #283E90';\n\n  constructor(private el: ElementRef, private matDialog: MatDialog) { }\n\n  ngOnInit() {\n    if (this.appButtonEditor) {\n      this.el.nativeElement.style.border = this.buttonStyle?.type == 'Outline' ? `2px solid ${this.backgroundInfo?.accentColor}` : 'unset';\n      this.setupEventListeners();\n    } else {\n      this.el.nativeElement.style.border = this.buttonStyle?.type == 'Outline' ? `2px solid ${this.backgroundInfo?.accentColor}` : 'unset';\n    }\n  }\n\n  ngOnChanges() {\n    this.cleanup();\n    if (this.appButtonEditor) {\n      this.setupEventListeners();\n    }\n  }\n\n  private setupEventListeners() {\n    this.mouseEnterSub = fromEvent(this.el.nativeElement, 'mouseenter')\n      .pipe(debounceTime(100))\n      .subscribe(() => {\n        this.el.nativeElement.style.border = this.HIGHLIGHT_BORDER;\n      });\n\n    this.mouseLeaveSub = fromEvent(this.el.nativeElement, 'mouseleave')\n      .pipe(debounceTime(100))\n      .subscribe(() => {\n        this.el.nativeElement.style.border = this.buttonStyle?.type == 'Outline' ? `2px solid ${this.backgroundInfo?.accentColor}` : 'unset';\n      });\n    this.clickSub = fromEvent(this.el.nativeElement, 'click')\n      .pipe(\n        filter(() => !this.matDialog.openDialogs.length)\n      )\n      .subscribe(() => {\n        this.matDialog.open(LinkEditorComponent, {\n          panelClass: 'link-editor',\n          data: {\n            linkData: this.buttonData ?? {},\n            type: \"BUTTON\",\n            buttonStyle: this.buttonStyle ?? {},\n            backgroundInfo: this.backgroundInfo ?? {},\n            buttonId: (this.sectionId + this.buttonId) ,\n          }\n        });\n      });\n  }\n\n  private cleanup() {\n    if (this.mouseEnterSub) {\n      this.mouseEnterSub.unsubscribe();\n      this.mouseEnterSub = undefined;\n    }\n\n    if (this.mouseLeaveSub) {\n      this.mouseLeaveSub.unsubscribe();\n      this.mouseLeaveSub = undefined;\n    }\n\n    if (this.clickSub) {\n      this.clickSub.unsubscribe();\n      this.clickSub = undefined;\n    }\n\n    // Reset styles when cleaning up\n    this.el.nativeElement.style.border = '';\n  }\n\n  ngOnDestroy() {\n    this.cleanup();\n  }\n\n}\n"]}
@@ -15,7 +15,7 @@ import { HoverDirective } from '../../../directive/hover-element-directive';
15
15
  import { OverlayDirective } from '../../../directive/overlay-directive';
16
16
  import { SpacingAroundDirective } from '../../../directive/spacing-around.directive';
17
17
  import BaseSection from '../../../sections/BaseSection';
18
- import { ButtonEditorDirective } from '@simpo-ui/directive/button-editor.directive';
18
+ import { ButtonEditorDirective } from '../../../directive/button-editor.directive';
19
19
  import * as i0 from "@angular/core";
20
20
  import * as i1 from "../../../services/rest.service";
21
21
  import * as i2 from "@angular/router";
@@ -423,4 +423,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
423
423
  }], delete: [{
424
424
  type: Input
425
425
  }] } });
426
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authentication-required.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/authentication-required/authentication-required.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/authentication-required/authentication-required.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, ElementRef, Input, Optional } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { RestService } from '../../../services/rest.service';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { MessageService } from 'primeng/api';\nimport { ToastModule } from 'primeng/toast';\nimport { DeviceInfo } from '../../styles/user.modal';\nimport { StorageServiceService } from '../../../services/storage.service';\nimport Swal from 'sweetalert2';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatBottomSheetRef } from '@angular/material/bottom-sheet';\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\nimport { UserBasicInfoComponent } from '../user-basic-info/user-basic-info.component';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { AuthenticationModel, AuthenticationStylesModel } from './authentication-required.model';\nimport { SimpoComponentModule } from '../../../components/index';\nimport { AnimationDirective } from '../../../directive/animation-directive';\nimport { BackgroundDirective } from '../../../directive/background-directive';\nimport { ContentFitDirective } from '../../../directive/content-fit-directive';\nimport { ButtonDirectiveDirective } from '../../../directive/button-directive.directive';\nimport { CornerDirective } from '../../../directive/corner-directive';\nimport { HoverDirective } from '../../../directive/hover-element-directive';\nimport { OverlayDirective } from '../../../directive/overlay-directive';\nimport { SpacingAroundDirective } from '../../../directive/spacing-around.directive';\nimport BaseSection from '../../../sections/BaseSection';\nimport { ButtonModel, LayOutModel } from '../../../styles/style.model';\nimport { ButtonEditorDirective } from '@simpo-ui/directive/button-editor.directive';\n\n@Component({\n  selector: 'simpo-authentication-required',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ToastModule,\n    MatIconModule,\n    MatProgressSpinnerModule,\n    SimpoComponentModule,\n\n    AnimationDirective,\n    BackgroundDirective,\n    ButtonDirectiveDirective,\n    ContentFitDirective,\n    CornerDirective,\n    HoverDirective,\n    OverlayDirective,\n    SpacingAroundDirective,\n    ButtonEditorDirective\n  ],\n  providers: [MessageService],\n  templateUrl: './authentication-required.component.html',\n  styleUrl: './authentication-required.component.css'\n})\nexport class AuthenticationRequiredComponent extends BaseSection {\n  // private emailTimer: NodeJS.Timeout | null = null;\n  @Input() data?: AuthenticationModel;\n  @Input() index?: number;\n  @Input() edit?: boolean;\n  @Input() delete?: boolean;\n  styles?: AuthenticationStylesModel;\n  button?: ButtonModel\n  buttonId: string = '';\n\n  currentPage: 'LOGIN' | 'SIGNUP' = 'LOGIN';\n  private mobileTimer: any;\n  public email: string = \"\";\n  public mobile: string = \"\";\n  public otp: string = \"\";\n  public password: string = \"\";\n  public confPassword: string = \"\";\n  public userName: string = \"\";\n  public buttonLoading: boolean = false;\n  public businessId: string | null = localStorage.getItem(\"bId\");\n  public isOTPVerified: boolean = false;\n  public passwordHidden: boolean = true;\n  public passwordStrengthCount: number = 0;\n  public passwordStrength = [\n    { type: \"minimum 8 character\", active: false },\n    { type: \"atleast one UPPERCASE\", active: false },\n    { type: \"atleast one lowercase\", active: false },\n    { type: \"atleast one number\", active: false },\n  ]\n\n  constructor(\n    private readonly restService: RestService,\n    private readonly router: Router,\n    private readonly messageService: MessageService,\n    private readonly storageService: StorageServiceService,\n    private readonly matDialog: MatDialog,\n    private readonly activatedRoute: ActivatedRoute,\n    private elementRef: ElementRef,\n\n    @Optional() private readonly dialogRef: MatDialogRef<AuthenticationRequiredComponent>,\n    @Optional() private readonly bottomsheetRef: MatBottomSheetRef<AuthenticationRequiredComponent>,\n  ) {\n    super();\n  }\n\n  signUpEnabled: any = true;\n\n  proceedToCheckout: boolean = false;\n  ngOnInit() {\n    this.activatedRoute.queryParams.subscribe((param: any) => {\n      if (param && param['cart'])\n        this.proceedToCheckout = true;\n    })\n    this.styles = this.data?.styles;\n    this.button = this.data?.action?.buttons[0];\n    this.buttonId = (this.data ? this.data.id : '') + (this.button ? this.button.id : '');\n\n    let enabled = localStorage.getItem('signUpEnabled');\n    if (enabled != null)\n      this.signUpEnabled = enabled === 'true';\n\n  }\n  ngAfterViewInit() {\n    this.setup3DEffects();\n  }\n\n  loginType: \"PASSWORD\" | \"OTP\" = \"PASSWORD\";\n\n  close() {\n    this.dialogRef.close();\n  }\n  login() {\n    if (this.loginType == \"OTP\") {\n      this.verifyOTP();\n    } else {\n      this.verifyPassword();\n    }\n  }\n\n  verifyPassword() {\n\n    if (!this.isEmailValid) {\n      this.messageService.add({ severity: 'error', summary: 'Invalid Email', detail: 'Please enter a valid email address' });\n      return;\n    }\n\n    if (!this.isPasswordValid) {\n      this.messageService.add({ severity: 'error', summary: 'Invalid Password', detail: 'Please enter a valid password' });\n      return;\n    }\n\n    const payload = {\n      businessId: this.businessId,\n      email: this.email,\n      password: this.password\n    }\n\n    this.buttonLoading = true;\n    this.restService.signinPassword(payload).subscribe((response: any) => {\n      const userDetails = this.storageService.setUser(response.data);\n      this.storageService.updateAllData();\n      this.buttonLoading = false;\n      // this.dialogRef.close('success');\n      this.messageService.add({ severity: 'success', summary: 'Logged In', detail: 'Logged in Successfully' });\n      if (this.proceedToCheckout)\n        this.router.navigate(['/cart'], { queryParams: { checkout: true } });\n      else\n        this.router.navigate(['']);\n    },\n      (error) => {\n        this.buttonLoading = false;\n        this.messageService.add({ severity: 'error', summary: 'Login request', detail: error?.error?.message });\n      })\n  }\n  verifyOTP() {\n\n    const deviceInfo: DeviceInfo | null = {\n      firebaseToken: localStorage.getItem(\"fbToken\") ?? \"\"\n    };\n\n    this.buttonLoading = true;\n    this.restService.verifyOTP(this.mobile ?? \"\", this.otp, deviceInfo).subscribe((response: any) => {\n      const userDetails = this.storageService.setUser(response.data);\n      this.storageService.updateAllData();\n      this.dialogRef.close('success');\n    },\n      (error) => {\n        this.buttonLoading = false;\n        this.messageService.add({ severity: 'error', summary: \"Login request\", detail: error?.error?.message });\n      })\n  }\n  sendSignupOTP() {\n    this.buttonLoading = true;\n    this.isOTPVerified = false;\n    if (this.mobileTimer)\n      clearTimeout(this.mobileTimer);\n    this.mobileTimer = setTimeout(() => {\n      if (this.mobile.length != 10)\n        return;\n      const payload: any = {\n        businessId: this.businessId,\n        mobile: this.mobile,\n        email: this.email,\n        password: this.password,\n        countryCode: '91'\n      }\n      this.restService.sendSignupOTP(payload).subscribe((res: any) => {\n        this.isOTPVerified = true;\n        this.buttonLoading = false;\n        this.messageService.add({ severity: 'success', summary: 'OTP', detail: 'OTP Sent' });\n      }, (err) => {\n        this.messageService.add({ severity: 'error', summary: 'OTP Request', detail: err.error.message });\n        this.buttonLoading = false;\n      })\n    }, 800);\n  }\n  createAccount() {\n\n    if (!this.isEmailValid) {\n      this.messageService.add({ severity: 'error', summary: 'Invalid Email', detail: 'Please enter a valid email address' });\n      return;\n    }\n    if (!this.isPasswordValid) {\n      this.messageService.add({ severity: 'error', summary: 'Invalid Password', detail: 'Please enter a valid password' });\n      return;\n    }\n    if (!this.mobileNumberValid) {\n      this.messageService.add({ severity: 'error', summary: 'Invalid Mobile Number', detail: 'Please enter a valid mobile number' });\n      return;\n    }\n\n    const deviceInfo: DeviceInfo | null = {\n      firebaseToken: localStorage.getItem(\"fbToken\") ?? \"\"\n    };\n\n    this.buttonLoading = true;\n    let verifySignData = {\n      name: this.userName,\n      businessId: this.businessId,\n      businessName: localStorage.getItem('bName'),\n      mobile: this.mobile,\n      email: this.email,\n      password: this.password,\n      countryCode: \"+91\",\n      enteredOtp: this.otp\n    }\n    this.restService.verifySignupOTP(verifySignData).subscribe((response: any) => {\n      const userDetails = this.storageService.setUser(response.data);\n      this.storageService.updateAllData();\n      // this.dialogRef.close('success');\n      this.buttonLoading = false;\n      this.messageService.add({ severity: 'success', summary: 'Sign Up', detail: 'Your account successfully created' });\n      if (this.proceedToCheckout)\n        this.router.navigate(['/cart'], { queryParams: { checkout: true } });\n      else\n        this.router.navigate(['']);      // Swal.fire({\n      //   icon: \"success\",\n      //   title: \"Hurray\",\n      //   text: \"Your account successfully created\",\n      //   showCancelButton: !(userDetails.contact?.name?.length > 0),\n      //   confirmButtonText: \"I loved it\",\n      //   cancelButtonText: \"Fill other basic details\",\n      //   cancelButtonColor: \"#928c8c\",\n      // }).then((result) => {\n\n      //   if (result.isDismissed) {\n      //     this.matDialog.open(UserBasicInfoComponent, {\n      //       height: '50vh',\n      //       width: window.innerWidth > 475 ? '40vw' : '95vw',\n      //       maxWidth: window.innerWidth > 475 ? '100vw' : '80vw',\n      //       data: {}\n      //     });\n      //   }\n      // })\n    }, (error) => {\n      this.buttonLoading = false;\n      if (error.status === 500) {\n        this.messageService.add({ severity: 'error', summary: 'Signup error', detail: error?.error?.message })\n      }\n      else {\n        this.messageService.add({ severity: 'error', summary: 'Signup error', detail: error?.error?.message });\n      }\n    })\n  }\n  verifySignupOTP() {\n\n    if (this.otp.length != 6)\n      return;\n\n    const deviceInfo: DeviceInfo | null = {\n      firebaseToken: localStorage.getItem(\"fbToken\") ?? \"\"\n    };\n\n    this.buttonLoading = true;\n    let verifySignData = {\n      businessId: this.businessId,\n      mobile: this.mobile,\n      email: this.email,\n      password: this.password,\n      countryCode: \"91\",\n      enteredOtp: this.otp\n    }\n    this.restService.verifySignupOTP(verifySignData).subscribe((response: any) => {\n\n      this.messageService.add({ severity: 'success', summary: 'OTP', detail: 'OTP Verified' });\n    }, (error) => {\n      this.buttonLoading = false;\n      if (error.status === 500) {\n        this.messageService.add({ severity: 'error', summary: 'User already exists' })\n      }\n      else {\n        this.messageService.add({ severity: 'error', summary: 'Invalid OTP', detail: 'Please enter valid otp' });\n      }\n    })\n  }\n  enterMobile() {\n\n    if (this.mobileTimer)\n      clearTimeout(this.mobileTimer);\n    this.mobileTimer = setTimeout(() => {\n      if (this.mobile.length != 10)\n        return;\n      this.generateOTP();\n    }, 500);\n  }\n\n  generateOTP() {\n    this.buttonLoading = true;\n    this.restService.generateOTP(this.mobile ?? \"\", \"91\").subscribe(\n      (response) => {\n        this.buttonLoading = false;\n        this.messageService.add({\n          severity: 'success',\n          summary: 'OTP Sent',\n          detail: 'OTP sent to mobile. Valid for 3 mins',\n          life: 10000\n        });\n      },\n      (error) => {\n        this.buttonLoading = false;\n        const errorMessage = error?.error?.message;\n\n        this.messageService.add({\n          severity: 'error',\n          summary: 'OTP Request',\n          detail: errorMessage,\n          life: 10000\n        });\n      }\n    );\n  }\n\n  validateNumber(event: KeyboardEvent): void {\n    const charCode = event.charCode;\n    if (charCode < 48 || charCode > 57) {\n      event.preventDefault();\n    }\n  }\n\n  validateOTP(event: KeyboardEvent): void {\n    if (this.otp.length == 6) {\n      event.preventDefault();\n    }\n  }\n  checkStrength() {\n    this.passwordStrengthCount = 0;\n    this.passwordStrengthCount += (/[A-Z]/.test(this.password)) ? 1 : 0;\n    this.passwordStrengthCount += (/[a-z]/.test(this.password)) ? 1 : 0;\n    this.passwordStrengthCount += (/\\d/.test(this.password)) ? 1 : 0;\n    this.passwordStrengthCount += (this.password.length > 8 ? 1 : 0);\n  }\n  getStrengthColor(index: number) {\n    switch (this.passwordStrengthCount) {\n      case 1:\n        return (index < this.passwordStrengthCount ? \"tomato\" : \"#d3d3d3ba\");\n      case 2:\n        return (index < this.passwordStrengthCount ? \"orange\" : \"#d3d3d3ba\");\n      case 3:\n        return (index < this.passwordStrengthCount ? \"yellow\" : \"#d3d3d3ba\");\n      case 4:\n        return (index < this.passwordStrengthCount ? \"lightgreen\" : \"#d3d3d3ba\");\n      default:\n        return \"#d3d3d3ba\";\n    }\n  }\n  emailDebounceTimer: any;\n  onEmailChange() {\n    clearTimeout(this.emailDebounceTimer);\n    this.emailDebounceTimer = setTimeout(() => {\n      this.isEmailValid();\n    }, 200);\n  }\n  emailCheck: boolean = false;\n  isEmailValid() {\n    const emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$/;\n    this.emailCheck = !emailRegex.test(this.email);\n    return emailRegex.test(this.email);\n  }\n  passwordDebounceTimer: any;\n  onPasswordChange() {\n    clearTimeout(this.passwordDebounceTimer);\n    this.passwordDebounceTimer = setTimeout(() => {\n      this.isPasswordValid();\n    }, 200);\n  }\n  passwordCheck: boolean = false;\n  isPasswordValid() {\n    const passwordRegex = /^(?=.*[a-z])(?=.*[A-Z])(?=.*\\d)(?=.*[@$!%*?&])[A-Za-z\\d@$!%*?&]{8,}$/;\n    this.passwordCheck = !passwordRegex.test(this.password);\n    return passwordRegex.test(this.password);\n  }\n\n  mobileDebounceTimer: any;\n  onMobileChange() {\n    clearTimeout(this.mobileDebounceTimer);\n    this.mobileDebounceTimer = setTimeout(() => {\n      this.mobileNumberValid();\n    }, 200);\n  }\n  mobileCheck: boolean = false;\n  mobileNumberValid() {\n    const mobileRegex = /^[6-9]\\d{9}$/;\n    this.mobileCheck = !mobileRegex.test(this.mobile);\n    return mobileRegex.test(this.mobile);\n  }\n\n  get isMobile(): boolean {\n    return window.innerWidth <= 475;\n  }\n\n  get stylesLayout() {\n    return { ...this.styles?.layout } as LayOutModel;\n  }\n\n  get accentColor() {\n    const color = this.styles?.background?.accentColor ? this.styles.background?.accentColor : '#667eea';\n    document.documentElement.style.setProperty('--accent-color', color);\n    document.documentElement.style.setProperty('--accent-shadow', this.hexToRgba(color, 0.4));\n    return color;\n  }\n  private hexToRgba(hex: string, alpha: number): string {\n    const r = parseInt(hex.slice(1, 3), 16);\n    const g = parseInt(hex.slice(3, 5), 16);\n    const b = parseInt(hex.slice(5, 7), 16);\n    return `rgba(${r}, ${g}, ${b}, ${alpha})`;\n  }\n  setup3DEffects() {\n    const mainPanel = this.elementRef.nativeElement.querySelector('.main-panel');\n\n    if (mainPanel) {\n      mainPanel.addEventListener('mousemove', (e: any) => {\n        if (this.isMobile) return;\n\n        const rect = mainPanel.getBoundingClientRect();\n        const x = e.clientX - rect.left;\n        const y = e.clientY - rect.top;\n\n        const centerX = rect.width / 2;\n        const centerY = rect.height / 2;\n\n        const rotateX = (y - centerY) / 20;\n        const rotateY = (centerX - x) / 20;\n\n        (mainPanel as HTMLElement).style.transform = `perspective(1200px) rotateX(${rotateX}deg) rotateY(${rotateY}deg) translateZ(0)`;\n      });\n\n      mainPanel.addEventListener('mouseleave', () => {\n        if (!this.isMobile) {\n          (mainPanel as HTMLElement).style.transform = 'rotateX(0deg) rotateY(0deg)';\n        }\n      });\n    }\n  }\n  showPassword: boolean = false;\n\n}","<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"\n  [showTransformOptions]=\"isMobile ? 'translateY(-100%)' : ''\"></p-toast>\n\n<section [id]=\"data?.id\" class=\"total-container\" simpoHover (hovering)=\"showEditTabs($event)\">\n  <div [spacingAround]=\"stylesLayout\">\n    <div [simpoBackground]=\"styles?.background\" [id]=\"data?.id\" [simpoLayout]=\"styles?.layout\">\n      <div class=\"area w-100\">\n        <ul class=\"circles\">\n          <li></li>\n          <li></li>\n          <li></li>\n          <li></li>\n          <li></li>\n          <li></li>\n          <li></li>\n          <li></li>\n          <li></li>\n          <li></li>\n        </ul>\n      </div>\n      <div [simpoOverlay]=\"styles?.background\" [id]=\"data?.id\" class=\"main-panel d-flex gap-2\">\n        <div class=\"panel w-100\" [simpoCorner]=\"styles?.corners\" [id]=\"data?.id\" [simpoAnimation]=\"styles?.animation\">\n          <ng-container *ngTemplateOutlet=\"currentPage === 'LOGIN' ? loginTemplate : null\"></ng-container>\n          <ng-container *ngTemplateOutlet=\"currentPage === 'SIGNUP' ? signInTemplate : null\"></ng-container>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\n    <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\n  </div>\n  <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\n    <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\n  </div>\n\n</section>\n\n<ng-template #loginTemplate>\n  <div>\n    <div class=\"input-box\">\n      <label for=\"\">Email</label>\n      <input type=\"email\" [(ngModel)]=\"email\" required=\"\" placeholder=\"janedoe@gmail.com\"\n        (ngModelChange)=\"onEmailChange()\" [style.borderColor]=\"!emailCheck ? '' : 'red'\">\n      <span class=\"f-12\" *ngIf=\"emailCheck\" [style.color]=\"'red'\">Please Enter valid Mobile number*</span>\n    </div>\n    <div class=\"input-box\">\n      <div class=\"w-100\">\n        <label for=\"\">Password</label>\n        <input [type]=\"showPassword ? 'text' : 'password'\" required=\"\" [(ngModel)]=\"password\"\n          (ngModelChange)=\"onPasswordChange()\" class=\"w-90\" placeholder=\"Janedoe@1234\"\n          [style.borderColor]=\"!passwordCheck ? '' : 'red'\">\n        <span class=\"eye\" (click)=\"showPassword = !showPassword\" style=\"cursor: pointer;\">\n          <i class=\"fa\" [ngClass]=\"showPassword ? 'fa-eye-slash' : 'fa-eye'\"></i>\n        </span>\n      </div>\n      <span *ngIf=\"passwordCheck\" class=\"f-12\" [style.color]=\"'red'\">Your password must contain 1 Uppercase , 1\n        Lowercase , 1 Special\n        Character , 1 Digit and Minimum 8 Characters*</span>\n    </div>\n    <!-- <div class=\"forgot-pwd\" [style.color]=\"accentColor\">Forgot Password?</div> -->\n    <!-- <button class=\"button\" *ngIf=\"!buttonLoading\" simpoButtonDirective [id]=\"buttonId\" [buttonStyle]=\"button?.styles\"\n      [backgroundInfo]=\"styles?.background\" [simpoCorner]=\"styles?.corners\" [color]=\"styles?.background?.accentColor\"\n      (click)=\"login()\">Login</button> -->\n       <button class=\"send-btn p-2\" *ngIf=\"!buttonLoading\" [buttonData]=\"button?.content\" [buttonStyle]=\"button?.styles\"\n      simpoButtonDirective [id]=\"data?.id+(button?.id || '')\"  [sectionId]=\"data?.id\" [color]=\"data?.styles?.background?.accentColor\"\n      [backgroundInfo]=\"data?.styles?.background\" [appButtonEditor]=\"edit ?? false\" [buttonId]=\"button?.id ?? ''\" (click)=\"login()\">{{button?.content?.label}}</button>\n    <!-- <button class=\"button\" *ngIf=\"buttonLoading\" simpoButtonDirective [id]=\"buttonId\" [buttonStyle]=\"button?.styles\"\n      [backgroundInfo]=\"styles?.background\" [simpoCorner]=\"styles?.corners\"\n      [color]=\"styles?.background?.accentColor\">Loading...</button> -->\n       <button class=\"send-btn p-2\" *ngIf=\"buttonLoading\" [buttonData]=\"button?.content\" [buttonStyle]=\"button?.styles\"\n      simpoButtonDirective [id]=\"data?.id+(button?.id || '')\"  [sectionId]=\"data?.id\" [color]=\"data?.styles?.background?.accentColor\"\n      [backgroundInfo]=\"data?.styles?.background\" [appButtonEditor]=\"edit ?? false\" [buttonId]=\"button?.id ?? ''\" (click)=\"login()\">Loading...</button>\n\n\n    <div class=\"sign-up\" *ngIf=\"signUpEnabled\">Don't have an account? <span [style.color]=\"accentColor\"\n        (click)=\"currentPage = 'SIGNUP'\">Sign\n        Up</span></div>\n\n    <!-- <div class=\"text-center mt-20\">\n      <div class=\"or-divider\">\n        <span class=\"or-text\">or</span>\n      </div>\n      <div class=\"sign-up\">Login with <span [style.color]=\"accentColor\">OTP</span></div>\n    </div> -->\n  </div>\n</ng-template>\n\n<ng-template #signInTemplate>\n  <div>\n    <div class=\"input-box\">\n      <label for=\"\">Name</label>\n      <input type=\"text\" [(ngModel)]=\"userName\" placeholder=\"Jane Doe\">\n    </div>\n    <div class=\"input-box\">\n      <label for=\"\">Email</label>\n      <input type=\"email\" [(ngModel)]=\"email\" placeholder=\"janedoe@gmail.com\" (ngModelChange)=\"onEmailChange()\"\n        [style.borderColor]=\"!emailCheck ? '' : 'red'\">\n      <span class=\"f-12\" *ngIf=\"emailCheck\" [style.color]=\"'red'\">Please Enter valid email*</span>\n    </div>\n    <div class=\"input-box\">\n      <label for=\"\">Phone Number</label>\n      <input type=\"number\" [(ngModel)]=\"mobile\" (ngModelChange)=\"onMobileChange()\" placeholder=\"9876543219\"\n        [style.borderColor]=\"!mobileCheck ? '' : 'red'\" class=\"no-arrows\">\n      <span class=\"f-12\" *ngIf=\"mobileCheck\" [style.color]=\"'red'\">Please Enter valid Mobile number*</span>\n    </div>\n    <div class=\" input-box position-relative\">\n      <label for=\"\">Password</label>\n      <div class=\"w-100\">\n        <input [type]=\"showPassword ? 'text' : 'password'\" required=\"\" [(ngModel)]=\"password\" class=\"w-90\"\n          placeholder=\"Janedoe@1234\" [style.borderColor]=\"!passwordCheck ? '' : 'red'\"\n          (ngModelChange)=\"onPasswordChange()\">\n        <span class=\"eye\" (click)=\"showPassword = !showPassword\" style=\"cursor: pointer;\">\n          <i class=\"fa\" [ngClass]=\"showPassword ? 'fa-eye-slash' : 'fa-eye'\"></i>\n        </span>\n      </div>\n      <span *ngIf=\"passwordCheck\" class=\"f-12\" [style.color]=\"'red'\">Your password must contain 1 Uppercase , 1\n        Lowercase , 1 Special\n        Character , 1 Digit and Minimum 8 Characters*</span>\n      <!-- <div class=\"strength-bar-container\">\n        <div *ngFor=\"let strength of passwordStrength; let idx = index\" class=\"strength-bar\"\n          [style.backgroundColor]=\"getStrengthColor(idx)\"></div>\n      </div> -->\n    </div>\n    <button class=\"button\" *ngIf=\"!buttonLoading\" simpoButtonDirective [id]=\"buttonId\" [buttonStyle]=\"button?.styles\"\n      [backgroundInfo]=\"styles?.background\" [simpoCorner]=\"styles?.corners\" [color]=\"styles?.background?.accentColor\"\n      (click)=\"createAccount()\" [disabled]=\"!isEmailValid || !isPasswordValid || !userName\">Create Account</button>\n    <button class=\"button\" simpoButtonDirective [id]=\"buttonId\" [buttonStyle]=\"button?.styles\"\n      [backgroundInfo]=\"styles?.background\" [simpoCorner]=\"styles?.corners\" [color]=\"styles?.background?.accentColor\"\n      *ngIf=\"buttonLoading\">Loading...</button>\n\n\n    <div class=\"sign-up\">Already have an account? <span [style.color]=\"accentColor\"\n        (click)=\"currentPage = 'LOGIN'\">Login</span></div>\n  </div>\n</ng-template>"]}
426
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authentication-required.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/authentication-required/authentication-required.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/authentication-required/authentication-required.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, ElementRef, Input, Optional } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { RestService } from '../../../services/rest.service';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { MessageService } from 'primeng/api';\nimport { ToastModule } from 'primeng/toast';\nimport { DeviceInfo } from '../../styles/user.modal';\nimport { StorageServiceService } from '../../../services/storage.service';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatBottomSheetRef } from '@angular/material/bottom-sheet';\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { AuthenticationModel, AuthenticationStylesModel } from './authentication-required.model';\nimport { SimpoComponentModule } from '../../../components/index';\nimport { AnimationDirective } from '../../../directive/animation-directive';\nimport { BackgroundDirective } from '../../../directive/background-directive';\nimport { ContentFitDirective } from '../../../directive/content-fit-directive';\nimport { ButtonDirectiveDirective } from '../../../directive/button-directive.directive';\nimport { CornerDirective } from '../../../directive/corner-directive';\nimport { HoverDirective } from '../../../directive/hover-element-directive';\nimport { OverlayDirective } from '../../../directive/overlay-directive';\nimport { SpacingAroundDirective } from '../../../directive/spacing-around.directive';\nimport BaseSection from '../../../sections/BaseSection';\nimport { ButtonModel, LayOutModel } from '../../../styles/style.model';\nimport { ButtonEditorDirective } from '../../../directive/button-editor.directive';\n\n@Component({\n  selector: 'simpo-authentication-required',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ToastModule,\n    MatIconModule,\n    MatProgressSpinnerModule,\n    SimpoComponentModule,\n\n    AnimationDirective,\n    BackgroundDirective,\n    ButtonDirectiveDirective,\n    ContentFitDirective,\n    CornerDirective,\n    HoverDirective,\n    OverlayDirective,\n    SpacingAroundDirective,\n    ButtonEditorDirective\n  ],\n  providers: [MessageService],\n  templateUrl: './authentication-required.component.html',\n  styleUrl: './authentication-required.component.css'\n})\nexport class AuthenticationRequiredComponent extends BaseSection {\n  // private emailTimer: NodeJS.Timeout | null = null;\n  @Input() data?: AuthenticationModel;\n  @Input() index?: number;\n  @Input() edit?: boolean;\n  @Input() delete?: boolean;\n  styles?: AuthenticationStylesModel;\n  button?: ButtonModel\n  buttonId: string = '';\n\n  currentPage: 'LOGIN' | 'SIGNUP' = 'LOGIN';\n  private mobileTimer: any;\n  public email: string = \"\";\n  public mobile: string = \"\";\n  public otp: string = \"\";\n  public password: string = \"\";\n  public confPassword: string = \"\";\n  public userName: string = \"\";\n  public buttonLoading: boolean = false;\n  public businessId: string | null = localStorage.getItem(\"bId\");\n  public isOTPVerified: boolean = false;\n  public passwordHidden: boolean = true;\n  public passwordStrengthCount: number = 0;\n  public passwordStrength = [\n    { type: \"minimum 8 character\", active: false },\n    { type: \"atleast one UPPERCASE\", active: false },\n    { type: \"atleast one lowercase\", active: false },\n    { type: \"atleast one number\", active: false },\n  ]\n\n  constructor(\n    private readonly restService: RestService,\n    private readonly router: Router,\n    private readonly messageService: MessageService,\n    private readonly storageService: StorageServiceService,\n    private readonly matDialog: MatDialog,\n    private readonly activatedRoute: ActivatedRoute,\n    private elementRef: ElementRef,\n\n    @Optional() private readonly dialogRef: MatDialogRef<AuthenticationRequiredComponent>,\n    @Optional() private readonly bottomsheetRef: MatBottomSheetRef<AuthenticationRequiredComponent>,\n  ) {\n    super();\n  }\n\n  signUpEnabled: any = true;\n\n  proceedToCheckout: boolean = false;\n  ngOnInit() {\n    this.activatedRoute.queryParams.subscribe((param: any) => {\n      if (param && param['cart'])\n        this.proceedToCheckout = true;\n    })\n    this.styles = this.data?.styles;\n    this.button = this.data?.action?.buttons[0];\n    this.buttonId = (this.data ? this.data.id : '') + (this.button ? this.button.id : '');\n\n    let enabled = localStorage.getItem('signUpEnabled');\n    if (enabled != null)\n      this.signUpEnabled = enabled === 'true';\n\n  }\n  ngAfterViewInit() {\n    this.setup3DEffects();\n  }\n\n  loginType: \"PASSWORD\" | \"OTP\" = \"PASSWORD\";\n\n  close() {\n    this.dialogRef.close();\n  }\n  login() {\n    if (this.loginType == \"OTP\") {\n      this.verifyOTP();\n    } else {\n      this.verifyPassword();\n    }\n  }\n\n  verifyPassword() {\n\n    if (!this.isEmailValid) {\n      this.messageService.add({ severity: 'error', summary: 'Invalid Email', detail: 'Please enter a valid email address' });\n      return;\n    }\n\n    if (!this.isPasswordValid) {\n      this.messageService.add({ severity: 'error', summary: 'Invalid Password', detail: 'Please enter a valid password' });\n      return;\n    }\n\n    const payload = {\n      businessId: this.businessId,\n      email: this.email,\n      password: this.password\n    }\n\n    this.buttonLoading = true;\n    this.restService.signinPassword(payload).subscribe((response: any) => {\n      const userDetails = this.storageService.setUser(response.data);\n      this.storageService.updateAllData();\n      this.buttonLoading = false;\n      // this.dialogRef.close('success');\n      this.messageService.add({ severity: 'success', summary: 'Logged In', detail: 'Logged in Successfully' });\n      if (this.proceedToCheckout)\n        this.router.navigate(['/cart'], { queryParams: { checkout: true } });\n      else\n        this.router.navigate(['']);\n    },\n      (error) => {\n        this.buttonLoading = false;\n        this.messageService.add({ severity: 'error', summary: 'Login request', detail: error?.error?.message });\n      })\n  }\n  verifyOTP() {\n\n    const deviceInfo: DeviceInfo | null = {\n      firebaseToken: localStorage.getItem(\"fbToken\") ?? \"\"\n    };\n\n    this.buttonLoading = true;\n    this.restService.verifyOTP(this.mobile ?? \"\", this.otp, deviceInfo).subscribe((response: any) => {\n      const userDetails = this.storageService.setUser(response.data);\n      this.storageService.updateAllData();\n      this.dialogRef.close('success');\n    },\n      (error) => {\n        this.buttonLoading = false;\n        this.messageService.add({ severity: 'error', summary: \"Login request\", detail: error?.error?.message });\n      })\n  }\n  sendSignupOTP() {\n    this.buttonLoading = true;\n    this.isOTPVerified = false;\n    if (this.mobileTimer)\n      clearTimeout(this.mobileTimer);\n    this.mobileTimer = setTimeout(() => {\n      if (this.mobile.length != 10)\n        return;\n      const payload: any = {\n        businessId: this.businessId,\n        mobile: this.mobile,\n        email: this.email,\n        password: this.password,\n        countryCode: '91'\n      }\n      this.restService.sendSignupOTP(payload).subscribe((res: any) => {\n        this.isOTPVerified = true;\n        this.buttonLoading = false;\n        this.messageService.add({ severity: 'success', summary: 'OTP', detail: 'OTP Sent' });\n      }, (err) => {\n        this.messageService.add({ severity: 'error', summary: 'OTP Request', detail: err.error.message });\n        this.buttonLoading = false;\n      })\n    }, 800);\n  }\n  createAccount() {\n\n    if (!this.isEmailValid) {\n      this.messageService.add({ severity: 'error', summary: 'Invalid Email', detail: 'Please enter a valid email address' });\n      return;\n    }\n    if (!this.isPasswordValid) {\n      this.messageService.add({ severity: 'error', summary: 'Invalid Password', detail: 'Please enter a valid password' });\n      return;\n    }\n    if (!this.mobileNumberValid) {\n      this.messageService.add({ severity: 'error', summary: 'Invalid Mobile Number', detail: 'Please enter a valid mobile number' });\n      return;\n    }\n\n    const deviceInfo: DeviceInfo | null = {\n      firebaseToken: localStorage.getItem(\"fbToken\") ?? \"\"\n    };\n\n    this.buttonLoading = true;\n    let verifySignData = {\n      name: this.userName,\n      businessId: this.businessId,\n      businessName: localStorage.getItem('bName'),\n      mobile: this.mobile,\n      email: this.email,\n      password: this.password,\n      countryCode: \"+91\",\n      enteredOtp: this.otp\n    }\n    this.restService.verifySignupOTP(verifySignData).subscribe((response: any) => {\n      const userDetails = this.storageService.setUser(response.data);\n      this.storageService.updateAllData();\n      // this.dialogRef.close('success');\n      this.buttonLoading = false;\n      this.messageService.add({ severity: 'success', summary: 'Sign Up', detail: 'Your account successfully created' });\n      if (this.proceedToCheckout)\n        this.router.navigate(['/cart'], { queryParams: { checkout: true } });\n      else\n        this.router.navigate(['']);      // Swal.fire({\n      //   icon: \"success\",\n      //   title: \"Hurray\",\n      //   text: \"Your account successfully created\",\n      //   showCancelButton: !(userDetails.contact?.name?.length > 0),\n      //   confirmButtonText: \"I loved it\",\n      //   cancelButtonText: \"Fill other basic details\",\n      //   cancelButtonColor: \"#928c8c\",\n      // }).then((result) => {\n\n      //   if (result.isDismissed) {\n      //     this.matDialog.open(UserBasicInfoComponent, {\n      //       height: '50vh',\n      //       width: window.innerWidth > 475 ? '40vw' : '95vw',\n      //       maxWidth: window.innerWidth > 475 ? '100vw' : '80vw',\n      //       data: {}\n      //     });\n      //   }\n      // })\n    }, (error) => {\n      this.buttonLoading = false;\n      if (error.status === 500) {\n        this.messageService.add({ severity: 'error', summary: 'Signup error', detail: error?.error?.message })\n      }\n      else {\n        this.messageService.add({ severity: 'error', summary: 'Signup error', detail: error?.error?.message });\n      }\n    })\n  }\n  verifySignupOTP() {\n\n    if (this.otp.length != 6)\n      return;\n\n    const deviceInfo: DeviceInfo | null = {\n      firebaseToken: localStorage.getItem(\"fbToken\") ?? \"\"\n    };\n\n    this.buttonLoading = true;\n    let verifySignData = {\n      businessId: this.businessId,\n      mobile: this.mobile,\n      email: this.email,\n      password: this.password,\n      countryCode: \"91\",\n      enteredOtp: this.otp\n    }\n    this.restService.verifySignupOTP(verifySignData).subscribe((response: any) => {\n\n      this.messageService.add({ severity: 'success', summary: 'OTP', detail: 'OTP Verified' });\n    }, (error) => {\n      this.buttonLoading = false;\n      if (error.status === 500) {\n        this.messageService.add({ severity: 'error', summary: 'User already exists' })\n      }\n      else {\n        this.messageService.add({ severity: 'error', summary: 'Invalid OTP', detail: 'Please enter valid otp' });\n      }\n    })\n  }\n  enterMobile() {\n\n    if (this.mobileTimer)\n      clearTimeout(this.mobileTimer);\n    this.mobileTimer = setTimeout(() => {\n      if (this.mobile.length != 10)\n        return;\n      this.generateOTP();\n    }, 500);\n  }\n\n  generateOTP() {\n    this.buttonLoading = true;\n    this.restService.generateOTP(this.mobile ?? \"\", \"91\").subscribe(\n      (response) => {\n        this.buttonLoading = false;\n        this.messageService.add({\n          severity: 'success',\n          summary: 'OTP Sent',\n          detail: 'OTP sent to mobile. Valid for 3 mins',\n          life: 10000\n        });\n      },\n      (error) => {\n        this.buttonLoading = false;\n        const errorMessage = error?.error?.message;\n\n        this.messageService.add({\n          severity: 'error',\n          summary: 'OTP Request',\n          detail: errorMessage,\n          life: 10000\n        });\n      }\n    );\n  }\n\n  validateNumber(event: KeyboardEvent): void {\n    const charCode = event.charCode;\n    if (charCode < 48 || charCode > 57) {\n      event.preventDefault();\n    }\n  }\n\n  validateOTP(event: KeyboardEvent): void {\n    if (this.otp.length == 6) {\n      event.preventDefault();\n    }\n  }\n  checkStrength() {\n    this.passwordStrengthCount = 0;\n    this.passwordStrengthCount += (/[A-Z]/.test(this.password)) ? 1 : 0;\n    this.passwordStrengthCount += (/[a-z]/.test(this.password)) ? 1 : 0;\n    this.passwordStrengthCount += (/\\d/.test(this.password)) ? 1 : 0;\n    this.passwordStrengthCount += (this.password.length > 8 ? 1 : 0);\n  }\n  getStrengthColor(index: number) {\n    switch (this.passwordStrengthCount) {\n      case 1:\n        return (index < this.passwordStrengthCount ? \"tomato\" : \"#d3d3d3ba\");\n      case 2:\n        return (index < this.passwordStrengthCount ? \"orange\" : \"#d3d3d3ba\");\n      case 3:\n        return (index < this.passwordStrengthCount ? \"yellow\" : \"#d3d3d3ba\");\n      case 4:\n        return (index < this.passwordStrengthCount ? \"lightgreen\" : \"#d3d3d3ba\");\n      default:\n        return \"#d3d3d3ba\";\n    }\n  }\n  emailDebounceTimer: any;\n  onEmailChange() {\n    clearTimeout(this.emailDebounceTimer);\n    this.emailDebounceTimer = setTimeout(() => {\n      this.isEmailValid();\n    }, 200);\n  }\n  emailCheck: boolean = false;\n  isEmailValid() {\n    const emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$/;\n    this.emailCheck = !emailRegex.test(this.email);\n    return emailRegex.test(this.email);\n  }\n  passwordDebounceTimer: any;\n  onPasswordChange() {\n    clearTimeout(this.passwordDebounceTimer);\n    this.passwordDebounceTimer = setTimeout(() => {\n      this.isPasswordValid();\n    }, 200);\n  }\n  passwordCheck: boolean = false;\n  isPasswordValid() {\n    const passwordRegex = /^(?=.*[a-z])(?=.*[A-Z])(?=.*\\d)(?=.*[@$!%*?&])[A-Za-z\\d@$!%*?&]{8,}$/;\n    this.passwordCheck = !passwordRegex.test(this.password);\n    return passwordRegex.test(this.password);\n  }\n\n  mobileDebounceTimer: any;\n  onMobileChange() {\n    clearTimeout(this.mobileDebounceTimer);\n    this.mobileDebounceTimer = setTimeout(() => {\n      this.mobileNumberValid();\n    }, 200);\n  }\n  mobileCheck: boolean = false;\n  mobileNumberValid() {\n    const mobileRegex = /^[6-9]\\d{9}$/;\n    this.mobileCheck = !mobileRegex.test(this.mobile);\n    return mobileRegex.test(this.mobile);\n  }\n\n  get isMobile(): boolean {\n    return window.innerWidth <= 475;\n  }\n\n  get stylesLayout() {\n    return { ...this.styles?.layout } as LayOutModel;\n  }\n\n  get accentColor() {\n    const color = this.styles?.background?.accentColor ? this.styles.background?.accentColor : '#667eea';\n    document.documentElement.style.setProperty('--accent-color', color);\n    document.documentElement.style.setProperty('--accent-shadow', this.hexToRgba(color, 0.4));\n    return color;\n  }\n  private hexToRgba(hex: string, alpha: number): string {\n    const r = parseInt(hex.slice(1, 3), 16);\n    const g = parseInt(hex.slice(3, 5), 16);\n    const b = parseInt(hex.slice(5, 7), 16);\n    return `rgba(${r}, ${g}, ${b}, ${alpha})`;\n  }\n  setup3DEffects() {\n    const mainPanel = this.elementRef.nativeElement.querySelector('.main-panel');\n\n    if (mainPanel) {\n      mainPanel.addEventListener('mousemove', (e: any) => {\n        if (this.isMobile) return;\n\n        const rect = mainPanel.getBoundingClientRect();\n        const x = e.clientX - rect.left;\n        const y = e.clientY - rect.top;\n\n        const centerX = rect.width / 2;\n        const centerY = rect.height / 2;\n\n        const rotateX = (y - centerY) / 20;\n        const rotateY = (centerX - x) / 20;\n\n        (mainPanel as HTMLElement).style.transform = `perspective(1200px) rotateX(${rotateX}deg) rotateY(${rotateY}deg) translateZ(0)`;\n      });\n\n      mainPanel.addEventListener('mouseleave', () => {\n        if (!this.isMobile) {\n          (mainPanel as HTMLElement).style.transform = 'rotateX(0deg) rotateY(0deg)';\n        }\n      });\n    }\n  }\n  showPassword: boolean = false;\n\n}","<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"\n  [showTransformOptions]=\"isMobile ? 'translateY(-100%)' : ''\"></p-toast>\n\n<section [id]=\"data?.id\" class=\"total-container\" simpoHover (hovering)=\"showEditTabs($event)\">\n  <div [spacingAround]=\"stylesLayout\">\n    <div [simpoBackground]=\"styles?.background\" [id]=\"data?.id\" [simpoLayout]=\"styles?.layout\">\n      <div class=\"area w-100\">\n        <ul class=\"circles\">\n          <li></li>\n          <li></li>\n          <li></li>\n          <li></li>\n          <li></li>\n          <li></li>\n          <li></li>\n          <li></li>\n          <li></li>\n          <li></li>\n        </ul>\n      </div>\n      <div [simpoOverlay]=\"styles?.background\" [id]=\"data?.id\" class=\"main-panel d-flex gap-2\">\n        <div class=\"panel w-100\" [simpoCorner]=\"styles?.corners\" [id]=\"data?.id\" [simpoAnimation]=\"styles?.animation\">\n          <ng-container *ngTemplateOutlet=\"currentPage === 'LOGIN' ? loginTemplate : null\"></ng-container>\n          <ng-container *ngTemplateOutlet=\"currentPage === 'SIGNUP' ? signInTemplate : null\"></ng-container>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\n    <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\n  </div>\n  <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\n    <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\n  </div>\n\n</section>\n\n<ng-template #loginTemplate>\n  <div>\n    <div class=\"input-box\">\n      <label for=\"\">Email</label>\n      <input type=\"email\" [(ngModel)]=\"email\" required=\"\" placeholder=\"janedoe@gmail.com\"\n        (ngModelChange)=\"onEmailChange()\" [style.borderColor]=\"!emailCheck ? '' : 'red'\">\n      <span class=\"f-12\" *ngIf=\"emailCheck\" [style.color]=\"'red'\">Please Enter valid Mobile number*</span>\n    </div>\n    <div class=\"input-box\">\n      <div class=\"w-100\">\n        <label for=\"\">Password</label>\n        <input [type]=\"showPassword ? 'text' : 'password'\" required=\"\" [(ngModel)]=\"password\"\n          (ngModelChange)=\"onPasswordChange()\" class=\"w-90\" placeholder=\"Janedoe@1234\"\n          [style.borderColor]=\"!passwordCheck ? '' : 'red'\">\n        <span class=\"eye\" (click)=\"showPassword = !showPassword\" style=\"cursor: pointer;\">\n          <i class=\"fa\" [ngClass]=\"showPassword ? 'fa-eye-slash' : 'fa-eye'\"></i>\n        </span>\n      </div>\n      <span *ngIf=\"passwordCheck\" class=\"f-12\" [style.color]=\"'red'\">Your password must contain 1 Uppercase , 1\n        Lowercase , 1 Special\n        Character , 1 Digit and Minimum 8 Characters*</span>\n    </div>\n    <!-- <div class=\"forgot-pwd\" [style.color]=\"accentColor\">Forgot Password?</div> -->\n    <!-- <button class=\"button\" *ngIf=\"!buttonLoading\" simpoButtonDirective [id]=\"buttonId\" [buttonStyle]=\"button?.styles\"\n      [backgroundInfo]=\"styles?.background\" [simpoCorner]=\"styles?.corners\" [color]=\"styles?.background?.accentColor\"\n      (click)=\"login()\">Login</button> -->\n       <button class=\"send-btn p-2\" *ngIf=\"!buttonLoading\" [buttonData]=\"button?.content\" [buttonStyle]=\"button?.styles\"\n      simpoButtonDirective [id]=\"data?.id+(button?.id || '')\"  [sectionId]=\"data?.id\" [color]=\"data?.styles?.background?.accentColor\"\n      [backgroundInfo]=\"data?.styles?.background\" [appButtonEditor]=\"edit ?? false\" [buttonId]=\"button?.id ?? ''\" (click)=\"login()\">{{button?.content?.label}}</button>\n    <!-- <button class=\"button\" *ngIf=\"buttonLoading\" simpoButtonDirective [id]=\"buttonId\" [buttonStyle]=\"button?.styles\"\n      [backgroundInfo]=\"styles?.background\" [simpoCorner]=\"styles?.corners\"\n      [color]=\"styles?.background?.accentColor\">Loading...</button> -->\n       <button class=\"send-btn p-2\" *ngIf=\"buttonLoading\" [buttonData]=\"button?.content\" [buttonStyle]=\"button?.styles\"\n      simpoButtonDirective [id]=\"data?.id+(button?.id || '')\"  [sectionId]=\"data?.id\" [color]=\"data?.styles?.background?.accentColor\"\n      [backgroundInfo]=\"data?.styles?.background\" [appButtonEditor]=\"edit ?? false\" [buttonId]=\"button?.id ?? ''\" (click)=\"login()\">Loading...</button>\n\n\n    <div class=\"sign-up\" *ngIf=\"signUpEnabled\">Don't have an account? <span [style.color]=\"accentColor\"\n        (click)=\"currentPage = 'SIGNUP'\">Sign\n        Up</span></div>\n\n    <!-- <div class=\"text-center mt-20\">\n      <div class=\"or-divider\">\n        <span class=\"or-text\">or</span>\n      </div>\n      <div class=\"sign-up\">Login with <span [style.color]=\"accentColor\">OTP</span></div>\n    </div> -->\n  </div>\n</ng-template>\n\n<ng-template #signInTemplate>\n  <div>\n    <div class=\"input-box\">\n      <label for=\"\">Name</label>\n      <input type=\"text\" [(ngModel)]=\"userName\" placeholder=\"Jane Doe\">\n    </div>\n    <div class=\"input-box\">\n      <label for=\"\">Email</label>\n      <input type=\"email\" [(ngModel)]=\"email\" placeholder=\"janedoe@gmail.com\" (ngModelChange)=\"onEmailChange()\"\n        [style.borderColor]=\"!emailCheck ? '' : 'red'\">\n      <span class=\"f-12\" *ngIf=\"emailCheck\" [style.color]=\"'red'\">Please Enter valid email*</span>\n    </div>\n    <div class=\"input-box\">\n      <label for=\"\">Phone Number</label>\n      <input type=\"number\" [(ngModel)]=\"mobile\" (ngModelChange)=\"onMobileChange()\" placeholder=\"9876543219\"\n        [style.borderColor]=\"!mobileCheck ? '' : 'red'\" class=\"no-arrows\">\n      <span class=\"f-12\" *ngIf=\"mobileCheck\" [style.color]=\"'red'\">Please Enter valid Mobile number*</span>\n    </div>\n    <div class=\" input-box position-relative\">\n      <label for=\"\">Password</label>\n      <div class=\"w-100\">\n        <input [type]=\"showPassword ? 'text' : 'password'\" required=\"\" [(ngModel)]=\"password\" class=\"w-90\"\n          placeholder=\"Janedoe@1234\" [style.borderColor]=\"!passwordCheck ? '' : 'red'\"\n          (ngModelChange)=\"onPasswordChange()\">\n        <span class=\"eye\" (click)=\"showPassword = !showPassword\" style=\"cursor: pointer;\">\n          <i class=\"fa\" [ngClass]=\"showPassword ? 'fa-eye-slash' : 'fa-eye'\"></i>\n        </span>\n      </div>\n      <span *ngIf=\"passwordCheck\" class=\"f-12\" [style.color]=\"'red'\">Your password must contain 1 Uppercase , 1\n        Lowercase , 1 Special\n        Character , 1 Digit and Minimum 8 Characters*</span>\n      <!-- <div class=\"strength-bar-container\">\n        <div *ngFor=\"let strength of passwordStrength; let idx = index\" class=\"strength-bar\"\n          [style.backgroundColor]=\"getStrengthColor(idx)\"></div>\n      </div> -->\n    </div>\n    <button class=\"button\" *ngIf=\"!buttonLoading\" simpoButtonDirective [id]=\"buttonId\" [buttonStyle]=\"button?.styles\"\n      [backgroundInfo]=\"styles?.background\" [simpoCorner]=\"styles?.corners\" [color]=\"styles?.background?.accentColor\"\n      (click)=\"createAccount()\" [disabled]=\"!isEmailValid || !isPasswordValid || !userName\">Create Account</button>\n    <button class=\"button\" simpoButtonDirective [id]=\"buttonId\" [buttonStyle]=\"button?.styles\"\n      [backgroundInfo]=\"styles?.background\" [simpoCorner]=\"styles?.corners\" [color]=\"styles?.background?.accentColor\"\n      *ngIf=\"buttonLoading\">Loading...</button>\n\n\n    <div class=\"sign-up\">Already have an account? <span [style.color]=\"accentColor\"\n        (click)=\"currentPage = 'LOGIN'\">Login</span></div>\n  </div>\n</ng-template>"]}
@@ -101,7 +101,6 @@ export class OrderDetailsComponent {
101
101
  window.open(this.orderDetailData?.orderTrackingLink, '_blank');
102
102
  }
103
103
  submitReview(item) {
104
- console.log(item);
105
104
  let payload = {
106
105
  userId: this.storageService.getUser()?.userId ?? "",
107
106
  businessId: localStorage.getItem('businessId') ?? "",
@@ -152,4 +151,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
152
151
  }], goBackEmitter: [{
153
152
  type: Output
154
153
  }] } });
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';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { MatIcon } from '@angular/material/icon';\nimport { SimpoComponentModule } from '../../../components/index';\nimport { TimelineModule } from 'primeng/timeline';\nimport { EventsService } from '../../../services/events.service';\nimport { ProfileStylesModal } from '../user-profile/user-profile.modal';\nimport { BUSINESS_CONSTANTS } from '../../../constants/business.constant';\nimport { PanelModule } from 'primeng/panel';\nimport { RatingModule } from 'primeng/rating';\nimport { FormsModule } from '@angular/forms';\nimport { StorageServiceService } from '../../../services/storage.service';\nimport { RestService } from '../../../services/rest.service';\nimport { MessageService } from 'primeng/api';\n\n@Component({\n  selector: 'simpo-order-details',\n  standalone: true,\n  imports: [\n    CommonModule,\n    SimpoComponentModule,\n    TimelineModule,\n    MatIcon,\n    PanelModule,\n    RatingModule,\n    FormsModule\n  ],\n  templateUrl: './order-details.component.html',\n  styleUrl: './order-details.component.css'\n})\nexport class OrderDetailsComponent implements OnInit {\n  @Input() responseData?: any;\n  @Input() data?: any;\n  @Input() index?: number;\n  @Input() edit?: boolean;\n  @Input() delete?: boolean;\n  @Input() customClass?: string;\n  @Input(\"orderDetailData\") orderDetailData: any;\n  @Output() goBackEmitter: EventEmitter<void> = new EventEmitter<void>();\n  isLoading: boolean = false;\n  styles?: ProfileStylesModal;\n\n  constructor(\n    private readonly _eventService: EventsService,\n    private storageService: StorageServiceService,\n    private restService: RestService,\n    private messageService: MessageService\n  ) { }\n\n  public orderTimiline: any = [];\n\n  ngOnInit(): void {\n    this.styles = this.data?.styles;\n    this.orderTimiline = this.orderDetailData?.brandOrderDetails?.[0]?.timeLineList?.map((timeline: any) => {\n      return {\n        icon: this.getIcon(timeline.orderStatus),\n        name: timeline.title,\n        desc: timeline.body\n      }\n    })\n\n    this._eventService.showLoadingScreen.subscribe((response) => {\n      this.isLoading = response;\n    })\n  }\n\n  private getIcon(type: \"ORDER_PLACED\" | \"ORDER_CONFIRMED\" | \"DISPATCHED\" | \"IN_TRANSIT\" | \"OUT_FOR_DELIVERY\" | \"DELIVERED\" | \"CANCELLED\") {\n    switch (type) {\n      case \"ORDER_PLACED\":\n      case \"ORDER_CONFIRMED\":\n        return \"widgets\";\n      case \"DISPATCHED\":\n      case \"IN_TRANSIT\":\n      case \"OUT_FOR_DELIVERY\":\n        return \"local_shipping\";\n      case \"DELIVERED\":\n        return \"inbox\";\n      case \"CANCELLED\":\n        return \"cancel\";\n    }\n  }\n  goBack() {\n    this.goBackEmitter.emit();\n  }\n\n  get getCardBGColor() {\n    return this.getComplementColor(this.styles?.background.color ?? \"#00000\");\n  }\n  get isMobile() {\n    return window.innerWidth <= 475;\n  }\n  getSupportingColor(bgColor: string): string {\n    return this.getComplementColor(bgColor);\n  }\n  private getComplementColor(hexColor: string) {\n\n    if (hexColor.length <= 4)\n      hexColor = this.convertHEX(hexColor);\n\n    hexColor = hexColor.replace(/^#/, '');\n\n    let r = parseInt(hexColor.substring(0, 2), 16);\n    let g = parseInt(hexColor.substring(2, 4), 16);\n    let b = parseInt(hexColor.substring(4, 6), 16);\n\n    r = 255 - r;\n    g = 255 - g;\n    b = 255 - b;\n\n    let compHex = `#${r.toString(16).padStart(2, '0')}${g.toString(16).padStart(2, '0')}${b.toString(16).padStart(2, '0')}`;\n\n    return compHex.toUpperCase();\n  }\n  private convertHEX(hexColor: string) {\n    hexColor = hexColor.replace(/^#/, '');\n    let color = \"#\";\n    for (let i = 0; i < 3; i++)\n      color += (hexColor[i] + hexColor[i + 1]);\n    return color;\n  }\n\n  get currency(): string {\n    return BUSINESS_CONSTANTS.CURRENCY;\n  }\n  get canCancelOrder(): boolean {\n    return this.orderTimiline?.length == 1;\n  }\n  get orderAddress(): string {\n    return this.orderDetailData?.addressDetails?.addressLine1 + ', ' + this.orderDetailData?.addressDetails?.addressLine2 + ', ' + this.orderDetailData?.addressDetails?.localityName + ', ' + this.orderDetailData?.addressDetails?.cityName + ', ' + this.orderDetailData?.addressDetails?.stateName;\n  }\n\n  trackOrder() {\n    window.open(this.orderDetailData?.orderTrackingLink, '_blank');\n  }\n  productReview: number = 0\n  submitReview(item: any) {\n    console.log(item);\n    let payload = {\n      userId: this.storageService.getUser()?.userId ?? \"\",\n      businessId: localStorage.getItem('businessId') ?? \"\",\n      productId: item.itemId,\n      rating: item.rating,\n      review: item.review,\n      orderId : this.orderDetailData?.userOrderId ?? \"\",\n      userName : this.storageService.getUser()?.contact.name\n    }\n    this.restService.addReviewToProduct(payload).subscribe({\n      next: (response) => {\n        this.messageService.add({ severity: 'success', summary: 'Review', detail: 'Review Added Successfully' });\n      },\n      error: (error) => {\n        this.messageService.add({ severity: 'error', summary: 'Review', detail: 'Adding Review Caused error' });\n      }\n    })\n  }\n}\n","<ng-container *ngIf=\"!isLoading\">\n    <section class=\"d-flex justify-content-between main-section\" [style.width.vw]=\"isMobile ? '100' : '65'\"\n        style=\"margin: auto;\" [attr.style]=\"customClass\">\n        <div class=\"left\" [style.width.%]=\"isMobile ? '90' : '70'\">\n            <h1 class=\"fs-3 fw-normal mb-3 d-flex align-items-center onlyDesktop position-relative\"\n                style=\"left: -35px;\">\n                <mat-icon style=\"cursor: pointer;\" (click)=\"goBack()\">keyboard_arrow_left</mat-icon>\n                <span>Order Details</span>\n            </h1>\n            <div class=\"d-flex justify-content-between align-items-end orderNum\">\n                <div class=\"d-flex flex-column\">\n                    <span class=\"fs-5\">Order {{ orderDetailData?.orderNum }}</span>\n                    <span class=\"fs-6\">{{ orderDetailData?.createdTimeStamp | date: 'medium' }}, {{\n                        orderDetailData?.brandOrderDetails?.[0]?.orderedItems.length }} items | <span\n                            [innerHTML]=\"currency\"></span>\n                        {{orderDetailData?.brandOrderDetails?.[0]?.billDetails?.totalGrossValue}}</span>\n                </div>\n                <span class=\"fw-bold fs-5\">{{orderDetailData?.brandOrderDetails?.[0]?.businessName | titlecase}}</span>\n            </div>\n            <ng-container *ngIf=\"!isMobile\">\n                <ng-container *ngTemplateOutlet=\"timelineContainer\"></ng-container>\n            </ng-container>\n            <div>\n                <div *ngFor=\"let item of orderDetailData?.brandOrderDetails[0]?.orderedItems\" class=\"d-flex mb-2\"\n                    style=\"gap: 10px; width: 100%;\">\n                    <img loading=\"lazy\" onerror=\"this.src='https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\"\n                        [src]=\"item.imgUrl\" alt=\"\" style=\"height: 85px;width: 85px; border-radius: 5px;\">\n                    <div class=\"d-flex flex-column justify-content-center\" style=\"gap: 6px; width: 89%;\">\n                        <span class=\"fs-6\">{{item.itemName}}</span>\n                        <!-- <span class=\"fs-6\">Size: XS</span> -->\n                        <div class=\"d-flex justify-content-between fs-6\">\n                            <span>{{item.quantity}} X <span [innerHTML]=\"currency\"></span> <span\n                                    class=\"fw-bold\">{{(item.discountedPrice) | number: '1.0-2'}}</span></span>\n                            <span> <span [innerHTML]=\"currency\"></span> <span class=\"fw-bold\">{{(item.discountedPrice *\n                                    item.quantity) | number: '1.0-2'}}</span></span>\n                        </div>\n                        <div class=\"review-rating d-flex justify-content-between flex-column\">\n                            <div class=\"w-75\">\n                                <p-rating [(ngModel)]=\"item.rating\" [cancel]=\"false\" [readonly]=\"false\" />\n                                <div class=\"message w-100\">\n                                    <div class=\"f-13\">Add a Detailed Review</div>\n                                    <textarea class=\"w-100 br-6 f-13\" [(ngModel)]=\"item.review\"></textarea>\n                                </div>\n                            </div>\n                            <div class=\"d-flex align-items-end\">\n                                <div (click)=\"submitReview(item)\" class=\"d-flex align-items-end f-16 fw-800\">Submit</div>\n                            </div>\n                        </div>\n                    </div>\n                </div>\n            </div>\n            <ng-container *ngIf=\"isMobile\">\n                <ng-container *ngTemplateOutlet=\"timelineContainer\"></ng-container>\n            </ng-container>\n            <div class=\"fs-6 mt-25\">\n                <div class=\"d-flex justify-content-between my-2\">\n                    <span class=\"fw-normal\">Item Total</span>\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\n                        {{orderDetailData?.billDetails?.totalNetValue | number:'1.0-2'}}</span>\n                </div>\n                <div class=\"d-flex justify-content-between my-2\" *ngIf=\"orderDetailData?.billDetails?.discountAmount\">\n                    <span class=\"fw-normal\">Discount</span>\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\n                        {{orderDetailData?.billDetails?.discountAmount | number:'1.0-2'}}</span>\n                </div>\n                <div class=\"d-flex justify-content-between my-2\">\n                    <span class=\"fw-normal\">Total Tax</span>\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\n                        {{orderDetailData?.billDetails?.discountAmount ?\n                        orderDetailData?.billDetails?.totalTaxAfterDiscount :\n                        orderDetailData?.billDetails?.totalTax | number:'1.0-2'}}</span>\n                </div>\n\n                <div class=\"d-flex justify-content-between my-2\">\n                    <span>Delivery</span>\n                    <span>FREE</span>\n                </div>\n\n                <div class=\"d-flex justify-content-between my-2\">\n                    <span class=\"fw-normal\">Grand Total</span>\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\n                        {{orderDetailData?.billDetails?.discountAmount ? (orderDetailData?.billDetails?.totalNetValue -\n                        orderDetailData?.billDetails?.discountAmount +\n                        orderDetailData?.billDetails?.totalTaxAfterDiscount) :\n                        orderDetailData?.billDetails?.totalGrossValue | number:'1.0-2'}}</span>\n                </div>\n            </div>\n        </div>\n        <div class=\"\" style=\"width: 28%;\" [style.width.%]=\"isMobile ? '90' : '28'\">\n            <div class=\"right\">\n                <h1 class=\"mb-3 fs-5\">User Details</h1>\n                <div class=\"my-2 fs-6\">\n                    <span style=\"margin-right: 10px;\">Name:</span>\n                    <span class=\"fw-bold pl-2\">{{orderDetailData?.addressDetails?.receiverName}}</span>\n                </div>\n                <div class=\"my-2 fs-6\">\n                    <span style=\"margin-right: 10px\">Phone:</span>\n                    <span class=\"fw-bold pl-2\">{{ orderDetailData?.addressDetails?.receiverPhone }}</span>\n                </div>\n                <div class=\"my-2 fs-6\">\n                    <span style=\"margin-right: 10px\">Address:</span>\n                    <span class=\"fw-bold pl-2\">{{ orderAddress }}</span>\n                </div>\n                <div class=\"my-2 fs-6\">\n                    <span style=\"margin-right: 10px\">Payment:</span>\n                    <span class=\"fw-bold pl-2\">Manual Payment</span>\n                </div>\n                <a (click)=\"trackOrder()\" class=\"track-order\" *ngIf=\"orderDetailData?.orderTrackingLink\">Track Order\n                </a>\n            </div>\n        </div>\n    </section>\n</ng-container>\n\n<ng-template #timelineContainer>\n    <hr />\n    <div class=\"timeline\">\n        <p-timeline [value]=\"orderTimiline\">\n            <ng-template pTemplate=\"content\" let-event>\n                <div class=\"d-flex time-line\">\n                    <mat-icon style=\"margin-right: 10px;\">{{ event.icon }}</mat-icon>\n                    <div class=\"d-flex flex-column ml-2\">\n                        <span class=\"fw-normal fs-6\">{{ event.name?.replaceAll(\"_\", \" \") }}</span>\n                        <div class=\"fs-6 \">{{event.desc?.replaceAll(\"_\", \" \")}}</div>\n                        <!-- <div class=\"action-btn\">\n                            <button *ngIf=\"canCancelOrder\">Cancel Order</button>\n                        </div> -->\n                    </div>\n                </div>\n            </ng-template>\n        </p-timeline>\n    </div>\n    <hr />\n</ng-template>\n\n<ngx-skeleton-loader *ngIf=\"isLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\n    width: '100%',\n    height: '40vh',\n    'border-radius': '10px',\n    'position': 'relative',\n    'right': '5px'\n  }\">\n</ngx-skeleton-loader>"]}
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":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AACjE,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAGlD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAC1E,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;;AAoB7C,MAAM,OAAO,qBAAqB;IAYhC,YACmB,aAA4B,EACrC,cAAqC,EACrC,WAAwB,EACxB,cAA8B;QAHrB,kBAAa,GAAb,aAAa,CAAe;QACrC,mBAAc,GAAd,cAAc,CAAuB;QACrC,gBAAW,GAAX,WAAW,CAAa;QACxB,mBAAc,GAAd,cAAc,CAAgB;QAR9B,kBAAa,GAAuB,IAAI,YAAY,EAAQ,CAAC;QACvE,cAAS,GAAY,KAAK,CAAC;QAUpB,kBAAa,GAAQ,EAAE,CAAC;QAqF/B,kBAAa,GAAW,CAAC,CAAA;IAvFrB,CAAC;IAIL,QAAQ;QACN,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC;QAChC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,eAAe,EAAE,iBAAiB,EAAE,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,GAAG,CAAC,CAAC,QAAa,EAAE,EAAE;YACrG,OAAO;gBACL,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC;gBACxC,IAAI,EAAE,QAAQ,CAAC,KAAK;gBACpB,IAAI,EAAE,QAAQ,CAAC,IAAI;aACpB,CAAA;QACH,CAAC,CAAC,CAAA;QAEF,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YAC1D,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC5B,CAAC,CAAC,CAAA;IACJ,CAAC;IAEO,OAAO,CAAC,IAAuH;QACrI,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,cAAc,CAAC;YACpB,KAAK,iBAAiB;gBACpB,OAAO,SAAS,CAAC;YACnB,KAAK,YAAY,CAAC;YAClB,KAAK,YAAY,CAAC;YAClB,KAAK,kBAAkB;gBACrB,OAAO,gBAAgB,CAAC;YAC1B,KAAK,WAAW;gBACd,OAAO,OAAO,CAAC;YACjB,KAAK,WAAW;gBACd,OAAO,QAAQ,CAAC;QACpB,CAAC;IACH,CAAC;IACD,MAAM;QACJ,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;IAC5B,CAAC;IAED,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,KAAK,IAAI,QAAQ,CAAC,CAAC;IAC5E,CAAC;IACD,IAAI,QAAQ;QACV,OAAO,MAAM,CAAC,UAAU,IAAI,GAAG,CAAC;IAClC,CAAC;IACD,kBAAkB,CAAC,OAAe;QAChC,OAAO,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;IAC1C,CAAC;IACO,kBAAkB,CAAC,QAAgB;QAEzC,IAAI,QAAQ,CAAC,MAAM,IAAI,CAAC;YACtB,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QAEvC,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QAEtC,IAAI,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC/C,IAAI,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC/C,IAAI,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAE/C,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;QACZ,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;QACZ,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;QAEZ,IAAI,OAAO,GAAG,IAAI,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;QAExH,OAAO,OAAO,CAAC,WAAW,EAAE,CAAC;IAC/B,CAAC;IACO,UAAU,CAAC,QAAgB;QACjC,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QACtC,IAAI,KAAK,GAAG,GAAG,CAAC;QAChB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;YACxB,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAC3C,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,kBAAkB,CAAC,QAAQ,CAAC;IACrC,CAAC;IACD,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,aAAa,EAAE,MAAM,IAAI,CAAC,CAAC;IACzC,CAAC;IACD,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,eAAe,EAAE,cAAc,EAAE,YAAY,GAAG,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,cAAc,EAAE,YAAY,GAAG,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,cAAc,EAAE,YAAY,GAAG,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,cAAc,EAAE,QAAQ,GAAG,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,cAAc,EAAE,SAAS,CAAC;IACrS,CAAC;IAED,UAAU;QACR,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,iBAAiB,EAAE,QAAQ,CAAC,CAAC;IACjE,CAAC;IAED,YAAY,CAAC,IAAS;QACpB,IAAI,OAAO,GAAG;YACZ,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,EAAE,MAAM,IAAI,EAAE;YACnD,UAAU,EAAE,YAAY,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,EAAE;YACpD,SAAS,EAAE,IAAI,CAAC,MAAM;YACtB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,OAAO,EAAG,IAAI,CAAC,eAAe,EAAE,WAAW,IAAI,EAAE;YACjD,QAAQ,EAAG,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,EAAE,OAAO,CAAC,IAAI;SACvD,CAAA;QACD,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC;YACrD,IAAI,EAAE,CAAC,QAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,2BAA2B,EAAE,CAAC,CAAC;YAC3G,CAAC;YACD,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;gBACf,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,4BAA4B,EAAE,CAAC,CAAC;YAC1G,CAAC;SACF,CAAC,CAAA;IACJ,CAAC;+GA3HU,qBAAqB;mGAArB,qBAAqB,oSC9BlC,isQA8IsB,4tCD3HlB,YAAY,8kBACZ,oBAAoB,8MACpB,cAAc,qQACd,OAAO,0IACP,WAAW,8BACX,YAAY,wTACZ,WAAW;;4FAKF,qBAAqB;kBAfjC,SAAS;+BACE,qBAAqB,cACnB,IAAI,WACP;wBACP,YAAY;wBACZ,oBAAoB;wBACpB,cAAc;wBACd,OAAO;wBACP,WAAW;wBACX,YAAY;wBACZ,WAAW;qBACZ;6KAKQ,YAAY;sBAApB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACoB,eAAe;sBAAxC,KAAK;uBAAC,iBAAiB;gBACd,aAAa;sBAAtB,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { MatIcon } from '@angular/material/icon';\nimport { SimpoComponentModule } from '../../../components/index';\nimport { TimelineModule } from 'primeng/timeline';\nimport { EventsService } from '../../../services/events.service';\nimport { ProfileStylesModal } from '../user-profile/user-profile.modal';\nimport { BUSINESS_CONSTANTS } from '../../../constants/business.constant';\nimport { PanelModule } from 'primeng/panel';\nimport { RatingModule } from 'primeng/rating';\nimport { FormsModule } from '@angular/forms';\nimport { StorageServiceService } from '../../../services/storage.service';\nimport { RestService } from '../../../services/rest.service';\nimport { MessageService } from 'primeng/api';\n\n@Component({\n  selector: 'simpo-order-details',\n  standalone: true,\n  imports: [\n    CommonModule,\n    SimpoComponentModule,\n    TimelineModule,\n    MatIcon,\n    PanelModule,\n    RatingModule,\n    FormsModule\n  ],\n  templateUrl: './order-details.component.html',\n  styleUrl: './order-details.component.css'\n})\nexport class OrderDetailsComponent implements OnInit {\n  @Input() responseData?: any;\n  @Input() data?: any;\n  @Input() index?: number;\n  @Input() edit?: boolean;\n  @Input() delete?: boolean;\n  @Input() customClass?: string;\n  @Input(\"orderDetailData\") orderDetailData: any;\n  @Output() goBackEmitter: EventEmitter<void> = new EventEmitter<void>();\n  isLoading: boolean = false;\n  styles?: ProfileStylesModal;\n\n  constructor(\n    private readonly _eventService: EventsService,\n    private storageService: StorageServiceService,\n    private restService: RestService,\n    private messageService: MessageService\n  ) { }\n\n  public orderTimiline: any = [];\n\n  ngOnInit(): void {\n    this.styles = this.data?.styles;\n    this.orderTimiline = this.orderDetailData?.brandOrderDetails?.[0]?.timeLineList?.map((timeline: any) => {\n      return {\n        icon: this.getIcon(timeline.orderStatus),\n        name: timeline.title,\n        desc: timeline.body\n      }\n    })\n\n    this._eventService.showLoadingScreen.subscribe((response) => {\n      this.isLoading = response;\n    })\n  }\n\n  private getIcon(type: \"ORDER_PLACED\" | \"ORDER_CONFIRMED\" | \"DISPATCHED\" | \"IN_TRANSIT\" | \"OUT_FOR_DELIVERY\" | \"DELIVERED\" | \"CANCELLED\") {\n    switch (type) {\n      case \"ORDER_PLACED\":\n      case \"ORDER_CONFIRMED\":\n        return \"widgets\";\n      case \"DISPATCHED\":\n      case \"IN_TRANSIT\":\n      case \"OUT_FOR_DELIVERY\":\n        return \"local_shipping\";\n      case \"DELIVERED\":\n        return \"inbox\";\n      case \"CANCELLED\":\n        return \"cancel\";\n    }\n  }\n  goBack() {\n    this.goBackEmitter.emit();\n  }\n\n  get getCardBGColor() {\n    return this.getComplementColor(this.styles?.background.color ?? \"#00000\");\n  }\n  get isMobile() {\n    return window.innerWidth <= 475;\n  }\n  getSupportingColor(bgColor: string): string {\n    return this.getComplementColor(bgColor);\n  }\n  private getComplementColor(hexColor: string) {\n\n    if (hexColor.length <= 4)\n      hexColor = this.convertHEX(hexColor);\n\n    hexColor = hexColor.replace(/^#/, '');\n\n    let r = parseInt(hexColor.substring(0, 2), 16);\n    let g = parseInt(hexColor.substring(2, 4), 16);\n    let b = parseInt(hexColor.substring(4, 6), 16);\n\n    r = 255 - r;\n    g = 255 - g;\n    b = 255 - b;\n\n    let compHex = `#${r.toString(16).padStart(2, '0')}${g.toString(16).padStart(2, '0')}${b.toString(16).padStart(2, '0')}`;\n\n    return compHex.toUpperCase();\n  }\n  private convertHEX(hexColor: string) {\n    hexColor = hexColor.replace(/^#/, '');\n    let color = \"#\";\n    for (let i = 0; i < 3; i++)\n      color += (hexColor[i] + hexColor[i + 1]);\n    return color;\n  }\n\n  get currency(): string {\n    return BUSINESS_CONSTANTS.CURRENCY;\n  }\n  get canCancelOrder(): boolean {\n    return this.orderTimiline?.length == 1;\n  }\n  get orderAddress(): string {\n    return this.orderDetailData?.addressDetails?.addressLine1 + ', ' + this.orderDetailData?.addressDetails?.addressLine2 + ', ' + this.orderDetailData?.addressDetails?.localityName + ', ' + this.orderDetailData?.addressDetails?.cityName + ', ' + this.orderDetailData?.addressDetails?.stateName;\n  }\n\n  trackOrder() {\n    window.open(this.orderDetailData?.orderTrackingLink, '_blank');\n  }\n  productReview: number = 0\n  submitReview(item: any) {\n    let payload = {\n      userId: this.storageService.getUser()?.userId ?? \"\",\n      businessId: localStorage.getItem('businessId') ?? \"\",\n      productId: item.itemId,\n      rating: item.rating,\n      review: item.review,\n      orderId : this.orderDetailData?.userOrderId ?? \"\",\n      userName : this.storageService.getUser()?.contact.name\n    }\n    this.restService.addReviewToProduct(payload).subscribe({\n      next: (response) => {\n        this.messageService.add({ severity: 'success', summary: 'Review', detail: 'Review Added Successfully' });\n      },\n      error: (error) => {\n        this.messageService.add({ severity: 'error', summary: 'Review', detail: 'Adding Review Caused error' });\n      }\n    })\n  }\n}\n","<ng-container *ngIf=\"!isLoading\">\n    <section class=\"d-flex justify-content-between main-section\" [style.width.vw]=\"isMobile ? '100' : '65'\"\n        style=\"margin: auto;\" [attr.style]=\"customClass\">\n        <div class=\"left\" [style.width.%]=\"isMobile ? '90' : '70'\">\n            <h1 class=\"fs-3 fw-normal mb-3 d-flex align-items-center onlyDesktop position-relative\"\n                style=\"left: -35px;\">\n                <mat-icon style=\"cursor: pointer;\" (click)=\"goBack()\">keyboard_arrow_left</mat-icon>\n                <span>Order Details</span>\n            </h1>\n            <div class=\"d-flex justify-content-between align-items-end orderNum\">\n                <div class=\"d-flex flex-column\">\n                    <span class=\"fs-5\">Order {{ orderDetailData?.orderNum }}</span>\n                    <span class=\"fs-6\">{{ orderDetailData?.createdTimeStamp | date: 'medium' }}, {{\n                        orderDetailData?.brandOrderDetails?.[0]?.orderedItems.length }} items | <span\n                            [innerHTML]=\"currency\"></span>\n                        {{orderDetailData?.brandOrderDetails?.[0]?.billDetails?.totalGrossValue}}</span>\n                </div>\n                <span class=\"fw-bold fs-5\">{{orderDetailData?.brandOrderDetails?.[0]?.businessName | titlecase}}</span>\n            </div>\n            <ng-container *ngIf=\"!isMobile\">\n                <ng-container *ngTemplateOutlet=\"timelineContainer\"></ng-container>\n            </ng-container>\n            <div>\n                <div *ngFor=\"let item of orderDetailData?.brandOrderDetails[0]?.orderedItems\" class=\"d-flex mb-2\"\n                    style=\"gap: 10px; width: 100%;\">\n                    <img loading=\"lazy\" onerror=\"this.src='https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\"\n                        [src]=\"item.imgUrl\" alt=\"\" style=\"height: 85px;width: 85px; border-radius: 5px;\">\n                    <div class=\"d-flex flex-column justify-content-center\" style=\"gap: 6px; width: 89%;\">\n                        <span class=\"fs-6\">{{item.itemName}}</span>\n                        <!-- <span class=\"fs-6\">Size: XS</span> -->\n                        <div class=\"d-flex justify-content-between fs-6\">\n                            <span>{{item.quantity}} X <span [innerHTML]=\"currency\"></span> <span\n                                    class=\"fw-bold\">{{(item.discountedPrice) | number: '1.0-2'}}</span></span>\n                            <span> <span [innerHTML]=\"currency\"></span> <span class=\"fw-bold\">{{(item.discountedPrice *\n                                    item.quantity) | number: '1.0-2'}}</span></span>\n                        </div>\n                        <div class=\"review-rating d-flex justify-content-between flex-column\">\n                            <div class=\"w-75\">\n                                <p-rating [(ngModel)]=\"item.rating\" [cancel]=\"false\" [readonly]=\"false\" />\n                                <div class=\"message w-100\">\n                                    <div class=\"f-13\">Add a Detailed Review</div>\n                                    <textarea class=\"w-100 br-6 f-13\" [(ngModel)]=\"item.review\"></textarea>\n                                </div>\n                            </div>\n                            <div class=\"d-flex align-items-end\">\n                                <div (click)=\"submitReview(item)\" class=\"d-flex align-items-end f-16 fw-800\">Submit</div>\n                            </div>\n                        </div>\n                    </div>\n                </div>\n            </div>\n            <ng-container *ngIf=\"isMobile\">\n                <ng-container *ngTemplateOutlet=\"timelineContainer\"></ng-container>\n            </ng-container>\n            <div class=\"fs-6 mt-25\">\n                <div class=\"d-flex justify-content-between my-2\">\n                    <span class=\"fw-normal\">Item Total</span>\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\n                        {{orderDetailData?.billDetails?.totalNetValue | number:'1.0-2'}}</span>\n                </div>\n                <div class=\"d-flex justify-content-between my-2\" *ngIf=\"orderDetailData?.billDetails?.discountAmount\">\n                    <span class=\"fw-normal\">Discount</span>\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\n                        {{orderDetailData?.billDetails?.discountAmount | number:'1.0-2'}}</span>\n                </div>\n                <div class=\"d-flex justify-content-between my-2\">\n                    <span class=\"fw-normal\">Total Tax</span>\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\n                        {{orderDetailData?.billDetails?.discountAmount ?\n                        orderDetailData?.billDetails?.totalTaxAfterDiscount :\n                        orderDetailData?.billDetails?.totalTax | number:'1.0-2'}}</span>\n                </div>\n\n                <div class=\"d-flex justify-content-between my-2\">\n                    <span>Delivery</span>\n                    <span>FREE</span>\n                </div>\n\n                <div class=\"d-flex justify-content-between my-2\">\n                    <span class=\"fw-normal\">Grand Total</span>\n                    <span class=\"fw-bold\"><span [innerHTML]=\"currency\"></span>\n                        {{orderDetailData?.billDetails?.discountAmount ? (orderDetailData?.billDetails?.totalNetValue -\n                        orderDetailData?.billDetails?.discountAmount +\n                        orderDetailData?.billDetails?.totalTaxAfterDiscount) :\n                        orderDetailData?.billDetails?.totalGrossValue | number:'1.0-2'}}</span>\n                </div>\n            </div>\n        </div>\n        <div class=\"\" style=\"width: 28%;\" [style.width.%]=\"isMobile ? '90' : '28'\">\n            <div class=\"right\">\n                <h1 class=\"mb-3 fs-5\">User Details</h1>\n                <div class=\"my-2 fs-6\">\n                    <span style=\"margin-right: 10px;\">Name:</span>\n                    <span class=\"fw-bold pl-2\">{{orderDetailData?.addressDetails?.receiverName}}</span>\n                </div>\n                <div class=\"my-2 fs-6\">\n                    <span style=\"margin-right: 10px\">Phone:</span>\n                    <span class=\"fw-bold pl-2\">{{ orderDetailData?.addressDetails?.receiverPhone }}</span>\n                </div>\n                <div class=\"my-2 fs-6\">\n                    <span style=\"margin-right: 10px\">Address:</span>\n                    <span class=\"fw-bold pl-2\">{{ orderAddress }}</span>\n                </div>\n                <div class=\"my-2 fs-6\">\n                    <span style=\"margin-right: 10px\">Payment:</span>\n                    <span class=\"fw-bold pl-2\">Manual Payment</span>\n                </div>\n                <a (click)=\"trackOrder()\" class=\"track-order\" *ngIf=\"orderDetailData?.orderTrackingLink\">Track Order\n                </a>\n            </div>\n        </div>\n    </section>\n</ng-container>\n\n<ng-template #timelineContainer>\n    <hr />\n    <div class=\"timeline\">\n        <p-timeline [value]=\"orderTimiline\">\n            <ng-template pTemplate=\"content\" let-event>\n                <div class=\"d-flex time-line\">\n                    <mat-icon style=\"margin-right: 10px;\">{{ event.icon }}</mat-icon>\n                    <div class=\"d-flex flex-column ml-2\">\n                        <span class=\"fw-normal fs-6\">{{ event.name?.replaceAll(\"_\", \" \") }}</span>\n                        <div class=\"fs-6 \">{{event.desc?.replaceAll(\"_\", \" \")}}</div>\n                        <!-- <div class=\"action-btn\">\n                            <button *ngIf=\"canCancelOrder\">Cancel Order</button>\n                        </div> -->\n                    </div>\n                </div>\n            </ng-template>\n        </p-timeline>\n    </div>\n    <hr />\n</ng-template>\n\n<ngx-skeleton-loader *ngIf=\"isLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\n    width: '100%',\n    height: '40vh',\n    'border-radius': '10px',\n    'position': 'relative',\n    'right': '5px'\n  }\">\n</ngx-skeleton-loader>"]}