ng-easycommerce-v18 0.3.13 → 0.3.14-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 +2 -7
- package/esm2022/lib/classes/filters/filter.mjs +27 -2
- package/esm2022/lib/constants/api.constants.service.mjs +28 -42
- package/esm2022/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.mjs +1 -5
- package/esm2022/lib/ec-components/auth-ec/register-form-ec/register-form-ec.component.mjs +1 -5
- package/esm2022/lib/ec-components/blocks-ec/block-products-ec/block-products-ec.component.mjs +5 -3
- package/esm2022/lib/ec-components/cart-ec/cart-item-ec/cart-item-ec.component.mjs +2 -6
- package/esm2022/lib/ec-components/header-ec/header-ec.component.mjs +34 -45
- package/esm2022/lib/ec-components/product-ec/product-ec.component.mjs +5 -95
- package/esm2022/lib/ec-components/related-products-ec/related-products-ec.component.mjs +6 -4
- package/esm2022/lib/ec-components/widgets-ec/index.mjs +1 -2
- package/esm2022/lib/ec-components/widgets-ec/magnizoom-ec/magnizoom-ec.component.mjs +4 -2
- package/esm2022/lib/ec-services/analytics/facebook-pixel.service.mjs +4 -2
- package/esm2022/lib/ec-services/analytics/google-analytics.service.mjs +4 -2
- package/esm2022/lib/ec-services/options.service.mjs +27 -3
- package/fesm2022/ng-easycommerce-v18.mjs +152 -348
- package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
- package/lib/constants/api.constants.service.d.ts +8 -23
- package/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.d.ts +0 -2
- package/lib/ec-components/auth-ec/register-form-ec/register-form-ec.component.d.ts +0 -2
- package/lib/ec-components/cart-ec/cart-item-ec/cart-item-ec.component.d.ts +0 -5
- package/lib/ec-components/header-ec/header-ec.component.d.ts +1 -5
- package/lib/ec-components/product-ec/product-ec.component.d.ts +1 -10
- package/lib/ec-components/widgets-ec/index.d.ts +0 -1
- package/lib/ec-services/options.service.d.ts +4 -0
- package/package.json +1 -1
- package/esm2022/lib/ec-components/widgets-ec/redsys-catch-ec/redsys-catch-ec.component.mjs +0 -138
- package/lib/ec-components/widgets-ec/redsys-catch-ec/redsys-catch-ec.component.d.ts +0 -26
package/README.md
CHANGED
|
@@ -1,10 +1,5 @@
|
|
|
1
|
-
# Version 0.3.
|
|
2
|
-
-
|
|
3
|
-
- Se hace estable feature/pop-up-inicial.
|
|
4
|
-
- Se hace estable feature/add-product-block.
|
|
5
|
-
- Se hace estable feature/logged,showpassword,otros.
|
|
6
|
-
# Version 0.3.12-beta.1
|
|
7
|
-
- Se añade ruta por si falla MP redirija y de error.
|
|
1
|
+
# Version 0.3.14-beta.1
|
|
2
|
+
- Pruebas para errores en console al desplegar
|
|
8
3
|
# Version 0.3.11
|
|
9
4
|
- se añade funcionalidad para ocultar categorias en header footer y filtros
|
|
10
5
|
# Version 0.3.10
|
|
@@ -1,3 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Función auxiliar para remover acentos de forma segura para SSR
|
|
3
|
+
*/
|
|
4
|
+
function safeRemoveAccents(str) {
|
|
5
|
+
if (typeof window !== 'undefined' && typeof String.prototype.normalize === 'function') {
|
|
6
|
+
return str.normalize("NFD").replace(/[\u0300-\u036f]/g, "");
|
|
7
|
+
}
|
|
8
|
+
// Fallback para SSR - remover acentos manualmente
|
|
9
|
+
return str.replace(/[àáâãäå]/g, 'a')
|
|
10
|
+
.replace(/[èéêë]/g, 'e')
|
|
11
|
+
.replace(/[ìíîï]/g, 'i')
|
|
12
|
+
.replace(/[òóôõö]/g, 'o')
|
|
13
|
+
.replace(/[ùúûü]/g, 'u')
|
|
14
|
+
.replace(/[ýÿ]/g, 'y')
|
|
15
|
+
.replace(/[ñ]/g, 'n')
|
|
16
|
+
.replace(/[ç]/g, 'c')
|
|
17
|
+
.replace(/[ÀÁÂÃÄÅ]/g, 'A')
|
|
18
|
+
.replace(/[ÈÉÊË]/g, 'E')
|
|
19
|
+
.replace(/[ÌÍÎÏ]/g, 'I')
|
|
20
|
+
.replace(/[ÒÓÔÕÖ]/g, 'O')
|
|
21
|
+
.replace(/[ÙÚÛÜ]/g, 'U')
|
|
22
|
+
.replace(/[ÝŸ]/g, 'Y')
|
|
23
|
+
.replace(/[Ñ]/g, 'N')
|
|
24
|
+
.replace(/[Ç]/g, 'C');
|
|
25
|
+
}
|
|
1
26
|
export class Filter {
|
|
2
27
|
data = [];
|
|
3
28
|
multi = false;
|
|
@@ -17,7 +42,7 @@ export class Filter {
|
|
|
17
42
|
throw new Error("Method not implemented.");
|
|
18
43
|
}
|
|
19
44
|
removeAccents = (str) => {
|
|
20
|
-
return str
|
|
45
|
+
return safeRemoveAccents(str);
|
|
21
46
|
};
|
|
22
47
|
setSelected(element, value) {
|
|
23
48
|
//console.log(element, value);
|
|
@@ -80,4 +105,4 @@ export class Filter {
|
|
|
80
105
|
return result;
|
|
81
106
|
};
|
|
82
107
|
}
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/classes/filters/filter.ts"],"names":[],"mappings":"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","sourcesContent":["import { FilterElement, FilterType, IFilter } from \"../../interfaces\";\r\n\r\nexport class Filter implements IFilter  {\r\n    \r\n    data: FilterElement[] = [];\r\n    multi: boolean = false;\r\n    \r\n    type(): FilterType {\r\n        throw new Error(\"Method not implemented.\");\r\n    }\r\n    setContent(options: any): void {\r\n        throw new Error(\"Method not implemented.\");\r\n    }\r\n    getContent(): FilterElement[] {\r\n        throw new Error(\"Method not implemented.\");\r\n    }\r\n    toUrlParams(): string {\r\n        throw new Error(\"Method not implemented.\");\r\n    }\r\n    createElement(filter: any, original: any, initialValue?: any) {\r\n        throw new Error(\"Method not implemented.\");\r\n    }\r\n    removeAccents = (str:string) => {\r\n        return str.normalize(\"NFD\").replace(/[\\u0300-\\u036f]/g, \"\");\r\n    }\r\n\r\n    setSelected(element:any, value?:any){\r\n        //console.log(element, value);\r\n        ((element.multi != undefined) && !element.multi) ? this.cleanFilter(this.data, element) : null;\r\n        this.setSelectedValue(element, value);\r\n    }\r\n\r\n    cleanFilter = (data:any, element_to_change:any) => {\r\n        //console.log(\"cleanFilter\");\r\n        element_to_change && data.forEach((element:any) => {\r\n            element_to_change != element ? element.selected = false : null;\r\n            (element.children && element.children.length > 0) && this.cleanFilter(element.children, element_to_change);\r\n        })\r\n    }\r\n\r\n    setSelectedValue(element:any, value?:any, sublist?:any, multi?:any){\r\n        let elements = sublist || this.data;\r\n        let index = elements.findIndex((subelement:any) => {\r\n            return (element.code || element) == subelement.code;\r\n        });\r\n        if (index >= 0) {\r\n            elements[index].selected = elements[index].selected ? false : true;\r\n            !multi && elements.forEach((child:any, i:number) => {\r\n                if (i != index) child.selected = false;\r\n            });\r\n            return {\r\n                elements,\r\n                founded: true\r\n            };\r\n        } else {\r\n            elements.some((elem:any) => elem.type == 'sub') && elements.some(\r\n                (filter:any) => {\r\n                    let founded = false;\r\n                    if (filter.type == 'sub') {\r\n                        const result = this.setSelectedValue(element, value, filter.children, filter.multi);\r\n                        if (result && result.founded) {\r\n                            filter.children = result.elements;\r\n                            founded = true;\r\n                        }\r\n                    }\r\n                    return founded;\r\n                }\r\n            )\r\n        }\r\n        return null;\r\n    };\r\n\r\n    getSelectedList = (): any => this.findSelected(this.data, []);\r\n\r\n    findSelected = (elements: any[], result:any) => {\r\n        let element = elements.find(elem => elem.selected);\r\n        if (element) {\r\n            result.push(element.code);\r\n            return result;\r\n        }\r\n        elements.forEach(elem => {\r\n            if (elem.children && elem.children.length) {\r\n                let new_result = this.findSelected(elem.children, result);\r\n                if (new_result) result = new_result;\r\n            }\r\n        })\r\n        return result;\r\n    }\r\n}\r\n"]}
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/classes/filters/filter.ts"],"names":[],"mappings":"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","sourcesContent":["import { FilterElement, FilterType, IFilter } from \"../../interfaces\";\r\n\r\n/**\r\n * Función auxiliar para remover acentos de forma segura para SSR\r\n */\r\nfunction safeRemoveAccents(str: string): string {\r\n    if (typeof window !== 'undefined' && typeof String.prototype.normalize === 'function') {\r\n        return str.normalize(\"NFD\").replace(/[\\u0300-\\u036f]/g, \"\");\r\n    }\r\n    // Fallback para SSR - remover acentos manualmente\r\n    return str.replace(/[àáâãäå]/g, 'a')\r\n        .replace(/[èéêë]/g, 'e')\r\n        .replace(/[ìíîï]/g, 'i')\r\n        .replace(/[òóôõö]/g, 'o')\r\n        .replace(/[ùúûü]/g, 'u')\r\n        .replace(/[ýÿ]/g, 'y')\r\n        .replace(/[ñ]/g, 'n')\r\n        .replace(/[ç]/g, 'c')\r\n        .replace(/[ÀÁÂÃÄÅ]/g, 'A')\r\n        .replace(/[ÈÉÊË]/g, 'E')\r\n        .replace(/[ÌÍÎÏ]/g, 'I')\r\n        .replace(/[ÒÓÔÕÖ]/g, 'O')\r\n        .replace(/[ÙÚÛÜ]/g, 'U')\r\n        .replace(/[ÝŸ]/g, 'Y')\r\n        .replace(/[Ñ]/g, 'N')\r\n        .replace(/[Ç]/g, 'C');\r\n}\r\n\r\nexport class Filter implements IFilter  {\r\n    \r\n    data: FilterElement[] = [];\r\n    multi: boolean = false;\r\n    \r\n    type(): FilterType {\r\n        throw new Error(\"Method not implemented.\");\r\n    }\r\n    setContent(options: any): void {\r\n        throw new Error(\"Method not implemented.\");\r\n    }\r\n    getContent(): FilterElement[] {\r\n        throw new Error(\"Method not implemented.\");\r\n    }\r\n    toUrlParams(): string {\r\n        throw new Error(\"Method not implemented.\");\r\n    }\r\n    createElement(filter: any, original: any, initialValue?: any) {\r\n        throw new Error(\"Method not implemented.\");\r\n    }\r\n    removeAccents = (str:string) => {\r\n        return safeRemoveAccents(str);\r\n    }\r\n\r\n    setSelected(element:any, value?:any){\r\n        //console.log(element, value);\r\n        ((element.multi != undefined) && !element.multi) ? this.cleanFilter(this.data, element) : null;\r\n        this.setSelectedValue(element, value);\r\n    }\r\n\r\n    cleanFilter = (data:any, element_to_change:any) => {\r\n        //console.log(\"cleanFilter\");\r\n        element_to_change && data.forEach((element:any) => {\r\n            element_to_change != element ? element.selected = false : null;\r\n            (element.children && element.children.length > 0) && this.cleanFilter(element.children, element_to_change);\r\n        })\r\n    }\r\n\r\n    setSelectedValue(element:any, value?:any, sublist?:any, multi?:any){\r\n        let elements = sublist || this.data;\r\n        let index = elements.findIndex((subelement:any) => {\r\n            return (element.code || element) == subelement.code;\r\n        });\r\n        if (index >= 0) {\r\n            elements[index].selected = elements[index].selected ? false : true;\r\n            !multi && elements.forEach((child:any, i:number) => {\r\n                if (i != index) child.selected = false;\r\n            });\r\n            return {\r\n                elements,\r\n                founded: true\r\n            };\r\n        } else {\r\n            elements.some((elem:any) => elem.type == 'sub') && elements.some(\r\n                (filter:any) => {\r\n                    let founded = false;\r\n                    if (filter.type == 'sub') {\r\n                        const result = this.setSelectedValue(element, value, filter.children, filter.multi);\r\n                        if (result && result.founded) {\r\n                            filter.children = result.elements;\r\n                            founded = true;\r\n                        }\r\n                    }\r\n                    return founded;\r\n                }\r\n            )\r\n        }\r\n        return null;\r\n    };\r\n\r\n    getSelectedList = (): any => this.findSelected(this.data, []);\r\n\r\n    findSelected = (elements: any[], result:any) => {\r\n        let element = elements.find(elem => elem.selected);\r\n        if (element) {\r\n            result.push(element.code);\r\n            return result;\r\n        }\r\n        elements.forEach(elem => {\r\n            if (elem.children && elem.children.length) {\r\n                let new_result = this.findSelected(elem.children, result);\r\n                if (new_result) result = new_result;\r\n            }\r\n        })\r\n        return result;\r\n    }\r\n}\r\n"]}
|
|
@@ -1,92 +1,75 @@
|
|
|
1
|
-
import { inject, Injectable } from '@angular/core';
|
|
1
|
+
import { inject, Injectable, PLATFORM_ID, Inject } from '@angular/core';
|
|
2
|
+
import { isPlatformServer } from '@angular/common';
|
|
2
3
|
import { ENVIRONMENT_TOKEN } from '../providers';
|
|
3
4
|
import { LocalStorageService } from '../ec-services';
|
|
4
5
|
import { TranslateService } from '@ngx-translate/core';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
/**
|
|
7
|
-
* Servicio que provee de datos
|
|
8
|
-
* @export
|
|
9
|
-
* @class ApiConstantsService
|
|
8
|
+
* Servicio que provee de datos relacionados con las peticiones a la API
|
|
10
9
|
*/
|
|
11
10
|
export class ApiConstantsService {
|
|
11
|
+
ssrApiUrl;
|
|
12
12
|
_localStorage = inject(LocalStorageService);
|
|
13
13
|
_translate = inject(TranslateService);
|
|
14
|
-
/**
|
|
15
|
-
* Contiene los datos provisto por el frontend en el archivo environment.ts
|
|
16
|
-
*/
|
|
17
14
|
environment = inject(ENVIRONMENT_TOKEN);
|
|
15
|
+
platformId = inject(PLATFORM_ID);
|
|
16
|
+
_channel;
|
|
17
|
+
LOCALE;
|
|
18
|
+
SHOP_API_URL = 'shop-api/';
|
|
19
|
+
CMS_URL = 'cms/';
|
|
20
|
+
constructor(ssrApiUrl) {
|
|
21
|
+
this.ssrApiUrl = ssrApiUrl;
|
|
22
|
+
this._channel = this.environment.channel;
|
|
23
|
+
this.LOCALE = this.environment.locale;
|
|
24
|
+
}
|
|
18
25
|
/**
|
|
19
26
|
* Canal actual del frontend
|
|
20
27
|
*/
|
|
21
28
|
get CHANNEL() {
|
|
22
|
-
// Verificar si estamos en el navegador (no en SSR)
|
|
23
29
|
if (typeof window !== 'undefined') {
|
|
24
|
-
// Primero intenta leer de window.__env (configurado por Docker)
|
|
25
30
|
const windowEnv = window.__env;
|
|
26
|
-
if (windowEnv?.channel)
|
|
31
|
+
if (windowEnv?.channel)
|
|
27
32
|
return windowEnv.channel;
|
|
28
|
-
}
|
|
29
33
|
}
|
|
30
|
-
// Fallback al environment
|
|
31
34
|
return this._channel;
|
|
32
35
|
}
|
|
33
36
|
set CHANNEL(value) {
|
|
34
37
|
this._channel = value;
|
|
35
38
|
}
|
|
36
|
-
_channel;
|
|
37
|
-
/**
|
|
38
|
-
* Locale actual del frontend
|
|
39
|
-
*/
|
|
40
|
-
LOCALE;
|
|
41
|
-
/**
|
|
42
|
-
* URL para las peticiones a shop-api
|
|
43
|
-
*/
|
|
44
|
-
SHOP_API_URL = 'shop-api/';
|
|
45
|
-
/**
|
|
46
|
-
* URL para las peticiones a cms
|
|
47
|
-
*/
|
|
48
|
-
CMS_URL = 'cms/';
|
|
49
|
-
constructor() {
|
|
50
|
-
this._channel = this.environment.channel;
|
|
51
|
-
this.LOCALE = this.environment.locale;
|
|
52
|
-
}
|
|
53
39
|
/**
|
|
54
40
|
* URL del backend para realizar las peticiones
|
|
55
41
|
*/
|
|
56
42
|
get API_URL() {
|
|
57
|
-
// Verificar si estamos en el navegador (no en SSR)
|
|
58
43
|
if (typeof window !== 'undefined') {
|
|
59
|
-
// Primero intenta leer de window.__env (configurado por Docker)
|
|
60
44
|
const windowEnv = window.__env;
|
|
61
|
-
if (windowEnv?.apiUrl)
|
|
45
|
+
if (windowEnv?.apiUrl)
|
|
62
46
|
return windowEnv.apiUrl;
|
|
63
|
-
}
|
|
64
47
|
}
|
|
65
|
-
|
|
48
|
+
if (isPlatformServer(this.platformId)) {
|
|
49
|
+
return this.ssrApiUrl; // ⚡ URL inyectada desde server.ts
|
|
50
|
+
}
|
|
66
51
|
return this.environment.apiUrl ?? '';
|
|
67
52
|
}
|
|
68
53
|
/**
|
|
69
54
|
* Retorna la url base
|
|
70
|
-
* @returns {string}
|
|
71
55
|
*/
|
|
72
56
|
getUrlBase() {
|
|
73
57
|
return this.API_URL;
|
|
74
58
|
}
|
|
75
59
|
/**
|
|
76
60
|
* Cambia el canal actual
|
|
77
|
-
* @param code
|
|
78
|
-
* @returns
|
|
79
61
|
*/
|
|
80
|
-
setChannel(code) {
|
|
62
|
+
setChannel(code) {
|
|
63
|
+
this.CHANNEL = code;
|
|
64
|
+
}
|
|
81
65
|
setLocale(locale) {
|
|
82
66
|
this._localStorage.setItem(this.LOCALE_KEY, locale);
|
|
83
67
|
this._translate.use(locale.split('_')[0]);
|
|
84
68
|
this.LOCALE = locale;
|
|
85
69
|
}
|
|
86
|
-
//Storage key
|
|
87
70
|
LOCALE_KEY = 'LOCALE';
|
|
88
71
|
CHANNEL_KEY = 'CHANNEL';
|
|
89
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ApiConstantsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
72
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ApiConstantsService, deps: [{ token: 'API_URL' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
90
73
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ApiConstantsService, providedIn: 'root' });
|
|
91
74
|
}
|
|
92
75
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ApiConstantsService, decorators: [{
|
|
@@ -94,5 +77,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
94
77
|
args: [{
|
|
95
78
|
providedIn: 'root'
|
|
96
79
|
}]
|
|
97
|
-
}], ctorParameters: () => [
|
|
98
|
-
|
|
80
|
+
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
81
|
+
type: Inject,
|
|
82
|
+
args: ['API_URL']
|
|
83
|
+
}] }] });
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmNvbnN0YW50cy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2NvbnN0YW50cy9hcGkuY29uc3RhbnRzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4RSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFakQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUJBQXFCLENBQUM7O0FBRXZEOztHQUVHO0FBSUgsTUFBTSxPQUFPLG1CQUFtQjtJQWFTO0lBWi9CLGFBQWEsR0FBd0IsTUFBTSxDQUFDLG1CQUFtQixDQUFDLENBQUM7SUFDakUsVUFBVSxHQUFxQixNQUFNLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUV4RCxXQUFXLEdBQWdCLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0lBQ3JELFVBQVUsR0FBRyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7SUFFakMsUUFBUSxDQUFTO0lBQ2xCLE1BQU0sQ0FBUztJQUVOLFlBQVksR0FBVyxXQUFXLENBQUM7SUFDbkMsT0FBTyxHQUFXLE1BQU0sQ0FBQztJQUV6QyxZQUF1QyxTQUFpQjtRQUFqQixjQUFTLEdBQVQsU0FBUyxDQUFRO1FBQ3RELElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUM7UUFDekMsSUFBSSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQztJQUN4QyxDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFXLE9BQU87UUFDaEIsSUFBSSxPQUFPLE1BQU0sS0FBSyxXQUFXLEVBQUUsQ0FBQztZQUNsQyxNQUFNLFNBQVMsR0FBSSxNQUFjLENBQUMsS0FBSyxDQUFDO1lBQ3hDLElBQUksU0FBUyxFQUFFLE9BQU87Z0JBQUUsT0FBTyxTQUFTLENBQUMsT0FBTyxDQUFDO1FBQ25ELENBQUM7UUFDRCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDdkIsQ0FBQztJQUVELElBQVcsT0FBTyxDQUFDLEtBQWE7UUFDOUIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7SUFDeEIsQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFBVyxPQUFPO1FBQ2hCLElBQUksT0FBTyxNQUFNLEtBQUssV0FBVyxFQUFFLENBQUM7WUFDbEMsTUFBTSxTQUFTLEdBQUksTUFBYyxDQUFDLEtBQUssQ0FBQztZQUN4QyxJQUFJLFNBQVMsRUFBRSxNQUFNO2dCQUFFLE9BQU8sU0FBUyxDQUFDLE1BQU0sQ0FBQztRQUNqRCxDQUFDO1FBRUQsSUFBSSxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQztZQUN0QyxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxrQ0FBa0M7UUFDM0QsQ0FBQztRQUVELE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLElBQUksRUFBRSxDQUFDO0lBQ3ZDLENBQUM7SUFFRDs7T0FFRztJQUNJLFVBQVU7UUFDZixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDdEIsQ0FBQztJQUVEOztPQUVHO0lBQ0ksVUFBVSxDQUFDLElBQVk7UUFDNUIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7SUFDdEIsQ0FBQztJQUVNLFNBQVMsQ0FBQyxNQUFjO1FBQzdCLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDcEQsSUFBSSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzFDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO0lBQ3ZCLENBQUM7SUFFZ0IsVUFBVSxHQUFXLFFBQVEsQ0FBQztJQUM5QixXQUFXLEdBQVcsU0FBUyxDQUFDO3dHQXRFdEMsbUJBQW1CLGtCQWFWLFNBQVM7NEdBYmxCLG1CQUFtQixjQUZsQixNQUFNOzs0RkFFUCxtQkFBbUI7a0JBSC9CLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25COzswQkFjYyxNQUFNOzJCQUFDLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QsIEluamVjdGFibGUsIFBMQVRGT1JNX0lELCBJbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgaXNQbGF0Zm9ybVNlcnZlciB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IEVOVklST05NRU5UX1RPS0VOIH0gZnJvbSAnLi4vcHJvdmlkZXJzJztcclxuaW1wb3J0IHsgRW52aXJvbm1lbnQgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcclxuaW1wb3J0IHsgTG9jYWxTdG9yYWdlU2VydmljZSB9IGZyb20gJy4uL2VjLXNlcnZpY2VzJztcclxuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xyXG5cclxuLyoqXHJcbiAqIFNlcnZpY2lvIHF1ZSBwcm92ZWUgZGUgZGF0b3MgcmVsYWNpb25hZG9zIGNvbiBsYXMgcGV0aWNpb25lcyBhIGxhIEFQSVxyXG4gKi9cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQXBpQ29uc3RhbnRzU2VydmljZSB7XHJcbiAgcHJpdmF0ZSBfbG9jYWxTdG9yYWdlOiBMb2NhbFN0b3JhZ2VTZXJ2aWNlID0gaW5qZWN0KExvY2FsU3RvcmFnZVNlcnZpY2UpO1xyXG4gIHByaXZhdGUgX3RyYW5zbGF0ZTogVHJhbnNsYXRlU2VydmljZSA9IGluamVjdChUcmFuc2xhdGVTZXJ2aWNlKTtcclxuXHJcbiAgcHJpdmF0ZSBlbnZpcm9ubWVudDogRW52aXJvbm1lbnQgPSBpbmplY3QoRU5WSVJPTk1FTlRfVE9LRU4pO1xyXG4gIHByaXZhdGUgcGxhdGZvcm1JZCA9IGluamVjdChQTEFURk9STV9JRCk7XHJcblxyXG4gIHByaXZhdGUgX2NoYW5uZWw6IHN0cmluZztcclxuICBwdWJsaWMgTE9DQUxFOiBzdHJpbmc7XHJcblxyXG4gIHB1YmxpYyByZWFkb25seSBTSE9QX0FQSV9VUkw6IHN0cmluZyA9ICdzaG9wLWFwaS8nO1xyXG4gIHB1YmxpYyByZWFkb25seSBDTVNfVVJMOiBzdHJpbmcgPSAnY21zLyc7XHJcblxyXG4gIGNvbnN0cnVjdG9yKEBJbmplY3QoJ0FQSV9VUkwnKSBwcml2YXRlIHNzckFwaVVybDogc3RyaW5nKSB7XHJcbiAgICB0aGlzLl9jaGFubmVsID0gdGhpcy5lbnZpcm9ubWVudC5jaGFubmVsO1xyXG4gICAgdGhpcy5MT0NBTEUgPSB0aGlzLmVudmlyb25tZW50LmxvY2FsZTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIENhbmFsIGFjdHVhbCBkZWwgZnJvbnRlbmRcclxuICAgKi9cclxuICBwdWJsaWMgZ2V0IENIQU5ORUwoKTogc3RyaW5nIHtcclxuICAgIGlmICh0eXBlb2Ygd2luZG93ICE9PSAndW5kZWZpbmVkJykge1xyXG4gICAgICBjb25zdCB3aW5kb3dFbnYgPSAod2luZG93IGFzIGFueSkuX19lbnY7XHJcbiAgICAgIGlmICh3aW5kb3dFbnY/LmNoYW5uZWwpIHJldHVybiB3aW5kb3dFbnYuY2hhbm5lbDtcclxuICAgIH1cclxuICAgIHJldHVybiB0aGlzLl9jaGFubmVsO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHNldCBDSEFOTkVMKHZhbHVlOiBzdHJpbmcpIHtcclxuICAgIHRoaXMuX2NoYW5uZWwgPSB2YWx1ZTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFVSTCBkZWwgYmFja2VuZCBwYXJhIHJlYWxpemFyIGxhcyBwZXRpY2lvbmVzXHJcbiAgICovXHJcbiAgcHVibGljIGdldCBBUElfVVJMKCk6IHN0cmluZyB7XHJcbiAgICBpZiAodHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCcpIHtcclxuICAgICAgY29uc3Qgd2luZG93RW52ID0gKHdpbmRvdyBhcyBhbnkpLl9fZW52O1xyXG4gICAgICBpZiAod2luZG93RW52Py5hcGlVcmwpIHJldHVybiB3aW5kb3dFbnYuYXBpVXJsO1xyXG4gICAgfVxyXG5cclxuICAgIGlmIChpc1BsYXRmb3JtU2VydmVyKHRoaXMucGxhdGZvcm1JZCkpIHtcclxuICAgICAgcmV0dXJuIHRoaXMuc3NyQXBpVXJsOyAvLyDimqEgVVJMIGlueWVjdGFkYSBkZXNkZSBzZXJ2ZXIudHNcclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gdGhpcy5lbnZpcm9ubWVudC5hcGlVcmwgPz8gJyc7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBSZXRvcm5hIGxhIHVybCBiYXNlXHJcbiAgICovXHJcbiAgcHVibGljIGdldFVybEJhc2UoKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLkFQSV9VUkw7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBDYW1iaWEgZWwgY2FuYWwgYWN0dWFsXHJcbiAgICovXHJcbiAgcHVibGljIHNldENoYW5uZWwoY29kZTogc3RyaW5nKTogdm9pZCB7XHJcbiAgICB0aGlzLkNIQU5ORUwgPSBjb2RlO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHNldExvY2FsZShsb2NhbGU6IHN0cmluZyk6IHZvaWQge1xyXG4gICAgdGhpcy5fbG9jYWxTdG9yYWdlLnNldEl0ZW0odGhpcy5MT0NBTEVfS0VZLCBsb2NhbGUpO1xyXG4gICAgdGhpcy5fdHJhbnNsYXRlLnVzZShsb2NhbGUuc3BsaXQoJ18nKVswXSk7XHJcbiAgICB0aGlzLkxPQ0FMRSA9IGxvY2FsZTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgcmVhZG9ubHkgTE9DQUxFX0tFWTogc3RyaW5nID0gJ0xPQ0FMRSc7XHJcbiAgcHJpdmF0ZSByZWFkb25seSBDSEFOTkVMX0tFWTogc3RyaW5nID0gJ0NIQU5ORUwnO1xyXG59XHJcbiJdfQ==
|
|
@@ -12,7 +12,6 @@ export class LoginFormEcComponent {
|
|
|
12
12
|
_formBuilder = inject(FormBuilder);
|
|
13
13
|
_toastService = inject(ToastService);
|
|
14
14
|
_router = inject(Router);
|
|
15
|
-
showPassword = false;
|
|
16
15
|
/**
|
|
17
16
|
* Parametro para indicar si tras loguear
|
|
18
17
|
* debe redireccionar o no.
|
|
@@ -101,9 +100,6 @@ export class LoginFormEcComponent {
|
|
|
101
100
|
? resolverFunction()
|
|
102
101
|
: this._router.navigateByUrl(this.redirectTo);
|
|
103
102
|
}
|
|
104
|
-
togglePassword() {
|
|
105
|
-
this.showPassword = !this.showPassword;
|
|
106
|
-
}
|
|
107
103
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LoginFormEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
108
104
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LoginFormEcComponent, isStandalone: true, selector: "app-login-form-ec", inputs: { redirect: "redirect", redirectTo: "redirectTo", inCart: "inCart" }, outputs: { ready: "ready" }, ngImport: i0, template: "<div class=\"d-flex flex-column position-relative\">\r\n <h1 class=\"right-line ff-ubuntu-light mb-4\"><span>Ingresar</span></h1>\r\n <p class=\"ff-ubuntu-light font-sm pr-4 mb-4\">\r\n Si ya est\u00E1s registrado. Ingresa en tu cuenta con tu email y la\r\n contrase\u00F1a adecuada.\r\n </p>\r\n <div class=\"w-md-50 w-100 text-center\">\r\n <form [formGroup]=\"loginForm()\" (submit)=\"login($event)\">\r\n <input class=\"form-control mb-4 radius-0\" type=\"email\" formControlName=\"username\"\r\n placeholder=\"Correo Electr\u00F3nico\">\r\n <input class=\"form-control mb-4 radius-0\" type=\"password\" formControlName=\"password\"\r\n placeholder=\"Contrase\u00F1a\">\r\n\r\n <div class=\"row d-flex flex-column\">\r\n <div class=\"col-12 mb-4\">\r\n <button type=\"submit\"\r\n class=\"bg-gray border-0 px-4 py-2 color-white ff-ubuntu-light\">INGRESAR</button>\r\n </div>\r\n <div class=\"col-12 d-flex justify-content-center align-items-center\">\r\n <a [routerLink]=\"'/auth/forgot-password'\" class=\"font-md ff-ubuntu-light\">\r\n \u00BFOlvid\u00F3 su contrase\u00F1a?\r\n </a>\r\n </div>\r\n </div>\r\n </form>\r\n </div>\r\n @if(loading){\r\n <app-loading-section-ec></app-loading-section-ec>\r\n }\r\n</div>", styles: [""], dependencies: [{ kind: "component", type: LoadingSectionEcComponent, selector: "app-loading-section-ec" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] });
|
|
109
105
|
}
|
|
@@ -119,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
119
115
|
}], inCart: [{
|
|
120
116
|
type: Input
|
|
121
117
|
}] } });
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"login-form-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, inject, Input, Output, signal } from '@angular/core';\r\nimport { LoadingSectionEcComponent } from '../../widgets-ec';\r\nimport { FormBuilder, FormGroup, ReactiveFormsModule, Validators } from '@angular/forms';\r\nimport { Router, RouterLink } from '@angular/router';\r\nimport { AuthService, ToastService } from '../../../ec-services';\r\nimport { UserRoleType } from '../../../interfaces';\r\nimport { firstValueFrom } from 'rxjs';\r\nimport { JsonPipe } from '@angular/common';\r\n\r\n@Component({\r\n\tselector: 'app-login-form-ec',\r\n\tstandalone: true,\r\n\timports: [LoadingSectionEcComponent, ReactiveFormsModule, RouterLink, JsonPipe],\r\n\ttemplateUrl: './login-form-ec.component.html',\r\n\tstyleUrl: './login-form-ec.component.scss'\r\n})\r\nexport class LoginFormEcComponent {\r\n\tprivate _authService: AuthService = inject(AuthService);\r\n\tprivate _formBuilder: FormBuilder = inject(FormBuilder);\r\n\tprivate _toastService: ToastService = inject(ToastService);\r\n\tprivate _router: Router = inject(Router);\r\n\tshowPassword = false;\r\n\r\n\t/**\r\n\t * Parametro para indicar si tras loguear\r\n\t * debe redireccionar o no.\r\n\t */\r\n\t@Input() redirect: boolean = true;\r\n\t/**\r\n\t * Parametro para indicar a donde redireccionar.\r\n\t */\r\n\t@Input() redirectTo: string = '/';\r\n\t@Output() ready = new EventEmitter();\r\n\t/**\r\n\t * Muestra si esta cargando o no.\r\n\t */\r\n\tpublic loading: boolean = false;\r\n\tpublic loggedIn: boolean = false;\r\n\r\n\t@Input() public inCart: boolean = false;\r\n\t/**\r\n\t * Signal que guarda el formulario de login.\r\n\t */\r\n\tpublic loginForm: any = signal<FormGroup>(\r\n\t\tthis._formBuilder.group({\r\n\t\t\tusername: ['', Validators.required],\r\n\t\t\tpassword: ['', Validators.required]\r\n\t\t})\r\n\t);\r\n\t/**\r\n\t * Loguea al usuario en la plataforma.\r\n\t * @param $event \r\n\t * @param withRoles \r\n\t * @returns \r\n\t */\r\n\tpublic login($event: Event, withRoles: UserRoleType[] = []) {\r\n\t\t$event.preventDefault();\r\n\t\tthis.loading = true;\r\n\t\tif (!this.loginForm().valid) {\r\n\t\t\tthis._toastService.show('login-form-incomplete')\r\n\t\t\tthis.loading = false;\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tfirstValueFrom(this._authService.login(this.loginForm().value, withRoles)).then(\r\n\t\t\t(res: any) => {\r\n\t\t\t\tif (res == 'ok') {\r\n\t\t\t\t\tthis.ready.emit(this.loginForm().value.username);\r\n\t\t\t\t\tthis._toastService.show('login-success');\r\n\t\t\t\t\tthis.loggedIn = true;\r\n\t\t\t\t\tif (this.inCart) {\r\n\t\t\t\t\t\t// Si se está en el carrito, se cierra el modal de login\r\n\t\t\t\t\t\tconst modal = document.getElementById('modalInvitado');\r\n\t\t\t\t\t\tif (modal) {\r\n\t\t\t\t\t\t\tconst modalInstance = (window as any).bootstrap?.Modal?.getInstance(modal);\r\n\t\t\t\t\t\t\tif (modalInstance) {\r\n\t\t\t\t\t\t\t\tmodalInstance.hide();\r\n\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\tconst closeButton = modal.querySelector('[data-bs-dismiss=\"modal\"]') as HTMLElement;\r\n\t\t\t\t\t\t\t\tif (closeButton) {\r\n\t\t\t\t\t\t\t\t\tcloseButton.click();\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tthis._router.navigateByUrl('/checkout');\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tthis.redirect && this.redirectHome();\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t} else if (res == 'error') {\r\n\t\t\t\t\tthis._toastService.error('login-error')\r\n\t\t\t\t}\r\n\t\t\t\tthis.loading = false;\r\n\t\t\t},\r\n\t\t\t(err: any) => {\r\n\t\t\t\t// Manejo de error 401\r\n\t\t\t\tif (err?.status === 401) {\r\n\t\t\t\t\tthis._toastService.show('invalid-credentials');\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis._toastService.error('login-error');\r\n\t\t\t\t}\r\n\t\t\t\tthis.loading = false;\r\n\t\t\t}\r\n\t\t)\r\n\t}\r\n\t/**\r\n\t * Si el servicio de auth tiene configurado a donde volver, se ejecutar ese caso.\r\n\t * De lo contrario redirige al contenido de la variable `redirectTo`.\r\n\t */\r\n\tredirectHome() {\r\n\t\tconst resolverFunction = this._authService.getHomeResolver()\r\n\t\tresolverFunction\r\n\t\t\t? resolverFunction()\r\n\t\t\t: this._router.navigateByUrl(this.redirectTo)\r\n\t}\r\n\ttogglePassword() {\r\n\t\tthis.showPassword = !this.showPassword;\r\n\t}\r\n\r\n\r\n}\r\n","<div class=\"d-flex flex-column position-relative\">\r\n    <h1 class=\"right-line ff-ubuntu-light mb-4\"><span>Ingresar</span></h1>\r\n    <p class=\"ff-ubuntu-light font-sm pr-4 mb-4\">\r\n        Si ya estás registrado. Ingresa en tu cuenta con tu email y la\r\n        contraseña adecuada.\r\n    </p>\r\n    <div class=\"w-md-50 w-100 text-center\">\r\n        <form [formGroup]=\"loginForm()\" (submit)=\"login($event)\">\r\n            <input class=\"form-control mb-4 radius-0\" type=\"email\" formControlName=\"username\"\r\n                placeholder=\"Correo Electrónico\">\r\n            <input class=\"form-control mb-4 radius-0\" type=\"password\" formControlName=\"password\"\r\n                placeholder=\"Contraseña\">\r\n\r\n            <div class=\"row d-flex flex-column\">\r\n                <div class=\"col-12 mb-4\">\r\n                    <button type=\"submit\"\r\n                        class=\"bg-gray border-0 px-4 py-2 color-white ff-ubuntu-light\">INGRESAR</button>\r\n                </div>\r\n                <div class=\"col-12 d-flex justify-content-center align-items-center\">\r\n                    <a [routerLink]=\"'/auth/forgot-password'\" class=\"font-md ff-ubuntu-light\">\r\n                        ¿Olvidó su contraseña?\r\n                    </a>\r\n                </div>\r\n            </div>\r\n        </form>\r\n    </div>\r\n    @if(loading){\r\n    <app-loading-section-ec></app-loading-section-ec>\r\n    }\r\n</div>"]}
|
|
118
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"login-form-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, inject, Input, Output, signal } from '@angular/core';\r\nimport { LoadingSectionEcComponent } from '../../widgets-ec';\r\nimport { FormBuilder, FormGroup, ReactiveFormsModule, Validators } from '@angular/forms';\r\nimport { Router, RouterLink } from '@angular/router';\r\nimport { AuthService, ToastService } from '../../../ec-services';\r\nimport { UserRoleType } from '../../../interfaces';\r\nimport { firstValueFrom } from 'rxjs';\r\nimport { JsonPipe } from '@angular/common';\r\n\r\n@Component({\r\n\tselector: 'app-login-form-ec',\r\n\tstandalone: true,\r\n\timports: [LoadingSectionEcComponent, ReactiveFormsModule, RouterLink, JsonPipe],\r\n\ttemplateUrl: './login-form-ec.component.html',\r\n\tstyleUrl: './login-form-ec.component.scss'\r\n})\r\nexport class LoginFormEcComponent {\r\n\tprivate _authService:AuthService = inject(AuthService);\r\n\tprivate _formBuilder:FormBuilder = inject(FormBuilder);\r\n\tprivate _toastService:ToastService = inject(ToastService);\r\n\tprivate _router:Router = inject(Router);\r\n\t/**\r\n\t * Parametro para indicar si tras loguear\r\n\t * debe redireccionar o no.\r\n\t */\r\n\t@Input() redirect:boolean = true;\r\n\t/**\r\n\t * Parametro para indicar a donde redireccionar.\r\n\t */\r\n\t@Input() redirectTo:string = '/';\r\n\t@Output() ready = new EventEmitter();\r\n\t/**\r\n\t * Muestra si esta cargando o no.\r\n\t */\r\n\tpublic loading: boolean = false;\r\n\tpublic loggedIn: boolean = false;\r\n\r\n\t@Input() public inCart: boolean = false;\r\n\t/**\r\n\t * Signal que guarda el formulario de login.\r\n\t */\r\n\tpublic loginForm: any = signal<FormGroup>(\r\n\t\tthis._formBuilder.group({\r\n\t\t\tusername: ['', Validators.required],\r\n\t\t\tpassword: ['', Validators.required]\r\n\t\t})\r\n\t);\r\n\t/**\r\n\t * Loguea al usuario en la plataforma.\r\n\t * @param $event \r\n\t * @param withRoles \r\n\t * @returns \r\n\t */\r\n\tpublic login($event: Event, withRoles: UserRoleType[] = []) {\r\n\t\t$event.preventDefault();\r\n\t\tthis.loading = true;\r\n\t\tif (!this.loginForm().valid) {\r\n\t\t\tthis._toastService.show('login-form-incomplete')\r\n\t\t\tthis.loading = false;\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tfirstValueFrom(this._authService.login(this.loginForm().value, withRoles)).then(\r\n\t\t\t(res: any) => {\r\n\t\t\t\tif (res == 'ok') {\r\n\t\t\t\t\tthis.ready.emit(this.loginForm().value.username);\r\n\t\t\t\t\tthis._toastService.show('login-success');\r\n\t\t\t\t\tthis.loggedIn = true;\r\n\t\t\t\t\tif (this.inCart) {\r\n\t\t\t\t\t\t// Si se está en el carrito, se cierra el modal de login\r\n\t\t\t\t\t\tconst modal = document.getElementById('modalInvitado');\r\n\t\t\t\t\t\tif (modal) {\r\n\t\t\t\t\t\t\tconst modalInstance = (window as any).bootstrap?.Modal?.getInstance(modal);\r\n\t\t\t\t\t\t\tif (modalInstance) {\r\n\t\t\t\t\t\t\t\tmodalInstance.hide();\r\n\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\tconst closeButton = modal.querySelector('[data-bs-dismiss=\"modal\"]') as HTMLElement;\r\n\t\t\t\t\t\t\t\tif (closeButton) {\r\n\t\t\t\t\t\t\t\t\tcloseButton.click();\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tthis._router.navigateByUrl('/checkout');\r\n\t\t\t\t\t} else{\r\n\t\t\t\t\t\tthis.redirect && this.redirectHome();\t\t\r\n\t\t\t\t\t}\r\n\t\t\t\t\t\r\n\t\t\t\t} else if (res == 'error') {\r\n\t\t\t\t\tthis._toastService.error('login-error')\r\n\t\t\t\t}\r\n\t\t\t\tthis.loading = false;\r\n\t\t\t},\r\n\t\t\t(err: any) => {\r\n\t\t\t\t// Manejo de error 401\r\n\t\t\t\tif (err?.status === 401) {\r\n\t\t\t\t\tthis._toastService.show('invalid-credentials');\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis._toastService.error('login-error');\r\n\t\t\t\t}\r\n\t\t\t\tthis.loading = false;\r\n\t\t\t}\r\n\t\t)\r\n\t}\r\n\t/**\r\n\t * Si el servicio de auth tiene configurado a donde volver, se ejecutar ese caso.\r\n\t * De lo contrario redirige al contenido de la variable `redirectTo`.\r\n\t */\r\n\tredirectHome(){\r\n        const resolverFunction = this._authService.getHomeResolver()\r\n        resolverFunction\r\n            ? resolverFunction()\r\n            : this._router.navigateByUrl(this.redirectTo)\r\n    }\r\n\r\n}\r\n","<div class=\"d-flex flex-column position-relative\">\r\n    <h1 class=\"right-line ff-ubuntu-light mb-4\"><span>Ingresar</span></h1>\r\n    <p class=\"ff-ubuntu-light font-sm pr-4 mb-4\">\r\n        Si ya estás registrado. Ingresa en tu cuenta con tu email y la\r\n        contraseña adecuada.\r\n    </p>\r\n    <div class=\"w-md-50 w-100 text-center\">\r\n        <form [formGroup]=\"loginForm()\" (submit)=\"login($event)\">\r\n            <input class=\"form-control mb-4 radius-0\" type=\"email\" formControlName=\"username\"\r\n                placeholder=\"Correo Electrónico\">\r\n            <input class=\"form-control mb-4 radius-0\" type=\"password\" formControlName=\"password\"\r\n                placeholder=\"Contraseña\">\r\n\r\n            <div class=\"row d-flex flex-column\">\r\n                <div class=\"col-12 mb-4\">\r\n                    <button type=\"submit\"\r\n                        class=\"bg-gray border-0 px-4 py-2 color-white ff-ubuntu-light\">INGRESAR</button>\r\n                </div>\r\n                <div class=\"col-12 d-flex justify-content-center align-items-center\">\r\n                    <a [routerLink]=\"'/auth/forgot-password'\" class=\"font-md ff-ubuntu-light\">\r\n                        ¿Olvidó su contraseña?\r\n                    </a>\r\n                </div>\r\n            </div>\r\n        </form>\r\n    </div>\r\n    @if(loading){\r\n    <app-loading-section-ec></app-loading-section-ec>\r\n    }\r\n</div>"]}
|
|
@@ -13,7 +13,6 @@ export class RegisterFormEcComponent {
|
|
|
13
13
|
_analyticsService = inject(AnalyticsService);
|
|
14
14
|
_formBuilder = inject(FormBuilder);
|
|
15
15
|
channelConfigService = inject(ChannelService);
|
|
16
|
-
showPassword = false;
|
|
17
16
|
/**
|
|
18
17
|
* Indica si debe redireccionar o se queda en la misma pantalla
|
|
19
18
|
*/
|
|
@@ -129,9 +128,6 @@ export class RegisterFormEcComponent {
|
|
|
129
128
|
this.register_loading = false;
|
|
130
129
|
}
|
|
131
130
|
}
|
|
132
|
-
togglePassword() {
|
|
133
|
-
this.showPassword = !this.showPassword;
|
|
134
|
-
}
|
|
135
131
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RegisterFormEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
136
132
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: RegisterFormEcComponent, isStandalone: true, selector: "app-register-form-ec", inputs: { redirect: "redirect" }, outputs: { ready: "ready" }, ngImport: i0, template: "<div class=\"w-100 pl-md-5 position-relative\" id=\"register\">\r\n <div class=\"py-2\">\r\n <h5>CREAR CUENTA</h5>\r\n </div>\r\n <form id=\"registro\" [formGroup]=\"registerForm\" (submit)=\"register($event)\">\r\n <div class=\"form-group\">\r\n <label for=\"\" class=\"form-label\">NOMBRE</label>\r\n <input formControlName=\"firstName\" class=\"form-control rounded-0\" type=\"text\" placeholder=\"Nombre\">\r\n </div>\r\n <div class=\"form-group\">\r\n <label for=\"\" class=\"form-label\">APELLIDO</label>\r\n <input formControlName=\"lastName\" class=\"form-control rounded-0\" type=\"text\" placeholder=\"Apellido\">\r\n </div>\r\n <div class=\"form-group\">\r\n <label for=\"\" class=\"\">CORREO ELECTRONICO</label>\r\n <input formControlName=\"email\" email required class=\"form-control rounded-0\" type=\"email\"\r\n placeholder=\"Correo electr\u00F3nico\">\r\n </div>\r\n <div class=\"form-group\">\r\n <label for=\"\" class=\"form-label\">CONTRASE\u00D1A</label>\r\n <input formControlName=\"plainPassword\" required class=\"form-control rounded-0\" type=\"password\"\r\n placeholder=\"Contrase\u00F1a\">\r\n </div>\r\n <div class=\"form-group\">\r\n <label for=\"\" class=\"form-label\">REPETIR CONTRASE\u00D1A</label>\r\n <input formControlName=\"plainPassword2\" required class=\"form-control rounded-0\" type=\"password\"\r\n placeholder=\"Repetir contrase\u00F1a\">\r\n </div>\r\n\r\n <div class=\"custom-control d-flex flex-row form-check custom-checkbox mr-sm-2 mt-4 mb-2\">\r\n <input type=\"checkbox\" formControlName=\"terms\" required class=\"custom-control-input form-check-input\" name=\"Color2\"\r\n id=\"Color2\">\r\n <label class=\"custom-control-label ff-ubuntu-light font-sm form-check-label\" for=\"Color2\"> He\r\n le\u00EDdo y acepto las pol\u00EDticas de privacidad y los t\u00E9rminos y\r\n condiciones</label>\r\n </div>\r\n\r\n <div class=\"custom-control d-flex flex-row form-check custom-checkbox mr-sm-2 mb-4\">\r\n <input type=\"checkbox\" formControlName=\"newsletter\" class=\"custom-control-input form-check-input\" name=\"Color3\" id=\"Color3\">\r\n <label class=\"custom-control-label form-check-label ff-ubuntu-light font-sm\" for=\"Color3\">\r\n Suscripci\u00F3n al Newsletter</label>\r\n </div>\r\n\r\n <div class=\"row\">\r\n <div class=\"col-12\">\r\n <button [disabled]=\"registerForm.invalid\" type=\"submit\"\r\n class=\"btn btn-primary px-5 py-2 h-fit\">CREAR</button>\r\n </div>\r\n </div>\r\n </form>\r\n @if(loading){\r\n <app-loading-section-ec />\r\n }\r\n \r\n</div>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.CheckboxRequiredValidator, selector: "input[type=checkbox][required][formControlName],input[type=checkbox][required][formControl],input[type=checkbox][required][ngModel]" }, { kind: "directive", type: i1.EmailValidator, selector: "[email][formControlName],[email][formControl],[email][ngModel]", inputs: ["email"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: LoadingSectionEcComponent, selector: "app-loading-section-ec" }] });
|
|
137
133
|
}
|
|
@@ -143,4 +139,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
143
139
|
}], ready: [{
|
|
144
140
|
type: Output
|
|
145
141
|
}] } });
|
|
146
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register-form-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/auth-ec/register-form-ec/register-form-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/auth-ec/register-form-ec/register-form-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, inject, Input, OnInit, Output, signal } from '@angular/core';\r\nimport { AnalyticsService, AuthService, ToastService } from '../../../ec-services';\r\nimport { Router } from '@angular/router';\r\nimport { FormBuilder, FormGroup, ReactiveFormsModule, Validators } from '@angular/forms';\r\nimport { LoadingSectionEcComponent } from \"../../widgets-ec/loading\";\r\nimport { firstValueFrom } from 'rxjs';\r\nimport { ChannelService } from '../../../ec-services';\r\n\r\n@Component({\r\n\tselector: 'app-register-form-ec',\r\n\tstandalone: true,\r\n\timports: [ReactiveFormsModule, LoadingSectionEcComponent],\r\n\ttemplateUrl: './register-form-ec.component.html',\r\n\tstyleUrls: ['./register-form-ec.component.scss']\r\n})\r\nexport class RegisterFormEcComponent {\r\n\tprivate _authService: AuthService = inject(AuthService);\r\n\tprivate _toastService: ToastService = inject(ToastService);\r\n\tprivate _router: Router = inject(Router);\r\n\tprivate _analyticsService: AnalyticsService = inject(AnalyticsService);\r\n\tprivate _formBuilder: FormBuilder = inject(FormBuilder);\r\n\tprivate channelConfigService: ChannelService = inject(ChannelService);\r\n\tshowPassword = false;\r\n\r\n\t/**\r\n\t* Indica si debe redireccionar o se queda en la misma pantalla\r\n\t*/\r\n\t@Input() redirect: boolean = true;\r\n\t/**\r\n\t * Para que se puede capturar el estado de la petición de registro.\r\n\t */\r\n\t@Output() ready = new EventEmitter();\r\n\t/**\r\n\t * Contiene el formulario de registro.\r\n\t */\r\n\tpublic registerForm: FormGroup = this._formBuilder.group({\r\n\t\tfirstName: ['', Validators.required],\r\n\t\tlastName: ['', Validators.required],\r\n\t\temail: ['', [Validators.required, Validators.email]],\r\n\t\tplainPassword: ['', Validators.required],\r\n\t\tplainPassword2: ['', Validators.required],\r\n\t\tphone: ['',],\r\n\t\tnewsletter: [''],\r\n\t\tterms: ['', Validators.requiredTrue],\r\n\t}, { validators: this.passwordMatchValidator });\r\n\tregister_loading: boolean | undefined;\r\n\tpublic isAccountVerificationRequired = false;\r\n\tpublic isSendWelcomeEmail = false;\r\n\r\n\tpasswordMatchValidator(group: FormGroup) {\r\n\t\treturn group.get('plainPassword')?.value === group.get('plainPassword2')?.value\r\n\t\t\t? null : { mismatch: true };\r\n\t}\r\n\t/**\r\n\t * Para indicar que se esta procesando la solicitud de registro.\r\n\t */\r\n\tpublic loading: boolean = false;\r\n\t/**\r\n\t * Para indicar el exito de la solicitud de registro.\r\n\t */\r\n\tpublic success: boolean = false;\r\n\r\n\tconstructor() {\r\n\t\tthis.channelConfigService.channel$.subscribe(\r\n\t\t\t(config) => {\r\n\t\t\t\tif (config && config.isAccountVerificationRequired !== undefined) {\r\n\t\t\t\t\tthis.isAccountVerificationRequired = config.isAccountVerificationRequired;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.isAccountVerificationRequired = false;\r\n\t\t\t\t}\r\n\t\t\t\tif (config && config.isSendWelcomeEmail !== undefined) {\r\n\t\t\t\t\tthis.isSendWelcomeEmail = config.isSendWelcomeEmail;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.isSendWelcomeEmail = false;\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t);\r\n\t}\r\n\t/**\r\n\t * Registra un usuario.\r\n\t * @param event \r\n\t * @returns \r\n\t */\r\n\tregister(event: Event) {\r\n\t\tevent.preventDefault();\r\n\t\tthis.loading = true;\r\n\t\t// console.log('registerForm', this.registerForm);\r\n\t\tif (!this.registerForm.valid) {\r\n\t\t\tthis._toastService.show('fields-incomplete');\r\n\t\t\tthis.loading = false\r\n\t\t\treturn;\r\n\t\t};\r\n\t\tif (this.registerForm.value.plainPassword != this.registerForm.value.plainPassword2) {\r\n\t\t\tthis._toastService.show('mismatched-password');\r\n\t\t\tthis.loading = false\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tif (this.registerForm.valid) {\r\n\t\t\tthis._authService.singUp(this.registerForm.value).toPromise().then(\r\n\t\t\t\tres => {\r\n\t\t\t\t\tthis.register_loading = false;\r\n\t\t\t\t\tlet messageKey: string;\r\n\t\t\t\t\tswitch (true) {\r\n\t\t\t\t\t\tcase this.isAccountVerificationRequired:\r\n\t\t\t\t\t\t\tmessageKey = 'register-ok';\r\n\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\tcase this.isSendWelcomeEmail:\r\n\t\t\t\t\t\t\tmessageKey = 'register-welcome';\r\n\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\tdefault:\r\n\t\t\t\t\t\t\tmessageKey = 'register-success';\r\n\t\t\t\t\t}\r\n\t\t\t\t\tthis._toastService.show(messageKey);\r\n\t\t\t\t\tthis._analyticsService.callEvent('sign_up', {\r\n\t\t\t\t\t\tfirstName: this.registerForm.value.firstName,\r\n\t\t\t\t\t\tlastName: this.registerForm.value.lastName,\r\n\t\t\t\t\t\temail: this.registerForm.value.email\r\n\t\t\t\t\t});\r\n\t\t\t\t\tthis.success = true;\r\n\t\t\t\t\tthis.ready.emit(true);\r\n\r\n\t\t\t\t\tif (messageKey !== 'register-ok' && this.redirect) {\r\n\t\t\t\t\t\tthis.registerForm.reset();\r\n\t\t\t\t\t}\r\n\t\t\t\t\tif (this.redirect) {\r\n\t\t\t\t\t\tthis._router.navigateByUrl('home');\r\n\t\t\t\t\t}\r\n\t\t\t\t},\r\n\t\t\t\terror => {\r\n\t\t\t\t\tthis.register_loading = false;\r\n\t\t\t\t\tif (error.status == 400) {\r\n\t\t\t\t\t\tthis._toastService.show('El email ingresado ya se encuentra registrado.');\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tthis._toastService.show('Error en el registro. Vuelva a intentarlo más tarde.');\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t\t} else {\r\n\t\t\tthis._toastService.show('invalid-form');\r\n\t\t\tthis.register_loading = false;\r\n\t\t}\r\n\t}\r\n\r\n\ttogglePassword() {\r\n\t\tthis.showPassword = !this.showPassword;\r\n\t}\r\n}\r\n","<div class=\"w-100 pl-md-5 position-relative\" id=\"register\">\r\n  <div class=\"py-2\">\r\n      <h5>CREAR CUENTA</h5>\r\n  </div>\r\n  <form id=\"registro\" [formGroup]=\"registerForm\" (submit)=\"register($event)\">\r\n      <div class=\"form-group\">\r\n          <label for=\"\" class=\"form-label\">NOMBRE</label>\r\n          <input formControlName=\"firstName\" class=\"form-control rounded-0\" type=\"text\" placeholder=\"Nombre\">\r\n      </div>\r\n      <div class=\"form-group\">\r\n          <label for=\"\" class=\"form-label\">APELLIDO</label>\r\n          <input formControlName=\"lastName\" class=\"form-control rounded-0\" type=\"text\" placeholder=\"Apellido\">\r\n      </div>\r\n      <div class=\"form-group\">\r\n          <label for=\"\" class=\"\">CORREO ELECTRONICO</label>\r\n          <input formControlName=\"email\" email required class=\"form-control rounded-0\" type=\"email\"\r\n              placeholder=\"Correo electrónico\">\r\n      </div>\r\n      <div class=\"form-group\">\r\n          <label for=\"\" class=\"form-label\">CONTRASEÑA</label>\r\n          <input formControlName=\"plainPassword\" required class=\"form-control rounded-0\" type=\"password\"\r\n              placeholder=\"Contraseña\">\r\n      </div>\r\n      <div class=\"form-group\">\r\n          <label for=\"\" class=\"form-label\">REPETIR CONTRASEÑA</label>\r\n          <input formControlName=\"plainPassword2\" required class=\"form-control rounded-0\" type=\"password\"\r\n              placeholder=\"Repetir contraseña\">\r\n      </div>\r\n\r\n      <div class=\"custom-control d-flex flex-row form-check custom-checkbox mr-sm-2 mt-4 mb-2\">\r\n          <input type=\"checkbox\" formControlName=\"terms\" required class=\"custom-control-input form-check-input\" name=\"Color2\"\r\n              id=\"Color2\">\r\n          <label class=\"custom-control-label ff-ubuntu-light font-sm form-check-label\" for=\"Color2\"> He\r\n              leído y acepto las políticas de privacidad y los términos y\r\n              condiciones</label>\r\n      </div>\r\n\r\n      <div class=\"custom-control d-flex flex-row form-check custom-checkbox mr-sm-2 mb-4\">\r\n          <input type=\"checkbox\" formControlName=\"newsletter\" class=\"custom-control-input form-check-input\" name=\"Color3\" id=\"Color3\">\r\n          <label class=\"custom-control-label form-check-label ff-ubuntu-light font-sm\" for=\"Color3\">\r\n              Suscripción al Newsletter</label>\r\n      </div>\r\n\r\n      <div class=\"row\">\r\n          <div class=\"col-12\">\r\n              <button [disabled]=\"registerForm.invalid\" type=\"submit\"\r\n                  class=\"btn btn-primary px-5 py-2 h-fit\">CREAR</button>\r\n          </div>\r\n      </div>\r\n  </form>\r\n  @if(loading){\r\n    <app-loading-section-ec />\r\n  }\r\n  \r\n</div>\r\n"]}
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register-form-ec.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/auth-ec/register-form-ec/register-form-ec.component.ts","../../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/auth-ec/register-form-ec/register-form-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, inject, Input, OnInit, Output, signal } from '@angular/core';\r\nimport { AnalyticsService, AuthService, ToastService } from '../../../ec-services';\r\nimport { Router } from '@angular/router';\r\nimport { FormBuilder, FormGroup, ReactiveFormsModule, Validators } from '@angular/forms';\r\nimport { LoadingSectionEcComponent } from \"../../widgets-ec/loading\";\r\nimport { firstValueFrom } from 'rxjs';\r\nimport { ChannelService } from '../../../ec-services';\r\n\r\n@Component({\r\n\tselector: 'app-register-form-ec',\r\n\tstandalone: true,\r\n\timports: [ReactiveFormsModule, LoadingSectionEcComponent],\r\n\ttemplateUrl: './register-form-ec.component.html',\r\n\tstyleUrls: ['./register-form-ec.component.scss']\r\n})\r\nexport class RegisterFormEcComponent {\r\n\tprivate _authService: AuthService = inject(AuthService);\r\n\tprivate _toastService: ToastService = inject(ToastService);\r\n\tprivate _router: Router = inject(Router);\r\n\tprivate _analyticsService: AnalyticsService = inject(AnalyticsService);\r\n\tprivate _formBuilder: FormBuilder = inject(FormBuilder);\r\n\tprivate channelConfigService: ChannelService = inject(ChannelService);\r\n\t/**\r\n\t* Indica si debe redireccionar o se queda en la misma pantalla\r\n\t*/\r\n\t@Input() redirect: boolean = true;\r\n\t/**\r\n\t * Para que se puede capturar el estado de la petición de registro.\r\n\t */\r\n\t@Output() ready = new EventEmitter();\r\n\t/**\r\n\t * Contiene el formulario de registro.\r\n\t */\r\n\tpublic registerForm: FormGroup = this._formBuilder.group({\r\n\t\tfirstName: ['', Validators.required],\r\n\t\tlastName: ['', Validators.required],\r\n\t\temail: ['', [Validators.required, Validators.email]],\r\n\t\tplainPassword: ['', Validators.required],\r\n\t\tplainPassword2: ['', Validators.required],\r\n\t\tphone: ['',],\r\n\t\tnewsletter: [''],\r\n\t\tterms: ['', Validators.requiredTrue],\r\n\t}, { validators: this.passwordMatchValidator });\r\n\tregister_loading: boolean | undefined;\r\n\tpublic isAccountVerificationRequired = false;\r\n\tpublic isSendWelcomeEmail = false;\r\n\r\n\tpasswordMatchValidator(group: FormGroup) {\r\n\t\treturn group.get('plainPassword')?.value === group.get('plainPassword2')?.value\r\n\t\t\t? null : { mismatch: true };\r\n\t}\r\n\t/**\r\n\t * Para indicar que se esta procesando la solicitud de registro.\r\n\t */\r\n\tpublic loading: boolean = false;\r\n\t/**\r\n\t * Para indicar el exito de la solicitud de registro.\r\n\t */\r\n\tpublic success: boolean = false;\r\n\r\n\tconstructor() {\r\n        this.channelConfigService.channel$.subscribe(\r\n            (config) => {\r\n                if (config && config.isAccountVerificationRequired !== undefined) {\r\n                    this.isAccountVerificationRequired = config.isAccountVerificationRequired;\r\n                } else {\r\n                    this.isAccountVerificationRequired = false;\r\n                }\r\n                if (config && config.isSendWelcomeEmail !== undefined) {\r\n                    this.isSendWelcomeEmail = config.isSendWelcomeEmail;\r\n                } else {\r\n                    this.isSendWelcomeEmail = false;\r\n                }\r\n            },\r\n        );\r\n\t}\r\n\t/**\r\n\t * Registra un usuario.\r\n\t * @param event \r\n\t * @returns \r\n\t */\r\n\tregister(event: Event) {\r\n\t\tevent.preventDefault();\r\n\t\tthis.loading = true;\r\n\t\t// console.log('registerForm', this.registerForm);\r\n\t\tif (!this.registerForm.valid) {\r\n\t\t\tthis._toastService.show('fields-incomplete');\r\n\t\t\tthis.loading = false\r\n\t\t\treturn;\r\n\t\t};\r\n\t\tif (this.registerForm.value.plainPassword != this.registerForm.value.plainPassword2) {\r\n\t\t\tthis._toastService.show('mismatched-password');\r\n\t\t\tthis.loading = false\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tif (this.registerForm.valid) {\r\n\t\t\tthis._authService.singUp(this.registerForm.value).toPromise().then(\r\n\t\t\t\tres => {\r\n\t\t\t\t\tthis.register_loading = false;\r\n\t\t\t\t\tlet messageKey: string;\r\n\t\t\t\t\tswitch (true) {\r\n\t\t\t\t\t\tcase this.isAccountVerificationRequired:\r\n\t\t\t\t\t\t\tmessageKey = 'register-ok';\r\n\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\tcase this.isSendWelcomeEmail:\r\n\t\t\t\t\t\t\tmessageKey = 'register-welcome';\r\n\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\tdefault:\r\n\t\t\t\t\t\t\tmessageKey = 'register-success';\r\n\t\t\t\t\t}\r\n\t\t\t\t\tthis._toastService.show(messageKey);\r\n\t\t\t\t\tthis._analyticsService.callEvent('sign_up', {\r\n\t\t\t\t\t\tfirstName: this.registerForm.value.firstName,\r\n\t\t\t\t\t\tlastName: this.registerForm.value.lastName,\r\n\t\t\t\t\t\temail: this.registerForm.value.email\r\n\t\t\t\t\t});\r\n\t\t\t\t\tthis.success = true;\r\n\t\t\t\t\tthis.ready.emit(true);\r\n\r\n\t\t\t\t\tif (messageKey !== 'register-ok' && this.redirect) {\r\n\t\t\t\t\t\tthis.registerForm.reset();\r\n\t\t\t\t\t}\r\n\t\t\t\t\tif (this.redirect) {\r\n\t\t\t\t\t\tthis._router.navigateByUrl('home');\r\n\t\t\t\t\t}\r\n\t\t\t\t},\r\n\t\t\t\terror => {\r\n\t\t\t\t\tthis.register_loading = false;\r\n\t\t\t\t\tif (error.status == 400) {\r\n\t\t\t\t\t\tthis._toastService.show('El email ingresado ya se encuentra registrado.');\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tthis._toastService.show('Error en el registro. Vuelva a intentarlo más tarde.');\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t\t} else {\r\n\t\t\tthis._toastService.show('invalid-form');\r\n\t\t\tthis.register_loading = false;\r\n\t\t}\r\n\t}\r\n\r\n}\r\n","<div class=\"w-100 pl-md-5 position-relative\" id=\"register\">\r\n  <div class=\"py-2\">\r\n      <h5>CREAR CUENTA</h5>\r\n  </div>\r\n  <form id=\"registro\" [formGroup]=\"registerForm\" (submit)=\"register($event)\">\r\n      <div class=\"form-group\">\r\n          <label for=\"\" class=\"form-label\">NOMBRE</label>\r\n          <input formControlName=\"firstName\" class=\"form-control rounded-0\" type=\"text\" placeholder=\"Nombre\">\r\n      </div>\r\n      <div class=\"form-group\">\r\n          <label for=\"\" class=\"form-label\">APELLIDO</label>\r\n          <input formControlName=\"lastName\" class=\"form-control rounded-0\" type=\"text\" placeholder=\"Apellido\">\r\n      </div>\r\n      <div class=\"form-group\">\r\n          <label for=\"\" class=\"\">CORREO ELECTRONICO</label>\r\n          <input formControlName=\"email\" email required class=\"form-control rounded-0\" type=\"email\"\r\n              placeholder=\"Correo electrónico\">\r\n      </div>\r\n      <div class=\"form-group\">\r\n          <label for=\"\" class=\"form-label\">CONTRASEÑA</label>\r\n          <input formControlName=\"plainPassword\" required class=\"form-control rounded-0\" type=\"password\"\r\n              placeholder=\"Contraseña\">\r\n      </div>\r\n      <div class=\"form-group\">\r\n          <label for=\"\" class=\"form-label\">REPETIR CONTRASEÑA</label>\r\n          <input formControlName=\"plainPassword2\" required class=\"form-control rounded-0\" type=\"password\"\r\n              placeholder=\"Repetir contraseña\">\r\n      </div>\r\n\r\n      <div class=\"custom-control d-flex flex-row form-check custom-checkbox mr-sm-2 mt-4 mb-2\">\r\n          <input type=\"checkbox\" formControlName=\"terms\" required class=\"custom-control-input form-check-input\" name=\"Color2\"\r\n              id=\"Color2\">\r\n          <label class=\"custom-control-label ff-ubuntu-light font-sm form-check-label\" for=\"Color2\"> He\r\n              leído y acepto las políticas de privacidad y los términos y\r\n              condiciones</label>\r\n      </div>\r\n\r\n      <div class=\"custom-control d-flex flex-row form-check custom-checkbox mr-sm-2 mb-4\">\r\n          <input type=\"checkbox\" formControlName=\"newsletter\" class=\"custom-control-input form-check-input\" name=\"Color3\" id=\"Color3\">\r\n          <label class=\"custom-control-label form-check-label ff-ubuntu-light font-sm\" for=\"Color3\">\r\n              Suscripción al Newsletter</label>\r\n      </div>\r\n\r\n      <div class=\"row\">\r\n          <div class=\"col-12\">\r\n              <button [disabled]=\"registerForm.invalid\" type=\"submit\"\r\n                  class=\"btn btn-primary px-5 py-2 h-fit\">CREAR</button>\r\n          </div>\r\n      </div>\r\n  </form>\r\n  @if(loading){\r\n    <app-loading-section-ec />\r\n  }\r\n  \r\n</div>\r\n"]}
|
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";
|
|
@@ -66,7 +66,7 @@ export class BlockProductsEcComponent extends BlockEcComponent {
|
|
|
66
66
|
* Permite personalización de las imágenes de las flechas mediante @Input.
|
|
67
67
|
*/
|
|
68
68
|
setupSwiperNavigation() {
|
|
69
|
-
if (this.meta?.styles?.carrousel !== false) {
|
|
69
|
+
if (this.meta?.styles?.carrousel !== false && isPlatformBrowser(this.platformId)) {
|
|
70
70
|
// Usar setTimeout para asegurar que el swiper esté inicializado
|
|
71
71
|
setTimeout(() => {
|
|
72
72
|
this.initializeSwiperWithCustomNavigation();
|
|
@@ -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 && isPlatformBrowser(this.platformId)) {\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>"]}
|