ng-easycommerce-v18 0.2.1 → 0.2.2
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/assets/ec-i18n/ct.json +2 -1
- package/assets/ec-i18n/en.json +2 -1
- package/assets/ec-i18n/es.json +1 -0
- package/assets/ec-i18n/fr.json +2 -1
- package/assets/ec-i18n/gl.json +2 -1
- package/assets/ec-i18n/pr.json +2 -1
- package/esm2022/lib/classes/filters/filter-factory.mjs +4 -1
- package/esm2022/lib/classes/filters/price_range-filter.mjs +59 -0
- package/esm2022/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.mjs +3 -3
- package/esm2022/lib/ec-components/blocks-ec/block-products-ec/block-products-ec.component.mjs +3 -2
- package/esm2022/lib/ec-components/cart-ec/cart-ec.component.mjs +9 -1
- package/esm2022/lib/ec-components/checkout-ec/dataform-ec/dataform-ec.component.mjs +24 -3
- package/esm2022/lib/ec-components/collection-ec/collection-ec.component.mjs +1 -5
- package/esm2022/lib/ec-components/coupon-ec/coupon-ec.component.mjs +3 -3
- package/esm2022/lib/ec-components/filters-ec/filters-ec.component.mjs +38 -91
- package/esm2022/lib/ec-components/index.mjs +2 -1
- package/esm2022/lib/ec-components/price-range-filter/price-range-filter.component.mjs +143 -0
- package/esm2022/lib/ec-components/product-detail-ec/product-detail-ec.component.mjs +39 -3
- package/esm2022/lib/ec-components/product-ec/product-ec.component.mjs +16 -2
- package/esm2022/lib/ec-components/widgets-ec/price-ec/price-ec.component.mjs +73 -10
- package/esm2022/lib/ec-services/filters.service.mjs +45 -12
- package/esm2022/lib/ec-services/pagination.service.mjs +8 -7
- package/esm2022/lib/ec-services/product-detail.service.mjs +50 -35
- package/esm2022/lib/ec-services/products.service.mjs +18 -4
- package/esm2022/lib/interfaces/filter.mjs +1 -1
- package/esm2022/lib/interfaces/pagination.mjs +1 -1
- package/fesm2022/ng-easycommerce-v18.mjs +504 -166
- package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
- package/lib/classes/filters/price_range-filter.d.ts +26 -0
- package/lib/ec-components/cart-ec/cart-ec.component.d.ts +1 -0
- package/lib/ec-components/checkout-ec/dataform-ec/dataform-ec.component.d.ts +1 -0
- package/lib/ec-components/filters-ec/filters-ec.component.d.ts +7 -22
- package/lib/ec-components/index.d.ts +1 -0
- package/lib/ec-components/price-range-filter/price-range-filter.component.d.ts +37 -0
- package/lib/ec-components/product-detail-ec/product-detail-ec.component.d.ts +4 -0
- package/lib/ec-components/product-ec/product-ec.component.d.ts +1 -0
- package/lib/ec-components/widgets-ec/price-ec/price-ec.component.d.ts +30 -10
- package/lib/ec-services/filters.service.d.ts +6 -1
- package/lib/ec-services/product-detail.service.d.ts +4 -4
- package/lib/ec-services/products.service.d.ts +1 -0
- package/lib/interfaces/filter.d.ts +1 -1
- package/lib/interfaces/pagination.d.ts +2 -0
- package/package.json +1 -1
|
@@ -49,10 +49,6 @@ export class CollectionEcComponent {
|
|
|
49
49
|
type: params['type'] || null,
|
|
50
50
|
value: params['value'] || null
|
|
51
51
|
};
|
|
52
|
-
//console.log(ready,"actualizar")
|
|
53
|
-
console.log(paginationSettings);
|
|
54
|
-
/* console.log(paginationSettings) */
|
|
55
|
-
// console.log('params',queryParams["search"])
|
|
56
52
|
this._productsService.getProductsForFilter(paginationSettings, queryParams["search"]);
|
|
57
53
|
}
|
|
58
54
|
});
|
|
@@ -70,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
70
66
|
}], ctorParameters: () => [], propDecorators: { optionsFilters: [{
|
|
71
67
|
type: Input
|
|
72
68
|
}] } });
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGVjdGlvbi1lYy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lYXN5Y29tbWVyY2UtdjE4L3NyYy9saWIvZWMtY29tcG9uZW50cy9jb2xsZWN0aW9uLWVjL2NvbGxlY3Rpb24tZWMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvY29sbGVjdGlvbi1lYy9jb2xsZWN0aW9uLWVjLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBbUIsU0FBUyxFQUFnQixNQUFNLEVBQUUsS0FBSyxFQUFVLFdBQVcsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFckgsT0FBTyxFQUFFLFdBQVcsRUFBRSxjQUFjLEVBQUUsY0FBYyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2pHLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNqRCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsYUFBYSxFQUFtQyxNQUFNLE1BQU0sQ0FBQztBQUV0RSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFRcEQsTUFBTSxPQUFPLHFCQUFxQjtJQUV2QixnQkFBZ0IsR0FBb0IsTUFBTSxDQUFDLGVBQWUsQ0FBQyxDQUFBO0lBQzNELFlBQVksR0FBbUIsTUFBTSxDQUFDLGNBQWMsQ0FBQyxDQUFBO0lBQ3JELGVBQWUsR0FBbUIsTUFBTSxDQUFDLGNBQWMsQ0FBQyxDQUFBO0lBRTNELE9BQU8sR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQTtJQUN6QywyQ0FBMkM7SUFDcEMsWUFBWSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFBO0lBQzVDLFNBQVMsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFBO0lBQ2xELHVCQUF1QjtJQUVoQixXQUFXLEdBQWdCLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQTtJQUM5QyxTQUFTLEdBQXlCLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFBO0lBRTlELFFBQVEsR0FBYyxFQUFFLENBQUM7SUFDekIsY0FBYyxHQUFvQixFQUFFLENBQUM7SUFDckMsT0FBTyxHQUFXLEtBQUssQ0FBQztJQUN4QixhQUFhLEdBQUcsTUFBTSxDQUFTLENBQUMsQ0FBQyxDQUFBO0lBQ2hDLE1BQU0sR0FBRyxLQUFLLENBQUM7SUFFZCxjQUFjLEdBQWlCLENBQUMsS0FBSyxDQUFDLENBQUM7SUFFaEQsWUFBWSxHQUFZLEVBQUUsQ0FBQztJQUVuQixlQUFlLEdBQW1CLE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQTtJQUN0RCxRQUFRLEdBQXlCLElBQUksQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDO0lBQ2xFLE1BQU0sR0FBd0IsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUM7SUFFekQsTUFBTSxDQUFTO0lBRXZCLFFBQVE7UUFDSixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDdEIsSUFBSSxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFBO0lBQzFCLENBQUM7SUFFRCx3REFBd0Q7SUFDaEQsS0FBSyxHQUFHLENBQUMsQ0FBQztJQUNWLFVBQVUsR0FBUSxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUE7SUFFN0M7UUFDQyxJQUFJLGlCQUFpQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsRUFBRSxDQUFDO1lBQ3hDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFBO1FBRXJCLENBQUM7SUFDRixDQUFDO0lBRUQsV0FBVztRQUNWLGFBQWEsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO1lBQzFELElBQUksRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFLFdBQVcsQ0FBQyxFQUFFLEVBQUU7Z0JBQy9CLE1BQU0sa0JBQWtCLEdBQXNCO29CQUM3QyxNQUFNLEVBQUMsSUFBSTtvQkFDWCxLQUFLLEVBQUMsRUFBRTtvQkFDUixJQUFJLEVBQUUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLElBQUk7b0JBQzVCLEtBQUssRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLElBQUksSUFBSTtpQkFDOUIsQ0FBQTtnQkFDRCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsb0JBQW9CLENBQUMsa0JBQWtCLEVBQUUsV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7WUFDdkYsQ0FBQztTQUNELENBQUMsQ0FBQTtJQUNILENBQUM7SUFFRCxRQUFRO1FBQ1AsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7UUFDZCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsY0FBYyxFQUFFLENBQUE7SUFDM0MsQ0FBQzt3R0FoRVMscUJBQXFCOzRGQUFyQixxQkFBcUIsMkhDaEJsQyxzYkFnQkE7OzRGREFhLHFCQUFxQjtrQkFQakMsU0FBUzsrQkFDQyxtQkFBbUIsY0FDakIsSUFBSSxXQUNQLENBQUMsdUJBQXVCLENBQUM7d0RBeUJ6QixjQUFjO3NCQUF0QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYWZ0ZXJOZXh0UmVuZGVyLCBDb21wb25lbnQsIEhvc3RMaXN0ZW5lciwgaW5qZWN0LCBJbnB1dCwgT25Jbml0LCBQTEFURk9STV9JRCwgc2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IERlZmF1bHRGaWx0ZXIsIEZpbHRlclR5cGUsIFBhZ2luYXRpb25TZXR0aW5ncywgUHJvZHVjdCB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xyXG5pbXBvcnQgeyBBdXRoU2VydmljZSwgRmlsdGVyc1NlcnZpY2UsIE9wdGlvbnNTZXJ2aWNlLCBQcm9kdWN0c1NlcnZpY2UgfSBmcm9tICcuLi8uLi9lYy1zZXJ2aWNlcyc7XHJcbmltcG9ydCB7IEFjdGl2YXRlZFJvdXRlIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuaW1wb3J0IHsgQ29yZUNvbnN0YW50c1NlcnZpY2UgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xyXG5pbXBvcnQgeyBjb21iaW5lTGF0ZXN0LCBmb3JrSm9pbiwgbWFwLCBPYnNlcnZhYmxlLCB0YWtlIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IEZpbHRlciB9IGZyb20gJy4uLy4uL2NsYXNzZXMnO1xyXG5pbXBvcnQgeyBJbmZpbml0ZVNjcm9sbERpcmVjdGl2ZSB9IGZyb20gXCJuZ3gtaW5maW5pdGUtc2Nyb2xsXCI7XHJcbmltcG9ydCB7IGlzUGxhdGZvcm1Ccm93c2VyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuQENvbXBvbmVudCh7XHJcblx0c2VsZWN0b3I6ICdsaWItY29sbGVjdGlvbi1lYycsXHJcblx0c3RhbmRhbG9uZTogdHJ1ZSxcclxuXHRpbXBvcnRzOiBbSW5maW5pdGVTY3JvbGxEaXJlY3RpdmVdLFxyXG5cdHRlbXBsYXRlVXJsOiAnLi9jb2xsZWN0aW9uLWVjLmNvbXBvbmVudC5odG1sJyxcclxuXHRzdHlsZVVybDogJy4vY29sbGVjdGlvbi1lYy5jb21wb25lbnQuc2NzcydcclxufSlcclxuZXhwb3J0IGNsYXNzIENvbGxlY3Rpb25FY0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG5cdHByb3RlY3RlZCBfcHJvZHVjdHNTZXJ2aWNlOiBQcm9kdWN0c1NlcnZpY2UgPSBpbmplY3QoUHJvZHVjdHNTZXJ2aWNlKVxyXG5cdHByb3RlY3RlZCBfYWN0aXZlUm91dGU6IEFjdGl2YXRlZFJvdXRlID0gaW5qZWN0KEFjdGl2YXRlZFJvdXRlKVxyXG5cdHByb3RlY3RlZCBfb3B0aW9uc1NlcnZpY2U6IE9wdGlvbnNTZXJ2aWNlID0gaW5qZWN0KE9wdGlvbnNTZXJ2aWNlKVxyXG5cclxuXHRwdWJsaWMgcGFyYW1zJCA9IHRoaXMuX2FjdGl2ZVJvdXRlLnBhcmFtc1xyXG5cdC8vcHVibGljIHJlYWR5ID0gdGhpcy5fb3B0aW9uc1NlcnZpY2UucmVhZHlcclxuXHRwdWJsaWMgcXVlcnlQYXJhbXMkID0gdGhpcy5fYWN0aXZlUm91dGUucXVlcnlQYXJhbXNcclxuXHRwdWJsaWMgcHJvZHVjdHMkID0gdGhpcy5fcHJvZHVjdHNTZXJ2aWNlLnByb2R1Y3RzJFxyXG5cdC8vcHVibGljIHByb2R1Y3RzJCA9IFtdXHJcblxyXG5cdHB1YmxpYyBhdXRoU2VydmljZTogQXV0aFNlcnZpY2UgPSBpbmplY3QoQXV0aFNlcnZpY2UpXHJcblx0cHVibGljIGNvbnN0YW5zdDogQ29yZUNvbnN0YW50c1NlcnZpY2UgPSBpbmplY3QoQ29yZUNvbnN0YW50c1NlcnZpY2UpXHJcblxyXG5cdHB1YmxpYyBwcm9kdWN0czogUHJvZHVjdFtdID0gW107XHJcblx0cHVibGljIGRlZmF1bHRGaWx0ZXJzOiBEZWZhdWx0RmlsdGVyW10gPSBbXTtcclxuXHRwdWJsaWMgbG9hZGluZzpCb29sZWFuID0gZmFsc2U7XHJcblx0cHVibGljIGNvdW50UHJvZHVjdHMgPSBzaWduYWw8bnVtYmVyPigwKVxyXG5cdHByaXZhdGUgbG9hZGVkID0gZmFsc2U7XHJcblxyXG5cdEBJbnB1dCgpIG9wdGlvbnNGaWx0ZXJzOiBGaWx0ZXJUeXBlW10gPSBbJ2FsbCddO1xyXG5cclxuXHRmaWx0ZXJzX3NvcnQ6RmlsdGVyW10gPSBbXTtcclxuXHJcblx0cHJpdmF0ZSBfZmlsdGVyc1NlcnZpY2U6IEZpbHRlcnNTZXJ2aWNlID0gaW5qZWN0KEZpbHRlcnNTZXJ2aWNlKVxyXG4gICAgcHVibGljIGZpbHRlcnMkOiBPYnNlcnZhYmxlPEZpbHRlcltdPiA9IHRoaXMuX2ZpbHRlcnNTZXJ2aWNlLmZpbHRlcnMkO1xyXG5cdHB1YmxpYyByZWFkeSQ6IE9ic2VydmFibGU8Ym9vbGVhbj4gPSB0aGlzLl9maWx0ZXJzU2VydmljZS5yZWFkeSQ7XHJcblxyXG5cdHByaXZhdGUgd2luZG93PzpXaW5kb3c7XHJcblxyXG5cdG5nT25Jbml0KCk6IHZvaWQge1xyXG5cdCAgIFx0dGhpcy5nZXRQcm9kdWN0cygpO1xyXG5cdFx0dGhpcy53aW5kb3c/LnNjcm9sbCgwLCAwKVxyXG5cdH1cclxuXHJcblx0Ly9wcm90ZWN0ZWQgcmVhZG9ubHkgcXVlc3Rpb25zID0gc2lnbmFsPFF1ZXN0aW9uW10+KFtdKTtcclxuXHRwcml2YXRlIHRvdGFsID0gMDtcclxuXHRwcml2YXRlIHBsYXRmb3JtSWQ6IGFueSA9IGluamVjdChQTEFURk9STV9JRClcclxuXHJcblx0Y29uc3RydWN0b3IoKSB7XHJcblx0XHRpZiAoaXNQbGF0Zm9ybUJyb3dzZXIodGhpcy5wbGF0Zm9ybUlkKSkge1xyXG5cdFx0XHR0aGlzLndpbmRvdyA9IHdpbmRvd1xyXG5cdFx0XHRcclxuXHRcdH1cclxuXHR9XHJcblxyXG5cdGdldFByb2R1Y3RzKCk6IHZvaWQge1x0XHRcclxuXHRcdGNvbWJpbmVMYXRlc3QoW3RoaXMucGFyYW1zJCwgdGhpcy5xdWVyeVBhcmFtcyRdKS5zdWJzY3JpYmUoe1xyXG5cdFx0XHRuZXh0OiAoW3BhcmFtcywgcXVlcnlQYXJhbXNdKSA9PiB7XHRcdFx0XHRcclxuXHRcdFx0XHRjb25zdCBwYWdpbmF0aW9uU2V0dGluZ3M6UGFnaW5hdGlvblNldHRpbmdzID0ge1xyXG5cdFx0XHRcdFx0bGF0ZXN0OnRydWUsXHJcblx0XHRcdFx0XHRsaW1pdDoxMCxcclxuXHRcdFx0XHRcdHR5cGU6IHBhcmFtc1sndHlwZSddIHx8IG51bGwsXHJcblx0XHRcdFx0XHR2YWx1ZTogcGFyYW1zWyd2YWx1ZSddIHx8IG51bGxcclxuXHRcdFx0XHR9XHJcblx0XHRcdFx0dGhpcy5fcHJvZHVjdHNTZXJ2aWNlLmdldFByb2R1Y3RzRm9yRmlsdGVyKHBhZ2luYXRpb25TZXR0aW5ncywgcXVlcnlQYXJhbXNbXCJzZWFyY2hcIl0pO1xyXG5cdFx0XHR9XHJcblx0XHR9KVxyXG5cdH1cclxuXHJcblx0b25TY3JvbGwoKSB7XHJcblx0XHR0aGlzLmxvYWRpbmcgPSB0cnVlO1xyXG4gICAgICAgIHRoaXMuX3Byb2R1Y3RzU2VydmljZS51cGRhdGVQcm9kdWN0cygpXHJcblx0ICB9XHJcblxyXG59XHJcbiIsIjxzZWN0aW9uIGNsYXNzPVwiY29udGFpbmVyLXhsIG1iLTVcIj5cclxuICAgIDxkaXYgY2xhc3M9XCJyb3cgbS0wIHAtMFwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJkLW5vbmUgZC1sZy1ibG9jayBjb2wtM1wiPlxyXG4gICAgICAgICAgICA8IS0tRmlsdHJvcy0tPlxyXG4gICAgICAgIDwvZGl2PlxyXG5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLTEyIGNvbC1sZy05IG10LTIgcC0wXCI+XHJcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjb250YWluZXJcIj5cclxuICAgICAgICAgICAgICAgIDwhLS0gQGZvcihbJ2EnLCAnYicsICdjJywgJ2QnXSBhcyBwcm9kdWN0KXtcclxuXHJcbiAgICAgICAgICAgICAgICB9IC0tPlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuXHJcbiAgICA8L2Rpdj5cclxuPC9zZWN0aW9uPlxyXG4iXX0=
|
|
@@ -26,10 +26,10 @@ export class CouponEcComponent {
|
|
|
26
26
|
}
|
|
27
27
|
setLoading = () => this.loading = true;
|
|
28
28
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CouponEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
29
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CouponEcComponent, isStandalone: true, selector: "app-coupon-ec", ngImport: i0, template: "<div class=\"border border-bottom card p-2\">\r\n <p class=\"w-100 mb-1\">C\u00F3digo de descuento</p>\r\n \r\n @if(coupon$ | async; as coupon){\r\n <div class=\"d-flex justify-content-between align-items-center px-1\">\r\n <p class=\"m-0\">{{coupon.code
|
|
29
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CouponEcComponent, isStandalone: true, selector: "app-coupon-ec", ngImport: i0, template: "<div class=\"border border-bottom card p-2\">\r\n <p class=\"w-100 mb-1\">C\u00F3digo de descuento</p>\r\n \r\n @if(coupon$ | async; as coupon){\r\n <div class=\"d-flex justify-content-between align-items-center px-1\">\r\n <p class=\"m-0\">{{coupon.code}}</p>\r\n <button class=\"btn\" (click)=\"removeCoupon()\"><i class=\"bi bi-trash\"></i></button>\r\n </div>\r\n }@else {\r\n <form class=\"campo d-flex align-items-center\">\r\n <input type='text' class=\"elcampo\" [(ngModel)]=\"couponValue\" name=\"coupon_value\" />\r\n <input type='button' value='VALIDAR' class=\"btn btn-primary btnSend py-1\"\r\n (click)=\" addCoupon()\" />\r\n </form> \r\n }\r\n</div>", styles: [""], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormsModule }, { 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.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }] });
|
|
30
30
|
}
|
|
31
31
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CouponEcComponent, decorators: [{
|
|
32
32
|
type: Component,
|
|
33
|
-
args: [{ selector: 'app-coupon-ec', standalone: true, imports: [AsyncPipe, FormsModule, UpperCasePipe], template: "<div class=\"border border-bottom card p-2\">\r\n <p class=\"w-100 mb-1\">C\u00F3digo de descuento</p>\r\n \r\n @if(coupon$ | async; as coupon){\r\n <div class=\"d-flex justify-content-between align-items-center px-1\">\r\n <p class=\"m-0\">{{coupon.code
|
|
33
|
+
args: [{ selector: 'app-coupon-ec', standalone: true, imports: [AsyncPipe, FormsModule, UpperCasePipe], template: "<div class=\"border border-bottom card p-2\">\r\n <p class=\"w-100 mb-1\">C\u00F3digo de descuento</p>\r\n \r\n @if(coupon$ | async; as coupon){\r\n <div class=\"d-flex justify-content-between align-items-center px-1\">\r\n <p class=\"m-0\">{{coupon.code}}</p>\r\n <button class=\"btn\" (click)=\"removeCoupon()\"><i class=\"bi bi-trash\"></i></button>\r\n </div>\r\n }@else {\r\n <form class=\"campo d-flex align-items-center\">\r\n <input type='text' class=\"elcampo\" [(ngModel)]=\"couponValue\" name=\"coupon_value\" />\r\n <input type='button' value='VALIDAR' class=\"btn btn-primary btnSend py-1\"\r\n (click)=\" addCoupon()\" />\r\n </form> \r\n }\r\n</div>" }]
|
|
34
34
|
}] });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291cG9uLWVjLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLWVhc3ljb21tZXJjZS12MTgvc3JjL2xpYi9lYy1jb21wb25lbnRzL2NvdXBvbi1lYy9jb3Vwb24tZWMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvY291cG9uLWVjL2NvdXBvbi1lYy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFaEQsT0FBTyxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQVM3QyxNQUFNLE9BQU8saUJBQWlCO0lBQ3JCLFlBQVksR0FBZ0IsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ2pELE9BQU8sR0FBb0IsSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUE7SUFDcEQsV0FBVyxHQUFXLEVBQUUsQ0FBQztJQUN6QixNQUFNLEdBQUcsS0FBSyxDQUFDO0lBQ2YsT0FBTyxHQUFHLEtBQUssQ0FBQztJQUV2QixTQUFTO1FBQ1IsSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQTtJQUNwRSxDQUFDO0lBRUQsV0FBVztRQUNWLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ3RCLE9BQU8sdUJBQXVCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN2RCxDQUFDO2FBQU0sQ0FBQztZQUNQLE9BQU8sS0FBSyxDQUFDO1FBQ2QsQ0FBQztJQUNGLENBQUM7SUFFRCxZQUFZO1FBQ1gsSUFBSSxDQUFDLFlBQVksQ0FBQyxZQUFZLEVBQUUsQ0FBQTtJQUNqQyxDQUFDO0lBRUQsVUFBVSxHQUFHLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDO3dHQXZCM0IsaUJBQWlCOzRGQUFqQixpQkFBaUIseUVDYjlCLHd1QkFlTSxxREROSyxTQUFTLDZDQUFFLFdBQVc7OzRGQUlwQixpQkFBaUI7a0JBUDdCLFNBQVM7K0JBQ0MsZUFBZSxjQUNiLElBQUksV0FDUCxDQUFDLFNBQVMsRUFBRSxXQUFXLEVBQUUsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ2FydFNlcnZpY2UgfSBmcm9tICcuLi8uLi9lYy1zZXJ2aWNlcyc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQXN5bmNQaXBlLCBVcHBlckNhc2VQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuXHRzZWxlY3RvcjogJ2FwcC1jb3Vwb24tZWMnLFxyXG5cdHN0YW5kYWxvbmU6IHRydWUsXHJcblx0aW1wb3J0czogW0FzeW5jUGlwZSwgRm9ybXNNb2R1bGUsIFVwcGVyQ2FzZVBpcGVdLFxyXG5cdHRlbXBsYXRlVXJsOiAnLi9jb3Vwb24tZWMuY29tcG9uZW50Lmh0bWwnLFxyXG5cdHN0eWxlVXJsOiAnLi9jb3Vwb24tZWMuY29tcG9uZW50LnNjc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb3Vwb25FY0NvbXBvbmVudCB7XHJcblx0cHJpdmF0ZSBfY2FydFNlcnZpY2U6IENhcnRTZXJ2aWNlID0gaW5qZWN0KENhcnRTZXJ2aWNlKTtcclxuXHRwdWJsaWMgY291cG9uJDogT2JzZXJ2YWJsZTxhbnk+ID0gdGhpcy5fY2FydFNlcnZpY2UuY291cG9uJFxyXG5cdHB1YmxpYyBjb3Vwb25WYWx1ZTogc3RyaW5nID0gXCJcIjtcclxuXHRwdWJsaWMgYXBsaWVkID0gZmFsc2U7XHJcblx0cHVibGljIGxvYWRpbmcgPSBmYWxzZTtcclxuXHJcblx0YWRkQ291cG9uKCkge1xyXG5cdFx0dGhpcy52YWxpZENvdXBvbigpICYmIHRoaXMuX2NhcnRTZXJ2aWNlLmFkZENvdXBvbih0aGlzLmNvdXBvblZhbHVlKVxyXG5cdH1cclxuXHJcblx0dmFsaWRDb3Vwb24oKTogYm9vbGVhbiB7XHJcblx0XHRpZiAodGhpcy5jb3Vwb25WYWx1ZSkge1xyXG5cdFx0XHRyZXR1cm4gL14oW0EtWmEtelxcLTAtOV0qKVxcdyskLy50ZXN0KHRoaXMuY291cG9uVmFsdWUpO1xyXG5cdFx0fSBlbHNlIHtcclxuXHRcdFx0cmV0dXJuIGZhbHNlO1xyXG5cdFx0fVxyXG5cdH1cclxuXHJcblx0cmVtb3ZlQ291cG9uKCkge1xyXG5cdFx0dGhpcy5fY2FydFNlcnZpY2UucmVtb3ZlQ291cG9uKClcclxuXHR9XHJcblx0XHJcblx0c2V0TG9hZGluZyA9ICgpID0+IHRoaXMubG9hZGluZyA9IHRydWU7XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImJvcmRlciBib3JkZXItYm90dG9tIGNhcmQgcC0yXCI+XHJcbiAgICA8cCBjbGFzcz1cInctMTAwIG1iLTFcIj5Dw7NkaWdvIGRlIGRlc2N1ZW50bzwvcD5cclxuICAgIFxyXG4gICAgQGlmKGNvdXBvbiQgfCBhc3luYzsgYXMgY291cG9uKXtcclxuICAgICAgICA8ZGl2IGNsYXNzPVwiZC1mbGV4IGp1c3RpZnktY29udGVudC1iZXR3ZWVuIGFsaWduLWl0ZW1zLWNlbnRlciBweC0xXCI+XHJcbiAgICAgICAgPHAgY2xhc3M9XCJtLTBcIj57e2NvdXBvbi5jb2RlfX08L3A+XHJcbiAgICAgICAgPGJ1dHRvbiBjbGFzcz1cImJ0blwiIChjbGljayk9XCJyZW1vdmVDb3Vwb24oKVwiPjxpIGNsYXNzPVwiYmkgYmktdHJhc2hcIj48L2k+PC9idXR0b24+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICB9QGVsc2Uge1xyXG4gICAgICAgPGZvcm0gY2xhc3M9XCJjYW1wbyBkLWZsZXggYWxpZ24taXRlbXMtY2VudGVyXCI+XHJcbiAgICAgICAgPGlucHV0IHR5cGU9J3RleHQnIGNsYXNzPVwiZWxjYW1wb1wiIFsobmdNb2RlbCldPVwiY291cG9uVmFsdWVcIiBuYW1lPVwiY291cG9uX3ZhbHVlXCIgLz5cclxuICAgICAgICA8aW5wdXQgdHlwZT0nYnV0dG9uJyAgdmFsdWU9J1ZBTElEQVInIGNsYXNzPVwiYnRuIGJ0bi1wcmltYXJ5IGJ0blNlbmQgcHktMVwiXHJcbiAgICAgICAgICAgIChjbGljayk9XCIgYWRkQ291cG9uKClcIiAvPlxyXG4gICAgPC9mb3JtPiBcclxuICAgIH1cclxuPC9kaXY+Il19
|
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import { Component, inject, Input
|
|
1
|
+
import { Component, inject, Input } from '@angular/core';
|
|
2
2
|
import { FiltersService } from '../../ec-services';
|
|
3
3
|
import { Filter } from '../../classes';
|
|
4
4
|
import { ProductsService } from '../../ec-services/products.service';
|
|
5
5
|
import { CoreConstantsService } from '../../constants';
|
|
6
6
|
import { Router } from '@angular/router';
|
|
7
|
+
import { PriceRangeFilter } from '../../classes/filters/price_range-filter';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
export class FiltersEcComponent {
|
|
9
10
|
_filtersService = inject(FiltersService);
|
|
@@ -13,9 +14,8 @@ export class FiltersEcComponent {
|
|
|
13
14
|
filters = [];
|
|
14
15
|
filter$ = this._filtersService.filters$;
|
|
15
16
|
setSelect;
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
priceGapPercentage = 0.1;
|
|
17
|
+
ngOnInit() {
|
|
18
|
+
}
|
|
19
19
|
constructor() {
|
|
20
20
|
this._filtersService.filters$.subscribe((filters) => {
|
|
21
21
|
this.filters = filters;
|
|
@@ -23,7 +23,7 @@ export class FiltersEcComponent {
|
|
|
23
23
|
}
|
|
24
24
|
getSpecificFilter(type) {
|
|
25
25
|
const filter = this.filters.find(f => f.type() === type);
|
|
26
|
-
if (!(filter instanceof Filter)) {
|
|
26
|
+
if (type === 'price_range' && filter && !(filter instanceof Filter)) {
|
|
27
27
|
console.error(`Expected a Filter instance but got`, filter);
|
|
28
28
|
}
|
|
29
29
|
return filter || null;
|
|
@@ -47,8 +47,6 @@ export class FiltersEcComponent {
|
|
|
47
47
|
console.error('filter.setSelected is not a function. Filter might not be an instance of the expected class:', filter);
|
|
48
48
|
return;
|
|
49
49
|
}
|
|
50
|
-
console.log("Setting selected filter:", filter);
|
|
51
|
-
console.log("Setting selected element:", selected);
|
|
52
50
|
try {
|
|
53
51
|
// this._filtersService.setFilterSelected(filter, selected);
|
|
54
52
|
if (selected.path) {
|
|
@@ -59,33 +57,12 @@ export class FiltersEcComponent {
|
|
|
59
57
|
console.error("Error while setting selected filter:", error);
|
|
60
58
|
}
|
|
61
59
|
}
|
|
62
|
-
/**
|
|
63
|
-
* Redondea al múltiplo de 'step' respetando el redondeo entero:
|
|
64
|
-
* - Mínimo: redondea hacia abajo.
|
|
65
|
-
* - Máximo: redondea hacia arriba.
|
|
66
|
-
*/
|
|
67
|
-
onRangeChange(event, type, filter) {
|
|
68
|
-
const input = event.target;
|
|
69
|
-
let value = parseInt(input.value, 10);
|
|
70
|
-
value = this.roundToNearest(value, 5, type, filter);
|
|
71
|
-
this.updateFilterPrices(type, value, filter, this.priceGapPercentage);
|
|
72
|
-
}
|
|
73
|
-
roundToNearest(value, step, type, filter) {
|
|
74
|
-
let rounded = Math.round(value / step) * step;
|
|
75
|
-
if (type === 'max' && rounded < filter.maxPrice) {
|
|
76
|
-
rounded = Math.ceil(value / step) * step;
|
|
77
|
-
}
|
|
78
|
-
if (type === 'min' && rounded > filter.minPrice) {
|
|
79
|
-
rounded = Math.floor(value / step) * step;
|
|
80
|
-
}
|
|
81
|
-
return rounded;
|
|
82
|
-
}
|
|
83
60
|
uniqueSelection(filter, filterChild) {
|
|
84
61
|
// Buscar si hay un filtro de tipo PriceRangeFilter en la lista de filtros
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
62
|
+
const priceRangeFilter = this.filters.find(f => f instanceof PriceRangeFilter);
|
|
63
|
+
if (priceRangeFilter) {
|
|
64
|
+
priceRangeFilter.reset();
|
|
65
|
+
}
|
|
89
66
|
filter.data.forEach(filterElement => {
|
|
90
67
|
if (filterElement.selected) {
|
|
91
68
|
filterElement.selected = false;
|
|
@@ -97,74 +74,44 @@ export class FiltersEcComponent {
|
|
|
97
74
|
});
|
|
98
75
|
});
|
|
99
76
|
}
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
if (newMin + priceGap > currentMax) {
|
|
111
|
-
let newMaxCandidate = newMin + priceGap;
|
|
112
|
-
if (newMaxCandidate <= globalMax) {
|
|
113
|
-
currentMax = newMaxCandidate;
|
|
114
|
-
}
|
|
115
|
-
else {
|
|
116
|
-
newMin = globalMax - priceGap;
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
filter.currentMinPrice = newMin;
|
|
120
|
-
filter.currentMaxPrice = currentMax;
|
|
121
|
-
}
|
|
122
|
-
else if (type === 'max') {
|
|
123
|
-
let newMax = Math.max(Math.min(value, globalMax), globalMin);
|
|
124
|
-
if (newMax - priceGap < currentMin) {
|
|
125
|
-
let newMinCandidate = newMax - priceGap;
|
|
126
|
-
if (newMinCandidate >= globalMin) {
|
|
127
|
-
currentMin = newMinCandidate;
|
|
128
|
-
}
|
|
129
|
-
else {
|
|
130
|
-
newMax = globalMin + priceGap;
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
filter.currentMaxPrice = newMax;
|
|
134
|
-
filter.currentMinPrice = currentMin;
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
// Método para actualizar los valores de precio seleccionados
|
|
138
|
-
// updatePriceRange(min: number, max: number, priceFilter: PriceRangeFilter) {
|
|
139
|
-
// priceFilter.setSelected(min, max);
|
|
140
|
-
// this.setSelect(priceFilter);
|
|
141
|
-
// }
|
|
142
|
-
// Métodos para actualizar la barra del filtro por precio
|
|
143
|
-
calculateLeftPercentage(currentMinPrice, minPrice, maxPrice) {
|
|
144
|
-
const minVal = Math.max(minPrice, Math.min(currentMinPrice ?? minPrice, maxPrice));
|
|
145
|
-
return Math.max(0, Math.min(((minVal - minPrice) / (maxPrice - minPrice)) * 100, 100));
|
|
146
|
-
}
|
|
147
|
-
calculateRightPercentage(currentMaxPrice, minPrice, maxPrice) {
|
|
148
|
-
const maxVal = Math.max(minPrice, Math.min(currentMaxPrice ?? maxPrice, maxPrice));
|
|
149
|
-
return Math.max(0, Math.min(100 - ((maxVal - minPrice) / (maxPrice - minPrice)) * 100, 100));
|
|
150
|
-
}
|
|
77
|
+
// close = () => {
|
|
78
|
+
// this.document.getElementById("filtros").classList.remove('in');
|
|
79
|
+
// return true;
|
|
80
|
+
// };
|
|
81
|
+
close = () => {
|
|
82
|
+
// this.consts.mobile()
|
|
83
|
+
// ? this.document.getElementById("accordionExample").classList.remove('show')
|
|
84
|
+
// : this.document.getElementById(accordion_id).classList.remove('show');
|
|
85
|
+
return true;
|
|
86
|
+
};
|
|
151
87
|
scrollUp = () => {
|
|
152
88
|
window.scroll(0, 0);
|
|
153
89
|
return true;
|
|
154
90
|
};
|
|
91
|
+
hasAppliedFilters() {
|
|
92
|
+
return this.filters?.some((filter) => {
|
|
93
|
+
if (filter.type?.() === 'price_range') {
|
|
94
|
+
const minSet = filter.currentMinPrice !== null && filter.currentMinPrice !== 0;
|
|
95
|
+
const maxSet = filter.currentMaxPrice !== null && filter.currentMaxPrice !== filter.maxPrice;
|
|
96
|
+
if (minSet || maxSet) {
|
|
97
|
+
return true;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
return filter.data?.some((filterElement) => {
|
|
101
|
+
if (Array.isArray(filterElement.children)) {
|
|
102
|
+
return filterElement.children.some((child) => child.selected);
|
|
103
|
+
}
|
|
104
|
+
return filterElement.selected;
|
|
105
|
+
});
|
|
106
|
+
}) ?? false;
|
|
107
|
+
}
|
|
155
108
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FiltersEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
156
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FiltersEcComponent, isStandalone: true, selector: "lib-filters-ec", inputs: { setSelect: "setSelect" },
|
|
109
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FiltersEcComponent, isStandalone: true, selector: "lib-filters-ec", inputs: { setSelect: "setSelect" }, ngImport: i0, template: "<p>filters-ec works!</p>\r\n", styles: [""] });
|
|
157
110
|
}
|
|
158
111
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FiltersEcComponent, decorators: [{
|
|
159
112
|
type: Component,
|
|
160
113
|
args: [{ selector: 'lib-filters-ec', standalone: true, imports: [], template: "<p>filters-ec works!</p>\r\n" }]
|
|
161
114
|
}], ctorParameters: () => [], propDecorators: { setSelect: [{
|
|
162
115
|
type: Input
|
|
163
|
-
}], rangeMinRef: [{
|
|
164
|
-
type: ViewChild,
|
|
165
|
-
args: ['rangeMin']
|
|
166
|
-
}], rangeMaxRef: [{
|
|
167
|
-
type: ViewChild,
|
|
168
|
-
args: ['rangeMax']
|
|
169
116
|
}] } });
|
|
170
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filters-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, ElementRef, ViewChild } from '@angular/core';\r\nimport { FiltersService } from '../../ec-services';\r\nimport { Filter } from '../../classes';\r\nimport { FilterElement, FilterType, PaginationSettings } from '../../interfaces';\r\nimport { ProductsService } from '../../ec-services/products.service';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { Router } from '@angular/router';\r\n\r\n@Component({\r\n\tselector: 'lib-filters-ec',\r\n\tstandalone: true,\r\n\timports: [],\r\n\ttemplateUrl: './filters-ec.component.html',\r\n\tstyleUrl: './filters-ec.component.scss'\r\n})\r\nexport class FiltersEcComponent {\r\n\tprivate _filtersService: FiltersService = inject(FiltersService);\r\n\tprivate _productsService: ProductsService = inject(ProductsService);\r\n\tprivate _constants: CoreConstantsService = inject(CoreConstantsService);\r\n\tprivate router: Router = inject(Router);\r\n\tpublic filters: Filter[] = [];\r\n\tpublic filter$ = this._filtersService.filters$;\r\n\t@Input() setSelect: any;\r\n\r\n\t@ViewChild('rangeMin') rangeMinRef!: ElementRef;\r\n\t@ViewChild('rangeMax') rangeMaxRef!: ElementRef;\r\n\r\n\tpriceGapPercentage = 0.1;\r\n\r\n\r\n\tconstructor() {\r\n\t\tthis._filtersService.filters$.subscribe((filters: Filter[]) => {\r\n\t\t\tthis.filters = filters;\r\n\t\t});\r\n\t}\r\n\r\n\tgetSpecificFilter(type: FilterType): Filter | null {\r\n\t\tconst filter = this.filters.find(f => f.type() === type);\r\n\t\tif (!(filter instanceof Filter)) {\r\n\t\t\tconsole.error(`Expected a Filter instance but got`, filter);\r\n\t\t}\r\n\t\treturn filter || null;\r\n\t}\r\n\r\n\t/*Obtiene el filtro elegido en el select, lo pasa al setSelect\r\n\tpara que se marque seleccionado*/\r\n\tonSelect(event: any, filter: FilterElement[] | null) {\r\n\t\tconsole.log(filter)\r\n\t\t/*  const selectedOption = filter\r\n\t\t\t .flatMap(category => category.children)\r\n\t\t\t .filter(option => option?.code === event.target.value)\r\n\t\t\t .pop()\r\n\t\t selectedOption && this._filtersService.setFilterSelected(this.filters[0], selectedOption) */\r\n\t}\r\n\r\n\tsetSelected(filter: Filter | null, selected: FilterElement | null) {\r\n\t\tif (!filter || !selected) {\r\n\t\t\tconsole.error('Filter or selected element is undefined:', { filter, selected });\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (typeof (filter as any).setSelected !== 'function') {\r\n\t\t\tconsole.error('filter.setSelected is not a function. Filter might not be an instance of the expected class:', filter);\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconsole.log(\"Setting selected filter:\", filter);\r\n\t\tconsole.log(\"Setting selected element:\", selected);\r\n\r\n\t\ttry {\r\n\t\t\t// this._filtersService.setFilterSelected(filter, selected);\r\n\t\t\tif (selected.path) {\r\n\t\t\t\tthis.router.navigate([selected.path]);\r\n\t\t\t}\r\n\r\n\r\n\t\t} catch (error) {\r\n\t\t\tconsole.error(\"Error while setting selected filter:\", error);\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t* Redondea al múltiplo de 'step' respetando el redondeo entero:\r\n\t* - Mínimo: redondea hacia abajo.\r\n\t* - Máximo: redondea hacia arriba.\r\n\t*/\r\n\tonRangeChange(event: Event, type: 'min' | 'max', filter: { minPrice: number; maxPrice: number; currentMinPrice?: number; currentMaxPrice?: number }) {\r\n\t\tconst input = event.target as HTMLInputElement;\r\n\t\tlet value = parseInt(input.value, 10);\r\n\t\tvalue = this.roundToNearest(value, 5, type, filter);\r\n\r\n\t\tthis.updateFilterPrices(type, value, filter, this.priceGapPercentage);\r\n\t}\r\n\r\n\troundToNearest(value: number, step: number, type: 'min' | 'max', filter: any): number {\r\n\t\tlet rounded = Math.round(value / step) * step;\r\n\t\tif (type === 'max' && rounded < filter.maxPrice) {\r\n\t\t\trounded = Math.ceil(value / step) * step;\r\n\t\t}\r\n\t\tif (type === 'min' && rounded > filter.minPrice) {\r\n\t\t\trounded = Math.floor(value / step) * step;\r\n\t\t}\r\n\t\treturn rounded;\r\n\t}\r\n\tuniqueSelection(filter: { data: any[]; }, filterChild: any) {\r\n\t\t// Buscar si hay un filtro de tipo PriceRangeFilter en la lista de filtros\r\n\t\t// const priceRangeFilter = this.filters.find(f => f instanceof PriceRangeFilter);\r\n\r\n\t\t// if (priceRangeFilter) {\r\n\t\t// \tpriceRangeFilter.reset();\r\n\t\t// }\r\n\t\tfilter.data.forEach(filterElement => {\r\n\t\t\tif (filterElement.selected) {\r\n\t\t\t\tfilterElement.selected = false;\r\n\t\t\t}\r\n\t\t\tfilterElement.children.forEach((filterChildren: FilterElement) => {\r\n\t\t\t\tif (filterChildren != filterChild && filterChildren.selected) {\r\n\t\t\t\t\tfilterChildren.selected = false;\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   * Actualiza los valores del filtro permitiendo que un input empuje al otro.\r\n  */\r\n\tupdateFilterPrices(type: 'min' | 'max', value: number, filter: any, priceGap: number) {\r\n\t\tconst globalMin = filter.minPrice ?? 0;\r\n\t\tconst globalMax = filter.maxPrice;\r\n\r\n\t\tlet currentMin = filter.currentMinPrice ?? globalMin;\r\n\t\tlet currentMax = filter.currentMaxPrice ?? globalMax;\r\n\r\n\t\tif (type === 'min') {\r\n\t\t\tlet newMin = Math.min(Math.max(value, globalMin), globalMax);\r\n\t\t\tif (newMin + priceGap > currentMax) {\r\n\t\t\t\tlet newMaxCandidate = newMin + priceGap;\r\n\t\t\t\tif (newMaxCandidate <= globalMax) {\r\n\t\t\t\t\tcurrentMax = newMaxCandidate;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tnewMin = globalMax - priceGap;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tfilter.currentMinPrice = newMin;\r\n\t\t\tfilter.currentMaxPrice = currentMax;\r\n\t\t} else if (type === 'max') {\r\n\t\t\tlet newMax = Math.max(Math.min(value, globalMax), globalMin);\r\n\t\t\tif (newMax - priceGap < currentMin) {\r\n\t\t\t\tlet newMinCandidate = newMax - priceGap;\r\n\t\t\t\tif (newMinCandidate >= globalMin) {\r\n\t\t\t\t\tcurrentMin = newMinCandidate;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tnewMax = globalMin + priceGap;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tfilter.currentMaxPrice = newMax;\r\n\t\t\tfilter.currentMinPrice = currentMin;\r\n\t\t}\r\n\t}\r\n\t// Método para actualizar los valores de precio seleccionados\r\n\t// updatePriceRange(min: number, max: number, priceFilter: PriceRangeFilter) {\r\n\t// \tpriceFilter.setSelected(min, max);\r\n\t// \tthis.setSelect(priceFilter);\r\n\t// }\r\n\r\n\t// Métodos para actualizar la barra del filtro por precio\r\n\tcalculateLeftPercentage(currentMinPrice: number, minPrice: number, maxPrice: number): number {\r\n\t\tconst minVal = Math.max(minPrice, Math.min(currentMinPrice ?? minPrice, maxPrice));\r\n\t\treturn Math.max(0, Math.min(((minVal - minPrice) / (maxPrice - minPrice)) * 100, 100));\r\n\t}\r\n\r\n\tcalculateRightPercentage(currentMaxPrice: number, minPrice: number, maxPrice: number): number {\r\n\t\tconst maxVal = Math.max(minPrice, Math.min(currentMaxPrice ?? maxPrice, maxPrice));\r\n\t\treturn Math.max(0, Math.min(100 - ((maxVal - minPrice) / (maxPrice - minPrice)) * 100, 100));\r\n\t}\r\n\r\n\tscrollUp = () => {\r\n\t\twindow.scroll(0, 0);\r\n\t\treturn true\r\n\t}\r\n\r\n}\r\n","<p>filters-ec works!</p>\r\n"]}
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filters-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, ElementRef, ViewChild } from '@angular/core';\r\nimport { FiltersService } from '../../ec-services';\r\nimport { Filter } from '../../classes';\r\nimport { FilterElement, FilterType, PaginationSettings } from '../../interfaces';\r\nimport { ProductsService } from '../../ec-services/products.service';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { Router } from '@angular/router';\r\nimport { PriceRangeFilter } from '../../classes/filters/price_range-filter';\r\n\r\n\r\n@Component({\r\n    selector: 'lib-filters-ec',\r\n    standalone: true,\r\n    imports: [],\r\n    templateUrl: './filters-ec.component.html',\r\n    styleUrl: './filters-ec.component.scss'\r\n})\r\nexport class FiltersEcComponent {\r\n\r\n    private _filtersService: FiltersService = inject(FiltersService);\r\n    private _productsService: ProductsService = inject(ProductsService);\r\n    private _constants: CoreConstantsService = inject(CoreConstantsService);\r\n    private router: Router = inject(Router);\r\n    public filters: Filter[] = [];\r\n    public filter$ = this._filtersService.filters$;\r\n    @Input() setSelect: any;\r\n\r\n    ngOnInit() {\r\n\r\n    }\r\n\r\n    constructor() {\r\n        this._filtersService.filters$.subscribe((filters: Filter[]) => {            \r\n            this.filters = filters;\r\n        });\r\n    }\r\n    /** 1) Para cuando me piden 'price_range', devuelvo PriceRangeFilter */\r\n    public getSpecificFilter(type: 'price_range'): PriceRangeFilter | null;\r\n\r\n    /** 2) Para cualquier otro FilterType, devuelvo Filter */\r\n    public getSpecificFilter(type: FilterType): Filter | null;\r\n    public getSpecificFilter(type: FilterType): Filter | null {\r\n        const filter = this.filters.find(f => f.type() === type);\r\n        if (type === 'price_range' && filter && !(filter instanceof Filter)) {\r\n            console.error(`Expected a Filter instance but got`, filter);\r\n        }\r\n        return filter || null;\r\n    }\r\n\r\n    /*Obtiene el filtro elegido en el select, lo pasa al setSelect\r\n    para que se marque seleccionado*/\r\n    onSelect(event: any, filter: FilterElement[] | null) {\r\n        console.log(filter)\r\n        /*  const selectedOption = filter\r\n             .flatMap(category => category.children)\r\n             .filter(option => option?.code === event.target.value)\r\n             .pop()\r\n         selectedOption && this._filtersService.setFilterSelected(this.filters[0], selectedOption) */\r\n    }\r\n\r\n    setSelected(filter: Filter | null, selected: FilterElement | null) {        \r\n        if (!filter || !selected) {\r\n            console.error('Filter or selected element is undefined:', { filter, selected });\r\n            return;\r\n        }\r\n\r\n        if (typeof (filter as any).setSelected !== 'function') {\r\n            console.error('filter.setSelected is not a function. Filter might not be an instance of the expected class:', filter);\r\n            return;\r\n        }\r\n\r\n        try {\r\n            // this._filtersService.setFilterSelected(filter, selected);\r\n            if (selected.path) {                \r\n                this.router.navigate([selected.path]);\r\n            }\r\n\r\n\r\n        } catch (error) {\r\n            console.error(\"Error while setting selected filter:\", error);\r\n        }\r\n    }\r\n\r\n    uniqueSelection(filter: { data: any[]; }, filterChild: any) {\r\n        // Buscar si hay un filtro de tipo PriceRangeFilter en la lista de filtros\r\n        const priceRangeFilter = this.filters.find(f => f instanceof PriceRangeFilter);        \r\n\r\n        if (priceRangeFilter) {\r\n            priceRangeFilter.reset();\r\n        }\r\n        filter.data.forEach(filterElement => {\r\n            if (filterElement.selected) {\r\n                filterElement.selected = false;\r\n            }\r\n            filterElement.children.forEach((filterChildren: FilterElement) => {\r\n                if (filterChildren != filterChild && filterChildren.selected) {\r\n                    filterChildren.selected = false;\r\n                }\r\n            });\r\n        });\r\n    }\r\n\r\n    //  close = () => {\r\n    //       this.document.getElementById(\"filtros\").classList.remove('in');\r\n    //       return true;\r\n    //  };\r\n\r\n\r\n    close = () => {\r\n        // this.consts.mobile()\r\n        //      ? this.document.getElementById(\"accordionExample\").classList.remove('show')\r\n        //      : this.document.getElementById(accordion_id).classList.remove('show');\r\n        return true;\r\n    };\r\n\r\n\r\n    scrollUp = () => {\r\n        window.scroll(0, 0);\r\n        return true\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n    hasAppliedFilters(): boolean {\r\n        return this.filters?.some((filter: any) => {\r\n            if (filter.type?.() === 'price_range') {\r\n                const minSet = filter.currentMinPrice !== null && filter.currentMinPrice !== 0;\r\n                const maxSet = filter.currentMaxPrice !== null && filter.currentMaxPrice !== filter.maxPrice;\r\n                if (minSet || maxSet) {\r\n                    return true;\r\n                }\r\n            }\r\n\r\n            return filter.data?.some((filterElement: any) => {\r\n                if (Array.isArray(filterElement.children)) {\r\n                    return filterElement.children.some((child: any) => child.selected);\r\n                }\r\n                return filterElement.selected;\r\n            });\r\n        }) ?? false;\r\n    }\r\n\r\n}\r\n","<p>filters-ec works!</p>\r\n"]}
|
|
@@ -31,4 +31,5 @@ export * from './reviews-ec/reviews-ec.component';
|
|
|
31
31
|
export * from './reviews-form-ec/reviews-form-ec.component';
|
|
32
32
|
export * from './section-container-ec/section-container-ec.component';
|
|
33
33
|
export * from './stores-ec/stores-ec.component';
|
|
34
|
-
|
|
34
|
+
export * from './price-range-filter/price-range-filter.component';
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lYXN5Y29tbWVyY2UtdjE4L3NyYy9saWIvZWMtY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLCtEQUErRCxDQUFDO0FBQzlFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYywyREFBMkQsQ0FBQztBQUMxRSxjQUFjLGlFQUFpRSxDQUFDO0FBQ2hGLGNBQWMsK0RBQStELENBQUE7QUFDN0UsY0FBYyxtRUFBbUUsQ0FBQTtBQUNqRixjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHVEQUF1RCxDQUFDO0FBQ3RFLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxtREFBbUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZm9vdGVyLWVjL2Zvb3Rlci1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2hlYWRlci1lYy9oZWFkZXItZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9ob21lLWVjL2hvbWUtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9ibG9ja3MtZWMvYmxvY2tzLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcHJvZHVjdC1lYy9wcm9kdWN0LWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29sbGVjdGlvbi1lYy9jb2xsZWN0aW9uLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZmlsdGVycy1zb3J0LWVjL2ZpbHRlcnMtc29ydC1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldHMtZWMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2F1dGgtZWMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2ZpbHRlcnMtZWMvZmlsdGVycy1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3Byb2R1Y3QtZGV0YWlsLWVjL3Byb2R1Y3QtZGV0YWlsLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vdmFyaWFudHMtZWMvdmFyaWFudHMtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9icmVhZGNydW1iLWVjL2JyZWFkY3J1bWItZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9jYXJ0LWVjJztcclxuZXhwb3J0ICogZnJvbSAnLi9jb3Vwb24tZWMvY291cG9uLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29udGFjdC1lYy9jb250YWN0LWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY2hlY2tvdXQtZWMvY2hlY2tvdXQtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9jaGVja291dC1lYy9zdWNjZXNzLWVjL3N1Y2Nlc3MtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9hY2NvdW50LWVjJztcclxuZXhwb3J0ICogZnJvbSAnLi9ibG9ja3MtZWMvYmxvY2stbmV3c2xldHRlci1lYy9ibG9jay1uZXdzbGV0dGVyLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYmxvY2tzLWVjL2Jsb2NrLWh0bWwtZWMvYmxvY2staHRtbC1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2Jsb2Nrcy1lYy9ibG9jay1wcm9kdWN0cy1lYy9ibG9jay1wcm9kdWN0cy1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2Jsb2Nrcy1lYy9ibG9jay1iYW5uZXItZnVsbC1lYy9ibG9jay1iYW5uZXItZnVsbC1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2Jsb2Nrcy1lYy9ibG9jay1iYW5uZXItYm94LWVjL2Jsb2NrLWJhbm5lci1ib3gtZWMuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2Jsb2Nrcy1lYy9ibG9jay1mb3JtLWNvbnRhY3QtZWMvYmxvY2stZm9ybS1jb250YWN0LWVjLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9zaWRlYmFyLWVjL3NpZGViYXItZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9yZWxhdGVkLXByb2R1Y3RzLWVjL3JlbGF0ZWQtcHJvZHVjdHMtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9mYXFzLWVjL2ZhcXMtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9zaGFyZS1lYy9zaGFyZS1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3Jldmlld3MtZWMvcmV2aWV3cy1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3Jldmlld3MtZm9ybS1lYy9yZXZpZXdzLWZvcm0tZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9zZWN0aW9uLWNvbnRhaW5lci1lYy9zZWN0aW9uLWNvbnRhaW5lci1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3N0b3Jlcy1lYy9zdG9yZXMtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9wcmljZS1yYW5nZS1maWx0ZXIvcHJpY2UtcmFuZ2UtZmlsdGVyLmNvbXBvbmVudCc7Il19
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output } from '@angular/core';
|
|
2
|
+
import { PriceRangeFilter } from '../../classes/filters/price_range-filter';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import { EcCurrencySymbolPipe } from '../../ec-pipe';
|
|
5
|
+
import { FiltersService } from '../../ec-services';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
export class PriceRangeFilterComponent {
|
|
9
|
+
_filtersService = inject(FiltersService);
|
|
10
|
+
priceGap = 1;
|
|
11
|
+
roundStep = 5;
|
|
12
|
+
filter;
|
|
13
|
+
rangeChanged = new EventEmitter();
|
|
14
|
+
getSliderStyle(filter) {
|
|
15
|
+
if (!(filter instanceof PriceRangeFilter))
|
|
16
|
+
return { left: '0%', right: '0%' };
|
|
17
|
+
const left = this.calculateLeftPercentage(filter);
|
|
18
|
+
const right = this.calculateRightPercentage(filter);
|
|
19
|
+
return { left: `${left}%`, right: `${right}%` };
|
|
20
|
+
}
|
|
21
|
+
// Métodos para actualizar la barra del filtro por precio
|
|
22
|
+
calculateLeftPercentage(filter) {
|
|
23
|
+
if (!(filter instanceof PriceRangeFilter))
|
|
24
|
+
return 0;
|
|
25
|
+
const min = filter.minPrice;
|
|
26
|
+
const max = filter.maxPrice;
|
|
27
|
+
const currentMin = filter.currentMinPrice ?? min;
|
|
28
|
+
const clampedMin = Math.max(min, Math.min(currentMin, max));
|
|
29
|
+
return Math.max(0, Math.min(((clampedMin - min) / (max - min)) * 100, 100));
|
|
30
|
+
}
|
|
31
|
+
calculateRightPercentage(filter) {
|
|
32
|
+
if (!(filter instanceof PriceRangeFilter))
|
|
33
|
+
return 0;
|
|
34
|
+
const min = filter.minPrice;
|
|
35
|
+
const max = filter.maxPrice;
|
|
36
|
+
const currentMax = filter.currentMaxPrice ?? max;
|
|
37
|
+
const clampedMax = Math.max(min, Math.min(currentMax, max));
|
|
38
|
+
return Math.max(0, Math.min(100 - ((clampedMax - min) / (max - min)) * 100, 100));
|
|
39
|
+
}
|
|
40
|
+
// Método para actualizar los valores de precio seleccionados
|
|
41
|
+
updatePriceRange(filter) {
|
|
42
|
+
if (!(filter instanceof PriceRangeFilter))
|
|
43
|
+
return;
|
|
44
|
+
const min = filter.currentMinPrice ?? filter.minPrice;
|
|
45
|
+
const max = filter.currentMaxPrice ?? filter.maxPrice;
|
|
46
|
+
this._filtersService.updatePriceRangeFilter(min, max);
|
|
47
|
+
}
|
|
48
|
+
getMinValue(filter) {
|
|
49
|
+
return (filter instanceof PriceRangeFilter && filter.currentMinPrice != null)
|
|
50
|
+
? filter.currentMinPrice
|
|
51
|
+
: filter.minPrice;
|
|
52
|
+
}
|
|
53
|
+
getMaxValue(filter) {
|
|
54
|
+
return (filter instanceof PriceRangeFilter && filter.currentMaxPrice != null)
|
|
55
|
+
? filter.currentMaxPrice
|
|
56
|
+
: filter.maxPrice;
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Redondea al múltiplo de 'step' respetando el redondeo entero:
|
|
60
|
+
* - Mínimo: redondea hacia abajo.
|
|
61
|
+
* - Máximo: redondea hacia arriba.
|
|
62
|
+
*/
|
|
63
|
+
onRangeChange(event, type, filter) {
|
|
64
|
+
const input = event.target;
|
|
65
|
+
let value = parseFloat(input.value);
|
|
66
|
+
value = this.roundToNearest(value, this.roundStep, type, filter);
|
|
67
|
+
this.updateFilterPrices(type, value, filter, this.priceGap);
|
|
68
|
+
}
|
|
69
|
+
roundToNearest(value, step, type, filter) {
|
|
70
|
+
let rounded = Math.round(value / step) * step;
|
|
71
|
+
if (type === 'max' && rounded < filter.maxPrice) {
|
|
72
|
+
rounded = Math.ceil(value / step) * step;
|
|
73
|
+
}
|
|
74
|
+
if (type === 'min' && rounded > filter.minPrice) {
|
|
75
|
+
rounded = Math.floor(value / step) * step;
|
|
76
|
+
}
|
|
77
|
+
return rounded;
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Actualiza los valores del filtro permitiendo que un input empuje al otro.
|
|
81
|
+
*/
|
|
82
|
+
updateFilterPrices(type, value, filter, priceGap) {
|
|
83
|
+
const globalMin = filter.minPrice ?? 0;
|
|
84
|
+
const globalMax = filter.maxPrice;
|
|
85
|
+
let currentMin = filter.currentMinPrice ?? globalMin;
|
|
86
|
+
let currentMax = filter.currentMaxPrice ?? globalMax;
|
|
87
|
+
if (type === 'min') {
|
|
88
|
+
let newMin = Math.min(Math.max(value, globalMin), globalMax);
|
|
89
|
+
if (newMin + priceGap > currentMax) {
|
|
90
|
+
let newMaxCandidate = newMin + priceGap;
|
|
91
|
+
if (newMaxCandidate <= globalMax) {
|
|
92
|
+
currentMax = newMaxCandidate;
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
newMin = globalMax - priceGap;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
filter.currentMinPrice = newMin;
|
|
99
|
+
filter.currentMaxPrice = currentMax;
|
|
100
|
+
}
|
|
101
|
+
else if (type === 'max') {
|
|
102
|
+
let newMax = Math.max(Math.min(value, globalMax), globalMin);
|
|
103
|
+
if (newMax - priceGap < currentMin) {
|
|
104
|
+
let newMinCandidate = newMax - priceGap;
|
|
105
|
+
if (newMinCandidate >= globalMin) {
|
|
106
|
+
currentMin = newMinCandidate;
|
|
107
|
+
}
|
|
108
|
+
else {
|
|
109
|
+
newMax = globalMin + priceGap;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
filter.currentMaxPrice = newMax;
|
|
113
|
+
filter.currentMinPrice = currentMin;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
scrollUp = () => {
|
|
117
|
+
window.scroll(0, 0);
|
|
118
|
+
return true;
|
|
119
|
+
};
|
|
120
|
+
getFormattedMinPrice(filter) {
|
|
121
|
+
const value = (filter instanceof PriceRangeFilter && filter.currentMinPrice != null)
|
|
122
|
+
? filter.currentMinPrice
|
|
123
|
+
: filter.minPrice;
|
|
124
|
+
return value;
|
|
125
|
+
}
|
|
126
|
+
getFormattedMaxPrice(filter) {
|
|
127
|
+
const value = (filter instanceof PriceRangeFilter && filter.currentMaxPrice != null)
|
|
128
|
+
? filter.currentMaxPrice
|
|
129
|
+
: filter.maxPrice;
|
|
130
|
+
return value;
|
|
131
|
+
}
|
|
132
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PriceRangeFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
133
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: PriceRangeFilterComponent, isStandalone: true, selector: "lib-price-range-filter", inputs: { filter: "filter" }, outputs: { rangeChanged: "rangeChanged" }, ngImport: i0, template: "<div class=\"slider\">\r\n <div class=\"slider\">\r\n <div class=\"progress\" [ngStyle]=\"getSliderStyle(filter)\">\r\n </div>\r\n </div>\r\n</div>\r\n<div class=\"range-input d-flex gap-2\">\r\n <input #rangeMin type=\"range\" class=\"range-min\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\r\n [value]=\"getMinValue(filter)\" (input)=\"onRangeChange($event, 'min', filter)\"\r\n (change)=\"updatePriceRange(filter); scrollUp()\">\r\n <input #rangeMax type=\"range\" class=\"range-max\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\r\n [value]=\"getMaxValue(filter)\" (input)=\"onRangeChange($event, 'max', filter)\"\r\n (change)=\"updatePriceRange(filter); scrollUp()\">\r\n</div>\r\n<!-- precios M\u00EDnimo / M\u00E1ximo -->\r\n<div class=\"price-container mt-2\">\r\n <div class=\"price-label-wrapper\">\r\n <span class=\"price-label\">M\u00EDnimo:</span>\r\n <span class=\"price-value\">\r\n {{ (getFormattedMinPrice(filter) | ecCurrencySymbol) || '0' }}\r\n </span>\r\n </div>\r\n <div class=\"price-label-wrapper\">\r\n <span class=\"price-label\">M\u00E1ximo:</span>\r\n <span class=\"price-value price-value-right\">\r\n {{ getFormattedMaxPrice(filter) | ecCurrencySymbol }}\r\n </span>\r\n </div>\r\n</div>", styles: [":root{--slider-bg: #ddd;--slider-progress-bg: #0FA3AF;--thumb-bg: #0FA3AF;--thumb-border: #fff;--text-color: #131716;--label-color: #0FA3AF;--shadow-color: rgba(15, 163, 175, .4)}.slider{height:6px;border-radius:5px;background:var(--slider-bg);position:relative;overflow:hidden}.slider .progress{height:6px;position:absolute;left:0;right:0;border-radius:5px;background:var(--slider-progress-bg)}.range-input{position:relative;margin-bottom:14px}.range-input input[type=range]{position:absolute;top:-5px;width:100%;height:5px;background:none;pointer-events:none;-webkit-appearance:none}.range-input input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;pointer-events:auto;height:20px;width:20px;border-radius:50%;background:var(--thumb-bg);border:3px solid var(--thumb-border);cursor:pointer;box-shadow:0 4px 8px #0003}.range-input input[type=range]::-moz-range-thumb{-moz-appearance:none;pointer-events:auto;height:20px;width:20px;border-radius:50%;background:var(--thumb-bg);border:3px solid var(--thumb-border);cursor:pointer;box-shadow:0 4px 8px #0003}.range-input input[type=range]:focus::-webkit-slider-thumb,.range-input input[type=range]:focus::-moz-range-thumb{box-shadow:0 0 0 4px var(--shadow-color);outline:none}.price-container{display:flex;flex-wrap:wrap;gap:1rem}.price-label-wrapper{display:flex;flex-direction:column;flex:0 1 auto;min-width:0}.price-label{font-weight:600;color:var(--label-color);margin-bottom:.25rem}.price-value{white-space:nowrap;font-weight:700;color:var(--text-color);overflow:hidden;text-overflow:ellipsis;font-size:14px}.price-value-right{text-align:right}\n"], dependencies: [{ kind: "pipe", type: EcCurrencySymbolPipe, name: "ecCurrencySymbol" }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
134
|
+
}
|
|
135
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PriceRangeFilterComponent, decorators: [{
|
|
136
|
+
type: Component,
|
|
137
|
+
args: [{ selector: 'lib-price-range-filter', standalone: true, imports: [EcCurrencySymbolPipe, CommonModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"slider\">\r\n <div class=\"slider\">\r\n <div class=\"progress\" [ngStyle]=\"getSliderStyle(filter)\">\r\n </div>\r\n </div>\r\n</div>\r\n<div class=\"range-input d-flex gap-2\">\r\n <input #rangeMin type=\"range\" class=\"range-min\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\r\n [value]=\"getMinValue(filter)\" (input)=\"onRangeChange($event, 'min', filter)\"\r\n (change)=\"updatePriceRange(filter); scrollUp()\">\r\n <input #rangeMax type=\"range\" class=\"range-max\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\r\n [value]=\"getMaxValue(filter)\" (input)=\"onRangeChange($event, 'max', filter)\"\r\n (change)=\"updatePriceRange(filter); scrollUp()\">\r\n</div>\r\n<!-- precios M\u00EDnimo / M\u00E1ximo -->\r\n<div class=\"price-container mt-2\">\r\n <div class=\"price-label-wrapper\">\r\n <span class=\"price-label\">M\u00EDnimo:</span>\r\n <span class=\"price-value\">\r\n {{ (getFormattedMinPrice(filter) | ecCurrencySymbol) || '0' }}\r\n </span>\r\n </div>\r\n <div class=\"price-label-wrapper\">\r\n <span class=\"price-label\">M\u00E1ximo:</span>\r\n <span class=\"price-value price-value-right\">\r\n {{ getFormattedMaxPrice(filter) | ecCurrencySymbol }}\r\n </span>\r\n </div>\r\n</div>", styles: [":root{--slider-bg: #ddd;--slider-progress-bg: #0FA3AF;--thumb-bg: #0FA3AF;--thumb-border: #fff;--text-color: #131716;--label-color: #0FA3AF;--shadow-color: rgba(15, 163, 175, .4)}.slider{height:6px;border-radius:5px;background:var(--slider-bg);position:relative;overflow:hidden}.slider .progress{height:6px;position:absolute;left:0;right:0;border-radius:5px;background:var(--slider-progress-bg)}.range-input{position:relative;margin-bottom:14px}.range-input input[type=range]{position:absolute;top:-5px;width:100%;height:5px;background:none;pointer-events:none;-webkit-appearance:none}.range-input input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;pointer-events:auto;height:20px;width:20px;border-radius:50%;background:var(--thumb-bg);border:3px solid var(--thumb-border);cursor:pointer;box-shadow:0 4px 8px #0003}.range-input input[type=range]::-moz-range-thumb{-moz-appearance:none;pointer-events:auto;height:20px;width:20px;border-radius:50%;background:var(--thumb-bg);border:3px solid var(--thumb-border);cursor:pointer;box-shadow:0 4px 8px #0003}.range-input input[type=range]:focus::-webkit-slider-thumb,.range-input input[type=range]:focus::-moz-range-thumb{box-shadow:0 0 0 4px var(--shadow-color);outline:none}.price-container{display:flex;flex-wrap:wrap;gap:1rem}.price-label-wrapper{display:flex;flex-direction:column;flex:0 1 auto;min-width:0}.price-label{font-weight:600;color:var(--label-color);margin-bottom:.25rem}.price-value{white-space:nowrap;font-weight:700;color:var(--text-color);overflow:hidden;text-overflow:ellipsis;font-size:14px}.price-value-right{text-align:right}\n"] }]
|
|
138
|
+
}], propDecorators: { filter: [{
|
|
139
|
+
type: Input
|
|
140
|
+
}], rangeChanged: [{
|
|
141
|
+
type: Output
|
|
142
|
+
}] } });
|
|
143
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"price-range-filter.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/price-range-filter/price-range-filter.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/price-range-filter/price-range-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output } from '@angular/core';\r\nimport { PriceRangeFilter } from '../../classes/filters/price_range-filter';\r\nimport { CommonModule } from '@angular/common';\r\nimport { EcCurrencySymbolPipe } from '../../ec-pipe';\r\nimport { FiltersService } from '../../ec-services';\r\n\r\n@Component({\r\n  selector: 'lib-price-range-filter',\r\n  standalone: true,\r\n  imports: [EcCurrencySymbolPipe, CommonModule],\r\n  templateUrl: './price-range-filter.component.html',\r\n  styleUrl: './price-range-filter.component.scss',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class PriceRangeFilterComponent {\r\n\r\n  private _filtersService: FiltersService = inject(FiltersService);\r\n\r\n  priceGap = 1;\r\n  roundStep = 5;\r\n\r\n  @Input() filter!: PriceRangeFilter;\r\n  @Output() rangeChanged = new EventEmitter<{ min: number; max: number }>();\r\n\r\n  getSliderStyle(filter: any): { [klass: string]: string } {\r\n    if (!(filter instanceof PriceRangeFilter)) return { left: '0%', right: '0%' };\r\n\r\n    const left = this.calculateLeftPercentage(filter);\r\n    const right = this.calculateRightPercentage(filter);\r\n    return { left: `${left}%`, right: `${right}%` };\r\n  }\r\n\r\n  // Métodos para actualizar la barra del filtro por precio\r\n  calculateLeftPercentage(filter: any): number {\r\n    if (!(filter instanceof PriceRangeFilter)) return 0;\r\n\r\n    const min = filter.minPrice;\r\n    const max = filter.maxPrice;\r\n    const currentMin = filter.currentMinPrice ?? min;\r\n\r\n    const clampedMin = Math.max(min, Math.min(currentMin, max));\r\n    return Math.max(0, Math.min(((clampedMin - min) / (max - min)) * 100, 100));\r\n  }\r\n\r\n  calculateRightPercentage(filter: any): number {\r\n    if (!(filter instanceof PriceRangeFilter)) return 0;\r\n\r\n    const min = filter.minPrice;\r\n    const max = filter.maxPrice;\r\n    const currentMax = filter.currentMaxPrice ?? max;\r\n\r\n    const clampedMax = Math.max(min, Math.min(currentMax, max));\r\n    return Math.max(0, Math.min(100 - ((clampedMax - min) / (max - min)) * 100, 100));\r\n  }\r\n\r\n  // Método para actualizar los valores de precio seleccionados\r\n  updatePriceRange(filter: any) {\r\n    if (!(filter instanceof PriceRangeFilter)) return;\r\n\r\n    const min = filter.currentMinPrice ?? filter.minPrice;\r\n    const max = filter.currentMaxPrice ?? filter.maxPrice;\r\n    this._filtersService.updatePriceRangeFilter(min, max);\r\n  }\r\n\r\n  getMinValue(filter: any): number {\r\n    return (filter instanceof PriceRangeFilter && filter.currentMinPrice != null)\r\n      ? filter.currentMinPrice\r\n      : filter.minPrice;\r\n  }\r\n\r\n  getMaxValue(filter: any): number {\r\n    return (filter instanceof PriceRangeFilter && filter.currentMaxPrice != null)\r\n      ? filter.currentMaxPrice\r\n      : filter.maxPrice;\r\n  }\r\n\r\n  /**\r\n  * Redondea al múltiplo de 'step' respetando el redondeo entero:\r\n  * - Mínimo: redondea hacia abajo.\r\n  * - Máximo: redondea hacia arriba.\r\n  */\r\n  onRangeChange(event: Event, type: 'min' | 'max', filter: any) {\r\n    const input = event.target as HTMLInputElement;\r\n    let value = parseFloat(input.value);\r\n    value = this.roundToNearest(value, this.roundStep, type, filter);\r\n    this.updateFilterPrices(type, value, filter, this.priceGap);\r\n  }\r\n\r\n  protected roundToNearest(value: number, step: number, type: 'min' | 'max', filter: any): number {\r\n    let rounded = Math.round(value / step) * step;\r\n    if (type === 'max' && rounded < filter.maxPrice) {\r\n      rounded = Math.ceil(value / step) * step;\r\n    }\r\n    if (type === 'min' && rounded > filter.minPrice) {\r\n      rounded = Math.floor(value / step) * step;\r\n    }\r\n    return rounded;\r\n  }\r\n\r\n  /**\r\n  * Actualiza los valores del filtro permitiendo que un input empuje al otro.\r\n  */\r\n  protected updateFilterPrices(type: 'min' | 'max', value: number, filter: any, priceGap: number) {\r\n    const globalMin = filter.minPrice ?? 0;\r\n    const globalMax = filter.maxPrice;\r\n\r\n    let currentMin = filter.currentMinPrice ?? globalMin;\r\n    let currentMax = filter.currentMaxPrice ?? globalMax;\r\n\r\n    if (type === 'min') {\r\n      let newMin = Math.min(Math.max(value, globalMin), globalMax);\r\n      if (newMin + priceGap > currentMax) {\r\n        let newMaxCandidate = newMin + priceGap;\r\n        if (newMaxCandidate <= globalMax) {\r\n          currentMax = newMaxCandidate;\r\n        } else {\r\n          newMin = globalMax - priceGap;\r\n        }\r\n      }\r\n      filter.currentMinPrice = newMin;\r\n      filter.currentMaxPrice = currentMax;\r\n    } else if (type === 'max') {\r\n      let newMax = Math.max(Math.min(value, globalMax), globalMin);\r\n      if (newMax - priceGap < currentMin) {\r\n        let newMinCandidate = newMax - priceGap;\r\n        if (newMinCandidate >= globalMin) {\r\n          currentMin = newMinCandidate;\r\n        } else {\r\n          newMax = globalMin + priceGap;\r\n        }\r\n      }\r\n      filter.currentMaxPrice = newMax;\r\n      filter.currentMinPrice = currentMin;\r\n    }\r\n  }\r\n\r\n  scrollUp = () => {\r\n    window.scroll(0, 0);\r\n    return true\r\n  }\r\n\r\n  getFormattedMinPrice(filter: any): string {\r\n    const value = (filter instanceof PriceRangeFilter && filter.currentMinPrice != null)\r\n      ? filter.currentMinPrice\r\n      : filter.minPrice;\r\n    return value;\r\n  }\r\n\r\n  getFormattedMaxPrice(filter: any): string {\r\n    const value = (filter instanceof PriceRangeFilter && filter.currentMaxPrice != null)\r\n      ? filter.currentMaxPrice\r\n      : filter.maxPrice;\r\n    return value;\r\n  }\r\n}\r\n","<div class=\"slider\">\r\n    <div class=\"slider\">\r\n        <div class=\"progress\" [ngStyle]=\"getSliderStyle(filter)\">\r\n        </div>\r\n    </div>\r\n</div>\r\n<div class=\"range-input d-flex gap-2\">\r\n    <input #rangeMin type=\"range\" class=\"range-min\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\r\n        [value]=\"getMinValue(filter)\" (input)=\"onRangeChange($event, 'min', filter)\"\r\n        (change)=\"updatePriceRange(filter); scrollUp()\">\r\n    <input #rangeMax type=\"range\" class=\"range-max\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\r\n        [value]=\"getMaxValue(filter)\" (input)=\"onRangeChange($event, 'max', filter)\"\r\n        (change)=\"updatePriceRange(filter); scrollUp()\">\r\n</div>\r\n<!-- precios Mínimo / Máximo -->\r\n<div class=\"price-container mt-2\">\r\n    <div class=\"price-label-wrapper\">\r\n        <span class=\"price-label\">Mínimo:</span>\r\n        <span class=\"price-value\">\r\n            {{ (getFormattedMinPrice(filter) | ecCurrencySymbol) || '0' }}\r\n        </span>\r\n    </div>\r\n    <div class=\"price-label-wrapper\">\r\n        <span class=\"price-label\">Máximo:</span>\r\n        <span class=\"price-value price-value-right\">\r\n            {{ getFormattedMaxPrice(filter) | ecCurrencySymbol }}\r\n        </span>\r\n    </div>\r\n</div>"]}
|