ng-easycommerce-v18 0.3.17 → 0.3.18-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 +3 -0
- package/esm2022/lib/constants/api.constants.service.mjs +19 -15
- package/esm2022/lib/ec-components/blocks-ec/block-products-ec/block-products-ec.component.mjs +4 -2
- package/esm2022/lib/ec-components/header-ec/header-ec.component.mjs +31 -21
- package/esm2022/lib/ec-services/analytics/google-analytics.service.mjs +2 -2
- package/esm2022/lib/ec-services/base-api.service.mjs +148 -0
- package/esm2022/lib/ec-services/checkout.service.mjs +4 -2
- package/esm2022/lib/ec-services/index.mjs +3 -1
- package/esm2022/lib/ec-services/runtime-config.service.mjs +149 -0
- package/esm2022/lib/interfaces/environment.mjs +1 -1
- package/esm2022/lib/interfaces/index.mjs +2 -1
- package/esm2022/lib/interfaces/runtime-config.mjs +2 -0
- package/esm2022/lib/providers/index.mjs +2 -1
- package/esm2022/lib/providers/provideRuntimeConfig.mjs +39 -0
- package/fesm2022/ng-easycommerce-v18.mjs +435 -95
- package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
- package/lib/constants/api.constants.service.d.ts +1 -0
- package/lib/ec-services/base-api.service.d.ts +64 -0
- package/lib/ec-services/index.d.ts +2 -0
- package/lib/ec-services/runtime-config.service.d.ts +56 -0
- package/lib/interfaces/environment.d.ts +1 -0
- package/lib/interfaces/index.d.ts +1 -0
- package/lib/interfaces/runtime-config.d.ts +22 -0
- package/lib/providers/index.d.ts +1 -0
- package/lib/providers/provideRuntimeConfig.d.ts +12 -0
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
# Version 0.3.18-beta.1
|
|
2
|
+
- Se modifican servicios y componentes para que funcione el deploy SSR.
|
|
3
|
+
- Se elimina uso de DOM ya que en SSR tira error.
|
|
1
4
|
# Version 0.3.17
|
|
2
5
|
- En el `header-ec.component.ts` se hacen public algunos injectores para poder usarlo en el `header.component.ts` de los frontends.
|
|
3
6
|
# Version 0.3.16
|
|
@@ -2,6 +2,7 @@ import { inject, Injectable } from '@angular/core';
|
|
|
2
2
|
import { ENVIRONMENT_TOKEN } from '../providers';
|
|
3
3
|
import { LocalStorageService } from '../ec-services';
|
|
4
4
|
import { TranslateService } from '@ngx-translate/core';
|
|
5
|
+
import { RuntimeConfigService } from '../ec-services/runtime-config.service';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
/**
|
|
7
8
|
* Servicio que provee de datos que estan relacionado con las peticiones a la API
|
|
@@ -11,6 +12,7 @@ import * as i0 from "@angular/core";
|
|
|
11
12
|
export class ApiConstantsService {
|
|
12
13
|
_localStorage = inject(LocalStorageService);
|
|
13
14
|
_translate = inject(TranslateService);
|
|
15
|
+
_runtimeConfig = inject(RuntimeConfigService);
|
|
14
16
|
/**
|
|
15
17
|
* Contiene los datos provisto por el frontend en el archivo environment.ts
|
|
16
18
|
*/
|
|
@@ -19,13 +21,10 @@ export class ApiConstantsService {
|
|
|
19
21
|
* Canal actual del frontend
|
|
20
22
|
*/
|
|
21
23
|
get CHANNEL() {
|
|
22
|
-
//
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
if (windowEnv?.channel) {
|
|
27
|
-
return windowEnv.channel;
|
|
28
|
-
}
|
|
24
|
+
// Usar runtime config primero
|
|
25
|
+
const runtimeConfig = this._runtimeConfig.getConfig();
|
|
26
|
+
if (runtimeConfig?.channel) {
|
|
27
|
+
return runtimeConfig.channel;
|
|
29
28
|
}
|
|
30
29
|
// Fallback al environment
|
|
31
30
|
return this._channel;
|
|
@@ -47,20 +46,25 @@ export class ApiConstantsService {
|
|
|
47
46
|
*/
|
|
48
47
|
CMS_URL = 'cms/';
|
|
49
48
|
constructor() {
|
|
49
|
+
// Inicializar con valores por defecto del environment
|
|
50
50
|
this._channel = this.environment.channel;
|
|
51
51
|
this.LOCALE = this.environment.locale;
|
|
52
|
+
// Actualizar con runtime config cuando esté disponible
|
|
53
|
+
this._runtimeConfig.config$.subscribe(config => {
|
|
54
|
+
if (config) {
|
|
55
|
+
this._channel = config.channel;
|
|
56
|
+
this.LOCALE = config.locale;
|
|
57
|
+
}
|
|
58
|
+
});
|
|
52
59
|
}
|
|
53
60
|
/**
|
|
54
61
|
* URL del backend para realizar las peticiones
|
|
55
62
|
*/
|
|
56
63
|
get API_URL() {
|
|
57
|
-
//
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
if (windowEnv?.apiUrl) {
|
|
62
|
-
return windowEnv.apiUrl;
|
|
63
|
-
}
|
|
64
|
+
// Usar runtime config primero
|
|
65
|
+
const runtimeConfig = this._runtimeConfig.getConfig();
|
|
66
|
+
if (runtimeConfig?.apiUrl) {
|
|
67
|
+
return runtimeConfig.apiUrl;
|
|
64
68
|
}
|
|
65
69
|
// Fallback al environment (para SSR y como backup)
|
|
66
70
|
return this.environment.apiUrl ?? '';
|
|
@@ -95,4 +99,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
95
99
|
providedIn: 'root'
|
|
96
100
|
}]
|
|
97
101
|
}], ctorParameters: () => [] });
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmNvbnN0YW50cy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2NvbnN0YW50cy9hcGkuY29uc3RhbnRzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRWpELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRXZELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDOztBQUU3RTs7OztHQUlHO0FBSUgsTUFBTSxPQUFPLG1CQUFtQjtJQUN2QixhQUFhLEdBQXdCLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0lBQ2pFLFVBQVUsR0FBcUIsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDeEQsY0FBYyxHQUF5QixNQUFNLENBQUMsb0JBQW9CLENBQUMsQ0FBQztJQUU1RTs7T0FFRztJQUNLLFdBQVcsR0FBZ0IsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUM7SUFFN0Q7O09BRUc7SUFDSCxJQUFXLE9BQU87UUFDakIsOEJBQThCO1FBQzlCLE1BQU0sYUFBYSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDdEQsSUFBSSxhQUFhLEVBQUUsT0FBTyxFQUFFLENBQUM7WUFDNUIsT0FBTyxhQUFhLENBQUMsT0FBTyxDQUFDO1FBQzlCLENBQUM7UUFFRCwwQkFBMEI7UUFDMUIsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQ3RCLENBQUM7SUFFRCxJQUFXLE9BQU8sQ0FBQyxLQUFhO1FBQy9CLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO0lBQ3ZCLENBQUM7SUFFTyxRQUFRLENBQVM7SUFDekI7O09BRUc7SUFDSSxNQUFNLENBQVM7SUFFdEI7O09BRUc7SUFDYSxZQUFZLEdBQVcsV0FBVyxDQUFDO0lBQ25EOztPQUVHO0lBQ2EsT0FBTyxHQUFXLE1BQU0sQ0FBQztJQUV6QztRQUNDLHNEQUFzRDtRQUN0RCxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDO1FBQ3pDLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUM7UUFFdEMsdURBQXVEO1FBQ3ZELElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUM5QyxJQUFJLE1BQU0sRUFBRSxDQUFDO2dCQUNaLElBQUksQ0FBQyxRQUFRLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQztnQkFDL0IsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDO1lBQzdCLENBQUM7UUFDRixDQUFDLENBQUMsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNILElBQVcsT0FBTztRQUNqQiw4QkFBOEI7UUFDOUIsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUN0RCxJQUFJLGFBQWEsRUFBRSxNQUFNLEVBQUUsQ0FBQztZQUMzQixPQUFPLGFBQWEsQ0FBQyxNQUFNLENBQUM7UUFDN0IsQ0FBQztRQUVELG1EQUFtRDtRQUNuRCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxJQUFJLEVBQUUsQ0FBQztJQUN0QyxDQUFDO0lBQ0Q7OztPQUdHO0lBQ0ksVUFBVTtRQUNoQixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDckIsQ0FBQztJQUNEOzs7O09BSUc7SUFDSSxVQUFVLENBQUMsSUFBWSxJQUFRLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLENBQUEsQ0FBQztJQUVwRCxTQUFTLENBQUMsTUFBYztRQUM5QixJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ3BELElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQTtRQUN6QyxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztJQUN0QixDQUFDO0lBRUQsYUFBYTtJQUNJLFVBQVUsR0FBVSxRQUFRLENBQUM7SUFDN0IsV0FBVyxHQUFVLFNBQVMsQ0FBQzt3R0E1RnBDLG1CQUFtQjs0R0FBbkIsbUJBQW1CLGNBRmxCLE1BQU07OzRGQUVQLG1CQUFtQjtrQkFIL0IsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRU5WSVJPTk1FTlRfVE9LRU4gfSBmcm9tICcuLi9wcm92aWRlcnMnO1xyXG5pbXBvcnQgeyBFbnZpcm9ubWVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xyXG5pbXBvcnQgeyBMb2NhbFN0b3JhZ2VTZXJ2aWNlIH0gZnJvbSAnLi4vZWMtc2VydmljZXMnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XHJcbmltcG9ydCB7IENvcmVDb25zdGFudHNTZXJ2aWNlIH0gZnJvbSAnLi9jb3JlLmNvbnN0YW50cy5zZXJ2aWNlJztcclxuaW1wb3J0IHsgUnVudGltZUNvbmZpZ1NlcnZpY2UgfSBmcm9tICcuLi9lYy1zZXJ2aWNlcy9ydW50aW1lLWNvbmZpZy5zZXJ2aWNlJztcclxuXHJcbi8qKlxyXG4gKiBTZXJ2aWNpbyBxdWUgcHJvdmVlIGRlIGRhdG9zIHF1ZSBlc3RhbiByZWxhY2lvbmFkbyBjb24gbGFzIHBldGljaW9uZXMgYSBsYSBBUElcclxuICogQGV4cG9ydFxyXG4gKiBAY2xhc3MgQXBpQ29uc3RhbnRzU2VydmljZVxyXG4gKi9cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQXBpQ29uc3RhbnRzU2VydmljZSB7XHJcblx0cHJpdmF0ZSBfbG9jYWxTdG9yYWdlOiBMb2NhbFN0b3JhZ2VTZXJ2aWNlID0gaW5qZWN0KExvY2FsU3RvcmFnZVNlcnZpY2UpO1xyXG5cdHByaXZhdGUgX3RyYW5zbGF0ZTogVHJhbnNsYXRlU2VydmljZSA9IGluamVjdChUcmFuc2xhdGVTZXJ2aWNlKTtcclxuXHRwcml2YXRlIF9ydW50aW1lQ29uZmlnOiBSdW50aW1lQ29uZmlnU2VydmljZSA9IGluamVjdChSdW50aW1lQ29uZmlnU2VydmljZSk7XHJcblxyXG5cdC8qKlxyXG5cdCAqIENvbnRpZW5lIGxvcyBkYXRvcyBwcm92aXN0byBwb3IgZWwgZnJvbnRlbmQgZW4gZWwgYXJjaGl2byBlbnZpcm9ubWVudC50c1xyXG5cdCAqL1xyXG5cdHByaXZhdGUgZW52aXJvbm1lbnQ6IEVudmlyb25tZW50ID0gaW5qZWN0KEVOVklST05NRU5UX1RPS0VOKTtcclxuXHRcclxuXHQvKipcclxuXHQgKiBDYW5hbCBhY3R1YWwgZGVsIGZyb250ZW5kXHJcblx0ICovXHJcblx0cHVibGljIGdldCBDSEFOTkVMKCk6IHN0cmluZyB7XHJcblx0XHQvLyBVc2FyIHJ1bnRpbWUgY29uZmlnIHByaW1lcm9cclxuXHRcdGNvbnN0IHJ1bnRpbWVDb25maWcgPSB0aGlzLl9ydW50aW1lQ29uZmlnLmdldENvbmZpZygpO1xyXG5cdFx0aWYgKHJ1bnRpbWVDb25maWc/LmNoYW5uZWwpIHtcclxuXHRcdFx0cmV0dXJuIHJ1bnRpbWVDb25maWcuY2hhbm5lbDtcclxuXHRcdH1cclxuXHRcdFxyXG5cdFx0Ly8gRmFsbGJhY2sgYWwgZW52aXJvbm1lbnRcclxuXHRcdHJldHVybiB0aGlzLl9jaGFubmVsO1xyXG5cdH1cclxuXHRcclxuXHRwdWJsaWMgc2V0IENIQU5ORUwodmFsdWU6IHN0cmluZykge1xyXG5cdFx0dGhpcy5fY2hhbm5lbCA9IHZhbHVlO1xyXG5cdH1cclxuXHRcclxuXHRwcml2YXRlIF9jaGFubmVsOiBzdHJpbmc7XHJcblx0LyoqXHJcblx0ICogTG9jYWxlIGFjdHVhbCBkZWwgZnJvbnRlbmRcclxuXHQgKi9cclxuXHRwdWJsaWMgTE9DQUxFOiBzdHJpbmc7XHJcblx0XHJcblx0LyoqXHJcblx0ICogVVJMIHBhcmEgbGFzIHBldGljaW9uZXMgYSBzaG9wLWFwaVxyXG5cdCAqL1xyXG5cdHB1YmxpYyByZWFkb25seSBTSE9QX0FQSV9VUkw6IHN0cmluZyA9ICdzaG9wLWFwaS8nO1xyXG5cdC8qKlxyXG5cdCAqIFVSTCBwYXJhIGxhcyBwZXRpY2lvbmVzIGEgY21zXHJcblx0ICovXHJcblx0cHVibGljIHJlYWRvbmx5IENNU19VUkw6IHN0cmluZyA9ICdjbXMvJztcclxuXHJcblx0Y29uc3RydWN0b3IoKSB7XHJcblx0XHQvLyBJbmljaWFsaXphciBjb24gdmFsb3JlcyBwb3IgZGVmZWN0byBkZWwgZW52aXJvbm1lbnRcclxuXHRcdHRoaXMuX2NoYW5uZWwgPSB0aGlzLmVudmlyb25tZW50LmNoYW5uZWw7XHJcblx0XHR0aGlzLkxPQ0FMRSA9IHRoaXMuZW52aXJvbm1lbnQubG9jYWxlO1xyXG5cclxuXHRcdC8vIEFjdHVhbGl6YXIgY29uIHJ1bnRpbWUgY29uZmlnIGN1YW5kbyBlc3TDqSBkaXNwb25pYmxlXHJcblx0XHR0aGlzLl9ydW50aW1lQ29uZmlnLmNvbmZpZyQuc3Vic2NyaWJlKGNvbmZpZyA9PiB7XHJcblx0XHRcdGlmIChjb25maWcpIHtcclxuXHRcdFx0XHR0aGlzLl9jaGFubmVsID0gY29uZmlnLmNoYW5uZWw7XHJcblx0XHRcdFx0dGhpcy5MT0NBTEUgPSBjb25maWcubG9jYWxlO1xyXG5cdFx0XHR9XHJcblx0XHR9KTtcclxuXHR9XHJcblxyXG5cdC8qKlxyXG5cdCAqIFVSTCBkZWwgYmFja2VuZCBwYXJhIHJlYWxpemFyIGxhcyBwZXRpY2lvbmVzXHJcblx0ICovXHJcblx0cHVibGljIGdldCBBUElfVVJMKCk6IHN0cmluZyB7XHJcblx0XHQvLyBVc2FyIHJ1bnRpbWUgY29uZmlnIHByaW1lcm9cclxuXHRcdGNvbnN0IHJ1bnRpbWVDb25maWcgPSB0aGlzLl9ydW50aW1lQ29uZmlnLmdldENvbmZpZygpO1xyXG5cdFx0aWYgKHJ1bnRpbWVDb25maWc/LmFwaVVybCkge1xyXG5cdFx0XHRyZXR1cm4gcnVudGltZUNvbmZpZy5hcGlVcmw7XHJcblx0XHR9XHJcblx0XHRcclxuXHRcdC8vIEZhbGxiYWNrIGFsIGVudmlyb25tZW50IChwYXJhIFNTUiB5IGNvbW8gYmFja3VwKVxyXG5cdFx0cmV0dXJuIHRoaXMuZW52aXJvbm1lbnQuYXBpVXJsID8/ICcnO1xyXG5cdH1cclxuXHQvKipcclxuXHQgKiBSZXRvcm5hIGxhIHVybCBiYXNlXHJcblx0ICogQHJldHVybnMge3N0cmluZ31cclxuXHQgKi9cclxuXHRwdWJsaWMgZ2V0VXJsQmFzZSgpOiBzdHJpbmcgeyBcclxuXHRcdHJldHVybiB0aGlzLkFQSV9VUkw7XHJcblx0fSBcclxuXHQvKipcclxuXHQgKiBDYW1iaWEgZWwgY2FuYWwgYWN0dWFsXHJcblx0ICogQHBhcmFtIGNvZGVcclxuXHQgKiBAcmV0dXJucyBcclxuXHQgKi9cclxuXHRwdWJsaWMgc2V0Q2hhbm5lbChjb2RlOiBzdHJpbmcpOnZvaWR7IHRoaXMuQ0hBTk5FTCA9IGNvZGU7fSBcclxuXHJcblx0cHVibGljIHNldExvY2FsZShsb2NhbGU6IHN0cmluZyk6dm9pZHtcclxuXHRcdHRoaXMuX2xvY2FsU3RvcmFnZS5zZXRJdGVtKHRoaXMuTE9DQUxFX0tFWSwgbG9jYWxlKTtcclxuXHRcdHRoaXMuX3RyYW5zbGF0ZS51c2UobG9jYWxlLnNwbGl0KCdfJylbMF0pXHJcblx0XHR0aGlzLkxPQ0FMRSA9IGxvY2FsZTtcclxuXHR9XHJcblxyXG5cdC8vU3RvcmFnZSBrZXlcclxuXHRwcml2YXRlIHJlYWRvbmx5IExPQ0FMRV9LRVk6c3RyaW5nID0gJ0xPQ0FMRSc7XHJcblx0cHJpdmF0ZSByZWFkb25seSBDSEFOTkVMX0tFWTpzdHJpbmcgPSAnQ0hBTk5FTCc7XHJcbn1cclxuIl19
|
package/esm2022/lib/ec-components/blocks-ec/block-products-ec/block-products-ec.component.mjs
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Component, CUSTOM_ELEMENTS_SCHEMA, inject, Input, PLATFORM_ID, signal } from '@angular/core';
|
|
2
2
|
import { BlockEcComponent } from '../../abstractions-components';
|
|
3
3
|
import { AnalyticsService } from '../../../ec-services';
|
|
4
|
-
import { CommonModule } from '@angular/common';
|
|
4
|
+
import { CommonModule, isPlatformBrowser } from '@angular/common';
|
|
5
5
|
// import function to register Swiper custom elements
|
|
6
6
|
import { register } from 'swiper/element/bundle';
|
|
7
7
|
import { ProductEcComponent } from "../../product-ec/product-ec.component";
|
|
@@ -78,6 +78,8 @@ export class BlockProductsEcComponent extends BlockEcComponent {
|
|
|
78
78
|
* Esta función puede ser movida al componente base para reutilización.
|
|
79
79
|
*/
|
|
80
80
|
initializeSwiperWithCustomNavigation() {
|
|
81
|
+
if (!isPlatformBrowser(this.platformId))
|
|
82
|
+
return;
|
|
81
83
|
const prevButton = document.getElementById(`${this.meta?.code}-prev`);
|
|
82
84
|
const nextButton = document.getElementById(`${this.meta?.code}-next`);
|
|
83
85
|
const swiperElement = document.getElementById(this.meta?.code);
|
|
@@ -216,4 +218,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
216
218
|
required: true
|
|
217
219
|
}]
|
|
218
220
|
}] } });
|
|
219
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"block-products-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/blocks-ec/block-products-ec/block-products-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/blocks-ec/block-products-ec/block-products-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { afterNextRender, AfterViewInit, Component, CUSTOM_ELEMENTS_SCHEMA, inject, Input, PLATFORM_ID, signal, TemplateRef } from '@angular/core';\r\nimport { BlockEcComponent } from '../../abstractions-components';\r\nimport { SwiperOptions } from 'swiper/types';\r\nimport { AnalyticsService } from '../../../ec-services';\r\nimport { CommonModule, isPlatformBrowser } from '@angular/common';\r\n// import function to register Swiper custom elements\r\nimport { register, SwiperContainer } from 'swiper/element/bundle';\r\nimport { ProductEcComponent } from \"../../product-ec/product-ec.component\";\r\n\r\nregister()\r\n/**\r\n * Componen para manejar los bloques de productos.\r\n * @extends {BlockEcComponent}\r\n * @class BlockProductsEcComponent\r\n */\r\n@Component({\r\n\tselector: 'app-block-products-ec',\r\n\tstandalone: true,\r\n\timports: [CommonModule, ProductEcComponent],\r\n\ttemplateUrl: './block-products-ec.component.html',\r\n\tstyleUrl: './block-products-ec.component.scss',\r\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA]\r\n})\r\nexport class BlockProductsEcComponent extends BlockEcComponent implements AfterViewInit {\r\n\t\t// Personalización de las flechas de navegación\r\n\t// Por defecto usa símbolos de texto, pero se pueden especificar imágenes\r\n\t@Input() prevArrowImage?: string; // undefined = usa símbolo de texto\r\n\t@Input() nextArrowImage?: string; // undefined = usa símbolo de texto\r\n\t@Input() prevArrowText: string = '<';\r\n\t@Input() nextArrowText: string = '>';\r\n\t/**\r\n\t * Servicio de Analytics\r\n\t */\r\n\tprivate analyticsService: AnalyticsService = inject(AnalyticsService)\r\n\t/**\r\n\t * Signal utlizado para guarda el contenedor del carrusel\r\n\t */\r\n\tswiperElement = signal<SwiperContainer | null>(null)\r\n\t/**\r\n\t * Input que recibe un template para el producto.\r\n\t */\r\n\t@Input() appProduct: TemplateRef<any> | undefined;\r\n\t/**\r\n\t * Colección de productos.\r\n\t */\r\n\t@Input({\r\n\t\trequired: true\r\n\t}) products: any; // Product[];\r\n\t/**\r\n\t * Bloque principal que contiene los productos\r\n\t */\r\n\t@Input({\r\n\t\trequired: true\r\n\t}) meta: any;\r\n\r\n\tngAfterViewInit() {\r\n\t\tthis.setupSwiperNavigation();\r\n\t}\r\n\t\r\n\tprivate document?: Document;\r\n\tprivate platformId: any = inject(PLATFORM_ID)\r\n\r\n\t/**\r\n\t * Ejecuta el método `afterNextRender`para cargar las configuraciones necesarias \r\n\t * para el carrusel del banners. Esto debe ser asi debido a que ya debe estar presente\r\n\t * en el Dom el element `<swiper-container>` para poder configurarlo.\r\n\t */\r\n\tconstructor() {\r\n\t\tsuper()\r\n\t}\r\n\t/**\r\n\t * Aplica el evento `select_promotion` junto con el banner que interactua.\r\n\t * @param banner \r\n\t */\r\n\tselectPromotion(item: any): void {\r\n\t\tthis.analyticsService.callEvent('select_promotion', item)\r\n\t}\r\n\r\n\t/**\r\n\t * Configura la navegación personalizada del Swiper.\r\n\t * Esta función está diseñada para ser movida al componente base BlockProductsEcComponent.\r\n\t * Permite personalización de las imágenes de las flechas mediante @Input.\r\n\t */\r\n\tprivate setupSwiperNavigation() {\r\n\t\tif (this.meta?.styles?.carrousel !== false) {\r\n\t\t\t// Usar setTimeout para asegurar que el swiper esté inicializado\r\n\t\t\tsetTimeout(() => {\r\n\t\t\t\tthis.initializeSwiperWithCustomNavigation();\r\n\t\t\t}, 200);\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Inicializa el Swiper con navegación personalizada.\r\n\t * Esta función puede ser movida al componente base para reutilización.\r\n\t */\r\n\tprivate initializeSwiperWithCustomNavigation() {\r\n\t\tconst prevButton = document.getElementById(`${this.meta?.code}-prev`);\r\n\t\tconst nextButton = document.getElementById(`${this.meta?.code}-next`);\r\n\t\tconst swiperElement = document.getElementById(this.meta?.code) as any;\r\n\r\n\t\tif (prevButton && nextButton && swiperElement) {\r\n\t\t\t// console.log('Configurando navegación personalizada para:', this.meta?.code);\r\n\t\t\t\r\n\t\t\tconst swiperConfig = this.getSwiperConfiguration();\r\n\r\n\t\t\t// Verificar si el Swiper ya está inicializado\r\n\t\t\tif (!swiperElement.swiper) {\r\n\t\t\t\tthis.initializeNewSwiper(swiperElement, swiperConfig);\r\n\t\t\t} else {\r\n\t\t\t\tthis.updateExistingSwiper(swiperElement);\r\n\t\t\t}\r\n\r\n\t\t\t// Configurar los event listeners para los botones\r\n\t\t\tthis.setupNavigationEventListeners(prevButton, nextButton, swiperElement);\r\n\t\t\t\r\n\t\t\t// console.log('Event listeners configurados para los botones de navegación');\r\n\t\t} else {\r\n\t\t\t// console.log('No se pudieron encontrar los elementos:', {\r\n\t\t\t// \tprevButton: !!prevButton,\r\n\t\t\t// \tnextButton: !!nextButton,\r\n\t\t\t// \tswiperElement: !!swiperElement\r\n\t\t\t// });\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Obtiene la configuración base del Swiper.\r\n\t * Esta configuración puede ser personalizada en el futuro mediante @Input.\r\n\t */\r\n\tprivate getSwiperConfiguration() {\r\n\t\treturn {\r\n\t\t\tslidesPerView: 'auto',\r\n\t\t\tspaceBetween: 16,\r\n\t\t\tslidesPerGroup: 1, // Importante: moverse de uno en uno\r\n\t\t\tnavigation: false, // Deshabilitamos la navegación por defecto\r\n\t\t\tpagination: false,\r\n\t\t\tloop: true,\r\n\t\t\tgrabCursor: true,\r\n\t\t\tautoplay: true,\r\n\t\t\tbreakpoints: {\r\n\t\t\t\t320: {\r\n\t\t\t\t\tslidesPerView: 1,\r\n\t\t\t\t\tspaceBetween: 8,\r\n\t\t\t\t\tslidesPerGroup: 1\r\n\t\t\t\t},\r\n\t\t\t\t576: {\r\n\t\t\t\t\tslidesPerView: 2,\r\n\t\t\t\t\tspaceBetween: 12,\r\n\t\t\t\t\tslidesPerGroup: 1\r\n\t\t\t\t},\r\n\t\t\t\t768: {\r\n\t\t\t\t\tslidesPerView: 3,\r\n\t\t\t\t\tspaceBetween: 16,\r\n\t\t\t\t\tslidesPerGroup: 1\r\n\t\t\t\t},\r\n\t\t\t\t1024: {\r\n\t\t\t\t\tslidesPerView: 4,\r\n\t\t\t\t\tspaceBetween: 16,\r\n\t\t\t\t\tslidesPerGroup: 1\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t};\r\n\t}\r\n\r\n\t/**\r\n\t * Inicializa un nuevo Swiper con la configuración proporcionada.\r\n\t */\r\n\tprivate initializeNewSwiper(swiperElement: any, config: any) {\r\n\t\t// Asignar configuración al elemento\r\n\t\tObject.assign(swiperElement, config);\r\n\t\t\r\n\t\t// Inicializar el Swiper\r\n\t\tswiperElement.initialize();\r\n\t\t\r\n\t\t// console.log('Swiper inicializado con configuración personalizada');\r\n\t}\r\n\r\n\t/**\r\n\t * Actualiza un Swiper existente para asegurar la configuración correcta.\r\n\t */\r\n\tprivate updateExistingSwiper(swiperElement: any) {\r\n\t\t// console.log('Actualizando configuración de Swiper existente');\r\n\t\t\r\n\t\t// Forzar slidesPerGroup a 1\r\n\t\tswiperElement.swiper.params.slidesPerGroup = 1;\r\n\t\tswiperElement.swiper.allowSlideNext = true;\r\n\t\tswiperElement.swiper.allowSlidePrev = true;\r\n\t\t\r\n\t\t// Actualizar también los breakpoints si existen\r\n\t\tif (swiperElement.swiper.params.breakpoints) {\r\n\t\t\tObject.keys(swiperElement.swiper.params.breakpoints).forEach(key => {\r\n\t\t\t\tswiperElement.swiper.params.breakpoints[key].slidesPerGroup = 1;\r\n\t\t\t});\r\n\t\t}\r\n\t\t\r\n\t\tswiperElement.swiper.update();\r\n\t}\r\n\r\n\t/**\r\n\t * Configura los event listeners para los botones de navegación.\r\n\t */\r\n\tprivate setupNavigationEventListeners(prevButton: Element, nextButton: Element, swiperElement: any) {\r\n\t\tprevButton.addEventListener('click', (e) => {\r\n\t\t\te.preventDefault();\r\n\t\t\te.stopPropagation();\r\n\t\t\t// console.log('Click en botón anterior');\r\n\t\t\tif (swiperElement.swiper) {\r\n\t\t\t\tswiperElement.swiper.slidePrev();\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tnextButton.addEventListener('click', (e) => {\r\n\t\t\te.preventDefault();\r\n\t\t\te.stopPropagation();\r\n\t\t\t// console.log('Click en botón siguiente');\r\n\t\t\tif (swiperElement.swiper) {\r\n\t\t\t\tswiperElement.swiper.slideNext();\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n}\r\n","<section [ngClass]=\"trimClassBlock(meta.code) + ' container-fluid'\">\r\n\r\n    <div class=\"blockProduct block-product\">\r\n        @if(meta.name){\r\n        <div class=\"row\">\r\n            <div class=\"col-12 mt-4\">\r\n                <h2  class=\"font-weight-normal font-gd\">\r\n                    <span>{{meta.name}}</span>\r\n                </h2>\r\n            </div>\r\n        </div>\r\n        }\r\n\r\n\r\n        @if(meta.styles && meta.styles.carrousel == false){\r\n        <div class=\"row \">\r\n            @for (product of products; track $index) {\r\n            <div [class]=\"'item '+ ' col-'+ (meta.styles.items?.sm) + ' col-md-' + (meta.styles.items?.md)  + ' col-lg-' + (meta.styles.items?.lg)  + ' px-2'\" [id]=\"$index\">\r\n                <!-- verifica que si vienen un template para un custom appProduct llamado \"appProduct\" con un objeto \"product\"- sino usa por defecto el del core -->\r\n                <ng-container *ngTemplateOutlet=\"appProduct ? appProduct : defaultAppProduct; context: {product:product}\"></ng-container>\r\n            </div>\r\n            }\r\n        </div>\r\n        } @else {\r\n        <div class=\"container position-relative\">\r\n            <swiper-container \r\n                init=\"false\" \r\n                [id]=\"meta?.code\"\r\n                slides-per-view=\"auto\"\r\n                space-between=\"16\"\r\n                slides-per-group=\"1\"\r\n                navigation=\"false\"\r\n                pagination=\"false\"\r\n                loop=\"false\">\r\n                @for (product of products; track $index) {\r\n                <swiper-slide id=\"swiper-slide\">\r\n                    <ng-container\r\n                        *ngTemplateOutlet=\"appProduct ? appProduct : defaultAppProduct; context: {product:product}\"></ng-container>\r\n                </swiper-slide>\r\n                }\r\n            </swiper-container>\r\n            \r\n            <!-- Botones de navegación personalizados -->\r\n            <div class=\"swiper-navigation\">\r\n                <div class=\"swiper-button-prev\" [id]=\"meta?.code + '-prev'\">\r\n                    @if(prevArrowImage) {\r\n                        <img [src]=\"prevArrowImage\" alt=\"Anterior\" />\r\n                    } @else {\r\n                        <span class=\"arrow-text\">{{prevArrowText}}</span>\r\n                    }\r\n                </div>\r\n                <div class=\"swiper-button-next\" [id]=\"meta?.code + '-next'\">\r\n                    @if(nextArrowImage) {\r\n                        <img [src]=\"nextArrowImage\" alt=\"Siguiente\" />\r\n                    } @else {\r\n                        <span class=\"arrow-text\">{{nextArrowText}}</span>\r\n                    }\r\n                </div>\r\n            </div>\r\n        </div>\r\n        }\r\n    </div>\r\n</section>\r\n\r\n\r\n<!-- componente por defecto (tomara como producto el contexto pasado como \"product\") -->\r\n<ng-template #defaultAppProduct let-product=\"product\">\r\n    <app-product-ec [product]=\"product\"></app-product-ec>\r\n</ng-template>"]}
|
|
221
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"block-products-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/blocks-ec/block-products-ec/block-products-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/blocks-ec/block-products-ec/block-products-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { afterNextRender, AfterViewInit, Component, CUSTOM_ELEMENTS_SCHEMA, inject, Input, PLATFORM_ID, signal, TemplateRef } from '@angular/core';\r\nimport { BlockEcComponent } from '../../abstractions-components';\r\nimport { SwiperOptions } from 'swiper/types';\r\nimport { AnalyticsService } from '../../../ec-services';\r\nimport { CommonModule, isPlatformBrowser } from '@angular/common';\r\n// import function to register Swiper custom elements\r\nimport { register, SwiperContainer } from 'swiper/element/bundle';\r\nimport { ProductEcComponent } from \"../../product-ec/product-ec.component\";\r\n\r\nregister()\r\n/**\r\n * Componen para manejar los bloques de productos.\r\n * @extends {BlockEcComponent}\r\n * @class BlockProductsEcComponent\r\n */\r\n@Component({\r\n\tselector: 'app-block-products-ec',\r\n\tstandalone: true,\r\n\timports: [CommonModule, ProductEcComponent],\r\n\ttemplateUrl: './block-products-ec.component.html',\r\n\tstyleUrl: './block-products-ec.component.scss',\r\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA]\r\n})\r\nexport class BlockProductsEcComponent extends BlockEcComponent implements AfterViewInit {\r\n\t\t// Personalización de las flechas de navegación\r\n\t// Por defecto usa símbolos de texto, pero se pueden especificar imágenes\r\n\t@Input() prevArrowImage?: string; // undefined = usa símbolo de texto\r\n\t@Input() nextArrowImage?: string; // undefined = usa símbolo de texto\r\n\t@Input() prevArrowText: string = '<';\r\n\t@Input() nextArrowText: string = '>';\r\n\t/**\r\n\t * Servicio de Analytics\r\n\t */\r\n\tprivate analyticsService: AnalyticsService = inject(AnalyticsService)\r\n\t/**\r\n\t * Signal utlizado para guarda el contenedor del carrusel\r\n\t */\r\n\tswiperElement = signal<SwiperContainer | null>(null)\r\n\t/**\r\n\t * Input que recibe un template para el producto.\r\n\t */\r\n\t@Input() appProduct: TemplateRef<any> | undefined;\r\n\t/**\r\n\t * Colección de productos.\r\n\t */\r\n\t@Input({\r\n\t\trequired: true\r\n\t}) products: any; // Product[];\r\n\t/**\r\n\t * Bloque principal que contiene los productos\r\n\t */\r\n\t@Input({\r\n\t\trequired: true\r\n\t}) meta: any;\r\n\r\n\tngAfterViewInit() {\r\n\t\tthis.setupSwiperNavigation();\r\n\t}\r\n\t\r\n\tprivate document?: Document;\r\n\tprivate platformId: any = inject(PLATFORM_ID)\r\n\r\n\t/**\r\n\t * Ejecuta el método `afterNextRender`para cargar las configuraciones necesarias \r\n\t * para el carrusel del banners. Esto debe ser asi debido a que ya debe estar presente\r\n\t * en el Dom el element `<swiper-container>` para poder configurarlo.\r\n\t */\r\n\tconstructor() {\r\n\t\tsuper()\r\n\t}\r\n\t/**\r\n\t * Aplica el evento `select_promotion` junto con el banner que interactua.\r\n\t * @param banner \r\n\t */\r\n\tselectPromotion(item: any): void {\r\n\t\tthis.analyticsService.callEvent('select_promotion', item)\r\n\t}\r\n\r\n\t/**\r\n\t * Configura la navegación personalizada del Swiper.\r\n\t * Esta función está diseñada para ser movida al componente base BlockProductsEcComponent.\r\n\t * Permite personalización de las imágenes de las flechas mediante @Input.\r\n\t */\r\n\tprivate setupSwiperNavigation() {\r\n\t\tif (this.meta?.styles?.carrousel !== false) {\r\n\t\t\t// Usar setTimeout para asegurar que el swiper esté inicializado\r\n\t\t\tsetTimeout(() => {\r\n\t\t\t\tthis.initializeSwiperWithCustomNavigation();\r\n\t\t\t}, 200);\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Inicializa el Swiper con navegación personalizada.\r\n\t * Esta función puede ser movida al componente base para reutilización.\r\n\t */\r\n\tprivate initializeSwiperWithCustomNavigation() {\r\n\t\tif (!isPlatformBrowser(this.platformId)) return;\r\n\t\t\r\n\t\tconst prevButton = document.getElementById(`${this.meta?.code}-prev`);\r\n\t\tconst nextButton = document.getElementById(`${this.meta?.code}-next`);\r\n\t\tconst swiperElement = document.getElementById(this.meta?.code) as any;\r\n\r\n\t\tif (prevButton && nextButton && swiperElement) {\r\n\t\t\t// console.log('Configurando navegación personalizada para:', this.meta?.code);\r\n\t\t\t\r\n\t\t\tconst swiperConfig = this.getSwiperConfiguration();\r\n\r\n\t\t\t// Verificar si el Swiper ya está inicializado\r\n\t\t\tif (!swiperElement.swiper) {\r\n\t\t\t\tthis.initializeNewSwiper(swiperElement, swiperConfig);\r\n\t\t\t} else {\r\n\t\t\t\tthis.updateExistingSwiper(swiperElement);\r\n\t\t\t}\r\n\r\n\t\t\t// Configurar los event listeners para los botones\r\n\t\t\tthis.setupNavigationEventListeners(prevButton, nextButton, swiperElement);\r\n\t\t\t\r\n\t\t\t// console.log('Event listeners configurados para los botones de navegación');\r\n\t\t} else {\r\n\t\t\t// console.log('No se pudieron encontrar los elementos:', {\r\n\t\t\t// \tprevButton: !!prevButton,\r\n\t\t\t// \tnextButton: !!nextButton,\r\n\t\t\t// \tswiperElement: !!swiperElement\r\n\t\t\t// });\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Obtiene la configuración base del Swiper.\r\n\t * Esta configuración puede ser personalizada en el futuro mediante @Input.\r\n\t */\r\n\tprivate getSwiperConfiguration() {\r\n\t\treturn {\r\n\t\t\tslidesPerView: 'auto',\r\n\t\t\tspaceBetween: 16,\r\n\t\t\tslidesPerGroup: 1, // Importante: moverse de uno en uno\r\n\t\t\tnavigation: false, // Deshabilitamos la navegación por defecto\r\n\t\t\tpagination: false,\r\n\t\t\tloop: true,\r\n\t\t\tgrabCursor: true,\r\n\t\t\tautoplay: true,\r\n\t\t\tbreakpoints: {\r\n\t\t\t\t320: {\r\n\t\t\t\t\tslidesPerView: 1,\r\n\t\t\t\t\tspaceBetween: 8,\r\n\t\t\t\t\tslidesPerGroup: 1\r\n\t\t\t\t},\r\n\t\t\t\t576: {\r\n\t\t\t\t\tslidesPerView: 2,\r\n\t\t\t\t\tspaceBetween: 12,\r\n\t\t\t\t\tslidesPerGroup: 1\r\n\t\t\t\t},\r\n\t\t\t\t768: {\r\n\t\t\t\t\tslidesPerView: 3,\r\n\t\t\t\t\tspaceBetween: 16,\r\n\t\t\t\t\tslidesPerGroup: 1\r\n\t\t\t\t},\r\n\t\t\t\t1024: {\r\n\t\t\t\t\tslidesPerView: 4,\r\n\t\t\t\t\tspaceBetween: 16,\r\n\t\t\t\t\tslidesPerGroup: 1\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t};\r\n\t}\r\n\r\n\t/**\r\n\t * Inicializa un nuevo Swiper con la configuración proporcionada.\r\n\t */\r\n\tprivate initializeNewSwiper(swiperElement: any, config: any) {\r\n\t\t// Asignar configuración al elemento\r\n\t\tObject.assign(swiperElement, config);\r\n\t\t\r\n\t\t// Inicializar el Swiper\r\n\t\tswiperElement.initialize();\r\n\t\t\r\n\t\t// console.log('Swiper inicializado con configuración personalizada');\r\n\t}\r\n\r\n\t/**\r\n\t * Actualiza un Swiper existente para asegurar la configuración correcta.\r\n\t */\r\n\tprivate updateExistingSwiper(swiperElement: any) {\r\n\t\t// console.log('Actualizando configuración de Swiper existente');\r\n\t\t\r\n\t\t// Forzar slidesPerGroup a 1\r\n\t\tswiperElement.swiper.params.slidesPerGroup = 1;\r\n\t\tswiperElement.swiper.allowSlideNext = true;\r\n\t\tswiperElement.swiper.allowSlidePrev = true;\r\n\t\t\r\n\t\t// Actualizar también los breakpoints si existen\r\n\t\tif (swiperElement.swiper.params.breakpoints) {\r\n\t\t\tObject.keys(swiperElement.swiper.params.breakpoints).forEach(key => {\r\n\t\t\t\tswiperElement.swiper.params.breakpoints[key].slidesPerGroup = 1;\r\n\t\t\t});\r\n\t\t}\r\n\t\t\r\n\t\tswiperElement.swiper.update();\r\n\t}\r\n\r\n\t/**\r\n\t * Configura los event listeners para los botones de navegación.\r\n\t */\r\n\tprivate setupNavigationEventListeners(prevButton: Element, nextButton: Element, swiperElement: any) {\r\n\t\tprevButton.addEventListener('click', (e) => {\r\n\t\t\te.preventDefault();\r\n\t\t\te.stopPropagation();\r\n\t\t\t// console.log('Click en botón anterior');\r\n\t\t\tif (swiperElement.swiper) {\r\n\t\t\t\tswiperElement.swiper.slidePrev();\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tnextButton.addEventListener('click', (e) => {\r\n\t\t\te.preventDefault();\r\n\t\t\te.stopPropagation();\r\n\t\t\t// console.log('Click en botón siguiente');\r\n\t\t\tif (swiperElement.swiper) {\r\n\t\t\t\tswiperElement.swiper.slideNext();\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n}\r\n","<section [ngClass]=\"trimClassBlock(meta.code) + ' container-fluid'\">\r\n\r\n    <div class=\"blockProduct block-product\">\r\n        @if(meta.name){\r\n        <div class=\"row\">\r\n            <div class=\"col-12 mt-4\">\r\n                <h2  class=\"font-weight-normal font-gd\">\r\n                    <span>{{meta.name}}</span>\r\n                </h2>\r\n            </div>\r\n        </div>\r\n        }\r\n\r\n\r\n        @if(meta.styles && meta.styles.carrousel == false){\r\n        <div class=\"row \">\r\n            @for (product of products; track $index) {\r\n            <div [class]=\"'item '+ ' col-'+ (meta.styles.items?.sm) + ' col-md-' + (meta.styles.items?.md)  + ' col-lg-' + (meta.styles.items?.lg)  + ' px-2'\" [id]=\"$index\">\r\n                <!-- verifica que si vienen un template para un custom appProduct llamado \"appProduct\" con un objeto \"product\"- sino usa por defecto el del core -->\r\n                <ng-container *ngTemplateOutlet=\"appProduct ? appProduct : defaultAppProduct; context: {product:product}\"></ng-container>\r\n            </div>\r\n            }\r\n        </div>\r\n        } @else {\r\n        <div class=\"container position-relative\">\r\n            <swiper-container \r\n                init=\"false\" \r\n                [id]=\"meta?.code\"\r\n                slides-per-view=\"auto\"\r\n                space-between=\"16\"\r\n                slides-per-group=\"1\"\r\n                navigation=\"false\"\r\n                pagination=\"false\"\r\n                loop=\"false\">\r\n                @for (product of products; track $index) {\r\n                <swiper-slide id=\"swiper-slide\">\r\n                    <ng-container\r\n                        *ngTemplateOutlet=\"appProduct ? appProduct : defaultAppProduct; context: {product:product}\"></ng-container>\r\n                </swiper-slide>\r\n                }\r\n            </swiper-container>\r\n            \r\n            <!-- Botones de navegación personalizados -->\r\n            <div class=\"swiper-navigation\">\r\n                <div class=\"swiper-button-prev\" [id]=\"meta?.code + '-prev'\">\r\n                    @if(prevArrowImage) {\r\n                        <img [src]=\"prevArrowImage\" alt=\"Anterior\" />\r\n                    } @else {\r\n                        <span class=\"arrow-text\">{{prevArrowText}}</span>\r\n                    }\r\n                </div>\r\n                <div class=\"swiper-button-next\" [id]=\"meta?.code + '-next'\">\r\n                    @if(nextArrowImage) {\r\n                        <img [src]=\"nextArrowImage\" alt=\"Siguiente\" />\r\n                    } @else {\r\n                        <span class=\"arrow-text\">{{nextArrowText}}</span>\r\n                    }\r\n                </div>\r\n            </div>\r\n        </div>\r\n        }\r\n    </div>\r\n</section>\r\n\r\n\r\n<!-- componente por defecto (tomara como producto el contexto pasado como \"product\") -->\r\n<ng-template #defaultAppProduct let-product=\"product\">\r\n    <app-product-ec [product]=\"product\"></app-product-ec>\r\n</ng-template>"]}
|
|
@@ -78,17 +78,21 @@ export class HeaderEcComponent extends MenuEcComponent {
|
|
|
78
78
|
});
|
|
79
79
|
}
|
|
80
80
|
onWindowScroll() {
|
|
81
|
-
|
|
82
|
-
|
|
81
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
82
|
+
const scrollTop = window.scrollY;
|
|
83
|
+
this.isScrolled = scrollTop > 80;
|
|
84
|
+
}
|
|
83
85
|
}
|
|
84
86
|
isHomeFunction() {
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
if (
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
87
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
88
|
+
const headerElement = document.querySelector('header');
|
|
89
|
+
if (headerElement) {
|
|
90
|
+
if (this.router.url !== '/home') {
|
|
91
|
+
headerElement.classList.add('show-menu');
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
headerElement.classList.remove('show-menu');
|
|
95
|
+
}
|
|
92
96
|
}
|
|
93
97
|
}
|
|
94
98
|
}
|
|
@@ -112,26 +116,30 @@ export class HeaderEcComponent extends MenuEcComponent {
|
|
|
112
116
|
}
|
|
113
117
|
};
|
|
114
118
|
borrarInput(inputId) {
|
|
115
|
-
if (
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
input.value = '';
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
else {
|
|
122
|
-
const inputs = ['searchInput1'];
|
|
123
|
-
inputs.forEach((id) => {
|
|
124
|
-
const input = document.getElementById(id);
|
|
119
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
120
|
+
if (inputId) {
|
|
121
|
+
const input = document.getElementById(inputId);
|
|
125
122
|
if (input) {
|
|
126
123
|
input.value = '';
|
|
127
124
|
}
|
|
128
|
-
}
|
|
125
|
+
}
|
|
126
|
+
else {
|
|
127
|
+
const inputs = ['searchInput1'];
|
|
128
|
+
inputs.forEach((id) => {
|
|
129
|
+
const input = document.getElementById(id);
|
|
130
|
+
if (input) {
|
|
131
|
+
input.value = '';
|
|
132
|
+
}
|
|
133
|
+
});
|
|
134
|
+
}
|
|
129
135
|
}
|
|
130
136
|
this.searchValue = '';
|
|
131
137
|
this.coreConstantsService.searchValue = '';
|
|
132
138
|
this.getCollectionSearch();
|
|
133
139
|
}
|
|
134
140
|
setupMobileMenu() {
|
|
141
|
+
if (!isPlatformBrowser(this.platformId))
|
|
142
|
+
return;
|
|
135
143
|
// console.log('setupMobileMenu called');
|
|
136
144
|
const menuMobile = document.querySelector('.menuMobile');
|
|
137
145
|
if (!(menuMobile instanceof HTMLElement))
|
|
@@ -167,6 +175,8 @@ export class HeaderEcComponent extends MenuEcComponent {
|
|
|
167
175
|
});
|
|
168
176
|
}
|
|
169
177
|
setupSearchInputs() {
|
|
178
|
+
if (!isPlatformBrowser(this.platformId))
|
|
179
|
+
return;
|
|
170
180
|
const inputs = ['searchInput1', 'searchInput2'];
|
|
171
181
|
inputs.forEach(id => {
|
|
172
182
|
const input = document.getElementById(id);
|
|
@@ -233,4 +243,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
233
243
|
type: HostListener,
|
|
234
244
|
args: ['window:scroll', []]
|
|
235
245
|
}] } });
|
|
236
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/header-ec/header-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/header-ec/header-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { afterNextRender, Component, inject,PLATFORM_ID, Injector, OnInit, HostListener, ChangeDetectorRef, signal } from '@angular/core';\r\nimport { TitleCasePipe, AsyncPipe, JsonPipe, CommonModule } from '@angular/common';\r\nimport { MenuEcComponent } from '../abstractions-components';\r\nimport { CartService, TestService, ToastService } from '../../ec-services';\r\nimport { Observable } from 'rxjs';\r\nimport { AuthService } from '../../ec-services';\r\nimport { Router, NavigationEnd, RouterLink, RouterLinkActive } from '@angular/router';\r\nimport { Category } from '../../interfaces';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { ChannelService } from '../../ec-services';\r\nimport { isPlatformBrowser } from '@angular/common';\r\n\r\n/**\r\n * Componente que se encarga de manejar la funcionalidad del Header.\r\n */\r\n@Component({\r\n  selector: 'lib-header-ec',\r\n  standalone: true,\r\n  imports: [CommonModule, TitleCasePipe, AsyncPipe, JsonPipe, RouterLink, RouterLinkActive],\r\n  templateUrl: './header-ec.component.html',\r\n  styleUrl: './header-ec.component.scss'\r\n})\r\nexport class HeaderEcComponent extends MenuEcComponent {\r\n  public channel: string | undefined;\r\n  public searchValue: string = '';\r\n  transparent: boolean = false;\r\n  isHome: boolean = false; // Nueva variable para verificar si estamos en /home\r\n  isScrolled: boolean = false;\r\n  showPricesOnlyToLoggedUsers: boolean = false;\r\n  hidePrices: boolean = false;\r\n  public __authService: AuthService = inject(AuthService)\r\n  public _channelService: ChannelService = inject(ChannelService);\r\n  public changeDetector = inject(ChangeDetectorRef);\r\n  public appRouter = inject(Router);\r\n  public platformId = inject(PLATFORM_ID);\r\n\r\n    mobileDropdownOpen = signal(false);\r\n     isMenuOpen = signal(false);\r\n\r\n\r\n  // Observable del estado de autenticación\r\n  public logged$!: Observable<boolean>;\r\n  public isAuthenticated$ = this.__authService.isAuthenticated();\r\n  constructor() {\r\n    super();\r\n    this._channelService.channel$.subscribe(cfg => {\r\n      // console.log('Channel configuration:', cfg);\r\n      this.showPricesOnlyToLoggedUsers = !!cfg.showPricesOnlyToLoggedUsers;\r\n      this.hidePrices = !!cfg.hidePrices;\r\n      // console.log('hidePrices:', this.hidePrices);\r\n    });\r\n  }\r\n\r\n  private coreConstantsService = inject(CoreConstantsService);\r\n  private router = inject(Router);\r\n  private cdr = inject(ChangeDetectorRef); // Inyectamos ChangeDetectorRef para forzar la actualización\r\n\r\n  ngOnInit(): void {\r\n    this.channel = this.coreConstantsService.getChannel();\r\n    this.onWindowScroll();\r\n    this.detectRouteChange(); // Llamamos a la función que detecta el cambio de ruta\r\n    // Usar el Observable del AuthService\r\n    this.logged$ = this.__authService.loggedIn$;\r\n\r\n    // Suscribirse al Observable y forzar detección de cambios cuando sea necesario\r\n    this.logged$.subscribe(isLoggedIn => {\r\n      this.changeDetector.detectChanges();\r\n    });\r\n     if (isPlatformBrowser(this.platformId)) {\r\n      this.appRouter.events.subscribe(evt => {\r\n        if (evt instanceof NavigationEnd) {\r\n          // Forzar detección de cambios después de navegación\r\n          setTimeout(() => {\r\n            this.changeDetector.detectChanges();\r\n          }, 100);\r\n        }\r\n      });\r\n    }\r\n  }\r\n  ngAfterViewInit(): void {\r\n    this.setupMobileMenu(); // Inicializamos el menú móvil\r\n    this.setupSearchInputs(); // Inicializamos los inputs de búsqueda   \r\n    this.isHomeFunction();\r\n  }\r\n  /**\r\n   * Detecta cuando cambia la ruta y actualiza la clase del header\r\n   */\r\n  private detectRouteChange() {\r\n    this.router.events.subscribe(event => {\r\n      if (event instanceof NavigationEnd) {\r\n        this.isHome = this.router.url === '/home';\r\n        this.cdr.detectChanges(); // Forzamos la detección de cambios para actualizar la vista\r\n      }\r\n    });\r\n  }\r\n\r\n  @HostListener('window:scroll', [])\r\n  onWindowScroll() {\r\n    const scrollTop = window.scrollY;\r\n    this.isScrolled = scrollTop > 80;\r\n  }\r\n\r\n  isHomeFunction(): void {\r\n    const headerElement = document.querySelector('header');\r\n    if (headerElement) {\r\n      if (this.router.url !== '/home') {\r\n        headerElement.classList.add('show-menu');\r\n      } else {\r\n        headerElement.classList.remove('show-menu');\r\n      }\r\n    }\r\n  }\r\n\r\n  changeUrlTransparent = (urlTransparent: string) => {\r\n    return urlTransparent;\r\n  };\r\n\r\n\r\n  getCollectionSearch = () => {\r\n    this.coreConstantsService.searchValue = this.searchValue;\r\n    this.router.navigateByUrl('/collection?search=' + this.searchValue);\r\n  };\r\n\r\n  setSearchValue = (event: Event, afterSearch?: Function, ...args: any[]) => {\r\n    const target = event.target as HTMLInputElement;\r\n    if (target) {\r\n      this.searchValue = target.value;\r\n    }\r\n\r\n    // if (event.key === 'Enter') {\r\n    // this.getCollectionSearch();\r\n    if (afterSearch) {\r\n      afterSearch(...args);\r\n      // }\r\n    }\r\n  };\r\n\r\n  borrarInput(inputId?: string) {\r\n    if (inputId) {\r\n      const input = document.getElementById(inputId) as HTMLInputElement;\r\n      if (input) {\r\n        input.value = '';\r\n      }\r\n    } else {\r\n      const inputs = ['searchInput1'];\r\n      inputs.forEach((id) => {\r\n        const input = document.getElementById(id) as HTMLInputElement;\r\n        if (input) {\r\n          input.value = '';\r\n        }\r\n      });\r\n    }\r\n\r\n    this.searchValue = '';\r\n    this.coreConstantsService.searchValue = '';\r\n    this.getCollectionSearch();\r\n  }\r\n  setupMobileMenu() {\r\n    // console.log('setupMobileMenu called');\r\n    const menuMobile = document.querySelector('.menuMobile');\r\n    if (!(menuMobile instanceof HTMLElement)) return;\r\n    const openBtn = document.querySelector('.abreMenuMobile .abre');\r\n    const closeBtn = document.querySelector('.abreMenuMobile .close');\r\n    const iconMenu = document.getElementById('icMenu');\r\n    const searchMobile = document.querySelector('.searchMobile');\r\n\r\n    const closeMenu = () => {\r\n      menuMobile.style.display = 'none';\r\n      closeBtn?.setAttribute('style', 'display:none');\r\n      iconMenu?.setAttribute('style', 'display:block');\r\n    };\r\n\r\n    menuMobile.style.display = 'none';\r\n\r\n    openBtn?.addEventListener('click', () => {\r\n      menuMobile.style.display = 'block';\r\n      closeBtn?.setAttribute('style', 'display:block');\r\n      if (searchMobile instanceof HTMLElement) {\r\n        searchMobile.style.display = 'none';\r\n      }\r\n      iconMenu?.setAttribute('style', 'display:none');\r\n    });\r\n\r\n    closeBtn?.addEventListener('click', closeMenu);\r\n\r\n    // Cierra el menú si se hace clic en un enlace específico dentro del menú\r\n    const linkSelectors = ['.categoryMobile', '.subcategoryMobile', '.usuariomobile'];\r\n    linkSelectors.forEach(selector => {\r\n      const links = menuMobile.querySelectorAll<HTMLAnchorElement>(`a${selector}`);\r\n      links.forEach(link => {\r\n        link.addEventListener('click', () => {\r\n          closeMenu();\r\n        });\r\n      });\r\n    });\r\n  }\r\n  setupSearchInputs() {\r\n    const inputs = ['searchInput1', 'searchInput2'];\r\n\r\n    inputs.forEach(id => {\r\n      const input = document.getElementById(id);\r\n      if (!(input instanceof HTMLInputElement)) return;\r\n      const clearBtn = document.querySelector(`.clear-btn${id.slice(-1)}`);\r\n\r\n      if (!input || !(clearBtn instanceof HTMLElement)) return;\r\n\r\n      input.addEventListener('focus', () => {\r\n        if (input.value === 'Buscar producto...') {\r\n          input.value = '';\r\n        }\r\n      });\r\n\r\n      input.addEventListener('blur', () => {\r\n        if (input.value.trim() === '') {\r\n          input.value = 'Buscar producto...';\r\n        }\r\n      });\r\n\r\n      input.addEventListener('input', () => {\r\n        clearBtn.style.display = input.value.trim() !== '' ? 'block' : 'none';\r\n      });\r\n\r\n      clearBtn.addEventListener('click', (e) => {\r\n        e.preventDefault();\r\n        input.value = '';\r\n        clearBtn.style.display = 'none';\r\n        input.focus();\r\n      });\r\n    });\r\n\r\n  }\r\n\r\n   togglePanel(id: string) {\r\n    // Solo ejecutar en el navegador para evitar problemas con SSR\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      this.openPanels.update(panels => ({\r\n        ...panels,\r\n        [id]: !panels[id]\r\n      }));\r\n    }\r\n  }\r\n\r\n    openPanels = signal<Record<string, boolean>>({\r\n    collapseUno: false,\r\n    collapseDos: true // Productos abierto por defecto\r\n  });\r\n\r\n\r\n\r\n\r\n       collapseAllMenus() {\r\n    // Solo ejecutar en el navegador para evitar problemas con SSR\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      this.openPanels.update(panels => {\r\n        const newPanels = { ...panels };\r\n        Object.keys(newPanels).forEach(key => {\r\n          if (key !== 'collapseDos') {\r\n            newPanels[key] = false;\r\n          }\r\n        });\r\n        return newPanels;\r\n      });\r\n    }\r\n  }\r\n}\r\n","<p>header-ec works!</p>\r\n"]}
|
|
246
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/header-ec/header-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/header-ec/header-ec.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAmB,SAAS,EAAE,MAAM,EAAC,WAAW,EAAoB,YAAY,EAAE,iBAAiB,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC1I,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AACnF,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAG7D,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,UAAU,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAEtF,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;;AAEpD;;GAEG;AAQH,MAAM,OAAO,iBAAkB,SAAQ,eAAe;IAC7C,OAAO,CAAqB;IAC5B,WAAW,GAAW,EAAE,CAAC;IAChC,WAAW,GAAY,KAAK,CAAC;IAC7B,MAAM,GAAY,KAAK,CAAC,CAAC,oDAAoD;IAC7E,UAAU,GAAY,KAAK,CAAC;IAC5B,2BAA2B,GAAY,KAAK,CAAC;IAC7C,UAAU,GAAY,KAAK,CAAC;IACrB,aAAa,GAAgB,MAAM,CAAC,WAAW,CAAC,CAAA;IAChD,eAAe,GAAmB,MAAM,CAAC,cAAc,CAAC,CAAC;IACzD,cAAc,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;IAC3C,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;IAC3B,UAAU,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;IAEtC,kBAAkB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAClC,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAG9B,yCAAyC;IAClC,OAAO,CAAuB;IAC9B,gBAAgB,GAAG,IAAI,CAAC,aAAa,CAAC,eAAe,EAAE,CAAC;IAC/D;QACE,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YAC5C,8CAA8C;YAC9C,IAAI,CAAC,2BAA2B,GAAG,CAAC,CAAC,GAAG,CAAC,2BAA2B,CAAC;YACrE,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC;YACnC,+CAA+C;QACjD,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,oBAAoB,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;IACpD,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;IACxB,GAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC,4DAA4D;IAErG,QAAQ;QACN,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,oBAAoB,CAAC,UAAU,EAAE,CAAC;QACtD,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC,sDAAsD;QAChF,qCAAqC;QACrC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC;QAE5C,+EAA+E;QAC/E,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,UAAU,CAAC,EAAE;YAClC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;QACtC,CAAC,CAAC,CAAC;QACF,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACxC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;gBACpC,IAAI,GAAG,YAAY,aAAa,EAAE,CAAC;oBACjC,oDAAoD;oBACpD,UAAU,CAAC,GAAG,EAAE;wBACd,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;oBACtC,CAAC,EAAE,GAAG,CAAC,CAAC;gBACV,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IACD,eAAe;QACb,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC,8BAA8B;QACtD,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC,0CAA0C;QACpE,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IACD;;OAEG;IACK,iBAAiB;QACvB,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YACnC,IAAI,KAAK,YAAY,aAAa,EAAE,CAAC;gBACnC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,KAAK,OAAO,CAAC;gBAC1C,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC,4DAA4D;YACxF,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAGD,cAAc;QACZ,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACvC,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC;YACjC,IAAI,CAAC,UAAU,GAAG,SAAS,GAAG,EAAE,CAAC;QACnC,CAAC;IACH,CAAC;IAED,cAAc;QACZ,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACvC,MAAM,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YACvD,IAAI,aAAa,EAAE,CAAC;gBAClB,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,KAAK,OAAO,EAAE,CAAC;oBAChC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;gBAC3C,CAAC;qBAAM,CAAC;oBACN,aAAa,CAAC,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;gBAC9C,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,oBAAoB,GAAG,CAAC,cAAsB,EAAE,EAAE;QAChD,OAAO,cAAc,CAAC;IACxB,CAAC,CAAC;IAGF,mBAAmB,GAAG,GAAG,EAAE;QACzB,IAAI,CAAC,oBAAoB,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QACzD,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,qBAAqB,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC;IACtE,CAAC,CAAC;IAEF,cAAc,GAAG,CAAC,KAAY,EAAE,WAAsB,EAAE,GAAG,IAAW,EAAE,EAAE;QACxE,MAAM,MAAM,GAAG,KAAK,CAAC,MAA0B,CAAC;QAChD,IAAI,MAAM,EAAE,CAAC;YACX,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC;QAClC,CAAC;QAED,+BAA+B;QAC/B,8BAA8B;QAC9B,IAAI,WAAW,EAAE,CAAC;YAChB,WAAW,CAAC,GAAG,IAAI,CAAC,CAAC;YACrB,IAAI;QACN,CAAC;IACH,CAAC,CAAC;IAEF,WAAW,CAAC,OAAgB;QAC1B,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACvC,IAAI,OAAO,EAAE,CAAC;gBACZ,MAAM,KAAK,GAAG,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAqB,CAAC;gBACnE,IAAI,KAAK,EAAE,CAAC;oBACV,KAAK,CAAC,KAAK,GAAG,EAAE,CAAC;gBACnB,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,MAAM,MAAM,GAAG,CAAC,cAAc,CAAC,CAAC;gBAChC,MAAM,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE;oBACpB,MAAM,KAAK,GAAG,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAqB,CAAC;oBAC9D,IAAI,KAAK,EAAE,CAAC;wBACV,KAAK,CAAC,KAAK,GAAG,EAAE,CAAC;oBACnB,CAAC;gBACH,CAAC,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QAED,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,oBAAoB,CAAC,WAAW,GAAG,EAAE,CAAC;QAC3C,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IACD,eAAe;QACb,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC;YAAE,OAAO;QAEhD,yCAAyC;QACzC,MAAM,UAAU,GAAG,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;QACzD,IAAI,CAAC,CAAC,UAAU,YAAY,WAAW,CAAC;YAAE,OAAO;QACjD,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,uBAAuB,CAAC,CAAC;QAChE,MAAM,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,wBAAwB,CAAC,CAAC;QAClE,MAAM,QAAQ,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACnD,MAAM,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;QAE7D,MAAM,SAAS,GAAG,GAAG,EAAE;YACrB,UAAU,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;YAClC,QAAQ,EAAE,YAAY,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC;YAChD,QAAQ,EAAE,YAAY,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;QACnD,CAAC,CAAC;QAEF,UAAU,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;QAElC,OAAO,EAAE,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;YACtC,UAAU,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;YACnC,QAAQ,EAAE,YAAY,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;YACjD,IAAI,YAAY,YAAY,WAAW,EAAE,CAAC;gBACxC,YAAY,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;YACtC,CAAC;YACD,QAAQ,EAAE,YAAY,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;QAEH,QAAQ,EAAE,gBAAgB,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAE/C,yEAAyE;QACzE,MAAM,aAAa,GAAG,CAAC,iBAAiB,EAAE,oBAAoB,EAAE,gBAAgB,CAAC,CAAC;QAClF,aAAa,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;YAC/B,MAAM,KAAK,GAAG,UAAU,CAAC,gBAAgB,CAAoB,IAAI,QAAQ,EAAE,CAAC,CAAC;YAC7E,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBACnB,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;oBAClC,SAAS,EAAE,CAAC;gBACd,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IACD,iBAAiB;QACf,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC;YAAE,OAAO;QAEhD,MAAM,MAAM,GAAG,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC;QAEhD,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;YAClB,MAAM,KAAK,GAAG,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;YAC1C,IAAI,CAAC,CAAC,KAAK,YAAY,gBAAgB,CAAC;gBAAE,OAAO;YACjD,MAAM,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,aAAa,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YAErE,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,QAAQ,YAAY,WAAW,CAAC;gBAAE,OAAO;YAEzD,KAAK,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;gBACnC,IAAI,KAAK,CAAC,KAAK,KAAK,oBAAoB,EAAE,CAAC;oBACzC,KAAK,CAAC,KAAK,GAAG,EAAE,CAAC;gBACnB,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,KAAK,CAAC,gBAAgB,CAAC,MAAM,EAAE,GAAG,EAAE;gBAClC,IAAI,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;oBAC9B,KAAK,CAAC,KAAK,GAAG,oBAAoB,CAAC;gBACrC,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,KAAK,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;gBACnC,QAAQ,CAAC,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;YACxE,CAAC,CAAC,CAAC;YAEH,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE;gBACvC,CAAC,CAAC,cAAc,EAAE,CAAC;gBACnB,KAAK,CAAC,KAAK,GAAG,EAAE,CAAC;gBACjB,QAAQ,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;gBAChC,KAAK,CAAC,KAAK,EAAE,CAAC;YAChB,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IAEL,CAAC;IAEA,WAAW,CAAC,EAAU;QACrB,8DAA8D;QAC9D,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACvC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;gBAChC,GAAG,MAAM;gBACT,CAAC,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC;aAClB,CAAC,CAAC,CAAC;QACN,CAAC;IACH,CAAC;IAEC,UAAU,GAAG,MAAM,CAA0B;QAC7C,WAAW,EAAE,KAAK;QAClB,WAAW,EAAE,IAAI,CAAC,gCAAgC;KACnD,CAAC,CAAC;IAKE,gBAAgB;QACnB,8DAA8D;QAC9D,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACvC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE;gBAC9B,MAAM,SAAS,GAAG,EAAE,GAAG,MAAM,EAAE,CAAC;gBAChC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;oBACnC,IAAI,GAAG,KAAK,aAAa,EAAE,CAAC;wBAC1B,SAAS,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;oBACzB,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,OAAO,SAAS,CAAC;YACnB,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;wGA3PU,iBAAiB;4FAAjB,iBAAiB,8JCtB9B,6BACA,yDDiBY,YAAY;;4FAIX,iBAAiB;kBAP7B,SAAS;+BACE,eAAe,cACb,IAAI,WACP,CAAC,YAAY,EAAE,aAAa,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,gBAAgB,CAAC;wDA+EzF,cAAc;sBADb,YAAY;uBAAC,eAAe,EAAE,EAAE","sourcesContent":["import { afterNextRender, Component, inject,PLATFORM_ID, Injector, OnInit, HostListener, ChangeDetectorRef, signal } from '@angular/core';\r\nimport { TitleCasePipe, AsyncPipe, JsonPipe, CommonModule } from '@angular/common';\r\nimport { MenuEcComponent } from '../abstractions-components';\r\nimport { CartService, TestService, ToastService } from '../../ec-services';\r\nimport { Observable } from 'rxjs';\r\nimport { AuthService } from '../../ec-services';\r\nimport { Router, NavigationEnd, RouterLink, RouterLinkActive } from '@angular/router';\r\nimport { Category } from '../../interfaces';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { ChannelService } from '../../ec-services';\r\nimport { isPlatformBrowser } from '@angular/common';\r\n\r\n/**\r\n * Componente que se encarga de manejar la funcionalidad del Header.\r\n */\r\n@Component({\r\n  selector: 'lib-header-ec',\r\n  standalone: true,\r\n  imports: [CommonModule, TitleCasePipe, AsyncPipe, JsonPipe, RouterLink, RouterLinkActive],\r\n  templateUrl: './header-ec.component.html',\r\n  styleUrl: './header-ec.component.scss'\r\n})\r\nexport class HeaderEcComponent extends MenuEcComponent {\r\n  public channel: string | undefined;\r\n  public searchValue: string = '';\r\n  transparent: boolean = false;\r\n  isHome: boolean = false; // Nueva variable para verificar si estamos en /home\r\n  isScrolled: boolean = false;\r\n  showPricesOnlyToLoggedUsers: boolean = false;\r\n  hidePrices: boolean = false;\r\n  public __authService: AuthService = inject(AuthService)\r\n  public _channelService: ChannelService = inject(ChannelService);\r\n  public changeDetector = inject(ChangeDetectorRef);\r\n  public appRouter = inject(Router);\r\n  public platformId = inject(PLATFORM_ID);\r\n\r\n    mobileDropdownOpen = signal(false);\r\n     isMenuOpen = signal(false);\r\n\r\n\r\n  // Observable del estado de autenticación\r\n  public logged$!: Observable<boolean>;\r\n  public isAuthenticated$ = this.__authService.isAuthenticated();\r\n  constructor() {\r\n    super();\r\n    this._channelService.channel$.subscribe(cfg => {\r\n      // console.log('Channel configuration:', cfg);\r\n      this.showPricesOnlyToLoggedUsers = !!cfg.showPricesOnlyToLoggedUsers;\r\n      this.hidePrices = !!cfg.hidePrices;\r\n      // console.log('hidePrices:', this.hidePrices);\r\n    });\r\n  }\r\n\r\n  private coreConstantsService = inject(CoreConstantsService);\r\n  private router = inject(Router);\r\n  private cdr = inject(ChangeDetectorRef); // Inyectamos ChangeDetectorRef para forzar la actualización\r\n\r\n  ngOnInit(): void {\r\n    this.channel = this.coreConstantsService.getChannel();\r\n    this.onWindowScroll();\r\n    this.detectRouteChange(); // Llamamos a la función que detecta el cambio de ruta\r\n    // Usar el Observable del AuthService\r\n    this.logged$ = this.__authService.loggedIn$;\r\n\r\n    // Suscribirse al Observable y forzar detección de cambios cuando sea necesario\r\n    this.logged$.subscribe(isLoggedIn => {\r\n      this.changeDetector.detectChanges();\r\n    });\r\n     if (isPlatformBrowser(this.platformId)) {\r\n      this.appRouter.events.subscribe(evt => {\r\n        if (evt instanceof NavigationEnd) {\r\n          // Forzar detección de cambios después de navegación\r\n          setTimeout(() => {\r\n            this.changeDetector.detectChanges();\r\n          }, 100);\r\n        }\r\n      });\r\n    }\r\n  }\r\n  ngAfterViewInit(): void {\r\n    this.setupMobileMenu(); // Inicializamos el menú móvil\r\n    this.setupSearchInputs(); // Inicializamos los inputs de búsqueda   \r\n    this.isHomeFunction();\r\n  }\r\n  /**\r\n   * Detecta cuando cambia la ruta y actualiza la clase del header\r\n   */\r\n  private detectRouteChange() {\r\n    this.router.events.subscribe(event => {\r\n      if (event instanceof NavigationEnd) {\r\n        this.isHome = this.router.url === '/home';\r\n        this.cdr.detectChanges(); // Forzamos la detección de cambios para actualizar la vista\r\n      }\r\n    });\r\n  }\r\n\r\n  @HostListener('window:scroll', [])\r\n  onWindowScroll() {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      const scrollTop = window.scrollY;\r\n      this.isScrolled = scrollTop > 80;\r\n    }\r\n  }\r\n\r\n  isHomeFunction(): void {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      const headerElement = document.querySelector('header');\r\n      if (headerElement) {\r\n        if (this.router.url !== '/home') {\r\n          headerElement.classList.add('show-menu');\r\n        } else {\r\n          headerElement.classList.remove('show-menu');\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  changeUrlTransparent = (urlTransparent: string) => {\r\n    return urlTransparent;\r\n  };\r\n\r\n\r\n  getCollectionSearch = () => {\r\n    this.coreConstantsService.searchValue = this.searchValue;\r\n    this.router.navigateByUrl('/collection?search=' + this.searchValue);\r\n  };\r\n\r\n  setSearchValue = (event: Event, afterSearch?: Function, ...args: any[]) => {\r\n    const target = event.target as HTMLInputElement;\r\n    if (target) {\r\n      this.searchValue = target.value;\r\n    }\r\n\r\n    // if (event.key === 'Enter') {\r\n    // this.getCollectionSearch();\r\n    if (afterSearch) {\r\n      afterSearch(...args);\r\n      // }\r\n    }\r\n  };\r\n\r\n  borrarInput(inputId?: string) {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      if (inputId) {\r\n        const input = document.getElementById(inputId) as HTMLInputElement;\r\n        if (input) {\r\n          input.value = '';\r\n        }\r\n      } else {\r\n        const inputs = ['searchInput1'];\r\n        inputs.forEach((id) => {\r\n          const input = document.getElementById(id) as HTMLInputElement;\r\n          if (input) {\r\n            input.value = '';\r\n          }\r\n        });\r\n      }\r\n    }\r\n\r\n    this.searchValue = '';\r\n    this.coreConstantsService.searchValue = '';\r\n    this.getCollectionSearch();\r\n  }\r\n  setupMobileMenu() {\r\n    if (!isPlatformBrowser(this.platformId)) return;\r\n    \r\n    // console.log('setupMobileMenu called');\r\n    const menuMobile = document.querySelector('.menuMobile');\r\n    if (!(menuMobile instanceof HTMLElement)) return;\r\n    const openBtn = document.querySelector('.abreMenuMobile .abre');\r\n    const closeBtn = document.querySelector('.abreMenuMobile .close');\r\n    const iconMenu = document.getElementById('icMenu');\r\n    const searchMobile = document.querySelector('.searchMobile');\r\n\r\n    const closeMenu = () => {\r\n      menuMobile.style.display = 'none';\r\n      closeBtn?.setAttribute('style', 'display:none');\r\n      iconMenu?.setAttribute('style', 'display:block');\r\n    };\r\n\r\n    menuMobile.style.display = 'none';\r\n\r\n    openBtn?.addEventListener('click', () => {\r\n      menuMobile.style.display = 'block';\r\n      closeBtn?.setAttribute('style', 'display:block');\r\n      if (searchMobile instanceof HTMLElement) {\r\n        searchMobile.style.display = 'none';\r\n      }\r\n      iconMenu?.setAttribute('style', 'display:none');\r\n    });\r\n\r\n    closeBtn?.addEventListener('click', closeMenu);\r\n\r\n    // Cierra el menú si se hace clic en un enlace específico dentro del menú\r\n    const linkSelectors = ['.categoryMobile', '.subcategoryMobile', '.usuariomobile'];\r\n    linkSelectors.forEach(selector => {\r\n      const links = menuMobile.querySelectorAll<HTMLAnchorElement>(`a${selector}`);\r\n      links.forEach(link => {\r\n        link.addEventListener('click', () => {\r\n          closeMenu();\r\n        });\r\n      });\r\n    });\r\n  }\r\n  setupSearchInputs() {\r\n    if (!isPlatformBrowser(this.platformId)) return;\r\n    \r\n    const inputs = ['searchInput1', 'searchInput2'];\r\n\r\n    inputs.forEach(id => {\r\n      const input = document.getElementById(id);\r\n      if (!(input instanceof HTMLInputElement)) return;\r\n      const clearBtn = document.querySelector(`.clear-btn${id.slice(-1)}`);\r\n\r\n      if (!input || !(clearBtn instanceof HTMLElement)) return;\r\n\r\n      input.addEventListener('focus', () => {\r\n        if (input.value === 'Buscar producto...') {\r\n          input.value = '';\r\n        }\r\n      });\r\n\r\n      input.addEventListener('blur', () => {\r\n        if (input.value.trim() === '') {\r\n          input.value = 'Buscar producto...';\r\n        }\r\n      });\r\n\r\n      input.addEventListener('input', () => {\r\n        clearBtn.style.display = input.value.trim() !== '' ? 'block' : 'none';\r\n      });\r\n\r\n      clearBtn.addEventListener('click', (e) => {\r\n        e.preventDefault();\r\n        input.value = '';\r\n        clearBtn.style.display = 'none';\r\n        input.focus();\r\n      });\r\n    });\r\n\r\n  }\r\n\r\n   togglePanel(id: string) {\r\n    // Solo ejecutar en el navegador para evitar problemas con SSR\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      this.openPanels.update(panels => ({\r\n        ...panels,\r\n        [id]: !panels[id]\r\n      }));\r\n    }\r\n  }\r\n\r\n    openPanels = signal<Record<string, boolean>>({\r\n    collapseUno: false,\r\n    collapseDos: true // Productos abierto por defecto\r\n  });\r\n\r\n\r\n\r\n\r\n       collapseAllMenus() {\r\n    // Solo ejecutar en el navegador para evitar problemas con SSR\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      this.openPanels.update(panels => {\r\n        const newPanels = { ...panels };\r\n        Object.keys(newPanels).forEach(key => {\r\n          if (key !== 'collapseDos') {\r\n            newPanels[key] = false;\r\n          }\r\n        });\r\n        return newPanels;\r\n      });\r\n    }\r\n  }\r\n}\r\n","<p>header-ec works!</p>\r\n"]}
|
|
@@ -35,7 +35,7 @@ export class GoogleAnalyticsService {
|
|
|
35
35
|
* @param gtm_id id provisto por Google Tag Manager.
|
|
36
36
|
*/
|
|
37
37
|
initialize(gtm_id) {
|
|
38
|
-
if (!document.getElementById('google_tag_manager')) {
|
|
38
|
+
if (typeof document !== 'undefined' && !document.getElementById('google_tag_manager')) {
|
|
39
39
|
console.log('hay elemento');
|
|
40
40
|
const declaration = this.renderer.createElement('script');
|
|
41
41
|
declaration.async = true;
|
|
@@ -280,4 +280,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
280
280
|
providedIn: 'root'
|
|
281
281
|
}]
|
|
282
282
|
}], ctorParameters: () => [] });
|
|
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":"AAAA,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,WAAW,EAAa,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAE7F,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACxD,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;;AAO9B;;;GAGG;AAIH,MAAM,OAAO,sBAAsB;IAClC;;;OAGG;IACK,QAAQ,CAAY;IAC5B;;OAEG;IACK,OAAO,GAAY,KAAK,CAAC;IAEzB,eAAe,GAAqB,MAAM,CAAC,gBAAgB,CAAC,CAAC;IAC7D,QAAQ,GAAoB,IAAI,CAAC;IACjC,UAAU,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;IAEzC;;OAEG;IACK,MAAM,GAAW,MAAM,CAAC,MAAM,CAAC,CAAC;IAExC;QACC,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACxC,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,kCAAkC;QACrE,CAAC;QACD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACjE,CAAC;IACD;;;OAGG;IACH,UAAU,CAAC,MAAc;QACxB,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,oBAAoB,CAAC,EAAE,CAAC;YACpD,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAA;YAC3B,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YAC1D,WAAW,CAAC,KAAK,GAAG,IAAI,CAAC;YACzB,WAAW,CAAC,EAAE,GAAG,oBAAoB,CAAC;YACtC,WAAW,CAAC,GAAG,GAAG,+CAA+C,MAAM,EAAE,CAAC;YAC1E,MAAM,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YAC7D,cAAc,CAAC,IAAI,GAAG,kIAAkI,MAAM,IAAI,CAAC;YACnK,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,cAAc,CAAC,CAAC;YAC/D,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,WAAW,CAAC,CAAC;YAC5D,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACrB,CAAC;QACD,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,CAAC;IAC9D,CAAC;IACD;;;OAGG;IACK,uBAAuB,CAAC,MAAW;QAC1C,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CACtB,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,YAAY,aAAa,CAAC,CAC/C,CAAC,SAAS,CAAC,CAAC,KAAoB,EAAE,EAAE;YACpC,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE;gBACtB,WAAW,EAAE,KAAK,CAAC,iBAAiB;aACpC,CAAC,CAAA;QACH,CAAC,CAAC,CAAA;IACH,CAAC;IACD;;;;;OAKG;IACH,SAAS,CAAC,UAA4B,EAAE,IAAI,GAAG,EAAE;QAChD,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAO;QAC1B,IAAI,KAAK,GAAG,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;QAChD,KAAK,IAAI,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC,CAAC;IAC/F,CAAC;IACD;;;;OAIG;IACH,kBAAkB,CAAC,UAA4B;QAC9C,QAAQ,UAAU,EAAE,CAAC;YACpB,KAAK,WAAW,CAAC,CAAC,OAAO,WAAW,CAAC;YACrC,KAAK,gBAAgB,CAAC,CAAC,OAAO,gBAAgB,CAAC;YAC/C,KAAK,eAAe,CAAC,CAAC,OAAO,gBAAgB,CAAC;YAC9C,KAAK,eAAe,CAAC,CAAC,OAAO,mBAAmB,CAAC;YACjD,KAAK,kBAAkB,CAAC,CAAC,OAAO,kBAAkB,CAAC;YACnD,KAAK,UAAU,CAAC,CAAC,OAAO,UAAU,CAAC;YACnC,KAAK,aAAa,CAAC,CAAC,OAAO,aAAa,CAAC;YACzC,KAAK,kBAAkB,CAAC,CAAC,OAAO,kBAAkB,CAAC;YACnD,KAAK,SAAS,CAAC,CAAC,OAAO,SAAS,CAAC;YACjC,OAAO,CAAC,CAAC,OAAO,IAAI,CAAC;YACrB,6BAA6B;QAC9B,CAAC;IACF,CAAC;IACD;;;;;OAKG;IACH,SAAS,CAAC,UAA4B,EAAE,IAAS;QAChD,QAAQ,UAAU,EAAE,CAAC;YACpB,KAAK,WAAW,CAAC,CAAC,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAC/C,KAAK,gBAAgB,CAAC,CAAC,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YACxD,KAAK,eAAe,CAAC,CAAC,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YACvD,KAAK,eAAe,CAAC,CAAC,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YACvD,KAAK,kBAAkB,CAAC,CAAC,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YACzD,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,KAAK,kBAAkB,CAAC,CAAC,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YAC1D,KAAK,SAAS,CAAC,CAAC,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC3C,OAAO,CAAC,CAAC,OAAO,IAAI,CAAC;QACtB,CAAC;IACF,CAAC;IACD;;;;OAIG;IACK,UAAU,CAAC,IAAS;QAC3B,OAAO;YACN,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC;YACjC,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ;YAC9B,GAAG,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK;YACtB,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK;YACxB,cAAc,EAAE,IAAI,CAAC,MAAM;YAC3B,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,CAAC;gBACrC,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,EAAE;gBACnB,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI;gBACvB,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ;gBAC/B,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ;aACvB,CAAC,CAAC;SACH,CAAA;IACF,CAAC;IACD;;;;OAIG;IACK,cAAc,CAAC,IAAS;QAC/B,OAAO;YACN,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC;YACjC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,KAAK;YAChC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,CAAC;gBACrC,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,EAAE;gBACnB,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI;gBACvB,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ;gBAC/B,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ;aACvB,CAAC,CAAC;YACH,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI,CAAC;SAC9B,CAAA;IACF,CAAC;IACD;;;;OAIG;IACK,cAAc,CAAC,IAAS;QAC/B,IAAI,WAAW,GAAG,EAAE,CAAA;QACpB,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,YAAiB,EAAE,EAAE,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC,IAAI,EAAE,CAAA;QACtF,OAAO,WAAW,IAAI,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,WAAW,CAAA;IACxD,CAAC;IACD;;;;OAIG;IACK,WAAW,CAAC,IAAS;QAC5B,IAAI,WAAW,GAAG,IAAI,CAAC,KAAK,EAAE,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;QACzE,OAAO;YACN,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,KAAK;YAChC,KAAK,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,QAAQ,EAAE,WAAW,CAAC,QAAQ,EAAE,GAAG,WAAW,CAAC,OAAO,EAAE,CAAC,CAAC;YAChF,KAAK,EAAE,WAAW,CAAC,KAAK,IAAI,CAAC;SAC7B,CAAA;IACF,CAAC;IACD;;;OAGG;IACH,OAAO,KAAK,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC;IACnC;;;;OAIG;IACK,UAAU,CAAC,OAAY;QAC9B,OAAO;YACN,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,KAAK,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;YAC7B,KAAK,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,SAAS,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,KAAK;SACnE,CAAA;IACF,CAAC;IACD;;;;OAIG;IACK,cAAc,CAAC,IAAS;QAC/B,OAAO;YACN,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAY,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;YAChE,cAAc,EAAE,IAAI,CAAC,cAAc,IAAI,YAAY;YACnD,YAAY,EAAE,IAAI,CAAC,YAAY,IAAI,YAAY;SAC/C,CAAA;IACF,CAAC;IACD;;;;OAIG;IACK,cAAc,CAAC,OAAY;QAClC,IAAI,YAAY,GAAG,OAAO,CAAC,OAAO,CAAA;QAClC,OAAO;YACN,QAAQ,EAAE,OAAO,CAAC,QAAQ,IAAI,KAAK;YACnC,KAAK,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,QAAQ,EAAE,OAAO,CAAC,QAAQ,EAAE,GAAG,YAAY,EAAE,CAAC,CAAC;YACrE,KAAK,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,SAAS,IAAI,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,GAAG,OAAO,CAAC,QAAQ,IAAI,CAAC;SACvG,CAAA;IACF,CAAC;IAEO,MAAM,GAAG,CAAC,OAAY,EAAE,EAAE,CAAC,CAAC;QACnC,SAAS,EAAE,OAAO,CAAC,IAAI;QACvB,OAAO,EAAE,OAAO,CAAC,EAAE;QACnB,UAAU,EAAE,OAAO,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;QACxE,aAAa,EAAE,OAAO,CAAC,QAAQ;QAC/B,KAAK,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,SAAS,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,KAAK;QACnE,QAAQ,EAAE,OAAO,CAAC,QAAQ,IAAI,CAAC;KAC/B,CAAC,CAAA;IACF;;;;OAIG;IACK,aAAa,CAAC,IAAS;QAC9B,OAAO;YACN,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC;YACjC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,KAAK;YAChC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,CAAC;gBACrC,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,EAAE;gBACnB,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI;gBACvB,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ;gBAC/B,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ;aACvB,CAAC,CAAC;YACH,YAAY,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,IAAI,cAAc;YAC9D,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI,CAAC;SAC9B,CAAA;IACF,CAAC;IACD;;;;OAIG;IACK,cAAc,CAAC,IAAS;QAC/B,OAAO;YACN,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC;YACjC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,KAAK;YAChC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,CAAC;gBACrC,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,EAAE;gBACnB,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI;gBACvB,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ;gBAC/B,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ;aACvB,CAAC,CAAC;YACH,aAAa,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,IAAI,cAAc;YAChE,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI,CAAC;SAC9B,CAAA;IACF,CAAC;IAEO,QAAQ,CAAC,IAAS;QACzB,OAAO;YACN,GAAG,IAAI;SACP,CAAA;IACF,CAAC;wGA7QW,sBAAsB;4GAAtB,sBAAsB,cAFtB,MAAM;;4FAEN,sBAAsB;kBAHlC,UAAU;mBAAC;oBACX,UAAU,EAAE,MAAM;iBAClB","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"]}
|
|
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 (typeof document !== 'undefined' && !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"]}
|