ng-easycommerce-v18 0.2.29 → 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.
- package/README.md +45 -0
- package/assets/ec-i18n/ct.json +1 -0
- package/assets/ec-i18n/en.json +88 -83
- package/assets/ec-i18n/es.json +6 -1
- package/assets/ec-i18n/fr.json +1 -0
- package/assets/ec-i18n/gl.json +1 -0
- package/assets/ec-i18n/pr.json +1 -0
- package/esm2022/lib/classes/component-helper.mjs +11 -2
- package/esm2022/lib/constants/core.constants.service.mjs +107 -2
- package/esm2022/lib/ec-components/abstractions-components/menu-ec.component.mjs +9 -1
- package/esm2022/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.mjs +5 -1
- package/esm2022/lib/ec-components/auth-ec/register-form-ec/register-form-ec.component.mjs +5 -1
- package/esm2022/lib/ec-components/blocks-ec/block-newsletter-ec/block-newsletter-ec.component.mjs +9 -3
- package/esm2022/lib/ec-components/cart-ec/cart-ec.component.mjs +8 -2
- package/esm2022/lib/ec-components/cart-ec/cart-item-ec/cart-item-ec.component.mjs +42 -10
- package/esm2022/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.mjs +141 -75
- package/esm2022/lib/ec-components/filters-ec/filters-ec.component.mjs +9 -1
- package/esm2022/lib/ec-components/header-ec/header-ec.component.mjs +53 -2
- package/esm2022/lib/ec-components/product-detail-ec/product-detail-ec.component.mjs +23 -15
- package/esm2022/lib/ec-components/product-ec/product-ec.component.mjs +143 -5
- package/esm2022/lib/ec-components/widgets-ec/decidir-ec/decidir-ec.component.mjs +3 -3
- package/esm2022/lib/ec-components/widgets-ec/index.mjs +2 -1
- package/esm2022/lib/ec-components/widgets-ec/redsys-catch-ec/redsys-catch-ec.component.mjs +193 -0
- package/esm2022/lib/ec-services/cart.service.mjs +23 -5
- package/esm2022/lib/ec-services/checkout.service.mjs +46 -21
- package/esm2022/lib/ec-services/form.service.mjs +13 -1
- package/esm2022/lib/ec-services/order-utility.service.mjs +12 -6
- package/esm2022/lib/ec-services/product-detail.service.mjs +11 -1
- package/esm2022/lib/interfaces/environment.mjs +1 -1
- package/esm2022/lib/interfaces/product.mjs +1 -1
- package/fesm2022/ng-easycommerce-v18.mjs +843 -147
- package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
- package/lib/classes/component-helper.d.ts +1 -1
- package/lib/constants/core.constants.service.d.ts +24 -0
- package/lib/ec-components/abstractions-components/menu-ec.component.d.ts +6 -0
- package/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.d.ts +2 -0
- package/lib/ec-components/auth-ec/register-form-ec/register-form-ec.component.d.ts +2 -0
- package/lib/ec-components/cart-ec/cart-ec.component.d.ts +3 -0
- package/lib/ec-components/cart-ec/cart-item-ec/cart-item-ec.component.d.ts +6 -1
- package/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.d.ts +38 -16
- package/lib/ec-components/filters-ec/filters-ec.component.d.ts +6 -0
- package/lib/ec-components/header-ec/header-ec.component.d.ts +16 -2
- package/lib/ec-components/product-detail-ec/product-detail-ec.component.d.ts +2 -1
- package/lib/ec-components/product-ec/product-ec.component.d.ts +14 -1
- package/lib/ec-components/widgets-ec/index.d.ts +1 -0
- package/lib/ec-components/widgets-ec/redsys-catch-ec/redsys-catch-ec.component.d.ts +47 -0
- package/lib/ec-services/cart.service.d.ts +1 -1
- package/lib/ec-services/form.service.d.ts +6 -0
- package/lib/interfaces/environment.d.ts +1 -0
- package/lib/interfaces/product.d.ts +6 -0
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, inject } from '@angular/core';
|
|
1
|
+
import { Component, inject, Injector } from '@angular/core';
|
|
2
2
|
import { Router } from '@angular/router';
|
|
3
3
|
import { CartService, ToastService, AuthService, ChannelService } from '../../ec-services';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -17,13 +17,19 @@ export class CartEcComponent {
|
|
|
17
17
|
isAuthenticated$ = this._authService.isAuthenticated();
|
|
18
18
|
getTotalAmount = this._cartService.getTotalAmount();
|
|
19
19
|
couponCode$ = this._cartService.getCouponCode();
|
|
20
|
+
hideTaxes = false;
|
|
21
|
+
injector;
|
|
20
22
|
constructor() {
|
|
21
23
|
//console.log("constructo.....");
|
|
24
|
+
this.injector = inject(Injector);
|
|
22
25
|
this._channelService.channel$.subscribe((res) => {
|
|
23
26
|
//console.log("construct")
|
|
24
27
|
this.channel = res;
|
|
25
28
|
//this.initializeSteps();
|
|
26
29
|
});
|
|
30
|
+
this.injector.get(ChannelService).channel$.subscribe(channel => {
|
|
31
|
+
this.hideTaxes = !!channel.hideTaxes;
|
|
32
|
+
});
|
|
27
33
|
}
|
|
28
34
|
removeCoupon() {
|
|
29
35
|
// console.log(this.couponCode$)
|
|
@@ -67,4 +73,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
67
73
|
type: Component,
|
|
68
74
|
args: [{ selector: 'lib-cart-ec', standalone: true, imports: [], template: "<p>cart-ec works!</p>\r\n" }]
|
|
69
75
|
}], ctorParameters: () => [] });
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FydC1lYy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lYXN5Y29tbWVyY2UtdjE4L3NyYy9saWIvZWMtY29tcG9uZW50cy9jYXJ0LWVjL2NhcnQtZWMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvY2FydC1lYy9jYXJ0LWVjLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM1RCxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1CQUFtQixDQUFDOztBQVUzRixNQUFNLE9BQU8sZUFBZTtJQUNuQixlQUFlLEdBQW1CLE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUMxRCxPQUFPLENBQU07SUFFWixjQUFjLEdBQWlCLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUVwRCxZQUFZLEdBQWdCLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUNqRCxNQUFNLEdBQVcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBRWhDLFVBQVUsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQztJQUMxQyxlQUFlLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO0lBQ3hELHFCQUFxQixHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsdUJBQXVCLEVBQUUsQ0FBQztJQUNwRSxZQUFZLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUNsRCxZQUFZLEdBQUcsSUFB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Y3QsIEluamVjdG9yIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7IENhcnRTZXJ2aWNlLCBUb2FzdFNlcnZpY2UsIEF1dGhTZXJ2aWNlLCBDaGFubmVsU2VydmljZSB9IGZyb20gJy4uLy4uL2VjLXNlcnZpY2VzJztcclxuaW1wb3J0IHsgQ29yZUNvbnN0YW50c1NlcnZpY2UgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcblx0c2VsZWN0b3I6ICdsaWItY2FydC1lYycsXHJcblx0c3RhbmRhbG9uZTogdHJ1ZSxcclxuXHRpbXBvcnRzOiBbXSxcclxuXHR0ZW1wbGF0ZVVybDogJy4vY2FydC1lYy5jb21wb25lbnQuaHRtbCcsXHJcblx0c3R5bGVVcmw6ICcuL2NhcnQtZWMuY29tcG9uZW50LnNjc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDYXJ0RWNDb21wb25lbnQge1xyXG5cdHByaXZhdGUgX2NoYW5uZWxTZXJ2aWNlOiBDaGFubmVsU2VydmljZSA9IGluamVjdChDaGFubmVsU2VydmljZSk7XHJcblx0cHVibGljIGNoYW5uZWw6IGFueTtcclxuXHJcblx0cHJpdmF0ZSBfdG9hc3RyU2VydmljZTogVG9hc3RTZXJ2aWNlID0gaW5qZWN0KFRvYXN0U2VydmljZSk7XHJcblxyXG5cdHByaXZhdGUgX2NhcnRTZXJ2aWNlOiBDYXJ0U2VydmljZSA9IGluamVjdChDYXJ0U2VydmljZSk7XHJcblx0cHVibGljIHJvdXRlcjogUm91dGVyID0gaW5qZWN0KFJvdXRlcik7XHJcblxyXG5cdHB1YmxpYyBjYXJ0SXRlbXMkID0gdGhpcy5fY2FydFNlcnZpY2UuY2FydEl0ZW1zJDtcclxuXHRwdWJsaWMgc3ViVG90YWxBbW91bnQkID0gdGhpcy5fY2FydFNlcnZpY2UuZ2V0U3ViVG90YWxBbW91bnQoKTtcclxuXHRwdWJsaWMgdG90YWxQcm9tb3Rpb25BbW91bnQkID0gdGhpcy5fY2FydFNlcnZpY2UuZ2V0VG90YWxQcm9tb3Rpb25BbW91bnQoKTtcclxuXHRwdWJsaWMgdGF4ZXNBbW91bnQkID0gdGhpcy5fY2FydFNlcnZpY2UuZ2V0VGF4ZXNBbW91bnQoKTtcclxuXHRwdWJsaWMgdG90YWxBbW91bnQkID0gdGhpcy5fY2FydFNlcnZpY2UuZ2V0VG90YWxBbW91bnQoKTtcclxuXHJcblx0cHJpdmF0ZSBfYXV0aFNlcnZpY2U6IEF1dGhTZXJ2aWNlID0gaW5qZWN0KEF1dGhTZXJ2aWNlKVxyXG5cclxuXHRwdWJsaWMgaXNBdXRoZW50aWNhdGVkJCA9IHRoaXMuX2F1dGhTZXJ2aWNlLmlzQXV0aGVudGljYXRlZCgpO1xyXG5cdHB1YmxpYyBnZXRUb3RhbEFtb3VudCA9IHRoaXMuX2NhcnRTZXJ2aWNlLmdldFRvdGFsQW1vdW50KCk7XHJcblxyXG5cdHB1YmxpYyBjb3Vwb25Db2RlJCA9IHRoaXMuX2NhcnRTZXJ2aWNlLmdldENvdXBvbkNvZGUoKTtcclxuXHJcblx0cHVibGljIGhpZGVUYXhlczogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuXHRwdWJsaWMgaW5qZWN0b3I6IEluamVjdG9yO1xyXG5cclxuXHRjb25zdHJ1Y3RvcigpIHtcclxuXHRcdC8vY29uc29sZS5sb2coXCJjb25zdHJ1Y3RvLi4uLi5cIik7XHJcblx0XHR0aGlzLmluamVjdG9yID0gaW5qZWN0KEluamVjdG9yKTtcclxuXHRcdHRoaXMuX2NoYW5uZWxTZXJ2aWNlLmNoYW5uZWwkLnN1YnNjcmliZShcclxuXHRcdFx0KHJlczogYW55KSA9PiB7XHJcblx0XHRcdFx0Ly9jb25zb2xlLmxvZyhcImNvbnN0cnVjdFwiKVxyXG5cdFx0XHRcdHRoaXMuY2hhbm5lbCA9IHJlcztcclxuXHRcdFx0XHQvL3RoaXMuaW5pdGlhbGl6ZVN0ZXBzKCk7XHJcblx0XHRcdH1cclxuXHRcdClcclxuXHRcdHRoaXMuaW5qZWN0b3IuZ2V0KENoYW5uZWxTZXJ2aWNlKS5jaGFubmVsJC5zdWJzY3JpYmUoY2hhbm5lbCA9PiB7XHJcblx0XHRcdHRoaXMuaGlkZVRheGVzID0gISFjaGFubmVsLmhpZGVUYXhlcztcclxuXHRcdH0pO1xyXG5cdH1cclxuXHQgXHJcblx0cmVtb3ZlQ291cG9uKCkge1xyXG5cdFx0Ly8gY29uc29sZS5sb2codGhpcy5jb3Vwb25Db2RlJClcclxuXHRcdHRoaXMuX2NhcnRTZXJ2aWNlLnJlbW92ZUNvdXBvbigpXHJcblx0fVxyXG5cclxuXHRyZWRpcmVjdENoZWNrb3V0KCk6IGJvb2xlYW4ge1xyXG5cdFx0aWYgKHRoaXMuX2NhcnRTZXJ2aWNlLmhhc1N1ZmZpY2llbnRDcmVkaXRzRm9yQ2FydFRvdGFsKCkpIHtcclxuXHRcdFx0dGhpcy5yb3V0ZXIubmF2aWdhdGVCeVVybChgL2NoZWNrb3V0YCk7XHJcblx0XHRcdHJldHVybiB0cnVlO1xyXG5cdFx0fSBlbHNlIHtcclxuXHRcdFx0Y29uc29sZS53YXJuKFwiTm8gc2UgcHVlZGUgcmVkaXJpZ2lyIGFsIGNoZWNrb3V0IGRlYmlkbyBhIHVuYSB2YWxpZGFjacOzbiBmYWxsaWRhLlwiKTtcclxuXHRcdFx0cmV0dXJuIGZhbHNlO1xyXG5cdFx0fVxyXG5cdH1cclxuXHJcblx0Z2V0TWluaW11bVB1cmNoYXNlQW1vdW50ID0gKCkgPT4ge1xyXG5cdFx0cmV0dXJuIHRoaXMuY2hhbm5lbC50eXBlID09ICdiMmInID8gdGhpcy5jaGFubmVsLndob2xlc2FsZXJNaW5pbXVtUHVyY2hhc2VBbW91bnQgOiB0aGlzLmNoYW5uZWwucmV0YWlsZXJNaW5pbXVtUHVyY2hhc2VBbW91bnRcclxuXHJcblx0fVxyXG5cdGV4Y2VlZHNNaW5pbXVtQW1vdW50ID0gKHZhbHVlOiBudW1iZXIpID0+IHtcclxuXHRcdGlmICh2YWx1ZSA+PSB0aGlzLmdldE1pbmltdW1QdXJjaGFzZUFtb3VudCgpKSB7XHJcblx0XHRcdHRoaXMucm91dGVyLm5hdmlnYXRlKFsnL2NoZWNrb3V0J10pO1xyXG5cdFx0XHRyZXR1cm4gdHJ1ZTtcclxuXHRcdH0gZWxzZSB7XHJcblx0XHRcdHRoaXMuX3RvYXN0clNlcnZpY2Uuc2hvdygncXVhbnRpdHktbm90LWV4Y2VlZGVkJywgeyBhbW91bnQ6IHRoaXMuZ2V0TWluaW11bVB1cmNoYXNlQW1vdW50KCkgfSk7XHJcblx0XHRcdHJldHVybiBmYWxzZTtcclxuXHRcdH1cclxuXHR9XHJcblx0cmV0dXJuQm9vbGVhbk1pbmltdW1BbW91bnQgPSAodmFsdWU6IG51bWJlcik6IGJvb2xlYW4gPT4ge1xyXG5cdFx0aWYgKHZhbHVlID49IHRoaXMuZ2V0TWluaW11bVB1cmNoYXNlQW1vdW50KCkpIHtcclxuXHRcdFx0cmV0dXJuIHRydWU7XHJcblx0XHR9IGVsc2Uge1xyXG5cdFx0XHRyZXR1cm4gZmFsc2U7XHJcblx0XHR9XHJcblx0fVxyXG5cclxufVxyXG4iLCI8cD5jYXJ0LWVjIHdvcmtzITwvcD5cclxuIl19
|
|
@@ -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
|
-
|
|
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
|
-
|
|
41
|
+
plus(stock, value = 1) {
|
|
35
42
|
if (this.isQuantityUpdating)
|
|
36
43
|
return;
|
|
37
44
|
this.isQuantityUpdating = true;
|
|
38
|
-
let
|
|
39
|
-
|
|
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
|
-
|
|
60
|
+
less(stock, value = 1) {
|
|
43
61
|
if (this.isQuantityUpdating)
|
|
44
62
|
return;
|
|
45
63
|
this.isQuantityUpdating = true;
|
|
46
|
-
let
|
|
47
|
-
|
|
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
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
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.
|
|
24
|
-
|
|
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
|
-
|
|
32
|
-
|
|
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.
|
|
36
|
-
|
|
37
|
-
this.
|
|
38
|
-
this.
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
this.
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
this.
|
|
55
|
-
this.
|
|
56
|
-
|
|
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.
|
|
69
|
-
|
|
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
|
-
|
|
77
|
-
|
|
78
|
-
|
|
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
|
-
|
|
82
|
-
|
|
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 = (
|
|
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\
|
|
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\
|
|
110
|
-
}],
|
|
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":"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","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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAU,MAAM,EAAE,WAAW,EAAa,MAAM,eAAe,CAAC;AAC/G,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;;AAYpD,MAAM,OAAO,qBAAqB;IAEzB,eAAe,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;IACzC,aAAa,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC;IACrC,UAAU,GAAQ,MAAM,CAAC,WAAW,CAAC,CAAC;IACtC,QAAQ,GAAG,KAAK,CAAC;IAEhB,MAAM,GAAG,IAAI,CAAC;IACd,YAAY,GAAG,CAAC,CAAC;IACjB,OAAO,CAAM;IACZ,KAAK,GAAG,IAAI,YAAY,EAAW,CAAC;IAEpC,UAAU,CAAM;IACnB,GAAG,CAAU;IAEpB,cAAc;IACP,KAAK,GAAU,MAAM,CAAC;IAC7B,IAAI,MAAM,KAAK,OAAO,IAAI,CAAC,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC;IAC9C,IAAI,QAAQ,KAAK,OAAO,IAAI,CAAC,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC;IAClD,IAAI,YAAY,KAAK,OAAO,IAAI,CAAC,KAAK,KAAK,YAAY,CAAC,CAAC,CAAC;IAElD,OAAO,GAAkB,IAAI,CAAC;IAC9B,SAAS,CAAU;IACnB,GAAG,GAAG,EAAE,CAAC;IACT,EAAE,CAAoB;IACtB,SAAS,CAAO;IAChB,aAAa,GAAG,CAAC,CAAC;IAE1B,QAAQ;QACP,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACxC,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC;YAExB,IAAI,kBAAkB,IAAI,MAAM,EAAE,CAAC;gBAClC,IAAI,CAAC,EAAE,GAAG,IAAI,gBAAgB,CAAC,YAAY,CAAC,CAAC;gBAC7C,IAAI,CAAC,EAAE,CAAC,SAAS,GAAG,CAAC,CAAe,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;YACpE,CAAC;YAED,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;YACnD,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QAC1D,CAAC;QAED,IAAI,CAAC,aAAa,EAAE,CAAC;IACtB,CAAC;IAED,WAAW;QACV,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC;YAAE,OAAO;QAChD,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,CAAC;QACjB,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QACtD,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QAC5D,IAAI,IAAI,CAAC,SAAS;YAAE,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACnD,CAAC;IAED,2EAA2E;IAC3E,UAAU,GAAG,GAAG,EAAE;QACjB,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;IAChC,CAAC,CAAA;IAED;;;;OAIG;IACH,OAAO,GAAG,GAAG,EAAE;QACd,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,GAAG;YAAE,OAAO;QAEhF,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC;QACtB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QACzB,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAE9B,YAAY,CAAC,OAAO,CAAC,QAAQ,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QAEzC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAEvD,2DAA2D;QAC3D,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;YAC1C,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC;YACxC,OAAO;QACR,CAAC;QAED,+CAA+C;QAC/C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAChC,IAAI,IAAI,CAAC,SAAS;YAAE,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAClD,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC,GAAG,EAAE;YACjC,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,aAAa,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,CAAC;gBACtD,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;gBAC9B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;gBACtB,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC;gBACpB,IAAI,CAAC,YAAY,CAAC,+CAA+C,CAAC,CAAC;gBACnE,OAAO;YACR,CAAC;YACD,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC9B,CAAC,EAAE,IAAI,CAAC,CAAC;IACV,CAAC,CAAA;IAEO,eAAe,GAAG,CAAC,KAAmB,EAAE,EAAE;QACjD,MAAM,IAAI,GAAG,KAAK,EAAE,IAAI,CAAC;QACzB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IACxB,CAAC,CAAA;IAEO,SAAS,GAAG,CAAC,CAAe,EAAE,EAAE;QACvC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG;YAAE,OAAO;QAChC,IAAI,CAAC,CAAC,GAAG,KAAK,YAAY,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC;YACpD,MAAM,KAAK,GAAG,CAAC,CAAC,QAAmB,CAAC;YACpC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAC7B,CAAC;IACF,CAAC,CAAA;IAEO,WAAW,GAAG,CAAC,IAAS,EAAE,EAAE;QACnC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU;YAAE,OAAO;QAC9C,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,CAAC,GAAG;YAAE,OAAO;QAClC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAgB,CAAC,CAAC;IAC7C,CAAC,CAAA;IAEO,qBAAqB;QAC5B,IAAI,CAAC,IAAI,CAAC,GAAG;YAAE,OAAO;QACtB,MAAM,KAAK,GAAG,YAAY,CAAC,OAAO,CAAC,YAAY,IAAI,CAAC,GAAG,EAAE,CAAmB,CAAC;QAC7E,IAAI,KAAK;YAAE,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAED,uEAAuE;IAC/D,eAAe,CAAC,KAAc;QACrC,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QAErB,IAAI,IAAI,CAAC,SAAS;YAAE,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAClD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QAEtB,YAAY,CAAC,UAAU,CAAC,YAAY,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;QAChD,YAAY,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QAClC,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAEjC,IAAI,CAAC;YAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QAAC,CAAC;QAAC,MAAM,CAAC,CAAC,CAAC;QAC/E,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QAEpB,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YAChD,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC;YAC1B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACvB,CAAC;aAAM,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,QAAQ,EAAE,CAAC;YACtD,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC;YACpB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,qCAAqC,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QACvG,CAAC;aAAM,CAAC;YACP,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC;YACpB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAC1C,CAAC;IACF,CAAC;IAEO,MAAM;QACb,OAAO,MAAM,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;IACrE,CAAC;IAEO,YAAY,GAAG,CAAC,GAAW,EAAE,EAAE;QACtC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,IAAI,eAAe,CAAC,CAAC;IACjD,CAAC,CAAA;IAED,sDAAsD;IACtD,iBAAiB,GAAG,GAAG,EAAE;QACxB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC;YAAE,OAAO;QAChD,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QACjC,MAAM,GAAG,GAAG,YAAY,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QAC3C,IAAI,GAAG;YAAE,YAAY,CAAC,UAAU,CAAC,YAAY,GAAG,EAAE,CAAC,CAAC;IACrD,CAAC,CAAA;IAED,8DAA8D;IACtD,aAAa,GAAG,GAAS,EAAE;QAClC,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CACpD,CAAC,GAAG,EAAE,EAAE;YACP,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;YACtB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,UAAU,EAAE,UAAU,CAAC;YACvC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAChC,CAAC,EACD,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CACtC,CAAC;IACH,CAAC,CAAC;IAEM,QAAQ,GAAG,CAAC,OAAY,EAAE,EAAE;QACnC,uBAAuB;IACxB,CAAC,CAAA;IAEO,QAAQ,GAAG,CAAC,KAAU,EAAQ,EAAE,GAAc,CAAC,CAAC;wGAnL5C,qBAAqB;4FAArB,qBAAqB,2LCflC,08CA4CM,0DD/BK,sBAAsB;;4FAEpB,qBAAqB;kBAPjC,SAAS;+BACC,oBAAoB,cAClB,IAAI,WAGP,CAAC,sBAAsB,CAAC;8BASxB,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, 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>"]}
|