ng-easycommerce-v18 0.3.21-beta.3 → 0.3.22-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.
Files changed (23) hide show
  1. package/README.md +7 -7
  2. package/esm2022/lib/classes/filters/filter.mjs +27 -2
  3. package/esm2022/lib/constants/api.constants.service.mjs +7 -1
  4. package/esm2022/lib/ec-components/blocks-ec/block-products-ec/block-products-ec.component.mjs +5 -3
  5. package/esm2022/lib/ec-components/checkout-ec/payment-ec/payment-ec.component.mjs +1 -5
  6. package/esm2022/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.mjs +44 -53
  7. package/esm2022/lib/ec-components/header-ec/header-ec.component.mjs +32 -23
  8. package/esm2022/lib/ec-components/related-products-ec/related-products-ec.component.mjs +6 -4
  9. package/esm2022/lib/ec-components/widgets-ec/magnizoom-ec/magnizoom-ec.component.mjs +4 -2
  10. package/esm2022/lib/ec-components/widgets-ec/redsys-catch-ec/redsys-catch-ec.component.mjs +7 -17
  11. package/esm2022/lib/ec-services/analytics/facebook-pixel.service.mjs +4 -2
  12. package/esm2022/lib/ec-services/analytics/google-analytics.service.mjs +4 -2
  13. package/esm2022/lib/ec-services/analytics/gtm.service.mjs +90 -30
  14. package/esm2022/lib/ec-services/options.service.mjs +27 -3
  15. package/esm2022/lib/ec-services/parameters.service.mjs +41 -1
  16. package/fesm2022/ng-easycommerce-v18.mjs +445 -296
  17. package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
  18. package/lib/constants/api.constants.service.d.ts +4 -0
  19. package/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.d.ts +0 -1
  20. package/lib/ec-services/analytics/gtm.service.d.ts +5 -0
  21. package/lib/ec-services/options.service.d.ts +4 -0
  22. package/lib/ec-services/parameters.service.d.ts +6 -0
  23. package/package.json +1 -1
@@ -1,4 +1,4 @@
1
- import { Component, EventEmitter, inject, Input, Output, PLATFORM_ID, NgZone } from '@angular/core';
1
+ import { Component, EventEmitter, inject, Input, Output, PLATFORM_ID } from '@angular/core';
2
2
  import { PaymentService, ToastService } from '../../../../../ec-services';
3
3
  import { LoadingFullEcComponent } from '../../../../widgets-ec';
4
4
  import { isPlatformBrowser } from '@angular/common';
@@ -8,7 +8,6 @@ export class MpRedirectEcComponent {
8
8
  _toastService = inject(ToastService);
9
9
  platformId = inject(PLATFORM_ID);
10
10
  finished = false;
11
- ngZone = inject(NgZone);
12
11
  method = null;
13
12
  total_amount = 0;
14
13
  allData;
@@ -31,10 +30,10 @@ export class MpRedirectEcComponent {
31
30
  this.windowRef = window;
32
31
  if ('BroadcastChannel' in window) {
33
32
  this.bc = new BroadcastChannel('mp_payment');
34
- this.bc.onmessage = (e) => this.ngZone.run(() => this.onMpMessage(e?.data));
33
+ this.bc.onmessage = (e) => this.onMpMessage(e?.data);
35
34
  }
36
- window.addEventListener('storage', (e) => this.ngZone.run(() => this.onStorage(e)));
37
- window.addEventListener('message', (e) => this.ngZone.run(() => this.onWindowMessage(e)));
35
+ window.addEventListener('storage', this.onStorage);
36
+ window.addEventListener('message', this.onWindowMessage);
38
37
  }
39
38
  this.getPreference();
40
39
  }
@@ -87,29 +86,23 @@ export class MpRedirectEcComponent {
87
86
  }, 1000);
88
87
  };
89
88
  onWindowMessage = (event) => {
90
- this.ngZone.run(() => {
91
- const data = event?.data;
92
- this.onMpMessage(data);
93
- });
89
+ const data = event?.data;
90
+ this.onMpMessage(data);
94
91
  };
95
92
  onStorage = (e) => {
96
- this.ngZone.run(() => {
97
- if (!e.key || !this.sid)
98
- return;
99
- if (e.key === `mp:state:${this.sid}` && e.newValue) {
100
- const state = e.newValue;
101
- this.finishWithState(state);
102
- }
103
- });
93
+ if (!e.key || !this.sid)
94
+ return;
95
+ if (e.key === `mp:state:${this.sid}` && e.newValue) {
96
+ const state = e.newValue;
97
+ this.finishWithState(state);
98
+ }
104
99
  };
105
100
  onMpMessage = (data) => {
106
- this.ngZone.run(() => {
107
- if (!data || data.type !== 'mp:state')
108
- return;
109
- if (data.sid !== this.sid)
110
- return;
111
- this.finishWithState(data.state);
112
- });
101
+ if (!data || data.type !== 'mp:state')
102
+ return;
103
+ if (data.sid !== this.sid)
104
+ return;
105
+ this.finishWithState(data.state);
113
106
  };
114
107
  checkLocalStorageOnce() {
115
108
  if (!this.sid)
@@ -120,34 +113,32 @@ export class MpRedirectEcComponent {
120
113
  }
121
114
  /** Cierra el flujo de pago con el estado final y notifica al padre. */
122
115
  finishWithState(state) {
123
- this.ngZone.run(() => {
124
- if (this.finished)
125
- return;
126
- this.finished = true;
127
- if (this.pollTimer)
128
- clearInterval(this.pollTimer);
129
- this.pollTimer = null;
130
- localStorage.removeItem(`mp:state:${this.sid}`);
131
- localStorage.removeItem('mp:sid');
132
- localStorage.removeItem('state');
133
- try {
134
- this.ventana && !this.ventana.closed && this.ventana.close();
135
- }
136
- catch { }
137
- this.ventana = null;
138
- if (state === 'success' || state === 'pending') {
139
- this.phase = 'finalizing';
140
- this.ready.emit(true);
141
- }
142
- else if (state === 'failure' || state === 'cancel') {
143
- this.phase = 'idle';
144
- this._toastService.show(state === 'cancel' ? 'Se canceló el pago con Mercado Pago' : 'payment-error');
145
- }
146
- else {
147
- this.phase = 'idle';
148
- this._toastService.show('payment-error');
149
- }
150
- });
116
+ if (this.finished)
117
+ return;
118
+ this.finished = true;
119
+ if (this.pollTimer)
120
+ clearInterval(this.pollTimer);
121
+ this.pollTimer = null;
122
+ localStorage.removeItem(`mp:state:${this.sid}`);
123
+ localStorage.removeItem('mp:sid');
124
+ localStorage.removeItem('state');
125
+ try {
126
+ this.ventana && !this.ventana.closed && this.ventana.close();
127
+ }
128
+ catch { }
129
+ this.ventana = null;
130
+ if (state === 'success' || state === 'pending') {
131
+ this.phase = 'finalizing';
132
+ this.ready.emit(true);
133
+ }
134
+ else if (state === 'failure' || state === 'cancel') {
135
+ this.phase = 'idle';
136
+ this._toastService.show(state === 'cancel' ? 'Se canceló el pago con Mercado Pago' : 'payment-error');
137
+ }
138
+ else {
139
+ this.phase = 'idle';
140
+ this._toastService.show('payment-error');
141
+ }
151
142
  }
152
143
  genSid() {
153
144
  return `mp_${Date.now()}_${Math.random().toString(36).slice(2, 9)}`;
@@ -191,4 +182,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
191
182
  }], ready: [{
192
183
  type: Output
193
184
  }] } });
194
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mp-redirect-ec.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.ts","../../../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, inject, Input, OnInit, Output, PLATFORM_ID, OnDestroy, NgZone } from '@angular/core';\nimport { PaymentService, ToastService } from '../../../../../ec-services';\nimport { LoadingFullEcComponent } from '../../../../widgets-ec';\nimport { isPlatformBrowser } from '@angular/common';\n\ntype MpState = 'success' | 'pending' | 'failure' | 'cancel';\ntype Phase = 'idle' | 'paying' | 'finalizing';\n\n@Component({\n\tselector: 'app-mp-redirect-ec',\n\tstandalone: true,\n\ttemplateUrl: './mp-redirect-ec.component.html',\n\tstyleUrls: ['./mp-redirect-ec.component.scss'],\n\timports: [LoadingFullEcComponent]\n})\nexport class MpRedirectEcComponent implements OnInit, OnDestroy {\n\n\tprivate _paymentService = inject(PaymentService);\n\tprivate _toastService = inject(ToastService);\n\tprivate platformId: any = inject(PLATFORM_ID);\n\tprivate finished = false;\n\tprivate ngZone = inject(NgZone);\n\n\t@Input() method = null;\n\t@Input() total_amount = 0;\n\t@Input() allData: any;\n\t@Output() ready = new EventEmitter<boolean>();\n\n\tprotected preference: any;\n\tpublic url?: string;\n\n\t// Fases de UI\n\tpublic phase: Phase = 'idle';\n\tget isIdle() { return this.phase === 'idle'; }\n\tget isPaying() { return this.phase === 'paying'; }\n\tget isFinalizing() { return this.phase === 'finalizing'; }\n\n\tprivate ventana: Window | null = null;\n\tprivate windowRef?: Window;\n\tprivate sid = '';\n\tprivate bc?: BroadcastChannel;\n\tprivate pollTimer?: any;\n\tprivate pollStartedAt = 0;\n\n\tngOnInit() {\n\t\tif (isPlatformBrowser(this.platformId)) {\n\t\t\tthis.windowRef = window;\n\n\t\t\tif ('BroadcastChannel' in window) {\n\t\t\t\tthis.bc = new BroadcastChannel('mp_payment');\n\t\t\t\tthis.bc.onmessage = (e: MessageEvent) =>\n\t\t\t\t\tthis.ngZone.run(() => this.onMpMessage(e?.data));\n\t\t\t}\n\n\t\t\twindow.addEventListener('storage', (e) =>\n\t\t\t\tthis.ngZone.run(() => this.onStorage(e as StorageEvent))\n\t\t\t);\n\t\t\twindow.addEventListener('message', (e) =>\n\t\t\t\tthis.ngZone.run(() => this.onWindowMessage(e as MessageEvent))\n\t\t\t);\n\t\t}\n\n\t\tthis.getPreference();\n\t}\n\n\tngOnDestroy() {\n\t\tif (!isPlatformBrowser(this.platformId)) return;\n\t\tthis.bc?.close();\n\t\twindow.removeEventListener('storage', this.onStorage);\n\t\twindow.removeEventListener('message', this.onWindowMessage);\n\t\tif (this.pollTimer) clearInterval(this.pollTimer);\n\t}\n\n\t/** Cancela manualmente el pago y finaliza el flujo con estado \"cancel\". */\n\tclickClose = () => {\n\t\tif (this.finished) return;\n\t\tthis.finishWithState('cancel');\n\t}\n\n\t/**\n\t * Inicia el pago abriendo `init_point` en una ventana/pestaña nueva.\n\t * Genera un SID y lo persiste para casar la respuesta del catch.\n\t * Si el popup es bloqueado, hace fallback navegando en la misma pestaña.\n\t */\n\tiniciar = () => {\n\t\tif (!isPlatformBrowser(this.platformId) || !this.windowRef || !this.url) return;\n\n\t\tthis.phase = 'paying';\n\t\tthis.sid = this.genSid();\n\t\tconst url = new URL(this.url);\n\n\t\tlocalStorage.setItem('mp:sid', this.sid);\n\n\t\tthis.ventana = this.windowRef.open(this.url, '_blank');\n\n\t\t// popup bloqueado → fallback a navegación en misma pestaña\n\t\tif (!this.ventana || this.ventana.closed) {\n\t\t\tthis.windowRef.location.href = this.url;\n\t\t\treturn;\n\t\t}\n\n\t\t// polling de último recurso (hasta 10 minutos)\n\t\tthis.pollStartedAt = Date.now();\n\t\tif (this.pollTimer) clearInterval(this.pollTimer);\n\t\tthis.pollTimer = setInterval(() => {\n\t\t\tif (Date.now() - this.pollStartedAt > 10 * 60 * 1000) {\n\t\t\t\tclearInterval(this.pollTimer);\n\t\t\t\tthis.pollTimer = null;\n\t\t\t\tthis.phase = 'idle';\n\t\t\t\tthis.processError('Tiempo de espera agotado al procesar el pago.');\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tthis.checkLocalStorageOnce();\n\t\t}, 1000);\n\t}\n\n\tprivate onWindowMessage = (event: MessageEvent) => {\n\t\tthis.ngZone.run(() => {\n\t\t\tconst data = event?.data;\n\t\t\tthis.onMpMessage(data);\n\t\t});\n\t}\n\n\tprivate onStorage = (e: StorageEvent) => {\n\t\tthis.ngZone.run(() => {\n\t\t\tif (!e.key || !this.sid) return;\n\t\t\tif (e.key === `mp:state:${this.sid}` && e.newValue) {\n\t\t\t\tconst state = e.newValue as MpState;\n\t\t\t\tthis.finishWithState(state);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate onMpMessage = (data: any) => {\n\t\tthis.ngZone.run(() => {\n\t\t\tif (!data || data.type !== 'mp:state') return;\n\t\t\tif (data.sid !== this.sid) return;\n\t\t\tthis.finishWithState(data.state as MpState);\n\t\t});\n\t}\n\n\tprivate checkLocalStorageOnce() {\n\t\tif (!this.sid) return;\n\t\tconst state = localStorage.getItem(`mp:state:${this.sid}`) as MpState | null;\n\t\tif (state) this.finishWithState(state);\n\t}\n\n\t/** Cierra el flujo de pago con el estado final y notifica al padre. */\n\tprivate finishWithState(state: MpState) {\n\t\tthis.ngZone.run(() => {\n\t\t\tif (this.finished) return;\n\t\t\tthis.finished = true;\n\n\t\t\tif (this.pollTimer) clearInterval(this.pollTimer);\n\t\t\tthis.pollTimer = null;\n\n\t\t\tlocalStorage.removeItem(`mp:state:${this.sid}`);\n\t\t\tlocalStorage.removeItem('mp:sid');\n\t\t\tlocalStorage.removeItem('state');\n\n\t\t\ttry { this.ventana && !this.ventana.closed && this.ventana.close(); } catch { }\n\t\t\tthis.ventana = null;\n\n\t\t\tif (state === 'success' || state === 'pending') {\n\t\t\t\tthis.phase = 'finalizing';\n\t\t\t\tthis.ready.emit(true);\n\t\t\t} else if (state === 'failure' || state === 'cancel') {\n\t\t\t\tthis.phase = 'idle';\n\t\t\t\tthis._toastService.show(state === 'cancel' ? 'Se canceló el pago con Mercado Pago' : 'payment-error');\n\t\t\t} else {\n\t\t\t\tthis.phase = 'idle';\n\t\t\t\tthis._toastService.show('payment-error');\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate genSid(): string {\n\t\treturn `mp_${Date.now()}_${Math.random().toString(36).slice(2, 9)}`;\n\t}\n\n\tprivate processError = (msg: string) => {\n\t\tthis._toastService.show(msg || 'payment-error');\n\t}\n\n\t/** Limpia posibles residuos de estado en storages. */\n\tclearStorageState = () => {\n\t\tif (!isPlatformBrowser(this.platformId)) return;\n\t\tlocalStorage.removeItem('state');\n\t\tconst sid = localStorage.getItem('mp:sid');\n\t\tif (sid) localStorage.removeItem(`mp:state:${sid}`);\n\t}\n\n\t/** Obtiene la preferencia e inicializa `url` (init_point). */\n\tprivate getPreference = (): void => {\n\t\tthis._paymentService.getPreference(this.allData).then(\n\t\t\t(res) => {\n\t\t\t\tthis.preference = res;\n\t\t\t\tthis.url = this.preference?.init_point;\n\t\t\t\tthis.renderMP(this.preference);\n\t\t\t},\n\t\t\t() => this.setError('operation-error')\n\t\t);\n\t};\n\n\tprivate setError = (message: any) => {\n\t\t//this.error = message;\n\t}\n\n\tprivate renderMP = (_pref: any): void => { /* noop */ };\n}\n","<div class=\"text-center\">\n\t@if(url) {\n\n\t@if(isIdle) {\n\t<button (click)=\"iniciar()\" class=\"btn btn-outline-primary rounded-0 comprar mt-3\">Pagar</button>\n\t}\n\n\t@if(isPaying) {\n\t<div class=\"d-flex flex-column jusitfy-content-center align-items-center mt-2\">\n\t\t<h3>Procesando el pago por Mercado Pago</h3>\n\t\t<h5>Recordá tocar “Volver al sitio” en Mercado Pago para finalizar.</h5>\n\t\t<app-loading-full-ec></app-loading-full-ec>\n\t</div>\n\n\t<div class=\"container-fluid\">\n\t\t<div class=\"row\">\n\t\t\t<div class=\"col-5\">\n\t\t\t\t<hr>\n\t\t\t</div>\n\t\t\t<div class=\"col-2 text-center\"><label>o</label></div>\n\t\t\t<div class=\"col-5\">\n\t\t\t\t<hr>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n\n\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\n\t\t<button (click)=\"clickClose()\" class=\"btn btn-outline-secondary\">Cancelar pago</button>\n\t</div>\n\t}\n\n\t@if(isFinalizing) {\n\t<div class=\"d-flex flex-column jusitfy-content-center align-items-center mt-2\">\n\t\t<h3>Confirmando pago y redirigiendo…</h3>\n\t\t<h5>No cierres ni recargues esta página.</h5>\n\t\t<app-loading-full-ec></app-loading-full-ec>\n\t</div>\n\t}\n\n\t} @else {\n\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\n\t\t<app-loading-full-ec></app-loading-full-ec>\n\t</div>\n\t}\n</div>"]}
185
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mp-redirect-ec.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.ts","../../../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, inject, Input, OnInit, Output, PLATFORM_ID, OnDestroy } from '@angular/core';\nimport { PaymentService, ToastService } from '../../../../../ec-services';\nimport { LoadingFullEcComponent } from '../../../../widgets-ec';\nimport { isPlatformBrowser } from '@angular/common';\n\ntype MpState = 'success' | 'pending' | 'failure' | 'cancel';\ntype Phase = 'idle' | 'paying' | 'finalizing';\n\n@Component({\n\tselector: 'app-mp-redirect-ec',\n\tstandalone: true,\n\ttemplateUrl: './mp-redirect-ec.component.html',\n\tstyleUrls: ['./mp-redirect-ec.component.scss'],\n\timports: [LoadingFullEcComponent]\n})\nexport class MpRedirectEcComponent implements OnInit, OnDestroy {\n\n\tprivate _paymentService = inject(PaymentService);\n\tprivate _toastService = inject(ToastService);\n\tprivate platformId: any = inject(PLATFORM_ID);\n\tprivate finished = false;\n\n\t@Input() method = null;\n\t@Input() total_amount = 0;\n\t@Input() allData: any;\n\t@Output() ready = new EventEmitter<boolean>();\n\n\tprotected preference: any;\n\tpublic url?: string;\n\n\t// Fases de UI\n\tpublic phase: Phase = 'idle';\n\tget isIdle() { return this.phase === 'idle'; }\n\tget isPaying() { return this.phase === 'paying'; }\n\tget isFinalizing() { return this.phase === 'finalizing'; }\n\n\tprivate ventana: Window | null = null;\n\tprivate windowRef?: Window;\n\tprivate sid = '';\n\tprivate bc?: BroadcastChannel;\n\tprivate pollTimer?: any;\n\tprivate pollStartedAt = 0;\n\n\tngOnInit() {\n\t\tif (isPlatformBrowser(this.platformId)) {\n\t\t\tthis.windowRef = window;\n\n\t\t\tif ('BroadcastChannel' in window) {\n\t\t\t\tthis.bc = new BroadcastChannel('mp_payment');\n\t\t\t\tthis.bc.onmessage = (e: MessageEvent) => this.onMpMessage(e?.data);\n\t\t\t}\n\n\t\t\twindow.addEventListener('storage', this.onStorage);\n\t\t\twindow.addEventListener('message', this.onWindowMessage);\n\t\t}\n\n\t\tthis.getPreference();\n\t}\n\n\tngOnDestroy() {\n\t\tif (!isPlatformBrowser(this.platformId)) return;\n\t\tthis.bc?.close();\n\t\twindow.removeEventListener('storage', this.onStorage);\n\t\twindow.removeEventListener('message', this.onWindowMessage);\n\t\tif (this.pollTimer) clearInterval(this.pollTimer);\n\t}\n\n\t/** Cancela manualmente el pago y finaliza el flujo con estado \"cancel\". */\n\tclickClose = () => {\n\t\tif (this.finished) return;\n\t\tthis.finishWithState('cancel');\n\t}\n\n\t/**\n\t * Inicia el pago abriendo `init_point` en una ventana/pestaña nueva.\n\t * Genera un SID y lo persiste para casar la respuesta del catch.\n\t * Si el popup es bloqueado, hace fallback navegando en la misma pestaña.\n\t */\n\tiniciar = () => {\n\t\tif (!isPlatformBrowser(this.platformId) || !this.windowRef || !this.url) return;\n\n\t\tthis.phase = 'paying';\n\t\tthis.sid = this.genSid();\n\t\tconst url = new URL(this.url);\n\n\t\tlocalStorage.setItem('mp:sid', this.sid);\n\n\t\tthis.ventana = this.windowRef.open(this.url, '_blank');\n\n\t\t// popup bloqueado → fallback a navegación en misma pestaña\n\t\tif (!this.ventana || this.ventana.closed) {\n\t\t\tthis.windowRef.location.href = this.url;\n\t\t\treturn;\n\t\t}\n\n\t\t// polling de último recurso (hasta 10 minutos)\n\t\tthis.pollStartedAt = Date.now();\n\t\tif (this.pollTimer) clearInterval(this.pollTimer);\n\t\tthis.pollTimer = setInterval(() => {\n\t\t\tif (Date.now() - this.pollStartedAt > 10 * 60 * 1000) {\n\t\t\t\tclearInterval(this.pollTimer);\n\t\t\t\tthis.pollTimer = null;\n\t\t\t\tthis.phase = 'idle';\n\t\t\t\tthis.processError('Tiempo de espera agotado al procesar el pago.');\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tthis.checkLocalStorageOnce();\n\t\t}, 1000);\n\t}\n\n\tprivate onWindowMessage = (event: MessageEvent) => {\n\t\tconst data = event?.data;\n\t\tthis.onMpMessage(data);\n\t}\n\n\tprivate onStorage = (e: StorageEvent) => {\n\t\tif (!e.key || !this.sid) return;\n\t\tif (e.key === `mp:state:${this.sid}` && e.newValue) {\n\t\t\tconst state = e.newValue as MpState;\n\t\t\tthis.finishWithState(state);\n\t\t}\n\t}\n\n\tprivate onMpMessage = (data: any) => {\n\t\tif (!data || data.type !== 'mp:state') return;\n\t\tif (data.sid !== this.sid) return;\n\t\tthis.finishWithState(data.state as MpState);\n\t}\n\n\tprivate checkLocalStorageOnce() {\n\t\tif (!this.sid) return;\n\t\tconst state = localStorage.getItem(`mp:state:${this.sid}`) as MpState | null;\n\t\tif (state) this.finishWithState(state);\n\t}\n\n\t/** Cierra el flujo de pago con el estado final y notifica al padre. */\n\tprivate finishWithState(state: MpState) {\n\t\tif (this.finished) return;\n\t\tthis.finished = true;\n\n\t\tif (this.pollTimer) clearInterval(this.pollTimer);\n\t\tthis.pollTimer = null;\n\n\t\tlocalStorage.removeItem(`mp:state:${this.sid}`);\n\t\tlocalStorage.removeItem('mp:sid');\n\t\tlocalStorage.removeItem('state');\n\n\t\ttry { this.ventana && !this.ventana.closed && this.ventana.close(); } catch { }\n\t\tthis.ventana = null;\n\n\t\tif (state === 'success' || state === 'pending') {\n\t\t\tthis.phase = 'finalizing';\n\t\t\tthis.ready.emit(true);\n\t\t} else if (state === 'failure' || state === 'cancel') {\n\t\t\tthis.phase = 'idle';\n\t\t\tthis._toastService.show(state === 'cancel' ? 'Se canceló el pago con Mercado Pago' : 'payment-error');\n\t\t} else {\n\t\t\tthis.phase = 'idle';\n\t\t\tthis._toastService.show('payment-error');\n\t\t}\n\t}\n\n\tprivate genSid(): string {\n\t\treturn `mp_${Date.now()}_${Math.random().toString(36).slice(2, 9)}`;\n\t}\n\n\tprivate processError = (msg: string) => {\n\t\tthis._toastService.show(msg || 'payment-error');\n\t}\n\n\t/** Limpia posibles residuos de estado en storages. */\n\tclearStorageState = () => {\n\t\tif (!isPlatformBrowser(this.platformId)) return;\n\t\tlocalStorage.removeItem('state');\n\t\tconst sid = localStorage.getItem('mp:sid');\n\t\tif (sid) localStorage.removeItem(`mp:state:${sid}`);\n\t}\n\n\t/** Obtiene la preferencia e inicializa `url` (init_point). */\n\tprivate getPreference = (): void => {\n\t\tthis._paymentService.getPreference(this.allData).then(\n\t\t\t(res) => {\n\t\t\t\tthis.preference = res;\n\t\t\t\tthis.url = this.preference?.init_point;\n\t\t\t\tthis.renderMP(this.preference);\n\t\t\t},\n\t\t\t() => this.setError('operation-error')\n\t\t);\n\t};\n\n\tprivate setError = (message: any) => {\n\t\t//this.error = message;\n\t}\n\n\tprivate renderMP = (_pref: any): void => { /* noop */ };\n}\n","<div class=\"text-center\">\n\t@if(url) {\n\n\t@if(isIdle) {\n\t<button (click)=\"iniciar()\" class=\"btn btn-outline-primary rounded-0 comprar mt-3\">Pagar</button>\n\t}\n\n\t@if(isPaying) {\n\t<div class=\"d-flex flex-column jusitfy-content-center align-items-center mt-2\">\n\t\t<h3>Procesando el pago por Mercado Pago</h3>\n\t\t<h5>Recordá tocar “Volver al sitio” en Mercado Pago para finalizar.</h5>\n\t\t<app-loading-full-ec></app-loading-full-ec>\n\t</div>\n\n\t<div class=\"container-fluid\">\n\t\t<div class=\"row\">\n\t\t\t<div class=\"col-5\">\n\t\t\t\t<hr>\n\t\t\t</div>\n\t\t\t<div class=\"col-2 text-center\"><label>o</label></div>\n\t\t\t<div class=\"col-5\">\n\t\t\t\t<hr>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n\n\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\n\t\t<button (click)=\"clickClose()\" class=\"btn btn-outline-secondary\">Cancelar pago</button>\n\t</div>\n\t}\n\n\t@if(isFinalizing) {\n\t<div class=\"d-flex flex-column jusitfy-content-center align-items-center mt-2\">\n\t\t<h3>Confirmando pago y redirigiendo…</h3>\n\t\t<h5>No cierres ni recargues esta página.</h5>\n\t\t<app-loading-full-ec></app-loading-full-ec>\n\t</div>\n\t}\n\n\t} @else {\n\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\n\t\t<app-loading-full-ec></app-loading-full-ec>\n\t</div>\n\t}\n</div>"]}
@@ -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.
@@ -78,17 +77,21 @@ export class HeaderEcComponent extends MenuEcComponent {
78
77
  });
79
78
  }
80
79
  onWindowScroll() {
81
- const scrollTop = window.scrollY;
82
- this.isScrolled = scrollTop > 80;
80
+ if (isPlatformBrowser(this.platformId)) {
81
+ const scrollTop = window.scrollY;
82
+ this.isScrolled = scrollTop > 80;
83
+ }
83
84
  }
84
85
  isHomeFunction() {
85
- const headerElement = document.querySelector('header');
86
- if (headerElement) {
87
- if (this.router.url !== '/home') {
88
- headerElement.classList.add('show-menu');
89
- }
90
- else {
91
- headerElement.classList.remove('show-menu');
86
+ if (isPlatformBrowser(this.platformId)) {
87
+ const headerElement = document.querySelector('header');
88
+ if (headerElement) {
89
+ if (this.router.url !== '/home') {
90
+ headerElement.classList.add('show-menu');
91
+ }
92
+ else {
93
+ headerElement.classList.remove('show-menu');
94
+ }
92
95
  }
93
96
  }
94
97
  }
@@ -112,26 +115,30 @@ export class HeaderEcComponent extends MenuEcComponent {
112
115
  }
113
116
  };
114
117
  borrarInput(inputId) {
115
- if (inputId) {
116
- const input = document.getElementById(inputId);
117
- if (input) {
118
- input.value = '';
119
- }
120
- }
121
- else {
122
- const inputs = ['searchInput1'];
123
- inputs.forEach((id) => {
124
- const input = document.getElementById(id);
118
+ if (isPlatformBrowser(this.platformId)) {
119
+ if (inputId) {
120
+ const input = document.getElementById(inputId);
125
121
  if (input) {
126
122
  input.value = '';
127
123
  }
128
- });
124
+ }
125
+ else {
126
+ const inputs = ['searchInput1'];
127
+ inputs.forEach((id) => {
128
+ const input = document.getElementById(id);
129
+ if (input) {
130
+ input.value = '';
131
+ }
132
+ });
133
+ }
129
134
  }
130
135
  this.searchValue = '';
131
136
  this.coreConstantsService.searchValue = '';
132
137
  this.getCollectionSearch();
133
138
  }
134
139
  setupMobileMenu() {
140
+ if (!isPlatformBrowser(this.platformId))
141
+ return;
135
142
  // console.log('setupMobileMenu called');
136
143
  const menuMobile = document.querySelector('.menuMobile');
137
144
  if (!(menuMobile instanceof HTMLElement))
@@ -167,6 +174,8 @@ export class HeaderEcComponent extends MenuEcComponent {
167
174
  });
168
175
  }
169
176
  setupSearchInputs() {
177
+ if (!isPlatformBrowser(this.platformId))
178
+ return;
170
179
  const inputs = ['searchInput1', 'searchInput2'];
171
180
  inputs.forEach(id => {
172
181
  const input = document.getElementById(id);
@@ -233,4 +242,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
233
242
  type: HostListener,
234
243
  args: ['window:scroll', []]
235
244
  }] } });
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"]}
245
+ //# 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      // 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    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    this.getCollectionSearch();\n  }\n  setupMobileMenu() {\n    if (!isPlatformBrowser(this.platformId)) return;\n    \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    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"]}
@@ -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
- setTimeout(() => {
71
- this.initSwiper();
72
- }, 100);
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
- setTimeout(() => this.render());
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"]}