@odx/angular 6.3.1 → 6.5.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 (37) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/cdk/autocomplete-control/lib/autocomplete-control.d.ts +53 -1
  3. package/components/autocomplete/lib/autocomplete.component.d.ts +0 -2
  4. package/components/calendar/lib/calendar.config.d.ts +1 -1
  5. package/components/card/lib/card.component.d.ts +11 -4
  6. package/components/card/lib/card.config.d.ts +43 -0
  7. package/components/card/lib/card.module.d.ts +6 -10
  8. package/components/card/lib/components/card-image/card-image.component.d.ts +26 -0
  9. package/components/card/lib/components/index.d.ts +1 -0
  10. package/components/card/lib/directives/card-content.directive.d.ts +1 -1
  11. package/components/card/lib/directives/index.d.ts +0 -1
  12. package/components/card/lib/models/card-variant.d.ts +1 -0
  13. package/esm2022/cdk/autocomplete-control/lib/autocomplete-control.mjs +73 -2
  14. package/esm2022/components/autocomplete/lib/autocomplete.component.mjs +3 -7
  15. package/esm2022/components/calendar/lib/calendar.config.mjs +2 -2
  16. package/esm2022/components/card/lib/card.component.mjs +13 -8
  17. package/esm2022/components/card/lib/card.config.mjs +24 -0
  18. package/esm2022/components/card/lib/card.module.mjs +7 -38
  19. package/esm2022/components/card/lib/components/card-image/card-image.component.mjs +56 -0
  20. package/esm2022/components/card/lib/components/index.mjs +2 -1
  21. package/esm2022/components/card/lib/directives/card-content.directive.mjs +3 -3
  22. package/esm2022/components/card/lib/directives/index.mjs +1 -2
  23. package/esm2022/components/card/lib/models/card-variant.mjs +2 -1
  24. package/esm2022/components/select/lib/select.component.mjs +6 -5
  25. package/fesm2022/odx-angular-cdk-autocomplete-control.mjs +72 -1
  26. package/fesm2022/odx-angular-cdk-autocomplete-control.mjs.map +1 -1
  27. package/fesm2022/odx-angular-components-autocomplete.mjs +2 -6
  28. package/fesm2022/odx-angular-components-autocomplete.mjs.map +1 -1
  29. package/fesm2022/odx-angular-components-calendar.mjs +1 -1
  30. package/fesm2022/odx-angular-components-calendar.mjs.map +1 -1
  31. package/fesm2022/odx-angular-components-card.mjs +99 -68
  32. package/fesm2022/odx-angular-components-card.mjs.map +1 -1
  33. package/fesm2022/odx-angular-components-select.mjs +5 -4
  34. package/fesm2022/odx-angular-components-select.mjs.map +1 -1
  35. package/package.json +5 -5
  36. package/components/card/lib/directives/card-title.directive.d.ts +0 -8
  37. package/esm2022/components/card/lib/directives/card-title.directive.mjs +0 -20
package/CHANGELOG.md CHANGED
@@ -1,5 +1,24 @@
1
1
  # @odx/angular
2
2
 
3
+ ## 6.5.0
4
+
5
+ ### Minor Changes
6
+
7
+ - bb425b3: New image-card variant for card component
8
+
9
+ ### Patch Changes
10
+
11
+ - d9b77c1: new options in storybook for rail navigation
12
+
13
+ ## 6.4.0
14
+
15
+ ### Minor Changes
16
+
17
+ - b4890e7: Add `beforeDropdownOpen`, `afterDropdownOpen`, `beforeDropdownClose` and `afterDropdownClose` outputs to `odx-select` and `odx-autocomplete` components
18
+
19
+ Updated `date-fns` dependency to `^3.6.0`
20
+ Updated `deepmerge-ts` dependency to `^7.0.0`
21
+
3
22
  ## 6.3.1
4
23
 
5
24
  ### Patch Changes
@@ -64,6 +64,54 @@ export declare abstract class AutocompleteControl<T> extends CustomFormControl<T
64
64
  * ```
65
65
  */
66
66
  optionSelected: EventEmitter<T>;
67
+ /**
68
+ * Event emitted before the dropdown opens.
69
+ *
70
+ * @emits {void}
71
+ *
72
+ * @example
73
+ * ```html
74
+ * <odx-select (beforeDropdownOpen)="onBeforeDropdownOpen()">
75
+ * </odx-select>
76
+ * ```
77
+ */
78
+ beforeDropdownOpen: EventEmitter<void>;
79
+ /**
80
+ * Event emitted after the dropdown opened.
81
+ *
82
+ * @emits {void}
83
+ *
84
+ * @example
85
+ * ```html
86
+ * <odx-select (afterDropdownOpen)="onAfterDropdownOpen()">
87
+ * </odx-select>
88
+ * ```
89
+ */
90
+ afterDropdownOpen: EventEmitter<void>;
91
+ /**
92
+ * Event emitted before the dropdown closes.
93
+ *
94
+ * @emits {void}
95
+ *
96
+ * @example
97
+ * ```html
98
+ * <odx-select (beforeDropdownClose)="onBeforeDropdownClose()">
99
+ * </odx-select>
100
+ * ```
101
+ */
102
+ beforeDropdownClose: EventEmitter<void>;
103
+ /**
104
+ * Event emitted after the dropdown closed.
105
+ *
106
+ * @emits {void}
107
+ *
108
+ * @example
109
+ * ```html
110
+ * <odx-select (afterDropdownClose)="onAfterDropdownClose()">
111
+ * </odx-select>
112
+ * ```
113
+ */
114
+ afterDropdownClose: EventEmitter<void>;
67
115
  constructor();
68
116
  ngAfterViewInit(): void;
69
117
  /**
@@ -86,8 +134,12 @@ export declare abstract class AutocompleteControl<T> extends CustomFormControl<T
86
134
  protected enableSmoothScroll(): void;
87
135
  protected openDropdown(): void;
88
136
  protected closeDropdown(): void;
137
+ protected onDropdownOpen(): void;
138
+ protected onDropdownOpened(): void;
139
+ protected onDropdownClose(): void;
140
+ protected onDropdownClosed(): void;
89
141
  protected handleFocusOut(event: FocusEvent): void;
90
142
  static ɵfac: i0.ɵɵFactoryDeclaration<AutocompleteControl<any>, never>;
91
- static ɵdir: i0.ɵɵDirectiveDeclaration<AutocompleteControl<any>, never, never, { "isLoading": { "alias": "isLoading"; "required": false; }; "stringify": { "alias": "stringify"; "required": false; }; }, { "optionSelected": "optionSelected"; }, never, never, true, never>;
143
+ static ɵdir: i0.ɵɵDirectiveDeclaration<AutocompleteControl<any>, never, never, { "isLoading": { "alias": "isLoading"; "required": false; }; "stringify": { "alias": "stringify"; "required": false; }; }, { "optionSelected": "optionSelected"; "beforeDropdownOpen": "beforeDropdownOpen"; "afterDropdownOpen": "afterDropdownOpen"; "beforeDropdownClose": "beforeDropdownClose"; "afterDropdownClose": "afterDropdownClose"; }, never, never, true, never>;
92
144
  static ngAcceptInputType_isLoading: unknown;
93
145
  }
@@ -30,7 +30,6 @@ export declare class AutocompleteComponent<T = unknown> extends AutocompleteCont
30
30
  * @type {AutocompleteInputControlDirective | undefined}
31
31
  */
32
32
  searchField?: AutocompleteInputControlDirective;
33
- readonly dropdownOpenTriggers: never[];
34
33
  ngAfterViewInit(): void;
35
34
  /**
36
35
  * Selects an option, updates the value, updates the search field display,
@@ -53,7 +52,6 @@ export declare class AutocompleteComponent<T = unknown> extends AutocompleteCont
53
52
  protected handleClickEvent(): void;
54
53
  protected handleKeyboardEvent(event: KeyboardEvent): void;
55
54
  protected activateSelectedOption(): void;
56
- protected onDropdownBeforeOpen(): void;
57
55
  private updateSearchField;
58
56
  private blurSelectSearchField;
59
57
  static ɵfac: i0.ɵɵFactoryDeclaration<AutocompleteComponent<any>, never>;
@@ -57,7 +57,7 @@ export interface CalendarConfig {
57
57
  * providers: [provideCalendarConfig({ selectionMode: CalendarSelectionMode.DateRange, locale: new BehaviorSubject<Locale>(deDE)})]
58
58
  * })
59
59
  * export class MyDateRangepickerComponent {}
60
- * ````
60
+ * ```
61
61
  *
62
62
  * @example
63
63
  * ```ts
@@ -14,18 +14,25 @@ import * as i1 from "@odx/angular/cdk/a11y";
14
14
  export declare class CardComponent {
15
15
  private readonly interactiveDirective;
16
16
  private readonly takeUntilDestroyed;
17
+ private readonly config;
18
+ protected cardVariant: {
19
+ readonly DEFAULT: "default";
20
+ readonly LAUNCH_TILE: "launch-tile";
21
+ readonly LAUNCH_TILE_CENTERED: "launch-tile-centered";
22
+ readonly IMAGE_CARD: "image-card";
23
+ };
17
24
  protected readonly menu?: MenuComponent;
18
25
  protected readonly buttons?: ActionGroupComponent;
19
26
  protected readonly menuHost?: MenuDirective;
20
27
  protected readonly footer?: ElementRef<HTMLElement>;
21
- readonly element: ElementRef<HTMLElement>;
28
+ element: ElementRef<HTMLElement>;
22
29
  /**
23
30
  * The variant of the card.
24
31
  *
25
32
  * @type {CardVariant}
26
33
  * @default CardVariant.DEFAULT
27
34
  */
28
- variant?: CardVariant;
35
+ variant: CardVariant;
29
36
  /**
30
37
  * Menu icon name.
31
38
  *
@@ -39,9 +46,9 @@ export declare class CardComponent {
39
46
  * @emits {Event}
40
47
  */
41
48
  interact: EventEmitter<Event>;
49
+ get launchTile(): boolean;
42
50
  constructor();
43
- protected get launchTile(): boolean;
44
51
  private stopEvents;
45
52
  static ɵfac: i0.ɵɵFactoryDeclaration<CardComponent, never>;
46
- static ɵcmp: i0.ɵɵComponentDeclaration<CardComponent, "odx-card", never, { "variant": { "alias": "variant"; "required": false; }; "menuIcon": { "alias": "menuIcon"; "required": false; }; }, { "interact": "interact"; }, ["menu", "buttons", "footer"], ["odx-avatar", "odx-launch-card-subtitle", "[odxCardContent]", "odx-card-footer", "odx-menu", "*", "odx-action-group"], true, [{ directive: typeof i1.InteractiveDirective; inputs: {}; outputs: {}; }]>;
53
+ static ɵcmp: i0.ɵɵComponentDeclaration<CardComponent, "odx-card", never, { "variant": { "alias": "variant"; "required": false; }; "menuIcon": { "alias": "menuIcon"; "required": false; }; }, { "interact": "interact"; }, ["menu", "buttons", "footer"], ["odx-card-image", "[odxCardContent], odx-card-content", "odx-avatar", "odx-launch-card-subtitle", "odx-card-footer", "odx-menu", "*", "odx-action-group"], true, [{ directive: typeof i1.InteractiveDirective; inputs: {}; outputs: {}; }]>;
47
54
  }
@@ -0,0 +1,43 @@
1
+ import { CardVariant } from './models';
2
+ export interface CardConfig {
3
+ variant?: CardVariant;
4
+ maxImageHeight?: string;
5
+ imageRatio?: string;
6
+ }
7
+ /**
8
+ * Tools for customizing configuration for the card component
9
+ *
10
+ * @example
11
+ * ```ts
12
+ * @Component({
13
+ * ...
14
+ * providers: [provideCardConfig({imageRatio: '5/3', maxImageHeight: '200px'})]
15
+ * })
16
+ * export class MyCardComponent {}
17
+ * ```
18
+ * @example
19
+ * ```ts
20
+ * constructor(@Inject(CardConfig) private readonly cardConfig: CardConfig) {}
21
+ * ```
22
+ */
23
+ export declare const CardConfig: import("@angular/core").InjectionToken<Partial<{
24
+ variant: CardVariant;
25
+ maxImageHeight: string;
26
+ imageRatio: string;
27
+ }>>, CardDefaultConfig: {
28
+ variant: CardVariant;
29
+ maxImageHeight: string;
30
+ imageRatio: string;
31
+ }, injectCardConfig: () => {
32
+ variant: CardVariant;
33
+ maxImageHeight: string;
34
+ imageRatio: string;
35
+ }, provideCardConfig: <D extends import("@odx/angular/utils").ConfigDependencies<unknown> = import("@odx/angular/utils").ConfigDependencies<Partial<{
36
+ variant: CardVariant;
37
+ maxImageHeight: string;
38
+ imageRatio: string;
39
+ }>>>(config: import("@odx/angular/utils").ConfigProvider<Partial<{
40
+ variant: CardVariant;
41
+ maxImageHeight: string;
42
+ imageRatio: string;
43
+ }>, D>) => import("@angular/core").FactoryProvider | import("@angular/core").ValueProvider;
@@ -1,16 +1,12 @@
1
1
  import * as i0 from "@angular/core";
2
2
  import * as i1 from "./card.component";
3
- import * as i2 from "./directives/card-title.directive";
4
- import * as i3 from "./directives/card-content.directive";
5
- import * as i4 from "./components/card-footer/card-footer.component";
6
- import * as i5 from "./components/launch-card-subtitle/launch-card-subtitle.component";
7
- import * as i6 from "@odx/angular/components/avatar";
8
- import * as i7 from "@odx/angular/components/button";
9
- import * as i8 from "@odx/angular/components/icon";
10
- import * as i9 from "@odx/angular";
11
- import * as i10 from "@odx/angular/components/menu";
3
+ import * as i2 from "./components/card-footer/card-footer.component";
4
+ import * as i3 from "./components/card-image/card-image.component";
5
+ import * as i4 from "./components/launch-card-subtitle/launch-card-subtitle.component";
6
+ import * as i5 from "./directives/card-content.directive";
7
+ import * as i6 from "@odx/angular";
12
8
  export declare class CardModule {
13
9
  static ɵfac: i0.ɵɵFactoryDeclaration<CardModule, never>;
14
- static ɵmod: i0.ɵɵNgModuleDeclaration<CardModule, never, [typeof i1.CardComponent, typeof i2.CardTitleDirective, typeof i3.CardContentDirective, typeof i4.CardFooterComponent, typeof i5.LaunchCardSubtitleComponent, typeof i6.AvatarComponent, typeof i7.ButtonComponent, typeof i8.IconComponent], [typeof i9.CoreModule, typeof i10.MenuModule, typeof i1.CardComponent, typeof i2.CardTitleDirective, typeof i3.CardContentDirective, typeof i4.CardFooterComponent, typeof i5.LaunchCardSubtitleComponent, typeof i6.AvatarComponent, typeof i7.ButtonComponent, typeof i8.IconComponent]>;
10
+ static ɵmod: i0.ɵɵNgModuleDeclaration<CardModule, never, [typeof i1.CardComponent, typeof i2.CardFooterComponent, typeof i3.CardImageComponent, typeof i4.LaunchCardSubtitleComponent, typeof i5.CardContentDirective], [typeof i6.CoreModule, typeof i1.CardComponent, typeof i2.CardFooterComponent, typeof i3.CardImageComponent, typeof i4.LaunchCardSubtitleComponent, typeof i5.CardContentDirective]>;
15
11
  static ɵinj: i0.ɵɵInjectorDeclaration<CardModule>;
16
12
  }
@@ -0,0 +1,26 @@
1
+ import * as i0 from "@angular/core";
2
+ /**
3
+ * Represents a card image component.
4
+ */
5
+ export declare class CardImageComponent {
6
+ private readonly config;
7
+ readonly element: import("@angular/core").ElementRef<HTMLElement>;
8
+ /**
9
+ * The ratio of the card image.
10
+ *
11
+ * @type {string}
12
+ * @default 'auto'
13
+ */
14
+ imageRatio: string;
15
+ /**
16
+ * The maximum height of the card image.
17
+ *
18
+ * @type {string}
19
+ * @default 'auto'
20
+ */
21
+ maxImageHeight: string;
22
+ protected get getMaxImageHeight(): string;
23
+ protected get getImageAspectRatio(): string;
24
+ static ɵfac: i0.ɵɵFactoryDeclaration<CardImageComponent, never>;
25
+ static ɵcmp: i0.ɵɵComponentDeclaration<CardImageComponent, "odx-card-image", never, { "imageRatio": { "alias": "imageRatio"; "required": false; }; "maxImageHeight": { "alias": "maxImageHeight"; "required": false; }; }, {}, never, ["odx-chip", "img"], true, never>;
26
+ }
@@ -1,2 +1,3 @@
1
1
  export * from './card-footer/card-footer.component';
2
+ export * from './card-image/card-image.component';
2
3
  export * from './launch-card-subtitle/launch-card-subtitle.component';
@@ -4,5 +4,5 @@ import * as i0 from "@angular/core";
4
4
  */
5
5
  export declare class CardContentDirective {
6
6
  static ɵfac: i0.ɵɵFactoryDeclaration<CardContentDirective, never>;
7
- static ɵdir: i0.ɵɵDirectiveDeclaration<CardContentDirective, "[odxCardContent]", never, {}, {}, never, never, true, never>;
7
+ static ɵdir: i0.ɵɵDirectiveDeclaration<CardContentDirective, "[odxCardContent], odx-card-content", never, {}, {}, never, never, true, never>;
8
8
  }
@@ -1,2 +1 @@
1
1
  export * from './card-content.directive';
2
- export * from './card-title.directive';
@@ -3,4 +3,5 @@ export declare const CardVariant: {
3
3
  readonly DEFAULT: "default";
4
4
  readonly LAUNCH_TILE: "launch-tile";
5
5
  readonly LAUNCH_TILE_CENTERED: "launch-tile-centered";
6
+ readonly IMAGE_CARD: "image-card";
6
7
  };
@@ -52,6 +52,54 @@ export class AutocompleteControl extends CustomFormControl {
52
52
  * ```
53
53
  */
54
54
  this.optionSelected = new EventEmitter();
55
+ /**
56
+ * Event emitted before the dropdown opens.
57
+ *
58
+ * @emits {void}
59
+ *
60
+ * @example
61
+ * ```html
62
+ * <odx-select (beforeDropdownOpen)="onBeforeDropdownOpen()">
63
+ * </odx-select>
64
+ * ```
65
+ */
66
+ this.beforeDropdownOpen = new EventEmitter();
67
+ /**
68
+ * Event emitted after the dropdown opened.
69
+ *
70
+ * @emits {void}
71
+ *
72
+ * @example
73
+ * ```html
74
+ * <odx-select (afterDropdownOpen)="onAfterDropdownOpen()">
75
+ * </odx-select>
76
+ * ```
77
+ */
78
+ this.afterDropdownOpen = new EventEmitter();
79
+ /**
80
+ * Event emitted before the dropdown closes.
81
+ *
82
+ * @emits {void}
83
+ *
84
+ * @example
85
+ * ```html
86
+ * <odx-select (beforeDropdownClose)="onBeforeDropdownClose()">
87
+ * </odx-select>
88
+ * ```
89
+ */
90
+ this.beforeDropdownClose = new EventEmitter();
91
+ /**
92
+ * Event emitted after the dropdown closed.
93
+ *
94
+ * @emits {void}
95
+ *
96
+ * @example
97
+ * ```html
98
+ * <odx-select (afterDropdownClose)="onAfterDropdownClose()">
99
+ * </odx-select>
100
+ * ```
101
+ */
102
+ this.afterDropdownClose = new EventEmitter();
55
103
  detectControllerChanges(this).subscribe();
56
104
  }
57
105
  ngAfterViewInit() {
@@ -93,6 +141,21 @@ export class AutocompleteControl extends CustomFormControl {
93
141
  closeDropdown() {
94
142
  this.dropdown?.close();
95
143
  }
144
+ onDropdownOpen() {
145
+ this.beforeDropdownOpen.emit();
146
+ this.activateSelectedOption();
147
+ }
148
+ onDropdownOpened() {
149
+ this.afterDropdownOpen.emit();
150
+ this.enableSmoothScroll();
151
+ }
152
+ onDropdownClose() {
153
+ this.beforeDropdownClose.emit();
154
+ this.disableSmoothScroll();
155
+ }
156
+ onDropdownClosed() {
157
+ this.afterDropdownClose.emit();
158
+ }
96
159
  handleFocusOut(event) {
97
160
  if (this.isOpen) {
98
161
  event.stopImmediatePropagation();
@@ -100,7 +163,7 @@ export class AutocompleteControl extends CustomFormControl {
100
163
  this.onTouched();
101
164
  }
102
165
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AutocompleteControl, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
103
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "16.2.12", type: AutocompleteControl, isStandalone: true, inputs: { isLoading: ["isLoading", "isLoading", booleanAttribute], stringify: "stringify" }, outputs: { optionSelected: "optionSelected" }, host: { listeners: { "focusout": "handleFocusOut($event)" }, properties: { "class.is-open": "isOpen", "attr.aria-disabled": "isDisabled || null" } }, viewQueries: [{ propertyName: "dropdown", first: true, predicate: DropdownDirective, descendants: true }], usesInheritance: true, ngImport: i0 }); }
166
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "16.2.12", type: AutocompleteControl, isStandalone: true, inputs: { isLoading: ["isLoading", "isLoading", booleanAttribute], stringify: "stringify" }, outputs: { optionSelected: "optionSelected", beforeDropdownOpen: "beforeDropdownOpen", afterDropdownOpen: "afterDropdownOpen", beforeDropdownClose: "beforeDropdownClose", afterDropdownClose: "afterDropdownClose" }, host: { listeners: { "focusout": "handleFocusOut($event)" }, properties: { "class.is-open": "isOpen", "attr.aria-disabled": "isDisabled || null" } }, viewQueries: [{ propertyName: "dropdown", first: true, predicate: DropdownDirective, descendants: true }], usesInheritance: true, ngImport: i0 }); }
104
167
  }
105
168
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AutocompleteControl, decorators: [{
106
169
  type: Directive,
@@ -121,8 +184,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
121
184
  type: Input
122
185
  }], optionSelected: [{
123
186
  type: Output
187
+ }], beforeDropdownOpen: [{
188
+ type: Output
189
+ }], afterDropdownOpen: [{
190
+ type: Output
191
+ }], beforeDropdownClose: [{
192
+ type: Output
193
+ }], afterDropdownClose: [{
194
+ type: Output
124
195
  }], handleFocusOut: [{
125
196
  type: HostListener,
126
197
  args: ['focusout', ['$event']]
127
198
  }] } });
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete-control.js","sourceRoot":"","sources":["../../../../../../../libs/angular/cdk/autocomplete-control/src/lib/autocomplete-control.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActiveDescendantKeyManager } from '@angular/cdk/a11y';\nimport {\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectorRef,\n  Directive,\n  EventEmitter,\n  HostListener,\n  inject,\n  Input,\n  Output,\n  QueryList,\n  ViewChild,\n} from '@angular/core';\nimport { detectControllerChanges, StringifyFn } from '@odx/angular';\nimport { CustomFormControl, InputControlDirective } from '@odx/angular/cdk/custom-form-control';\nimport { OptionControl } from '@odx/angular/cdk/option-control';\nimport { DropdownDirective } from '@odx/angular/components/dropdown';\nimport { FormFieldComponent } from '@odx/angular/components/form-field';\nimport { injectElement, isFunction, untilDestroyed } from '@odx/angular/utils';\n\n/**\n * `AutocompleteControl` is a base directive to enhance an input field with autocomplete functionality,\n * providing keyboard navigation and selection for options displayed in a dropdown. It's designed to be extended\n * for specific implementations.\n * Extends `CustomFormControl` to provide form control behavior and state management.\n *\n * @see {CustomFormControl}\n *\n * This directive manages the open/close state of the dropdown, the loading state indication, and the interaction between\n * the autocomplete input and the dropdown options. It utilizes `ActiveDescendantKeyManager` for keyboard navigation among options.\n *\n * Extend this directive to create a fully functional autocomplete control tailored to your data type and UI requirements.\n *\n * @template T - The type of the items displayed in the autocomplete dropdown.\n */\n@Directive({\n  standalone: true,\n  host: {\n    '[class.is-open]': 'isOpen',\n    '[attr.aria-disabled]': 'isDisabled || null',\n  },\n})\nexport abstract class AutocompleteControl<T> extends CustomFormControl<T | null> implements AfterViewInit {\n  protected abstract readonly options?: QueryList<OptionControl<T>>;\n\n  protected readonly changeDetector = inject(ChangeDetectorRef);\n  protected readonly formField = inject(FormFieldComponent, { optional: true });\n  protected readonly takeUntilDestroyed = untilDestroyed();\n\n  protected keyManager?: ActiveDescendantKeyManager<OptionControl<T>>;\n  protected smoothScrollEnabled = false;\n\n  @ViewChild(DropdownDirective)\n  protected readonly dropdown?: DropdownDirective;\n\n  public abstract searchField?: InputControlDirective;\n\n  public readonly element = injectElement();\n\n  public get dropdownReferenceElement(): HTMLElement {\n    return this.formField?.controlElement?.nativeElement ?? this.element?.nativeElement;\n  }\n\n  public get hasOptions(): boolean {\n    return !!this.options?.length;\n  }\n\n  public get isOpen(): boolean {\n    return !!this.dropdown?.isOpen;\n  }\n\n  @Input({ transform: booleanAttribute })\n  public isLoading = false;\n\n  /**\n   * A function that converts an item of type T to a string representation.\n   * Used by the AutocompleteControl component to display the selected item.\n   *\n   * @type {StringifyFn<T>}\n   *\n   * @example\n   * ```ts\n   * // Define a stringify function for a custom type Person\n   * const stringifyPerson: StringifyFn<Person> = (person) => `${person.firstName} ${person.lastName}`;\n   *\n   * // Assign the stringify function to the AutocompleteControl\n   * autocompleteControl.stringify = stringifyPerson;\n   * ```\n   */\n  @Input()\n  public stringify?: StringifyFn<T>;\n\n  /**\n   * Emits the selected option when an option is selected from the dropdown.\n   *\n   * @emits {T} - The selected option.\n   *\n   * @example\n   * ```ts\n   * autocompleteControl.optionSelected.subscribe((selectedOption) => {\n   *   console.log('Selected option:', selectedOption);\n   * });\n   * ```\n   */\n  @Output()\n  public optionSelected = new EventEmitter<T>();\n\n  constructor() {\n    super(null);\n    detectControllerChanges(this).subscribe();\n  }\n\n  public ngAfterViewInit(): void {\n    if (!this.options) return;\n\n    this.initKeyManager(this.options);\n    this.handleQueryListOption(this.options);\n    this.handleSearchFieldChanges();\n  }\n\n  /**\n   * Scrolls the specified option element into view.\n   * @param {OptionControl<T>} option - The option control containing the element to scroll into view.\n   * @returns {void}\n   *\n   * @example\n   * ```ts\n   * const optionControl: OptionControl<string> = { element: myOptionElement };\n   * scrollOptionIntoView(optionControl);\n   * ```\n   */\n  public scrollOptionIntoView({ element }: OptionControl<T>): void {\n    const behavior = this.smoothScrollEnabled ? 'smooth' : undefined;\n    if (isFunction(element.nativeElement.scrollIntoView)) {\n      element.nativeElement.scrollIntoView({ block: 'center', behavior });\n    }\n  }\n\n  protected abstract handleQueryListOption(options: QueryList<OptionControl<T>>): void;\n\n  protected abstract handleSearchFieldChanges(): void;\n\n  protected abstract activateSelectedOption(): void;\n\n  protected initKeyManager(options: QueryList<OptionControl<T>>): void {\n    this.keyManager = new ActiveDescendantKeyManager(options).withHomeAndEnd();\n  }\n\n  protected disableSmoothScroll(): void {\n    this.smoothScrollEnabled = false;\n  }\n\n  protected enableSmoothScroll(): void {\n    this.smoothScrollEnabled = true;\n  }\n\n  protected openDropdown(): void {\n    this.dropdown?.open();\n  }\n\n  protected closeDropdown(): void {\n    this.dropdown?.close();\n  }\n\n  @HostListener('focusout', ['$event'])\n  protected handleFocusOut(event: FocusEvent): void {\n    if (this.isOpen) {\n      event.stopImmediatePropagation();\n    }\n    this.onTouched();\n  }\n}\n"]}
199
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete-control.js","sourceRoot":"","sources":["../../../../../../../libs/angular/cdk/autocomplete-control/src/lib/autocomplete-control.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActiveDescendantKeyManager } from '@angular/cdk/a11y';\nimport {\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectorRef,\n  Directive,\n  EventEmitter,\n  HostListener,\n  inject,\n  Input,\n  Output,\n  QueryList,\n  ViewChild,\n} from '@angular/core';\nimport { detectControllerChanges, StringifyFn } from '@odx/angular';\nimport { CustomFormControl, InputControlDirective } from '@odx/angular/cdk/custom-form-control';\nimport { OptionControl } from '@odx/angular/cdk/option-control';\nimport { DropdownDirective } from '@odx/angular/components/dropdown';\nimport { FormFieldComponent } from '@odx/angular/components/form-field';\nimport { injectElement, isFunction, untilDestroyed } from '@odx/angular/utils';\n\n/**\n * `AutocompleteControl` is a base directive to enhance an input field with autocomplete functionality,\n * providing keyboard navigation and selection for options displayed in a dropdown. It's designed to be extended\n * for specific implementations.\n * Extends `CustomFormControl` to provide form control behavior and state management.\n *\n * @see {CustomFormControl}\n *\n * This directive manages the open/close state of the dropdown, the loading state indication, and the interaction between\n * the autocomplete input and the dropdown options. It utilizes `ActiveDescendantKeyManager` for keyboard navigation among options.\n *\n * Extend this directive to create a fully functional autocomplete control tailored to your data type and UI requirements.\n *\n * @template T - The type of the items displayed in the autocomplete dropdown.\n */\n@Directive({\n  standalone: true,\n  host: {\n    '[class.is-open]': 'isOpen',\n    '[attr.aria-disabled]': 'isDisabled || null',\n  },\n})\nexport abstract class AutocompleteControl<T> extends CustomFormControl<T | null> implements AfterViewInit {\n  protected abstract readonly options?: QueryList<OptionControl<T>>;\n\n  protected readonly changeDetector = inject(ChangeDetectorRef);\n  protected readonly formField = inject(FormFieldComponent, { optional: true });\n  protected readonly takeUntilDestroyed = untilDestroyed();\n\n  protected keyManager?: ActiveDescendantKeyManager<OptionControl<T>>;\n  protected smoothScrollEnabled = false;\n\n  @ViewChild(DropdownDirective)\n  protected readonly dropdown?: DropdownDirective;\n\n  public abstract searchField?: InputControlDirective;\n\n  public readonly element = injectElement();\n\n  public get dropdownReferenceElement(): HTMLElement {\n    return this.formField?.controlElement?.nativeElement ?? this.element?.nativeElement;\n  }\n\n  public get hasOptions(): boolean {\n    return !!this.options?.length;\n  }\n\n  public get isOpen(): boolean {\n    return !!this.dropdown?.isOpen;\n  }\n\n  @Input({ transform: booleanAttribute })\n  public isLoading = false;\n\n  /**\n   * A function that converts an item of type T to a string representation.\n   * Used by the AutocompleteControl component to display the selected item.\n   *\n   * @type {StringifyFn<T>}\n   *\n   * @example\n   * ```ts\n   * // Define a stringify function for a custom type Person\n   * const stringifyPerson: StringifyFn<Person> = (person) => `${person.firstName} ${person.lastName}`;\n   *\n   * // Assign the stringify function to the AutocompleteControl\n   * autocompleteControl.stringify = stringifyPerson;\n   * ```\n   */\n  @Input()\n  public stringify?: StringifyFn<T>;\n\n  /**\n   * Emits the selected option when an option is selected from the dropdown.\n   *\n   * @emits {T} - The selected option.\n   *\n   * @example\n   * ```ts\n   * autocompleteControl.optionSelected.subscribe((selectedOption) => {\n   *   console.log('Selected option:', selectedOption);\n   * });\n   * ```\n   */\n  @Output()\n  public optionSelected = new EventEmitter<T>();\n\n  /**\n   * Event emitted before the dropdown opens.\n   *\n   * @emits {void}\n   *\n   * @example\n   * ```html\n   * <odx-select (beforeDropdownOpen)=\"onBeforeDropdownOpen()\">\n   * </odx-select>\n   * ```\n   */\n  @Output()\n  public beforeDropdownOpen = new EventEmitter<void>();\n\n  /**\n   * Event emitted after the dropdown opened.\n   *\n   * @emits {void}\n   *\n   * @example\n   * ```html\n   * <odx-select (afterDropdownOpen)=\"onAfterDropdownOpen()\">\n   * </odx-select>\n   * ```\n   */\n  @Output()\n  public afterDropdownOpen = new EventEmitter<void>();\n\n  /**\n   * Event emitted before the dropdown closes.\n   *\n   * @emits {void}\n   *\n   * @example\n   * ```html\n   * <odx-select (beforeDropdownClose)=\"onBeforeDropdownClose()\">\n   * </odx-select>\n   * ```\n   */\n  @Output()\n  public beforeDropdownClose = new EventEmitter<void>();\n\n  /**\n   * Event emitted after the dropdown closed.\n   *\n   * @emits {void}\n   *\n   * @example\n   * ```html\n   * <odx-select (afterDropdownClose)=\"onAfterDropdownClose()\">\n   * </odx-select>\n   * ```\n   */\n  @Output()\n  public afterDropdownClose = new EventEmitter<void>();\n\n  constructor() {\n    super(null);\n    detectControllerChanges(this).subscribe();\n  }\n\n  public ngAfterViewInit(): void {\n    if (!this.options) return;\n\n    this.initKeyManager(this.options);\n    this.handleQueryListOption(this.options);\n    this.handleSearchFieldChanges();\n  }\n\n  /**\n   * Scrolls the specified option element into view.\n   * @param {OptionControl<T>} option - The option control containing the element to scroll into view.\n   * @returns {void}\n   *\n   * @example\n   * ```ts\n   * const optionControl: OptionControl<string> = { element: myOptionElement };\n   * scrollOptionIntoView(optionControl);\n   * ```\n   */\n  public scrollOptionIntoView({ element }: OptionControl<T>): void {\n    const behavior = this.smoothScrollEnabled ? 'smooth' : undefined;\n    if (isFunction(element.nativeElement.scrollIntoView)) {\n      element.nativeElement.scrollIntoView({ block: 'center', behavior });\n    }\n  }\n\n  protected abstract handleQueryListOption(options: QueryList<OptionControl<T>>): void;\n\n  protected abstract handleSearchFieldChanges(): void;\n\n  protected abstract activateSelectedOption(): void;\n\n  protected initKeyManager(options: QueryList<OptionControl<T>>): void {\n    this.keyManager = new ActiveDescendantKeyManager(options).withHomeAndEnd();\n  }\n\n  protected disableSmoothScroll(): void {\n    this.smoothScrollEnabled = false;\n  }\n\n  protected enableSmoothScroll(): void {\n    this.smoothScrollEnabled = true;\n  }\n\n  protected openDropdown(): void {\n    this.dropdown?.open();\n  }\n\n  protected closeDropdown(): void {\n    this.dropdown?.close();\n  }\n\n  protected onDropdownOpen(): void {\n    this.beforeDropdownOpen.emit();\n    this.activateSelectedOption();\n  }\n\n  protected onDropdownOpened(): void {\n    this.afterDropdownOpen.emit();\n    this.enableSmoothScroll();\n  }\n\n  protected onDropdownClose(): void {\n    this.beforeDropdownClose.emit();\n    this.disableSmoothScroll();\n  }\n\n  protected onDropdownClosed(): void {\n    this.afterDropdownClose.emit();\n  }\n\n  @HostListener('focusout', ['$event'])\n  protected handleFocusOut(event: FocusEvent): void {\n    if (this.isOpen) {\n      event.stopImmediatePropagation();\n    }\n    this.onTouched();\n  }\n}\n"]}
@@ -29,7 +29,6 @@ export let AutocompleteComponent = class AutocompleteComponent extends Autocompl
29
29
  this.defaultActiveOptionIndex = 0;
30
30
  this.patchValueFlag = false;
31
31
  this.clickOutsideDirective = inject(ClickOutsideDirective, { host: true });
32
- this.dropdownOpenTriggers = [];
33
32
  }
34
33
  static { AutocompleteComponent_1 = this; }
35
34
  ngAfterViewInit() {
@@ -133,9 +132,6 @@ export let AutocompleteComponent = class AutocompleteComponent extends Autocompl
133
132
  activateSelectedOption() {
134
133
  this.keyManager?.setActiveItem(this.defaultActiveOptionIndex);
135
134
  }
136
- onDropdownBeforeOpen() {
137
- this.activateSelectedOption();
138
- }
139
135
  updateSearchField(value) {
140
136
  if (!this.searchField)
141
137
  return;
@@ -155,7 +151,7 @@ export let AutocompleteComponent = class AutocompleteComponent extends Autocompl
155
151
  provide: ODX_SEARCH_FILTER_HOST,
156
152
  useExisting: AUTOCOMPLETE_CONTROL,
157
153
  },
158
- ], queries: [{ propertyName: "searchField", first: true, predicate: AutocompleteInputControlDirective, descendants: true }, { propertyName: "options", predicate: AutocompleteOptionComponent, descendants: true }], usesInheritance: true, hostDirectives: [{ directive: i1.ClickOutsideDirective }], ngImport: i0, template: "<div\n aria-haspopup=\"listbox\"\n class=\"odx-autocomplete__trigger\"\n [odxDropdown]=\"dropdownContent\"\n [odxDropdownDisabled]=\"isDisabled || isReadonly\"\n [odxDropdownOptions]=\"{ matchReferenceWidth: true, offset: 4, outerPadding: 10, position: 'bottom-start' }\"\n [odxDropdownReferenceElement]=\"dropdownReferenceElement\"\n [odxDropdownShowLoader]=\"isLoading\"\n [odxDropdownOpenTrigger]=\"dropdownOpenTriggers\"\n [odxDropdownClickOutsideActive]=\"false\"\n (odxDropdownBeforeOpen)=\"onDropdownBeforeOpen()\"\n (odxDropdownAfterOpen)=\"enableSmoothScroll()\"\n (odxDropdownBeforeClose)=\"disableSmoothScroll()\"\n>\n <ng-content select=\"input[odxAutocompleteControl]\"></ng-content>\n</div>\n<ng-template #dropdownContent>\n <div class=\"odx-dropdown__option-list\" role=\"listbox\">\n <ng-template [ngIf]=\"hasOptions\">\n <ng-content></ng-content>\n </ng-template>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: DropdownDirective, selector: "[odxDropdown]", inputs: ["odxDropdown", "odxDropdownDisabled", "odxDropdownShowLoader", "odxDropdownClickOutsideActive", "odxDropdownOptions", "odxDropdownReferenceElement", "odxDropdownTriggerElement", "odxDropdownHost", "odxDropdownOpenTrigger", "odxDropdownCloseTrigger"], outputs: ["odxDropdownBeforeOpen", "odxDropdownAfterOpen", "odxDropdownBeforeClose", "odxDropdownAfterClose"], exportAs: ["odxDropdown"] }, { kind: "ngmodule", type: LoadingSpinnerModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
154
+ ], queries: [{ propertyName: "searchField", first: true, predicate: AutocompleteInputControlDirective, descendants: true }, { propertyName: "options", predicate: AutocompleteOptionComponent, descendants: true }], usesInheritance: true, hostDirectives: [{ directive: i1.ClickOutsideDirective }], ngImport: i0, template: "<div\n aria-haspopup=\"listbox\"\n class=\"odx-autocomplete__trigger\"\n [odxDropdown]=\"dropdownContent\"\n [odxDropdownDisabled]=\"isDisabled || isReadonly\"\n [odxDropdownOptions]=\"{ matchReferenceWidth: true, offset: 4, outerPadding: 10, position: 'bottom-start' }\"\n [odxDropdownReferenceElement]=\"dropdownReferenceElement\"\n [odxDropdownShowLoader]=\"isLoading\"\n [odxDropdownOpenTrigger]=\"[]\"\n [odxDropdownClickOutsideActive]=\"false\"\n (odxDropdownBeforeOpen)=\"onDropdownOpen()\"\n (odxDropdownAfterOpen)=\"onDropdownOpened()\"\n (odxDropdownBeforeClose)=\"onDropdownClose()\"\n (odxDropdownAfterClose)=\"onDropdownClosed()\"\n>\n <ng-content select=\"input[odxAutocompleteControl]\"></ng-content>\n</div>\n<ng-template #dropdownContent>\n <div class=\"odx-dropdown__option-list\" role=\"listbox\">\n <ng-template [ngIf]=\"hasOptions\">\n <ng-content></ng-content>\n </ng-template>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: DropdownDirective, selector: "[odxDropdown]", inputs: ["odxDropdown", "odxDropdownDisabled", "odxDropdownShowLoader", "odxDropdownClickOutsideActive", "odxDropdownOptions", "odxDropdownReferenceElement", "odxDropdownTriggerElement", "odxDropdownHost", "odxDropdownOpenTrigger", "odxDropdownCloseTrigger"], outputs: ["odxDropdownBeforeOpen", "odxDropdownAfterOpen", "odxDropdownBeforeClose", "odxDropdownAfterClose"], exportAs: ["odxDropdown"] }, { kind: "ngmodule", type: LoadingSpinnerModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
159
155
  };
160
156
  AutocompleteComponent = AutocompleteComponent_1 = __decorate([
161
157
  CSSComponent('autocomplete')
@@ -171,7 +167,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
171
167
  provide: ODX_SEARCH_FILTER_HOST,
172
168
  useExisting: AUTOCOMPLETE_CONTROL,
173
169
  },
174
- ], hostDirectives: [ClickOutsideDirective], template: "<div\n aria-haspopup=\"listbox\"\n class=\"odx-autocomplete__trigger\"\n [odxDropdown]=\"dropdownContent\"\n [odxDropdownDisabled]=\"isDisabled || isReadonly\"\n [odxDropdownOptions]=\"{ matchReferenceWidth: true, offset: 4, outerPadding: 10, position: 'bottom-start' }\"\n [odxDropdownReferenceElement]=\"dropdownReferenceElement\"\n [odxDropdownShowLoader]=\"isLoading\"\n [odxDropdownOpenTrigger]=\"dropdownOpenTriggers\"\n [odxDropdownClickOutsideActive]=\"false\"\n (odxDropdownBeforeOpen)=\"onDropdownBeforeOpen()\"\n (odxDropdownAfterOpen)=\"enableSmoothScroll()\"\n (odxDropdownBeforeClose)=\"disableSmoothScroll()\"\n>\n <ng-content select=\"input[odxAutocompleteControl]\"></ng-content>\n</div>\n<ng-template #dropdownContent>\n <div class=\"odx-dropdown__option-list\" role=\"listbox\">\n <ng-template [ngIf]=\"hasOptions\">\n <ng-content></ng-content>\n </ng-template>\n </div>\n</ng-template>\n" }]
170
+ ], hostDirectives: [ClickOutsideDirective], template: "<div\n aria-haspopup=\"listbox\"\n class=\"odx-autocomplete__trigger\"\n [odxDropdown]=\"dropdownContent\"\n [odxDropdownDisabled]=\"isDisabled || isReadonly\"\n [odxDropdownOptions]=\"{ matchReferenceWidth: true, offset: 4, outerPadding: 10, position: 'bottom-start' }\"\n [odxDropdownReferenceElement]=\"dropdownReferenceElement\"\n [odxDropdownShowLoader]=\"isLoading\"\n [odxDropdownOpenTrigger]=\"[]\"\n [odxDropdownClickOutsideActive]=\"false\"\n (odxDropdownBeforeOpen)=\"onDropdownOpen()\"\n (odxDropdownAfterOpen)=\"onDropdownOpened()\"\n (odxDropdownBeforeClose)=\"onDropdownClose()\"\n (odxDropdownAfterClose)=\"onDropdownClosed()\"\n>\n <ng-content select=\"input[odxAutocompleteControl]\"></ng-content>\n</div>\n<ng-template #dropdownContent>\n <div class=\"odx-dropdown__option-list\" role=\"listbox\">\n <ng-template [ngIf]=\"hasOptions\">\n <ng-content></ng-content>\n </ng-template>\n </div>\n</ng-template>\n" }]
175
171
  }], propDecorators: { options: [{
176
172
  type: ContentChildren,
177
173
  args: [AutocompleteOptionComponent, { descendants: true, emitDistinctChangesOnly: true }]
@@ -185,4 +181,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
185
181
  type: HostListener,
186
182
  args: ['keydown', ['$event']]
187
183
  }] } });
188
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/components/autocomplete/src/lib/autocomplete.component.ts","../../../../../../../libs/angular/components/autocomplete/src/lib/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ContentChildren,\n  forwardRef,\n  HostListener,\n  inject,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ClickOutsideDirective } from '@odx/angular';\nimport { AutocompleteControl, ODX_SEARCH_FILTER_HOST } from '@odx/angular/cdk/autocomplete-control';\nimport { DropdownDirective } from '@odx/angular/components/dropdown';\nimport { LoadingSpinnerModule } from '@odx/angular/components/loading-spinner';\nimport { CSSComponent } from '@odx/angular/internal';\nimport { deferFn } from '@odx/angular/utils';\nimport { filter, tap } from 'rxjs';\nimport { AUTOCOMPLETE_CONTROL } from './autocomplete.tokens';\nimport { AutocompleteOptionComponent } from './components';\nimport { AutocompleteInputControlDirective } from './directives';\n\n/**\n * Represents an autocomplete component that provides user interface for a dropdown list to select from as users type.\n * It extends `AutocompleteControl`, integrating custom logic for handling keyboard and mouse events,\n * managing the dropdown state, and updating the associated search field.\n *\n * @see {AutocompleteControl}\n *\n * @template T - The type of the value handled by the autocomplete.\n */\n@CSSComponent('autocomplete')\n@Component({\n  standalone: true,\n  selector: 'odx-autocomplete',\n  imports: [DropdownDirective, AutocompleteOptionComponent, LoadingSpinnerModule],\n  templateUrl: './autocomplete.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: AUTOCOMPLETE_CONTROL,\n      useExisting: forwardRef(() => AutocompleteComponent),\n    },\n    {\n      provide: ODX_SEARCH_FILTER_HOST,\n      useExisting: AUTOCOMPLETE_CONTROL,\n    },\n  ],\n  hostDirectives: [ClickOutsideDirective],\n})\nexport class AutocompleteComponent<T = unknown> extends AutocompleteControl<T | null> implements AfterViewInit {\n  private readonly defaultActiveOptionIndex = 0;\n  private patchValueFlag = false;\n  protected readonly clickOutsideDirective = inject(ClickOutsideDirective, { host: true });\n\n  /**\n   * The list of autocomplete options.\n   *\n   * @type {QueryList<AutocompleteOptionComponent<T>> | undefined}\n   */\n  @ContentChildren(AutocompleteOptionComponent, { descendants: true, emitDistinctChangesOnly: true })\n  public options?: QueryList<AutocompleteOptionComponent<T>>;\n\n  /**\n   * The search field input control.\n   *\n   * @type {AutocompleteInputControlDirective | undefined}\n   */\n  @ContentChild(AutocompleteInputControlDirective)\n  public searchField?: AutocompleteInputControlDirective;\n\n  public readonly dropdownOpenTriggers = [];\n\n  public override ngAfterViewInit(): void {\n    if (!this.options) return;\n    if (this.value) this.updateSearchField(this.value);\n\n    this.initKeyManager(this.options);\n    this.handleQueryListOption(this.options);\n    this.handleSearchFieldChanges();\n    this.handleClickOutside();\n  }\n\n  /**\n   * Selects an option, updates the value, updates the search field display,\n   * emits the selected value, and closes the dropdown.\n   *\n   * @param {AutocompleteOptionComponent<T> | null} option - The option component to select. If the option is undefined or its value is undefined,\n   * no action is taken.\n   */\n  public selectOption(option?: AutocompleteOptionComponent<T> | null): void {\n    if (!option?.value) return;\n\n    this.updateValue(option.value);\n    this.updateSearchField(option.value);\n\n    this.optionSelected.emit(option.value);\n\n    this.closeDropdown();\n  }\n\n  /**\n   * Resets the search field to its initial state and updates the value of the autocomplete\n   * to an empty string or initial value.\n   */\n  public resetSearchField(): void {\n    this.updateValue('' as T);\n    this.searchField?.reset();\n  }\n\n  protected handleQueryListOption(options: QueryList<AutocompleteOptionComponent<T>>): void {\n    options.changes\n      .pipe(\n        tap(() => deferFn(() => this.updateDropdownState())),\n        filter(() => this.isOpen),\n        this.takeUntilDestroyed(),\n      )\n      .subscribe(() => {\n        deferFn(() => this.activateSelectedOption());\n      });\n  }\n\n  protected handleSearchFieldChanges(): void {\n    this.searchField?.valueChange$.pipe(this.takeUntilDestroyed()).subscribe(() => this.triggerControllerChange());\n  }\n\n  protected handleClickOutside(): void {\n    this.clickOutsideDirective.odxClickOutside.pipe(this.takeUntilDestroyed()).subscribe(() => this.clickOutside());\n  }\n\n  protected clickOutside(): void {\n    this.closeDropdown();\n    this.blurSelectSearchField();\n  }\n\n  protected updateDropdownState(): void {\n    if (this.patchValueFlag) {\n      this.patchValueFlag = false;\n      return;\n    }\n\n    if (this.isOpen && !this.hasOptions) {\n      this.closeDropdown();\n    } else if (!this.isOpen && this.hasOptions) {\n      this.openDropdown();\n    }\n  }\n\n  @HostListener('click')\n  protected handleClickEvent() {\n    if (this.isLoading && this.isOpen) {\n      this.closeDropdown();\n      this.blurSelectSearchField();\n      return;\n    }\n\n    if (this.isReadonly || this.isDisabled) return;\n\n    if (!this.isOpen && this.hasOptions) {\n      this.openDropdown();\n    }\n  }\n\n  @HostListener('keydown', ['$event'])\n  protected handleKeyboardEvent(event: KeyboardEvent) {\n    if (this.isReadonly || this.isDisabled) return;\n\n    if (this.isOpen && this.hasOptions) {\n      if (event.key === 'Enter' || event.key === 'Tab') {\n        event.preventDefault();\n        event.stopImmediatePropagation();\n        this.selectOption(this.keyManager?.activeItem as AutocompleteOptionComponent<T> | undefined);\n        return;\n      }\n    }\n\n    if (event.key === 'Enter' && !!this.value) {\n      this.optionSelected.emit(this.value as T);\n      return;\n    }\n\n    if (!this.isOpen && event.key === 'Tab') {\n      return;\n    }\n\n    if (!this.isOpen && this.hasOptions) {\n      this.openDropdown();\n      return;\n    }\n\n    this.keyManager?.onKeydown(event);\n  }\n\n  protected activateSelectedOption(): void {\n    this.keyManager?.setActiveItem(this.defaultActiveOptionIndex);\n  }\n\n  protected onDropdownBeforeOpen(): void {\n    this.activateSelectedOption();\n  }\n\n  private updateSearchField(value: T): void {\n    if (!this.searchField) return;\n    this.patchValueFlag = true;\n    this.searchField.nativeElementValue = this.stringify?.(value) ?? (value as string);\n  }\n\n  private blurSelectSearchField(): void {\n    this.searchField?.blur();\n  }\n}\n","<div\n  aria-haspopup=\"listbox\"\n  class=\"odx-autocomplete__trigger\"\n  [odxDropdown]=\"dropdownContent\"\n  [odxDropdownDisabled]=\"isDisabled || isReadonly\"\n  [odxDropdownOptions]=\"{ matchReferenceWidth: true, offset: 4, outerPadding: 10, position: 'bottom-start' }\"\n  [odxDropdownReferenceElement]=\"dropdownReferenceElement\"\n  [odxDropdownShowLoader]=\"isLoading\"\n  [odxDropdownOpenTrigger]=\"dropdownOpenTriggers\"\n  [odxDropdownClickOutsideActive]=\"false\"\n  (odxDropdownBeforeOpen)=\"onDropdownBeforeOpen()\"\n  (odxDropdownAfterOpen)=\"enableSmoothScroll()\"\n  (odxDropdownBeforeClose)=\"disableSmoothScroll()\"\n>\n  <ng-content select=\"input[odxAutocompleteControl]\"></ng-content>\n</div>\n<ng-template #dropdownContent>\n  <div class=\"odx-dropdown__option-list\" role=\"listbox\">\n    <ng-template [ngIf]=\"hasOptions\">\n      <ng-content></ng-content>\n    </ng-template>\n  </div>\n</ng-template>\n"]}
184
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/components/autocomplete/src/lib/autocomplete.component.ts","../../../../../../../libs/angular/components/autocomplete/src/lib/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ContentChildren,\n  forwardRef,\n  HostListener,\n  inject,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ClickOutsideDirective } from '@odx/angular';\nimport { AutocompleteControl, ODX_SEARCH_FILTER_HOST } from '@odx/angular/cdk/autocomplete-control';\nimport { DropdownDirective } from '@odx/angular/components/dropdown';\nimport { LoadingSpinnerModule } from '@odx/angular/components/loading-spinner';\nimport { CSSComponent } from '@odx/angular/internal';\nimport { deferFn } from '@odx/angular/utils';\nimport { filter, tap } from 'rxjs';\nimport { AUTOCOMPLETE_CONTROL } from './autocomplete.tokens';\nimport { AutocompleteOptionComponent } from './components';\nimport { AutocompleteInputControlDirective } from './directives';\n\n/**\n * Represents an autocomplete component that provides user interface for a dropdown list to select from as users type.\n * It extends `AutocompleteControl`, integrating custom logic for handling keyboard and mouse events,\n * managing the dropdown state, and updating the associated search field.\n *\n * @see {AutocompleteControl}\n *\n * @template T - The type of the value handled by the autocomplete.\n */\n@CSSComponent('autocomplete')\n@Component({\n  standalone: true,\n  selector: 'odx-autocomplete',\n  imports: [DropdownDirective, AutocompleteOptionComponent, LoadingSpinnerModule],\n  templateUrl: './autocomplete.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: AUTOCOMPLETE_CONTROL,\n      useExisting: forwardRef(() => AutocompleteComponent),\n    },\n    {\n      provide: ODX_SEARCH_FILTER_HOST,\n      useExisting: AUTOCOMPLETE_CONTROL,\n    },\n  ],\n  hostDirectives: [ClickOutsideDirective],\n})\nexport class AutocompleteComponent<T = unknown> extends AutocompleteControl<T | null> implements AfterViewInit {\n  private readonly defaultActiveOptionIndex = 0;\n  private patchValueFlag = false;\n  protected readonly clickOutsideDirective = inject(ClickOutsideDirective, { host: true });\n\n  /**\n   * The list of autocomplete options.\n   *\n   * @type {QueryList<AutocompleteOptionComponent<T>> | undefined}\n   */\n  @ContentChildren(AutocompleteOptionComponent, { descendants: true, emitDistinctChangesOnly: true })\n  public options?: QueryList<AutocompleteOptionComponent<T>>;\n\n  /**\n   * The search field input control.\n   *\n   * @type {AutocompleteInputControlDirective | undefined}\n   */\n  @ContentChild(AutocompleteInputControlDirective)\n  public searchField?: AutocompleteInputControlDirective;\n\n  public override ngAfterViewInit(): void {\n    if (!this.options) return;\n    if (this.value) this.updateSearchField(this.value);\n\n    this.initKeyManager(this.options);\n    this.handleQueryListOption(this.options);\n    this.handleSearchFieldChanges();\n    this.handleClickOutside();\n  }\n\n  /**\n   * Selects an option, updates the value, updates the search field display,\n   * emits the selected value, and closes the dropdown.\n   *\n   * @param {AutocompleteOptionComponent<T> | null} option - The option component to select. If the option is undefined or its value is undefined,\n   * no action is taken.\n   */\n  public selectOption(option?: AutocompleteOptionComponent<T> | null): void {\n    if (!option?.value) return;\n\n    this.updateValue(option.value);\n    this.updateSearchField(option.value);\n\n    this.optionSelected.emit(option.value);\n\n    this.closeDropdown();\n  }\n\n  /**\n   * Resets the search field to its initial state and updates the value of the autocomplete\n   * to an empty string or initial value.\n   */\n  public resetSearchField(): void {\n    this.updateValue('' as T);\n    this.searchField?.reset();\n  }\n\n  protected handleQueryListOption(options: QueryList<AutocompleteOptionComponent<T>>): void {\n    options.changes\n      .pipe(\n        tap(() => deferFn(() => this.updateDropdownState())),\n        filter(() => this.isOpen),\n        this.takeUntilDestroyed(),\n      )\n      .subscribe(() => {\n        deferFn(() => this.activateSelectedOption());\n      });\n  }\n\n  protected handleSearchFieldChanges(): void {\n    this.searchField?.valueChange$.pipe(this.takeUntilDestroyed()).subscribe(() => this.triggerControllerChange());\n  }\n\n  protected handleClickOutside(): void {\n    this.clickOutsideDirective.odxClickOutside.pipe(this.takeUntilDestroyed()).subscribe(() => this.clickOutside());\n  }\n\n  protected clickOutside(): void {\n    this.closeDropdown();\n    this.blurSelectSearchField();\n  }\n\n  protected updateDropdownState(): void {\n    if (this.patchValueFlag) {\n      this.patchValueFlag = false;\n      return;\n    }\n\n    if (this.isOpen && !this.hasOptions) {\n      this.closeDropdown();\n    } else if (!this.isOpen && this.hasOptions) {\n      this.openDropdown();\n    }\n  }\n\n  @HostListener('click')\n  protected handleClickEvent() {\n    if (this.isLoading && this.isOpen) {\n      this.closeDropdown();\n      this.blurSelectSearchField();\n      return;\n    }\n\n    if (this.isReadonly || this.isDisabled) return;\n\n    if (!this.isOpen && this.hasOptions) {\n      this.openDropdown();\n    }\n  }\n\n  @HostListener('keydown', ['$event'])\n  protected handleKeyboardEvent(event: KeyboardEvent) {\n    if (this.isReadonly || this.isDisabled) return;\n\n    if (this.isOpen && this.hasOptions) {\n      if (event.key === 'Enter' || event.key === 'Tab') {\n        event.preventDefault();\n        event.stopImmediatePropagation();\n        this.selectOption(this.keyManager?.activeItem as AutocompleteOptionComponent<T> | undefined);\n        return;\n      }\n    }\n\n    if (event.key === 'Enter' && !!this.value) {\n      this.optionSelected.emit(this.value as T);\n      return;\n    }\n\n    if (!this.isOpen && event.key === 'Tab') {\n      return;\n    }\n\n    if (!this.isOpen && this.hasOptions) {\n      this.openDropdown();\n      return;\n    }\n\n    this.keyManager?.onKeydown(event);\n  }\n\n  protected activateSelectedOption(): void {\n    this.keyManager?.setActiveItem(this.defaultActiveOptionIndex);\n  }\n\n  private updateSearchField(value: T): void {\n    if (!this.searchField) return;\n    this.patchValueFlag = true;\n    this.searchField.nativeElementValue = this.stringify?.(value) ?? (value as string);\n  }\n\n  private blurSelectSearchField(): void {\n    this.searchField?.blur();\n  }\n}\n","<div\n  aria-haspopup=\"listbox\"\n  class=\"odx-autocomplete__trigger\"\n  [odxDropdown]=\"dropdownContent\"\n  [odxDropdownDisabled]=\"isDisabled || isReadonly\"\n  [odxDropdownOptions]=\"{ matchReferenceWidth: true, offset: 4, outerPadding: 10, position: 'bottom-start' }\"\n  [odxDropdownReferenceElement]=\"dropdownReferenceElement\"\n  [odxDropdownShowLoader]=\"isLoading\"\n  [odxDropdownOpenTrigger]=\"[]\"\n  [odxDropdownClickOutsideActive]=\"false\"\n  (odxDropdownBeforeOpen)=\"onDropdownOpen()\"\n  (odxDropdownAfterOpen)=\"onDropdownOpened()\"\n  (odxDropdownBeforeClose)=\"onDropdownClose()\"\n  (odxDropdownAfterClose)=\"onDropdownClosed()\"\n>\n  <ng-content select=\"input[odxAutocompleteControl]\"></ng-content>\n</div>\n<ng-template #dropdownContent>\n  <div class=\"odx-dropdown__option-list\" role=\"listbox\">\n    <ng-template [ngIf]=\"hasOptions\">\n      <ng-content></ng-content>\n    </ng-template>\n  </div>\n</ng-template>\n"]}
@@ -10,7 +10,7 @@ import { CalendarSelectionMode } from './models/selection-mode';
10
10
  * providers: [provideCalendarConfig({ selectionMode: CalendarSelectionMode.DateRange, locale: new BehaviorSubject<Locale>(deDE)})]
11
11
  * })
12
12
  * export class MyDateRangepickerComponent {}
13
- * ````
13
+ * ```
14
14
  *
15
15
  * @example
16
16
  * ```ts
@@ -28,4 +28,4 @@ export const { CalendarConfig, CalendarDefaultConfig, injectCalendarConfig, prov
28
28
  padding: 100,
29
29
  },
30
30
  });
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2NvbXBvbmVudHMvY2FsZW5kYXIvc3JjL2xpYi9jYWxlbmRhci5jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDeEQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUErQ2hFOzs7Ozs7Ozs7Ozs7Ozs7O0dBZ0JHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sRUFBRSxjQUFjLEVBQUUscUJBQXFCLEVBQUUsb0JBQW9CLEVBQUUscUJBQXFCLEVBQUUsR0FBRyxrQkFBa0IsQ0FDdEgsVUFBVSxFQUNWLGtDQUFrQyxFQUNsQztJQUNFLG1CQUFtQixFQUFFLElBQUk7SUFDekIsYUFBYSxFQUFFLHFCQUFxQixDQUFDLElBQUk7SUFDekMsUUFBUSxFQUFFO1FBQ1IsV0FBVyxFQUFFLENBQUM7S0FDZjtJQUNELFNBQVMsRUFBRTtRQUNULFdBQVcsRUFBRSxDQUFDO1FBQ2QsT0FBTyxFQUFFLEdBQUc7S0FDYjtDQUNGLENBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZUNvbmZpZ1Rva2VucyB9IGZyb20gJ0BvZHgvYW5ndWxhci91dGlscyc7XG5pbXBvcnQgeyBDYWxlbmRhclNlbGVjdGlvbk1vZGUgfSBmcm9tICcuL21vZGVscy9zZWxlY3Rpb24tbW9kZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FsZW5kYXJDb25maWcge1xuICAvKipcbiAgICogRGlzcGxheXMgdGhlIGFkamFjZW50IGRheXMgaW4gbW9udGggY2FsZW5kYXIgdmlldy5cbiAgICpcbiAgICogQGRlZmF1bHQgdHJ1ZVxuICAgKi9cbiAgZGlzcGxheUFkamFjZW50RGF5czogYm9vbGVhbjtcbiAgLyoqXG4gICAqIFN3aXRjaGVzIGJldHdlZW4gc2luZ2xlIHNlbGVjdGlvbiBhbmQgYSBkYXRlcmFuZ2Ugc2VsZWN0aW9uLlxuICAgKlxuICAgKiBAZGVmYXVsdCBDYWxlbmRhclNlbGVjdGlvbk1vZGUuRGF0ZVxuICAgKi9cbiAgc2VsZWN0aW9uTW9kZTogQ2FsZW5kYXJTZWxlY3Rpb25Nb2RlO1xuXG4gIC8qKlxuICAgKiBDb25maWd1cmF0aW9uIGZvciB0aGUgeWVhciB2aWV3LlxuICAgKlxuICAgKiBAdHlwZWRlZiB7T2JqZWN0fSBZZWFyVmlld0NvbmZpZ1xuICAgKiBAcHJvcGVydHkge251bWJlcn0gaXRlbXNQZXJSb3cgLSBOdW1iZXIgb2YgaXRlbXMgdG8gZGlzcGxheSBwZXIgcm93IGluIHRoZSB5ZWFyIHZpZXcuXG4gICAqIEBkZWZhdWx0IDNcbiAgICovXG4gIC8qKlxuICAgKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIHRoZSBjYWxlbmRhcidzIHllYXIgdmlldy5cbiAgICpcbiAgICogQHR5cGUge1llYXJWaWV3Q29uZmlnfVxuICAgKi9cbiAgeWVhclZpZXc6IHsgaXRlbXNQZXJSb3c6IG51bWJlciB9O1xuICAvKipcbiAgICogQ29uZmlndXJhdGlvbiBmb3IgdGhlIHllYXJzIHZpZXcuXG4gICAqXG4gICAqIEB0eXBlZGVmIHtPYmplY3R9IFllYXJzVmlld0NvbmZpZ1xuICAgKiBAcHJvcGVydHkge251bWJlcn0gaXRlbXNQZXJSb3cgLSBOdW1iZXIgb2YgaXRlbXMgdG8gZGlzcGxheSBwZXIgcm93IGluIHRoZSB5ZWFycyB2aWV3LlxuICAgKiBAcHJvcGVydHkge251bWJlcn0gW3BhZGRpbmc9MTAwXSAtIFRoZSBudW1iZXIgb2YgeWVhciBpdGVtcyBiZWZvcmUgYW5kIGFmdGVyIHRoZSBjdXJyZW50IHllYXJcbiAgICogQGRlZmF1bHRcbiAgICogICBpdGVtc1BlclJvdzogMyxcbiAgICogICBwYWRkaW5nOiAxMDBcbiAgICovXG4gIC8qKlxuICAgKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIHRoZSBjYWxlbmRhcidzIHllYXJzIHZpZXcuXG4gICAqXG4gICAqIEB0eXBlIHtZZWFyc1ZpZXdDb25maWd9XG4gICAqL1xuICB5ZWFyc1ZpZXc6IHsgaXRlbXNQZXJSb3c6IG51bWJlcjsgcGFkZGluZzogbnVtYmVyIH07XG59XG5cbi8qKlxuICogVG9vbHMgZm9yIGN1c3RvbWl6aW5nIGNvbmZpZ3VyYXRpb24gZm9yIHRoZSBjYWxlbmRhciBjb21wb25lbnRcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIEBDb21wb25lbnQoe1xuICogIC4uLlxuICogIHByb3ZpZGVyczogW3Byb3ZpZGVDYWxlbmRhckNvbmZpZyh7IHNlbGVjdGlvbk1vZGU6IENhbGVuZGFyU2VsZWN0aW9uTW9kZS5EYXRlUmFuZ2UsIGxvY2FsZTogbmV3IEJlaGF2aW9yU3ViamVjdDxMb2NhbGU+KGRlREUpfSldXG4gKiB9KVxuICogZXhwb3J0IGNsYXNzIE15RGF0ZVJhbmdlcGlja2VyQ29tcG9uZW50IHt9XG4gKiBgYGBgXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzXG4gKiBjb25zdHJ1Y3RvcihASW5qZWN0KENhbGVuZGFyQ29uZmlnKSBwcml2YXRlIHJlYWRvbmx5IGNhbGVuZGFyQ29uZmlnOiBDYWxlbmRhckNvbmZpZykge31cbiAqIGBgYFxuICovXG5leHBvcnQgY29uc3QgeyBDYWxlbmRhckNvbmZpZywgQ2FsZW5kYXJEZWZhdWx0Q29uZmlnLCBpbmplY3RDYWxlbmRhckNvbmZpZywgcHJvdmlkZUNhbGVuZGFyQ29uZmlnIH0gPSBjcmVhdGVDb25maWdUb2tlbnMoXG4gICdDYWxlbmRhcicsXG4gICdAb2R4L2FuZ3VsYXIvY29tcG9uZW50cy9jYWxlbmRhcicsXG4gIHtcbiAgICBkaXNwbGF5QWRqYWNlbnREYXlzOiB0cnVlLFxuICAgIHNlbGVjdGlvbk1vZGU6IENhbGVuZGFyU2VsZWN0aW9uTW9kZS5EYXRlLFxuICAgIHllYXJWaWV3OiB7XG4gICAgICBpdGVtc1BlclJvdzogMyxcbiAgICB9LFxuICAgIHllYXJzVmlldzoge1xuICAgICAgaXRlbXNQZXJSb3c6IDMsXG4gICAgICBwYWRkaW5nOiAxMDAsXG4gICAgfSxcbiAgfSxcbik7XG4iXX0=
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2NvbXBvbmVudHMvY2FsZW5kYXIvc3JjL2xpYi9jYWxlbmRhci5jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDeEQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUErQ2hFOzs7Ozs7Ozs7Ozs7Ozs7O0dBZ0JHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sRUFBRSxjQUFjLEVBQUUscUJBQXFCLEVBQUUsb0JBQW9CLEVBQUUscUJBQXFCLEVBQUUsR0FBRyxrQkFBa0IsQ0FDdEgsVUFBVSxFQUNWLGtDQUFrQyxFQUNsQztJQUNFLG1CQUFtQixFQUFFLElBQUk7SUFDekIsYUFBYSxFQUFFLHFCQUFxQixDQUFDLElBQUk7SUFDekMsUUFBUSxFQUFFO1FBQ1IsV0FBVyxFQUFFLENBQUM7S0FDZjtJQUNELFNBQVMsRUFBRTtRQUNULFdBQVcsRUFBRSxDQUFDO1FBQ2QsT0FBTyxFQUFFLEdBQUc7S0FDYjtDQUNGLENBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZUNvbmZpZ1Rva2VucyB9IGZyb20gJ0BvZHgvYW5ndWxhci91dGlscyc7XG5pbXBvcnQgeyBDYWxlbmRhclNlbGVjdGlvbk1vZGUgfSBmcm9tICcuL21vZGVscy9zZWxlY3Rpb24tbW9kZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FsZW5kYXJDb25maWcge1xuICAvKipcbiAgICogRGlzcGxheXMgdGhlIGFkamFjZW50IGRheXMgaW4gbW9udGggY2FsZW5kYXIgdmlldy5cbiAgICpcbiAgICogQGRlZmF1bHQgdHJ1ZVxuICAgKi9cbiAgZGlzcGxheUFkamFjZW50RGF5czogYm9vbGVhbjtcbiAgLyoqXG4gICAqIFN3aXRjaGVzIGJldHdlZW4gc2luZ2xlIHNlbGVjdGlvbiBhbmQgYSBkYXRlcmFuZ2Ugc2VsZWN0aW9uLlxuICAgKlxuICAgKiBAZGVmYXVsdCBDYWxlbmRhclNlbGVjdGlvbk1vZGUuRGF0ZVxuICAgKi9cbiAgc2VsZWN0aW9uTW9kZTogQ2FsZW5kYXJTZWxlY3Rpb25Nb2RlO1xuXG4gIC8qKlxuICAgKiBDb25maWd1cmF0aW9uIGZvciB0aGUgeWVhciB2aWV3LlxuICAgKlxuICAgKiBAdHlwZWRlZiB7T2JqZWN0fSBZZWFyVmlld0NvbmZpZ1xuICAgKiBAcHJvcGVydHkge251bWJlcn0gaXRlbXNQZXJSb3cgLSBOdW1iZXIgb2YgaXRlbXMgdG8gZGlzcGxheSBwZXIgcm93IGluIHRoZSB5ZWFyIHZpZXcuXG4gICAqIEBkZWZhdWx0IDNcbiAgICovXG4gIC8qKlxuICAgKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIHRoZSBjYWxlbmRhcidzIHllYXIgdmlldy5cbiAgICpcbiAgICogQHR5cGUge1llYXJWaWV3Q29uZmlnfVxuICAgKi9cbiAgeWVhclZpZXc6IHsgaXRlbXNQZXJSb3c6IG51bWJlciB9O1xuICAvKipcbiAgICogQ29uZmlndXJhdGlvbiBmb3IgdGhlIHllYXJzIHZpZXcuXG4gICAqXG4gICAqIEB0eXBlZGVmIHtPYmplY3R9IFllYXJzVmlld0NvbmZpZ1xuICAgKiBAcHJvcGVydHkge251bWJlcn0gaXRlbXNQZXJSb3cgLSBOdW1iZXIgb2YgaXRlbXMgdG8gZGlzcGxheSBwZXIgcm93IGluIHRoZSB5ZWFycyB2aWV3LlxuICAgKiBAcHJvcGVydHkge251bWJlcn0gW3BhZGRpbmc9MTAwXSAtIFRoZSBudW1iZXIgb2YgeWVhciBpdGVtcyBiZWZvcmUgYW5kIGFmdGVyIHRoZSBjdXJyZW50IHllYXJcbiAgICogQGRlZmF1bHRcbiAgICogICBpdGVtc1BlclJvdzogMyxcbiAgICogICBwYWRkaW5nOiAxMDBcbiAgICovXG4gIC8qKlxuICAgKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIHRoZSBjYWxlbmRhcidzIHllYXJzIHZpZXcuXG4gICAqXG4gICAqIEB0eXBlIHtZZWFyc1ZpZXdDb25maWd9XG4gICAqL1xuICB5ZWFyc1ZpZXc6IHsgaXRlbXNQZXJSb3c6IG51bWJlcjsgcGFkZGluZzogbnVtYmVyIH07XG59XG5cbi8qKlxuICogVG9vbHMgZm9yIGN1c3RvbWl6aW5nIGNvbmZpZ3VyYXRpb24gZm9yIHRoZSBjYWxlbmRhciBjb21wb25lbnRcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIEBDb21wb25lbnQoe1xuICogIC4uLlxuICogIHByb3ZpZGVyczogW3Byb3ZpZGVDYWxlbmRhckNvbmZpZyh7IHNlbGVjdGlvbk1vZGU6IENhbGVuZGFyU2VsZWN0aW9uTW9kZS5EYXRlUmFuZ2UsIGxvY2FsZTogbmV3IEJlaGF2aW9yU3ViamVjdDxMb2NhbGU+KGRlREUpfSldXG4gKiB9KVxuICogZXhwb3J0IGNsYXNzIE15RGF0ZVJhbmdlcGlja2VyQ29tcG9uZW50IHt9XG4gKiBgYGBcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIGNvbnN0cnVjdG9yKEBJbmplY3QoQ2FsZW5kYXJDb25maWcpIHByaXZhdGUgcmVhZG9ubHkgY2FsZW5kYXJDb25maWc6IENhbGVuZGFyQ29uZmlnKSB7fVxuICogYGBgXG4gKi9cbmV4cG9ydCBjb25zdCB7IENhbGVuZGFyQ29uZmlnLCBDYWxlbmRhckRlZmF1bHRDb25maWcsIGluamVjdENhbGVuZGFyQ29uZmlnLCBwcm92aWRlQ2FsZW5kYXJDb25maWcgfSA9IGNyZWF0ZUNvbmZpZ1Rva2VucyhcbiAgJ0NhbGVuZGFyJyxcbiAgJ0BvZHgvYW5ndWxhci9jb21wb25lbnRzL2NhbGVuZGFyJyxcbiAge1xuICAgIGRpc3BsYXlBZGphY2VudERheXM6IHRydWUsXG4gICAgc2VsZWN0aW9uTW9kZTogQ2FsZW5kYXJTZWxlY3Rpb25Nb2RlLkRhdGUsXG4gICAgeWVhclZpZXc6IHtcbiAgICAgIGl0ZW1zUGVyUm93OiAzLFxuICAgIH0sXG4gICAgeWVhcnNWaWV3OiB7XG4gICAgICBpdGVtc1BlclJvdzogMyxcbiAgICAgIHBhZGRpbmc6IDEwMCxcbiAgICB9LFxuICB9LFxuKTtcbiJdfQ==