ng-easycommerce-v18 0.3.22-beta.1 → 0.3.22
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.
- package/README.md +8 -2
- package/esm2022/lib/classes/filters/attributes-filter.mjs +74 -4
- package/esm2022/lib/classes/filters/category-filter.mjs +105 -26
- package/esm2022/lib/classes/filters/filter-factory.mjs +7 -3
- package/esm2022/lib/classes/filters/filter.mjs +27 -2
- package/esm2022/lib/classes/filters/price_range-filter.mjs +3 -3
- package/esm2022/lib/constants/core.constants.service.mjs +12 -1
- package/esm2022/lib/ec-components/blocks-ec/block-products-ec/block-products-ec.component.mjs +5 -3
- package/esm2022/lib/ec-components/collection-ec/collection-ec.component.mjs +41 -17
- package/esm2022/lib/ec-components/filters-ec/filters-ec.component.mjs +42 -9
- package/esm2022/lib/ec-components/header-ec/header-ec.component.mjs +42 -27
- package/esm2022/lib/ec-components/price-range-filter/price-range-filter.component.mjs +13 -2
- package/esm2022/lib/ec-components/related-products-ec/related-products-ec.component.mjs +6 -4
- package/esm2022/lib/ec-components/widgets-ec/magnizoom-ec/magnizoom-ec.component.mjs +4 -2
- package/esm2022/lib/ec-services/analytics/facebook-pixel.service.mjs +4 -2
- package/esm2022/lib/ec-services/analytics/google-analytics.service.mjs +4 -2
- package/esm2022/lib/ec-services/filters.service.mjs +124 -18
- package/esm2022/lib/ec-services/options.service.mjs +27 -3
- package/esm2022/lib/ec-services/pagination.service.mjs +70 -22
- package/esm2022/lib/ec-services/products.service.mjs +5 -3
- package/fesm2022/ng-easycommerce-v18.mjs +586 -126
- package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
- package/lib/classes/filters/attributes-filter.d.ts +24 -0
- package/lib/classes/filters/category-filter.d.ts +30 -3
- package/lib/constants/core.constants.service.d.ts +7 -0
- package/lib/ec-components/collection-ec/collection-ec.component.d.ts +5 -4
- package/lib/ec-components/filters-ec/filters-ec.component.d.ts +13 -0
- package/lib/ec-components/price-range-filter/price-range-filter.component.d.ts +2 -0
- package/lib/ec-services/filters.service.d.ts +18 -1
- package/lib/ec-services/options.service.d.ts +4 -0
- package/lib/ec-services/pagination.service.d.ts +21 -5
- package/lib/ec-services/products.service.d.ts +1 -1
- package/package.json +1 -1
|
@@ -1,11 +1,10 @@
|
|
|
1
1
|
import { Component, inject, PLATFORM_ID, HostListener, ChangeDetectorRef, signal } from '@angular/core';
|
|
2
|
-
import { TitleCasePipe, AsyncPipe, JsonPipe, CommonModule } from '@angular/common';
|
|
2
|
+
import { TitleCasePipe, AsyncPipe, JsonPipe, CommonModule, isPlatformBrowser } from '@angular/common';
|
|
3
3
|
import { MenuEcComponent } from '../abstractions-components';
|
|
4
4
|
import { AuthService } from '../../ec-services';
|
|
5
5
|
import { Router, NavigationEnd, RouterLink, RouterLinkActive } from '@angular/router';
|
|
6
6
|
import { CoreConstantsService } from '../../constants';
|
|
7
7
|
import { ChannelService } from '../../ec-services';
|
|
8
|
-
import { isPlatformBrowser } from '@angular/common';
|
|
9
8
|
import * as i0 from "@angular/core";
|
|
10
9
|
/**
|
|
11
10
|
* Componente que se encarga de manejar la funcionalidad del Header.
|
|
@@ -31,10 +30,8 @@ export class HeaderEcComponent extends MenuEcComponent {
|
|
|
31
30
|
constructor() {
|
|
32
31
|
super();
|
|
33
32
|
this._channelService.channel$.subscribe(cfg => {
|
|
34
|
-
// console.log('Channel configuration:', cfg);
|
|
35
33
|
this.showPricesOnlyToLoggedUsers = !!cfg.showPricesOnlyToLoggedUsers;
|
|
36
34
|
this.hidePrices = !!cfg.hidePrices;
|
|
37
|
-
// console.log('hidePrices:', this.hidePrices);
|
|
38
35
|
});
|
|
39
36
|
}
|
|
40
37
|
coreConstantsService = inject(CoreConstantsService);
|
|
@@ -42,6 +39,7 @@ export class HeaderEcComponent extends MenuEcComponent {
|
|
|
42
39
|
cdr = inject(ChangeDetectorRef); // Inyectamos ChangeDetectorRef para forzar la actualización
|
|
43
40
|
ngOnInit() {
|
|
44
41
|
this.channel = this.coreConstantsService.getChannel();
|
|
42
|
+
this.searchValue = this.coreConstantsService.searchValue || '';
|
|
45
43
|
this.onWindowScroll();
|
|
46
44
|
this.detectRouteChange(); // Llamamos a la función que detecta el cambio de ruta
|
|
47
45
|
// Usar el Observable del AuthService
|
|
@@ -78,17 +76,21 @@ export class HeaderEcComponent extends MenuEcComponent {
|
|
|
78
76
|
});
|
|
79
77
|
}
|
|
80
78
|
onWindowScroll() {
|
|
81
|
-
|
|
82
|
-
|
|
79
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
80
|
+
const scrollTop = window.scrollY;
|
|
81
|
+
this.isScrolled = scrollTop > 80;
|
|
82
|
+
}
|
|
83
83
|
}
|
|
84
84
|
isHomeFunction() {
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
if (
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
85
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
86
|
+
const headerElement = document.querySelector('header');
|
|
87
|
+
if (headerElement) {
|
|
88
|
+
if (this.router.url !== '/home') {
|
|
89
|
+
headerElement.classList.add('show-menu');
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
headerElement.classList.remove('show-menu');
|
|
93
|
+
}
|
|
92
94
|
}
|
|
93
95
|
}
|
|
94
96
|
}
|
|
@@ -112,27 +114,38 @@ export class HeaderEcComponent extends MenuEcComponent {
|
|
|
112
114
|
}
|
|
113
115
|
};
|
|
114
116
|
borrarInput(inputId) {
|
|
115
|
-
if (
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
input.value = '';
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
else {
|
|
122
|
-
const inputs = ['searchInput1'];
|
|
123
|
-
inputs.forEach((id) => {
|
|
124
|
-
const input = document.getElementById(id);
|
|
117
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
118
|
+
if (inputId) {
|
|
119
|
+
const input = document.getElementById(inputId);
|
|
125
120
|
if (input) {
|
|
126
121
|
input.value = '';
|
|
127
122
|
}
|
|
128
|
-
}
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
const inputs = ['searchInput1'];
|
|
126
|
+
inputs.forEach((id) => {
|
|
127
|
+
const input = document.getElementById(id);
|
|
128
|
+
if (input) {
|
|
129
|
+
input.value = '';
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
}
|
|
129
133
|
}
|
|
130
134
|
this.searchValue = '';
|
|
131
135
|
this.coreConstantsService.searchValue = '';
|
|
132
|
-
|
|
136
|
+
// En lugar de relanzar la búsqueda con string vacío,
|
|
137
|
+
// actualizamos la URL para quitar el query param `search` y resetear la paginación.
|
|
138
|
+
this.router.navigate(['/collection'], {
|
|
139
|
+
queryParams: {
|
|
140
|
+
search: null,
|
|
141
|
+
page: null
|
|
142
|
+
},
|
|
143
|
+
queryParamsHandling: 'merge'
|
|
144
|
+
});
|
|
133
145
|
}
|
|
134
146
|
setupMobileMenu() {
|
|
135
|
-
|
|
147
|
+
if (!isPlatformBrowser(this.platformId) || typeof document === 'undefined')
|
|
148
|
+
return;
|
|
136
149
|
const menuMobile = document.querySelector('.menuMobile');
|
|
137
150
|
if (!(menuMobile instanceof HTMLElement))
|
|
138
151
|
return;
|
|
@@ -167,6 +180,8 @@ export class HeaderEcComponent extends MenuEcComponent {
|
|
|
167
180
|
});
|
|
168
181
|
}
|
|
169
182
|
setupSearchInputs() {
|
|
183
|
+
if (!isPlatformBrowser(this.platformId))
|
|
184
|
+
return;
|
|
170
185
|
const inputs = ['searchInput1', 'searchInput2'];
|
|
171
186
|
inputs.forEach(id => {
|
|
172
187
|
const input = document.getElementById(id);
|
|
@@ -233,4 +248,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
233
248
|
type: HostListener,
|
|
234
249
|
args: ['window:scroll', []]
|
|
235
250
|
}] } });
|
|
236
|
-
//# 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 } 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';\nimport { isPlatformBrowser } from '@angular/common';\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      // console.log('Channel configuration:', cfg);\n      this.showPricesOnlyToLoggedUsers = !!cfg.showPricesOnlyToLoggedUsers;\n      this.hidePrices = !!cfg.hidePrices;\n      // console.log('hidePrices:', this.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    this.onWindowScroll();\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    this.setupMobileMenu(); // Inicializamos el menú móvil\n    this.setupSearchInputs(); // Inicializamos los inputs de búsqueda   \n    this.isHomeFunction();\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    const scrollTop = window.scrollY;\n    this.isScrolled = scrollTop > 80;\n  }\n\n  isHomeFunction(): void {\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  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 (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    this.searchValue = '';\n    this.coreConstantsService.searchValue = '';\n    this.getCollectionSearch();\n  }\n  setupMobileMenu() {\n    // console.log('setupMobileMenu called');\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    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"]}
|
|
251
|
+
//# 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    this.searchValue = this.coreConstantsService.searchValue || '';\n    this.onWindowScroll();\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    this.setupMobileMenu(); // Inicializamos el menú móvil\n    this.setupSearchInputs(); // Inicializamos los inputs de búsqueda   \n    this.isHomeFunction();\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"]}
|
|
@@ -3,10 +3,13 @@ import { PriceRangeFilter } from '../../classes/filters/price_range-filter';
|
|
|
3
3
|
import { CommonModule } from '@angular/common';
|
|
4
4
|
import { EcCurrencySymbolPipe } from '../../ec-pipe';
|
|
5
5
|
import { FiltersService } from '../../ec-services';
|
|
6
|
+
import { Router, ActivatedRoute } from '@angular/router';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@angular/common";
|
|
8
9
|
export class PriceRangeFilterComponent {
|
|
9
10
|
_filtersService = inject(FiltersService);
|
|
11
|
+
router = inject(Router);
|
|
12
|
+
route = inject(ActivatedRoute);
|
|
10
13
|
priceGap = 1;
|
|
11
14
|
roundStep = 5;
|
|
12
15
|
filter;
|
|
@@ -43,7 +46,15 @@ export class PriceRangeFilterComponent {
|
|
|
43
46
|
return;
|
|
44
47
|
const min = filter.currentMinPrice ?? filter.minPrice;
|
|
45
48
|
const max = filter.currentMaxPrice ?? filter.maxPrice;
|
|
46
|
-
this.
|
|
49
|
+
this.router.navigate([], {
|
|
50
|
+
relativeTo: this.route,
|
|
51
|
+
queryParams: {
|
|
52
|
+
price_min: min !== filter.minPrice ? min : null,
|
|
53
|
+
price_max: max !== filter.maxPrice ? max : null,
|
|
54
|
+
page: null,
|
|
55
|
+
},
|
|
56
|
+
queryParamsHandling: 'merge'
|
|
57
|
+
});
|
|
47
58
|
}
|
|
48
59
|
getMinValue(filter) {
|
|
49
60
|
return (filter instanceof PriceRangeFilter && filter.currentMinPrice != null)
|
|
@@ -140,4 +151,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
140
151
|
}], rangeChanged: [{
|
|
141
152
|
type: Output
|
|
142
153
|
}] } });
|
|
143
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"price-range-filter.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/price-range-filter/price-range-filter.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/price-range-filter/price-range-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output } from '@angular/core';\nimport { PriceRangeFilter } from '../../classes/filters/price_range-filter';\nimport { CommonModule } from '@angular/common';\nimport { EcCurrencySymbolPipe } from '../../ec-pipe';\nimport { FiltersService } from '../../ec-services';\n\n@Component({\n  selector: 'lib-price-range-filter',\n  standalone: true,\n  imports: [EcCurrencySymbolPipe, CommonModule],\n  templateUrl: './price-range-filter.component.html',\n  styleUrl: './price-range-filter.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PriceRangeFilterComponent {\n\n  private _filtersService: FiltersService = inject(FiltersService);\n\n  priceGap = 1;\n  roundStep = 5;\n\n  @Input() filter!: PriceRangeFilter;\n  @Output() rangeChanged = new EventEmitter<{ min: number; max: number }>();\n\n  getSliderStyle(filter: any): { [klass: string]: string } {\n    if (!(filter instanceof PriceRangeFilter)) return { left: '0%', right: '0%' };\n\n    const left = this.calculateLeftPercentage(filter);\n    const right = this.calculateRightPercentage(filter);\n    return { left: `${left}%`, right: `${right}%` };\n  }\n\n  // Métodos para actualizar la barra del filtro por precio\n  calculateLeftPercentage(filter: any): number {\n    if (!(filter instanceof PriceRangeFilter)) return 0;\n\n    const min = filter.minPrice;\n    const max = filter.maxPrice;\n    const currentMin = filter.currentMinPrice ?? min;\n\n    const clampedMin = Math.max(min, Math.min(currentMin, max));\n    return Math.max(0, Math.min(((clampedMin - min) / (max - min)) * 100, 100));\n  }\n\n  calculateRightPercentage(filter: any): number {\n    if (!(filter instanceof PriceRangeFilter)) return 0;\n\n    const min = filter.minPrice;\n    const max = filter.maxPrice;\n    const currentMax = filter.currentMaxPrice ?? max;\n\n    const clampedMax = Math.max(min, Math.min(currentMax, max));\n    return Math.max(0, Math.min(100 - ((clampedMax - min) / (max - min)) * 100, 100));\n  }\n\n  // Método para actualizar los valores de precio seleccionados\n  updatePriceRange(filter: any) {\n    if (!(filter instanceof PriceRangeFilter)) return;\n\n    const min = filter.currentMinPrice ?? filter.minPrice;\n    const max = filter.currentMaxPrice ?? filter.maxPrice;\n    this._filtersService.updatePriceRangeFilter(min, max);\n  }\n\n  getMinValue(filter: any): number {\n    return (filter instanceof PriceRangeFilter && filter.currentMinPrice != null)\n      ? filter.currentMinPrice\n      : filter.minPrice;\n  }\n\n  getMaxValue(filter: any): number {\n    return (filter instanceof PriceRangeFilter && filter.currentMaxPrice != null)\n      ? filter.currentMaxPrice\n      : filter.maxPrice;\n  }\n\n  /**\n  * Redondea al múltiplo de 'step' respetando el redondeo entero:\n  * - Mínimo: redondea hacia abajo.\n  * - Máximo: redondea hacia arriba.\n  */\n  onRangeChange(event: Event, type: 'min' | 'max', filter: any) {\n    const input = event.target as HTMLInputElement;\n    let value = parseFloat(input.value);\n    value = this.roundToNearest(value, this.roundStep, type, filter);\n    this.updateFilterPrices(type, value, filter, this.priceGap);\n  }\n\n  protected roundToNearest(value: number, step: number, type: 'min' | 'max', filter: any): number {\n    let rounded = Math.round(value / step) * step;\n    if (type === 'max' && rounded < filter.maxPrice) {\n      rounded = Math.ceil(value / step) * step;\n    }\n    if (type === 'min' && rounded > filter.minPrice) {\n      rounded = Math.floor(value / step) * step;\n    }\n    return rounded;\n  }\n\n  /**\n  * Actualiza los valores del filtro permitiendo que un input empuje al otro.\n  */\n  protected updateFilterPrices(type: 'min' | 'max', value: number, filter: any, priceGap: number) {\n    const globalMin = filter.minPrice ?? 0;\n    const globalMax = filter.maxPrice;\n\n    let currentMin = filter.currentMinPrice ?? globalMin;\n    let currentMax = filter.currentMaxPrice ?? globalMax;\n\n    if (type === 'min') {\n      let newMin = Math.min(Math.max(value, globalMin), globalMax);\n      if (newMin + priceGap > currentMax) {\n        let newMaxCandidate = newMin + priceGap;\n        if (newMaxCandidate <= globalMax) {\n          currentMax = newMaxCandidate;\n        } else {\n          newMin = globalMax - priceGap;\n        }\n      }\n      filter.currentMinPrice = newMin;\n      filter.currentMaxPrice = currentMax;\n    } else if (type === 'max') {\n      let newMax = Math.max(Math.min(value, globalMax), globalMin);\n      if (newMax - priceGap < currentMin) {\n        let newMinCandidate = newMax - priceGap;\n        if (newMinCandidate >= globalMin) {\n          currentMin = newMinCandidate;\n        } else {\n          newMax = globalMin + priceGap;\n        }\n      }\n      filter.currentMaxPrice = newMax;\n      filter.currentMinPrice = currentMin;\n    }\n  }\n\n  scrollUp = () => {\n    window.scroll(0, 0);\n    return true\n  }\n\n  getFormattedMinPrice(filter: any): string {\n    const value = (filter instanceof PriceRangeFilter && filter.currentMinPrice != null)\n      ? filter.currentMinPrice\n      : filter.minPrice;\n    return value;\n  }\n\n  getFormattedMaxPrice(filter: any): string {\n    const value = (filter instanceof PriceRangeFilter && filter.currentMaxPrice != null)\n      ? filter.currentMaxPrice\n      : filter.maxPrice;\n    return value;\n  }\n}\n","<div class=\"slider\">\n    <div class=\"slider\">\n        <div class=\"progress\" [ngStyle]=\"getSliderStyle(filter)\">\n        </div>\n    </div>\n</div>\n<div class=\"range-input d-flex gap-2\">\n    <input #rangeMin type=\"range\" class=\"range-min\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\n        [value]=\"getMinValue(filter)\" (input)=\"onRangeChange($event, 'min', filter)\"\n        (change)=\"updatePriceRange(filter); scrollUp()\">\n    <input #rangeMax type=\"range\" class=\"range-max\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\n        [value]=\"getMaxValue(filter)\" (input)=\"onRangeChange($event, 'max', filter)\"\n        (change)=\"updatePriceRange(filter); scrollUp()\">\n</div>\n<!-- precios Mínimo / Máximo -->\n<div class=\"price-container mt-2\">\n    <div class=\"price-label-wrapper\">\n        <span class=\"price-label\">Mínimo:</span>\n        <span class=\"price-value\">\n            {{ (getFormattedMinPrice(filter) | ecCurrencySymbol) || '0' }}\n        </span>\n    </div>\n    <div class=\"price-label-wrapper\">\n        <span class=\"price-label\">Máximo:</span>\n        <span class=\"price-value price-value-right\">\n            {{ getFormattedMaxPrice(filter) | ecCurrencySymbol }}\n        </span>\n    </div>\n</div>"]}
|
|
154
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"price-range-filter.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/price-range-filter/price-range-filter.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/price-range-filter/price-range-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output } from '@angular/core';\nimport { PriceRangeFilter } from '../../classes/filters/price_range-filter';\nimport { CommonModule } from '@angular/common';\nimport { EcCurrencySymbolPipe } from '../../ec-pipe';\nimport { FiltersService } from '../../ec-services';\nimport { Router, ActivatedRoute } from '@angular/router';\n\n@Component({\n  selector: 'lib-price-range-filter',\n  standalone: true,\n  imports: [EcCurrencySymbolPipe, CommonModule],\n  templateUrl: './price-range-filter.component.html',\n  styleUrl: './price-range-filter.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PriceRangeFilterComponent {\n\n  private _filtersService: FiltersService = inject(FiltersService);\n  private router: Router = inject(Router);\n  private route: ActivatedRoute = inject(ActivatedRoute);\n\n  priceGap = 1;\n  roundStep = 5;\n\n  @Input() filter!: PriceRangeFilter;\n  @Output() rangeChanged = new EventEmitter<{ min: number; max: number }>();\n\n  getSliderStyle(filter: any): { [klass: string]: string } {\n    if (!(filter instanceof PriceRangeFilter)) return { left: '0%', right: '0%' };\n\n    const left = this.calculateLeftPercentage(filter);\n    const right = this.calculateRightPercentage(filter);\n    return { left: `${left}%`, right: `${right}%` };\n  }\n\n  // Métodos para actualizar la barra del filtro por precio\n  calculateLeftPercentage(filter: any): number {\n    if (!(filter instanceof PriceRangeFilter)) return 0;\n\n    const min = filter.minPrice;\n    const max = filter.maxPrice;\n    const currentMin = filter.currentMinPrice ?? min;\n\n    const clampedMin = Math.max(min, Math.min(currentMin, max));\n    return Math.max(0, Math.min(((clampedMin - min) / (max - min)) * 100, 100));\n  }\n\n  calculateRightPercentage(filter: any): number {\n    if (!(filter instanceof PriceRangeFilter)) return 0;\n\n    const min = filter.minPrice;\n    const max = filter.maxPrice;\n    const currentMax = filter.currentMaxPrice ?? max;\n\n    const clampedMax = Math.max(min, Math.min(currentMax, max));\n    return Math.max(0, Math.min(100 - ((clampedMax - min) / (max - min)) * 100, 100));\n  }\n\n  // Método para actualizar los valores de precio seleccionados\n  updatePriceRange(filter: any) {\n    if (!(filter instanceof PriceRangeFilter)) return;\n\n    const min = filter.currentMinPrice ?? filter.minPrice;\n    const max = filter.currentMaxPrice ?? filter.maxPrice;\n\n    this.router.navigate([], {\n      relativeTo: this.route,\n      queryParams: {\n        price_min: min !== filter.minPrice ? min : null,\n        price_max: max !== filter.maxPrice ? max : null,\n        page: null,\n      },\n      queryParamsHandling: 'merge'\n    });\n  }\n\n  getMinValue(filter: any): number {\n    return (filter instanceof PriceRangeFilter && filter.currentMinPrice != null)\n      ? filter.currentMinPrice\n      : filter.minPrice;\n  }\n\n  getMaxValue(filter: any): number {\n    return (filter instanceof PriceRangeFilter && filter.currentMaxPrice != null)\n      ? filter.currentMaxPrice\n      : filter.maxPrice;\n  }\n\n  /**\n  * Redondea al múltiplo de 'step' respetando el redondeo entero:\n  * - Mínimo: redondea hacia abajo.\n  * - Máximo: redondea hacia arriba.\n  */\n  onRangeChange(event: Event, type: 'min' | 'max', filter: any) {\n    const input = event.target as HTMLInputElement;\n    let value = parseFloat(input.value);\n    value = this.roundToNearest(value, this.roundStep, type, filter);\n    this.updateFilterPrices(type, value, filter, this.priceGap);\n  }\n\n  protected roundToNearest(value: number, step: number, type: 'min' | 'max', filter: any): number {\n    let rounded = Math.round(value / step) * step;\n    if (type === 'max' && rounded < filter.maxPrice) {\n      rounded = Math.ceil(value / step) * step;\n    }\n    if (type === 'min' && rounded > filter.minPrice) {\n      rounded = Math.floor(value / step) * step;\n    }\n    return rounded;\n  }\n\n  /**\n  * Actualiza los valores del filtro permitiendo que un input empuje al otro.\n  */\n  protected updateFilterPrices(type: 'min' | 'max', value: number, filter: any, priceGap: number) {\n    const globalMin = filter.minPrice ?? 0;\n    const globalMax = filter.maxPrice;\n\n    let currentMin = filter.currentMinPrice ?? globalMin;\n    let currentMax = filter.currentMaxPrice ?? globalMax;\n\n    if (type === 'min') {\n      let newMin = Math.min(Math.max(value, globalMin), globalMax);\n      if (newMin + priceGap > currentMax) {\n        let newMaxCandidate = newMin + priceGap;\n        if (newMaxCandidate <= globalMax) {\n          currentMax = newMaxCandidate;\n        } else {\n          newMin = globalMax - priceGap;\n        }\n      }\n      filter.currentMinPrice = newMin;\n      filter.currentMaxPrice = currentMax;\n    } else if (type === 'max') {\n      let newMax = Math.max(Math.min(value, globalMax), globalMin);\n      if (newMax - priceGap < currentMin) {\n        let newMinCandidate = newMax - priceGap;\n        if (newMinCandidate >= globalMin) {\n          currentMin = newMinCandidate;\n        } else {\n          newMax = globalMin + priceGap;\n        }\n      }\n      filter.currentMaxPrice = newMax;\n      filter.currentMinPrice = currentMin;\n    }\n  }\n\n  scrollUp = () => {\n    window.scroll(0, 0);\n    return true\n  }\n\n  getFormattedMinPrice(filter: any): string {\n    const value = (filter instanceof PriceRangeFilter && filter.currentMinPrice != null)\n      ? filter.currentMinPrice\n      : filter.minPrice;\n    return value;\n  }\n\n  getFormattedMaxPrice(filter: any): string {\n    const value = (filter instanceof PriceRangeFilter && filter.currentMaxPrice != null)\n      ? filter.currentMaxPrice\n      : filter.maxPrice;\n    return value;\n  }\n}\n","<div class=\"slider\">\n    <div class=\"slider\">\n        <div class=\"progress\" [ngStyle]=\"getSliderStyle(filter)\">\n        </div>\n    </div>\n</div>\n<div class=\"range-input d-flex gap-2\">\n    <input #rangeMin type=\"range\" class=\"range-min\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\n        [value]=\"getMinValue(filter)\" (input)=\"onRangeChange($event, 'min', filter)\"\n        (change)=\"updatePriceRange(filter); scrollUp()\">\n    <input #rangeMax type=\"range\" class=\"range-max\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\n        [value]=\"getMaxValue(filter)\" (input)=\"onRangeChange($event, 'max', filter)\"\n        (change)=\"updatePriceRange(filter); scrollUp()\">\n</div>\n<!-- precios Mínimo / Máximo -->\n<div class=\"price-container mt-2\">\n    <div class=\"price-label-wrapper\">\n        <span class=\"price-label\">Mínimo:</span>\n        <span class=\"price-value\">\n            {{ (getFormattedMinPrice(filter) | ecCurrencySymbol) || '0' }}\n        </span>\n    </div>\n    <div class=\"price-label-wrapper\">\n        <span class=\"price-label\">Máximo:</span>\n        <span class=\"price-value price-value-right\">\n            {{ getFormattedMaxPrice(filter) | ecCurrencySymbol }}\n        </span>\n    </div>\n</div>"]}
|
|
@@ -67,9 +67,11 @@ export class RelatedProductsEcComponent extends BlockEcComponent {
|
|
|
67
67
|
this._relatedProductsSubject.next(relatedProducts);
|
|
68
68
|
res.map((products) => this._analyticsService.callEvent('view_item_list', { products: products.items, item_list_name: products.title || 'Related Products', item_list_id: products.id || 'related-products' }));
|
|
69
69
|
// Inicializar swiper después de que los datos estén disponibles
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
70
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
71
|
+
setTimeout(() => {
|
|
72
|
+
this.initSwiper();
|
|
73
|
+
}, 100);
|
|
74
|
+
}
|
|
73
75
|
});
|
|
74
76
|
}
|
|
75
77
|
initSwiper() {
|
|
@@ -110,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
110
112
|
required: true
|
|
111
113
|
}]
|
|
112
114
|
}] } });
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"related-products-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/related-products-ec/related-products-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/related-products-ec/related-products-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, TemplateRef, SimpleChanges, CUSTOM_ELEMENTS_SCHEMA, signal, PLATFORM_ID, afterNextRender , OnChanges } from '@angular/core';\nimport { AnalyticsService, ProductsService } from '../../ec-services';\nimport { Router } from '@angular/router';\nimport { BehaviorSubject, Observable, take } from 'rxjs';\nimport { AsyncPipe, CommonModule, isPlatformBrowser } from '@angular/common';\nimport { Product } from '../../interfaces';\nimport { ProductEcComponent } from '../product-ec/product-ec.component';\nimport { SwiperContainer } from 'swiper/element';\nimport { SwiperOptions } from 'swiper/types';\nimport { BlockEcComponent } from '../abstractions-components';\n\n@Component({\n    selector: 'app-related-products-ec',\n    standalone: true,\n    imports: [AsyncPipe, ProductEcComponent, CommonModule],\n    templateUrl: './related-products-ec.component.html',\n    styleUrl: './related-products-ec.component.scss',\n    schemas: [CUSTOM_ELEMENTS_SCHEMA]\n})\nexport class RelatedProductsEcComponent extends BlockEcComponent implements OnChanges {\n    private _productsService: ProductsService = inject(ProductsService)\n    private _analyticsService: AnalyticsService = inject(AnalyticsService)\n    private _router: Router = inject(Router)\n    \t/**\n\t * Signal utlizado para guarda el contenedor del carrusel\n\t */\n\tswiperElement = signal<SwiperContainer | null>(null)\n    /**\n     * Input que recibe un template para el producto.\n     */\n    @Input() appProduct: TemplateRef<any> | undefined;\n    @Input({\n        required: true\n    }) productID: any;\n\n        private document?: Document;\n        private platformId: any = inject(PLATFORM_ID)\n    \n    private _relatedProductsSubject:BehaviorSubject<Product[]> =  new BehaviorSubject<Product[]>([])\n    public relatedProducts$:Observable<any[]> = this._relatedProductsSubject.asObservable();\n    private keywordsToCompare:string[] = ['compare', 'comparar', 'comparacion', 'comparación', 'compared'];\n    override swiperOptions = (): SwiperOptions => {\n        return {\n            navigation: true,\n            loop: true,\n            autoHeight: true,\n            autoplay: true,\n            breakpoints: {\n                0: {\n                    slidesPerView: 1\n                },\n                576: {\n                    slidesPerView: 2\n                },\n                768: {\n                    slidesPerView: 2,\n                },\n                992: {\n                    slidesPerView: 3,\n                },\n                1200: {\n                    slidesPerView: 4,\n                }\n            }\n        }\n    }\n    constructor() {\n        super()\n        if (isPlatformBrowser(this.platformId)) {\n            this.document = document\n        }\n        // Swiper initialization moved to initSwiper() method called after data loads\n    }\n\n    ngOnInit() {\n        // console.log(this.productID)\n        this.load(this.productID)\n    }\n\n    private load(product_id:any) {\n        this._productsService.getRelatedProducts(product_id).pipe(take(1)).subscribe(\n            res => {\n                // console.log('response',res);\n                const relatedProducts:any = res.filter((elem:any) => !this.includeKeyword(elem.title.toLowerCase()))\n                this._relatedProductsSubject.next(relatedProducts)\n                res.map((products:any) => this._analyticsService.callEvent('view_item_list', { products: products.items, item_list_name: products.title || 'Related Products', item_list_id: products.id || 'related-products' }))\n                \n                // Inicializar swiper después de que los datos estén disponibles\n                setTimeout(() => {\n                    this.initSwiper();\n                }, 100);\n            }\n        )\n    }\n\n    private initSwiper() {\n        if (isPlatformBrowser(this.platformId)) {\n            const swiperElemConstructor = this.document?.querySelector('#relatedProductsSwiper')\n            // console.log('swiperElemConstructor', swiperElemConstructor)\n            if (swiperElemConstructor) {\n                Object.assign(swiperElemConstructor!, this.swiperOptions())\n                this.swiperElement.set(swiperElemConstructor as SwiperContainer)\n                this.swiperElement()?.initialize();\n            }\n        }\n    }\n\n    includeKeyword = (word:string) => {\n        let result = false\n        this.keywordsToCompare.forEach( keyword => {\n            word.includes(keyword) ? result = true : null\n        })\n        return result\n    }\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes['productID'] && changes['productID'].currentValue && !changes['productID'].firstChange) {\n            // Solo reinicializar si el productID realmente cambió y no es la primera vez\n            this.ngOnInit();\n        }\n    }\n}\n\n","\n"]}
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"related-products-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/related-products-ec/related-products-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/related-products-ec/related-products-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, TemplateRef, SimpleChanges, CUSTOM_ELEMENTS_SCHEMA, signal, PLATFORM_ID, afterNextRender , OnChanges } from '@angular/core';\nimport { AnalyticsService, ProductsService } from '../../ec-services';\nimport { Router } from '@angular/router';\nimport { BehaviorSubject, Observable, take } from 'rxjs';\nimport { AsyncPipe, CommonModule, isPlatformBrowser } from '@angular/common';\nimport { Product } from '../../interfaces';\nimport { ProductEcComponent } from '../product-ec/product-ec.component';\nimport { SwiperContainer } from 'swiper/element';\nimport { SwiperOptions } from 'swiper/types';\nimport { BlockEcComponent } from '../abstractions-components';\n\n@Component({\n    selector: 'app-related-products-ec',\n    standalone: true,\n    imports: [AsyncPipe, ProductEcComponent, CommonModule],\n    templateUrl: './related-products-ec.component.html',\n    styleUrl: './related-products-ec.component.scss',\n    schemas: [CUSTOM_ELEMENTS_SCHEMA]\n})\nexport class RelatedProductsEcComponent extends BlockEcComponent implements OnChanges {\n    private _productsService: ProductsService = inject(ProductsService)\n    private _analyticsService: AnalyticsService = inject(AnalyticsService)\n    private _router: Router = inject(Router)\n    \t/**\n\t * Signal utlizado para guarda el contenedor del carrusel\n\t */\n\tswiperElement = signal<SwiperContainer | null>(null)\n    /**\n     * Input que recibe un template para el producto.\n     */\n    @Input() appProduct: TemplateRef<any> | undefined;\n    @Input({\n        required: true\n    }) productID: any;\n\n        private document?: Document;\n        private platformId: any = inject(PLATFORM_ID)\n    \n    private _relatedProductsSubject:BehaviorSubject<Product[]> =  new BehaviorSubject<Product[]>([])\n    public relatedProducts$:Observable<any[]> = this._relatedProductsSubject.asObservable();\n    private keywordsToCompare:string[] = ['compare', 'comparar', 'comparacion', 'comparación', 'compared'];\n    override swiperOptions = (): SwiperOptions => {\n        return {\n            navigation: true,\n            loop: true,\n            autoHeight: true,\n            autoplay: true,\n            breakpoints: {\n                0: {\n                    slidesPerView: 1\n                },\n                576: {\n                    slidesPerView: 2\n                },\n                768: {\n                    slidesPerView: 2,\n                },\n                992: {\n                    slidesPerView: 3,\n                },\n                1200: {\n                    slidesPerView: 4,\n                }\n            }\n        }\n    }\n    constructor() {\n        super()\n        if (isPlatformBrowser(this.platformId)) {\n            this.document = document\n        }\n        // Swiper initialization moved to initSwiper() method called after data loads\n    }\n\n    ngOnInit() {\n        // console.log(this.productID)\n        this.load(this.productID)\n    }\n\n    private load(product_id:any) {\n        this._productsService.getRelatedProducts(product_id).pipe(take(1)).subscribe(\n            res => {\n                // console.log('response',res);\n                const relatedProducts:any = res.filter((elem:any) => !this.includeKeyword(elem.title.toLowerCase()))\n                this._relatedProductsSubject.next(relatedProducts)\n                res.map((products:any) => this._analyticsService.callEvent('view_item_list', { products: products.items, item_list_name: products.title || 'Related Products', item_list_id: products.id || 'related-products' }))\n                \n                // Inicializar swiper después de que los datos estén disponibles\n                if (isPlatformBrowser(this.platformId)) {\n                    setTimeout(() => {\n                        this.initSwiper();\n                    }, 100);\n                }\n            }\n        )\n    }\n\n    private initSwiper() {\n        if (isPlatformBrowser(this.platformId)) {\n            const swiperElemConstructor = this.document?.querySelector('#relatedProductsSwiper')\n            // console.log('swiperElemConstructor', swiperElemConstructor)\n            if (swiperElemConstructor) {\n                Object.assign(swiperElemConstructor!, this.swiperOptions())\n                this.swiperElement.set(swiperElemConstructor as SwiperContainer)\n                this.swiperElement()?.initialize();\n            }\n        }\n    }\n\n    includeKeyword = (word:string) => {\n        let result = false\n        this.keywordsToCompare.forEach( keyword => {\n            word.includes(keyword) ? result = true : null\n        })\n        return result\n    }\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes['productID'] && changes['productID'].currentValue && !changes['productID'].firstChange) {\n            // Solo reinicializar si el productID realmente cambió y no es la primera vez\n            this.ngOnInit();\n        }\n    }\n}\n\n","\n"]}
|
|
@@ -46,7 +46,9 @@ export class MagnizoomEcComponent {
|
|
|
46
46
|
this.image = this.document.createElement('img');
|
|
47
47
|
this.image.onload = () => {
|
|
48
48
|
this.lensSize = { width: this.image.width / 2, height: this.image.height / 2 };
|
|
49
|
-
|
|
49
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
50
|
+
setTimeout(() => this.render());
|
|
51
|
+
}
|
|
50
52
|
};
|
|
51
53
|
this.image.src = src;
|
|
52
54
|
}
|
|
@@ -175,4 +177,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
175
177
|
type: ViewChild,
|
|
176
178
|
args: ['mainCanvas', { static: true }]
|
|
177
179
|
}] } });
|
|
178
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"magnizoom-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/widgets-ec/magnizoom-ec/magnizoom-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/widgets-ec/magnizoom-ec/magnizoom-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport { afterNextRender, afterRender, Component, ElementRef, inject, Input, OnInit, PLATFORM_ID, ViewChild } from '@angular/core';\n\ninterface Size2D { width: number; height: number; }\ntype Point2D = { x: number, y: number } | null;\n\n@Component({\n\tselector: '[app-magnizoom-ec]',\n\tstandalone: true,\n\timports: [CommonModule],\n\ttemplateUrl: './magnizoom-ec.component.html',\n\tstyleUrl: './magnizoom-ec.component.scss'\n})\nexport class MagnizoomEcComponent implements OnInit {\n\tprivate document:Document | null = null;\n    private platformId = inject(PLATFORM_ID);\n\n\tprivate imageSrc:string='';\n    @Input() set ImageSrc(value:string) { \n        this.imageSrc = value; \n        this.loadImage(this.imageSrc); \n    }\n    @Input() zoomMode: 'LENS' | 'COVER' = 'COVER';\n    @Input() minZoomFactor = 1.2;\n    @Input() maxZoomFactor = 3;\n\n    @Input()\n\timageStyle!: { [x: string]: any; };\n    @Input() imageClass: any;\n\n    @ViewChild('mainCanvas', { static: true }) mainCanvasRef!: ElementRef;\n\n    canvas!: HTMLCanvasElement;\n    context!: CanvasRenderingContext2D | null;\n    image!: HTMLImageElement;\n\n    mousePosition: Point2D = null;\n    lensSize: Size2D = { width: 400, height: 300 };\n    zoomFactor = 2;\n\n    get canvasWidth() { return this.image && this.image.width || 800; }\n    get canvasHeight() { return this.image && this.image.height || 600; }\n\n    constructor() {\n        if (isPlatformBrowser(this.platformId)) {\n            this.document = inject(DOCUMENT); // Solo se inyecta en el navegador\n          }\n\t\tafterRender(()=> {\n\t\t\tthis.initContext();\n\t\t\tthis.loadImage(this.imageSrc);\n\t\t})\n\t }\n    \n    ngOnInit() {\n       /*  this.initContext();\n        this.loadImage(this.imageSrc); */\n    }\n\n    initContext() {\n        \n        this.canvas = (this.mainCanvasRef.nativeElement as HTMLCanvasElement);\n        this.context = this.canvas.getContext('2d');\n    }\n\n    loadImage(src: string) {\n\t\tif(this.document){\n\t\t\tthis.image = this.document.createElement('img');\n\t\t\tthis.image.onload = () => {\n\t\t\t\tthis.lensSize = { width: this.image.width / 2, height: this.image.height / 2 };\n\t\t\t\tsetTimeout(() => this.render());\n\t\t\t};\n\t\t\tthis.image.src = src;\n\t\t}\n    }\n\n    render() {\n\t\tif(this.context){\n\t\t\tthis.context.clearRect(0, 0, this.canvasWidth, this.canvasHeight); // clear canvas\n\t\t\tthis.context.lineWidth = 1; // border width\n\t\t\tthis.context.drawImage(this.image, 0, 0); // bg image\n\n\t\t\tif (this.mousePosition) {\n\t\t\t\tswitch (this.zoomMode) {\n\t\t\t\t\tcase 'LENS': this.renderLensMode(); break;\n\t\t\t\t\tcase 'COVER': this.renderCoverMode(); break;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n    }\n\n    renderLensMode() {\n\t\tif(this.context){\n        this.context.lineWidth = 5; // border width\n        const zoomRect = this.getZoomRect();\n        this.context.fillRect(zoomRect.x, zoomRect.y, zoomRect.w, zoomRect.h); // bg (clear)\n        const clippingRect = this.getClippingRect();\n        // zoom image\n        this.context.drawImage(\n            this.image,\n            clippingRect.x, clippingRect.y, clippingRect.w, clippingRect.h,\n            zoomRect.x, zoomRect.y, zoomRect.w, zoomRect.h\n        );\n        this.context.strokeRect(zoomRect.x, zoomRect.y, zoomRect.w, zoomRect.h); // border\n\t}\n\t}\n\n    renderCoverMode() {\n        const covertRect = this.getCoverRect();\n        this.context && this.context.drawImage(\n            this.image,\n            covertRect.x, covertRect.y, covertRect.w, covertRect.h,\n            0, 0, this.canvasWidth, this.canvasHeight\n        ); // cover image\n    }\n\n    getZoomRect() {\n        const w = this.lensSize.width;\n        const h = this.lensSize.height;\n        const x = this.mousePosition!.x - (w / 2);\n        const y = this.mousePosition!.y - (h / 2);\n        return this.clampRect(x, y, w, h);\n    }\n\n    getClippingRect() {\n        const w = this.lensSize.width / this.zoomFactor;\n        const h = this.lensSize.height / this.zoomFactor;\n        const x = this.mousePosition!.x - (w / 2);\n        const y = this.mousePosition!.y - (h / 2);\n        return this.clampRect(x, y, w, h);\n    }\n\n    getCoverRect() {\n        const w = this.canvasWidth / this.zoomFactor;\n        const h = this.canvasHeight / this.zoomFactor;\n        // const x = this.mousePosition.x - (w / 2);\n        // const y = this.mousePosition.y - (h / 2);\n        const x = this.mousePosition!.x - this.mousePosition!.x / this.zoomFactor;\n        const y = this.mousePosition!.y - this.mousePosition!.y / this.zoomFactor;\n        return this.clampRect(x, y, w, h);\n    }\n\n    clampRect(x: number, y: number, w: number, h: number) {\n        if (x <= 0) { x = 0; }\n        if (x + w >= this.canvasWidth) { x = this.canvasWidth - w; }\n        if (y < 0) { y = 0; }\n        if (y + h >= this.canvasHeight) { y = this.canvasHeight - h; }\n        return { x, y, w, h };\n    }\n\n    calculateMousePosition(clientX: number, clientY: number) {\n        const boundingRect = this.canvas.getBoundingClientRect();\n        const viewToModelX = this.canvasWidth / boundingRect.width;\n        const viewToModelY = this.canvasHeight / boundingRect.height;\n        const x = (clientX - boundingRect.left) * viewToModelX;\n        const y = (clientY - boundingRect.top) * viewToModelY;\n        this.mousePosition = { x, y };\n    }\n\n    onMouseLeave(event: MouseEvent) {\n        this.mousePosition = null;\n        this.render();\n    }\n\n    onMouseEnterOrMove(event: MouseEvent) {\n        this.calculateMousePosition(event.clientX, event.clientY);\n        this.render();\n    }\n\n    onMouseScroll(event: WheelEvent) {\n        let newZoomFactor = this.zoomFactor;\n        newZoomFactor -= event.deltaY / 1000;\n        if (newZoomFactor < this.minZoomFactor) { newZoomFactor = this.minZoomFactor; }\n        if (newZoomFactor > this.maxZoomFactor) { newZoomFactor = this.maxZoomFactor; }\n        if (this.zoomFactor !== newZoomFactor) {\n            this.zoomFactor = newZoomFactor;\n            this.render();\n        }\n        event.preventDefault();\n        event.stopPropagation();\n    }\n}\n","<canvas #mainCanvas\n  class=\"main-canvas\"\n  [ngClass]=\"imageClass\"\n  [ngStyle]=\"imageStyle\"\n  [width]=\"canvasWidth\"\n  [height]=\"canvasHeight\"\n  (mouseleave)=\"onMouseLeave($event)\"\n  (mouseenter)=\"onMouseEnterOrMove($event)\"\n  (mousemove)=\"onMouseEnterOrMove($event)\"\n  (wheel)=\"onMouseScroll($event)\">\n</canvas>\n"]}
|
|
180
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"magnizoom-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/widgets-ec/magnizoom-ec/magnizoom-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/widgets-ec/magnizoom-ec/magnizoom-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport { afterNextRender, afterRender, Component, ElementRef, inject, Input, OnInit, PLATFORM_ID, ViewChild } from '@angular/core';\n\ninterface Size2D { width: number; height: number; }\ntype Point2D = { x: number, y: number } | null;\n\n@Component({\n\tselector: '[app-magnizoom-ec]',\n\tstandalone: true,\n\timports: [CommonModule],\n\ttemplateUrl: './magnizoom-ec.component.html',\n\tstyleUrl: './magnizoom-ec.component.scss'\n})\nexport class MagnizoomEcComponent implements OnInit {\n\tprivate document:Document | null = null;\n    private platformId = inject(PLATFORM_ID);\n\n\tprivate imageSrc:string='';\n    @Input() set ImageSrc(value:string) { \n        this.imageSrc = value; \n        this.loadImage(this.imageSrc); \n    }\n    @Input() zoomMode: 'LENS' | 'COVER' = 'COVER';\n    @Input() minZoomFactor = 1.2;\n    @Input() maxZoomFactor = 3;\n\n    @Input()\n\timageStyle!: { [x: string]: any; };\n    @Input() imageClass: any;\n\n    @ViewChild('mainCanvas', { static: true }) mainCanvasRef!: ElementRef;\n\n    canvas!: HTMLCanvasElement;\n    context!: CanvasRenderingContext2D | null;\n    image!: HTMLImageElement;\n\n    mousePosition: Point2D = null;\n    lensSize: Size2D = { width: 400, height: 300 };\n    zoomFactor = 2;\n\n    get canvasWidth() { return this.image && this.image.width || 800; }\n    get canvasHeight() { return this.image && this.image.height || 600; }\n\n    constructor() {\n        if (isPlatformBrowser(this.platformId)) {\n            this.document = inject(DOCUMENT); // Solo se inyecta en el navegador\n          }\n\t\tafterRender(()=> {\n\t\t\tthis.initContext();\n\t\t\tthis.loadImage(this.imageSrc);\n\t\t})\n\t }\n    \n    ngOnInit() {\n       /*  this.initContext();\n        this.loadImage(this.imageSrc); */\n    }\n\n    initContext() {\n        \n        this.canvas = (this.mainCanvasRef.nativeElement as HTMLCanvasElement);\n        this.context = this.canvas.getContext('2d');\n    }\n\n    loadImage(src: string) {\n\t\tif(this.document){\n\t\t\tthis.image = this.document.createElement('img');\n\t\t\tthis.image.onload = () => {\n\t\t\t\tthis.lensSize = { width: this.image.width / 2, height: this.image.height / 2 };\n\t\t\t\tif (isPlatformBrowser(this.platformId)) {\n\t\t\t\t\tsetTimeout(() => this.render());\n\t\t\t\t}\n\t\t\t};\n\t\t\tthis.image.src = src;\n\t\t}\n    }\n\n    render() {\n\t\tif(this.context){\n\t\t\tthis.context.clearRect(0, 0, this.canvasWidth, this.canvasHeight); // clear canvas\n\t\t\tthis.context.lineWidth = 1; // border width\n\t\t\tthis.context.drawImage(this.image, 0, 0); // bg image\n\n\t\t\tif (this.mousePosition) {\n\t\t\t\tswitch (this.zoomMode) {\n\t\t\t\t\tcase 'LENS': this.renderLensMode(); break;\n\t\t\t\t\tcase 'COVER': this.renderCoverMode(); break;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n    }\n\n    renderLensMode() {\n\t\tif(this.context){\n        this.context.lineWidth = 5; // border width\n        const zoomRect = this.getZoomRect();\n        this.context.fillRect(zoomRect.x, zoomRect.y, zoomRect.w, zoomRect.h); // bg (clear)\n        const clippingRect = this.getClippingRect();\n        // zoom image\n        this.context.drawImage(\n            this.image,\n            clippingRect.x, clippingRect.y, clippingRect.w, clippingRect.h,\n            zoomRect.x, zoomRect.y, zoomRect.w, zoomRect.h\n        );\n        this.context.strokeRect(zoomRect.x, zoomRect.y, zoomRect.w, zoomRect.h); // border\n\t}\n\t}\n\n    renderCoverMode() {\n        const covertRect = this.getCoverRect();\n        this.context && this.context.drawImage(\n            this.image,\n            covertRect.x, covertRect.y, covertRect.w, covertRect.h,\n            0, 0, this.canvasWidth, this.canvasHeight\n        ); // cover image\n    }\n\n    getZoomRect() {\n        const w = this.lensSize.width;\n        const h = this.lensSize.height;\n        const x = this.mousePosition!.x - (w / 2);\n        const y = this.mousePosition!.y - (h / 2);\n        return this.clampRect(x, y, w, h);\n    }\n\n    getClippingRect() {\n        const w = this.lensSize.width / this.zoomFactor;\n        const h = this.lensSize.height / this.zoomFactor;\n        const x = this.mousePosition!.x - (w / 2);\n        const y = this.mousePosition!.y - (h / 2);\n        return this.clampRect(x, y, w, h);\n    }\n\n    getCoverRect() {\n        const w = this.canvasWidth / this.zoomFactor;\n        const h = this.canvasHeight / this.zoomFactor;\n        // const x = this.mousePosition.x - (w / 2);\n        // const y = this.mousePosition.y - (h / 2);\n        const x = this.mousePosition!.x - this.mousePosition!.x / this.zoomFactor;\n        const y = this.mousePosition!.y - this.mousePosition!.y / this.zoomFactor;\n        return this.clampRect(x, y, w, h);\n    }\n\n    clampRect(x: number, y: number, w: number, h: number) {\n        if (x <= 0) { x = 0; }\n        if (x + w >= this.canvasWidth) { x = this.canvasWidth - w; }\n        if (y < 0) { y = 0; }\n        if (y + h >= this.canvasHeight) { y = this.canvasHeight - h; }\n        return { x, y, w, h };\n    }\n\n    calculateMousePosition(clientX: number, clientY: number) {\n        const boundingRect = this.canvas.getBoundingClientRect();\n        const viewToModelX = this.canvasWidth / boundingRect.width;\n        const viewToModelY = this.canvasHeight / boundingRect.height;\n        const x = (clientX - boundingRect.left) * viewToModelX;\n        const y = (clientY - boundingRect.top) * viewToModelY;\n        this.mousePosition = { x, y };\n    }\n\n    onMouseLeave(event: MouseEvent) {\n        this.mousePosition = null;\n        this.render();\n    }\n\n    onMouseEnterOrMove(event: MouseEvent) {\n        this.calculateMousePosition(event.clientX, event.clientY);\n        this.render();\n    }\n\n    onMouseScroll(event: WheelEvent) {\n        let newZoomFactor = this.zoomFactor;\n        newZoomFactor -= event.deltaY / 1000;\n        if (newZoomFactor < this.minZoomFactor) { newZoomFactor = this.minZoomFactor; }\n        if (newZoomFactor > this.maxZoomFactor) { newZoomFactor = this.maxZoomFactor; }\n        if (this.zoomFactor !== newZoomFactor) {\n            this.zoomFactor = newZoomFactor;\n            this.render();\n        }\n        event.preventDefault();\n        event.stopPropagation();\n    }\n}\n","<canvas #mainCanvas\n  class=\"main-canvas\"\n  [ngClass]=\"imageClass\"\n  [ngStyle]=\"imageStyle\"\n  [width]=\"canvasWidth\"\n  [height]=\"canvasHeight\"\n  (mouseleave)=\"onMouseLeave($event)\"\n  (mouseenter)=\"onMouseEnterOrMove($event)\"\n  (mousemove)=\"onMouseEnterOrMove($event)\"\n  (wheel)=\"onMouseScroll($event)\">\n</canvas>\n"]}
|