ng-easycommerce-v18 0.4.0 → 0.4.1-beta.1

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 (43) hide show
  1. package/README.md +7 -0
  2. package/assets/ec-i18n/ct.json +4 -0
  3. package/assets/ec-i18n/en.json +12 -1
  4. package/assets/ec-i18n/es.json +12 -1
  5. package/assets/ec-i18n/fr.json +4 -0
  6. package/assets/ec-i18n/gl.json +4 -0
  7. package/assets/ec-i18n/pr.json +4 -0
  8. package/esm2022/lib/ec-components/account-ec/order-ec/order-ec.component.mjs +5 -9
  9. package/esm2022/lib/ec-components/account-ec/orders-list-ec/orders-list-ec.component.mjs +11 -5
  10. package/esm2022/lib/ec-components/cart-ec/cart-ec.component.mjs +12 -3
  11. package/esm2022/lib/ec-components/checkout-ec/checkout-ec.component.mjs +8 -1
  12. package/esm2022/lib/ec-components/checkout-ec/detail-checkout-block-ec/detail-checkout-block-ec.component.mjs +5 -3
  13. package/esm2022/lib/ec-components/checkout-ec/payment-ec/payment-ec.component.mjs +44 -4
  14. package/esm2022/lib/ec-components/checkout-ec/success-ec/success-ec.component.mjs +4 -3
  15. package/esm2022/lib/ec-components/credit-account-banner-ec/credit-account-banner-ec.component.mjs +79 -0
  16. package/esm2022/lib/ec-components/header-ec/header-ec.component.mjs +25 -11
  17. package/esm2022/lib/ec-components/index.mjs +2 -1
  18. package/esm2022/lib/ec-components/product-ec/product-ec.component.mjs +3 -3
  19. package/esm2022/lib/ec-components/sidebar-ec/sidebar-ec.component.mjs +5 -7
  20. package/esm2022/lib/ec-components/widgets-ec/price-ec/price-ec.component.mjs +5 -11
  21. package/esm2022/lib/ec-services/cart.service.mjs +42 -7
  22. package/esm2022/lib/ec-services/index.mjs +2 -1
  23. package/esm2022/lib/ec-services/price-visibility.service.mjs +40 -0
  24. package/esm2022/lib/ec-services/product-detail.service.mjs +45 -7
  25. package/fesm2022/ng-easycommerce-v18.mjs +295 -61
  26. package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
  27. package/lib/ec-components/account-ec/order-ec/order-ec.component.d.ts +2 -2
  28. package/lib/ec-components/account-ec/orders-list-ec/orders-list-ec.component.d.ts +3 -0
  29. package/lib/ec-components/cart-ec/cart-ec.component.d.ts +4 -2
  30. package/lib/ec-components/checkout-ec/checkout-ec.component.d.ts +2 -0
  31. package/lib/ec-components/checkout-ec/detail-checkout-block-ec/detail-checkout-block-ec.component.d.ts +2 -0
  32. package/lib/ec-components/checkout-ec/payment-ec/payment-ec.component.d.ts +6 -0
  33. package/lib/ec-components/checkout-ec/success-ec/success-ec.component.d.ts +1 -0
  34. package/lib/ec-components/credit-account-banner-ec/credit-account-banner-ec.component.d.ts +27 -0
  35. package/lib/ec-components/header-ec/header-ec.component.d.ts +12 -4
  36. package/lib/ec-components/index.d.ts +1 -0
  37. package/lib/ec-components/sidebar-ec/sidebar-ec.component.d.ts +2 -1
  38. package/lib/ec-components/widgets-ec/price-ec/price-ec.component.d.ts +2 -4
  39. package/lib/ec-services/cart.service.d.ts +1 -0
  40. package/lib/ec-services/index.d.ts +1 -0
  41. package/lib/ec-services/price-visibility.service.d.ts +23 -0
  42. package/lib/ec-services/product-detail.service.d.ts +3 -0
  43. package/package.json +1 -1
@@ -1,6 +1,9 @@
1
1
  import { Component, inject, PLATFORM_ID, HostListener, ChangeDetectorRef, signal } from '@angular/core';
2
2
  import { TitleCasePipe, AsyncPipe, JsonPipe, CommonModule, isPlatformBrowser } from '@angular/common';
3
3
  import { MenuEcComponent } from '../abstractions-components';
4
+ import { CartService } from '../../ec-services';
5
+ import { PriceVisibilityService } from '../../ec-services/price-visibility.service';
6
+ import { Subscription } from 'rxjs';
4
7
  import { AuthService } from '../../ec-services';
5
8
  import { Router, NavigationEnd, RouterLink, RouterLinkActive } from '@angular/router';
6
9
  import { CoreConstantsService } from '../../constants';
@@ -15,13 +18,16 @@ export class HeaderEcComponent extends MenuEcComponent {
15
18
  transparent = false;
16
19
  isHome = false; // Nueva variable para verificar si estamos en /home
17
20
  isScrolled = false;
18
- showPricesOnlyToLoggedUsers = false;
19
- hidePrices = false;
21
+ balanceAttributes = null;
22
+ subscriptions = new Subscription();
20
23
  __authService = inject(AuthService);
21
24
  _channelService = inject(ChannelService);
25
+ priceVisibility = inject(PriceVisibilityService);
22
26
  changeDetector = inject(ChangeDetectorRef);
23
27
  appRouter = inject(Router);
24
28
  platformId = inject(PLATFORM_ID);
29
+ _cartService = inject(CartService);
30
+ balanceAttributes$ = this._cartService.balanceCustomer$;
25
31
  mobileDropdownOpen = signal(false);
26
32
  isMenuOpen = signal(false);
27
33
  // Observable del estado de autenticación
@@ -29,10 +35,6 @@ export class HeaderEcComponent extends MenuEcComponent {
29
35
  isAuthenticated$ = this.__authService.isAuthenticated();
30
36
  constructor() {
31
37
  super();
32
- this._channelService.channel$.subscribe(cfg => {
33
- this.showPricesOnlyToLoggedUsers = !!cfg.showPricesOnlyToLoggedUsers;
34
- this.hidePrices = !!cfg.hidePrices;
35
- });
36
38
  }
37
39
  coreConstantsService = inject(CoreConstantsService);
38
40
  router = inject(Router);
@@ -48,18 +50,19 @@ export class HeaderEcComponent extends MenuEcComponent {
48
50
  // Usar el Observable del AuthService
49
51
  this.logged$ = this.__authService.loggedIn$;
50
52
  // Suscribirse al Observable y forzar detección de cambios cuando sea necesario
51
- this.logged$.subscribe(isLoggedIn => {
53
+ this.subscriptions.add(this.logged$.subscribe(isLoggedIn => {
52
54
  this.changeDetector.detectChanges();
53
- });
55
+ }));
56
+ this.subscribeToBalance();
54
57
  if (isPlatformBrowser(this.platformId)) {
55
- this.appRouter.events.subscribe(evt => {
58
+ this.subscriptions.add(this.appRouter.events.subscribe(evt => {
56
59
  if (evt instanceof NavigationEnd) {
57
60
  // Forzar detección de cambios después de navegación
58
61
  setTimeout(() => {
59
62
  this.changeDetector.detectChanges();
60
63
  }, 100);
61
64
  }
62
- });
65
+ }));
63
66
  }
64
67
  }
65
68
  ngAfterViewInit() {
@@ -244,6 +247,17 @@ export class HeaderEcComponent extends MenuEcComponent {
244
247
  });
245
248
  }
246
249
  }
250
+ get canShowPrices() {
251
+ return this.priceVisibility.canShowPrices();
252
+ }
253
+ ngOnDestroy() {
254
+ this.subscriptions.unsubscribe();
255
+ }
256
+ subscribeToBalance() {
257
+ this.subscriptions.add(this._cartService.balanceCustomer$.subscribe(balanceData => {
258
+ this.balanceAttributes = balanceData;
259
+ }));
260
+ }
247
261
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: HeaderEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
248
262
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: HeaderEcComponent, isStandalone: true, selector: "lib-header-ec", host: { listeners: { "window:scroll": "onWindowScroll()" } }, usesInheritance: true, ngImport: i0, template: "<p>header-ec works!</p>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }] });
249
263
  }
@@ -254,4 +268,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
254
268
  type: HostListener,
255
269
  args: ['window:scroll', []]
256
270
  }] } });
257
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/header-ec/header-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/header-ec/header-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { afterNextRender, Component, inject, PLATFORM_ID, Injector, OnInit, HostListener, ChangeDetectorRef, signal } from '@angular/core';\nimport { TitleCasePipe, AsyncPipe, JsonPipe, CommonModule, isPlatformBrowser } from '@angular/common';\nimport { MenuEcComponent } from '../abstractions-components';\nimport { CartService, TestService, ToastService } from '../../ec-services';\nimport { Observable } from 'rxjs';\nimport { AuthService } from '../../ec-services';\nimport { Router, NavigationEnd, RouterLink, RouterLinkActive } from '@angular/router';\nimport { Category } from '../../interfaces';\nimport { CoreConstantsService } from '../../constants';\nimport { ChannelService } from '../../ec-services';\n\n/**\n * Componente que se encarga de manejar la funcionalidad del Header.\n */\n@Component({\n  selector: 'lib-header-ec',\n  standalone: true,\n  imports: [CommonModule, TitleCasePipe, AsyncPipe, JsonPipe, RouterLink, RouterLinkActive],\n  templateUrl: './header-ec.component.html',\n  styleUrl: './header-ec.component.scss'\n})\nexport class HeaderEcComponent extends MenuEcComponent {\n  public channel: string | undefined;\n  public searchValue: string = '';\n  transparent: boolean = false;\n  isHome: boolean = false; // Nueva variable para verificar si estamos en /home\n  isScrolled: boolean = false;\n  showPricesOnlyToLoggedUsers: boolean = false;\n  hidePrices: boolean = false;\n  public __authService: AuthService = inject(AuthService)\n  public _channelService: ChannelService = inject(ChannelService);\n  public changeDetector = inject(ChangeDetectorRef);\n  public appRouter = inject(Router);\n  public platformId = inject(PLATFORM_ID);\n\n  mobileDropdownOpen = signal(false);\n  isMenuOpen = signal(false);\n\n\n  // Observable del estado de autenticación\n  public logged$!: Observable<boolean>;\n  public isAuthenticated$ = this.__authService.isAuthenticated();\n  constructor() {\n    super();\n    this._channelService.channel$.subscribe(cfg => {\n      this.showPricesOnlyToLoggedUsers = !!cfg.showPricesOnlyToLoggedUsers;\n      this.hidePrices = !!cfg.hidePrices;\n    });\n  }\n\n  private coreConstantsService = inject(CoreConstantsService);\n  private router = inject(Router);\n  private cdr = inject(ChangeDetectorRef); // Inyectamos ChangeDetectorRef para forzar la actualización\n\n  ngOnInit(): void {\n    this.channel = this.coreConstantsService.getChannel();\n    \n    this.searchValue = this.coreConstantsService.searchValue || '';\n    // Solo ejecutar en el navegador\n    if (isPlatformBrowser(this.platformId)) {\n    this.onWindowScroll();\n    }\n    \n    this.detectRouteChange(); // Llamamos a la función que detecta el cambio de ruta\n    // Usar el Observable del AuthService\n    this.logged$ = this.__authService.loggedIn$;\n\n    // Suscribirse al Observable y forzar detección de cambios cuando sea necesario\n    this.logged$.subscribe(isLoggedIn => {\n      this.changeDetector.detectChanges();\n    });\n    if (isPlatformBrowser(this.platformId)) {\n      this.appRouter.events.subscribe(evt => {\n        if (evt instanceof NavigationEnd) {\n          // Forzar detección de cambios después de navegación\n          setTimeout(() => {\n            this.changeDetector.detectChanges();\n          }, 100);\n        }\n      });\n    }\n  }\n  ngAfterViewInit(): void {\n    // Solo ejecutar en el navegador\n    if (isPlatformBrowser(this.platformId)) {\n      this.setupMobileMenu(); // Inicializamos el menú móvil\n      this.setupSearchInputs(); // Inicializamos los inputs de búsqueda   \n      this.isHomeFunction();\n    }\n  }\n  /**\n   * Detecta cuando cambia la ruta y actualiza la clase del header\n   */\n  private detectRouteChange() {\n    this.router.events.subscribe(event => {\n      if (event instanceof NavigationEnd) {\n        this.isHome = this.router.url === '/home';\n        this.cdr.detectChanges(); // Forzamos la detección de cambios para actualizar la vista\n      }\n    });\n  }\n\n  @HostListener('window:scroll', [])\n  onWindowScroll() {\n    if (isPlatformBrowser(this.platformId)) {\n      const scrollTop = window.scrollY;\n      this.isScrolled = scrollTop > 80;\n    }\n  }\n\n  isHomeFunction(): void {\n    if (isPlatformBrowser(this.platformId)) {\n      const headerElement = document.querySelector('header');\n      if (headerElement) {\n        if (this.router.url !== '/home') {\n          headerElement.classList.add('show-menu');\n        } else {\n          headerElement.classList.remove('show-menu');\n        }\n      }\n    }\n  }\n\n  changeUrlTransparent = (urlTransparent: string) => {\n    return urlTransparent;\n  };\n\n\n  getCollectionSearch = () => {\n    this.coreConstantsService.searchValue = this.searchValue;\n    this.router.navigateByUrl('/collection?search=' + this.searchValue);\n  };\n\n  setSearchValue = (event: Event, afterSearch?: Function, ...args: any[]) => {\n    const target = event.target as HTMLInputElement;\n    if (target) {\n      this.searchValue = target.value;\n    }\n\n    // if (event.key === 'Enter') {\n    // this.getCollectionSearch();\n    if (afterSearch) {\n      afterSearch(...args);\n      // }\n    }\n  };\n\n  borrarInput(inputId?: string) {\n    if (isPlatformBrowser(this.platformId)) {\n      if (inputId) {\n        const input = document.getElementById(inputId) as HTMLInputElement;\n        if (input) {\n          input.value = '';\n        }\n      } else {\n        const inputs = ['searchInput1'];\n        inputs.forEach((id) => {\n          const input = document.getElementById(id) as HTMLInputElement;\n          if (input) {\n            input.value = '';\n          }\n        });\n      }\n    }\n\n    this.searchValue = '';\n    this.coreConstantsService.searchValue = '';\n    \n    // En lugar de relanzar la búsqueda con string vacío,\n    // actualizamos la URL para quitar el query param `search` y resetear la paginación.\n    this.router.navigate(['/collection'], {\n      queryParams: {\n        search: null,\n        page: null\n      },\n      queryParamsHandling: 'merge'\n    });\n  }\n  setupMobileMenu() {\n    if (!isPlatformBrowser(this.platformId) || typeof document === 'undefined') return;\n    const menuMobile = document.querySelector('.menuMobile');\n    if (!(menuMobile instanceof HTMLElement)) return;\n    const openBtn = document.querySelector('.abreMenuMobile .abre');\n    const closeBtn = document.querySelector('.abreMenuMobile .close');\n    const iconMenu = document.getElementById('icMenu');\n    const searchMobile = document.querySelector('.searchMobile');\n\n    const closeMenu = () => {\n      menuMobile.style.display = 'none';\n      closeBtn?.setAttribute('style', 'display:none');\n      iconMenu?.setAttribute('style', 'display:block');\n    };\n\n    menuMobile.style.display = 'none';\n\n    openBtn?.addEventListener('click', () => {\n      menuMobile.style.display = 'block';\n      closeBtn?.setAttribute('style', 'display:block');\n      if (searchMobile instanceof HTMLElement) {\n        searchMobile.style.display = 'none';\n      }\n      iconMenu?.setAttribute('style', 'display:none');\n    });\n\n    closeBtn?.addEventListener('click', closeMenu);\n\n    // Cierra el menú si se hace clic en un enlace específico dentro del menú\n    const linkSelectors = ['.categoryMobile', '.subcategoryMobile', '.usuariomobile'];\n    linkSelectors.forEach(selector => {\n      const links = menuMobile.querySelectorAll<HTMLAnchorElement>(`a${selector}`);\n      links.forEach(link => {\n        link.addEventListener('click', () => {\n          closeMenu();\n        });\n      });\n    });\n  }\n  setupSearchInputs() {\n    if (!isPlatformBrowser(this.platformId)) return;\n    \n    const inputs = ['searchInput1', 'searchInput2'];\n\n    inputs.forEach(id => {\n      const input = document.getElementById(id);\n      if (!(input instanceof HTMLInputElement)) return;\n      const clearBtn = document.querySelector(`.clear-btn${id.slice(-1)}`);\n\n      if (!input || !(clearBtn instanceof HTMLElement)) return;\n\n      input.addEventListener('focus', () => {\n        if (input.value === 'Buscar producto...') {\n          input.value = '';\n        }\n      });\n\n      input.addEventListener('blur', () => {\n        if (input.value.trim() === '') {\n          input.value = 'Buscar producto...';\n        }\n      });\n\n      input.addEventListener('input', () => {\n        clearBtn.style.display = input.value.trim() !== '' ? 'block' : 'none';\n      });\n\n      clearBtn.addEventListener('click', (e) => {\n        e.preventDefault();\n        input.value = '';\n        clearBtn.style.display = 'none';\n        input.focus();\n      });\n    });\n\n  }\n\n  togglePanel(id: string) {\n    // Solo ejecutar en el navegador para evitar problemas con SSR\n    if (isPlatformBrowser(this.platformId)) {\n      this.openPanels.update(panels => ({\n        ...panels,\n        [id]: !panels[id]\n      }));\n    }\n  }\n\n  openPanels = signal<Record<string, boolean>>({\n    collapseUno: false,\n    collapseDos: true // Productos abierto por defecto\n  });\n\n\n\n\n  collapseAllMenus() {\n    // Solo ejecutar en el navegador para evitar problemas con SSR\n    if (isPlatformBrowser(this.platformId)) {\n      this.openPanels.update(panels => {\n        const newPanels = { ...panels };\n        Object.keys(newPanels).forEach(key => {\n          if (key !== 'collapseDos') {\n            newPanels[key] = false;\n          }\n        });\n        return newPanels;\n      });\n    }\n  }\n}\n","<p>header-ec works!</p>\n"]}
271
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/header-ec/header-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/header-ec/header-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { afterNextRender, Component, inject, PLATFORM_ID, Injector, OnInit, HostListener, ChangeDetectorRef, signal, OnDestroy } from '@angular/core';\nimport { TitleCasePipe, AsyncPipe, JsonPipe, CommonModule, isPlatformBrowser } from '@angular/common';\nimport { MenuEcComponent } from '../abstractions-components';\nimport { CartService, TestService, ToastService } from '../../ec-services';\nimport { PriceVisibilityService } from '../../ec-services/price-visibility.service';\nimport { Observable, Subscription } from 'rxjs';\nimport { AuthService } from '../../ec-services';\nimport { Router, NavigationEnd, RouterLink, RouterLinkActive } from '@angular/router';\nimport { BalanceCustomer, Category } from '../../interfaces';\nimport { CoreConstantsService } from '../../constants';\nimport { ChannelService } from '../../ec-services';\n\n/**\n * Componente que se encarga de manejar la funcionalidad del Header.\n */\n@Component({\n  selector: 'lib-header-ec',\n  standalone: true,\n  imports: [CommonModule, TitleCasePipe, AsyncPipe, JsonPipe, RouterLink, RouterLinkActive],\n  templateUrl: './header-ec.component.html',\n  styleUrl: './header-ec.component.scss'\n})\nexport class HeaderEcComponent extends MenuEcComponent implements OnInit, OnDestroy {\n  public channel: string | undefined;\n  public searchValue: string = '';\n  transparent: boolean = false;\n  isHome: boolean = false; // Nueva variable para verificar si estamos en /home\n  isScrolled: boolean = false;\n  balanceAttributes: BalanceCustomer | null = null;\n  private subscriptions = new Subscription();\n  public __authService: AuthService = inject(AuthService)\n  public _channelService: ChannelService = inject(ChannelService);\n  public readonly priceVisibility = inject(PriceVisibilityService);\n  public changeDetector = inject(ChangeDetectorRef);\n  public appRouter = inject(Router);\n  public platformId = inject(PLATFORM_ID);\n  private _cartService: CartService = inject(CartService);\n  balanceAttributes$ = this._cartService.balanceCustomer$;\n\n  mobileDropdownOpen = signal(false);\n  isMenuOpen = signal(false);\n\n\n  // Observable del estado de autenticación\n  public logged$!: Observable<boolean>;\n  public isAuthenticated$ = this.__authService.isAuthenticated();\n  constructor() {\n    super();\n  }\n\n  private coreConstantsService = inject(CoreConstantsService);\n  private router = inject(Router);\n  private cdr = inject(ChangeDetectorRef); // Inyectamos ChangeDetectorRef para forzar la actualización\n\n  ngOnInit(): void {\n    this.channel = this.coreConstantsService.getChannel();\n    \n    this.searchValue = this.coreConstantsService.searchValue || '';\n    // Solo ejecutar en el navegador\n    if (isPlatformBrowser(this.platformId)) {\n    this.onWindowScroll();\n    }\n    \n    this.detectRouteChange(); // Llamamos a la función que detecta el cambio de ruta\n    // Usar el Observable del AuthService\n    this.logged$ = this.__authService.loggedIn$;\n\n    // Suscribirse al Observable y forzar detección de cambios cuando sea necesario\n    this.subscriptions.add(this.logged$.subscribe(isLoggedIn => {\n      this.changeDetector.detectChanges();\n    }));\n    this.subscribeToBalance();\n     if (isPlatformBrowser(this.platformId)) {\n      this.subscriptions.add(this.appRouter.events.subscribe(evt => {\n        if (evt instanceof NavigationEnd) {\n          // Forzar detección de cambios después de navegación\n          setTimeout(() => {\n            this.changeDetector.detectChanges();\n          }, 100);\n        }\n      }));\n    }\n  }\n  ngAfterViewInit(): void {\n    // Solo ejecutar en el navegador\n    if (isPlatformBrowser(this.platformId)) {\n      this.setupMobileMenu(); // Inicializamos el menú móvil\n      this.setupSearchInputs(); // Inicializamos los inputs de búsqueda   \n      this.isHomeFunction();\n    }\n  }\n  /**\n   * Detecta cuando cambia la ruta y actualiza la clase del header\n   */\n  private detectRouteChange() {\n    this.router.events.subscribe(event => {\n      if (event instanceof NavigationEnd) {\n        this.isHome = this.router.url === '/home';\n        this.cdr.detectChanges(); // Forzamos la detección de cambios para actualizar la vista\n      }\n    });\n  }\n\n  @HostListener('window:scroll', [])\n  onWindowScroll() {\n    if (isPlatformBrowser(this.platformId)) {\n      const scrollTop = window.scrollY;\n      this.isScrolled = scrollTop > 80;\n    }\n  }\n\n  isHomeFunction(): void {\n    if (isPlatformBrowser(this.platformId)) {\n      const headerElement = document.querySelector('header');\n      if (headerElement) {\n        if (this.router.url !== '/home') {\n          headerElement.classList.add('show-menu');\n        } else {\n          headerElement.classList.remove('show-menu');\n        }\n      }\n    }\n  }\n\n  changeUrlTransparent = (urlTransparent: string) => {\n    return urlTransparent;\n  };\n\n\n  getCollectionSearch = () => {\n    this.coreConstantsService.searchValue = this.searchValue;\n    this.router.navigateByUrl('/collection?search=' + this.searchValue);\n  };\n\n  setSearchValue = (event: Event, afterSearch?: Function, ...args: any[]) => {\n    const target = event.target as HTMLInputElement;\n    if (target) {\n      this.searchValue = target.value;\n    }\n\n    // if (event.key === 'Enter') {\n    // this.getCollectionSearch();\n    if (afterSearch) {\n      afterSearch(...args);\n      // }\n    }\n  };\n\n  borrarInput(inputId?: string) {\n    if (isPlatformBrowser(this.platformId)) {\n      if (inputId) {\n        const input = document.getElementById(inputId) as HTMLInputElement;\n        if (input) {\n          input.value = '';\n        }\n      } else {\n        const inputs = ['searchInput1'];\n        inputs.forEach((id) => {\n          const input = document.getElementById(id) as HTMLInputElement;\n          if (input) {\n            input.value = '';\n          }\n        });\n      }\n    }\n\n    this.searchValue = '';\n    this.coreConstantsService.searchValue = '';\n    \n    // En lugar de relanzar la búsqueda con string vacío,\n    // actualizamos la URL para quitar el query param `search` y resetear la paginación.\n    this.router.navigate(['/collection'], {\n      queryParams: {\n        search: null,\n        page: null\n      },\n      queryParamsHandling: 'merge'\n    });\n  }\n  setupMobileMenu() {\n    if (!isPlatformBrowser(this.platformId) || typeof document === 'undefined') return;\n    const menuMobile = document.querySelector('.menuMobile');\n    if (!(menuMobile instanceof HTMLElement)) return;\n    const openBtn = document.querySelector('.abreMenuMobile .abre');\n    const closeBtn = document.querySelector('.abreMenuMobile .close');\n    const iconMenu = document.getElementById('icMenu');\n    const searchMobile = document.querySelector('.searchMobile');\n\n    const closeMenu = () => {\n      menuMobile.style.display = 'none';\n      closeBtn?.setAttribute('style', 'display:none');\n      iconMenu?.setAttribute('style', 'display:block');\n    };\n\n    menuMobile.style.display = 'none';\n\n    openBtn?.addEventListener('click', () => {\n      menuMobile.style.display = 'block';\n      closeBtn?.setAttribute('style', 'display:block');\n      if (searchMobile instanceof HTMLElement) {\n        searchMobile.style.display = 'none';\n      }\n      iconMenu?.setAttribute('style', 'display:none');\n    });\n\n    closeBtn?.addEventListener('click', closeMenu);\n\n    // Cierra el menú si se hace clic en un enlace específico dentro del menú\n    const linkSelectors = ['.categoryMobile', '.subcategoryMobile', '.usuariomobile'];\n    linkSelectors.forEach(selector => {\n      const links = menuMobile.querySelectorAll<HTMLAnchorElement>(`a${selector}`);\n      links.forEach(link => {\n        link.addEventListener('click', () => {\n          closeMenu();\n        });\n      });\n    });\n  }\n  setupSearchInputs() {\n    if (!isPlatformBrowser(this.platformId)) return;\n    \n    const inputs = ['searchInput1', 'searchInput2'];\n\n    inputs.forEach(id => {\n      const input = document.getElementById(id);\n      if (!(input instanceof HTMLInputElement)) return;\n      const clearBtn = document.querySelector(`.clear-btn${id.slice(-1)}`);\n\n      if (!input || !(clearBtn instanceof HTMLElement)) return;\n\n      input.addEventListener('focus', () => {\n        if (input.value === 'Buscar producto...') {\n          input.value = '';\n        }\n      });\n\n      input.addEventListener('blur', () => {\n        if (input.value.trim() === '') {\n          input.value = 'Buscar producto...';\n        }\n      });\n\n      input.addEventListener('input', () => {\n        clearBtn.style.display = input.value.trim() !== '' ? 'block' : 'none';\n      });\n\n      clearBtn.addEventListener('click', (e) => {\n        e.preventDefault();\n        input.value = '';\n        clearBtn.style.display = 'none';\n        input.focus();\n      });\n    });\n\n  }\n\n  togglePanel(id: string) {\n    // Solo ejecutar en el navegador para evitar problemas con SSR\n    if (isPlatformBrowser(this.platformId)) {\n      this.openPanels.update(panels => ({\n        ...panels,\n        [id]: !panels[id]\n      }));\n    }\n  }\n\n  openPanels = signal<Record<string, boolean>>({\n    collapseUno: false,\n    collapseDos: true // Productos abierto por defecto\n  });\n\n\n\n\n  collapseAllMenus() {\n    // Solo ejecutar en el navegador para evitar problemas con SSR\n    if (isPlatformBrowser(this.platformId)) {\n      this.openPanels.update(panels => {\n        const newPanels = { ...panels };\n        Object.keys(newPanels).forEach(key => {\n          if (key !== 'collapseDos') {\n            newPanels[key] = false;\n          }\n        });\n        return newPanels;\n      });\n    }\n  }\n\n  get canShowPrices(): boolean {\n    return this.priceVisibility.canShowPrices();\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.unsubscribe();\n  }\n\n  private subscribeToBalance(): void {\n    this.subscriptions.add(this._cartService.balanceCustomer$.subscribe(balanceData => {\n      this.balanceAttributes = balanceData;\n    }));\n  }\n}\n","<p>header-ec works!</p>\n"]}
@@ -32,4 +32,5 @@ export * from './reviews-form-ec/reviews-form-ec.component';
32
32
  export * from './section-container-ec/section-container-ec.component';
33
33
  export * from './stores-ec/stores-ec.component';
34
34
  export * from './price-range-filter/price-range-filter.component';
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lYXN5Y29tbWVyY2UtdjE4L3NyYy9saWIvZWMtY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLCtEQUErRCxDQUFDO0FBQzlFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYywyREFBMkQsQ0FBQztBQUMxRSxjQUFjLGlFQUFpRSxDQUFDO0FBQ2hGLGNBQWMsK0RBQStELENBQUE7QUFDN0UsY0FBYyxtRUFBbUUsQ0FBQTtBQUNqRixjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHVEQUF1RCxDQUFDO0FBQ3RFLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxtREFBbUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZm9vdGVyLWVjL2Zvb3Rlci1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9oZWFkZXItZWMvaGVhZGVyLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2hvbWUtZWMvaG9tZS1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9ibG9ja3MtZWMvYmxvY2tzLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3Byb2R1Y3QtZWMvcHJvZHVjdC1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb2xsZWN0aW9uLWVjL2NvbGxlY3Rpb24tZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZmlsdGVycy1zb3J0LWVjL2ZpbHRlcnMtc29ydC1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXRzLWVjJztcbmV4cG9ydCAqIGZyb20gJy4vYXV0aC1lYyc7XG5leHBvcnQgKiBmcm9tICcuL2ZpbHRlcnMtZWMvZmlsdGVycy1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9wcm9kdWN0LWRldGFpbC1lYy9wcm9kdWN0LWRldGFpbC1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi92YXJpYW50cy1lYy92YXJpYW50cy1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9icmVhZGNydW1iLWVjL2JyZWFkY3J1bWItZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY2FydC1lYyc7XG5leHBvcnQgKiBmcm9tICcuL2NvdXBvbi1lYy9jb3Vwb24tZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29udGFjdC1lYy9jb250YWN0LWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NoZWNrb3V0LWVjL2NoZWNrb3V0LWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NoZWNrb3V0LWVjL3N1Y2Nlc3MtZWMvc3VjY2Vzcy1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9hY2NvdW50LWVjJztcbmV4cG9ydCAqIGZyb20gJy4vYmxvY2tzLWVjL2Jsb2NrLW5ld3NsZXR0ZXItZWMvYmxvY2stbmV3c2xldHRlci1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9ibG9ja3MtZWMvYmxvY2staHRtbC1lYy9ibG9jay1odG1sLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2Jsb2Nrcy1lYy9ibG9jay1wcm9kdWN0cy1lYy9ibG9jay1wcm9kdWN0cy1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9ibG9ja3MtZWMvYmxvY2stYmFubmVyLWZ1bGwtZWMvYmxvY2stYmFubmVyLWZ1bGwtZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vYmxvY2tzLWVjL2Jsb2NrLWJhbm5lci1ib3gtZWMvYmxvY2stYmFubmVyLWJveC1lYy5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2Jsb2Nrcy1lYy9ibG9jay1mb3JtLWNvbnRhY3QtZWMvYmxvY2stZm9ybS1jb250YWN0LWVjLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vc2lkZWJhci1lYy9zaWRlYmFyLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JlbGF0ZWQtcHJvZHVjdHMtZWMvcmVsYXRlZC1wcm9kdWN0cy1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9mYXFzLWVjL2ZhcXMtZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc2hhcmUtZWMvc2hhcmUtZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcmV2aWV3cy1lYy9yZXZpZXdzLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3Jldmlld3MtZm9ybS1lYy9yZXZpZXdzLWZvcm0tZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc2VjdGlvbi1jb250YWluZXItZWMvc2VjdGlvbi1jb250YWluZXItZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc3RvcmVzLWVjL3N0b3Jlcy1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9wcmljZS1yYW5nZS1maWx0ZXIvcHJpY2UtcmFuZ2UtZmlsdGVyLmNvbXBvbmVudCc7Il19
35
+ export * from './credit-account-banner-ec/credit-account-banner-ec.component';
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lYXN5Y29tbWVyY2UtdjE4L3NyYy9saWIvZWMtY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLCtEQUErRCxDQUFDO0FBQzlFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYywyREFBMkQsQ0FBQztBQUMxRSxjQUFjLGlFQUFpRSxDQUFDO0FBQ2hGLGNBQWMsK0RBQStELENBQUE7QUFDN0UsY0FBYyxtRUFBbUUsQ0FBQTtBQUNqRixjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHVEQUF1RCxDQUFDO0FBQ3RFLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLCtEQUErRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9mb290ZXItZWMvZm9vdGVyLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2hlYWRlci1lYy9oZWFkZXItZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vaG9tZS1lYy9ob21lLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2Jsb2Nrcy1lYy9ibG9ja3MtZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcHJvZHVjdC1lYy9wcm9kdWN0LWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbGxlY3Rpb24tZWMvY29sbGVjdGlvbi1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9maWx0ZXJzLXNvcnQtZWMvZmlsdGVycy1zb3J0LWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3dpZGdldHMtZWMnO1xuZXhwb3J0ICogZnJvbSAnLi9hdXRoLWVjJztcbmV4cG9ydCAqIGZyb20gJy4vZmlsdGVycy1lYy9maWx0ZXJzLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3Byb2R1Y3QtZGV0YWlsLWVjL3Byb2R1Y3QtZGV0YWlsLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3ZhcmlhbnRzLWVjL3ZhcmlhbnRzLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2JyZWFkY3J1bWItZWMvYnJlYWRjcnVtYi1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jYXJ0LWVjJztcbmV4cG9ydCAqIGZyb20gJy4vY291cG9uLWVjL2NvdXBvbi1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250YWN0LWVjL2NvbnRhY3QtZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY2hlY2tvdXQtZWMvY2hlY2tvdXQtZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY2hlY2tvdXQtZWMvc3VjY2Vzcy1lYy9zdWNjZXNzLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2FjY291bnQtZWMnO1xuZXhwb3J0ICogZnJvbSAnLi9ibG9ja3MtZWMvYmxvY2stbmV3c2xldHRlci1lYy9ibG9jay1uZXdzbGV0dGVyLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2Jsb2Nrcy1lYy9ibG9jay1odG1sLWVjL2Jsb2NrLWh0bWwtZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vYmxvY2tzLWVjL2Jsb2NrLXByb2R1Y3RzLWVjL2Jsb2NrLXByb2R1Y3RzLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2Jsb2Nrcy1lYy9ibG9jay1iYW5uZXItZnVsbC1lYy9ibG9jay1iYW5uZXItZnVsbC1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9ibG9ja3MtZWMvYmxvY2stYmFubmVyLWJveC1lYy9ibG9jay1iYW5uZXItYm94LWVjLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vYmxvY2tzLWVjL2Jsb2NrLWZvcm0tY29udGFjdC1lYy9ibG9jay1mb3JtLWNvbnRhY3QtZWMuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9zaWRlYmFyLWVjL3NpZGViYXItZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcmVsYXRlZC1wcm9kdWN0cy1lYy9yZWxhdGVkLXByb2R1Y3RzLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2ZhcXMtZWMvZmFxcy1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zaGFyZS1lYy9zaGFyZS1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9yZXZpZXdzLWVjL3Jldmlld3MtZWMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcmV2aWV3cy1mb3JtLWVjL3Jldmlld3MtZm9ybS1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWN0aW9uLWNvbnRhaW5lci1lYy9zZWN0aW9uLWNvbnRhaW5lci1lYy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zdG9yZXMtZWMvc3RvcmVzLWVjLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3ByaWNlLXJhbmdlLWZpbHRlci9wcmljZS1yYW5nZS1maWx0ZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY3JlZGl0LWFjY291bnQtYmFubmVyLWVjL2NyZWRpdC1hY2NvdW50LWJhbm5lci1lYy5jb21wb25lbnQnO1xuIl19
@@ -226,11 +226,11 @@ export class ProductEcComponent {
226
226
  }
227
227
  }
228
228
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProductEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
229
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ProductEcComponent, isStandalone: true, selector: "app-product-ec", inputs: { product: "product", isProductBox: "isProductBox", isCollection: "isCollection" }, outputs: { loaded: "loaded" }, ngImport: i0, template: "<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none producto\">\n <!-- Marca especial y descuento -->\n <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\n class=\"marcas\">\n <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\n <ng-container *ngIf=\"shouldShowPrice\">\n <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\n [ecProductOff]=\"product\">\n </div>\n </ng-container>\n </div> -->\n\n <!-- Imagen del producto -->\n <div class=\"foto\">\n @if(product.picturesdefault){\n @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\n <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\n } @else {\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\n }\n }\n </div>\n <!-- Precio -->\n\n\n <!-- Nombre del producto -->\n <h6 class=\"title\">{{ product.name | titlecase }}</h6>\n\n <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\n\n @if (shouldShowPrice) {\n <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\n }\n @if(!hidePrices){\n @if(!showPricesOnlyToLoggedUsers || isAuthenticated$){\n\n <div class=\"fixBottom\">\n\n <!-- Bot\u00F3n de acciones -->\n <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\n <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\n @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\n 'standard') {\n <button class=\"btn standard\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n <ng-container *ngIf=\"isCollection; else normalText\">\n <span> {{(\"buy\" | translate) | uppercase}} </span>\n </ng-container>\n <ng-template #normalText>\n {{(\"buy\" | translate) | uppercase}}\n </ng-template>\n </button>\n }@else {\n <!-- Caso 1: Agotado o Disponible muy pronto -->\n @if (product.special_mark[0]?.type === 'out_of_stock' || product.special_mark[0]?.type === 'coming_soon') {\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n @if(isCollection){\n <span>{{ product.special_mark[0].name | uppercase }} </span>\n }@else {\n {{ product.special_mark[0]?.name | uppercase }}\n }\n </button>}\n <!-- Caso 2: Contacto por WhatsApp -->\n @if (product.special_mark[0].type === 'whatsapp_contact') {\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\n (click)=\"openWhatsApp(product.special_mark[0]?.whatsappContact)\">\n @if(isCollection){\n <span>{{ product.special_mark[0]?.name | uppercase }}</span>\n }@else {\n {{ product.special_mark[0]?.name | uppercase }}\n }\n\n </button>\n }\n <!-- Caso 3: Solicitar m\u00E1s informaci\u00F3n -->\n @if (product.special_mark[0]?.type === 'more_info') {\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n @if(isCollection){\n <span>{{ product.special_mark[0]?.name | uppercase }}</span>\n }@else {\n {{ product.special_mark[0]?.name | uppercase }}\n }\n </button>\n }\n }\n </div>\n }}\n</a>", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i1.TitleCasePipe, name: "titlecase" }, { kind: "component", type: PriceEcComponent, selector: "app-price-ec", inputs: ["price", "saleprice", "basePrice", "taxeAmount", "taxes", "priceSize", "showTaxLegendOnly", "disableTaxInfo", "customPriceTemplate", "customSalePriceTemplate", "customSimplePriceTemplate", "customSimpleSalePriceTemplate", "customTaxTemplate", "customOnlyTaxLabelTemplate"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: FormsModule }] });
229
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ProductEcComponent, isStandalone: true, selector: "app-product-ec", inputs: { product: "product", isProductBox: "isProductBox", isCollection: "isCollection" }, outputs: { loaded: "loaded" }, ngImport: i0, template: "<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none producto\">\n <!-- Marca especial y descuento -->\n <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\n class=\"marcas\">\n <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\n <ng-container *ngIf=\"shouldShowPrice\">\n <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\n [ecProductOff]=\"product\">\n </div>\n </ng-container>\n </div> -->\n\n <!-- Imagen del producto -->\n <div class=\"foto\">\n @if(product.picturesdefault){\n @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\n <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\n } @else {\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\n }\n }\n </div>\n <!-- Precio -->\n\n\n <!-- Nombre del producto -->\n <h6 class=\"title\">{{ product.name | titlecase }}</h6>\n\n <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\n\n @if (shouldShowPrice) {\n <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\n }\n @if(!hidePrices){\n @if(!showPricesOnlyToLoggedUsers || isAuthenticated$){\n\n <div class=\"fixBottom\">\n\n <!-- Bot\u00F3n de acciones -->\n <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\n <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\n @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\n 'standard') {\n <button class=\"btn standard\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n <ng-container *ngIf=\"isCollection; else normalText\">\n <span> {{(\"buy\" | translate) | uppercase}} </span>\n </ng-container>\n <ng-template #normalText>\n {{(\"buy\" | translate) | uppercase}}\n </ng-template>\n </button>\n }@else {\n <!-- Caso 1: Agotado o Disponible muy pronto -->\n @if (product.special_mark[0]?.type === 'out_of_stock' || product.special_mark[0]?.type === 'coming_soon') {\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n @if(isCollection){\n <span>{{ product.special_mark[0].name | uppercase }} </span>\n }@else {\n {{ product.special_mark[0]?.name | uppercase }}\n }\n </button>}\n <!-- Caso 2: Contacto por WhatsApp -->\n @if (product.special_mark[0].type === 'whatsapp_contact') {\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\n (click)=\"openWhatsApp(product.special_mark[0]?.whatsappContact)\">\n @if(isCollection){\n <span>{{ product.special_mark[0]?.name | uppercase }}</span>\n }@else {\n {{ product.special_mark[0]?.name | uppercase }}\n }\n\n </button>\n }\n <!-- Caso 3: Solicitar m\u00E1s informaci\u00F3n -->\n @if (product.special_mark[0]?.type === 'more_info') {\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n @if(isCollection){\n <span>{{ product.special_mark[0]?.name | uppercase }}</span>\n }@else {\n {{ product.special_mark[0]?.name | uppercase }}\n }\n </button>\n }\n }\n </div>\n }}\n</a>", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i1.TitleCasePipe, name: "titlecase" }, { kind: "component", type: PriceEcComponent, selector: "app-price-ec", inputs: ["price", "saleprice", "basePrice", "taxeAmount", "taxes", "priceSize", "showTaxLegendOnly", "disableTaxInfo", "customPriceTemplate", "customSalePriceTemplate", "customSimplePriceTemplate", "customSimpleSalePriceTemplate", "customTaxTemplate", "customOnlyTaxLabelTemplate"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: FormsModule }] });
230
230
  }
231
231
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProductEcComponent, decorators: [{
232
232
  type: Component,
233
- args: [{ selector: 'app-product-ec', standalone: true, imports: [CommonModule, PriceEcComponent, RouterLink, TranslateModule, FormsModule], template: "<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none producto\">\n <!-- Marca especial y descuento -->\n <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\n class=\"marcas\">\n <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\n <ng-container *ngIf=\"shouldShowPrice\">\n <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\n [ecProductOff]=\"product\">\n </div>\n </ng-container>\n </div> -->\n\n <!-- Imagen del producto -->\n <div class=\"foto\">\n @if(product.picturesdefault){\n @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\n <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\n } @else {\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\n }\n }\n </div>\n <!-- Precio -->\n\n\n <!-- Nombre del producto -->\n <h6 class=\"title\">{{ product.name | titlecase }}</h6>\n\n <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\n\n @if (shouldShowPrice) {\n <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\n }\n @if(!hidePrices){\n @if(!showPricesOnlyToLoggedUsers || isAuthenticated$){\n\n <div class=\"fixBottom\">\n\n <!-- Bot\u00F3n de acciones -->\n <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\n <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\n @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\n 'standard') {\n <button class=\"btn standard\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n <ng-container *ngIf=\"isCollection; else normalText\">\n <span> {{(\"buy\" | translate) | uppercase}} </span>\n </ng-container>\n <ng-template #normalText>\n {{(\"buy\" | translate) | uppercase}}\n </ng-template>\n </button>\n }@else {\n <!-- Caso 1: Agotado o Disponible muy pronto -->\n @if (product.special_mark[0]?.type === 'out_of_stock' || product.special_mark[0]?.type === 'coming_soon') {\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n @if(isCollection){\n <span>{{ product.special_mark[0].name | uppercase }} </span>\n }@else {\n {{ product.special_mark[0]?.name | uppercase }}\n }\n </button>}\n <!-- Caso 2: Contacto por WhatsApp -->\n @if (product.special_mark[0].type === 'whatsapp_contact') {\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\n (click)=\"openWhatsApp(product.special_mark[0]?.whatsappContact)\">\n @if(isCollection){\n <span>{{ product.special_mark[0]?.name | uppercase }}</span>\n }@else {\n {{ product.special_mark[0]?.name | uppercase }}\n }\n\n </button>\n }\n <!-- Caso 3: Solicitar m\u00E1s informaci\u00F3n -->\n @if (product.special_mark[0]?.type === 'more_info') {\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n @if(isCollection){\n <span>{{ product.special_mark[0]?.name | uppercase }}</span>\n }@else {\n {{ product.special_mark[0]?.name | uppercase }}\n }\n </button>\n }\n }\n </div>\n }}\n</a>" }]
233
+ args: [{ selector: 'app-product-ec', standalone: true, imports: [CommonModule, PriceEcComponent, RouterLink, TranslateModule, FormsModule], template: "<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none producto\">\n <!-- Marca especial y descuento -->\n <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\n class=\"marcas\">\n <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\n <ng-container *ngIf=\"shouldShowPrice\">\n <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\n [ecProductOff]=\"product\">\n </div>\n </ng-container>\n </div> -->\n\n <!-- Imagen del producto -->\n <div class=\"foto\">\n @if(product.picturesdefault){\n @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\n <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\n } @else {\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\n }\n }\n </div>\n <!-- Precio -->\n\n\n <!-- Nombre del producto -->\n <h6 class=\"title\">{{ product.name | titlecase }}</h6>\n\n <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\n\n @if (shouldShowPrice) {\n <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\n }\n @if(!hidePrices){\n @if(!showPricesOnlyToLoggedUsers || isAuthenticated$){\n\n <div class=\"fixBottom\">\n\n <!-- Bot\u00F3n de acciones -->\n <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\n <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\n @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\n 'standard') {\n <button class=\"btn standard\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n <ng-container *ngIf=\"isCollection; else normalText\">\n <span> {{(\"buy\" | translate) | uppercase}} </span>\n </ng-container>\n <ng-template #normalText>\n {{(\"buy\" | translate) | uppercase}}\n </ng-template>\n </button>\n }@else {\n <!-- Caso 1: Agotado o Disponible muy pronto -->\n @if (product.special_mark[0]?.type === 'out_of_stock' || product.special_mark[0]?.type === 'coming_soon') {\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n @if(isCollection){\n <span>{{ product.special_mark[0].name | uppercase }} </span>\n }@else {\n {{ product.special_mark[0]?.name | uppercase }}\n }\n </button>}\n <!-- Caso 2: Contacto por WhatsApp -->\n @if (product.special_mark[0].type === 'whatsapp_contact') {\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\n (click)=\"openWhatsApp(product.special_mark[0]?.whatsappContact)\">\n @if(isCollection){\n <span>{{ product.special_mark[0]?.name | uppercase }}</span>\n }@else {\n {{ product.special_mark[0]?.name | uppercase }}\n }\n\n </button>\n }\n <!-- Caso 3: Solicitar m\u00E1s informaci\u00F3n -->\n @if (product.special_mark[0]?.type === 'more_info') {\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n @if(isCollection){\n <span>{{ product.special_mark[0]?.name | uppercase }}</span>\n }@else {\n {{ product.special_mark[0]?.name | uppercase }}\n }\n </button>\n }\n }\n </div>\n }}\n</a>" }]
234
234
  }], ctorParameters: () => [], propDecorators: { product: [{
235
235
  type: Input,
236
236
  args: [{
@@ -243,4 +243,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
243
243
  }], isCollection: [{
244
244
  type: Input
245
245
  }] } });
246
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-ec/product-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-ec/product-ec.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAU,MAAM,EAAE,QAAQ,EAAkB,MAAM,GAAG,MAAM,eAAe,CAAC;AAE1H,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,WAAW,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAC7G,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;;;;AAC7C;;;GAGG;AAQH,MAAM,OAAO,kBAAkB;IACvB,QAAQ,GAAa,MAAM,CAAC,QAAQ,CAAC,CAAC;IACrC,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;IAC/B,YAAY,GAAgB,MAAM,CAAC,WAAW,CAAC,CAAC;IAChD,aAAa,GAAiB,MAAM,CAAC,YAAY,CAAC,CAAC;IAEpD,cAAc,GAA4B,MAAM,CAAC,KAAK,CAAC,CAAC;IACxD,QAAQ,GAA2B,MAAM,CAAC,CAAC,CAAC,CAAC;IAEpD;;;OAGG;IACH,iBAAiB,CAAC,SAAiB;QAClC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;YAC9D,sCAAsC;YACtC,MAAM,CAAC,QAAQ,CAAC;gBACf,GAAG,EAAE,CAAC;gBACN,IAAI,EAAE,CAAC;gBACP,QAAQ,EAAE,QAAQ;aAClB,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;IACJ,CAAC;IAGD;;OAEG;IAIH,OAAO,CAAW;IAClB;;OAEG;IACM,YAAY,GAAY,IAAI,CAAC;IACtC;;OAEG;IACO,MAAM,GAAG,IAAI,YAAY,EAAU,CAAC;IAErC,YAAY,GAAY,KAAK,CAAC;IAEvC,QAAQ;QACP,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAEnC,CAAC;IACM,2BAA2B,GAAY,KAAK,CAAC;IAC7C,UAAU,GAAY,KAAK,CAAC;IAE3B,YAAY,GAAgB,MAAM,CAAC,WAAW,CAAC,CAAA;IAChD,gBAAgB,GAAG,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,CAAC;IAC9D;QACC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE;YAC9D,IAAI,CAAC,2BAA2B,GAAG,CAAC,CAAC,OAAO,CAAC,2BAA2B,CAAC;YACzE,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC;QACxC,CAAC,CAAC,CAAC;IACJ,CAAC;IACO,MAAM,GAAyB,MAAM,CAAC,oBAAoB,CAAC,CAAA;IAC3D,gBAAgB,GAAqB,MAAM,CAAC,gBAAgB,CAAC,CAAA;IAC7D,MAAM,GAAW,MAAM,CAAC,MAAM,CAAC,CAAA;IACvC;;OAEG;IACI,QAAQ,GAAW,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAA;IAChD,YAAY,CAAC,GAAW;QACvB,IAAI,GAAG,EAAE,CAAC;YACT,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC5B,CAAC;IACF,CAAC;IAED,IAAI,eAAe;QAClB,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC;IACzH,CAAC;IAED,IAAI,WAAW;QACd,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,KAAK,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;IAChF,CAAC;IAED,IAAI,kBAAkB;QACrB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACvB,OAAO,IAAI,CAAC;QACb,CAAC;QAED,MAAM,aAAa,GAAG,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,GAAG,CAAC,CAAC;QACxE,MAAM,SAAS,GAAG,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,QAAQ,EAAE,IAAI,GAAG,CAAC,CAAC;QAExE,uCAAuC;QACvC,IAAI,aAAa,IAAI,CAAC,IAAI,SAAS,IAAI,CAAC,IAAI,SAAS,IAAI,aAAa,EAAE,CAAC;YACxE,OAAO,IAAI,CAAC;QACb,CAAC;QAED,sFAAsF;QACtF,MAAM,QAAQ,GAAG,CAAC,CAAC,aAAa,GAAG,SAAS,CAAC,GAAG,aAAa,CAAC,GAAG,GAAG,CAAC;QAErE,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IAC7B,CAAC;IACD,IAAI,CAAC,KAAc,EAAE,gBAAyB;QAC7C,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,sBAAsB;QAC/D,IAAI,gBAAgB,IAAI,gBAAgB,GAAG,CAAC,EAAE,CAAC;YAC9C,KAAK;gBACJ,CAAC,CAAC,CAAC,OAAO,GAAG,KAAK;oBACjB,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,GAAG,gBAAgB,CAAC;oBAC/C,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;gBACpD,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,GAAG,gBAAgB,CAAC,CAAC;QAClD,CAAC;aAAM,CAAC;YACP,KAAK;gBACJ,CAAC,CAAC,CAAC,OAAO,GAAG,KAAK;oBACjB,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,GAAG,CAAC,CAAC;oBAChC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;gBACpD,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC;QACnC,CAAC;IACF,CAAC;IAED,IAAI,CAAC,gBAAyB;QAC7B,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,sBAAsB;QAC/D,IAAI,gBAAgB,IAAI,gBAAgB,GAAG,CAAC,EAAE,CAAC;YAC9C,OAAO,GAAG,gBAAgB;gBACzB,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,GAAG,gBAAgB,CAAC;gBAC/C,CAAC,CAAC,IAAI,CAAC;QACT,CAAC;aAAM,CAAC;YACP,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACrD,CAAC;IACF,CAAC;IAED,SAAS;QACR,IAAI,IAAI,CAAC,cAAc,EAAE,IAAI,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC;YAAE,OAAO;QAE1D,oDAAoD;QACpD,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACnF,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACpC,OAAO;QACR,CAAC;QACD,kBAAkB;QAClB,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QAC9C,IAAI,CAAC,YAAY,CAAC,KAAK,IAAI,YAAY,CAAC,KAAK,IAAI,CAAC,EAAE,CAAC;YACpD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YACxC,OAAO;QACR,CAAC;QACD,iDAAiD;QACjD,IAAI,IAAI,CAAC,QAAQ,EAAE,GAAG,YAAY,CAAC,KAAK,EAAE,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;YACjD,OAAO;QACR,CAAC;QACD,4DAA4D;QAC5D,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,EAAE,CAAC;YAC7C,OAAO,CAAC,mDAAmD;QAC5D,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC9B,IAAI,CAAC;YACJ,qDAAqD;YACrD,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,YAAY,CAAC,IAAI,CAAC,CAAC;YAC9E,sDAAsD;YACtD,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACtB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACrC,CAAC;QAED,UAAU,CAAC,GAAG,EAAE;YACf,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAChC,CAAC,EAAE,IAAI,CAAC,CAAC;IACV,CAAC;IAED;;OAEG;IACK,gBAAgB,CAAC,QAAgB;QACxC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAClE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACpC,OAAO,KAAK,CAAC;QACd,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QAEzC,wCAAwC;QACxC,MAAM,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC,sBAAsB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC9E,MAAM,aAAa,GAAG,MAAM,CAAC,cAAc,CAAC,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAChE,wEAAwE;QACxE,MAAM,oBAAoB,GAAG,IAAI,CAAC,OAAO,CAAC,oBAAoB;YAC7D,OAAO,CAAC,oBAAoB;YAC5B,MAAM,CAAC;QACR,MAAM,oBAAoB,GAAG,IAAI,CAAC,OAAO,CAAC,oBAAoB;YAC7D,OAAO,CAAC,oBAAoB;YAC5B,CAAC,CAAC;QACH,MAAM,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB;YACrD,OAAO,CAAC,gBAAgB;YACxB,CAAC,CAAC;QAEH,0BAA0B;QAC1B,IAAI,aAAa,GAAG,oBAAoB,EAAE,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,wBAAwB,EAAE,EAAE,QAAQ,EAAE,oBAAoB,EAAE,CAAC,CAAC;YACtF,OAAO,KAAK,CAAC;QACd,CAAC;QAED,0BAA0B;QAC1B,IAAI,aAAa,GAAG,oBAAoB,EAAE,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,wBAAwB,EAAE,EAAE,QAAQ,EAAE,oBAAoB,EAAE,CAAC,CAAC;YACtF,OAAO,KAAK,CAAC;QACd,CAAC;QACD,+BAA+B;QAC/B,IAAI,gBAAgB,IAAI,gBAAgB,GAAG,CAAC,EAAE,CAAC;YAC9C,IAAI,aAAa,GAAG,gBAAgB,KAAK,CAAC,EAAE,CAAC;gBAC5C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,4BAA4B,EAAE;oBACrD,QAAQ,EAAE,gBAAgB;oBAC1B,OAAO,EAAE,aAAa;iBACtB,CAAC,CAAC;gBACH,OAAO,KAAK,CAAC;YACd,CAAC;QACF,CAAC;QACD,uCAAuC;QACvC,IAAI,aAAa,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;YACnC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;YACjD,OAAO,KAAK,CAAC;QACd,CAAC;QACD,OAAO,IAAI,CAAC,CAAC,iCAAiC;IAC/C,CAAC;IACD,UAAU,CAAC,KAAa;QACvB,IAAI,IAAI,CAAC,QAAQ,EAAE,IAAI,KAAK;YAC3B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED,gBAAgB,CAAC,KAAY;QAC5B,MAAM,MAAM,GAAG,KAAK,CAAC,MAA0B,CAAC;QAChD,MAAM,KAAK,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC;QAC5B,qCAAqC;QACrC,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;YACf,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YACzB,qCAAqC;YACrC,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,IAAI,CAAC,OAAO,EAAE,KAAK,IAAI,CAAC,CAAC;YAChF,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QAC3B,CAAC;aAAM,CAAC;YACP,4CAA4C;YAC5C,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACtB,CAAC;IACF,CAAC;wGA1OW,kBAAkB;4FAAlB,kBAAkB,qMCpB/B,i4HAuFI,yDDvEO,YAAY,2VAAE,gBAAgB,oVAAE,UAAU,mOAAE,eAAe,2FAAE,WAAW;;4FAItE,kBAAkB;kBAP9B,SAAS;+BACC,gBAAgB,cACd,IAAI,WACP,CAAC,YAAY,EAAE,gBAAgB,EAAE,UAAU,EAAE,eAAe,EAAE,WAAW,CAAC;wDAmCnF,OAAO;sBAHN,KAAK;uBAAC;wBACN,QAAQ,EAAE,IAAI;qBACd;gBAKQ,YAAY;sBAApB,KAAK;gBAII,MAAM;sBAAf,MAAM;gBAEE,YAAY;sBAApB,KAAK","sourcesContent":["import { Component, EventEmitter, inject, Input, OnInit, Output, Injector, WritableSignal, signal, } from '@angular/core';\nimport { Product } from '../../interfaces';\nimport { CoreConstantsService } from '../../constants';\nimport { AnalyticsService, ChannelService, AuthService, CartService, ToastService } from '../../ec-services';\nimport { Router, RouterLink } from '@angular/router';\nimport { CommonModule } from '@angular/common';\nimport { PriceEcComponent } from \"../widgets-ec/price-ec/price-ec.component\";\nimport { TranslateModule } from '@ngx-translate/core';\nimport { FormsModule } from '@angular/forms';\n/**\n * Componente que se encarga de manejar un producto.\n * @class ProductEcComponent\n */\n@Component({\n\tselector: 'app-product-ec',\n\tstandalone: true,\n\timports: [CommonModule, PriceEcComponent, RouterLink, TranslateModule, FormsModule],\n\ttemplateUrl: './product-ec.component.html',\n\tstyleUrl: './product-ec.component.scss'\n})\nexport class ProductEcComponent implements OnInit {\n\tpublic injector: Injector = inject(Injector);\n\tprivate routerService = inject(Router);\n\tprivate _cartService: CartService = inject(CartService);\n\tprivate _toastService: ToastService = inject(ToastService);\n\n\tpublic isAddingToCart: WritableSignal<boolean> = signal(false);\n\tpublic quantity: WritableSignal<number> = signal(1);\n\n\t/**\n\t * Navega al detalle del producto y sube al inicio de la página\n\t * @param productId ID del producto\n\t */\n\tnavigateToProduct(productId: string): void {\n\t\tthis.routerService.navigate(['/product', productId]).then(() => {\n\t\t\t// Scroll suave al inicio de la página\n\t\t\twindow.scrollTo({\n\t\t\t\ttop: 0,\n\t\t\t\tleft: 0,\n\t\t\t\tbehavior: 'smooth'\n\t\t\t});\n\t\t});\n\t}\n\n\n\t/**\n\t * Datos del producto.\n\t */\n\t@Input({\n\t\trequired: true\n\t})\n\tproduct!: Product;\n\t/**\n\t * Se usa para saber si el producto es de tipo Box o no y definir la vista adecuada.\n\t */\n\t@Input() isProductBox: boolean = true;\n\t/**\n\t * Constantes del core\n\t */\n\t@Output() loaded = new EventEmitter<number>();\n\n\t@Input() isCollection: boolean = false;\n\n\tngOnInit() {\n\t\tthis.loaded.emit(this.product.id);\n\n\t}\n\tpublic showPricesOnlyToLoggedUsers: boolean = false;\n\tpublic hidePrices: boolean = false;\n\n\tprivate _authService: AuthService = inject(AuthService)\n\tpublic isAuthenticated$ = this._authService.isAuthenticated();\n\tconstructor() {\n\t\tthis.injector.get(ChannelService).channel$.subscribe(channel => {\n\t\t\tthis.showPricesOnlyToLoggedUsers = !!channel.showPricesOnlyToLoggedUsers;\n\t\t\tthis.hidePrices = !!channel.hidePrices;\n\t\t});\n\t}\n\tprivate consts: CoreConstantsService = inject(CoreConstantsService)\n\tprivate analyticsService: AnalyticsService = inject(AnalyticsService)\n\tprivate router: Router = inject(Router)\n\t/**\n\t * URL para las imagenes del producto.\n\t */\n\tpublic mediaUrl: string = this.consts.mediaUrl()\n\topenWhatsApp(url: string): void {\n\t\tif (url) {\n\t\t\twindow.open(url, '_blank');\n\t\t}\n\t}\n\n\tget shouldShowPrice(): boolean {\n\t\treturn !this.product?.special_mark || this.product.special_mark.length === 0 || this.product.special_mark[0]?.showPrice;\n\t}\n\n\tget hasDiscount(): boolean {\n\t\treturn this.product.saleprice && this.product.saleprice !== this.product.price;\n\t}\n\n\tget discountPercentage(): number | null {\n\t\tif (!this.hasDiscount) {\n\t\t\treturn null;\n\t\t}\n\n\t\tconst originalPrice = parseFloat(this.product.price?.toString() || '0');\n\t\tconst salePrice = parseFloat(this.product.saleprice?.toString() || '0');\n\n\t\t// Validar que los precios sean válidos\n\t\tif (originalPrice <= 0 || salePrice <= 0 || salePrice >= originalPrice) {\n\t\t\treturn null;\n\t\t}\n\n\t\t// Calcular el porcentaje: ((precio_original - precio_oferta) / precio_original) * 100\n\t\tconst discount = ((originalPrice - salePrice) / originalPrice) * 100;\n\n\t\treturn Math.round(discount);\n\t}\n\tplus(stock?: number, multipleQuantity?: number) {\n\t\tconst current = Number(this.quantity()); // <-- fuerza a número\n\t\tif (multipleQuantity && multipleQuantity > 0) {\n\t\t\tstock\n\t\t\t\t? (current < stock\n\t\t\t\t\t? this.quantity.set(current + multipleQuantity)\n\t\t\t\t\t: this._toastService.show('out-of-stock-actually'))\n\t\t\t\t: this.quantity.set(current + multipleQuantity);\n\t\t} else {\n\t\t\tstock\n\t\t\t\t? (current < stock\n\t\t\t\t\t? this.quantity.set(current + 1)\n\t\t\t\t\t: this._toastService.show('out-of-stock-actually'))\n\t\t\t\t: this.quantity.set(current + 1);\n\t\t}\n\t}\n\n\tless(multipleQuantity?: number) {\n\t\tconst current = Number(this.quantity()); // <-- fuerza a número\n\t\tif (multipleQuantity && multipleQuantity > 0) {\n\t\t\tcurrent > multipleQuantity\n\t\t\t\t? this.quantity.set(current - multipleQuantity)\n\t\t\t\t: null;\n\t\t} else {\n\t\t\tcurrent > 1 ? this.quantity.set(current - 1) : null;\n\t\t}\n\t}\n\n\taddToCart() {\n\t\tif (this.isAddingToCart() || this.quantity() <= 0) return;\n\n\t\t// Verificar que tenemos el producto y sus variantes\n\t\tif (!this.product || !this.product.variants || this.product.variants.length === 0) {\n\t\t\tthis._toastService.show('cant-buy');\n\t\t\treturn;\n\t\t}\n\t\t// Verificar stock\n\t\tconst firstVariant = this.product.variants[0];\n\t\tif (!firstVariant.stock || firstVariant.stock <= 0) {\n\t\t\tthis._toastService.show('out-of-stock');\n\t\t\treturn;\n\t\t}\n\t\t// Verificar que no se supere el stock disponible\n\t\tif (this.quantity() > firstVariant.stock) {\n\t\t\tthis._toastService.show('out-of-stock-actually');\n\t\t\treturn;\n\t\t}\n\t\t// NUEVAS VALIDACIONES: Verificar restricciones del producto\n\t\tif (!this.validateQuantity(this.quantity())) {\n\t\t\treturn; // La validación ya mostró el toast correspondiente\n\t\t}\n\t\tthis.isAddingToCart.set(true);\n\t\ttry {\n\t\t\t// Agregar al carrito usando CartService directamente\n\t\t\tthis._cartService.addToCart(this.product, this.quantity(), firstVariant.code);\n\t\t\t// Resetear cantidad a 1 después de agregar al carrito\n\t\t\tthis.quantity.set(1);\n\t\t} catch (error) {\n\t\t\tthis._toastService.show('cant-buy');\n\t\t}\n\n\t\tsetTimeout(() => {\n\t\t\tthis.isAddingToCart.set(false);\n\t\t}, 2000);\n\t}\n\n\t/**\n\t * Valida las restricciones de cantidad del producto\n\t */\n\tprivate validateQuantity(quantity: number): boolean {\n\t\tif (!this.product.variants || this.product.variants.length === 0) {\n\t\t\tthis._toastService.show('cant-buy');\n\t\t\treturn false;\n\t\t}\n\n\t\tconst variant = this.product.variants[0];\n\n\t\t// Obtener cantidad actual en el carrito\n\t\tconst actualQuantity = this._cartService.getCountFromItemInCart(variant.code);\n\t\tconst totalQuantity = Number(actualQuantity) + Number(quantity);\n\t\t// Obtener restricciones del producto/variante (con valores por defecto)\n\t\tconst maximumItemsQuantity = this.product.maximumItemsQuantity ||\n\t\t\tvariant.maximumItemsQuantity ||\n\t\t\t999999;\n\t\tconst minimumItemsQuantity = this.product.minimumItemsQuantity ||\n\t\t\tvariant.minimumItemsQuantity ||\n\t\t\t1;\n\t\tconst multipleQuantity = this.product.multipleQuantity ||\n\t\t\tvariant.multipleQuantity ||\n\t\t\t1;\n\n\t\t// Validar cantidad máxima\n\t\tif (totalQuantity > maximumItemsQuantity) {\n\t\t\tthis._toastService.show('maximum-items-quantity', { quantity: maximumItemsQuantity });\n\t\t\treturn false;\n\t\t}\n\n\t\t// Validar cantidad mínima\n\t\tif (totalQuantity < minimumItemsQuantity) {\n\t\t\tthis._toastService.show('minimum-items-quantity', { quantity: minimumItemsQuantity });\n\t\t\treturn false;\n\t\t}\n\t\t// Validar múltiplo de cantidad\n\t\tif (multipleQuantity && multipleQuantity > 1) {\n\t\t\tif (totalQuantity % multipleQuantity !== 0) {\n\t\t\t\tthis._toastService.show('multiple-quantity-required', {\n\t\t\t\t\tmultiple: multipleQuantity,\n\t\t\t\t\tcurrent: totalQuantity\n\t\t\t\t});\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\t\t// Validar que no exceda el stock total\n\t\tif (totalQuantity > variant.stock) {\n\t\t\tthis._toastService.show('out-of-stock-actually');\n\t\t\treturn false;\n\t\t}\n\t\treturn true; // Todas las validaciones pasaron\n\t}\n\tcheckStock(stock: number) {\n\t\tif (this.quantity() >= stock)\n\t\t\tthis.quantity.set(stock);\n\t}\n\n\tonQuantityChange(event: Event) {\n\t\tconst target = event.target as HTMLInputElement;\n\t\tconst value = +target.value;\n\t\t// Validar que el valor sea mayor a 0\n\t\tif (value > 0) {\n\t\t\tthis.quantity.set(value);\n\t\t\t// Validar contra el stock disponible\n\t\t\tconst maxStock = this.product?.variants?.[0]?.stock || this.product?.stock || 0;\n\t\t\tthis.checkStock(maxStock);\n\t\t} else {\n\t\t\t// Si el valor es 0 o negativo, resetear a 1\n\t\t\tthis.quantity.set(1);\n\t\t}\n\t}\n}\n","<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none producto\">\n    <!-- Marca especial y descuento -->\n    <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\n        class=\"marcas\">\n        <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\n        <ng-container *ngIf=\"shouldShowPrice\">\n            <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\n                [ecProductOff]=\"product\">\n            </div>\n        </ng-container>\n    </div> -->\n\n    <!-- Imagen del producto -->\n    <div class=\"foto\">\n        @if(product.picturesdefault){\n        @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\n        <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\n        <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\n        } @else {\n        <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\n        }\n        }\n    </div>\n    <!-- Precio -->\n\n\n    <!-- Nombre del producto -->\n    <h6 class=\"title\">{{ product.name | titlecase }}</h6>\n\n    <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\n\n    @if (shouldShowPrice) {\n    <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\n    }\n    @if(!hidePrices){\n    @if(!showPricesOnlyToLoggedUsers || isAuthenticated$){\n\n    <div class=\"fixBottom\">\n\n        <!-- Botón de acciones -->\n        <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\n        <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\n        @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\n        'standard') {\n        <button class=\"btn standard\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n            <ng-container *ngIf=\"isCollection; else normalText\">\n                <span> {{(\"buy\" | translate) | uppercase}} </span>\n            </ng-container>\n            <ng-template #normalText>\n                {{(\"buy\" | translate) | uppercase}}\n            </ng-template>\n        </button>\n        }@else {\n        <!-- Caso 1: Agotado o Disponible muy pronto -->\n        @if (product.special_mark[0]?.type === 'out_of_stock' || product.special_mark[0]?.type === 'coming_soon') {\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n            @if(isCollection){\n            <span>{{ product.special_mark[0].name | uppercase }} </span>\n            }@else {\n            {{ product.special_mark[0]?.name | uppercase }}\n            }\n        </button>}\n        <!-- Caso 2: Contacto por WhatsApp -->\n        @if (product.special_mark[0].type === 'whatsapp_contact') {\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\n            (click)=\"openWhatsApp(product.special_mark[0]?.whatsappContact)\">\n            @if(isCollection){\n            <span>{{ product.special_mark[0]?.name | uppercase }}</span>\n            }@else {\n            {{ product.special_mark[0]?.name | uppercase }}\n            }\n\n        </button>\n        }\n        <!-- Caso 3: Solicitar más información -->\n        @if (product.special_mark[0]?.type === 'more_info') {\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n            @if(isCollection){\n            <span>{{ product.special_mark[0]?.name | uppercase }}</span>\n            }@else {\n            {{ product.special_mark[0]?.name | uppercase }}\n            }\n        </button>\n        }\n        }\n    </div>\n    }}\n</a>"]}
246
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-ec/product-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-ec/product-ec.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAU,MAAM,EAAE,QAAQ,EAAkB,MAAM,GAAG,MAAM,eAAe,CAAC;AAE1H,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,WAAW,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAC7G,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;;;;AAC7C;;;GAGG;AAQH,MAAM,OAAO,kBAAkB;IACvB,QAAQ,GAAa,MAAM,CAAC,QAAQ,CAAC,CAAC;IACrC,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;IAC/B,YAAY,GAAgB,MAAM,CAAC,WAAW,CAAC,CAAC;IAChD,aAAa,GAAiB,MAAM,CAAC,YAAY,CAAC,CAAC;IAEpD,cAAc,GAA4B,MAAM,CAAC,KAAK,CAAC,CAAC;IACxD,QAAQ,GAA2B,MAAM,CAAC,CAAC,CAAC,CAAC;IAEpD;;;OAGG;IACH,iBAAiB,CAAC,SAAiB;QAClC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;YAC9D,sCAAsC;YACtC,MAAM,CAAC,QAAQ,CAAC;gBACf,GAAG,EAAE,CAAC;gBACN,IAAI,EAAE,CAAC;gBACP,QAAQ,EAAE,QAAQ;aAClB,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;IACJ,CAAC;IAGD;;OAEG;IAIH,OAAO,CAAW;IAClB;;OAEG;IACM,YAAY,GAAY,IAAI,CAAC;IACtC;;OAEG;IACO,MAAM,GAAG,IAAI,YAAY,EAAU,CAAC;IAErC,YAAY,GAAY,KAAK,CAAC;IAEvC,QAAQ;QACP,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAEnC,CAAC;IACM,2BAA2B,GAAY,KAAK,CAAC;IAC7C,UAAU,GAAY,KAAK,CAAC;IAE3B,YAAY,GAAgB,MAAM,CAAC,WAAW,CAAC,CAAA;IAChD,gBAAgB,GAAG,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,CAAC;IAC9D;QACC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE;YAC9D,IAAI,CAAC,2BAA2B,GAAG,CAAC,CAAC,OAAO,CAAC,2BAA2B,CAAC;YACzE,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC;QACxC,CAAC,CAAC,CAAC;IACJ,CAAC;IACO,MAAM,GAAyB,MAAM,CAAC,oBAAoB,CAAC,CAAA;IAC3D,gBAAgB,GAAqB,MAAM,CAAC,gBAAgB,CAAC,CAAA;IAC7D,MAAM,GAAW,MAAM,CAAC,MAAM,CAAC,CAAA;IACvC;;OAEG;IACI,QAAQ,GAAW,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAA;IAChD,YAAY,CAAC,GAAW;QACvB,IAAI,GAAG,EAAE,CAAC;YACT,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC5B,CAAC;IACF,CAAC;IAED,IAAI,eAAe;QAClB,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC;IACzH,CAAC;IAED,IAAI,WAAW;QACd,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,KAAK,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;IAChF,CAAC;IAED,IAAI,kBAAkB;QACrB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACvB,OAAO,IAAI,CAAC;QACb,CAAC;QAED,MAAM,aAAa,GAAG,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,GAAG,CAAC,CAAC;QACxE,MAAM,SAAS,GAAG,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,QAAQ,EAAE,IAAI,GAAG,CAAC,CAAC;QAExE,uCAAuC;QACvC,IAAI,aAAa,IAAI,CAAC,IAAI,SAAS,IAAI,CAAC,IAAI,SAAS,IAAI,aAAa,EAAE,CAAC;YACxE,OAAO,IAAI,CAAC;QACb,CAAC;QAED,sFAAsF;QACtF,MAAM,QAAQ,GAAG,CAAC,CAAC,aAAa,GAAG,SAAS,CAAC,GAAG,aAAa,CAAC,GAAG,GAAG,CAAC;QAErE,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IAC7B,CAAC;IACD,IAAI,CAAC,KAAc,EAAE,gBAAyB;QAC7C,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,sBAAsB;QAC/D,IAAI,gBAAgB,IAAI,gBAAgB,GAAG,CAAC,EAAE,CAAC;YAC9C,KAAK;gBACJ,CAAC,CAAC,CAAC,OAAO,GAAG,KAAK;oBACjB,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,GAAG,gBAAgB,CAAC;oBAC/C,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;gBACpD,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,GAAG,gBAAgB,CAAC,CAAC;QAClD,CAAC;aAAM,CAAC;YACP,KAAK;gBACJ,CAAC,CAAC,CAAC,OAAO,GAAG,KAAK;oBACjB,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,GAAG,CAAC,CAAC;oBAChC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;gBACpD,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC;QACnC,CAAC;IACF,CAAC;IAED,IAAI,CAAC,gBAAyB;QAC7B,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,sBAAsB;QAC/D,IAAI,gBAAgB,IAAI,gBAAgB,GAAG,CAAC,EAAE,CAAC;YAC9C,OAAO,GAAG,gBAAgB;gBACzB,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,GAAG,gBAAgB,CAAC;gBAC/C,CAAC,CAAC,IAAI,CAAC;QACT,CAAC;aAAM,CAAC;YACP,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACrD,CAAC;IACF,CAAC;IAED,SAAS;QACR,IAAI,IAAI,CAAC,cAAc,EAAE,IAAI,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC;YAAE,OAAO;QAE1D,oDAAoD;QACpD,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACnF,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACpC,OAAO;QACR,CAAC;QACD,kBAAkB;QAClB,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QAC9C,IAAI,CAAC,YAAY,CAAC,KAAK,IAAI,YAAY,CAAC,KAAK,IAAI,CAAC,EAAE,CAAC;YACpD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YACxC,OAAO;QACR,CAAC;QACD,iDAAiD;QACjD,IAAI,IAAI,CAAC,QAAQ,EAAE,GAAG,YAAY,CAAC,KAAK,EAAE,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;YACjD,OAAO;QACR,CAAC;QACD,4DAA4D;QAC5D,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,EAAE,CAAC;YAC7C,OAAO,CAAC,mDAAmD;QAC5D,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC9B,IAAI,CAAC;YACJ,qDAAqD;YACrD,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,YAAY,CAAC,IAAI,CAAC,CAAC;YAC9E,sDAAsD;YACtD,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACtB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACrC,CAAC;QAED,UAAU,CAAC,GAAG,EAAE;YACf,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAChC,CAAC,EAAE,IAAI,CAAC,CAAC;IACV,CAAC;IAED;;OAEG;IACK,gBAAgB,CAAC,QAAgB;QACxC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAClE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACpC,OAAO,KAAK,CAAC;QACd,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QAEzC,wCAAwC;QACxC,MAAM,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC,sBAAsB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC9E,MAAM,aAAa,GAAG,MAAM,CAAC,cAAc,CAAC,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAChE,wEAAwE;QACxE,MAAM,oBAAoB,GAAG,IAAI,CAAC,OAAO,CAAC,oBAAoB;YAC7D,OAAO,CAAC,oBAAoB;YAC5B,MAAM,CAAC;QACR,MAAM,oBAAoB,GAAG,IAAI,CAAC,OAAO,CAAC,oBAAoB;YAC7D,OAAO,CAAC,oBAAoB;YAC5B,CAAC,CAAC;QACH,MAAM,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB;YACrD,OAAO,CAAC,gBAAgB;YACxB,CAAC,CAAC;QAEH,0BAA0B;QAC1B,IAAI,aAAa,GAAG,oBAAoB,EAAE,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,wBAAwB,EAAE,EAAE,QAAQ,EAAE,oBAAoB,EAAE,CAAC,CAAC;YACtF,OAAO,KAAK,CAAC;QACd,CAAC;QAED,0BAA0B;QAC1B,IAAI,aAAa,GAAG,oBAAoB,EAAE,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,wBAAwB,EAAE,EAAE,QAAQ,EAAE,oBAAoB,EAAE,CAAC,CAAC;YACtF,OAAO,KAAK,CAAC;QACd,CAAC;QACD,+BAA+B;QAC/B,IAAI,gBAAgB,IAAI,gBAAgB,GAAG,CAAC,EAAE,CAAC;YAC9C,IAAI,aAAa,GAAG,gBAAgB,KAAK,CAAC,EAAE,CAAC;gBAC5C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,4BAA4B,EAAE;oBACrD,QAAQ,EAAE,gBAAgB;oBAC1B,OAAO,EAAE,aAAa;iBACtB,CAAC,CAAC;gBACH,OAAO,KAAK,CAAC;YACd,CAAC;QACF,CAAC;QACD,uCAAuC;QACvC,IAAI,aAAa,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;YACnC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;YACjD,OAAO,KAAK,CAAC;QACd,CAAC;QACD,OAAO,IAAI,CAAC,CAAC,iCAAiC;IAC/C,CAAC;IACD,UAAU,CAAC,KAAa;QACvB,IAAI,IAAI,CAAC,QAAQ,EAAE,IAAI,KAAK;YAC3B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED,gBAAgB,CAAC,KAAY;QAC5B,MAAM,MAAM,GAAG,KAAK,CAAC,MAA0B,CAAC;QAChD,MAAM,KAAK,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC;QAC5B,qCAAqC;QACrC,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;YACf,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YACzB,qCAAqC;YACrC,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,IAAI,CAAC,OAAO,EAAE,KAAK,IAAI,CAAC,CAAC;YAChF,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QAC3B,CAAC;aAAM,CAAC;YACP,4CAA4C;YAC5C,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACtB,CAAC;IACF,CAAC;wGA1OW,kBAAkB;4FAAlB,kBAAkB,qMCpB/B,q4HAuFI,yDDvEO,YAAY,2VAAE,gBAAgB,oVAAE,UAAU,mOAAE,eAAe,2FAAE,WAAW;;4FAItE,kBAAkB;kBAP9B,SAAS;+BACC,gBAAgB,cACd,IAAI,WACP,CAAC,YAAY,EAAE,gBAAgB,EAAE,UAAU,EAAE,eAAe,EAAE,WAAW,CAAC;wDAmCnF,OAAO;sBAHN,KAAK;uBAAC;wBACN,QAAQ,EAAE,IAAI;qBACd;gBAKQ,YAAY;sBAApB,KAAK;gBAII,MAAM;sBAAf,MAAM;gBAEE,YAAY;sBAApB,KAAK","sourcesContent":["import { Component, EventEmitter, inject, Input, OnInit, Output, Injector, WritableSignal, signal, } from '@angular/core';\nimport { Product } from '../../interfaces';\nimport { CoreConstantsService } from '../../constants';\nimport { AnalyticsService, ChannelService, AuthService, CartService, ToastService } from '../../ec-services';\nimport { Router, RouterLink } from '@angular/router';\nimport { CommonModule } from '@angular/common';\nimport { PriceEcComponent } from \"../widgets-ec/price-ec/price-ec.component\";\nimport { TranslateModule } from '@ngx-translate/core';\nimport { FormsModule } from '@angular/forms';\n/**\n * Componente que se encarga de manejar un producto.\n * @class ProductEcComponent\n */\n@Component({\n\tselector: 'app-product-ec',\n\tstandalone: true,\n\timports: [CommonModule, PriceEcComponent, RouterLink, TranslateModule, FormsModule],\n\ttemplateUrl: './product-ec.component.html',\n\tstyleUrl: './product-ec.component.scss'\n})\nexport class ProductEcComponent implements OnInit {\n\tpublic injector: Injector = inject(Injector);\n\tprivate routerService = inject(Router);\n\tprivate _cartService: CartService = inject(CartService);\n\tprivate _toastService: ToastService = inject(ToastService);\n\n\tpublic isAddingToCart: WritableSignal<boolean> = signal(false);\n\tpublic quantity: WritableSignal<number> = signal(1);\n\n\t/**\n\t * Navega al detalle del producto y sube al inicio de la página\n\t * @param productId ID del producto\n\t */\n\tnavigateToProduct(productId: string): void {\n\t\tthis.routerService.navigate(['/product', productId]).then(() => {\n\t\t\t// Scroll suave al inicio de la página\n\t\t\twindow.scrollTo({\n\t\t\t\ttop: 0,\n\t\t\t\tleft: 0,\n\t\t\t\tbehavior: 'smooth'\n\t\t\t});\n\t\t});\n\t}\n\n\n\t/**\n\t * Datos del producto.\n\t */\n\t@Input({\n\t\trequired: true\n\t})\n\tproduct!: Product;\n\t/**\n\t * Se usa para saber si el producto es de tipo Box o no y definir la vista adecuada.\n\t */\n\t@Input() isProductBox: boolean = true;\n\t/**\n\t * Constantes del core\n\t */\n\t@Output() loaded = new EventEmitter<number>();\n\n\t@Input() isCollection: boolean = false;\n\n\tngOnInit() {\n\t\tthis.loaded.emit(this.product.id);\n\n\t}\n\tpublic showPricesOnlyToLoggedUsers: boolean = false;\n\tpublic hidePrices: boolean = false;\n\n\tprivate _authService: AuthService = inject(AuthService)\n\tpublic isAuthenticated$ = this._authService.isAuthenticated();\n\tconstructor() {\n\t\tthis.injector.get(ChannelService).channel$.subscribe(channel => {\n\t\t\tthis.showPricesOnlyToLoggedUsers = !!channel.showPricesOnlyToLoggedUsers;\n\t\t\tthis.hidePrices = !!channel.hidePrices;\n\t\t});\n\t}\n\tprivate consts: CoreConstantsService = inject(CoreConstantsService)\n\tprivate analyticsService: AnalyticsService = inject(AnalyticsService)\n\tprivate router: Router = inject(Router)\n\t/**\n\t * URL para las imagenes del producto.\n\t */\n\tpublic mediaUrl: string = this.consts.mediaUrl()\n\topenWhatsApp(url: string): void {\n\t\tif (url) {\n\t\t\twindow.open(url, '_blank');\n\t\t}\n\t}\n\n\tget shouldShowPrice(): boolean {\n\t\treturn !this.product?.special_mark || this.product.special_mark.length === 0 || this.product.special_mark[0]?.showPrice;\n\t}\n\n\tget hasDiscount(): boolean {\n\t\treturn this.product.saleprice && this.product.saleprice !== this.product.price;\n\t}\n\n\tget discountPercentage(): number | null {\n\t\tif (!this.hasDiscount) {\n\t\t\treturn null;\n\t\t}\n\n\t\tconst originalPrice = parseFloat(this.product.price?.toString() || '0');\n\t\tconst salePrice = parseFloat(this.product.saleprice?.toString() || '0');\n\n\t\t// Validar que los precios sean válidos\n\t\tif (originalPrice <= 0 || salePrice <= 0 || salePrice >= originalPrice) {\n\t\t\treturn null;\n\t\t}\n\n\t\t// Calcular el porcentaje: ((precio_original - precio_oferta) / precio_original) * 100\n\t\tconst discount = ((originalPrice - salePrice) / originalPrice) * 100;\n\n\t\treturn Math.round(discount);\n\t}\n\tplus(stock?: number, multipleQuantity?: number) {\n\t\tconst current = Number(this.quantity()); // <-- fuerza a número\n\t\tif (multipleQuantity && multipleQuantity > 0) {\n\t\t\tstock\n\t\t\t\t? (current < stock\n\t\t\t\t\t? this.quantity.set(current + multipleQuantity)\n\t\t\t\t\t: this._toastService.show('out-of-stock-actually'))\n\t\t\t\t: this.quantity.set(current + multipleQuantity);\n\t\t} else {\n\t\t\tstock\n\t\t\t\t? (current < stock\n\t\t\t\t\t? this.quantity.set(current + 1)\n\t\t\t\t\t: this._toastService.show('out-of-stock-actually'))\n\t\t\t\t: this.quantity.set(current + 1);\n\t\t}\n\t}\n\n\tless(multipleQuantity?: number) {\n\t\tconst current = Number(this.quantity()); // <-- fuerza a número\n\t\tif (multipleQuantity && multipleQuantity > 0) {\n\t\t\tcurrent > multipleQuantity\n\t\t\t\t? this.quantity.set(current - multipleQuantity)\n\t\t\t\t: null;\n\t\t} else {\n\t\t\tcurrent > 1 ? this.quantity.set(current - 1) : null;\n\t\t}\n\t}\n\n\taddToCart() {\n\t\tif (this.isAddingToCart() || this.quantity() <= 0) return;\n\n\t\t// Verificar que tenemos el producto y sus variantes\n\t\tif (!this.product || !this.product.variants || this.product.variants.length === 0) {\n\t\t\tthis._toastService.show('cant-buy');\n\t\t\treturn;\n\t\t}\n\t\t// Verificar stock\n\t\tconst firstVariant = this.product.variants[0];\n\t\tif (!firstVariant.stock || firstVariant.stock <= 0) {\n\t\t\tthis._toastService.show('out-of-stock');\n\t\t\treturn;\n\t\t}\n\t\t// Verificar que no se supere el stock disponible\n\t\tif (this.quantity() > firstVariant.stock) {\n\t\t\tthis._toastService.show('out-of-stock-actually');\n\t\t\treturn;\n\t\t}\n\t\t// NUEVAS VALIDACIONES: Verificar restricciones del producto\n\t\tif (!this.validateQuantity(this.quantity())) {\n\t\t\treturn; // La validación ya mostró el toast correspondiente\n\t\t}\n\t\tthis.isAddingToCart.set(true);\n\t\ttry {\n\t\t\t// Agregar al carrito usando CartService directamente\n\t\t\tthis._cartService.addToCart(this.product, this.quantity(), firstVariant.code);\n\t\t\t// Resetear cantidad a 1 después de agregar al carrito\n\t\t\tthis.quantity.set(1);\n\t\t} catch (error) {\n\t\t\tthis._toastService.show('cant-buy');\n\t\t}\n\n\t\tsetTimeout(() => {\n\t\t\tthis.isAddingToCart.set(false);\n\t\t}, 2000);\n\t}\n\n\t/**\n\t * Valida las restricciones de cantidad del producto\n\t */\n\tprivate validateQuantity(quantity: number): boolean {\n\t\tif (!this.product.variants || this.product.variants.length === 0) {\n\t\t\tthis._toastService.show('cant-buy');\n\t\t\treturn false;\n\t\t}\n\n\t\tconst variant = this.product.variants[0];\n\n\t\t// Obtener cantidad actual en el carrito\n\t\tconst actualQuantity = this._cartService.getCountFromItemInCart(variant.code);\n\t\tconst totalQuantity = Number(actualQuantity) + Number(quantity);\n\t\t// Obtener restricciones del producto/variante (con valores por defecto)\n\t\tconst maximumItemsQuantity = this.product.maximumItemsQuantity ||\n\t\t\tvariant.maximumItemsQuantity ||\n\t\t\t999999;\n\t\tconst minimumItemsQuantity = this.product.minimumItemsQuantity ||\n\t\t\tvariant.minimumItemsQuantity ||\n\t\t\t1;\n\t\tconst multipleQuantity = this.product.multipleQuantity ||\n\t\t\tvariant.multipleQuantity ||\n\t\t\t1;\n\n\t\t// Validar cantidad máxima\n\t\tif (totalQuantity > maximumItemsQuantity) {\n\t\t\tthis._toastService.show('maximum-items-quantity', { quantity: maximumItemsQuantity });\n\t\t\treturn false;\n\t\t}\n\n\t\t// Validar cantidad mínima\n\t\tif (totalQuantity < minimumItemsQuantity) {\n\t\t\tthis._toastService.show('minimum-items-quantity', { quantity: minimumItemsQuantity });\n\t\t\treturn false;\n\t\t}\n\t\t// Validar múltiplo de cantidad\n\t\tif (multipleQuantity && multipleQuantity > 1) {\n\t\t\tif (totalQuantity % multipleQuantity !== 0) {\n\t\t\t\tthis._toastService.show('multiple-quantity-required', {\n\t\t\t\t\tmultiple: multipleQuantity,\n\t\t\t\t\tcurrent: totalQuantity\n\t\t\t\t});\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\t\t// Validar que no exceda el stock total\n\t\tif (totalQuantity > variant.stock) {\n\t\t\tthis._toastService.show('out-of-stock-actually');\n\t\t\treturn false;\n\t\t}\n\t\treturn true; // Todas las validaciones pasaron\n\t}\n\tcheckStock(stock: number) {\n\t\tif (this.quantity() >= stock)\n\t\t\tthis.quantity.set(stock);\n\t}\n\n\tonQuantityChange(event: Event) {\n\t\tconst target = event.target as HTMLInputElement;\n\t\tconst value = +target.value;\n\t\t// Validar que el valor sea mayor a 0\n\t\tif (value > 0) {\n\t\t\tthis.quantity.set(value);\n\t\t\t// Validar contra el stock disponible\n\t\t\tconst maxStock = this.product?.variants?.[0]?.stock || this.product?.stock || 0;\n\t\t\tthis.checkStock(maxStock);\n\t\t} else {\n\t\t\t// Si el valor es 0 o negativo, resetear a 1\n\t\t\tthis.quantity.set(1);\n\t\t}\n\t}\n}\n","<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none producto\">\n    <!-- Marca especial y descuento -->\n    <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\n        class=\"marcas\">\n        <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\n        <ng-container *ngIf=\"shouldShowPrice\">\n            <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\n                [ecProductOff]=\"product\">\n            </div>\n        </ng-container>\n    </div> -->\n\n    <!-- Imagen del producto -->\n    <div class=\"foto\">\n        @if(product.picturesdefault){\n        @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\n        <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\n        <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\n        } @else {\n        <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\n        }\n        }\n    </div>\n    <!-- Precio -->\n\n\n    <!-- Nombre del producto -->\n    <h6 class=\"title\">{{ product.name | titlecase }}</h6>\n\n    <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\n\n    @if (shouldShowPrice) {\n        <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\n    }\n    @if(!hidePrices){\n    @if(!showPricesOnlyToLoggedUsers || isAuthenticated$){\n\n    <div class=\"fixBottom\">\n\n        <!-- Botón de acciones -->\n        <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\n        <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\n        @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\n        'standard') {\n        <button class=\"btn standard\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n            <ng-container *ngIf=\"isCollection; else normalText\">\n                <span> {{(\"buy\" | translate) | uppercase}} </span>\n            </ng-container>\n            <ng-template #normalText>\n                {{(\"buy\" | translate) | uppercase}}\n            </ng-template>\n        </button>\n        }@else {\n        <!-- Caso 1: Agotado o Disponible muy pronto -->\n        @if (product.special_mark[0]?.type === 'out_of_stock' || product.special_mark[0]?.type === 'coming_soon') {\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n            @if(isCollection){\n            <span>{{ product.special_mark[0].name | uppercase }} </span>\n            }@else {\n            {{ product.special_mark[0]?.name | uppercase }}\n            }\n        </button>}\n        <!-- Caso 2: Contacto por WhatsApp -->\n        @if (product.special_mark[0].type === 'whatsapp_contact') {\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\n            (click)=\"openWhatsApp(product.special_mark[0]?.whatsappContact)\">\n            @if(isCollection){\n            <span>{{ product.special_mark[0]?.name | uppercase }}</span>\n            }@else {\n            {{ product.special_mark[0]?.name | uppercase }}\n            }\n\n        </button>\n        }\n        <!-- Caso 3: Solicitar más información -->\n        @if (product.special_mark[0]?.type === 'more_info') {\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\n            @if(isCollection){\n            <span>{{ product.special_mark[0]?.name | uppercase }}</span>\n            }@else {\n            {{ product.special_mark[0]?.name | uppercase }}\n            }\n        </button>\n        }\n        }\n    </div>\n    }}\n</a>"]}
@@ -1,5 +1,6 @@
1
1
  import { Component, inject } from '@angular/core';
2
2
  import { AuthService, CartService, ChannelService, ToastService } from '../../ec-services';
3
+ import { PriceVisibilityService } from '../../ec-services/price-visibility.service';
3
4
  import { CoreConstantsService } from '../../constants';
4
5
  import { Router, RouterLink } from '@angular/router';
5
6
  import { AsyncPipe } from '@angular/common';
@@ -14,13 +15,13 @@ export class SidebarEcComponent {
14
15
  _router = inject(Router);
15
16
  _toastrService = inject(ToastService);
16
17
  _channelService = inject(ChannelService);
18
+ priceVisibility = inject(PriceVisibilityService);
17
19
  user = null;
18
20
  mediaUrl = this._consts.mediaUrl();
19
21
  promotions = [];
20
22
  variantsToShow = ['TALLE', 'COLOR'];
21
23
  hideDiscounts = false;
22
24
  hideTaxes = false;
23
- creditAccountShowPrices = null;
24
25
  cartItems$ = this._cartService.cartItems$;
25
26
  subTotalAmount$ = this._cartService.getSubTotalAmount();
26
27
  totalPromotionAmount$ = this._cartService.getTotalPromotionAmount();
@@ -35,9 +36,6 @@ export class SidebarEcComponent {
35
36
  this.hideDiscounts = channel?.hideDiscounts ?? false;
36
37
  this.hideTaxes = channel?.hideTaxes ?? false;
37
38
  });
38
- this._cartService.showPrice$.subscribe((showPrice) => {
39
- this.creditAccountShowPrices = showPrice;
40
- });
41
39
  }
42
40
  actualizarCantidad(_t13, arg1, arg2, arg3, arg4) {
43
41
  throw new Error('Method not implemented.');
@@ -55,10 +53,10 @@ export class SidebarEcComponent {
55
53
  throw new Error('Method not implemented.');
56
54
  }
57
55
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SidebarEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
58
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: SidebarEcComponent, isStandalone: true, selector: "app-sidebar-ec", ngImport: i0, template: "<div class=\"nav nav-sidebar py-4 mx-0 position-relative text-center shadow-sm border-bottom d-flex justify-content-center\">\n <h2 class=\"row text-center\">Mi pedido</h2>\n <div class=\" me-3 closeCart position-absolute end-0\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\n <i class=\"fa fa-times-circle fs-5\" aria-hidden=\"true\"></i>\n </div>\n</div>\n\n\n@if(cartItems$ | async; as items){\n @if(items.length > 0){\n <!-- PRODUCTO -->\n <div class=\"d-flex flex-column mb-4 items border-bottom\">\n @for(item of items; track $index; let i = $index){\n <div class=\"productoCarrito mt-1 mb-2 w-100\">\n <app-cart-item-ec [inSidebar]=\"true\" [item]=\"item\"></app-cart-item-ec>\n </div>\n }\n </div>\n <div class=\"d-flex mx-4 justify-content-between mt-2 \">\n <p class=\"fw-bold\">Subtotal</p>\n <p class=\"fw-700\">{{ (subTotalAmount$ | async) | ecCurrencySymbol}}</p>\n </div>\n <div class=\"mx-4 bordeBot py-2\">\n <app-coupon-ec></app-coupon-ec>\n </div>\n <div class=\"d-flex mx-4 justify-content-between bordeBot2 mt-2\">\n <p class=\"fw-bold\">Descuentos:</p>\n <p>{{ (totalPromotionAmount$ | async) |ecCurrencySymbol }}</p>\n </div>\n\n <div class=\"d-flex mx-4 justify-content-between bordeBot2 pt-2\">\n <!-- @if(this._cartService.cart.source.value.couponCode){\n <a class=\"quitar-cupon text-dark\" role=\"button\"\n (click)=\"removeCoupon()\">(Quitar cup\u00F3n)</a>\n } -->\n </div>\n <div class=\"d-flex mx-4 justify-content-between mb-3 mt-2\">\n <p class=\"fw-bold h5\">TOTAL</p>\n <p class=\"fw-bold h5\">{{(totalAmount$ | async) | ecCurrencySymbol}}</p>\n </div>\n <div class=\"d-flex flex-column mx-4 justify-content-between mb-3\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\n <a [routerLink]=\"['/cart']\" class=\"btn btnPedido mb-2\">FINALIZAR PEDIDO</a>\n <a [routerLink]=\"['/collection']\" class=\"btn btnSeguir mb-3\">SEGUIR COMPRANDO</a>\n </div>\n\n\n } @else {\n <div class=\"container-lg px-lg-0 px-md-4 my-5\">\n <div class=\"row\">\n <div class=\"col-12\">\n <h5 class=\"text-center mb-sm-4 text-uppercase\"> \u00B7 Su carrito se\n encuentra vac\u00EDo \u00B7 </h5>\n </div>\n </div>\n </div>\n }\n}", styles: [""], dependencies: [{ kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: CouponEcComponent, selector: "app-coupon-ec" }, { kind: "component", type: CartItemEcComponent, selector: "app-cart-item-ec", inputs: ["item", "inSidebar"] }, { kind: "pipe", type: EcCurrencySymbolPipe, name: "ecCurrencySymbol" }] });
56
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: SidebarEcComponent, isStandalone: true, selector: "app-sidebar-ec", ngImport: i0, template: "<div class=\"nav nav-sidebar py-4 mx-0 position-relative text-center shadow-sm border-bottom d-flex justify-content-center\">\n <h2 class=\"row text-center\">Mi pedido</h2>\n <div class=\" me-3 closeCart position-absolute end-0\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\n <i class=\"fa fa-times-circle fs-5\" aria-hidden=\"true\"></i>\n </div>\n</div>\n\n\n@if(cartItems$ | async; as items){\n @if(items.length > 0){\n <!-- PRODUCTO -->\n <div class=\"d-flex flex-column mb-4 items border-bottom\">\n @for(item of items; track $index; let i = $index){\n <div class=\"productoCarrito mt-1 mb-2 w-100\">\n <app-cart-item-ec [inSidebar]=\"true\" [item]=\"item\"></app-cart-item-ec>\n </div>\n }\n </div>\n @if (priceVisibility.canShowPrices()) {\n <div class=\"d-flex mx-4 justify-content-between mt-2 \">\n <p class=\"fw-bold\">Subtotal</p>\n <p class=\"fw-700\">{{ (subTotalAmount$ | async) | ecCurrencySymbol}}</p>\n </div>\n <div class=\"mx-4 bordeBot py-2\">\n <app-coupon-ec></app-coupon-ec>\n </div>\n <div class=\"d-flex mx-4 justify-content-between bordeBot2 mt-2\">\n <p class=\"fw-bold\">Descuentos:</p>\n <p>{{ (totalPromotionAmount$ | async) |ecCurrencySymbol }}</p>\n </div>\n\n <div class=\"d-flex mx-4 justify-content-between bordeBot2 pt-2\">\n <!-- @if(this._cartService.cart.source.value.couponCode){\n <a class=\"quitar-cupon text-dark\" role=\"button\"\n (click)=\"removeCoupon()\">(Quitar cup\u00F3n)</a>\n } -->\n </div>\n <div class=\"d-flex mx-4 justify-content-between mb-3 mt-2\">\n <p class=\"fw-bold h5\">TOTAL</p>\n <p class=\"fw-bold h5\">{{(totalAmount$ | async) | ecCurrencySymbol}}</p>\n </div>\n }\n <div class=\"d-flex flex-column mx-4 justify-content-between mb-3\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\n <a [routerLink]=\"['/cart']\" class=\"btn btnPedido mb-2\">FINALIZAR PEDIDO</a>\n <a [routerLink]=\"['/collection']\" class=\"btn btnSeguir mb-3\">SEGUIR COMPRANDO</a>\n </div>\n\n\n } @else {\n <div class=\"container-lg px-lg-0 px-md-4 my-5\">\n <div class=\"row\">\n <div class=\"col-12\">\n <h5 class=\"text-center mb-sm-4 text-uppercase\"> \u00B7 Su carrito se\n encuentra vac\u00EDo \u00B7 </h5>\n </div>\n </div>\n </div>\n }\n}", styles: [""], dependencies: [{ kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: CouponEcComponent, selector: "app-coupon-ec" }, { kind: "component", type: CartItemEcComponent, selector: "app-cart-item-ec", inputs: ["item", "inSidebar"] }, { kind: "pipe", type: EcCurrencySymbolPipe, name: "ecCurrencySymbol" }] });
59
57
  }
60
58
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SidebarEcComponent, decorators: [{
61
59
  type: Component,
62
- args: [{ selector: 'app-sidebar-ec', standalone: true, imports: [RouterLink, AsyncPipe, CouponEcComponent, CartItemEcComponent, EcCurrencySymbolPipe, CouponEcComponent], template: "<div class=\"nav nav-sidebar py-4 mx-0 position-relative text-center shadow-sm border-bottom d-flex justify-content-center\">\n <h2 class=\"row text-center\">Mi pedido</h2>\n <div class=\" me-3 closeCart position-absolute end-0\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\n <i class=\"fa fa-times-circle fs-5\" aria-hidden=\"true\"></i>\n </div>\n</div>\n\n\n@if(cartItems$ | async; as items){\n @if(items.length > 0){\n <!-- PRODUCTO -->\n <div class=\"d-flex flex-column mb-4 items border-bottom\">\n @for(item of items; track $index; let i = $index){\n <div class=\"productoCarrito mt-1 mb-2 w-100\">\n <app-cart-item-ec [inSidebar]=\"true\" [item]=\"item\"></app-cart-item-ec>\n </div>\n }\n </div>\n <div class=\"d-flex mx-4 justify-content-between mt-2 \">\n <p class=\"fw-bold\">Subtotal</p>\n <p class=\"fw-700\">{{ (subTotalAmount$ | async) | ecCurrencySymbol}}</p>\n </div>\n <div class=\"mx-4 bordeBot py-2\">\n <app-coupon-ec></app-coupon-ec>\n </div>\n <div class=\"d-flex mx-4 justify-content-between bordeBot2 mt-2\">\n <p class=\"fw-bold\">Descuentos:</p>\n <p>{{ (totalPromotionAmount$ | async) |ecCurrencySymbol }}</p>\n </div>\n\n <div class=\"d-flex mx-4 justify-content-between bordeBot2 pt-2\">\n <!-- @if(this._cartService.cart.source.value.couponCode){\n <a class=\"quitar-cupon text-dark\" role=\"button\"\n (click)=\"removeCoupon()\">(Quitar cup\u00F3n)</a>\n } -->\n </div>\n <div class=\"d-flex mx-4 justify-content-between mb-3 mt-2\">\n <p class=\"fw-bold h5\">TOTAL</p>\n <p class=\"fw-bold h5\">{{(totalAmount$ | async) | ecCurrencySymbol}}</p>\n </div>\n <div class=\"d-flex flex-column mx-4 justify-content-between mb-3\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\n <a [routerLink]=\"['/cart']\" class=\"btn btnPedido mb-2\">FINALIZAR PEDIDO</a>\n <a [routerLink]=\"['/collection']\" class=\"btn btnSeguir mb-3\">SEGUIR COMPRANDO</a>\n </div>\n\n\n } @else {\n <div class=\"container-lg px-lg-0 px-md-4 my-5\">\n <div class=\"row\">\n <div class=\"col-12\">\n <h5 class=\"text-center mb-sm-4 text-uppercase\"> \u00B7 Su carrito se\n encuentra vac\u00EDo \u00B7 </h5>\n </div>\n </div>\n </div>\n }\n}" }]
60
+ args: [{ selector: 'app-sidebar-ec', standalone: true, imports: [RouterLink, AsyncPipe, CouponEcComponent, CartItemEcComponent, EcCurrencySymbolPipe, CouponEcComponent], template: "<div class=\"nav nav-sidebar py-4 mx-0 position-relative text-center shadow-sm border-bottom d-flex justify-content-center\">\n <h2 class=\"row text-center\">Mi pedido</h2>\n <div class=\" me-3 closeCart position-absolute end-0\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\n <i class=\"fa fa-times-circle fs-5\" aria-hidden=\"true\"></i>\n </div>\n</div>\n\n\n@if(cartItems$ | async; as items){\n @if(items.length > 0){\n <!-- PRODUCTO -->\n <div class=\"d-flex flex-column mb-4 items border-bottom\">\n @for(item of items; track $index; let i = $index){\n <div class=\"productoCarrito mt-1 mb-2 w-100\">\n <app-cart-item-ec [inSidebar]=\"true\" [item]=\"item\"></app-cart-item-ec>\n </div>\n }\n </div>\n @if (priceVisibility.canShowPrices()) {\n <div class=\"d-flex mx-4 justify-content-between mt-2 \">\n <p class=\"fw-bold\">Subtotal</p>\n <p class=\"fw-700\">{{ (subTotalAmount$ | async) | ecCurrencySymbol}}</p>\n </div>\n <div class=\"mx-4 bordeBot py-2\">\n <app-coupon-ec></app-coupon-ec>\n </div>\n <div class=\"d-flex mx-4 justify-content-between bordeBot2 mt-2\">\n <p class=\"fw-bold\">Descuentos:</p>\n <p>{{ (totalPromotionAmount$ | async) |ecCurrencySymbol }}</p>\n </div>\n\n <div class=\"d-flex mx-4 justify-content-between bordeBot2 pt-2\">\n <!-- @if(this._cartService.cart.source.value.couponCode){\n <a class=\"quitar-cupon text-dark\" role=\"button\"\n (click)=\"removeCoupon()\">(Quitar cup\u00F3n)</a>\n } -->\n </div>\n <div class=\"d-flex mx-4 justify-content-between mb-3 mt-2\">\n <p class=\"fw-bold h5\">TOTAL</p>\n <p class=\"fw-bold h5\">{{(totalAmount$ | async) | ecCurrencySymbol}}</p>\n </div>\n }\n <div class=\"d-flex flex-column mx-4 justify-content-between mb-3\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\n <a [routerLink]=\"['/cart']\" class=\"btn btnPedido mb-2\">FINALIZAR PEDIDO</a>\n <a [routerLink]=\"['/collection']\" class=\"btn btnSeguir mb-3\">SEGUIR COMPRANDO</a>\n </div>\n\n\n } @else {\n <div class=\"container-lg px-lg-0 px-md-4 my-5\">\n <div class=\"row\">\n <div class=\"col-12\">\n <h5 class=\"text-center mb-sm-4 text-uppercase\"> \u00B7 Su carrito se\n encuentra vac\u00EDo \u00B7 </h5>\n </div>\n </div>\n </div>\n }\n}" }]
63
61
  }] });
64
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/sidebar-ec/sidebar-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/sidebar-ec/sidebar-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject } from '@angular/core';\nimport { User } from '../../classes';\nimport { AuthService, CartService, ChannelService, ToastService } from '../../ec-services';\nimport { CoreConstantsService } from '../../constants';\nimport { Router, RouterLink } from '@angular/router';\nimport { AsyncPipe, TitleCasePipe } from '@angular/common';\nimport { EcCurrencySymbolPipe } from '../../ec-pipe';\nimport { CouponEcComponent } from '../coupon-ec/coupon-ec.component';\nimport { CartItemEcComponent } from '../cart-ec';\n\n@Component({\n    selector: 'app-sidebar-ec',\n    standalone: true,\n    imports: [RouterLink, AsyncPipe, CouponEcComponent, CartItemEcComponent, EcCurrencySymbolPipe, CouponEcComponent],\n    templateUrl: './sidebar-ec.component.html',\n    styleUrl: './sidebar-ec.component.scss'\n})\nexport class SidebarEcComponent {\n\n    private _cartService: CartService = inject(CartService)\n    private _consts: CoreConstantsService = inject(CoreConstantsService)\n    private _authService: AuthService = inject(AuthService)\n    private _router: Router = inject(Router)\n    private _toastrService: ToastService = inject(ToastService)\n    private _channelService: ChannelService = inject(ChannelService)\n\n    public user: User | null = null\n    public mediaUrl: string = this._consts.mediaUrl();\n    public promotions = [];\n    public variantsToShow: string[] = ['TALLE', 'COLOR'];\n    public hideDiscounts: boolean = false;\n    public hideTaxes: boolean = false;\n    public creditAccountShowPrices: boolean | null = null;\n\n    public cartItems$ = this._cartService.cartItems$;\n    public subTotalAmount$ = this._cartService.getSubTotalAmount();\n\tpublic totalPromotionAmount$ = this._cartService.getTotalPromotionAmount();\n\tpublic taxesAmount$ = this._cartService.getTaxesAmount();\n\tpublic totalAmount$ = this._cartService.getTotalAmount();\n\n    ngOnInit() {\n        this._cartService.promotions$.subscribe(promotions => this.promotions = promotions);\n        this._authService.getUserProfile().subscribe(u => {\n            this.user = u\n        })\n        this._channelService.channel$.subscribe(channel => {\n            this.hideDiscounts = channel?.hideDiscounts ?? false;\n            this.hideTaxes = channel?.hideTaxes ?? false;\n        });\n\n        this._cartService.showPrice$.subscribe((showPrice) => {\n            this.creditAccountShowPrices = showPrice;\n        });\n    }\n    actualizarCantidad(_t13: any, arg1?: any, arg2?: any, arg3?: any, arg4?: any) {\n        throw new Error('Method not implemented.');\n    }\n\n    getVariants(_t8: any): any {\n        throw new Error('Method not implemented.');\n    }\n    getTotalAmount(): import(\"rxjs\").Observable<any> | Promise<any> | import(\"rxjs\").Subscribable<any> {\n        throw new Error('Method not implemented.');\n    }\n    removeCoupon() {\n        throw new Error('Method not implemented.');\n    }\n\n    deleteCartItem(_t8: any, arg1: boolean) {\n        throw new Error('Method not implemented.');\n    }\n}\n","<div class=\"nav nav-sidebar py-4 mx-0 position-relative text-center shadow-sm border-bottom d-flex justify-content-center\">\n    <h2 class=\"row text-center\">Mi pedido</h2>\n    <div class=\" me-3 closeCart position-absolute end-0\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\n        <i class=\"fa fa-times-circle fs-5\" aria-hidden=\"true\"></i>\n    </div>\n</div>\n\n\n@if(cartItems$ | async; as items){\n    @if(items.length > 0){\n    <!-- PRODUCTO -->\n    <div class=\"d-flex flex-column mb-4 items border-bottom\">\n        @for(item of items; track $index; let i = $index){\n        <div class=\"productoCarrito mt-1 mb-2 w-100\">\n            <app-cart-item-ec [inSidebar]=\"true\" [item]=\"item\"></app-cart-item-ec>\n        </div>\n        }\n    </div>\n    <div class=\"d-flex mx-4 justify-content-between mt-2 \">\n        <p class=\"fw-bold\">Subtotal</p>\n        <p class=\"fw-700\">{{ (subTotalAmount$ | async) | ecCurrencySymbol}}</p>\n    </div>\n    <div class=\"mx-4 bordeBot py-2\">\n        <app-coupon-ec></app-coupon-ec>\n    </div>\n    <div class=\"d-flex mx-4 justify-content-between bordeBot2 mt-2\">\n        <p class=\"fw-bold\">Descuentos:</p>\n        <p>{{ (totalPromotionAmount$ | async) |ecCurrencySymbol }}</p>\n    </div>\n\n    <div class=\"d-flex mx-4 justify-content-between bordeBot2 pt-2\">\n        <!--  @if(this._cartService.cart.source.value.couponCode){\n                <a class=\"quitar-cupon text-dark\" role=\"button\"\n                (click)=\"removeCoupon()\">(Quitar cupón)</a>\n            } -->\n    </div>\n    <div class=\"d-flex mx-4 justify-content-between mb-3 mt-2\">\n        <p class=\"fw-bold h5\">TOTAL</p>\n     <p class=\"fw-bold h5\">{{(totalAmount$ | async) | ecCurrencySymbol}}</p>\n    </div>\n    <div class=\"d-flex flex-column mx-4 justify-content-between mb-3\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\n        <a [routerLink]=\"['/cart']\" class=\"btn btnPedido mb-2\">FINALIZAR PEDIDO</a>\n        <a [routerLink]=\"['/collection']\" class=\"btn btnSeguir mb-3\">SEGUIR COMPRANDO</a>\n    </div>\n\n\n    } @else {\n    <div class=\"container-lg px-lg-0 px-md-4 my-5\">\n        <div class=\"row\">\n            <div class=\"col-12\">\n                <h5 class=\"text-center mb-sm-4 text-uppercase\"> · Su carrito se\n                    encuentra vacío · </h5>\n            </div>\n        </div>\n    </div>\n    }\n}"]}
62
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/sidebar-ec/sidebar-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/sidebar-ec/sidebar-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject } from '@angular/core';\nimport { User } from '../../classes';\nimport { AuthService, CartService, ChannelService, ToastService } from '../../ec-services';\nimport { PriceVisibilityService } from '../../ec-services/price-visibility.service';\nimport { CoreConstantsService } from '../../constants';\nimport { Router, RouterLink } from '@angular/router';\nimport { AsyncPipe, TitleCasePipe } from '@angular/common';\nimport { EcCurrencySymbolPipe } from '../../ec-pipe';\nimport { CouponEcComponent } from '../coupon-ec/coupon-ec.component';\nimport { CartItemEcComponent } from '../cart-ec';\n\n@Component({\n    selector: 'app-sidebar-ec',\n    standalone: true,\n    imports: [RouterLink, AsyncPipe, CouponEcComponent, CartItemEcComponent, EcCurrencySymbolPipe, CouponEcComponent],\n    templateUrl: './sidebar-ec.component.html',\n    styleUrl: './sidebar-ec.component.scss'\n})\nexport class SidebarEcComponent {\n\n    private _cartService: CartService = inject(CartService)\n    private _consts: CoreConstantsService = inject(CoreConstantsService)\n    private _authService: AuthService = inject(AuthService)\n    private _router: Router = inject(Router)\n    private _toastrService: ToastService = inject(ToastService)\n    private _channelService: ChannelService = inject(ChannelService)\n    public readonly priceVisibility = inject(PriceVisibilityService);\n\n    public user: User | null = null\n    public mediaUrl: string = this._consts.mediaUrl();\n    public promotions = [];\n    public variantsToShow: string[] = ['TALLE', 'COLOR'];\n    public hideDiscounts: boolean = false;\n    public hideTaxes: boolean = false;\n\n    public cartItems$ = this._cartService.cartItems$;\n    public subTotalAmount$ = this._cartService.getSubTotalAmount();\n\tpublic totalPromotionAmount$ = this._cartService.getTotalPromotionAmount();\n\tpublic taxesAmount$ = this._cartService.getTaxesAmount();\n\tpublic totalAmount$ = this._cartService.getTotalAmount();\n\n    ngOnInit() {\n        this._cartService.promotions$.subscribe(promotions => this.promotions = promotions);\n        this._authService.getUserProfile().subscribe(u => {\n            this.user = u\n        })\n        this._channelService.channel$.subscribe(channel => {\n            this.hideDiscounts = channel?.hideDiscounts ?? false;\n            this.hideTaxes = channel?.hideTaxes ?? false;\n        });\n    }\n    actualizarCantidad(_t13: any, arg1?: any, arg2?: any, arg3?: any, arg4?: any) {\n        throw new Error('Method not implemented.');\n    }\n\n    getVariants(_t8: any): any {\n        throw new Error('Method not implemented.');\n    }\n    getTotalAmount(): import(\"rxjs\").Observable<any> | Promise<any> | import(\"rxjs\").Subscribable<any> {\n        throw new Error('Method not implemented.');\n    }\n    removeCoupon() {\n        throw new Error('Method not implemented.');\n    }\n\n    deleteCartItem(_t8: any, arg1: boolean) {\n        throw new Error('Method not implemented.');\n    }\n}\n","<div class=\"nav nav-sidebar py-4 mx-0 position-relative text-center shadow-sm border-bottom d-flex justify-content-center\">\n    <h2 class=\"row text-center\">Mi pedido</h2>\n    <div class=\" me-3 closeCart position-absolute end-0\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\n        <i class=\"fa fa-times-circle fs-5\" aria-hidden=\"true\"></i>\n    </div>\n</div>\n\n\n@if(cartItems$ | async; as items){\n    @if(items.length > 0){\n    <!-- PRODUCTO -->\n    <div class=\"d-flex flex-column mb-4 items border-bottom\">\n        @for(item of items; track $index; let i = $index){\n        <div class=\"productoCarrito mt-1 mb-2 w-100\">\n            <app-cart-item-ec [inSidebar]=\"true\" [item]=\"item\"></app-cart-item-ec>\n        </div>\n        }\n    </div>\n    @if (priceVisibility.canShowPrices()) {\n        <div class=\"d-flex mx-4 justify-content-between mt-2 \">\n            <p class=\"fw-bold\">Subtotal</p>\n            <p class=\"fw-700\">{{ (subTotalAmount$ | async) | ecCurrencySymbol}}</p>\n        </div>\n        <div class=\"mx-4 bordeBot py-2\">\n            <app-coupon-ec></app-coupon-ec>\n        </div>\n        <div class=\"d-flex mx-4 justify-content-between bordeBot2 mt-2\">\n            <p class=\"fw-bold\">Descuentos:</p>\n            <p>{{ (totalPromotionAmount$ | async) |ecCurrencySymbol }}</p>\n        </div>\n\n        <div class=\"d-flex mx-4 justify-content-between bordeBot2 pt-2\">\n            <!--  @if(this._cartService.cart.source.value.couponCode){\n                    <a class=\"quitar-cupon text-dark\" role=\"button\"\n                    (click)=\"removeCoupon()\">(Quitar cupón)</a>\n                } -->\n        </div>\n        <div class=\"d-flex mx-4 justify-content-between mb-3 mt-2\">\n            <p class=\"fw-bold h5\">TOTAL</p>\n         <p class=\"fw-bold h5\">{{(totalAmount$ | async) | ecCurrencySymbol}}</p>\n        </div>\n    }\n    <div class=\"d-flex flex-column mx-4 justify-content-between mb-3\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\n        <a [routerLink]=\"['/cart']\" class=\"btn btnPedido mb-2\">FINALIZAR PEDIDO</a>\n        <a [routerLink]=\"['/collection']\" class=\"btn btnSeguir mb-3\">SEGUIR COMPRANDO</a>\n    </div>\n\n\n    } @else {\n    <div class=\"container-lg px-lg-0 px-md-4 my-5\">\n        <div class=\"row\">\n            <div class=\"col-12\">\n                <h5 class=\"text-center mb-sm-4 text-uppercase\"> · Su carrito se\n                    encuentra vacío · </h5>\n            </div>\n        </div>\n    </div>\n    }\n}"]}