ng-easycommerce-v18 0.0.4 → 0.0.5

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.
@@ -38,6 +38,7 @@
38
38
  "blog-right-sidebar": "blog",
39
39
  "branch-delivery": "Retiro en sucursal",
40
40
  "branch_delivery": "Retiro en sucursal",
41
+ "buy": "Comprar",
41
42
  "buy-now": "Comprar ahora",
42
43
  "call-us": "Llamanos",
43
44
  "cancelled": "Cancelado",
@@ -152,6 +153,7 @@
152
153
  "invalid-form": "Aún hay campos sin completar y/o datos no validos",
153
154
  "invalid-value": "El valor ingresado no es válido",
154
155
  "invited-checkout": "Comprar como invitado",
156
+ "keep-shopping": "Seguir comprando",
155
157
  "kids-fashion": "Niños/as",
156
158
  "last-name": "Apellido",
157
159
  "last-name-help1": "El apellido es requerido",
@@ -258,6 +260,7 @@
258
260
  "register": "Solicitar Registro",
259
261
  "register-ok": "Se envió un mail a su casilla de correo para verificar su nueva cuenta",
260
262
  "related-products": "Productos relacionados",
263
+ "remove-coupon": "Eliminar cupon",
261
264
  "repeat-new-password": "Repita nueva contraseña",
262
265
  "repeat-password": "Confirme la contraseña",
263
266
  "repeated-new-password": "Nueva contraseña repetida",
@@ -1,5 +1,5 @@
1
1
  import { Component, inject } from '@angular/core';
2
- import { CartService } from '../../ec-services';
2
+ import { CartService, AuthService } from '../../ec-services';
3
3
  import * as i0 from "@angular/core";
4
4
  export class CartEcComponent {
5
5
  _cartService = inject(CartService);
@@ -8,6 +8,8 @@ export class CartEcComponent {
8
8
  totalPromotionAmount$ = this._cartService.getTotalPromotionAmount();
9
9
  taxesAmount$ = this._cartService.getTaxesAmount();
10
10
  totalAmount$ = this._cartService.getTotalAmount();
11
+ _authService = inject(AuthService);
12
+ isAuthenticated$ = this._authService.isAuthenticated();
11
13
  removeCoupon() {
12
14
  this._cartService.removeCoupon();
13
15
  }
@@ -18,4 +20,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
18
20
  type: Component,
19
21
  args: [{ selector: 'lib-cart-ec', standalone: true, imports: [], template: "<p>cart-ec works!</p>\r\n" }]
20
22
  }] });
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FydC1lYy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lYXN5Y29tbWVyY2UtdjE4L3NyYy9saWIvZWMtY29tcG9uZW50cy9jYXJ0LWVjL2NhcnQtZWMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvY2FydC1lYy9jYXJ0LWVjLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxXQUFXLEVBQWdCLE1BQU0sbUJBQW1CLENBQUM7O0FBVTlELE1BQU0sT0FBTyxlQUFlO0lBQ25CLFlBQVksR0FBZ0IsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBRWpELFVBQVUsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQztJQUMxQyxlQUFlLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO0lBQ3hELHFCQUFxQixHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsdUJBQXVCLEVBQUUsQ0FBQztJQUNwRSxZQUFZLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUNsRCxZQUFZLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUN6RCxZQUFZO1FBQ1gsSUFBSSxDQUFDLFlBQVksQ0FBQyxZQUFZLEVBQUUsQ0FBQTtJQUNqQyxDQUFDO3VHQVZXLGVBQWU7MkZBQWYsZUFBZSx1RUNYNUIsMkJBQ0E7OzJGRFVhLGVBQWU7a0JBUDNCLFNBQVM7K0JBQ0MsYUFBYSxjQUNYLElBQUksV0FDUCxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ2FydFNlcnZpY2UsIFRvYXN0U2VydmljZSB9IGZyb20gJy4uLy4uL2VjLXNlcnZpY2VzJztcclxuaW1wb3J0IHsgQ29yZUNvbnN0YW50c1NlcnZpY2UgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcblx0c2VsZWN0b3I6ICdsaWItY2FydC1lYycsXHJcblx0c3RhbmRhbG9uZTogdHJ1ZSxcclxuXHRpbXBvcnRzOiBbXSxcclxuXHR0ZW1wbGF0ZVVybDogJy4vY2FydC1lYy5jb21wb25lbnQuaHRtbCcsXHJcblx0c3R5bGVVcmw6ICcuL2NhcnQtZWMuY29tcG9uZW50LnNjc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDYXJ0RWNDb21wb25lbnQge1xyXG5cdHByaXZhdGUgX2NhcnRTZXJ2aWNlOiBDYXJ0U2VydmljZSA9IGluamVjdChDYXJ0U2VydmljZSk7XHJcblxyXG5cdHB1YmxpYyBjYXJ0SXRlbXMkID0gdGhpcy5fY2FydFNlcnZpY2UuY2FydEl0ZW1zJDtcclxuXHRwdWJsaWMgc3ViVG90YWxBbW91bnQkID0gdGhpcy5fY2FydFNlcnZpY2UuZ2V0U3ViVG90YWxBbW91bnQoKTtcclxuXHRwdWJsaWMgdG90YWxQcm9tb3Rpb25BbW91bnQkID0gdGhpcy5fY2FydFNlcnZpY2UuZ2V0VG90YWxQcm9tb3Rpb25BbW91bnQoKTtcclxuXHRwdWJsaWMgdGF4ZXNBbW91bnQkID0gdGhpcy5fY2FydFNlcnZpY2UuZ2V0VGF4ZXNBbW91bnQoKTtcclxuXHRwdWJsaWMgdG90YWxBbW91bnQkID0gdGhpcy5fY2FydFNlcnZpY2UuZ2V0VG90YWxBbW91bnQoKTtcclxuXHRyZW1vdmVDb3Vwb24oKXtcclxuXHRcdHRoaXMuX2NhcnRTZXJ2aWNlLnJlbW92ZUNvdXBvbigpXHJcblx0fVxyXG5cclxufVxyXG4iLCI8cD5jYXJ0LWVjIHdvcmtzITwvcD5cclxuIl19
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FydC1lYy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lYXN5Y29tbWVyY2UtdjE4L3NyYy9saWIvZWMtY29tcG9uZW50cy9jYXJ0LWVjL2NhcnQtZWMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvY2FydC1lYy9jYXJ0LWVjLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxXQUFXLEVBQWlCLFdBQVcsRUFBRSxNQUFNLG1CQUFtQixDQUFDOztBQVU1RSxNQUFNLE9BQU8sZUFBZTtJQUduQixZQUFZLEdBQWdCLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUVqRCxVQUFVLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxVQUFVLENBQUM7SUFDMUMsZUFBZSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztJQUN4RCxxQkFBcUIsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLHVCQUF1QixFQUFFLENBQUM7SUFDcEUsWUFBWSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsY0FBYyxFQUFFLENBQUM7SUFDbEQsWUFBWSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsY0FBYyxFQUFFLENBQUM7SUFFakQsWUFBWSxHQUFnQixNQUFNLENBQUMsV0FBVyxDQUFDLENBQUE7SUFFaEQsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxlQUFlLEVBQUUsQ0FBQztJQUU5RCxZQUFZO1FBQ1gsSUFBSSxDQUFDLFlBQVksQ0FBQyxZQUFZLEVBQUUsQ0FBQTtJQUNqQyxDQUFDO3VHQWpCVyxlQUFlOzJGQUFmLGVBQWUsdUVDWDVCLDJCQUNBOzsyRkRVYSxlQUFlO2tCQVAzQixTQUFTOytCQUNDLGFBQWEsY0FDWCxJQUFJLFdBQ1AsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENhcnRTZXJ2aWNlLCBUb2FzdFNlcnZpY2UgLCBBdXRoU2VydmljZSB9IGZyb20gJy4uLy4uL2VjLXNlcnZpY2VzJztcclxuaW1wb3J0IHsgQ29yZUNvbnN0YW50c1NlcnZpY2UgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcblx0c2VsZWN0b3I6ICdsaWItY2FydC1lYycsXHJcblx0c3RhbmRhbG9uZTogdHJ1ZSxcclxuXHRpbXBvcnRzOiBbXSxcclxuXHR0ZW1wbGF0ZVVybDogJy4vY2FydC1lYy5jb21wb25lbnQuaHRtbCcsXHJcblx0c3R5bGVVcmw6ICcuL2NhcnQtZWMuY29tcG9uZW50LnNjc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDYXJ0RWNDb21wb25lbnQge1xyXG5cclxuXHRcclxuXHRwcml2YXRlIF9jYXJ0U2VydmljZTogQ2FydFNlcnZpY2UgPSBpbmplY3QoQ2FydFNlcnZpY2UpO1xyXG5cclxuXHRwdWJsaWMgY2FydEl0ZW1zJCA9IHRoaXMuX2NhcnRTZXJ2aWNlLmNhcnRJdGVtcyQ7XHJcblx0cHVibGljIHN1YlRvdGFsQW1vdW50JCA9IHRoaXMuX2NhcnRTZXJ2aWNlLmdldFN1YlRvdGFsQW1vdW50KCk7XHJcblx0cHVibGljIHRvdGFsUHJvbW90aW9uQW1vdW50JCA9IHRoaXMuX2NhcnRTZXJ2aWNlLmdldFRvdGFsUHJvbW90aW9uQW1vdW50KCk7XHJcblx0cHVibGljIHRheGVzQW1vdW50JCA9IHRoaXMuX2NhcnRTZXJ2aWNlLmdldFRheGVzQW1vdW50KCk7XHJcblx0cHVibGljIHRvdGFsQW1vdW50JCA9IHRoaXMuX2NhcnRTZXJ2aWNlLmdldFRvdGFsQW1vdW50KCk7XHJcblx0XHJcblx0cHJpdmF0ZSBfYXV0aFNlcnZpY2U6IEF1dGhTZXJ2aWNlID0gaW5qZWN0KEF1dGhTZXJ2aWNlKVxyXG5cclxuXHRwdWJsaWMgaXNBdXRoZW50aWNhdGVkJCA9IHRoaXMuX2F1dGhTZXJ2aWNlLmlzQXV0aGVudGljYXRlZCgpO1xyXG5cdFxyXG5cdHJlbW92ZUNvdXBvbigpe1xyXG5cdFx0dGhpcy5fY2FydFNlcnZpY2UucmVtb3ZlQ291cG9uKClcclxuXHR9XHJcblxyXG59XHJcbiIsIjxwPmNhcnQtZWMgd29ya3MhPC9wPlxyXG4iXX0=
@@ -16,6 +16,7 @@ export class CartItemEcComponent {
16
16
  mediaUrl = this._constants.mediaUrl();
17
17
  quantity = 0;
18
18
  variantsToShow = ['TALLE', 'COLOR'];
19
+ updateStock = false;
19
20
  ngOnInit() {
20
21
  this.quantity = this.item.quantity;
21
22
  console.log(this.item, this.mediaUrl);
@@ -80,6 +81,29 @@ export class CartItemEcComponent {
80
81
  return null;
81
82
  }
82
83
  }
84
+ createDiscountMessage(saleprice, price) {
85
+ if (isNaN(saleprice) || isNaN(price) || saleprice >= price || saleprice <= 0 || price <= 0) {
86
+ return '';
87
+ }
88
+ let discountPercentage = Math.round(((price - saleprice) / price) * 100);
89
+ let discountMessage = `${discountPercentage}% OFF`;
90
+ return discountMessage;
91
+ }
92
+ checkStock(product) {
93
+ for (const variant of product.product.variants) {
94
+ if (product.variant_id === variant.code) {
95
+ if (variant.stock === 0) {
96
+ this.updateStock = true;
97
+ return '0';
98
+ }
99
+ else if (product.quantity > variant.stock) {
100
+ this.updateStock = true;
101
+ return variant.stock;
102
+ }
103
+ }
104
+ }
105
+ return false; // Solo se ejecuta si no se cumple la condición
106
+ }
83
107
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: CartItemEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
84
108
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: CartItemEcComponent, isStandalone: true, selector: "app-cart-item-ec", inputs: { item: "item", inSidebar: "inSidebar" }, ngImport: i0, template: "@if(!inSidebar){\r\n<p>cart-item-ec works!</p>\r\n}@else{\r\n\r\n<div class=\"row\">\r\n <div class=\"col-2\">\r\n @let product= item.product;\r\n @if(item.variant_id && product.variants.length>0){\r\n <img [src]=\"mediaUrl + product.variants[0].images[0]\" alt=\"\" class=\"img-fluid\">\r\n }@else{\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"\" class=\"img-fluid\">\r\n }\r\n </div>\r\n <div class=\"col-8\">\r\n <div class=\"info d-flex flex-column align-items-start\">\r\n <a class=\"title text-dark text-decoration-none m-0 p-0 h6 mb-0\"\r\n [routerLink]=\"['/product', item.variant_id]\">{{\r\n item.product.name | titlecase\r\n }}</a>\r\n <div class=\"qty1\">\r\n <span>{{ item.product.id}}</span>\r\n </div>\r\n <div class=\"price h6 fw-bold mb-0 pb-0\">{{ item.product.price | ecCurrencySymbol\r\n }}</div>\r\n @if(getVariants(item); as options){\r\n <div class=\"d-flex align-items-center p-0\">\r\n @for(option of options; track $index){\r\n <span class=\"me-1\"> {{option.name | titlecase}}:</span>\r\n @if(option.name == 'COLOR'){\r\n <div class=\"p-2 rounded\" [style.background]=\"'#' + option.value\"></div>\r\n }@else{\r\n <b>{{option.value}}</b>\r\n }\r\n }\r\n </div>\r\n }\r\n <div class=\"input-group mb-3\">\r\n <button (click)=\"less(item.product.variants[0]?.stock)\" class=\"btn btn-outline-secondary\" type=\"button\" id=\"button-addon1\">\r\n <i class=\"fa fa-minus\" aria-hidden=\"true\"></i>\r\n </button>\r\n <input type=\"text\" class=\"form-control text-center\" placeholder=\"\" aria-label=\"Example text with button addon\"\r\n aria-describedby=\"button-addon1\" [value]=\"item.quantity\" min=\"1\" step=\"1\" [(ngModel)]=\"quantity\"\r\n (change)=\"updateQuantity(item.product.variants[0]?.stock)\">\r\n <button (click)=\"plus(item.product.variants[0]?.stock)\" class=\"btn btn-outline-secondary\" type=\"button\" id=\"button-addon1\">\r\n <i class=\"fa fa-plus\" aria-hidden=\"true\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"col-2\">\r\n <a (click)=\"deleteCartItem()\" class=\"btn botBorrar\"><i class=\"fa fa-trash\" aria-hidden=\"true\"></i></a>\r\n </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n}", styles: [""], dependencies: [{ kind: "pipe", type: TitleCasePipe, name: "titlecase" }, { kind: "pipe", type: EcCurrencySymbolPipe, name: "ecCurrencySymbol" }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
85
109
  }
@@ -94,4 +118,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
94
118
  }], inSidebar: [{
95
119
  type: Input
96
120
  }] } });
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cart-item-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/cart-ec/cart-item-ec/cart-item-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/cart-ec/cart-item-ec/cart-item-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, OnInit } from '@angular/core';\r\nimport { CoreConstantsService } from '../../../constants';\r\nimport { CartService, ToastService } from '../../../ec-services';\r\nimport { TitleCasePipe } from '@angular/common';\r\nimport { EcCurrencySymbolPipe } from '../../../ec-pipe';\r\nimport { RouterLink } from '@angular/router';\r\nimport { FormsModule } from '@angular/forms';\r\n\r\n@Component({\r\n\tselector: 'app-cart-item-ec',\r\n\tstandalone: true,\r\n\timports: [TitleCasePipe, EcCurrencySymbolPipe, RouterLink, FormsModule],\r\n\ttemplateUrl: './cart-item-ec.component.html',\r\n\tstyleUrl: './cart-item-ec.component.scss'\r\n})\r\nexport class CartItemEcComponent implements OnInit {\r\n\t@Input({\r\n\t\trequired: true\r\n\t}) item: any;\r\n\r\n\t@Input() inSidebar: boolean = false;\r\n\r\n\tprivate _cartService: CartService = inject(CartService);\r\n\tprivate _toastService: ToastService = inject(ToastService);\r\n\r\n\tprivate _constants: CoreConstantsService = inject(CoreConstantsService);\r\n\tpublic mediaUrl = this._constants.mediaUrl();\r\n\tpublic quantity = 0;\r\n\tpublic variantsToShow: string[] = ['TALLE', 'COLOR'];\r\n\r\n\tngOnInit() {\r\n\t\tthis.quantity = this.item.quantity\r\n\t\tconsole.log(this.item, this.mediaUrl);\r\n\t}\r\n\r\n\tupdateQuantity(stock: number) {\r\n\t\tif (this.quantity > 0 && this.quantity <= stock) {\r\n\t\t\tthis._cartService.updateItemQuantity(this.item, this.quantity)\r\n\t\t} else {\r\n\t\t\tthis.quantity = this.item.quantity\r\n\t\t\tthis._toastService.show('out-of-stock-actually');\r\n\t\t}\r\n\t}\r\n\r\n\tless(stock: number, value: number = 1) {\r\n\t\tlet quantity = this.item.quantity - value;\r\n\t\tquantity > 0 && quantity <= stock ? this._cartService.updateItemQuantity(this.item, quantity) : this._toastService.show('out-of-stock-actually');\r\n\r\n\t}\r\n\r\n\tplus(stock: number, value: number = 1) {\r\n\t\tlet quantity = this.item.quantity + value;\r\n\t\tquantity > 0 && quantity <= stock ? this._cartService.updateItemQuantity(this.item, quantity) : this._toastService.show('out-of-stock-actually');\r\n\t}\r\n\r\n\tdeleteCartItem(){\r\n\t\tthis._cartService.deleteCartItem(this.item)\r\n\t}\r\n\r\n\tgetVariants(product: any):any {\r\n\t\tlet item = product.product\r\n\r\n        if (item.variants && item.variants.length && item.variants[0].options && item.variants[0].options.length) {\r\n            let options = item.variants[0].options\r\n            options = options.filter((option:any) => this.variantsToShow.find((name:any) => option.hasOwnProperty(name)))\r\n            let optionsMap:any = []\r\n            options.map((option:any) => {\r\n                Object.keys(option).forEach((entry) => {\r\n                    let optionAdded = false;  // Variable para evitar múltiples inserciones\r\n\r\n                    item.options.forEach((option2:any) => {\r\n                        if (option2.code == 'COLOR') {\r\n                            option2.values.forEach((color:any) => {\r\n                                if (color.code == option[entry] && !optionAdded) {\r\n                                    optionsMap.push({ name: entry, value: option[entry], image: color.image, mobileImage: color.mobileImage });\r\n                                    optionAdded = true; // Marcar opción agregada\r\n                                }\r\n                            });\r\n                        }\r\n                    });\r\n                    // Si no se añadió la opción de COLOR, manejar otras opciones\r\n                    if (!optionAdded) {\r\n                        item.options.forEach((option2:any) => {\r\n\r\n                            if (option2.code !== 'COLOR') {\r\n                                optionsMap.push({\r\n                                    name: entry,\r\n                                    value: option[entry]\r\n\r\n                                });\r\n                                optionAdded = true;\r\n                            }\r\n                        });\r\n                    }\r\n                });\r\n                return optionsMap;\r\n            });\r\n\r\n            return optionsMap;\r\n\r\n        } else {\r\n            return null\r\n        }\r\n\t}\r\n\r\n}\r\n","@if(!inSidebar){\r\n<p>cart-item-ec works!</p>\r\n}@else{\r\n\r\n<div class=\"row\">\r\n    <div class=\"col-2\">\r\n        @let product= item.product;\r\n        @if(item.variant_id && product.variants.length>0){\r\n            <img [src]=\"mediaUrl +  product.variants[0].images[0]\" alt=\"\" class=\"img-fluid\">\r\n        }@else{\r\n            <img [src]=\"mediaUrl +  product.picturesdefault[0]\" alt=\"\" class=\"img-fluid\">\r\n        }\r\n    </div>\r\n    <div class=\"col-8\">\r\n        <div class=\"info d-flex flex-column align-items-start\">\r\n            <a class=\"title text-dark text-decoration-none m-0 p-0 h6 mb-0\"\r\n                [routerLink]=\"['/product', item.variant_id]\">{{\r\n                item.product.name | titlecase\r\n                }}</a>\r\n            <div class=\"qty1\">\r\n                <span>{{ item.product.id}}</span>\r\n            </div>\r\n            <div class=\"price h6 fw-bold mb-0 pb-0\">{{ item.product.price | ecCurrencySymbol\r\n                }}</div>\r\n             @if(getVariants(item); as options){\r\n                <div class=\"d-flex align-items-center p-0\">\r\n                    @for(option of options; track $index){\r\n                        <span class=\"me-1\"> {{option.name | titlecase}}:</span>\r\n                        @if(option.name == 'COLOR'){\r\n                            <div class=\"p-2 rounded\" [style.background]=\"'#' + option.value\"></div>\r\n                        }@else{\r\n                            <b>{{option.value}}</b>\r\n                        }\r\n                    }\r\n                </div>\r\n            }\r\n            <div class=\"input-group mb-3\">\r\n                <button (click)=\"less(item.product.variants[0]?.stock)\" class=\"btn btn-outline-secondary\" type=\"button\" id=\"button-addon1\">\r\n                    <i class=\"fa fa-minus\" aria-hidden=\"true\"></i>\r\n                </button>\r\n                <input type=\"text\" class=\"form-control text-center\" placeholder=\"\" aria-label=\"Example text with button addon\"\r\n                    aria-describedby=\"button-addon1\" [value]=\"item.quantity\" min=\"1\" step=\"1\" [(ngModel)]=\"quantity\"\r\n                    (change)=\"updateQuantity(item.product.variants[0]?.stock)\">\r\n                <button (click)=\"plus(item.product.variants[0]?.stock)\" class=\"btn btn-outline-secondary\" type=\"button\" id=\"button-addon1\">\r\n                    <i class=\"fa fa-plus\" aria-hidden=\"true\"></i>\r\n                </button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"col-2\">\r\n        <a (click)=\"deleteCartItem()\" class=\"btn botBorrar\"><i class=\"fa fa-trash\" aria-hidden=\"true\"></i></a>\r\n    </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n}"]}
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cart-item-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/cart-ec/cart-item-ec/cart-item-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/cart-ec/cart-item-ec/cart-item-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, OnInit } from '@angular/core';\r\nimport { CoreConstantsService } from '../../../constants';\r\nimport { CartService, ToastService } from '../../../ec-services';\r\nimport { TitleCasePipe } from '@angular/common';\r\nimport { EcCurrencySymbolPipe } from '../../../ec-pipe';\r\nimport { RouterLink } from '@angular/router';\r\nimport { FormsModule } from '@angular/forms';\r\n\r\n@Component({\r\n\tselector: 'app-cart-item-ec',\r\n\tstandalone: true,\r\n\timports: [TitleCasePipe, EcCurrencySymbolPipe, RouterLink, FormsModule],\r\n\ttemplateUrl: './cart-item-ec.component.html',\r\n\tstyleUrl: './cart-item-ec.component.scss'\r\n})\r\nexport class CartItemEcComponent implements OnInit {\r\n\t@Input({\r\n\t\trequired: true\r\n\t}) item: any;\r\n\r\n\t@Input() inSidebar: boolean = false;\r\n\r\n\tprivate _cartService: CartService = inject(CartService);\r\n\tprivate _toastService: ToastService = inject(ToastService);\r\n\tprivate _constants: CoreConstantsService = inject(CoreConstantsService);\r\n\r\n\tpublic mediaUrl = this._constants.mediaUrl();\r\n\tpublic quantity = 0;\r\n\tpublic variantsToShow: string[] = ['TALLE', 'COLOR'];\r\n\tpublic updateStock: boolean = false;\r\n\t\r\n\tngOnInit() {\r\n\t\tthis.quantity = this.item.quantity\r\n\t\tconsole.log(this.item, this.mediaUrl);\r\n\t}\r\n\r\n\tupdateQuantity(stock: number) {\r\n\t\tif (this.quantity > 0 && this.quantity <= stock) {\r\n\t\t\tthis._cartService.updateItemQuantity(this.item, this.quantity)\r\n\t\t} else {\r\n\t\t\tthis.quantity = this.item.quantity\r\n\t\t\tthis._toastService.show('out-of-stock-actually');\r\n\t\t}\r\n\t}\r\n\r\n\tless(stock: number, value: number = 1) {\r\n\t\tlet quantity = this.item.quantity - value;\r\n\t\tquantity > 0 && quantity <= stock ? this._cartService.updateItemQuantity(this.item, quantity) : this._toastService.show('out-of-stock-actually');\r\n\r\n\t}\r\n\r\n\tplus(stock: number, value: number = 1) {\r\n\t\tlet quantity = this.item.quantity + value;\r\n\t\tquantity > 0 && quantity <= stock ? this._cartService.updateItemQuantity(this.item, quantity) : this._toastService.show('out-of-stock-actually');\r\n\t}\r\n\r\n\tdeleteCartItem(){\r\n\t\tthis._cartService.deleteCartItem(this.item)\r\n\t}\r\n\r\n\tgetVariants(product: any):any {\r\n\t\tlet item = product.product\r\n\r\n        if (item.variants && item.variants.length && item.variants[0].options && item.variants[0].options.length) {\r\n            let options = item.variants[0].options\r\n            options = options.filter((option:any) => this.variantsToShow.find((name:any) => option.hasOwnProperty(name)))\r\n            let optionsMap:any = []\r\n            options.map((option:any) => {\r\n                Object.keys(option).forEach((entry) => {\r\n                    let optionAdded = false;  // Variable para evitar múltiples inserciones\r\n\r\n                    item.options.forEach((option2:any) => {\r\n                        if (option2.code == 'COLOR') {\r\n                            option2.values.forEach((color:any) => {\r\n                                if (color.code == option[entry] && !optionAdded) {\r\n                                    optionsMap.push({ name: entry, value: option[entry], image: color.image, mobileImage: color.mobileImage });\r\n                                    optionAdded = true; // Marcar opción agregada\r\n                                }\r\n                            });\r\n                        }\r\n                    });\r\n                    // Si no se añadió la opción de COLOR, manejar otras opciones\r\n                    if (!optionAdded) {\r\n                        item.options.forEach((option2:any) => {\r\n\r\n                            if (option2.code !== 'COLOR') {\r\n                                optionsMap.push({\r\n                                    name: entry,\r\n                                    value: option[entry]\r\n\r\n                                });\r\n                                optionAdded = true;\r\n                            }\r\n                        });\r\n                    }\r\n                });\r\n                return optionsMap;\r\n            });\r\n\r\n            return optionsMap;\r\n\r\n        } else {\r\n            return null\r\n        }\r\n\t}\r\n\r\n\tcreateDiscountMessage(saleprice: number, price: number): string {\r\n\t\tif (isNaN(saleprice) || isNaN(price) || saleprice >= price || saleprice <= 0 || price <= 0) {\r\n\t\t\t return '';\r\n\t\t}\r\n\t\r\n\t\tlet discountPercentage = Math.round(((price - saleprice) / price) * 100);\r\n\t\r\n\t\tlet discountMessage = `${discountPercentage}% OFF`;\r\n\t\treturn discountMessage;\r\n\t}\r\n\r\n\tcheckStock(product:any):any {\r\n        for (const variant of product.product.variants) {\r\n          if (product.variant_id === variant.code) {\r\n            if(variant.stock === 0){\r\n                this.updateStock=true;\r\n                return '0';\r\n            }else if (product.quantity > variant.stock) {\r\n                this.updateStock=true;\r\n              return variant.stock;\r\n            }\r\n          }\r\n        }\r\n        return false; // Solo se ejecuta si no se cumple la condición\r\n      }\r\n}\r\n","@if(!inSidebar){\r\n<p>cart-item-ec works!</p>\r\n}@else{\r\n\r\n<div class=\"row\">\r\n    <div class=\"col-2\">\r\n        @let product= item.product;\r\n        @if(item.variant_id && product.variants.length>0){\r\n            <img [src]=\"mediaUrl +  product.variants[0].images[0]\" alt=\"\" class=\"img-fluid\">\r\n        }@else{\r\n            <img [src]=\"mediaUrl +  product.picturesdefault[0]\" alt=\"\" class=\"img-fluid\">\r\n        }\r\n    </div>\r\n    <div class=\"col-8\">\r\n        <div class=\"info d-flex flex-column align-items-start\">\r\n            <a class=\"title text-dark text-decoration-none m-0 p-0 h6 mb-0\"\r\n                [routerLink]=\"['/product', item.variant_id]\">{{\r\n                item.product.name | titlecase\r\n                }}</a>\r\n            <div class=\"qty1\">\r\n                <span>{{ item.product.id}}</span>\r\n            </div>\r\n            <div class=\"price h6 fw-bold mb-0 pb-0\">{{ item.product.price | ecCurrencySymbol\r\n                }}</div>\r\n             @if(getVariants(item); as options){\r\n                <div class=\"d-flex align-items-center p-0\">\r\n                    @for(option of options; track $index){\r\n                        <span class=\"me-1\"> {{option.name | titlecase}}:</span>\r\n                        @if(option.name == 'COLOR'){\r\n                            <div class=\"p-2 rounded\" [style.background]=\"'#' + option.value\"></div>\r\n                        }@else{\r\n                            <b>{{option.value}}</b>\r\n                        }\r\n                    }\r\n                </div>\r\n            }\r\n            <div class=\"input-group mb-3\">\r\n                <button (click)=\"less(item.product.variants[0]?.stock)\" class=\"btn btn-outline-secondary\" type=\"button\" id=\"button-addon1\">\r\n                    <i class=\"fa fa-minus\" aria-hidden=\"true\"></i>\r\n                </button>\r\n                <input type=\"text\" class=\"form-control text-center\" placeholder=\"\" aria-label=\"Example text with button addon\"\r\n                    aria-describedby=\"button-addon1\" [value]=\"item.quantity\" min=\"1\" step=\"1\" [(ngModel)]=\"quantity\"\r\n                    (change)=\"updateQuantity(item.product.variants[0]?.stock)\">\r\n                <button (click)=\"plus(item.product.variants[0]?.stock)\" class=\"btn btn-outline-secondary\" type=\"button\" id=\"button-addon1\">\r\n                    <i class=\"fa fa-plus\" aria-hidden=\"true\"></i>\r\n                </button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"col-2\">\r\n        <a (click)=\"deleteCartItem()\" class=\"btn botBorrar\"><i class=\"fa fa-trash\" aria-hidden=\"true\"></i></a>\r\n    </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n}"]}
@@ -1,4 +1,4 @@
1
- import { Component, inject, Input } from '@angular/core';
1
+ import { Component, inject, Input, ViewChild } from '@angular/core';
2
2
  import { FiltersService } from '../../ec-services';
3
3
  import { PriceRangeFilter } from '../../classes/filters/PriceRangeFilter';
4
4
  import * as i0 from "@angular/core";
@@ -7,9 +7,12 @@ export class FiltersEcComponent {
7
7
  filters = [];
8
8
  filter$ = this._filtersService.filters$;
9
9
  setSelect;
10
+ rangeMinRef;
11
+ rangeMaxRef;
12
+ priceGapPercentage = 0.1;
10
13
  constructor() {
11
14
  this.filter$.subscribe(res => {
12
- this.filters = this._filtersService.getSpecificFilters(['attributes', 'categories', 'dynamics']);
15
+ this.filters = this._filtersService.getSpecificFilters(['attributes', 'categories', 'price_range', 'dynamics']);
13
16
  });
14
17
  }
15
18
  getSpecificFilter(type) {
@@ -35,6 +38,12 @@ export class FiltersEcComponent {
35
38
  * - Mínimo: redondea hacia abajo.
36
39
  * - Máximo: redondea hacia arriba.
37
40
  */
41
+ onRangeChange(event, type, filter) {
42
+ const input = event.target;
43
+ let value = parseInt(input.value, 10);
44
+ value = this.roundToNearest(value, 5, type, filter);
45
+ this.updateFilterPrices(type, value, filter, this.priceGapPercentage);
46
+ }
38
47
  roundToNearest(value, step, type, filter) {
39
48
  let rounded = Math.round(value / step) * step;
40
49
  if (type === 'max' && rounded < filter.maxPrice) {
@@ -118,12 +127,18 @@ export class FiltersEcComponent {
118
127
  return true;
119
128
  };
120
129
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: FiltersEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
121
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: FiltersEcComponent, isStandalone: true, selector: "lib-filters-ec", inputs: { setSelect: "setSelect" }, ngImport: i0, template: "<p>filters-ec works!</p>\r\n", styles: [""] });
130
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: FiltersEcComponent, isStandalone: true, selector: "lib-filters-ec", inputs: { setSelect: "setSelect" }, viewQueries: [{ propertyName: "rangeMinRef", first: true, predicate: ["rangeMin"], descendants: true }, { propertyName: "rangeMaxRef", first: true, predicate: ["rangeMax"], descendants: true }], ngImport: i0, template: "<p>filters-ec works!</p>\r\n", styles: [""] });
122
131
  }
123
132
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: FiltersEcComponent, decorators: [{
124
133
  type: Component,
125
134
  args: [{ selector: 'lib-filters-ec', standalone: true, imports: [], template: "<p>filters-ec works!</p>\r\n" }]
126
135
  }], ctorParameters: () => [], propDecorators: { setSelect: [{
127
136
  type: Input
137
+ }], rangeMinRef: [{
138
+ type: ViewChild,
139
+ args: ['rangeMin']
140
+ }], rangeMaxRef: [{
141
+ type: ViewChild,
142
+ args: ['rangeMax']
128
143
  }] } });
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filters-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input } from '@angular/core';\r\nimport { FiltersService } from '../../ec-services';\r\nimport { Filter } from '../../classes';\r\nimport { FilterElement, FilterType } from '../../interfaces';\r\nimport { PriceRangeFilter } from '../../classes/filters/PriceRangeFilter';\r\n\r\n@Component({\r\n\tselector: 'lib-filters-ec',\r\n\tstandalone: true,\r\n\timports: [],\r\n\ttemplateUrl: './filters-ec.component.html',\r\n\tstyleUrl: './filters-ec.component.scss'\r\n})\r\nexport class FiltersEcComponent {\r\n\tprivate _filtersService: FiltersService = inject(FiltersService);\r\n\tpublic filters: Filter[] = [];\r\n\tpublic filter$ = this._filtersService.filters$;\r\n\t@Input() setSelect: any;\r\n\tconstructor() {\r\n\t\tthis.filter$.subscribe(res => {\r\n\t\t\tthis.filters = this._filtersService.getSpecificFilters(['attributes', 'categories', 'dynamics'])\r\n\t\t})\r\n\t}\r\n\r\n\tgetSpecificFilter(type: FilterType): Filter | null {\r\n\t\tconst filter = this.filters.find(filter => filter.type() === type)\r\n\t\treturn filter || null;\r\n\t}\r\n\r\n\t/*Obtiene el filtro elegido en el select, lo pasa al setSelect\r\n\tpara que se marque seleccionado*/\r\n\tonSelect(event: any, filter: FilterElement[] | null) {\r\n\t\tconsole.log(filter)\r\n\t\t/*  const selectedOption = filter\r\n\t\t\t .flatMap(category => category.children)\r\n\t\t\t .filter(option => option?.code === event.target.value)\r\n\t\t\t .pop()\r\n\t\t selectedOption && this._filtersService.setFilterSelected(this.filters[0], selectedOption) */\r\n\t}\r\n\r\n\tsetSelected(filter: Filter | null, selected: FilterElement) {\r\n\t\tconsole.log(\"set\", filter);\r\n\t\tfilter && this._filtersService.setFilterSelected(filter, selected)\r\n\t}\r\n\r\n\t/**\r\n\t* Redondea al múltiplo de 'step' respetando el redondeo entero:\r\n\t* - Mínimo: redondea hacia abajo.\r\n\t* - Máximo: redondea hacia arriba.\r\n\t*/\r\n\r\n\troundToNearest(value: number, step: number, type: 'min' | 'max', filter: any): number {\r\n\t\tlet rounded = Math.round(value / step) * step;\r\n\t\tif (type === 'max' && rounded < filter.maxPrice) {\r\n\t\t\trounded = Math.ceil(value / step) * step;\r\n\t\t}\r\n\t\tif (type === 'min' && rounded > filter.minPrice) {\r\n\t\t\trounded = Math.floor(value / step) * step;\r\n\t\t}\r\n\t\treturn rounded;\r\n\t}\r\n\tuniqueSelection(filter: { data: any[]; }, filterChild: any) {\r\n        // Buscar si hay un filtro de tipo PriceRangeFilter en la lista de filtros\r\n        const priceRangeFilter = this.filters.find(f => f instanceof PriceRangeFilter);\r\n\r\n        if (priceRangeFilter) {\r\n            priceRangeFilter.reset();\r\n        }\r\n        filter.data.forEach(filterElement => {\r\n            if (filterElement.selected) {\r\n                filterElement.selected = false;\r\n            }\r\n\t\t\tfilterElement.children.forEach((filterChildren: FilterElement) => {\r\n                if (filterChildren != filterChild && filterChildren.selected) {\r\n                    filterChildren.selected = false;\r\n                }\r\n            });\r\n        });\r\n    }\r\n\r\n\t/**\r\n   * Actualiza los valores del filtro permitiendo que un input empuje al otro.\r\n  */\r\n\tupdateFilterPrices(type: 'min' | 'max', value: number, filter: any, priceGap: number) {\r\n\t\tconst globalMin = filter.minPrice ?? 0;\r\n\t\tconst globalMax = filter.maxPrice;\r\n\r\n\t\tlet currentMin = filter.currentMinPrice ?? globalMin;\r\n\t\tlet currentMax = filter.currentMaxPrice ?? globalMax;\r\n\r\n\t\tif (type === 'min') {\r\n\t\t\tlet newMin = Math.min(Math.max(value, globalMin), globalMax);\r\n\t\t\tif (newMin + priceGap > currentMax) {\r\n\t\t\t\tlet newMaxCandidate = newMin + priceGap;\r\n\t\t\t\tif (newMaxCandidate <= globalMax) {\r\n\t\t\t\t\tcurrentMax = newMaxCandidate;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tnewMin = globalMax - priceGap;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tfilter.currentMinPrice = newMin;\r\n\t\t\tfilter.currentMaxPrice = currentMax;\r\n\t\t} else if (type === 'max') {\r\n\t\t\tlet newMax = Math.max(Math.min(value, globalMax), globalMin);\r\n\t\t\tif (newMax - priceGap < currentMin) {\r\n\t\t\t\tlet newMinCandidate = newMax - priceGap;\r\n\t\t\t\tif (newMinCandidate >= globalMin) {\r\n\t\t\t\t\tcurrentMin = newMinCandidate;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tnewMax = globalMin + priceGap;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tfilter.currentMaxPrice = newMax;\r\n\t\t\tfilter.currentMinPrice = currentMin;\r\n\t\t}\r\n\t}\r\n\t// Método para actualizar los valores de precio seleccionados\r\n\tupdatePriceRange(min: number, max: number, priceFilter: PriceRangeFilter) {\r\n\t\tpriceFilter.setSelected(min, max);\r\n\t\tthis.setSelect(priceFilter);\r\n\t}\r\n\r\n\t// Métodos para actualizar la barra del filtro por precio\r\n\tcalculateLeftPercentage(currentMinPrice: number, minPrice: number, maxPrice: number): number {\r\n\t\tconst minVal = Math.max(minPrice, Math.min(currentMinPrice ?? minPrice, maxPrice));\r\n\t\treturn Math.max(0, Math.min(((minVal - minPrice) / (maxPrice - minPrice)) * 100, 100));\r\n\t}\r\n\r\n\tcalculateRightPercentage(currentMaxPrice: number, minPrice: number, maxPrice: number): number {\r\n\t\tconst maxVal = Math.max(minPrice, Math.min(currentMaxPrice ?? maxPrice, maxPrice));\r\n\t\treturn Math.max(0, Math.min(100 - ((maxVal - minPrice) / (maxPrice - minPrice)) * 100, 100));\r\n\t}\r\n\r\n\tscrollUp = () => {\r\n        window.scroll(0, 0);\r\n        return true\r\n    }\r\n\t\r\n}\r\n","<p>filters-ec works!</p>\r\n"]}
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filters-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, ElementRef , ViewChild } from '@angular/core';\r\nimport { FiltersService } from '../../ec-services';\r\nimport { Filter } from '../../classes';\r\nimport { FilterElement, FilterType } from '../../interfaces';\r\nimport { PriceRangeFilter } from '../../classes/filters/PriceRangeFilter';\r\n\r\n@Component({\r\n\tselector: 'lib-filters-ec',\r\n\tstandalone: true,\r\n\timports: [],\r\n\ttemplateUrl: './filters-ec.component.html',\r\n\tstyleUrl: './filters-ec.component.scss'\r\n})\r\nexport class FiltersEcComponent {\r\n\tprivate _filtersService: FiltersService = inject(FiltersService);\r\n\tpublic filters: Filter[] = [];\r\n\tpublic filter$ = this._filtersService.filters$;\r\n\t@Input() setSelect: any;\r\n\r\n\t@ViewChild('rangeMin') rangeMinRef!: ElementRef;\r\n\t@ViewChild('rangeMax') rangeMaxRef!: ElementRef;\r\n\r\n\tpriceGapPercentage = 0.1;\r\n\r\n\r\n\tconstructor() {\r\n\t\tthis.filter$.subscribe(res => {\r\n\t\t\tthis.filters = this._filtersService.getSpecificFilters(['attributes', 'categories', 'price_range', 'dynamics'])\r\n\t\t})\r\n\t}\r\n\r\n\tgetSpecificFilter(type: FilterType): Filter | null {\r\n\t\tconst filter = this.filters.find(filter => filter.type() === type)\r\n\t\treturn filter || null;\r\n\t}\r\n\r\n\t/*Obtiene el filtro elegido en el select, lo pasa al setSelect\r\n\tpara que se marque seleccionado*/\r\n\tonSelect(event: any, filter: FilterElement[] | null) {\r\n\t\tconsole.log(filter)\r\n\t\t/*  const selectedOption = filter\r\n\t\t\t .flatMap(category => category.children)\r\n\t\t\t .filter(option => option?.code === event.target.value)\r\n\t\t\t .pop()\r\n\t\t selectedOption && this._filtersService.setFilterSelected(this.filters[0], selectedOption) */\r\n\t}\r\n\r\n\tsetSelected(filter: Filter | null, selected: FilterElement) {\r\n\t\tconsole.log(\"set\", filter);\r\n\t\tfilter && this._filtersService.setFilterSelected(filter, selected)\r\n\t}\r\n\r\n\t/**\r\n\t* Redondea al múltiplo de 'step' respetando el redondeo entero:\r\n\t* - Mínimo: redondea hacia abajo.\r\n\t* - Máximo: redondea hacia arriba.\r\n\t*/\r\n\tonRangeChange(event: Event, type: 'min' | 'max', filter: { minPrice: number; maxPrice: number; currentMinPrice?: number; currentMaxPrice?: number }) {\r\n\t\tconst input = event.target as HTMLInputElement;\r\n\t\tlet value = parseInt(input.value, 10);\r\n\t\tvalue = this.roundToNearest(value, 5, type, filter);\r\n\r\n\t\tthis.updateFilterPrices(type, value, filter, this.priceGapPercentage);\r\n\t}\r\n\r\n\troundToNearest(value: number, step: number, type: 'min' | 'max', filter: any): number {\r\n\t\tlet rounded = Math.round(value / step) * step;\r\n\t\tif (type === 'max' && rounded < filter.maxPrice) {\r\n\t\t\trounded = Math.ceil(value / step) * step;\r\n\t\t}\r\n\t\tif (type === 'min' && rounded > filter.minPrice) {\r\n\t\t\trounded = Math.floor(value / step) * step;\r\n\t\t}\r\n\t\treturn rounded;\r\n\t}\r\n\tuniqueSelection(filter: { data: any[]; }, filterChild: any) {\r\n\t\t// Buscar si hay un filtro de tipo PriceRangeFilter en la lista de filtros\r\n\t\tconst priceRangeFilter = this.filters.find(f => f instanceof PriceRangeFilter);\r\n\r\n\t\tif (priceRangeFilter) {\r\n\t\t\tpriceRangeFilter.reset();\r\n\t\t}\r\n\t\tfilter.data.forEach(filterElement => {\r\n\t\t\tif (filterElement.selected) {\r\n\t\t\t\tfilterElement.selected = false;\r\n\t\t\t}\r\n\t\t\tfilterElement.children.forEach((filterChildren: FilterElement) => {\r\n\t\t\t\tif (filterChildren != filterChild && filterChildren.selected) {\r\n\t\t\t\t\tfilterChildren.selected = false;\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t});\r\n\t}\r\n\r\n\t/**\r\n   * Actualiza los valores del filtro permitiendo que un input empuje al otro.\r\n  */\r\n\tupdateFilterPrices(type: 'min' | 'max', value: number, filter: any, priceGap: number) {\r\n\t\tconst globalMin = filter.minPrice ?? 0;\r\n\t\tconst globalMax = filter.maxPrice;\r\n\r\n\t\tlet currentMin = filter.currentMinPrice ?? globalMin;\r\n\t\tlet currentMax = filter.currentMaxPrice ?? globalMax;\r\n\r\n\t\tif (type === 'min') {\r\n\t\t\tlet newMin = Math.min(Math.max(value, globalMin), globalMax);\r\n\t\t\tif (newMin + priceGap > currentMax) {\r\n\t\t\t\tlet newMaxCandidate = newMin + priceGap;\r\n\t\t\t\tif (newMaxCandidate <= globalMax) {\r\n\t\t\t\t\tcurrentMax = newMaxCandidate;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tnewMin = globalMax - priceGap;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tfilter.currentMinPrice = newMin;\r\n\t\t\tfilter.currentMaxPrice = currentMax;\r\n\t\t} else if (type === 'max') {\r\n\t\t\tlet newMax = Math.max(Math.min(value, globalMax), globalMin);\r\n\t\t\tif (newMax - priceGap < currentMin) {\r\n\t\t\t\tlet newMinCandidate = newMax - priceGap;\r\n\t\t\t\tif (newMinCandidate >= globalMin) {\r\n\t\t\t\t\tcurrentMin = newMinCandidate;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tnewMax = globalMin + priceGap;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tfilter.currentMaxPrice = newMax;\r\n\t\t\tfilter.currentMinPrice = currentMin;\r\n\t\t}\r\n\t}\r\n\t// Método para actualizar los valores de precio seleccionados\r\n\tupdatePriceRange(min: number, max: number, priceFilter: PriceRangeFilter) {\r\n\t\tpriceFilter.setSelected(min, max);\r\n\t\tthis.setSelect(priceFilter);\r\n\t}\r\n\r\n\t// Métodos para actualizar la barra del filtro por precio\r\n\tcalculateLeftPercentage(currentMinPrice: number, minPrice: number, maxPrice: number): number {\r\n\t\tconst minVal = Math.max(minPrice, Math.min(currentMinPrice ?? minPrice, maxPrice));\r\n\t\treturn Math.max(0, Math.min(((minVal - minPrice) / (maxPrice - minPrice)) * 100, 100));\r\n\t}\r\n\r\n\tcalculateRightPercentage(currentMaxPrice: number, minPrice: number, maxPrice: number): number {\r\n\t\tconst maxVal = Math.max(minPrice, Math.min(currentMaxPrice ?? maxPrice, maxPrice));\r\n\t\treturn Math.max(0, Math.min(100 - ((maxVal - minPrice) / (maxPrice - minPrice)) * 100, 100));\r\n\t}\r\n\r\n\tscrollUp = () => {\r\n\t\twindow.scroll(0, 0);\r\n\t\treturn true\r\n\t}\r\n\t\r\n}\r\n","<p>filters-ec works!</p>\r\n"]}
@@ -28,6 +28,8 @@ export class ProductDetailEcComponent {
28
28
  code = '';
29
29
  showFormContact = false;
30
30
  showReviews = false;
31
+ reset = false;
32
+ success = false;
31
33
  quantity = signal(1);
32
34
  parameters$ = this.parametersService.getParameters();
33
35
  hasParams = this.parametersService.hasParams;
@@ -100,6 +102,10 @@ export class ProductDetailEcComponent {
100
102
  }
101
103
  }, 500);
102
104
  }
105
+ resetForm = () => {
106
+ this.reset = !this.reset;
107
+ this.success = true;
108
+ };
103
109
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: ProductDetailEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
104
110
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: ProductDetailEcComponent, isStandalone: true, selector: "app-product-detail-ec", ngImport: i0, template: "", styles: [""] });
105
111
  }
@@ -107,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
107
113
  type: Component,
108
114
  args: [{ selector: 'app-product-detail-ec', standalone: true, imports: [], template: "" }]
109
115
  }], ctorParameters: () => [] });
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-detail-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-detail-ec/product-detail-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-detail-ec/product-detail-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { computed , Injector} from '@angular/core';\r\nimport { ParametersService, ChannelService } from '../../ec-services';\r\nimport {  Parameter } from '../../interfaces';\r\nimport { Component, inject, WritableSignal, signal, PLATFORM_ID, Inject } from '@angular/core';\r\nimport { Location } from '@angular/common';\r\nimport { Meta, Title } from '@angular/platform-browser';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { ProductDetailService, ProductsService, ToastService } from '../../ec-services';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { Observable } from 'rxjs';\r\nimport { Product } from '../../interfaces';\r\nimport * as he from 'he';\r\n\r\n\r\n\r\n@Component({\r\n  selector: 'app-product-detail-ec',\r\n  standalone: true,\r\n  imports: [],\r\n  templateUrl: './product-detail-ec.component.html',\r\n  styleUrls: ['./product-detail-ec.component.scss']\r\n})\r\nexport class ProductDetailEcComponent {\r\n\tprivate _productDetailService: ProductDetailService = inject(ProductDetailService);\r\n\tprivate _productService: ProductsService = inject(ProductsService);\r\n\tprivate _activedRoute: ActivatedRoute = inject(ActivatedRoute);\r\n\tprivate _domSanitizer: DomSanitizer = inject(DomSanitizer);\r\n\tprivate _consts: CoreConstantsService = inject(CoreConstantsService);\r\n\tprivate _toastService: ToastService = inject(ToastService);\r\n\tprivate parametersService = inject(ParametersService);\r\n\tpublic injector: Injector = inject(Injector);\r\n\tprivate _meta: Meta = inject(Meta);\r\n\tprivate _title: Title = inject(Title);\r\n\tprivate _location: Location = inject(Location);\r\n\tpublic product$: Observable<Product | null> = this._productDetailService.product$;\r\n\tpublic options$: Observable<any> = this._productDetailService.options$;\r\n\tpublic data$: Observable<any> = this._productDetailService.associatedData$;\r\n\r\n\tpublic mediaUrl = this._consts.mediaUrl();\r\n\tpublic code: string = '';\r\n\tpublic showFormContact = false;\r\n\tpublic showReviews: boolean = false;\r\n\t\r\n\r\n\tpublic quantity: WritableSignal<number> = signal(1);\r\n\tpublic parameters$: Observable<Parameter[] | null> = this.parametersService.getParameters();\r\n\tpublic hasParams = this.parametersService.hasParams\r\n\r\n\tconstructor() {\r\n\t\tthis._activedRoute.params.subscribe(queryParams => {\r\n\t\t\tthis.code = queryParams[\"id\"];\r\n\t\t\tthis._productDetailService.loadProduct(this.code);\r\n\t\t  });\r\n\t\tthis._activedRoute.params.subscribe(queryParams => {\r\n\t\t\tthis.code = queryParams[\"id\"];\r\n\t\t\tthis._productDetailService.loadProduct(this.code);\r\n\t\t})\r\n\t\t this.injector.get(ChannelService).channel$.subscribe(channel => {\r\n           this.showReviews = channel.showReviews;\r\n     });\r\n\t}\r\n\r\n  ngOnInit() {\r\n    this.product$.subscribe(product => {\r\n      if (product) {\r\n        this.updateMetaTags(product);\r\n      }\r\n    });\r\n  }\r\n\r\n  updateMetaTags(product: Product) {\r\n\tconst descripcionLimpia = he.decode(product.description || '').replace(/<[^>]*>/g, ' ').replace(/\\s+/g, ' ').trim();\r\n    const currentUrl =this._consts.url() +  this._location.path(true);  // `true` incluye el query string\r\n\r\n\r\n\r\n    this._meta.updateTag({ property: 'og:title', content: product.name || '' });\r\n    this._meta.updateTag({ property: 'og:description', content: descripcionLimpia || '' });\r\n    this._meta.updateTag({ property: 'og:image', content: this._consts.mediaUrl(Array.isArray(product.picturesdefault) ? product.picturesdefault[0] : product.picturesdefault) || '' });\r\n    this._meta.updateTag({ property: 'og:url', content: currentUrl });\r\n  }\r\n\r\n  sanitizedHtml(html: string) {\r\n    return this._domSanitizer.bypassSecurityTrustHtml(html);\r\n  }\r\n\r\n  addToCart() {\r\n    this.quantity() > 0 && this._productDetailService.addToCart(this.quantity());\r\n  }\r\n\r\n  plus(stock?: number, multipleQuantity?: number) {\r\n    if (multipleQuantity && multipleQuantity > 0) {\r\n      stock ? (this.quantity() < stock\r\n        ? this.quantity.update(value => value + multipleQuantity)\r\n        : this._toastService.show('out-of-stock-actually'))\r\n        : this.quantity.update(value => value + multipleQuantity)\r\n    } else {\r\n      stock ? (this.quantity() < stock\r\n        ? this.quantity.update(value => value + 1)\r\n        : this._toastService.show('out-of-stock-actually'))\r\n        : this.quantity.update(value => value + 1)\r\n    }\r\n  }\r\n\r\n  less(multipleQuantity?: any) {\r\n    if (multipleQuantity && multipleQuantity > 0) {\r\n      this.quantity() > multipleQuantity ? this.quantity.update(value => value - multipleQuantity) : null;\r\n    } else {\r\n      this.quantity() > 1 ? this.quantity.update(value => value - 1) : null;\r\n    }\r\n  }\r\n\r\n  checkStock(stock: number) {\r\n    if (this.quantity() >= stock)\r\n      this.quantity.set(stock);\r\n  }\r\n\r\n  public goToSection(section: string): void {\r\n\t\tthis.showFormContact = true;\r\n\t\tsetTimeout(() => {\r\n\t\t\tconst element = document.getElementById(section);\r\n\t\t\tif (element) {\r\n\t\t\t\telement.scrollIntoView({ behavior: 'smooth' });\r\n\t\t\t}\r\n\t\t}, 500);\r\n\t}\r\n\r\n}\r\n",""]}
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-detail-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-detail-ec/product-detail-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-detail-ec/product-detail-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { computed , Injector} from '@angular/core';\r\nimport { ParametersService, ChannelService } from '../../ec-services';\r\nimport {  Parameter } from '../../interfaces';\r\nimport { Component, inject, WritableSignal, signal, PLATFORM_ID, Inject } from '@angular/core';\r\nimport { Location } from '@angular/common';\r\nimport { Meta, Title } from '@angular/platform-browser';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { ProductDetailService, ProductsService, ToastService } from '../../ec-services';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { Observable } from 'rxjs';\r\nimport { Product } from '../../interfaces';\r\nimport * as he from 'he';\r\n\r\n\r\n\r\n@Component({\r\n  selector: 'app-product-detail-ec',\r\n  standalone: true,\r\n  imports: [],\r\n  templateUrl: './product-detail-ec.component.html',\r\n  styleUrls: ['./product-detail-ec.component.scss']\r\n})\r\nexport class ProductDetailEcComponent {\r\n\tprivate _productDetailService: ProductDetailService = inject(ProductDetailService);\r\n\tprivate _productService: ProductsService = inject(ProductsService);\r\n\tprivate _activedRoute: ActivatedRoute = inject(ActivatedRoute);\r\n\tprivate _domSanitizer: DomSanitizer = inject(DomSanitizer);\r\n\tprivate _consts: CoreConstantsService = inject(CoreConstantsService);\r\n\tprivate _toastService: ToastService = inject(ToastService);\r\n\tprivate parametersService = inject(ParametersService);\r\n\tpublic injector: Injector = inject(Injector);\r\n\tprivate _meta: Meta = inject(Meta);\r\n\tprivate _title: Title = inject(Title);\r\n\tprivate _location: Location = inject(Location);\r\n\tpublic product$: Observable<Product | null> = this._productDetailService.product$;\r\n\tpublic options$: Observable<any> = this._productDetailService.options$;\r\n\tpublic data$: Observable<any> = this._productDetailService.associatedData$;\r\n\r\n\tpublic mediaUrl = this._consts.mediaUrl();\r\n\tpublic code: string = '';\r\n\tpublic showFormContact = false;\r\n\tpublic showReviews: boolean = false;\r\n  public reset: boolean = false;\r\n\t public success: boolean = false;\r\n\r\n\tpublic quantity: WritableSignal<number> = signal(1);\r\n\tpublic parameters$: Observable<Parameter[] | null> = this.parametersService.getParameters();\r\n\tpublic hasParams = this.parametersService.hasParams\r\n\r\n\tconstructor() {\r\n\t\tthis._activedRoute.params.subscribe(queryParams => {\r\n\t\t\tthis.code = queryParams[\"id\"];\r\n\t\t\tthis._productDetailService.loadProduct(this.code);\r\n\t\t  });\r\n\t\tthis._activedRoute.params.subscribe(queryParams => {\r\n\t\t\tthis.code = queryParams[\"id\"];\r\n\t\t\tthis._productDetailService.loadProduct(this.code);\r\n\t\t})\r\n\t\t this.injector.get(ChannelService).channel$.subscribe(channel => {\r\n           this.showReviews = channel.showReviews;\r\n     });\r\n\t}\r\n\r\n  ngOnInit() {\r\n    this.product$.subscribe(product => {\r\n      if (product) {\r\n        this.updateMetaTags(product);\r\n      }\r\n    });\r\n  }\r\n\r\n  updateMetaTags(product: Product) {\r\n\tconst descripcionLimpia = he.decode(product.description || '').replace(/<[^>]*>/g, ' ').replace(/\\s+/g, ' ').trim();\r\n    const currentUrl =this._consts.url() +  this._location.path(true);  // `true` incluye el query string\r\n\r\n\r\n\r\n    this._meta.updateTag({ property: 'og:title', content: product.name || '' });\r\n    this._meta.updateTag({ property: 'og:description', content: descripcionLimpia || '' });\r\n    this._meta.updateTag({ property: 'og:image', content: this._consts.mediaUrl(Array.isArray(product.picturesdefault) ? product.picturesdefault[0] : product.picturesdefault) || '' });\r\n    this._meta.updateTag({ property: 'og:url', content: currentUrl });\r\n  }\r\n\r\n  sanitizedHtml(html: string) {\r\n    return this._domSanitizer.bypassSecurityTrustHtml(html);\r\n  }\r\n\r\n  addToCart() {\r\n    this.quantity() > 0 && this._productDetailService.addToCart(this.quantity());\r\n  }\r\n\r\n  plus(stock?: number, multipleQuantity?: number) {\r\n    if (multipleQuantity && multipleQuantity > 0) {\r\n      stock ? (this.quantity() < stock\r\n        ? this.quantity.update(value => value + multipleQuantity)\r\n        : this._toastService.show('out-of-stock-actually'))\r\n        : this.quantity.update(value => value + multipleQuantity)\r\n    } else {\r\n      stock ? (this.quantity() < stock\r\n        ? this.quantity.update(value => value + 1)\r\n        : this._toastService.show('out-of-stock-actually'))\r\n        : this.quantity.update(value => value + 1)\r\n    }\r\n  }\r\n\r\n  less(multipleQuantity?: any) {\r\n    if (multipleQuantity && multipleQuantity > 0) {\r\n      this.quantity() > multipleQuantity ? this.quantity.update(value => value - multipleQuantity) : null;\r\n    } else {\r\n      this.quantity() > 1 ? this.quantity.update(value => value - 1) : null;\r\n    }\r\n  }\r\n\r\n  checkStock(stock: number) {\r\n    if (this.quantity() >= stock)\r\n      this.quantity.set(stock);\r\n  }\r\n\r\n  public goToSection(section: string): void {\r\n    this.showFormContact = true;\r\n    setTimeout(() => {\r\n      const element = document.getElementById(section);\r\n      if (element) {\r\n        element.scrollIntoView({ behavior: 'smooth' });\r\n      }\r\n    }, 500);\r\n  }\r\n\r\n  resetForm = () => {\r\n    this.reset = !this.reset\r\n    this.success = true\r\n}\r\n}\r\n",""]}
@@ -48,11 +48,11 @@ export class ProductEcComponent {
48
48
  return this.product.saleprice && this.product.saleprice !== this.product.price;
49
49
  }
50
50
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: ProductEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
51
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: ProductEcComponent, isStandalone: true, selector: "app-product-ec", inputs: { product: "product", isProductBox: "isProductBox", isCollection: "isCollection" }, outputs: { loaded: "loaded" }, ngImport: i0, template: "<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none\">\r\n <!-- Marca especial y descuento -->\r\n <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\r\n class=\"marcas\">\r\n <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\r\n <ng-container *ngIf=\"shouldShowPrice\">\r\n <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\r\n [ecProductOff]=\"product\">\r\n </div>\r\n </ng-container>\r\n </div> -->\r\n\r\n <!-- Imagen del producto -->\r\n <div class=\"foto\">\r\n @if(product.picturesdefault){\r\n @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\r\n } @else {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n }\r\n }\r\n </div>\r\n <!-- Precio -->\r\n @if (shouldShowPrice) {\r\n <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\r\n }@else {\r\n <p class=\"noPrice mb-1 mt-2 pt-1\"></p>\r\n }\r\n\r\n <!-- Nombre del producto -->\r\n <h6 class=\"my-0\">{{ product.name | titlecase }}</h6>\r\n\r\n <p class=\"sku mt-2\" [innerHTML]=\"product.shortdetails\"></p>\r\n\r\n <div class=\"fixBottom mt-1\">\r\n\r\n <!-- Bot\u00F3n de acciones -->\r\n <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\r\n <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\r\n @if (!product?.special_mark || product.special_mark?.length === 0 || product.special_mark?.[0]?.type ===\r\n 'standard') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span> {{(\"buy\" | translate) | uppercase}} </span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"buy\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n }\r\n <!-- Cuando tiene marca especial y el tipo no es 'standard' -->\r\n @if(product?.special_mark?.[0]?.type !== 'standard'){\r\n @for (item of product.special_mark; track $index) {\r\n <!-- Caso 1: Agotado o Disponible muy pronto -->\r\n @if (item.type === 'out_of_stock' || item.type === 'coming_soon') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>}\r\n <!-- Caso 2: Contacto por WhatsApp -->\r\n @if (item.type === 'whatsapp_contact') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\r\n (click)=\"openWhatsApp(item.whatsappContact)\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n\r\n </button>\r\n }\r\n <!-- Caso 3: Solicitar m\u00E1s informaci\u00F3n -->\r\n @if (item.type === 'more_info') {\r\n <button *ngIf=\"\" class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>\r\n }\r\n\r\n }\r\n }\r\n\r\n <!-- </ng-container>\r\n <ng-template #noStock>\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span>{{(\"out-of-stock-short\" | translate) | uppercase}}</span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"out-of-stock-short\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n </ng-template> -->\r\n </div>\r\n</a>", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i1.TitleCasePipe, name: "titlecase" }, { kind: "component", type: PriceEcComponent, selector: "app-price-ec", inputs: ["price", "saleprice"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
51
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: ProductEcComponent, isStandalone: true, selector: "app-product-ec", inputs: { product: "product", isProductBox: "isProductBox", isCollection: "isCollection" }, outputs: { loaded: "loaded" }, ngImport: i0, template: "<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none\">\r\n <!-- Marca especial y descuento -->\r\n <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\r\n class=\"marcas\">\r\n <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\r\n <ng-container *ngIf=\"shouldShowPrice\">\r\n <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\r\n [ecProductOff]=\"product\">\r\n </div>\r\n </ng-container>\r\n </div> -->\r\n\r\n <!-- Imagen del producto -->\r\n <div class=\"foto\">\r\n @if(product.picturesdefault){\r\n @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\r\n } @else {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n }\r\n }\r\n </div>\r\n <!-- Precio -->\r\n \r\n\r\n <!-- Nombre del producto -->\r\n <h6 class=\"title\">{{ product.name | titlecase }}</h6>\r\n\r\n <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\r\n \r\n @if (shouldShowPrice) {\r\n <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\r\n }@else {\r\n <p class=\"noPrice\"></p>\r\n }\r\n\r\n <div class=\"fixBottom\">\r\n\r\n <!-- Bot\u00F3n de acciones -->\r\n <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\r\n <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\r\n @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\r\n 'standard') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span> {{(\"buy\" | translate) | uppercase}} </span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"buy\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n }\r\n <!-- Cuando tiene marca especial y el tipo no es 'standard' -->\r\n @if(product.special_mark?.[0]?.type !== 'standard'){\r\n @for (item of product.special_mark; track $index) {\r\n <!-- Caso 1: Agotado o Disponible muy pronto -->\r\n @if (item.type === 'out_of_stock' || item.type === 'coming_soon') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }} </span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>}\r\n <!-- Caso 2: Contacto por WhatsApp -->\r\n @if (item.type === 'whatsapp_contact') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\r\n (click)=\"openWhatsApp(item.whatsappContact)\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n\r\n </button>\r\n }\r\n <!-- Caso 3: Solicitar m\u00E1s informaci\u00F3n -->\r\n @if (item.type === 'more_info') {\r\n <button *ngIf=\"\" class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>\r\n }\r\n\r\n }\r\n }\r\n\r\n <!-- </ng-container>\r\n <ng-template #noStock>\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span>{{(\"out-of-stock-short\" | translate) | uppercase}}</span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"out-of-stock-short\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n </ng-template> -->\r\n </div>\r\n</a>", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i1.TitleCasePipe, name: "titlecase" }, { kind: "component", type: PriceEcComponent, selector: "app-price-ec", inputs: ["price", "saleprice"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
52
52
  }
53
53
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: ProductEcComponent, decorators: [{
54
54
  type: Component,
55
- args: [{ selector: 'app-product-ec', standalone: true, imports: [CommonModule, PriceEcComponent, RouterLink, TranslateModule], template: "<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none\">\r\n <!-- Marca especial y descuento -->\r\n <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\r\n class=\"marcas\">\r\n <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\r\n <ng-container *ngIf=\"shouldShowPrice\">\r\n <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\r\n [ecProductOff]=\"product\">\r\n </div>\r\n </ng-container>\r\n </div> -->\r\n\r\n <!-- Imagen del producto -->\r\n <div class=\"foto\">\r\n @if(product.picturesdefault){\r\n @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\r\n } @else {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n }\r\n }\r\n </div>\r\n <!-- Precio -->\r\n @if (shouldShowPrice) {\r\n <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\r\n }@else {\r\n <p class=\"noPrice mb-1 mt-2 pt-1\"></p>\r\n }\r\n\r\n <!-- Nombre del producto -->\r\n <h6 class=\"my-0\">{{ product.name | titlecase }}</h6>\r\n\r\n <p class=\"sku mt-2\" [innerHTML]=\"product.shortdetails\"></p>\r\n\r\n <div class=\"fixBottom mt-1\">\r\n\r\n <!-- Bot\u00F3n de acciones -->\r\n <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\r\n <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\r\n @if (!product?.special_mark || product.special_mark?.length === 0 || product.special_mark?.[0]?.type ===\r\n 'standard') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span> {{(\"buy\" | translate) | uppercase}} </span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"buy\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n }\r\n <!-- Cuando tiene marca especial y el tipo no es 'standard' -->\r\n @if(product?.special_mark?.[0]?.type !== 'standard'){\r\n @for (item of product.special_mark; track $index) {\r\n <!-- Caso 1: Agotado o Disponible muy pronto -->\r\n @if (item.type === 'out_of_stock' || item.type === 'coming_soon') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>}\r\n <!-- Caso 2: Contacto por WhatsApp -->\r\n @if (item.type === 'whatsapp_contact') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\r\n (click)=\"openWhatsApp(item.whatsappContact)\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n\r\n </button>\r\n }\r\n <!-- Caso 3: Solicitar m\u00E1s informaci\u00F3n -->\r\n @if (item.type === 'more_info') {\r\n <button *ngIf=\"\" class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>\r\n }\r\n\r\n }\r\n }\r\n\r\n <!-- </ng-container>\r\n <ng-template #noStock>\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span>{{(\"out-of-stock-short\" | translate) | uppercase}}</span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"out-of-stock-short\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n </ng-template> -->\r\n </div>\r\n</a>" }]
55
+ args: [{ selector: 'app-product-ec', standalone: true, imports: [CommonModule, PriceEcComponent, RouterLink, TranslateModule], template: "<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none\">\r\n <!-- Marca especial y descuento -->\r\n <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\r\n class=\"marcas\">\r\n <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\r\n <ng-container *ngIf=\"shouldShowPrice\">\r\n <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\r\n [ecProductOff]=\"product\">\r\n </div>\r\n </ng-container>\r\n </div> -->\r\n\r\n <!-- Imagen del producto -->\r\n <div class=\"foto\">\r\n @if(product.picturesdefault){\r\n @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\r\n } @else {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n }\r\n }\r\n </div>\r\n <!-- Precio -->\r\n \r\n\r\n <!-- Nombre del producto -->\r\n <h6 class=\"title\">{{ product.name | titlecase }}</h6>\r\n\r\n <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\r\n \r\n @if (shouldShowPrice) {\r\n <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\r\n }@else {\r\n <p class=\"noPrice\"></p>\r\n }\r\n\r\n <div class=\"fixBottom\">\r\n\r\n <!-- Bot\u00F3n de acciones -->\r\n <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\r\n <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\r\n @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\r\n 'standard') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span> {{(\"buy\" | translate) | uppercase}} </span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"buy\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n }\r\n <!-- Cuando tiene marca especial y el tipo no es 'standard' -->\r\n @if(product.special_mark?.[0]?.type !== 'standard'){\r\n @for (item of product.special_mark; track $index) {\r\n <!-- Caso 1: Agotado o Disponible muy pronto -->\r\n @if (item.type === 'out_of_stock' || item.type === 'coming_soon') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }} </span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>}\r\n <!-- Caso 2: Contacto por WhatsApp -->\r\n @if (item.type === 'whatsapp_contact') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\r\n (click)=\"openWhatsApp(item.whatsappContact)\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n\r\n </button>\r\n }\r\n <!-- Caso 3: Solicitar m\u00E1s informaci\u00F3n -->\r\n @if (item.type === 'more_info') {\r\n <button *ngIf=\"\" class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>\r\n }\r\n\r\n }\r\n }\r\n\r\n <!-- </ng-container>\r\n <ng-template #noStock>\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span>{{(\"out-of-stock-short\" | translate) | uppercase}}</span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"out-of-stock-short\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n </ng-template> -->\r\n </div>\r\n</a>" }]
56
56
  }], propDecorators: { product: [{
57
57
  type: Input,
58
58
  args: [{
@@ -65,4 +65,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
65
65
  }], isCollection: [{
66
66
  type: Input
67
67
  }] } });
68
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-ec/product-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-ec/product-ec.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvF,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;;;;AACtD;;;GAGG;AAQH,MAAM,OAAO,kBAAkB;IAC9B;;OAEG;IAIH,OAAO,CAAW;IAClB;;OAEG;IACM,YAAY,GAAW,IAAI,CAAC;IACrC;;OAEG;IACO,MAAM,GAAG,IAAI,YAAY,EAAU,CAAC;IAErC,YAAY,GAAY,KAAK,CAAC;IAEvC,QAAQ;QACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACpC,CAAC;IACO,MAAM,GAAwB,MAAM,CAAC,oBAAoB,CAAC,CAAA;IAC1D,gBAAgB,GAAqB,MAAM,CAAC,gBAAgB,CAAC,CAAA;IAC7D,MAAM,GAAU,MAAM,CAAC,MAAM,CAAC,CAAA;IACtC;;OAEG;IACI,QAAQ,GAAU,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAA;IAC/C,YAAY,CAAC,GAAW;QACjB,IAAI,GAAG,EAAE,CAAC;YACN,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC/B,CAAC;IACL,CAAC;IAED,IAAI,eAAe;QACf,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC;IAC5H,CAAC;IAED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,KAAK,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;IACnF,CAAC;uGAzCQ,kBAAkB;2FAAlB,kBAAkB,qMCnB/B,6kJAsGI,yDDvFO,YAAY,2VAAE,gBAAgB,yFAAE,UAAU,mOAAG,eAAe;;2FAI1D,kBAAkB;kBAP9B,SAAS;+BACC,gBAAgB,cACd,IAAI,WACP,CAAC,YAAY,EAAE,gBAAgB,EAAE,UAAU,EAAG,eAAe,CAAC;8BAWvE,OAAO;sBAHN,KAAK;uBAAC;wBACN,QAAQ,EAAE,IAAI;qBACd;gBAKQ,YAAY;sBAApB,KAAK;gBAII,MAAM;sBAAf,MAAM;gBAEE,YAAY;sBAApB,KAAK","sourcesContent":["import { Component, EventEmitter, inject, Input, OnInit, Output } from '@angular/core';\r\nimport { Product } from '../../interfaces';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { AnalyticsService } from '../../ec-services';\r\nimport { Router, RouterLink } from '@angular/router';\r\nimport { CommonModule } from '@angular/common';\r\nimport { PriceEcComponent } from \"../widgets-ec/price-ec/price-ec.component\";\r\nimport { TranslateModule } from '@ngx-translate/core';\r\n/**\r\n * Componente que se encarga de manejar un producto.\r\n * @class ProductEcComponent\r\n */\r\n@Component({\r\n\tselector: 'app-product-ec',\r\n\tstandalone: true,\r\n\timports: [CommonModule, PriceEcComponent, RouterLink , TranslateModule],\r\n\ttemplateUrl: './product-ec.component.html',\r\n\tstyleUrl: './product-ec.component.scss'\r\n})\r\nexport class ProductEcComponent implements OnInit {\r\n\t/**\r\n\t * Datos del producto.\r\n\t */\r\n\t@Input({\r\n\t\trequired: true\r\n\t})\r\n\tproduct!: Product;\r\n\t/**\r\n\t * Se usa para saber si el producto es de tipo Box o no y definir la vista adecuada.\r\n\t */\r\n\t@Input() isProductBox:boolean = true;\r\n\t/**\r\n\t * Constantes del core\r\n\t */\r\n\t@Output() loaded = new EventEmitter<number>();\r\n\r\n\t@Input() isCollection: boolean = false;\r\n\r\n\tngOnInit() {\r\n\t  this.loaded.emit(this.product.id);\r\n\t}\r\n\tprivate consts:CoreConstantsService = inject(CoreConstantsService)\r\n\tprivate analyticsService: AnalyticsService = inject(AnalyticsService)\r\n\tprivate router:Router = inject(Router)\r\n\t/**\r\n\t * URL para las imagenes del producto.\r\n\t */\r\n\tpublic mediaUrl:string = this.consts.mediaUrl()\r\n\topenWhatsApp(url: string): void {\r\n        if (url) {\r\n            window.open(url, '_blank');\r\n        }\r\n    }\r\n\r\n    get shouldShowPrice(): boolean {\r\n        return !this.product?.special_mark || this.product.special_mark.length === 0 || this.product.special_mark[0]?.showPrice;\r\n    }\r\n\r\n    get hasDiscount(): boolean {\r\n        return this.product.saleprice && this.product.saleprice !== this.product.price;\r\n    }\r\n}\r\n","<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none\">\r\n    <!-- Marca especial y descuento -->\r\n    <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\r\n        class=\"marcas\">\r\n        <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\r\n        <ng-container *ngIf=\"shouldShowPrice\">\r\n            <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\r\n                [ecProductOff]=\"product\">\r\n            </div>\r\n        </ng-container>\r\n    </div> -->\r\n\r\n    <!-- Imagen del producto -->\r\n    <div class=\"foto\">\r\n        @if(product.picturesdefault){\r\n        @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\r\n        <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n        <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\r\n        } @else {\r\n        <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n        }\r\n        }\r\n    </div>\r\n    <!-- Precio -->\r\n    @if (shouldShowPrice) {\r\n    <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\r\n    }@else {\r\n    <p class=\"noPrice mb-1 mt-2 pt-1\"></p>\r\n    }\r\n\r\n    <!-- Nombre del producto -->\r\n    <h6 class=\"my-0\">{{ product.name | titlecase }}</h6>\r\n\r\n    <p class=\"sku mt-2\" [innerHTML]=\"product.shortdetails\"></p>\r\n\r\n    <div class=\"fixBottom mt-1\">\r\n\r\n        <!-- Botón de acciones -->\r\n        <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\r\n        <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\r\n        @if (!product?.special_mark || product.special_mark?.length === 0 || product.special_mark?.[0]?.type ===\r\n        'standard') {\r\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n            <ng-container *ngIf=\"isCollection; else normalText\">\r\n                <span> {{(\"buy\" | translate) | uppercase}} </span>\r\n            </ng-container>\r\n            <ng-template #normalText>\r\n                {{(\"buy\" | translate) | uppercase}}\r\n            </ng-template>\r\n        </button>\r\n        }\r\n        <!-- Cuando tiene marca especial y el tipo no es 'standard' -->\r\n        @if(product?.special_mark?.[0]?.type !== 'standard'){\r\n        @for (item of product.special_mark; track $index) {\r\n        <!-- Caso 1: Agotado o Disponible muy pronto -->\r\n        @if (item.type === 'out_of_stock' || item.type === 'coming_soon') {\r\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n            @if(isCollection){\r\n            <span>{{ item.name | uppercase }}</span>\r\n            }@else {\r\n            {{ item.name | uppercase }}\r\n            }\r\n        </button>}\r\n        <!-- Caso 2: Contacto por WhatsApp -->\r\n        @if (item.type === 'whatsapp_contact') {\r\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\r\n            (click)=\"openWhatsApp(item.whatsappContact)\">\r\n            @if(isCollection){\r\n            <span>{{ item.name | uppercase }}</span>\r\n            }@else {\r\n            {{ item.name | uppercase }}\r\n            }\r\n\r\n        </button>\r\n        }\r\n        <!-- Caso 3: Solicitar más información -->\r\n        @if (item.type === 'more_info') {\r\n        <button *ngIf=\"\" class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n\r\n            @if(isCollection){\r\n            <span>{{ item.name | uppercase }}</span>\r\n            }@else {\r\n            {{ item.name | uppercase }}\r\n            }\r\n        </button>\r\n        }\r\n\r\n        }\r\n        }\r\n\r\n        <!-- </ng-container>\r\n        <ng-template #noStock>\r\n            <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n                <ng-container *ngIf=\"isCollection; else normalText\">\r\n                    <span>{{(\"out-of-stock-short\" | translate) | uppercase}}</span>\r\n                </ng-container>\r\n                <ng-template #normalText>\r\n                    {{(\"out-of-stock-short\" | translate) | uppercase}}\r\n                </ng-template>\r\n            </button>\r\n        </ng-template> -->\r\n    </div>\r\n</a>"]}
68
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-ec/product-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-ec/product-ec.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvF,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;;;;AACtD;;;GAGG;AAQH,MAAM,OAAO,kBAAkB;IAC9B;;OAEG;IAIH,OAAO,CAAW;IAClB;;OAEG;IACM,YAAY,GAAW,IAAI,CAAC;IACrC;;OAEG;IACO,MAAM,GAAG,IAAI,YAAY,EAAU,CAAC;IAErC,YAAY,GAAY,KAAK,CAAC;IAEvC,QAAQ;QACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACpC,CAAC;IACO,MAAM,GAAwB,MAAM,CAAC,oBAAoB,CAAC,CAAA;IAC1D,gBAAgB,GAAqB,MAAM,CAAC,gBAAgB,CAAC,CAAA;IAC7D,MAAM,GAAU,MAAM,CAAC,MAAM,CAAC,CAAA;IACtC;;OAEG;IACI,QAAQ,GAAU,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAA;IAC/C,YAAY,CAAC,GAAW;QACjB,IAAI,GAAG,EAAE,CAAC;YACN,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC/B,CAAC;IACL,CAAC;IAED,IAAI,eAAe;QACf,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC;IAC5H,CAAC;IAED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,KAAK,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;IACnF,CAAC;uGAzCQ,kBAAkB;2FAAlB,kBAAkB,qMCnB/B,kkJAuGI,yDDxFO,YAAY,2VAAE,gBAAgB,yFAAE,UAAU,mOAAG,eAAe;;2FAI1D,kBAAkB;kBAP9B,SAAS;+BACC,gBAAgB,cACd,IAAI,WACP,CAAC,YAAY,EAAE,gBAAgB,EAAE,UAAU,EAAG,eAAe,CAAC;8BAWvE,OAAO;sBAHN,KAAK;uBAAC;wBACN,QAAQ,EAAE,IAAI;qBACd;gBAKQ,YAAY;sBAApB,KAAK;gBAII,MAAM;sBAAf,MAAM;gBAEE,YAAY;sBAApB,KAAK","sourcesContent":["import { Component, EventEmitter, inject, Input, OnInit, Output } from '@angular/core';\r\nimport { Product } from '../../interfaces';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { AnalyticsService } from '../../ec-services';\r\nimport { Router, RouterLink } from '@angular/router';\r\nimport { CommonModule } from '@angular/common';\r\nimport { PriceEcComponent } from \"../widgets-ec/price-ec/price-ec.component\";\r\nimport { TranslateModule } from '@ngx-translate/core';\r\n/**\r\n * Componente que se encarga de manejar un producto.\r\n * @class ProductEcComponent\r\n */\r\n@Component({\r\n\tselector: 'app-product-ec',\r\n\tstandalone: true,\r\n\timports: [CommonModule, PriceEcComponent, RouterLink , TranslateModule],\r\n\ttemplateUrl: './product-ec.component.html',\r\n\tstyleUrl: './product-ec.component.scss'\r\n})\r\nexport class ProductEcComponent implements OnInit {\r\n\t/**\r\n\t * Datos del producto.\r\n\t */\r\n\t@Input({\r\n\t\trequired: true\r\n\t})\r\n\tproduct!: Product;\r\n\t/**\r\n\t * Se usa para saber si el producto es de tipo Box o no y definir la vista adecuada.\r\n\t */\r\n\t@Input() isProductBox:boolean = true;\r\n\t/**\r\n\t * Constantes del core\r\n\t */\r\n\t@Output() loaded = new EventEmitter<number>();\r\n\r\n\t@Input() isCollection: boolean = false;\r\n\r\n\tngOnInit() {\r\n\t  this.loaded.emit(this.product.id);\r\n\t}\r\n\tprivate consts:CoreConstantsService = inject(CoreConstantsService)\r\n\tprivate analyticsService: AnalyticsService = inject(AnalyticsService)\r\n\tprivate router:Router = inject(Router)\r\n\t/**\r\n\t * URL para las imagenes del producto.\r\n\t */\r\n\tpublic mediaUrl:string = this.consts.mediaUrl()\r\n\topenWhatsApp(url: string): void {\r\n        if (url) {\r\n            window.open(url, '_blank');\r\n        }\r\n    }\r\n\r\n    get shouldShowPrice(): boolean {\r\n        return !this.product?.special_mark || this.product.special_mark.length === 0 || this.product.special_mark[0]?.showPrice;\r\n    }\r\n\r\n    get hasDiscount(): boolean {\r\n        return this.product.saleprice && this.product.saleprice !== this.product.price;\r\n    }\r\n}\r\n","<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none\">\r\n    <!-- Marca especial y descuento -->\r\n    <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\r\n        class=\"marcas\">\r\n        <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\r\n        <ng-container *ngIf=\"shouldShowPrice\">\r\n            <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\r\n                [ecProductOff]=\"product\">\r\n            </div>\r\n        </ng-container>\r\n    </div> -->\r\n\r\n    <!-- Imagen del producto -->\r\n    <div class=\"foto\">\r\n        @if(product.picturesdefault){\r\n        @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\r\n        <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n        <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\r\n        } @else {\r\n        <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n        }\r\n        }\r\n    </div>\r\n    <!-- Precio -->\r\n    \r\n\r\n    <!-- Nombre del producto -->\r\n    <h6 class=\"title\">{{ product.name | titlecase }}</h6>\r\n\r\n    <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\r\n    \r\n    @if (shouldShowPrice) {\r\n    <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\r\n    }@else {\r\n    <p class=\"noPrice\"></p>\r\n    }\r\n\r\n    <div class=\"fixBottom\">\r\n\r\n        <!-- Botón de acciones -->\r\n         <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\r\n        <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\r\n        @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\r\n        'standard') {\r\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n            <ng-container *ngIf=\"isCollection; else normalText\">\r\n                <span> {{(\"buy\" | translate) | uppercase}} </span>\r\n            </ng-container>\r\n            <ng-template #normalText>\r\n                {{(\"buy\" | translate) | uppercase}}\r\n            </ng-template>\r\n        </button>\r\n        }\r\n        <!-- Cuando tiene marca especial y el tipo no es 'standard' -->\r\n        @if(product.special_mark?.[0]?.type !== 'standard'){\r\n        @for (item of product.special_mark; track $index) {\r\n        <!-- Caso 1: Agotado o Disponible muy pronto -->\r\n        @if (item.type === 'out_of_stock' || item.type === 'coming_soon') {\r\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n            @if(isCollection){\r\n            <span>{{ item.name | uppercase }} </span>\r\n            }@else {\r\n            {{ item.name | uppercase }}\r\n            }\r\n        </button>}\r\n        <!-- Caso 2: Contacto por WhatsApp -->\r\n        @if (item.type === 'whatsapp_contact') {\r\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\r\n            (click)=\"openWhatsApp(item.whatsappContact)\">\r\n            @if(isCollection){\r\n            <span>{{ item.name | uppercase }}</span>\r\n            }@else {\r\n            {{ item.name | uppercase }}\r\n            }\r\n\r\n        </button>\r\n        }\r\n        <!-- Caso 3: Solicitar más información -->\r\n        @if (item.type === 'more_info') {\r\n        <button *ngIf=\"\" class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n            @if(isCollection){\r\n            <span>{{ item.name | uppercase }}</span>\r\n            }@else {\r\n            {{ item.name | uppercase }}\r\n            }\r\n        </button>\r\n        }\r\n\r\n        }\r\n        }\r\n\r\n        <!-- </ng-container>\r\n        <ng-template #noStock>\r\n            <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n                <ng-container *ngIf=\"isCollection; else normalText\">\r\n                    <span>{{(\"out-of-stock-short\" | translate) | uppercase}}</span>\r\n                </ng-container>\r\n                <ng-template #normalText>\r\n                    {{(\"out-of-stock-short\" | translate) | uppercase}}\r\n                </ng-template>\r\n            </button>\r\n        </ng-template> -->\r\n    </div>\r\n</a>"]}
@@ -9,10 +9,10 @@ export class VariantsEcComponent {
9
9
  this._productDetailsService.setOption(optionCode, optionValue);
10
10
  }
11
11
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: VariantsEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
12
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: VariantsEcComponent, isStandalone: true, selector: "app-variants-ec", ngImport: i0, template: "@if(options$ | async; as options){\r\n @if(options && options.length){\r\n @for(option of options; track $index){\r\n @switch (option.type) {\r\n @case ('color') {\r\n <h5>Colores disponibles</h5>\r\n <div class=\"row w-100 mx-auto pb-3 mb-3\">\r\n @for(value of option.values; track $index; let x = $index){\r\n <a role=\"button\" [title]=\"value.description\" (click)=\"setOption(option.code, value.name)\"\r\n [class]=\"'item m-1 circle ' + (value.selected ? 'shadow' : '')\" [id]=\"x + value.name\"\r\n [style.background]=\"'#' + value.name\" [style.box-shadow]=\"(value.selected ? '0px 0px 0px 2px #000' : 'none')\">\r\n </a>\r\n }\r\n </div>\r\n }\r\n @case ('size') {\r\n\r\n }\r\n @default {\r\n\r\n }\r\n }\r\n }\r\n } @else {\r\n <p>loading</p>\r\n }\r\n}\r\n\r\n<!-- <div *ngIf=\"(options$ | async) as options\">\r\n <div *ngIf=\"options && options.length; else loading\">\r\n <div *ngFor=\"let option of options; let i = index\">\r\n\r\n <div [ngSwitch]=\"option.type\">\r\n <div *ngSwitchCase=\"'color'\">\r\n <h5>Colores disponibles</h5>\r\n <div class=\"row w-100 mx-auto pb-3 mb-3\">\r\n <a *ngFor=\"let value of option.values; let x = index\" role=\"button\"\r\n (click)=\"setOption(option.code, value.name)\" [class]=\"'item m-1 ' + (value.selected ? 'shadow' : '')\"\r\n [id]=\"x + value.name\"\r\n [style.background]=\"'#' + value.name\"\r\n [style.box-shadow]=\"(value.selected ? '0px 0px 0px 2px #000' : 'none')\">\r\n </a>\r\n </div>\r\n </div>\r\n <div *ngSwitchCase=\"'size'\">\r\n <h5>Talles displonibles</h5>\r\n <div class=\"row w-100 mx-auto pb-3\">\r\n <a *ngFor=\"let value of option.values; let x = index\" role=\"buttom\"\r\n (click)=\"setOption(option.code, value.name)\"\r\n [id]=\"x + value.name\"\r\n [class]=\"'btn item m-1 ' + (value.selected ? 'selected-size' : 'unselected-size')\">\r\n {{ value.name }}\r\n </a>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #loading>\r\n <div class=\"loading-container\">\r\n <div id=\"loading\"></div>\r\n </div>\r\n</ng-template> -->", styles: [".circle{width:32px;height:32px;border-radius:50%}.shadow{border:1px solid #000}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }] });
12
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: VariantsEcComponent, isStandalone: true, selector: "app-variants-ec", ngImport: i0, template: "@if(options$ | async; as options){\r\n@if(options && options.length){\r\n@for(option of options; track $index){\r\n@switch (option.type) {\r\n@case ('color') {\r\n<h5>Colores disponibles</h5>\r\n<div class=\"row w-100 mx-auto pb-3 mb-3\">\r\n @for(value of option.values; track $index; let x = $index){\r\n <a role=\"button\" [title]=\"value.description\" (click)=\"setOption(option.code, value.name)\"\r\n [class]=\"'item m-1 circle ' + (value.selected ? 'shadow' : '')\" [id]=\"x + value.name\"\r\n [style.background]=\"'#' + value.name\" [style.box-shadow]=\"(value.selected ? '0px 0px 0px 2px #000' : 'none')\">\r\n </a>\r\n }\r\n</div>\r\n}\r\n@case ('size') {\r\n<h5>Talles displonibles</h5>\r\n<div class=\"row w-100 mx-auto pb-3\">\r\n @for(value of option.values; track $index; let x = $index){\r\n <a role=\"buttom\" (click)=\"setOption(option.code, value.name)\" [id]=\"x + value.name\"\r\n [class]=\"'btn item m-1 ' + (value.selected ? 'selected-size' : 'unselected-size')\">\r\n {{ value.name }}\r\n </a>\r\n }\r\n\r\n</div>\r\n}\r\n@default {\r\n\r\n}\r\n}\r\n}\r\n}\r\n}\r\n", styles: [".circle{width:32px;height:32px;border-radius:50%}.shadow{border:1px solid #000}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }] });
13
13
  }
14
14
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: VariantsEcComponent, decorators: [{
15
15
  type: Component,
16
- args: [{ selector: 'app-variants-ec', standalone: true, imports: [AsyncPipe], template: "@if(options$ | async; as options){\r\n @if(options && options.length){\r\n @for(option of options; track $index){\r\n @switch (option.type) {\r\n @case ('color') {\r\n <h5>Colores disponibles</h5>\r\n <div class=\"row w-100 mx-auto pb-3 mb-3\">\r\n @for(value of option.values; track $index; let x = $index){\r\n <a role=\"button\" [title]=\"value.description\" (click)=\"setOption(option.code, value.name)\"\r\n [class]=\"'item m-1 circle ' + (value.selected ? 'shadow' : '')\" [id]=\"x + value.name\"\r\n [style.background]=\"'#' + value.name\" [style.box-shadow]=\"(value.selected ? '0px 0px 0px 2px #000' : 'none')\">\r\n </a>\r\n }\r\n </div>\r\n }\r\n @case ('size') {\r\n\r\n }\r\n @default {\r\n\r\n }\r\n }\r\n }\r\n } @else {\r\n <p>loading</p>\r\n }\r\n}\r\n\r\n<!-- <div *ngIf=\"(options$ | async) as options\">\r\n <div *ngIf=\"options && options.length; else loading\">\r\n <div *ngFor=\"let option of options; let i = index\">\r\n\r\n <div [ngSwitch]=\"option.type\">\r\n <div *ngSwitchCase=\"'color'\">\r\n <h5>Colores disponibles</h5>\r\n <div class=\"row w-100 mx-auto pb-3 mb-3\">\r\n <a *ngFor=\"let value of option.values; let x = index\" role=\"button\"\r\n (click)=\"setOption(option.code, value.name)\" [class]=\"'item m-1 ' + (value.selected ? 'shadow' : '')\"\r\n [id]=\"x + value.name\"\r\n [style.background]=\"'#' + value.name\"\r\n [style.box-shadow]=\"(value.selected ? '0px 0px 0px 2px #000' : 'none')\">\r\n </a>\r\n </div>\r\n </div>\r\n <div *ngSwitchCase=\"'size'\">\r\n <h5>Talles displonibles</h5>\r\n <div class=\"row w-100 mx-auto pb-3\">\r\n <a *ngFor=\"let value of option.values; let x = index\" role=\"buttom\"\r\n (click)=\"setOption(option.code, value.name)\"\r\n [id]=\"x + value.name\"\r\n [class]=\"'btn item m-1 ' + (value.selected ? 'selected-size' : 'unselected-size')\">\r\n {{ value.name }}\r\n </a>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #loading>\r\n <div class=\"loading-container\">\r\n <div id=\"loading\"></div>\r\n </div>\r\n</ng-template> -->", styles: [".circle{width:32px;height:32px;border-radius:50%}.shadow{border:1px solid #000}\n"] }]
16
+ args: [{ selector: 'app-variants-ec', standalone: true, imports: [AsyncPipe], template: "@if(options$ | async; as options){\r\n@if(options && options.length){\r\n@for(option of options; track $index){\r\n@switch (option.type) {\r\n@case ('color') {\r\n<h5>Colores disponibles</h5>\r\n<div class=\"row w-100 mx-auto pb-3 mb-3\">\r\n @for(value of option.values; track $index; let x = $index){\r\n <a role=\"button\" [title]=\"value.description\" (click)=\"setOption(option.code, value.name)\"\r\n [class]=\"'item m-1 circle ' + (value.selected ? 'shadow' : '')\" [id]=\"x + value.name\"\r\n [style.background]=\"'#' + value.name\" [style.box-shadow]=\"(value.selected ? '0px 0px 0px 2px #000' : 'none')\">\r\n </a>\r\n }\r\n</div>\r\n}\r\n@case ('size') {\r\n<h5>Talles displonibles</h5>\r\n<div class=\"row w-100 mx-auto pb-3\">\r\n @for(value of option.values; track $index; let x = $index){\r\n <a role=\"buttom\" (click)=\"setOption(option.code, value.name)\" [id]=\"x + value.name\"\r\n [class]=\"'btn item m-1 ' + (value.selected ? 'selected-size' : 'unselected-size')\">\r\n {{ value.name }}\r\n </a>\r\n }\r\n\r\n</div>\r\n}\r\n@default {\r\n\r\n}\r\n}\r\n}\r\n}\r\n}\r\n", styles: [".circle{width:32px;height:32px;border-radius:50%}.shadow{border:1px solid #000}\n"] }]
17
17
  }] });
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFyaWFudHMtZWMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvdmFyaWFudHMtZWMvdmFyaWFudHMtZWMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvdmFyaWFudHMtZWMvdmFyaWFudHMtZWMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQVMsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDekQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQVM1QyxNQUFNLE9BQU8sbUJBQW1CO0lBQ3ZCLHNCQUFzQixHQUF5QixNQUFNLENBQUMsb0JBQW9CLENBQUMsQ0FBQztJQUM3RSxRQUFRLEdBQUcsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFFBQVEsQ0FBQztJQUV2RCxTQUFTLENBQUMsVUFBYyxFQUFFLFdBQWU7UUFDdEMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFNBQVMsQ0FBQyxVQUFVLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDakUsQ0FBQzt1R0FOVSxtQkFBbUI7MkZBQW5CLG1CQUFtQiwyRUNYaEMsbTdGQWdFa0Isc0lEekROLFNBQVM7OzJGQUlSLG1CQUFtQjtrQkFQL0IsU0FBUzsrQkFDRSxpQkFBaUIsY0FDZixJQUFJLFdBQ1AsQ0FBQyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIGluamVjdCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUHJvZHVjdERldGFpbFNlcnZpY2UgfSBmcm9tICcuLi8uLi9lYy1zZXJ2aWNlcyc7XHJcbmltcG9ydCB7IEFzeW5jUGlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC12YXJpYW50cy1lYycsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbQXN5bmNQaXBlXSxcclxuICB0ZW1wbGF0ZVVybDogJy4vdmFyaWFudHMtZWMuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsOiAnLi92YXJpYW50cy1lYy5jb21wb25lbnQuc2NzcydcclxufSlcclxuZXhwb3J0IGNsYXNzIFZhcmlhbnRzRWNDb21wb25lbnQge1xyXG5cdHByaXZhdGUgX3Byb2R1Y3REZXRhaWxzU2VydmljZTogUHJvZHVjdERldGFpbFNlcnZpY2UgPSBpbmplY3QoUHJvZHVjdERldGFpbFNlcnZpY2UpO1xyXG5cdHB1YmxpYyBvcHRpb25zJCA9IHRoaXMuX3Byb2R1Y3REZXRhaWxzU2VydmljZS5vcHRpb25zJDtcclxuXHRcclxuXHRzZXRPcHRpb24ob3B0aW9uQ29kZTphbnksIG9wdGlvblZhbHVlOmFueSkge1xyXG4gICAgdGhpcy5fcHJvZHVjdERldGFpbHNTZXJ2aWNlLnNldE9wdGlvbihvcHRpb25Db2RlLCBvcHRpb25WYWx1ZSk7XHJcbiAgfVxyXG5cdFxyXG59XHJcbiIsIkBpZihvcHRpb25zJCB8IGFzeW5jOyBhcyBvcHRpb25zKXtcclxuICAgIEBpZihvcHRpb25zICYmIG9wdGlvbnMubGVuZ3RoKXtcclxuICAgICAgICBAZm9yKG9wdGlvbiBvZiBvcHRpb25zOyB0cmFjayAkaW5kZXgpe1xyXG4gICAgICAgICAgICBAc3dpdGNoIChvcHRpb24udHlwZSkge1xyXG4gICAgICAgICAgICAgICAgQGNhc2UgKCdjb2xvcicpIHtcclxuICAgICAgICAgICAgICAgIDxoNT5Db2xvcmVzIGRpc3BvbmlibGVzPC9oNT5cclxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyb3cgdy0xMDAgbXgtYXV0byBwYi0zIG1iLTNcIj5cclxuICAgICAgICAgICAgICAgICAgICBAZm9yKHZhbHVlIG9mIG9wdGlvbi52YWx1ZXM7IHRyYWNrICRpbmRleDsgbGV0IHggPSAkaW5kZXgpe1xyXG4gICAgICAgICAgICAgICAgICAgIDxhIHJvbGU9XCJidXR0b25cIiBbdGl0bGVdPVwidmFsdWUuZGVzY3JpcHRpb25cIiAoY2xpY2spPVwic2V0T3B0aW9uKG9wdGlvbi5jb2RlLCB2YWx1ZS5uYW1lKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtjbGFzc109XCInaXRlbSBtLTEgY2lyY2xlICcgKyAodmFsdWUuc2VsZWN0ZWQgPyAnc2hhZG93JyA6ICcnKVwiIFtpZF09XCJ4ICsgdmFsdWUubmFtZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtzdHlsZS5iYWNrZ3JvdW5kXT1cIicjJyArIHZhbHVlLm5hbWVcIiBbc3R5bGUuYm94LXNoYWRvd109XCIodmFsdWUuc2VsZWN0ZWQgPyAnMHB4IDBweCAwcHggMnB4ICMwMDAnIDogJ25vbmUnKVwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDwvYT5cclxuICAgICAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgIEBjYXNlICgnc2l6ZScpIHtcclxuXHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICBAZGVmYXVsdCB7XHJcblxyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgfSBAZWxzZSB7XHJcbiAgICA8cD5sb2FkaW5nPC9wPlxyXG4gICAgfVxyXG59XHJcblxyXG48IS0tIDxkaXYgKm5nSWY9XCIob3B0aW9ucyQgfCBhc3luYykgYXMgb3B0aW9uc1wiPlxyXG4gICAgPGRpdiAqbmdJZj1cIm9wdGlvbnMgJiYgb3B0aW9ucy5sZW5ndGg7IGVsc2UgbG9hZGluZ1wiPlxyXG4gICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBvcHRpb24gb2Ygb3B0aW9uczsgbGV0IGkgPSBpbmRleFwiPlxyXG5cclxuICAgICAgICAgICAgICA8ZGl2IFtuZ1N3aXRjaF09XCJvcHRpb24udHlwZVwiPlxyXG4gICAgICAgICAgICAgICAgICAgPGRpdiAqbmdTd2l0Y2hDYXNlPVwiJ2NvbG9yJ1wiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICA8aDU+Q29sb3JlcyBkaXNwb25pYmxlczwvaDU+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyb3cgdy0xMDAgbXgtYXV0byBwYi0zIG1iLTNcIj5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxhICpuZ0Zvcj1cImxldCB2YWx1ZSBvZiBvcHRpb24udmFsdWVzOyBsZXQgeCA9IGluZGV4XCIgcm9sZT1cImJ1dHRvblwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cInNldE9wdGlvbihvcHRpb24uY29kZSwgdmFsdWUubmFtZSlcIiBbY2xhc3NdPVwiJ2l0ZW0gbS0xICcgKyAodmFsdWUuc2VsZWN0ZWQgPyAnc2hhZG93JyA6ICcnKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2lkXT1cInggKyB2YWx1ZS5uYW1lXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbc3R5bGUuYmFja2dyb3VuZF09XCInIycgKyB2YWx1ZS5uYW1lXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbc3R5bGUuYm94LXNoYWRvd109XCIodmFsdWUuc2VsZWN0ZWQgPyAnMHB4IDBweCAwcHggMnB4ICMwMDAnIDogJ25vbmUnKVwiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPC9hPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICAgICAgICAgPGRpdiAqbmdTd2l0Y2hDYXNlPVwiJ3NpemUnXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDxoNT5UYWxsZXMgZGlzcGxvbmlibGVzPC9oNT5cclxuICAgICAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cInJvdyB3LTEwMCBteC1hdXRvIHBiLTNcIj5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8YSAqbmdGb3I9XCJsZXQgdmFsdWUgb2Ygb3B0aW9uLnZhbHVlczsgbGV0IHggPSBpbmRleFwiIHJvbGU9XCJidXR0b21cIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cInNldE9wdGlvbihvcHRpb24uY29kZSwgdmFsdWUubmFtZSlcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2lkXT1cInggKyB2YWx1ZS5uYW1lXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtjbGFzc109XCInYnRuIGl0ZW0gbS0xICcgKyAodmFsdWUuc2VsZWN0ZWQgPyAnc2VsZWN0ZWQtc2l6ZScgOiAndW5zZWxlY3RlZC1zaXplJylcIj5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHt7IHZhbHVlLm5hbWUgfX1cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L2E+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PlxyXG5cclxuPG5nLXRlbXBsYXRlICNsb2FkaW5nPlxyXG4gICAgPGRpdiBjbGFzcz1cImxvYWRpbmctY29udGFpbmVyXCI+XHJcbiAgICAgICAgIDxkaXYgaWQ9XCJsb2FkaW5nXCI+PC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuPC9uZy10ZW1wbGF0ZT4gLS0+Il19
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFyaWFudHMtZWMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvdmFyaWFudHMtZWMvdmFyaWFudHMtZWMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvdmFyaWFudHMtZWMvdmFyaWFudHMtZWMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQVMsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDekQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQVM1QyxNQUFNLE9BQU8sbUJBQW1CO0lBQ3ZCLHNCQUFzQixHQUF5QixNQUFNLENBQUMsb0JBQW9CLENBQUMsQ0FBQztJQUM3RSxRQUFRLEdBQUcsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFFBQVEsQ0FBQztJQUV2RCxTQUFTLENBQUMsVUFBYyxFQUFFLFdBQWU7UUFDdEMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFNBQVMsQ0FBQyxVQUFVLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDakUsQ0FBQzt1R0FOVSxtQkFBbUI7MkZBQW5CLG1CQUFtQiwyRUNYaEMsdW5DQWtDQSxzSUQzQlksU0FBUzs7MkZBSVIsbUJBQW1CO2tCQVAvQixTQUFTOytCQUNFLGlCQUFpQixjQUNmLElBQUksV0FDUCxDQUFDLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgaW5qZWN0LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBQcm9kdWN0RGV0YWlsU2VydmljZSB9IGZyb20gJy4uLy4uL2VjLXNlcnZpY2VzJztcclxuaW1wb3J0IHsgQXN5bmNQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXBwLXZhcmlhbnRzLWVjJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtBc3luY1BpcGVdLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi92YXJpYW50cy1lYy5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmw6ICcuL3ZhcmlhbnRzLWVjLmNvbXBvbmVudC5zY3NzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgVmFyaWFudHNFY0NvbXBvbmVudCB7XHJcblx0cHJpdmF0ZSBfcHJvZHVjdERldGFpbHNTZXJ2aWNlOiBQcm9kdWN0RGV0YWlsU2VydmljZSA9IGluamVjdChQcm9kdWN0RGV0YWlsU2VydmljZSk7XHJcblx0cHVibGljIG9wdGlvbnMkID0gdGhpcy5fcHJvZHVjdERldGFpbHNTZXJ2aWNlLm9wdGlvbnMkO1xyXG5cdFxyXG5cdHNldE9wdGlvbihvcHRpb25Db2RlOmFueSwgb3B0aW9uVmFsdWU6YW55KSB7XHJcbiAgICB0aGlzLl9wcm9kdWN0RGV0YWlsc1NlcnZpY2Uuc2V0T3B0aW9uKG9wdGlvbkNvZGUsIG9wdGlvblZhbHVlKTtcclxuICB9XHJcblx0XHJcbn1cclxuIiwiQGlmKG9wdGlvbnMkIHwgYXN5bmM7IGFzIG9wdGlvbnMpe1xyXG5AaWYob3B0aW9ucyAmJiBvcHRpb25zLmxlbmd0aCl7XHJcbkBmb3Iob3B0aW9uIG9mIG9wdGlvbnM7IHRyYWNrICRpbmRleCl7XHJcbkBzd2l0Y2ggKG9wdGlvbi50eXBlKSB7XHJcbkBjYXNlICgnY29sb3InKSB7XHJcbjxoNT5Db2xvcmVzIGRpc3BvbmlibGVzPC9oNT5cclxuPGRpdiBjbGFzcz1cInJvdyB3LTEwMCBteC1hdXRvIHBiLTMgbWItM1wiPlxyXG4gICAgQGZvcih2YWx1ZSBvZiBvcHRpb24udmFsdWVzOyB0cmFjayAkaW5kZXg7IGxldCB4ID0gJGluZGV4KXtcclxuICAgIDxhIHJvbGU9XCJidXR0b25cIiBbdGl0bGVdPVwidmFsdWUuZGVzY3JpcHRpb25cIiAoY2xpY2spPVwic2V0T3B0aW9uKG9wdGlvbi5jb2RlLCB2YWx1ZS5uYW1lKVwiXHJcbiAgICAgICAgW2NsYXNzXT1cIidpdGVtIG0tMSBjaXJjbGUgJyArICh2YWx1ZS5zZWxlY3RlZCA/ICdzaGFkb3cnIDogJycpXCIgW2lkXT1cInggKyB2YWx1ZS5uYW1lXCJcclxuICAgICAgICBbc3R5bGUuYmFja2dyb3VuZF09XCInIycgKyB2YWx1ZS5uYW1lXCIgW3N0eWxlLmJveC1zaGFkb3ddPVwiKHZhbHVlLnNlbGVjdGVkID8gJzBweCAwcHggMHB4IDJweCAjMDAwJyA6ICdub25lJylcIj5cclxuICAgIDwvYT5cclxuICAgIH1cclxuPC9kaXY+XHJcbn1cclxuQGNhc2UgKCdzaXplJykge1xyXG48aDU+VGFsbGVzIGRpc3Bsb25pYmxlczwvaDU+XHJcbjxkaXYgY2xhc3M9XCJyb3cgdy0xMDAgbXgtYXV0byBwYi0zXCI+XHJcbiAgICBAZm9yKHZhbHVlIG9mIG9wdGlvbi52YWx1ZXM7IHRyYWNrICRpbmRleDsgbGV0IHggPSAkaW5kZXgpe1xyXG4gICAgPGEgcm9sZT1cImJ1dHRvbVwiIChjbGljayk9XCJzZXRPcHRpb24ob3B0aW9uLmNvZGUsIHZhbHVlLm5hbWUpXCIgW2lkXT1cInggKyB2YWx1ZS5uYW1lXCJcclxuICAgICAgICBbY2xhc3NdPVwiJ2J0biBpdGVtIG0tMSAnICsgKHZhbHVlLnNlbGVjdGVkID8gJ3NlbGVjdGVkLXNpemUnIDogJ3Vuc2VsZWN0ZWQtc2l6ZScpXCI+XHJcbiAgICAgICAge3sgdmFsdWUubmFtZSB9fVxyXG4gICAgPC9hPlxyXG4gICAgfVxyXG5cclxuPC9kaXY+XHJcbn1cclxuQGRlZmF1bHQge1xyXG5cclxufVxyXG59XHJcbn1cclxufVxyXG59XHJcbiJdfQ==