@wlcm/angular 1.0.1 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (32) hide show
  1. package/core/esm2022/index.mjs +4 -1
  2. package/core/esm2022/lib/constants/icon.contants.mjs +11 -0
  3. package/core/esm2022/lib/directives/icon.directive.mjs +29 -0
  4. package/core/esm2022/lib/models/icon.models.mjs +5 -0
  5. package/core/fesm2022/wlcm-angular-core.mjs +52 -13
  6. package/core/fesm2022/wlcm-angular-core.mjs.map +1 -1
  7. package/core/index.d.ts +3 -0
  8. package/core/lib/constants/icon.contants.d.ts +4 -0
  9. package/core/lib/directives/icon.directive.d.ts +12 -0
  10. package/core/lib/models/icon.models.d.ts +7 -0
  11. package/forms/esm2022/index.mjs +3 -1
  12. package/forms/esm2022/lib/forms/components/autocomplete/autocomplete.component.mjs +5 -2
  13. package/forms/esm2022/lib/forms/components/form-field/form-field.component.mjs +12 -10
  14. package/forms/esm2022/lib/forms/components/select/select.component.mjs +50 -15
  15. package/forms/esm2022/lib/forms/directives/form-field-prefix.directive.mjs +14 -0
  16. package/forms/esm2022/lib/forms/directives/input.directive.mjs +15 -7
  17. package/forms/esm2022/lib/forms/directives/select-input-binder.directive.mjs +33 -0
  18. package/forms/esm2022/lib/forms/forms.module.mjs +5 -1
  19. package/forms/esm2022/lib/forms/models/input.models.mjs +1 -1
  20. package/forms/fesm2022/wlcm-angular-forms.mjs +203 -116
  21. package/forms/fesm2022/wlcm-angular-forms.mjs.map +1 -1
  22. package/forms/index.d.ts +2 -0
  23. package/forms/lib/forms/components/form-field/form-field.component.d.ts +4 -2
  24. package/forms/lib/forms/components/select/select.component.d.ts +22 -7
  25. package/forms/lib/forms/directives/form-field-prefix.directive.d.ts +5 -0
  26. package/forms/lib/forms/directives/input.directive.d.ts +10 -1
  27. package/forms/lib/forms/directives/select-input-binder.directive.d.ts +5 -0
  28. package/forms/lib/forms/forms.module.d.ts +4 -3
  29. package/forms/lib/forms/models/input.models.d.ts +9 -3
  30. package/package.json +1 -1
  31. package/styles/components/forms/_form-field.scss +6 -0
  32. package/styles/components/forms/_select.scss +11 -21
@@ -1,33 +1,59 @@
1
1
  import { __decorate, __metadata } from "tslib";
2
2
  import { CommonModule } from '@angular/common';
3
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, Optional, forwardRef, } from '@angular/core';
3
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, Optional, ViewChild, forwardRef, } from '@angular/core';
4
4
  import { FormControl, NG_VALIDATORS, NG_VALUE_ACCESSOR, ReactiveFormsModule, } from '@angular/forms';
5
- import { MAT_SELECT_CONFIG, MatSelectModule } from '@angular/material/select';
5
+ import { MAT_SELECT_CONFIG, MatSelect, MatSelectModule } from '@angular/material/select';
6
6
  import { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';
7
- import { first, fromEvent } from 'rxjs';
8
- import { WLCM_FORM_CONTROL, WLCM_FORM_CONTROL_PROVIDER } from '../../constants';
7
+ import { WlcmIconDirective, WlcmIconName } from '@wlcm/angular/core';
8
+ import { WLCM_FORM_CONTROL, WLCM_FORM_CONTROL_PROVIDER, WLCM_FORM_FIELD } from '../../constants';
9
+ import { BehaviorSubject, EMPTY, first, fromEvent, switchMap } from 'rxjs';
10
+ import { WlcmSelectInputBinderDirective } from '../../directives/select-input-binder.directive';
11
+ import { CdkOverlayOrigin } from '@angular/cdk/overlay';
9
12
  import * as i0 from "@angular/core";
10
- import * as i1 from "@angular/common";
11
- import * as i2 from "@angular/material/select";
12
- import * as i3 from "@angular/material/core";
13
- import * as i4 from "@angular/forms";
13
+ import * as i1 from "../../directives/select-input-binder.directive";
14
+ import * as i2 from "@angular/common";
15
+ import * as i3 from "@angular/material/select";
16
+ import * as i4 from "@angular/material/core";
17
+ import * as i5 from "@angular/forms";
14
18
  const PANEL_CLASS = 'wlcm-select-panel';
15
19
  let WlcmSelectComponent = class WlcmSelectComponent {
16
- constructor(changeDetectorRef, parentFormMember) {
20
+ constructor(changeDetectorRef, formField, parentFormMember) {
17
21
  this.changeDetectorRef = changeDetectorRef;
22
+ this.formField = formField;
18
23
  this.parentFormMember = parentFormMember;
19
24
  this.multiple = false;
20
25
  this.placeholder = 'Not selected';
21
26
  this.options = [];
22
27
  this.control = new FormControl();
28
+ this.WlcmIconName = WlcmIconName;
29
+ this._focusStream$ = new BehaviorSubject(EMPTY);
30
+ this._blurStream$ = new BehaviorSubject(EMPTY);
31
+ this.focus$ = this._focusStream$.pipe(switchMap((stream) => stream));
32
+ this.blur$ = this._blurStream$.pipe(switchMap((stream) => stream));
33
+ this.focus = () => this.matSelect.open();
34
+ this.isFocused = () => this.isOpen;
23
35
  if (this.parentFormMember) {
24
36
  this.handleStateChange();
25
37
  }
26
38
  }
39
+ ngAfterViewInit() {
40
+ const formField = this.formField.inputContainer;
41
+ if (formField) {
42
+ this.matSelect._preferredOverlayOrigin = new CdkOverlayOrigin(this.formField.inputContainer);
43
+ }
44
+ this._focusStream$.next(this.matSelect._openedStream);
45
+ this._blurStream$.next(this.matSelect._closedStream);
46
+ }
27
47
  select(event) {
28
48
  this._changed?.(event.value);
29
49
  this._validatorChanged?.();
30
50
  }
51
+ openPanel() {
52
+ this.matSelect.open();
53
+ }
54
+ closePanel() {
55
+ this.matSelect.close();
56
+ }
31
57
  panelOpened() {
32
58
  this.handleClickOutside();
33
59
  }
@@ -52,6 +78,9 @@ let WlcmSelectComponent = class WlcmSelectComponent {
52
78
  this.control.markAsUntouched();
53
79
  }
54
80
  }
81
+ get isOpen() {
82
+ return this.matSelect?.panelOpen ?? false;
83
+ }
55
84
  handleStateChange() {
56
85
  this.parentFormMember.stateChanges$.pipe(untilDestroyed(this)).subscribe(() => {
57
86
  this._validatorChanged?.();
@@ -71,28 +100,31 @@ let WlcmSelectComponent = class WlcmSelectComponent {
71
100
  });
72
101
  }
73
102
  }
74
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmSelectComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: WLCM_FORM_CONTROL, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
103
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmSelectComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: WLCM_FORM_FIELD }, { token: WLCM_FORM_CONTROL, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
75
104
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.5", type: WlcmSelectComponent, isStandalone: true, selector: "wlcm-select", inputs: { multiple: "multiple", placeholder: "placeholder", options: "options" }, providers: [
76
105
  WLCM_FORM_CONTROL_PROVIDER,
77
106
  { provide: MAT_SELECT_CONFIG, useValue: { overlayPanelClass: PANEL_CLASS } },
78
107
  { provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },
79
108
  { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },
80
- ], ngImport: i0, template: "<mat-select\n #selectComponent\n [multiple]=\"multiple\"\n [disableRipple]=\"true\"\n [formControl]=\"control\"\n [placeholder]=\"placeholder\"\n [hideSingleSelectionIndicator]=\"true\"\n [ngClass]=\"{ focused: selectComponent.focused }\"\n (selectionChange)=\"select($event)\"\n (opened)=\"panelOpened()\"\n>\n <mat-option *ngFor=\"let option of options\" [value]=\"option.value\">\n {{ option.viewValue }}\n </mat-option>\n</mat-select>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i2.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i3.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
109
+ ], viewQueries: [{ propertyName: "matSelect", first: true, predicate: MatSelect, descendants: true }], hostDirectives: [{ directive: i1.WlcmSelectInputBinderDirective }], ngImport: i0, template: "<mat-select\n #selectComponent\n [multiple]=\"multiple\"\n [disableRipple]=\"true\"\n [formControl]=\"control\"\n [placeholder]=\"placeholder\"\n [hideSingleSelectionIndicator]=\"true\"\n [ngClass]=\"{ focused: selectComponent.focused }\"\n (selectionChange)=\"select($event)\"\n (opened)=\"panelOpened()\"\n>\n <mat-option *ngFor=\"let option of options\" [value]=\"option.value\">\n {{ option.viewValue }}\n </mat-option>\n</mat-select>\n\n<ng-container [wlcmIcon]=\"WlcmIconName.CHEVRON_DOWN\"></ng-container>\n", styles: [":host{display:flex;align-items:center}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i3.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i4.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: WlcmIconDirective, selector: "[wlcmIcon]", inputs: ["wlcmIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
81
110
  };
82
111
  WlcmSelectComponent = __decorate([
83
112
  UntilDestroy(),
84
- __metadata("design:paramtypes", [ChangeDetectorRef, Object])
113
+ __metadata("design:paramtypes", [ChangeDetectorRef, Object, Object])
85
114
  ], WlcmSelectComponent);
86
115
  export { WlcmSelectComponent };
87
116
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmSelectComponent, decorators: [{
88
117
  type: Component,
89
- args: [{ selector: 'wlcm-select', standalone: true, imports: [CommonModule, MatSelectModule, ReactiveFormsModule], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
118
+ args: [{ selector: 'wlcm-select', standalone: true, imports: [CommonModule, MatSelectModule, ReactiveFormsModule, WlcmIconDirective, WlcmSelectInputBinderDirective], changeDetection: ChangeDetectionStrategy.OnPush, hostDirectives: [WlcmSelectInputBinderDirective], providers: [
90
119
  WLCM_FORM_CONTROL_PROVIDER,
91
120
  { provide: MAT_SELECT_CONFIG, useValue: { overlayPanelClass: PANEL_CLASS } },
92
121
  { provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },
93
122
  { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },
94
- ], template: "<mat-select\n #selectComponent\n [multiple]=\"multiple\"\n [disableRipple]=\"true\"\n [formControl]=\"control\"\n [placeholder]=\"placeholder\"\n [hideSingleSelectionIndicator]=\"true\"\n [ngClass]=\"{ focused: selectComponent.focused }\"\n (selectionChange)=\"select($event)\"\n (opened)=\"panelOpened()\"\n>\n <mat-option *ngFor=\"let option of options\" [value]=\"option.value\">\n {{ option.viewValue }}\n </mat-option>\n</mat-select>\n", styles: [":host{display:block}\n"] }]
123
+ ], template: "<mat-select\n #selectComponent\n [multiple]=\"multiple\"\n [disableRipple]=\"true\"\n [formControl]=\"control\"\n [placeholder]=\"placeholder\"\n [hideSingleSelectionIndicator]=\"true\"\n [ngClass]=\"{ focused: selectComponent.focused }\"\n (selectionChange)=\"select($event)\"\n (opened)=\"panelOpened()\"\n>\n <mat-option *ngFor=\"let option of options\" [value]=\"option.value\">\n {{ option.viewValue }}\n </mat-option>\n</mat-select>\n\n<ng-container [wlcmIcon]=\"WlcmIconName.CHEVRON_DOWN\"></ng-container>\n", styles: [":host{display:flex;align-items:center}\n"] }]
95
124
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
125
+ type: Inject,
126
+ args: [WLCM_FORM_FIELD]
127
+ }] }, { type: undefined, decorators: [{
96
128
  type: Optional
97
129
  }, {
98
130
  type: Inject,
@@ -103,5 +135,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
103
135
  type: Input
104
136
  }], options: [{
105
137
  type: Input
138
+ }], matSelect: [{
139
+ type: ViewChild,
140
+ args: [MatSelect]
106
141
  }] } });
107
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../../modules/forms/src/lib/forms/components/select/select.component.ts","../../../../../../../../modules/forms/src/lib/forms/components/select/select.component.html"],"names":[],"mappings":";AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,MAAM,EACN,KAAK,EACL,QAAQ,EACR,UAAU,GACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAGL,WAAW,EACX,aAAa,EACb,iBAAiB,EACjB,mBAAmB,GACpB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,iBAAiB,EAAmB,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC/F,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACrE,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAExC,OAAO,EAAE,iBAAiB,EAAE,0BAA0B,EAAE,MAAM,iBAAiB,CAAC;;;;;;AAKhF,MAAM,WAAW,GAAW,mBAAmB,CAAC;AAiBzC,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IAe9B,YACU,iBAAoC,EACG,gBAAiC;QADxE,sBAAiB,GAAjB,iBAAiB,CAAmB;QACG,qBAAgB,GAAhB,gBAAgB,CAAiB;QAhBzE,aAAQ,GAAY,KAAK,CAAC;QAE1B,gBAAW,GAAW,cAAc,CAAC;QAErC,YAAO,GAAiB,EAAE,CAAC;QAE3B,YAAO,GAAgB,IAAI,WAAW,EAAE,CAAC;QAYhD,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,MAAM,CAAC,KAAsB;QAC3B,IAAI,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAE7B,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,UAAU,CAAC,KAAkB;QAC3B,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED,gBAAgB,CAAC,QAAqC;QACpD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAED,iBAAiB,CAAC,QAAoB;QACpC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAED,yBAAyB,CAAC,QAAoB;QAC5C,IAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC;IACpC,CAAC;IAED,QAAQ,CAAC,OAAwB;QAC/B,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAEvC,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;YACpB,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC;QAC/B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,OAAO,CAAC,eAAe,EAAE,CAAC;QACjC,CAAC;IACH,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC5E,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;YAE3B,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,kBAAkB;QACxB,MAAM,gBAAgB,GAAuB,QAAQ,CAAC,aAAa,CAAC,+BAA+B,WAAW,GAAG,CAAC,CAAC;QAEnH,MAAM,QAAQ,GAAmC,gBAAgB,EAAE,aAAa,CAAC,uBAAuB,CAAC,CAAC;QAE1G,IAAI,QAAQ,YAAY,WAAW,EAAE,CAAC;YACpC,SAAS,CAAC,QAAQ,EAAE,OAAO,CAAC;iBACzB,IAAI,CAAC,KAAK,EAAE,CAAC;iBACb,SAAS,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;gBAElB,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;gBAE3B,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;YACxC,CAAC,CAAC,CAAC;QACP,CAAC;IACH,CAAC;8GApFU,mBAAmB,mDAiBR,iBAAiB;kGAjB5B,mBAAmB,4IAPnB;YACT,0BAA0B;YAC1B,EAAE,OAAO,EAAE,iBAAiB,EAAE,QAAQ,EAAE,EAAE,iBAAiB,EAAE,WAAW,EAAE,EAAE;YAC5E,EAAE,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE;YAC3F,EAAE,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE;SAChG,0BC1CH,wcAeA,+EDkBY,YAAY,yPAAE,eAAe,mrBAAE,mBAAmB;;AAWjD,mBAAmB;IAf/B,YAAY,EAAE;qCA+BgB,iBAAiB;GAhBnC,mBAAmB,CAqF/B;;2FArFY,mBAAmB;kBAd/B,SAAS;+BACE,aAAa,cACX,IAAI,WACP,CAAC,YAAY,EAAE,eAAe,EAAE,mBAAmB,CAAC,mBAG5C,uBAAuB,CAAC,MAAM,aACpC;wBACT,0BAA0B;wBAC1B,EAAE,OAAO,EAAE,iBAAiB,EAAE,QAAQ,EAAE,EAAE,iBAAiB,EAAE,WAAW,EAAE,EAAE;wBAC5E,EAAE,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,oBAAoB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE;wBAC3F,EAAE,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,oBAAoB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE;qBAChG;;0BAmBE,QAAQ;;0BAAI,MAAM;2BAAC,iBAAiB;yCAhB9B,QAAQ;sBAAhB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEG,OAAO;sBAAf,KAAK","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Inject,\n  Input,\n  Optional,\n  forwardRef,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormControl,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n} from '@angular/forms';\nimport { MAT_SELECT_CONFIG, MatSelectChange, MatSelectModule } from '@angular/material/select';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport { first, fromEvent } from 'rxjs';\nimport { WlcmOption } from '@wlcm/angular/core';\nimport { WLCM_FORM_CONTROL, WLCM_FORM_CONTROL_PROVIDER } from '../../constants';\nimport { WlcmFormControl } from '../../models/_index';\n\ntype SelectValue = string[] | string;\n\nconst PANEL_CLASS: string = 'wlcm-select-panel';\n\n@UntilDestroy()\n@Component({\n  selector: 'wlcm-select',\n  standalone: true,\n  imports: [CommonModule, MatSelectModule, ReactiveFormsModule],\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    WLCM_FORM_CONTROL_PROVIDER,\n    { provide: MAT_SELECT_CONFIG, useValue: { overlayPanelClass: PANEL_CLASS } },\n    { provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },\n    { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },\n  ],\n})\nexport class WlcmSelectComponent implements ControlValueAccessor {\n  @Input() multiple: boolean = false;\n\n  @Input() placeholder: string = 'Not selected';\n\n  @Input() options: WlcmOption[] = [];\n\n  readonly control: FormControl = new FormControl();\n\n  private _changed?: (value: WlcmOption) => void;\n\n  private _touched?: () => void;\n\n  private _validatorChanged?: () => void;\n\n  constructor(\n    private changeDetectorRef: ChangeDetectorRef,\n    @Optional() @Inject(WLCM_FORM_CONTROL) private parentFormMember: WlcmFormControl\n  ) {\n    if (this.parentFormMember) {\n      this.handleStateChange();\n    }\n  }\n\n  select(event: MatSelectChange): void {\n    this._changed?.(event.value);\n\n    this._validatorChanged?.();\n  }\n\n  panelOpened(): void {\n    this.handleClickOutside();\n  }\n\n  writeValue(value: SelectValue): void {\n    this.control.setValue(value);\n  }\n\n  registerOnChange(callback: (value: WlcmOption) => void): void {\n    this._changed = callback;\n  }\n\n  registerOnTouched(callback: () => void): void {\n    this._touched = callback;\n  }\n\n  registerOnValidatorChange(callback: () => void): void {\n    this._validatorChanged = callback;\n  }\n\n  validate(control: AbstractControl): void {\n    this.control.setErrors(control.errors);\n\n    if (control.touched) {\n      this.control.markAsTouched();\n    } else {\n      this.control.markAsUntouched();\n    }\n  }\n\n  private handleStateChange(): void {\n    this.parentFormMember.stateChanges$.pipe(untilDestroyed(this)).subscribe(() => {\n      this._validatorChanged?.();\n\n      this.changeDetectorRef.markForCheck();\n    });\n  }\n\n  private handleClickOutside(): void {\n    const overlayContainer: HTMLElement | null = document.querySelector(`.cdk-overlay-container:has(.${PANEL_CLASS})`);\n\n    const backdrop: HTMLElement | null | undefined = overlayContainer?.querySelector(`.cdk-overlay-backdrop`);\n\n    if (backdrop instanceof HTMLElement) {\n      fromEvent(backdrop, 'click')\n        .pipe(first())\n        .subscribe(() => {\n          this._touched?.();\n\n          this._validatorChanged?.();\n\n          this.changeDetectorRef.markForCheck();\n        });\n    }\n  }\n}\n","<mat-select\n  #selectComponent\n  [multiple]=\"multiple\"\n  [disableRipple]=\"true\"\n  [formControl]=\"control\"\n  [placeholder]=\"placeholder\"\n  [hideSingleSelectionIndicator]=\"true\"\n  [ngClass]=\"{ focused: selectComponent.focused }\"\n  (selectionChange)=\"select($event)\"\n  (opened)=\"panelOpened()\"\n>\n  <mat-option *ngFor=\"let option of options\" [value]=\"option.value\">\n    {{ option.viewValue }}\n  </mat-option>\n</mat-select>\n"]}
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../../modules/forms/src/lib/forms/components/select/select.component.ts","../../../../../../../../modules/forms/src/lib/forms/components/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  Optional,\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} from '@angular/forms';\nimport { MAT_SELECT_CONFIG, MatSelect, MatSelectChange, MatSelectModule } from '@angular/material/select';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport { WlcmIconDirective, WlcmIconName, WlcmOption } from '@wlcm/angular/core';\nimport { WLCM_FORM_CONTROL, WLCM_FORM_CONTROL_PROVIDER, WLCM_FORM_FIELD } from '../../constants';\nimport { WlcmFormControl, WlcmFormField, WlcmFormFieldInput } from '../../models/_index';\nimport { BehaviorSubject, EMPTY, Observable, first, fromEvent, switchMap } from 'rxjs';\nimport { WlcmSelectInputBinderDirective } from '../../directives/select-input-binder.directive';\nimport { CdkOverlayOrigin } from '@angular/cdk/overlay';\n\ntype SelectValue = string[] | string;\n\nconst PANEL_CLASS: string = 'wlcm-select-panel';\n\n@UntilDestroy()\n@Component({\n  selector: 'wlcm-select',\n  standalone: true,\n  imports: [CommonModule, MatSelectModule, ReactiveFormsModule, WlcmIconDirective, WlcmSelectInputBinderDirective],\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  hostDirectives: [WlcmSelectInputBinderDirective],\n  providers: [\n    WLCM_FORM_CONTROL_PROVIDER,\n    { provide: MAT_SELECT_CONFIG, useValue: { overlayPanelClass: PANEL_CLASS } },\n    { provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },\n    { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },\n  ],\n})\nexport class WlcmSelectComponent implements WlcmFormFieldInput, ControlValueAccessor {\n  @Input() multiple: boolean = false;\n\n  @Input() placeholder: string = 'Not selected';\n\n  @Input() options: WlcmOption[] = [];\n\n  readonly control: FormControl = new FormControl();\n\n  readonly WlcmIconName = WlcmIconName;\n\n  private _changed?: (value: WlcmOption) => void;\n\n  private _touched?: () => void;\n\n  private _validatorChanged?: () => void;\n\n  @ViewChild(MatSelect) matSelect!: MatSelect;\n\n  private readonly _focusStream$: BehaviorSubject<Observable<void>> = new BehaviorSubject(EMPTY as Observable<void>);\n\n  private readonly _blurStream$: BehaviorSubject<Observable<void>> = new BehaviorSubject(EMPTY as Observable<void>);\n\n  focus$: Observable<unknown> = this._focusStream$.pipe(switchMap((stream: Observable<unknown>) => stream));\n\n  blur$: Observable<unknown> = this._blurStream$.pipe(switchMap((stream: Observable<unknown>) => stream));\n\n  constructor(\n    private changeDetectorRef: ChangeDetectorRef,\n    @Inject(WLCM_FORM_FIELD) private formField: WlcmFormField,\n    @Optional() @Inject(WLCM_FORM_CONTROL) private parentFormMember: WlcmFormControl\n  ) {\n    if (this.parentFormMember) {\n      this.handleStateChange();\n    }\n  }\n\n  ngAfterViewInit(): void {\n    const formField: ElementRef<HTMLElement> = this.formField.inputContainer;\n\n    if (formField) {\n      this.matSelect._preferredOverlayOrigin = new CdkOverlayOrigin(this.formField.inputContainer);\n    }\n\n    this._focusStream$.next(this.matSelect._openedStream);\n\n    this._blurStream$.next(this.matSelect._closedStream);\n  }\n\n  focus = (): void => this.matSelect.open();\n\n  isFocused = (): boolean => this.isOpen;\n\n  select(event: MatSelectChange): void {\n    this._changed?.(event.value);\n\n    this._validatorChanged?.();\n  }\n\n  openPanel(): void {\n    this.matSelect.open();\n  }\n\n  closePanel(): void {\n    this.matSelect.close();\n  }\n\n  panelOpened(): void {\n    this.handleClickOutside();\n  }\n\n  writeValue(value: SelectValue): void {\n    this.control.setValue(value);\n  }\n\n  registerOnChange(callback: (value: WlcmOption) => void): void {\n    this._changed = callback;\n  }\n\n  registerOnTouched(callback: () => void): void {\n    this._touched = callback;\n  }\n\n  registerOnValidatorChange(callback: () => void): void {\n    this._validatorChanged = callback;\n  }\n\n  validate(control: AbstractControl): void {\n    this.control.setErrors(control.errors);\n\n    if (control.touched) {\n      this.control.markAsTouched();\n    } else {\n      this.control.markAsUntouched();\n    }\n  }\n\n  get isOpen(): boolean {\n    return this.matSelect?.panelOpen ?? false;\n  }\n\n  private handleStateChange(): void {\n    this.parentFormMember.stateChanges$.pipe(untilDestroyed(this)).subscribe(() => {\n      this._validatorChanged?.();\n\n      this.changeDetectorRef.markForCheck();\n    });\n  }\n\n  private handleClickOutside(): void {\n    const overlayContainer: HTMLElement | null = document.querySelector(`.cdk-overlay-container:has(.${PANEL_CLASS})`);\n\n    const backdrop: HTMLElement | null | undefined = overlayContainer?.querySelector(`.cdk-overlay-backdrop`);\n\n    if (backdrop instanceof HTMLElement) {\n      fromEvent(backdrop, 'click')\n        .pipe(first())\n        .subscribe(() => {\n          this._touched?.();\n\n          this._validatorChanged?.();\n\n          this.changeDetectorRef.markForCheck();\n        });\n    }\n  }\n}\n","<mat-select\n  #selectComponent\n  [multiple]=\"multiple\"\n  [disableRipple]=\"true\"\n  [formControl]=\"control\"\n  [placeholder]=\"placeholder\"\n  [hideSingleSelectionIndicator]=\"true\"\n  [ngClass]=\"{ focused: selectComponent.focused }\"\n  (selectionChange)=\"select($event)\"\n  (opened)=\"panelOpened()\"\n>\n  <mat-option *ngFor=\"let option of options\" [value]=\"option.value\">\n    {{ option.viewValue }}\n  </mat-option>\n</mat-select>\n\n<ng-container [wlcmIcon]=\"WlcmIconName.CHEVRON_DOWN\"></ng-container>\n"]}
@@ -0,0 +1,14 @@
1
+ import { Directive } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class WlcmFormFieldPrefixDirective {
4
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmFormFieldPrefixDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
5
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.5", type: WlcmFormFieldPrefixDirective, isStandalone: true, selector: "[wlcmFormFieldPrefix]", ngImport: i0 }); }
6
+ }
7
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmFormFieldPrefixDirective, decorators: [{
8
+ type: Directive,
9
+ args: [{
10
+ selector: '[wlcmFormFieldPrefix]',
11
+ standalone: true,
12
+ }]
13
+ }] });
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1maWVsZC1wcmVmaXguZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9mb3Jtcy9zcmMvbGliL2Zvcm1zL2RpcmVjdGl2ZXMvZm9ybS1maWVsZC1wcmVmaXguZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTTFDLE1BQU0sT0FBTyw0QkFBNEI7OEdBQTVCLDRCQUE0QjtrR0FBNUIsNEJBQTRCOzsyRkFBNUIsNEJBQTRCO2tCQUp4QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbd2xjbUZvcm1GaWVsZFByZWZpeF0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBXbGNtRm9ybUZpZWxkUHJlZml4RGlyZWN0aXZlIHt9XG4iXX0=
@@ -1,15 +1,23 @@
1
1
  import { Directive, ElementRef, inject } from '@angular/core';
2
2
  import { WLCM_INPUT, WLCM_INPUT_BINDER } from '../constants/form-elements.constants';
3
+ import { fromEvent } from 'rxjs';
3
4
  import * as i0 from "@angular/core";
4
5
  export class WlcmInputDirective {
5
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmInputDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
6
+ constructor(_elementRef) {
7
+ this._elementRef = _elementRef;
8
+ this.focus = () => this._elementRef.nativeElement.focus();
9
+ this.isFocused = () => this._elementRef.nativeElement === document.activeElement;
10
+ this.focus$ = fromEvent(this._elementRef.nativeElement, 'focus');
11
+ this.blur$ = fromEvent(this._elementRef.nativeElement, 'blur');
12
+ }
13
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmInputDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
6
14
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.5", type: WlcmInputDirective, isStandalone: true, selector: "[wlcmInput]", host: { classAttribute: "wlcm-form-field-input" }, providers: [
7
15
  {
8
16
  provide: WLCM_INPUT,
9
17
  useFactory: () => {
10
- const inputRef = inject(ElementRef, { self: true });
18
+ const input = inject(WlcmInputDirective, { self: true });
11
19
  const binder = inject(WLCM_INPUT_BINDER, { self: true, optional: true });
12
- return { get: () => (binder ? binder.bind() : inputRef) };
20
+ return { get: () => (binder ? binder.bind() : input) };
13
21
  },
14
22
  },
15
23
  ], ngImport: i0 }); }
@@ -23,13 +31,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
23
31
  {
24
32
  provide: WLCM_INPUT,
25
33
  useFactory: () => {
26
- const inputRef = inject(ElementRef, { self: true });
34
+ const input = inject(WlcmInputDirective, { self: true });
27
35
  const binder = inject(WLCM_INPUT_BINDER, { self: true, optional: true });
28
- return { get: () => (binder ? binder.bind() : inputRef) };
36
+ return { get: () => (binder ? binder.bind() : input) };
29
37
  },
30
38
  },
31
39
  ],
32
40
  standalone: true,
33
41
  }]
34
- }] });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9mb3Jtcy9zcmMvbGliL2Zvcm1zL2RpcmVjdGl2ZXMvaW5wdXQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsVUFBVSxFQUFFLGlCQUFpQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7O0FBb0JyRixNQUFNLE9BQU8sa0JBQWtCOzhHQUFsQixrQkFBa0I7a0dBQWxCLGtCQUFrQiw2R0FkbEI7WUFDVDtnQkFDRSxPQUFPLEVBQUUsVUFBVTtnQkFDbkIsVUFBVSxFQUFFLEdBQUcsRUFBRTtvQkFDZixNQUFNLFFBQVEsR0FBaUMsTUFBTSxDQUFDLFVBQVUsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO29CQUVsRixNQUFNLE1BQU0sR0FBMkIsTUFBTSxDQUFDLGlCQUFpQixFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztvQkFFakcsT0FBTyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO2dCQUM1RCxDQUFDO2FBQ0Y7U0FDRjs7MkZBR1Usa0JBQWtCO2tCQWpCOUIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsYUFBYTtvQkFDdkIsSUFBSSxFQUFFLEVBQUUsS0FBSyxFQUFFLHVCQUF1QixFQUFFO29CQUN4QyxTQUFTLEVBQUU7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLFVBQVU7NEJBQ25CLFVBQVUsRUFBRSxHQUFHLEVBQUU7Z0NBQ2YsTUFBTSxRQUFRLEdBQWlDLE1BQU0sQ0FBQyxVQUFVLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztnQ0FFbEYsTUFBTSxNQUFNLEdBQTJCLE1BQU0sQ0FBQyxpQkFBaUIsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7Z0NBRWpHLE9BQU8sRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQzs0QkFDNUQsQ0FBQzt5QkFDRjtxQkFDRjtvQkFDRCxVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgV0xDTV9JTlBVVCwgV0xDTV9JTlBVVF9CSU5ERVIgfSBmcm9tICcuLi9jb25zdGFudHMvZm9ybS1lbGVtZW50cy5jb25zdGFudHMnO1xuaW1wb3J0IHsgV2xjbUlucHV0QmluZGVyIH0gZnJvbSAnLi4vbW9kZWxzL2lucHV0Lm1vZGVscyc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1t3bGNtSW5wdXRdJyxcbiAgaG9zdDogeyBjbGFzczogJ3dsY20tZm9ybS1maWVsZC1pbnB1dCcgfSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogV0xDTV9JTlBVVCxcbiAgICAgIHVzZUZhY3Rvcnk6ICgpID0+IHtcbiAgICAgICAgY29uc3QgaW5wdXRSZWY6IEVsZW1lbnRSZWY8SFRNTElucHV0RWxlbWVudD4gPSBpbmplY3QoRWxlbWVudFJlZiwgeyBzZWxmOiB0cnVlIH0pO1xuXG4gICAgICAgIGNvbnN0IGJpbmRlcjogV2xjbUlucHV0QmluZGVyIHwgbnVsbCA9IGluamVjdChXTENNX0lOUFVUX0JJTkRFUiwgeyBzZWxmOiB0cnVlLCBvcHRpb25hbDogdHJ1ZSB9KTtcblxuICAgICAgICByZXR1cm4geyBnZXQ6ICgpID0+IChiaW5kZXIgPyBiaW5kZXIuYmluZCgpIDogaW5wdXRSZWYpIH07XG4gICAgICB9LFxuICAgIH0sXG4gIF0sXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIFdsY21JbnB1dERpcmVjdGl2ZSB7fVxuIl19
42
+ }], ctorParameters: () => [{ type: i0.ElementRef }] });
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9mb3Jtcy9zcmMvbGliL2Zvcm1zL2RpcmVjdGl2ZXMvaW5wdXQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsVUFBVSxFQUFFLGlCQUFpQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFFckYsT0FBTyxFQUFjLFNBQVMsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFtQjdDLE1BQU0sT0FBTyxrQkFBa0I7SUFDN0IsWUFBb0IsV0FBeUM7UUFBekMsZ0JBQVcsR0FBWCxXQUFXLENBQThCO1FBRTdELFVBQUssR0FBRyxHQUFTLEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUUzRCxjQUFTLEdBQUcsR0FBWSxFQUFFLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLEtBQUssUUFBUSxDQUFDLGFBQWEsQ0FBQztRQUVyRixXQUFNLEdBQXdCLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsRUFBRSxPQUFPLENBQUMsQ0FBQztRQUVqRixVQUFLLEdBQXdCLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsRUFBRSxNQUFNLENBQUMsQ0FBQztJQVJmLENBQUM7OEdBRHRELGtCQUFrQjtrR0FBbEIsa0JBQWtCLDZHQWRsQjtZQUNUO2dCQUNFLE9BQU8sRUFBRSxVQUFVO2dCQUNuQixVQUFVLEVBQUUsR0FBRyxFQUFFO29CQUNmLE1BQU0sS0FBSyxHQUF1QixNQUFNLENBQUMsa0JBQWtCLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztvQkFFN0UsTUFBTSxNQUFNLEdBQTJCLE1BQU0sQ0FBQyxpQkFBaUIsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7b0JBRWpHLE9BQU8sRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztnQkFDekQsQ0FBQzthQUNGO1NBQ0Y7OzJGQUdVLGtCQUFrQjtrQkFqQjlCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGFBQWE7b0JBQ3ZCLElBQUksRUFBRSxFQUFFLEtBQUssRUFBRSx1QkFBdUIsRUFBRTtvQkFDeEMsU0FBUyxFQUFFO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxVQUFVOzRCQUNuQixVQUFVLEVBQUUsR0FBRyxFQUFFO2dDQUNmLE1BQU0sS0FBSyxHQUF1QixNQUFNLHFCQUFxQixFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO2dDQUU3RSxNQUFNLE1BQU0sR0FBMkIsTUFBTSxDQUFDLGlCQUFpQixFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztnQ0FFakcsT0FBTyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDOzRCQUN6RCxDQUFDO3lCQUNGO3FCQUNGO29CQUNELFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBXTENNX0lOUFVULCBXTENNX0lOUFVUX0JJTkRFUiB9IGZyb20gJy4uL2NvbnN0YW50cy9mb3JtLWVsZW1lbnRzLmNvbnN0YW50cyc7XG5pbXBvcnQgeyBXbGNtRm9ybUZpZWxkSW5wdXQsIFdsY21JbnB1dEJpbmRlciB9IGZyb20gJy4uL21vZGVscy9pbnB1dC5tb2RlbHMnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgZnJvbUV2ZW50IH0gZnJvbSAncnhqcyc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1t3bGNtSW5wdXRdJyxcbiAgaG9zdDogeyBjbGFzczogJ3dsY20tZm9ybS1maWVsZC1pbnB1dCcgfSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogV0xDTV9JTlBVVCxcbiAgICAgIHVzZUZhY3Rvcnk6ICgpID0+IHtcbiAgICAgICAgY29uc3QgaW5wdXQ6IFdsY21JbnB1dERpcmVjdGl2ZSA9IGluamVjdChXbGNtSW5wdXREaXJlY3RpdmUsIHsgc2VsZjogdHJ1ZSB9KTtcblxuICAgICAgICBjb25zdCBiaW5kZXI6IFdsY21JbnB1dEJpbmRlciB8IG51bGwgPSBpbmplY3QoV0xDTV9JTlBVVF9CSU5ERVIsIHsgc2VsZjogdHJ1ZSwgb3B0aW9uYWw6IHRydWUgfSk7XG5cbiAgICAgICAgcmV0dXJuIHsgZ2V0OiAoKSA9PiAoYmluZGVyID8gYmluZGVyLmJpbmQoKSA6IGlucHV0KSB9O1xuICAgICAgfSxcbiAgICB9LFxuICBdLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBXbGNtSW5wdXREaXJlY3RpdmUgaW1wbGVtZW50cyBXbGNtRm9ybUZpZWxkSW5wdXQge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxJbnB1dEVsZW1lbnQ+KSB7fVxuXG4gIGZvY3VzID0gKCk6IHZvaWQgPT4gdGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmZvY3VzKCk7XG5cbiAgaXNGb2N1c2VkID0gKCk6IGJvb2xlYW4gPT4gdGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50ID09PSBkb2N1bWVudC5hY3RpdmVFbGVtZW50O1xuXG4gIGZvY3VzJDogT2JzZXJ2YWJsZTx1bmtub3duPiA9IGZyb21FdmVudCh0aGlzLl9lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsICdmb2N1cycpO1xuXG4gIGJsdXIkOiBPYnNlcnZhYmxlPHVua25vd24+ID0gZnJvbUV2ZW50KHRoaXMuX2VsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgJ2JsdXInKTtcbn1cbiJdfQ==
@@ -0,0 +1,33 @@
1
+ import { Directive, inject } from '@angular/core';
2
+ import { WLCM_INPUT_BINDER } from '../constants';
3
+ import { WlcmSelectComponent } from '../components';
4
+ import * as i0 from "@angular/core";
5
+ export class WlcmSelectInputBinderDirective {
6
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmSelectInputBinderDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
7
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.5", type: WlcmSelectInputBinderDirective, isStandalone: true, selector: "[wlcmSelectInputBinder]", providers: [
8
+ {
9
+ provide: WLCM_INPUT_BINDER,
10
+ useFactory: () => {
11
+ const select = inject(WlcmSelectComponent, { self: true });
12
+ return { bind: () => select };
13
+ },
14
+ },
15
+ ], ngImport: i0 }); }
16
+ }
17
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmSelectInputBinderDirective, decorators: [{
18
+ type: Directive,
19
+ args: [{
20
+ standalone: true,
21
+ selector: '[wlcmSelectInputBinder]',
22
+ providers: [
23
+ {
24
+ provide: WLCM_INPUT_BINDER,
25
+ useFactory: () => {
26
+ const select = inject(WlcmSelectComponent, { self: true });
27
+ return { bind: () => select };
28
+ },
29
+ },
30
+ ],
31
+ }]
32
+ }] });
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWlucHV0LWJpbmRlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9tb2R1bGVzL2Zvcm1zL3NyYy9saWIvZm9ybXMvZGlyZWN0aXZlcy9zZWxlY3QtaW5wdXQtYmluZGVyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDakQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQWdCcEQsTUFBTSxPQUFPLDhCQUE4Qjs4R0FBOUIsOEJBQThCO2tHQUE5Qiw4QkFBOEIsc0VBWDlCO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsVUFBVSxFQUFFLEdBQUcsRUFBRTtvQkFDZixNQUFNLE1BQU0sR0FBd0IsTUFBTSxDQUFDLG1CQUFtQixFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7b0JBRWhGLE9BQU8sRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLENBQUMsTUFBTSxFQUFFLENBQUM7Z0JBQ2hDLENBQUM7YUFDRjtTQUNGOzsyRkFFVSw4QkFBOEI7a0JBZDFDLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSx5QkFBeUI7b0JBQ25DLFNBQVMsRUFBRTt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixVQUFVLEVBQUUsR0FBRyxFQUFFO2dDQUNmLE1BQU0sTUFBTSxHQUF3QixNQUFNLENBQUMsbUJBQW1CLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztnQ0FFaEYsT0FBTyxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQzs0QkFDaEMsQ0FBQzt5QkFDRjtxQkFDRjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBXTENNX0lOUFVUX0JJTkRFUiB9IGZyb20gJy4uL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBXbGNtU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi4vY29tcG9uZW50cyc7XG5cbkBEaXJlY3RpdmUoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ1t3bGNtU2VsZWN0SW5wdXRCaW5kZXJdJyxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogV0xDTV9JTlBVVF9CSU5ERVIsXG4gICAgICB1c2VGYWN0b3J5OiAoKSA9PiB7XG4gICAgICAgIGNvbnN0IHNlbGVjdDogV2xjbVNlbGVjdENvbXBvbmVudCA9IGluamVjdChXbGNtU2VsZWN0Q29tcG9uZW50LCB7IHNlbGY6IHRydWUgfSk7XG5cbiAgICAgICAgcmV0dXJuIHsgYmluZDogKCkgPT4gc2VsZWN0IH07XG4gICAgICB9LFxuICAgIH0sXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIFdsY21TZWxlY3RJbnB1dEJpbmRlckRpcmVjdGl2ZSB7fVxuIl19
@@ -8,11 +8,13 @@ import { WlcmAutocompleteComponent } from './components/autocomplete/autocomplet
8
8
  import { WlcmAcInputBinderDirective } from './directives/ac-input-binder.directive';
9
9
  import { WlcmFormFieldSuffixDirective } from './directives/form-field-suffix.directive';
10
10
  import { WlcmFormFieldHintDirective } from './directives/form-field-hint.directive';
11
+ import { WlcmFormFieldPrefixDirective } from './directives/form-field-prefix.directive';
11
12
  import * as i0 from "@angular/core";
12
13
  const directives = [
13
14
  WlcmInputDirective,
14
15
  WlcmFormFieldCustomContainerDirective,
15
16
  WlcmFormFieldSuffixDirective,
17
+ WlcmFormFieldPrefixDirective,
16
18
  WlcmAcInputBinderDirective,
17
19
  WlcmFormFieldHintDirective,
18
20
  ];
@@ -30,6 +32,7 @@ export class WlcmFormsModule {
30
32
  WlcmLabelComponent, WlcmInputDirective,
31
33
  WlcmFormFieldCustomContainerDirective,
32
34
  WlcmFormFieldSuffixDirective,
35
+ WlcmFormFieldPrefixDirective,
33
36
  WlcmAcInputBinderDirective,
34
37
  WlcmFormFieldHintDirective], exports: [WlcmFormFieldComponent,
35
38
  WlcmAutocompleteComponent,
@@ -37,6 +40,7 @@ export class WlcmFormsModule {
37
40
  WlcmLabelComponent, WlcmInputDirective,
38
41
  WlcmFormFieldCustomContainerDirective,
39
42
  WlcmFormFieldSuffixDirective,
43
+ WlcmFormFieldPrefixDirective,
40
44
  WlcmAcInputBinderDirective,
41
45
  WlcmFormFieldHintDirective] }); }
42
46
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmFormsModule, imports: [components] }); }
@@ -48,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
48
52
  exports: [...components, ...directives],
49
53
  }]
50
54
  }] });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybXMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9mb3Jtcy9zcmMvbGliL2Zvcm1zL2Zvcm1zLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFRLE1BQU0sZUFBZSxDQUFDO0FBQy9DLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDhDQUE4QyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQzNFLE9BQU8sRUFBRSxxQ0FBcUMsRUFBRSxNQUFNLG9EQUFvRCxDQUFDO0FBQzNHLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGtEQUFrRCxDQUFDO0FBQzdGLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQ3BGLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQ3hGLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLHdDQUF3QyxDQUFDOztBQUVwRixNQUFNLFVBQVUsR0FBb0I7SUFDbEMsa0JBQWtCO0lBQ2xCLHFDQUFxQztJQUNyQyw0QkFBNEI7SUFDNUIsMEJBQTBCO0lBQzFCLDBCQUEwQjtDQUMzQixDQUFDO0FBRUYsTUFBTSxVQUFVLEdBQW9CO0lBQ2xDLHNCQUFzQjtJQUN0Qix5QkFBeUI7SUFDekIsbUJBQW1CO0lBQ25CLGtCQUFrQjtDQUNuQixDQUFDO0FBTUYsTUFBTSxPQUFPLGVBQWU7OEdBQWYsZUFBZTsrR0FBZixlQUFlLFlBVjFCLHNCQUFzQjtZQUN0Qix5QkFBeUI7WUFDekIsbUJBQW1CO1lBQ25CLGtCQUFrQixFQVhsQixrQkFBa0I7WUFDbEIscUNBQXFDO1lBQ3JDLDRCQUE0QjtZQUM1QiwwQkFBMEI7WUFDMUIsMEJBQTBCLGFBSTFCLHNCQUFzQjtZQUN0Qix5QkFBeUI7WUFDekIsbUJBQW1CO1lBQ25CLGtCQUFrQixFQVhsQixrQkFBa0I7WUFDbEIscUNBQXFDO1lBQ3JDLDRCQUE0QjtZQUM1QiwwQkFBMEI7WUFDMUIsMEJBQTBCOytHQWNmLGVBQWUsWUFIYixVQUFVOzsyRkFHWixlQUFlO2tCQUozQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLEdBQUcsVUFBVSxFQUFFLEdBQUcsVUFBVSxDQUFDO29CQUN2QyxPQUFPLEVBQUUsQ0FBQyxHQUFHLFVBQVUsRUFBRSxHQUFHLFVBQVUsQ0FBQztpQkFDeEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSwgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgV2xjbUZvcm1GaWVsZENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9mb3JtLWZpZWxkL2Zvcm0tZmllbGQuY29tcG9uZW50JztcbmltcG9ydCB7IFdsY21JbnB1dERpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy9pbnB1dC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgV2xjbUxhYmVsQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2xhYmVsL2xhYmVsLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBXbGNtU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3NlbGVjdC9zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7IFdsY21Gb3JtRmllbGRDdXN0b21Db250YWluZXJEaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZXMvZm9ybS1maWVsZC1jdXN0b20tY29udGFpbmVyLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBXbGNtQXV0b2NvbXBsZXRlQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2F1dG9jb21wbGV0ZS9hdXRvY29tcGxldGUuY29tcG9uZW50JztcbmltcG9ydCB7IFdsY21BY0lucHV0QmluZGVyRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL2FjLWlucHV0LWJpbmRlci5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgV2xjbUZvcm1GaWVsZFN1ZmZpeERpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy9mb3JtLWZpZWxkLXN1ZmZpeC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgV2xjbUZvcm1GaWVsZEhpbnREaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZXMvZm9ybS1maWVsZC1oaW50LmRpcmVjdGl2ZSc7XG5cbmNvbnN0IGRpcmVjdGl2ZXM6IFR5cGU8dW5rbm93bj5bXSA9IFtcbiAgV2xjbUlucHV0RGlyZWN0aXZlLFxuICBXbGNtRm9ybUZpZWxkQ3VzdG9tQ29udGFpbmVyRGlyZWN0aXZlLFxuICBXbGNtRm9ybUZpZWxkU3VmZml4RGlyZWN0aXZlLFxuICBXbGNtQWNJbnB1dEJpbmRlckRpcmVjdGl2ZSxcbiAgV2xjbUZvcm1GaWVsZEhpbnREaXJlY3RpdmUsXG5dO1xuXG5jb25zdCBjb21wb25lbnRzOiBUeXBlPHVua25vd24+W10gPSBbXG4gIFdsY21Gb3JtRmllbGRDb21wb25lbnQsXG4gIFdsY21BdXRvY29tcGxldGVDb21wb25lbnQsXG4gIFdsY21TZWxlY3RDb21wb25lbnQsXG4gIFdsY21MYWJlbENvbXBvbmVudCxcbl07XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFsuLi5jb21wb25lbnRzLCAuLi5kaXJlY3RpdmVzXSxcbiAgZXhwb3J0czogWy4uLmNvbXBvbmVudHMsIC4uLmRpcmVjdGl2ZXNdLFxufSlcbmV4cG9ydCBjbGFzcyBXbGNtRm9ybXNNb2R1bGUge31cbiJdfQ==
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybXMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9mb3Jtcy9zcmMvbGliL2Zvcm1zL2Zvcm1zLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFRLE1BQU0sZUFBZSxDQUFDO0FBQy9DLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDhDQUE4QyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQzNFLE9BQU8sRUFBRSxxQ0FBcUMsRUFBRSxNQUFNLG9EQUFvRCxDQUFDO0FBQzNHLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGtEQUFrRCxDQUFDO0FBQzdGLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQ3BGLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQ3hGLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQ3BGLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDOztBQUV4RixNQUFNLFVBQVUsR0FBb0I7SUFDbEMsa0JBQWtCO0lBQ2xCLHFDQUFxQztJQUNyQyw0QkFBNEI7SUFDNUIsNEJBQTRCO0lBQzVCLDBCQUEwQjtJQUMxQiwwQkFBMEI7Q0FDM0IsQ0FBQztBQUVGLE1BQU0sVUFBVSxHQUFvQjtJQUNsQyxzQkFBc0I7SUFDdEIseUJBQXlCO0lBQ3pCLG1CQUFtQjtJQUNuQixrQkFBa0I7Q0FDbkIsQ0FBQztBQU1GLE1BQU0sT0FBTyxlQUFlOzhHQUFmLGVBQWU7K0dBQWYsZUFBZSxZQVYxQixzQkFBc0I7WUFDdEIseUJBQXlCO1lBQ3pCLG1CQUFtQjtZQUNuQixrQkFBa0IsRUFabEIsa0JBQWtCO1lBQ2xCLHFDQUFxQztZQUNyQyw0QkFBNEI7WUFDNUIsNEJBQTRCO1lBQzVCLDBCQUEwQjtZQUMxQiwwQkFBMEIsYUFJMUIsc0JBQXNCO1lBQ3RCLHlCQUF5QjtZQUN6QixtQkFBbUI7WUFDbkIsa0JBQWtCLEVBWmxCLGtCQUFrQjtZQUNsQixxQ0FBcUM7WUFDckMsNEJBQTRCO1lBQzVCLDRCQUE0QjtZQUM1QiwwQkFBMEI7WUFDMUIsMEJBQTBCOytHQWNmLGVBQWUsWUFIYixVQUFVOzsyRkFHWixlQUFlO2tCQUozQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLEdBQUcsVUFBVSxFQUFFLEdBQUcsVUFBVSxDQUFDO29CQUN2QyxPQUFPLEVBQUUsQ0FBQyxHQUFHLFVBQVUsRUFBRSxHQUFHLFVBQVUsQ0FBQztpQkFDeEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSwgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgV2xjbUZvcm1GaWVsZENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9mb3JtLWZpZWxkL2Zvcm0tZmllbGQuY29tcG9uZW50JztcbmltcG9ydCB7IFdsY21JbnB1dERpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy9pbnB1dC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgV2xjbUxhYmVsQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2xhYmVsL2xhYmVsLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBXbGNtU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3NlbGVjdC9zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7IFdsY21Gb3JtRmllbGRDdXN0b21Db250YWluZXJEaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZXMvZm9ybS1maWVsZC1jdXN0b20tY29udGFpbmVyLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBXbGNtQXV0b2NvbXBsZXRlQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2F1dG9jb21wbGV0ZS9hdXRvY29tcGxldGUuY29tcG9uZW50JztcbmltcG9ydCB7IFdsY21BY0lucHV0QmluZGVyRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL2FjLWlucHV0LWJpbmRlci5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgV2xjbUZvcm1GaWVsZFN1ZmZpeERpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy9mb3JtLWZpZWxkLXN1ZmZpeC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgV2xjbUZvcm1GaWVsZEhpbnREaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZXMvZm9ybS1maWVsZC1oaW50LmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBXbGNtRm9ybUZpZWxkUHJlZml4RGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL2Zvcm0tZmllbGQtcHJlZml4LmRpcmVjdGl2ZSc7XG5cbmNvbnN0IGRpcmVjdGl2ZXM6IFR5cGU8dW5rbm93bj5bXSA9IFtcbiAgV2xjbUlucHV0RGlyZWN0aXZlLFxuICBXbGNtRm9ybUZpZWxkQ3VzdG9tQ29udGFpbmVyRGlyZWN0aXZlLFxuICBXbGNtRm9ybUZpZWxkU3VmZml4RGlyZWN0aXZlLFxuICBXbGNtRm9ybUZpZWxkUHJlZml4RGlyZWN0aXZlLFxuICBXbGNtQWNJbnB1dEJpbmRlckRpcmVjdGl2ZSxcbiAgV2xjbUZvcm1GaWVsZEhpbnREaXJlY3RpdmUsXG5dO1xuXG5jb25zdCBjb21wb25lbnRzOiBUeXBlPHVua25vd24+W10gPSBbXG4gIFdsY21Gb3JtRmllbGRDb21wb25lbnQsXG4gIFdsY21BdXRvY29tcGxldGVDb21wb25lbnQsXG4gIFdsY21TZWxlY3RDb21wb25lbnQsXG4gIFdsY21MYWJlbENvbXBvbmVudCxcbl07XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFsuLi5jb21wb25lbnRzLCAuLi5kaXJlY3RpdmVzXSxcbiAgZXhwb3J0czogWy4uLmNvbXBvbmVudHMsIC4uLmRpcmVjdGl2ZXNdLFxufSlcbmV4cG9ydCBjbGFzcyBXbGNtRm9ybXNNb2R1bGUge31cbiJdfQ==
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQubW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9mb3Jtcy9zcmMvbGliL2Zvcm1zL21vZGVscy9pbnB1dC5tb2RlbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVsZW1lbnRSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBXbGNtSW5wdXRHZXR0ZXIge1xuICBnZXQ6ICgpID0+IEVsZW1lbnRSZWY8SFRNTElucHV0RWxlbWVudD47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgV2xjbUlucHV0QmluZGVyIHtcbiAgYmluZDogKCkgPT4gRWxlbWVudFJlZjxIVE1MSW5wdXRFbGVtZW50Pjtcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQubW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9mb3Jtcy9zcmMvbGliL2Zvcm1zL21vZGVscy9pbnB1dC5tb2RlbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcblxuZXhwb3J0IGludGVyZmFjZSBXbGNtSW5wdXRHZXR0ZXIge1xuICBnZXQ6ICgpID0+IFdsY21Gb3JtRmllbGRJbnB1dDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBXbGNtSW5wdXRCaW5kZXIge1xuICBiaW5kOiAoKSA9PiBXbGNtRm9ybUZpZWxkSW5wdXQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgV2xjbUZvcm1GaWVsZElucHV0IHtcbiAgZm9jdXMkOiBPYnNlcnZhYmxlPHVua25vd24+O1xuXG4gIGJsdXIkOiBPYnNlcnZhYmxlPHVua25vd24+O1xuXG4gIGlzRm9jdXNlZCgpOiBib29sZWFuO1xuXG4gIGZvY3VzKCk6IHZvaWQ7XG59XG4iXX0=