@wlcm/angular 18.2.3 → 18.2.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. package/filters/esm2022/index.mjs +6 -8
  2. package/filters/esm2022/lib/components/filters-group/filters-group.component.mjs +13 -0
  3. package/filters/esm2022/lib/constants/filter.constants.mjs +3 -0
  4. package/filters/esm2022/lib/constants/index.mjs +2 -0
  5. package/filters/esm2022/lib/directives/filter.directive.mjs +11 -0
  6. package/filters/esm2022/lib/directives/index.mjs +2 -0
  7. package/filters/esm2022/lib/filters.module.mjs +20 -0
  8. package/filters/esm2022/lib/models/array-filter.models.mjs +73 -0
  9. package/filters/esm2022/lib/models/filter.models.mjs +41 -0
  10. package/filters/esm2022/lib/models/filters-group.models.mjs +60 -0
  11. package/filters/esm2022/lib/models/index.mjs +4 -0
  12. package/filters/fesm2022/wlcm-angular-filters.mjs +159 -420
  13. package/filters/fesm2022/wlcm-angular-filters.mjs.map +1 -1
  14. package/filters/index.d.ts +5 -7
  15. package/filters/lib/components/filters-group/filters-group.component.d.ts +6 -0
  16. package/filters/lib/constants/filter.constants.d.ts +3 -0
  17. package/filters/lib/constants/index.d.ts +1 -0
  18. package/filters/lib/directives/filter.directive.d.ts +5 -0
  19. package/filters/lib/directives/index.d.ts +1 -0
  20. package/filters/lib/filters.module.d.ts +9 -0
  21. package/filters/lib/models/array-filter.models.d.ts +19 -0
  22. package/filters/lib/models/filter.models.d.ts +19 -0
  23. package/filters/lib/models/filters-group.models.d.ts +22 -0
  24. package/filters/lib/models/index.d.ts +3 -0
  25. package/forms/esm2022/lib/forms/components/autocomplete/autocomplete.component.mjs +7 -5
  26. package/forms/fesm2022/wlcm-angular-forms.mjs +5 -3
  27. package/forms/fesm2022/wlcm-angular-forms.mjs.map +1 -1
  28. package/forms/lib/forms/components/autocomplete/autocomplete.component.d.ts +4 -1
  29. package/package.json +1 -1
  30. package/styles/components/forms/_select.scss +6 -0
  31. package/styles/core/_all-theme.scss +0 -2
  32. package/filters/esm2022/lib/filters/components/filters/filters.component.mjs +0 -21
  33. package/filters/esm2022/lib/filters/components/filters-button/filters-button.component.mjs +0 -25
  34. package/filters/esm2022/lib/filters/components/filters-panel/filters-panel.component.mjs +0 -86
  35. package/filters/esm2022/lib/filters/components/filters-unit/filters-unit.component.mjs +0 -55
  36. package/filters/esm2022/lib/filters/directives/filters-content.directive.mjs +0 -11
  37. package/filters/esm2022/lib/filters/directives/filters-trigger.directive.mjs +0 -69
  38. package/filters/esm2022/lib/filters/filters.module.mjs +0 -53
  39. package/filters/esm2022/lib/filters/models/filters-default-selection-model.mjs +0 -56
  40. package/filters/esm2022/lib/filters/models/filters-trigger.base.mjs +0 -56
  41. package/filters/esm2022/lib/filters/models/filters.models.mjs +0 -44
  42. package/filters/esm2022/lib/filters/pipes/is-filters-param-checked.pipe.mjs +0 -21
  43. package/filters/esm2022/lib/filters/pipes/total-filters-applied.pipe.mjs +0 -18
  44. package/filters/esm2022/lib/filters/utils/filters.utils.mjs +0 -13
  45. package/filters/lib/filters/components/filters/filters.component.d.ts +0 -10
  46. package/filters/lib/filters/components/filters-button/filters-button.component.d.ts +0 -11
  47. package/filters/lib/filters/components/filters-panel/filters-panel.component.d.ts +0 -25
  48. package/filters/lib/filters/components/filters-unit/filters-unit.component.d.ts +0 -21
  49. package/filters/lib/filters/directives/filters-content.directive.d.ts +0 -5
  50. package/filters/lib/filters/directives/filters-trigger.directive.d.ts +0 -22
  51. package/filters/lib/filters/filters.module.d.ts +0 -20
  52. package/filters/lib/filters/models/filters-default-selection-model.d.ts +0 -18
  53. package/filters/lib/filters/models/filters-trigger.base.d.ts +0 -15
  54. package/filters/lib/filters/models/filters.models.d.ts +0 -42
  55. package/filters/lib/filters/pipes/is-filters-param-checked.pipe.d.ts +0 -10
  56. package/filters/lib/filters/pipes/total-filters-applied.pipe.d.ts +0 -8
  57. package/filters/lib/filters/utils/filters.utils.d.ts +0 -5
  58. package/styles/components/filters/_filters-panel.scss +0 -44
  59. package/styles/components/filters/_filters-unit.scss +0 -92
  60. package/styles/components/filters/index.scss +0 -7
@@ -1,21 +0,0 @@
1
- import { Host, Pipe } from '@angular/core';
2
- import { MatCheckbox } from '@angular/material/checkbox';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/material/checkbox";
5
- export class IsFiltersParamCheckedPipe {
6
- transform(data) {
7
- return data.has(this.checkbox.value);
8
- }
9
- constructor(checkbox) {
10
- this.checkbox = checkbox;
11
- }
12
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: IsFiltersParamCheckedPipe, deps: [{ token: i1.MatCheckbox, host: true }], target: i0.ɵɵFactoryTarget.Pipe }); }
13
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.6", ngImport: i0, type: IsFiltersParamCheckedPipe, name: "isFiltersParamChecked" }); }
14
- }
15
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: IsFiltersParamCheckedPipe, decorators: [{
16
- type: Pipe,
17
- args: [{ name: 'isFiltersParamChecked' }]
18
- }], ctorParameters: () => [{ type: i1.MatCheckbox, decorators: [{
19
- type: Host
20
- }] }] });
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtZmlsdGVycy1wYXJhbS1jaGVja2VkLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9tb2R1bGVzL2ZpbHRlcnMvc3JjL2xpYi9maWx0ZXJzL3BpcGVzL2lzLWZpbHRlcnMtcGFyYW0tY2hlY2tlZC5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUMxRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sNEJBQTRCLENBQUM7OztBQUd6RCxNQUFNLE9BQU8seUJBQXlCO0lBQ3BDLFNBQVMsQ0FBQyxJQUFpQjtRQUN6QixPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN2QyxDQUFDO0lBRUQsWUFBNEIsUUFBcUI7UUFBckIsYUFBUSxHQUFSLFFBQVEsQ0FBYTtJQUFHLENBQUM7OEdBTDFDLHlCQUF5Qjs0R0FBekIseUJBQXlCOzsyRkFBekIseUJBQXlCO2tCQURyQyxJQUFJO21CQUFDLEVBQUUsSUFBSSxFQUFFLHVCQUF1QixFQUFFOzswQkFNeEIsSUFBSSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhvc3QsIFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdENoZWNrYm94IH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY2hlY2tib3gnO1xuXG5AUGlwZSh7IG5hbWU6ICdpc0ZpbHRlcnNQYXJhbUNoZWNrZWQnIH0pXG5leHBvcnQgY2xhc3MgSXNGaWx0ZXJzUGFyYW1DaGVja2VkUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICB0cmFuc2Zvcm0oZGF0YTogU2V0PHN0cmluZz4pOiBib29sZWFuIHtcbiAgICByZXR1cm4gZGF0YS5oYXModGhpcy5jaGVja2JveC52YWx1ZSk7XG4gIH1cblxuICBjb25zdHJ1Y3RvcihASG9zdCgpIHByaXZhdGUgY2hlY2tib3g6IE1hdENoZWNrYm94KSB7fVxufVxuIl19
@@ -1,18 +0,0 @@
1
- import { Pipe } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class WlcmTotalFiltersAppliedPipe {
4
- transform(filters) {
5
- if (!filters)
6
- return 0;
7
- return Object.values(filters).reduce((total, filter) => {
8
- return total + (filter.oneOf?.length || 0);
9
- }, 0);
10
- }
11
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmTotalFiltersAppliedPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
12
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.6", ngImport: i0, type: WlcmTotalFiltersAppliedPipe, isStandalone: true, name: "totalFiltersApplied" }); }
13
- }
14
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmTotalFiltersAppliedPipe, decorators: [{
15
- type: Pipe,
16
- args: [{ name: 'totalFiltersApplied', standalone: true }]
17
- }] });
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG90YWwtZmlsdGVycy1hcHBsaWVkLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9tb2R1bGVzL2ZpbHRlcnMvc3JjL2xpYi9maWx0ZXJzL3BpcGVzL3RvdGFsLWZpbHRlcnMtYXBwbGllZC5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOztBQUlwRCxNQUFNLE9BQU8sMkJBQTJCO0lBQ3RDLFNBQVMsQ0FBQyxPQUFpQztRQUN6QyxJQUFJLENBQUMsT0FBTztZQUFFLE9BQU8sQ0FBQyxDQUFDO1FBRXZCLE9BQU8sTUFBTSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxLQUFhLEVBQUUsTUFBbUIsRUFBRSxFQUFFO1lBQzFFLE9BQU8sS0FBSyxHQUFHLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxNQUFNLElBQUksQ0FBQyxDQUFDLENBQUM7UUFDN0MsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ1IsQ0FBQzs4R0FQVSwyQkFBMkI7NEdBQTNCLDJCQUEyQjs7MkZBQTNCLDJCQUEyQjtrQkFEdkMsSUFBSTttQkFBQyxFQUFFLElBQUksRUFBRSxxQkFBcUIsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUXVlcnlGaWx0ZXIsIFF1ZXJ5RmlsdGVycyB9IGZyb20gJ0B3bGNtL2FuZ3VsYXIvY29yZSc7XG5cbkBQaXBlKHsgbmFtZTogJ3RvdGFsRmlsdGVyc0FwcGxpZWQnLCBzdGFuZGFsb25lOiB0cnVlIH0pXG5leHBvcnQgY2xhc3MgV2xjbVRvdGFsRmlsdGVyc0FwcGxpZWRQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIHRyYW5zZm9ybShmaWx0ZXJzOiBRdWVyeUZpbHRlcnMgfCB1bmRlZmluZWQpOiBudW1iZXIge1xuICAgIGlmICghZmlsdGVycykgcmV0dXJuIDA7XG5cbiAgICByZXR1cm4gT2JqZWN0LnZhbHVlcyhmaWx0ZXJzKS5yZWR1Y2UoKHRvdGFsOiBudW1iZXIsIGZpbHRlcjogUXVlcnlGaWx0ZXIpID0+IHtcbiAgICAgIHJldHVybiB0b3RhbCArIChmaWx0ZXIub25lT2Y/Lmxlbmd0aCB8fCAwKTtcbiAgICB9LCAwKTtcbiAgfVxufVxuIl19
@@ -1,13 +0,0 @@
1
- export class WlcmFiltersUtils {
2
- static modelToQueryFilters(model) {
3
- const filters = {};
4
- Object.keys(model).forEach((key) => {
5
- const data = model[key].data;
6
- if (data.length > 0) {
7
- filters[key] = { oneOf: data };
8
- }
9
- });
10
- return filters;
11
- }
12
- }
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVycy51dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL21vZHVsZXMvZmlsdGVycy9zcmMvbGliL2ZpbHRlcnMvdXRpbHMvZmlsdGVycy51dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxLQUF1QjtRQUNoRCxNQUFNLE9BQU8sR0FBaUIsRUFBRSxDQUFDO1FBRWpDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsR0FBVyxFQUFFLEVBQUU7WUFDekMsTUFBTSxJQUFJLEdBQWEsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQztZQUV2QyxJQUFJLElBQUksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7Z0JBQ3BCLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQWlCLENBQUM7WUFDaEQsQ0FBQztRQUNILENBQUMsQ0FBQyxDQUFDO1FBRUgsT0FBTyxPQUFPLENBQUM7SUFDakIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUXVlcnlGaWx0ZXIsIFF1ZXJ5RmlsdGVycyB9IGZyb20gJ0B3bGNtL2FuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBXbGNtRmlsdGVyc01vZGVsIH0gZnJvbSAnLi4vbW9kZWxzL2ZpbHRlcnMubW9kZWxzJztcblxuZXhwb3J0IGNsYXNzIFdsY21GaWx0ZXJzVXRpbHMge1xuICBzdGF0aWMgbW9kZWxUb1F1ZXJ5RmlsdGVycyhtb2RlbDogV2xjbUZpbHRlcnNNb2RlbCk6IFF1ZXJ5RmlsdGVycyB7XG4gICAgY29uc3QgZmlsdGVyczogUXVlcnlGaWx0ZXJzID0ge307XG5cbiAgICBPYmplY3Qua2V5cyhtb2RlbCkuZm9yRWFjaCgoa2V5OiBzdHJpbmcpID0+IHtcbiAgICAgIGNvbnN0IGRhdGE6IHN0cmluZ1tdID0gbW9kZWxba2V5XS5kYXRhO1xuXG4gICAgICBpZiAoZGF0YS5sZW5ndGggPiAwKSB7XG4gICAgICAgIGZpbHRlcnNba2V5XSA9IHsgb25lT2Y6IGRhdGEgfSBhcyBRdWVyeUZpbHRlcjtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIHJldHVybiBmaWx0ZXJzO1xuICB9XG59XG4iXX0=
@@ -1,10 +0,0 @@
1
- import { TemplateRef } from '@angular/core';
2
- import { CountResultsFn } from '../../models/filters.models';
3
- import * as i0 from "@angular/core";
4
- export declare class WlcmFiltersComponent {
5
- countResults?: CountResultsFn;
6
- templateRef: TemplateRef<void>;
7
- protected filtersContent: TemplateRef<void>;
8
- static ɵfac: i0.ɵɵFactoryDeclaration<WlcmFiltersComponent, never>;
9
- static ɵcmp: i0.ɵɵComponentDeclaration<WlcmFiltersComponent, "wlcm-filters", ["wlcmFilters"], { "countResults": { "alias": "countResults"; "required": false; }; }, {}, ["filtersContent"], never, false, never>;
10
- }
@@ -1,11 +0,0 @@
1
- import { EventEmitter } from '@angular/core';
2
- import { WlcmFiltersComponent } from '../filters/filters.component';
3
- import { QueryFilters } from '@wlcm/angular/core';
4
- import * as i0 from "@angular/core";
5
- export declare class WlcmFiltersButtonComponent {
6
- panel: WlcmFiltersComponent;
7
- filters: QueryFilters;
8
- filtersChange: EventEmitter<QueryFilters>;
9
- static ɵfac: i0.ɵɵFactoryDeclaration<WlcmFiltersButtonComponent, never>;
10
- static ɵcmp: i0.ɵɵComponentDeclaration<WlcmFiltersButtonComponent, "wlcm-filters-button", never, { "panel": { "alias": "panel"; "required": false; }; "filters": { "alias": "filters"; "required": false; }; }, { "filtersChange": "filtersChange"; }, never, never, false, never>;
11
- }
@@ -1,25 +0,0 @@
1
- import { Injector, OnInit, TemplateRef } from '@angular/core';
2
- import { CountResultsFn, WlcmFiltersTriggerControl, WlcmFiltersSelectionModel } from '../../models/filters.models';
3
- import { BehaviorSubject } from 'rxjs';
4
- import * as i0 from "@angular/core";
5
- export declare class WlcmFiltersPanelComponent implements OnInit {
6
- protected injector: Injector;
7
- private panelControl;
8
- private globalSelectionModel;
9
- countResults?: CountResultsFn;
10
- filtersContent: TemplateRef<void>;
11
- readonly loading$: BehaviorSubject<boolean>;
12
- readonly totalResults$: BehaviorSubject<number | null>;
13
- private _selectionModel;
14
- private _countResults$;
15
- constructor(injector: Injector, panelControl: WlcmFiltersTriggerControl, globalSelectionModel: WlcmFiltersSelectionModel);
16
- ngOnInit(): void;
17
- apply(): void;
18
- reset(): void;
19
- close(): void;
20
- private updateGlobalModel;
21
- private handleSelectionChanges;
22
- private handleCountResultsEvent;
23
- static ɵfac: i0.ɵɵFactoryDeclaration<WlcmFiltersPanelComponent, [null, null, { skipSelf: true; }]>;
24
- static ɵcmp: i0.ɵɵComponentDeclaration<WlcmFiltersPanelComponent, "wlcm-filters-panel", never, { "countResults": { "alias": "countResults"; "required": false; }; "filtersContent": { "alias": "filtersContent"; "required": false; }; }, {}, never, never, false, never>;
25
- }
@@ -1,21 +0,0 @@
1
- import { OnInit } from '@angular/core';
2
- import { WlcmFiltersSelectionModel, WlcmFiltersUnit } from '../../models/filters.models';
3
- import { MatCheckboxChange } from '@angular/material/checkbox';
4
- import { WlcmOption } from '@wlcm/angular/core';
5
- import { Observable } from 'rxjs';
6
- import * as i0 from "@angular/core";
7
- export declare class WlcmFiltersUnitComponent implements OnInit {
8
- private selectionModel;
9
- label: string;
10
- param: string;
11
- options: WlcmOption[];
12
- protected filtersUnit: WlcmFiltersUnit;
13
- protected dataChanges$: Observable<Set<string>>;
14
- constructor(selectionModel: WlcmFiltersSelectionModel);
15
- ngOnInit(): void;
16
- reset(): void;
17
- change(event: MatCheckboxChange): void;
18
- private initializeFiltersUnit;
19
- static ɵfac: i0.ɵɵFactoryDeclaration<WlcmFiltersUnitComponent, never>;
20
- static ɵcmp: i0.ɵɵComponentDeclaration<WlcmFiltersUnitComponent, "wlcm-filters-unit", never, { "label": { "alias": "label"; "required": false; }; "param": { "alias": "param"; "required": false; }; "options": { "alias": "options"; "required": false; }; }, {}, never, never, false, never>;
21
- }
@@ -1,5 +0,0 @@
1
- import * as i0 from "@angular/core";
2
- export declare class WlcmFiltersContentDirective {
3
- static ɵfac: i0.ɵɵFactoryDeclaration<WlcmFiltersContentDirective, never>;
4
- static ɵdir: i0.ɵɵDirectiveDeclaration<WlcmFiltersContentDirective, "[wlcmFiltersContent]", never, {}, {}, never, never, false, never>;
5
- }
@@ -1,22 +0,0 @@
1
- import { ElementRef, Injector, ViewContainerRef } from '@angular/core';
2
- import { Overlay } from '@angular/cdk/overlay';
3
- import { WlcmFiltersSelectionModel } from '../models/filters.models';
4
- import { WlcmFiltersComponent } from '../components/filters/filters.component';
5
- import { FiltersTriggerBase } from '../models/filters-trigger.base';
6
- import * as i0 from "@angular/core";
7
- export declare class WlcmFiltersTriggerDirective extends FiltersTriggerBase {
8
- private overlay;
9
- private injector;
10
- private elementRef;
11
- private viewContainerRef;
12
- protected selectionModel: WlcmFiltersSelectionModel;
13
- panel: WlcmFiltersComponent;
14
- openPanel(): void;
15
- private overlayRef;
16
- constructor(overlay: Overlay, injector: Injector, elementRef: ElementRef, viewContainerRef: ViewContainerRef, selectionModel: WlcmFiltersSelectionModel);
17
- close(): void;
18
- private createInjector;
19
- private createOverlayConfig;
20
- static ɵfac: i0.ɵɵFactoryDeclaration<WlcmFiltersTriggerDirective, never>;
21
- static ɵdir: i0.ɵɵDirectiveDeclaration<WlcmFiltersTriggerDirective, "[wlcmFiltersTrigger]", never, { "panel": { "alias": "wlcmFiltersTrigger"; "required": false; }; }, {}, never, never, false, never>;
22
- }
@@ -1,20 +0,0 @@
1
- import * as i0 from "@angular/core";
2
- import * as i1 from "./components/filters/filters.component";
3
- import * as i2 from "./components/filters-unit/filters-unit.component";
4
- import * as i3 from "./components/filters-button/filters-button.component";
5
- import * as i4 from "./directives/filters-trigger.directive";
6
- import * as i5 from "./directives/filters-content.directive";
7
- import * as i6 from "./components/filters-panel/filters-panel.component";
8
- import * as i7 from "./pipes/is-filters-param-checked.pipe";
9
- import * as i8 from "@rx-angular/template/let";
10
- import * as i9 from "@angular/common";
11
- import * as i10 from "@angular/material/expansion";
12
- import * as i11 from "@angular/material/checkbox";
13
- import * as i12 from "./pipes/total-filters-applied.pipe";
14
- import * as i13 from "@wlcm/angular/core";
15
- import * as i14 from "@wlcm/angular/button";
16
- export declare class WlcmFiltersModule {
17
- static ɵfac: i0.ɵɵFactoryDeclaration<WlcmFiltersModule, never>;
18
- static ɵmod: i0.ɵɵNgModuleDeclaration<WlcmFiltersModule, [typeof i1.WlcmFiltersComponent, typeof i2.WlcmFiltersUnitComponent, typeof i3.WlcmFiltersButtonComponent, typeof i4.WlcmFiltersTriggerDirective, typeof i5.WlcmFiltersContentDirective, typeof i6.WlcmFiltersPanelComponent, typeof i7.IsFiltersParamCheckedPipe], [typeof i8.RxLet, typeof i9.CommonModule, typeof i10.MatExpansionModule, typeof i11.MatCheckboxModule, typeof i12.WlcmTotalFiltersAppliedPipe, typeof i13.ChevronDownIconComponent, typeof i14.WlcmButtonComponent, typeof i13.CloseIconComponent], [typeof i1.WlcmFiltersComponent, typeof i2.WlcmFiltersUnitComponent, typeof i3.WlcmFiltersButtonComponent, typeof i4.WlcmFiltersTriggerDirective, typeof i5.WlcmFiltersContentDirective]>;
19
- static ɵinj: i0.ɵɵInjectorDeclaration<WlcmFiltersModule>;
20
- }
@@ -1,18 +0,0 @@
1
- import { Observable } from 'rxjs';
2
- import { WlcmFiltersModel, WlcmFiltersSelectionModel, WlcmFiltersUnit } from './filters.models';
3
- export declare class FiltersDefaultSelectionModel extends WlcmFiltersSelectionModel {
4
- model: WlcmFiltersModel;
5
- private readonly _modelChanges$;
6
- readonly modelChanges$: Observable<WlcmFiltersModel>;
7
- add(param: string, unit: WlcmFiltersUnit, wlcmtChanges?: boolean): void;
8
- has(param: string): boolean;
9
- get(param: string): WlcmFiltersUnit;
10
- createUnit(param: string): WlcmFiltersUnit;
11
- updateSelection(model: WlcmFiltersModel): void;
12
- syncUnitChanges(): void;
13
- clone(): WlcmFiltersSelectionModel;
14
- reset(): void;
15
- get isEmpty(): boolean;
16
- private cloneModel;
17
- private notifyChanges;
18
- }
@@ -1,15 +0,0 @@
1
- import { EventEmitter } from '@angular/core';
2
- import { WlcmFiltersSelectionModel } from './filters.models';
3
- import { QueryFilters } from '@wlcm/angular/core';
4
- import * as i0 from "@angular/core";
5
- export declare class FiltersTriggerBase {
6
- protected selectionModel: WlcmFiltersSelectionModel;
7
- set filters(value: QueryFilters | undefined);
8
- filtersChanges: EventEmitter<QueryFilters>;
9
- private _filters;
10
- constructor(selectionModel: WlcmFiltersSelectionModel);
11
- protected updateSelectionModel(): void;
12
- protected handleModelChanges(): void;
13
- static ɵfac: i0.ɵɵFactoryDeclaration<FiltersTriggerBase, never>;
14
- static ɵdir: i0.ɵɵDirectiveDeclaration<FiltersTriggerBase, never, never, { "filters": { "alias": "wlcmFiltersTriggerData"; "required": false; }; }, { "filtersChanges": "wlcmFiltersTriggerDataChanges"; }, never, never, false, never>;
15
- }
@@ -1,42 +0,0 @@
1
- import { QueryFilters } from '@wlcm/angular/core';
2
- import { Observable } from 'rxjs';
3
- export declare class WlcmFiltersUnit {
4
- param: string;
5
- data: string[];
6
- parent: WlcmFiltersSelectionModel;
7
- private readonly _dataChanges$;
8
- readonly dataChanges$: Observable<string[]>;
9
- constructor(param: string, parent: WlcmFiltersSelectionModel);
10
- add(value: string): void;
11
- setAll(value: string[], onlySelf?: boolean): void;
12
- remove(value: string): void;
13
- reset(onlySelf?: boolean): void;
14
- clone(parent: WlcmFiltersSelectionModel): WlcmFiltersUnit;
15
- private notifyChanges;
16
- }
17
- export interface WlcmFiltersModel {
18
- [key: string]: WlcmFiltersUnit;
19
- }
20
- export declare abstract class WlcmFiltersSelectionModel {
21
- abstract model: WlcmFiltersModel;
22
- abstract readonly modelChanges$: Observable<WlcmFiltersModel>;
23
- abstract add(param: string, unit: WlcmFiltersUnit, wlcmtChanges?: boolean): void;
24
- abstract has(param: string): boolean;
25
- abstract get(param: string): WlcmFiltersUnit;
26
- abstract createUnit(param: string): WlcmFiltersUnit;
27
- abstract updateSelection(model: WlcmFiltersModel): void;
28
- abstract syncUnitChanges(): void;
29
- abstract clone(): WlcmFiltersSelectionModel;
30
- abstract reset(): void;
31
- abstract get isEmpty(): boolean;
32
- }
33
- export declare abstract class WlcmFiltersTriggerControl {
34
- abstract close(): void;
35
- }
36
- export type CountResultsFn = (filters: QueryFilters) => Observable<number>;
37
- export interface WlcmFiltersPanelControl {
38
- readonly loading$: Observable<boolean>;
39
- readonly totalResults$: Observable<number | null>;
40
- apply(): void;
41
- reset(): void;
42
- }
@@ -1,10 +0,0 @@
1
- import { PipeTransform } from '@angular/core';
2
- import { MatCheckbox } from '@angular/material/checkbox';
3
- import * as i0 from "@angular/core";
4
- export declare class IsFiltersParamCheckedPipe implements PipeTransform {
5
- private checkbox;
6
- transform(data: Set<string>): boolean;
7
- constructor(checkbox: MatCheckbox);
8
- static ɵfac: i0.ɵɵFactoryDeclaration<IsFiltersParamCheckedPipe, [{ host: true; }]>;
9
- static ɵpipe: i0.ɵɵPipeDeclaration<IsFiltersParamCheckedPipe, "isFiltersParamChecked", false>;
10
- }
@@ -1,8 +0,0 @@
1
- import { PipeTransform } from '@angular/core';
2
- import { QueryFilters } from '@wlcm/angular/core';
3
- import * as i0 from "@angular/core";
4
- export declare class WlcmTotalFiltersAppliedPipe implements PipeTransform {
5
- transform(filters: QueryFilters | undefined): number;
6
- static ɵfac: i0.ɵɵFactoryDeclaration<WlcmTotalFiltersAppliedPipe, never>;
7
- static ɵpipe: i0.ɵɵPipeDeclaration<WlcmTotalFiltersAppliedPipe, "totalFiltersApplied", true>;
8
- }
@@ -1,5 +0,0 @@
1
- import { QueryFilters } from '@wlcm/angular/core';
2
- import { WlcmFiltersModel } from '../models/filters.models';
3
- export declare class WlcmFiltersUtils {
4
- static modelToQueryFilters(model: WlcmFiltersModel): QueryFilters;
5
- }
@@ -1,44 +0,0 @@
1
- @use 'sass:map';
2
- @use '../../core/utils' as utils;
3
-
4
- @mixin theme($theme-config) {
5
- $theme: utils.using-theme($theme_config);
6
-
7
- .wlcm-filters-panel {
8
- width: 100%;
9
- padding: 16px;
10
- box-sizing: border-box;
11
- box-shadow: 0 10px 32px 0 rgba(38, 41, 45, 0.15);
12
- background: white;
13
- border-radius: 4px;
14
-
15
- &__title {
16
- font-size: 16px;
17
- letter-spacing: 0.47px;
18
- font-family: map-get($theme, bold-font-family);
19
- line-height: 24px;
20
- margin: 0 0 8px 0;
21
- margin-bottom: 0;
22
- }
23
- }
24
-
25
- .wlcm-filters-panel-header {
26
- display: flex;
27
- align-items: center;
28
- justify-content: space-between;
29
- margin-bottom: 10px;
30
- }
31
-
32
- .wlcm-filters-panel-units {
33
- display: grid;
34
- grid-auto-flow: row;
35
- grid-auto-rows: max-content;
36
- margin-bottom: 16px;
37
- gap: 8px;
38
- }
39
-
40
- .wlcm-filters-panel-actions {
41
- display: flex;
42
- justify-content: flex-end;
43
- }
44
- }
@@ -1,92 +0,0 @@
1
- @use 'sass:map';
2
- @use '../../core/utils' as utils;
3
-
4
- @mixin theme($theme-config) {
5
- $theme: utils.using-theme($theme_config);
6
-
7
- .wlcm-filters-unit {
8
- &__chevron {
9
- width: 12px;
10
- height: 12px;
11
- display: flex;
12
- align-items: center;
13
- justify-content: center;
14
- transform: rotateZ(-90deg);
15
- transition: 225ms cubic-bezier(0.4, 0, 0.2, 1),
16
- box-shadow 280ms cubic-bezier(0.4, 0, 0.2, 1);
17
- }
18
- }
19
-
20
- .wlcm-filters-unit-header {
21
- display: flex;
22
- align-items: center;
23
- justify-content: space-between;
24
- height: 30px;
25
- width: 100%;
26
-
27
- section {
28
- display: flex;
29
- align-items: center;
30
- }
31
-
32
- .wlcm-entities-count {
33
- margin-left: 6px;
34
- }
35
-
36
- .reset-btn {
37
- margin-right: 12px;
38
- }
39
-
40
- &__label {
41
- font-family: map-get($theme, bold-font-family);
42
- letter-spacing: 0.41px;
43
- line-height: 24px;
44
- font-size: 14px;
45
- }
46
- }
47
-
48
- .reset-btn {
49
- border: none;
50
- outline: none;
51
- background: white;
52
- font-family: map-get($theme, bold-font-family);
53
- color: map-get($theme, primary-color);
54
- letter-spacing: 0.41px;
55
- font-size: 14px;
56
- padding: 0;
57
- }
58
-
59
- .wlcm-filters-unit-checkboxes {
60
- display: grid;
61
- grid-auto-flow: row;
62
- grid-auto-rows: max-content;
63
- gap: 4px;
64
- }
65
-
66
- .wlcm-filters-unit {
67
- box-shadow: none !important;
68
-
69
- .wlcm-filters-unit-header {
70
- background-color: white !important;
71
- }
72
-
73
- .mat-content {
74
- margin: 0 !important;
75
- }
76
-
77
- .mat-expansion-panel-body {
78
- padding: 8px 0 !important;
79
- }
80
-
81
- &.mat-expanded {
82
- .wlcm-filters-unit__chevron {
83
- color: map-get($theme, primary-color);
84
- transform: rotateZ(0deg);
85
- }
86
- }
87
-
88
- mat-expansion-panel-header {
89
- padding: 0 !important;
90
- }
91
- }
92
- }
@@ -1,7 +0,0 @@
1
- @use './filters-unit' as filtersUnit;
2
- @use './filters-panel' as filtersPanel;
3
-
4
- @mixin theme($theme-config) {
5
- @include filtersUnit.theme($theme-config);
6
- @include filtersPanel.theme($theme-config);
7
- }