ng-easycommerce-v18 0.3.0 → 0.3.1-9.beta-1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (48) hide show
  1. package/README.md +40 -0
  2. package/assets/ec-i18n/ct.json +1 -0
  3. package/assets/ec-i18n/en.json +88 -83
  4. package/assets/ec-i18n/es.json +6 -1
  5. package/assets/ec-i18n/fr.json +1 -0
  6. package/assets/ec-i18n/gl.json +1 -0
  7. package/assets/ec-i18n/pr.json +1 -0
  8. package/esm2022/lib/classes/component-helper.mjs +11 -2
  9. package/esm2022/lib/constants/core.constants.service.mjs +107 -2
  10. package/esm2022/lib/ec-components/abstractions-components/menu-ec.component.mjs +9 -1
  11. package/esm2022/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.mjs +5 -1
  12. package/esm2022/lib/ec-components/auth-ec/register-form-ec/register-form-ec.component.mjs +5 -1
  13. package/esm2022/lib/ec-components/blocks-ec/block-newsletter-ec/block-newsletter-ec.component.mjs +9 -3
  14. package/esm2022/lib/ec-components/cart-ec/cart-item-ec/cart-item-ec.component.mjs +42 -10
  15. package/esm2022/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.mjs +141 -75
  16. package/esm2022/lib/ec-components/filters-ec/filters-ec.component.mjs +9 -1
  17. package/esm2022/lib/ec-components/header-ec/header-ec.component.mjs +53 -2
  18. package/esm2022/lib/ec-components/product-detail-ec/product-detail-ec.component.mjs +7 -5
  19. package/esm2022/lib/ec-components/product-ec/product-ec.component.mjs +143 -5
  20. package/esm2022/lib/ec-components/widgets-ec/decidir-ec/decidir-ec.component.mjs +3 -3
  21. package/esm2022/lib/ec-components/widgets-ec/index.mjs +2 -1
  22. package/esm2022/lib/ec-components/widgets-ec/redsys-catch-ec/redsys-catch-ec.component.mjs +193 -0
  23. package/esm2022/lib/ec-services/cart.service.mjs +22 -4
  24. package/esm2022/lib/ec-services/form.service.mjs +13 -1
  25. package/esm2022/lib/ec-services/order-utility.service.mjs +11 -5
  26. package/esm2022/lib/ec-services/product-detail.service.mjs +11 -1
  27. package/esm2022/lib/interfaces/environment.mjs +1 -1
  28. package/esm2022/lib/interfaces/product.mjs +1 -1
  29. package/fesm2022/ng-easycommerce-v18.mjs +775 -116
  30. package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
  31. package/lib/classes/component-helper.d.ts +1 -1
  32. package/lib/constants/core.constants.service.d.ts +24 -0
  33. package/lib/ec-components/abstractions-components/menu-ec.component.d.ts +6 -0
  34. package/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.d.ts +2 -0
  35. package/lib/ec-components/auth-ec/register-form-ec/register-form-ec.component.d.ts +2 -0
  36. package/lib/ec-components/cart-ec/cart-item-ec/cart-item-ec.component.d.ts +6 -1
  37. package/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.d.ts +38 -16
  38. package/lib/ec-components/filters-ec/filters-ec.component.d.ts +6 -0
  39. package/lib/ec-components/header-ec/header-ec.component.d.ts +16 -2
  40. package/lib/ec-components/product-detail-ec/product-detail-ec.component.d.ts +1 -0
  41. package/lib/ec-components/product-ec/product-ec.component.d.ts +14 -1
  42. package/lib/ec-components/widgets-ec/index.d.ts +1 -0
  43. package/lib/ec-components/widgets-ec/redsys-catch-ec/redsys-catch-ec.component.d.ts +47 -0
  44. package/lib/ec-services/cart.service.d.ts +1 -1
  45. package/lib/ec-services/form.service.d.ts +6 -0
  46. package/lib/interfaces/environment.d.ts +1 -0
  47. package/lib/interfaces/product.d.ts +6 -0
  48. package/package.json +1 -1
@@ -1,6 +1,6 @@
1
1
  import { Component, inject, Input } from '@angular/core';
2
2
  import { CoreConstantsService } from '../../../constants';
3
- import { CartService, ToastService } from '../../../ec-services';
3
+ import { CartService, ToastService, ParametersService } from '../../../ec-services';
4
4
  import { TitleCasePipe } from '@angular/common';
5
5
  import { EcCurrencySymbolPipe } from '../../../ec-pipe';
6
6
  import { RouterLink } from '@angular/router';
@@ -13,6 +13,7 @@ export class CartItemEcComponent {
13
13
  _cartService = inject(CartService);
14
14
  _toastService = inject(ToastService);
15
15
  _constants = inject(CoreConstantsService);
16
+ parametersService = inject(ParametersService);
16
17
  mediaUrl = this._constants.mediaUrl();
17
18
  quantity = 0;
18
19
  variantsToShow = ['TALLA', 'COLOR'];
@@ -23,28 +24,56 @@ export class CartItemEcComponent {
23
24
  // console.log(this.item, this.mediaUrl);
24
25
  }
25
26
  updateQuantity(stock) {
27
+ const originalQuantity = this.item.quantity; // Guardar cantidad original
26
28
  if (this.quantity > 0 && this.quantity <= stock) {
27
- this._cartService.updateItemQuantity(this.item, this.quantity);
29
+ const success = this._cartService.updateItemQuantity(this.item, this.quantity);
30
+ // Si la validación falló, restaurar la cantidad original
31
+ if (!success) {
32
+ this.quantity = originalQuantity;
33
+ }
28
34
  }
29
35
  else {
30
- this.quantity = this.item.quantity;
36
+ // Restaurar cantidad original si está fuera de rango
37
+ this.quantity = originalQuantity;
31
38
  this._toastService.show('out-of-stock-actually');
32
39
  }
33
40
  }
34
- less(stock, value = 1) {
41
+ plus(stock, value = 1) {
35
42
  if (this.isQuantityUpdating)
36
43
  return;
37
44
  this.isQuantityUpdating = true;
38
- let quantity = this.item.quantity - value;
39
- quantity > 0 && quantity <= stock ? this._cartService.updateItemQuantity(this.item, quantity) : this._toastService.show('out-of-stock-actually');
45
+ let newQuantity = Number(this.quantity) + value; // Forzar a número
46
+ // Verificar stock ANTES de llamar al servicio
47
+ if (newQuantity > stock) {
48
+ this._toastService.show('out-of-stock-actually');
49
+ setTimeout(() => { this.isQuantityUpdating = false; }, 1000);
50
+ return;
51
+ }
52
+ const success = this._cartService.updateItemQuantity(this.item, newQuantity);
53
+ // Solo actualizar el input si la operación fue exitosa
54
+ if (success) {
55
+ this.quantity = newQuantity;
56
+ }
57
+ // Si success es false, NO mostrar mensaje aquí porque ya lo mostró validateQuantity()
40
58
  setTimeout(() => { this.isQuantityUpdating = false; }, 1000);
41
59
  }
42
- plus(stock, value = 1) {
60
+ less(stock, value = 1) {
43
61
  if (this.isQuantityUpdating)
44
62
  return;
45
63
  this.isQuantityUpdating = true;
46
- let quantity = this.item.quantity + value;
47
- quantity > 0 && quantity <= stock ? this._cartService.updateItemQuantity(this.item, quantity) : this._toastService.show('out-of-stock-actually');
64
+ let newQuantity = Number(this.quantity) - value; // Forzar a número
65
+ // Verificar cantidad mínima ANTES de llamar al servicio
66
+ if (newQuantity <= 0) {
67
+ // No permitir cantidades menores o iguales a 0
68
+ setTimeout(() => { this.isQuantityUpdating = false; }, 1000);
69
+ return;
70
+ }
71
+ const success = this._cartService.updateItemQuantity(this.item, newQuantity);
72
+ // Solo actualizar el input si la operación fue exitosa
73
+ if (success) {
74
+ this.quantity = newQuantity;
75
+ }
76
+ // Si success es false, NO mostrar mensaje aquí porque ya lo mostró validateQuantity()
48
77
  setTimeout(() => { this.isQuantityUpdating = false; }, 1000);
49
78
  }
50
79
  deleteCartItem() {
@@ -99,6 +128,9 @@ export class CartItemEcComponent {
99
128
  }
100
129
  return false; // Solo se ejecuta si no se cumple la condición
101
130
  }
131
+ // PARAMETROS
132
+ parameters$ = this.parametersService.getParameters();
133
+ hasParams = this.parametersService.hasParams;
102
134
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CartItemEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
103
135
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", 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-3\">\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-7\">\r\n <div class=\"info d-flex flex-column align-items-start\">\r\n @if (item.product.special_mark?.length > 0 || item.product.saleprice) {\r\n <div class=\"marcas\">\r\n <img [src]=\"mediaUrl + (item.product.special_mark?.[0]?.images[0] || '')\" alt=\"\">\r\n\r\n @if (item.product.saleprice) {\r\n <div class=\"tag-dsc\">\r\n {{\r\n createDiscountMessage(item.product.saleprice,\r\n item.product.price)\r\n }}\r\n </div>\r\n }\r\n </div>\r\n }\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=\"campoCantidad mt-2\">\r\n <div class=\"numero\">\r\n <button (click)=\"less(item.product.variants[0]?.stock)\" class=\"btn btn-outline-secondary\"\r\n 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=\"\"\r\n aria-label=\"Example text with button addon\" aria-describedby=\"button-addon1\"\r\n [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\"\r\n type=\"button\" id=\"button-addon1\">\r\n <i class=\"fa fa-plus\" aria-hidden=\"true\"></i>\r\n </button>\r\n </div>\r\n\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"] }] });
104
136
  }
@@ -113,4 +145,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
113
145
  }], inSidebar: [{
114
146
  type: Input
115
147
  }] } });
116
- //# 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[] = ['TALLA', 'COLOR'];\r\n\tpublic updateStock: boolean = false;\r\n\tpublic isQuantityUpdating = false;\r\n\t\r\n\tngOnInit() {\r\n\t\tthis.quantity = this.item.quantity\r\n\t\t// console.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\tif (this.isQuantityUpdating) return;\r\n\t\tthis.isQuantityUpdating = true;\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\tsetTimeout(() => { this.isQuantityUpdating = false; }, 1000);\r\n\t}\r\n\r\n\tplus(stock: number, value: number = 1) {\r\n\t\tif (this.isQuantityUpdating) return;\r\n\t\tthis.isQuantityUpdating = true;\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\tsetTimeout(() => { this.isQuantityUpdating = false; }, 1000);\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                            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                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-3\">\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-7\">\r\n        <div class=\"info d-flex flex-column align-items-start\">\r\n            @if (item.product.special_mark?.length > 0 || item.product.saleprice) {\r\n                    <div class=\"marcas\">\r\n                        <img [src]=\"mediaUrl + (item.product.special_mark?.[0]?.images[0] || '')\" alt=\"\">\r\n\r\n                        @if (item.product.saleprice) {\r\n                        <div class=\"tag-dsc\">\r\n                            {{\r\n                            createDiscountMessage(item.product.saleprice,\r\n                            item.product.price)\r\n                            }}\r\n                        </div>\r\n                        }\r\n                    </div>\r\n                    }\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=\"campoCantidad mt-2\">\r\n                <div class=\"numero\">\r\n                    <button (click)=\"less(item.product.variants[0]?.stock)\" class=\"btn btn-outline-secondary\"\r\n                        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=\"\"\r\n                        aria-label=\"Example text with button addon\" aria-describedby=\"button-addon1\"\r\n                        [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\"\r\n                        type=\"button\" id=\"button-addon1\">\r\n                        <i class=\"fa fa-plus\" aria-hidden=\"true\"></i>\r\n                    </button>\r\n                </div>\r\n\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}"]}
148
+ //# 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, ParametersService } 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\nimport { Observable } from 'rxjs';\r\nimport { Parameter } from '../../../interfaces';\r\n\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\tprivate parametersService = inject(ParametersService)\r\n\r\n\tpublic mediaUrl = this._constants.mediaUrl();\r\n\tpublic quantity = 0;\r\n\tpublic variantsToShow: string[] = ['TALLA', 'COLOR'];\r\n\tpublic updateStock: boolean = false;\r\n\tpublic isQuantityUpdating = false;\r\n\r\n\tngOnInit() {\r\n\t\tthis.quantity = this.item.quantity\r\n\t\t// console.log(this.item, this.mediaUrl);\r\n\t}\r\n\r\n\tupdateQuantity(stock: number) {\r\n\t\tconst originalQuantity = this.item.quantity; // Guardar cantidad original\r\n\r\n\t\tif (this.quantity > 0 && this.quantity <= stock) {\r\n\t\t\tconst success = this._cartService.updateItemQuantity(this.item, this.quantity);\r\n\r\n\t\t\t// Si la validación falló, restaurar la cantidad original\r\n\t\t\tif (!success) {\r\n\t\t\t\tthis.quantity = originalQuantity;\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\t// Restaurar cantidad original si está fuera de rango\r\n\t\t\tthis.quantity = originalQuantity;\r\n\t\t\tthis._toastService.show('out-of-stock-actually');\r\n\t\t}\r\n\t}\r\n\r\n\tplus(stock: number, value: number = 1) {\r\n\t\tif (this.isQuantityUpdating) return;\r\n\t\tthis.isQuantityUpdating = true;\r\n\r\n\t\tlet newQuantity = Number(this.quantity) + value; // Forzar a número\r\n\r\n\t\t// Verificar stock ANTES de llamar al servicio\r\n\t\tif (newQuantity > stock) {\r\n\t\t\tthis._toastService.show('out-of-stock-actually');\r\n\t\t\tsetTimeout(() => { this.isQuantityUpdating = false; }, 1000);\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst success = this._cartService.updateItemQuantity(this.item, newQuantity);\r\n\r\n\t\t// Solo actualizar el input si la operación fue exitosa\r\n\t\tif (success) {\r\n\t\t\tthis.quantity = newQuantity;\r\n\t\t}\r\n\t\t// Si success es false, NO mostrar mensaje aquí porque ya lo mostró validateQuantity()\r\n\r\n\t\tsetTimeout(() => { this.isQuantityUpdating = false; }, 1000);\r\n\t}\r\n\r\n\tless(stock: number, value: number = 1) {\r\n\t\tif (this.isQuantityUpdating) return;\r\n\t\tthis.isQuantityUpdating = true;\r\n\r\n\t\tlet newQuantity = Number(this.quantity) - value; // Forzar a número\r\n\r\n\t\t// Verificar cantidad mínima ANTES de llamar al servicio\r\n\t\tif (newQuantity <= 0) {\r\n\t\t\t// No permitir cantidades menores o iguales a 0\r\n\t\t\tsetTimeout(() => { this.isQuantityUpdating = false; }, 1000);\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst success = this._cartService.updateItemQuantity(this.item, newQuantity);\r\n\r\n\t\t// Solo actualizar el input si la operación fue exitosa\r\n\t\tif (success) {\r\n\t\t\tthis.quantity = newQuantity;\r\n\t\t}\r\n\t\t// Si success es false, NO mostrar mensaje aquí porque ya lo mostró validateQuantity()\r\n\r\n\t\tsetTimeout(() => { this.isQuantityUpdating = false; }, 1000);\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\t\tif (item.variants && item.variants.length && item.variants[0].options && item.variants[0].options.length) {\r\n\t\t\tlet options = item.variants[0].options\r\n\t\t\toptions = options.filter((option: any) => this.variantsToShow.find((name: any) => option.hasOwnProperty(name)))\r\n\t\t\tlet optionsMap: any = []\r\n\t\t\toptions.map((option: any) => {\r\n\t\t\t\tObject.keys(option).forEach((entry) => {\r\n\t\t\t\t\tlet optionAdded = false;  // Variable para evitar múltiples inserciones\r\n\r\n\t\t\t\t\titem.options.forEach((option2: any) => {\r\n\t\t\t\t\t\toption2.values.forEach((color: any) => {\r\n\t\t\t\t\t\t\tif (color.code == option[entry] && !optionAdded) {\r\n\t\t\t\t\t\t\t\toptionsMap.push({ name: entry, value: option[entry], image: color.image, mobileImage: color.mobileImage });\r\n\t\t\t\t\t\t\t\toptionAdded = true; // Marcar opción agregada\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t});\r\n\t\t\t\t});\r\n\t\t\t\treturn optionsMap;\r\n\t\t\t});\r\n\r\n\t\t\treturn optionsMap;\r\n\r\n\t\t} else {\r\n\t\t\treturn null\r\n\t\t}\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\treturn '';\r\n\t\t}\r\n\r\n\t\tlet discountPercentage = Math.round(((price - saleprice) / price) * 100);\r\n\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\t\tfor (const variant of product.product.variants) {\r\n\t\t\tif (product.variant_id === variant.code) {\r\n\t\t\t\tif (variant.stock === 0) {\r\n\t\t\t\t\tthis.updateStock = true;\r\n\t\t\t\t\treturn '0';\r\n\t\t\t\t} else if (product.quantity > variant.stock) {\r\n\t\t\t\t\tthis.updateStock = true;\r\n\t\t\t\t\treturn variant.stock;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn false; // Solo se ejecuta si no se cumple la condición\r\n\t}\r\n\r\n\t// PARAMETROS\r\n\tpublic parameters$: Observable<Parameter[] | null> = this.parametersService.getParameters()\r\n\tpublic hasParams = this.parametersService.hasParams\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-3\">\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-7\">\r\n        <div class=\"info d-flex flex-column align-items-start\">\r\n            @if (item.product.special_mark?.length > 0 || item.product.saleprice) {\r\n                    <div class=\"marcas\">\r\n                        <img [src]=\"mediaUrl + (item.product.special_mark?.[0]?.images[0] || '')\" alt=\"\">\r\n\r\n                        @if (item.product.saleprice) {\r\n                        <div class=\"tag-dsc\">\r\n                            {{\r\n                            createDiscountMessage(item.product.saleprice,\r\n                            item.product.price)\r\n                            }}\r\n                        </div>\r\n                        }\r\n                    </div>\r\n                    }\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=\"campoCantidad mt-2\">\r\n                <div class=\"numero\">\r\n                    <button (click)=\"less(item.product.variants[0]?.stock)\" class=\"btn btn-outline-secondary\"\r\n                        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=\"\"\r\n                        aria-label=\"Example text with button addon\" aria-describedby=\"button-addon1\"\r\n                        [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\"\r\n                        type=\"button\" id=\"button-addon1\">\r\n                        <i class=\"fa fa-plus\" aria-hidden=\"true\"></i>\r\n                    </button>\r\n                </div>\r\n\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}"]}
@@ -6,108 +6,174 @@ import * as i0 from "@angular/core";
6
6
  export class MpRedirectEcComponent {
7
7
  _paymentService = inject(PaymentService);
8
8
  _toastService = inject(ToastService);
9
+ platformId = inject(PLATFORM_ID);
10
+ finished = false;
9
11
  method = null;
10
12
  total_amount = 0;
11
13
  allData;
12
14
  ready = new EventEmitter();
13
15
  preference;
14
- loading = false;
15
16
  url;
16
- closeModal = '';
17
- ventana;
18
- window;
19
- localStorage;
20
- platformId = inject(PLATFORM_ID);
21
- constructor() {
17
+ // Fases de UI
18
+ phase = 'idle';
19
+ get isIdle() { return this.phase === 'idle'; }
20
+ get isPaying() { return this.phase === 'paying'; }
21
+ get isFinalizing() { return this.phase === 'finalizing'; }
22
+ ventana = null;
23
+ windowRef;
24
+ sid = '';
25
+ bc;
26
+ pollTimer;
27
+ pollStartedAt = 0;
28
+ ngOnInit() {
22
29
  if (isPlatformBrowser(this.platformId)) {
23
- this.window = window;
24
- this.localStorage = localStorage;
30
+ this.windowRef = window;
31
+ if ('BroadcastChannel' in window) {
32
+ this.bc = new BroadcastChannel('mp_payment');
33
+ this.bc.onmessage = (e) => this.onMpMessage(e?.data);
34
+ }
35
+ window.addEventListener('storage', this.onStorage);
36
+ window.addEventListener('message', this.onWindowMessage);
25
37
  }
26
- }
27
- ngOnInit() {
28
38
  this.getPreference();
29
39
  }
40
+ ngOnDestroy() {
41
+ if (!isPlatformBrowser(this.platformId))
42
+ return;
43
+ this.bc?.close();
44
+ window.removeEventListener('storage', this.onStorage);
45
+ window.removeEventListener('message', this.onWindowMessage);
46
+ if (this.pollTimer)
47
+ clearInterval(this.pollTimer);
48
+ }
49
+ /** Cancela manualmente el pago y finaliza el flujo con estado "cancel". */
30
50
  clickClose = () => {
31
- /* this.closeModal = 'cancel'
32
- this.ventana?.close() */
51
+ if (this.finished)
52
+ return;
53
+ this.finishWithState('cancel');
33
54
  };
55
+ /**
56
+ * Inicia el pago abriendo `init_point` en una ventana/pestaña nueva.
57
+ * Genera un SID y lo persiste para casar la respuesta del catch.
58
+ * Si el popup es bloqueado, hace fallback navegando en la misma pestaña.
59
+ */
34
60
  iniciar = () => {
35
- this.closeModal = '';
36
- this.clearStorageState();
37
- this.ventana = this.window?.open(this.url);
38
- this.callState();
39
- };
40
- callState = () => {
41
- let state = this.closeModal != '' ? this.closeModal : this.localStorage?.getItem('state');
42
- !state && this.ventana.closed && (state = 'cancel');
43
- this.loading = true;
44
- state && console.log(state);
45
- if (state) {
46
- this.loading = false;
47
- this.localStorage?.removeItem('state');
48
- if (state == 'success') {
49
- this.ventana?.close();
50
- this.ready.emit(true);
51
- return;
52
- }
53
- if (state == 'pending') {
54
- this.ventana?.close();
55
- this.ready.emit(true);
56
- return;
57
- }
58
- if (state == 'failure') {
59
- this.ventana?.close();
60
- this.processError('');
61
- return;
62
- }
63
- if (state == 'cancel') {
64
- this.ventana?.close();
65
- this.processError('Se cancelo el pago con mercado pago');
61
+ if (!isPlatformBrowser(this.platformId) || !this.windowRef || !this.url)
62
+ return;
63
+ this.phase = 'paying';
64
+ this.sid = this.genSid();
65
+ const url = new URL(this.url);
66
+ localStorage.setItem('mp:sid', this.sid);
67
+ this.ventana = this.windowRef.open(this.url, '_blank');
68
+ // popup bloqueado fallback a navegación en misma pestaña
69
+ if (!this.ventana || this.ventana.closed) {
70
+ this.windowRef.location.href = this.url;
71
+ return;
72
+ }
73
+ // polling de último recurso (hasta 10 minutos)
74
+ this.pollStartedAt = Date.now();
75
+ if (this.pollTimer)
76
+ clearInterval(this.pollTimer);
77
+ this.pollTimer = setInterval(() => {
78
+ if (Date.now() - this.pollStartedAt > 10 * 60 * 1000) {
79
+ clearInterval(this.pollTimer);
80
+ this.pollTimer = null;
81
+ this.phase = 'idle';
82
+ this.processError('Tiempo de espera agotado al procesar el pago.');
66
83
  return;
67
84
  }
68
- this.ventana?.close();
69
- this.processError('');
85
+ this.checkLocalStorageOnce();
86
+ }, 1000);
87
+ };
88
+ onWindowMessage = (event) => {
89
+ const data = event?.data;
90
+ this.onMpMessage(data);
91
+ };
92
+ onStorage = (e) => {
93
+ if (!e.key || !this.sid)
70
94
  return;
95
+ if (e.key === `mp:state:${this.sid}` && e.newValue) {
96
+ const state = e.newValue;
97
+ this.finishWithState(state);
71
98
  }
72
- setTimeout(() => {
73
- this.callState();
74
- }, 5000);
75
99
  };
76
- processError = (err) => {
77
- this._toastService.show(err != '' ? err : 'payment-error');
78
- // console.log("ERROR ENVIO BACK ", err);
100
+ onMpMessage = (data) => {
101
+ if (!data || data.type !== 'mp:state')
102
+ return;
103
+ if (data.sid !== this.sid)
104
+ return;
105
+ this.finishWithState(data.state);
106
+ };
107
+ checkLocalStorageOnce() {
108
+ if (!this.sid)
109
+ return;
110
+ const state = localStorage.getItem(`mp:state:${this.sid}`);
111
+ if (state)
112
+ this.finishWithState(state);
113
+ }
114
+ /** Cierra el flujo de pago con el estado final y notifica al padre. */
115
+ finishWithState(state) {
116
+ if (this.finished)
117
+ return;
118
+ this.finished = true;
119
+ if (this.pollTimer)
120
+ clearInterval(this.pollTimer);
121
+ this.pollTimer = null;
122
+ localStorage.removeItem(`mp:state:${this.sid}`);
123
+ localStorage.removeItem('mp:sid');
124
+ localStorage.removeItem('state');
125
+ try {
126
+ this.ventana && !this.ventana.closed && this.ventana.close();
127
+ }
128
+ catch { }
129
+ this.ventana = null;
130
+ if (state === 'success' || state === 'pending') {
131
+ this.phase = 'finalizing';
132
+ this.ready.emit(true);
133
+ }
134
+ else if (state === 'failure' || state === 'cancel') {
135
+ this.phase = 'idle';
136
+ this._toastService.show(state === 'cancel' ? 'Se canceló el pago con Mercado Pago' : 'payment-error');
137
+ }
138
+ else {
139
+ this.phase = 'idle';
140
+ this._toastService.show('payment-error');
141
+ }
142
+ }
143
+ genSid() {
144
+ return `mp_${Date.now()}_${Math.random().toString(36).slice(2, 9)}`;
145
+ }
146
+ processError = (msg) => {
147
+ this._toastService.show(msg || 'payment-error');
79
148
  };
149
+ /** Limpia posibles residuos de estado en storages. */
80
150
  clearStorageState = () => {
81
- sessionStorage.removeItem('state');
82
- this.localStorage?.removeItem('state');
151
+ if (!isPlatformBrowser(this.platformId))
152
+ return;
153
+ localStorage.removeItem('state');
154
+ const sid = localStorage.getItem('mp:sid');
155
+ if (sid)
156
+ localStorage.removeItem(`mp:state:${sid}`);
157
+ };
158
+ /** Obtiene la preferencia e inicializa `url` (init_point). */
159
+ getPreference = () => {
160
+ this._paymentService.getPreference(this.allData).then((res) => {
161
+ this.preference = res;
162
+ this.url = this.preference?.init_point;
163
+ this.renderMP(this.preference);
164
+ }, () => this.setError('operation-error'));
83
165
  };
84
- getPreference = () => this._paymentService.getPreference(this.allData).then(res => {
85
- this.preference = res;
86
- this.url = this.preference.init_point;
87
- this.renderMP(this.preference);
88
- }, err => this.setError('operation-error'));
89
166
  setError = (message) => {
90
167
  //this.error = message;
91
168
  };
92
- renderMP = (preference) => {
93
- this.window?.addEventListener("message", (event) => {
94
- if (event.origin !== 'https://www.mercadopago.com.ar' || !event.data.type) {
95
- return;
96
- }
97
- let dataType = event.data.type;
98
- if (dataType === 'submit') {
99
- const paymentData = event.data.value;
100
- return;
101
- }
102
- });
103
- };
169
+ renderMP = (_pref) => { };
104
170
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MpRedirectEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
105
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: MpRedirectEcComponent, isStandalone: true, selector: "app-mp-redirect-ec", inputs: { method: "method", total_amount: "total_amount", allData: "allData" }, outputs: { ready: "ready" }, ngImport: i0, template: "<div class=\"text-center\">\r\n\t@if(url){\r\n\t\t@if(!loading){\r\n\t\t\t<button (click)=\"iniciar()\" class=\"btn btn-outline-primary rounded-0 comprar mt-3\">Pagar</button>\r\n\t\t} @else {\r\n\t\t\t<div class=\"d-flex flex-column jusitfy-content-center align-items-center mt-2\">\r\n\t\t\t\t<h3>Procesando el pago por mercado pago</h3>\r\n\t\t\t\t<h5>Recuerde hacer click en \"Volver al sitio\" desde mercado pago para finalizar la compra.</h5>\r\n\t\t\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t\t\t</div>\r\n\t\t\t<div class=\"container-fluid\">\r\n\t\t\t\t<div class=\"row\">\r\n\t\t\t\t\t<div class=\"col-5\">\r\n\t\t\t\t\t\t<hr>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"col-2 text-center\">\r\n\t\t\t\t\t\t<label for=\"\">o</label>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"col-5\">\r\n\t\t\t\t\t\t<hr>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\r\n\t\t\t\t<button (click)=\"clickClose()\" class=\"btn btn-outline-secondary\">Cancelar pago</button>\r\n\t\t\t</div>\r\n\t\t}\r\n\t} @else{\r\n\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\r\n\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t</div>\r\n\t}\r\n</div>", styles: [""], dependencies: [{ kind: "component", type: LoadingFullEcComponent, selector: "app-loading-full-ec" }] });
171
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: MpRedirectEcComponent, isStandalone: true, selector: "app-mp-redirect-ec", inputs: { method: "method", total_amount: "total_amount", allData: "allData" }, outputs: { ready: "ready" }, ngImport: i0, template: "<div class=\"text-center\">\r\n\t@if(url) {\r\n\r\n\t@if(isIdle) {\r\n\t<button (click)=\"iniciar()\" class=\"btn btn-outline-primary rounded-0 comprar mt-3\">Pagar</button>\r\n\t}\r\n\r\n\t@if(isPaying) {\r\n\t<div class=\"d-flex flex-column jusitfy-content-center align-items-center mt-2\">\r\n\t\t<h3>Procesando el pago por Mercado Pago</h3>\r\n\t\t<h5>Record\u00E1 tocar \u201CVolver al sitio\u201D en Mercado Pago para finalizar.</h5>\r\n\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t</div>\r\n\r\n\t<div class=\"container-fluid\">\r\n\t\t<div class=\"row\">\r\n\t\t\t<div class=\"col-5\">\r\n\t\t\t\t<hr>\r\n\t\t\t</div>\r\n\t\t\t<div class=\"col-2 text-center\"><label>o</label></div>\r\n\t\t\t<div class=\"col-5\">\r\n\t\t\t\t<hr>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n\r\n\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\r\n\t\t<button (click)=\"clickClose()\" class=\"btn btn-outline-secondary\">Cancelar pago</button>\r\n\t</div>\r\n\t}\r\n\r\n\t@if(isFinalizing) {\r\n\t<div class=\"d-flex flex-column jusitfy-content-center align-items-center mt-2\">\r\n\t\t<h3>Confirmando pago y redirigiendo\u2026</h3>\r\n\t\t<h5>No cierres ni recargues esta p\u00E1gina.</h5>\r\n\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t</div>\r\n\t}\r\n\r\n\t} @else {\r\n\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\r\n\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t</div>\r\n\t}\r\n</div>", styles: [""], dependencies: [{ kind: "component", type: LoadingFullEcComponent, selector: "app-loading-full-ec" }] });
106
172
  }
107
173
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MpRedirectEcComponent, decorators: [{
108
174
  type: Component,
109
- args: [{ selector: 'app-mp-redirect-ec', standalone: true, imports: [LoadingFullEcComponent], template: "<div class=\"text-center\">\r\n\t@if(url){\r\n\t\t@if(!loading){\r\n\t\t\t<button (click)=\"iniciar()\" class=\"btn btn-outline-primary rounded-0 comprar mt-3\">Pagar</button>\r\n\t\t} @else {\r\n\t\t\t<div class=\"d-flex flex-column jusitfy-content-center align-items-center mt-2\">\r\n\t\t\t\t<h3>Procesando el pago por mercado pago</h3>\r\n\t\t\t\t<h5>Recuerde hacer click en \"Volver al sitio\" desde mercado pago para finalizar la compra.</h5>\r\n\t\t\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t\t\t</div>\r\n\t\t\t<div class=\"container-fluid\">\r\n\t\t\t\t<div class=\"row\">\r\n\t\t\t\t\t<div class=\"col-5\">\r\n\t\t\t\t\t\t<hr>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"col-2 text-center\">\r\n\t\t\t\t\t\t<label for=\"\">o</label>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"col-5\">\r\n\t\t\t\t\t\t<hr>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\r\n\t\t\t\t<button (click)=\"clickClose()\" class=\"btn btn-outline-secondary\">Cancelar pago</button>\r\n\t\t\t</div>\r\n\t\t}\r\n\t} @else{\r\n\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\r\n\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t</div>\r\n\t}\r\n</div>" }]
110
- }], ctorParameters: () => [], propDecorators: { method: [{
175
+ args: [{ selector: 'app-mp-redirect-ec', standalone: true, imports: [LoadingFullEcComponent], template: "<div class=\"text-center\">\r\n\t@if(url) {\r\n\r\n\t@if(isIdle) {\r\n\t<button (click)=\"iniciar()\" class=\"btn btn-outline-primary rounded-0 comprar mt-3\">Pagar</button>\r\n\t}\r\n\r\n\t@if(isPaying) {\r\n\t<div class=\"d-flex flex-column jusitfy-content-center align-items-center mt-2\">\r\n\t\t<h3>Procesando el pago por Mercado Pago</h3>\r\n\t\t<h5>Record\u00E1 tocar \u201CVolver al sitio\u201D en Mercado Pago para finalizar.</h5>\r\n\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t</div>\r\n\r\n\t<div class=\"container-fluid\">\r\n\t\t<div class=\"row\">\r\n\t\t\t<div class=\"col-5\">\r\n\t\t\t\t<hr>\r\n\t\t\t</div>\r\n\t\t\t<div class=\"col-2 text-center\"><label>o</label></div>\r\n\t\t\t<div class=\"col-5\">\r\n\t\t\t\t<hr>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n\r\n\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\r\n\t\t<button (click)=\"clickClose()\" class=\"btn btn-outline-secondary\">Cancelar pago</button>\r\n\t</div>\r\n\t}\r\n\r\n\t@if(isFinalizing) {\r\n\t<div class=\"d-flex flex-column jusitfy-content-center align-items-center mt-2\">\r\n\t\t<h3>Confirmando pago y redirigiendo\u2026</h3>\r\n\t\t<h5>No cierres ni recargues esta p\u00E1gina.</h5>\r\n\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t</div>\r\n\t}\r\n\r\n\t} @else {\r\n\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\r\n\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t</div>\r\n\t}\r\n</div>" }]
176
+ }], propDecorators: { method: [{
111
177
  type: Input
112
178
  }], total_amount: [{
113
179
  type: Input
@@ -116,4 +182,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
116
182
  }], ready: [{
117
183
  type: Output
118
184
  }] } });
119
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mp-redirect-ec.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.ts","../../../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAU,MAAM,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AACpG,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1E,OAAO,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;;AASpD,MAAM,OAAO,qBAAqB;IAEzB,eAAe,GAAmB,MAAM,CAAC,cAAc,CAAC,CAAA;IACxD,aAAa,GAAiB,MAAM,CAAC,YAAY,CAAC,CAAA;IAEjD,MAAM,GAAG,IAAI,CAAC;IACd,YAAY,GAAG,CAAC,CAAC;IACjB,OAAO,CAAM;IACZ,KAAK,GAAG,IAAI,YAAY,EAAE,CAAC;IAE3B,UAAU,CAAM;IAEnB,OAAO,GAAG,KAAK,CAAC;IAChB,GAAG,CAAM;IACT,UAAU,GAAG,EAAE,CAAA;IACf,OAAO,CAAM;IACb,MAAM,CAAU;IAChB,YAAY,CAAU;IAErB,UAAU,GAAQ,MAAM,CAAC,WAAW,CAAC,CAAA;IAE7C;QACC,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACxC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;YACpB,IAAI,CAAC,YAAY,GAAG,YAAY,CAAA;QACjC,CAAC;IACF,CAAC;IAED,QAAQ;QACP,IAAI,CAAC,aAAa,EAAE,CAAA;IACrB,CAAC;IACD,UAAU,GAAG,GAAG,EAAE;QACjB;iCACyB;IAC1B,CAAC,CAAA;IAED,OAAO,GAAG,GAAG,EAAE;QACd,IAAI,CAAC,UAAU,GAAG,EAAE,CAAA;QACpB,IAAI,CAAC,iBAAiB,EAAE,CAAA;QACxB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAC1C,IAAI,CAAC,SAAS,EAAE,CAAA;IACjB,CAAC,CAAA;IAED,SAAS,GAAG,GAAG,EAAE;QAChB,IAAI,KAAK,GAAG,IAAI,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,CAAC,OAAO,CAAC,CAAA;QACzF,CAAC,KAAK,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAA;QACnD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAA;QACnB,KAAK,IAAI,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,OAAO,GAAG,KAAK,CAAA;YACpB,IAAI,CAAC,YAAY,EAAE,UAAU,CAAC,OAAO,CAAC,CAAA;YACtC,IAAI,KAAK,IAAI,SAAS,EAAE,CAAC;gBACxB,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,CAAA;gBACrB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;gBACrB,OAAM;YACP,CAAC;YACD,IAAI,KAAK,IAAI,SAAS,EAAE,CAAC;gBACxB,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,CAAA;gBACrB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;gBACrB,OAAM;YACP,CAAC;YACD,IAAI,KAAK,IAAI,SAAS,EAAE,CAAC;gBACxB,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,CAAA;gBACrB,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAA;gBACrB,OAAM;YACP,CAAC;YACD,IAAI,KAAK,IAAI,QAAQ,EAAE,CAAC;gBACvB,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,CAAA;gBACrB,IAAI,CAAC,YAAY,CAAC,qCAAqC,CAAC,CAAA;gBACxD,OAAM;YACP,CAAC;YACD,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,CAAA;YACrB,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAA;YACrB,OAAM;QACP,CAAC;QACD,UAAU,CAAC,GAAG,EAAE;YACf,IAAI,CAAC,SAAS,EAAE,CAAA;QACjB,CAAC,EAAE,IAAI,CAAC,CAAC;IAEV,CAAC,CAAA;IACD,YAAY,GAAG,CAAC,GAAQ,EAAE,EAAE;QAC3B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QAC3D,0CAA0C;IAC3C,CAAC,CAAA;IACD,iBAAiB,GAAG,GAAG,EAAE;QACxB,cAAc,CAAC,UAAU,CAAC,OAAO,CAAC,CAAA;QAClC,IAAI,CAAC,YAAY,EAAE,UAAU,CAAC,OAAO,CAAC,CAAA;IACvC,CAAC,CAAA;IAED,aAAa,GAAG,GAAG,EAAE,CACpB,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CACpD,GAAG,CAAC,EAAE;QACL,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;QACtB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,UAAU,CAAA;QACrC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAChC,CAAC,EACD,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CACvC,CAAC;IACH,QAAQ,GAAG,CAAC,OAAY,EAAE,EAAE;QAC3B,uBAAuB;IACxB,CAAC,CAAA;IACD,QAAQ,GAAG,CAAC,UAAe,EAAE,EAAE;QAC9B,IAAI,CAAC,MAAM,EAAE,gBAAgB,CAAC,SAAS,EAAE,CAAC,KAAU,EAAE,EAAE;YACvD,IAAI,KAAK,CAAC,MAAM,KAAK,gCAAgC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;gBAC3E,OAAO;YACR,CAAC;YACD,IAAI,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC;YAC/B,IAAI,QAAQ,KAAK,QAAQ,EAAE,CAAC;gBAC3B,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC;gBACrC,OAAO;YACR,CAAC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC,CAAA;wGAhHW,qBAAqB;4FAArB,qBAAqB,2LCZlC,qwCAgCM,0DDtBK,sBAAsB;;4FAEpB,qBAAqB;kBAPjC,SAAS;+BACC,oBAAoB,cAClB,IAAI,WAGP,CAAC,sBAAsB,CAAC;wDAOxB,MAAM;sBAAd,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACI,KAAK;sBAAd,MAAM","sourcesContent":["import { Component, EventEmitter, inject, Input, OnInit, Output, PLATFORM_ID } from '@angular/core';\r\nimport { PaymentService, ToastService } from '../../../../../ec-services';\r\nimport { LoadingFullEcComponent } from '../../../../widgets-ec';\r\nimport { isPlatformBrowser } from '@angular/common';\r\n\r\n@Component({\r\n\tselector: 'app-mp-redirect-ec',\r\n\tstandalone: true,\r\n\ttemplateUrl: './mp-redirect-ec.component.html',\r\n\tstyleUrls: ['./mp-redirect-ec.component.scss'],\r\n\timports: [LoadingFullEcComponent]\r\n})\r\nexport class MpRedirectEcComponent implements OnInit {\r\n\r\n\tprivate _paymentService: PaymentService = inject(PaymentService)\r\n\tprivate _toastService: ToastService = inject(ToastService)\r\n\r\n\t@Input() method = null;\r\n\t@Input() total_amount = 0;\r\n\t@Input() allData: any;\r\n\t@Output() ready = new EventEmitter();\r\n\r\n\tprotected preference: any;\r\n\r\n\tpublic loading = false;\r\n\tpublic url: any;\r\n\tpublic closeModal = ''\r\n\tpublic ventana: any;\r\n\tpublic window?: Window;\r\n\tpublic localStorage?:Storage;\r\n\r\n\tprivate platformId: any = inject(PLATFORM_ID)\r\n\r\n\tconstructor() {\r\n\t\tif (isPlatformBrowser(this.platformId)) {\r\n\t\t\tthis.window = window\r\n\t\t\tthis.localStorage = localStorage\r\n\t\t}\r\n\t}\r\n\r\n\tngOnInit() {\r\n\t\tthis.getPreference()\r\n\t}\r\n\tclickClose = () => {\r\n\t\t/*  this.closeModal = 'cancel'\r\n\t\t this.ventana?.close() */\r\n\t}\r\n\r\n\tiniciar = () => {\r\n\t\tthis.closeModal = ''\r\n\t\tthis.clearStorageState()\r\n\t\tthis.ventana = this.window?.open(this.url)\r\n\t\tthis.callState()\r\n\t}\r\n\r\n\tcallState = () => {\r\n\t\tlet state = this.closeModal != '' ? this.closeModal : this.localStorage?.getItem('state')\r\n\t\t!state && this.ventana.closed && (state = 'cancel')\r\n\t\tthis.loading = true\r\n\t\tstate && console.log(state);\r\n\t\tif (state) {\r\n\t\t\tthis.loading = false\r\n\t\t\tthis.localStorage?.removeItem('state')\r\n\t\t\tif (state == 'success') {\r\n\t\t\t\tthis.ventana?.close()\r\n\t\t\t\tthis.ready.emit(true)\r\n\t\t\t\treturn\r\n\t\t\t}\r\n\t\t\tif (state == 'pending') {\r\n\t\t\t\tthis.ventana?.close()\r\n\t\t\t\tthis.ready.emit(true)\r\n\t\t\t\treturn\r\n\t\t\t}\r\n\t\t\tif (state == 'failure') {\r\n\t\t\t\tthis.ventana?.close()\r\n\t\t\t\tthis.processError('')\r\n\t\t\t\treturn\r\n\t\t\t}\r\n\t\t\tif (state == 'cancel') {\r\n\t\t\t\tthis.ventana?.close()\r\n\t\t\t\tthis.processError('Se cancelo el pago con mercado pago')\r\n\t\t\t\treturn\r\n\t\t\t}\r\n\t\t\tthis.ventana?.close()\r\n\t\t\tthis.processError('')\r\n\t\t\treturn\r\n\t\t}\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.callState()\r\n\t\t}, 5000);\r\n\r\n\t}\r\n\tprocessError = (err: any) => {\r\n\t\tthis._toastService.show(err != '' ? err : 'payment-error');\r\n\t\t// console.log(\"ERROR ENVIO BACK  \", err);\r\n\t}\r\n\tclearStorageState = () => {\r\n\t\tsessionStorage.removeItem('state')\r\n\t\tthis.localStorage?.removeItem('state')\r\n\t}\r\n\r\n\tgetPreference = () =>\r\n\t\tthis._paymentService.getPreference(this.allData).then(\r\n\t\t\tres => {\r\n\t\t\t\tthis.preference = res;\r\n\t\t\t\tthis.url = this.preference.init_point\r\n\t\t\t\tthis.renderMP(this.preference);\r\n\t\t\t},\r\n\t\t\terr => this.setError('operation-error')\r\n\t\t);\r\n\tsetError = (message: any) => {\r\n\t\t//this.error = message;\r\n\t}\r\n\trenderMP = (preference: any) => {\r\n\t\tthis.window?.addEventListener(\"message\", (event: any) => {\r\n\t\t\tif (event.origin !== 'https://www.mercadopago.com.ar' || !event.data.type) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tlet dataType = event.data.type;\r\n\t\t\tif (dataType === 'submit') {\r\n\t\t\t\tconst paymentData = event.data.value;\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n}\r\n","<div class=\"text-center\">\r\n\t@if(url){\r\n\t\t@if(!loading){\r\n\t\t\t<button (click)=\"iniciar()\" class=\"btn btn-outline-primary rounded-0 comprar mt-3\">Pagar</button>\r\n\t\t} @else {\r\n\t\t\t<div class=\"d-flex flex-column jusitfy-content-center align-items-center mt-2\">\r\n\t\t\t\t<h3>Procesando el pago por mercado pago</h3>\r\n\t\t\t\t<h5>Recuerde hacer click en \"Volver al sitio\" desde mercado pago para finalizar la compra.</h5>\r\n\t\t\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t\t\t</div>\r\n\t\t\t<div class=\"container-fluid\">\r\n\t\t\t\t<div class=\"row\">\r\n\t\t\t\t\t<div class=\"col-5\">\r\n\t\t\t\t\t\t<hr>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"col-2 text-center\">\r\n\t\t\t\t\t\t<label for=\"\">o</label>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"col-5\">\r\n\t\t\t\t\t\t<hr>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\r\n\t\t\t\t<button (click)=\"clickClose()\" class=\"btn btn-outline-secondary\">Cancelar pago</button>\r\n\t\t\t</div>\r\n\t\t}\r\n\t} @else{\r\n\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\r\n\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t</div>\r\n\t}\r\n</div>"]}
185
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mp-redirect-ec.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.ts","../../../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, inject, Input, OnInit, Output, PLATFORM_ID, OnDestroy } from '@angular/core';\r\nimport { PaymentService, ToastService } from '../../../../../ec-services';\r\nimport { LoadingFullEcComponent } from '../../../../widgets-ec';\r\nimport { isPlatformBrowser } from '@angular/common';\r\n\r\ntype MpState = 'success' | 'pending' | 'failure' | 'cancel';\r\ntype Phase = 'idle' | 'paying' | 'finalizing';\r\n\r\n@Component({\r\n\tselector: 'app-mp-redirect-ec',\r\n\tstandalone: true,\r\n\ttemplateUrl: './mp-redirect-ec.component.html',\r\n\tstyleUrls: ['./mp-redirect-ec.component.scss'],\r\n\timports: [LoadingFullEcComponent]\r\n})\r\nexport class MpRedirectEcComponent implements OnInit, OnDestroy {\r\n\r\n\tprivate _paymentService = inject(PaymentService);\r\n\tprivate _toastService = inject(ToastService);\r\n\tprivate platformId: any = inject(PLATFORM_ID);\r\n\tprivate finished = false;\r\n\r\n\t@Input() method = null;\r\n\t@Input() total_amount = 0;\r\n\t@Input() allData: any;\r\n\t@Output() ready = new EventEmitter<boolean>();\r\n\r\n\tprotected preference: any;\r\n\tpublic url?: string;\r\n\r\n\t// Fases de UI\r\n\tpublic phase: Phase = 'idle';\r\n\tget isIdle() { return this.phase === 'idle'; }\r\n\tget isPaying() { return this.phase === 'paying'; }\r\n\tget isFinalizing() { return this.phase === 'finalizing'; }\r\n\r\n\tprivate ventana: Window | null = null;\r\n\tprivate windowRef?: Window;\r\n\tprivate sid = '';\r\n\tprivate bc?: BroadcastChannel;\r\n\tprivate pollTimer?: any;\r\n\tprivate pollStartedAt = 0;\r\n\r\n\tngOnInit() {\r\n\t\tif (isPlatformBrowser(this.platformId)) {\r\n\t\t\tthis.windowRef = window;\r\n\r\n\t\t\tif ('BroadcastChannel' in window) {\r\n\t\t\t\tthis.bc = new BroadcastChannel('mp_payment');\r\n\t\t\t\tthis.bc.onmessage = (e: MessageEvent) => this.onMpMessage(e?.data);\r\n\t\t\t}\r\n\r\n\t\t\twindow.addEventListener('storage', this.onStorage);\r\n\t\t\twindow.addEventListener('message', this.onWindowMessage);\r\n\t\t}\r\n\r\n\t\tthis.getPreference();\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\tif (!isPlatformBrowser(this.platformId)) return;\r\n\t\tthis.bc?.close();\r\n\t\twindow.removeEventListener('storage', this.onStorage);\r\n\t\twindow.removeEventListener('message', this.onWindowMessage);\r\n\t\tif (this.pollTimer) clearInterval(this.pollTimer);\r\n\t}\r\n\r\n\t/** Cancela manualmente el pago y finaliza el flujo con estado \"cancel\". */\r\n\tclickClose = () => {\r\n\t\tif (this.finished) return;\r\n\t\tthis.finishWithState('cancel');\r\n\t}\r\n\r\n\t/**\r\n\t * Inicia el pago abriendo `init_point` en una ventana/pestaña nueva.\r\n\t * Genera un SID y lo persiste para casar la respuesta del catch.\r\n\t * Si el popup es bloqueado, hace fallback navegando en la misma pestaña.\r\n\t */\r\n\tiniciar = () => {\r\n\t\tif (!isPlatformBrowser(this.platformId) || !this.windowRef || !this.url) return;\r\n\r\n\t\tthis.phase = 'paying';\r\n\t\tthis.sid = this.genSid();\r\n\t\tconst url = new URL(this.url);\r\n\r\n\t\tlocalStorage.setItem('mp:sid', this.sid);\r\n\r\n\t\tthis.ventana = this.windowRef.open(this.url, '_blank');\r\n\r\n\t\t// popup bloqueado → fallback a navegación en misma pestaña\r\n\t\tif (!this.ventana || this.ventana.closed) {\r\n\t\t\tthis.windowRef.location.href = this.url;\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// polling de último recurso (hasta 10 minutos)\r\n\t\tthis.pollStartedAt = Date.now();\r\n\t\tif (this.pollTimer) clearInterval(this.pollTimer);\r\n\t\tthis.pollTimer = setInterval(() => {\r\n\t\t\tif (Date.now() - this.pollStartedAt > 10 * 60 * 1000) {\r\n\t\t\t\tclearInterval(this.pollTimer);\r\n\t\t\t\tthis.pollTimer = null;\r\n\t\t\t\tthis.phase = 'idle';\r\n\t\t\t\tthis.processError('Tiempo de espera agotado al procesar el pago.');\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tthis.checkLocalStorageOnce();\r\n\t\t}, 1000);\r\n\t}\r\n\r\n\tprivate onWindowMessage = (event: MessageEvent) => {\r\n\t\tconst data = event?.data;\r\n\t\tthis.onMpMessage(data);\r\n\t}\r\n\r\n\tprivate onStorage = (e: StorageEvent) => {\r\n\t\tif (!e.key || !this.sid) return;\r\n\t\tif (e.key === `mp:state:${this.sid}` && e.newValue) {\r\n\t\t\tconst state = e.newValue as MpState;\r\n\t\t\tthis.finishWithState(state);\r\n\t\t}\r\n\t}\r\n\r\n\tprivate onMpMessage = (data: any) => {\r\n\t\tif (!data || data.type !== 'mp:state') return;\r\n\t\tif (data.sid !== this.sid) return;\r\n\t\tthis.finishWithState(data.state as MpState);\r\n\t}\r\n\r\n\tprivate checkLocalStorageOnce() {\r\n\t\tif (!this.sid) return;\r\n\t\tconst state = localStorage.getItem(`mp:state:${this.sid}`) as MpState | null;\r\n\t\tif (state) this.finishWithState(state);\r\n\t}\r\n\r\n\t/** Cierra el flujo de pago con el estado final y notifica al padre. */\r\n\tprivate finishWithState(state: MpState) {\r\n\t\tif (this.finished) return;\r\n\t\tthis.finished = true;\r\n\r\n\t\tif (this.pollTimer) clearInterval(this.pollTimer);\r\n\t\tthis.pollTimer = null;\r\n\r\n\t\tlocalStorage.removeItem(`mp:state:${this.sid}`);\r\n\t\tlocalStorage.removeItem('mp:sid');\r\n\t\tlocalStorage.removeItem('state');\r\n\r\n\t\ttry { this.ventana && !this.ventana.closed && this.ventana.close(); } catch { }\r\n\t\tthis.ventana = null;\r\n\r\n\t\tif (state === 'success' || state === 'pending') {\r\n\t\t\tthis.phase = 'finalizing';\r\n\t\t\tthis.ready.emit(true);\r\n\t\t} else if (state === 'failure' || state === 'cancel') {\r\n\t\t\tthis.phase = 'idle';\r\n\t\t\tthis._toastService.show(state === 'cancel' ? 'Se canceló el pago con Mercado Pago' : 'payment-error');\r\n\t\t} else {\r\n\t\t\tthis.phase = 'idle';\r\n\t\t\tthis._toastService.show('payment-error');\r\n\t\t}\r\n\t}\r\n\r\n\tprivate genSid(): string {\r\n\t\treturn `mp_${Date.now()}_${Math.random().toString(36).slice(2, 9)}`;\r\n\t}\r\n\r\n\tprivate processError = (msg: string) => {\r\n\t\tthis._toastService.show(msg || 'payment-error');\r\n\t}\r\n\r\n\t/** Limpia posibles residuos de estado en storages. */\r\n\tclearStorageState = () => {\r\n\t\tif (!isPlatformBrowser(this.platformId)) return;\r\n\t\tlocalStorage.removeItem('state');\r\n\t\tconst sid = localStorage.getItem('mp:sid');\r\n\t\tif (sid) localStorage.removeItem(`mp:state:${sid}`);\r\n\t}\r\n\r\n\t/** Obtiene la preferencia e inicializa `url` (init_point). */\r\n\tprivate getPreference = (): void => {\r\n\t\tthis._paymentService.getPreference(this.allData).then(\r\n\t\t\t(res) => {\r\n\t\t\t\tthis.preference = res;\r\n\t\t\t\tthis.url = this.preference?.init_point;\r\n\t\t\t\tthis.renderMP(this.preference);\r\n\t\t\t},\r\n\t\t\t() => this.setError('operation-error')\r\n\t\t);\r\n\t};\r\n\r\n\tprivate setError = (message: any) => {\r\n\t\t//this.error = message;\r\n\t}\r\n\r\n\tprivate renderMP = (_pref: any): void => { /* noop */ };\r\n}\r\n","<div class=\"text-center\">\r\n\t@if(url) {\r\n\r\n\t@if(isIdle) {\r\n\t<button (click)=\"iniciar()\" class=\"btn btn-outline-primary rounded-0 comprar mt-3\">Pagar</button>\r\n\t}\r\n\r\n\t@if(isPaying) {\r\n\t<div class=\"d-flex flex-column jusitfy-content-center align-items-center mt-2\">\r\n\t\t<h3>Procesando el pago por Mercado Pago</h3>\r\n\t\t<h5>Recordá tocar “Volver al sitio” en Mercado Pago para finalizar.</h5>\r\n\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t</div>\r\n\r\n\t<div class=\"container-fluid\">\r\n\t\t<div class=\"row\">\r\n\t\t\t<div class=\"col-5\">\r\n\t\t\t\t<hr>\r\n\t\t\t</div>\r\n\t\t\t<div class=\"col-2 text-center\"><label>o</label></div>\r\n\t\t\t<div class=\"col-5\">\r\n\t\t\t\t<hr>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n\r\n\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\r\n\t\t<button (click)=\"clickClose()\" class=\"btn btn-outline-secondary\">Cancelar pago</button>\r\n\t</div>\r\n\t}\r\n\r\n\t@if(isFinalizing) {\r\n\t<div class=\"d-flex flex-column jusitfy-content-center align-items-center mt-2\">\r\n\t\t<h3>Confirmando pago y redirigiendo…</h3>\r\n\t\t<h5>No cierres ni recargues esta página.</h5>\r\n\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t</div>\r\n\t}\r\n\r\n\t} @else {\r\n\t<div class=\"d-flex flex-column justify-content-center align-items-center mt-2\">\r\n\t\t<app-loading-full-ec></app-loading-full-ec>\r\n\t</div>\r\n\t}\r\n</div>"]}
@@ -121,6 +121,14 @@ export class FiltersEcComponent {
121
121
  });
122
122
  }) ?? false;
123
123
  }
124
+ /**
125
+ * Verifica si una categoría tiene la propiedad isVisible y está marcada como visible
126
+ * @param category - La categoría a verificar
127
+ * @returns true si la categoría es visible, false en caso contrario
128
+ */
129
+ hasVisibleProperty(category) {
130
+ return category.isVisible === true;
131
+ }
124
132
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FiltersEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
125
133
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FiltersEcComponent, isStandalone: true, selector: "lib-filters-ec", inputs: { setSelect: "setSelect" }, ngImport: i0, template: "<p>filters-ec works!</p>\r\n", styles: [""] });
126
134
  }
@@ -130,4 +138,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
130
138
  }], ctorParameters: () => [], propDecorators: { setSelect: [{
131
139
  type: Input
132
140
  }] } });
133
- //# 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, Injector } from '@angular/core';\r\nimport { FiltersService , AuthService} from '../../ec-services';\r\nimport { Filter } from '../../classes';\r\nimport { FilterElement, FilterType, PaginationSettings } from '../../interfaces';\r\nimport { ProductsService } from '../../ec-services/products.service';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { Router } from '@angular/router';\r\nimport { PriceRangeFilter } from '../../classes/filters/price_range-filter';\r\nimport { ChannelService } from '../../ec-services/channel.service';\r\n\r\n\r\n@Component({\r\n    selector: 'lib-filters-ec',\r\n    standalone: true,\r\n    imports: [],\r\n    templateUrl: './filters-ec.component.html',\r\n    styleUrl: './filters-ec.component.scss'\r\n})\r\nexport class FiltersEcComponent {\r\n\r\n    private _authService: AuthService = inject(AuthService);\r\n    private _filtersService: FiltersService = inject(FiltersService);\r\n    private _productsService: ProductsService = inject(ProductsService);\r\n    private _constants: CoreConstantsService = inject(CoreConstantsService);\r\n    private router: Router = inject(Router);\r\n    public filters: Filter[] = [];\r\n    public filter$ = this._filtersService.filters$;\r\n    public showPricesOnlyToLoggedUsers: boolean = false;\r\n    public injector: Injector = inject(Injector);\r\n\tpublic isAuthenticated$ = this._authService.isAuthenticated();\r\n    public hidePrices: boolean = false;\r\n    \r\n    @Input() setSelect: any;\r\n\r\n    ngOnInit() {\r\n\r\n    }\r\n\r\n    constructor() {\r\n        this._filtersService.filters$.subscribe((filters: Filter[]) => {\r\n            this.filters = filters;\r\n        });\r\n        this.injector.get(ChannelService).channel$.subscribe(channel => {\r\n            this.showPricesOnlyToLoggedUsers = !!channel.showPricesOnlyToLoggedUsers;\r\n            this.hidePrices = !!channel.hidePrices;\r\n        });\r\n    }\r\n    /** 1) Para cuando me piden 'price_range', devuelvo PriceRangeFilter */\r\n    public getSpecificFilter(type: 'price_range'): PriceRangeFilter | null;\r\n\r\n    /** 2) Para cualquier otro FilterType, devuelvo Filter */\r\n    public getSpecificFilter(type: FilterType): Filter | null;\r\n    public getSpecificFilter(type: FilterType): Filter | null {\r\n        const filter = this.filters.find(f => f.type() === type);\r\n        if (type === 'price_range' && filter && !(filter instanceof Filter)) {\r\n            console.error(`Expected a Filter instance but got`, filter);\r\n        }\r\n        return filter || null;\r\n    }\r\n\r\n    /*Obtiene el filtro elegido en el select, lo pasa al setSelect\r\n    para que se marque seleccionado*/\r\n    onSelect(event: any, filter: FilterElement[] | null) {\r\n        // console.log(filter)\r\n        /*  const selectedOption = filter\r\n             .flatMap(category => category.children)\r\n             .filter(option => option?.code === event.target.value)\r\n             .pop()\r\n         selectedOption && this._filtersService.setFilterSelected(this.filters[0], selectedOption) */\r\n    }\r\n\r\n    setSelected(filter: Filter | null, selected: FilterElement | null) {\r\n        if (!filter || !selected) {\r\n            console.error('Filter or selected element is undefined:', { filter, selected });\r\n            return;\r\n        }\r\n\r\n        if (typeof (filter as any).setSelected !== 'function') {\r\n            console.error('filter.setSelected is not a function. Filter might not be an instance of the expected class:', filter);\r\n            return;\r\n        }\r\n\r\n        try {\r\n            // this._filtersService.setFilterSelected(filter, selected);\r\n            if (filter.type() === 'categories') {\r\n                if (selected.path) {\r\n                    this.router.navigate([selected.path]);\r\n                }\r\n            } else if (filter.type() === 'attributes') {\r\n                // Manejar la navegación para atributos\r\n                this._filtersService.setFilterSelected(filter, selected);\r\n            }\r\n\r\n\r\n        } catch (error) {\r\n            console.error(\"Error while setting selected filter:\", error);\r\n        }\r\n    }\r\n\r\n    uniqueSelection(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            filterElement.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    //  close = () => {\r\n    //       this.document.getElementById(\"filtros\").classList.remove('in');\r\n    //       return true;\r\n    //  };\r\n\r\n\r\n    close = () => {\r\n        // this.consts.mobile()\r\n        //      ? this.document.getElementById(\"accordionExample\").classList.remove('show')\r\n        //      : this.document.getElementById(accordion_id).classList.remove('show');\r\n        return true;\r\n    };\r\n\r\n\r\n    scrollUp = () => {\r\n        window.scroll(0, 0);\r\n        return true\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n    hasAppliedFilters(): boolean {\r\n        return this.filters?.some((filter: any) => {\r\n            if (filter.type?.() === 'price_range') {\r\n                const minSet = filter.currentMinPrice !== null && filter.currentMinPrice !== 0;\r\n                const maxSet = filter.currentMaxPrice !== null && filter.currentMaxPrice !== filter.maxPrice;\r\n                if (minSet || maxSet) {\r\n                    return true;\r\n                }\r\n            }\r\n\r\n            return filter.data?.some((filterElement: any) => {\r\n                if (Array.isArray(filterElement.children)) {\r\n                    return filterElement.children.some((child: any) => child.selected);\r\n                }\r\n                return filterElement.selected;\r\n            });\r\n        }) ?? false;\r\n    }\r\n\r\n}\r\n","<p>filters-ec works!</p>\r\n"]}
141
+ //# 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, Injector } from '@angular/core';\r\nimport { FiltersService , AuthService} from '../../ec-services';\r\nimport { Filter } from '../../classes';\r\nimport { FilterElement, FilterType, PaginationSettings } from '../../interfaces';\r\nimport { ProductsService } from '../../ec-services/products.service';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { Router } from '@angular/router';\r\nimport { PriceRangeFilter } from '../../classes/filters/price_range-filter';\r\nimport { ChannelService } from '../../ec-services/channel.service';\r\n\r\n\r\n@Component({\r\n    selector: 'lib-filters-ec',\r\n    standalone: true,\r\n    imports: [],\r\n    templateUrl: './filters-ec.component.html',\r\n    styleUrl: './filters-ec.component.scss'\r\n})\r\nexport class FiltersEcComponent {\r\n\r\n    private _authService: AuthService = inject(AuthService);\r\n    private _filtersService: FiltersService = inject(FiltersService);\r\n    private _productsService: ProductsService = inject(ProductsService);\r\n    private _constants: CoreConstantsService = inject(CoreConstantsService);\r\n    private router: Router = inject(Router);\r\n    public filters: Filter[] = [];\r\n    public filter$ = this._filtersService.filters$;\r\n    public showPricesOnlyToLoggedUsers: boolean = false;\r\n    public injector: Injector = inject(Injector);\r\n\tpublic isAuthenticated$ = this._authService.isAuthenticated();\r\n    public hidePrices: boolean = false;\r\n    \r\n    @Input() setSelect: any;\r\n\r\n    ngOnInit() {\r\n\r\n    }\r\n\r\n    constructor() {\r\n        this._filtersService.filters$.subscribe((filters: Filter[]) => {\r\n            this.filters = filters;\r\n        });\r\n        this.injector.get(ChannelService).channel$.subscribe(channel => {\r\n            this.showPricesOnlyToLoggedUsers = !!channel.showPricesOnlyToLoggedUsers;\r\n            this.hidePrices = !!channel.hidePrices;\r\n        });\r\n    }\r\n    /** 1) Para cuando me piden 'price_range', devuelvo PriceRangeFilter */\r\n    public getSpecificFilter(type: 'price_range'): PriceRangeFilter | null;\r\n\r\n    /** 2) Para cualquier otro FilterType, devuelvo Filter */\r\n    public getSpecificFilter(type: FilterType): Filter | null;\r\n    public getSpecificFilter(type: FilterType): Filter | null {\r\n        const filter = this.filters.find(f => f.type() === type);\r\n        if (type === 'price_range' && filter && !(filter instanceof Filter)) {\r\n            console.error(`Expected a Filter instance but got`, filter);\r\n        }\r\n        return filter || null;\r\n    }\r\n\r\n    /*Obtiene el filtro elegido en el select, lo pasa al setSelect\r\n    para que se marque seleccionado*/\r\n    onSelect(event: any, filter: FilterElement[] | null) {\r\n        // console.log(filter)\r\n        /*  const selectedOption = filter\r\n             .flatMap(category => category.children)\r\n             .filter(option => option?.code === event.target.value)\r\n             .pop()\r\n         selectedOption && this._filtersService.setFilterSelected(this.filters[0], selectedOption) */\r\n    }\r\n\r\n    setSelected(filter: Filter | null, selected: FilterElement | null) {\r\n        if (!filter || !selected) {\r\n            console.error('Filter or selected element is undefined:', { filter, selected });\r\n            return;\r\n        }\r\n\r\n        if (typeof (filter as any).setSelected !== 'function') {\r\n            console.error('filter.setSelected is not a function. Filter might not be an instance of the expected class:', filter);\r\n            return;\r\n        }\r\n\r\n        try {\r\n            // this._filtersService.setFilterSelected(filter, selected);\r\n            if (filter.type() === 'categories') {\r\n                if (selected.path) {\r\n                    this.router.navigate([selected.path]);\r\n                }\r\n            } else if (filter.type() === 'attributes') {\r\n                // Manejar la navegación para atributos\r\n                this._filtersService.setFilterSelected(filter, selected);\r\n            }\r\n\r\n\r\n        } catch (error) {\r\n            console.error(\"Error while setting selected filter:\", error);\r\n        }\r\n    }\r\n\r\n    uniqueSelection(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            filterElement.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    //  close = () => {\r\n    //       this.document.getElementById(\"filtros\").classList.remove('in');\r\n    //       return true;\r\n    //  };\r\n\r\n\r\n    close = () => {\r\n        // this.consts.mobile()\r\n        //      ? this.document.getElementById(\"accordionExample\").classList.remove('show')\r\n        //      : this.document.getElementById(accordion_id).classList.remove('show');\r\n        return true;\r\n    };\r\n\r\n\r\n    scrollUp = () => {\r\n        window.scroll(0, 0);\r\n        return true\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n    hasAppliedFilters(): boolean {\r\n        return this.filters?.some((filter: any) => {\r\n            if (filter.type?.() === 'price_range') {\r\n                const minSet = filter.currentMinPrice !== null && filter.currentMinPrice !== 0;\r\n                const maxSet = filter.currentMaxPrice !== null && filter.currentMaxPrice !== filter.maxPrice;\r\n                if (minSet || maxSet) {\r\n                    return true;\r\n                }\r\n            }\r\n\r\n            return filter.data?.some((filterElement: any) => {\r\n                if (Array.isArray(filterElement.children)) {\r\n                    return filterElement.children.some((child: any) => child.selected);\r\n                }\r\n                return filterElement.selected;\r\n            });\r\n        }) ?? false;\r\n    }\r\n/**\r\n   * Verifica si una categoría tiene la propiedad isVisible y está marcada como visible\r\n   * @param category - La categoría a verificar\r\n   * @returns true si la categoría es visible, false en caso contrario\r\n   */\r\n    hasVisibleProperty(category: FilterElement): boolean {\r\n        return (category as any).isVisible === true;\r\n    }\r\n}\r\n","<p>filters-ec works!</p>\r\n"]}