ng-easycommerce-v18 0.2.9 → 0.2.11
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 +3 -1
- package/esm2022/lib/constants/api.constants.service.mjs +2 -11
- package/esm2022/lib/ec-components/blocks-ec/block-banner-full-ec/block-banner-full-ec.component.mjs +146 -11
- package/esm2022/lib/ec-components/blocks-ec/blocks-ec.component.mjs +2 -2
- package/fesm2022/ng-easycommerce-v18.mjs +147 -21
- package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
- package/lib/ec-components/blocks-ec/block-banner-full-ec/block-banner-full-ec.component.d.ts +41 -8
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -47,14 +47,8 @@ export class ApiConstantsService {
|
|
|
47
47
|
*/
|
|
48
48
|
CMS_URL = 'cms/';
|
|
49
49
|
constructor() {
|
|
50
|
-
console.log('🚀 ApiConstantsService inicializando...');
|
|
51
50
|
this._channel = this.environment.channel;
|
|
52
51
|
this.LOCALE = this.environment.locale;
|
|
53
|
-
console.log('🌍 Environment:', this.environment);
|
|
54
|
-
// Verificar si window.__env existe
|
|
55
|
-
if (typeof window !== 'undefined') {
|
|
56
|
-
console.log('🪟 window.__env:', window.__env);
|
|
57
|
-
}
|
|
58
52
|
}
|
|
59
53
|
/**
|
|
60
54
|
* URL del backend para realizar las peticiones
|
|
@@ -65,14 +59,11 @@ export class ApiConstantsService {
|
|
|
65
59
|
// Primero intenta leer de window.__env (configurado por Docker)
|
|
66
60
|
const windowEnv = window.__env;
|
|
67
61
|
if (windowEnv?.apiUrl) {
|
|
68
|
-
console.log('🐳 API_URL desde Docker:', windowEnv.apiUrl);
|
|
69
62
|
return windowEnv.apiUrl;
|
|
70
63
|
}
|
|
71
64
|
}
|
|
72
65
|
// Fallback al environment (para SSR y como backup)
|
|
73
|
-
|
|
74
|
-
console.log('📦 API_URL desde environment:', apiUrl);
|
|
75
|
-
return apiUrl;
|
|
66
|
+
return this.environment.apiUrl ?? '';
|
|
76
67
|
}
|
|
77
68
|
/**
|
|
78
69
|
* Retorna la url base
|
|
@@ -104,4 +95,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
104
95
|
providedIn: 'root'
|
|
105
96
|
}]
|
|
106
97
|
}], ctorParameters: () => [] });
|
|
107
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmNvbnN0YW50cy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2NvbnN0YW50cy9hcGkuY29uc3RhbnRzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRWpELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQUd2RDs7OztHQUlHO0FBSUgsTUFBTSxPQUFPLG1CQUFtQjtJQUN2QixhQUFhLEdBQXdCLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0lBQ2pFLFVBQVUsR0FBcUIsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFFaEU7O09BRUc7SUFDSyxXQUFXLEdBQWdCLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0lBRTdEOztPQUVHO0lBQ0gsSUFBVyxPQUFPO1FBQ2pCLG1EQUFtRDtRQUNuRCxJQUFJLE9BQU8sTUFBTSxLQUFLLFdBQVcsRUFBRSxDQUFDO1lBQ25DLGdFQUFnRTtZQUNoRSxNQUFNLFNBQVMsR0FBSSxNQUFjLENBQUMsS0FBSyxDQUFDO1lBQ3hDLElBQUksU0FBUyxFQUFFLE9BQU8sRUFBRSxDQUFDO2dCQUN4QixPQUFPLFNBQVMsQ0FBQyxPQUFPLENBQUM7WUFDMUIsQ0FBQztRQUNGLENBQUM7UUFFRCwwQkFBMEI7UUFDMUIsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQ3RCLENBQUM7SUFFRCxJQUFXLE9BQU8sQ0FBQyxLQUFhO1FBQy9CLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO0lBQ3ZCLENBQUM7SUFFTyxRQUFRLENBQVM7SUFDekI7O09BRUc7SUFDSSxNQUFNLENBQVM7SUFFdEI7O09BRUc7SUFDYSxZQUFZLEdBQVcsV0FBVyxDQUFDO0lBQ25EOztPQUVHO0lBQ2EsT0FBTyxHQUFXLE1BQU0sQ0FBQztJQUV6QztRQUNDLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUM7UUFDekMsSUFBSSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQztJQUN2QyxDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFXLE9BQU87UUFDakIsbURBQW1EO1FBQ25ELElBQUksT0FBTyxNQUFNLEtBQUssV0FBVyxFQUFFLENBQUM7WUFDbkMsZ0VBQWdFO1lBQ2hFLE1BQU0sU0FBUyxHQUFJLE1BQWMsQ0FBQyxLQUFLLENBQUM7WUFDeEMsSUFBSSxTQUFTLEVBQUUsTUFBTSxFQUFFLENBQUM7Z0JBQ3ZCLE9BQU8sU0FBUyxDQUFDLE1BQU0sQ0FBQztZQUN6QixDQUFDO1FBQ0YsQ0FBQztRQUVELG1EQUFtRDtRQUNuRCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxJQUFJLEVBQUUsQ0FBQztJQUN0QyxDQUFDO0lBQ0Q7OztPQUdHO0lBQ0ksVUFBVTtRQUNoQixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDckIsQ0FBQztJQUNEOzs7O09BSUc7SUFDSSxVQUFVLENBQUMsSUFBWSxJQUFRLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLENBQUEsQ0FBQztJQUVwRCxTQUFTLENBQUMsTUFBYztRQUM5QixJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ3BELElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQTtRQUN6QyxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztJQUN0QixDQUFDO0lBRUQsYUFBYTtJQUNJLFVBQVUsR0FBVSxRQUFRLENBQUM7SUFDN0IsV0FBVyxHQUFVLFNBQVMsQ0FBQzt3R0F4RnBDLG1CQUFtQjs0R0FBbkIsbUJBQW1CLGNBRmxCLE1BQU07OzRGQUVQLG1CQUFtQjtrQkFIL0IsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRU5WSVJPTk1FTlRfVE9LRU4gfSBmcm9tICcuLi9wcm92aWRlcnMnO1xyXG5pbXBvcnQgeyBFbnZpcm9ubWVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xyXG5pbXBvcnQgeyBMb2NhbFN0b3JhZ2VTZXJ2aWNlIH0gZnJvbSAnLi4vZWMtc2VydmljZXMnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XHJcbmltcG9ydCB7IENvcmVDb25zdGFudHNTZXJ2aWNlIH0gZnJvbSAnLi9jb3JlLmNvbnN0YW50cy5zZXJ2aWNlJztcclxuXHJcbi8qKlxyXG4gKiBTZXJ2aWNpbyBxdWUgcHJvdmVlIGRlIGRhdG9zIHF1ZSBlc3RhbiByZWxhY2lvbmFkbyBjb24gbGFzIHBldGljaW9uZXMgYSBsYSBBUElcclxuICogQGV4cG9ydFxyXG4gKiBAY2xhc3MgQXBpQ29uc3RhbnRzU2VydmljZVxyXG4gKi9cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQXBpQ29uc3RhbnRzU2VydmljZSB7XHJcblx0cHJpdmF0ZSBfbG9jYWxTdG9yYWdlOiBMb2NhbFN0b3JhZ2VTZXJ2aWNlID0gaW5qZWN0KExvY2FsU3RvcmFnZVNlcnZpY2UpO1xyXG5cdHByaXZhdGUgX3RyYW5zbGF0ZTogVHJhbnNsYXRlU2VydmljZSA9IGluamVjdChUcmFuc2xhdGVTZXJ2aWNlKTtcclxuXHJcblx0LyoqXHJcblx0ICogQ29udGllbmUgbG9zIGRhdG9zIHByb3Zpc3RvIHBvciBlbCBmcm9udGVuZCBlbiBlbCBhcmNoaXZvIGVudmlyb25tZW50LnRzXHJcblx0ICovXHJcblx0cHJpdmF0ZSBlbnZpcm9ubWVudDogRW52aXJvbm1lbnQgPSBpbmplY3QoRU5WSVJPTk1FTlRfVE9LRU4pO1xyXG5cdFxyXG5cdC8qKlxyXG5cdCAqIENhbmFsIGFjdHVhbCBkZWwgZnJvbnRlbmRcclxuXHQgKi9cclxuXHRwdWJsaWMgZ2V0IENIQU5ORUwoKTogc3RyaW5nIHtcclxuXHRcdC8vIFZlcmlmaWNhciBzaSBlc3RhbW9zIGVuIGVsIG5hdmVnYWRvciAobm8gZW4gU1NSKVxyXG5cdFx0aWYgKHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnKSB7XHJcblx0XHRcdC8vIFByaW1lcm8gaW50ZW50YSBsZWVyIGRlIHdpbmRvdy5fX2VudiAoY29uZmlndXJhZG8gcG9yIERvY2tlcilcclxuXHRcdFx0Y29uc3Qgd2luZG93RW52ID0gKHdpbmRvdyBhcyBhbnkpLl9fZW52O1xyXG5cdFx0XHRpZiAod2luZG93RW52Py5jaGFubmVsKSB7XHJcblx0XHRcdFx0cmV0dXJuIHdpbmRvd0Vudi5jaGFubmVsO1xyXG5cdFx0XHR9XHJcblx0XHR9XHJcblx0XHRcclxuXHRcdC8vIEZhbGxiYWNrIGFsIGVudmlyb25tZW50XHJcblx0XHRyZXR1cm4gdGhpcy5fY2hhbm5lbDtcclxuXHR9XHJcblx0XHJcblx0cHVibGljIHNldCBDSEFOTkVMKHZhbHVlOiBzdHJpbmcpIHtcclxuXHRcdHRoaXMuX2NoYW5uZWwgPSB2YWx1ZTtcclxuXHR9XHJcblx0XHJcblx0cHJpdmF0ZSBfY2hhbm5lbDogc3RyaW5nO1xyXG5cdC8qKlxyXG5cdCAqIExvY2FsZSBhY3R1YWwgZGVsIGZyb250ZW5kXHJcblx0ICovXHJcblx0cHVibGljIExPQ0FMRTogc3RyaW5nO1xyXG5cdFxyXG5cdC8qKlxyXG5cdCAqIFVSTCBwYXJhIGxhcyBwZXRpY2lvbmVzIGEgc2hvcC1hcGlcclxuXHQgKi9cclxuXHRwdWJsaWMgcmVhZG9ubHkgU0hPUF9BUElfVVJMOiBzdHJpbmcgPSAnc2hvcC1hcGkvJztcclxuXHQvKipcclxuXHQgKiBVUkwgcGFyYSBsYXMgcGV0aWNpb25lcyBhIGNtc1xyXG5cdCAqL1xyXG5cdHB1YmxpYyByZWFkb25seSBDTVNfVVJMOiBzdHJpbmcgPSAnY21zLyc7XHJcblxyXG5cdGNvbnN0cnVjdG9yKCkge1xyXG5cdFx0dGhpcy5fY2hhbm5lbCA9IHRoaXMuZW52aXJvbm1lbnQuY2hhbm5lbDtcclxuXHRcdHRoaXMuTE9DQUxFID0gdGhpcy5lbnZpcm9ubWVudC5sb2NhbGU7XHJcblx0fVxyXG5cclxuXHQvKipcclxuXHQgKiBVUkwgZGVsIGJhY2tlbmQgcGFyYSByZWFsaXphciBsYXMgcGV0aWNpb25lc1xyXG5cdCAqL1xyXG5cdHB1YmxpYyBnZXQgQVBJX1VSTCgpOiBzdHJpbmcge1xyXG5cdFx0Ly8gVmVyaWZpY2FyIHNpIGVzdGFtb3MgZW4gZWwgbmF2ZWdhZG9yIChubyBlbiBTU1IpXHJcblx0XHRpZiAodHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCcpIHtcclxuXHRcdFx0Ly8gUHJpbWVybyBpbnRlbnRhIGxlZXIgZGUgd2luZG93Ll9fZW52IChjb25maWd1cmFkbyBwb3IgRG9ja2VyKVxyXG5cdFx0XHRjb25zdCB3aW5kb3dFbnYgPSAod2luZG93IGFzIGFueSkuX19lbnY7XHJcblx0XHRcdGlmICh3aW5kb3dFbnY/LmFwaVVybCkge1xyXG5cdFx0XHRcdHJldHVybiB3aW5kb3dFbnYuYXBpVXJsO1xyXG5cdFx0XHR9XHJcblx0XHR9XHJcblx0XHRcclxuXHRcdC8vIEZhbGxiYWNrIGFsIGVudmlyb25tZW50IChwYXJhIFNTUiB5IGNvbW8gYmFja3VwKVxyXG5cdFx0cmV0dXJuIHRoaXMuZW52aXJvbm1lbnQuYXBpVXJsID8/ICcnO1xyXG5cdH1cclxuXHQvKipcclxuXHQgKiBSZXRvcm5hIGxhIHVybCBiYXNlXHJcblx0ICogQHJldHVybnMge3N0cmluZ31cclxuXHQgKi9cclxuXHRwdWJsaWMgZ2V0VXJsQmFzZSgpOiBzdHJpbmcgeyBcclxuXHRcdHJldHVybiB0aGlzLkFQSV9VUkw7XHJcblx0fSBcclxuXHQvKipcclxuXHQgKiBDYW1iaWEgZWwgY2FuYWwgYWN0dWFsXHJcblx0ICogQHBhcmFtIGNvZGVcclxuXHQgKiBAcmV0dXJucyBcclxuXHQgKi9cclxuXHRwdWJsaWMgc2V0Q2hhbm5lbChjb2RlOiBzdHJpbmcpOnZvaWR7IHRoaXMuQ0hBTk5FTCA9IGNvZGU7fSBcclxuXHJcblx0cHVibGljIHNldExvY2FsZShsb2NhbGU6IHN0cmluZyk6dm9pZHtcclxuXHRcdHRoaXMuX2xvY2FsU3RvcmFnZS5zZXRJdGVtKHRoaXMuTE9DQUxFX0tFWSwgbG9jYWxlKTtcclxuXHRcdHRoaXMuX3RyYW5zbGF0ZS51c2UobG9jYWxlLnNwbGl0KCdfJylbMF0pXHJcblx0XHR0aGlzLkxPQ0FMRSA9IGxvY2FsZTtcclxuXHR9XHJcblxyXG5cdC8vU3RvcmFnZSBrZXlcclxuXHRwcml2YXRlIHJlYWRvbmx5IExPQ0FMRV9LRVk6c3RyaW5nID0gJ0xPQ0FMRSc7XHJcblx0cHJpdmF0ZSByZWFkb25seSBDSEFOTkVMX0tFWTpzdHJpbmcgPSAnQ0hBTk5FTCc7XHJcbn1cclxuIl19
|
package/esm2022/lib/ec-components/blocks-ec/block-banner-full-ec/block-banner-full-ec.component.mjs
CHANGED
|
@@ -22,12 +22,26 @@ export class BlockBannerFullEcComponent extends BlockEcComponent {
|
|
|
22
22
|
* Datos del bloque que contiene a los banners
|
|
23
23
|
*/
|
|
24
24
|
meta;
|
|
25
|
+
// =================== PERSONALIZACIÓN DE NAVEGACIÓN ===================
|
|
26
|
+
/**
|
|
27
|
+
* Personalización de las flechas de navegación
|
|
28
|
+
* Por defecto usa símbolos de texto, pero se pueden especificar imágenes
|
|
29
|
+
*/
|
|
30
|
+
prevArrowImage; // undefined = usa símbolo de texto
|
|
31
|
+
nextArrowImage; // undefined = usa símbolo de texto
|
|
32
|
+
prevArrowText = '<';
|
|
33
|
+
nextArrowText = '>';
|
|
34
|
+
/**
|
|
35
|
+
* Opción para habilitar/deshabilitar la navegación personalizada
|
|
36
|
+
*/
|
|
37
|
+
enableCustomNavigation = true;
|
|
38
|
+
// ====================================================================
|
|
25
39
|
/**
|
|
26
40
|
* Servicio para Analytics
|
|
27
41
|
*/
|
|
28
42
|
analyticsService = inject(AnalyticsService);
|
|
29
43
|
/**
|
|
30
|
-
* Signal
|
|
44
|
+
* Signal utilizado para guardar el contenedor del carrusel
|
|
31
45
|
*/
|
|
32
46
|
swiperElement = signal(null);
|
|
33
47
|
/**
|
|
@@ -36,19 +50,21 @@ export class BlockBannerFullEcComponent extends BlockEcComponent {
|
|
|
36
50
|
* @returns
|
|
37
51
|
*/
|
|
38
52
|
getImage = (banner) => this.getBannerImage(banner);
|
|
53
|
+
document;
|
|
54
|
+
platformId = inject(PLATFORM_ID);
|
|
39
55
|
/**
|
|
40
56
|
* Se mappea los banners para sumarle el objeto de translations y que
|
|
41
57
|
* sean mas amigables para su uso.
|
|
42
58
|
*/
|
|
43
59
|
ngOnInit() {
|
|
44
|
-
this.banners = this.banners.map((banner) => {
|
|
60
|
+
this.banners = this.banners.map((banner) => {
|
|
61
|
+
return { ...banner, ...banner.translations[this.apiConsts.LOCALE] };
|
|
62
|
+
});
|
|
45
63
|
}
|
|
46
|
-
document;
|
|
47
|
-
platformId = inject(PLATFORM_ID);
|
|
48
64
|
/**
|
|
49
|
-
* Ejecuta el método `afterNextRender`para cargar las configuraciones necesarias
|
|
50
|
-
* para el carrusel
|
|
51
|
-
* en el
|
|
65
|
+
* Ejecuta el método `afterNextRender` para cargar las configuraciones necesarias
|
|
66
|
+
* para el carrusel de banners. Esto debe ser así debido a que ya debe estar presente
|
|
67
|
+
* en el DOM el elemento `<swiper-container>` para poder configurarlo.
|
|
52
68
|
*/
|
|
53
69
|
constructor() {
|
|
54
70
|
super();
|
|
@@ -56,21 +72,130 @@ export class BlockBannerFullEcComponent extends BlockEcComponent {
|
|
|
56
72
|
this.document = document;
|
|
57
73
|
}
|
|
58
74
|
afterNextRender(() => {
|
|
59
|
-
|
|
75
|
+
this.initializeSwiperWithNavigation();
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Inicializa el Swiper con navegación personalizada
|
|
80
|
+
*/
|
|
81
|
+
initializeSwiperWithNavigation() {
|
|
82
|
+
const swiperElemConstructor = this.document?.querySelector('#' + this.meta?.code);
|
|
83
|
+
if (swiperElemConstructor) {
|
|
84
|
+
// Configurar el Swiper con las opciones base
|
|
60
85
|
Object.assign(swiperElemConstructor, this.swiperOptions());
|
|
61
86
|
this.swiperElement.set(swiperElemConstructor);
|
|
62
87
|
this.swiperElement()?.initialize();
|
|
88
|
+
// Configurar navegación personalizada si está habilitada
|
|
89
|
+
if (this.enableCustomNavigation) {
|
|
90
|
+
setTimeout(() => {
|
|
91
|
+
this.setupCustomNavigation();
|
|
92
|
+
}, 200);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Configura la navegación personalizada del Swiper para banners
|
|
98
|
+
*/
|
|
99
|
+
setupCustomNavigation() {
|
|
100
|
+
const prevButton = this.document?.getElementById(`${this.meta?.code}-prev`);
|
|
101
|
+
const nextButton = this.document?.getElementById(`${this.meta?.code}-next`);
|
|
102
|
+
const swiperElement = this.document?.getElementById(this.meta?.code);
|
|
103
|
+
if (prevButton && nextButton && swiperElement) {
|
|
104
|
+
console.log('Configurando navegación personalizada para banners:', this.meta?.code);
|
|
105
|
+
// Actualizar configuración del Swiper existente
|
|
106
|
+
this.updateSwiperForBanners(swiperElement);
|
|
107
|
+
// Configurar los event listeners para los botones
|
|
108
|
+
this.setupBannerNavigationEventListeners(prevButton, nextButton, swiperElement);
|
|
109
|
+
console.log('Event listeners configurados para navegación de banners');
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
console.log('No se pudieron encontrar los elementos de navegación para banners:', {
|
|
113
|
+
prevButton: !!prevButton,
|
|
114
|
+
nextButton: !!nextButton,
|
|
115
|
+
swiperElement: !!swiperElement
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* Actualiza la configuración del Swiper específicamente para banners
|
|
121
|
+
*/
|
|
122
|
+
updateSwiperForBanners(swiperElement) {
|
|
123
|
+
if (swiperElement.swiper) {
|
|
124
|
+
console.log('Actualizando configuración de Swiper para banners');
|
|
125
|
+
// Configuración específica para banners
|
|
126
|
+
swiperElement.swiper.params.slidesPerGroup = 1;
|
|
127
|
+
swiperElement.swiper.allowSlideNext = true;
|
|
128
|
+
swiperElement.swiper.allowSlidePrev = true;
|
|
129
|
+
// Actualizar también los breakpoints si existen
|
|
130
|
+
if (swiperElement.swiper.params.breakpoints) {
|
|
131
|
+
Object.keys(swiperElement.swiper.params.breakpoints).forEach(key => {
|
|
132
|
+
swiperElement.swiper.params.breakpoints[key].slidesPerGroup = 1;
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
swiperElement.swiper.update();
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Configura los event listeners para los botones de navegación de banners
|
|
140
|
+
*/
|
|
141
|
+
setupBannerNavigationEventListeners(prevButton, nextButton, swiperElement) {
|
|
142
|
+
// Remover event listeners existentes para evitar duplicados
|
|
143
|
+
const prevClone = prevButton.cloneNode(true);
|
|
144
|
+
const nextClone = nextButton.cloneNode(true);
|
|
145
|
+
prevButton.parentNode?.replaceChild(prevClone, prevButton);
|
|
146
|
+
nextButton.parentNode?.replaceChild(nextClone, nextButton);
|
|
147
|
+
// Agregar nuevos event listeners
|
|
148
|
+
prevClone.addEventListener('click', (e) => {
|
|
149
|
+
e.preventDefault();
|
|
150
|
+
e.stopPropagation();
|
|
151
|
+
console.log('Click en botón anterior (banners)');
|
|
152
|
+
if (swiperElement.swiper) {
|
|
153
|
+
swiperElement.swiper.slidePrev();
|
|
154
|
+
}
|
|
155
|
+
});
|
|
156
|
+
nextClone.addEventListener('click', (e) => {
|
|
157
|
+
e.preventDefault();
|
|
158
|
+
e.stopPropagation();
|
|
159
|
+
console.log('Click en botón siguiente (banners)');
|
|
160
|
+
if (swiperElement.swiper) {
|
|
161
|
+
swiperElement.swiper.slideNext();
|
|
162
|
+
}
|
|
63
163
|
});
|
|
64
164
|
}
|
|
65
165
|
/**
|
|
66
|
-
* Aplica el evento `select_promotion` junto con el banner que
|
|
166
|
+
* Aplica el evento `select_promotion` junto con el banner que interactúa.
|
|
67
167
|
* @param banner
|
|
68
168
|
*/
|
|
69
169
|
selectPromotion(banner) {
|
|
70
170
|
this.analyticsService.callEvent('select_promotion', banner);
|
|
71
171
|
}
|
|
172
|
+
/**
|
|
173
|
+
* Obtiene la configuración específica del Swiper para banners
|
|
174
|
+
* Sobrescribe la configuración base si es necesario
|
|
175
|
+
*/
|
|
176
|
+
getBannerSwiperConfiguration() {
|
|
177
|
+
return {
|
|
178
|
+
slidesPerView: 1,
|
|
179
|
+
spaceBetween: 0,
|
|
180
|
+
slidesPerGroup: 1,
|
|
181
|
+
navigation: false, // Deshabilitamos la navegación por defecto
|
|
182
|
+
pagination: {
|
|
183
|
+
el: '.swiper-pagination',
|
|
184
|
+
clickable: true,
|
|
185
|
+
},
|
|
186
|
+
loop: true,
|
|
187
|
+
autoplay: {
|
|
188
|
+
delay: 5000,
|
|
189
|
+
disableOnInteraction: false,
|
|
190
|
+
},
|
|
191
|
+
effect: 'fade',
|
|
192
|
+
fadeEffect: {
|
|
193
|
+
crossFade: true
|
|
194
|
+
}
|
|
195
|
+
};
|
|
196
|
+
}
|
|
72
197
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BlockBannerFullEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
73
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: BlockBannerFullEcComponent, isStandalone: true, selector: "app-block-banner-full-ec", inputs: { banners: "banners", meta: "meta" }, usesInheritance: true, ngImport: i0, template: "@if(banners.length > 0) {\r\n <section [ngClass]=\"trimClassBlock(meta?.code)+' container-fluid px-0'\"\r\n [style.background-color]=\"meta.styles?.backgroundColor\"\r\n [style.background-image]=\"meta.styles?.backgroundImage ? 'url(' + mediaUrl + meta.styles?.backgroundImage +')' : 'inherit'\">\r\n\r\n @if (banners.length == 1) {\r\n <!-- si es formato fijo -->\r\n <div class=\"row justify-content-center\">\r\n @let banner = banners[0];\r\n @if(!banners.styles?.button?.text){\r\n <!-- banner sin boton -->\r\n <a [href]=\"banner.url\" >\r\n <div class=\"item col-12\">\r\n <img class=\"img-fluid\" [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\">\r\n <div class=\"position-absolute w-100 h-100 start-0 top-0\">\r\n @if(banner.title){\r\n <h2 [class]=\"'item-title-full px-2 item-position-vertical-' + (banner.styles?.description?.position)\"\r\n [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#fff' \">\r\n {{banner.title}}\r\n </h2>\r\n }\r\n @if(banner.subtitle){\r\n <p [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \"\r\n [class]=\"'px-4 item-subtitle-full item-position-vertical-' + (banner.styles?.description?.position)\">\r\n {{banner.subtitle}}\r\n </p>\r\n }\r\n </div>\r\n </div>\r\n </a>\r\n }@else {\r\n <!-- banner fijo con boton -->\r\n <div class=\"item col-12\">\r\n <img class=\"img-fluid\" [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\">\r\n <div class=\"position-absolute w-100 h-100 start-0 top-0\">\r\n @if(banner.title){\r\n <h2 [class]=\"'item-title-full px-2 item-position-vertical-' + (banner.styles?.description?.position)\"\r\n [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \">\r\n {{banner.title}}\r\n </h2>\r\n }\r\n @if(banner.subtitle){\r\n <p \r\n [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \"\r\n [class]=\"'px-4 item-subtitle-full item-position-vertical-' + (banner.styles?.description?.position)\">\r\n {{banner.subtitle}}\r\n </p>\r\n <div [class]=\"'item-position-vertical-' + (banner.styles?.button?.position)\">\r\n @if(banner.styles?.button?.text){\r\n <a href=\"{{banner.url}}\"\r\n [class]=\"'item-button-full btn btn-light '\">\r\n {{banner.styles.button.text}}\r\n </a> \r\n }\r\n \r\n </div>\r\n }\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n }@else {\r\n <!-- si es carrousel -->\r\n <!-- @if(swiperElement() != null){ -->\r\n <swiper-container init=\"false\" [id]=\"meta?.code\">\r\n @for (banner of banners; track $index) {\r\n <swiper-slide>\r\n <div class=\"item\">\r\n @if (!banner.styles?.button?.text) {\r\n <!-- banner sin boton -->\r\n @if(banner.url){\r\n <a [href]=\"banner.url\" class=\"\">\r\n <img [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\" class=\"img-fluid w-100\" />\r\n </a>\r\n }@else {\r\n <img [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\" class=\"img-fluid w-100\" />\r\n }\r\n }@else {\r\n <!-- banner con boton -->\r\n <img [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\" />\r\n <div class=\"position-absolute w-100 h-100 start-0 top-0\">\r\n @if(banner.title){\r\n <h2 [class]=\"'item-title-full px-2 item-position-vertical-'+ (banner.styles?.description?.position)\"\r\n [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \">\r\n {{banner.title}}\r\n </h2>\r\n }\r\n @if(banner.subtitle){\r\n <p [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \"\r\n [class]=\"'px-4 item-subtitle-full item-position-vertical-' + (banner.styles?.description?.position)\">\r\n {{banner.subtitle}}\r\n </p>\r\n }\r\n <div [class]=\"'item-position-vertical-' + (banner.styles?.button?.position)\">\r\n @if(banner.styles?.button?.text){\r\n <a href=\"{{banner.url}}\" [class]=\"'item-button-full btn btn-light'\">\r\n {{banner.styles.button.text}}\r\n </a>\r\n }\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n </swiper-slide>\r\n }\r\n </swiper-container>\r\n <!-- } -->\r\n \r\n }\r\n </section>\r\n}", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
|
|
198
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: BlockBannerFullEcComponent, isStandalone: true, selector: "app-block-banner-full-ec", inputs: { banners: "banners", meta: "meta", prevArrowImage: "prevArrowImage", nextArrowImage: "nextArrowImage", prevArrowText: "prevArrowText", nextArrowText: "nextArrowText", enableCustomNavigation: "enableCustomNavigation" }, usesInheritance: true, ngImport: i0, template: "@if(banners.length > 0) {\r\n <section [ngClass]=\"trimClassBlock(meta?.code)+' container-fluid px-0'\"\r\n [style.background-color]=\"meta.styles?.backgroundColor\"\r\n [style.background-image]=\"meta.styles?.backgroundImage ? 'url(' + mediaUrl + meta.styles?.backgroundImage +')' : 'inherit'\">\r\n\r\n @if (banners.length == 1) {\r\n <!-- si es formato fijo -->\r\n <div class=\"row justify-content-center\">\r\n @let banner = banners[0];\r\n @if(!banners.styles?.button?.text){\r\n <!-- banner sin boton -->\r\n <a [href]=\"banner.url\" >\r\n <div class=\"item col-12\">\r\n <img class=\"img-fluid\" [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\">\r\n <div class=\"position-absolute w-100 h-100 start-0 top-0\">\r\n @if(banner.title){\r\n <h2 [class]=\"'item-title-full px-2 item-position-vertical-' + (banner.styles?.description?.position)\"\r\n [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#fff' \">\r\n {{banner.title}}\r\n </h2>\r\n }\r\n @if(banner.subtitle){\r\n <p [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \"\r\n [class]=\"'px-4 item-subtitle-full item-position-vertical-' + (banner.styles?.description?.position)\">\r\n {{banner.subtitle}}\r\n </p>\r\n }\r\n </div>\r\n </div>\r\n </a>\r\n }@else {\r\n <!-- banner fijo con boton -->\r\n <div class=\"item col-12\">\r\n <img class=\"img-fluid\" [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\">\r\n <div class=\"position-absolute w-100 h-100 start-0 top-0\">\r\n @if(banner.title){\r\n <h2 [class]=\"'item-title-full px-2 item-position-vertical-' + (banner.styles?.description?.position)\"\r\n [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \">\r\n {{banner.title}}\r\n </h2>\r\n }\r\n @if(banner.subtitle){\r\n <p \r\n [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \"\r\n [class]=\"'px-4 item-subtitle-full item-position-vertical-' + (banner.styles?.description?.position)\">\r\n {{banner.subtitle}}\r\n </p>\r\n <div [class]=\"'item-position-vertical-' + (banner.styles?.button?.position)\">\r\n @if(banner.styles?.button?.text){\r\n <a href=\"{{banner.url}}\"\r\n [class]=\"'item-button-full btn btn-light '\">\r\n {{banner.styles.button.text}}\r\n </a> \r\n }\r\n \r\n </div>\r\n }\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n }@else {\r\n <!-- si es carrousel -->\r\n <!-- @if(swiperElement() != null){ -->\r\n <swiper-container init=\"false\" [id]=\"meta?.code\">\r\n @for (banner of banners; track $index) {\r\n <swiper-slide>\r\n <div class=\"item\">\r\n @if (!banner.styles?.button?.text) {\r\n <!-- banner sin boton -->\r\n @if(banner.url){\r\n <a [href]=\"banner.url\" class=\"\">\r\n <img [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\" class=\"img-fluid w-100\" />\r\n </a>\r\n }@else {\r\n <img [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\" class=\"img-fluid w-100\" />\r\n }\r\n }@else {\r\n <!-- banner con boton -->\r\n <img [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\" />\r\n <div class=\"position-absolute w-100 h-100 start-0 top-0\">\r\n @if(banner.title){\r\n <h2 [class]=\"'item-title-full px-2 item-position-vertical-'+ (banner.styles?.description?.position)\"\r\n [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \">\r\n {{banner.title}}\r\n </h2>\r\n }\r\n @if(banner.subtitle){\r\n <p [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \"\r\n [class]=\"'px-4 item-subtitle-full item-position-vertical-' + (banner.styles?.description?.position)\">\r\n {{banner.subtitle}}\r\n </p>\r\n }\r\n <div [class]=\"'item-position-vertical-' + (banner.styles?.button?.position)\">\r\n @if(banner.styles?.button?.text){\r\n <a href=\"{{banner.url}}\" [class]=\"'item-button-full btn btn-light'\">\r\n {{banner.styles.button.text}}\r\n </a>\r\n }\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n </swiper-slide>\r\n }\r\n </swiper-container>\r\n <!-- } -->\r\n \r\n }\r\n </section>\r\n}", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
|
|
74
199
|
}
|
|
75
200
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BlockBannerFullEcComponent, decorators: [{
|
|
76
201
|
type: Component,
|
|
@@ -83,5 +208,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
83
208
|
}], meta: [{
|
|
84
209
|
type: Input,
|
|
85
210
|
args: [{ required: true }]
|
|
211
|
+
}], prevArrowImage: [{
|
|
212
|
+
type: Input
|
|
213
|
+
}], nextArrowImage: [{
|
|
214
|
+
type: Input
|
|
215
|
+
}], prevArrowText: [{
|
|
216
|
+
type: Input
|
|
217
|
+
}], nextArrowText: [{
|
|
218
|
+
type: Input
|
|
219
|
+
}], enableCustomNavigation: [{
|
|
220
|
+
type: Input
|
|
86
221
|
}] } });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"block-banner-full-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/blocks-ec/block-banner-full-ec/block-banner-full-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/blocks-ec/block-banner-full-ec/block-banner-full-ec.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAe,SAAS,EAAE,sBAAsB,EAAE,MAAM,EAAE,KAAK,EAAU,WAAW,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAE5I,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAmB,MAAM,uBAAuB,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAClE,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;;;AAExD,QAAQ,EAAE,CAAC;AACX;;;;;GAKG;AASH,MAAM,OAAO,0BAA2B,SAAQ,gBAAgB;IAC/D;;OAEG;IAGA,OAAO,CAAM;IAChB;;OAEG;IACwB,IAAI,CAAM;IACrC;;OAEG;IACK,gBAAgB,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAA;IACnD;;OAEG;IACH,aAAa,GAAG,MAAM,CAAyB,IAAI,CAAC,CAAA;IACpD;;;;OAIG;IACa,QAAQ,GAAG,CAAC,MAAW,EAAE,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;IACxE;;;OAGG;IACH,QAAQ;QACP,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAW,EAAE,EAAE,GAAG,OAAO,EAAE,GAAG,MAAM,EAAE,GAAG,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAA,CAAC,CAAC,CAAC,CAAA;IAC1H,CAAC;IACO,QAAQ,CAAY;IACpB,UAAU,GAAQ,MAAM,CAAC,WAAW,CAAC,CAAA;IAE7C;;;;OAIG;IACH;QACC,KAAK,EAAE,CAAA;QACP,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACxC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAA;QACzB,CAAC;QACD,eAAe,CAAC,GAAG,EAAE;YACpB,MAAM,qBAAqB,GAAG,IAAI,CAAC,QAAQ,EAAE,aAAa,CAAC,GAAG,GAAG,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAA;YACjF,MAAM,CAAC,MAAM,CAAC,qBAAsB,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,CAAA;YAC3D,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,qBAAwC,CAAC,CAAA;YAChE,IAAI,CAAC,aAAa,EAAE,EAAE,UAAU,EAAE,CAAC;QACpC,CAAC,CAAC,CAAA;IACH,CAAC;IACD;;;OAGG;IACH,eAAe,CAAC,MAAW;QAC1B,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,kBAAkB,EAAE,MAAM,CAAC,CAAA;IAC5D,CAAC;wGA1DW,0BAA0B;4FAA1B,0BAA0B,yJCvBvC,s3NA8GC,yDD5FU,YAAY;;4FAKV,0BAA0B;kBARtC,SAAS;+BACC,0BAA0B,cACxB,IAAI,WACP,CAAC,YAAY,EAAE,UAAU,CAAC,WAC1B,CAAC,sBAAsB,CAAC;wDAU9B,OAAO;sBAFT,KAAK;uBAAC;wBACN,QAAQ,EAAE,IAAI;qBACd;gBAI0B,IAAI;sBAA9B,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE","sourcesContent":["import { afterNextRender, afterRender, Component, CUSTOM_ELEMENTS_SCHEMA, inject, Input, OnInit, PLATFORM_ID, signal } from '@angular/core';\r\nimport { IBlock } from '../../../interfaces';\r\nimport { BlockEcComponent } from '../../abstractions-components';\r\nimport { register, SwiperContainer } from 'swiper/element/bundle';\r\nimport { CommonModule, isPlatformBrowser } from '@angular/common';\r\nimport { RouterLink } from '@angular/router';\r\nimport { AnalyticsService } from '../../../ec-services';\r\n\r\nregister();\r\n/**\r\n * Componente para manejar los banners de tipo full\r\n * @extends {BlockEcComponent}\r\n * @implements {OnInit}\r\n * @class BlockBannerFullEcComponent\r\n */\r\n@Component({\r\n\tselector: 'app-block-banner-full-ec',\r\n\tstandalone: true,\r\n\timports: [CommonModule, RouterLink],\r\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n\ttemplateUrl: './block-banner-full-ec.component.html',\r\n\tstyleUrl: './block-banner-full-ec.component.scss'\r\n})\r\nexport class BlockBannerFullEcComponent extends BlockEcComponent implements OnInit {\r\n\t/**\r\n\t * Banners tipo full\r\n\t */\r\n\t@Input({\r\n\t\trequired: true\r\n\t}) banners: any;\r\n\t/**\r\n\t * Datos del bloque que contiene a los banners\r\n\t */\r\n\t@Input({ required: true }) meta: any;\r\n\t/**\r\n\t * Servicio para Analytics\r\n\t */\r\n\tprivate analyticsService = inject(AnalyticsService)\r\n\t/**\r\n\t * Signal utlizado para guarda el contenedor del carrusel\r\n\t */\r\n\tswiperElement = signal<SwiperContainer | null>(null)\r\n\t/**\r\n\t * Método original en: {@link BlockEcComponent}\r\n\t * @param banner \r\n\t * @returns \r\n\t */\r\n\tpublic override getImage = (banner: any) => this.getBannerImage(banner);\r\n\t/**\r\n\t * Se mappea los banners para sumarle el objeto de translations y que\r\n\t * sean mas amigables para su uso.\r\n\t */\r\n\tngOnInit(): void {\r\n\t\tthis.banners = this.banners.map((banner: any) => { return { ...banner, ...banner.translations[this.apiConsts.LOCALE] } })\r\n\t}\r\n\tprivate document?: Document;\r\n\tprivate platformId: any = inject(PLATFORM_ID)\r\n\r\n\t/**\r\n\t * Ejecuta el método `afterNextRender`para cargar las configuraciones necesarias \r\n\t * para el carrusel del banners. Esto debe ser asi debido a que ya debe estar presente\r\n\t * en el Dom el element `<swiper-container>` para poder configurarlo.\r\n\t */\r\n\tconstructor() {\r\n\t\tsuper()\r\n\t\tif (isPlatformBrowser(this.platformId)) {\r\n\t\t\tthis.document = document\r\n\t\t}\r\n\t\tafterNextRender(() => {\r\n\t\t\tconst swiperElemConstructor = this.document?.querySelector('#' + this.meta?.code)\r\n\t\t\tObject.assign(swiperElemConstructor!, this.swiperOptions())\r\n\t\t\tthis.swiperElement.set(swiperElemConstructor as SwiperContainer)\r\n\t\t\tthis.swiperElement()?.initialize();\r\n\t\t})\r\n\t}\r\n\t/**\r\n\t * Aplica el evento `select_promotion` junto con el banner que interactua.\r\n\t * @param banner \r\n\t */\r\n\tselectPromotion(banner: any): void {\r\n\t\tthis.analyticsService.callEvent('select_promotion', banner)\r\n\t}\r\n}\r\n","@if(banners.length > 0) {\r\n    <section [ngClass]=\"trimClassBlock(meta?.code)+' container-fluid px-0'\"\r\n        [style.background-color]=\"meta.styles?.backgroundColor\"\r\n        [style.background-image]=\"meta.styles?.backgroundImage ? 'url(' + mediaUrl + meta.styles?.backgroundImage +')' : 'inherit'\">\r\n\r\n        @if (banners.length == 1) {\r\n            <!-- si es formato fijo -->\r\n            <div class=\"row justify-content-center\">\r\n                @let banner = banners[0];\r\n                @if(!banners.styles?.button?.text){\r\n                    <!-- banner sin boton -->\r\n                    <a [href]=\"banner.url\" >\r\n                        <div class=\"item col-12\">\r\n                            <img class=\"img-fluid\" [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\">\r\n                            <div class=\"position-absolute w-100 h-100 start-0 top-0\">\r\n                                @if(banner.title){\r\n                                    <h2 [class]=\"'item-title-full px-2 item-position-vertical-' + (banner.styles?.description?.position)\"\r\n                                    [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#fff' \">\r\n                                        {{banner.title}}\r\n                                    </h2>\r\n                                }\r\n                                @if(banner.subtitle){\r\n                                    <p [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \"\r\n                                    [class]=\"'px-4 item-subtitle-full item-position-vertical-' + (banner.styles?.description?.position)\">\r\n                                        {{banner.subtitle}}\r\n                                    </p>\r\n                                }\r\n                            </div>\r\n                        </div>\r\n                    </a>\r\n                }@else {\r\n                    <!-- banner fijo con boton -->\r\n                    <div class=\"item col-12\">\r\n                        <img class=\"img-fluid\" [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\">\r\n                        <div class=\"position-absolute w-100 h-100 start-0 top-0\">\r\n                            @if(banner.title){\r\n                                <h2 [class]=\"'item-title-full px-2 item-position-vertical-' + (banner.styles?.description?.position)\"\r\n                                [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \">\r\n                                    {{banner.title}}\r\n                                </h2>\r\n                            }\r\n                            @if(banner.subtitle){\r\n                                <p \r\n                                [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \"\r\n                                [class]=\"'px-4 item-subtitle-full item-position-vertical-' + (banner.styles?.description?.position)\">\r\n                                    {{banner.subtitle}}\r\n                                </p>\r\n                            <div [class]=\"'item-position-vertical-' + (banner.styles?.button?.position)\">\r\n                                @if(banner.styles?.button?.text){\r\n                                <a href=\"{{banner.url}}\"\r\n                                    [class]=\"'item-button-full btn btn-light '\">\r\n                                        {{banner.styles.button.text}}\r\n                                    </a> \r\n                                }\r\n                                \r\n                            </div>\r\n                            }\r\n                        </div>\r\n                    </div>\r\n                }\r\n            </div>\r\n        }@else {\r\n            <!-- si es carrousel -->\r\n            <!--  @if(swiperElement() != null){ -->\r\n                <swiper-container init=\"false\" [id]=\"meta?.code\">\r\n                @for (banner of banners; track $index) {\r\n                    <swiper-slide>\r\n                        <div class=\"item\">\r\n                            @if (!banner.styles?.button?.text) {\r\n                                <!-- banner sin boton -->\r\n                                @if(banner.url){\r\n                                    <a [href]=\"banner.url\" class=\"\">\r\n                                        <img [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\" class=\"img-fluid w-100\" />\r\n                                    </a>\r\n                                }@else {\r\n                                    <img [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\"  class=\"img-fluid w-100\" />\r\n                                }\r\n                            }@else {\r\n                                <!-- banner con boton -->\r\n                                <img [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\" />\r\n                                <div class=\"position-absolute w-100 h-100 start-0 top-0\">\r\n                                    @if(banner.title){\r\n                                        <h2 [class]=\"'item-title-full px-2 item-position-vertical-'+ (banner.styles?.description?.position)\"\r\n                                            [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \">\r\n                                            {{banner.title}}\r\n                                        </h2>\r\n                                    }\r\n                                    @if(banner.subtitle){\r\n                                        <p [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \"\r\n                                            [class]=\"'px-4 item-subtitle-full item-position-vertical-' + (banner.styles?.description?.position)\">\r\n                                            {{banner.subtitle}}\r\n                                        </p>\r\n                                    }\r\n                                    <div [class]=\"'item-position-vertical-' + (banner.styles?.button?.position)\">\r\n                                        @if(banner.styles?.button?.text){\r\n                                            <a href=\"{{banner.url}}\" [class]=\"'item-button-full btn btn-light'\">\r\n                                                {{banner.styles.button.text}}\r\n                                            </a>\r\n                                        }\r\n                                    </div>\r\n                                </div>\r\n                            }\r\n                        </div>\r\n                    </swiper-slide>\r\n                }\r\n            </swiper-container>\r\n            <!--  } -->\r\n            \r\n        }\r\n    </section>\r\n}"]}
|
|
222
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"block-banner-full-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/blocks-ec/block-banner-full-ec/block-banner-full-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/blocks-ec/block-banner-full-ec/block-banner-full-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { afterNextRender, afterRender, Component, CUSTOM_ELEMENTS_SCHEMA, inject, Input, OnInit, PLATFORM_ID, signal } from '@angular/core';\r\nimport { IBlock } from '../../../interfaces';\r\nimport { BlockEcComponent } from '../../abstractions-components';\r\nimport { register, SwiperContainer } from 'swiper/element/bundle';\r\nimport { CommonModule, isPlatformBrowser } from '@angular/common';\r\nimport { RouterLink } from '@angular/router';\r\nimport { AnalyticsService } from '../../../ec-services';\r\n\r\nregister();\r\n\r\n/**\r\n * Componente para manejar los banners de tipo full\r\n * @extends {BlockEcComponent}\r\n * @implements {OnInit}\r\n * @class BlockBannerFullEcComponent\r\n */\r\n@Component({\r\n    selector: 'app-block-banner-full-ec',\r\n    standalone: true,\r\n    imports: [CommonModule, RouterLink],\r\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n    templateUrl: './block-banner-full-ec.component.html',\r\n    styleUrl: './block-banner-full-ec.component.scss'\r\n})\r\nexport class BlockBannerFullEcComponent extends BlockEcComponent implements OnInit {\r\n    /**\r\n     * Banners tipo full\r\n     */\r\n    @Input({\r\n        required: true\r\n    }) banners: any;\r\n    \r\n    /**\r\n     * Datos del bloque que contiene a los banners\r\n     */\r\n    @Input({ required: true }) meta: any;\r\n\r\n    // =================== PERSONALIZACIÓN DE NAVEGACIÓN ===================\r\n    /**\r\n     * Personalización de las flechas de navegación\r\n     * Por defecto usa símbolos de texto, pero se pueden especificar imágenes\r\n     */\r\n    @Input() prevArrowImage?: string; // undefined = usa símbolo de texto\r\n    @Input() nextArrowImage?: string; // undefined = usa símbolo de texto\r\n    @Input() prevArrowText: string = '<';\r\n    @Input() nextArrowText: string = '>';\r\n\r\n    /**\r\n     * Opción para habilitar/deshabilitar la navegación personalizada\r\n     */\r\n    @Input() enableCustomNavigation: boolean = true;\r\n\r\n    // ====================================================================\r\n\r\n    /**\r\n     * Servicio para Analytics\r\n     */\r\n    private analyticsService = inject(AnalyticsService);\r\n    \r\n    /**\r\n     * Signal utilizado para guardar el contenedor del carrusel\r\n     */\r\n    swiperElement = signal<SwiperContainer | null>(null);\r\n    \r\n    /**\r\n     * Método original en: {@link BlockEcComponent}\r\n     * @param banner \r\n     * @returns \r\n     */\r\n    public override getImage = (banner: any) => this.getBannerImage(banner);\r\n    \r\n    private document?: Document;\r\n    private platformId: any = inject(PLATFORM_ID);\r\n\r\n    /**\r\n     * Se mappea los banners para sumarle el objeto de translations y que\r\n     * sean mas amigables para su uso.\r\n     */\r\n    ngOnInit(): void {\r\n        this.banners = this.banners.map((banner: any) => { \r\n            return { ...banner, ...banner.translations[this.apiConsts.LOCALE] } \r\n        });\r\n    }\r\n\r\n    /**\r\n     * Ejecuta el método `afterNextRender` para cargar las configuraciones necesarias \r\n     * para el carrusel de banners. Esto debe ser así debido a que ya debe estar presente\r\n     * en el DOM el elemento `<swiper-container>` para poder configurarlo.\r\n     */\r\n    constructor() {\r\n        super();\r\n        if (isPlatformBrowser(this.platformId)) {\r\n            this.document = document;\r\n        }\r\n        \r\n        afterNextRender(() => {\r\n            this.initializeSwiperWithNavigation();\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Inicializa el Swiper con navegación personalizada\r\n     */\r\n    private initializeSwiperWithNavigation(): void {\r\n        const swiperElemConstructor = this.document?.querySelector('#' + this.meta?.code);\r\n        \r\n        if (swiperElemConstructor) {\r\n            // Configurar el Swiper con las opciones base\r\n            Object.assign(swiperElemConstructor, this.swiperOptions());\r\n            this.swiperElement.set(swiperElemConstructor as SwiperContainer);\r\n            this.swiperElement()?.initialize();\r\n\r\n            // Configurar navegación personalizada si está habilitada\r\n            if (this.enableCustomNavigation) {\r\n                setTimeout(() => {\r\n                    this.setupCustomNavigation();\r\n                }, 200);\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Configura la navegación personalizada del Swiper para banners\r\n     */\r\n    private setupCustomNavigation(): void {\r\n        const prevButton = this.document?.getElementById(`${this.meta?.code}-prev`);\r\n        const nextButton = this.document?.getElementById(`${this.meta?.code}-next`);\r\n        const swiperElement = this.document?.getElementById(this.meta?.code) as any;\r\n\r\n        if (prevButton && nextButton && swiperElement) {\r\n            console.log('Configurando navegación personalizada para banners:', this.meta?.code);\r\n            \r\n            // Actualizar configuración del Swiper existente\r\n            this.updateSwiperForBanners(swiperElement);\r\n\r\n            // Configurar los event listeners para los botones\r\n            this.setupBannerNavigationEventListeners(prevButton, nextButton, swiperElement);\r\n            \r\n            console.log('Event listeners configurados para navegación de banners');\r\n        } else {\r\n            console.log('No se pudieron encontrar los elementos de navegación para banners:', {\r\n                prevButton: !!prevButton,\r\n                nextButton: !!nextButton,\r\n                swiperElement: !!swiperElement\r\n            });\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Actualiza la configuración del Swiper específicamente para banners\r\n     */\r\n    private updateSwiperForBanners(swiperElement: any): void {\r\n        if (swiperElement.swiper) {\r\n            console.log('Actualizando configuración de Swiper para banners');\r\n            \r\n            // Configuración específica para banners\r\n            swiperElement.swiper.params.slidesPerGroup = 1;\r\n            swiperElement.swiper.allowSlideNext = true;\r\n            swiperElement.swiper.allowSlidePrev = true;\r\n            \r\n            // Actualizar también los breakpoints si existen\r\n            if (swiperElement.swiper.params.breakpoints) {\r\n                Object.keys(swiperElement.swiper.params.breakpoints).forEach(key => {\r\n                    swiperElement.swiper.params.breakpoints[key].slidesPerGroup = 1;\r\n                });\r\n            }\r\n            \r\n            swiperElement.swiper.update();\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Configura los event listeners para los botones de navegación de banners\r\n     */\r\n    private setupBannerNavigationEventListeners(prevButton: Element, nextButton: Element, swiperElement: any): void {\r\n        // Remover event listeners existentes para evitar duplicados\r\n        const prevClone = prevButton.cloneNode(true);\r\n        const nextClone = nextButton.cloneNode(true);\r\n        prevButton.parentNode?.replaceChild(prevClone, prevButton);\r\n        nextButton.parentNode?.replaceChild(nextClone, nextButton);\r\n\r\n        // Agregar nuevos event listeners\r\n        prevClone.addEventListener('click', (e) => {\r\n            e.preventDefault();\r\n            e.stopPropagation();\r\n            console.log('Click en botón anterior (banners)');\r\n            if (swiperElement.swiper) {\r\n                swiperElement.swiper.slidePrev();\r\n            }\r\n        });\r\n\r\n        nextClone.addEventListener('click', (e) => {\r\n            e.preventDefault();\r\n            e.stopPropagation();\r\n            console.log('Click en botón siguiente (banners)');\r\n            if (swiperElement.swiper) {\r\n                swiperElement.swiper.slideNext();\r\n            }\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Aplica el evento `select_promotion` junto con el banner que interactúa.\r\n     * @param banner \r\n     */\r\n    selectPromotion(banner: any): void {\r\n        this.analyticsService.callEvent('select_promotion', banner);\r\n    }\r\n\r\n    /**\r\n     * Obtiene la configuración específica del Swiper para banners\r\n     * Sobrescribe la configuración base si es necesario\r\n     */\r\n    private getBannerSwiperConfiguration() {\r\n        return {\r\n            slidesPerView: 1,\r\n            spaceBetween: 0,\r\n            slidesPerGroup: 1,\r\n            navigation: false, // Deshabilitamos la navegación por defecto\r\n            pagination: {\r\n                el: '.swiper-pagination',\r\n                clickable: true,\r\n            },\r\n            loop: true,\r\n            autoplay: {\r\n                delay: 5000,\r\n                disableOnInteraction: false,\r\n            },\r\n            effect: 'fade',\r\n            fadeEffect: {\r\n                crossFade: true\r\n            }\r\n        };\r\n    }\r\n}\r\n","@if(banners.length > 0) {\r\n    <section [ngClass]=\"trimClassBlock(meta?.code)+' container-fluid px-0'\"\r\n        [style.background-color]=\"meta.styles?.backgroundColor\"\r\n        [style.background-image]=\"meta.styles?.backgroundImage ? 'url(' + mediaUrl + meta.styles?.backgroundImage +')' : 'inherit'\">\r\n\r\n        @if (banners.length == 1) {\r\n            <!-- si es formato fijo -->\r\n            <div class=\"row justify-content-center\">\r\n                @let banner = banners[0];\r\n                @if(!banners.styles?.button?.text){\r\n                    <!-- banner sin boton -->\r\n                    <a [href]=\"banner.url\" >\r\n                        <div class=\"item col-12\">\r\n                            <img class=\"img-fluid\" [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\">\r\n                            <div class=\"position-absolute w-100 h-100 start-0 top-0\">\r\n                                @if(banner.title){\r\n                                    <h2 [class]=\"'item-title-full px-2 item-position-vertical-' + (banner.styles?.description?.position)\"\r\n                                    [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#fff' \">\r\n                                        {{banner.title}}\r\n                                    </h2>\r\n                                }\r\n                                @if(banner.subtitle){\r\n                                    <p [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \"\r\n                                    [class]=\"'px-4 item-subtitle-full item-position-vertical-' + (banner.styles?.description?.position)\">\r\n                                        {{banner.subtitle}}\r\n                                    </p>\r\n                                }\r\n                            </div>\r\n                        </div>\r\n                    </a>\r\n                }@else {\r\n                    <!-- banner fijo con boton -->\r\n                    <div class=\"item col-12\">\r\n                        <img class=\"img-fluid\" [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\">\r\n                        <div class=\"position-absolute w-100 h-100 start-0 top-0\">\r\n                            @if(banner.title){\r\n                                <h2 [class]=\"'item-title-full px-2 item-position-vertical-' + (banner.styles?.description?.position)\"\r\n                                [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \">\r\n                                    {{banner.title}}\r\n                                </h2>\r\n                            }\r\n                            @if(banner.subtitle){\r\n                                <p \r\n                                [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \"\r\n                                [class]=\"'px-4 item-subtitle-full item-position-vertical-' + (banner.styles?.description?.position)\">\r\n                                    {{banner.subtitle}}\r\n                                </p>\r\n                            <div [class]=\"'item-position-vertical-' + (banner.styles?.button?.position)\">\r\n                                @if(banner.styles?.button?.text){\r\n                                <a href=\"{{banner.url}}\"\r\n                                    [class]=\"'item-button-full btn btn-light '\">\r\n                                        {{banner.styles.button.text}}\r\n                                    </a> \r\n                                }\r\n                                \r\n                            </div>\r\n                            }\r\n                        </div>\r\n                    </div>\r\n                }\r\n            </div>\r\n        }@else {\r\n            <!-- si es carrousel -->\r\n            <!--  @if(swiperElement() != null){ -->\r\n                <swiper-container init=\"false\" [id]=\"meta?.code\">\r\n                @for (banner of banners; track $index) {\r\n                    <swiper-slide>\r\n                        <div class=\"item\">\r\n                            @if (!banner.styles?.button?.text) {\r\n                                <!-- banner sin boton -->\r\n                                @if(banner.url){\r\n                                    <a [href]=\"banner.url\" class=\"\">\r\n                                        <img [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\" class=\"img-fluid w-100\" />\r\n                                    </a>\r\n                                }@else {\r\n                                    <img [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\"  class=\"img-fluid w-100\" />\r\n                                }\r\n                            }@else {\r\n                                <!-- banner con boton -->\r\n                                <img [src]=\"mediaBannerUrl + getImage(banner)\" alt=\"\" />\r\n                                <div class=\"position-absolute w-100 h-100 start-0 top-0\">\r\n                                    @if(banner.title){\r\n                                        <h2 [class]=\"'item-title-full px-2 item-position-vertical-'+ (banner.styles?.description?.position)\"\r\n                                            [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \">\r\n                                            {{banner.title}}\r\n                                        </h2>\r\n                                    }\r\n                                    @if(banner.subtitle){\r\n                                        <p [style.color]=\"(banner.styles?.description?.color) ? banner.styles?.description?.color : '#000' \"\r\n                                            [class]=\"'px-4 item-subtitle-full item-position-vertical-' + (banner.styles?.description?.position)\">\r\n                                            {{banner.subtitle}}\r\n                                        </p>\r\n                                    }\r\n                                    <div [class]=\"'item-position-vertical-' + (banner.styles?.button?.position)\">\r\n                                        @if(banner.styles?.button?.text){\r\n                                            <a href=\"{{banner.url}}\" [class]=\"'item-button-full btn btn-light'\">\r\n                                                {{banner.styles.button.text}}\r\n                                            </a>\r\n                                        }\r\n                                    </div>\r\n                                </div>\r\n                            }\r\n                        </div>\r\n                    </swiper-slide>\r\n                }\r\n            </swiper-container>\r\n            <!--  } -->\r\n            \r\n        }\r\n    </section>\r\n}"]}
|
|
@@ -70,7 +70,7 @@ export class BlocksEcComponent {
|
|
|
70
70
|
}
|
|
71
71
|
}
|
|
72
72
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BlocksEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
73
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: BlocksEcComponent, isStandalone: true, selector: "app-blocks-ec", inputs: { templates: "templates", show_loading: "show_loading", section: "section", blockFilters: "blockFilters" }, ngImport: i0, template: "@if(blocks$ | async; as blocks){\r\n @if(blocks.length > 0){\r\n <div class=\"container-fluid px-0\">\r\n <div class=\"row\">\r\n @for (block of blocks; track $index) {\r\n @switch (block.contentType) {\r\n @case ('banner') {\r\n @switch(block.design){\r\n @case ('full') {\r\n <app-block-banner-full-ec [banners]=\"block.banners\" [meta]=\"block\" />\r\n }\r\n @case ('boxes') {\r\n <app-block-banner-box-ec [banners]=\"block.banners\" [meta]=\"block\"/>\r\n }\r\n }\r\n }\r\n @case ('html') {\r\n @if(showBlock(block)){\r\n <app-block-html-ec [html_content]=\"getHTMLContent(block)\" />\r\n }\r\n }\r\n @case ('products') {\r\n <app-block-products-ec [products]=\"block.products?.items\" [meta]=\"block\" />\r\n }\r\n @case ('contact_form') {\r\n @if(isNewsletter(block)){\r\n <app-block-newsletter-ec [block]=\"block.contactForm\" />\r\n } @else {\r\n <app-block-form-contact-ec [block]=\"block.contactForm\" />\r\n }\r\n }\r\n }\r\n }\r\n </div>\r\n </div>\r\n }\r\n}", styles: [""], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: BlockBannerFullEcComponent, selector: "app-block-banner-full-ec", inputs: ["banners", "meta"] }, { kind: "component", type: BlockBannerBoxEcComponent, selector: "app-block-banner-box-ec", inputs: ["banners", "meta"] }, { kind: "component", type: BlockHtmlEcComponent, selector: "app-block-html-ec", inputs: ["html_content"] }, { kind: "component", type: BlockProductsEcComponent, selector: "app-block-products-ec", inputs: ["prevArrowImage", "nextArrowImage", "prevArrowText", "nextArrowText", "appProduct", "products", "meta"] }, { kind: "component", type: BlockNewsletterEcComponent, selector: "app-block-newsletter-ec", inputs: ["block", "success_message", "subject"] }, { kind: "component", type: BlockFormContactEcComponent, selector: "app-block-form-contact-ec", inputs: ["block", "success_message", "redirect", "subject"] }] });
|
|
73
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: BlocksEcComponent, isStandalone: true, selector: "app-blocks-ec", inputs: { templates: "templates", show_loading: "show_loading", section: "section", blockFilters: "blockFilters" }, ngImport: i0, template: "@if(blocks$ | async; as blocks){\r\n @if(blocks.length > 0){\r\n <div class=\"container-fluid px-0\">\r\n <div class=\"row\">\r\n @for (block of blocks; track $index) {\r\n @switch (block.contentType) {\r\n @case ('banner') {\r\n @switch(block.design){\r\n @case ('full') {\r\n <app-block-banner-full-ec [banners]=\"block.banners\" [meta]=\"block\" />\r\n }\r\n @case ('boxes') {\r\n <app-block-banner-box-ec [banners]=\"block.banners\" [meta]=\"block\"/>\r\n }\r\n }\r\n }\r\n @case ('html') {\r\n @if(showBlock(block)){\r\n <app-block-html-ec [html_content]=\"getHTMLContent(block)\" />\r\n }\r\n }\r\n @case ('products') {\r\n <app-block-products-ec [products]=\"block.products?.items\" [meta]=\"block\" />\r\n }\r\n @case ('contact_form') {\r\n @if(isNewsletter(block)){\r\n <app-block-newsletter-ec [block]=\"block.contactForm\" />\r\n } @else {\r\n <app-block-form-contact-ec [block]=\"block.contactForm\" />\r\n }\r\n }\r\n }\r\n }\r\n </div>\r\n </div>\r\n }\r\n}", styles: [""], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: BlockBannerFullEcComponent, selector: "app-block-banner-full-ec", inputs: ["banners", "meta", "prevArrowImage", "nextArrowImage", "prevArrowText", "nextArrowText", "enableCustomNavigation"] }, { kind: "component", type: BlockBannerBoxEcComponent, selector: "app-block-banner-box-ec", inputs: ["banners", "meta"] }, { kind: "component", type: BlockHtmlEcComponent, selector: "app-block-html-ec", inputs: ["html_content"] }, { kind: "component", type: BlockProductsEcComponent, selector: "app-block-products-ec", inputs: ["prevArrowImage", "nextArrowImage", "prevArrowText", "nextArrowText", "appProduct", "products", "meta"] }, { kind: "component", type: BlockNewsletterEcComponent, selector: "app-block-newsletter-ec", inputs: ["block", "success_message", "subject"] }, { kind: "component", type: BlockFormContactEcComponent, selector: "app-block-form-contact-ec", inputs: ["block", "success_message", "redirect", "subject"] }] });
|
|
74
74
|
}
|
|
75
75
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BlocksEcComponent, decorators: [{
|
|
76
76
|
type: Component,
|
|
@@ -96,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
96
96
|
}], blockFilters: [{
|
|
97
97
|
type: Input
|
|
98
98
|
}] } });
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"blocks-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/blocks-ec/blocks-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/blocks-ec/blocks-ec.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAuB,MAAM,eAAe,CAAC;AAE9E,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAEtD,OAAO,EAAE,0BAA0B,EAAE,MAAM,uDAAuD,CAAC;AACnG,OAAO,EAAE,yBAAyB,EAAE,MAAM,qDAAqD,CAAC;AAChG,OAAO,EAAE,oBAAoB,EAAE,MAAM,yCAAyC,CAAC;AAC/E,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AACtD,OAAO,EAAE,wBAAwB,EAAE,MAAM,iDAAiD,CAAC;AAC3F,OAAO,EAAE,0BAA0B,EAAE,MAAM,qDAAqD,CAAC;AACjG,OAAO,EAAE,2BAA2B,EAAE,MAAM,yDAAyD,CAAC;;AACtG;;;;;GAKG;AAiBH,MAAM,OAAO,iBAAiB;IAC7B;;OAEG;IACK,cAAc,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;IAC/C;;;OAGG;IACK,aAAa,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;IACpD;;OAEG;IACI,OAAO,CAAmC;IACjD;;OAEG;IACK,WAAW,GAAkB,IAAI,CAAC;IAC1C;;;OAGG;IACM,SAAS,CAAoB;IACtC;;OAEG;IACM,YAAY,GAAY,KAAK,CAAC;IACvC;;OAEG;IACH,IAEO,OAAO,CAAC,KAAoB;QAClC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,UAAU,EAAE,CAAC;IACnB,CAAC;IACQ,YAAY,GAAoB,IAAI,CAAC;IAC9C,gBAAgB,CAAC;IAEjB,QAAQ,KAAW,CAAC;IACpB;;;;OAIG;IACH,cAAc,GAAG,CAAC,KAAa,EAAE,EAAE,CAAC,KAAK,CAAC,YAAY,IAAI,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;IAEhH,YAAY,CAAC,KAAU,IAAa,OAAO,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAA,CAAC,CAAC;IAAA,CAAC;IAErF,SAAS,GAAG,CAAC,KAAa,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;IAEhG;;KAEI;IACI,UAAU;QACjB,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAChE,CAAC;IACF,CAAC;wGA1DW,iBAAiB;4FAAjB,iBAAiB,6LClC9B,0uDAoCC,qDDdC,SAAS,8CAET,0BAA0B,kMAC1B,yBAAyB,iGACzB,oBAAoB,wFACpB,wBAAwB,oLACxB,0BAA0B,qHAC1B,2BAA2B;;4FAKhB,iBAAiB;kBAhB7B,SAAS;+BACC,eAAe,cACb,IAAI,WACP;wBACR,SAAS;wBACT,QAAQ;wBACR,0BAA0B;wBAC1B,yBAAyB;wBACzB,oBAAoB;wBACpB,wBAAwB;wBACxB,0BAA0B;wBAC1B,2BAA2B;qBAC3B;wDA0BQ,SAAS;sBAAjB,KAAK;gBAIG,YAAY;sBAApB,KAAK;gBAMC,OAAO;sBAFb,KAAK;uBAAC;wBACN,QAAQ,EAAE,IAAI;qBACd;gBAIQ,YAAY;sBAApB,KAAK","sourcesContent":["import { Component, inject, Input, OnInit, TemplateRef } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { BlocksService } from '../../ec-services';\r\nimport { AsyncPipe, JsonPipe } from '@angular/common';\r\nimport { IBlock } from '../../interfaces';\r\nimport { BlockBannerFullEcComponent } from './block-banner-full-ec/block-banner-full-ec.component';\r\nimport { BlockBannerBoxEcComponent } from \"./block-banner-box-ec/block-banner-box-ec.component\";\r\nimport { BlockHtmlEcComponent } from \"./block-html-ec/block-html-ec.component\";\r\nimport { ApiConstantsService } from '../../constants';\r\nimport { BlockProductsEcComponent } from \"./block-products-ec/block-products-ec.component\";\r\nimport { BlockNewsletterEcComponent } from \"./block-newsletter-ec/block-newsletter-ec.component\";\r\nimport { BlockFormContactEcComponent } from \"./block-form-contact-ec/block-form-contact-ec.component\";\r\n/**\r\n * Componente que es utilizado para manejar los distintos tipos\r\n * de bloques y distribuirlos por la aplicación.\r\n * @implements {OnInit}\r\n * @class BlocksEcComponent\r\n */\r\n@Component({\r\n\tselector: 'app-blocks-ec',\r\n\tstandalone: true,\r\n\timports: [\r\n\t\tAsyncPipe,\r\n\t\tJsonPipe,\r\n\t\tBlockBannerFullEcComponent,\r\n\t\tBlockBannerBoxEcComponent,\r\n\t\tBlockHtmlEcComponent,\r\n\t\tBlockProductsEcComponent,\r\n\t\tBlockNewsletterEcComponent,\r\n\t\tBlockFormContactEcComponent\r\n\t],\r\n\ttemplateUrl: './blocks-ec.component.html',\r\n\tstyleUrl: './blocks-ec.component.scss'\r\n})\r\nexport class BlocksEcComponent implements OnInit {\r\n\t/**\r\n\t * Servicio de Bloques\r\n\t */\r\n\tprivate _blocksService = inject(BlocksService);\r\n\t/**\tprivate _blocksService = inject(BlocksService);\r\n\r\n\t * Constantes de la API\r\n\t */\r\n\tprivate _apiConstants = inject(ApiConstantsService);\r\n\t/**\r\n\t * Observable de bloques\r\n\t */\r\n\tpublic blocks$: Observable<IBlock[]> | undefined;\r\n\t/**\r\n\t * Nombre de la sección que alberga a los bloques.\r\n\t */\r\n\tprivate _strsection: string | null = null;\r\n\t/**\r\n\t * Colección de Templates para reemplazar en los distintos tipos\r\n\t * de bloque por bloques locales generados en el frontend.\r\n\t */\r\n\t@Input() templates!: TemplateRef<any>;\r\n\t/**\r\n\t * Indicador para cuando se esten cargando los bloques.\r\n\t */\r\n\t@Input() show_loading: boolean = false;\r\n\t/**\r\n\t * Nombre de la sección del bloque. \r\n\t */\r\n\t@Input({\r\n\t\trequired: true,\r\n\t}) set section(value: string | null) {\r\n\t\tthis._strsection = value;\r\n\t\tthis.loadBlocks();\r\n\t}\r\n\t@Input() blockFilters: string[] | null = null;\r\n\tconstructor() { }\r\n\r\n\tngOnInit(): void { }\r\n\t/**\r\n\t * Obtiene el contenido html de un bloque, este método es usado cuando el bloque es de tipo **HTML**\r\n\t * @param block \r\n\t * @returns \r\n\t */\r\n\tgetHTMLContent = (block: IBlock) => block.translations && block.translations[this._apiConstants.LOCALE].content;\r\n\r\n\tisNewsletter(block: any): boolean { return block.contactForm.code.includes('news') };\r\n\r\n\tshowBlock = (block: IBlock) => this.blockFilters ? this.blockFilters.includes(block.code) : true\r\n\r\n\t/**\r\n   * Carga los bloques de la sección actual.\r\n   */\r\n\tprivate loadBlocks(): void {\r\n\t\tif (this._strsection) {\r\n\t\t\tthis.blocks$ = this._blocksService.getBlocks(this._strsection);\r\n\t\t}\r\n\t}\r\n}\t\r\n","@if(blocks$ | async; as blocks){\r\n    @if(blocks.length > 0){\r\n        <div class=\"container-fluid px-0\">\r\n            <div class=\"row\">\r\n                @for (block of blocks; track $index) {\r\n                    @switch (block.contentType) {\r\n                        @case ('banner') {\r\n                            @switch(block.design){\r\n                                @case ('full') {\r\n                                    <app-block-banner-full-ec [banners]=\"block.banners\" [meta]=\"block\" />\r\n                                }\r\n                                @case ('boxes') {\r\n                                    <app-block-banner-box-ec [banners]=\"block.banners\" [meta]=\"block\"/>\r\n                                }\r\n                            }\r\n                        }\r\n                        @case ('html') {\r\n                            @if(showBlock(block)){\r\n                                <app-block-html-ec [html_content]=\"getHTMLContent(block)\" />\r\n                            }\r\n                        }\r\n                        @case ('products') {\r\n                            <app-block-products-ec [products]=\"block.products?.items\" [meta]=\"block\" />\r\n                        }\r\n                        @case ('contact_form') {\r\n                            @if(isNewsletter(block)){\r\n                                <app-block-newsletter-ec [block]=\"block.contactForm\" />\r\n                            } @else {\r\n                                <app-block-form-contact-ec [block]=\"block.contactForm\" />\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n            </div>\r\n        </div>\r\n    }\r\n}"]}
|