@wlcm/angular 0.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +62 -0
- package/button/README.md +7 -0
- package/button/esm2022/index.mjs +3 -0
- package/button/esm2022/lib/button.module.mjs +16 -0
- package/button/esm2022/lib/components/button/button.component.mjs +37 -0
- package/button/esm2022/lib/models/button.models.mjs +2 -0
- package/button/esm2022/wlcm-angular-button.mjs +5 -0
- package/button/fesm2022/wlcm-angular-button.mjs +57 -0
- package/button/fesm2022/wlcm-angular-button.mjs.map +1 -0
- package/button/index.d.ts +2 -0
- package/button/lib/button.module.d.ts +7 -0
- package/button/lib/components/button/button.component.d.ts +13 -0
- package/button/lib/models/button.models.d.ts +1 -0
- package/core/README.md +7 -0
- package/core/esm2022/index.mjs +10 -0
- package/core/esm2022/lib/components/chevron-down-icon/chevron-down-icon.component.mjs +12 -0
- package/core/esm2022/lib/components/close-icon/close-icon.component.mjs +12 -0
- package/core/esm2022/lib/components/search-icon/search-icon.component.mjs +12 -0
- package/core/esm2022/lib/constants/http.constants.mjs +6 -0
- package/core/esm2022/lib/models/option.models.mjs +15 -0
- package/core/esm2022/lib/models/paginated-data.models.mjs +2 -0
- package/core/esm2022/lib/models/query-params.models.mjs +6 -0
- package/core/esm2022/lib/utils/stream.utils.mjs +28 -0
- package/core/esm2022/wlcm-angular-core.mjs +5 -0
- package/core/fesm2022/wlcm-angular-core.mjs +92 -0
- package/core/fesm2022/wlcm-angular-core.mjs.map +1 -0
- package/core/index.d.ts +8 -0
- package/core/lib/components/chevron-down-icon/chevron-down-icon.component.d.ts +5 -0
- package/core/lib/components/close-icon/close-icon.component.d.ts +5 -0
- package/core/lib/components/search-icon/search-icon.component.d.ts +5 -0
- package/core/lib/constants/http.constants.d.ts +2 -0
- package/core/lib/models/option.models.d.ts +11 -0
- package/core/lib/models/paginated-data.models.d.ts +6 -0
- package/core/lib/models/query-params.models.d.ts +26 -0
- package/core/lib/utils/stream.utils.d.ts +7 -0
- package/filters/README.md +7 -0
- package/filters/esm2022/index.mjs +8 -0
- package/filters/esm2022/lib/filters/components/filters/filters.component.mjs +21 -0
- package/filters/esm2022/lib/filters/components/filters-button/filters-button.component.mjs +25 -0
- package/filters/esm2022/lib/filters/components/filters-panel/filters-panel.component.mjs +86 -0
- package/filters/esm2022/lib/filters/components/filters-unit/filters-unit.component.mjs +55 -0
- package/filters/esm2022/lib/filters/directives/filters-content.directive.mjs +11 -0
- package/filters/esm2022/lib/filters/directives/filters-trigger.directive.mjs +69 -0
- package/filters/esm2022/lib/filters/filters.module.mjs +53 -0
- package/filters/esm2022/lib/filters/models/filters-default-selection-model.mjs +56 -0
- package/filters/esm2022/lib/filters/models/filters-trigger.base.mjs +56 -0
- package/filters/esm2022/lib/filters/models/filters.models.mjs +44 -0
- package/filters/esm2022/lib/filters/pipes/is-filters-param-checked.pipe.mjs +21 -0
- package/filters/esm2022/lib/filters/pipes/total-filters-applied.pipe.mjs +18 -0
- package/filters/esm2022/lib/filters/utils/filters.utils.mjs +13 -0
- package/filters/esm2022/wlcm-angular-filters.mjs +5 -0
- package/filters/fesm2022/wlcm-angular-filters.mjs +474 -0
- package/filters/fesm2022/wlcm-angular-filters.mjs.map +1 -0
- package/filters/index.d.ts +7 -0
- package/filters/lib/filters/components/filters/filters.component.d.ts +10 -0
- package/filters/lib/filters/components/filters-button/filters-button.component.d.ts +11 -0
- package/filters/lib/filters/components/filters-panel/filters-panel.component.d.ts +25 -0
- package/filters/lib/filters/components/filters-unit/filters-unit.component.d.ts +21 -0
- package/filters/lib/filters/directives/filters-content.directive.d.ts +5 -0
- package/filters/lib/filters/directives/filters-trigger.directive.d.ts +22 -0
- package/filters/lib/filters/filters.module.d.ts +20 -0
- package/filters/lib/filters/models/filters-default-selection-model.d.ts +18 -0
- package/filters/lib/filters/models/filters-trigger.base.d.ts +15 -0
- package/filters/lib/filters/models/filters.models.d.ts +42 -0
- package/filters/lib/filters/pipes/is-filters-param-checked.pipe.d.ts +10 -0
- package/filters/lib/filters/pipes/total-filters-applied.pipe.d.ts +8 -0
- package/filters/lib/filters/utils/filters.utils.d.ts +5 -0
- package/forms/README.md +7 -0
- package/forms/esm2022/index.mjs +10 -0
- package/forms/esm2022/lib/forms/components/autocomplete/autocomplete.component.mjs +164 -0
- package/forms/esm2022/lib/forms/components/error/error.component.mjs +12 -0
- package/forms/esm2022/lib/forms/components/form-field/form-field.component.mjs +118 -0
- package/forms/esm2022/lib/forms/components/index.mjs +6 -0
- package/forms/esm2022/lib/forms/components/label/label.component.mjs +23 -0
- package/forms/esm2022/lib/forms/components/select/select.component.mjs +107 -0
- package/forms/esm2022/lib/forms/constants/form-elements.constants.mjs +5 -0
- package/forms/esm2022/lib/forms/constants/form-errors.constants.mjs +7 -0
- package/forms/esm2022/lib/forms/constants/form-state-handlers.constants.mjs +13 -0
- package/forms/esm2022/lib/forms/constants/index.mjs +4 -0
- package/forms/esm2022/lib/forms/directives/ac-input-binder.directive.mjs +33 -0
- package/forms/esm2022/lib/forms/directives/autocomplete.directive.mjs +63 -0
- package/forms/esm2022/lib/forms/directives/form-field-custom-container.directive.mjs +17 -0
- package/forms/esm2022/lib/forms/directives/form-field-hint.directive.mjs +15 -0
- package/forms/esm2022/lib/forms/directives/form-field-suffix.directive.mjs +14 -0
- package/forms/esm2022/lib/forms/directives/input.directive.mjs +35 -0
- package/forms/esm2022/lib/forms/forms.module.mjs +51 -0
- package/forms/esm2022/lib/forms/models/_index.mjs +4 -0
- package/forms/esm2022/lib/forms/models/form-errors.models.mjs +2 -0
- package/forms/esm2022/lib/forms/models/form.models.mjs +2 -0
- package/forms/esm2022/lib/forms/models/input.models.mjs +2 -0
- package/forms/esm2022/lib/forms/pipes/errors-mapper.pipe.mjs +53 -0
- package/forms/esm2022/lib/forms/services/form-state-handler.service.mjs +19 -0
- package/forms/esm2022/lib/forms/services/index.mjs +2 -0
- package/forms/esm2022/wlcm-angular-forms.mjs +5 -0
- package/forms/fesm2022/wlcm-angular-forms.mjs +675 -0
- package/forms/fesm2022/wlcm-angular-forms.mjs.map +1 -0
- package/forms/index.d.ts +9 -0
- package/forms/lib/forms/components/autocomplete/autocomplete.component.d.ts +46 -0
- package/forms/lib/forms/components/error/error.component.d.ts +5 -0
- package/forms/lib/forms/components/form-field/form-field.component.d.ts +27 -0
- package/forms/lib/forms/components/index.d.ts +5 -0
- package/forms/lib/forms/components/label/label.component.d.ts +7 -0
- package/forms/lib/forms/components/select/select.component.d.ts +31 -0
- package/forms/lib/forms/constants/form-elements.constants.d.ts +6 -0
- package/forms/lib/forms/constants/form-errors.constants.d.ts +4 -0
- package/forms/lib/forms/constants/form-state-handlers.constants.d.ts +6 -0
- package/forms/lib/forms/constants/index.d.ts +3 -0
- package/forms/lib/forms/directives/ac-input-binder.directive.d.ts +5 -0
- package/forms/lib/forms/directives/autocomplete.directive.d.ts +16 -0
- package/forms/lib/forms/directives/form-field-custom-container.directive.d.ts +8 -0
- package/forms/lib/forms/directives/form-field-hint.directive.d.ts +5 -0
- package/forms/lib/forms/directives/form-field-suffix.directive.d.ts +5 -0
- package/forms/lib/forms/directives/input.directive.d.ts +5 -0
- package/forms/lib/forms/forms.module.d.ts +15 -0
- package/forms/lib/forms/models/_index.d.ts +3 -0
- package/forms/lib/forms/models/form-errors.models.d.ts +5 -0
- package/forms/lib/forms/models/form.models.d.ts +11 -0
- package/forms/lib/forms/models/input.models.d.ts +7 -0
- package/forms/lib/forms/pipes/errors-mapper.pipe.d.ts +17 -0
- package/forms/lib/forms/services/form-state-handler.service.d.ts +10 -0
- package/forms/lib/forms/services/index.d.ts +1 -0
- package/index.d.ts +1 -0
- package/index.mjs +4 -0
- package/package.json +109 -0
- package/search-field/README.md +7 -0
- package/search-field/esm2022/index.mjs +3 -0
- package/search-field/esm2022/lib/components/search-field/search-field.component.mjs +36 -0
- package/search-field/esm2022/lib/search-field.module.mjs +18 -0
- package/search-field/esm2022/wlcm-angular-search-field.mjs +5 -0
- package/search-field/fesm2022/wlcm-angular-search-field.mjs +57 -0
- package/search-field/fesm2022/wlcm-angular-search-field.mjs.map +1 -0
- package/search-field/index.d.ts +2 -0
- package/search-field/lib/components/search-field/search-field.component.d.ts +14 -0
- package/search-field/lib/search-field.module.d.ts +8 -0
- package/styles/components/button/index.scss +91 -0
- package/styles/components/common/index.scss +33 -0
- package/styles/components/filters/_filters-panel.scss +44 -0
- package/styles/components/filters/_filters-unit.scss +92 -0
- package/styles/components/filters/index.scss +7 -0
- package/styles/components/forms/_checkbox.scss +89 -0
- package/styles/components/forms/_error.scss +23 -0
- package/styles/components/forms/_form-field.scss +65 -0
- package/styles/components/forms/_label.scss +42 -0
- package/styles/components/forms/_select.scss +74 -0
- package/styles/components/forms/index.scss +13 -0
- package/styles/components/search-field/index.scss +31 -0
- package/styles/core/_all-theme.scss +15 -0
- package/styles/core/_core.scss +10 -0
- package/styles/core/_utils.scss +53 -0
- package/styles/wlcm.scss +3 -0
@@ -0,0 +1,25 @@
|
|
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
|
+
}
|
@@ -0,0 +1,21 @@
|
|
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
|
+
}
|
@@ -0,0 +1,5 @@
|
|
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
|
+
}
|
@@ -0,0 +1,22 @@
|
|
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
|
+
}
|
@@ -0,0 +1,20 @@
|
|
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
|
+
}
|
@@ -0,0 +1,18 @@
|
|
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
|
+
}
|
@@ -0,0 +1,15 @@
|
|
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
|
+
}
|
@@ -0,0 +1,42 @@
|
|
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
|
+
}
|
@@ -0,0 +1,10 @@
|
|
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
|
+
}
|
@@ -0,0 +1,8 @@
|
|
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
|
+
}
|
package/forms/README.md
ADDED
@@ -0,0 +1,10 @@
|
|
1
|
+
export * from './lib/forms/forms.module';
|
2
|
+
export * from './lib/forms/models/_index';
|
3
|
+
export * from './lib/forms/constants/index';
|
4
|
+
export * from './lib/forms/directives/form-field-custom-container.directive';
|
5
|
+
export * from './lib/forms/directives/form-field-suffix.directive';
|
6
|
+
export * from './lib/forms/directives/form-field-hint.directive';
|
7
|
+
export * from './lib/forms/directives/ac-input-binder.directive';
|
8
|
+
export * from './lib/forms/directives/input.directive';
|
9
|
+
export * from './lib/forms/components';
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9tb2R1bGVzL2Zvcm1zL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDhEQUE4RCxDQUFDO0FBQzdFLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyx3QkFBd0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm1zL2Zvcm1zLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3Jtcy9tb2RlbHMvX2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm1zL2NvbnN0YW50cy9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3Jtcy9kaXJlY3RpdmVzL2Zvcm0tZmllbGQtY3VzdG9tLWNvbnRhaW5lci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZm9ybXMvZGlyZWN0aXZlcy9mb3JtLWZpZWxkLXN1ZmZpeC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZm9ybXMvZGlyZWN0aXZlcy9mb3JtLWZpZWxkLWhpbnQuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm1zL2RpcmVjdGl2ZXMvYWMtaW5wdXQtYmluZGVyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3Jtcy9kaXJlY3RpdmVzL2lucHV0LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3Jtcy9jb21wb25lbnRzJztcbiJdfQ==
|
@@ -0,0 +1,164 @@
|
|
1
|
+
import { __decorate, __metadata } from "tslib";
|
2
|
+
import { ChangeDetectionStrategy, Component, Inject, Input, ViewChild, forwardRef, } from '@angular/core';
|
3
|
+
import { FormControl, NG_VALIDATORS, NG_VALUE_ACCESSOR, ReactiveFormsModule, } from '@angular/forms';
|
4
|
+
import { CommonModule } from '@angular/common';
|
5
|
+
import { WlcmFormFieldComponent } from '../form-field/form-field.component';
|
6
|
+
import { WlcmLabelComponent } from '../label/label.component';
|
7
|
+
import { WlcmInputDirective } from '../../directives/input.directive';
|
8
|
+
import { MatAutocompleteModule, MatAutocompleteOrigin, MatAutocompleteTrigger } from '@angular/material/autocomplete';
|
9
|
+
import { BehaviorSubject, EMPTY, Observable, Subject, asyncScheduler, concatMap, debounceTime, filter, first, observeOn, switchMap, tap, } from 'rxjs';
|
10
|
+
import { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';
|
11
|
+
import { AutocompleteDirective } from '../../directives/autocomplete.directive';
|
12
|
+
import { DEFAULT_QUERY_PARAMS } from '@wlcm/angular/core';
|
13
|
+
import { WLCM_FORM_FIELD, WLCM_INPUT } from '../../constants';
|
14
|
+
import * as i0 from "@angular/core";
|
15
|
+
import * as i1 from "@angular/common";
|
16
|
+
import * as i2 from "@angular/material/autocomplete";
|
17
|
+
import * as i3 from "@angular/material/core";
|
18
|
+
import * as i4 from "@angular/forms";
|
19
|
+
let WlcmAutocompleteComponent = class WlcmAutocompleteComponent {
|
20
|
+
constructor(formField) {
|
21
|
+
this.formField = formField;
|
22
|
+
this.required = false;
|
23
|
+
this.placeholder = '';
|
24
|
+
this.control = new FormControl('');
|
25
|
+
this._loadMore$ = new Subject();
|
26
|
+
this._options$ = new BehaviorSubject([]);
|
27
|
+
this.options$ = this._options$.asObservable();
|
28
|
+
this.closed$ = new Subject();
|
29
|
+
this.queryParams = { ...DEFAULT_QUERY_PARAMS, limit: 15 };
|
30
|
+
this._paginatedData = null;
|
31
|
+
this.handleLoadMoreEvent();
|
32
|
+
this.handleControlValueChanges();
|
33
|
+
}
|
34
|
+
ngOnInit() {
|
35
|
+
this.loadOptions(this.queryParams).subscribe();
|
36
|
+
}
|
37
|
+
ngAfterViewInit() {
|
38
|
+
const container = this.formField.inputContainer;
|
39
|
+
const origin = new MatAutocompleteOrigin(container);
|
40
|
+
this.autocompleteTrigger.connectedTo = origin;
|
41
|
+
}
|
42
|
+
displayWith(value) {
|
43
|
+
if (value instanceof Object) {
|
44
|
+
return value.viewValue;
|
45
|
+
}
|
46
|
+
return value;
|
47
|
+
}
|
48
|
+
loadMore() {
|
49
|
+
this._loadMore$.next();
|
50
|
+
}
|
51
|
+
writeValue(value) {
|
52
|
+
this.control.setValue(value);
|
53
|
+
}
|
54
|
+
registerOnChange(callback) {
|
55
|
+
this._changed = callback;
|
56
|
+
}
|
57
|
+
registerOnTouched(callback) {
|
58
|
+
this._touched = callback;
|
59
|
+
}
|
60
|
+
setDisabledState(isDisabled) {
|
61
|
+
if (isDisabled) {
|
62
|
+
return this.control.disable();
|
63
|
+
}
|
64
|
+
this.control.enable();
|
65
|
+
}
|
66
|
+
blured() {
|
67
|
+
let closed = new Observable((observer) => (observer.next(), observer.complete()));
|
68
|
+
if (this.autocompleteTrigger.panelOpen) {
|
69
|
+
closed = this.closed$.pipe(first(), observeOn(asyncScheduler));
|
70
|
+
}
|
71
|
+
closed.subscribe(() => this._touched?.());
|
72
|
+
}
|
73
|
+
validate(control) {
|
74
|
+
if (!!this.control.value) {
|
75
|
+
if (this.control.value instanceof Object)
|
76
|
+
return null;
|
77
|
+
return { ...control.errors, unselected: true, required: false };
|
78
|
+
}
|
79
|
+
return null;
|
80
|
+
}
|
81
|
+
registerOnValidatorChange(fn) {
|
82
|
+
this._onValidatorChange = fn;
|
83
|
+
}
|
84
|
+
loadOptions(params) {
|
85
|
+
this._options$.next([]);
|
86
|
+
return this.pullDataMethod({ ...params, page: 1 }).pipe(tap((paginatedData) => {
|
87
|
+
this._paginatedData = paginatedData;
|
88
|
+
this._options$.next(paginatedData.data);
|
89
|
+
}));
|
90
|
+
}
|
91
|
+
handleLoadMoreEvent() {
|
92
|
+
this._loadMore$
|
93
|
+
.pipe(concatMap(() => {
|
94
|
+
if (this._paginatedData && this._paginatedData.currPage + 1 <= this._paginatedData.totalPages) {
|
95
|
+
this.queryParams.page++;
|
96
|
+
return this.pullDataMethod(this.queryParams).pipe(tap((paginatedData) => {
|
97
|
+
this._paginatedData = paginatedData;
|
98
|
+
this._options$.next([...this._options$.value, ...paginatedData.data]);
|
99
|
+
}));
|
100
|
+
}
|
101
|
+
return EMPTY;
|
102
|
+
}))
|
103
|
+
.subscribe();
|
104
|
+
}
|
105
|
+
handleControlValueChanges() {
|
106
|
+
this.control.valueChanges
|
107
|
+
.pipe(debounceTime(200))
|
108
|
+
.pipe(untilDestroyed(this))
|
109
|
+
.pipe(filter((value) => {
|
110
|
+
this._onValidatorChange?.();
|
111
|
+
if (!(value instanceof Object))
|
112
|
+
return true;
|
113
|
+
this._changed?.(value.value);
|
114
|
+
return false;
|
115
|
+
}))
|
116
|
+
.pipe(switchMap((value) => {
|
117
|
+
return this.loadOptions({ ...this.queryParams, query: value });
|
118
|
+
}))
|
119
|
+
.subscribe();
|
120
|
+
}
|
121
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmAutocompleteComponent, deps: [{ token: WLCM_FORM_FIELD }], target: i0.ɵɵFactoryTarget.Component }); }
|
122
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.5", type: WlcmAutocompleteComponent, isStandalone: true, selector: "wlcm-autocomplete", inputs: { pullDataMethod: "pullDataMethod", label: "label", required: "required", placeholder: "placeholder" }, providers: [
|
123
|
+
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmAutocompleteComponent), multi: true },
|
124
|
+
{ provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmAutocompleteComponent), multi: true },
|
125
|
+
], viewQueries: [{ propertyName: "wlcmInput", first: true, predicate: WLCM_INPUT, descendants: true }, { propertyName: "autocompleteTrigger", first: true, predicate: MatAutocompleteTrigger, descendants: true }], ngImport: i0, template: "<input\n wlcmInput\n type=\"text\"\n [matAutocomplete]=\"autocomplete\"\n [placeholder]=\"placeholder\"\n [formControl]=\"control\"\n (blur)=\"blured()\"\n/>\n\n<mat-autocomplete\n #autocomplete=\"matAutocomplete\"\n wlcmAutocomplete\n [disableRipple]=\"true\"\n [displayWith]=\"displayWith\"\n [hideSingleSelectionIndicator]=\"true\"\n (panelScrolled)=\"loadMore()\"\n (closed)=\"closed$.next()\"\n>\n <mat-option *ngFor=\"let option of options$ | async\" [value]=\"option\">\n {{ option.viewValue }}\n </mat-option>\n</mat-autocomplete>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatAutocompleteModule }, { kind: "component", type: i2.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i3.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i2.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: AutocompleteDirective, selector: "[wlcmAutocomplete]", outputs: ["panelScrolled"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.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: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: WlcmInputDirective, selector: "[wlcmInput]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
126
|
+
};
|
127
|
+
WlcmAutocompleteComponent = __decorate([
|
128
|
+
UntilDestroy(),
|
129
|
+
__metadata("design:paramtypes", [Object])
|
130
|
+
], WlcmAutocompleteComponent);
|
131
|
+
export { WlcmAutocompleteComponent };
|
132
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmAutocompleteComponent, decorators: [{
|
133
|
+
type: Component,
|
134
|
+
args: [{ selector: 'wlcm-autocomplete', standalone: true, imports: [
|
135
|
+
CommonModule,
|
136
|
+
MatAutocompleteModule,
|
137
|
+
AutocompleteDirective,
|
138
|
+
ReactiveFormsModule,
|
139
|
+
WlcmFormFieldComponent,
|
140
|
+
WlcmLabelComponent,
|
141
|
+
WlcmInputDirective,
|
142
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
143
|
+
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmAutocompleteComponent), multi: true },
|
144
|
+
{ provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmAutocompleteComponent), multi: true },
|
145
|
+
], template: "<input\n wlcmInput\n type=\"text\"\n [matAutocomplete]=\"autocomplete\"\n [placeholder]=\"placeholder\"\n [formControl]=\"control\"\n (blur)=\"blured()\"\n/>\n\n<mat-autocomplete\n #autocomplete=\"matAutocomplete\"\n wlcmAutocomplete\n [disableRipple]=\"true\"\n [displayWith]=\"displayWith\"\n [hideSingleSelectionIndicator]=\"true\"\n (panelScrolled)=\"loadMore()\"\n (closed)=\"closed$.next()\"\n>\n <mat-option *ngFor=\"let option of options$ | async\" [value]=\"option\">\n {{ option.viewValue }}\n </mat-option>\n</mat-autocomplete>\n", styles: [":host{display:block}\n"] }]
|
146
|
+
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
147
|
+
type: Inject,
|
148
|
+
args: [WLCM_FORM_FIELD]
|
149
|
+
}] }], propDecorators: { pullDataMethod: [{
|
150
|
+
type: Input
|
151
|
+
}], label: [{
|
152
|
+
type: Input
|
153
|
+
}], required: [{
|
154
|
+
type: Input
|
155
|
+
}], placeholder: [{
|
156
|
+
type: Input
|
157
|
+
}], wlcmInput: [{
|
158
|
+
type: ViewChild,
|
159
|
+
args: [WLCM_INPUT]
|
160
|
+
}], autocompleteTrigger: [{
|
161
|
+
type: ViewChild,
|
162
|
+
args: [MatAutocompleteTrigger]
|
163
|
+
}] } });
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../../modules/forms/src/lib/forms/components/autocomplete/autocomplete.component.ts","../../../../../../../../modules/forms/src/lib/forms/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  OnInit,\n  ViewChild,\n  forwardRef,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormControl,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { WlcmFormFieldComponent } from '../form-field/form-field.component';\nimport { WlcmLabelComponent } from '../label/label.component';\nimport { WlcmInputDirective } from '../../directives/input.directive';\nimport { MatAutocompleteModule, MatAutocompleteOrigin, MatAutocompleteTrigger } from '@angular/material/autocomplete';\nimport {\n  BehaviorSubject,\n  EMPTY,\n  Observable,\n  Subject,\n  asyncScheduler,\n  concatMap,\n  debounceTime,\n  empty,\n  filter,\n  first,\n  observeOn,\n  switchMap,\n  tap,\n} from 'rxjs';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport { AutocompleteDirective } from '../../directives/autocomplete.directive';\nimport { DEFAULT_QUERY_PARAMS, PaginatedData, QueryParams, WlcmAutocompleteOption } from '@wlcm/angular/core';\nimport { WLCM_FORM_FIELD, WLCM_INPUT } from '../../constants';\nimport { WlcmInputGetter } from '../../models/input.models';\nimport { WlcmFormField } from '../../models/form.models';\n\ntype Option = WlcmAutocompleteOption;\n\ntype AutocompleteValue = WlcmAutocompleteOption | string | null;\n\n@UntilDestroy()\n@Component({\n  selector: 'wlcm-autocomplete',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatAutocompleteModule,\n    AutocompleteDirective,\n    ReactiveFormsModule,\n    WlcmFormFieldComponent,\n    WlcmLabelComponent,\n    WlcmInputDirective,\n  ],\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['./autocomplete.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmAutocompleteComponent), multi: true },\n    { provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmAutocompleteComponent), multi: true },\n  ],\n})\nexport class WlcmAutocompleteComponent implements OnInit, ControlValueAccessor, Validator, AfterViewInit {\n  @Input() pullDataMethod!: (params: QueryParams) => Observable<PaginatedData<Option>>;\n\n  @Input() label!: string;\n\n  @Input() required: boolean = false;\n\n  @Input() placeholder: string = '';\n\n  readonly control: FormControl<AutocompleteValue> = new FormControl('');\n\n  private readonly _loadMore$: Subject<void> = new Subject();\n\n  private readonly _options$: BehaviorSubject<Option[]> = new BehaviorSubject<Option[]>([]);\n\n  protected readonly options$: Observable<Option[]> = this._options$.asObservable();\n\n  protected readonly closed$: Subject<void> = new Subject();\n\n  private queryParams: QueryParams = { ...DEFAULT_QUERY_PARAMS, limit: 15 };\n\n  private _changed?: (value: string) => void;\n\n  private _touched?: () => void;\n\n  private _onValidatorChange?: () => void;\n\n  private _paginatedData: PaginatedData<Option> | null = null;\n\n  @ViewChild(WLCM_INPUT) public wlcmInput!: WlcmInputGetter;\n\n  @ViewChild(MatAutocompleteTrigger) private autocompleteTrigger!: MatAutocompleteTrigger;\n\n  constructor(@Inject(WLCM_FORM_FIELD) private formField: WlcmFormField) {\n    this.handleLoadMoreEvent();\n    this.handleControlValueChanges();\n  }\n\n  ngOnInit(): void {\n    this.loadOptions(this.queryParams).subscribe();\n  }\n\n  ngAfterViewInit(): void {\n    const container: ElementRef = this.formField.inputContainer;\n\n    const origin: MatAutocompleteOrigin = new MatAutocompleteOrigin(container);\n\n    this.autocompleteTrigger.connectedTo = origin;\n  }\n\n  displayWith(value: Option | string): string {\n    if (value instanceof Object) {\n      return value.viewValue;\n    }\n\n    return value;\n  }\n\n  loadMore(): void {\n    this._loadMore$.next();\n  }\n\n  writeValue(value: AutocompleteValue): void {\n    this.control.setValue(value);\n  }\n\n  registerOnChange(callback: (value: string) => void): void {\n    this._changed = callback;\n  }\n\n  registerOnTouched(callback: () => void): void {\n    this._touched = callback;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (isDisabled) {\n      return this.control.disable();\n    }\n\n    this.control.enable();\n  }\n\n  blured(): void {\n    let closed: Observable<void> = new Observable((observer) => (observer.next(), observer.complete()));\n\n    if (this.autocompleteTrigger.panelOpen) {\n      closed = this.closed$.pipe(first(), observeOn(asyncScheduler));\n    }\n\n    closed.subscribe(() => this._touched?.());\n  }\n\n  validate(control: AbstractControl): ValidationErrors | null {\n    if (!!this.control.value) {\n      if (this.control.value instanceof Object) return null;\n\n      return { ...control.errors, unselected: true, required: false };\n    }\n\n    return null;\n  }\n\n  registerOnValidatorChange(fn: () => void): void {\n    this._onValidatorChange = fn;\n  }\n\n  private loadOptions(params: QueryParams): Observable<PaginatedData<Option>> {\n    this._options$.next([]);\n\n    return this.pullDataMethod({ ...params, page: 1 }).pipe(\n      tap((paginatedData: PaginatedData<Option>) => {\n        this._paginatedData = paginatedData;\n\n        this._options$.next(paginatedData.data);\n      })\n    );\n  }\n\n  private handleLoadMoreEvent(): void {\n    this._loadMore$\n      .pipe(\n        concatMap(() => {\n          if (this._paginatedData && this._paginatedData.currPage + 1 <= this._paginatedData.totalPages) {\n            this.queryParams.page++;\n\n            return this.pullDataMethod(this.queryParams).pipe(\n              tap((paginatedData: PaginatedData<Option>) => {\n                this._paginatedData = paginatedData;\n\n                this._options$.next([...this._options$.value, ...paginatedData.data]);\n              })\n            );\n          }\n\n          return EMPTY;\n        })\n      )\n      .subscribe();\n  }\n\n  private handleControlValueChanges(): void {\n    this.control.valueChanges\n      .pipe(debounceTime(200))\n      .pipe(untilDestroyed(this))\n      .pipe(\n        filter((value: AutocompleteValue) => {\n          this._onValidatorChange?.();\n\n          if (!(value instanceof Object)) return true;\n\n          this._changed?.(value.value);\n\n          return false;\n        })\n      )\n      .pipe(\n        switchMap((value: AutocompleteValue) => {\n          return this.loadOptions({ ...this.queryParams, query: value as string });\n        })\n      )\n      .subscribe();\n  }\n}\n","<input\n  wlcmInput\n  type=\"text\"\n  [matAutocomplete]=\"autocomplete\"\n  [placeholder]=\"placeholder\"\n  [formControl]=\"control\"\n  (blur)=\"blured()\"\n/>\n\n<mat-autocomplete\n  #autocomplete=\"matAutocomplete\"\n  wlcmAutocomplete\n  [disableRipple]=\"true\"\n  [displayWith]=\"displayWith\"\n  [hideSingleSelectionIndicator]=\"true\"\n  (panelScrolled)=\"loadMore()\"\n  (closed)=\"closed$.next()\"\n>\n  <mat-option *ngFor=\"let option of options$ | async\" [value]=\"option\">\n    {{ option.viewValue }}\n  </mat-option>\n</mat-autocomplete>\n"]}
|
@@ -0,0 +1,12 @@
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
2
|
+
import { CommonModule } from '@angular/common';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
export class WlcmErrorComponent {
|
5
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmErrorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
6
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.5", type: WlcmErrorComponent, isStandalone: true, selector: "wlcm-error", host: { classAttribute: "wlcm-error" }, ngImport: i0, template: "<ng-content></ng-content>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
7
|
+
}
|
8
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmErrorComponent, decorators: [{
|
9
|
+
type: Component,
|
10
|
+
args: [{ selector: 'wlcm-error', standalone: true, imports: [CommonModule], host: { class: 'wlcm-error' }, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content></ng-content>\n" }]
|
11
|
+
}] });
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9mb3Jtcy9zcmMvbGliL2Zvcm1zL2NvbXBvbmVudHMvZXJyb3IvZXJyb3IuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9mb3Jtcy9zcmMvbGliL2Zvcm1zL2NvbXBvbmVudHMvZXJyb3IvZXJyb3IuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBVy9DLE1BQU0sT0FBTyxrQkFBa0I7OEdBQWxCLGtCQUFrQjtrR0FBbEIsa0JBQWtCLDhHQ1ovQiw2QkFDQSx5RERLWSxZQUFZOzsyRkFNWCxrQkFBa0I7a0JBVDlCLFNBQVM7K0JBQ0UsWUFBWSxjQUNWLElBQUksV0FDUCxDQUFDLFlBQVksQ0FBQyxRQUNqQixFQUFFLEtBQUssRUFBRSxZQUFZLEVBQUUsbUJBR1osdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3dsY20tZXJyb3InLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgaG9zdDogeyBjbGFzczogJ3dsY20tZXJyb3InIH0sXG4gIHRlbXBsYXRlVXJsOiAnLi9lcnJvci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2Vycm9yLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBXbGNtRXJyb3JDb21wb25lbnQge31cbiIsIjxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiJdfQ==
|
@@ -0,0 +1,118 @@
|
|
1
|
+
import { __decorate, __metadata } from "tslib";
|
2
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ElementRef, HostBinding, Inject, Optional, ViewChild, forwardRef, } from '@angular/core';
|
3
|
+
import { Validators, NgControl } from '@angular/forms';
|
4
|
+
import { CommonModule } from '@angular/common';
|
5
|
+
import { fromEvent, merge } from 'rxjs';
|
6
|
+
import { WlcmErrorComponent } from '../error/error.component';
|
7
|
+
import { WLCM_FORM_CONTROL, WLCM_FORM_CONTROL_PROVIDER } from '../../constants/form-state-handlers.constants';
|
8
|
+
import { WlcmFormFieldCustomContainerDirective } from '../../directives/form-field-custom-container.directive';
|
9
|
+
import { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';
|
10
|
+
import { ErrorsMapperPipe } from '../../pipes/errors-mapper.pipe';
|
11
|
+
import { WLCM_FORM_FIELD, WLCM_INPUT } from '../../constants/form-elements.constants';
|
12
|
+
import * as i0 from "@angular/core";
|
13
|
+
import * as i1 from "@angular/common";
|
14
|
+
let WlcmFormFieldComponent = class WlcmFormFieldComponent {
|
15
|
+
get isFocused() {
|
16
|
+
return this.inputRef?.nativeElement === document.activeElement;
|
17
|
+
}
|
18
|
+
get isRequired() {
|
19
|
+
return this.control?.hasValidator(Validators.required);
|
20
|
+
}
|
21
|
+
get isInvalid() {
|
22
|
+
return this.control?.invalid;
|
23
|
+
}
|
24
|
+
get isTouched() {
|
25
|
+
return this.control?.touched;
|
26
|
+
}
|
27
|
+
constructor(parentFormMember, changeDetectorRef) {
|
28
|
+
this.parentFormMember = parentFormMember;
|
29
|
+
this.changeDetectorRef = changeDetectorRef;
|
30
|
+
}
|
31
|
+
ngAfterViewInit() {
|
32
|
+
if (!this.inputRef && !this.customContainer) {
|
33
|
+
throw new Error('Input element should be bound to the wlcmInput directive.');
|
34
|
+
}
|
35
|
+
this.handleStateChanges();
|
36
|
+
}
|
37
|
+
focus() {
|
38
|
+
if (!this.isFocused) {
|
39
|
+
this.inputRef?.nativeElement.focus();
|
40
|
+
}
|
41
|
+
}
|
42
|
+
get control() {
|
43
|
+
return this.ngControl?.control;
|
44
|
+
}
|
45
|
+
get inputContainer() {
|
46
|
+
return this.customContainer?.elementRef || this.defaultContainer;
|
47
|
+
}
|
48
|
+
handleStateChanges() {
|
49
|
+
const events = this.controlEvents;
|
50
|
+
if (this.parentFormMember) {
|
51
|
+
events.push(this.parentFormMember.stateChanges$);
|
52
|
+
}
|
53
|
+
merge(...events)
|
54
|
+
.pipe(untilDestroyed(this))
|
55
|
+
.subscribe(() => this.changeDetectorRef.markForCheck());
|
56
|
+
}
|
57
|
+
get inputRef() {
|
58
|
+
return this._inputRef?.get();
|
59
|
+
}
|
60
|
+
get controlEvents() {
|
61
|
+
const events = [];
|
62
|
+
if (this.inputRef) {
|
63
|
+
const element = this.inputRef.nativeElement;
|
64
|
+
events.push(fromEvent(element, 'focus'), fromEvent(element, 'blur'));
|
65
|
+
}
|
66
|
+
if (this.control) {
|
67
|
+
events.push(this.control.statusChanges);
|
68
|
+
}
|
69
|
+
return events;
|
70
|
+
}
|
71
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmFormFieldComponent, deps: [{ token: WLCM_FORM_CONTROL, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
72
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.5", type: WlcmFormFieldComponent, isStandalone: true, selector: "wlcm-form-field", host: { properties: { "class.wlcm-field-focused": "this.isFocused", "class.wlcm-field-required": "this.isRequired", "class.wlcm-field-invalid": "this.isInvalid", "class.wlcm-field-touched": "this.isTouched" }, classAttribute: "wlcm-form-field" }, providers: [
|
73
|
+
WLCM_FORM_CONTROL_PROVIDER,
|
74
|
+
{ provide: WLCM_FORM_FIELD, useExisting: forwardRef(() => WlcmFormFieldComponent) },
|
75
|
+
], queries: [{ propertyName: "ngControl", first: true, predicate: NgControl, descendants: true }, { propertyName: "_inputRef", first: true, predicate: WLCM_INPUT, descendants: true }, { propertyName: "customContainer", first: true, predicate: WlcmFormFieldCustomContainerDirective, descendants: true }], viewQueries: [{ propertyName: "defaultContainer", first: true, predicate: ["defaultContainer"], descendants: true }], ngImport: i0, template: "<ng-content select=\"wlcm-label\"></ng-content>\n\n<ng-content select=\"[wlcmFormFieldCustomContainer]\"></ng-content>\n\n<div\n class=\"wlcm-field-container\"\n (click)=\"focus()\"\n #defaultContainer\n *ngIf=\"!customContainer\"\n>\n <ng-content select=\"[wlcmInput], wlcm-autocomplete\"></ng-content>\n\n <div class=\"wlcm-field-suffix\">\n <ng-content select=\"[wlcmFormFieldSuffix]\"></ng-content>\n </div>\n</div>\n\n<ng-content select=\"[wlcmFormFieldHint]\"></ng-content>\n\n<div class=\"wlcm-field-error-container\" *ngIf=\"control\">\n <wlcm-error>{{ $any(control) | errorsMapper }}</wlcm-error>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: WlcmErrorComponent, selector: "wlcm-error" }, { kind: "pipe", type: ErrorsMapperPipe, name: "errorsMapper" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
76
|
+
};
|
77
|
+
WlcmFormFieldComponent = __decorate([
|
78
|
+
UntilDestroy(),
|
79
|
+
__metadata("design:paramtypes", [Object, ChangeDetectorRef])
|
80
|
+
], WlcmFormFieldComponent);
|
81
|
+
export { WlcmFormFieldComponent };
|
82
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmFormFieldComponent, decorators: [{
|
83
|
+
type: Component,
|
84
|
+
args: [{ selector: 'wlcm-form-field', standalone: true, imports: [CommonModule, WlcmErrorComponent, ErrorsMapperPipe], host: { class: 'wlcm-form-field' }, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
85
|
+
WLCM_FORM_CONTROL_PROVIDER,
|
86
|
+
{ provide: WLCM_FORM_FIELD, useExisting: forwardRef(() => WlcmFormFieldComponent) },
|
87
|
+
], template: "<ng-content select=\"wlcm-label\"></ng-content>\n\n<ng-content select=\"[wlcmFormFieldCustomContainer]\"></ng-content>\n\n<div\n class=\"wlcm-field-container\"\n (click)=\"focus()\"\n #defaultContainer\n *ngIf=\"!customContainer\"\n>\n <ng-content select=\"[wlcmInput], wlcm-autocomplete\"></ng-content>\n\n <div class=\"wlcm-field-suffix\">\n <ng-content select=\"[wlcmFormFieldSuffix]\"></ng-content>\n </div>\n</div>\n\n<ng-content select=\"[wlcmFormFieldHint]\"></ng-content>\n\n<div class=\"wlcm-field-error-container\" *ngIf=\"control\">\n <wlcm-error>{{ $any(control) | errorsMapper }}</wlcm-error>\n</div>\n" }]
|
88
|
+
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
89
|
+
type: Optional
|
90
|
+
}, {
|
91
|
+
type: Inject,
|
92
|
+
args: [WLCM_FORM_CONTROL]
|
93
|
+
}] }, { type: i0.ChangeDetectorRef }], propDecorators: { ngControl: [{
|
94
|
+
type: ContentChild,
|
95
|
+
args: [NgControl, { descendants: true }]
|
96
|
+
}], _inputRef: [{
|
97
|
+
type: ContentChild,
|
98
|
+
args: [WLCM_INPUT]
|
99
|
+
}], customContainer: [{
|
100
|
+
type: ContentChild,
|
101
|
+
args: [WlcmFormFieldCustomContainerDirective]
|
102
|
+
}], defaultContainer: [{
|
103
|
+
type: ViewChild,
|
104
|
+
args: ['defaultContainer']
|
105
|
+
}], isFocused: [{
|
106
|
+
type: HostBinding,
|
107
|
+
args: ['class.wlcm-field-focused']
|
108
|
+
}], isRequired: [{
|
109
|
+
type: HostBinding,
|
110
|
+
args: ['class.wlcm-field-required']
|
111
|
+
}], isInvalid: [{
|
112
|
+
type: HostBinding,
|
113
|
+
args: ['class.wlcm-field-invalid']
|
114
|
+
}], isTouched: [{
|
115
|
+
type: HostBinding,
|
116
|
+
args: ['class.wlcm-field-touched']
|
117
|
+
}] } });
|
118
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.component.js","sourceRoot":"","sources":["../../../../../../../../modules/forms/src/lib/forms/components/form-field/form-field.component.ts","../../../../../../../../modules/forms/src/lib/forms/components/form-field/form-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ElementRef,\n  HostBinding,\n  Inject,\n  Optional,\n  ViewChild,\n  forwardRef,\n} from '@angular/core';\nimport { Validators, AbstractControl, NgControl } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { Observable, fromEvent, merge } from 'rxjs';\nimport { WlcmErrorComponent } from '../error/error.component';\nimport { WLCM_FORM_CONTROL, WLCM_FORM_CONTROL_PROVIDER } from '../../constants/form-state-handlers.constants';\nimport { WlcmFormFieldCustomContainerDirective } from '../../directives/form-field-custom-container.directive';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport { ErrorsMapperPipe } from '../../pipes/errors-mapper.pipe';\nimport { WLCM_FORM_FIELD, WLCM_INPUT } from '../../constants/form-elements.constants';\nimport { WlcmFormControl } from '../../models/form.models';\nimport { WlcmInputGetter } from '../../models/input.models';\n\n@UntilDestroy()\n@Component({\n  selector: 'wlcm-form-field',\n  standalone: true,\n  imports: [CommonModule, WlcmErrorComponent, ErrorsMapperPipe],\n  host: { class: 'wlcm-form-field' },\n  templateUrl: './form-field.component.html',\n  styleUrls: ['./form-field.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    WLCM_FORM_CONTROL_PROVIDER,\n    { provide: WLCM_FORM_FIELD, useExisting: forwardRef(() => WlcmFormFieldComponent) },\n  ],\n})\nexport class WlcmFormFieldComponent implements AfterViewInit {\n  @ContentChild(NgControl, { descendants: true }) private ngControl!: NgControl;\n\n  @ContentChild(WLCM_INPUT) private _inputRef?: WlcmInputGetter;\n\n  @ContentChild(WlcmFormFieldCustomContainerDirective)\n  protected customContainer?: WlcmFormFieldCustomContainerDirective;\n\n  @ViewChild('defaultContainer')\n  protected defaultContainer?: ElementRef<HTMLElement>;\n\n  @HostBinding('class.wlcm-field-focused') get isFocused() {\n    return this.inputRef?.nativeElement === document.activeElement;\n  }\n\n  @HostBinding('class.wlcm-field-required') get isRequired() {\n    return this.control?.hasValidator(Validators.required);\n  }\n\n  @HostBinding('class.wlcm-field-invalid') get isInvalid() {\n    return this.control?.invalid;\n  }\n\n  @HostBinding('class.wlcm-field-touched') get isTouched() {\n    return this.control?.touched;\n  }\n\n  constructor(\n    @Optional()\n    @Inject(WLCM_FORM_CONTROL)\n    private parentFormMember: WlcmFormControl,\n    private changeDetectorRef: ChangeDetectorRef\n  ) {}\n\n  ngAfterViewInit(): void {\n    if (!this.inputRef && !this.customContainer) {\n      throw new Error('Input element should be bound to the wlcmInput directive.');\n    }\n\n    this.handleStateChanges();\n  }\n\n  focus(): void {\n    if (!this.isFocused) {\n      this.inputRef?.nativeElement.focus();\n    }\n  }\n\n  get control(): AbstractControl | null {\n    return this.ngControl?.control;\n  }\n\n  get inputContainer(): ElementRef<HTMLElement> {\n    return this.customContainer?.elementRef || (this.defaultContainer as ElementRef<HTMLElement>);\n  }\n\n  private handleStateChanges(): void {\n    const events: Observable<unknown>[] = this.controlEvents;\n\n    if (this.parentFormMember) {\n      events.push(this.parentFormMember.stateChanges$);\n    }\n\n    merge(...events)\n      .pipe(untilDestroyed(this))\n      .subscribe(() => this.changeDetectorRef.markForCheck());\n  }\n\n  private get inputRef(): ElementRef<HTMLInputElement> | undefined {\n    return this._inputRef?.get();\n  }\n\n  private get controlEvents(): Observable<unknown>[] {\n    const events: Observable<unknown>[] = [];\n\n    if (this.inputRef) {\n      const element: HTMLInputElement = (this.inputRef as ElementRef).nativeElement;\n\n      events.push(fromEvent(element, 'focus'), fromEvent(element, 'blur'));\n    }\n\n    if (this.control) {\n      events.push(this.control.statusChanges);\n    }\n\n    return events;\n  }\n}\n","<ng-content select=\"wlcm-label\"></ng-content>\n\n<ng-content select=\"[wlcmFormFieldCustomContainer]\"></ng-content>\n\n<div\n  class=\"wlcm-field-container\"\n  (click)=\"focus()\"\n  #defaultContainer\n  *ngIf=\"!customContainer\"\n>\n  <ng-content select=\"[wlcmInput], wlcm-autocomplete\"></ng-content>\n\n  <div class=\"wlcm-field-suffix\">\n    <ng-content select=\"[wlcmFormFieldSuffix]\"></ng-content>\n  </div>\n</div>\n\n<ng-content select=\"[wlcmFormFieldHint]\"></ng-content>\n\n<div class=\"wlcm-field-error-container\" *ngIf=\"control\">\n  <wlcm-error>{{ $any(control) | errorsMapper }}</wlcm-error>\n</div>\n"]}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
export * from './autocomplete/autocomplete.component';
|
2
|
+
export * from './form-field/form-field.component';
|
3
|
+
export * from './select/select.component';
|
4
|
+
export * from './error/error.component';
|
5
|
+
export * from './label/label.component';
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9tb2R1bGVzL2Zvcm1zL3NyYy9saWIvZm9ybXMvY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMseUJBQXlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2F1dG9jb21wbGV0ZS9hdXRvY29tcGxldGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZm9ybS1maWVsZC9mb3JtLWZpZWxkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdC9zZWxlY3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZXJyb3IvZXJyb3IuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGFiZWwvbGFiZWwuY29tcG9uZW50JztcbiJdfQ==
|