ng-easycommerce-v18 0.3.11-beta.1 → 0.3.11-beta.2

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.
@@ -193,4 +193,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
193
193
  type: HostListener,
194
194
  args: ['window:scroll', []]
195
195
  }] } });
196
- //# 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, Injector, OnInit, HostListener, ChangeDetectorRef, PLATFORM_ID } from '@angular/core';\r\nimport { TitleCasePipe, AsyncPipe, JsonPipe, CommonModule, isPlatformBrowser } from '@angular/common';\r\nimport { MenuEcComponent } from '../abstractions-components';\r\nimport { CartService, TestService, ToastService } from '../../ec-services';\r\nimport { Observable } from 'rxjs';\r\nimport { AuthService } from '../../ec-services';\r\nimport { Router, NavigationEnd, RouterLink, RouterLinkActive } from '@angular/router';\r\nimport { Category } from '../../interfaces';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { ChannelService } from '../../ec-services';\r\n/**\r\n * Componente que se encarga de manejar la funcionalidad del Header.\r\n */\r\n@Component({\r\n  selector: 'lib-header-ec',\r\n  standalone: true,\r\n  imports: [CommonModule, TitleCasePipe, AsyncPipe, JsonPipe, RouterLink, RouterLinkActive],\r\n  templateUrl: './header-ec.component.html',\r\n  styleUrl: './header-ec.component.scss'\r\n})\r\nexport class HeaderEcComponent extends MenuEcComponent {\r\n  public channel: string | undefined;\r\n  public searchValue: string = '';\r\n  transparent: boolean = false;\r\n  isHome: boolean = false; // Nueva variable para verificar si estamos en /home\r\n  isScrolled: boolean = false;\r\n  showPricesOnlyToLoggedUsers: boolean = false;\r\n  hidePrices: boolean = false;\r\n  private __authService: AuthService = inject(AuthService)\r\n  private _channelService: ChannelService = inject(ChannelService);\r\n\r\n  public isAuthenticated$ = this.__authService.isAuthenticated();\r\n  constructor() {\r\n    super();\r\n    this._channelService.channel$.subscribe(cfg => {\r\n      // console.log('Channel configuration:', cfg);\r\n      this.showPricesOnlyToLoggedUsers = !!cfg.showPricesOnlyToLoggedUsers;\r\n      this.hidePrices = !!cfg.hidePrices;\r\n      // console.log('hidePrices:', this.hidePrices);\r\n    });\r\n  }\r\n\r\n  private coreConstantsService = inject(CoreConstantsService);\r\n  private router = inject(Router);\r\n  private cdr = inject(ChangeDetectorRef); // Inyectamos ChangeDetectorRef para forzar la actualización\r\n  private platformId = inject(PLATFORM_ID);\r\n\r\n  ngOnInit(): void {\r\n    this.channel = this.coreConstantsService.getChannel();\r\n    this.onWindowScroll();\r\n    this.detectRouteChange(); // Llamamos a la función que detecta el cambio de ruta\r\n  }\r\n  ngAfterViewInit(): void {\r\n    this.setupMobileMenu(); // Inicializamos el menú móvil\r\n    this.setupSearchInputs(); // Inicializamos los inputs de búsqueda   \r\n    this.isHomeFunction();\r\n  }\r\n  /**\r\n   * Detecta cuando cambia la ruta y actualiza la clase del header\r\n   */\r\n  private detectRouteChange() {\r\n    this.router.events.subscribe(event => {\r\n      if (event instanceof NavigationEnd) {\r\n        this.isHome = this.router.url === '/home';\r\n        this.cdr.detectChanges(); // Forzamos la detección de cambios para actualizar la vista\r\n      }\r\n    });\r\n  }\r\n\r\n  @HostListener('window:scroll', [])\r\n  onWindowScroll() {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      const scrollTop = window.scrollY;\r\n      this.isScrolled = scrollTop > 80;\r\n    }\r\n  }\r\n\r\n  isHomeFunction(): void {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      const headerElement = document.querySelector('header');\r\n      if (headerElement) {\r\n        if (this.router.url !== '/home') {\r\n          headerElement.classList.add('show-menu');\r\n        } else {\r\n          headerElement.classList.remove('show-menu');\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  changeUrlTransparent = (urlTransparent: string) => {\r\n    return urlTransparent;\r\n  };\r\n\r\n\r\n  getCollectionSearch = () => {\r\n    this.coreConstantsService.searchValue = this.searchValue;\r\n    this.router.navigateByUrl('/collection?search=' + this.searchValue);\r\n  };\r\n\r\n  setSearchValue = (event: Event, afterSearch?: Function, ...args: any[]) => {\r\n    const target = event.target as HTMLInputElement;\r\n    if (target) {\r\n      this.searchValue = target.value;\r\n    }\r\n\r\n    // if (event.key === 'Enter') {\r\n    // this.getCollectionSearch();\r\n    if (afterSearch) {\r\n      afterSearch(...args);\r\n      // }\r\n    }\r\n  };\r\n\r\n  borrarInput(inputId?: string) {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      if (inputId) {\r\n        const input = document.getElementById(inputId) as HTMLInputElement;\r\n        if (input) {\r\n          input.value = '';\r\n        }\r\n      } else {\r\n        const inputs = ['searchInput1'];\r\n        inputs.forEach((id) => {\r\n          const input = document.getElementById(id) as HTMLInputElement;\r\n          if (input) {\r\n            input.value = '';\r\n          }\r\n        });\r\n      }\r\n    }\r\n\r\n    this.searchValue = '';\r\n    this.coreConstantsService.searchValue = '';\r\n    this.getCollectionSearch();\r\n  }\r\n  setupMobileMenu() {\r\n    if (!isPlatformBrowser(this.platformId)) return;\r\n    \r\n    // console.log('setupMobileMenu called');\r\n    const menuMobile = document.querySelector('.menuMobile');\r\n    if (!(menuMobile instanceof HTMLElement)) return;\r\n    const openBtn = document.querySelector('.abreMenuMobile .abre');\r\n    const closeBtn = document.querySelector('.abreMenuMobile .close');\r\n    const iconMenu = document.getElementById('icMenu');\r\n    const searchMobile = document.querySelector('.searchMobile');\r\n\r\n    const closeMenu = () => {\r\n      menuMobile.style.display = 'none';\r\n      closeBtn?.setAttribute('style', 'display:none');\r\n      iconMenu?.setAttribute('style', 'display:block');\r\n    };\r\n\r\n    menuMobile.style.display = 'none';\r\n\r\n    openBtn?.addEventListener('click', () => {\r\n      menuMobile.style.display = 'block';\r\n      closeBtn?.setAttribute('style', 'display:block');\r\n      if (searchMobile instanceof HTMLElement) {\r\n        searchMobile.style.display = 'none';\r\n      }\r\n      iconMenu?.setAttribute('style', 'display:none');\r\n    });\r\n\r\n    closeBtn?.addEventListener('click', closeMenu);\r\n\r\n    // Cierra el menú si se hace clic en un enlace específico dentro del menú\r\n    const linkSelectors = ['.categoryMobile', '.subcategoryMobile', '.usuariomobile'];\r\n    linkSelectors.forEach(selector => {\r\n      const links = menuMobile.querySelectorAll<HTMLAnchorElement>(`a${selector}`);\r\n      links.forEach(link => {\r\n        link.addEventListener('click', () => {\r\n          closeMenu();\r\n        });\r\n      });\r\n    });\r\n  }\r\n  setupSearchInputs() {\r\n    if (!isPlatformBrowser(this.platformId)) return;\r\n    \r\n    const inputs = ['searchInput1', 'searchInput2'];\r\n\r\n    inputs.forEach(id => {\r\n      const input = document.getElementById(id);\r\n      if (!(input instanceof HTMLInputElement)) return;\r\n      const clearBtn = document.querySelector(`.clear-btn${id.slice(-1)}`);\r\n\r\n      if (!input || !(clearBtn instanceof HTMLElement)) return;\r\n\r\n      input.addEventListener('focus', () => {\r\n        if (input.value === 'Buscar producto...') {\r\n          input.value = '';\r\n        }\r\n      });\r\n\r\n      input.addEventListener('blur', () => {\r\n        if (input.value.trim() === '') {\r\n          input.value = 'Buscar producto...';\r\n        }\r\n      });\r\n\r\n      input.addEventListener('input', () => {\r\n        clearBtn.style.display = input.value.trim() !== '' ? 'block' : 'none';\r\n      });\r\n\r\n      clearBtn.addEventListener('click', (e) => {\r\n        e.preventDefault();\r\n        input.value = '';\r\n        clearBtn.style.display = 'none';\r\n        input.focus();\r\n      });\r\n    });\r\n\r\n  }\r\n}\r\n","<p>header-ec works!</p>\r\n"]}
196
+ //# 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, Injector, OnInit, HostListener, ChangeDetectorRef, PLATFORM_ID } from '@angular/core';\r\nimport { TitleCasePipe, AsyncPipe, JsonPipe, CommonModule, isPlatformBrowser } from '@angular/common';\r\nimport { MenuEcComponent } from '../abstractions-components';\r\nimport { CartService, TestService, ToastService } from '../../ec-services';\r\nimport { Observable } from 'rxjs';\r\nimport { AuthService } from '../../ec-services';\r\nimport { Router, NavigationEnd, RouterLink, RouterLinkActive } from '@angular/router';\r\nimport { Category } from '../../interfaces';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { ChannelService } from '../../ec-services';\r\n/**\r\n * Componente que se encarga de manejar la funcionalidad del Header.\r\n */\r\n@Component({\r\n  selector: 'lib-header-ec',\r\n  standalone: true,\r\n  imports: [CommonModule, TitleCasePipe, AsyncPipe, JsonPipe, RouterLink, RouterLinkActive],\r\n  templateUrl: './header-ec.component.html',\r\n  styleUrl: './header-ec.component.scss'\r\n})\r\nexport class HeaderEcComponent extends MenuEcComponent {\r\n  public channel: string | undefined;\r\n  public searchValue: string = '';\r\n  transparent: boolean = false;\r\n  isHome: boolean = false; // Nueva variable para verificar si estamos en /home\r\n  isScrolled: boolean = false;\r\n  showPricesOnlyToLoggedUsers: boolean = false;\r\n  hidePrices: boolean = false;\r\n  private __authService: AuthService = inject(AuthService)\r\n  private _channelService: ChannelService = inject(ChannelService);\r\n\r\n  public isAuthenticated$ = this.__authService.isAuthenticated();\r\n  constructor() {\r\n    super();\r\n    this._channelService.channel$.subscribe(cfg => {\r\n      // console.log('Channel configuration:', cfg);\r\n      this.showPricesOnlyToLoggedUsers = !!cfg.showPricesOnlyToLoggedUsers;\r\n      this.hidePrices = !!cfg.hidePrices;\r\n      // console.log('hidePrices:', this.hidePrices);\r\n    });\r\n  }\r\n\r\n  private coreConstantsService = inject(CoreConstantsService);\r\n  private router = inject(Router);\r\n  private cdr = inject(ChangeDetectorRef); // Inyectamos ChangeDetectorRef para forzar la actualización\r\n  protected platformId = inject(PLATFORM_ID);\r\n\r\n  ngOnInit(): void {\r\n    this.channel = this.coreConstantsService.getChannel();\r\n    this.onWindowScroll();\r\n    this.detectRouteChange(); // Llamamos a la función que detecta el cambio de ruta\r\n  }\r\n  ngAfterViewInit(): void {\r\n    this.setupMobileMenu(); // Inicializamos el menú móvil\r\n    this.setupSearchInputs(); // Inicializamos los inputs de búsqueda   \r\n    this.isHomeFunction();\r\n  }\r\n  /**\r\n   * Detecta cuando cambia la ruta y actualiza la clase del header\r\n   */\r\n  private detectRouteChange() {\r\n    this.router.events.subscribe(event => {\r\n      if (event instanceof NavigationEnd) {\r\n        this.isHome = this.router.url === '/home';\r\n        this.cdr.detectChanges(); // Forzamos la detección de cambios para actualizar la vista\r\n      }\r\n    });\r\n  }\r\n\r\n  @HostListener('window:scroll', [])\r\n  onWindowScroll() {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      const scrollTop = window.scrollY;\r\n      this.isScrolled = scrollTop > 80;\r\n    }\r\n  }\r\n\r\n  isHomeFunction(): void {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      const headerElement = document.querySelector('header');\r\n      if (headerElement) {\r\n        if (this.router.url !== '/home') {\r\n          headerElement.classList.add('show-menu');\r\n        } else {\r\n          headerElement.classList.remove('show-menu');\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  changeUrlTransparent = (urlTransparent: string) => {\r\n    return urlTransparent;\r\n  };\r\n\r\n\r\n  getCollectionSearch = () => {\r\n    this.coreConstantsService.searchValue = this.searchValue;\r\n    this.router.navigateByUrl('/collection?search=' + this.searchValue);\r\n  };\r\n\r\n  setSearchValue = (event: Event, afterSearch?: Function, ...args: any[]) => {\r\n    const target = event.target as HTMLInputElement;\r\n    if (target) {\r\n      this.searchValue = target.value;\r\n    }\r\n\r\n    // if (event.key === 'Enter') {\r\n    // this.getCollectionSearch();\r\n    if (afterSearch) {\r\n      afterSearch(...args);\r\n      // }\r\n    }\r\n  };\r\n\r\n  borrarInput(inputId?: string) {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      if (inputId) {\r\n        const input = document.getElementById(inputId) as HTMLInputElement;\r\n        if (input) {\r\n          input.value = '';\r\n        }\r\n      } else {\r\n        const inputs = ['searchInput1'];\r\n        inputs.forEach((id) => {\r\n          const input = document.getElementById(id) as HTMLInputElement;\r\n          if (input) {\r\n            input.value = '';\r\n          }\r\n        });\r\n      }\r\n    }\r\n\r\n    this.searchValue = '';\r\n    this.coreConstantsService.searchValue = '';\r\n    this.getCollectionSearch();\r\n  }\r\n  setupMobileMenu() {\r\n    if (!isPlatformBrowser(this.platformId)) return;\r\n    \r\n    // console.log('setupMobileMenu called');\r\n    const menuMobile = document.querySelector('.menuMobile');\r\n    if (!(menuMobile instanceof HTMLElement)) return;\r\n    const openBtn = document.querySelector('.abreMenuMobile .abre');\r\n    const closeBtn = document.querySelector('.abreMenuMobile .close');\r\n    const iconMenu = document.getElementById('icMenu');\r\n    const searchMobile = document.querySelector('.searchMobile');\r\n\r\n    const closeMenu = () => {\r\n      menuMobile.style.display = 'none';\r\n      closeBtn?.setAttribute('style', 'display:none');\r\n      iconMenu?.setAttribute('style', 'display:block');\r\n    };\r\n\r\n    menuMobile.style.display = 'none';\r\n\r\n    openBtn?.addEventListener('click', () => {\r\n      menuMobile.style.display = 'block';\r\n      closeBtn?.setAttribute('style', 'display:block');\r\n      if (searchMobile instanceof HTMLElement) {\r\n        searchMobile.style.display = 'none';\r\n      }\r\n      iconMenu?.setAttribute('style', 'display:none');\r\n    });\r\n\r\n    closeBtn?.addEventListener('click', closeMenu);\r\n\r\n    // Cierra el menú si se hace clic en un enlace específico dentro del menú\r\n    const linkSelectors = ['.categoryMobile', '.subcategoryMobile', '.usuariomobile'];\r\n    linkSelectors.forEach(selector => {\r\n      const links = menuMobile.querySelectorAll<HTMLAnchorElement>(`a${selector}`);\r\n      links.forEach(link => {\r\n        link.addEventListener('click', () => {\r\n          closeMenu();\r\n        });\r\n      });\r\n    });\r\n  }\r\n  setupSearchInputs() {\r\n    if (!isPlatformBrowser(this.platformId)) return;\r\n    \r\n    const inputs = ['searchInput1', 'searchInput2'];\r\n\r\n    inputs.forEach(id => {\r\n      const input = document.getElementById(id);\r\n      if (!(input instanceof HTMLInputElement)) return;\r\n      const clearBtn = document.querySelector(`.clear-btn${id.slice(-1)}`);\r\n\r\n      if (!input || !(clearBtn instanceof HTMLElement)) return;\r\n\r\n      input.addEventListener('focus', () => {\r\n        if (input.value === 'Buscar producto...') {\r\n          input.value = '';\r\n        }\r\n      });\r\n\r\n      input.addEventListener('blur', () => {\r\n        if (input.value.trim() === '') {\r\n          input.value = 'Buscar producto...';\r\n        }\r\n      });\r\n\r\n      input.addEventListener('input', () => {\r\n        clearBtn.style.display = input.value.trim() !== '' ? 'block' : 'none';\r\n      });\r\n\r\n      clearBtn.addEventListener('click', (e) => {\r\n        e.preventDefault();\r\n        input.value = '';\r\n        clearBtn.style.display = 'none';\r\n        input.focus();\r\n      });\r\n    });\r\n\r\n  }\r\n}\r\n","<p>header-ec works!</p>\r\n"]}