@alauda/ui 6.4.1-beta.7 → 6.4.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.
- package/autocomplete/autocomplete.directive.d.ts +1 -1
- package/esm2020/accordion/accordion-item/accordion-item.component.mjs +2 -2
- package/esm2020/anchor/anchor.component.mjs +2 -3
- package/esm2020/anchor/anchor.directive.mjs +2 -3
- package/esm2020/autocomplete/autocomplete.component.mjs +9 -6
- package/esm2020/autocomplete/autocomplete.directive.mjs +3 -4
- package/esm2020/autocomplete/suggestion/suggestion.component.mjs +5 -6
- package/esm2020/autocomplete/suggestion-group/suggestion-group.component.mjs +4 -4
- package/esm2020/back-top/back-top.component.mjs +2 -3
- package/esm2020/breadcrumb/breadcrumb-item.component.mjs +2 -2
- package/esm2020/checkbox/checkbox.component.mjs +2 -3
- package/esm2020/dialog/confirm-dialog/confirm-dialog.component.mjs +3 -4
- package/esm2020/drawer/component/drawer.component.mjs +2 -3
- package/esm2020/drawer/drawer.service.mjs +2 -3
- package/esm2020/dropdown/dropdown.directive.mjs +2 -2
- package/esm2020/form/form-item/form-item.component.mjs +4 -4
- package/esm2020/form/form.directive.mjs +2 -3
- package/esm2020/icon/icon-register.service.mjs +8 -5
- package/esm2020/input/autosize.directive.mjs +2 -3
- package/esm2020/radio/base-radio.mjs +2 -3
- package/esm2020/radio/radio-button/radio-button.component.mjs +2 -2
- package/esm2020/radio/radio-group/radio-group.component.mjs +2 -3
- package/esm2020/scrolling/fixed-size-table-virtual-scroll-strategy.mjs +2 -3
- package/esm2020/scrolling/fixed-size-table-virtual-scroll.directive.mjs +2 -3
- package/esm2020/select/base-select.mjs +7 -8
- package/esm2020/select/multi-select/multi-select.component.mjs +5 -6
- package/esm2020/select/option/option.component.mjs +5 -6
- package/esm2020/select/option-group/option-group.component.mjs +4 -4
- package/esm2020/select/select.component.mjs +5 -6
- package/esm2020/steps/steps.component.mjs +2 -3
- package/esm2020/table/table-scroll.directive.mjs +2 -3
- package/esm2020/table-of-contents/toc-container.directive.mjs +2 -3
- package/esm2020/tabs/tab-context.service.mjs +2 -3
- package/esm2020/tabs/tab-header.component.mjs +2 -3
- package/esm2020/theme/theme.pipe.mjs +2 -3
- package/esm2020/theme/theme.service.mjs +2 -3
- package/esm2020/tooltip/base-tooltip.mjs +2 -3
- package/esm2020/tooltip/tooltip.component.mjs +7 -8
- package/esm2020/tree-select/tree-select.component.mjs +6 -6
- package/esm2020/utils/index.mjs +2 -1
- package/esm2020/utils/operators.mjs +12 -0
- package/esm2020/utils/watch-content-exist.mjs +4 -3
- package/fesm2015/alauda-ui.mjs +70 -54
- package/fesm2015/alauda-ui.mjs.map +1 -1
- package/fesm2020/alauda-ui.mjs +70 -54
- package/fesm2020/alauda-ui.mjs.map +1 -1
- package/package.json +1 -1
- package/utils/index.d.ts +1 -0
- package/utils/operators.d.ts +8 -0
|
@@ -36,7 +36,7 @@ export declare class AutoCompleteDirective extends BaseTooltip<AutoCompleteConte
|
|
|
36
36
|
updateSuggestionsContext(): void;
|
|
37
37
|
onSuggestionClick(value: string): void;
|
|
38
38
|
createTooltip(): void;
|
|
39
|
-
|
|
39
|
+
autoFocusFirstSuggestion(): void;
|
|
40
40
|
private focusSuggestionDir;
|
|
41
41
|
private resetFocusedSuggestion;
|
|
42
42
|
private scrollToSuggestion;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { animate, state, style, transition, trigger, } from '@angular/animations';
|
|
2
2
|
import { CdkAccordionItem } from '@angular/cdk/accordion';
|
|
3
3
|
import { ChangeDetectionStrategy, Component, ContentChild, Directive, Input, TemplateRef, ViewEncapsulation, } from '@angular/core';
|
|
4
|
-
import { filter, startWith, take } from 'rxjs
|
|
4
|
+
import { filter, startWith, take } from 'rxjs';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "../accordion.component";
|
|
7
7
|
import * as i2 from "@angular/cdk/collections";
|
|
@@ -70,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
70
70
|
static: true,
|
|
71
71
|
}]
|
|
72
72
|
}] } });
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FjY29yZGlvbi9hY2NvcmRpb24taXRlbS9hY2NvcmRpb24taXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvYWNjb3JkaW9uL2FjY29yZGlvbi1pdGVtL2FjY29yZGlvbi1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxPQUFPLEVBQ1AsS0FBSyxFQUNMLEtBQUssRUFDTCxVQUFVLEVBQ1YsT0FBTyxHQUNSLE1BQU0scUJBQXFCLENBQUM7QUFDN0IsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFMUQsT0FBTyxFQUVMLHVCQUF1QixFQUV2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLFNBQVMsRUFDVCxLQUFLLEVBQ0wsV0FBVyxFQUNYLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7OztBQU8vQyxNQUFNLE9BQU8sNEJBQTRCOzt5SEFBNUIsNEJBQTRCOzZHQUE1Qiw0QkFBNEI7MkZBQTVCLDRCQUE0QjtrQkFIeEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsMEJBQTBCO2lCQUNyQzs7QUFLRCxNQUFNLE9BQU8sNkJBQTZCOzswSEFBN0IsNkJBQTZCOzhHQUE3Qiw2QkFBNkI7MkZBQTdCLDZCQUE2QjtrQkFIekMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsdUJBQXVCO2lCQUNsQzs7QUFrQkQsTUFBTSxPQUFPLHNCQUNYLFNBQVEsZ0JBQWdCO0lBY3hCLHFFQUFxRTtJQUNyRSxZQUNFLFNBQTZCLEVBQzdCLEdBQXNCLEVBQ3RCLHlCQUFvRDtRQUVwRCxLQUFLLENBQUMsU0FBUyxFQUFFLEdBQUcsRUFBRSx5QkFBeUIsQ0FBQyxDQUFDO1FBaEJuRCxlQUFVLEdBQUcsSUFBSSxDQUFDO0lBaUJsQixDQUFDO0lBRUQsa0JBQWtCO1FBQ2hCLElBQUksSUFBSSxDQUFDLGVBQWUsRUFBRTtZQUN4Qiw0REFBNEQ7WUFDNUQsSUFBSSxDQUFDLE1BQU07aUJBQ1IsSUFBSSxDQUNILFNBQVMsQ0FBQyxJQUFZLENBQUMsRUFDdkIsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEVBQzdCLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FDUjtpQkFDQSxTQUFTLENBQUMsR0FBRyxFQUFFO2dCQUNkLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQztZQUM3QyxDQUFDLENBQUMsQ0FBQztTQUNOO0lBQ0gsQ0FBQzs7bUhBckNVLHNCQUFzQjt1R0FBdEIsc0JBQXNCLDZJQU9uQiw2QkFBNkIsMkJBQ25DLFdBQVcsa0VDeERyQixxOEJBaUNBLDRnRkRhaUIsQ0FBQyxzQkFBc0IsQ0FBQyxjQVAzQjtRQUNWLE9BQU8sQ0FBQyxRQUFRLEVBQUU7WUFDaEIsS0FBSyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxNQUFNLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztZQUNoQyxLQUFLLENBQUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO1lBQ3pDLFVBQVUsQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLE9BQU8sQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLENBQUM7U0FDNUQsQ0FBQztLQUNIOzJGQUdVLHNCQUFzQjtrQkFoQmxDLFNBQVM7K0JBQ0Usb0JBQW9CLG1CQUdiLHVCQUF1QixDQUFDLE1BQU0saUJBQ2hDLGlCQUFpQixDQUFDLElBQUksdUJBQ2hCLEtBQUssY0FDZDt3QkFDVixPQUFPLENBQUMsUUFBUSxFQUFFOzRCQUNoQixLQUFLLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDOzRCQUNoQyxLQUFLLENBQUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDOzRCQUN6QyxVQUFVLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxPQUFPLENBQUMsa0JBQWtCLENBQUMsQ0FBQyxDQUFDO3lCQUM1RCxDQUFDO3FCQUNILGlCQUNjLHdCQUF3QjtpTEFPdkMsVUFBVTtzQkFEVCxLQUFLO2dCQU9OLGVBQWU7c0JBSmQsWUFBWTt1QkFBQyw2QkFBNkIsRUFBRTt3QkFDM0MsSUFBSSxFQUFFLFdBQVc7d0JBQ2pCLE1BQU0sRUFBRSxJQUFJO3FCQUNiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgYW5pbWF0ZSxcbiAgc3RhdGUsXG4gIHN0eWxlLFxuICB0cmFuc2l0aW9uLFxuICB0cmlnZ2VyLFxufSBmcm9tICdAYW5ndWxhci9hbmltYXRpb25zJztcbmltcG9ydCB7IENka0FjY29yZGlvbkl0ZW0gfSBmcm9tICdAYW5ndWxhci9jZGsvYWNjb3JkaW9uJztcbmltcG9ydCB7IFVuaXF1ZVNlbGVjdGlvbkRpc3BhdGNoZXIgfSBmcm9tICdAYW5ndWxhci9jZGsvY29sbGVjdGlvbnMnO1xuaW1wb3J0IHtcbiAgQWZ0ZXJDb250ZW50SW5pdCxcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENoYW5nZURldGVjdG9yUmVmLFxuICBDb21wb25lbnQsXG4gIENvbnRlbnRDaGlsZCxcbiAgRGlyZWN0aXZlLFxuICBJbnB1dCxcbiAgVGVtcGxhdGVSZWYsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGZpbHRlciwgc3RhcnRXaXRoLCB0YWtlIH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IEFjY29yZGlvbkNvbXBvbmVudCB9IGZyb20gJy4uL2FjY29yZGlvbi5jb21wb25lbnQnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXVpQWNjb3JkaW9uSXRlbUhlYWRlcl0nLFxufSlcbmV4cG9ydCBjbGFzcyBBY2NvcmRpb25JdGVtSGVhZGVyRGlyZWN0aXZlIHt9XG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXVpQWNjb3JkaW9uQ29udGVudF0nLFxufSlcbmV4cG9ydCBjbGFzcyBBY2NvcmRpb25JdGVtQ29udGVudERpcmVjdGl2ZSB7fVxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXVpLWFjY29yZGlvbi1pdGVtJyxcbiAgdGVtcGxhdGVVcmw6ICdhY2NvcmRpb24taXRlbS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWydhY2NvcmRpb24taXRlbS5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgcHJlc2VydmVXaGl0ZXNwYWNlczogZmFsc2UsXG4gIGFuaW1hdGlvbnM6IFtcbiAgICB0cmlnZ2VyKCdleHBhbmQnLCBbXG4gICAgICBzdGF0ZSgnKicsIHN0eWxlKHsgaGVpZ2h0OiAwIH0pKSxcbiAgICAgIHN0YXRlKCdleHBhbmRlZCcsIHN0eWxlKHsgaGVpZ2h0OiAnKicgfSkpLFxuICAgICAgdHJhbnNpdGlvbignKiA8PT4gZXhwYW5kZWQnLCBbYW5pbWF0ZSgnMC4xcyBlYXNlLWluLW91dCcpXSksXG4gICAgXSksXG4gIF0sXG4gIHZpZXdQcm92aWRlcnM6IFtBY2NvcmRpb25JdGVtQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgQWNjb3JkaW9uSXRlbUNvbXBvbmVudFxuICBleHRlbmRzIENka0FjY29yZGlvbkl0ZW1cbiAgaW1wbGVtZW50cyBBZnRlckNvbnRlbnRJbml0XG57XG4gIEBJbnB1dCgpXG4gIGJhY2tncm91bmQgPSB0cnVlO1xuXG4gIEBDb250ZW50Q2hpbGQoQWNjb3JkaW9uSXRlbUNvbnRlbnREaXJlY3RpdmUsIHtcbiAgICByZWFkOiBUZW1wbGF0ZVJlZixcbiAgICBzdGF0aWM6IHRydWUsXG4gIH0pXG4gIF9sYXp5Q29udGVudFRwbDogVGVtcGxhdGVSZWY8dW5rbm93bj47XG5cbiAgbGF6eUNvbnRlbnRUcGw6IFRlbXBsYXRlUmVmPHVua25vd24+O1xuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdXNlbGVzcy1jb25zdHJ1Y3RvclxuICBjb25zdHJ1Y3RvcihcbiAgICBhY2NvcmRpb246IEFjY29yZGlvbkNvbXBvbmVudCxcbiAgICBjZHI6IENoYW5nZURldGVjdG9yUmVmLFxuICAgIHVuaXF1ZVNlbGVjdGlvbkRpc3BhdGNoZXI6IFVuaXF1ZVNlbGVjdGlvbkRpc3BhdGNoZXIsXG4gICkge1xuICAgIHN1cGVyKGFjY29yZGlvbiwgY2RyLCB1bmlxdWVTZWxlY3Rpb25EaXNwYXRjaGVyKTtcbiAgfVxuXG4gIG5nQWZ0ZXJDb250ZW50SW5pdCgpIHtcbiAgICBpZiAodGhpcy5fbGF6eUNvbnRlbnRUcGwpIHtcbiAgICAgIC8vIFJlbmRlciB0aGUgY29udGVudCBhcyBzb29uIGFzIHRoZSBhY2NvcmRpb24gYmVjb21lcyBvcGVuLlxuICAgICAgdGhpcy5vcGVuZWRcbiAgICAgICAgLnBpcGUoXG4gICAgICAgICAgc3RhcnRXaXRoKG51bGwgYXMgdm9pZCksXG4gICAgICAgICAgZmlsdGVyKCgpID0+ICEhdGhpcy5leHBhbmRlZCksXG4gICAgICAgICAgdGFrZSgxKSxcbiAgICAgICAgKVxuICAgICAgICAuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICB0aGlzLmxhenlDb250ZW50VHBsID0gdGhpcy5fbGF6eUNvbnRlbnRUcGw7XG4gICAgICAgIH0pO1xuICAgIH1cbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImF1aS1hY2NvcmRpb24taXRlbVwiPlxuICA8ZGl2IGNsYXNzPVwiYXVpLWFjY29yZGlvbi1pdGVtX19oZWFkZXJcIj5cbiAgICA8YnV0dG9uXG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIGNsYXNzPVwiYXVpLWFjY29yZGlvbi1pdGVtX19leHBhbmQtYnV0dG9uXCJcbiAgICAgIFtjbGFzcy5pc0V4cGFuZGVkXT1cImV4cGFuZGVkXCJcbiAgICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXG4gICAgICAoY2xpY2spPVwidG9nZ2xlKClcIlxuICAgID5cbiAgICAgIDxhdWktaWNvbiBpY29uPVwiYW5nbGVfcmlnaHRcIj48L2F1aS1pY29uPlxuICAgIDwvYnV0dG9uPlxuICAgIDxkaXZcbiAgICAgIGNsYXNzPVwiYXVpLWFjY29yZGlvbi1pdGVtX19oZWFkZXItY29udGVudFwiXG4gICAgICBbY2xhc3MuYXVpLWFjY29yZGlvbi1pdGVtX19oZWFkZXItY29udGVudC0tZXhwYW5kZWRdPVwiZXhwYW5kZWRcIlxuICAgID5cbiAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIlthdWlBY2NvcmRpb25JdGVtSGVhZGVyXVwiPjwvbmctY29udGVudD5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG4gIDxkaXZcbiAgICAqbmdJZj1cImV4cGFuZGVkXCJcbiAgICBjbGFzcz1cImF1aS1hY2NvcmRpb24taXRlbV9fYm9keVwiXG4gICAgW2lkXT1cImlkXCJcbiAgICBbQGV4cGFuZF09XCJleHBhbmRlZCA/ICdleHBhbmRlZCcgOiAnY29sbGFwc2VkJ1wiXG4gID5cbiAgICA8ZGl2XG4gICAgICBjbGFzcz1cImF1aS1hY2NvcmRpb24taXRlbV9fY29udGVudFwiXG4gICAgICBbY2xhc3MuaGFzQmFja2dyb3VuZF09XCJiYWNrZ3JvdW5kXCJcbiAgICA+XG4gICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgICA8bmctdGVtcGxhdGUgW25nVGVtcGxhdGVPdXRsZXRdPVwibGF6eUNvbnRlbnRUcGxcIj48L25nLXRlbXBsYXRlPlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core';
|
|
2
|
-
import { EMPTY, Subject, combineLatest, fromEvent, of } from 'rxjs';
|
|
3
|
-
import { debounceTime, switchMap, takeUntil, tap } from 'rxjs/operators';
|
|
2
|
+
import { EMPTY, Subject, combineLatest, fromEvent, of, debounceTime, switchMap, takeUntil, tap, } from 'rxjs';
|
|
4
3
|
import { buildBem, isTemplateRef, last } from '../utils';
|
|
5
4
|
import { AnchorDirectiveChild } from './anchor.directive';
|
|
6
5
|
import { getAnchorTreeItems } from './utils';
|
|
@@ -136,4 +135,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
136
135
|
}], activeId: [{
|
|
137
136
|
type: Input
|
|
138
137
|
}] } });
|
|
139
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anchor.component.js","sourceRoot":"","sources":["../../../src/anchor/anchor.component.ts","../../../src/anchor/anchor-tree.component.html","../../../src/anchor/anchor.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EAEZ,KAAK,EAEL,MAAM,EACN,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,EAAE,EAAE,MAAM,MAAM,CAAC;AACpE,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAEzE,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,IAAI,EAAE,MAAM,UAAU,CAAC;AAEzD,OAAO,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAE1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;;;AAE7C,MAAM,GAAG,GAAG,QAAQ,CAAC,YAAY,CAAC,CAAC;AAQnC,MAAM,OAAO,mBACX,SAAQ,oBAAoB;IAP9B;;QA0BE,mBAAc,GAAG,IAAI,YAAY,EAAU,CAAC;QAE5C,QAAG,GAAG,GAAG,CAAC;QAEV,kBAAa,GAAG,aAAa,CAAC;QAEb,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;KAkDjD;IAxEC,IACI,SAAS,CAAC,SAAS;QACrB,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAgBD,iBAAiB;QACf,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;QACjD,kDAAkD;QAClD,aAAa,CACX,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CACrE;aACE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC/C,SAAS,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC,CAAC;IACzC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED,QAAQ,CAAC,IAAoB;QAC3B,OAAO,CACL,IAAI,CAAC,EAAE,KAAK,IAAI,CAAC,QAAQ;YACzB,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CACvD,CAAC;IACJ,CAAC;IAED,WAAW,CAAC,CAAQ,EAAE,IAAoB;QACxC,CAAC,CAAC,cAAc,EAAE,CAAC;QAEnB,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;YACxB,MAAM,QAAQ,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC;YAE/B,IAAI,QAAQ,CAAC,IAAI,KAAK,QAAQ,EAAE;gBAC9B,OAAO;aACR;YAED,OAAO,CAAC,SAAS,CACf,IAAI,EACJ,IAAI,EACJ,QAAQ,CAAC,QAAQ,GAAG,QAAQ,CAAC,MAAM,GAAG,QAAQ,CAC/C,CAAC;SACH;QAED,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;QAEnD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACpC,CAAC;IAED,SAAS,CAAC,MAAc,EAAE,IAAoB;QAC5C,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;;gHA3EU,mBAAmB;oGAAnB,mBAAmB,uLC7BhC,0sBAyBA,uBDIa,mBAAmB;2FAAnB,mBAAmB;kBAN/B,SAAS;+BACE,iBAAiB,iBAEZ,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;8BAO3C,SAAS;sBADZ,KAAK;gBAaN,QAAQ;sBADP,KAAK;gBAIN,cAAc;sBADb,MAAM;;AAkET,MAAM,OAAO,eACX,SAAQ,oBAAoB;IAmC5B,YACqB,QAAkB,EACpB,GAAsB;QAEvC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAHG,aAAQ,GAAR,QAAQ,CAAU;QACpB,QAAG,GAAH,GAAG,CAAmB;QANzC,QAAG,GAAG,GAAG,CAAC;QAEO,cAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;IAOjD,CAAC;IArCD,IACI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IAAI,KAAK,CAAC,KAAK;QACb,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,SAAS,GAAG,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAC3C,MAAM,QAAQ,GACZ,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC;QACpE,MAAM,UAAU,GACd,CAAC,QAAQ,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,QAAQ,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC;QACpE,IAAI,UAAU,EAAE;YACd,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,IAAI,IAAI,CAAC,MAAM,CAAC,YAAY,KAAK,MAAM,EAAE;gBAC/D,UAAU,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;aACpC;YACD,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC,EAAE,CAAC;SAC/B;IACH,CAAC;IAqBD,eAAe;QACb,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,YAAY,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC;QAC5D,MAAM,aAAa,GAAG,WAAW,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC;QAChE,MAAM,UAAU,GAAG,aAAa;YAC9B,CAAC,CAAC,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YAC1D,CAAC,CAAC,CAAC,CAAC;QACN,SAAS,CAAC,YAAY,EAAE,QAAQ,CAAC;aAC9B,IAAI,CACH,YAAY,CAAC,GAAG,CAAC,EACjB,SAAS,CAAC,GAAG,EAAE;YACb,MAAM,EAAE,SAAS,EAAE,GACjB,YAAY,KAAK,MAAM;gBACrB,CAAC,CAAC,QAAQ,CAAC,eAAe;gBAC1B,CAAC,CAAE,YAA4B,CAAC;YACpC,MAAM,WAAW,GACf,IAAI,CAAC,KAAK,CAAC,IAAI,CACb,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CACb,MAAM,CAAC,SAAS;gBACd,MAAM,CAAC,YAAY,GAAG,CAAC;gBACvB,CAAC,CAAC,YAAY,KAAK,MAAM;oBACtB,MAAM,CAAC,YAA4B,EAAE,SAAS,CAAC;oBAChD,CAAC,CAAC;gBACN,SAAS,GAAG,UAAU,CACzB,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACxB,OAAO,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QAC/C,CAAC,CAAC,EACF,GAAG,CAAC,WAAW,CAAC,EAAE;YAChB,IAAI,WAAW,CAAC,EAAE,EAAE;gBAClB,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,EAAE,CAAC;gBAC/B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;aACzB;QACH,CAAC,CAAC,EACF,YAAY,CAAC,GAAG,CAAC,EACjB,GAAG,CAAC,WAAW,CAAC,EAAE;YAChB,IAAI,QAAQ,IAAI,WAAW,CAAC,EAAE,EAAE;gBAC9B,OAAO,CAAC,YAAY,CAClB,IAAI,EACJ,IAAI,EACJ,QAAQ,CAAC,QAAQ,GAAG,QAAQ,CAAC,MAAM,GAAG,GAAG,GAAG,WAAW,CAAC,EAAE,CAC3D,CAAC;aACH;QACH,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B;aACA,SAAS,EAAE,CAAC;IACjB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;;4GA7FU,eAAe;gGAAf,eAAe,mJElH5B,kJAMA,8oDFuBa,mBAAmB;2FAqFnB,eAAe;kBAP3B,SAAS;+BACE,YAAY,iBAGP,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;+HAO3C,KAAK;sBADR,KAAK;gBAuBN,SAAS;sBADR,KAAK;gBAIN,QAAQ;sBADP,KAAK","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Injector,\n  Input,\n  OnDestroy,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { EMPTY, Subject, combineLatest, fromEvent, of } from 'rxjs';\nimport { debounceTime, switchMap, takeUntil, tap } from 'rxjs/operators';\n\nimport { buildBem, isTemplateRef, last } from '../utils';\n\nimport { AnchorDirectiveChild } from './anchor.directive';\nimport { AnchorItem, AnchorTreeItem } from './types';\nimport { getAnchorTreeItems } from './utils';\n\nconst bem = buildBem('aui-anchor');\n\n@Component({\n  selector: 'aui-anchor-tree',\n  templateUrl: 'anchor-tree.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AnchorTreeComponent\n  extends AnchorDirectiveChild\n  implements OnDestroy\n{\n  @Input()\n  set treeItems(treeItems) {\n    this._treeItems = treeItems;\n    this.watchLabelsChange();\n  }\n\n  get treeItems() {\n    return this._treeItems;\n  }\n\n  private _treeItems: AnchorTreeItem[];\n\n  @Input()\n  activeId: string;\n\n  @Output()\n  activeIdChange = new EventEmitter<string>();\n\n  bem = bem;\n\n  isTemplateRef = isTemplateRef;\n\n  private readonly depose$$ = new Subject<void>();\n\n  watchLabelsChange() {\n    this.depose$$.next();\n    const cdr = this.injector.get(ChangeDetectorRef);\n    // FIXME: Is there any better way to achieve this?\n    combineLatest(\n      this.treeItems.map(({ labelChange }) => labelChange).filter(Boolean),\n    )\n      .pipe(debounceTime(0), takeUntil(this.depose$$))\n      .subscribe(() => cdr.markForCheck());\n  }\n\n  ngOnDestroy() {\n    this.depose$$.next();\n    this.depose$$.complete();\n  }\n\n  isActive(item: AnchorTreeItem): boolean {\n    return (\n      item.id === this.activeId ||\n      item.children?.some(subItem => this.isActive(subItem))\n    );\n  }\n\n  onItemClick(e: Event, item: AnchorTreeItem) {\n    e.preventDefault();\n\n    if (this.parent.injectId) {\n      const selector = '#' + item.id;\n\n      if (location.hash === selector) {\n        return;\n      }\n\n      history.pushState(\n        null,\n        null,\n        location.pathname + location.search + selector,\n      );\n    }\n\n    item.target.scrollIntoView({ behavior: 'smooth' });\n\n    this.activeIdChange.emit(item.id);\n  }\n\n  trackById(_index: number, item: AnchorTreeItem) {\n    return item.id;\n  }\n}\n\n@Component({\n  selector: 'aui-anchor',\n  templateUrl: 'anchor.component.html',\n  styleUrls: ['anchor.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AnchorComponent\n  extends AnchorDirectiveChild\n  implements AfterViewInit, OnDestroy\n{\n  @Input()\n  get items() {\n    return this._items;\n  }\n\n  set items(items) {\n    this._items = items;\n    this.treeItems = getAnchorTreeItems(items);\n    const anchorId =\n      (this.parent.injectId && location.hash.slice(1)) || this.activeId;\n    const activeItem =\n      (anchorId && items.find(({ id }) => id === anchorId)) || items[0];\n    if (activeItem) {\n      if (this.parent.injectId && this.parent.scrollableEl !== window) {\n        activeItem.target.scrollIntoView();\n      }\n      this.activeId = activeItem.id;\n    }\n  }\n\n  private _items: AnchorItem[];\n\n  @Input()\n  treeItems: AnchorTreeItem[];\n\n  @Input()\n  activeId: string;\n\n  bem = bem;\n\n  private readonly destroy$$ = new Subject<void>();\n\n  constructor(\n    protected override injector: Injector,\n    private readonly cdr: ChangeDetectorRef,\n  ) {\n    super(injector);\n  }\n\n  ngAfterViewInit() {\n    const { injectId, containerEl, scrollableEl } = this.parent;\n    const pageContentEl = containerEl.closest('.aui-page__content');\n    const paddingTop = pageContentEl\n      ? +getComputedStyle(pageContentEl).paddingTop.slice(0, -2)\n      : 0;\n    fromEvent(scrollableEl, 'scroll')\n      .pipe(\n        debounceTime(100),\n        switchMap(() => {\n          const { scrollTop } =\n            scrollableEl === window\n              ? document.documentElement\n              : (scrollableEl as HTMLElement);\n          const activedItem =\n            this.items.find(\n              ({ target }) =>\n                target.offsetTop +\n                  target.offsetHeight / 2 +\n                  ((scrollableEl === window &&\n                    (target.offsetParent as HTMLElement)?.offsetTop) ||\n                    0) >\n                scrollTop + paddingTop,\n            ) || last(this.items);\n          return activedItem ? of(activedItem) : EMPTY;\n        }),\n        tap(activedItem => {\n          if (activedItem.id) {\n            this.activeId = activedItem.id;\n            this.cdr.markForCheck();\n          }\n        }),\n        debounceTime(100),\n        tap(activedItem => {\n          if (injectId && activedItem.id) {\n            history.replaceState(\n              null,\n              null,\n              location.pathname + location.search + '#' + activedItem.id,\n            );\n          }\n        }),\n        takeUntil(this.destroy$$),\n      )\n      .subscribe();\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n}\n","<div\n  [class]=\"bem.element('item')\"\n  [class.active]=\"isActive(item)\"\n  *ngFor=\"let item of treeItems; trackBy: trackById\"\n>\n  <a\n    *ngIf=\"item.label as label\"\n    [href]=\"parent.injectId ? '#' + item.id : undefined\"\n    (click)=\"onItemClick($event, item)\"\n  >\n    <ng-container *ngIf=\"isTemplateRef(label); else plain\">\n      <ng-container\n        *ngTemplateOutlet=\"label; context: item.labelContext\"\n      ></ng-container>\n    </ng-container>\n    <ng-template #plain>\n      {{ item.label }}\n    </ng-template>\n  </a>\n  <aui-anchor-tree\n    *ngIf=\"item.children?.length\"\n    [treeItems]=\"item.children\"\n    [(activeId)]=\"activeId\"\n  ></aui-anchor-tree>\n</div>\n","<div [class]=\"bem.block()\">\n  <aui-anchor-tree\n    [treeItems]=\"treeItems\"\n    [(activeId)]=\"activeId\"\n  ></aui-anchor-tree>\n</div>\n"]}
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anchor.component.js","sourceRoot":"","sources":["../../../src/anchor/anchor.component.ts","../../../src/anchor/anchor-tree.component.html","../../../src/anchor/anchor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Injector,\n  Input,\n  OnDestroy,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  EMPTY,\n  Subject,\n  combineLatest,\n  fromEvent,\n  of,\n  debounceTime,\n  switchMap,\n  takeUntil,\n  tap,\n} from 'rxjs';\n\nimport { buildBem, isTemplateRef, last } from '../utils';\n\nimport { AnchorDirectiveChild } from './anchor.directive';\nimport { AnchorItem, AnchorTreeItem } from './types';\nimport { getAnchorTreeItems } from './utils';\n\nconst bem = buildBem('aui-anchor');\n\n@Component({\n  selector: 'aui-anchor-tree',\n  templateUrl: 'anchor-tree.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AnchorTreeComponent\n  extends AnchorDirectiveChild\n  implements OnDestroy\n{\n  @Input()\n  set treeItems(treeItems) {\n    this._treeItems = treeItems;\n    this.watchLabelsChange();\n  }\n\n  get treeItems() {\n    return this._treeItems;\n  }\n\n  private _treeItems: AnchorTreeItem[];\n\n  @Input()\n  activeId: string;\n\n  @Output()\n  activeIdChange = new EventEmitter<string>();\n\n  bem = bem;\n\n  isTemplateRef = isTemplateRef;\n\n  private readonly depose$$ = new Subject<void>();\n\n  watchLabelsChange() {\n    this.depose$$.next();\n    const cdr = this.injector.get(ChangeDetectorRef);\n    // FIXME: Is there any better way to achieve this?\n    combineLatest(\n      this.treeItems.map(({ labelChange }) => labelChange).filter(Boolean),\n    )\n      .pipe(debounceTime(0), takeUntil(this.depose$$))\n      .subscribe(() => cdr.markForCheck());\n  }\n\n  ngOnDestroy() {\n    this.depose$$.next();\n    this.depose$$.complete();\n  }\n\n  isActive(item: AnchorTreeItem): boolean {\n    return (\n      item.id === this.activeId ||\n      item.children?.some(subItem => this.isActive(subItem))\n    );\n  }\n\n  onItemClick(e: Event, item: AnchorTreeItem) {\n    e.preventDefault();\n\n    if (this.parent.injectId) {\n      const selector = '#' + item.id;\n\n      if (location.hash === selector) {\n        return;\n      }\n\n      history.pushState(\n        null,\n        null,\n        location.pathname + location.search + selector,\n      );\n    }\n\n    item.target.scrollIntoView({ behavior: 'smooth' });\n\n    this.activeIdChange.emit(item.id);\n  }\n\n  trackById(_index: number, item: AnchorTreeItem) {\n    return item.id;\n  }\n}\n\n@Component({\n  selector: 'aui-anchor',\n  templateUrl: 'anchor.component.html',\n  styleUrls: ['anchor.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AnchorComponent\n  extends AnchorDirectiveChild\n  implements AfterViewInit, OnDestroy\n{\n  @Input()\n  get items() {\n    return this._items;\n  }\n\n  set items(items) {\n    this._items = items;\n    this.treeItems = getAnchorTreeItems(items);\n    const anchorId =\n      (this.parent.injectId && location.hash.slice(1)) || this.activeId;\n    const activeItem =\n      (anchorId && items.find(({ id }) => id === anchorId)) || items[0];\n    if (activeItem) {\n      if (this.parent.injectId && this.parent.scrollableEl !== window) {\n        activeItem.target.scrollIntoView();\n      }\n      this.activeId = activeItem.id;\n    }\n  }\n\n  private _items: AnchorItem[];\n\n  @Input()\n  treeItems: AnchorTreeItem[];\n\n  @Input()\n  activeId: string;\n\n  bem = bem;\n\n  private readonly destroy$$ = new Subject<void>();\n\n  constructor(\n    protected override injector: Injector,\n    private readonly cdr: ChangeDetectorRef,\n  ) {\n    super(injector);\n  }\n\n  ngAfterViewInit() {\n    const { injectId, containerEl, scrollableEl } = this.parent;\n    const pageContentEl = containerEl.closest('.aui-page__content');\n    const paddingTop = pageContentEl\n      ? +getComputedStyle(pageContentEl).paddingTop.slice(0, -2)\n      : 0;\n    fromEvent(scrollableEl, 'scroll')\n      .pipe(\n        debounceTime(100),\n        switchMap(() => {\n          const { scrollTop } =\n            scrollableEl === window\n              ? document.documentElement\n              : (scrollableEl as HTMLElement);\n          const activedItem =\n            this.items.find(\n              ({ target }) =>\n                target.offsetTop +\n                  target.offsetHeight / 2 +\n                  ((scrollableEl === window &&\n                    (target.offsetParent as HTMLElement)?.offsetTop) ||\n                    0) >\n                scrollTop + paddingTop,\n            ) || last(this.items);\n          return activedItem ? of(activedItem) : EMPTY;\n        }),\n        tap(activedItem => {\n          if (activedItem.id) {\n            this.activeId = activedItem.id;\n            this.cdr.markForCheck();\n          }\n        }),\n        debounceTime(100),\n        tap(activedItem => {\n          if (injectId && activedItem.id) {\n            history.replaceState(\n              null,\n              null,\n              location.pathname + location.search + '#' + activedItem.id,\n            );\n          }\n        }),\n        takeUntil(this.destroy$$),\n      )\n      .subscribe();\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n}\n","<div\n  [class]=\"bem.element('item')\"\n  [class.active]=\"isActive(item)\"\n  *ngFor=\"let item of treeItems; trackBy: trackById\"\n>\n  <a\n    *ngIf=\"item.label as label\"\n    [href]=\"parent.injectId ? '#' + item.id : undefined\"\n    (click)=\"onItemClick($event, item)\"\n  >\n    <ng-container *ngIf=\"isTemplateRef(label); else plain\">\n      <ng-container\n        *ngTemplateOutlet=\"label; context: item.labelContext\"\n      ></ng-container>\n    </ng-container>\n    <ng-template #plain>\n      {{ item.label }}\n    </ng-template>\n  </a>\n  <aui-anchor-tree\n    *ngIf=\"item.children?.length\"\n    [treeItems]=\"item.children\"\n    [(activeId)]=\"activeId\"\n  ></aui-anchor-tree>\n</div>\n","<div [class]=\"bem.block()\">\n  <aui-anchor-tree\n    [treeItems]=\"treeItems\"\n    [(activeId)]=\"activeId\"\n  ></aui-anchor-tree>\n</div>\n"]}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { ComponentPortal, DomPortalOutlet } from '@angular/cdk/portal';
|
|
2
2
|
import { ContentChildren, Directive, ElementRef, EventEmitter, HostBinding, Input, Optional, Output, } from '@angular/core';
|
|
3
|
-
import { Subject, fromEvent, merge } from 'rxjs';
|
|
4
|
-
import { startWith, takeUntil } from 'rxjs/operators';
|
|
3
|
+
import { Subject, fromEvent, merge, startWith, takeUntil } from 'rxjs';
|
|
5
4
|
import { observeResizeOn } from '../utils';
|
|
6
5
|
import { AnchorComponent } from './anchor.component';
|
|
7
6
|
import * as i0 from "@angular/core";
|
|
@@ -180,4 +179,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
180
179
|
type: ContentChildren,
|
|
181
180
|
args: [AnchorLabelDirective, { descendants: true }]
|
|
182
181
|
}] } });
|
|
183
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anchor.directive.js","sourceRoot":"","sources":["../../../src/anchor/anchor.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentPortal, DomPortalOutlet } from '@angular/cdk/portal';\nimport { CdkScrollable } from '@angular/cdk/scrolling';\nimport {\n  AfterContentChecked,\n  AfterContentInit,\n  ApplicationRef,\n  ComponentFactoryResolver,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Injector,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  TemplateRef,\n} from '@angular/core';\nimport { Subject, fromEvent, merge } from 'rxjs';\nimport { startWith, takeUntil } from 'rxjs/operators';\n\nimport { observeResizeOn } from '../utils';\n\nimport { AnchorComponent } from './anchor.component';\n\nlet uid = 0;\n\n@Directive()\nexport class AnchorDirectiveChild {\n  readonly parent: AnchorDirective;\n\n  constructor(protected injector: Injector) {\n    this.parent = this.injector.get(AnchorDirective);\n  }\n}\n\n@Directive({\n  selector: '[auiAnchorLabel]',\n})\nexport class AnchorLabelDirective\n  extends AnchorDirectiveChild\n  implements OnInit, AfterContentChecked\n{\n  @HostBinding('class.aui-anchor__label')\n  @Input('auiAnchorLabel')\n  get label() {\n    return this._label || this.elRef.nativeElement.textContent;\n  }\n\n  set label(value) {\n    this._label = value;\n    this.labelChange.emit(value);\n  }\n\n  private _label: string | TemplateRef<unknown>;\n\n  @Input('auiAnchorLabelContext')\n  labelContext: unknown;\n\n  get target() {\n    return this.elRef.nativeElement;\n  }\n\n  @Input()\n  set id(id) {\n    if (this.parent.injectId && !this.id) {\n      this.elRef.nativeElement.id = id;\n    }\n    this._id = id;\n  }\n\n  get id() {\n    return this._id;\n  }\n\n  private _id: string;\n\n  @Input()\n  set level(value: number | '') {\n    this._level = value === '' ? 1 : value;\n  }\n\n  get level() {\n    return this._level;\n  }\n\n  private _level = 0;\n\n  @Output()\n  labelChange = new EventEmitter<string | TemplateRef<unknown>>();\n\n  constructor(\n    protected override injector: Injector,\n    public readonly elRef: ElementRef<HTMLElement>,\n  ) {\n    super(injector);\n    this._id = this.elRef.nativeElement.id;\n  }\n\n  ngOnInit() {\n    if (!this.id) {\n      this.id = 'anchor-uid-' + uid++;\n    }\n  }\n\n  ngAfterContentChecked() {\n    if (!this._label) {\n      this.labelChange.emit(this.label);\n    }\n  }\n}\n\n@Directive({\n  selector: '[auiAnchor]',\n})\nexport class AnchorDirective implements AfterContentInit, OnDestroy {\n  @Input()\n  auiAnchor: HTMLElement | '';\n\n  @Input()\n  adaptPosition = true;\n\n  @Input()\n  padding = 20;\n\n  @Input()\n  minTop: number;\n\n  @Input()\n  injectId = window === window.top;\n\n  @ContentChildren(AnchorLabelDirective, { descendants: true })\n  anchorLabels: QueryList<AnchorLabelDirective>;\n\n  get containerEl() {\n    return this.elRef.nativeElement;\n  }\n\n  get scrollableEl() {\n    const el = this.containerEl;\n    return (\n      this.auiAnchor ||\n      this.cdkScrollable?.getElementRef().nativeElement ||\n      (el.scrollHeight > el.offsetHeight ? el : window)\n    );\n  }\n\n  anchorPortal: ComponentPortal<AnchorComponent>;\n\n  destroy$$ = new Subject<void>();\n\n  constructor(\n    private readonly cfr: ComponentFactoryResolver,\n    private readonly appRef: ApplicationRef,\n    private readonly injector: Injector,\n    public readonly elRef: ElementRef<HTMLElement>,\n    @Optional() private readonly cdkScrollable: CdkScrollable,\n  ) {}\n\n  ngAfterContentInit() {\n    const containerEl = this.containerEl;\n    this.anchorPortal = new ComponentPortal(AnchorComponent);\n    const portalOutlet = new DomPortalOutlet(\n      document.body,\n      this.cfr,\n      this.appRef,\n      this.injector,\n    );\n    const anchorComponentRef = this.anchorPortal.attach(portalOutlet);\n    const anchorEl = anchorComponentRef.injector.get(ElementRef)\n      .nativeElement as HTMLElement;\n\n    requestAnimationFrame(() =>\n      this.adaptAnchorPosition(containerEl, anchorEl),\n    );\n\n    this.anchorLabels.changes\n      .pipe(startWith(this.anchorLabels), takeUntil(this.destroy$$))\n      .subscribe((anchorLabels: QueryList<AnchorLabelDirective>) => {\n        Object.assign(anchorComponentRef.instance, {\n          items: anchorLabels.toArray(),\n        });\n      });\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n    this.anchorPortal.detach();\n  }\n\n  adaptAnchorPosition(containerEl: HTMLElement, anchorEl: HTMLElement) {\n    const pageContentEl = containerEl.closest('.aui-page__content');\n    const anchorContentEl = anchorEl.querySelector('.aui-anchor');\n\n    merge(observeResizeOn(containerEl), fromEvent(window, 'scroll'))\n      .pipe(startWith(null as void), takeUntil(this.destroy$$))\n      .subscribe(() => {\n        const containerRect = containerEl.getBoundingClientRect();\n        Object.assign(anchorEl.style, {\n          display: !containerRect.width || !containerRect.height ? 'none' : '',\n          left:\n            containerRect.right -\n            anchorContentEl.getBoundingClientRect().width +\n            'px',\n          top:\n            Math.max(\n              containerRect.top,\n              (this.minTop ??\n                (pageContentEl &&\n                  +getComputedStyle(pageContentEl).paddingTop.slice(0, -2))) ||\n                0,\n            ) + 'px',\n        });\n      });\n\n    if (this.adaptPosition) {\n      observeResizeOn(anchorContentEl)\n        .pipe(takeUntil(this.destroy$$))\n        .subscribe(el => {\n          const width = el.getBoundingClientRect().width;\n          const padding = width + this.padding;\n          containerEl.style.paddingRight = padding + 'px';\n        });\n    }\n  }\n}\n"]}
|
|
182
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anchor.directive.js","sourceRoot":"","sources":["../../../src/anchor/anchor.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentPortal, DomPortalOutlet } from '@angular/cdk/portal';\nimport { CdkScrollable } from '@angular/cdk/scrolling';\nimport {\n  AfterContentChecked,\n  AfterContentInit,\n  ApplicationRef,\n  ComponentFactoryResolver,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Injector,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  TemplateRef,\n} from '@angular/core';\nimport { Subject, fromEvent, merge, startWith, takeUntil } from 'rxjs';\n\nimport { observeResizeOn } from '../utils';\n\nimport { AnchorComponent } from './anchor.component';\n\nlet uid = 0;\n\n@Directive()\nexport class AnchorDirectiveChild {\n  readonly parent: AnchorDirective;\n\n  constructor(protected injector: Injector) {\n    this.parent = this.injector.get(AnchorDirective);\n  }\n}\n\n@Directive({\n  selector: '[auiAnchorLabel]',\n})\nexport class AnchorLabelDirective\n  extends AnchorDirectiveChild\n  implements OnInit, AfterContentChecked\n{\n  @HostBinding('class.aui-anchor__label')\n  @Input('auiAnchorLabel')\n  get label() {\n    return this._label || this.elRef.nativeElement.textContent;\n  }\n\n  set label(value) {\n    this._label = value;\n    this.labelChange.emit(value);\n  }\n\n  private _label: string | TemplateRef<unknown>;\n\n  @Input('auiAnchorLabelContext')\n  labelContext: unknown;\n\n  get target() {\n    return this.elRef.nativeElement;\n  }\n\n  @Input()\n  set id(id) {\n    if (this.parent.injectId && !this.id) {\n      this.elRef.nativeElement.id = id;\n    }\n    this._id = id;\n  }\n\n  get id() {\n    return this._id;\n  }\n\n  private _id: string;\n\n  @Input()\n  set level(value: number | '') {\n    this._level = value === '' ? 1 : value;\n  }\n\n  get level() {\n    return this._level;\n  }\n\n  private _level = 0;\n\n  @Output()\n  labelChange = new EventEmitter<string | TemplateRef<unknown>>();\n\n  constructor(\n    protected override injector: Injector,\n    public readonly elRef: ElementRef<HTMLElement>,\n  ) {\n    super(injector);\n    this._id = this.elRef.nativeElement.id;\n  }\n\n  ngOnInit() {\n    if (!this.id) {\n      this.id = 'anchor-uid-' + uid++;\n    }\n  }\n\n  ngAfterContentChecked() {\n    if (!this._label) {\n      this.labelChange.emit(this.label);\n    }\n  }\n}\n\n@Directive({\n  selector: '[auiAnchor]',\n})\nexport class AnchorDirective implements AfterContentInit, OnDestroy {\n  @Input()\n  auiAnchor: HTMLElement | '';\n\n  @Input()\n  adaptPosition = true;\n\n  @Input()\n  padding = 20;\n\n  @Input()\n  minTop: number;\n\n  @Input()\n  injectId = window === window.top;\n\n  @ContentChildren(AnchorLabelDirective, { descendants: true })\n  anchorLabels: QueryList<AnchorLabelDirective>;\n\n  get containerEl() {\n    return this.elRef.nativeElement;\n  }\n\n  get scrollableEl() {\n    const el = this.containerEl;\n    return (\n      this.auiAnchor ||\n      this.cdkScrollable?.getElementRef().nativeElement ||\n      (el.scrollHeight > el.offsetHeight ? el : window)\n    );\n  }\n\n  anchorPortal: ComponentPortal<AnchorComponent>;\n\n  destroy$$ = new Subject<void>();\n\n  constructor(\n    private readonly cfr: ComponentFactoryResolver,\n    private readonly appRef: ApplicationRef,\n    private readonly injector: Injector,\n    public readonly elRef: ElementRef<HTMLElement>,\n    @Optional() private readonly cdkScrollable: CdkScrollable,\n  ) {}\n\n  ngAfterContentInit() {\n    const containerEl = this.containerEl;\n    this.anchorPortal = new ComponentPortal(AnchorComponent);\n    const portalOutlet = new DomPortalOutlet(\n      document.body,\n      this.cfr,\n      this.appRef,\n      this.injector,\n    );\n    const anchorComponentRef = this.anchorPortal.attach(portalOutlet);\n    const anchorEl = anchorComponentRef.injector.get(ElementRef)\n      .nativeElement as HTMLElement;\n\n    requestAnimationFrame(() =>\n      this.adaptAnchorPosition(containerEl, anchorEl),\n    );\n\n    this.anchorLabels.changes\n      .pipe(startWith(this.anchorLabels), takeUntil(this.destroy$$))\n      .subscribe((anchorLabels: QueryList<AnchorLabelDirective>) => {\n        Object.assign(anchorComponentRef.instance, {\n          items: anchorLabels.toArray(),\n        });\n      });\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n    this.anchorPortal.detach();\n  }\n\n  adaptAnchorPosition(containerEl: HTMLElement, anchorEl: HTMLElement) {\n    const pageContentEl = containerEl.closest('.aui-page__content');\n    const anchorContentEl = anchorEl.querySelector('.aui-anchor');\n\n    merge(observeResizeOn(containerEl), fromEvent(window, 'scroll'))\n      .pipe(startWith(null as void), takeUntil(this.destroy$$))\n      .subscribe(() => {\n        const containerRect = containerEl.getBoundingClientRect();\n        Object.assign(anchorEl.style, {\n          display: !containerRect.width || !containerRect.height ? 'none' : '',\n          left:\n            containerRect.right -\n            anchorContentEl.getBoundingClientRect().width +\n            'px',\n          top:\n            Math.max(\n              containerRect.top,\n              (this.minTop ??\n                (pageContentEl &&\n                  +getComputedStyle(pageContentEl).paddingTop.slice(0, -2))) ||\n                0,\n            ) + 'px',\n        });\n      });\n\n    if (this.adaptPosition) {\n      observeResizeOn(anchorContentEl)\n        .pipe(takeUntil(this.destroy$$))\n        .subscribe(el => {\n          const width = el.getBoundingClientRect().width;\n          const padding = width + this.padding;\n          containerEl.style.paddingRight = padding + 'px';\n        });\n    }\n  }\n}\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, ContentChildren, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
2
|
-
import { ReplaySubject, combineLatest, of } from 'rxjs';
|
|
3
|
-
import {
|
|
2
|
+
import { ReplaySubject, combineLatest, of, debounceTime, distinctUntilChanged, map, startWith, switchMap, tap, withLatestFrom, } from 'rxjs';
|
|
3
|
+
import { publishRef } from '../utils';
|
|
4
4
|
import { AutocompletePlaceholderComponent } from './autocomplete-placeholder.component';
|
|
5
5
|
import { SuggestionComponent } from './suggestion/suggestion.component';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
@@ -13,9 +13,12 @@ export class AutocompleteComponent {
|
|
|
13
13
|
ngAfterContentInit() {
|
|
14
14
|
this.hasVisibleSuggestion$ = this.suggestions.changes.pipe(startWith(this.suggestions), switchMap((suggestions) => suggestions.length > 0
|
|
15
15
|
? combineLatest(suggestions.map(suggestion => suggestion.visible$))
|
|
16
|
-
: of([])), map(visible => visible.some(Boolean)),
|
|
17
|
-
|
|
18
|
-
|
|
16
|
+
: of([])), map(visible => visible.some(Boolean)), withLatestFrom(this.directive$$), map(([hasVisibleSuggestion, directive]) => {
|
|
17
|
+
if (hasVisibleSuggestion && directive.defaultFirstSuggestion) {
|
|
18
|
+
directive.autoFocusFirstSuggestion();
|
|
19
|
+
}
|
|
20
|
+
return hasVisibleSuggestion;
|
|
21
|
+
}), distinctUntilChanged(), debounceTime(0), tap(() => this.cdr.markForCheck()), publishRef());
|
|
19
22
|
this.hasContent$ = combineLatest([
|
|
20
23
|
this.hasVisibleSuggestion$,
|
|
21
24
|
this.placeholder.changes.pipe(startWith(this.placeholder), map((list) => !!list.length)),
|
|
@@ -40,4 +43,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
40
43
|
type: ViewChild,
|
|
41
44
|
args: ['suggestionListRef', { static: true }]
|
|
42
45
|
}] } });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hdXRvY29tcGxldGUvYXV0b2NvbXBsZXRlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uL3NyYy9hdXRvY29tcGxldGUvYXV0b2NvbXBsZXRlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCx1QkFBdUIsRUFFdkIsU0FBUyxFQUNULGVBQWUsRUFHZixXQUFXLEVBQ1gsU0FBUyxFQUNULGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBRUwsYUFBYSxFQUNiLGFBQWEsRUFDYixFQUFFLEVBQ0YsWUFBWSxFQUNaLG9CQUFvQixFQUNwQixHQUFHLEVBQ0gsU0FBUyxFQUNULFNBQVMsRUFDVCxHQUFHLEVBQ0gsY0FBYyxHQUNmLE1BQU0sTUFBTSxDQUFDO0FBRWQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUV0QyxPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUV4RixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7O0FBVXhFLE1BQU0sT0FBTyxxQkFBcUI7SUFrQmhDLFlBQTZCLEdBQXNCO1FBQXRCLFFBQUcsR0FBSCxHQUFHLENBQW1CO1FBRm5ELGdCQUFXLEdBQUcsSUFBSSxhQUFhLENBQXdCLENBQUMsQ0FBQyxDQUFDO0lBRUosQ0FBQztJQUV2RCxrQkFBa0I7UUFDaEIsSUFBSSxDQUFDLHFCQUFxQixHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLElBQUksQ0FDeEQsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsRUFDM0IsU0FBUyxDQUFDLENBQUMsV0FBMkMsRUFBRSxFQUFFLENBQ3hELFdBQVcsQ0FBQyxNQUFNLEdBQUcsQ0FBQztZQUNwQixDQUFDLENBQUMsYUFBYSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDbkUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFlLENBQUMsQ0FDeEIsRUFDRCxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEVBQ3JDLGNBQWMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLEVBQ2hDLEdBQUcsQ0FBQyxDQUFDLENBQUMsb0JBQW9CLEVBQUUsU0FBUyxDQUFDLEVBQUUsRUFBRTtZQUN4QyxJQUFJLG9CQUFvQixJQUFJLFNBQVMsQ0FBQyxzQkFBc0IsRUFBRTtnQkFDNUQsU0FBUyxDQUFDLHdCQUF3QixFQUFFLENBQUM7YUFDdEM7WUFDRCxPQUFPLG9CQUFvQixDQUFDO1FBQzlCLENBQUMsQ0FBQyxFQUNGLG9CQUFvQixFQUFFLEVBQ3RCLFlBQVksQ0FBQyxDQUFDLENBQUMsRUFDZixHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxZQUFZLEVBQUUsQ0FBQyxFQUNsQyxVQUFVLEVBQUUsQ0FDYixDQUFDO1FBRUYsSUFBSSxDQUFDLFdBQVcsR0FBRyxhQUFhLENBQUM7WUFDL0IsSUFBSSxDQUFDLHFCQUFxQjtZQUMxQixJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQzNCLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLEVBQzNCLEdBQUcsQ0FDRCxDQUFDLElBQWlELEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUNyRSxDQUNGO1NBQ0YsQ0FBQyxDQUFDLElBQUksQ0FDTCxHQUFHLENBQ0QsQ0FBQyxDQUFDLG9CQUFvQixFQUFFLGNBQWMsQ0FBQyxFQUFFLEVBQUUsQ0FDekMsb0JBQW9CLElBQUksY0FBYyxDQUN6QyxDQUNGLENBQUM7SUFDSixDQUFDOztrSEF4RFUscUJBQXFCO3NHQUFyQixxQkFBcUIsb0ZBQ2YsbUJBQW1CLGlFQUduQixnQ0FBZ0MsdUVBR3RDLFdBQVcscUxDL0N4Qiw0aUJBcUJBOzJGRG1CYSxxQkFBcUI7a0JBUmpDLFNBQVM7K0JBQ0Usa0JBQWtCLG1CQUdYLHVCQUF1QixDQUFDLE1BQU0saUJBQ2hDLGlCQUFpQixDQUFDLElBQUksdUJBQ2hCLEtBQUs7d0dBSTFCLFdBQVc7c0JBRFYsZUFBZTt1QkFBQyxtQkFBbUIsRUFBRSxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUU7Z0JBSTNELFdBQVc7c0JBRFYsZUFBZTt1QkFBQyxnQ0FBZ0M7Z0JBSWpELFFBQVE7c0JBRFAsU0FBUzt1QkFBQyxXQUFXLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFO2dCQUl4QyxpQkFBaUI7c0JBRGhCLFNBQVM7dUJBQUMsbUJBQW1CLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQWZ0ZXJDb250ZW50SW5pdCxcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENoYW5nZURldGVjdG9yUmVmLFxuICBDb21wb25lbnQsXG4gIENvbnRlbnRDaGlsZHJlbixcbiAgRWxlbWVudFJlZixcbiAgUXVlcnlMaXN0LFxuICBUZW1wbGF0ZVJlZixcbiAgVmlld0NoaWxkLFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBPYnNlcnZhYmxlLFxuICBSZXBsYXlTdWJqZWN0LFxuICBjb21iaW5lTGF0ZXN0LFxuICBvZixcbiAgZGVib3VuY2VUaW1lLFxuICBkaXN0aW5jdFVudGlsQ2hhbmdlZCxcbiAgbWFwLFxuICBzdGFydFdpdGgsXG4gIHN3aXRjaE1hcCxcbiAgdGFwLFxuICB3aXRoTGF0ZXN0RnJvbSxcbn0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IHB1Ymxpc2hSZWYgfSBmcm9tICcuLi91dGlscyc7XG5cbmltcG9ydCB7IEF1dG9jb21wbGV0ZVBsYWNlaG9sZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9hdXRvY29tcGxldGUtcGxhY2Vob2xkZXIuY29tcG9uZW50JztcbmltcG9ydCB7IEF1dG9Db21wbGV0ZURpcmVjdGl2ZSB9IGZyb20gJy4vYXV0b2NvbXBsZXRlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBTdWdnZXN0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi9zdWdnZXN0aW9uL3N1Z2dlc3Rpb24uY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXVpLWF1dG9jb21wbGV0ZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9hdXRvY29tcGxldGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9hdXRvY29tcGxldGUuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIHByZXNlcnZlV2hpdGVzcGFjZXM6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBBdXRvY29tcGxldGVDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlckNvbnRlbnRJbml0IHtcbiAgQENvbnRlbnRDaGlsZHJlbihTdWdnZXN0aW9uQ29tcG9uZW50LCB7IGRlc2NlbmRhbnRzOiB0cnVlIH0pXG4gIHN1Z2dlc3Rpb25zOiBRdWVyeUxpc3Q8U3VnZ2VzdGlvbkNvbXBvbmVudD47XG5cbiAgQENvbnRlbnRDaGlsZHJlbihBdXRvY29tcGxldGVQbGFjZWhvbGRlckNvbXBvbmVudClcbiAgcGxhY2Vob2xkZXI6IFF1ZXJ5TGlzdDxBdXRvY29tcGxldGVQbGFjZWhvbGRlckNvbXBvbmVudD47XG5cbiAgQFZpZXdDaGlsZChUZW1wbGF0ZVJlZiwgeyBzdGF0aWM6IHRydWUgfSlcbiAgdGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XG5cbiAgQFZpZXdDaGlsZCgnc3VnZ2VzdGlvbkxpc3RSZWYnLCB7IHN0YXRpYzogdHJ1ZSB9KVxuICBzdWdnZXN0aW9uTGlzdFJlZjogRWxlbWVudFJlZjtcblxuICBoYXNWaXNpYmxlU3VnZ2VzdGlvbiQ6IE9ic2VydmFibGU8Ym9vbGVhbj47XG4gIGhhc0NvbnRlbnQkOiBPYnNlcnZhYmxlPGJvb2xlYW4+O1xuXG4gIGRpcmVjdGl2ZSQkID0gbmV3IFJlcGxheVN1YmplY3Q8QXV0b0NvbXBsZXRlRGlyZWN0aXZlPigxKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHt9XG5cbiAgbmdBZnRlckNvbnRlbnRJbml0KCkge1xuICAgIHRoaXMuaGFzVmlzaWJsZVN1Z2dlc3Rpb24kID0gdGhpcy5zdWdnZXN0aW9ucy5jaGFuZ2VzLnBpcGUoXG4gICAgICBzdGFydFdpdGgodGhpcy5zdWdnZXN0aW9ucyksXG4gICAgICBzd2l0Y2hNYXAoKHN1Z2dlc3Rpb25zOiBRdWVyeUxpc3Q8U3VnZ2VzdGlvbkNvbXBvbmVudD4pID0+XG4gICAgICAgIHN1Z2dlc3Rpb25zLmxlbmd0aCA+IDBcbiAgICAgICAgICA/IGNvbWJpbmVMYXRlc3Qoc3VnZ2VzdGlvbnMubWFwKHN1Z2dlc3Rpb24gPT4gc3VnZ2VzdGlvbi52aXNpYmxlJCkpXG4gICAgICAgICAgOiBvZihbXSBhcyBib29sZWFuW10pLFxuICAgICAgKSxcbiAgICAgIG1hcCh2aXNpYmxlID0+IHZpc2libGUuc29tZShCb29sZWFuKSksXG4gICAgICB3aXRoTGF0ZXN0RnJvbSh0aGlzLmRpcmVjdGl2ZSQkKSxcbiAgICAgIG1hcCgoW2hhc1Zpc2libGVTdWdnZXN0aW9uLCBkaXJlY3RpdmVdKSA9PiB7XG4gICAgICAgIGlmIChoYXNWaXNpYmxlU3VnZ2VzdGlvbiAmJiBkaXJlY3RpdmUuZGVmYXVsdEZpcnN0U3VnZ2VzdGlvbikge1xuICAgICAgICAgIGRpcmVjdGl2ZS5hdXRvRm9jdXNGaXJzdFN1Z2dlc3Rpb24oKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gaGFzVmlzaWJsZVN1Z2dlc3Rpb247XG4gICAgICB9KSxcbiAgICAgIGRpc3RpbmN0VW50aWxDaGFuZ2VkKCksXG4gICAgICBkZWJvdW5jZVRpbWUoMCksXG4gICAgICB0YXAoKCkgPT4gdGhpcy5jZHIubWFya0ZvckNoZWNrKCkpLFxuICAgICAgcHVibGlzaFJlZigpLFxuICAgICk7XG5cbiAgICB0aGlzLmhhc0NvbnRlbnQkID0gY29tYmluZUxhdGVzdChbXG4gICAgICB0aGlzLmhhc1Zpc2libGVTdWdnZXN0aW9uJCxcbiAgICAgIHRoaXMucGxhY2Vob2xkZXIuY2hhbmdlcy5waXBlKFxuICAgICAgICBzdGFydFdpdGgodGhpcy5wbGFjZWhvbGRlciksXG4gICAgICAgIG1hcChcbiAgICAgICAgICAobGlzdDogUXVlcnlMaXN0PEF1dG9jb21wbGV0ZVBsYWNlaG9sZGVyQ29tcG9uZW50PikgPT4gISFsaXN0Lmxlbmd0aCxcbiAgICAgICAgKSxcbiAgICAgICksXG4gICAgXSkucGlwZShcbiAgICAgIG1hcChcbiAgICAgICAgKFtoYXNWaXNpYmxlU3VnZ2VzdGlvbiwgaGFzUGxhY2Vob2xkZXJdKSA9PlxuICAgICAgICAgIGhhc1Zpc2libGVTdWdnZXN0aW9uIHx8IGhhc1BsYWNlaG9sZGVyLFxuICAgICAgKSxcbiAgICApO1xuICB9XG59XG4iLCI8bmctdGVtcGxhdGUgbGV0LXdpZHRoPVwid2lkdGhcIj5cbiAgPGRpdlxuICAgIFtoaWRkZW5dPVwiIShoYXNDb250ZW50JCB8IGFzeW5jKVwiXG4gICAgY2xhc3M9XCJhdWktYXV0b2NvbXBsZXRlXCJcbiAgICBbc3R5bGUubWluV2lkdGhdPVwid2lkdGhcIlxuICAgIChtb3VzZWRvd24pPVwiJGV2ZW50LnByZXZlbnREZWZhdWx0KClcIlxuICA+XG4gICAgPGRpdlxuICAgICAgI3N1Z2dlc3Rpb25MaXN0UmVmXG4gICAgICBjbGFzcz1cImF1aS1hdXRvY29tcGxldGVfX2NvbnRlbnRcIlxuICAgID5cbiAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2XG4gICAgICBbaGlkZGVuXT1cImhhc1Zpc2libGVTdWdnZXN0aW9uJCB8IGFzeW5jXCJcbiAgICAgIGNsYXNzPVwiYXVpLWF1dG9jb21wbGV0ZV9fcGxhY2Vob2xkZXJcIlxuICAgID5cbiAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cImF1aS1hdXRvY29tcGxldGUtcGxhY2Vob2xkZXJcIj48L25nLWNvbnRlbnQ+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { Directive, EventEmitter, Host, Input, Optional, Output, } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject, Subject, fromEvent, merge } from 'rxjs';
|
|
3
|
-
import { takeUntil } from 'rxjs/operators';
|
|
2
|
+
import { BehaviorSubject, Subject, fromEvent, merge, takeUntil, debounceTime, } from 'rxjs';
|
|
4
3
|
import { BaseTooltip, TooltipTrigger, TooltipType } from '../tooltip';
|
|
5
4
|
import { scrollIntoView } from '../utils';
|
|
6
5
|
import * as i0 from "@angular/core";
|
|
@@ -69,7 +68,7 @@ export class AutoCompleteDirective extends BaseTooltip {
|
|
|
69
68
|
ngAfterViewInit() {
|
|
70
69
|
const input = this.input;
|
|
71
70
|
merge(fromEvent(this.elRef.nativeElement, 'click'), fromEvent(input, 'focus'))
|
|
72
|
-
.pipe(takeUntil(this.unsubscribe$))
|
|
71
|
+
.pipe(debounceTime(0), takeUntil(this.unsubscribe$))
|
|
73
72
|
.subscribe(() => this.onFocus());
|
|
74
73
|
fromEvent(input, 'blur')
|
|
75
74
|
.pipe(takeUntil(this.unsubscribe$))
|
|
@@ -273,4 +272,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
273
272
|
type: Input,
|
|
274
273
|
args: ['auiAutocompleteInnerSelector']
|
|
275
274
|
}] } });
|
|
276
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.directive.js","sourceRoot":"","sources":["../../../src/autocomplete/autocomplete.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay } from '@angular/cdk/overlay';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Host,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Renderer2,\n  ViewContainerRef,\n} from '@angular/core';\nimport { NgControl } from '@angular/forms';\nimport { BehaviorSubject, Observable, Subject, fromEvent, merge } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { BaseTooltip, TooltipTrigger, TooltipType } from '../tooltip';\nimport { scrollIntoView } from '../utils';\n\nimport { AutocompleteComponent } from './autocomplete.component';\nimport { AutoCompleteContext, SuggestionFilterFn } from './autocomplete.types';\nimport { SuggestionComponent } from './suggestion/suggestion.component';\n\n@Directive({\n  selector: 'input[auiAutocomplete],textarea[auiAutocomplete]',\n  exportAs: 'auiAutocomplete',\n  inputs: ['class:auiAutocompleteClass'],\n  host: {\n    autocomplete: 'off',\n  },\n})\nexport class AutoCompleteDirective\n  extends BaseTooltip<AutoCompleteContext>\n  implements OnInit, OnDestroy, AfterViewInit\n{\n  @Input('auiAutocomplete')\n  get autocomplete() {\n    return this._autocomplete;\n  }\n\n  set autocomplete(val) {\n    if (val === this._autocomplete) {\n      return;\n    }\n    val.directive$$.next(this);\n    this._autocomplete = val;\n    this.content = val.template;\n  }\n\n  @Input('auiAutocompleteFilterFn')\n  @Input()\n  get filterFn() {\n    return this._filterFn;\n  }\n\n  set filterFn(val) {\n    if (val !== this._filterFn) {\n      this._filterFn = val;\n      this.filterFn$$.next(val);\n    }\n  }\n\n  @Input('auiAutocompleteDefaultFirstSuggestion')\n  defaultFirstSuggestion = true;\n\n  @Input('auiAutocompleteTrigger')\n  suggestionTrigger: 'auto' | 'input' = 'auto';\n\n  declare innerSelector: string;\n\n  @Output('auiAutocompleteShow')\n  override show = new EventEmitter<void>();\n\n  @Output('auiAutocompleteHide')\n  override hide = new EventEmitter<void>();\n\n  @Output('auiAutocompleteSelected')\n  selected = new EventEmitter<string>();\n\n  private _autocomplete: AutocompleteComponent;\n  private focusedSuggestion: SuggestionComponent;\n\n  private readonly inputValue$$ = new BehaviorSubject<string>('');\n  private readonly filterFn$$ = new BehaviorSubject<SuggestionFilterFn>(\n    this.filterFn,\n  );\n\n  private readonly unsubscribe$ = new Subject<void>();\n\n  inputValue$: Observable<string> = this.inputValue$$.asObservable();\n  filterFn$: Observable<SuggestionFilterFn> = this.filterFn$$.asObservable();\n\n  get input(): HTMLInputElement {\n    const el = this.elRef.nativeElement;\n    return this.innerSelector ? el.querySelector(this.innerSelector) : el;\n  }\n\n  constructor(\n    overlay: Overlay,\n    viewContainerRef: ViewContainerRef,\n    elRef: ElementRef<HTMLInputElement>,\n    renderer: Renderer2,\n    cdr: ChangeDetectorRef,\n    ngZone: NgZone,\n    @Optional()\n    @Host()\n    private readonly ngControl: NgControl,\n  ) {\n    super(overlay, viewContainerRef, elRef, renderer, cdr, ngZone);\n    this.type = TooltipType.Plain;\n    this.trigger = TooltipTrigger.Manual;\n    this.position = 'bottom start';\n    this.hideOnClick = true;\n  }\n\n  ngOnInit() {\n    this.show.subscribe(() => {\n      this.updateSuggestionsContext();\n    });\n    this.hide.subscribe(() => {\n      this.resetFocusedSuggestion();\n    });\n\n    if (this.ngControl) {\n      this.ngControl.valueChanges\n        .pipe(takeUntil(this.unsubscribe$))\n        .subscribe((value: string | string[]) => {\n          if (!Array.isArray(value)) {\n            this.inputValue$$.next(value);\n          }\n        });\n    }\n  }\n\n  override ngAfterViewInit() {\n    const input = this.input;\n\n    merge(\n      fromEvent(this.elRef.nativeElement, 'click'),\n      fromEvent(input, 'focus'),\n    )\n      .pipe(takeUntil(this.unsubscribe$))\n      .subscribe(() => this.onFocus());\n\n    fromEvent(input, 'blur')\n      .pipe(takeUntil(this.unsubscribe$))\n      .subscribe(() => this.onBlur());\n\n    fromEvent(input, 'input')\n      .pipe(takeUntil(this.unsubscribe$))\n      .subscribe(ev => this.onInput(ev));\n\n    fromEvent<KeyboardEvent>(input, 'keydown')\n      .pipe(takeUntil(this.unsubscribe$))\n      .subscribe(ev => this.onKeyDown(ev));\n  }\n\n  override ngOnDestroy() {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n  }\n\n  override onFocus() {\n    if (this.suggestionTrigger === 'auto') {\n      super.onFocus();\n    }\n  }\n\n  onInput(event: Event) {\n    const value = (event.target as HTMLInputElement).value;\n    this.inputValue$$.next(value);\n    this.createTooltip();\n  }\n\n  onKeyDown(event: KeyboardEvent) {\n    switch (event.key) {\n      case 'ArrowDown':\n        this.focusSuggestionDir('down');\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n      case 'ArrowUp':\n        this.focusSuggestionDir('up');\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n      case 'Enter':\n        if (this.focusedSuggestion) {\n          this.selectFocusedOption();\n          event.stopPropagation();\n          event.preventDefault();\n        }\n        break;\n      case 'Escape':\n        this.disposeTooltip();\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n    }\n  }\n\n  updateSuggestionsContext() {\n    this.context = {\n      ...this.context,\n      width: this.elRef.nativeElement.offsetWidth + 'px',\n    };\n  }\n\n  onSuggestionClick(value: string) {\n    let isArrCtrl = false;\n\n    if (this.ngControl) {\n      const { control } = this.ngControl;\n      isArrCtrl = Array.isArray(control.value);\n      control.patchValue(isArrCtrl ? [...control.value, value] : value);\n    } else {\n      this.input.value = value;\n    }\n\n    this.inputValue$$.next(isArrCtrl ? '' : value);\n\n    this.selected.emit(value);\n    this.disposeTooltip();\n  }\n\n  override createTooltip() {\n    super.createTooltip();\n    this.autoFocusFirstSuggestion();\n  }\n\n  private autoFocusFirstSuggestion() {\n    const focusedSuggestion = this.autocomplete.suggestions.find(\n      suggestion => suggestion.focused,\n    );\n    if (focusedSuggestion) {\n      return;\n    }\n    const selectedSuggestion = this.autocomplete.suggestions.find(\n      suggestion => suggestion.selected,\n    );\n    if (selectedSuggestion) {\n      this.resetFocusedSuggestion(selectedSuggestion);\n      requestAnimationFrame(() => {\n        this.scrollToSuggestion(selectedSuggestion);\n      });\n    } else if (this.defaultFirstSuggestion) {\n      const firstFocusableSuggestion = this.autocomplete.suggestions.find(\n        suggestion => suggestion.visible && !suggestion.disabled,\n      );\n      this.resetFocusedSuggestion(firstFocusableSuggestion);\n      if (firstFocusableSuggestion) {\n        requestAnimationFrame(() => {\n          this.scrollToSuggestion(firstFocusableSuggestion);\n        });\n      }\n    }\n  }\n\n  private focusSuggestionDir(dir: 'down' | 'up') {\n    if (!this.isCreated) {\n      this.createTooltip();\n      return;\n    }\n    const visibleSuggestions = this.autocomplete.suggestions.filter(\n      suggestion => suggestion.visible && !suggestion.disabled,\n    );\n    if (visibleSuggestions.length === 0) {\n      return;\n    }\n    const step = dir === 'down' ? 1 : -1;\n    let i = visibleSuggestions.indexOf(this.focusedSuggestion);\n    i = i + step;\n    if (i >= visibleSuggestions.length) {\n      i = 0;\n    } else if (i < 0) {\n      i = visibleSuggestions.length - 1;\n    }\n    this.resetFocusedSuggestion(visibleSuggestions[i]);\n    this.scrollToSuggestion(this.focusedSuggestion);\n  }\n\n  private resetFocusedSuggestion(\n    focusedSuggestion: SuggestionComponent = null,\n  ) {\n    if (this.focusedSuggestion) {\n      this.focusedSuggestion.blur();\n    }\n    this.focusedSuggestion = focusedSuggestion;\n    if (this.focusedSuggestion) {\n      this.focusedSuggestion.focus();\n    }\n  }\n\n  private scrollToSuggestion(suggestion: SuggestionComponent) {\n    if (this.autocomplete.suggestionListRef) {\n      scrollIntoView(\n        this.autocomplete.suggestionListRef.nativeElement,\n        suggestion.elRef.nativeElement,\n      );\n    }\n  }\n\n  protected selectFocusedOption() {\n    if (this.focusedSuggestion) {\n      this.onSuggestionClick(this.focusedSuggestion.value);\n    }\n  }\n\n  private _filterFn(inputValue: string, suggestion: string) {\n    return suggestion?.toLowerCase().includes(inputValue?.toLowerCase() ?? '');\n  }\n}\n\n@Directive({\n  selector: '[auiAutocomplete]:not(input):not(textarea)',\n  exportAs: 'auiAutocomplete',\n  inputs: ['class:auiAutocompleteClass'],\n  host: {\n    autocomplete: 'off',\n  },\n})\nexport class CustomAutoCompleteDirective extends AutoCompleteDirective {\n  @Input('auiAutocompleteInnerSelector')\n  override innerSelector = 'input,textarea';\n}\n"]}
|
|
275
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.directive.js","sourceRoot":"","sources":["../../../src/autocomplete/autocomplete.directive.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,SAAS,EAET,YAAY,EACZ,IAAI,EACJ,KAAK,EAIL,QAAQ,EACR,MAAM,GAGP,MAAM,eAAe,CAAC;AAEvB,OAAO,EACL,eAAe,EAEf,OAAO,EACP,SAAS,EACT,KAAK,EACL,SAAS,EACT,YAAY,GACb,MAAM,MAAM,CAAC;AAEd,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACtE,OAAO,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;;;;AAc1C,MAAM,OAAO,qBACX,SAAQ,WAAgC;IAiExC,YACE,OAAgB,EAChB,gBAAkC,EAClC,KAAmC,EACnC,QAAmB,EACnB,GAAsB,EACtB,MAAc,EAGG,SAAoB;QAErC,KAAK,CAAC,OAAO,EAAE,gBAAgB,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;QAF9C,cAAS,GAAT,SAAS,CAAW;QA3CvC,2BAAsB,GAAG,IAAI,CAAC;QAG9B,sBAAiB,GAAqB,MAAM,CAAC;QAKpC,SAAI,GAAG,IAAI,YAAY,EAAQ,CAAC;QAGhC,SAAI,GAAG,IAAI,YAAY,EAAQ,CAAC;QAGzC,aAAQ,GAAG,IAAI,YAAY,EAAU,CAAC;QAKrB,iBAAY,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;QAC/C,eAAU,GAAG,IAAI,eAAe,CAC/C,IAAI,CAAC,QAAQ,CACd,CAAC;QAEe,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QAEpD,gBAAW,GAAuB,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC;QACnE,cAAS,GAAmC,IAAI,CAAC,UAAU,CAAC,YAAY,EAAE,CAAC;QAmBzE,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC,KAAK,CAAC;QAC9B,IAAI,CAAC,OAAO,GAAG,cAAc,CAAC,MAAM,CAAC;QACrC,IAAI,CAAC,QAAQ,GAAG,cAAc,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IA9ED,IACI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED,IAAI,YAAY,CAAC,GAAG;QAClB,IAAI,GAAG,KAAK,IAAI,CAAC,aAAa,EAAE;YAC9B,OAAO;SACR;QACD,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC;QACzB,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC,QAAQ,CAAC;IAC9B,CAAC;IAED,IAEI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAI,QAAQ,CAAC,GAAG;QACd,IAAI,GAAG,KAAK,IAAI,CAAC,SAAS,EAAE;YAC1B,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;YACrB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SAC3B;IACH,CAAC;IAgCD,IAAI,KAAK;QACP,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC;QACpC,OAAO,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACxE,CAAC;IAoBD,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE;YACvB,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAClC,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE;YACvB,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAChC,CAAC,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,SAAS,CAAC,YAAY;iBACxB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;iBAClC,SAAS,CAAC,CAAC,KAAwB,EAAE,EAAE;gBACtC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;oBACzB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBAC/B;YACH,CAAC,CAAC,CAAC;SACN;IACH,CAAC;IAEQ,eAAe;QACtB,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QAEzB,KAAK,CACH,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,OAAO,CAAC,EAC5C,SAAS,CAAC,KAAK,EAAE,OAAO,CAAC,CAC1B;aACE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aACnD,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QAEnC,SAAS,CAAC,KAAK,EAAE,MAAM,CAAC;aACrB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aAClC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QAElC,SAAS,CAAC,KAAK,EAAE,OAAO,CAAC;aACtB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aAClC,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;QAErC,SAAS,CAAgB,KAAK,EAAE,SAAS,CAAC;aACvC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aAClC,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;IACzC,CAAC;IAEQ,WAAW;QAClB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QACzB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAEQ,OAAO;QACd,IAAI,IAAI,CAAC,iBAAiB,KAAK,MAAM,EAAE;YACrC,KAAK,CAAC,OAAO,EAAE,CAAC;SACjB;IACH,CAAC;IAED,OAAO,CAAC,KAAY;QAClB,MAAM,KAAK,GAAI,KAAK,CAAC,MAA2B,CAAC,KAAK,CAAC;QACvD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC9B,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,SAAS,CAAC,KAAoB;QAC5B,QAAQ,KAAK,CAAC,GAAG,EAAE;YACjB,KAAK,WAAW;gBACd,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;gBAChC,KAAK,CAAC,eAAe,EAAE,CAAC;gBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;YACR,KAAK,SAAS;gBACZ,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;gBAC9B,KAAK,CAAC,eAAe,EAAE,CAAC;gBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;YACR,KAAK,OAAO;gBACV,IAAI,IAAI,CAAC,iBAAiB,EAAE;oBAC1B,IAAI,CAAC,mBAAmB,EAAE,CAAC;oBAC3B,KAAK,CAAC,eAAe,EAAE,CAAC;oBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;iBACxB;gBACD,MAAM;YACR,KAAK,QAAQ;gBACX,IAAI,CAAC,cAAc,EAAE,CAAC;gBACtB,KAAK,CAAC,eAAe,EAAE,CAAC;gBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;SACT;IACH,CAAC;IAED,wBAAwB;QACtB,IAAI,CAAC,OAAO,GAAG;YACb,GAAG,IAAI,CAAC,OAAO;YACf,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,GAAG,IAAI;SACnD,CAAC;IACJ,CAAC;IAED,iBAAiB,CAAC,KAAa;QAC7B,IAAI,SAAS,GAAG,KAAK,CAAC;QAEtB,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,MAAM,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC;YACnC,SAAS,GAAG,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YACzC,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;SACnE;aAAM;YACL,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;SAC1B;QAED,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QAE/C,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEQ,aAAa;QACpB,KAAK,CAAC,aAAa,EAAE,CAAC;QACtB,IAAI,CAAC,wBAAwB,EAAE,CAAC;IAClC,CAAC;IAED,wBAAwB;QACtB,MAAM,iBAAiB,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CAC1D,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,CACjC,CAAC;QACF,IAAI,iBAAiB,EAAE;YACrB,OAAO;SACR;QACD,MAAM,kBAAkB,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CAC3D,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,CAClC,CAAC;QACF,IAAI,kBAAkB,EAAE;YACtB,IAAI,CAAC,sBAAsB,CAAC,kBAAkB,CAAC,CAAC;YAChD,qBAAqB,CAAC,GAAG,EAAE;gBACzB,IAAI,CAAC,kBAAkB,CAAC,kBAAkB,CAAC,CAAC;YAC9C,CAAC,CAAC,CAAC;SACJ;aAAM,IAAI,IAAI,CAAC,sBAAsB,EAAE;YACtC,MAAM,wBAAwB,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CACjE,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,IAAI,CAAC,UAAU,CAAC,QAAQ,CACzD,CAAC;YACF,IAAI,CAAC,sBAAsB,CAAC,wBAAwB,CAAC,CAAC;YACtD,IAAI,wBAAwB,EAAE;gBAC5B,qBAAqB,CAAC,GAAG,EAAE;oBACzB,IAAI,CAAC,kBAAkB,CAAC,wBAAwB,CAAC,CAAC;gBACpD,CAAC,CAAC,CAAC;aACJ;SACF;IACH,CAAC;IAEO,kBAAkB,CAAC,GAAkB;QAC3C,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,OAAO;SACR;QACD,MAAM,kBAAkB,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,MAAM,CAC7D,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,IAAI,CAAC,UAAU,CAAC,QAAQ,CACzD,CAAC;QACF,IAAI,kBAAkB,CAAC,MAAM,KAAK,CAAC,EAAE;YACnC,OAAO;SACR;QACD,MAAM,IAAI,GAAG,GAAG,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACrC,IAAI,CAAC,GAAG,kBAAkB,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC3D,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;QACb,IAAI,CAAC,IAAI,kBAAkB,CAAC,MAAM,EAAE;YAClC,CAAC,GAAG,CAAC,CAAC;SACP;aAAM,IAAI,CAAC,GAAG,CAAC,EAAE;YAChB,CAAC,GAAG,kBAAkB,CAAC,MAAM,GAAG,CAAC,CAAC;SACnC;QACD,IAAI,CAAC,sBAAsB,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC;QACnD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAClD,CAAC;IAEO,sBAAsB,CAC5B,oBAAyC,IAAI;QAE7C,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;SAC/B;QACD,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;QAC3C,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC;SAChC;IACH,CAAC;IAEO,kBAAkB,CAAC,UAA+B;QACxD,IAAI,IAAI,CAAC,YAAY,CAAC,iBAAiB,EAAE;YACvC,cAAc,CACZ,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,aAAa,EACjD,UAAU,CAAC,KAAK,CAAC,aAAa,CAC/B,CAAC;SACH;IACH,CAAC;IAES,mBAAmB;QAC3B,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;SACtD;IACH,CAAC;IAEO,SAAS,CAAC,UAAkB,EAAE,UAAkB;QACtD,OAAO,UAAU,EAAE,WAAW,EAAE,CAAC,QAAQ,CAAC,UAAU,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC;IAC7E,CAAC;;kHAvRU,qBAAqB;sGAArB,qBAAqB;2FAArB,qBAAqB;kBARjC,SAAS;mBAAC;oBACT,QAAQ,EAAE,kDAAkD;oBAC5D,QAAQ,EAAE,iBAAiB;oBAC3B,MAAM,EAAE,CAAC,4BAA4B,CAAC;oBACtC,IAAI,EAAE;wBACJ,YAAY,EAAE,KAAK;qBACpB;iBACF;;0BA0EI,QAAQ;;0BACR,IAAI;4CArEH,YAAY;sBADf,KAAK;uBAAC,iBAAiB;gBAgBpB,QAAQ;sBAFX,KAAK;uBAAC,yBAAyB;;sBAC/B,KAAK;gBAaN,sBAAsB;sBADrB,KAAK;uBAAC,uCAAuC;gBAI9C,iBAAiB;sBADhB,KAAK;uBAAC,wBAAwB;gBAMtB,IAAI;sBADZ,MAAM;uBAAC,qBAAqB;gBAIpB,IAAI;sBADZ,MAAM;uBAAC,qBAAqB;gBAI7B,QAAQ;sBADP,MAAM;uBAAC,yBAAyB;;AAqPnC,MAAM,OAAO,2BAA4B,SAAQ,qBAAqB;IARtE;;QAUW,kBAAa,GAAG,gBAAgB,CAAC;KAC3C;;wHAHY,2BAA2B;4GAA3B,2BAA2B;2FAA3B,2BAA2B;kBARvC,SAAS;mBAAC;oBACT,QAAQ,EAAE,4CAA4C;oBACtD,QAAQ,EAAE,iBAAiB;oBAC3B,MAAM,EAAE,CAAC,4BAA4B,CAAC;oBACtC,IAAI,EAAE;wBACJ,YAAY,EAAE,KAAK;qBACpB;iBACF;8BAGU,aAAa;sBADrB,KAAK;uBAAC,8BAA8B","sourcesContent":["import { Overlay } from '@angular/cdk/overlay';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Host,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Renderer2,\n  ViewContainerRef,\n} from '@angular/core';\nimport { NgControl } from '@angular/forms';\nimport {\n  BehaviorSubject,\n  Observable,\n  Subject,\n  fromEvent,\n  merge,\n  takeUntil,\n  debounceTime,\n} from 'rxjs';\n\nimport { BaseTooltip, TooltipTrigger, TooltipType } from '../tooltip';\nimport { scrollIntoView } from '../utils';\n\nimport { AutocompleteComponent } from './autocomplete.component';\nimport { AutoCompleteContext, SuggestionFilterFn } from './autocomplete.types';\nimport { SuggestionComponent } from './suggestion/suggestion.component';\n\n@Directive({\n  selector: 'input[auiAutocomplete],textarea[auiAutocomplete]',\n  exportAs: 'auiAutocomplete',\n  inputs: ['class:auiAutocompleteClass'],\n  host: {\n    autocomplete: 'off',\n  },\n})\nexport class AutoCompleteDirective\n  extends BaseTooltip<AutoCompleteContext>\n  implements OnInit, OnDestroy, AfterViewInit\n{\n  @Input('auiAutocomplete')\n  get autocomplete() {\n    return this._autocomplete;\n  }\n\n  set autocomplete(val) {\n    if (val === this._autocomplete) {\n      return;\n    }\n    val.directive$$.next(this);\n    this._autocomplete = val;\n    this.content = val.template;\n  }\n\n  @Input('auiAutocompleteFilterFn')\n  @Input()\n  get filterFn() {\n    return this._filterFn;\n  }\n\n  set filterFn(val) {\n    if (val !== this._filterFn) {\n      this._filterFn = val;\n      this.filterFn$$.next(val);\n    }\n  }\n\n  @Input('auiAutocompleteDefaultFirstSuggestion')\n  defaultFirstSuggestion = true;\n\n  @Input('auiAutocompleteTrigger')\n  suggestionTrigger: 'auto' | 'input' = 'auto';\n\n  declare innerSelector: string;\n\n  @Output('auiAutocompleteShow')\n  override show = new EventEmitter<void>();\n\n  @Output('auiAutocompleteHide')\n  override hide = new EventEmitter<void>();\n\n  @Output('auiAutocompleteSelected')\n  selected = new EventEmitter<string>();\n\n  private _autocomplete: AutocompleteComponent;\n  private focusedSuggestion: SuggestionComponent;\n\n  private readonly inputValue$$ = new BehaviorSubject<string>('');\n  private readonly filterFn$$ = new BehaviorSubject<SuggestionFilterFn>(\n    this.filterFn,\n  );\n\n  private readonly unsubscribe$ = new Subject<void>();\n\n  inputValue$: Observable<string> = this.inputValue$$.asObservable();\n  filterFn$: Observable<SuggestionFilterFn> = this.filterFn$$.asObservable();\n\n  get input(): HTMLInputElement {\n    const el = this.elRef.nativeElement;\n    return this.innerSelector ? el.querySelector(this.innerSelector) : el;\n  }\n\n  constructor(\n    overlay: Overlay,\n    viewContainerRef: ViewContainerRef,\n    elRef: ElementRef<HTMLInputElement>,\n    renderer: Renderer2,\n    cdr: ChangeDetectorRef,\n    ngZone: NgZone,\n    @Optional()\n    @Host()\n    private readonly ngControl: NgControl,\n  ) {\n    super(overlay, viewContainerRef, elRef, renderer, cdr, ngZone);\n    this.type = TooltipType.Plain;\n    this.trigger = TooltipTrigger.Manual;\n    this.position = 'bottom start';\n    this.hideOnClick = true;\n  }\n\n  ngOnInit() {\n    this.show.subscribe(() => {\n      this.updateSuggestionsContext();\n    });\n    this.hide.subscribe(() => {\n      this.resetFocusedSuggestion();\n    });\n\n    if (this.ngControl) {\n      this.ngControl.valueChanges\n        .pipe(takeUntil(this.unsubscribe$))\n        .subscribe((value: string | string[]) => {\n          if (!Array.isArray(value)) {\n            this.inputValue$$.next(value);\n          }\n        });\n    }\n  }\n\n  override ngAfterViewInit() {\n    const input = this.input;\n\n    merge(\n      fromEvent(this.elRef.nativeElement, 'click'),\n      fromEvent(input, 'focus'),\n    )\n      .pipe(debounceTime(0), takeUntil(this.unsubscribe$))\n      .subscribe(() => this.onFocus());\n\n    fromEvent(input, 'blur')\n      .pipe(takeUntil(this.unsubscribe$))\n      .subscribe(() => this.onBlur());\n\n    fromEvent(input, 'input')\n      .pipe(takeUntil(this.unsubscribe$))\n      .subscribe(ev => this.onInput(ev));\n\n    fromEvent<KeyboardEvent>(input, 'keydown')\n      .pipe(takeUntil(this.unsubscribe$))\n      .subscribe(ev => this.onKeyDown(ev));\n  }\n\n  override ngOnDestroy() {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n  }\n\n  override onFocus() {\n    if (this.suggestionTrigger === 'auto') {\n      super.onFocus();\n    }\n  }\n\n  onInput(event: Event) {\n    const value = (event.target as HTMLInputElement).value;\n    this.inputValue$$.next(value);\n    this.createTooltip();\n  }\n\n  onKeyDown(event: KeyboardEvent) {\n    switch (event.key) {\n      case 'ArrowDown':\n        this.focusSuggestionDir('down');\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n      case 'ArrowUp':\n        this.focusSuggestionDir('up');\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n      case 'Enter':\n        if (this.focusedSuggestion) {\n          this.selectFocusedOption();\n          event.stopPropagation();\n          event.preventDefault();\n        }\n        break;\n      case 'Escape':\n        this.disposeTooltip();\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n    }\n  }\n\n  updateSuggestionsContext() {\n    this.context = {\n      ...this.context,\n      width: this.elRef.nativeElement.offsetWidth + 'px',\n    };\n  }\n\n  onSuggestionClick(value: string) {\n    let isArrCtrl = false;\n\n    if (this.ngControl) {\n      const { control } = this.ngControl;\n      isArrCtrl = Array.isArray(control.value);\n      control.patchValue(isArrCtrl ? [...control.value, value] : value);\n    } else {\n      this.input.value = value;\n    }\n\n    this.inputValue$$.next(isArrCtrl ? '' : value);\n\n    this.selected.emit(value);\n    this.disposeTooltip();\n  }\n\n  override createTooltip() {\n    super.createTooltip();\n    this.autoFocusFirstSuggestion();\n  }\n\n  autoFocusFirstSuggestion() {\n    const focusedSuggestion = this.autocomplete.suggestions.find(\n      suggestion => suggestion.focused,\n    );\n    if (focusedSuggestion) {\n      return;\n    }\n    const selectedSuggestion = this.autocomplete.suggestions.find(\n      suggestion => suggestion.selected,\n    );\n    if (selectedSuggestion) {\n      this.resetFocusedSuggestion(selectedSuggestion);\n      requestAnimationFrame(() => {\n        this.scrollToSuggestion(selectedSuggestion);\n      });\n    } else if (this.defaultFirstSuggestion) {\n      const firstFocusableSuggestion = this.autocomplete.suggestions.find(\n        suggestion => suggestion.visible && !suggestion.disabled,\n      );\n      this.resetFocusedSuggestion(firstFocusableSuggestion);\n      if (firstFocusableSuggestion) {\n        requestAnimationFrame(() => {\n          this.scrollToSuggestion(firstFocusableSuggestion);\n        });\n      }\n    }\n  }\n\n  private focusSuggestionDir(dir: 'down' | 'up') {\n    if (!this.isCreated) {\n      this.createTooltip();\n      return;\n    }\n    const visibleSuggestions = this.autocomplete.suggestions.filter(\n      suggestion => suggestion.visible && !suggestion.disabled,\n    );\n    if (visibleSuggestions.length === 0) {\n      return;\n    }\n    const step = dir === 'down' ? 1 : -1;\n    let i = visibleSuggestions.indexOf(this.focusedSuggestion);\n    i = i + step;\n    if (i >= visibleSuggestions.length) {\n      i = 0;\n    } else if (i < 0) {\n      i = visibleSuggestions.length - 1;\n    }\n    this.resetFocusedSuggestion(visibleSuggestions[i]);\n    this.scrollToSuggestion(this.focusedSuggestion);\n  }\n\n  private resetFocusedSuggestion(\n    focusedSuggestion: SuggestionComponent = null,\n  ) {\n    if (this.focusedSuggestion) {\n      this.focusedSuggestion.blur();\n    }\n    this.focusedSuggestion = focusedSuggestion;\n    if (this.focusedSuggestion) {\n      this.focusedSuggestion.focus();\n    }\n  }\n\n  private scrollToSuggestion(suggestion: SuggestionComponent) {\n    if (this.autocomplete.suggestionListRef) {\n      scrollIntoView(\n        this.autocomplete.suggestionListRef.nativeElement,\n        suggestion.elRef.nativeElement,\n      );\n    }\n  }\n\n  protected selectFocusedOption() {\n    if (this.focusedSuggestion) {\n      this.onSuggestionClick(this.focusedSuggestion.value);\n    }\n  }\n\n  private _filterFn(inputValue: string, suggestion: string) {\n    return suggestion?.toLowerCase().includes(inputValue?.toLowerCase() ?? '');\n  }\n}\n\n@Directive({\n  selector: '[auiAutocomplete]:not(input):not(textarea)',\n  exportAs: 'auiAutocomplete',\n  inputs: ['class:auiAutocompleteClass'],\n  host: {\n    autocomplete: 'off',\n  },\n})\nexport class CustomAutoCompleteDirective extends AutoCompleteDirective {\n  @Input('auiAutocompleteInnerSelector')\n  override innerSelector = 'input,textarea';\n}\n"]}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, Inject, Input, ViewChild, ViewEncapsulation, forwardRef, } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject, combineLatest } from 'rxjs';
|
|
3
|
-
import {
|
|
4
|
-
import { buildBem, coerceAttrBoolean } from '../../utils';
|
|
2
|
+
import { BehaviorSubject, combineLatest, map, switchMap, take, tap, } from 'rxjs';
|
|
3
|
+
import { buildBem, coerceAttrBoolean, publishRef } from '../../utils';
|
|
5
4
|
import { AutocompleteComponent } from '../autocomplete.component';
|
|
6
5
|
import * as i0 from "@angular/core";
|
|
7
6
|
import * as i1 from "@angular/common";
|
|
@@ -20,14 +19,14 @@ export class SuggestionComponent {
|
|
|
20
19
|
this.value$$,
|
|
21
20
|
]).pipe(map(([inputValue, selfValue]) => inputValue === selfValue), tap(selected => {
|
|
22
21
|
this.selected = selected;
|
|
23
|
-
}),
|
|
22
|
+
}), publishRef());
|
|
24
23
|
this.visible$ = combineLatest([
|
|
25
24
|
this.autocomplete.directive$$.pipe(switchMap(directive => directive.filterFn$)),
|
|
26
25
|
this.autocomplete.directive$$.pipe(switchMap(directive => directive.inputValue$)),
|
|
27
26
|
this.value$$,
|
|
28
27
|
]).pipe(map(([filterFn, filterString, suggestion]) => filterFn(filterString, suggestion)), tap(visible => {
|
|
29
28
|
this.visible = visible;
|
|
30
|
-
}),
|
|
29
|
+
}), publishRef());
|
|
31
30
|
}
|
|
32
31
|
get value() {
|
|
33
32
|
return this._value;
|
|
@@ -75,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
75
74
|
type: ViewChild,
|
|
76
75
|
args: ['elRef', { static: true }]
|
|
77
76
|
}] } });
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"suggestion.component.js","sourceRoot":"","sources":["../../../../src/autocomplete/suggestion/suggestion.component.ts","../../../../src/autocomplete/suggestion/suggestion.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport {\n  BehaviorSubject,\n  Observable,\n  combineLatest,\n  map,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\n\nimport { Bem, buildBem, coerceAttrBoolean, publishRef } from '../../utils';\nimport { AutocompleteComponent } from '../autocomplete.component';\n\n@Component({\n  selector: 'aui-suggestion',\n  templateUrl: './suggestion.component.html',\n  styleUrls: ['./suggestion.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n})\nexport class SuggestionComponent {\n  bem: Bem = buildBem('aui-suggestion');\n\n  private _disabled = false;\n  private _value: string;\n  private readonly value$$ = new BehaviorSubject<string>(this.value);\n\n  @Input()\n  get value() {\n    return this._value;\n  }\n\n  set value(val) {\n    this._value = val;\n    this.value$$.next(val);\n  }\n\n  @Input()\n  get disabled() {\n    return this._disabled;\n  }\n\n  set disabled(val: boolean | '') {\n    this._disabled = coerceAttrBoolean(val);\n  }\n\n  @ViewChild('elRef', { static: true })\n  elRef: ElementRef;\n\n  selected = false;\n  visible = true;\n  focused = false;\n\n  private readonly autocomplete: AutocompleteComponent;\n  selected$: Observable<boolean>;\n  visible$: Observable<boolean>;\n\n  constructor(\n    private readonly cdr: ChangeDetectorRef,\n    @Inject(forwardRef(() => AutocompleteComponent))\n    autocomplete: any, // FIXME: workaround temporarily\n  ) {\n    this.autocomplete = autocomplete;\n    this.selected$ = combineLatest([\n      this.autocomplete.directive$$.pipe(\n        switchMap(directive => directive.inputValue$),\n      ),\n      this.value$$,\n    ]).pipe(\n      map(([inputValue, selfValue]) => inputValue === selfValue),\n      tap(selected => {\n        this.selected = selected;\n      }),\n      publishRef(),\n    );\n    this.visible$ = combineLatest([\n      this.autocomplete.directive$$.pipe(\n        switchMap(directive => directive.filterFn$),\n      ),\n      this.autocomplete.directive$$.pipe(\n        switchMap(directive => directive.inputValue$),\n      ),\n      this.value$$,\n    ]).pipe(\n      map(([filterFn, filterString, suggestion]) =>\n        filterFn(filterString, suggestion),\n      ),\n      tap(visible => {\n        this.visible = visible;\n      }),\n      publishRef(),\n    );\n  }\n\n  onClick() {\n    if (this.disabled) {\n      return;\n    }\n    this.autocomplete.directive$$.pipe(take(1)).subscribe(directive => {\n      directive.onSuggestionClick(this.value);\n    });\n  }\n\n  focus() {\n    this.focused = true;\n    this.cdr.markForCheck();\n  }\n\n  blur() {\n    this.focused = false;\n    this.cdr.markForCheck();\n  }\n}\n","<div\n  #elRef\n  [hidden]=\"!(visible$ | async)\"\n  [class]=\"bem.block('medium')\"\n  [class.isDisabled]=\"disabled\"\n  [class.isSelected]=\"selected$ | async\"\n  [class.isFocused]=\"focused\"\n  (click)=\"onClick()\"\n>\n  <ng-content></ng-content>\n</div>\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, ContentChildren, ViewEncapsulation, forwardRef, } from '@angular/core';
|
|
2
|
-
import { combineLatest, of } from 'rxjs';
|
|
3
|
-
import {
|
|
2
|
+
import { combineLatest, of, map, startWith, switchMap } from 'rxjs';
|
|
3
|
+
import { publishRef } from '../../utils';
|
|
4
4
|
import { SuggestionComponent } from '../suggestion/suggestion.component';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/common";
|
|
@@ -8,7 +8,7 @@ export class SuggestionGroupComponent {
|
|
|
8
8
|
ngAfterContentInit() {
|
|
9
9
|
this.hasVisibleSuggestion$ = this.suggestions.changes.pipe(startWith(this.suggestions), switchMap((options) => options.length > 0
|
|
10
10
|
? combineLatest(options.map(node => node.visible$))
|
|
11
|
-
: of([false])), map(visible => visible.some(Boolean)),
|
|
11
|
+
: of([false])), map(visible => visible.some(Boolean)), publishRef());
|
|
12
12
|
}
|
|
13
13
|
}
|
|
14
14
|
SuggestionGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SuggestionGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -20,4 +20,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
20
20
|
type: ContentChildren,
|
|
21
21
|
args: [forwardRef(() => SuggestionComponent)]
|
|
22
22
|
}] } });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VnZ2VzdGlvbi1ncm91cC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXV0b2NvbXBsZXRlL3N1Z2dlc3Rpb24tZ3JvdXAvc3VnZ2VzdGlvbi1ncm91cC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvYXV0b2NvbXBsZXRlL3N1Z2dlc3Rpb24tZ3JvdXAvc3VnZ2VzdGlvbi1ncm91cC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxlQUFlLEVBRWYsaUJBQWlCLEVBQ2pCLFVBQVUsR0FDWCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQWMsYUFBYSxFQUFFLEVBQUUsRUFBRSxHQUFHLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUVoRixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDOzs7QUFVekUsTUFBTSxPQUFPLHdCQUF3QjtJQU1uQyxrQkFBa0I7UUFDaEIsSUFBSSxDQUFDLHFCQUFxQixHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLElBQUksQ0FDeEQsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsRUFDM0IsU0FBUyxDQUFDLENBQUMsT0FBdUMsRUFBRSxFQUFFLENBQ3BELE9BQU8sQ0FBQyxNQUFNLEdBQUcsQ0FBQztZQUNoQixDQUFDLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDbkQsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQ2hCLEVBQ0QsR0FBRyxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxFQUNyQyxVQUFVLEVBQUUsQ0FDYixDQUFDO0lBQ0osQ0FBQzs7cUhBakJVLHdCQUF3Qjt5R0FBeEIsd0JBQXdCLDJIQUNELG1CQUFtQixpQ0N2QnZELHdQQU9BOzJGRGVhLHdCQUF3QjtrQkFScEMsU0FBUzsrQkFDRSxzQkFBc0IsbUJBR2YsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSx1QkFDaEIsS0FBSzs4QkFJMUIsV0FBVztzQkFEVixlQUFlO3VCQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFmdGVyQ29udGVudEluaXQsXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIENvbnRlbnRDaGlsZHJlbixcbiAgUXVlcnlMaXN0LFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbiAgZm9yd2FyZFJlZixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBjb21iaW5lTGF0ZXN0LCBvZiwgbWFwLCBzdGFydFdpdGgsIHN3aXRjaE1hcCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBwdWJsaXNoUmVmIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgU3VnZ2VzdGlvbkNvbXBvbmVudCB9IGZyb20gJy4uL3N1Z2dlc3Rpb24vc3VnZ2VzdGlvbi5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhdWktc3VnZ2VzdGlvbi1ncm91cCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9zdWdnZXN0aW9uLWdyb3VwLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vc3VnZ2VzdGlvbi1ncm91cC5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgcHJlc2VydmVXaGl0ZXNwYWNlczogZmFsc2UsXG59KVxuZXhwb3J0IGNsYXNzIFN1Z2dlc3Rpb25Hcm91cENvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyQ29udGVudEluaXQge1xuICBAQ29udGVudENoaWxkcmVuKGZvcndhcmRSZWYoKCkgPT4gU3VnZ2VzdGlvbkNvbXBvbmVudCkpXG4gIHN1Z2dlc3Rpb25zOiBRdWVyeUxpc3Q8U3VnZ2VzdGlvbkNvbXBvbmVudD47XG5cbiAgaGFzVmlzaWJsZVN1Z2dlc3Rpb24kOiBPYnNlcnZhYmxlPGJvb2xlYW4+O1xuXG4gIG5nQWZ0ZXJDb250ZW50SW5pdCgpIHtcbiAgICB0aGlzLmhhc1Zpc2libGVTdWdnZXN0aW9uJCA9IHRoaXMuc3VnZ2VzdGlvbnMuY2hhbmdlcy5waXBlKFxuICAgICAgc3RhcnRXaXRoKHRoaXMuc3VnZ2VzdGlvbnMpLFxuICAgICAgc3dpdGNoTWFwKChvcHRpb25zOiBRdWVyeUxpc3Q8U3VnZ2VzdGlvbkNvbXBvbmVudD4pID0+XG4gICAgICAgIG9wdGlvbnMubGVuZ3RoID4gMFxuICAgICAgICAgID8gY29tYmluZUxhdGVzdChvcHRpb25zLm1hcChub2RlID0+IG5vZGUudmlzaWJsZSQpKVxuICAgICAgICAgIDogb2YoW2ZhbHNlXSksXG4gICAgICApLFxuICAgICAgbWFwKHZpc2libGUgPT4gdmlzaWJsZS5zb21lKEJvb2xlYW4pKSxcbiAgICAgIHB1Ymxpc2hSZWYoKSxcbiAgICApO1xuICB9XG59XG4iLCI8ZGl2XG4gIFtoaWRkZW5dPVwiIShoYXNWaXNpYmxlU3VnZ2VzdGlvbiQgfCBhc3luYylcIlxuICBjbGFzcz1cImF1aS1zdWdnZXN0aW9uLWdyb3VwXCJcbj5cbiAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW2F1aVN1Z2dlc3Rpb25Hcm91cFRpdGxlXVwiPjwvbmctY29udGVudD5cbiAgPGRpdiBjbGFzcz1cImF1aS1zdWdnZXN0aW9uLWdyb3VwX19jb250ZW50XCI+PG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PjwvZGl2PlxuPC9kaXY+XG4iXX0=
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Optional, Output, ViewEncapsulation, } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject, combineLatest, fromEvent } from 'rxjs';
|
|
3
|
-
import { distinctUntilChanged, map, switchMap, throttleTime, } from 'rxjs/operators';
|
|
2
|
+
import { BehaviorSubject, combineLatest, fromEvent, distinctUntilChanged, map, switchMap, throttleTime, } from 'rxjs';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
4
|
import * as i1 from "@angular/cdk/overlay";
|
|
6
5
|
import * as i2 from "../icon/icon.component";
|
|
@@ -65,4 +64,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
65
64
|
}], click: [{
|
|
66
65
|
type: Output
|
|
67
66
|
}] } });
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFjay10b3AuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2JhY2stdG9wL2JhY2stdG9wLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uL3NyYy9iYWNrLXRvcC9iYWNrLXRvcC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUNMLFFBQVEsRUFDUixNQUFNLEVBQ04saUJBQWlCLEdBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFDTCxlQUFlLEVBQ2YsYUFBYSxFQUNiLFNBQVMsRUFDVCxvQkFBb0IsRUFDcEIsR0FBRyxFQUNILFNBQVMsRUFDVCxZQUFZLEdBQ2IsTUFBTSxNQUFNLENBQUM7Ozs7O0FBWWQsTUFBTSxPQUFPLGdCQUFnQjtJQWlDM0IsWUFBeUMsYUFBNEI7UUFBNUIsa0JBQWEsR0FBYixhQUFhLENBQWU7UUFYckUsVUFBSyxHQUFHLElBQUksWUFBWSxFQUFTLENBQUM7UUFFMUIsc0JBQWlCLEdBQUcsR0FBRyxDQUFDO1FBQ2YsYUFBUSxHQUFHLElBQUksZUFBZSxDQUFhLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN4RCx1QkFBa0IsR0FBRyxJQUFJLGVBQWUsQ0FDdkQsSUFBSSxDQUFDLGdCQUFnQixDQUN0QixDQUFDO1FBT0YsaUJBQVksR0FBRyxhQUFhLENBQUM7WUFDM0IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxZQUFZLEVBQUUsQ0FBQyxJQUFJLENBQy9CLEdBQUcsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUMsRUFDckMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQ2pCLFNBQVMsQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUMsSUFBSTtZQUM5Qix3QkFBd0I7WUFDeEIsWUFBWSxDQUFDLEVBQUUsRUFBRSxTQUFTLEVBQUUsRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUM5RCxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQzNDLENBQ0YsQ0FDRjtZQUNELElBQUksQ0FBQyxrQkFBa0I7U0FDeEIsQ0FBQyxDQUFDLElBQUksQ0FDTCxHQUFHLENBQUMsQ0FBQyxDQUFDLFNBQVMsRUFBRSxnQkFBZ0IsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxTQUFTLElBQUksZ0JBQWdCLENBQUMsRUFDckUsb0JBQW9CLEVBQUUsQ0FDdkIsQ0FBQztJQWpCc0UsQ0FBQztJQWhDekUsSUFDSSxnQkFBZ0IsQ0FBQyxHQUFXO1FBQzlCLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxHQUFHLENBQUM7UUFDN0IsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRUQsSUFBSSxnQkFBZ0I7UUFDbEIsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUM7SUFDaEMsQ0FBQztJQUVELElBQ0ksTUFBTSxDQUFDLEdBQWU7UUFDeEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxHQUFHLENBQUM7UUFDbkIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQUVELElBQUksTUFBTTtRQUNSLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0lBaUNELGtCQUFrQixDQUFDLE1BQXdCO1FBQ3pDLElBQUksTUFBTSxLQUFLLE1BQU0sRUFBRTtZQUNyQixPQUFPLFFBQVEsQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUFDO1NBQzNDO1FBQ0QsT0FBUSxNQUFzQixDQUFDLFNBQVMsQ0FBQztJQUMzQyxDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQVk7UUFDdEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBQzVELElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3pCLENBQUM7SUFFRCxTQUFTLENBQUMsTUFBa0I7UUFDMUIsTUFBTSxZQUFZLEdBQ2hCLENBQUMsT0FBTyxNQUFNLEtBQUssUUFBUSxJQUFJLFFBQVEsQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDOUQsSUFBSSxDQUFDLGFBQWEsRUFBRSxhQUFhLEVBQUUsQ0FBQyxhQUFhO1lBQ2pELE1BQU0sQ0FBQztRQUNULElBQUksQ0FBQyxhQUFhLEdBQUcsWUFBWSxDQUFDO1FBQ2xDLE9BQU8sWUFBWSxDQUFDO0lBQ3RCLENBQUM7OzZHQXZFVSxnQkFBZ0I7aUdBQWhCLGdCQUFnQixxSkM5QjdCLCtNQVVBOzJGRG9CYSxnQkFBZ0I7a0JBUjVCLFNBQVM7K0JBQ0UsY0FBYyxpQkFHVCxpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNLHVCQUMxQixLQUFLOzswQkFtQ2IsUUFBUTs0Q0EvQmpCLGdCQUFnQjtzQkFEbkIsS0FBSztnQkFXRixNQUFNO3NCQURULEtBQUs7Z0JBV04sS0FBSztzQkFESixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2RrU2Nyb2xsYWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE9wdGlvbmFsLFxuICBPdXRwdXQsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIEJlaGF2aW9yU3ViamVjdCxcbiAgY29tYmluZUxhdGVzdCxcbiAgZnJvbUV2ZW50LFxuICBkaXN0aW5jdFVudGlsQ2hhbmdlZCxcbiAgbWFwLFxuICBzd2l0Y2hNYXAsXG4gIHRocm90dGxlVGltZSxcbn0gZnJvbSAncnhqcyc7XG5cbnR5cGUgVGFyZ2V0VHlwZSA9IEVsZW1lbnQgfCBXaW5kb3cgfCBzdHJpbmc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2F1aS1iYWNrLXRvcCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9iYWNrLXRvcC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2JhY2stdG9wLmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBwcmVzZXJ2ZVdoaXRlc3BhY2VzOiBmYWxzZSxcbn0pXG5leHBvcnQgY2xhc3MgQmFja1RvcENvbXBvbmVudCB7XG4gIEBJbnB1dCgpXG4gIHNldCB2aXNpYmlsaXR5SGVpZ2h0KHZhbDogbnVtYmVyKSB7XG4gICAgdGhpcy5fdmlzaWJpbGl0eUhlaWdodCA9IHZhbDtcbiAgICB0aGlzLnZpc2liaWxpdHlIZWlnaHQkJC5uZXh0KHZhbCk7XG4gIH1cblxuICBnZXQgdmlzaWJpbGl0eUhlaWdodCgpIHtcbiAgICByZXR1cm4gdGhpcy5fdmlzaWJpbGl0eUhlaWdodDtcbiAgfVxuXG4gIEBJbnB1dCgpXG4gIHNldCB0YXJnZXQodmFsOiBUYXJnZXRUeXBlKSB7XG4gICAgdGhpcy5fdGFyZ2V0ID0gdmFsO1xuICAgIHRoaXMudGFyZ2V0JCQubmV4dCh2YWwpO1xuICB9XG5cbiAgZ2V0IHRhcmdldCgpIHtcbiAgICByZXR1cm4gdGhpcy5fdGFyZ2V0O1xuICB9XG5cbiAgQE91dHB1dCgpXG4gIGNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjxFdmVudD4oKTtcblxuICBwcml2YXRlIF92aXNpYmlsaXR5SGVpZ2h0ID0gNDAwO1xuICBwcml2YXRlIHJlYWRvbmx5IHRhcmdldCQkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxUYXJnZXRUeXBlPih0aGlzLnRhcmdldCk7XG4gIHByaXZhdGUgcmVhZG9ubHkgdmlzaWJpbGl0eUhlaWdodCQkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxudW1iZXI+KFxuICAgIHRoaXMudmlzaWJpbGl0eUhlaWdodCxcbiAgKTtcblxuICBwcml2YXRlIF90YXJnZXQ6IFRhcmdldFR5cGU7XG4gIHByaXZhdGUgX3Njcm9sbFRhcmdldDogRWxlbWVudCB8IFdpbmRvdztcblxuICBjb25zdHJ1Y3RvcihAT3B0aW9uYWwoKSBwcml2YXRlIHJlYWRvbmx5IGNka1Njcm9sbGFibGU6IENka1Njcm9sbGFibGUpIHt9XG5cbiAgaXNEaXNwbGF5ZWQkID0gY29tYmluZUxhdGVzdChbXG4gICAgdGhpcy50YXJnZXQkJC5hc09ic2VydmFibGUoKS5waXBlKFxuICAgICAgbWFwKHRhcmdldCA9PiB0aGlzLmdldFRhcmdldCh0YXJnZXQpKSxcbiAgICAgIHN3aXRjaE1hcCh0YXJnZXQgPT5cbiAgICAgICAgZnJvbUV2ZW50KHRhcmdldCwgJ3Njcm9sbCcpLnBpcGUoXG4gICAgICAgICAgLy8gdXNlIGRlZmF1bHQgc2NoZWR1bGVyXG4gICAgICAgICAgdGhyb3R0bGVUaW1lKDUwLCB1bmRlZmluZWQsIHsgbGVhZGluZzogdHJ1ZSwgdHJhaWxpbmc6IHRydWUgfSksXG4gICAgICAgICAgbWFwKCgpID0+IHRoaXMuZ2V0VGFyZ2V0U2Nyb2xsVG9wKHRhcmdldCkpLFxuICAgICAgICApLFxuICAgICAgKSxcbiAgICApLFxuICAgIHRoaXMudmlzaWJpbGl0eUhlaWdodCQkLFxuICBdKS5waXBlKFxuICAgIG1hcCgoW3Njcm9sbFRvcCwgdmlzaWJpbGl0eUhlaWdodF0pID0+IHNjcm9sbFRvcCA+PSB2aXNpYmlsaXR5SGVpZ2h0KSxcbiAgICBkaXN0aW5jdFVudGlsQ2hhbmdlZCgpLFxuICApO1xuXG4gIGdldFRhcmdldFNjcm9sbFRvcCh0YXJnZXQ6IEVsZW1lbnQgfCBXaW5kb3cpIHtcbiAgICBpZiAodGFyZ2V0ID09PSB3aW5kb3cpIHtcbiAgICAgIHJldHVybiBkb2N1bWVudC5kb2N1bWVudEVsZW1lbnQuc2Nyb2xsVG9wO1xuICAgIH1cbiAgICByZXR1cm4gKHRhcmdldCBhcyBIVE1MRWxlbWVudCkuc2Nyb2xsVG9wO1xuICB9XG5cbiAgaGFuZGxlQ2xpY2soZXZlbnQ6IEV2ZW50KSB7XG4gICAgdGhpcy5fc2Nyb2xsVGFyZ2V0LnNjcm9sbFRvKHsgdG9wOiAwLCBiZWhhdmlvcjogJ3Ntb290aCcgfSk7XG4gICAgdGhpcy5jbGljay5lbWl0KGV2ZW50KTtcbiAgfVxuXG4gIGdldFRhcmdldCh0YXJnZXQ6IFRhcmdldFR5cGUpOiBFbGVtZW50IHwgV2luZG93IHtcbiAgICBjb25zdCBzY3JvbGxUYXJnZXQgPVxuICAgICAgKHR5cGVvZiB0YXJnZXQgPT09ICdzdHJpbmcnICYmIGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IodGFyZ2V0KSkgfHxcbiAgICAgIHRoaXMuY2RrU2Nyb2xsYWJsZT8uZ2V0RWxlbWVudFJlZigpLm5hdGl2ZUVsZW1lbnQgfHxcbiAgICAgIHdpbmRvdztcbiAgICB0aGlzLl9zY3JvbGxUYXJnZXQgPSBzY3JvbGxUYXJnZXQ7XG4gICAgcmV0dXJuIHNjcm9sbFRhcmdldDtcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cImF1aS1iYWNrLXRvcFwiXG4gIChjbGljayk9XCJoYW5kbGVDbGljaygkZXZlbnQpXCJcbiAgW2NsYXNzLnNob3ddPVwiaXNEaXNwbGF5ZWQkIHwgYXN5bmNcIlxuPlxuICA8YXVpLWljb25cbiAgICBpY29uPVwiYmFja190b3BcIlxuICAgIGNsYXNzPVwiYXVpLWJhY2stdG9wX19pY29uXCJcbiAgPjwvYXVpLWljb24+XG48L2Rpdj5cbiJdfQ==
|