@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.
Files changed (150) hide show
  1. package/README.md +62 -0
  2. package/button/README.md +7 -0
  3. package/button/esm2022/index.mjs +3 -0
  4. package/button/esm2022/lib/button.module.mjs +16 -0
  5. package/button/esm2022/lib/components/button/button.component.mjs +37 -0
  6. package/button/esm2022/lib/models/button.models.mjs +2 -0
  7. package/button/esm2022/wlcm-angular-button.mjs +5 -0
  8. package/button/fesm2022/wlcm-angular-button.mjs +57 -0
  9. package/button/fesm2022/wlcm-angular-button.mjs.map +1 -0
  10. package/button/index.d.ts +2 -0
  11. package/button/lib/button.module.d.ts +7 -0
  12. package/button/lib/components/button/button.component.d.ts +13 -0
  13. package/button/lib/models/button.models.d.ts +1 -0
  14. package/core/README.md +7 -0
  15. package/core/esm2022/index.mjs +10 -0
  16. package/core/esm2022/lib/components/chevron-down-icon/chevron-down-icon.component.mjs +12 -0
  17. package/core/esm2022/lib/components/close-icon/close-icon.component.mjs +12 -0
  18. package/core/esm2022/lib/components/search-icon/search-icon.component.mjs +12 -0
  19. package/core/esm2022/lib/constants/http.constants.mjs +6 -0
  20. package/core/esm2022/lib/models/option.models.mjs +15 -0
  21. package/core/esm2022/lib/models/paginated-data.models.mjs +2 -0
  22. package/core/esm2022/lib/models/query-params.models.mjs +6 -0
  23. package/core/esm2022/lib/utils/stream.utils.mjs +28 -0
  24. package/core/esm2022/wlcm-angular-core.mjs +5 -0
  25. package/core/fesm2022/wlcm-angular-core.mjs +92 -0
  26. package/core/fesm2022/wlcm-angular-core.mjs.map +1 -0
  27. package/core/index.d.ts +8 -0
  28. package/core/lib/components/chevron-down-icon/chevron-down-icon.component.d.ts +5 -0
  29. package/core/lib/components/close-icon/close-icon.component.d.ts +5 -0
  30. package/core/lib/components/search-icon/search-icon.component.d.ts +5 -0
  31. package/core/lib/constants/http.constants.d.ts +2 -0
  32. package/core/lib/models/option.models.d.ts +11 -0
  33. package/core/lib/models/paginated-data.models.d.ts +6 -0
  34. package/core/lib/models/query-params.models.d.ts +26 -0
  35. package/core/lib/utils/stream.utils.d.ts +7 -0
  36. package/filters/README.md +7 -0
  37. package/filters/esm2022/index.mjs +8 -0
  38. package/filters/esm2022/lib/filters/components/filters/filters.component.mjs +21 -0
  39. package/filters/esm2022/lib/filters/components/filters-button/filters-button.component.mjs +25 -0
  40. package/filters/esm2022/lib/filters/components/filters-panel/filters-panel.component.mjs +86 -0
  41. package/filters/esm2022/lib/filters/components/filters-unit/filters-unit.component.mjs +55 -0
  42. package/filters/esm2022/lib/filters/directives/filters-content.directive.mjs +11 -0
  43. package/filters/esm2022/lib/filters/directives/filters-trigger.directive.mjs +69 -0
  44. package/filters/esm2022/lib/filters/filters.module.mjs +53 -0
  45. package/filters/esm2022/lib/filters/models/filters-default-selection-model.mjs +56 -0
  46. package/filters/esm2022/lib/filters/models/filters-trigger.base.mjs +56 -0
  47. package/filters/esm2022/lib/filters/models/filters.models.mjs +44 -0
  48. package/filters/esm2022/lib/filters/pipes/is-filters-param-checked.pipe.mjs +21 -0
  49. package/filters/esm2022/lib/filters/pipes/total-filters-applied.pipe.mjs +18 -0
  50. package/filters/esm2022/lib/filters/utils/filters.utils.mjs +13 -0
  51. package/filters/esm2022/wlcm-angular-filters.mjs +5 -0
  52. package/filters/fesm2022/wlcm-angular-filters.mjs +474 -0
  53. package/filters/fesm2022/wlcm-angular-filters.mjs.map +1 -0
  54. package/filters/index.d.ts +7 -0
  55. package/filters/lib/filters/components/filters/filters.component.d.ts +10 -0
  56. package/filters/lib/filters/components/filters-button/filters-button.component.d.ts +11 -0
  57. package/filters/lib/filters/components/filters-panel/filters-panel.component.d.ts +25 -0
  58. package/filters/lib/filters/components/filters-unit/filters-unit.component.d.ts +21 -0
  59. package/filters/lib/filters/directives/filters-content.directive.d.ts +5 -0
  60. package/filters/lib/filters/directives/filters-trigger.directive.d.ts +22 -0
  61. package/filters/lib/filters/filters.module.d.ts +20 -0
  62. package/filters/lib/filters/models/filters-default-selection-model.d.ts +18 -0
  63. package/filters/lib/filters/models/filters-trigger.base.d.ts +15 -0
  64. package/filters/lib/filters/models/filters.models.d.ts +42 -0
  65. package/filters/lib/filters/pipes/is-filters-param-checked.pipe.d.ts +10 -0
  66. package/filters/lib/filters/pipes/total-filters-applied.pipe.d.ts +8 -0
  67. package/filters/lib/filters/utils/filters.utils.d.ts +5 -0
  68. package/forms/README.md +7 -0
  69. package/forms/esm2022/index.mjs +10 -0
  70. package/forms/esm2022/lib/forms/components/autocomplete/autocomplete.component.mjs +164 -0
  71. package/forms/esm2022/lib/forms/components/error/error.component.mjs +12 -0
  72. package/forms/esm2022/lib/forms/components/form-field/form-field.component.mjs +118 -0
  73. package/forms/esm2022/lib/forms/components/index.mjs +6 -0
  74. package/forms/esm2022/lib/forms/components/label/label.component.mjs +23 -0
  75. package/forms/esm2022/lib/forms/components/select/select.component.mjs +107 -0
  76. package/forms/esm2022/lib/forms/constants/form-elements.constants.mjs +5 -0
  77. package/forms/esm2022/lib/forms/constants/form-errors.constants.mjs +7 -0
  78. package/forms/esm2022/lib/forms/constants/form-state-handlers.constants.mjs +13 -0
  79. package/forms/esm2022/lib/forms/constants/index.mjs +4 -0
  80. package/forms/esm2022/lib/forms/directives/ac-input-binder.directive.mjs +33 -0
  81. package/forms/esm2022/lib/forms/directives/autocomplete.directive.mjs +63 -0
  82. package/forms/esm2022/lib/forms/directives/form-field-custom-container.directive.mjs +17 -0
  83. package/forms/esm2022/lib/forms/directives/form-field-hint.directive.mjs +15 -0
  84. package/forms/esm2022/lib/forms/directives/form-field-suffix.directive.mjs +14 -0
  85. package/forms/esm2022/lib/forms/directives/input.directive.mjs +35 -0
  86. package/forms/esm2022/lib/forms/forms.module.mjs +51 -0
  87. package/forms/esm2022/lib/forms/models/_index.mjs +4 -0
  88. package/forms/esm2022/lib/forms/models/form-errors.models.mjs +2 -0
  89. package/forms/esm2022/lib/forms/models/form.models.mjs +2 -0
  90. package/forms/esm2022/lib/forms/models/input.models.mjs +2 -0
  91. package/forms/esm2022/lib/forms/pipes/errors-mapper.pipe.mjs +53 -0
  92. package/forms/esm2022/lib/forms/services/form-state-handler.service.mjs +19 -0
  93. package/forms/esm2022/lib/forms/services/index.mjs +2 -0
  94. package/forms/esm2022/wlcm-angular-forms.mjs +5 -0
  95. package/forms/fesm2022/wlcm-angular-forms.mjs +675 -0
  96. package/forms/fesm2022/wlcm-angular-forms.mjs.map +1 -0
  97. package/forms/index.d.ts +9 -0
  98. package/forms/lib/forms/components/autocomplete/autocomplete.component.d.ts +46 -0
  99. package/forms/lib/forms/components/error/error.component.d.ts +5 -0
  100. package/forms/lib/forms/components/form-field/form-field.component.d.ts +27 -0
  101. package/forms/lib/forms/components/index.d.ts +5 -0
  102. package/forms/lib/forms/components/label/label.component.d.ts +7 -0
  103. package/forms/lib/forms/components/select/select.component.d.ts +31 -0
  104. package/forms/lib/forms/constants/form-elements.constants.d.ts +6 -0
  105. package/forms/lib/forms/constants/form-errors.constants.d.ts +4 -0
  106. package/forms/lib/forms/constants/form-state-handlers.constants.d.ts +6 -0
  107. package/forms/lib/forms/constants/index.d.ts +3 -0
  108. package/forms/lib/forms/directives/ac-input-binder.directive.d.ts +5 -0
  109. package/forms/lib/forms/directives/autocomplete.directive.d.ts +16 -0
  110. package/forms/lib/forms/directives/form-field-custom-container.directive.d.ts +8 -0
  111. package/forms/lib/forms/directives/form-field-hint.directive.d.ts +5 -0
  112. package/forms/lib/forms/directives/form-field-suffix.directive.d.ts +5 -0
  113. package/forms/lib/forms/directives/input.directive.d.ts +5 -0
  114. package/forms/lib/forms/forms.module.d.ts +15 -0
  115. package/forms/lib/forms/models/_index.d.ts +3 -0
  116. package/forms/lib/forms/models/form-errors.models.d.ts +5 -0
  117. package/forms/lib/forms/models/form.models.d.ts +11 -0
  118. package/forms/lib/forms/models/input.models.d.ts +7 -0
  119. package/forms/lib/forms/pipes/errors-mapper.pipe.d.ts +17 -0
  120. package/forms/lib/forms/services/form-state-handler.service.d.ts +10 -0
  121. package/forms/lib/forms/services/index.d.ts +1 -0
  122. package/index.d.ts +1 -0
  123. package/index.mjs +4 -0
  124. package/package.json +109 -0
  125. package/search-field/README.md +7 -0
  126. package/search-field/esm2022/index.mjs +3 -0
  127. package/search-field/esm2022/lib/components/search-field/search-field.component.mjs +36 -0
  128. package/search-field/esm2022/lib/search-field.module.mjs +18 -0
  129. package/search-field/esm2022/wlcm-angular-search-field.mjs +5 -0
  130. package/search-field/fesm2022/wlcm-angular-search-field.mjs +57 -0
  131. package/search-field/fesm2022/wlcm-angular-search-field.mjs.map +1 -0
  132. package/search-field/index.d.ts +2 -0
  133. package/search-field/lib/components/search-field/search-field.component.d.ts +14 -0
  134. package/search-field/lib/search-field.module.d.ts +8 -0
  135. package/styles/components/button/index.scss +91 -0
  136. package/styles/components/common/index.scss +33 -0
  137. package/styles/components/filters/_filters-panel.scss +44 -0
  138. package/styles/components/filters/_filters-unit.scss +92 -0
  139. package/styles/components/filters/index.scss +7 -0
  140. package/styles/components/forms/_checkbox.scss +89 -0
  141. package/styles/components/forms/_error.scss +23 -0
  142. package/styles/components/forms/_form-field.scss +65 -0
  143. package/styles/components/forms/_label.scss +42 -0
  144. package/styles/components/forms/_select.scss +74 -0
  145. package/styles/components/forms/index.scss +13 -0
  146. package/styles/components/search-field/index.scss +31 -0
  147. package/styles/core/_all-theme.scss +15 -0
  148. package/styles/core/_core.scss +10 -0
  149. package/styles/core/_utils.scss +53 -0
  150. 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
+ }
@@ -0,0 +1,5 @@
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
+ }
@@ -0,0 +1,7 @@
1
+ # forms
2
+
3
+ This library was generated with [Nx](https://nx.dev).
4
+
5
+ ## Running unit tests
6
+
7
+ Run `nx test forms` to execute the unit tests.
@@ -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":";AAAA,OAAO,EAEL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,UAAU,EACV,WAAW,EACX,MAAM,EACN,QAAQ,EACR,SAAS,EACT,UAAU,GACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,UAAU,EAAmB,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACxE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAc,SAAS,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AACpD,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,0BAA0B,EAAE,MAAM,+CAA+C,CAAC;AAC9G,OAAO,EAAE,qCAAqC,EAAE,MAAM,wDAAwD,CAAC;AAC/G,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,yCAAyC,CAAC;;;AAkB/E,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;IAWjC,IAA6C,SAAS;QACpD,OAAO,IAAI,CAAC,QAAQ,EAAE,aAAa,KAAK,QAAQ,CAAC,aAAa,CAAC;IACjE,CAAC;IAED,IAA8C,UAAU;QACtD,OAAO,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;IACzD,CAAC;IAED,IAA6C,SAAS;QACpD,OAAO,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC;IAC/B,CAAC;IAED,IAA6C,SAAS;QACpD,OAAO,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC;IAC/B,CAAC;IAED,YAGU,gBAAiC,EACjC,iBAAoC;QADpC,qBAAgB,GAAhB,gBAAgB,CAAiB;QACjC,sBAAiB,GAAjB,iBAAiB,CAAmB;IAC3C,CAAC;IAEJ,eAAe;QACb,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YAC5C,MAAM,IAAI,KAAK,CAAC,2DAA2D,CAAC,CAAC;QAC/E,CAAC;QAED,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,KAAK;QACH,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpB,IAAI,CAAC,QAAQ,EAAE,aAAa,CAAC,KAAK,EAAE,CAAC;QACvC,CAAC;IACH,CAAC;IAED,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC;IACjC,CAAC;IAED,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,eAAe,EAAE,UAAU,IAAK,IAAI,CAAC,gBAA4C,CAAC;IAChG,CAAC;IAEO,kBAAkB;QACxB,MAAM,MAAM,GAA0B,IAAI,CAAC,aAAa,CAAC;QAEzD,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;QACnD,CAAC;QAED,KAAK,CAAC,GAAG,MAAM,CAAC;aACb,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;aAC1B,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC,CAAC;IAC5D,CAAC;IAED,IAAY,QAAQ;QAClB,OAAO,IAAI,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC;IAC/B,CAAC;IAED,IAAY,aAAa;QACvB,MAAM,MAAM,GAA0B,EAAE,CAAC;QAEzC,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,MAAM,OAAO,GAAsB,IAAI,CAAC,QAAuB,CAAC,aAAa,CAAC;YAE9E,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC;QACvE,CAAC;QAED,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAC1C,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;8GAtFU,sBAAsB,kBA6BvB,iBAAiB;kGA7BhB,sBAAsB,qTALtB;YACT,0BAA0B;YAC1B,EAAE,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC,EAAE;SACpF,iEAGa,SAAS,4EAET,UAAU,kFAEV,qCAAqC,sKC5CrD,onBAsBA,yDDOY,YAAY,mIAAE,kBAAkB,kDAAE,gBAAgB;;AAUjD,sBAAsB;IAdlC,YAAY,EAAE;6CA6CgB,iBAAiB;GA/BnC,sBAAsB,CAuFlC;;2FAvFY,sBAAsB;kBAblC,SAAS;+BACE,iBAAiB,cACf,IAAI,WACP,CAAC,YAAY,EAAE,kBAAkB,EAAE,gBAAgB,CAAC,QACvD,EAAE,KAAK,EAAE,iBAAiB,EAAE,mBAGjB,uBAAuB,CAAC,MAAM,aACpC;wBACT,0BAA0B;wBAC1B,EAAE,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC,EAAE;qBACpF;;0BA8BE,QAAQ;;0BACR,MAAM;2BAAC,iBAAiB;yEA5B6B,SAAS;sBAAhE,YAAY;uBAAC,SAAS,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAEZ,SAAS;sBAA1C,YAAY;uBAAC,UAAU;gBAGd,eAAe;sBADxB,YAAY;uBAAC,qCAAqC;gBAIzC,gBAAgB;sBADzB,SAAS;uBAAC,kBAAkB;gBAGgB,SAAS;sBAArD,WAAW;uBAAC,0BAA0B;gBAIO,UAAU;sBAAvD,WAAW;uBAAC,2BAA2B;gBAIK,SAAS;sBAArD,WAAW;uBAAC,0BAA0B;gBAIM,SAAS;sBAArD,WAAW;uBAAC,0BAA0B","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==