ng-easycommerce-v18 0.3.20-beta.2 → 0.3.21-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 -16
- package/esm2022/lib/classes/filters/attributes-filter.mjs +4 -74
- package/esm2022/lib/classes/filters/category-filter.mjs +26 -105
- package/esm2022/lib/classes/filters/filter-factory.mjs +3 -7
- package/esm2022/lib/classes/filters/price_range-filter.mjs +3 -3
- package/esm2022/lib/constants/core.constants.service.mjs +1 -12
- package/esm2022/lib/ec-components/collection-ec/collection-ec.component.mjs +17 -41
- package/esm2022/lib/ec-components/filters-ec/filters-ec.component.mjs +9 -42
- package/esm2022/lib/ec-components/header-ec/header-ec.component.mjs +5 -13
- package/esm2022/lib/ec-components/price-range-filter/price-range-filter.component.mjs +2 -13
- package/esm2022/lib/ec-components/widgets-ec/redsys-catch-ec/redsys-catch-ec.component.mjs +17 -7
- package/esm2022/lib/ec-services/filters.service.mjs +18 -124
- package/esm2022/lib/ec-services/pagination.service.mjs +22 -70
- package/esm2022/lib/ec-services/products.service.mjs +3 -5
- package/fesm2022/ng-easycommerce-v18.mjs +113 -497
- package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
- package/lib/classes/filters/attributes-filter.d.ts +0 -24
- package/lib/classes/filters/category-filter.d.ts +3 -30
- package/lib/constants/core.constants.service.d.ts +0 -7
- package/lib/ec-components/collection-ec/collection-ec.component.d.ts +4 -5
- package/lib/ec-components/filters-ec/filters-ec.component.d.ts +0 -13
- package/lib/ec-components/price-range-filter/price-range-filter.component.d.ts +0 -2
- package/lib/ec-services/filters.service.d.ts +1 -18
- package/lib/ec-services/pagination.service.d.ts +5 -21
- package/lib/ec-services/products.service.d.ts +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -1,19 +1,5 @@
|
|
|
1
|
-
# Version 0.3.
|
|
2
|
-
-
|
|
3
|
-
- Unificación del flujo de filtrado: ahora toda la lógica se basa en URL (params + queryParams) y se hidrata desde `FiltersService.hydrateFromRoute()`.
|
|
4
|
-
- Se optimiza el runtime inicial para evitar ciclos innecesarios y cargar filtros antes del primer render.
|
|
5
|
-
- Se centraliza la sincronización de rangos de precio (filters ↔ pagination ↔ products).
|
|
6
|
-
# Version 0.3.17-beta.4
|
|
7
|
-
- Se agrega if platformID en mas archivos para que no de error al navegar elden.
|
|
8
|
-
# Version 0.3.17-beta.2
|
|
9
|
-
- Ya estaba contemplado isVisible en el componente `menu-ec.component`, pero se adapto para que devuelva solo las categorias, atributos y secciones visibles y no tener que filtrarlos en el frontend.
|
|
10
|
-
# Version 0.3.17-beta.1
|
|
11
|
-
- Se agrego el isVisible de las categorias a su interfaz
|
|
12
|
-
# Version 0.3.18-beta.2
|
|
13
|
-
- Se optimizar y comenta codigo para que el runtime no sea un bucle y se haga antes de la primera carga
|
|
14
|
-
# Version 0.3.18-beta.1
|
|
15
|
-
- Se modifican servicios y componentes para que funcione el deploy SSR.
|
|
16
|
-
- Se elimina uso de DOM ya que en SSR tira error.
|
|
1
|
+
# Version 0.3.21-beta.1
|
|
2
|
+
- Mejora en el flujo de pago con Mercado Pago en dispositivos móviles: se agrega fallback de redirección cuando `window.close()` es ignorado, asegurando que la pantalla de resultado no quede bloqueada en el catch.
|
|
17
3
|
# Version 0.3.17
|
|
18
4
|
- En el `header-ec.component.ts` se hacen public algunos injectores para poder usarlo en el `header.component.ts` de los frontends.
|
|
19
5
|
# Version 0.3.16
|
|
@@ -1,16 +1,10 @@
|
|
|
1
1
|
import { inject } from "@angular/core";
|
|
2
2
|
import { OptionsService } from "../../ec-services";
|
|
3
3
|
import { Filter } from "./filter";
|
|
4
|
-
/**
|
|
5
|
-
* AttributesFilter
|
|
6
|
-
* - Gestiona el filtro de atributos (estructura de padres/children).
|
|
7
|
-
* - Soporta hidratación desde query params y aplicación de códigos seleccionados.
|
|
8
|
-
*/
|
|
9
4
|
export class AttributesFilter extends Filter {
|
|
10
5
|
_optionsService = inject(OptionsService);
|
|
11
6
|
data = [];
|
|
12
7
|
multi = false;
|
|
13
|
-
_codesFromQuery = null;
|
|
14
8
|
constructor(initialValue, options) {
|
|
15
9
|
super();
|
|
16
10
|
if (options) {
|
|
@@ -18,6 +12,7 @@ export class AttributesFilter extends Filter {
|
|
|
18
12
|
}
|
|
19
13
|
else {
|
|
20
14
|
this._optionsService.getAttributes().subscribe(res => {
|
|
15
|
+
//console.log(res);
|
|
21
16
|
this.setContent(res, initialValue);
|
|
22
17
|
});
|
|
23
18
|
}
|
|
@@ -27,18 +22,10 @@ export class AttributesFilter extends Filter {
|
|
|
27
22
|
const attributes = this._optionsService.generateMenu(options);
|
|
28
23
|
attributes.forEach((filter) => filter = this.createElement(filter, options, initialValue));
|
|
29
24
|
this.data = attributes;
|
|
30
|
-
// Si ya teníamos códigos de la URL guardados, aplicarlos ahora
|
|
31
|
-
if (this._codesFromQuery && this._codesFromQuery.length) {
|
|
32
|
-
// ADDED: Aplicar códigos guardados tras cargar la data.
|
|
33
|
-
this.applyCodes(this._codesFromQuery);
|
|
34
|
-
}
|
|
35
25
|
}
|
|
36
26
|
getContent() {
|
|
37
27
|
return this.data;
|
|
38
28
|
}
|
|
39
|
-
/**
|
|
40
|
-
* ADDED: toUrlParams construye la porción de query string que representa las selecciones de atributos.
|
|
41
|
-
*/
|
|
42
29
|
toUrlParams(actual_url = '&attributeCodes=', sublist, already) {
|
|
43
30
|
let elements = sublist || this.data;
|
|
44
31
|
let aux_url = '';
|
|
@@ -60,14 +47,12 @@ export class AttributesFilter extends Filter {
|
|
|
60
47
|
}
|
|
61
48
|
}
|
|
62
49
|
});
|
|
50
|
+
//console.log(actual_url + aux_url);
|
|
63
51
|
return actual_url + aux_url;
|
|
64
52
|
}
|
|
65
53
|
;
|
|
66
54
|
cleanResult(text) { return text.replace('&attributeCodes=', ''); }
|
|
67
55
|
;
|
|
68
|
-
/**
|
|
69
|
-
* ADDED: createElement transforma cada nodo original en FilterElement y marca selección inicial si corresponde.
|
|
70
|
-
*/
|
|
71
56
|
createElement(filter, original, initialValue) {
|
|
72
57
|
if (filter.type == 'sub') {
|
|
73
58
|
filter.multi = false;
|
|
@@ -80,64 +65,9 @@ export class AttributesFilter extends Filter {
|
|
|
80
65
|
else {
|
|
81
66
|
filter.value = original.code;
|
|
82
67
|
filter.multi = false;
|
|
83
|
-
filter.selected = (initialValue &&
|
|
84
|
-
this.removeAccents(original.slug?.toLowerCase()) === this.removeAccents(initialValue?.toLowerCase()));
|
|
68
|
+
filter.selected = (initialValue && this.removeAccents(original.slug?.toLowerCase()) == this.removeAccents(initialValue?.toLowerCase()));
|
|
85
69
|
}
|
|
86
70
|
return filter;
|
|
87
71
|
}
|
|
88
|
-
/** hidratar desde la URL */
|
|
89
|
-
hydrateFromQuery(params) {
|
|
90
|
-
const raw = params['attributeCodes'];
|
|
91
|
-
if (!raw) {
|
|
92
|
-
// nada en la URL → limpió filtro
|
|
93
|
-
this._codesFromQuery = null;
|
|
94
|
-
this.clearSelection();
|
|
95
|
-
return;
|
|
96
|
-
}
|
|
97
|
-
const codes = String(raw)
|
|
98
|
-
.split('<and>')
|
|
99
|
-
.map(c => c.trim())
|
|
100
|
-
.filter(Boolean);
|
|
101
|
-
if (!codes.length) {
|
|
102
|
-
this._codesFromQuery = null;
|
|
103
|
-
this.clearSelection();
|
|
104
|
-
return;
|
|
105
|
-
}
|
|
106
|
-
this._codesFromQuery = codes;
|
|
107
|
-
// Si ya tengo data cargada, aplico ahora;
|
|
108
|
-
// si no, se aplicará en setContent().
|
|
109
|
-
if (this.data && this.data.length) {
|
|
110
|
-
// ADDED: Aplicar códigos inmediatamente porque la data ya está disponible.
|
|
111
|
-
this.applyCodes(codes);
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
/**
|
|
115
|
-
* ADDED: applyCodes recorre la estructura y marca selected=true en los children cuyo código está en 'codes'.
|
|
116
|
-
* Además marca el parent como seleccionado si alguno de sus hijos lo está.
|
|
117
|
-
*/
|
|
118
|
-
applyCodes(codes) {
|
|
119
|
-
this.data?.forEach((parent) => {
|
|
120
|
-
parent.selected = false;
|
|
121
|
-
(parent.children || []).forEach((child) => {
|
|
122
|
-
const code = child.code || child.value;
|
|
123
|
-
const isSelected = codes.includes(code);
|
|
124
|
-
child.selected = isSelected;
|
|
125
|
-
if (isSelected) {
|
|
126
|
-
parent.selected = true;
|
|
127
|
-
}
|
|
128
|
-
});
|
|
129
|
-
});
|
|
130
|
-
}
|
|
131
|
-
/**
|
|
132
|
-
* ADDED: clearSelection desmarca todos los parents y children (restablece el filtro).
|
|
133
|
-
*/
|
|
134
|
-
clearSelection() {
|
|
135
|
-
this.data?.forEach((parent) => {
|
|
136
|
-
parent.selected = false;
|
|
137
|
-
(parent.children || []).forEach((child) => {
|
|
138
|
-
child.selected = false;
|
|
139
|
-
});
|
|
140
|
-
});
|
|
141
|
-
}
|
|
142
72
|
}
|
|
143
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attributes-filter.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/classes/filters/attributes-filter.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject } from \"@angular/core\";\nimport { OptionsService } from \"../../ec-services\";\nimport { FilterElement, FilterType, IFilter } from \"../../interfaces\";\nimport { Filter } from \"./filter\";\nimport { Params } from \"@angular/router\";\n\n/**\n * AttributesFilter\n * - Gestiona el filtro de atributos (estructura de padres/children).\n * - Soporta hidratación desde query params y aplicación de códigos seleccionados.\n */\nexport class AttributesFilter extends Filter {\n    private _optionsService: OptionsService = inject(OptionsService);\n\n    override data: FilterElement[] = [];\n    override multi: boolean = false;\n\n    private _codesFromQuery: string[] | null = null;\n\n    constructor(initialValue?: any, options?: any) {\n        super();\n        if (options) {\n            this.setContent(options, initialValue);\n        } else {\n            this._optionsService.getAttributes().subscribe(\n                res => {\n                    this.setContent(res, initialValue);\n                }\n            )\n        }\n    }\n\n    override type(): FilterType { return 'attributes'; }\n\n    override setContent(options: any, initialValue?: any): void {\n        const attributes = this._optionsService.generateMenu(options);\n        attributes.forEach((filter: any) => filter = this.createElement(filter, options, initialValue));\n        this.data = attributes;\n\n        // Si ya teníamos códigos de la URL guardados, aplicarlos ahora\n        if (this._codesFromQuery && this._codesFromQuery.length) {\n            // ADDED: Aplicar códigos guardados tras cargar la data.\n            this.applyCodes(this._codesFromQuery);\n        }\n    }\n    override getContent(): FilterElement[] {\n        return this.data;\n    }\n    /**\n     * ADDED: toUrlParams construye la porción de query string que representa las selecciones de atributos.\n     */\n    override toUrlParams(actual_url = '&attributeCodes=', sublist?: any, already?: any) {\n        let elements = sublist || this.data;\n        let aux_url = '';\n        elements.forEach((element: any) => {\n            if (element.type == 'sub') {\n                let result = this.toUrlParams('', element.children, (actual_url != '&attributeCodes=' && actual_url != ''))\n                if (!actual_url.includes(result)) actual_url += this.cleanResult(result);\n            } else if (element.selected) {\n                if (actual_url == '&attributeCodes=' && aux_url == '') {\n                    aux_url = element.code;\n                }\n                else {\n                    if (aux_url == '') aux_url = (already ? '<and>' : '') + element.code;\n                    else aux_url += ('<and>' + element.code);\n                }\n            }\n        })\n        return actual_url + aux_url;\n    };\n\n    cleanResult(text: string) { return text.replace('&attributeCodes=', '') };\n\n    /**\n     * ADDED: createElement transforma cada nodo original en FilterElement y marca selección inicial si corresponde.\n     */\n    override createElement(filter: any, original: any, initialValue?: any) {\n        if (filter.type == 'sub') {\n            filter.multi = false;\n            filter.shape = 'text';\n            filter.value = original.code;\n            filter.children = filter.children.map((child: any, i: number) => {\n                return this.createElement(child, child.children, initialValue)\n            });\n        } else {\n            filter.value = original.code;\n            filter.multi = false;\n            filter.selected = (\n                initialValue &&\n                this.removeAccents(original.slug?.toLowerCase()) === this.removeAccents(initialValue?.toLowerCase())\n            );\n        }\n        return filter;\n    }\n\n    /** hidratar desde la URL */\n    hydrateFromQuery(params: Params): void {\n        const raw = params['attributeCodes'];\n\n        if (!raw) {\n            // nada en la URL → limpió filtro\n            this._codesFromQuery = null;\n            this.clearSelection();\n            return;\n        }\n\n        const codes = String(raw)\n            .split('<and>')\n            .map(c => c.trim())\n            .filter(Boolean);\n\n        if (!codes.length) {\n            this._codesFromQuery = null;\n            this.clearSelection();\n            return;\n        }\n\n        this._codesFromQuery = codes;\n\n        // Si ya tengo data cargada, aplico ahora;\n        // si no, se aplicará en setContent().\n        if (this.data && this.data.length) {\n            // ADDED: Aplicar códigos inmediatamente porque la data ya está disponible.\n            this.applyCodes(codes);\n        }\n    }\n\n    /**\n     * ADDED: applyCodes recorre la estructura y marca selected=true en los children cuyo código está en 'codes'.\n     * Además marca el parent como seleccionado si alguno de sus hijos lo está.\n     */\n    private applyCodes(codes: string[]): void {\n        this.data?.forEach((parent: any) => {\n            parent.selected = false;\n            (parent.children || []).forEach((child: any) => {\n                const code = child.code || child.value;\n                const isSelected = codes.includes(code);\n                child.selected = isSelected;\n                if (isSelected) {\n                    parent.selected = true;\n                }\n            });\n        });\n    }\n\n    /**\n     * ADDED: clearSelection desmarca todos los parents y children (restablece el filtro).\n     */\n    private clearSelection(): void {\n        this.data?.forEach((parent: any) => {\n            parent.selected = false;\n            (parent.children || []).forEach((child: any) => {\n                child.selected = false;\n            });\n        });\n    }\n}\n"]}
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXR0cmlidXRlcy1maWx0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lYXN5Y29tbWVyY2UtdjE4L3NyYy9saWIvY2xhc3Nlcy9maWx0ZXJzL2F0dHJpYnV0ZXMtZmlsdGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRW5ELE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFFbEMsTUFBTSxPQUFPLGdCQUFpQixTQUFRLE1BQU07SUFDaEMsZUFBZSxHQUFtQixNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7SUFFeEQsSUFBSSxHQUFvQixFQUFFLENBQUM7SUFDM0IsS0FBSyxHQUFZLEtBQUssQ0FBQztJQUVoQyxZQUFZLFlBQWtCLEVBQUUsT0FBWTtRQUN4QyxLQUFLLEVBQUUsQ0FBQztRQUNSLElBQUcsT0FBTyxFQUFDLENBQUM7WUFDUixJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sRUFBRSxZQUFZLENBQUMsQ0FBQztRQUMzQyxDQUFDO2FBQUksQ0FBQztZQUNGLElBQUksQ0FBQyxlQUFlLENBQUMsYUFBYSxFQUFFLENBQUMsU0FBUyxDQUMxQyxHQUFHLENBQUMsRUFBRTtnQkFDRixtQkFBbUI7Z0JBQ25CLElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxFQUFFLFlBQVksQ0FBQyxDQUFDO1lBQ3ZDLENBQUMsQ0FDSixDQUFBO1FBQ0wsQ0FBQztJQUNMLENBQUM7SUFFUSxJQUFJLEtBQWlCLE9BQU8sWUFBWSxDQUFDLENBQUMsQ0FBQztJQUUzQyxVQUFVLENBQUMsT0FBWSxFQUFFLFlBQWtCO1FBQ2hELE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzlELFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFXLEVBQUUsRUFBRSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sRUFBRSxPQUFPLEVBQUUsWUFBWSxDQUFDLENBQUMsQ0FBQztRQUNoRyxJQUFJLENBQUMsSUFBSSxHQUFHLFVBQVUsQ0FBQztJQUMzQixDQUFDO0lBQ1EsVUFBVTtRQUNmLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQztJQUNyQixDQUFDO0lBQ1EsV0FBVyxDQUFDLFVBQVUsR0FBRyxrQkFBa0IsRUFBRSxPQUFZLEVBQUUsT0FBWTtRQUM1RSxJQUFJLFFBQVEsR0FBRyxPQUFPLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQztRQUNwQyxJQUFJLE9BQU8sR0FBRyxFQUFFLENBQUM7UUFDakIsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLE9BQVksRUFBRSxFQUFFO1lBQzlCLElBQUksT0FBTyxDQUFDLElBQUksSUFBSSxLQUFLLEVBQUUsQ0FBQztnQkFDeEIsSUFBSSxNQUFNLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxFQUFFLEVBQUUsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDLFVBQVUsSUFBSSxrQkFBa0IsSUFBSSxVQUFVLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQTtnQkFDM0csSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDO29CQUFFLFVBQVUsSUFBSSxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQzdFLENBQUM7aUJBQU0sSUFBSSxPQUFPLENBQUMsUUFBUSxFQUFFLENBQUM7Z0JBQzFCLElBQUksVUFBVSxJQUFJLGtCQUFrQixJQUFJLE9BQU8sSUFBSSxFQUFFLEVBQUUsQ0FBQztvQkFDcEQsT0FBTyxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUM7Z0JBQzNCLENBQUM7cUJBQ0ksQ0FBQztvQkFDRixJQUFJLE9BQU8sSUFBSSxFQUFFO3dCQUFFLE9BQU8sR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDOzt3QkFDaEUsT0FBTyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDN0MsQ0FBQztZQUNMLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQTtRQUNGLG9DQUFvQztRQUNwQyxPQUFPLFVBQVUsR0FBRyxPQUFPLENBQUM7SUFDaEMsQ0FBQztJQUFBLENBQUM7SUFFRixXQUFXLENBQUMsSUFBWSxJQUFJLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxrQkFBa0IsRUFBRSxFQUFFLENBQUMsQ0FBQSxDQUFDLENBQUM7SUFBQSxDQUFDO0lBRWpFLGFBQWEsQ0FBQyxNQUFXLEVBQUUsUUFBYSxFQUFFLFlBQWtCO1FBQ2pFLElBQUksTUFBTSxDQUFDLElBQUksSUFBSSxLQUFLLEVBQUUsQ0FBQztZQUN2QixNQUFNLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztZQUNyQixNQUFNLENBQUMsS0FBSyxHQUFHLE1BQU0sQ0FBQztZQUN0QixNQUFNLENBQUMsS0FBSyxHQUFHLFFBQVEsQ0FBQyxJQUFJLENBQUM7WUFDN0IsTUFBTSxDQUFDLFFBQVEsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQVUsRUFBRSxDQUFTLEVBQUUsRUFBRTtnQkFDNUQsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsUUFBUSxFQUFFLFlBQVksQ0FBQyxDQUFBO1lBQ2xFLENBQUMsQ0FBQyxDQUFDO1FBQ1AsQ0FBQzthQUFNLENBQUM7WUFDSixNQUFNLENBQUMsS0FBSyxHQUFHLFFBQVEsQ0FBQyxJQUFJLENBQUM7WUFDN0IsTUFBTSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7WUFDckIsTUFBTSxDQUFDLFFBQVEsR0FBRyxDQUFDLFlBQVksSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsV0FBVyxFQUFFLENBQUMsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLFlBQVksRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDNUksQ0FBQztRQUNELE9BQU8sTUFBTSxDQUFDO0lBQ2xCLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBPcHRpb25zU2VydmljZSB9IGZyb20gXCIuLi8uLi9lYy1zZXJ2aWNlc1wiO1xuaW1wb3J0IHsgRmlsdGVyRWxlbWVudCwgRmlsdGVyVHlwZSwgSUZpbHRlciB9IGZyb20gXCIuLi8uLi9pbnRlcmZhY2VzXCI7XG5pbXBvcnQgeyBGaWx0ZXIgfSBmcm9tIFwiLi9maWx0ZXJcIjtcblxuZXhwb3J0IGNsYXNzIEF0dHJpYnV0ZXNGaWx0ZXIgZXh0ZW5kcyBGaWx0ZXIge1xuICAgIHByaXZhdGUgX29wdGlvbnNTZXJ2aWNlOiBPcHRpb25zU2VydmljZSA9IGluamVjdChPcHRpb25zU2VydmljZSk7XG5cbiAgICBvdmVycmlkZSBkYXRhOiBGaWx0ZXJFbGVtZW50W10gPSBbXTtcbiAgICBvdmVycmlkZSBtdWx0aTogYm9vbGVhbiA9IGZhbHNlO1xuXG4gICAgY29uc3RydWN0b3IoaW5pdGlhbFZhbHVlPzogYW55LCBvcHRpb25zPzphbnkpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICAgICAgaWYob3B0aW9ucyl7XG4gICAgICAgICAgICB0aGlzLnNldENvbnRlbnQob3B0aW9ucywgaW5pdGlhbFZhbHVlKTsgXG4gICAgICAgIH1lbHNle1xuICAgICAgICAgICAgdGhpcy5fb3B0aW9uc1NlcnZpY2UuZ2V0QXR0cmlidXRlcygpLnN1YnNjcmliZShcbiAgICAgICAgICAgICAgICByZXMgPT4ge1xuICAgICAgICAgICAgICAgICAgICAvL2NvbnNvbGUubG9nKHJlcyk7XG4gICAgICAgICAgICAgICAgICAgIHRoaXMuc2V0Q29udGVudChyZXMsIGluaXRpYWxWYWx1ZSk7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgKVxuICAgICAgICB9XG4gICAgfVxuXG4gICAgb3ZlcnJpZGUgdHlwZSgpOiBGaWx0ZXJUeXBlIHsgcmV0dXJuICdhdHRyaWJ1dGVzJzsgfVxuXG4gICAgb3ZlcnJpZGUgc2V0Q29udGVudChvcHRpb25zOiBhbnksIGluaXRpYWxWYWx1ZT86IGFueSk6IHZvaWQge1xuICAgICAgICBjb25zdCBhdHRyaWJ1dGVzID0gdGhpcy5fb3B0aW9uc1NlcnZpY2UuZ2VuZXJhdGVNZW51KG9wdGlvbnMpO1xuICAgICAgICBhdHRyaWJ1dGVzLmZvckVhY2goKGZpbHRlcjogYW55KSA9PiBmaWx0ZXIgPSB0aGlzLmNyZWF0ZUVsZW1lbnQoZmlsdGVyLCBvcHRpb25zLCBpbml0aWFsVmFsdWUpKTtcbiAgICAgICAgdGhpcy5kYXRhID0gYXR0cmlidXRlcztcbiAgICB9XG4gICAgb3ZlcnJpZGUgZ2V0Q29udGVudCgpOiBGaWx0ZXJFbGVtZW50W10ge1xuICAgICAgICByZXR1cm4gdGhpcy5kYXRhO1xuICAgIH1cbiAgICBvdmVycmlkZSB0b1VybFBhcmFtcyhhY3R1YWxfdXJsID0gJyZhdHRyaWJ1dGVDb2Rlcz0nLCBzdWJsaXN0PzphbnksIGFscmVhZHk/OmFueSkge1xuICAgICAgICBsZXQgZWxlbWVudHMgPSBzdWJsaXN0IHx8IHRoaXMuZGF0YTtcbiAgICAgICAgbGV0IGF1eF91cmwgPSAnJztcbiAgICAgICAgZWxlbWVudHMuZm9yRWFjaCgoZWxlbWVudDogYW55KSA9PiB7XG4gICAgICAgICAgICBpZiAoZWxlbWVudC50eXBlID09ICdzdWInKSB7XG4gICAgICAgICAgICAgICAgbGV0IHJlc3VsdCA9IHRoaXMudG9VcmxQYXJhbXMoJycsIGVsZW1lbnQuY2hpbGRyZW4sIChhY3R1YWxfdXJsICE9ICcmYXR0cmlidXRlQ29kZXM9JyAmJiBhY3R1YWxfdXJsICE9ICcnKSlcbiAgICAgICAgICAgICAgICBpZiAoIWFjdHVhbF91cmwuaW5jbHVkZXMocmVzdWx0KSkgYWN0dWFsX3VybCArPSB0aGlzLmNsZWFuUmVzdWx0KHJlc3VsdCk7XG4gICAgICAgICAgICB9IGVsc2UgaWYgKGVsZW1lbnQuc2VsZWN0ZWQpIHtcbiAgICAgICAgICAgICAgICBpZiAoYWN0dWFsX3VybCA9PSAnJmF0dHJpYnV0ZUNvZGVzPScgJiYgYXV4X3VybCA9PSAnJykge1xuICAgICAgICAgICAgICAgICAgICBhdXhfdXJsID0gZWxlbWVudC5jb2RlO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKGF1eF91cmwgPT0gJycpIGF1eF91cmwgPSAoYWxyZWFkeSA/ICc8YW5kPicgOiAnJykgKyBlbGVtZW50LmNvZGU7XG4gICAgICAgICAgICAgICAgICAgIGVsc2UgYXV4X3VybCArPSAoJzxhbmQ+JyArIGVsZW1lbnQuY29kZSk7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICB9KVxuICAgICAgICAvL2NvbnNvbGUubG9nKGFjdHVhbF91cmwgKyBhdXhfdXJsKTtcbiAgICAgICAgcmV0dXJuIGFjdHVhbF91cmwgKyBhdXhfdXJsO1xuICAgIH07XG5cbiAgICBjbGVhblJlc3VsdCh0ZXh0OiBzdHJpbmcpIHsgcmV0dXJuIHRleHQucmVwbGFjZSgnJmF0dHJpYnV0ZUNvZGVzPScsICcnKSB9O1xuXG4gICAgb3ZlcnJpZGUgY3JlYXRlRWxlbWVudChmaWx0ZXI6IGFueSwgb3JpZ2luYWw6IGFueSwgaW5pdGlhbFZhbHVlPzogYW55KSB7XG4gICAgICAgIGlmIChmaWx0ZXIudHlwZSA9PSAnc3ViJykge1xuICAgICAgICAgICAgZmlsdGVyLm11bHRpID0gZmFsc2U7XG4gICAgICAgICAgICBmaWx0ZXIuc2hhcGUgPSAndGV4dCc7XG4gICAgICAgICAgICBmaWx0ZXIudmFsdWUgPSBvcmlnaW5hbC5jb2RlO1xuICAgICAgICAgICAgZmlsdGVyLmNoaWxkcmVuID0gZmlsdGVyLmNoaWxkcmVuLm1hcCgoY2hpbGQ6IGFueSwgaTogbnVtYmVyKSA9PntcbiAgICAgICAgICAgICAgICByZXR1cm4gdGhpcy5jcmVhdGVFbGVtZW50KGNoaWxkLCBjaGlsZC5jaGlsZHJlbiwgaW5pdGlhbFZhbHVlKVxuICAgICAgICAgICAgfSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBmaWx0ZXIudmFsdWUgPSBvcmlnaW5hbC5jb2RlO1xuICAgICAgICAgICAgZmlsdGVyLm11bHRpID0gZmFsc2U7XG4gICAgICAgICAgICBmaWx0ZXIuc2VsZWN0ZWQgPSAoaW5pdGlhbFZhbHVlICYmIHRoaXMucmVtb3ZlQWNjZW50cyhvcmlnaW5hbC5zbHVnPy50b0xvd2VyQ2FzZSgpKSA9PSB0aGlzLnJlbW92ZUFjY2VudHMoaW5pdGlhbFZhbHVlPy50b0xvd2VyQ2FzZSgpKSk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGZpbHRlcjtcbiAgICB9XG59XG4iXX0=
|
|
@@ -1,24 +1,17 @@
|
|
|
1
1
|
import { inject } from "@angular/core";
|
|
2
|
-
import {
|
|
2
|
+
import { OptionsService } from "../../ec-services";
|
|
3
3
|
import { Filter } from "./filter";
|
|
4
|
-
/**
|
|
5
|
-
* CategoryFilter
|
|
6
|
-
* - Gestiona el filtro de categorías.
|
|
7
|
-
* - Mantiene la estructura de categorías (parents/children) y permite:
|
|
8
|
-
* * Inicializar desde OptionsService.
|
|
9
|
-
* * Marcar elementos según slug o query param.
|
|
10
|
-
* * Generar porción de query string (&category=...).
|
|
11
|
-
*/
|
|
12
4
|
export class CategoryFilter extends Filter {
|
|
5
|
+
initialValues;
|
|
13
6
|
_optionsService = inject(OptionsService);
|
|
14
|
-
_filtersService = inject(FiltersService);
|
|
15
7
|
data = [];
|
|
16
8
|
multi = false;
|
|
17
|
-
constructor(
|
|
9
|
+
constructor(initialValues) {
|
|
18
10
|
super();
|
|
11
|
+
this.initialValues = initialValues;
|
|
19
12
|
this._optionsService.getCategories().subscribe(res => {
|
|
20
|
-
|
|
21
|
-
this.
|
|
13
|
+
//console.log(res);
|
|
14
|
+
this.setContent(res, initialValues);
|
|
22
15
|
});
|
|
23
16
|
}
|
|
24
17
|
type() {
|
|
@@ -30,109 +23,37 @@ export class CategoryFilter extends Filter {
|
|
|
30
23
|
this.data = categories;
|
|
31
24
|
}
|
|
32
25
|
getContent() {
|
|
33
|
-
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
});
|
|
51
|
-
};
|
|
52
|
-
walk(this.data);
|
|
53
|
-
if (selectedCodes.length > 0) {
|
|
54
|
-
return `&category=${encodeURIComponent(selectedCodes[0])}`;
|
|
55
|
-
}
|
|
56
|
-
return '';
|
|
26
|
+
throw new Error("Method not implemented.");
|
|
27
|
+
}
|
|
28
|
+
toUrlParams(actual_url = '', sublist) {
|
|
29
|
+
let elements = sublist || this.data;
|
|
30
|
+
elements.forEach((element) => {
|
|
31
|
+
if (element.type == 'sub' && !element.selected) {
|
|
32
|
+
const result = this.toUrlParams('', element.children);
|
|
33
|
+
!actual_url.includes(result) ? actual_url += result : null;
|
|
34
|
+
}
|
|
35
|
+
else if (element.selected) {
|
|
36
|
+
if (actual_url == '')
|
|
37
|
+
actual_url = '&category=' + element.value;
|
|
38
|
+
else
|
|
39
|
+
actual_url = element.value;
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
return actual_url;
|
|
57
43
|
}
|
|
58
44
|
createElement(filter, original, initialValue) {
|
|
59
45
|
if (filter.type == 'sub') {
|
|
60
46
|
filter.multi = false;
|
|
61
47
|
filter.shape = 'text';
|
|
62
48
|
filter.value = original.code;
|
|
63
|
-
filter.selected = (initialValue &&
|
|
64
|
-
this.removeAccents(original.slug?.toLowerCase()) ===
|
|
65
|
-
this.removeAccents(String(initialValue).toLowerCase()));
|
|
49
|
+
filter.selected = (initialValue && this.removeAccents(original.slug?.toLowerCase()) == this.removeAccents(initialValue?.toLowerCase()));
|
|
66
50
|
filter.children = filter.children.map((child, i) => this.createElement(child, original.children[i], initialValue));
|
|
67
51
|
}
|
|
68
52
|
else {
|
|
69
53
|
filter.value = original.code;
|
|
70
|
-
filter.selected = (initialValue &&
|
|
71
|
-
this.removeAccents(original.slug?.toLowerCase()) ===
|
|
72
|
-
this.removeAccents(String(initialValue).toLowerCase()));
|
|
54
|
+
filter.selected = (initialValue && this.removeAccents(original.slug?.toLowerCase()) == this.removeAccents(initialValue?.toLowerCase()));
|
|
73
55
|
}
|
|
74
56
|
return filter;
|
|
75
57
|
}
|
|
76
|
-
/**
|
|
77
|
-
* setFromSlug
|
|
78
|
-
* - Marca como selected los nodos cuyo slug/path/name coincide con el slug proporcionado.
|
|
79
|
-
* - Utiliza removeAccents para comparar sin tildes y en minúsculas.
|
|
80
|
-
* - No retorna valor, solo modifica this.data.
|
|
81
|
-
*/
|
|
82
|
-
setFromSlug(slug) {
|
|
83
|
-
const target = this.removeAccents(String(slug).toLowerCase());
|
|
84
|
-
const walk = (nodes) => {
|
|
85
|
-
nodes.forEach(n => {
|
|
86
|
-
// ADDED: iniciar sin selección explícita (asegura estado consistente)
|
|
87
|
-
n.selected = false;
|
|
88
|
-
const candidates = [
|
|
89
|
-
n.slug,
|
|
90
|
-
n.path && String(n.path).split('/').filter(Boolean).pop(),
|
|
91
|
-
n.name
|
|
92
|
-
]
|
|
93
|
-
.filter(Boolean)
|
|
94
|
-
.map((s) => this.removeAccents(s.toLowerCase()));
|
|
95
|
-
if (candidates.includes(target)) {
|
|
96
|
-
n.selected = true;
|
|
97
|
-
}
|
|
98
|
-
if (Array.isArray(n.children) && n.children.length) {
|
|
99
|
-
walk(n.children);
|
|
100
|
-
}
|
|
101
|
-
});
|
|
102
|
-
};
|
|
103
|
-
walk(this.data);
|
|
104
|
-
}
|
|
105
|
-
/**
|
|
106
|
-
* hydrateFromQuery
|
|
107
|
-
* - Marca la categoría según el parámetro de query 'category' si existe.
|
|
108
|
-
* - Busca el code exacto en la estructura y marca el nodo correspondiente.
|
|
109
|
-
* - Loggea si se encontró o no la categoría.
|
|
110
|
-
*/
|
|
111
|
-
hydrateFromQuery(query) {
|
|
112
|
-
const raw = query?.['category'];
|
|
113
|
-
if (!raw)
|
|
114
|
-
return;
|
|
115
|
-
const code = String(raw).trim();
|
|
116
|
-
if (!code)
|
|
117
|
-
return;
|
|
118
|
-
const mark = (nodes) => {
|
|
119
|
-
let found = false;
|
|
120
|
-
nodes.forEach(n => {
|
|
121
|
-
if (n.code === code) {
|
|
122
|
-
n.selected = true;
|
|
123
|
-
found = true;
|
|
124
|
-
}
|
|
125
|
-
else {
|
|
126
|
-
n.selected = false;
|
|
127
|
-
}
|
|
128
|
-
if (Array.isArray(n.children) && n.children.length) {
|
|
129
|
-
if (mark(n.children))
|
|
130
|
-
found = true;
|
|
131
|
-
}
|
|
132
|
-
});
|
|
133
|
-
return found;
|
|
134
|
-
};
|
|
135
|
-
const ok = mark(this.data);
|
|
136
|
-
}
|
|
137
58
|
}
|
|
138
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"category-filter.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/classes/filters/category-filter.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject } from \"@angular/core\";\nimport { FiltersService, OptionsService } from \"../../ec-services\";\nimport { FilterElement, FilterType } from \"../../interfaces\";\nimport { Filter } from \"./filter\";\n\n/**\n * CategoryFilter\n * - Gestiona el filtro de categorías.\n * - Mantiene la estructura de categorías (parents/children) y permite:\n *   * Inicializar desde OptionsService.\n *   * Marcar elementos según slug o query param.\n *   * Generar porción de query string (&category=...).\n */\nexport class CategoryFilter extends Filter {\n    private _optionsService: OptionsService = inject(OptionsService);\n    private _filtersService: FiltersService = inject(FiltersService);\n\n    override data: FilterElement[] = [];\n    override multi: boolean = false;\n\n    constructor(initialValue?: any) {\n        super();\n\n        this._optionsService.getCategories().subscribe(res => {\n            this.setContent(res, initialValue);\n            this._filtersService.refreshFilters()\n        });\n    }\n\n    override type(): FilterType {\n        return 'categories';\n    }\n\n    override setContent(options: any, initialValue?: any): void {\n        const categories = this._optionsService.generateMenu(options);\n        categories.forEach((filter: any, i: number) =>\n            filter = this.createElement(filter, options[i], initialValue)\n        );\n        this.data = categories;\n    }\n\n    override getContent(): FilterElement[] {\n        return this.data;\n    }\n\n    /**\n     * toUrlParams\n     * - Recorre la estructura y devuelve la porción de query string para la categoría seleccionada.\n     * - Prioriza el primer selected encontrado (solo una categoría se envía).\n     */\n    override toUrlParams(): string {\n        const selectedCodes: string[] = [];\n\n        const walk = (nodes: any[]) => {\n            nodes.forEach(n => {\n                if (n.selected) {\n                    selectedCodes.push(n.code || n.value);\n                }\n                if (Array.isArray(n.children) && n.children.length) {\n                    walk(n.children);\n                }\n            });\n        };\n\n        walk(this.data);\n\n        if (selectedCodes.length > 0) {\n            return `&category=${encodeURIComponent(selectedCodes[0])}`;\n        }\n\n        return '';\n    }\n\n    override createElement(filter: any, original: any, initialValue?: any) {\n        if (filter.type == 'sub') {\n            filter.multi = false;\n            filter.shape = 'text';\n            filter.value = original.code;\n            filter.selected = (\n                initialValue &&\n                this.removeAccents(original.slug?.toLowerCase()) ===\n                this.removeAccents(String(initialValue).toLowerCase())\n            );\n            filter.children = filter.children.map(\n                (child: any, i: number) => this.createElement(child, original.children[i], initialValue)\n            );\n        } else {\n            filter.value = original.code;\n            filter.selected = (\n                initialValue &&\n                this.removeAccents(original.slug?.toLowerCase()) ===\n                this.removeAccents(String(initialValue).toLowerCase())\n            );\n        }\n        return filter;\n    }\n\n    /**\n     * setFromSlug\n     * - Marca como selected los nodos cuyo slug/path/name coincide con el slug proporcionado.\n     * - Utiliza removeAccents para comparar sin tildes y en minúsculas.\n     * - No retorna valor, solo modifica this.data.\n     */\n    setFromSlug(slug: string): void {\n        const target = this.removeAccents(String(slug).toLowerCase());\n\n        const walk = (nodes: any[]) => {\n            nodes.forEach(n => {\n                // ADDED: iniciar sin selección explícita (asegura estado consistente)\n                n.selected = false;\n                const candidates = [\n                    n.slug,\n                    n.path && String(n.path).split('/').filter(Boolean).pop(),\n                    n.name\n                ]\n                    .filter(Boolean)\n                    .map((s: string) => this.removeAccents(s.toLowerCase()));\n\n                if (candidates.includes(target)) {\n                    n.selected = true;\n                }\n\n                if (Array.isArray(n.children) && n.children.length) {\n                    walk(n.children);\n                }\n            });\n        };\n\n        walk(this.data);\n    }\n\n    /**\n     * hydrateFromQuery\n     * - Marca la categoría según el parámetro de query 'category' si existe.\n     * - Busca el code exacto en la estructura y marca el nodo correspondiente.\n     * - Loggea si se encontró o no la categoría.\n     */\n    hydrateFromQuery(query: any): void {\n        const raw = query?.['category'];\n        if (!raw) return;\n\n        const code = String(raw).trim();\n        if (!code) return;\n\n        const mark = (nodes: any[]): boolean => {\n            let found = false;\n            nodes.forEach(n => {\n                if (n.code === code) {\n                    n.selected = true;\n                    found = true;\n                } else {\n                    n.selected = false;\n                }\n                if (Array.isArray(n.children) && n.children.length) {\n                    if (mark(n.children)) found = true;\n                }\n            });\n            return found;\n        };\n\n        const ok = mark(this.data);\n    }\n}"]}
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0ZWdvcnktZmlsdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2NsYXNzZXMvZmlsdGVycy9jYXRlZ29yeS1maWx0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFbkQsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUVsQyxNQUFNLE9BQU8sY0FBZSxTQUFRLE1BQU07SUFNbEI7SUFMWixlQUFlLEdBQW1CLE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUV4RCxJQUFJLEdBQW9CLEVBQUUsQ0FBQztJQUMzQixLQUFLLEdBQVksS0FBSyxDQUFDO0lBRWhDLFlBQW9CLGFBQW1CO1FBQ25DLEtBQUssRUFBRSxDQUFDO1FBRFEsa0JBQWEsR0FBYixhQUFhLENBQU07UUFFbkMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxhQUFhLEVBQUUsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDakQsbUJBQW1CO1lBQ25CLElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxFQUFFLGFBQWEsQ0FBQyxDQUFDO1FBQ3hDLENBQUMsQ0FBQyxDQUFBO0lBQ04sQ0FBQztJQUVRLElBQUk7UUFDVCxPQUFPLFlBQVksQ0FBQztJQUN4QixDQUFDO0lBQ1EsVUFBVSxDQUFDLE9BQVksRUFBRSxZQUFrQjtRQUNoRCxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUM5RCxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUMsTUFBVyxFQUFFLENBQVMsRUFBRSxFQUFFLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxZQUFZLENBQUMsQ0FBQyxDQUFDO1FBQzlHLElBQUksQ0FBQyxJQUFJLEdBQUcsVUFBVSxDQUFDO0lBQzNCLENBQUM7SUFDUSxVQUFVO1FBQ2YsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQy9DLENBQUM7SUFDUSxXQUFXLENBQUMsVUFBVSxHQUFHLEVBQUUsRUFBRSxPQUFhO1FBQy9DLElBQUksUUFBUSxHQUFHLE9BQU8sSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDO1FBQ3BDLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxPQUFZLEVBQUUsRUFBRTtZQUM5QixJQUFJLE9BQU8sQ0FBQyxJQUFJLElBQUksS0FBSyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUM3QyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEVBQUUsRUFBRSxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUM7Z0JBQ3RELENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsVUFBVSxJQUFJLE1BQU0sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO1lBQy9ELENBQUM7aUJBQU0sSUFBSSxPQUFPLENBQUMsUUFBUSxFQUFFLENBQUM7Z0JBQzFCLElBQUksVUFBVSxJQUFJLEVBQUU7b0JBQUUsVUFBVSxHQUFHLFlBQVksR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDOztvQkFDM0QsVUFBVSxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUM7WUFDcEMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFBO1FBQ0YsT0FBTyxVQUFVLENBQUM7SUFDdEIsQ0FBQztJQUNRLGFBQWEsQ0FBQyxNQUFXLEVBQUUsUUFBYSxFQUFFLFlBQWtCO1FBQ2pFLElBQUksTUFBTSxDQUFDLElBQUksSUFBSSxLQUFLLEVBQUUsQ0FBQztZQUN2QixNQUFNLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztZQUNyQixNQUFNLENBQUMsS0FBSyxHQUFHLE1BQU0sQ0FBQztZQUN0QixNQUFNLENBQUMsS0FBSyxHQUFHLFFBQVEsQ0FBQyxJQUFJLENBQUM7WUFDN0IsTUFBTSxDQUFDLFFBQVEsR0FBRyxDQUFDLFlBQVksSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsV0FBVyxFQUFFLENBQUMsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLFlBQVksRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDeEksTUFBTSxDQUFDLFFBQVEsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQVMsRUFBRSxDQUFRLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsWUFBWSxDQUFDLENBQUMsQ0FBQztRQUNsSSxDQUFDO2FBQU0sQ0FBQztZQUNKLE1BQU0sQ0FBQyxLQUFLLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQztZQUM3QixNQUFNLENBQUMsUUFBUSxHQUFHLENBQUMsWUFBWSxJQUFJLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxXQUFXLEVBQUUsQ0FBQyxJQUFJLElBQUksQ0FBQyxhQUFhLENBQUMsWUFBWSxFQUFFLFdBQVcsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUM1SSxDQUFDO1FBQ0QsT0FBTyxNQUFNLENBQUE7SUFDakIsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW5qZWN0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IE9wdGlvbnNTZXJ2aWNlIH0gZnJvbSBcIi4uLy4uL2VjLXNlcnZpY2VzXCI7XG5pbXBvcnQgeyBGaWx0ZXJFbGVtZW50LCBGaWx0ZXJUeXBlLCBJRmlsdGVyIH0gZnJvbSBcIi4uLy4uL2ludGVyZmFjZXNcIjtcbmltcG9ydCB7IEZpbHRlciB9IGZyb20gXCIuL2ZpbHRlclwiO1xuXG5leHBvcnQgY2xhc3MgQ2F0ZWdvcnlGaWx0ZXIgZXh0ZW5kcyBGaWx0ZXJ7XG4gICAgcHJpdmF0ZSBfb3B0aW9uc1NlcnZpY2U6IE9wdGlvbnNTZXJ2aWNlID0gaW5qZWN0KE9wdGlvbnNTZXJ2aWNlKTtcblxuICAgIG92ZXJyaWRlIGRhdGE6IEZpbHRlckVsZW1lbnRbXSA9IFtdO1xuICAgIG92ZXJyaWRlIG11bHRpOiBib29sZWFuID0gZmFsc2U7XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGluaXRpYWxWYWx1ZXM/OiBhbnksKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgICAgIHRoaXMuX29wdGlvbnNTZXJ2aWNlLmdldENhdGVnb3JpZXMoKS5zdWJzY3JpYmUocmVzID0+IHtcbiAgICAgICAgICAgIC8vY29uc29sZS5sb2cocmVzKTtcbiAgICAgICAgICAgIHRoaXMuc2V0Q29udGVudChyZXMsIGluaXRpYWxWYWx1ZXMpO1xuICAgICAgICB9KVxuICAgIH1cblxuICAgIG92ZXJyaWRlIHR5cGUoKTogRmlsdGVyVHlwZSB7XG4gICAgICAgIHJldHVybiAnY2F0ZWdvcmllcyc7XG4gICAgfVxuICAgIG92ZXJyaWRlIHNldENvbnRlbnQob3B0aW9uczogYW55LCBpbml0aWFsVmFsdWU/OiBhbnkpOiB2b2lkIHtcbiAgICAgICAgY29uc3QgY2F0ZWdvcmllcyA9IHRoaXMuX29wdGlvbnNTZXJ2aWNlLmdlbmVyYXRlTWVudShvcHRpb25zKTtcbiAgICAgICAgY2F0ZWdvcmllcy5mb3JFYWNoKChmaWx0ZXI6IGFueSwgaTogbnVtYmVyKSA9PiBmaWx0ZXIgPSB0aGlzLmNyZWF0ZUVsZW1lbnQoZmlsdGVyLCBvcHRpb25zW2ldLCBpbml0aWFsVmFsdWUpKTtcbiAgICAgICAgdGhpcy5kYXRhID0gY2F0ZWdvcmllcztcbiAgICB9XG4gICAgb3ZlcnJpZGUgZ2V0Q29udGVudCgpOiBGaWx0ZXJFbGVtZW50W10ge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXCJNZXRob2Qgbm90IGltcGxlbWVudGVkLlwiKTtcbiAgICB9XG4gICAgb3ZlcnJpZGUgdG9VcmxQYXJhbXMoYWN0dWFsX3VybCA9ICcnLCBzdWJsaXN0PzogYW55KTogc3RyaW5nIHtcbiAgICAgICAgbGV0IGVsZW1lbnRzID0gc3VibGlzdCB8fCB0aGlzLmRhdGE7XG4gICAgICAgIGVsZW1lbnRzLmZvckVhY2goKGVsZW1lbnQ6IGFueSkgPT4ge1xuICAgICAgICAgICAgaWYgKGVsZW1lbnQudHlwZSA9PSAnc3ViJyAmJiAhZWxlbWVudC5zZWxlY3RlZCkge1xuICAgICAgICAgICAgICAgIGNvbnN0IHJlc3VsdCA9IHRoaXMudG9VcmxQYXJhbXMoJycsIGVsZW1lbnQuY2hpbGRyZW4pO1xuICAgICAgICAgICAgICAgICFhY3R1YWxfdXJsLmluY2x1ZGVzKHJlc3VsdCkgPyBhY3R1YWxfdXJsICs9IHJlc3VsdCA6IG51bGw7XG4gICAgICAgICAgICB9IGVsc2UgaWYgKGVsZW1lbnQuc2VsZWN0ZWQpIHtcbiAgICAgICAgICAgICAgICBpZiAoYWN0dWFsX3VybCA9PSAnJykgYWN0dWFsX3VybCA9ICcmY2F0ZWdvcnk9JyArIGVsZW1lbnQudmFsdWU7XG4gICAgICAgICAgICAgICAgZWxzZSBhY3R1YWxfdXJsID0gZWxlbWVudC52YWx1ZTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSlcbiAgICAgICAgcmV0dXJuIGFjdHVhbF91cmw7XG4gICAgfVxuICAgIG92ZXJyaWRlIGNyZWF0ZUVsZW1lbnQoZmlsdGVyOiBhbnksIG9yaWdpbmFsOiBhbnksIGluaXRpYWxWYWx1ZT86IGFueSkge1xuICAgICAgICBpZiAoZmlsdGVyLnR5cGUgPT0gJ3N1YicpIHtcbiAgICAgICAgICAgIGZpbHRlci5tdWx0aSA9IGZhbHNlO1xuICAgICAgICAgICAgZmlsdGVyLnNoYXBlID0gJ3RleHQnO1xuICAgICAgICAgICAgZmlsdGVyLnZhbHVlID0gb3JpZ2luYWwuY29kZTtcbiAgICAgICAgICAgIGZpbHRlci5zZWxlY3RlZCA9IChpbml0aWFsVmFsdWUgJiYgdGhpcy5yZW1vdmVBY2NlbnRzKG9yaWdpbmFsLnNsdWc/LnRvTG93ZXJDYXNlKCkpID09IHRoaXMucmVtb3ZlQWNjZW50cyhpbml0aWFsVmFsdWU/LnRvTG93ZXJDYXNlKCkpKTtcbiAgICAgICAgICAgIGZpbHRlci5jaGlsZHJlbiA9IGZpbHRlci5jaGlsZHJlbi5tYXAoKGNoaWxkOmFueSwgaTpudW1iZXIpID0+IHRoaXMuY3JlYXRlRWxlbWVudChjaGlsZCwgb3JpZ2luYWwuY2hpbGRyZW5baV0sIGluaXRpYWxWYWx1ZSkpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgZmlsdGVyLnZhbHVlID0gb3JpZ2luYWwuY29kZTtcbiAgICAgICAgICAgIGZpbHRlci5zZWxlY3RlZCA9IChpbml0aWFsVmFsdWUgJiYgdGhpcy5yZW1vdmVBY2NlbnRzKG9yaWdpbmFsLnNsdWc/LnRvTG93ZXJDYXNlKCkpID09IHRoaXMucmVtb3ZlQWNjZW50cyhpbml0aWFsVmFsdWU/LnRvTG93ZXJDYXNlKCkpKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gZmlsdGVyXG4gICAgfVxufVxuIl19
|
|
@@ -7,13 +7,9 @@ export class FilterFactory {
|
|
|
7
7
|
create(filterType, productsFilter) {
|
|
8
8
|
switch (filterType) {
|
|
9
9
|
case 'categories':
|
|
10
|
-
return new CategoryFilter(productsFilter
|
|
11
|
-
? productsFilter.value
|
|
12
|
-
: null);
|
|
10
|
+
return new CategoryFilter(productsFilter ? (productsFilter.type == 'categories' && productsFilter.value) : null);
|
|
13
11
|
case 'attributes':
|
|
14
|
-
return new AttributesFilter(productsFilter
|
|
15
|
-
? productsFilter.value
|
|
16
|
-
: null);
|
|
12
|
+
return new AttributesFilter(productsFilter ? (productsFilter.type == 'attributes' && productsFilter.value) : null);
|
|
17
13
|
case 'dynamics':
|
|
18
14
|
return new DynamicsFilter();
|
|
19
15
|
case 'sort':
|
|
@@ -26,4 +22,4 @@ export class FilterFactory {
|
|
|
26
22
|
}
|
|
27
23
|
}
|
|
28
24
|
}
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWZhY3RvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lYXN5Y29tbWVyY2UtdjE4L3NyYy9saWIvY2xhc3Nlcy9maWx0ZXJzL2ZpbHRlci1mYWN0b3J5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFbkQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUV4RCxNQUFNLE9BQU8sYUFBYTtJQUNmLE1BQU0sQ0FBQyxVQUFzQixFQUFFLGNBQW1DO1FBQ3JFLFFBQVEsVUFBVSxFQUFFLENBQUM7WUFDakIsS0FBSyxZQUFZO2dCQUNiLE9BQU8sSUFBSSxjQUFjLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxJQUFJLElBQUksWUFBWSxJQUFJLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDckgsS0FBSyxZQUFZO2dCQUNiLE9BQU8sSUFBSSxnQkFBZ0IsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLENBQUMsY0FBYyxDQUFDLElBQUksSUFBSSxZQUFZLElBQUksY0FBYyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUN2SCxLQUFLLFVBQVU7Z0JBQ1gsT0FBTyxJQUFJLGNBQWMsRUFBRSxDQUFDO1lBQ2hDLEtBQUssTUFBTTtnQkFDUCxPQUFPLElBQUksVUFBVSxFQUFFLENBQUM7WUFDNUIsS0FBSyxhQUFhO2dCQUNkLE9BQU8sSUFBSSxnQkFBZ0IsRUFBRSxDQUFDO1lBQ2xDO2dCQUNJLDREQUE0RDtnQkFDNUQsTUFBTSxJQUFJLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxDQUFBO1FBQzFDLENBQUM7SUFDTCxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGaWx0ZXJUeXBlLCBJRmlsdGVyLCBQYWdpbmF0aW9uU2V0dGluZ3MgfSBmcm9tIFwiLi4vLi4vaW50ZXJmYWNlc1wiO1xuaW1wb3J0IHsgQXR0cmlidXRlc0ZpbHRlciB9IGZyb20gXCIuL2F0dHJpYnV0ZXMtZmlsdGVyXCI7XG5pbXBvcnQgeyBDYXRlZ29yeUZpbHRlciB9IGZyb20gXCIuL2NhdGVnb3J5LWZpbHRlclwiO1xuaW1wb3J0IHsgRHluYW1pY3NGaWx0ZXIgfSBmcm9tIFwiLi9keW5hbWljcy1maWx0ZXJcIjtcbmltcG9ydCB7IEZpbHRlciB9IGZyb20gXCIuL2ZpbHRlclwiO1xuaW1wb3J0IHsgU29ydEZpbHRlciB9IGZyb20gXCIuL3NvcnQtZmlsdGVyXCI7XG5pbXBvcnQgeyBQcmljZVJhbmdlRmlsdGVyIH0gZnJvbSBcIi4vcHJpY2VfcmFuZ2UtZmlsdGVyXCI7XG5cbmV4cG9ydCBjbGFzcyBGaWx0ZXJGYWN0b3J5IHtcbiAgICBwdWJsaWMgY3JlYXRlKGZpbHRlclR5cGU6IEZpbHRlclR5cGUsIHByb2R1Y3RzRmlsdGVyPzogUGFnaW5hdGlvblNldHRpbmdzKTogRmlsdGVyIHtcbiAgICAgICAgc3dpdGNoIChmaWx0ZXJUeXBlKSB7XG4gICAgICAgICAgICBjYXNlICdjYXRlZ29yaWVzJzpcbiAgICAgICAgICAgICAgICByZXR1cm4gbmV3IENhdGVnb3J5RmlsdGVyKHByb2R1Y3RzRmlsdGVyID8gKHByb2R1Y3RzRmlsdGVyLnR5cGUgPT0gJ2NhdGVnb3JpZXMnICYmIHByb2R1Y3RzRmlsdGVyLnZhbHVlKSA6IG51bGwpO1xuICAgICAgICAgICAgY2FzZSAnYXR0cmlidXRlcyc6XG4gICAgICAgICAgICAgICAgcmV0dXJuIG5ldyBBdHRyaWJ1dGVzRmlsdGVyKHByb2R1Y3RzRmlsdGVyID8gKHByb2R1Y3RzRmlsdGVyLnR5cGUgPT0gJ2F0dHJpYnV0ZXMnICYmIHByb2R1Y3RzRmlsdGVyLnZhbHVlKSA6IG51bGwpO1xuICAgICAgICAgICAgY2FzZSAnZHluYW1pY3MnOlxuICAgICAgICAgICAgICAgIHJldHVybiBuZXcgRHluYW1pY3NGaWx0ZXIoKTtcbiAgICAgICAgICAgIGNhc2UgJ3NvcnQnOlxuICAgICAgICAgICAgICAgIHJldHVybiBuZXcgU29ydEZpbHRlcigpO1xuICAgICAgICAgICAgY2FzZSAncHJpY2VfcmFuZ2UnOlxuICAgICAgICAgICAgICAgIHJldHVybiBuZXcgUHJpY2VSYW5nZUZpbHRlcigpO1xuICAgICAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICAgICAgICAvLyBjb25zb2xlLmVycm9yKCdGaWx0ZXIgdHlwZSBub3QgcmVjb2duaXplZDonLCBmaWx0ZXJUeXBlKTtcbiAgICAgICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXCJOb3QgaW1wbGVtZW50ZWRcIilcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
|
|
@@ -15,8 +15,8 @@ export class PriceRangeFilter extends Filter {
|
|
|
15
15
|
if (options.minPrice != null && options.maxPrice != null) {
|
|
16
16
|
this.minPrice = options.minPrice;
|
|
17
17
|
this.maxPrice = options.maxPrice;
|
|
18
|
-
this.currentMinPrice = options.currentMinPrice ??
|
|
19
|
-
this.currentMaxPrice = options.currentMaxPrice ??
|
|
18
|
+
this.currentMinPrice = options.currentMinPrice ?? this.minPrice;
|
|
19
|
+
this.currentMaxPrice = options.currentMaxPrice ?? this.maxPrice;
|
|
20
20
|
this._loaded = true;
|
|
21
21
|
}
|
|
22
22
|
};
|
|
@@ -56,4 +56,4 @@ export class PriceRangeFilter extends Filter {
|
|
|
56
56
|
this.currentMaxPrice = null;
|
|
57
57
|
};
|
|
58
58
|
}
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJpY2VfcmFuZ2UtZmlsdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2NsYXNzZXMvZmlsdGVycy9wcmljZV9yYW5nZS1maWx0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUdsQyxNQUFNLE9BQU8sZ0JBQWlCLFNBQVEsTUFBTTtJQUNoQyxPQUFPLEdBQUcsS0FBSyxDQUFDO0lBRXhCLFFBQVEsR0FBVyxDQUFDLENBQUM7SUFDckIsUUFBUSxHQUFXLENBQUMsQ0FBQztJQUNyQixlQUFlLEdBQWtCLElBQUksQ0FBQztJQUN0QyxlQUFlLEdBQWtCLElBQUksQ0FBQztJQUU3QixJQUFJLEdBQUcsR0FBZSxFQUFFLENBQUMsYUFBYSxDQUFDO0lBRWhELHlDQUF5QztJQUN6QyxJQUFJLFFBQVE7UUFDUixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDeEIsQ0FBQztJQUVELHFEQUFxRDtJQUM1QyxVQUFVLEdBQUcsQ0FBQyxPQUFxRyxFQUFFLEVBQUU7UUFDNUgsSUFBSSxPQUFPLENBQUMsUUFBUSxJQUFJLElBQUksSUFBSSxPQUFPLENBQUMsUUFBUSxJQUFJLElBQUksRUFBRSxDQUFDO1lBQ3ZELElBQUksQ0FBQyxRQUFRLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQztZQUNqQyxJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUM7WUFDakMsSUFBSSxDQUFDLGVBQWUsR0FBRyxPQUFPLENBQUMsZUFBZSxJQUFJLElBQUksQ0FBQyxRQUFRLENBQUM7WUFDaEUsSUFBSSxDQUFDLGVBQWUsR0FBRyxPQUFPLENBQUMsZUFBZSxJQUFJLElBQUksQ0FBQyxRQUFRLENBQUM7WUFDaEUsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7UUFDeEIsQ0FBQztJQUNMLENBQUMsQ0FBQTtJQUVELFlBQVksQ0FBQyxHQUFXLEVBQUUsR0FBVztRQUNqQyxJQUFJLENBQUMsUUFBUSxHQUFHLEdBQUcsQ0FBQztRQUNwQixJQUFJLENBQUMsUUFBUSxHQUFHLEdBQUcsQ0FBQztRQUNwQixJQUFJLElBQUksQ0FBQyxlQUFlLEtBQUssSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsR0FBRyxHQUFHLElBQUksSUFBSSxDQUFDLGVBQWUsR0FBRyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQzlGLElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDO1FBQ2hDLENBQUM7UUFFRCxJQUFJLElBQUksQ0FBQyxlQUFlLEtBQUssSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsR0FBRyxHQUFHLElBQUksSUFBSSxDQUFDLGVBQWUsR0FBRyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQzlGLElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDO1FBQ2hDLENBQUM7UUFFRCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztJQUN4QixDQUFDO0lBRUQsbURBQW1EO0lBQzFDLFdBQVcsR0FBRyxDQUFDLEdBQVcsRUFBRSxHQUFXLEVBQVEsRUFBRTtRQUN0RCxJQUFJLENBQUMsZUFBZSxHQUFHLEdBQUcsS0FBSyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztRQUMxRCxJQUFJLENBQUMsZUFBZSxHQUFHLEdBQUcsS0FBSyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUM5RCxDQUFDLENBQUE7SUFFRCx1REFBdUQ7SUFDdkQsZ0JBQWdCLEdBQUcsR0FBaUMsRUFBRSxDQUFDLENBQUM7UUFDcEQsR0FBRyxFQUFFLElBQUksQ0FBQyxlQUFlLElBQUksSUFBSSxDQUFDLFFBQVM7UUFDM0MsR0FBRyxFQUFFLElBQUksQ0FBQyxlQUFlLElBQUksSUFBSSxDQUFDLFFBQVM7S0FDOUMsQ0FBQyxDQUFBO0lBRUYsMkVBQTJFO0lBQ2xFLFdBQVcsR0FBRyxHQUFXLEVBQUU7UUFDaEMsSUFBSSxNQUFNLEdBQUcsRUFBRSxDQUFDO1FBQ2hCLElBQUksSUFBSSxDQUFDLGVBQWUsSUFBSSxJQUFJO1lBQUUsTUFBTSxJQUFJLGNBQWMsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ2pGLElBQUksSUFBSSxDQUFDLGVBQWUsSUFBSSxJQUFJO1lBQUUsTUFBTSxJQUFJLGNBQWMsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ2pGLE9BQU8sTUFBTSxDQUFDO0lBQ2xCLENBQUMsQ0FBQTtJQUVELGlEQUFpRDtJQUNqRCxLQUFLLEdBQUcsR0FBUyxFQUFFO1FBQ2YsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUM7UUFDNUIsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUM7SUFDaEMsQ0FBQyxDQUFBO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGaWx0ZXIgfSBmcm9tIFwiLi9maWx0ZXJcIjtcbmltcG9ydCB7IEZpbHRlckVsZW1lbnQsIEZpbHRlclR5cGUgfSBmcm9tIFwiLi4vLi4vaW50ZXJmYWNlcy9maWx0ZXJcIjtcblxuZXhwb3J0IGNsYXNzIFByaWNlUmFuZ2VGaWx0ZXIgZXh0ZW5kcyBGaWx0ZXIge1xuICAgIHByaXZhdGUgX2xvYWRlZCA9IGZhbHNlO1xuXG4gICAgbWluUHJpY2U6IG51bWJlciA9IDA7XG4gICAgbWF4UHJpY2U6IG51bWJlciA9IDA7XG4gICAgY3VycmVudE1pblByaWNlOiBudW1iZXIgfCBudWxsID0gbnVsbDtcbiAgICBjdXJyZW50TWF4UHJpY2U6IG51bWJlciB8IG51bGwgPSBudWxsO1xuXG4gICAgb3ZlcnJpZGUgdHlwZSA9ICgpOiBGaWx0ZXJUeXBlID0+ICdwcmljZV9yYW5nZSc7XG5cbiAgICAvKiogdHJ1ZSBjdWFuZG8geWEgdGVuZ28gdW4gcmFuZ28gcmVhbCAqL1xuICAgIGdldCBpc0xvYWRlZCgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX2xvYWRlZDtcbiAgICB9XG5cbiAgICAvLyBNw6l0b2RvIHBhcmEgY29uZmlndXJhciBlbCByYW5nbyBkZSBwcmVjaW9zIGluaWNpYWxcbiAgICBvdmVycmlkZSBzZXRDb250ZW50ID0gKG9wdGlvbnM6IHsgbWluUHJpY2U/OiBudW1iZXI7IG1heFByaWNlPzogbnVtYmVyOyBjdXJyZW50TWluUHJpY2U/OiBudW1iZXI7IGN1cnJlbnRNYXhQcmljZT86IG51bWJlciB9KSA9PiB7XG4gICAgICAgIGlmIChvcHRpb25zLm1pblByaWNlICE9IG51bGwgJiYgb3B0aW9ucy5tYXhQcmljZSAhPSBudWxsKSB7XG4gICAgICAgICAgICB0aGlzLm1pblByaWNlID0gb3B0aW9ucy5taW5QcmljZTtcbiAgICAgICAgICAgIHRoaXMubWF4UHJpY2UgPSBvcHRpb25zLm1heFByaWNlO1xuICAgICAgICAgICAgdGhpcy5jdXJyZW50TWluUHJpY2UgPSBvcHRpb25zLmN1cnJlbnRNaW5QcmljZSA/PyB0aGlzLm1pblByaWNlO1xuICAgICAgICAgICAgdGhpcy5jdXJyZW50TWF4UHJpY2UgPSBvcHRpb25zLmN1cnJlbnRNYXhQcmljZSA/PyB0aGlzLm1heFByaWNlO1xuICAgICAgICAgICAgdGhpcy5fbG9hZGVkID0gdHJ1ZTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHVwZGF0ZVByaWNlcyhtaW46IG51bWJlciwgbWF4OiBudW1iZXIpIHtcbiAgICAgICAgdGhpcy5taW5QcmljZSA9IG1pbjtcbiAgICAgICAgdGhpcy5tYXhQcmljZSA9IG1heDtcbiAgICAgICAgaWYgKHRoaXMuY3VycmVudE1pblByaWNlICE9PSBudWxsICYmICh0aGlzLmN1cnJlbnRNaW5QcmljZSA8IG1pbiB8fCB0aGlzLmN1cnJlbnRNaW5QcmljZSA+IG1heCkpIHtcbiAgICAgICAgICAgIHRoaXMuY3VycmVudE1pblByaWNlID0gbnVsbDtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICh0aGlzLmN1cnJlbnRNYXhQcmljZSAhPT0gbnVsbCAmJiAodGhpcy5jdXJyZW50TWF4UHJpY2UgPiBtYXggfHwgdGhpcy5jdXJyZW50TWF4UHJpY2UgPCBtaW4pKSB7XG4gICAgICAgICAgICB0aGlzLmN1cnJlbnRNYXhQcmljZSA9IG51bGw7XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLl9sb2FkZWQgPSB0cnVlO1xuICAgIH1cblxuICAgIC8vIE3DqXRvZG8gcGFyYSBhY3R1YWxpemFyIGxvcyB2YWxvcmVzIHNlbGVjY2lvbmFkb3NcbiAgICBvdmVycmlkZSBzZXRTZWxlY3RlZCA9IChtaW46IG51bWJlciwgbWF4OiBudW1iZXIpOiB2b2lkID0+IHtcbiAgICAgICAgdGhpcy5jdXJyZW50TWluUHJpY2UgPSBtaW4gIT09IHRoaXMubWluUHJpY2UgPyBtaW4gOiBudWxsO1xuICAgICAgICB0aGlzLmN1cnJlbnRNYXhQcmljZSA9IG1heCAhPT0gdGhpcy5tYXhQcmljZSA/IG1heCA6IG51bGw7XG4gICAgfVxuXG4gICAgLy8gUmV0b3JuYSBsb3MgdmFsb3JlcyBzZWxlY2Npb25hZG9zIChyYW5nbyBkZSBwcmVjaW9zKVxuICAgIGdldFNlbGVjdGVkUmFuZ2UgPSAoKTogeyBtaW46IG51bWJlciwgbWF4OiBudW1iZXIgfSA9PiAoe1xuICAgICAgICBtaW46IHRoaXMuY3VycmVudE1pblByaWNlID8/IHRoaXMubWluUHJpY2UhLFxuICAgICAgICBtYXg6IHRoaXMuY3VycmVudE1heFByaWNlID8/IHRoaXMubWF4UHJpY2UhXG4gICAgfSlcblxuICAgIC8vIEdlbmVyYSBsb3MgcGFyw6FtZXRyb3MgZGUgbGEgVVJMIGVuIGJhc2UgYWwgcmFuZ28gZGUgcHJlY2lvcyBzZWxlY2Npb25hZG9cbiAgICBvdmVycmlkZSB0b1VybFBhcmFtcyA9ICgpOiBzdHJpbmcgPT4ge1xuICAgICAgICBsZXQgcGFyYW1zID0gJyc7XG4gICAgICAgIGlmICh0aGlzLmN1cnJlbnRNaW5QcmljZSAhPSBudWxsKSBwYXJhbXMgKz0gYCZwcmljZV9taW49JHt0aGlzLmN1cnJlbnRNaW5QcmljZX1gO1xuICAgICAgICBpZiAodGhpcy5jdXJyZW50TWF4UHJpY2UgIT0gbnVsbCkgcGFyYW1zICs9IGAmcHJpY2VfbWF4PSR7dGhpcy5jdXJyZW50TWF4UHJpY2V9YDtcbiAgICAgICAgcmV0dXJuIHBhcmFtcztcbiAgICB9XG5cbiAgICAvLyBSZXN0YWJsZWNlIGVsIGZpbHRybyBhIGxvcyB2YWxvcmVzIHBvciBkZWZlY3RvXG4gICAgcmVzZXQgPSAoKTogdm9pZCA9PiB7XG4gICAgICAgIHRoaXMuY3VycmVudE1pblByaWNlID0gbnVsbDtcbiAgICAgICAgdGhpcy5jdXJyZW50TWF4UHJpY2UgPSBudWxsO1xuICAgIH1cbn1cbiJdfQ==
|