ng-easycommerce-v18 0.3.14-beta.2 → 0.3.15-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 (30) hide show
  1. package/README.md +9 -4
  2. package/esm2022/lib/classes/filters/filter.mjs +2 -27
  3. package/esm2022/lib/constants/api.constants.service.mjs +44 -41
  4. package/esm2022/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.mjs +5 -1
  5. package/esm2022/lib/ec-components/auth-ec/register-form-ec/register-form-ec.component.mjs +5 -1
  6. package/esm2022/lib/ec-components/blocks-ec/block-products-ec/block-products-ec.component.mjs +3 -5
  7. package/esm2022/lib/ec-components/cart-ec/cart-item-ec/cart-item-ec.component.mjs +6 -2
  8. package/esm2022/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.mjs +79 -9
  9. package/esm2022/lib/ec-components/header-ec/header-ec.component.mjs +45 -34
  10. package/esm2022/lib/ec-components/product-ec/product-ec.component.mjs +95 -5
  11. package/esm2022/lib/ec-components/related-products-ec/related-products-ec.component.mjs +4 -6
  12. package/esm2022/lib/ec-components/widgets-ec/index.mjs +2 -1
  13. package/esm2022/lib/ec-components/widgets-ec/magnizoom-ec/magnizoom-ec.component.mjs +2 -4
  14. package/esm2022/lib/ec-components/widgets-ec/redsys-catch-ec/redsys-catch-ec.component.mjs +246 -0
  15. package/esm2022/lib/ec-services/analytics/facebook-pixel.service.mjs +2 -4
  16. package/esm2022/lib/ec-services/analytics/google-analytics.service.mjs +2 -4
  17. package/esm2022/lib/ec-services/options.service.mjs +3 -27
  18. package/fesm2022/ng-easycommerce-v18.mjs +536 -173
  19. package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
  20. package/lib/constants/api.constants.service.d.ts +24 -13
  21. package/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.d.ts +2 -0
  22. package/lib/ec-components/auth-ec/register-form-ec/register-form-ec.component.d.ts +2 -0
  23. package/lib/ec-components/cart-ec/cart-item-ec/cart-item-ec.component.d.ts +5 -0
  24. package/lib/ec-components/checkout-ec/payment-ec/payment-methods/mp-redirect-ec/mp-redirect-ec.component.d.ts +4 -0
  25. package/lib/ec-components/header-ec/header-ec.component.d.ts +5 -1
  26. package/lib/ec-components/product-ec/product-ec.component.d.ts +10 -1
  27. package/lib/ec-components/widgets-ec/index.d.ts +1 -0
  28. package/lib/ec-components/widgets-ec/redsys-catch-ec/redsys-catch-ec.component.d.ts +35 -0
  29. package/lib/ec-services/options.service.d.ts +0 -4
  30. package/package.json +1 -1
@@ -0,0 +1,246 @@
1
+ import { Component, Inject, PLATFORM_ID } from '@angular/core';
2
+ import { combineLatest } from 'rxjs';
3
+ import { ComponentHelper } from '../../../classes/component-helper';
4
+ import { CommonModule, isPlatformBrowser } from '@angular/common';
5
+ import { DOCUMENT } from '@angular/common';
6
+ import { LoadingFullEcComponent } from '../loading/loading-full-ec/loading-full-ec.component';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/router";
9
+ import * as i2 from "../../../ec-services";
10
+ import * as i3 from "@angular/common";
11
+ export class RedsysCatchEcComponent extends ComponentHelper {
12
+ activedRoute;
13
+ router;
14
+ checkoutService;
15
+ renderer;
16
+ elementRef;
17
+ document;
18
+ platformId;
19
+ message = '';
20
+ subscription = null;
21
+ isMobile = false;
22
+ sessionId = '';
23
+ constructor(activedRoute, router, checkoutService, renderer, elementRef, document, platformId) {
24
+ super();
25
+ this.activedRoute = activedRoute;
26
+ this.router = router;
27
+ this.checkoutService = checkoutService;
28
+ this.renderer = renderer;
29
+ this.elementRef = elementRef;
30
+ this.document = document;
31
+ this.platformId = platformId;
32
+ if (isPlatformBrowser(this.platformId)) {
33
+ this.detectMobile();
34
+ this.sessionId = this.generateSessionId();
35
+ // Verificar si debe procesar esta pestaña
36
+ if (this.shouldProcessPayment()) {
37
+ this.hideHeaderFooter();
38
+ }
39
+ else {
40
+ // Si no debe procesar, cerrar esta pestaña y redirigir a la principal
41
+ this.closeRedundantTab();
42
+ return;
43
+ }
44
+ }
45
+ this.ecOnConstruct();
46
+ }
47
+ detectMobile() {
48
+ if (isPlatformBrowser(this.platformId) && typeof window !== 'undefined') {
49
+ const userAgent = window.navigator.userAgent.toLowerCase();
50
+ this.isMobile = /android|webos|iphone|ipad|ipod|blackberry|iemobile|opera mini|mobile/i.test(userAgent) ||
51
+ (window.innerWidth <= 768);
52
+ }
53
+ }
54
+ generateSessionId() {
55
+ return `catch_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
56
+ }
57
+ shouldProcessPayment() {
58
+ if (!isPlatformBrowser(this.platformId)) {
59
+ return false; // En el servidor no procesar
60
+ }
61
+ if (!this.isMobile) {
62
+ return true; // En desktop siempre procesar
63
+ }
64
+ // En mobile, verificar si ya hay otra pestaña procesando
65
+ const processingTab = localStorage.getItem('mp_processing_tab');
66
+ const currentTime = Date.now();
67
+ const processingTabTime = localStorage.getItem('mp_processing_tab_time');
68
+ // Si no hay pestaña procesando o la anterior es muy antigua (más de 30 segundos)
69
+ if (!processingTab || !processingTabTime || (currentTime - parseInt(processingTabTime)) > 30000) {
70
+ // Esta pestaña será la que procese
71
+ localStorage.setItem('mp_processing_tab', this.sessionId);
72
+ localStorage.setItem('mp_processing_tab_time', currentTime.toString());
73
+ return true;
74
+ }
75
+ // Si ya hay otra pestaña procesando
76
+ return processingTab === this.sessionId;
77
+ }
78
+ closeRedundantTab() {
79
+ console.log('Cerrando pestaña redundante...');
80
+ // Intentar cerrar la pestaña
81
+ if (isPlatformBrowser(this.platformId) && typeof window !== 'undefined') {
82
+ // Redirigir a la página principal en lugar de cerrar
83
+ window.location.href = '/checkout/order_success';
84
+ }
85
+ }
86
+ ngOnInit() {
87
+ this.subscription = combineLatest([
88
+ this.activedRoute.params,
89
+ this.activedRoute.queryParams
90
+ ]).subscribe(([queryRouter, queryParams]) => {
91
+ let state;
92
+ state = queryRouter['state'];
93
+ if (state && state === 'statuspayment') {
94
+ state = queryParams['status'];
95
+ }
96
+ console.log('PARAMETROS STATE -> ', state);
97
+ this.handlePaymentState(state, queryParams);
98
+ });
99
+ this.ecOnInit();
100
+ }
101
+ ngOnDestroy() {
102
+ if (this.subscription) {
103
+ this.subscription.unsubscribe();
104
+ }
105
+ this.showHeaderFooter();
106
+ // Limpiar marcadores de mobile si esta pestaña estaba procesando
107
+ if (this.isMobile && isPlatformBrowser(this.platformId)) {
108
+ const processingTab = localStorage.getItem('mp_processing_tab');
109
+ if (processingTab === this.sessionId) {
110
+ localStorage.removeItem('mp_processing_tab');
111
+ localStorage.removeItem('mp_processing_tab_time');
112
+ }
113
+ }
114
+ // this.ecOnDestroy(); // Removido si no existe en ComponentHelper
115
+ }
116
+ hideHeaderFooter() {
117
+ // Usar Renderer2 en lugar de jQuery para manipular el DOM
118
+ const header = this.document.querySelector('header');
119
+ const footer = this.document.querySelector('footer');
120
+ if (header) {
121
+ this.renderer.setStyle(header, 'display', 'none');
122
+ }
123
+ if (footer) {
124
+ this.renderer.setStyle(footer, 'display', 'none');
125
+ }
126
+ }
127
+ showHeaderFooter() {
128
+ // Restaurar la visibilidad al destruir el componente
129
+ const header = this.document.querySelector('header');
130
+ const footer = this.document.querySelector('footer');
131
+ if (header) {
132
+ this.renderer.removeStyle(header, 'display');
133
+ }
134
+ if (footer) {
135
+ this.renderer.removeStyle(footer, 'display');
136
+ }
137
+ }
138
+ handlePaymentState(state, queryParams) {
139
+ // Solo procesar el estado si esta pestaña está autorizada
140
+ if (this.isMobile && !this.shouldProcessPayment()) {
141
+ console.log('Pestaña no autorizada para procesar el pago, redirigiendo...');
142
+ this.closeRedundantTab();
143
+ return;
144
+ }
145
+ switch (state) {
146
+ case '200':
147
+ this.setStateInLocal('Su pago fue procesado con éxito.', 'success');
148
+ this.storeTotalAmount(queryParams);
149
+ this.redirectToSuccess();
150
+ break;
151
+ case 'success':
152
+ this.setStateInLocal('Su pago fue procesado con éxito.', state);
153
+ this.storeTotalAmount(queryParams);
154
+ this.redirectToSuccess();
155
+ break;
156
+ case 'pending':
157
+ this.setStateInLocal('Su pago fue procesado con éxito.', state);
158
+ this.redirectToSuccess();
159
+ break;
160
+ case 'failure':
161
+ this.setStateInLocal('Se ha cancelado el proceso de pago.', state);
162
+ this.storeTotalAmount(queryParams);
163
+ this.redirectToCheckout();
164
+ break;
165
+ case 'cancel':
166
+ this.setStateInLocal('Se ha cancelado el proceso de pago.', state);
167
+ this.redirectToCheckout();
168
+ break;
169
+ case 'ok':
170
+ this.setStateInSesion('Su pago fue procesado con éxito.', state);
171
+ break;
172
+ case 'challenge':
173
+ this.setStateInSesion('Redirigiendo a autenticación del banco emisor.', state);
174
+ break;
175
+ case 'error':
176
+ this.setStateInSesion('Algo no salio bien en la validación de sus datos.', state);
177
+ break;
178
+ case '0':
179
+ this.setStateInLocal('Se ha cancelado el proceso de pago.', 'failure');
180
+ this.redirectToCheckout();
181
+ break;
182
+ default:
183
+ break;
184
+ }
185
+ }
186
+ redirectToSuccess() {
187
+ // Limpiar marcadores de procesamiento
188
+ if (this.isMobile && isPlatformBrowser(this.platformId)) {
189
+ localStorage.removeItem('mp_processing_tab');
190
+ localStorage.removeItem('mp_processing_tab_time');
191
+ }
192
+ // Redirigir después de un breve delay
193
+ setTimeout(() => {
194
+ this.router.navigate(['/checkout/order_success']);
195
+ }, 2000);
196
+ }
197
+ redirectToCheckout() {
198
+ // Limpiar marcadores de procesamiento
199
+ if (this.isMobile && isPlatformBrowser(this.platformId)) {
200
+ localStorage.removeItem('mp_processing_tab');
201
+ localStorage.removeItem('mp_processing_tab_time');
202
+ }
203
+ // Redirigir después de un breve delay
204
+ setTimeout(() => {
205
+ this.router.navigate(['/checkout']);
206
+ }, 2000);
207
+ }
208
+ storeTotalAmount(queryParams) {
209
+ const totalAmount = queryParams['total_amount'];
210
+ if (totalAmount && isPlatformBrowser(this.platformId)) {
211
+ localStorage.setItem('total_amount', totalAmount);
212
+ }
213
+ }
214
+ setStateInLocal = (mensaje, state) => {
215
+ this.message = mensaje;
216
+ if (isPlatformBrowser(this.platformId)) {
217
+ localStorage.setItem('state', state);
218
+ if (typeof sessionStorage !== 'undefined') {
219
+ sessionStorage.setItem('modalnews', 'false');
220
+ }
221
+ }
222
+ };
223
+ setStateInSesion = (mensaje, state) => {
224
+ this.message = mensaje;
225
+ if (isPlatformBrowser(this.platformId)) {
226
+ if (typeof sessionStorage !== 'undefined') {
227
+ sessionStorage.setItem('state', state);
228
+ sessionStorage.setItem('modalnews', 'false');
229
+ }
230
+ localStorage.setItem('state', state);
231
+ }
232
+ };
233
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RedsysCatchEcComponent, deps: [{ token: i1.ActivatedRoute }, { token: i1.Router }, { token: i2.CheckoutService }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: DOCUMENT }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component });
234
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: RedsysCatchEcComponent, isStandalone: true, selector: "app-redsys-catch-ec", usesInheritance: true, ngImport: i0, template: "<div id=\"container\">\r\n <div class=\"row\">\r\n <div class=\"col align-self-center\">\r\n <h4 class=\"titpage center-block text-center font-nexa font-lg my-3\">{{ message | uppercase }}</h4>\r\n </div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col align-self-center\">\r\n <h5 class=\"center-block text-center font-nexa my-3\">Redirigiendo en segundos...</h5>\r\n <br>\r\n <div class=\"d-flex flex-column jusitfy-content-center align-items-center\">\r\n <app-loading-full-ec></app-loading-full-ec>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".loader{border:16px solid #f3f3f3;border-top:16px solid #dc3545;border-radius:50%;width:50px;height:50px;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.flex-container{display:flex;justify-content:center;align-items:center;height:80vh;width:100%}.flex-container>div{width:90%;height:100px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i3.UpperCasePipe, name: "uppercase" }, { kind: "component", type: LoadingFullEcComponent, selector: "app-loading-full-ec" }] });
235
+ }
236
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RedsysCatchEcComponent, decorators: [{
237
+ type: Component,
238
+ args: [{ selector: 'app-redsys-catch-ec', standalone: true, imports: [CommonModule, LoadingFullEcComponent], template: "<div id=\"container\">\r\n <div class=\"row\">\r\n <div class=\"col align-self-center\">\r\n <h4 class=\"titpage center-block text-center font-nexa font-lg my-3\">{{ message | uppercase }}</h4>\r\n </div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col align-self-center\">\r\n <h5 class=\"center-block text-center font-nexa my-3\">Redirigiendo en segundos...</h5>\r\n <br>\r\n <div class=\"d-flex flex-column jusitfy-content-center align-items-center\">\r\n <app-loading-full-ec></app-loading-full-ec>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".loader{border:16px solid #f3f3f3;border-top:16px solid #dc3545;border-radius:50%;width:50px;height:50px;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.flex-container{display:flex;justify-content:center;align-items:center;height:80vh;width:100%}.flex-container>div{width:90%;height:100px}\n"] }]
239
+ }], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i1.Router }, { type: i2.CheckoutService }, { type: i0.Renderer2 }, { type: i0.ElementRef }, { type: Document, decorators: [{
240
+ type: Inject,
241
+ args: [DOCUMENT]
242
+ }] }, { type: undefined, decorators: [{
243
+ type: Inject,
244
+ args: [PLATFORM_ID]
245
+ }] }] });
246
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"redsys-catch-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/widgets-ec/redsys-catch-ec/redsys-catch-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/widgets-ec/redsys-catch-ec/redsys-catch-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, Renderer2, ElementRef, Inject, PLATFORM_ID } from '@angular/core';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { combineLatest, Subscription } from 'rxjs';\r\nimport { ComponentHelper } from '../../../classes/component-helper';\r\nimport { CartService } from '../../../ec-services';\r\nimport { CheckoutService } from '../../../ec-services';\r\nimport { CommonModule, isPlatformBrowser } from '@angular/common';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { LoadingFullEcComponent } from '../loading/loading-full-ec/loading-full-ec.component';\r\n\r\n@Component({\r\n    selector: 'app-redsys-catch-ec',\r\n    standalone: true,\r\n    imports: [CommonModule, LoadingFullEcComponent],\r\n    templateUrl: './redsys-catch-ec.component.html',\r\n    styleUrls: ['./redsys-catch-ec.component.scss']\r\n})\r\nexport class RedsysCatchEcComponent extends ComponentHelper implements OnInit, OnDestroy {\r\n\r\n    public message = '';\r\n    private subscription: Subscription | null = null;\r\n    private isMobile = false;\r\n    private sessionId = '';\r\n\r\n    constructor(\r\n        public activedRoute: ActivatedRoute,\r\n        public router: Router,\r\n        public checkoutService: CheckoutService,\r\n        private renderer: Renderer2,\r\n        private elementRef: ElementRef,\r\n        @Inject(DOCUMENT) private document: Document,\r\n        @Inject(PLATFORM_ID) private platformId: any\r\n    ) {\r\n        super();\r\n        \r\n        if (isPlatformBrowser(this.platformId)) {\r\n            this.detectMobile();\r\n            this.sessionId = this.generateSessionId();\r\n            \r\n            // Verificar si debe procesar esta pestaña\r\n            if (this.shouldProcessPayment()) {\r\n                this.hideHeaderFooter();\r\n            } else {\r\n                // Si no debe procesar, cerrar esta pestaña y redirigir a la principal\r\n                this.closeRedundantTab();\r\n                return;\r\n            }\r\n        }\r\n        \r\n        this.ecOnConstruct();\r\n    }\r\n\r\n    private detectMobile(): void {\r\n        if (isPlatformBrowser(this.platformId) && typeof window !== 'undefined') {\r\n            const userAgent = window.navigator.userAgent.toLowerCase();\r\n            this.isMobile = /android|webos|iphone|ipad|ipod|blackberry|iemobile|opera mini|mobile/i.test(userAgent) ||\r\n                          (window.innerWidth <= 768);\r\n        }\r\n    }\r\n\r\n    private generateSessionId(): string {\r\n        return `catch_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;\r\n    }\r\n\r\n    private shouldProcessPayment(): boolean {\r\n        if (!isPlatformBrowser(this.platformId)) {\r\n            return false; // En el servidor no procesar\r\n        }\r\n        \r\n        if (!this.isMobile) {\r\n            return true; // En desktop siempre procesar\r\n        }\r\n\r\n        // En mobile, verificar si ya hay otra pestaña procesando\r\n        const processingTab = localStorage.getItem('mp_processing_tab');\r\n        const currentTime = Date.now();\r\n        const processingTabTime = localStorage.getItem('mp_processing_tab_time');\r\n        \r\n        // Si no hay pestaña procesando o la anterior es muy antigua (más de 30 segundos)\r\n        if (!processingTab || !processingTabTime || (currentTime - parseInt(processingTabTime)) > 30000) {\r\n            // Esta pestaña será la que procese\r\n            localStorage.setItem('mp_processing_tab', this.sessionId);\r\n            localStorage.setItem('mp_processing_tab_time', currentTime.toString());\r\n            return true;\r\n        }\r\n        \r\n        // Si ya hay otra pestaña procesando\r\n        return processingTab === this.sessionId;\r\n    }\r\n\r\n    private closeRedundantTab(): void {\r\n        console.log('Cerrando pestaña redundante...');\r\n        // Intentar cerrar la pestaña\r\n        if (isPlatformBrowser(this.platformId) && typeof window !== 'undefined') {\r\n            // Redirigir a la página principal en lugar de cerrar\r\n            window.location.href = '/checkout/order_success';\r\n        }\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.subscription = combineLatest([\r\n            this.activedRoute.params,\r\n            this.activedRoute.queryParams\r\n        ]).subscribe(([queryRouter, queryParams]) => {\r\n            let state: string | undefined;\r\n            state = queryRouter['state'];\r\n            if (state && state === 'statuspayment') {\r\n                state = queryParams['status'];\r\n            }\r\n            console.log('PARAMETROS STATE  -> ', state);\r\n            this.handlePaymentState(state, queryParams);\r\n        });\r\n        this.ecOnInit();\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        if (this.subscription) {\r\n            this.subscription.unsubscribe();\r\n        }\r\n        this.showHeaderFooter();\r\n        \r\n        // Limpiar marcadores de mobile si esta pestaña estaba procesando\r\n        if (this.isMobile && isPlatformBrowser(this.platformId)) {\r\n            const processingTab = localStorage.getItem('mp_processing_tab');\r\n            if (processingTab === this.sessionId) {\r\n                localStorage.removeItem('mp_processing_tab');\r\n                localStorage.removeItem('mp_processing_tab_time');\r\n            }\r\n        }\r\n        \r\n        // this.ecOnDestroy(); // Removido si no existe en ComponentHelper\r\n    }\r\n\r\n    private hideHeaderFooter(): void {\r\n        // Usar Renderer2 en lugar de jQuery para manipular el DOM\r\n        const header = this.document.querySelector('header');\r\n        const footer = this.document.querySelector('footer');\r\n\r\n        if (header) {\r\n            this.renderer.setStyle(header, 'display', 'none');\r\n        }\r\n        if (footer) {\r\n            this.renderer.setStyle(footer, 'display', 'none');\r\n        }\r\n    }\r\n\r\n    private showHeaderFooter(): void {\r\n        // Restaurar la visibilidad al destruir el componente\r\n        const header = this.document.querySelector('header');\r\n        const footer = this.document.querySelector('footer');\r\n\r\n        if (header) {\r\n            this.renderer.removeStyle(header, 'display');\r\n        }\r\n        if (footer) {\r\n            this.renderer.removeStyle(footer, 'display');\r\n        }\r\n    }\r\n\r\n    private handlePaymentState(state: string | undefined, queryParams: any): void {\r\n        // Solo procesar el estado si esta pestaña está autorizada\r\n        if (this.isMobile && !this.shouldProcessPayment()) {\r\n            console.log('Pestaña no autorizada para procesar el pago, redirigiendo...');\r\n            this.closeRedundantTab();\r\n            return;\r\n        }\r\n        \r\n        switch (state) {\r\n            case '200':\r\n                this.setStateInLocal('Su pago fue procesado con éxito.', 'success');\r\n                this.storeTotalAmount(queryParams);\r\n                this.redirectToSuccess();\r\n                break;\r\n            case 'success':\r\n                this.setStateInLocal('Su pago fue procesado con éxito.', state);\r\n                this.storeTotalAmount(queryParams);\r\n                this.redirectToSuccess();\r\n                break;\r\n            case 'pending':\r\n                this.setStateInLocal('Su pago fue procesado con éxito.', state);\r\n                this.redirectToSuccess();\r\n                break;\r\n            case 'failure':\r\n                this.setStateInLocal('Se ha cancelado el proceso de pago.', state);\r\n                this.storeTotalAmount(queryParams);\r\n                this.redirectToCheckout();\r\n                break;\r\n            case 'cancel':\r\n                this.setStateInLocal('Se ha cancelado el proceso de pago.', state);\r\n                this.redirectToCheckout();\r\n                break;\r\n            case 'ok':\r\n                this.setStateInSesion('Su pago fue procesado con éxito.', state);\r\n                break;\r\n            case 'challenge':\r\n                this.setStateInSesion('Redirigiendo a autenticación del banco emisor.', state);\r\n                break;\r\n            case 'error':\r\n                this.setStateInSesion('Algo no salio bien en la validación de sus datos.', state);\r\n                break;\r\n            case '0':\r\n                this.setStateInLocal('Se ha cancelado el proceso de pago.', 'failure');\r\n                this.redirectToCheckout();\r\n                break;\r\n            default:\r\n                break;\r\n        }\r\n    }\r\n\r\n    private redirectToSuccess(): void {\r\n        // Limpiar marcadores de procesamiento\r\n        if (this.isMobile && isPlatformBrowser(this.platformId)) {\r\n            localStorage.removeItem('mp_processing_tab');\r\n            localStorage.removeItem('mp_processing_tab_time');\r\n        }\r\n        \r\n        // Redirigir después de un breve delay\r\n        setTimeout(() => {\r\n            this.router.navigate(['/checkout/order_success']);\r\n        }, 2000);\r\n    }\r\n\r\n    private redirectToCheckout(): void {\r\n        // Limpiar marcadores de procesamiento\r\n        if (this.isMobile && isPlatformBrowser(this.platformId)) {\r\n            localStorage.removeItem('mp_processing_tab');\r\n            localStorage.removeItem('mp_processing_tab_time');\r\n        }\r\n        \r\n        // Redirigir después de un breve delay\r\n        setTimeout(() => {\r\n            this.router.navigate(['/checkout']);\r\n        }, 2000);\r\n    }\r\n\r\n    private storeTotalAmount(queryParams: any): void {\r\n        const totalAmount = queryParams['total_amount'];\r\n        if (totalAmount && isPlatformBrowser(this.platformId)) {\r\n            localStorage.setItem('total_amount', totalAmount);\r\n        }\r\n    }\r\n\r\n\r\n    private setStateInLocal = (mensaje: string, state: string): void => {\r\n        this.message = mensaje;\r\n        \r\n        if (isPlatformBrowser(this.platformId)) {\r\n            localStorage.setItem('state', state);\r\n            if (typeof sessionStorage !== 'undefined') {\r\n                sessionStorage.setItem('modalnews', 'false');\r\n            }\r\n        }\r\n    }\r\n\r\n    private setStateInSesion = (mensaje: string, state: string): void => {\r\n        this.message = mensaje;\r\n        \r\n        if (isPlatformBrowser(this.platformId)) {\r\n            if (typeof sessionStorage !== 'undefined') {\r\n                sessionStorage.setItem('state', state);\r\n                sessionStorage.setItem('modalnews', 'false');\r\n            }\r\n            localStorage.setItem('state', state);\r\n        }\r\n    }\r\n\r\n}\r\n","<div id=\"container\">\r\n    <div class=\"row\">\r\n        <div class=\"col align-self-center\">\r\n            <h4 class=\"titpage center-block text-center font-nexa font-lg my-3\">{{ message | uppercase }}</h4>\r\n        </div>\r\n    </div>\r\n    <div class=\"row\">\r\n        <div class=\"col align-self-center\">\r\n            <h5 class=\"center-block text-center font-nexa my-3\">Redirigiendo en segundos...</h5>\r\n            <br>\r\n            <div class=\"d-flex flex-column jusitfy-content-center align-items-center\">\r\n                <app-loading-full-ec></app-loading-full-ec>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
@@ -37,9 +37,7 @@ export class FacebookPixelService {
37
37
  this.renderer.appendChild(this.document?.body, new_analityc_script);
38
38
  this.enabled = true;
39
39
  }
40
- if (isPlatformBrowser(this.platformId)) {
41
- setTimeout(() => this.callEvent('initialize'), 1000);
42
- }
40
+ setTimeout(() => this.callEvent('initialize'), 1000);
43
41
  }
44
42
  /**
45
43
  * Ejecuta el evento pasado por parametro.
@@ -211,4 +209,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
211
209
  providedIn: 'root'
212
210
  }]
213
211
  }], ctorParameters: () => [] });
214
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"facebook-pixel.service.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-services/analytics/facebook-pixel.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,WAAW,EAAa,gBAAgB,EAAE,MAAM,eAAe,CAAC;;AAU7F;;;GAGG;AAIH,MAAM,OAAO,oBAAoB;IAErB,eAAe,GAAqB,MAAM,CAAC,gBAAgB,CAAC,CAAA;IAC5D,QAAQ,GAAoB,IAAI,CAAC;IACzC;;;OAGG;IACK,QAAQ,CAAY;IAC5B;;OAEG;IACK,OAAO,GAAY,KAAK,CAAC;IACzB,UAAU,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;IAEzC;QACI,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACrC,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,kCAAkC;QACxE,CAAC;QACD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACpE,CAAC;IACD;;;OAGG;IACH,UAAU,CAAC,QAAa;QACpB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,cAAc,CAAC,gBAAgB,CAAC,EAAE,CAAC;YACnD,IAAI,mBAAmB,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YAChE,mBAAmB,CAAC,EAAE,GAAG,gBAAgB,CAAA;YACzC,mBAAmB,CAAC,IAAI,GAAG,iBAAiB,CAAC;YAC7C,mBAAmB,CAAC,IAAI,GAAG,gZAAgZ,QAAQ,IAAI,CAAC;YACxb,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,mBAAmB,CAAC,CAAC;YACpE,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACxB,CAAC;QACD,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACrC,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE,IAAI,CAAC,CAAC;QACzD,CAAC;IACL,CAAC;IACD;;;;;OAKG;IACH,SAAS,CAAC,UAA4B,EAAE,IAAI,GAAG,EAAE;QAC7C,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAO;QAC1B,IAAI,KAAK,GAAG,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;QAChD,KAAK,IAAI,GAAG,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC,CAAC;IACjG,CAAC;IACD;;;;OAIG;IACH,kBAAkB,CAAC,UAA4B;QAC3C,QAAQ,UAAU,EAAE,CAAC;YACjB,KAAK,YAAY,CAAC,CAAC,OAAO,UAAU,CAAC;YACrC,KAAK,WAAW,CAAC,CAAC,OAAO,aAAa,CAAC;YACvC,KAAK,eAAe,CAAC,CAAC,OAAO,kBAAkB,CAAC;YAChD,KAAK,cAAc,CAAC,CAAC,OAAO,gBAAgB,CAAC;YAC7C,KAAK,UAAU,CAAC,CAAC,OAAO,UAAU,CAAC;YACnC,KAAK,aAAa,CAAC,CAAC,OAAO,WAAW,CAAC;YACvC,OAAO,CAAC,CAAC,OAAO,IAAI,CAAC;QACzB,CAAC;IACL,CAAC;IACD;;;;;OAKG;IACH,SAAS,CAAC,UAA4B,EAAE,IAAS;QAC7C,QAAQ,UAAU,EAAE,CAAC;YACjB,KAAK,YAAY,CAAC,CAAC,OAAO,IAAI,CAAC;YAC/B,KAAK,WAAW,CAAC,CAAC,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YAClD,KAAK,eAAe,CAAC,CAAC,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YACvD,KAAK,cAAc,CAAC,CAAC,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YACrD,KAAK,UAAU,CAAC,CAAC,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAC9C,KAAK,aAAa,CAAC,CAAC,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YAClD,OAAO,CAAC,CAAC,OAAO,IAAI,CAAC;QACzB,CAAC;IACL,CAAC;IACD;;;;;OAKG;IACH,eAAe,CAAC,UAA4B,EAAE,OAA0B,EAAE;QACtE,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAO;QAC1B,GAAG,CAAC,aAAa,EAAE,UAAU,EAAE,IAAI,CAAC,CAAC;IACzC,CAAC;IACD;;;OAGG;IACH,OAAO,KAAK,IAAI,CAAC,OAAO,GAAG,KAAK,CAAA,CAAC,CAAC;IAAA,CAAC;IACnC;;;;OAIG;IACK,aAAa,CAAC,IAAS;QAC3B,IAAI,WAAW,GAAG,IAAI,EAAE,IAAI,IAAI,aAAa,CAAA;QAC7C,OAAO;YACH,YAAY,EAAE,SAAS;YACvB,YAAY,EAAE,WAAW;YACzB,WAAW,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC;YACrC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,KAAK;YAChC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,SAAS,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,KAAK;YAC7D,4BAA4B;SAC/B,CAAA;IACL,CAAC;IACD;;;;OAIG;IACK,UAAU,CAAC,IAAS;QACxB,OAAO;YACH,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,KAAK;YAChC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI,CAAC;YAC9B,YAAY,EAAE,eAAe;YAC7B,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YAChC,4BAA4B;SAC/B,CAAA;IACL,CAAC;IACD;;;;OAIG;IACK,cAAc,CAAC,IAAS;QAC5B,OAAO;YACH,uCAAuC;YACvC,YAAY,EAAE,eAAe;YAC7B,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YAChC,WAAW,EAAE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;YACrC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,KAAK;YAChC,SAAS,EAAE,IAAI,CAAC,KAAK,EAAE,MAAM,IAAI,CAAC;YAClC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI,CAAC;SACjC,CAAA;IACL,CAAC;IACD;;;;OAIG;IACK,aAAa,CAAC,IAAS;QAC3B,OAAO;YACH,uCAAuC;YACvC,YAAY,EAAE,eAAe;YAC7B,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YAChC,WAAW,EAAE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;YACrC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,KAAK;YAChC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI,CAAC;SACjC,CAAA;IACL,CAAC;IACD;;;;OAIG;IACK,WAAW,CAAC,IAAS;QACzB,IAAI,WAAW,GAAG,IAAI,CAAC,KAAK,EAAE,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,IAAI,aAAa,CAAA;QACzG,OAAO;YACH,YAAY,EAAE,WAAW;YACzB,YAAY,EAAE,SAAS;YACvB,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YAChC,WAAW,EAAE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;YACrC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,KAAK;YAChC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI,CAAC;YAC9B,4BAA4B;SAE/B,CAAA;IACL,CAAC;IACD;;;;OAIG;IACK,WAAW,CAAC,IAAS;QACzB,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CACjB,CAAC,IAAS,EAAE,EAAE;YACV,OAAO;gBACH,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI;gBAClC,QAAQ,EAAE,IAAI,CAAC,QAAQ;aAC1B,CAAA;QACL,CAAC,CACJ,CAAA;IACL,CAAC;IACD;;;;OAIG;IACK,aAAa,CAAC,IAAS;QAC3B,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CACjB,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI,CAChD,CAAA;IACL,CAAC;wGAxMQ,oBAAoB;4GAApB,oBAAoB,cAFjB,MAAM;;4FAET,oBAAoB;kBAHhC,UAAU;mBAAC;oBACR,UAAU,EAAE,MAAM;iBACrB","sourcesContent":["import { DOCUMENT, isPlatformBrowser } from '@angular/common';\r\nimport { inject, Injectable, PLATFORM_ID, Renderer2, RendererFactory2 } from '@angular/core';\r\nimport { AnalyticEventKey, FacebookPixelData } from '../../interfaces';\r\n/**\r\n * Funcion que sera dada por el script que se inserta en el inicializador de Facebook Analytics.\r\n * \r\n * https://es-la.facebook.com/business/help/402791146561655?id=1205376682832142 \r\n * \r\n * Relacionado con: {@link FacebookPixelService}\r\n */\r\ndeclare let fbq: Function;\r\n/**\r\n * Servicio que se encarga de manejar el Analytics de Facebook.\r\n * @class FacebookPixelService\r\n */\r\n@Injectable({\r\n    providedIn: 'root'\r\n})\r\nexport class FacebookPixelService {\r\n\r\n    private rendererFactory: RendererFactory2 = inject(RendererFactory2)\r\n    private document: Document | null = null;\r\n    /**\r\n     * Se encarga de crear el elemento HTML con las configuraciones para \r\n     * que se pueda ejecutar el servicio.\r\n     */\r\n    private renderer: Renderer2;\r\n    /**\r\n     * Indica cuando el servicio esta habilitado.\r\n     */\r\n    private enabled: boolean = false;\r\n    private platformId = inject(PLATFORM_ID);\r\n\r\n    constructor() {\r\n        if (isPlatformBrowser(this.platformId)) {\r\n            this.document = inject(DOCUMENT); // Solo se inyecta en el navegador\r\n        }\r\n        this.renderer = this.rendererFactory.createRenderer(null, null);\r\n    }\r\n    /**\r\n     * Inicializa el Servicio de analytics con sus configuraciones.\r\n     * @param pixel_id id provisto por Facebook Pixel.\r\n     */\r\n    initialize(pixel_id: any) {\r\n        if (!this.document?.getElementById('facebook_pixel')) {\r\n            let new_analityc_script = this.renderer.createElement('script');\r\n            new_analityc_script.id = \"facebook_pixel\"\r\n            new_analityc_script.type = 'text/javascript';\r\n            new_analityc_script.text = `!function(f,b,e,v,n,t,s) {if(f.fbq)return;n=f.fbq=function(){n.callMethod? n.callMethod.apply(n,arguments):n.queue.push(arguments)}; if(!f._fbq)f._fbq=n;n.push=n;n.loaded=!0;n.version='2.0'; n.queue=[];t=b.createElement(e);t.async=!0; t.src=v;s=b.getElementsByTagName(e)[0]; s.parentNode.insertBefore(t,s)}(window, document,'script', 'https://connect.facebook.net/en_US/fbevents.js'); fbq('init', ${pixel_id});`;\r\n            this.renderer.appendChild(this.document?.body, new_analityc_script);\r\n            this.enabled = true;\r\n        }\r\n        if (isPlatformBrowser(this.platformId)) {\r\n            setTimeout(() => this.callEvent('initialize'), 1000);\r\n        }\r\n    }\r\n    /**\r\n     * Ejecuta el evento pasado por parametro. \r\n     * @param event_name Nombre del evento.\r\n     * @param data Data extra para agregar al evento.\r\n     * @returns \r\n     */\r\n    callEvent(event_name: AnalyticEventKey, data = {}) {\r\n        if (!this.enabled) return;\r\n        let event = this.translateEventName(event_name);\r\n        event && fbq('track', this.translateEventName(event_name), this.evalEvent(event_name, data));\r\n    }\r\n    /**\r\n     * Traduce el evento recibido y devuelve el nombre de la función que lo va a tratar.\r\n     * @param event_name \r\n     * @returns \r\n     */\r\n    translateEventName(event_name: AnalyticEventKey) {\r\n        switch (event_name) {\r\n            case 'initialize': return 'PageView';\r\n            case 'view_item': return 'ViewContent';\r\n            case 'checkout_init': return 'InitiateCheckout';\r\n            case 'payment_info': return 'AddPaymentInfo';\r\n            case 'purchase': return 'Purchase';\r\n            case 'add_to_cart': return 'AddToCart';\r\n            default: return null;\r\n        }\r\n    }\r\n    /**\r\n     * Evalua el evento y devuelve los datos de las funciones relacionadas.\r\n     * @param event_name Nombre del evento\r\n     * @param data Data extra para agregar al evento\r\n     * @returns \r\n     */\r\n    evalEvent(event_name: AnalyticEventKey, data: any) {\r\n        switch (event_name) {\r\n            case 'initialize': return data;\r\n            case 'view_item': return this.toViewContent(data);\r\n            case 'checkout_init': return this.toCheckoutInit(data);\r\n            case 'payment_info': return this.toPaymentInfo(data);\r\n            case 'purchase': return this.toPurchase(data);\r\n            case 'add_to_cart': return this.toAddToCart(data);\r\n            default: return data;\r\n        }\r\n    }\r\n    /**\r\n     * Para ejecutar un evento propio.\r\n     * @param event_name Nombre de evento\r\n     * @param data Data extra para agregar al evento.\r\n     * @returns \r\n     */\r\n    callCustomEvent(event_name: AnalyticEventKey, data: FacebookPixelData = {}) {\r\n        if (!this.enabled) return;\r\n        fbq('trackCustom', event_name, data);\r\n    }\r\n    /**\r\n     * Cambia la variable **enabled** a `false`\r\n     * @returns \r\n     */\r\n    disable() { this.enabled = false };\r\n    /**\r\n     * Cuando un evento interactua con el contenido de la vista del producto.\r\n     * @param data \r\n     * @returns \r\n     */\r\n    private toViewContent(data: any) {\r\n        let lastProduct = data?.name || 'not-product'\r\n        return {\r\n            content_type: 'product',\r\n            content_name: lastProduct,\r\n            content_ids: [data.variants[0]?.code],\r\n            currency: data.currency || \"USD\",\r\n            value: data.variants[0]?.saleprice || data.variants[0]?.price,\r\n            //product_catalog_id: 'TEST'\r\n        }\r\n    }\r\n    /**\r\n     * Evento que se dispara cuando se quiere comprar un producto.\r\n     * @param data \r\n     * @returns \r\n     */\r\n    private toPurchase(data: any) {\r\n        return {\r\n            currency: data.currency || \"USD\",\r\n            value: data.totals?.total || 0,\r\n            content_type: 'product_group',\r\n            contents: this.getContents(data),\r\n            //product_catalog_id: 'TEST'\r\n        }\r\n    }\r\n    /**\r\n     * Evento que se dispara cuando se inicializa en checkout.\r\n     * @param data \r\n     * @returns \r\n     */\r\n    private toCheckoutInit(data: any) {\r\n        return {\r\n            //content_category : \"inicio checkout\",\r\n            content_type: 'product_group',\r\n            contents: this.getContents(data),\r\n            content_ids: this.getContentIds(data),\r\n            currency: data.currency || \"USD\",\r\n            num_items: data.items?.length || 0,\r\n            value: data.totals?.total || 0,\r\n        }\r\n    }\r\n    /**\r\n     * Evento que se dispara cuando se consulta la información de pago.\r\n     * @param data \r\n     * @returns \r\n     */\r\n    private toPaymentInfo(data: any) {\r\n        return {\r\n            //content_category : \"inicio checkout\",\r\n            content_type: 'product_group',\r\n            contents: this.getContents(data),\r\n            content_ids: this.getContentIds(data),\r\n            currency: data.currency || \"USD\",\r\n            value: data.totals?.total || 0,\r\n        }\r\n    }\r\n    /**\r\n     * Evento que se dispara cuando se agrega un producto al carrito. \r\n     * @param data \r\n     * @returns \r\n     */\r\n    private toAddToCart(data: any) {\r\n        let lastProduct = data.items?.length && data.items[data.items.length - 1]?.product?.name || 'not-product'\r\n        return {\r\n            content_name: lastProduct,\r\n            content_type: 'product',\r\n            contents: this.getContents(data),\r\n            content_ids: this.getContentIds(data),\r\n            currency: data.currency || \"USD\",\r\n            value: data.totals?.total || 0,\r\n            //product_catalog_id: 'TEST'\r\n\r\n        }\r\n    }\r\n    /**\r\n     * Mapeo de datos para obtener solo el ID del producto y la cantidad.\r\n     * @param data \r\n     * @returns \r\n     */\r\n    private getContents(data: any) {\r\n        return data.items.map(\r\n            (item: any) => {\r\n                return {\r\n                    id: item.product.variants[0]?.code,\r\n                    quantity: item.quantity\r\n                }\r\n            }\r\n        )\r\n    }\r\n    /**\r\n     * Mapeo de datos para obtener solo el ID del producto.\r\n     * @param data \r\n     * @returns \r\n     */\r\n    private getContentIds(data: any) {\r\n        return data.items.map(\r\n            (item: any) => item.product.variants[0]?.code\r\n        )\r\n    }\r\n}\r\n"]}
212
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"facebook-pixel.service.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-services/analytics/facebook-pixel.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT, isPlatformBrowser } from '@angular/common';\r\nimport { inject, Injectable, PLATFORM_ID, Renderer2, RendererFactory2 } from '@angular/core';\r\nimport { AnalyticEventKey, FacebookPixelData } from '../../interfaces';\r\n/**\r\n * Funcion que sera dada por el script que se inserta en el inicializador de Facebook Analytics.\r\n * \r\n * https://es-la.facebook.com/business/help/402791146561655?id=1205376682832142 \r\n * \r\n * Relacionado con: {@link FacebookPixelService}\r\n */\r\ndeclare let fbq: Function;\r\n/**\r\n * Servicio que se encarga de manejar el Analytics de Facebook.\r\n * @class FacebookPixelService\r\n */\r\n@Injectable({\r\n    providedIn: 'root'\r\n})\r\nexport class FacebookPixelService {\r\n\r\n    private rendererFactory: RendererFactory2 = inject(RendererFactory2)\r\n    private document: Document | null = null;\r\n    /**\r\n     * Se encarga de crear el elemento HTML con las configuraciones para \r\n     * que se pueda ejecutar el servicio.\r\n     */\r\n    private renderer: Renderer2;\r\n    /**\r\n     * Indica cuando el servicio esta habilitado.\r\n     */\r\n    private enabled: boolean = false;\r\n    private platformId = inject(PLATFORM_ID);\r\n\r\n    constructor() {\r\n        if (isPlatformBrowser(this.platformId)) {\r\n            this.document = inject(DOCUMENT); // Solo se inyecta en el navegador\r\n        }\r\n        this.renderer = this.rendererFactory.createRenderer(null, null);\r\n    }\r\n    /**\r\n     * Inicializa el Servicio de analytics con sus configuraciones.\r\n     * @param pixel_id id provisto por Facebook Pixel.\r\n     */\r\n    initialize(pixel_id: any) {\r\n        if (!this.document?.getElementById('facebook_pixel')) {\r\n            let new_analityc_script = this.renderer.createElement('script');\r\n            new_analityc_script.id = \"facebook_pixel\"\r\n            new_analityc_script.type = 'text/javascript';\r\n            new_analityc_script.text = `!function(f,b,e,v,n,t,s) {if(f.fbq)return;n=f.fbq=function(){n.callMethod? n.callMethod.apply(n,arguments):n.queue.push(arguments)}; if(!f._fbq)f._fbq=n;n.push=n;n.loaded=!0;n.version='2.0'; n.queue=[];t=b.createElement(e);t.async=!0; t.src=v;s=b.getElementsByTagName(e)[0]; s.parentNode.insertBefore(t,s)}(window, document,'script', 'https://connect.facebook.net/en_US/fbevents.js'); fbq('init', ${pixel_id});`;\r\n            this.renderer.appendChild(this.document?.body, new_analityc_script);\r\n            this.enabled = true;\r\n        }\r\n        setTimeout(() => this.callEvent('initialize'), 1000);\r\n    }\r\n    /**\r\n     * Ejecuta el evento pasado por parametro. \r\n     * @param event_name Nombre del evento.\r\n     * @param data Data extra para agregar al evento.\r\n     * @returns \r\n     */\r\n    callEvent(event_name: AnalyticEventKey, data = {}) {\r\n        if (!this.enabled) return;\r\n        let event = this.translateEventName(event_name);\r\n        event && fbq('track', this.translateEventName(event_name), this.evalEvent(event_name, data));\r\n    }\r\n    /**\r\n     * Traduce el evento recibido y devuelve el nombre de la función que lo va a tratar.\r\n     * @param event_name \r\n     * @returns \r\n     */\r\n    translateEventName(event_name: AnalyticEventKey) {\r\n        switch (event_name) {\r\n            case 'initialize': return 'PageView';\r\n            case 'view_item': return 'ViewContent';\r\n            case 'checkout_init': return 'InitiateCheckout';\r\n            case 'payment_info': return 'AddPaymentInfo';\r\n            case 'purchase': return 'Purchase';\r\n            case 'add_to_cart': return 'AddToCart';\r\n            default: return null;\r\n        }\r\n    }\r\n    /**\r\n     * Evalua el evento y devuelve los datos de las funciones relacionadas.\r\n     * @param event_name Nombre del evento\r\n     * @param data Data extra para agregar al evento\r\n     * @returns \r\n     */\r\n    evalEvent(event_name: AnalyticEventKey, data: any) {\r\n        switch (event_name) {\r\n            case 'initialize': return data;\r\n            case 'view_item': return this.toViewContent(data);\r\n            case 'checkout_init': return this.toCheckoutInit(data);\r\n            case 'payment_info': return this.toPaymentInfo(data);\r\n            case 'purchase': return this.toPurchase(data);\r\n            case 'add_to_cart': return this.toAddToCart(data);\r\n            default: return data;\r\n        }\r\n    }\r\n    /**\r\n     * Para ejecutar un evento propio.\r\n     * @param event_name Nombre de evento\r\n     * @param data Data extra para agregar al evento.\r\n     * @returns \r\n     */\r\n    callCustomEvent(event_name: AnalyticEventKey, data: FacebookPixelData = {}) {\r\n        if (!this.enabled) return;\r\n        fbq('trackCustom', event_name, data);\r\n    }\r\n    /**\r\n     * Cambia la variable **enabled** a `false`\r\n     * @returns \r\n     */\r\n    disable() { this.enabled = false };\r\n    /**\r\n     * Cuando un evento interactua con el contenido de la vista del producto.\r\n     * @param data \r\n     * @returns \r\n     */\r\n    private toViewContent(data: any) {\r\n        let lastProduct = data?.name || 'not-product'\r\n        return {\r\n            content_type: 'product',\r\n            content_name: lastProduct,\r\n            content_ids: [data.variants[0]?.code],\r\n            currency: data.currency || \"USD\",\r\n            value: data.variants[0]?.saleprice || data.variants[0]?.price,\r\n            //product_catalog_id: 'TEST'\r\n        }\r\n    }\r\n    /**\r\n     * Evento que se dispara cuando se quiere comprar un producto.\r\n     * @param data \r\n     * @returns \r\n     */\r\n    private toPurchase(data: any) {\r\n        return {\r\n            currency: data.currency || \"USD\",\r\n            value: data.totals?.total || 0,\r\n            content_type: 'product_group',\r\n            contents: this.getContents(data),\r\n            //product_catalog_id: 'TEST'\r\n        }\r\n    }\r\n    /**\r\n     * Evento que se dispara cuando se inicializa en checkout.\r\n     * @param data \r\n     * @returns \r\n     */\r\n    private toCheckoutInit(data: any) {\r\n        return {\r\n            //content_category : \"inicio checkout\",\r\n            content_type: 'product_group',\r\n            contents: this.getContents(data),\r\n            content_ids: this.getContentIds(data),\r\n            currency: data.currency || \"USD\",\r\n            num_items: data.items?.length || 0,\r\n            value: data.totals?.total || 0,\r\n        }\r\n    }\r\n    /**\r\n     * Evento que se dispara cuando se consulta la información de pago.\r\n     * @param data \r\n     * @returns \r\n     */\r\n    private toPaymentInfo(data: any) {\r\n        return {\r\n            //content_category : \"inicio checkout\",\r\n            content_type: 'product_group',\r\n            contents: this.getContents(data),\r\n            content_ids: this.getContentIds(data),\r\n            currency: data.currency || \"USD\",\r\n            value: data.totals?.total || 0,\r\n        }\r\n    }\r\n    /**\r\n     * Evento que se dispara cuando se agrega un producto al carrito. \r\n     * @param data \r\n     * @returns \r\n     */\r\n    private toAddToCart(data: any) {\r\n        let lastProduct = data.items?.length && data.items[data.items.length - 1]?.product?.name || 'not-product'\r\n        return {\r\n            content_name: lastProduct,\r\n            content_type: 'product',\r\n            contents: this.getContents(data),\r\n            content_ids: this.getContentIds(data),\r\n            currency: data.currency || \"USD\",\r\n            value: data.totals?.total || 0,\r\n            //product_catalog_id: 'TEST'\r\n\r\n        }\r\n    }\r\n    /**\r\n     * Mapeo de datos para obtener solo el ID del producto y la cantidad.\r\n     * @param data \r\n     * @returns \r\n     */\r\n    private getContents(data: any) {\r\n        return data.items.map(\r\n            (item: any) => {\r\n                return {\r\n                    id: item.product.variants[0]?.code,\r\n                    quantity: item.quantity\r\n                }\r\n            }\r\n        )\r\n    }\r\n    /**\r\n     * Mapeo de datos para obtener solo el ID del producto.\r\n     * @param data \r\n     * @returns \r\n     */\r\n    private getContentIds(data: any) {\r\n        return data.items.map(\r\n            (item: any) => item.product.variants[0]?.code\r\n        )\r\n    }\r\n}\r\n"]}
@@ -47,9 +47,7 @@ export class GoogleAnalyticsService {
47
47
  this.renderer.appendChild(this.document?.head, declaration);
48
48
  this.enabled = true;
49
49
  }
50
- if (isPlatformBrowser(this.platformId)) {
51
- setTimeout(() => this.startListeningPageViews(gtm_id), 1000);
52
- }
50
+ setTimeout(() => this.startListeningPageViews(gtm_id), 1000);
53
51
  }
54
52
  /**
55
53
  *
@@ -282,4 +280,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
282
280
  providedIn: 'root'
283
281
  }]
284
282
  }], ctorParameters: () => [] });
285
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-analytics.service.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-services/analytics/google-analytics.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT, isPlatformBrowser } from '@angular/common';\r\nimport { inject, Injectable, PLATFORM_ID, Renderer2, RendererFactory2 } from '@angular/core';\r\nimport { AnalyticEventKey } from '../../interfaces';\r\nimport { NavigationEnd, Router } from '@angular/router';\r\nimport { filter } from 'rxjs';\r\n/**\r\n * Funcion que sera dada por el script que se inserta en el inicializador de Google Analytics.\r\n */\r\ndeclare var gtag: Function;\r\ndeclare var dataLayer: any[];\r\n\r\n/**\r\n * Servicio encargado de manejar el analytics de google.\r\n * @class GoogleAnalyticsService\r\n */\r\n@Injectable({\r\n\tprovidedIn: 'root'\r\n})\r\nexport class GoogleAnalyticsService {\r\n\t/**\r\n\t * Se encarga de crear el elemento HTML con las configuraciones para \r\n\t * que se pueda ejecutar el servicio.\r\n\t */\r\n\tprivate renderer: Renderer2;\r\n\t/**\r\n\t * Indica cuando el servicio esta habilitado.\r\n\t */\r\n\tprivate enabled: boolean = false;\r\n\r\n\tprivate rendererFactory: RendererFactory2 = inject(RendererFactory2);\r\n\tprivate document: Document | null = null;\r\n\tprivate platformId = inject(PLATFORM_ID);\r\n\r\n\t/**\r\n\t * Servicio de ruteo de angular.\r\n\t */\r\n\tprivate router: Router = inject(Router);\r\n\r\n\tconstructor() {\r\n\t\tif (isPlatformBrowser(this.platformId)) {\r\n\t\t\tthis.document = inject(DOCUMENT); // Solo se inyecta en el navegador\r\n\t\t}\r\n\t\tthis.renderer = this.rendererFactory.createRenderer(null, null);\r\n\t}\r\n\t/**\r\n\t * Inicializa el Servicio de analytics con sus configuraciones.\r\n\t * @param gtm_id id provisto por Google Tag Manager.\r\n\t */\r\n\tinitialize(gtm_id: string) {\r\n\t\tif (!document.getElementById('google_tag_manager')) {\r\n\t\t\tconsole.log('hay elemento')\r\n\t\t\tconst declaration = this.renderer.createElement('script');\r\n\t\t\tdeclaration.async = true;\r\n\t\t\tdeclaration.id = 'google_tag_manager';\r\n\t\t\tdeclaration.src = `https://www.googletagmanager.com/gtag/js?id=${gtm_id}`;\r\n\t\t\tconst initialization = this.renderer.createElement('script');\r\n\t\t\tinitialization.text = `window.dataLayer = window.dataLayer || []; function gtag(){dataLayer.push(arguments);} gtag('js', new Date()); gtag('config', '${gtm_id}')`;\r\n\t\t\tthis.renderer.appendChild(this.document?.head, initialization);\r\n\t\t\tthis.renderer.appendChild(this.document?.head, declaration);\r\n\t\t\tthis.enabled = true;\r\n\t\t}\r\n\t\tif (isPlatformBrowser(this.platformId)) {\r\n\t\t\tsetTimeout(() => this.startListeningPageViews(gtm_id), 1000);\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * \r\n\t * @param gtm_id \r\n\t */\r\n\tprivate startListeningPageViews(gtm_id: any) {\r\n\t\tthis.router.events.pipe(\r\n\t\t\tfilter(event => event instanceof NavigationEnd)\r\n\t\t).subscribe((event: NavigationEnd) => {\r\n\t\t\tgtag('config', gtm_id, {\r\n\t\t\t\t'page_path': event.urlAfterRedirects\r\n\t\t\t})\r\n\t\t})\r\n\t}\r\n\t/**\r\n\t * Ejecuta el evento pasado por parametro. \r\n\t * @param event_name Nombre del evento.\r\n\t * @param data Data extra para agregar al evento.\r\n\t * @returns \r\n\t */\r\n\tcallEvent(event_name: AnalyticEventKey, data = {}) {\r\n\t\tif (!this.enabled) return;\r\n\t\tlet event = this.translateEventName(event_name);\r\n\t\tevent && gtag('event', this.translateEventName(event_name), this.evalEvent(event_name, data));\r\n\t}\r\n\t/**\r\n\t * Traduce el evento recibido y devuelve el nombre de la función que lo va a tratar.\r\n\t * @param event_name \r\n\t * @returns \r\n\t */\r\n\ttranslateEventName(event_name: AnalyticEventKey) {\r\n\t\tswitch (event_name) {\r\n\t\t\tcase 'view_item': return 'view_item';\r\n\t\t\tcase 'view_item_list': return 'view_item_list';\r\n\t\t\tcase 'checkout_init': return 'begin_checkout';\r\n\t\t\tcase 'shipping_info': return 'add_shipping_info';\r\n\t\t\tcase 'add_payment_info': return 'add_payment_info';\r\n\t\t\tcase 'purchase': return 'purchase';\r\n\t\t\tcase 'add_to_cart': return 'add_to_cart';\r\n\t\t\tcase 'remove_from_cart': return 'remove_from_cart';\r\n\t\t\tcase 'sign_up': return 'sign_up';\r\n\t\t\tdefault: return null;\r\n\t\t\t//default: return event_name;\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Evalua el evento y devuelve los datos de las funciones relacionadas.\r\n\t * @param event_name Nombre del evento\r\n\t * @param data Data extra para agregar al evento\r\n\t * @returns \r\n\t */\r\n\tevalEvent(event_name: AnalyticEventKey, data: any) {\r\n\t\tswitch (event_name) {\r\n\t\t\tcase 'view_item': return this.toViewItem(data);\r\n\t\t\tcase 'view_item_list': return this.toViewItemList(data);\r\n\t\t\tcase 'checkout_init': return this.toCheckoutInit(data);\r\n\t\t\tcase 'shipping_info': return this.toShippingInfo(data);\r\n\t\t\tcase 'add_payment_info': return this.toPaymentInfo(data);\r\n\t\t\tcase 'purchase': return this.toPurchase(data);\r\n\t\t\tcase 'add_to_cart': return this.toAddToCart(data);\r\n\t\t\tcase 'remove_from_cart': return this.toRemoveToCart(data);\r\n\t\t\tcase 'sign_up': return this.toSignUp(data);\r\n\t\t\tdefault: return data;\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Evento que se dispara cuando se quiere comprar un producto.\r\n\t * @param data \r\n\t * @returns \r\n\t */\r\n\tprivate toPurchase(data: any) {\r\n\t\treturn {\r\n\t\t\tcoupon: this.toCartDiscount(data),\r\n\t\t\tcurrency: data.currency,\r\n\t\t\tshipping: data.totals.shipping,\r\n\t\t\ttax: data.totals.taxes,\r\n\t\t\tvalue: data.totals.total,\r\n\t\t\ttransaction_id: data.number,\r\n\t\t\titems: data.items.map((item: any) => ({\r\n\t\t\t\tid: item.product.id,\r\n\t\t\t\tname: item.product.name,\r\n\t\t\t\tcategory: item.product.category,\r\n\t\t\t\tprice: item.total,\r\n\t\t\t\tquantity: item.quantity\r\n\t\t\t}))\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Evento que se dispara cuando se inicializa en checkout.\r\n\t * @param data \r\n\t * @returns \r\n\t */\r\n\tprivate toCheckoutInit(data: any) {\r\n\t\treturn {\r\n\t\t\tcoupon: this.toCartDiscount(data),\r\n\t\t\tcurrency: data.currency || \"USD\",\r\n\t\t\titems: data.items.map((item: any) => ({\r\n\t\t\t\tid: item.product.id,\r\n\t\t\t\tname: item.product.name,\r\n\t\t\t\tcategory: item.product.category,\r\n\t\t\t\tprice: item.total,\r\n\t\t\t\tquantity: item.quantity\r\n\t\t\t})),\r\n\t\t\tvalue: data.totals?.total || 0,\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Evento que se dispara con los descuentos en el carrito.\r\n\t * @param data \r\n\t * @returns \r\n\t */\r\n\tprivate toCartDiscount(data: any) {\r\n\t\tlet strDiscount = ''\r\n\t\tstrDiscount = data.cartDiscounts.map((itemDiscount: any) => itemDiscount?.type).join()\r\n\t\treturn strDiscount == '' ? 'not-discount' : strDiscount\r\n\t}\r\n\t/**\r\n\t * Evento que se dispara cuando se agrega un producto al carrito. \r\n\t * @param data \r\n\t * @returns \r\n\t */\r\n\tprivate toAddToCart(data: any) {\r\n\t\tlet lastProduct = data.items?.length && data.items[data.items.length - 1]\r\n\t\treturn {\r\n\t\t\tcurrency: data.currency || \"USD\",\r\n\t\t\titems: [this.toItem({ quantity: lastProduct.quantity, ...lastProduct.product })],\r\n\t\t\tvalue: lastProduct.total || 0,\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Cambia la variable **enabled** a `false`\r\n\t * @returns \r\n\t */\r\n\tdisable() { this.enabled = false; }\r\n\t/**\r\n\t * Evento que se dispara cuando se interactua a las vista del producto.\r\n\t * @param product \r\n\t * @returns \r\n\t */\r\n\tprivate toViewItem(product: any) {\r\n\t\treturn {\r\n\t\t\tcurrency: product.currency,\r\n\t\t\titems: [this.toItem(product)],\r\n\t\t\tvalue: product.variants[0]?.saleprice || product.variants[0]?.price,\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Evento que se dispara cuando se interactua con el listado de productos.\r\n\t * @param data \r\n\t * @returns \r\n\t */\r\n\tprivate toViewItemList(data: any) {\r\n\t\treturn {\r\n\t\t\titems: data.products.map((product: any) => this.toItem(product)),\r\n\t\t\titem_list_name: data.item_list_name || 'Collection',\r\n\t\t\titem_list_id: data.item_list_id || 'collection'\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Evento que se dispara cuando se quita un item del carrito.\r\n\t * @param product \r\n\t * @returns \r\n\t */\r\n\tprivate toRemoveToCart(product: any) {\r\n\t\tlet productParam = product.product\r\n\t\treturn {\r\n\t\t\tcurrency: product.currency || \"USD\",\r\n\t\t\titems: [this.toItem({ quantity: product.quantity, ...productParam })],\r\n\t\t\tvalue: (productParam.variants[0]?.saleprice || productParam.variants[0]?.price) * product.quantity || 1,\r\n\t\t}\r\n\t}\r\n\r\n\tprivate toItem = (product: any) => ({\r\n\t\titem_name: product.name,\r\n\t\titem_id: product.id,\r\n\t\titem_brand: product.attributes?.length ? product.attributes[0].name : '',\r\n\t\titem_category: product.category,\r\n\t\tprice: product.variants[0]?.saleprice || product.variants[0]?.price,\r\n\t\tquantity: product.quantity || 1,\r\n\t})\r\n\t/**\r\n\t * Evento que se dispara cuando se consulta la información de pago.\r\n\t * @param data \r\n\t * @returns \r\n\t */\r\n\tprivate toPaymentInfo(data: any) {\r\n\t\treturn {\r\n\t\t\tcoupon: this.toCartDiscount(data),\r\n\t\t\tcurrency: data.currency || \"USD\",\r\n\t\t\titems: data.items.map((item: any) => ({\r\n\t\t\t\tid: item.product.id,\r\n\t\t\t\tname: item.product.name,\r\n\t\t\t\tcategory: item.product.category,\r\n\t\t\t\tprice: item.total,\r\n\t\t\t\tquantity: item.quantity\r\n\t\t\t})),\r\n\t\t\tpayment_type: data.payments[0]?.method?.code || 'not-payments',\r\n\t\t\tvalue: data.totals?.total || 0,\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Evento que se dispara cuando se interactua con los métodos de envío.\r\n\t * @param data \r\n\t * @returns \r\n\t */\r\n\tprivate toShippingInfo(data: any) {\r\n\t\treturn {\r\n\t\t\tcoupon: this.toCartDiscount(data),\r\n\t\t\tcurrency: data.currency || \"USD\",\r\n\t\t\titems: data.items.map((item: any) => ({\r\n\t\t\t\tid: item.product.id,\r\n\t\t\t\tname: item.product.name,\r\n\t\t\t\tcategory: item.product.category,\r\n\t\t\t\tprice: item.total,\r\n\t\t\t\tquantity: item.quantity\r\n\t\t\t})),\r\n\t\t\tshipping_tier: data.shipments[0]?.method?.code || 'not-shipping',\r\n\t\t\tvalue: data.totals?.total || 0,\r\n\t\t}\r\n\t}\r\n\r\n\tprivate toSignUp(data: any) {\r\n\t\treturn {\r\n\t\t\t...data\r\n\t\t}\r\n\t}\r\n}\r\n"]}
283
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-analytics.service.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-services/analytics/google-analytics.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT, isPlatformBrowser } from '@angular/common';\r\nimport { inject, Injectable, PLATFORM_ID, Renderer2, RendererFactory2 } from '@angular/core';\r\nimport { AnalyticEventKey } from '../../interfaces';\r\nimport { NavigationEnd, Router } from '@angular/router';\r\nimport { filter } from 'rxjs';\r\n/**\r\n * Funcion que sera dada por el script que se inserta en el inicializador de Google Analytics.\r\n */\r\ndeclare var gtag: Function;\r\ndeclare var dataLayer: any[];\r\n\r\n/**\r\n * Servicio encargado de manejar el analytics de google.\r\n * @class GoogleAnalyticsService\r\n */\r\n@Injectable({\r\n\tprovidedIn: 'root'\r\n})\r\nexport class GoogleAnalyticsService {\r\n\t/**\r\n\t * Se encarga de crear el elemento HTML con las configuraciones para \r\n\t * que se pueda ejecutar el servicio.\r\n\t */\r\n\tprivate renderer: Renderer2;\r\n\t/**\r\n\t * Indica cuando el servicio esta habilitado.\r\n\t */\r\n\tprivate enabled: boolean = false;\r\n\r\n\tprivate rendererFactory: RendererFactory2 = inject(RendererFactory2);\r\n\tprivate document: Document | null = null;\r\n\tprivate platformId = inject(PLATFORM_ID);\r\n\r\n\t/**\r\n\t * Servicio de ruteo de angular.\r\n\t */\r\n\tprivate router: Router = inject(Router);\r\n\r\n\tconstructor() {\r\n\t\tif (isPlatformBrowser(this.platformId)) {\r\n\t\t\tthis.document = inject(DOCUMENT); // Solo se inyecta en el navegador\r\n\t\t}\r\n\t\tthis.renderer = this.rendererFactory.createRenderer(null, null);\r\n\t}\r\n\t/**\r\n\t * Inicializa el Servicio de analytics con sus configuraciones.\r\n\t * @param gtm_id id provisto por Google Tag Manager.\r\n\t */\r\n\tinitialize(gtm_id: string) {\r\n\t\tif (!document.getElementById('google_tag_manager')) {\r\n\t\t\tconsole.log('hay elemento')\r\n\t\t\tconst declaration = this.renderer.createElement('script');\r\n\t\t\tdeclaration.async = true;\r\n\t\t\tdeclaration.id = 'google_tag_manager';\r\n\t\t\tdeclaration.src = `https://www.googletagmanager.com/gtag/js?id=${gtm_id}`;\r\n\t\t\tconst initialization = this.renderer.createElement('script');\r\n\t\t\tinitialization.text = `window.dataLayer = window.dataLayer || []; function gtag(){dataLayer.push(arguments);} gtag('js', new Date()); gtag('config', '${gtm_id}')`;\r\n\t\t\tthis.renderer.appendChild(this.document?.head, initialization);\r\n\t\t\tthis.renderer.appendChild(this.document?.head, declaration);\r\n\t\t\tthis.enabled = true;\r\n\t\t}\r\n\t\tsetTimeout(() => this.startListeningPageViews(gtm_id), 1000);\r\n\t}\r\n\t/**\r\n\t * \r\n\t * @param gtm_id \r\n\t */\r\n\tprivate startListeningPageViews(gtm_id: any) {\r\n\t\tthis.router.events.pipe(\r\n\t\t\tfilter(event => event instanceof NavigationEnd)\r\n\t\t).subscribe((event: NavigationEnd) => {\r\n\t\t\tgtag('config', gtm_id, {\r\n\t\t\t\t'page_path': event.urlAfterRedirects\r\n\t\t\t})\r\n\t\t})\r\n\t}\r\n\t/**\r\n\t * Ejecuta el evento pasado por parametro. \r\n\t * @param event_name Nombre del evento.\r\n\t * @param data Data extra para agregar al evento.\r\n\t * @returns \r\n\t */\r\n\tcallEvent(event_name: AnalyticEventKey, data = {}) {\r\n\t\tif (!this.enabled) return;\r\n\t\tlet event = this.translateEventName(event_name);\r\n\t\tevent && gtag('event', this.translateEventName(event_name), this.evalEvent(event_name, data));\r\n\t}\r\n\t/**\r\n\t * Traduce el evento recibido y devuelve el nombre de la función que lo va a tratar.\r\n\t * @param event_name \r\n\t * @returns \r\n\t */\r\n\ttranslateEventName(event_name: AnalyticEventKey) {\r\n\t\tswitch (event_name) {\r\n\t\t\tcase 'view_item': return 'view_item';\r\n\t\t\tcase 'view_item_list': return 'view_item_list';\r\n\t\t\tcase 'checkout_init': return 'begin_checkout';\r\n\t\t\tcase 'shipping_info': return 'add_shipping_info';\r\n\t\t\tcase 'add_payment_info': return 'add_payment_info';\r\n\t\t\tcase 'purchase': return 'purchase';\r\n\t\t\tcase 'add_to_cart': return 'add_to_cart';\r\n\t\t\tcase 'remove_from_cart': return 'remove_from_cart';\r\n\t\t\tcase 'sign_up': return 'sign_up';\r\n\t\t\tdefault: return null;\r\n\t\t\t//default: return event_name;\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Evalua el evento y devuelve los datos de las funciones relacionadas.\r\n\t * @param event_name Nombre del evento\r\n\t * @param data Data extra para agregar al evento\r\n\t * @returns \r\n\t */\r\n\tevalEvent(event_name: AnalyticEventKey, data: any) {\r\n\t\tswitch (event_name) {\r\n\t\t\tcase 'view_item': return this.toViewItem(data);\r\n\t\t\tcase 'view_item_list': return this.toViewItemList(data);\r\n\t\t\tcase 'checkout_init': return this.toCheckoutInit(data);\r\n\t\t\tcase 'shipping_info': return this.toShippingInfo(data);\r\n\t\t\tcase 'add_payment_info': return this.toPaymentInfo(data);\r\n\t\t\tcase 'purchase': return this.toPurchase(data);\r\n\t\t\tcase 'add_to_cart': return this.toAddToCart(data);\r\n\t\t\tcase 'remove_from_cart': return this.toRemoveToCart(data);\r\n\t\t\tcase 'sign_up': return this.toSignUp(data);\r\n\t\t\tdefault: return data;\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Evento que se dispara cuando se quiere comprar un producto.\r\n\t * @param data \r\n\t * @returns \r\n\t */\r\n\tprivate toPurchase(data: any) {\r\n\t\treturn {\r\n\t\t\tcoupon: this.toCartDiscount(data),\r\n\t\t\tcurrency: data.currency,\r\n\t\t\tshipping: data.totals.shipping,\r\n\t\t\ttax: data.totals.taxes,\r\n\t\t\tvalue: data.totals.total,\r\n\t\t\ttransaction_id: data.number,\r\n\t\t\titems: data.items.map((item: any) => ({\r\n\t\t\t\tid: item.product.id,\r\n\t\t\t\tname: item.product.name,\r\n\t\t\t\tcategory: item.product.category,\r\n\t\t\t\tprice: item.total,\r\n\t\t\t\tquantity: item.quantity\r\n\t\t\t}))\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Evento que se dispara cuando se inicializa en checkout.\r\n\t * @param data \r\n\t * @returns \r\n\t */\r\n\tprivate toCheckoutInit(data: any) {\r\n\t\treturn {\r\n\t\t\tcoupon: this.toCartDiscount(data),\r\n\t\t\tcurrency: data.currency || \"USD\",\r\n\t\t\titems: data.items.map((item: any) => ({\r\n\t\t\t\tid: item.product.id,\r\n\t\t\t\tname: item.product.name,\r\n\t\t\t\tcategory: item.product.category,\r\n\t\t\t\tprice: item.total,\r\n\t\t\t\tquantity: item.quantity\r\n\t\t\t})),\r\n\t\t\tvalue: data.totals?.total || 0,\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Evento que se dispara con los descuentos en el carrito.\r\n\t * @param data \r\n\t * @returns \r\n\t */\r\n\tprivate toCartDiscount(data: any) {\r\n\t\tlet strDiscount = ''\r\n\t\tstrDiscount = data.cartDiscounts.map((itemDiscount: any) => itemDiscount?.type).join()\r\n\t\treturn strDiscount == '' ? 'not-discount' : strDiscount\r\n\t}\r\n\t/**\r\n\t * Evento que se dispara cuando se agrega un producto al carrito. \r\n\t * @param data \r\n\t * @returns \r\n\t */\r\n\tprivate toAddToCart(data: any) {\r\n\t\tlet lastProduct = data.items?.length && data.items[data.items.length - 1]\r\n\t\treturn {\r\n\t\t\tcurrency: data.currency || \"USD\",\r\n\t\t\titems: [this.toItem({ quantity: lastProduct.quantity, ...lastProduct.product })],\r\n\t\t\tvalue: lastProduct.total || 0,\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Cambia la variable **enabled** a `false`\r\n\t * @returns \r\n\t */\r\n\tdisable() { this.enabled = false; }\r\n\t/**\r\n\t * Evento que se dispara cuando se interactua a las vista del producto.\r\n\t * @param product \r\n\t * @returns \r\n\t */\r\n\tprivate toViewItem(product: any) {\r\n\t\treturn {\r\n\t\t\tcurrency: product.currency,\r\n\t\t\titems: [this.toItem(product)],\r\n\t\t\tvalue: product.variants[0]?.saleprice || product.variants[0]?.price,\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Evento que se dispara cuando se interactua con el listado de productos.\r\n\t * @param data \r\n\t * @returns \r\n\t */\r\n\tprivate toViewItemList(data: any) {\r\n\t\treturn {\r\n\t\t\titems: data.products.map((product: any) => this.toItem(product)),\r\n\t\t\titem_list_name: data.item_list_name || 'Collection',\r\n\t\t\titem_list_id: data.item_list_id || 'collection'\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Evento que se dispara cuando se quita un item del carrito.\r\n\t * @param product \r\n\t * @returns \r\n\t */\r\n\tprivate toRemoveToCart(product: any) {\r\n\t\tlet productParam = product.product\r\n\t\treturn {\r\n\t\t\tcurrency: product.currency || \"USD\",\r\n\t\t\titems: [this.toItem({ quantity: product.quantity, ...productParam })],\r\n\t\t\tvalue: (productParam.variants[0]?.saleprice || productParam.variants[0]?.price) * product.quantity || 1,\r\n\t\t}\r\n\t}\r\n\r\n\tprivate toItem = (product: any) => ({\r\n\t\titem_name: product.name,\r\n\t\titem_id: product.id,\r\n\t\titem_brand: product.attributes?.length ? product.attributes[0].name : '',\r\n\t\titem_category: product.category,\r\n\t\tprice: product.variants[0]?.saleprice || product.variants[0]?.price,\r\n\t\tquantity: product.quantity || 1,\r\n\t})\r\n\t/**\r\n\t * Evento que se dispara cuando se consulta la información de pago.\r\n\t * @param data \r\n\t * @returns \r\n\t */\r\n\tprivate toPaymentInfo(data: any) {\r\n\t\treturn {\r\n\t\t\tcoupon: this.toCartDiscount(data),\r\n\t\t\tcurrency: data.currency || \"USD\",\r\n\t\t\titems: data.items.map((item: any) => ({\r\n\t\t\t\tid: item.product.id,\r\n\t\t\t\tname: item.product.name,\r\n\t\t\t\tcategory: item.product.category,\r\n\t\t\t\tprice: item.total,\r\n\t\t\t\tquantity: item.quantity\r\n\t\t\t})),\r\n\t\t\tpayment_type: data.payments[0]?.method?.code || 'not-payments',\r\n\t\t\tvalue: data.totals?.total || 0,\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Evento que se dispara cuando se interactua con los métodos de envío.\r\n\t * @param data \r\n\t * @returns \r\n\t */\r\n\tprivate toShippingInfo(data: any) {\r\n\t\treturn {\r\n\t\t\tcoupon: this.toCartDiscount(data),\r\n\t\t\tcurrency: data.currency || \"USD\",\r\n\t\t\titems: data.items.map((item: any) => ({\r\n\t\t\t\tid: item.product.id,\r\n\t\t\t\tname: item.product.name,\r\n\t\t\t\tcategory: item.product.category,\r\n\t\t\t\tprice: item.total,\r\n\t\t\t\tquantity: item.quantity\r\n\t\t\t})),\r\n\t\t\tshipping_tier: data.shipments[0]?.method?.code || 'not-shipping',\r\n\t\t\tvalue: data.totals?.total || 0,\r\n\t\t}\r\n\t}\r\n\r\n\tprivate toSignUp(data: any) {\r\n\t\treturn {\r\n\t\t\t...data\r\n\t\t}\r\n\t}\r\n}\r\n"]}