ng-easycommerce-v18 0.2.10 → 0.2.12

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 CHANGED
@@ -1,4 +1,8 @@
1
- # Version 0.2.6
1
+ # Version 0.2.12
2
+ - Se agrega logia al app-price para funcion de mostrar precios logeados o no
3
+ # Version 0.2.11
4
+ - se cambia el block-banner-full para personalizar las flechas
5
+ # Version 0.2.10
2
6
  - Se modifica las constantes de apiURL para probar.
3
7
  # Version 0.2.5
4
8
  - Se prueba el apiURL
@@ -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 utlizado para guarda el contenedor del carrusel
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) => { return { ...banner, ...banner.translations[this.apiConsts.LOCALE] }; });
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 del banners. Esto debe ser asi debido a que ya debe estar presente
51
- * en el Dom el element `<swiper-container>` para poder configurarlo.
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
- const swiperElemConstructor = this.document?.querySelector('#' + this.meta?.code);
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 interactua.
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,{"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,kGAC1B,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}"]}
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}"]}
@@ -3,6 +3,7 @@ import { EcCurrencySymbolPipe } from "../../../ec-pipe/ec-currency-symbol.pipe";
3
3
  import { ChannelService } from '../../../ec-services';
4
4
  import { TranslateModule } from '@ngx-translate/core';
5
5
  import { CommonModule } from '@angular/common';
6
+ import { AuthService } from '../../../ec-services';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "@angular/common";
8
9
  import * as i2 from "@ngx-translate/core";
@@ -28,13 +29,18 @@ export class PriceEcComponent {
28
29
  customTaxTemplate = null;
29
30
  customOnlyTaxLabelTemplate = null;
30
31
  _channelService = inject(ChannelService);
32
+ _authService = inject(AuthService);
31
33
  showTaxLegend = false;
32
34
  hideTaxes = false;
35
+ showPricesOnlyToLoggedUsers = false;
36
+ logged = false;
33
37
  ngOnInit() {
34
38
  this._channelService.channel$.subscribe(cfg => {
35
39
  this.showTaxLegend = !!cfg.showTaxLegend;
36
40
  this.hideTaxes = !!cfg.hideTaxes;
41
+ this.showPricesOnlyToLoggedUsers = !!cfg.showPricesOnlyToLoggedUsers;
37
42
  });
43
+ this.logged = this._authService.isAuthenticated();
38
44
  }
39
45
  /** Determina si mostrar la sección de impuestos */
40
46
  get shouldShowTaxes() {
@@ -53,11 +59,11 @@ export class PriceEcComponent {
53
59
  return !!value && value.split(' - ').length === 2;
54
60
  }
55
61
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PriceEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
56
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: PriceEcComponent, isStandalone: true, selector: "app-price-ec", inputs: { price: "price", saleprice: "saleprice", basePrice: "basePrice", taxeAmount: "taxeAmount", taxes: "taxes", priceSize: "priceSize", showTaxLegendOnly: "showTaxLegendOnly", disableTaxInfo: "disableTaxInfo", customPriceTemplate: "customPriceTemplate", customSalePriceTemplate: "customSalePriceTemplate", customSimplePriceTemplate: "customSimplePriceTemplate", customSimpleSalePriceTemplate: "customSimpleSalePriceTemplate", customTaxTemplate: "customTaxTemplate", customOnlyTaxLabelTemplate: "customOnlyTaxLabelTemplate" }, ngImport: i0, template: "<ng-container *ngIf=\"customSalePriceTemplate || customPriceTemplate; else defaultPriceBlock\">\r\n <ng-container *ngTemplateOutlet=\"customSalePriceTemplate || customPriceTemplate\">\r\n </ng-container>\r\n</ng-container>\r\n\r\n<ng-template #defaultPriceBlock>\r\n <div class=\"price\">\r\n <!-- Con precio de oferta -->\r\n <div *ngIf=\"saleprice; else onlyPriceBlock\" class=\"line-height-custom\">\r\n\r\n <!-- Precio original como rango o tachado simple -->\r\n <div *ngIf=\"hasRange(price); else simplePriceDel\" class=\"price-whithSaleprice\">\r\n <del class=\"\">\r\n {{\r\n price!.split(' - ')[0] | ecCurrencySymbol\r\n }}\r\n {{\r\n price!.split(' - ')[1] | ecCurrencySymbol\r\n }}\r\n </del>\r\n </div>\r\n\r\n <!-- Oferta como rango o simple -->\r\n <div *ngIf=\"hasRange(saleprice); else simpleSalePrice\" class=\"\">\r\n {{\r\n saleprice!.split(' - ')[0] | ecCurrencySymbol\r\n }}\r\n {{\r\n saleprice!.split(' - ')[1] | ecCurrencySymbol\r\n }}\r\n </div>\r\n </div>\r\n\r\n <!-- S\u00F3lo precio sin oferta -->\r\n <ng-template #onlyPriceBlock>\r\n <div *ngIf=\"hasRange(price); else simplePrice\" class=\"price-onlyPrice\">\r\n {{\r\n price!.split(' - ')[0] | ecCurrencySymbol\r\n }} -\r\n {{\r\n price!.split(' - ')[1] | ecCurrencySymbol\r\n }}\r\n </div>\r\n </ng-template>\r\n\r\n <!-- Fallback simple price -->\r\n <ng-template #simplePrice>\r\n <ng-container *ngIf=\"customSimplePriceTemplate; else fallbackSimplePrice\">\r\n <ng-container *ngTemplateOutlet=\"customSimplePriceTemplate\"></ng-container>\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #fallbackSimplePrice>\r\n <del>&nbsp;</del>\r\n <div class=\"price-simplePrice\">\r\n {{ price | ecCurrencySymbol }}\r\n </div>\r\n </ng-template>\r\n\r\n <!-- Fallback simple price-del -->\r\n <ng-template #simplePriceDel>\r\n <div class=\"price-simpleDel\">\r\n <del class=\"\">{{ price | ecCurrencySymbol }}</del>\r\n </div>\r\n </ng-template>\r\n\r\n <!-- Fallback simple saleprice -->\r\n <ng-template #simpleSalePrice>\r\n <ng-container *ngIf=\"customSimpleSalePriceTemplate; else fallbackSimpleSalePrice\">\r\n <ng-container *ngTemplateOutlet=\"customSimpleSalePriceTemplate\"></ng-container>\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #fallbackSimpleSalePrice>\r\n <div class=\"price-simpleSaleprice\">\r\n {{ saleprice | ecCurrencySymbol }}\r\n </div>\r\n </ng-template>\r\n </div>\r\n</ng-template>\r\n\r\n<!-- Secci\u00F3n de impuestos -->\r\n<ng-container *ngIf=\"shouldShowTaxes\">\r\n <!-- S\u00F3lo leyenda -->\r\n <ng-container *ngIf=\"showTaxLegendOnly; else detailedTaxBlock\">\r\n <ng-container *ngIf=\"customOnlyTaxLabelTemplate; else defaultOnlyTaxLabel\">\r\n <ng-container *ngTemplateOutlet=\"customOnlyTaxLabelTemplate\"></ng-container>\r\n </ng-container>\r\n <ng-template #defaultOnlyTaxLabel>\r\n <p class=\"taxes-title\">\r\n {{ 'price-without-national-taxes' | translate }}:\r\n {{ basePrice! | ecCurrencySymbol }}\r\n </p>\r\n </ng-template>\r\n </ng-container>\r\n\r\n <!-- Detalle impuestos -->\r\n <ng-template #detailedTaxBlock>\r\n <ng-container *ngIf=\"customTaxTemplate; else defaultTaxBlock\">\r\n <ng-container *ngTemplateOutlet=\"customTaxTemplate\"></ng-container>\r\n </ng-container>\r\n </ng-template>\r\n</ng-container>\r\n\r\n<ng-template #defaultTaxBlock>\r\n <div class=\"taxes-section\">\r\n <p class=\"taxes-title\">\r\n {{ 'price-without-national-taxes' | translate }}:\r\n {{ basePrice! | ecCurrencySymbol }}\r\n </p>\r\n <ul class=\"taxes-list\">\r\n <li>\r\n {{ taxes.Name }}: {{ taxeAmount | ecCurrencySymbol }}\r\n </li>\r\n </ul>\r\n </div>\r\n</ng-template>", styles: [".price-sm{font-size:13px}.price{font-size:18px}.line-height-custom{line-height:1.2}.lnth{text-decoration:line-through;color:gray}.taxes-section{margin-top:.5rem;border-radius:.5rem;font-size:.95rem;color:#333;line-height:1.4;max-width:400px}.taxes-title{font-weight:500;margin-bottom:.2rem;font-size:.7rem;color:#222}.taxes-list{list-style:none;padding:0;margin:0}.taxes-list li{display:flex;justify-content:space-between;margin-bottom:.1rem;font-size:.65rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: EcCurrencySymbolPipe, name: "ecCurrencySymbol" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
62
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: PriceEcComponent, isStandalone: true, selector: "app-price-ec", inputs: { price: "price", saleprice: "saleprice", basePrice: "basePrice", taxeAmount: "taxeAmount", taxes: "taxes", priceSize: "priceSize", showTaxLegendOnly: "showTaxLegendOnly", disableTaxInfo: "disableTaxInfo", customPriceTemplate: "customPriceTemplate", customSalePriceTemplate: "customSalePriceTemplate", customSimplePriceTemplate: "customSimplePriceTemplate", customSimpleSalePriceTemplate: "customSimpleSalePriceTemplate", customTaxTemplate: "customTaxTemplate", customOnlyTaxLabelTemplate: "customOnlyTaxLabelTemplate" }, ngImport: i0, template: "@if (!showPricesOnlyToLoggedUsers || logged) {\r\n<ng-container *ngIf=\"customSalePriceTemplate || customPriceTemplate; else defaultPriceBlock\">\r\n <ng-container *ngTemplateOutlet=\"customSalePriceTemplate || customPriceTemplate\">\r\n </ng-container>\r\n</ng-container>\r\n\r\n<ng-template #defaultPriceBlock>\r\n <div class=\"price\">\r\n <!-- Con precio de oferta -->\r\n <div *ngIf=\"saleprice; else onlyPriceBlock\" class=\"line-height-custom\">\r\n\r\n <!-- Precio original como rango o tachado simple -->\r\n <div *ngIf=\"hasRange(price); else simplePriceDel\" class=\"price-whithSaleprice\">\r\n <del class=\"\">\r\n {{\r\n price!.split(' - ')[0] | ecCurrencySymbol\r\n }}\r\n {{\r\n price!.split(' - ')[1] | ecCurrencySymbol\r\n }}\r\n </del>\r\n </div>\r\n\r\n <!-- Oferta como rango o simple -->\r\n <div *ngIf=\"hasRange(saleprice); else simpleSalePrice\" class=\"\">\r\n {{\r\n saleprice!.split(' - ')[0] | ecCurrencySymbol\r\n }}\r\n {{\r\n saleprice!.split(' - ')[1] | ecCurrencySymbol\r\n }}\r\n </div>\r\n </div>\r\n\r\n <!-- S\u00F3lo precio sin oferta -->\r\n <ng-template #onlyPriceBlock>\r\n <div *ngIf=\"hasRange(price); else simplePrice\" class=\"price-onlyPrice\">\r\n {{\r\n price!.split(' - ')[0] | ecCurrencySymbol\r\n }} -\r\n {{\r\n price!.split(' - ')[1] | ecCurrencySymbol\r\n }}\r\n </div>\r\n </ng-template>\r\n\r\n <!-- Fallback simple price -->\r\n <ng-template #simplePrice>\r\n <ng-container *ngIf=\"customSimplePriceTemplate; else fallbackSimplePrice\">\r\n <ng-container *ngTemplateOutlet=\"customSimplePriceTemplate\"></ng-container>\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #fallbackSimplePrice>\r\n <del>&nbsp;</del>\r\n <div class=\"price-simplePrice\">\r\n {{ price | ecCurrencySymbol }}\r\n </div>\r\n </ng-template>\r\n\r\n <!-- Fallback simple price-del -->\r\n <ng-template #simplePriceDel>\r\n <div class=\"price-simpleDel\">\r\n <del class=\"\">{{ price | ecCurrencySymbol }}</del>\r\n </div>\r\n </ng-template>\r\n\r\n <!-- Fallback simple saleprice -->\r\n <ng-template #simpleSalePrice>\r\n <ng-container *ngIf=\"customSimpleSalePriceTemplate; else fallbackSimpleSalePrice\">\r\n <ng-container *ngTemplateOutlet=\"customSimpleSalePriceTemplate\"></ng-container>\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #fallbackSimpleSalePrice>\r\n <div class=\"price-simpleSaleprice\">\r\n {{ saleprice | ecCurrencySymbol }}\r\n </div>\r\n </ng-template>\r\n </div>\r\n</ng-template>\r\n\r\n<!-- Secci\u00F3n de impuestos -->\r\n<ng-container *ngIf=\"shouldShowTaxes\">\r\n <!-- S\u00F3lo leyenda -->\r\n <ng-container *ngIf=\"showTaxLegendOnly; else detailedTaxBlock\">\r\n <ng-container *ngIf=\"customOnlyTaxLabelTemplate; else defaultOnlyTaxLabel\">\r\n <ng-container *ngTemplateOutlet=\"customOnlyTaxLabelTemplate\"></ng-container>\r\n </ng-container>\r\n <ng-template #defaultOnlyTaxLabel>\r\n <p class=\"taxes-title\">\r\n {{ 'price-without-national-taxes' | translate }}:\r\n {{ basePrice! | ecCurrencySymbol }}\r\n </p>\r\n </ng-template>\r\n </ng-container>\r\n\r\n <!-- Detalle impuestos -->\r\n <ng-template #detailedTaxBlock>\r\n <ng-container *ngIf=\"customTaxTemplate; else defaultTaxBlock\">\r\n <ng-container *ngTemplateOutlet=\"customTaxTemplate\"></ng-container>\r\n </ng-container>\r\n </ng-template>\r\n</ng-container>\r\n\r\n<ng-template #defaultTaxBlock>\r\n <div class=\"taxes-section\">\r\n <p class=\"taxes-title\">\r\n {{ 'price-without-national-taxes' | translate }}:\r\n {{ basePrice! | ecCurrencySymbol }}\r\n </p>\r\n <ul class=\"taxes-list\">\r\n <li>\r\n {{ taxes.Name }}: {{ taxeAmount | ecCurrencySymbol }}\r\n </li>\r\n </ul>\r\n </div>\r\n</ng-template>\r\n}", styles: [".price-sm{font-size:13px}.price{font-size:18px}.line-height-custom{line-height:1.2}.lnth{text-decoration:line-through;color:gray}.taxes-section{margin-top:.5rem;border-radius:.5rem;font-size:.95rem;color:#333;line-height:1.4;max-width:400px}.taxes-title{font-weight:500;margin-bottom:.2rem;font-size:.7rem;color:#222}.taxes-list{list-style:none;padding:0;margin:0}.taxes-list li{display:flex;justify-content:space-between;margin-bottom:.1rem;font-size:.65rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: EcCurrencySymbolPipe, name: "ecCurrencySymbol" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
57
63
  }
58
64
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PriceEcComponent, decorators: [{
59
65
  type: Component,
60
- args: [{ selector: 'app-price-ec', standalone: true, imports: [CommonModule, EcCurrencySymbolPipe, TranslateModule], template: "<ng-container *ngIf=\"customSalePriceTemplate || customPriceTemplate; else defaultPriceBlock\">\r\n <ng-container *ngTemplateOutlet=\"customSalePriceTemplate || customPriceTemplate\">\r\n </ng-container>\r\n</ng-container>\r\n\r\n<ng-template #defaultPriceBlock>\r\n <div class=\"price\">\r\n <!-- Con precio de oferta -->\r\n <div *ngIf=\"saleprice; else onlyPriceBlock\" class=\"line-height-custom\">\r\n\r\n <!-- Precio original como rango o tachado simple -->\r\n <div *ngIf=\"hasRange(price); else simplePriceDel\" class=\"price-whithSaleprice\">\r\n <del class=\"\">\r\n {{\r\n price!.split(' - ')[0] | ecCurrencySymbol\r\n }}\r\n {{\r\n price!.split(' - ')[1] | ecCurrencySymbol\r\n }}\r\n </del>\r\n </div>\r\n\r\n <!-- Oferta como rango o simple -->\r\n <div *ngIf=\"hasRange(saleprice); else simpleSalePrice\" class=\"\">\r\n {{\r\n saleprice!.split(' - ')[0] | ecCurrencySymbol\r\n }}\r\n {{\r\n saleprice!.split(' - ')[1] | ecCurrencySymbol\r\n }}\r\n </div>\r\n </div>\r\n\r\n <!-- S\u00F3lo precio sin oferta -->\r\n <ng-template #onlyPriceBlock>\r\n <div *ngIf=\"hasRange(price); else simplePrice\" class=\"price-onlyPrice\">\r\n {{\r\n price!.split(' - ')[0] | ecCurrencySymbol\r\n }} -\r\n {{\r\n price!.split(' - ')[1] | ecCurrencySymbol\r\n }}\r\n </div>\r\n </ng-template>\r\n\r\n <!-- Fallback simple price -->\r\n <ng-template #simplePrice>\r\n <ng-container *ngIf=\"customSimplePriceTemplate; else fallbackSimplePrice\">\r\n <ng-container *ngTemplateOutlet=\"customSimplePriceTemplate\"></ng-container>\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #fallbackSimplePrice>\r\n <del>&nbsp;</del>\r\n <div class=\"price-simplePrice\">\r\n {{ price | ecCurrencySymbol }}\r\n </div>\r\n </ng-template>\r\n\r\n <!-- Fallback simple price-del -->\r\n <ng-template #simplePriceDel>\r\n <div class=\"price-simpleDel\">\r\n <del class=\"\">{{ price | ecCurrencySymbol }}</del>\r\n </div>\r\n </ng-template>\r\n\r\n <!-- Fallback simple saleprice -->\r\n <ng-template #simpleSalePrice>\r\n <ng-container *ngIf=\"customSimpleSalePriceTemplate; else fallbackSimpleSalePrice\">\r\n <ng-container *ngTemplateOutlet=\"customSimpleSalePriceTemplate\"></ng-container>\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #fallbackSimpleSalePrice>\r\n <div class=\"price-simpleSaleprice\">\r\n {{ saleprice | ecCurrencySymbol }}\r\n </div>\r\n </ng-template>\r\n </div>\r\n</ng-template>\r\n\r\n<!-- Secci\u00F3n de impuestos -->\r\n<ng-container *ngIf=\"shouldShowTaxes\">\r\n <!-- S\u00F3lo leyenda -->\r\n <ng-container *ngIf=\"showTaxLegendOnly; else detailedTaxBlock\">\r\n <ng-container *ngIf=\"customOnlyTaxLabelTemplate; else defaultOnlyTaxLabel\">\r\n <ng-container *ngTemplateOutlet=\"customOnlyTaxLabelTemplate\"></ng-container>\r\n </ng-container>\r\n <ng-template #defaultOnlyTaxLabel>\r\n <p class=\"taxes-title\">\r\n {{ 'price-without-national-taxes' | translate }}:\r\n {{ basePrice! | ecCurrencySymbol }}\r\n </p>\r\n </ng-template>\r\n </ng-container>\r\n\r\n <!-- Detalle impuestos -->\r\n <ng-template #detailedTaxBlock>\r\n <ng-container *ngIf=\"customTaxTemplate; else defaultTaxBlock\">\r\n <ng-container *ngTemplateOutlet=\"customTaxTemplate\"></ng-container>\r\n </ng-container>\r\n </ng-template>\r\n</ng-container>\r\n\r\n<ng-template #defaultTaxBlock>\r\n <div class=\"taxes-section\">\r\n <p class=\"taxes-title\">\r\n {{ 'price-without-national-taxes' | translate }}:\r\n {{ basePrice! | ecCurrencySymbol }}\r\n </p>\r\n <ul class=\"taxes-list\">\r\n <li>\r\n {{ taxes.Name }}: {{ taxeAmount | ecCurrencySymbol }}\r\n </li>\r\n </ul>\r\n </div>\r\n</ng-template>", styles: [".price-sm{font-size:13px}.price{font-size:18px}.line-height-custom{line-height:1.2}.lnth{text-decoration:line-through;color:gray}.taxes-section{margin-top:.5rem;border-radius:.5rem;font-size:.95rem;color:#333;line-height:1.4;max-width:400px}.taxes-title{font-weight:500;margin-bottom:.2rem;font-size:.7rem;color:#222}.taxes-list{list-style:none;padding:0;margin:0}.taxes-list li{display:flex;justify-content:space-between;margin-bottom:.1rem;font-size:.65rem}\n"] }]
66
+ args: [{ selector: 'app-price-ec', standalone: true, imports: [CommonModule, EcCurrencySymbolPipe, TranslateModule], template: "@if (!showPricesOnlyToLoggedUsers || logged) {\r\n<ng-container *ngIf=\"customSalePriceTemplate || customPriceTemplate; else defaultPriceBlock\">\r\n <ng-container *ngTemplateOutlet=\"customSalePriceTemplate || customPriceTemplate\">\r\n </ng-container>\r\n</ng-container>\r\n\r\n<ng-template #defaultPriceBlock>\r\n <div class=\"price\">\r\n <!-- Con precio de oferta -->\r\n <div *ngIf=\"saleprice; else onlyPriceBlock\" class=\"line-height-custom\">\r\n\r\n <!-- Precio original como rango o tachado simple -->\r\n <div *ngIf=\"hasRange(price); else simplePriceDel\" class=\"price-whithSaleprice\">\r\n <del class=\"\">\r\n {{\r\n price!.split(' - ')[0] | ecCurrencySymbol\r\n }}\r\n {{\r\n price!.split(' - ')[1] | ecCurrencySymbol\r\n }}\r\n </del>\r\n </div>\r\n\r\n <!-- Oferta como rango o simple -->\r\n <div *ngIf=\"hasRange(saleprice); else simpleSalePrice\" class=\"\">\r\n {{\r\n saleprice!.split(' - ')[0] | ecCurrencySymbol\r\n }}\r\n {{\r\n saleprice!.split(' - ')[1] | ecCurrencySymbol\r\n }}\r\n </div>\r\n </div>\r\n\r\n <!-- S\u00F3lo precio sin oferta -->\r\n <ng-template #onlyPriceBlock>\r\n <div *ngIf=\"hasRange(price); else simplePrice\" class=\"price-onlyPrice\">\r\n {{\r\n price!.split(' - ')[0] | ecCurrencySymbol\r\n }} -\r\n {{\r\n price!.split(' - ')[1] | ecCurrencySymbol\r\n }}\r\n </div>\r\n </ng-template>\r\n\r\n <!-- Fallback simple price -->\r\n <ng-template #simplePrice>\r\n <ng-container *ngIf=\"customSimplePriceTemplate; else fallbackSimplePrice\">\r\n <ng-container *ngTemplateOutlet=\"customSimplePriceTemplate\"></ng-container>\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #fallbackSimplePrice>\r\n <del>&nbsp;</del>\r\n <div class=\"price-simplePrice\">\r\n {{ price | ecCurrencySymbol }}\r\n </div>\r\n </ng-template>\r\n\r\n <!-- Fallback simple price-del -->\r\n <ng-template #simplePriceDel>\r\n <div class=\"price-simpleDel\">\r\n <del class=\"\">{{ price | ecCurrencySymbol }}</del>\r\n </div>\r\n </ng-template>\r\n\r\n <!-- Fallback simple saleprice -->\r\n <ng-template #simpleSalePrice>\r\n <ng-container *ngIf=\"customSimpleSalePriceTemplate; else fallbackSimpleSalePrice\">\r\n <ng-container *ngTemplateOutlet=\"customSimpleSalePriceTemplate\"></ng-container>\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #fallbackSimpleSalePrice>\r\n <div class=\"price-simpleSaleprice\">\r\n {{ saleprice | ecCurrencySymbol }}\r\n </div>\r\n </ng-template>\r\n </div>\r\n</ng-template>\r\n\r\n<!-- Secci\u00F3n de impuestos -->\r\n<ng-container *ngIf=\"shouldShowTaxes\">\r\n <!-- S\u00F3lo leyenda -->\r\n <ng-container *ngIf=\"showTaxLegendOnly; else detailedTaxBlock\">\r\n <ng-container *ngIf=\"customOnlyTaxLabelTemplate; else defaultOnlyTaxLabel\">\r\n <ng-container *ngTemplateOutlet=\"customOnlyTaxLabelTemplate\"></ng-container>\r\n </ng-container>\r\n <ng-template #defaultOnlyTaxLabel>\r\n <p class=\"taxes-title\">\r\n {{ 'price-without-national-taxes' | translate }}:\r\n {{ basePrice! | ecCurrencySymbol }}\r\n </p>\r\n </ng-template>\r\n </ng-container>\r\n\r\n <!-- Detalle impuestos -->\r\n <ng-template #detailedTaxBlock>\r\n <ng-container *ngIf=\"customTaxTemplate; else defaultTaxBlock\">\r\n <ng-container *ngTemplateOutlet=\"customTaxTemplate\"></ng-container>\r\n </ng-container>\r\n </ng-template>\r\n</ng-container>\r\n\r\n<ng-template #defaultTaxBlock>\r\n <div class=\"taxes-section\">\r\n <p class=\"taxes-title\">\r\n {{ 'price-without-national-taxes' | translate }}:\r\n {{ basePrice! | ecCurrencySymbol }}\r\n </p>\r\n <ul class=\"taxes-list\">\r\n <li>\r\n {{ taxes.Name }}: {{ taxeAmount | ecCurrencySymbol }}\r\n </li>\r\n </ul>\r\n </div>\r\n</ng-template>\r\n}", styles: [".price-sm{font-size:13px}.price{font-size:18px}.line-height-custom{line-height:1.2}.lnth{text-decoration:line-through;color:gray}.taxes-section{margin-top:.5rem;border-radius:.5rem;font-size:.95rem;color:#333;line-height:1.4;max-width:400px}.taxes-title{font-weight:500;margin-bottom:.2rem;font-size:.7rem;color:#222}.taxes-list{list-style:none;padding:0;margin:0}.taxes-list li{display:flex;justify-content:space-between;margin-bottom:.1rem;font-size:.65rem}\n"] }]
61
67
  }], propDecorators: { price: [{
62
68
  type: Input
63
69
  }], saleprice: [{
@@ -87,4 +93,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
87
93
  }], customOnlyTaxLabelTemplate: [{
88
94
  type: Input
89
95
  }] } });
90
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"price-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/widgets-ec/price-ec/price-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/widgets-ec/price-ec/price-ec.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAuB,MAAM,eAAe,CAAC;AAC9E,OAAO,EAAE,oBAAoB,EAAE,MAAM,0CAA0C,CAAC;AAChF,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;;;;AAC/C;;GAEG;AAQH,MAAM,OAAO,gBAAgB;IAC3B,UAAU;IACD,KAAK,CAAU;IACf,SAAS,CAAU;IACnB,SAAS,CAAU;IACnB,UAAU,CAAU;IACpB,KAAK,GAAyC,EAAE,IAAI,EAAE,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC;IAEnF,WAAW;IACF,SAAS,GAAY,KAAK,CAAC;IAC3B,iBAAiB,GAAY,KAAK,CAAC;IACnC,cAAc,GAAY,KAAK,CAAC;IAEzC,wCAAwC;IAC/B,mBAAmB,GAAsC,IAAI,CAAC;IAC9D,uBAAuB,GAAkC,IAAI,CAAC;IAC9D,yBAAyB,GAAgC,IAAI,CAAC;IAC9D,6BAA6B,GAA4B,IAAI,CAAC;IAC9D,iBAAiB,GAAwC,IAAI,CAAC;IAC9D,0BAA0B,GAA+B,IAAI,CAAC;IAE/D,eAAe,GAAmB,MAAM,CAAC,cAAc,CAAC,CAAC;IAC1D,aAAa,GAAG,KAAK,CAAC;IACtB,SAAS,GAAG,KAAK,CAAC;IAEzB,QAAQ;QACN,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YAC5C,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,GAAG,CAAC,aAAa,CAAC;YACzC,IAAI,CAAC,SAAS,GAAO,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC;QACvC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,mDAAmD;IACnD,IAAI,eAAe;QACjB,OAAO,CAAC,IAAI,CAAC,cAAc;eACpB,IAAI,CAAC,aAAa;eAClB,CAAC,IAAI,CAAC,SAAS;eACf,CAAC,CAAC,IAAI,CAAC,SAAS;eAChB,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAED,kCAAkC;IAClC,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC;IAC/C,CAAC;IAED,kCAAkC;IAClC,QAAQ,CAAC,KAAc;QACrB,OAAO,CAAC,CAAC,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC;IACpD,CAAC;wGAjDU,gBAAgB;4FAAhB,gBAAgB,0lBCf7B,++IAkHc,sgBDvGF,YAAY,qSAAE,oBAAoB,wDAAE,eAAe;;4FAIlD,gBAAgB;kBAP5B,SAAS;+BACE,cAAc,cACZ,IAAI,WACP,CAAC,YAAY,EAAE,oBAAoB,EAAE,eAAe,CAAC;8BAMrD,KAAK;sBAAb,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBAGG,mBAAmB;sBAA3B,KAAK;gBACG,uBAAuB;sBAA/B,KAAK;gBACG,yBAAyB;sBAAjC,KAAK;gBACG,6BAA6B;sBAArC,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,0BAA0B;sBAAlC,KAAK","sourcesContent":["import { Component, inject, Input, OnInit, TemplateRef } from '@angular/core';\r\nimport { EcCurrencySymbolPipe } from \"../../../ec-pipe/ec-currency-symbol.pipe\";\r\nimport { ChannelService } from '../../../ec-services';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { CommonModule } from '@angular/common';\r\n/**\r\n * Componente para manejar la vista del precio de un producto.\r\n */\r\n@Component({\r\n  selector: 'app-price-ec',\r\n  standalone: true,\r\n  imports: [CommonModule, EcCurrencySymbolPipe, TranslateModule],\r\n  templateUrl: './price-ec.component.html',\r\n  styleUrl: './price-ec.component.scss'\r\n})\r\nexport class PriceEcComponent implements OnInit {\r\n  // Precios\r\n  @Input() price!: string;\r\n  @Input() saleprice?: string;\r\n  @Input() basePrice?: string;\r\n  @Input() taxeAmount?: number;\r\n  @Input() taxes: { Name: string; taxeAmount: number } = { Name: '', taxeAmount: 0 };\r\n\r\n  // Opciones\r\n  @Input() priceSize: boolean = false;\r\n  @Input() showTaxLegendOnly: boolean = false;\r\n  @Input() disableTaxInfo: boolean = false;\r\n\r\n  // Templates personalizados (proyección)\r\n  @Input() customPriceTemplate: TemplateRef<any> | null           = null;\r\n  @Input() customSalePriceTemplate: TemplateRef<any> | null       = null;\r\n  @Input() customSimplePriceTemplate: TemplateRef<any> | null     = null;\r\n  @Input() customSimpleSalePriceTemplate: TemplateRef<any> | null = null;\r\n  @Input() customTaxTemplate: TemplateRef<any> | null             = null;\r\n  @Input() customOnlyTaxLabelTemplate: TemplateRef<any> | null    = null;\r\n\r\n  private _channelService: ChannelService = inject(ChannelService);\r\n  public showTaxLegend = false;\r\n  public hideTaxes = false;\r\n\r\n  ngOnInit() {\r\n    this._channelService.channel$.subscribe(cfg => {\r\n      this.showTaxLegend = !!cfg.showTaxLegend;\r\n      this.hideTaxes     = !!cfg.hideTaxes;\r\n    });\r\n  }\r\n\r\n  /** Determina si mostrar la sección de impuestos */\r\n  get shouldShowTaxes(): boolean {    \r\n    return !this.disableTaxInfo\r\n        && this.showTaxLegend\r\n        && !this.hideTaxes\r\n        && !!this.basePrice\r\n        && !!this.taxeAmount;\r\n  }\r\n\r\n  /** Clase CSS base según tamaño */\r\n  get priceClass(): string {\r\n    return this.priceSize ? 'price-sm' : 'price';\r\n  }\r\n\r\n  /** Helper para detectar rangos */\r\n  hasRange(value?: string): boolean {\r\n    return !!value && value.split(' - ').length === 2;\r\n  }\r\n}\r\n","<ng-container *ngIf=\"customSalePriceTemplate || customPriceTemplate; else defaultPriceBlock\">\r\n    <ng-container *ngTemplateOutlet=\"customSalePriceTemplate || customPriceTemplate\">\r\n    </ng-container>\r\n</ng-container>\r\n\r\n<ng-template #defaultPriceBlock>\r\n    <div class=\"price\">\r\n        <!-- Con precio de oferta -->\r\n        <div *ngIf=\"saleprice; else onlyPriceBlock\" class=\"line-height-custom\">\r\n\r\n            <!-- Precio original como rango o tachado simple -->\r\n            <div *ngIf=\"hasRange(price); else simplePriceDel\" class=\"price-whithSaleprice\">\r\n                <del class=\"\">\r\n                    {{\r\n                    price!.split(' - ')[0] | ecCurrencySymbol\r\n                    }}\r\n                    {{\r\n                    price!.split(' - ')[1] | ecCurrencySymbol\r\n                    }}\r\n                </del>\r\n            </div>\r\n\r\n            <!-- Oferta como rango o simple -->\r\n            <div *ngIf=\"hasRange(saleprice); else simpleSalePrice\" class=\"\">\r\n                {{\r\n                saleprice!.split(' - ')[0] | ecCurrencySymbol\r\n                }}\r\n                {{\r\n                saleprice!.split(' - ')[1] | ecCurrencySymbol\r\n                }}\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Sólo precio sin oferta -->\r\n        <ng-template #onlyPriceBlock>\r\n            <div *ngIf=\"hasRange(price); else simplePrice\" class=\"price-onlyPrice\">\r\n                {{\r\n                price!.split(' - ')[0] | ecCurrencySymbol\r\n                }} -\r\n                {{\r\n                price!.split(' - ')[1] | ecCurrencySymbol\r\n                }}\r\n            </div>\r\n        </ng-template>\r\n\r\n        <!-- Fallback simple price -->\r\n        <ng-template #simplePrice>\r\n            <ng-container *ngIf=\"customSimplePriceTemplate; else fallbackSimplePrice\">\r\n                <ng-container *ngTemplateOutlet=\"customSimplePriceTemplate\"></ng-container>\r\n            </ng-container>\r\n        </ng-template>\r\n        <ng-template #fallbackSimplePrice>\r\n            <del>&nbsp;</del>\r\n            <div class=\"price-simplePrice\">\r\n                {{ price | ecCurrencySymbol }}\r\n            </div>\r\n        </ng-template>\r\n\r\n        <!-- Fallback simple price-del -->\r\n        <ng-template #simplePriceDel>\r\n            <div class=\"price-simpleDel\">\r\n                <del class=\"\">{{ price | ecCurrencySymbol }}</del>\r\n            </div>\r\n        </ng-template>\r\n\r\n        <!-- Fallback simple saleprice -->\r\n        <ng-template #simpleSalePrice>\r\n            <ng-container *ngIf=\"customSimpleSalePriceTemplate; else fallbackSimpleSalePrice\">\r\n                <ng-container *ngTemplateOutlet=\"customSimpleSalePriceTemplate\"></ng-container>\r\n            </ng-container>\r\n        </ng-template>\r\n        <ng-template #fallbackSimpleSalePrice>\r\n            <div class=\"price-simpleSaleprice\">\r\n                {{ saleprice | ecCurrencySymbol }}\r\n            </div>\r\n        </ng-template>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- Sección de impuestos -->\r\n<ng-container *ngIf=\"shouldShowTaxes\">\r\n    <!-- Sólo leyenda -->\r\n    <ng-container *ngIf=\"showTaxLegendOnly; else detailedTaxBlock\">\r\n        <ng-container *ngIf=\"customOnlyTaxLabelTemplate; else defaultOnlyTaxLabel\">\r\n            <ng-container *ngTemplateOutlet=\"customOnlyTaxLabelTemplate\"></ng-container>\r\n        </ng-container>\r\n        <ng-template #defaultOnlyTaxLabel>\r\n            <p class=\"taxes-title\">\r\n                {{ 'price-without-national-taxes' | translate }}:\r\n                {{ basePrice! | ecCurrencySymbol }}\r\n            </p>\r\n        </ng-template>\r\n    </ng-container>\r\n\r\n    <!-- Detalle impuestos -->\r\n    <ng-template #detailedTaxBlock>\r\n        <ng-container *ngIf=\"customTaxTemplate; else defaultTaxBlock\">\r\n            <ng-container *ngTemplateOutlet=\"customTaxTemplate\"></ng-container>\r\n        </ng-container>\r\n    </ng-template>\r\n</ng-container>\r\n\r\n<ng-template #defaultTaxBlock>\r\n    <div class=\"taxes-section\">\r\n        <p class=\"taxes-title\">\r\n            {{ 'price-without-national-taxes' | translate }}:\r\n            {{ basePrice! | ecCurrencySymbol }}\r\n        </p>\r\n        <ul class=\"taxes-list\">\r\n            <li>\r\n                {{ taxes.Name }}: {{ taxeAmount | ecCurrencySymbol }}\r\n            </li>\r\n        </ul>\r\n    </div>\r\n</ng-template>"]}
96
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"price-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/widgets-ec/price-ec/price-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/widgets-ec/price-ec/price-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, OnInit, TemplateRef } from '@angular/core';\r\nimport { EcCurrencySymbolPipe } from \"../../../ec-pipe/ec-currency-symbol.pipe\";\r\nimport { ChannelService } from '../../../ec-services';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { AuthService } from '../../../ec-services';\r\n/**\r\n * Componente para manejar la vista del precio de un producto.\r\n */\r\n@Component({\r\n  selector: 'app-price-ec',\r\n  standalone: true,\r\n  imports: [CommonModule, EcCurrencySymbolPipe, TranslateModule],\r\n  templateUrl: './price-ec.component.html',\r\n  styleUrl: './price-ec.component.scss'\r\n})\r\nexport class PriceEcComponent implements OnInit {\r\n  // Precios\r\n  @Input() price!: string;\r\n  @Input() saleprice?: string;\r\n  @Input() basePrice?: string;\r\n  @Input() taxeAmount?: number;\r\n  @Input() taxes: { Name: string; taxeAmount: number } = { Name: '', taxeAmount: 0 };\r\n\r\n  // Opciones\r\n  @Input() priceSize: boolean = false;\r\n  @Input() showTaxLegendOnly: boolean = false;\r\n  @Input() disableTaxInfo: boolean = false;\r\n\r\n  // Templates personalizados (proyección)\r\n  @Input() customPriceTemplate: TemplateRef<any> | null           = null;\r\n  @Input() customSalePriceTemplate: TemplateRef<any> | null       = null;\r\n  @Input() customSimplePriceTemplate: TemplateRef<any> | null     = null;\r\n  @Input() customSimpleSalePriceTemplate: TemplateRef<any> | null = null;\r\n  @Input() customTaxTemplate: TemplateRef<any> | null             = null;\r\n  @Input() customOnlyTaxLabelTemplate: TemplateRef<any> | null    = null;\r\n\r\n  private _channelService: ChannelService = inject(ChannelService);\r\n  private _authService: AuthService = inject(AuthService);\r\n  public showTaxLegend = false;\r\n  public hideTaxes = false;\r\n  public showPricesOnlyToLoggedUsers = false;\r\n  public logged = false;\r\n\r\n  ngOnInit() {\r\n    this._channelService.channel$.subscribe(cfg => {\r\n      this.showTaxLegend = !!cfg.showTaxLegend;\r\n      this.hideTaxes     = !!cfg.hideTaxes;\r\n      this.showPricesOnlyToLoggedUsers = !!cfg.showPricesOnlyToLoggedUsers;\r\n    });\r\n   this.logged= this._authService.isAuthenticated();\r\n  }\r\n\r\n  /** Determina si mostrar la sección de impuestos */\r\n  get shouldShowTaxes(): boolean {    \r\n    return !this.disableTaxInfo\r\n        && this.showTaxLegend\r\n        && !this.hideTaxes\r\n        && !!this.basePrice\r\n        && !!this.taxeAmount;\r\n  }\r\n\r\n  /** Clase CSS base según tamaño */\r\n  get priceClass(): string {\r\n    return this.priceSize ? 'price-sm' : 'price';\r\n  }\r\n\r\n  /** Helper para detectar rangos */\r\n  hasRange(value?: string): boolean {\r\n    return !!value && value.split(' - ').length === 2;\r\n  }\r\n}\r\n","@if (!showPricesOnlyToLoggedUsers || logged) {\r\n<ng-container *ngIf=\"customSalePriceTemplate || customPriceTemplate; else defaultPriceBlock\">\r\n    <ng-container *ngTemplateOutlet=\"customSalePriceTemplate || customPriceTemplate\">\r\n    </ng-container>\r\n</ng-container>\r\n\r\n<ng-template #defaultPriceBlock>\r\n    <div class=\"price\">\r\n        <!-- Con precio de oferta -->\r\n        <div *ngIf=\"saleprice; else onlyPriceBlock\" class=\"line-height-custom\">\r\n\r\n            <!-- Precio original como rango o tachado simple -->\r\n            <div *ngIf=\"hasRange(price); else simplePriceDel\" class=\"price-whithSaleprice\">\r\n                <del class=\"\">\r\n                    {{\r\n                    price!.split(' - ')[0] | ecCurrencySymbol\r\n                    }}\r\n                    {{\r\n                    price!.split(' - ')[1] | ecCurrencySymbol\r\n                    }}\r\n                </del>\r\n            </div>\r\n\r\n            <!-- Oferta como rango o simple -->\r\n            <div *ngIf=\"hasRange(saleprice); else simpleSalePrice\" class=\"\">\r\n                {{\r\n                saleprice!.split(' - ')[0] | ecCurrencySymbol\r\n                }}\r\n                {{\r\n                saleprice!.split(' - ')[1] | ecCurrencySymbol\r\n                }}\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Sólo precio sin oferta -->\r\n        <ng-template #onlyPriceBlock>\r\n            <div *ngIf=\"hasRange(price); else simplePrice\" class=\"price-onlyPrice\">\r\n                {{\r\n                price!.split(' - ')[0] | ecCurrencySymbol\r\n                }} -\r\n                {{\r\n                price!.split(' - ')[1] | ecCurrencySymbol\r\n                }}\r\n            </div>\r\n        </ng-template>\r\n\r\n        <!-- Fallback simple price -->\r\n        <ng-template #simplePrice>\r\n            <ng-container *ngIf=\"customSimplePriceTemplate; else fallbackSimplePrice\">\r\n                <ng-container *ngTemplateOutlet=\"customSimplePriceTemplate\"></ng-container>\r\n            </ng-container>\r\n        </ng-template>\r\n        <ng-template #fallbackSimplePrice>\r\n            <del>&nbsp;</del>\r\n            <div class=\"price-simplePrice\">\r\n                {{ price | ecCurrencySymbol }}\r\n            </div>\r\n        </ng-template>\r\n\r\n        <!-- Fallback simple price-del -->\r\n        <ng-template #simplePriceDel>\r\n            <div class=\"price-simpleDel\">\r\n                <del class=\"\">{{ price | ecCurrencySymbol }}</del>\r\n            </div>\r\n        </ng-template>\r\n\r\n        <!-- Fallback simple saleprice -->\r\n        <ng-template #simpleSalePrice>\r\n            <ng-container *ngIf=\"customSimpleSalePriceTemplate; else fallbackSimpleSalePrice\">\r\n                <ng-container *ngTemplateOutlet=\"customSimpleSalePriceTemplate\"></ng-container>\r\n            </ng-container>\r\n        </ng-template>\r\n        <ng-template #fallbackSimpleSalePrice>\r\n            <div class=\"price-simpleSaleprice\">\r\n                {{ saleprice | ecCurrencySymbol }}\r\n            </div>\r\n        </ng-template>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- Sección de impuestos -->\r\n<ng-container *ngIf=\"shouldShowTaxes\">\r\n    <!-- Sólo leyenda -->\r\n    <ng-container *ngIf=\"showTaxLegendOnly; else detailedTaxBlock\">\r\n        <ng-container *ngIf=\"customOnlyTaxLabelTemplate; else defaultOnlyTaxLabel\">\r\n            <ng-container *ngTemplateOutlet=\"customOnlyTaxLabelTemplate\"></ng-container>\r\n        </ng-container>\r\n        <ng-template #defaultOnlyTaxLabel>\r\n            <p class=\"taxes-title\">\r\n                {{ 'price-without-national-taxes' | translate }}:\r\n                {{ basePrice! | ecCurrencySymbol }}\r\n            </p>\r\n        </ng-template>\r\n    </ng-container>\r\n\r\n    <!-- Detalle impuestos -->\r\n    <ng-template #detailedTaxBlock>\r\n        <ng-container *ngIf=\"customTaxTemplate; else defaultTaxBlock\">\r\n            <ng-container *ngTemplateOutlet=\"customTaxTemplate\"></ng-container>\r\n        </ng-container>\r\n    </ng-template>\r\n</ng-container>\r\n\r\n<ng-template #defaultTaxBlock>\r\n    <div class=\"taxes-section\">\r\n        <p class=\"taxes-title\">\r\n            {{ 'price-without-national-taxes' | translate }}:\r\n            {{ basePrice! | ecCurrencySymbol }}\r\n        </p>\r\n        <ul class=\"taxes-list\">\r\n            <li>\r\n                {{ taxes.Name }}: {{ taxeAmount | ecCurrencySymbol }}\r\n            </li>\r\n        </ul>\r\n    </div>\r\n</ng-template>\r\n}"]}