@alauda/ui 6.5.6 → 6.5.7-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (31) hide show
  1. package/esm2020/autocomplete/autocomplete.component.mjs +2 -2
  2. package/esm2020/paginator/paginator.component.mjs +2 -2
  3. package/esm2020/scrolling/virtual-for-of.directive.mjs +14 -2
  4. package/esm2020/select/base-select.mjs +185 -88
  5. package/esm2020/select/index.mjs +2 -2
  6. package/esm2020/select/multi-select/multi-select.component.mjs +26 -47
  7. package/esm2020/select/option-group/option-group.component.mjs +13 -6
  8. package/esm2020/select/option-item/option-item.component.mjs +104 -0
  9. package/esm2020/select/option.component.mjs +46 -0
  10. package/esm2020/select/select.component.mjs +22 -18
  11. package/esm2020/select/select.module.mjs +14 -3
  12. package/esm2020/select/select.types.mjs +1 -1
  13. package/esm2020/select/validators.mjs +7 -4
  14. package/esm2020/tooltip/base-tooltip.mjs +5 -1
  15. package/esm2020/tree-select/tree-select.component.mjs +3 -3
  16. package/fesm2015/alauda-ui.mjs +1005 -864
  17. package/fesm2015/alauda-ui.mjs.map +1 -1
  18. package/fesm2020/alauda-ui.mjs +1003 -866
  19. package/fesm2020/alauda-ui.mjs.map +1 -1
  20. package/package.json +1 -1
  21. package/select/base-select.d.ts +55 -27
  22. package/select/index.d.ts +1 -1
  23. package/select/multi-select/multi-select.component.d.ts +3 -5
  24. package/select/option-group/option-group.component.d.ts +4 -3
  25. package/select/option-item/option-item.component.d.ts +41 -0
  26. package/select/option.component.d.ts +16 -0
  27. package/select/select.component.d.ts +6 -6
  28. package/select/select.module.d.ts +16 -13
  29. package/select/select.types.d.ts +8 -2
  30. package/esm2020/select/option/option.component.mjs +0 -112
  31. package/select/option/option.component.d.ts +0 -45
@@ -1,23 +1,30 @@
1
- import { ChangeDetectionStrategy, Component, ContentChildren, ViewEncapsulation, forwardRef, } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, ContentChildren, ViewEncapsulation, forwardRef, ContentChild, ElementRef, } from '@angular/core';
2
2
  import { combineLatest, of, map, startWith, switchMap } from 'rxjs';
3
3
  import { publishRef } from '../../utils';
4
- import { OptionComponent } from '../option/option.component';
4
+ import { OptionGroupTitleDirective } from '../helper-directives';
5
+ import { OptionComponent } from '../option.component';
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "@angular/common";
7
8
  export class OptionGroupComponent {
8
9
  ngAfterContentInit() {
9
10
  this.hasVisibleOption$ = this.options.changes.pipe(startWith(this.options), switchMap((options) => options.length > 0
10
- ? combineLatest(options.map(node => node.visible$))
11
- : of([false])), map(visible => visible.some(Boolean)), publishRef());
11
+ ? combineLatest(options.map(node => {
12
+ node.groupTitle = this.groupTitle;
13
+ return node.changes;
14
+ }))
15
+ : of([false])), map(options => !!options.length), publishRef());
12
16
  }
13
17
  }
14
18
  OptionGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: OptionGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
15
- OptionGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: OptionGroupComponent, selector: "aui-option-group", queries: [{ propertyName: "options", predicate: i0.forwardRef(function () { return OptionComponent; }) }], ngImport: i0, template: "<div\n [hidden]=\"!(hasVisibleOption$ | async)\"\n class=\"aui-option-group\"\n>\n <ng-content select=\"[auiOptionGroupTitle]\"></ng-content>\n <div class=\"aui-option-group__content\"><ng-content></ng-content></div>\n</div>\n", styles: [".aui-option-group__title{padding:4px 8px;font-size:var(--aui-font-size-s);line-height:var(--aui-line-height-s);font-weight:var(--aui-font-weight-normal);color:rgb(var(--aui-color-help-text))}aui-option-group:not(:first-child) .aui-option-group{margin-top:8px;padding-top:8px;border-top:1px solid rgb(var(--aui-color-n-8))}\n"], pipes: { "async": i1.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
19
+ OptionGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: OptionGroupComponent, selector: "aui-option-group", queries: [{ propertyName: "groupTitle", first: true, predicate: OptionGroupTitleDirective, descendants: true, read: ElementRef }, { propertyName: "options", predicate: i0.forwardRef(function () { return OptionComponent; }) }], ngImport: i0, template: "<div\n [hidden]=\"!(hasVisibleOption$ | async)\"\n class=\"aui-option-group\"\n>\n <ng-content select=\"[auiOptionGroupTitle]\"></ng-content>\n <div class=\"aui-option-group__content\"><ng-content></ng-content></div>\n</div>\n", styles: [".aui-option-group__title{padding:4px 8px;font-size:var(--aui-font-size-s);line-height:var(--aui-line-height-s);font-weight:var(--aui-font-weight-normal);color:rgb(var(--aui-color-help-text))}aui-option-group:not(:first-child) .aui-option-group{margin-top:8px;padding-top:8px;border-top:1px solid rgb(var(--aui-color-n-8))}\n"], pipes: { "async": i1.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
16
20
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: OptionGroupComponent, decorators: [{
17
21
  type: Component,
18
22
  args: [{ selector: 'aui-option-group', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, preserveWhitespaces: false, template: "<div\n [hidden]=\"!(hasVisibleOption$ | async)\"\n class=\"aui-option-group\"\n>\n <ng-content select=\"[auiOptionGroupTitle]\"></ng-content>\n <div class=\"aui-option-group__content\"><ng-content></ng-content></div>\n</div>\n", styles: [".aui-option-group__title{padding:4px 8px;font-size:var(--aui-font-size-s);line-height:var(--aui-line-height-s);font-weight:var(--aui-font-weight-normal);color:rgb(var(--aui-color-help-text))}aui-option-group:not(:first-child) .aui-option-group{margin-top:8px;padding-top:8px;border-top:1px solid rgb(var(--aui-color-n-8))}\n"] }]
19
23
  }], propDecorators: { options: [{
20
24
  type: ContentChildren,
21
25
  args: [forwardRef(() => OptionComponent)]
26
+ }], groupTitle: [{
27
+ type: ContentChild,
28
+ args: [OptionGroupTitleDirective, { read: ElementRef }]
22
29
  }] } });
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLWdyb3VwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9zZWxlY3Qvb3B0aW9uLWdyb3VwL29wdGlvbi1ncm91cC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvc2VsZWN0L29wdGlvbi1ncm91cC9vcHRpb24tZ3JvdXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsZUFBZSxFQUVmLGlCQUFpQixFQUNqQixVQUFVLEdBQ1gsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFjLGFBQWEsRUFBRSxFQUFFLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFaEYsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7OztBQVU3RCxNQUFNLE9BQU8sb0JBQW9CO0lBTS9CLGtCQUFrQjtRQUNoQixJQUFJLENBQUMsaUJBQWlCLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUNoRCxTQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxFQUN2QixTQUFTLENBQUMsQ0FBQyxPQUFzQyxFQUFFLEVBQUUsQ0FDbkQsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDO1lBQ2hCLENBQUMsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUNuRCxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FDaEIsRUFDRCxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEVBQ3JDLFVBQVUsRUFBRSxDQUNiLENBQUM7SUFDSixDQUFDOztpSEFqQlUsb0JBQW9CO3FHQUFwQixvQkFBb0IsbUhBQ0csZUFBZSxpQ0N2Qm5ELHdPQU9BOzJGRGVhLG9CQUFvQjtrQkFSaEMsU0FBUzsrQkFDRSxrQkFBa0IsbUJBR1gsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSx1QkFDaEIsS0FBSzs4QkFJMUIsT0FBTztzQkFETixlQUFlO3VCQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBZnRlckNvbnRlbnRJbml0LFxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBDb250ZW50Q2hpbGRyZW4sXG4gIFF1ZXJ5TGlzdCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG4gIGZvcndhcmRSZWYsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgY29tYmluZUxhdGVzdCwgb2YsIG1hcCwgc3RhcnRXaXRoLCBzd2l0Y2hNYXAgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgcHVibGlzaFJlZiB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IE9wdGlvbkNvbXBvbmVudCB9IGZyb20gJy4uL29wdGlvbi9vcHRpb24uY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXVpLW9wdGlvbi1ncm91cCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9vcHRpb24tZ3JvdXAuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9vcHRpb24tZ3JvdXAuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIHByZXNlcnZlV2hpdGVzcGFjZXM6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBPcHRpb25Hcm91cENvbXBvbmVudDxUPiBpbXBsZW1lbnRzIEFmdGVyQ29udGVudEluaXQge1xuICBAQ29udGVudENoaWxkcmVuKGZvcndhcmRSZWYoKCkgPT4gT3B0aW9uQ29tcG9uZW50KSlcbiAgb3B0aW9uczogUXVlcnlMaXN0PE9wdGlvbkNvbXBvbmVudDxUPj47XG5cbiAgaGFzVmlzaWJsZU9wdGlvbiQ6IE9ic2VydmFibGU8Ym9vbGVhbj47XG5cbiAgbmdBZnRlckNvbnRlbnRJbml0KCkge1xuICAgIHRoaXMuaGFzVmlzaWJsZU9wdGlvbiQgPSB0aGlzLm9wdGlvbnMuY2hhbmdlcy5waXBlKFxuICAgICAgc3RhcnRXaXRoKHRoaXMub3B0aW9ucyksXG4gICAgICBzd2l0Y2hNYXAoKG9wdGlvbnM6IFF1ZXJ5TGlzdDxPcHRpb25Db21wb25lbnQ8VD4+KSA9PlxuICAgICAgICBvcHRpb25zLmxlbmd0aCA+IDBcbiAgICAgICAgICA/IGNvbWJpbmVMYXRlc3Qob3B0aW9ucy5tYXAobm9kZSA9PiBub2RlLnZpc2libGUkKSlcbiAgICAgICAgICA6IG9mKFtmYWxzZV0pLFxuICAgICAgKSxcbiAgICAgIG1hcCh2aXNpYmxlID0+IHZpc2libGUuc29tZShCb29sZWFuKSksXG4gICAgICBwdWJsaXNoUmVmKCksXG4gICAgKTtcbiAgfVxufVxuIiwiPGRpdlxuICBbaGlkZGVuXT1cIiEoaGFzVmlzaWJsZU9wdGlvbiQgfCBhc3luYylcIlxuICBjbGFzcz1cImF1aS1vcHRpb24tZ3JvdXBcIlxuPlxuICA8bmctY29udGVudCBzZWxlY3Q9XCJbYXVpT3B0aW9uR3JvdXBUaXRsZV1cIj48L25nLWNvbnRlbnQ+XG4gIDxkaXYgY2xhc3M9XCJhdWktb3B0aW9uLWdyb3VwX19jb250ZW50XCI+PG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PjwvZGl2PlxuPC9kaXY+XG4iXX0=
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLWdyb3VwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9zZWxlY3Qvb3B0aW9uLWdyb3VwL29wdGlvbi1ncm91cC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvc2VsZWN0L29wdGlvbi1ncm91cC9vcHRpb24tZ3JvdXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsZUFBZSxFQUVmLGlCQUFpQixFQUNqQixVQUFVLEVBQ1YsWUFBWSxFQUNaLFVBQVUsR0FDWCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQWMsYUFBYSxFQUFFLEVBQUUsRUFBRSxHQUFHLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUVoRixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7O0FBVXRELE1BQU0sT0FBTyxvQkFBb0I7SUFTL0Isa0JBQWtCO1FBQ2hCLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQ2hELFNBQVMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEVBQ3ZCLFNBQVMsQ0FBQyxDQUFDLE9BQXNDLEVBQUUsRUFBRSxDQUNuRCxPQUFPLENBQUMsTUFBTSxHQUFHLENBQUM7WUFDaEIsQ0FBQyxDQUFDLGFBQWEsQ0FDWCxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFO2dCQUNqQixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUM7Z0JBQ2xDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztZQUN0QixDQUFDLENBQUMsQ0FDSDtZQUNILENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUNoQixFQUNELEdBQUcsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLEVBQ2hDLFVBQVUsRUFBRSxDQUNiLENBQUM7SUFDSixDQUFDOztpSEF6QlUsb0JBQW9CO3FHQUFwQixvQkFBb0IsZ0dBSWpCLHlCQUF5QiwyQkFBVSxVQUFVLDZFQUh6QixlQUFlLGlDQzFCbkQsd09BT0E7MkZEa0JhLG9CQUFvQjtrQkFSaEMsU0FBUzsrQkFDRSxrQkFBa0IsbUJBR1gsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSx1QkFDaEIsS0FBSzs4QkFJMUIsT0FBTztzQkFETixlQUFlO3VCQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxlQUFlLENBQUM7Z0JBSWxELFVBQVU7c0JBRFQsWUFBWTt1QkFBQyx5QkFBeUIsRUFBRSxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBZnRlckNvbnRlbnRJbml0LFxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBDb250ZW50Q2hpbGRyZW4sXG4gIFF1ZXJ5TGlzdCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG4gIGZvcndhcmRSZWYsXG4gIENvbnRlbnRDaGlsZCxcbiAgRWxlbWVudFJlZixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBjb21iaW5lTGF0ZXN0LCBvZiwgbWFwLCBzdGFydFdpdGgsIHN3aXRjaE1hcCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBwdWJsaXNoUmVmIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgT3B0aW9uR3JvdXBUaXRsZURpcmVjdGl2ZSB9IGZyb20gJy4uL2hlbHBlci1kaXJlY3RpdmVzJztcbmltcG9ydCB7IE9wdGlvbkNvbXBvbmVudCB9IGZyb20gJy4uL29wdGlvbi5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhdWktb3B0aW9uLWdyb3VwJyxcbiAgdGVtcGxhdGVVcmw6ICcuL29wdGlvbi1ncm91cC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL29wdGlvbi1ncm91cC5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgcHJlc2VydmVXaGl0ZXNwYWNlczogZmFsc2UsXG59KVxuZXhwb3J0IGNsYXNzIE9wdGlvbkdyb3VwQ29tcG9uZW50PFQ+IGltcGxlbWVudHMgQWZ0ZXJDb250ZW50SW5pdCB7XG4gIEBDb250ZW50Q2hpbGRyZW4oZm9yd2FyZFJlZigoKSA9PiBPcHRpb25Db21wb25lbnQpKVxuICBvcHRpb25zOiBRdWVyeUxpc3Q8T3B0aW9uQ29tcG9uZW50PFQ+PjtcblxuICBAQ29udGVudENoaWxkKE9wdGlvbkdyb3VwVGl0bGVEaXJlY3RpdmUsIHsgcmVhZDogRWxlbWVudFJlZiB9KVxuICBncm91cFRpdGxlOiBFbGVtZW50UmVmO1xuXG4gIGhhc1Zpc2libGVPcHRpb24kOiBPYnNlcnZhYmxlPGJvb2xlYW4+O1xuXG4gIG5nQWZ0ZXJDb250ZW50SW5pdCgpIHtcbiAgICB0aGlzLmhhc1Zpc2libGVPcHRpb24kID0gdGhpcy5vcHRpb25zLmNoYW5nZXMucGlwZShcbiAgICAgIHN0YXJ0V2l0aCh0aGlzLm9wdGlvbnMpLFxuICAgICAgc3dpdGNoTWFwKChvcHRpb25zOiBRdWVyeUxpc3Q8T3B0aW9uQ29tcG9uZW50PFQ+PikgPT5cbiAgICAgICAgb3B0aW9ucy5sZW5ndGggPiAwXG4gICAgICAgICAgPyBjb21iaW5lTGF0ZXN0KFxuICAgICAgICAgICAgICBvcHRpb25zLm1hcChub2RlID0+IHtcbiAgICAgICAgICAgICAgICBub2RlLmdyb3VwVGl0bGUgPSB0aGlzLmdyb3VwVGl0bGU7XG4gICAgICAgICAgICAgICAgcmV0dXJuIG5vZGUuY2hhbmdlcztcbiAgICAgICAgICAgICAgfSksXG4gICAgICAgICAgICApXG4gICAgICAgICAgOiBvZihbZmFsc2VdKSxcbiAgICAgICksXG4gICAgICBtYXAob3B0aW9ucyA9PiAhIW9wdGlvbnMubGVuZ3RoKSxcbiAgICAgIHB1Ymxpc2hSZWYoKSxcbiAgICApO1xuICB9XG59XG4iLCI8ZGl2XG4gIFtoaWRkZW5dPVwiIShoYXNWaXNpYmxlT3B0aW9uJCB8IGFzeW5jKVwiXG4gIGNsYXNzPVwiYXVpLW9wdGlvbi1ncm91cFwiXG4+XG4gIDxuZy1jb250ZW50IHNlbGVjdD1cIlthdWlPcHRpb25Hcm91cFRpdGxlXVwiPjwvbmctY29udGVudD5cbiAgPGRpdiBjbGFzcz1cImF1aS1vcHRpb24tZ3JvdXBfX2NvbnRlbnRcIj48bmctY29udGVudD48L25nLWNvbnRlbnQ+PC9kaXY+XG48L2Rpdj5cbiJdfQ==
@@ -0,0 +1,104 @@
1
+ import { DomPortal } from '@angular/cdk/portal';
2
+ import { ChangeDetectionStrategy, Component, Inject, Input, ViewChild, ViewEncapsulation, forwardRef, HostBinding, } from '@angular/core';
3
+ import { BehaviorSubject, Subject, tap } from 'rxjs';
4
+ import { ComponentSize } from '../../types';
5
+ import { buildBem } from '../../utils';
6
+ import { BaseSelect } from '../base-select';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "../../icon/icon.component";
9
+ import * as i2 from "@angular/common";
10
+ import * as i3 from "@angular/cdk/portal";
11
+ export class OptionItemComponent {
12
+ constructor(select) {
13
+ this.changes = new Subject();
14
+ this.bem = buildBem('aui-option');
15
+ this._label = '';
16
+ this._labelContext = {};
17
+ this.label$$ = new BehaviorSubject(this.label);
18
+ this.labelContext$$ = new BehaviorSubject(this.labelContext);
19
+ this.value$$ = new BehaviorSubject(this.value);
20
+ this._focused = false;
21
+ this.isMulti = false;
22
+ this.size = ComponentSize.Medium;
23
+ this.isMulti = select.isMulti;
24
+ this.select = select;
25
+ this.size$ = this.select.size$.pipe(tap(size => {
26
+ this.size = size;
27
+ }));
28
+ }
29
+ get label() {
30
+ return this._label;
31
+ }
32
+ set label(val) {
33
+ this._label = val;
34
+ this.label$$.next(val);
35
+ }
36
+ get labelContext() {
37
+ return this._labelContext;
38
+ }
39
+ set labelContext(val) {
40
+ this._labelContext = val;
41
+ this.labelContext$$.next(val);
42
+ }
43
+ get value() {
44
+ return this._value;
45
+ }
46
+ set value(val) {
47
+ this._value = val;
48
+ this.value$$.next(val);
49
+ }
50
+ get groupTitlePortal() {
51
+ return this.groupTitle ? new DomPortal(this.groupTitle) : '';
52
+ }
53
+ ngOnChanges() {
54
+ this.changes.next(null);
55
+ }
56
+ onClick() {
57
+ if (this.disabled) {
58
+ return;
59
+ }
60
+ this.select.onOptionClick(this);
61
+ }
62
+ focus() {
63
+ console.log(123);
64
+ if (this.disabled) {
65
+ return;
66
+ }
67
+ this.select.focus(this);
68
+ }
69
+ blur() {
70
+ this.select.blur();
71
+ }
72
+ }
73
+ OptionItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: OptionItemComponent, deps: [{ token: forwardRef(() => BaseSelect) }], target: i0.ɵɵFactoryTarget.Component });
74
+ OptionItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: OptionItemComponent, selector: "aui-option-item", inputs: { label: "label", labelContext: "labelContext", value: "value", disabled: "disabled", focused: "focused", selected: "selected", groupTitle: "groupTitle", contentTemplate: "contentTemplate" }, host: { properties: { "class.is-group": "this.groupTitle" } }, viewQueries: [{ propertyName: "elRef", first: true, predicate: ["elRef"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div\n #elRef\n *ngIf=\"!groupTitlePortal; else group\"\n [class]=\"bem.block(size$ | async)\"\n [class.isDisabled]=\"disabled\"\n [class.isSelected]=\"selected\"\n [class.isMulti]=\"isMulti\"\n [class.isFocused]=\"focused\"\n (click)=\"onClick()\"\n>\n <i\n *ngIf=\"isMulti\"\n class=\"aui-option__pointer\"\n >\n <aui-icon\n [hidden]=\"!selected\"\n icon=\"check\"\n ></aui-icon>\n </i>\n <ng-content></ng-content>\n</div>\n\n<ng-template #group>\n <div class=\"aui-option__group-item\">\n <ng-container *cdkPortalOutlet=\"groupTitlePortal!\"></ng-container>\n </div>\n</ng-template>\n", styles: [".aui-option{padding:0 var(--aui-inline-padding-xs);color:rgb(var(--aui-color-main-text));font-weight:var(--aui-font-weight-normal);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}.aui-option--large{padding:calc((var(--aui-inline-height-l) - var(--aui-line-height-l)) / 2);line-height:var(--aui-line-height-l);font-size:var(--aui-font-size-l)}.aui-option--medium{padding:calc((var(--aui-inline-height-m) - var(--aui-line-height-m)) / 2);line-height:var(--aui-line-height-m);font-size:var(--aui-font-size-m)}.aui-option--small{padding:calc((var(--aui-inline-height-s) - var(--aui-line-height-m)) / 2);line-height:var(--aui-line-height-m);font-size:var(--aui-font-size-m)}.aui-option--mini{padding:calc((var(--aui-inline-height-xs) - var(--aui-line-height-s)) / 2);line-height:var(--aui-line-height-s);font-size:var(--aui-font-size-s)}.aui-option:not(.isMulti).isSelected{color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-p-6))}.aui-option:hover,.aui-option.isFocused{background-color:rgb(var(--aui-color-p-6))}.aui-option.isDisabled{color:rgb(var(--aui-color-n-6));cursor:not-allowed}.aui-option__pointer{display:inline-flex;justify-content:center;align-items:center;flex-shrink:0;width:var(--aui-icon-size-m);height:var(--aui-icon-size-m);margin-right:var(--aui-spacing-m);border-radius:var(--aui-border-radius-m);border:1px solid rgb(var(--aui-color-n-7));color:#fff;background-color:rgb(var(--aui-color-main-bg));position:relative;vertical-align:middle;transition:all .3s ease}.aui-option.cdk-keyboard-focused .aui-option__pointer{border-color:rgb(var(--aui-color-primary))}:root .aui-option.cdk-keyboard-focused .aui-option__pointer{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.16)}html[aui-theme-mode=light] .aui-option.cdk-keyboard-focused .aui-option__pointer{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-option.cdk-keyboard-focused .aui-option__pointer{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.3)}}html[aui-theme-mode=dark] .aui-option.cdk-keyboard-focused .aui-option__pointer{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.3)}.aui-option.isSelected .aui-option__pointer{border-color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-primary))}.aui-option.isIndeterminate .aui-option__pointer{border-color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-main-bg))}.aui-option.isIndeterminate .aui-option__pointer:before{content:\"\";display:block;width:8px;height:8px;border-radius:1px;background-color:rgb(var(--aui-color-primary))}.aui-option.isSelected.isDisabled .aui-option__pointer{border-color:rgb(var(--aui-color-p-4));background-color:rgb(var(--aui-color-p-4))}.aui-option.isDisabled .aui-option__label{cursor:not-allowed}.aui-option.isDisabled .aui-option__pointer{border-color:rgb(var(--aui-color-n-7));background-color:rgb(var(--aui-color-n-8))}.aui-option:not(.isDisabled):hover .aui-option__pointer,.aui-option:not(.isDisabled).isFocused .aui-option__pointer{border-color:rgb(var(--aui-color-primary))}aui-option-item.is-group:not(:first-of-type) .aui-option__group-item{margin-top:8px;padding-top:8px;border-top:1px solid rgb(var(--aui-color-n-8))}\n"], components: [{ type: i1.IconComponent, selector: "aui-icon", inputs: ["icon", "light", "dark", "link", "margin", "size", "color", "background", "backgroundColor"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }], pipes: { "async": i2.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
75
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: OptionItemComponent, decorators: [{
76
+ type: Component,
77
+ args: [{ selector: 'aui-option-item', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, preserveWhitespaces: false, template: "<div\n #elRef\n *ngIf=\"!groupTitlePortal; else group\"\n [class]=\"bem.block(size$ | async)\"\n [class.isDisabled]=\"disabled\"\n [class.isSelected]=\"selected\"\n [class.isMulti]=\"isMulti\"\n [class.isFocused]=\"focused\"\n (click)=\"onClick()\"\n>\n <i\n *ngIf=\"isMulti\"\n class=\"aui-option__pointer\"\n >\n <aui-icon\n [hidden]=\"!selected\"\n icon=\"check\"\n ></aui-icon>\n </i>\n <ng-content></ng-content>\n</div>\n\n<ng-template #group>\n <div class=\"aui-option__group-item\">\n <ng-container *cdkPortalOutlet=\"groupTitlePortal!\"></ng-container>\n </div>\n</ng-template>\n", styles: [".aui-option{padding:0 var(--aui-inline-padding-xs);color:rgb(var(--aui-color-main-text));font-weight:var(--aui-font-weight-normal);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}.aui-option--large{padding:calc((var(--aui-inline-height-l) - var(--aui-line-height-l)) / 2);line-height:var(--aui-line-height-l);font-size:var(--aui-font-size-l)}.aui-option--medium{padding:calc((var(--aui-inline-height-m) - var(--aui-line-height-m)) / 2);line-height:var(--aui-line-height-m);font-size:var(--aui-font-size-m)}.aui-option--small{padding:calc((var(--aui-inline-height-s) - var(--aui-line-height-m)) / 2);line-height:var(--aui-line-height-m);font-size:var(--aui-font-size-m)}.aui-option--mini{padding:calc((var(--aui-inline-height-xs) - var(--aui-line-height-s)) / 2);line-height:var(--aui-line-height-s);font-size:var(--aui-font-size-s)}.aui-option:not(.isMulti).isSelected{color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-p-6))}.aui-option:hover,.aui-option.isFocused{background-color:rgb(var(--aui-color-p-6))}.aui-option.isDisabled{color:rgb(var(--aui-color-n-6));cursor:not-allowed}.aui-option__pointer{display:inline-flex;justify-content:center;align-items:center;flex-shrink:0;width:var(--aui-icon-size-m);height:var(--aui-icon-size-m);margin-right:var(--aui-spacing-m);border-radius:var(--aui-border-radius-m);border:1px solid rgb(var(--aui-color-n-7));color:#fff;background-color:rgb(var(--aui-color-main-bg));position:relative;vertical-align:middle;transition:all .3s ease}.aui-option.cdk-keyboard-focused .aui-option__pointer{border-color:rgb(var(--aui-color-primary))}:root .aui-option.cdk-keyboard-focused .aui-option__pointer{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.16)}html[aui-theme-mode=light] .aui-option.cdk-keyboard-focused .aui-option__pointer{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-option.cdk-keyboard-focused .aui-option__pointer{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.3)}}html[aui-theme-mode=dark] .aui-option.cdk-keyboard-focused .aui-option__pointer{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.3)}.aui-option.isSelected .aui-option__pointer{border-color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-primary))}.aui-option.isIndeterminate .aui-option__pointer{border-color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-main-bg))}.aui-option.isIndeterminate .aui-option__pointer:before{content:\"\";display:block;width:8px;height:8px;border-radius:1px;background-color:rgb(var(--aui-color-primary))}.aui-option.isSelected.isDisabled .aui-option__pointer{border-color:rgb(var(--aui-color-p-4));background-color:rgb(var(--aui-color-p-4))}.aui-option.isDisabled .aui-option__label{cursor:not-allowed}.aui-option.isDisabled .aui-option__pointer{border-color:rgb(var(--aui-color-n-7));background-color:rgb(var(--aui-color-n-8))}.aui-option:not(.isDisabled):hover .aui-option__pointer,.aui-option:not(.isDisabled).isFocused .aui-option__pointer{border-color:rgb(var(--aui-color-primary))}aui-option-item.is-group:not(:first-of-type) .aui-option__group-item{margin-top:8px;padding-top:8px;border-top:1px solid rgb(var(--aui-color-n-8))}\n"] }]
78
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
79
+ type: Inject,
80
+ args: [forwardRef(() => BaseSelect)]
81
+ }] }]; }, propDecorators: { label: [{
82
+ type: Input
83
+ }], labelContext: [{
84
+ type: Input
85
+ }], value: [{
86
+ type: Input
87
+ }], disabled: [{
88
+ type: Input
89
+ }], focused: [{
90
+ type: Input
91
+ }], selected: [{
92
+ type: Input
93
+ }], groupTitle: [{
94
+ type: HostBinding,
95
+ args: ['class.is-group']
96
+ }, {
97
+ type: Input
98
+ }], contentTemplate: [{
99
+ type: Input
100
+ }], elRef: [{
101
+ type: ViewChild,
102
+ args: ['elRef', { static: true }]
103
+ }] } });
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option-item.component.js","sourceRoot":"","sources":["../../../../src/select/option-item/option-item.component.ts","../../../../src/select/option-item/option-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DomPortal } from '@angular/cdk/portal';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n  OnChanges,\n  HostBinding,\n} from '@angular/core';\nimport { BehaviorSubject, Observable, Subject, tap } from 'rxjs';\n\nimport { ComponentSize } from '../../types';\nimport { Bem, buildBem } from '../../utils';\nimport { BaseSelect } from '../base-select';\n\n@Component({\n  selector: 'aui-option-item',\n  templateUrl: './option-item.component.html',\n  styleUrls: ['./option-item.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n})\nexport class OptionItemComponent<T> implements OnChanges {\n  changes = new Subject();\n  bem: Bem = buildBem('aui-option');\n\n  private _label: string | TemplateRef<unknown> = '';\n  private _labelContext: unknown = {};\n  private _value: T;\n  private readonly label$$ = new BehaviorSubject(this.label);\n\n  private readonly labelContext$$ = new BehaviorSubject(this.labelContext);\n\n  private readonly value$$ = new BehaviorSubject(this.value);\n\n  @Input()\n  get label() {\n    return this._label;\n  }\n\n  set label(val) {\n    this._label = val;\n    this.label$$.next(val);\n  }\n\n  @Input()\n  get labelContext() {\n    return this._labelContext;\n  }\n\n  set labelContext(val) {\n    this._labelContext = val;\n    this.labelContext$$.next(val);\n  }\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  disabled: boolean;\n\n  @Input()\n  focused: boolean;\n\n  @Input()\n  selected: boolean;\n\n  @HostBinding('class.is-group')\n  @Input()\n  groupTitle: ElementRef;\n\n  @Input()\n  contentTemplate: TemplateRef<any>;\n\n  @ViewChild('elRef', { static: true })\n  elRef: ElementRef<HTMLDivElement>;\n\n  get groupTitlePortal() {\n    return this.groupTitle ? new DomPortal(this.groupTitle) : '';\n  }\n\n  _focused = false;\n  isMulti = false;\n  private readonly select: BaseSelect<T>;\n  size: ComponentSize = ComponentSize.Medium;\n\n  size$: Observable<ComponentSize>;\n\n  constructor(\n    @Inject(forwardRef(() => BaseSelect))\n    select: any, // FIXME: workaround temporarily\n  ) {\n    this.isMulti = select.isMulti;\n    this.select = select;\n    this.size$ = this.select.size$.pipe(\n      tap(size => {\n        this.size = size;\n      }),\n    );\n  }\n\n  ngOnChanges(): void {\n    this.changes.next(null);\n  }\n\n  onClick() {\n    if (this.disabled) {\n      return;\n    }\n    this.select.onOptionClick(this);\n  }\n\n  focus() {\n    console.log(123);\n    if (this.disabled) {\n      return;\n    }\n    this.select.focus(this);\n  }\n\n  blur() {\n    this.select.blur();\n  }\n}\n","<div\n  #elRef\n  *ngIf=\"!groupTitlePortal; else group\"\n  [class]=\"bem.block(size$ | async)\"\n  [class.isDisabled]=\"disabled\"\n  [class.isSelected]=\"selected\"\n  [class.isMulti]=\"isMulti\"\n  [class.isFocused]=\"focused\"\n  (click)=\"onClick()\"\n>\n  <i\n    *ngIf=\"isMulti\"\n    class=\"aui-option__pointer\"\n  >\n    <aui-icon\n      [hidden]=\"!selected\"\n      icon=\"check\"\n    ></aui-icon>\n  </i>\n  <ng-content></ng-content>\n</div>\n\n<ng-template #group>\n  <div class=\"aui-option__group-item\">\n    <ng-container *cdkPortalOutlet=\"groupTitlePortal!\"></ng-container>\n  </div>\n</ng-template>\n"]}
@@ -0,0 +1,46 @@
1
+ import { ChangeDetectionStrategy, Component, Input, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import * as i0 from "@angular/core";
4
+ export class OptionComponent {
5
+ constructor() {
6
+ this.changes = new Subject();
7
+ this.value = null;
8
+ this.disabled = false;
9
+ this.labelContext = {};
10
+ }
11
+ ngOnChanges() {
12
+ this.changes.next(null);
13
+ }
14
+ }
15
+ OptionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: OptionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
16
+ OptionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: OptionComponent, selector: "aui-option", inputs: { label: "label", value: "value", disabled: "disabled", labelContext: "labelContext" }, viewQueries: [{ propertyName: "template", first: true, predicate: TemplateRef, descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: `
17
+ <ng-template>
18
+ <ng-content></ng-content>
19
+ </ng-template>
20
+ `, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
21
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: OptionComponent, decorators: [{
22
+ type: Component,
23
+ args: [{
24
+ selector: 'aui-option',
25
+ encapsulation: ViewEncapsulation.None,
26
+ changeDetection: ChangeDetectionStrategy.OnPush,
27
+ template: `
28
+ <ng-template>
29
+ <ng-content></ng-content>
30
+ </ng-template>
31
+ `,
32
+ preserveWhitespaces: false,
33
+ }]
34
+ }], propDecorators: { template: [{
35
+ type: ViewChild,
36
+ args: [TemplateRef, { static: true }]
37
+ }], label: [{
38
+ type: Input
39
+ }], value: [{
40
+ type: Input
41
+ }], disabled: [{
42
+ type: Input
43
+ }], labelContext: [{
44
+ type: Input
45
+ }] } });
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zZWxlY3Qvb3B0aW9uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFFVCxLQUFLLEVBRUwsV0FBVyxFQUNYLFNBQVMsRUFDVCxpQkFBaUIsR0FDbEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFlL0IsTUFBTSxPQUFPLGVBQWU7SUFYNUI7UUFZRSxZQUFPLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztRQUlmLFVBQUssR0FBTSxJQUFJLENBQUM7UUFDaEIsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUNqQixpQkFBWSxHQUFZLEVBQUUsQ0FBQztLQU9yQztJQUhDLFdBQVc7UUFDVCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMxQixDQUFDOzs0R0FiVSxlQUFlO2dHQUFmLGVBQWUsNExBR2YsV0FBVyxtRkFWWjs7OztHQUlUOzJGQUdVLGVBQWU7a0JBWDNCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFlBQVk7b0JBQ3RCLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO29CQUNyQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsUUFBUSxFQUFFOzs7O0dBSVQ7b0JBQ0QsbUJBQW1CLEVBQUUsS0FBSztpQkFDM0I7OEJBSTJDLFFBQVE7c0JBQWpELFNBQVM7dUJBQUMsV0FBVyxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTtnQkFDL0IsS0FBSztzQkFBYixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFbGVtZW50UmVmLFxuICBJbnB1dCxcbiAgT25DaGFuZ2VzLFxuICBUZW1wbGF0ZVJlZixcbiAgVmlld0NoaWxkLFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IFNlbGVjdE9wdGlvbiB9IGZyb20gJy4vc2VsZWN0LnR5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXVpLW9wdGlvbicsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxuZy10ZW1wbGF0ZT5cbiAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICA8L25nLXRlbXBsYXRlPlxuICBgLFxuICBwcmVzZXJ2ZVdoaXRlc3BhY2VzOiBmYWxzZSxcbn0pXG5leHBvcnQgY2xhc3MgT3B0aW9uQ29tcG9uZW50PFQ+IGltcGxlbWVudHMgT25DaGFuZ2VzIHtcbiAgY2hhbmdlcyA9IG5ldyBTdWJqZWN0KCk7XG5cbiAgQFZpZXdDaGlsZChUZW1wbGF0ZVJlZiwgeyBzdGF0aWM6IHRydWUgfSkgdGVtcGxhdGUhOiBUZW1wbGF0ZVJlZjxhbnk+O1xuICBASW5wdXQoKSBsYWJlbDogU2VsZWN0T3B0aW9uWydsYWJlbCddO1xuICBASW5wdXQoKSB2YWx1ZTogVCA9IG51bGw7XG4gIEBJbnB1dCgpIGRpc2FibGVkID0gZmFsc2U7XG4gIEBJbnB1dCgpIGxhYmVsQ29udGV4dDogdW5rbm93biA9IHt9O1xuXG4gIGdyb3VwVGl0bGU6IEVsZW1lbnRSZWY7XG5cbiAgbmdPbkNoYW5nZXMoKTogdm9pZCB7XG4gICAgdGhpcy5jaGFuZ2VzLm5leHQobnVsbCk7XG4gIH1cbn1cbiJdfQ==
@@ -1,16 +1,19 @@
1
1
  import { ChangeDetectionStrategy, Component, ViewChild, ViewEncapsulation, forwardRef, } from '@angular/core';
2
2
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
- import { combineLatest, of, distinctUntilChanged, map, startWith, switchMap, } from 'rxjs';
3
+ import { combineLatest, map } from 'rxjs';
4
4
  import { coerceString, publishRef } from '../utils';
5
5
  import { BaseSelect } from './base-select';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "../input/input-group/input-group.component";
8
8
  import * as i2 from "../input/input.component";
9
9
  import * as i3 from "../icon/icon.component";
10
- import * as i4 from "./option/option.component";
11
- import * as i5 from "../tooltip/tooltip.directive";
12
- import * as i6 from "../input/helper-directives";
13
- import * as i7 from "@angular/common";
10
+ import * as i4 from "./option-item/option-item.component";
11
+ import * as i5 from "../scrolling/virtual-scroll-viewport.component";
12
+ import * as i6 from "../tooltip/tooltip.directive";
13
+ import * as i7 from "../input/helper-directives";
14
+ import * as i8 from "@angular/common";
15
+ import * as i9 from "../scrolling/fixed-size-virtual-scroll.directive";
16
+ import * as i10 from "../scrolling/virtual-for-of.directive";
14
17
  export class SelectComponent extends BaseSelect {
15
18
  constructor() {
16
19
  super(...arguments);
@@ -23,20 +26,21 @@ export class SelectComponent extends BaseSelect {
23
26
  get containerClass() {
24
27
  return `aui-option-container aui-option-container--${this.size}`;
25
28
  }
26
- ngAfterContentInit() {
27
- super.ngAfterContentInit();
29
+ ngAfterViewInit() {
30
+ super.ngAfterViewInit();
28
31
  this.selectedOption$ = combineLatest([
29
- this.contentOptions.changes.pipe(startWith(this.contentOptions), switchMap(options => combineLatest(options.map(option => option.selected$)).pipe(startWith(null), map(() => options.find(option => option.selected)), distinctUntilChanged(), switchMap(option => option
30
- ? combineLatest([
31
- option.value$,
32
- option.label$,
33
- option.labelContext$,
34
- ]).pipe(map(([value, label, labelContext]) => ({
32
+ this.filterOptions$.pipe(map(options => {
33
+ const selected = options.find(option => option.selected);
34
+ if (!selected) {
35
+ return;
36
+ }
37
+ const { value, label, labelContext } = selected;
38
+ return {
35
39
  value,
36
40
  label,
37
41
  labelContext,
38
- })))
39
- : of(null))))),
42
+ };
43
+ })),
40
44
  this.model$,
41
45
  ]).pipe(map(([option, value]) => option
42
46
  ? {
@@ -85,7 +89,7 @@ SelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", versio
85
89
  provide: BaseSelect,
86
90
  useExisting: SelectComponent,
87
91
  },
88
- ], viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["inputRef"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div\n [class]=\"rootClass\"\n [class.isDisabled]=\"disabled\"\n [class.isClearable]=\"isClearable(hasSelected$ | async)\"\n [class.isFilterable]=\"filterable\"\n [class.isOpened]=\"opened\"\n #selectRef\n #tooltipRef=\"auiTooltip\"\n [auiTooltip]=\"templateRef\"\n [auiTooltipDisabled]=\"disabled\"\n auiTooltipTrigger=\"click\"\n auiTooltipPosition=\"bottom start\"\n auiTooltipType=\"plain\"\n (auiTooltipShow)=\"onShowOptions()\"\n (auiTooltipHide)=\"onHideOptions()\"\n>\n <aui-input-group>\n <input\n #inputRef\n class=\"aui-select__input\"\n autocomplete=\"off\"\n aui-input\n [disabled]=\"disabled\"\n [size]=\"size\"\n [readonly]=\"inputReadonly\"\n [placeholder]=\"!(hasSelected$ | async) ? placeholder : ''\"\n (input)=\"onInput($event)\"\n (keydown)=\"onKeyDown($event)\"\n (blur)=\"closeOption()\"\n />\n <span\n auiInputSuffix\n class=\"aui-select__icon-container\"\n >\n <aui-icon\n class=\"aui-select__indicator\"\n [icon]=\"loading ? 'spinner' : 'caret_down_s'\"\n ></aui-icon>\n <aui-icon\n class=\"aui-select__clear\"\n icon=\"xmark_small\"\n (click)=\"clearValue($event)\"\n ></aui-icon>\n </span>\n <div\n *ngIf=\"(selectedOption$ | async) && !filterString\"\n class=\"aui-select__label-container aui-input aui-input--{{ size }}\"\n [attr.disabled]=\"disabled ? true : null\"\n >\n <div class=\"aui-select__label\">\n <ng-container *ngIf=\"(selectedOption$ | async).label as optionLabel\">\n <ng-container\n *ngIf=\"isTemplateRef(optionLabel); else label\"\n [ngTemplateOutlet]=\"optionLabel\"\n [ngTemplateOutletContext]=\"(selectedOption$ | async).labelContext\"\n ></ng-container>\n <ng-template #label>{{ optionLabel }}</ng-template>\n </ng-container>\n </div>\n </div>\n </aui-input-group>\n</div>\n\n<ng-template #templateRef>\n <div\n [class]=\"containerClass\"\n [style.minWidth]=\"containerWidth\"\n (mousedown)=\"$event.preventDefault()\"\n >\n <div\n #optionListRef\n class=\"aui-option-container__content\"\n >\n <aui-option\n #inputtingOption\n *ngIf=\"allowCreate && filterString && !(hasMatchedOption$ | async)\"\n [value]=\"filterString\"\n >\n {{ filterString }}\n </aui-option>\n <ng-container *ngIf=\"allowCreate\">\n <aui-option\n *ngFor=\"let option of customCreatedOptions$ | async\"\n [label]=\"option.label\"\n [value]=\"option.value\"\n >\n {{ option.label }}\n </aui-option>\n </ng-container>\n <ng-content></ng-content>\n </div>\n <div\n *ngIf=\"\n !(\n (hasVisibleOption$ | async) ||\n (allowCreate && (customCreatedOptions$ | async).length) ||\n (allowCreate && filterString)\n )\n \"\n class=\"aui-option-container__placeholder\"\n >\n <ng-content select=\"aui-option-placeholder\"></ng-content>\n </div>\n </div>\n</ng-template>\n", styles: [".aui-option-container{padding:8px 0;border-radius:var(--aui-border-radius-m);background-color:rgb(var(--aui-color-popper-bg))}:root .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.75)}.aui-option-container__content{max-height:calc(var(--aui-inline-height-m) * 10);position:relative;overflow:auto}.aui-option-container__content::-webkit-scrollbar{width:4px;height:4px}.aui-option-container__content::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-option-container__content::-webkit-scrollbar-corner{background-color:transparent}.aui-option-container__content .divider{border:none;border-top:1px solid rgb(var(--aui-color-n-8))}.aui-option-container__placeholder{color:rgb(var(--aui-color-n-4));font-size:var(--aui-font-size-m);text-align:center}.aui-option-container--small .aui-option-container__content{max-height:calc(var(--aui-inline-height-s) * 10)}.aui-option-container--small .aui-option-container__placeholder{font-size:var(--aui-font-size-s)}.aui-select{display:inline-block;position:relative;width:100%}.aui-select__icon-container{display:block;position:relative}.aui-select.isDisabled .aui-select__icon-container{color:rgb(var(--aui-color-n-4))}.aui-select__clear{display:none}.aui-select__clear .aui-icon{border-radius:50%;color:rgb(var(--aui-color-help-text));cursor:pointer;transition:all .3s ease}.aui-select__clear .aui-icon:hover{color:rgb(var(--aui-color-main-bg));background-color:rgb(var(--aui-color-help-text))}.aui-select.isClearable:not(.isDisabled):hover .aui-select__indicator{display:none}.aui-select.isClearable:not(.isDisabled):hover .aui-select__clear{display:flex}.aui-select__label-container.aui-input{position:absolute;top:0;left:0;display:inline-flex;align-items:center;pointer-events:none;background-color:transparent;border-color:transparent}.aui-select.isFilterable.isOpened .aui-select__label-container.aui-input{color:rgb(var(--aui-color-n-4))}.aui-select__label{width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.aui-select__input.aui-input[readonly]{background-color:rgb(var(--aui-color-main-bg));border-color:rgb(var(--aui-color-n-7))!important;cursor:text}.aui-select__input.aui-input[readonly]:focus{border-color:rgb(var(--aui-color-primary))}.aui-select__input.aui-input[disabled]{background-color:rgb(var(--aui-color-n-8));border-color:rgb(var(--aui-color-n-7))}aui-select.ng-invalid.ng-dirty .aui-input,.ng-submitted aui-select.ng-invalid .aui-input{border-color:rgb(var(--aui-color-red))!important}:root aui-select.ng-invalid.ng-dirty .aui-input:focus,:root aui-select.ng-invalid.ng-dirty .aui-input.isFocused,:root .ng-submitted aui-select.ng-invalid .aui-input:focus,:root .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.16)}html[aui-theme-mode=light] aui-select.ng-invalid.ng-dirty .aui-input:focus,html[aui-theme-mode=light] aui-select.ng-invalid.ng-dirty .aui-input.isFocused,html[aui-theme-mode=light] .ng-submitted aui-select.ng-invalid .aui-input:focus,html[aui-theme-mode=light] .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] aui-select.ng-invalid.ng-dirty .aui-input:focus,html[aui-theme-mode=system] aui-select.ng-invalid.ng-dirty .aui-input.isFocused,html[aui-theme-mode=system] .ng-submitted aui-select.ng-invalid .aui-input:focus,html[aui-theme-mode=system] .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.3)}}html[aui-theme-mode=dark] aui-select.ng-invalid.ng-dirty .aui-input:focus,html[aui-theme-mode=dark] aui-select.ng-invalid.ng-dirty .aui-input.isFocused,html[aui-theme-mode=dark] .ng-submitted aui-select.ng-invalid .aui-input:focus,html[aui-theme-mode=dark] .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.3)}\n"], components: [{ type: i1.InputGroupComponent, selector: "aui-input-group" }, { type: i2.InputComponent, selector: "input[aui-input],textarea[aui-input]", inputs: ["size", "disabled"] }, { type: i3.IconComponent, selector: "aui-icon", inputs: ["icon", "light", "dark", "link", "margin", "size", "color", "background", "backgroundColor"] }, { type: i4.OptionComponent, selector: "aui-option", inputs: ["label", "labelContext", "value", "disabled"] }], directives: [{ type: i5.TooltipDirective, selector: "[auiTooltip]", inputs: ["auiTooltip", "auiTooltipContext", "auiTooltipClass", "auiTooltipType", "auiTooltipPosition", "auiTooltipTrigger", "auiTooltipDisabled", "auiTooltipHideOnClick"], outputs: ["auiTooltipShow", "auiTooltipHide"], exportAs: ["auiTooltip"] }, { type: i6.InputSuffixDirective, selector: "[auiInputSuffix]" }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i7.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
92
+ ], viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["inputRef"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div\n [class]=\"rootClass\"\n [class.isDisabled]=\"disabled\"\n [class.isClearable]=\"isClearable(hasSelected$ | async)\"\n [class.isFilterable]=\"filterable\"\n [class.isOpened]=\"opened\"\n #selectRef\n #tooltipRef=\"auiTooltip\"\n [auiTooltip]=\"templateRef\"\n [auiTooltipDisabled]=\"disabled\"\n auiTooltipTrigger=\"click\"\n auiTooltipPosition=\"bottom start\"\n auiTooltipType=\"plain\"\n (auiTooltipShow)=\"onShowOptions()\"\n (auiTooltipHide)=\"onHideOptions()\"\n>\n <aui-input-group>\n <input\n #inputRef\n class=\"aui-select__input\"\n autocomplete=\"off\"\n aui-input\n [disabled]=\"disabled\"\n [size]=\"size\"\n [readonly]=\"inputReadonly\"\n [placeholder]=\"!(hasSelected$ | async) ? placeholder : ''\"\n (input)=\"onInput($event)\"\n (keydown)=\"onKeyDown($event)\"\n (blur)=\"closeOption()\"\n />\n <span\n auiInputSuffix\n class=\"aui-select__icon-container\"\n >\n <aui-icon\n class=\"aui-select__indicator\"\n [icon]=\"loading ? 'spinner' : 'caret_down_s'\"\n ></aui-icon>\n <aui-icon\n class=\"aui-select__clear\"\n icon=\"xmark_small\"\n (click)=\"clearValue($event)\"\n ></aui-icon>\n </span>\n <div\n *ngIf=\"(selectedOption$ | async) && !filterString\"\n class=\"aui-select__label-container aui-input aui-input--{{ size }}\"\n [attr.disabled]=\"disabled ? true : null\"\n >\n <div class=\"aui-select__label\">\n <ng-container *ngIf=\"(selectedOption$ | async).label as optionLabel\">\n <ng-container\n *ngIf=\"isTemplateRef(optionLabel); else label\"\n [ngTemplateOutlet]=\"optionLabel\"\n [ngTemplateOutletContext]=\"(selectedOption$ | async).labelContext\"\n ></ng-container>\n <ng-template #label>{{ optionLabel }}</ng-template>\n </ng-container>\n </div>\n </div>\n </aui-input-group>\n</div>\n\n<ng-template #templateRef>\n <div\n [class]=\"containerClass\"\n [style.minWidth]=\"containerWidth\"\n (mousedown)=\"$event.preventDefault()\"\n >\n <div\n #optionListRef\n class=\"aui-option-container__content\"\n >\n <ng-container *ngIf=\"!useVirtual; else virtual\">\n <aui-option-item\n *ngFor=\"let item of filterOptions$ | async\"\n [label]=\"item.label\"\n [value]=\"item.value\"\n [selected]=\"item.selected\"\n [disabled]=\"item.disabled\"\n [groupTitle]=\"item.groupTitle\"\n [focused]=\"isFocus(item.value, focused$ | async)\"\n >\n <ng-container *ngIf=\"item.contentTemplate; else normal\">\n <ng-container\n *ngTemplateOutlet=\"\n item.contentTemplate;\n context: item.labelContext\n \"\n ></ng-container>\n </ng-container>\n <ng-template #normal>\n {{ item.label || getLabelByValue(item.value) }}\n </ng-template>\n </aui-option-item>\n </ng-container>\n <ng-template #virtual>\n <aui-virtual-scroll-viewport\n [itemSize]=\"_itemSize\"\n [maxBufferPx]=\"_itemSize * maxItemLength\"\n [minBufferPx]=\"_itemSize * maxItemLength\"\n (scrolledIndexChange)=\"onScrolledIndexChange($event)\"\n [style.height.px]=\"(filterOptions$ | async).length * _itemSize\"\n [style.max-height.px]=\"_itemSize * maxItemLength\"\n >\n <aui-option-item\n *auiVirtualFor=\"let item of filterOptions$ | async\"\n [label]=\"item.label\"\n [value]=\"item.value\"\n [selected]=\"item.selected\"\n [disabled]=\"item.disabled\"\n [labelContext]=\"item.labelContext\"\n [focused]=\"isFocus(item.value, focused$ | async)\"\n >\n <ng-container *ngIf=\"item.contentTemplate; else normal\">\n <ng-container\n *ngTemplateOutlet=\"\n item.contentTemplate;\n context: item.labelContext\n \"\n ></ng-container>\n </ng-container>\n <ng-template #normal>\n {{ item.label || getLabelByValue(item.value) }}\n </ng-template>\n </aui-option-item>\n </aui-virtual-scroll-viewport>\n </ng-template>\n </div>\n <div\n *ngIf=\"\n !((filterOptions$ | async)?.length || (allowCreate && filterString))\n \"\n class=\"aui-option-container__placeholder\"\n >\n <ng-content select=\"aui-option-placeholder\"></ng-content>\n </div>\n </div>\n</ng-template>\n", styles: [".aui-option-container{padding:8px 0;border-radius:var(--aui-border-radius-m);background-color:rgb(var(--aui-color-popper-bg))}:root .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.75)}.aui-option-container .divider{border:none;border-top:1px solid rgb(var(--aui-color-n-8))}.aui-option-container__content{max-height:calc(var(--aui-inline-height-m) * 10);position:relative;overflow:auto}.aui-option-container__content::-webkit-scrollbar{width:4px;height:4px}.aui-option-container__content::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-option-container__content::-webkit-scrollbar-corner{background-color:transparent}.aui-option-container__content aui-virtual-scroll-viewport::-webkit-scrollbar{width:4px;height:4px}.aui-option-container__content aui-virtual-scroll-viewport::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-option-container__content aui-virtual-scroll-viewport::-webkit-scrollbar-corner{background-color:transparent}.aui-option-container__placeholder{color:rgb(var(--aui-color-n-4));font-size:var(--aui-font-size-m);text-align:center}.aui-option-container--large .aui-option-container__content{max-height:calc(var(--aui-inline-height-l) * 10)}.aui-option-container--large .aui-option-container__placeholder{font-size:var(--aui-font-size-l)}.aui-option-container--small .aui-option-container__content{max-height:calc(var(--aui-inline-height-s) * 10)}.aui-option-container--small .aui-option-container__placeholder{font-size:var(--aui-font-size-s)}.aui-option-container--mini .aui-option-container__content{max-height:calc(var(--aui-inline-height-xs) * 10)}.aui-option-container--mini .aui-option-container__placeholder{font-size:var(--aui-font-size-s)}.aui-select{display:inline-block;position:relative;width:100%}.aui-select__icon-container{display:block;position:relative}.aui-select.isDisabled .aui-select__icon-container{color:rgb(var(--aui-color-n-4))}.aui-select__clear{display:none}.aui-select__clear .aui-icon{border-radius:50%;color:rgb(var(--aui-color-help-text));cursor:pointer;transition:all .3s ease}.aui-select__clear .aui-icon:hover{color:rgb(var(--aui-color-main-bg));background-color:rgb(var(--aui-color-help-text))}.aui-select.isClearable:not(.isDisabled):hover .aui-select__indicator{display:none}.aui-select.isClearable:not(.isDisabled):hover .aui-select__clear{display:flex}.aui-select__label-container.aui-input{position:absolute;top:0;left:0;display:inline-flex;align-items:center;pointer-events:none;background-color:transparent;border-color:transparent}.aui-select.isFilterable.isOpened .aui-select__label-container.aui-input{color:rgb(var(--aui-color-n-4))}.aui-select__label{width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.aui-select__input.aui-input[readonly]{background-color:rgb(var(--aui-color-main-bg));border-color:rgb(var(--aui-color-n-7))!important;cursor:text}.aui-select__input.aui-input[readonly]:focus{border-color:rgb(var(--aui-color-primary))}.aui-select__input.aui-input[disabled]{background-color:rgb(var(--aui-color-n-8));border-color:rgb(var(--aui-color-n-7))}aui-select.ng-invalid.ng-dirty .aui-input,.ng-submitted aui-select.ng-invalid .aui-input{border-color:rgb(var(--aui-color-red))!important}:root aui-select.ng-invalid.ng-dirty .aui-input:focus,:root aui-select.ng-invalid.ng-dirty .aui-input.isFocused,:root .ng-submitted aui-select.ng-invalid .aui-input:focus,:root .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.16)}html[aui-theme-mode=light] aui-select.ng-invalid.ng-dirty .aui-input:focus,html[aui-theme-mode=light] aui-select.ng-invalid.ng-dirty .aui-input.isFocused,html[aui-theme-mode=light] .ng-submitted aui-select.ng-invalid .aui-input:focus,html[aui-theme-mode=light] .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] aui-select.ng-invalid.ng-dirty .aui-input:focus,html[aui-theme-mode=system] aui-select.ng-invalid.ng-dirty .aui-input.isFocused,html[aui-theme-mode=system] .ng-submitted aui-select.ng-invalid .aui-input:focus,html[aui-theme-mode=system] .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.3)}}html[aui-theme-mode=dark] aui-select.ng-invalid.ng-dirty .aui-input:focus,html[aui-theme-mode=dark] aui-select.ng-invalid.ng-dirty .aui-input.isFocused,html[aui-theme-mode=dark] .ng-submitted aui-select.ng-invalid .aui-input:focus,html[aui-theme-mode=dark] .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.3)}\n"], components: [{ type: i1.InputGroupComponent, selector: "aui-input-group" }, { type: i2.InputComponent, selector: "input[aui-input],textarea[aui-input]", inputs: ["size", "disabled"] }, { type: i3.IconComponent, selector: "aui-icon", inputs: ["icon", "light", "dark", "link", "margin", "size", "color", "background", "backgroundColor"] }, { type: i4.OptionItemComponent, selector: "aui-option-item", inputs: ["label", "labelContext", "value", "disabled", "focused", "selected", "groupTitle", "contentTemplate"] }, { type: i5.VirtualScrollViewportComponent, selector: "aui-virtual-scroll-viewport" }], directives: [{ type: i6.TooltipDirective, selector: "[auiTooltip]", inputs: ["auiTooltip", "auiTooltipContext", "auiTooltipClass", "auiTooltipType", "auiTooltipPosition", "auiTooltipTrigger", "auiTooltipDisabled", "auiTooltipHideOnClick"], outputs: ["auiTooltipShow", "auiTooltipHide"], exportAs: ["auiTooltip"] }, { type: i7.InputSuffixDirective, selector: "[auiInputSuffix]" }, { type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i9.FixedSizeVirtualScrollDirective, selector: "aui-virtual-scroll-viewport[itemSize]" }, { type: i10.VirtualForOfDirective, selector: "[auiVirtualFor][auiVirtualForOf]", inputs: ["auiVirtualForOf", "auiVirtualForTrackBy", "auiVirtualForTemplate", "auiVirtualForTemplateCacheSize"] }], pipes: { "async": i8.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
89
93
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: SelectComponent, decorators: [{
90
94
  type: Component,
91
95
  args: [{ selector: 'aui-select', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, preserveWhitespaces: false, providers: [
@@ -98,9 +102,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
98
102
  provide: BaseSelect,
99
103
  useExisting: SelectComponent,
100
104
  },
101
- ], template: "<div\n [class]=\"rootClass\"\n [class.isDisabled]=\"disabled\"\n [class.isClearable]=\"isClearable(hasSelected$ | async)\"\n [class.isFilterable]=\"filterable\"\n [class.isOpened]=\"opened\"\n #selectRef\n #tooltipRef=\"auiTooltip\"\n [auiTooltip]=\"templateRef\"\n [auiTooltipDisabled]=\"disabled\"\n auiTooltipTrigger=\"click\"\n auiTooltipPosition=\"bottom start\"\n auiTooltipType=\"plain\"\n (auiTooltipShow)=\"onShowOptions()\"\n (auiTooltipHide)=\"onHideOptions()\"\n>\n <aui-input-group>\n <input\n #inputRef\n class=\"aui-select__input\"\n autocomplete=\"off\"\n aui-input\n [disabled]=\"disabled\"\n [size]=\"size\"\n [readonly]=\"inputReadonly\"\n [placeholder]=\"!(hasSelected$ | async) ? placeholder : ''\"\n (input)=\"onInput($event)\"\n (keydown)=\"onKeyDown($event)\"\n (blur)=\"closeOption()\"\n />\n <span\n auiInputSuffix\n class=\"aui-select__icon-container\"\n >\n <aui-icon\n class=\"aui-select__indicator\"\n [icon]=\"loading ? 'spinner' : 'caret_down_s'\"\n ></aui-icon>\n <aui-icon\n class=\"aui-select__clear\"\n icon=\"xmark_small\"\n (click)=\"clearValue($event)\"\n ></aui-icon>\n </span>\n <div\n *ngIf=\"(selectedOption$ | async) && !filterString\"\n class=\"aui-select__label-container aui-input aui-input--{{ size }}\"\n [attr.disabled]=\"disabled ? true : null\"\n >\n <div class=\"aui-select__label\">\n <ng-container *ngIf=\"(selectedOption$ | async).label as optionLabel\">\n <ng-container\n *ngIf=\"isTemplateRef(optionLabel); else label\"\n [ngTemplateOutlet]=\"optionLabel\"\n [ngTemplateOutletContext]=\"(selectedOption$ | async).labelContext\"\n ></ng-container>\n <ng-template #label>{{ optionLabel }}</ng-template>\n </ng-container>\n </div>\n </div>\n </aui-input-group>\n</div>\n\n<ng-template #templateRef>\n <div\n [class]=\"containerClass\"\n [style.minWidth]=\"containerWidth\"\n (mousedown)=\"$event.preventDefault()\"\n >\n <div\n #optionListRef\n class=\"aui-option-container__content\"\n >\n <aui-option\n #inputtingOption\n *ngIf=\"allowCreate && filterString && !(hasMatchedOption$ | async)\"\n [value]=\"filterString\"\n >\n {{ filterString }}\n </aui-option>\n <ng-container *ngIf=\"allowCreate\">\n <aui-option\n *ngFor=\"let option of customCreatedOptions$ | async\"\n [label]=\"option.label\"\n [value]=\"option.value\"\n >\n {{ option.label }}\n </aui-option>\n </ng-container>\n <ng-content></ng-content>\n </div>\n <div\n *ngIf=\"\n !(\n (hasVisibleOption$ | async) ||\n (allowCreate && (customCreatedOptions$ | async).length) ||\n (allowCreate && filterString)\n )\n \"\n class=\"aui-option-container__placeholder\"\n >\n <ng-content select=\"aui-option-placeholder\"></ng-content>\n </div>\n </div>\n</ng-template>\n", styles: [".aui-option-container{padding:8px 0;border-radius:var(--aui-border-radius-m);background-color:rgb(var(--aui-color-popper-bg))}:root .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.75)}.aui-option-container__content{max-height:calc(var(--aui-inline-height-m) * 10);position:relative;overflow:auto}.aui-option-container__content::-webkit-scrollbar{width:4px;height:4px}.aui-option-container__content::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-option-container__content::-webkit-scrollbar-corner{background-color:transparent}.aui-option-container__content .divider{border:none;border-top:1px solid rgb(var(--aui-color-n-8))}.aui-option-container__placeholder{color:rgb(var(--aui-color-n-4));font-size:var(--aui-font-size-m);text-align:center}.aui-option-container--small .aui-option-container__content{max-height:calc(var(--aui-inline-height-s) * 10)}.aui-option-container--small .aui-option-container__placeholder{font-size:var(--aui-font-size-s)}.aui-select{display:inline-block;position:relative;width:100%}.aui-select__icon-container{display:block;position:relative}.aui-select.isDisabled .aui-select__icon-container{color:rgb(var(--aui-color-n-4))}.aui-select__clear{display:none}.aui-select__clear .aui-icon{border-radius:50%;color:rgb(var(--aui-color-help-text));cursor:pointer;transition:all .3s ease}.aui-select__clear .aui-icon:hover{color:rgb(var(--aui-color-main-bg));background-color:rgb(var(--aui-color-help-text))}.aui-select.isClearable:not(.isDisabled):hover .aui-select__indicator{display:none}.aui-select.isClearable:not(.isDisabled):hover .aui-select__clear{display:flex}.aui-select__label-container.aui-input{position:absolute;top:0;left:0;display:inline-flex;align-items:center;pointer-events:none;background-color:transparent;border-color:transparent}.aui-select.isFilterable.isOpened .aui-select__label-container.aui-input{color:rgb(var(--aui-color-n-4))}.aui-select__label{width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.aui-select__input.aui-input[readonly]{background-color:rgb(var(--aui-color-main-bg));border-color:rgb(var(--aui-color-n-7))!important;cursor:text}.aui-select__input.aui-input[readonly]:focus{border-color:rgb(var(--aui-color-primary))}.aui-select__input.aui-input[disabled]{background-color:rgb(var(--aui-color-n-8));border-color:rgb(var(--aui-color-n-7))}aui-select.ng-invalid.ng-dirty .aui-input,.ng-submitted aui-select.ng-invalid .aui-input{border-color:rgb(var(--aui-color-red))!important}:root aui-select.ng-invalid.ng-dirty .aui-input:focus,:root aui-select.ng-invalid.ng-dirty .aui-input.isFocused,:root .ng-submitted aui-select.ng-invalid .aui-input:focus,:root .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.16)}html[aui-theme-mode=light] aui-select.ng-invalid.ng-dirty .aui-input:focus,html[aui-theme-mode=light] aui-select.ng-invalid.ng-dirty .aui-input.isFocused,html[aui-theme-mode=light] .ng-submitted aui-select.ng-invalid .aui-input:focus,html[aui-theme-mode=light] .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] aui-select.ng-invalid.ng-dirty .aui-input:focus,html[aui-theme-mode=system] aui-select.ng-invalid.ng-dirty .aui-input.isFocused,html[aui-theme-mode=system] .ng-submitted aui-select.ng-invalid .aui-input:focus,html[aui-theme-mode=system] .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.3)}}html[aui-theme-mode=dark] aui-select.ng-invalid.ng-dirty .aui-input:focus,html[aui-theme-mode=dark] aui-select.ng-invalid.ng-dirty .aui-input.isFocused,html[aui-theme-mode=dark] .ng-submitted aui-select.ng-invalid .aui-input:focus,html[aui-theme-mode=dark] .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.3)}\n"] }]
105
+ ], template: "<div\n [class]=\"rootClass\"\n [class.isDisabled]=\"disabled\"\n [class.isClearable]=\"isClearable(hasSelected$ | async)\"\n [class.isFilterable]=\"filterable\"\n [class.isOpened]=\"opened\"\n #selectRef\n #tooltipRef=\"auiTooltip\"\n [auiTooltip]=\"templateRef\"\n [auiTooltipDisabled]=\"disabled\"\n auiTooltipTrigger=\"click\"\n auiTooltipPosition=\"bottom start\"\n auiTooltipType=\"plain\"\n (auiTooltipShow)=\"onShowOptions()\"\n (auiTooltipHide)=\"onHideOptions()\"\n>\n <aui-input-group>\n <input\n #inputRef\n class=\"aui-select__input\"\n autocomplete=\"off\"\n aui-input\n [disabled]=\"disabled\"\n [size]=\"size\"\n [readonly]=\"inputReadonly\"\n [placeholder]=\"!(hasSelected$ | async) ? placeholder : ''\"\n (input)=\"onInput($event)\"\n (keydown)=\"onKeyDown($event)\"\n (blur)=\"closeOption()\"\n />\n <span\n auiInputSuffix\n class=\"aui-select__icon-container\"\n >\n <aui-icon\n class=\"aui-select__indicator\"\n [icon]=\"loading ? 'spinner' : 'caret_down_s'\"\n ></aui-icon>\n <aui-icon\n class=\"aui-select__clear\"\n icon=\"xmark_small\"\n (click)=\"clearValue($event)\"\n ></aui-icon>\n </span>\n <div\n *ngIf=\"(selectedOption$ | async) && !filterString\"\n class=\"aui-select__label-container aui-input aui-input--{{ size }}\"\n [attr.disabled]=\"disabled ? true : null\"\n >\n <div class=\"aui-select__label\">\n <ng-container *ngIf=\"(selectedOption$ | async).label as optionLabel\">\n <ng-container\n *ngIf=\"isTemplateRef(optionLabel); else label\"\n [ngTemplateOutlet]=\"optionLabel\"\n [ngTemplateOutletContext]=\"(selectedOption$ | async).labelContext\"\n ></ng-container>\n <ng-template #label>{{ optionLabel }}</ng-template>\n </ng-container>\n </div>\n </div>\n </aui-input-group>\n</div>\n\n<ng-template #templateRef>\n <div\n [class]=\"containerClass\"\n [style.minWidth]=\"containerWidth\"\n (mousedown)=\"$event.preventDefault()\"\n >\n <div\n #optionListRef\n class=\"aui-option-container__content\"\n >\n <ng-container *ngIf=\"!useVirtual; else virtual\">\n <aui-option-item\n *ngFor=\"let item of filterOptions$ | async\"\n [label]=\"item.label\"\n [value]=\"item.value\"\n [selected]=\"item.selected\"\n [disabled]=\"item.disabled\"\n [groupTitle]=\"item.groupTitle\"\n [focused]=\"isFocus(item.value, focused$ | async)\"\n >\n <ng-container *ngIf=\"item.contentTemplate; else normal\">\n <ng-container\n *ngTemplateOutlet=\"\n item.contentTemplate;\n context: item.labelContext\n \"\n ></ng-container>\n </ng-container>\n <ng-template #normal>\n {{ item.label || getLabelByValue(item.value) }}\n </ng-template>\n </aui-option-item>\n </ng-container>\n <ng-template #virtual>\n <aui-virtual-scroll-viewport\n [itemSize]=\"_itemSize\"\n [maxBufferPx]=\"_itemSize * maxItemLength\"\n [minBufferPx]=\"_itemSize * maxItemLength\"\n (scrolledIndexChange)=\"onScrolledIndexChange($event)\"\n [style.height.px]=\"(filterOptions$ | async).length * _itemSize\"\n [style.max-height.px]=\"_itemSize * maxItemLength\"\n >\n <aui-option-item\n *auiVirtualFor=\"let item of filterOptions$ | async\"\n [label]=\"item.label\"\n [value]=\"item.value\"\n [selected]=\"item.selected\"\n [disabled]=\"item.disabled\"\n [labelContext]=\"item.labelContext\"\n [focused]=\"isFocus(item.value, focused$ | async)\"\n >\n <ng-container *ngIf=\"item.contentTemplate; else normal\">\n <ng-container\n *ngTemplateOutlet=\"\n item.contentTemplate;\n context: item.labelContext\n \"\n ></ng-container>\n </ng-container>\n <ng-template #normal>\n {{ item.label || getLabelByValue(item.value) }}\n </ng-template>\n </aui-option-item>\n </aui-virtual-scroll-viewport>\n </ng-template>\n </div>\n <div\n *ngIf=\"\n !((filterOptions$ | async)?.length || (allowCreate && filterString))\n \"\n class=\"aui-option-container__placeholder\"\n >\n <ng-content select=\"aui-option-placeholder\"></ng-content>\n </div>\n </div>\n</ng-template>\n", styles: [".aui-option-container{padding:8px 0;border-radius:var(--aui-border-radius-m);background-color:rgb(var(--aui-color-popper-bg))}:root .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .aui-option-container{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.75)}.aui-option-container .divider{border:none;border-top:1px solid rgb(var(--aui-color-n-8))}.aui-option-container__content{max-height:calc(var(--aui-inline-height-m) * 10);position:relative;overflow:auto}.aui-option-container__content::-webkit-scrollbar{width:4px;height:4px}.aui-option-container__content::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-option-container__content::-webkit-scrollbar-corner{background-color:transparent}.aui-option-container__content aui-virtual-scroll-viewport::-webkit-scrollbar{width:4px;height:4px}.aui-option-container__content aui-virtual-scroll-viewport::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-option-container__content aui-virtual-scroll-viewport::-webkit-scrollbar-corner{background-color:transparent}.aui-option-container__placeholder{color:rgb(var(--aui-color-n-4));font-size:var(--aui-font-size-m);text-align:center}.aui-option-container--large .aui-option-container__content{max-height:calc(var(--aui-inline-height-l) * 10)}.aui-option-container--large .aui-option-container__placeholder{font-size:var(--aui-font-size-l)}.aui-option-container--small .aui-option-container__content{max-height:calc(var(--aui-inline-height-s) * 10)}.aui-option-container--small .aui-option-container__placeholder{font-size:var(--aui-font-size-s)}.aui-option-container--mini .aui-option-container__content{max-height:calc(var(--aui-inline-height-xs) * 10)}.aui-option-container--mini .aui-option-container__placeholder{font-size:var(--aui-font-size-s)}.aui-select{display:inline-block;position:relative;width:100%}.aui-select__icon-container{display:block;position:relative}.aui-select.isDisabled .aui-select__icon-container{color:rgb(var(--aui-color-n-4))}.aui-select__clear{display:none}.aui-select__clear .aui-icon{border-radius:50%;color:rgb(var(--aui-color-help-text));cursor:pointer;transition:all .3s ease}.aui-select__clear .aui-icon:hover{color:rgb(var(--aui-color-main-bg));background-color:rgb(var(--aui-color-help-text))}.aui-select.isClearable:not(.isDisabled):hover .aui-select__indicator{display:none}.aui-select.isClearable:not(.isDisabled):hover .aui-select__clear{display:flex}.aui-select__label-container.aui-input{position:absolute;top:0;left:0;display:inline-flex;align-items:center;pointer-events:none;background-color:transparent;border-color:transparent}.aui-select.isFilterable.isOpened .aui-select__label-container.aui-input{color:rgb(var(--aui-color-n-4))}.aui-select__label{width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.aui-select__input.aui-input[readonly]{background-color:rgb(var(--aui-color-main-bg));border-color:rgb(var(--aui-color-n-7))!important;cursor:text}.aui-select__input.aui-input[readonly]:focus{border-color:rgb(var(--aui-color-primary))}.aui-select__input.aui-input[disabled]{background-color:rgb(var(--aui-color-n-8));border-color:rgb(var(--aui-color-n-7))}aui-select.ng-invalid.ng-dirty .aui-input,.ng-submitted aui-select.ng-invalid .aui-input{border-color:rgb(var(--aui-color-red))!important}:root aui-select.ng-invalid.ng-dirty .aui-input:focus,:root aui-select.ng-invalid.ng-dirty .aui-input.isFocused,:root .ng-submitted aui-select.ng-invalid .aui-input:focus,:root .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.16)}html[aui-theme-mode=light] aui-select.ng-invalid.ng-dirty .aui-input:focus,html[aui-theme-mode=light] aui-select.ng-invalid.ng-dirty .aui-input.isFocused,html[aui-theme-mode=light] .ng-submitted aui-select.ng-invalid .aui-input:focus,html[aui-theme-mode=light] .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] aui-select.ng-invalid.ng-dirty .aui-input:focus,html[aui-theme-mode=system] aui-select.ng-invalid.ng-dirty .aui-input.isFocused,html[aui-theme-mode=system] .ng-submitted aui-select.ng-invalid .aui-input:focus,html[aui-theme-mode=system] .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.3)}}html[aui-theme-mode=dark] aui-select.ng-invalid.ng-dirty .aui-input:focus,html[aui-theme-mode=dark] aui-select.ng-invalid.ng-dirty .aui-input.isFocused,html[aui-theme-mode=dark] .ng-submitted aui-select.ng-invalid .aui-input:focus,html[aui-theme-mode=dark] .ng-submitted aui-select.ng-invalid .aui-input.isFocused{box-shadow:0 0 0 2px rgba(var(--aui-color-red),.3)}\n"] }]
102
106
  }], propDecorators: { inputRef: [{
103
107
  type: ViewChild,
104
108
  args: ['inputRef', { static: true }]
105
109
  }] } });
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../src/select/select.component.ts","../../../src/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  QueryList,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport {\n  Observable,\n  combineLatest,\n  of,\n  distinctUntilChanged,\n  map,\n  startWith,\n  switchMap,\n} from 'rxjs';\n\nimport { InputComponent } from '../input';\nimport { coerceString, publishRef } from '../utils';\n\nimport { BaseSelect } from './base-select';\nimport { OptionComponent } from './option/option.component';\nimport { SelectOption } from './select.types';\n\n@Component({\n  selector: 'aui-select',\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SelectComponent),\n      multi: true,\n    },\n    {\n      provide: BaseSelect,\n      useExisting: SelectComponent,\n    },\n  ],\n})\nexport class SelectComponent<T = unknown>\n  extends BaseSelect<T>\n  implements AfterContentInit\n{\n  @ViewChild('inputRef', { static: true })\n  inputRef: InputComponent;\n\n  values$ = this.model$.asObservable().pipe(map(val => [val]));\n\n  selectedOption$: Observable<SelectOption>;\n\n  hasSelected$: Observable<boolean>;\n\n  get rootClass() {\n    return `aui-select aui-select--${this.size}`;\n  }\n\n  get containerClass() {\n    return `aui-option-container aui-option-container--${this.size}`;\n  }\n\n  isClearable = (hasSelected: boolean) =>\n    !this.disabled && this.clearable && hasSelected;\n\n  override ngAfterContentInit() {\n    super.ngAfterContentInit();\n\n    this.selectedOption$ = combineLatest([\n      (\n        this.contentOptions.changes as Observable<QueryList<OptionComponent<T>>>\n      ).pipe(\n        startWith(this.contentOptions),\n        switchMap(options =>\n          combineLatest(options.map(option => option.selected$)).pipe(\n            startWith(null as void),\n            map(() => options.find(option => option.selected)),\n            distinctUntilChanged(),\n            switchMap(option =>\n              option\n                ? combineLatest([\n                    option.value$,\n                    option.label$,\n                    option.labelContext$,\n                  ]).pipe(\n                    map(([value, label, labelContext]) => ({\n                      value,\n                      label,\n                      labelContext,\n                    })),\n                  )\n                : of(null as void),\n            ),\n          ),\n        ),\n      ),\n      this.model$,\n    ]).pipe(\n      map(([option, value]) =>\n        option\n          ? {\n              label:\n                option.label ||\n                this.labelFn?.(option.value) ||\n                coerceString(this.trackFn(option.value)),\n              // https://github.com/angular/angular/issues/24515\n              labelContext: {\n                ...(option.labelContext as Record<string, unknown>),\n              },\n            }\n          : {\n              label: this.labelFn?.(value) || coerceString(this.trackFn(value)),\n            },\n      ),\n      publishRef(),\n    );\n\n    this.hasSelected$ = this.selectedOption$.pipe(\n      map(({ label }) => !!label),\n      publishRef(),\n    );\n  }\n\n  override onShowOptions() {\n    super.onShowOptions();\n  }\n\n  override onHideOptions() {\n    super.onHideOptions();\n    this.inputRef.elementRef.nativeElement.value = '';\n  }\n\n  protected override valueIn(v: T): T {\n    this.closeOption();\n    return v;\n  }\n\n  selectOption(option: OptionComponent<T>) {\n    this.emitValue(option.value);\n    this.closeOption();\n  }\n\n  clearValue(event: Event) {\n    this.emitValue(null);\n    event.stopPropagation();\n    event.preventDefault();\n  }\n}\n","<div\n  [class]=\"rootClass\"\n  [class.isDisabled]=\"disabled\"\n  [class.isClearable]=\"isClearable(hasSelected$ | async)\"\n  [class.isFilterable]=\"filterable\"\n  [class.isOpened]=\"opened\"\n  #selectRef\n  #tooltipRef=\"auiTooltip\"\n  [auiTooltip]=\"templateRef\"\n  [auiTooltipDisabled]=\"disabled\"\n  auiTooltipTrigger=\"click\"\n  auiTooltipPosition=\"bottom start\"\n  auiTooltipType=\"plain\"\n  (auiTooltipShow)=\"onShowOptions()\"\n  (auiTooltipHide)=\"onHideOptions()\"\n>\n  <aui-input-group>\n    <input\n      #inputRef\n      class=\"aui-select__input\"\n      autocomplete=\"off\"\n      aui-input\n      [disabled]=\"disabled\"\n      [size]=\"size\"\n      [readonly]=\"inputReadonly\"\n      [placeholder]=\"!(hasSelected$ | async) ? placeholder : ''\"\n      (input)=\"onInput($event)\"\n      (keydown)=\"onKeyDown($event)\"\n      (blur)=\"closeOption()\"\n    />\n    <span\n      auiInputSuffix\n      class=\"aui-select__icon-container\"\n    >\n      <aui-icon\n        class=\"aui-select__indicator\"\n        [icon]=\"loading ? 'spinner' : 'caret_down_s'\"\n      ></aui-icon>\n      <aui-icon\n        class=\"aui-select__clear\"\n        icon=\"xmark_small\"\n        (click)=\"clearValue($event)\"\n      ></aui-icon>\n    </span>\n    <div\n      *ngIf=\"(selectedOption$ | async) && !filterString\"\n      class=\"aui-select__label-container aui-input aui-input--{{ size }}\"\n      [attr.disabled]=\"disabled ? true : null\"\n    >\n      <div class=\"aui-select__label\">\n        <ng-container *ngIf=\"(selectedOption$ | async).label as optionLabel\">\n          <ng-container\n            *ngIf=\"isTemplateRef(optionLabel); else label\"\n            [ngTemplateOutlet]=\"optionLabel\"\n            [ngTemplateOutletContext]=\"(selectedOption$ | async).labelContext\"\n          ></ng-container>\n          <ng-template #label>{{ optionLabel }}</ng-template>\n        </ng-container>\n      </div>\n    </div>\n  </aui-input-group>\n</div>\n\n<ng-template #templateRef>\n  <div\n    [class]=\"containerClass\"\n    [style.minWidth]=\"containerWidth\"\n    (mousedown)=\"$event.preventDefault()\"\n  >\n    <div\n      #optionListRef\n      class=\"aui-option-container__content\"\n    >\n      <aui-option\n        #inputtingOption\n        *ngIf=\"allowCreate && filterString && !(hasMatchedOption$ | async)\"\n        [value]=\"filterString\"\n      >\n        {{ filterString }}\n      </aui-option>\n      <ng-container *ngIf=\"allowCreate\">\n        <aui-option\n          *ngFor=\"let option of customCreatedOptions$ | async\"\n          [label]=\"option.label\"\n          [value]=\"option.value\"\n        >\n          {{ option.label }}\n        </aui-option>\n      </ng-container>\n      <ng-content></ng-content>\n    </div>\n    <div\n      *ngIf=\"\n        !(\n          (hasVisibleOption$ | async) ||\n          (allowCreate && (customCreatedOptions$ | async).length) ||\n          (allowCreate && filterString)\n        )\n      \"\n      class=\"aui-option-container__placeholder\"\n    >\n      <ng-content select=\"aui-option-placeholder\"></ng-content>\n    </div>\n  </div>\n</ng-template>\n"]}
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../src/select/select.component.ts","../../../src/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n  AfterViewInit,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Observable, combineLatest, map } from 'rxjs';\n\nimport { InputComponent } from '../input';\nimport { coerceString, publishRef } from '../utils';\n\nimport { BaseSelect } from './base-select';\nimport { OptionItemComponent } from './option-item/option-item.component';\nimport { SelectOption } from './select.types';\n\n@Component({\n  selector: 'aui-select',\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SelectComponent),\n      multi: true,\n    },\n    {\n      provide: BaseSelect,\n      useExisting: SelectComponent,\n    },\n  ],\n})\nexport class SelectComponent<T = unknown>\n  extends BaseSelect<T>\n  implements AfterViewInit\n{\n  @ViewChild('inputRef', { static: true })\n  inputRef: InputComponent;\n\n  values$ = this.model$.asObservable().pipe(map(val => [val]));\n\n  selectedOption$: Observable<SelectOption>;\n\n  hasSelected$: Observable<boolean>;\n\n  get rootClass() {\n    return `aui-select aui-select--${this.size}`;\n  }\n\n  get containerClass() {\n    return `aui-option-container aui-option-container--${this.size}`;\n  }\n\n  isClearable = (hasSelected: boolean) =>\n    !this.disabled && this.clearable && hasSelected;\n\n  override ngAfterViewInit() {\n    super.ngAfterViewInit();\n\n    this.selectedOption$ = combineLatest([\n      this.filterOptions$.pipe(\n        map(options => {\n          const selected = options.find(option => option.selected);\n          if (!selected) {\n            return;\n          }\n          const { value, label, labelContext } = selected;\n          return {\n            value,\n            label,\n            labelContext,\n          };\n        }),\n      ),\n      this.model$,\n    ]).pipe(\n      map(([option, value]) =>\n        option\n          ? {\n              label:\n                option.label ||\n                this.labelFn?.(option.value) ||\n                coerceString(this.trackFn(option.value)),\n              // https://github.com/angular/angular/issues/24515\n              labelContext: {\n                ...(option.labelContext as Record<string, unknown>),\n              },\n            }\n          : {\n              label: this.labelFn?.(value) || coerceString(this.trackFn(value)),\n            },\n      ),\n      publishRef(),\n    );\n\n    this.hasSelected$ = this.selectedOption$.pipe(\n      map(({ label }) => !!label),\n      publishRef(),\n    );\n  }\n\n  override onShowOptions() {\n    super.onShowOptions();\n  }\n\n  override onHideOptions() {\n    super.onHideOptions();\n    this.inputRef.elementRef.nativeElement.value = '';\n  }\n\n  protected override valueIn(v: T): T {\n    this.closeOption();\n    return v;\n  }\n\n  selectOption(option: OptionItemComponent<T>) {\n    this.emitValue(option.value);\n    this.closeOption();\n  }\n\n  clearValue(event: Event) {\n    this.emitValue(null);\n    event.stopPropagation();\n    event.preventDefault();\n  }\n}\n","<div\n  [class]=\"rootClass\"\n  [class.isDisabled]=\"disabled\"\n  [class.isClearable]=\"isClearable(hasSelected$ | async)\"\n  [class.isFilterable]=\"filterable\"\n  [class.isOpened]=\"opened\"\n  #selectRef\n  #tooltipRef=\"auiTooltip\"\n  [auiTooltip]=\"templateRef\"\n  [auiTooltipDisabled]=\"disabled\"\n  auiTooltipTrigger=\"click\"\n  auiTooltipPosition=\"bottom start\"\n  auiTooltipType=\"plain\"\n  (auiTooltipShow)=\"onShowOptions()\"\n  (auiTooltipHide)=\"onHideOptions()\"\n>\n  <aui-input-group>\n    <input\n      #inputRef\n      class=\"aui-select__input\"\n      autocomplete=\"off\"\n      aui-input\n      [disabled]=\"disabled\"\n      [size]=\"size\"\n      [readonly]=\"inputReadonly\"\n      [placeholder]=\"!(hasSelected$ | async) ? placeholder : ''\"\n      (input)=\"onInput($event)\"\n      (keydown)=\"onKeyDown($event)\"\n      (blur)=\"closeOption()\"\n    />\n    <span\n      auiInputSuffix\n      class=\"aui-select__icon-container\"\n    >\n      <aui-icon\n        class=\"aui-select__indicator\"\n        [icon]=\"loading ? 'spinner' : 'caret_down_s'\"\n      ></aui-icon>\n      <aui-icon\n        class=\"aui-select__clear\"\n        icon=\"xmark_small\"\n        (click)=\"clearValue($event)\"\n      ></aui-icon>\n    </span>\n    <div\n      *ngIf=\"(selectedOption$ | async) && !filterString\"\n      class=\"aui-select__label-container aui-input aui-input--{{ size }}\"\n      [attr.disabled]=\"disabled ? true : null\"\n    >\n      <div class=\"aui-select__label\">\n        <ng-container *ngIf=\"(selectedOption$ | async).label as optionLabel\">\n          <ng-container\n            *ngIf=\"isTemplateRef(optionLabel); else label\"\n            [ngTemplateOutlet]=\"optionLabel\"\n            [ngTemplateOutletContext]=\"(selectedOption$ | async).labelContext\"\n          ></ng-container>\n          <ng-template #label>{{ optionLabel }}</ng-template>\n        </ng-container>\n      </div>\n    </div>\n  </aui-input-group>\n</div>\n\n<ng-template #templateRef>\n  <div\n    [class]=\"containerClass\"\n    [style.minWidth]=\"containerWidth\"\n    (mousedown)=\"$event.preventDefault()\"\n  >\n    <div\n      #optionListRef\n      class=\"aui-option-container__content\"\n    >\n      <ng-container *ngIf=\"!useVirtual; else virtual\">\n        <aui-option-item\n          *ngFor=\"let item of filterOptions$ | async\"\n          [label]=\"item.label\"\n          [value]=\"item.value\"\n          [selected]=\"item.selected\"\n          [disabled]=\"item.disabled\"\n          [groupTitle]=\"item.groupTitle\"\n          [focused]=\"isFocus(item.value, focused$ | async)\"\n        >\n          <ng-container *ngIf=\"item.contentTemplate; else normal\">\n            <ng-container\n              *ngTemplateOutlet=\"\n                item.contentTemplate;\n                context: item.labelContext\n              \"\n            ></ng-container>\n          </ng-container>\n          <ng-template #normal>\n            {{ item.label || getLabelByValue(item.value) }}\n          </ng-template>\n        </aui-option-item>\n      </ng-container>\n      <ng-template #virtual>\n        <aui-virtual-scroll-viewport\n          [itemSize]=\"_itemSize\"\n          [maxBufferPx]=\"_itemSize * maxItemLength\"\n          [minBufferPx]=\"_itemSize * maxItemLength\"\n          (scrolledIndexChange)=\"onScrolledIndexChange($event)\"\n          [style.height.px]=\"(filterOptions$ | async).length * _itemSize\"\n          [style.max-height.px]=\"_itemSize * maxItemLength\"\n        >\n          <aui-option-item\n            *auiVirtualFor=\"let item of filterOptions$ | async\"\n            [label]=\"item.label\"\n            [value]=\"item.value\"\n            [selected]=\"item.selected\"\n            [disabled]=\"item.disabled\"\n            [labelContext]=\"item.labelContext\"\n            [focused]=\"isFocus(item.value, focused$ | async)\"\n          >\n            <ng-container *ngIf=\"item.contentTemplate; else normal\">\n              <ng-container\n                *ngTemplateOutlet=\"\n                  item.contentTemplate;\n                  context: item.labelContext\n                \"\n              ></ng-container>\n            </ng-container>\n            <ng-template #normal>\n              {{ item.label || getLabelByValue(item.value) }}\n            </ng-template>\n          </aui-option-item>\n        </aui-virtual-scroll-viewport>\n      </ng-template>\n    </div>\n    <div\n      *ngIf=\"\n        !((filterOptions$ | async)?.length || (allowCreate && filterString))\n      \"\n      class=\"aui-option-container__placeholder\"\n    >\n      <ng-content select=\"aui-option-placeholder\"></ng-content>\n    </div>\n  </div>\n</ng-template>\n"]}
@@ -1,15 +1,18 @@
1
+ import { PortalModule } from '@angular/cdk/portal';
1
2
  import { CommonModule } from '@angular/common';
2
3
  import { NgModule } from '@angular/core';
3
4
  import { I18nModule } from '../i18n';
4
5
  import { IconModule } from '../icon';
5
6
  import { InputModule } from '../input';
7
+ import { ScrollingModule } from '../scrolling';
6
8
  import { TagModule } from '../tag';
7
9
  import { TooltipModule } from '../tooltip';
8
10
  import { OptionContentDirective, OptionGroupTitleDirective, } from './helper-directives';
9
11
  import { MultiSelectComponent } from './multi-select/multi-select.component';
10
12
  import { OptionGroupComponent } from './option-group/option-group.component';
13
+ import { OptionItemComponent } from './option-item/option-item.component';
11
14
  import { OptionPlaceholderComponent } from './option-placeholder.component';
12
- import { OptionComponent } from './option/option.component';
15
+ import { OptionComponent } from './option.component';
13
16
  import { SelectComponent } from './select.component';
14
17
  import { IncludesDirective } from './validators';
15
18
  import * as i0 from "@angular/core";
@@ -18,6 +21,7 @@ export class SelectModule {
18
21
  SelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: SelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
19
22
  SelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: SelectModule, declarations: [SelectComponent,
20
23
  OptionComponent,
24
+ OptionItemComponent,
21
25
  OptionGroupComponent,
22
26
  OptionPlaceholderComponent,
23
27
  MultiSelectComponent,
@@ -28,7 +32,9 @@ SelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "
28
32
  I18nModule,
29
33
  IconModule,
30
34
  TooltipModule,
31
- TagModule], exports: [SelectComponent,
35
+ TagModule,
36
+ ScrollingModule,
37
+ PortalModule], exports: [SelectComponent,
32
38
  OptionComponent,
33
39
  OptionGroupComponent,
34
40
  OptionPlaceholderComponent,
@@ -43,6 +49,8 @@ SelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
43
49
  IconModule,
44
50
  TooltipModule,
45
51
  TagModule,
52
+ ScrollingModule,
53
+ PortalModule,
46
54
  ]] });
47
55
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: SelectModule, decorators: [{
48
56
  type: NgModule,
@@ -54,10 +62,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
54
62
  IconModule,
55
63
  TooltipModule,
56
64
  TagModule,
65
+ ScrollingModule,
66
+ PortalModule,
57
67
  ],
58
68
  declarations: [
59
69
  SelectComponent,
60
70
  OptionComponent,
71
+ OptionItemComponent,
61
72
  OptionGroupComponent,
62
73
  OptionPlaceholderComponent,
63
74
  MultiSelectComponent,
@@ -77,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
77
88
  ],
78
89
  }]
79
90
  }] });
80
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zZWxlY3Qvc2VsZWN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQ3JDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDckMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUN2QyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQ25DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFFM0MsT0FBTyxFQUNMLHNCQUFzQixFQUN0Qix5QkFBeUIsR0FDMUIsTUFBTSxxQkFBcUIsQ0FBQztBQUM3QixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7QUFnQ2pELE1BQU0sT0FBTyxZQUFZOzt5R0FBWixZQUFZOzBHQUFaLFlBQVksaUJBcEJyQixlQUFlO1FBQ2YsZUFBZTtRQUNmLG9CQUFvQjtRQUNwQiwwQkFBMEI7UUFDMUIsb0JBQW9CO1FBQ3BCLGlCQUFpQjtRQUNqQix5QkFBeUI7UUFDekIsc0JBQXNCLGFBZnRCLFlBQVk7UUFDWixXQUFXO1FBQ1gsVUFBVTtRQUNWLFVBQVU7UUFDVixhQUFhO1FBQ2IsU0FBUyxhQWFULGVBQWU7UUFDZixlQUFlO1FBQ2Ysb0JBQW9CO1FBQ3BCLDBCQUEwQjtRQUMxQixvQkFBb0I7UUFDcEIsaUJBQWlCO1FBQ2pCLHlCQUF5QjtRQUN6QixzQkFBc0I7MEdBR2IsWUFBWSxZQTdCZDtZQUNQLFlBQVk7WUFDWixXQUFXO1lBQ1gsVUFBVTtZQUNWLFVBQVU7WUFDVixhQUFhO1lBQ2IsU0FBUztTQUNWOzJGQXNCVSxZQUFZO2tCQTlCeEIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLFVBQVU7d0JBQ1YsVUFBVTt3QkFDVixhQUFhO3dCQUNiLFNBQVM7cUJBQ1Y7b0JBQ0QsWUFBWSxFQUFFO3dCQUNaLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixvQkFBb0I7d0JBQ3BCLDBCQUEwQjt3QkFDMUIsb0JBQW9CO3dCQUNwQixpQkFBaUI7d0JBQ2pCLHlCQUF5Qjt3QkFDekIsc0JBQXNCO3FCQUN2QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsZUFBZTt3QkFDZixlQUFlO3dCQUNmLG9CQUFvQjt3QkFDcEIsMEJBQTBCO3dCQUMxQixvQkFBb0I7d0JBQ3BCLGlCQUFpQjt3QkFDakIseUJBQXlCO3dCQUN6QixzQkFBc0I7cUJBQ3ZCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEkxOG5Nb2R1bGUgfSBmcm9tICcuLi9pMThuJztcbmltcG9ydCB7IEljb25Nb2R1bGUgfSBmcm9tICcuLi9pY29uJztcbmltcG9ydCB7IElucHV0TW9kdWxlIH0gZnJvbSAnLi4vaW5wdXQnO1xuaW1wb3J0IHsgVGFnTW9kdWxlIH0gZnJvbSAnLi4vdGFnJztcbmltcG9ydCB7IFRvb2x0aXBNb2R1bGUgfSBmcm9tICcuLi90b29sdGlwJztcblxuaW1wb3J0IHtcbiAgT3B0aW9uQ29udGVudERpcmVjdGl2ZSxcbiAgT3B0aW9uR3JvdXBUaXRsZURpcmVjdGl2ZSxcbn0gZnJvbSAnLi9oZWxwZXItZGlyZWN0aXZlcyc7XG5pbXBvcnQgeyBNdWx0aVNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vbXVsdGktc2VsZWN0L211bHRpLXNlbGVjdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgT3B0aW9uR3JvdXBDb21wb25lbnQgfSBmcm9tICcuL29wdGlvbi1ncm91cC9vcHRpb24tZ3JvdXAuY29tcG9uZW50JztcbmltcG9ydCB7IE9wdGlvblBsYWNlaG9sZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9vcHRpb24tcGxhY2Vob2xkZXIuY29tcG9uZW50JztcbmltcG9ydCB7IE9wdGlvbkNvbXBvbmVudCB9IGZyb20gJy4vb3B0aW9uL29wdGlvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7IEluY2x1ZGVzRGlyZWN0aXZlIH0gZnJvbSAnLi92YWxpZGF0b3JzJztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBJbnB1dE1vZHVsZSxcbiAgICBJMThuTW9kdWxlLFxuICAgIEljb25Nb2R1bGUsXG4gICAgVG9vbHRpcE1vZHVsZSxcbiAgICBUYWdNb2R1bGUsXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIFNlbGVjdENvbXBvbmVudCxcbiAgICBPcHRpb25Db21wb25lbnQsXG4gICAgT3B0aW9uR3JvdXBDb21wb25lbnQsXG4gICAgT3B0aW9uUGxhY2Vob2xkZXJDb21wb25lbnQsXG4gICAgTXVsdGlTZWxlY3RDb21wb25lbnQsXG4gICAgSW5jbHVkZXNEaXJlY3RpdmUsXG4gICAgT3B0aW9uR3JvdXBUaXRsZURpcmVjdGl2ZSxcbiAgICBPcHRpb25Db250ZW50RGlyZWN0aXZlLFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgU2VsZWN0Q29tcG9uZW50LFxuICAgIE9wdGlvbkNvbXBvbmVudCxcbiAgICBPcHRpb25Hcm91cENvbXBvbmVudCxcbiAgICBPcHRpb25QbGFjZWhvbGRlckNvbXBvbmVudCxcbiAgICBNdWx0aVNlbGVjdENvbXBvbmVudCxcbiAgICBJbmNsdWRlc0RpcmVjdGl2ZSxcbiAgICBPcHRpb25Hcm91cFRpdGxlRGlyZWN0aXZlLFxuICAgIE9wdGlvbkNvbnRlbnREaXJlY3RpdmUsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIFNlbGVjdE1vZHVsZSB7fVxuIl19
91
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zZWxlY3Qvc2VsZWN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFekMsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUNyQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQ3JDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDdkMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQ25DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFFM0MsT0FBTyxFQUNMLHNCQUFzQixFQUN0Qix5QkFBeUIsR0FDMUIsTUFBTSxxQkFBcUIsQ0FBQztBQUM3QixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDckQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7QUFtQ2pELE1BQU0sT0FBTyxZQUFZOzt5R0FBWixZQUFZOzBHQUFaLFlBQVksaUJBckJyQixlQUFlO1FBQ2YsZUFBZTtRQUNmLG1CQUFtQjtRQUNuQixvQkFBb0I7UUFDcEIsMEJBQTBCO1FBQzFCLG9CQUFvQjtRQUNwQixpQkFBaUI7UUFDakIseUJBQXlCO1FBQ3pCLHNCQUFzQixhQWxCdEIsWUFBWTtRQUNaLFdBQVc7UUFDWCxVQUFVO1FBQ1YsVUFBVTtRQUNWLGFBQWE7UUFDYixTQUFTO1FBQ1QsZUFBZTtRQUNmLFlBQVksYUFjWixlQUFlO1FBQ2YsZUFBZTtRQUNmLG9CQUFvQjtRQUNwQiwwQkFBMEI7UUFDMUIsb0JBQW9CO1FBQ3BCLGlCQUFpQjtRQUNqQix5QkFBeUI7UUFDekIsc0JBQXNCOzBHQUdiLFlBQVksWUFoQ2Q7WUFDUCxZQUFZO1lBQ1osV0FBVztZQUNYLFVBQVU7WUFDVixVQUFVO1lBQ1YsYUFBYTtZQUNiLFNBQVM7WUFDVCxlQUFlO1lBQ2YsWUFBWTtTQUNiOzJGQXVCVSxZQUFZO2tCQWpDeEIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLFVBQVU7d0JBQ1YsVUFBVTt3QkFDVixhQUFhO3dCQUNiLFNBQVM7d0JBQ1QsZUFBZTt3QkFDZixZQUFZO3FCQUNiO29CQUNELFlBQVksRUFBRTt3QkFDWixlQUFlO3dCQUNmLGVBQWU7d0JBQ2YsbUJBQW1CO3dCQUNuQixvQkFBb0I7d0JBQ3BCLDBCQUEwQjt3QkFDMUIsb0JBQW9CO3dCQUNwQixpQkFBaUI7d0JBQ2pCLHlCQUF5Qjt3QkFDekIsc0JBQXNCO3FCQUN2QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsZUFBZTt3QkFDZixlQUFlO3dCQUNmLG9CQUFvQjt3QkFDcEIsMEJBQTBCO3dCQUMxQixvQkFBb0I7d0JBQ3BCLGlCQUFpQjt3QkFDakIseUJBQXlCO3dCQUN6QixzQkFBc0I7cUJBQ3ZCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUG9ydGFsTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3BvcnRhbCc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgSTE4bk1vZHVsZSB9IGZyb20gJy4uL2kxOG4nO1xuaW1wb3J0IHsgSWNvbk1vZHVsZSB9IGZyb20gJy4uL2ljb24nO1xuaW1wb3J0IHsgSW5wdXRNb2R1bGUgfSBmcm9tICcuLi9pbnB1dCc7XG5pbXBvcnQgeyBTY3JvbGxpbmdNb2R1bGUgfSBmcm9tICcuLi9zY3JvbGxpbmcnO1xuaW1wb3J0IHsgVGFnTW9kdWxlIH0gZnJvbSAnLi4vdGFnJztcbmltcG9ydCB7IFRvb2x0aXBNb2R1bGUgfSBmcm9tICcuLi90b29sdGlwJztcblxuaW1wb3J0IHtcbiAgT3B0aW9uQ29udGVudERpcmVjdGl2ZSxcbiAgT3B0aW9uR3JvdXBUaXRsZURpcmVjdGl2ZSxcbn0gZnJvbSAnLi9oZWxwZXItZGlyZWN0aXZlcyc7XG5pbXBvcnQgeyBNdWx0aVNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vbXVsdGktc2VsZWN0L211bHRpLXNlbGVjdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgT3B0aW9uR3JvdXBDb21wb25lbnQgfSBmcm9tICcuL29wdGlvbi1ncm91cC9vcHRpb24tZ3JvdXAuY29tcG9uZW50JztcbmltcG9ydCB7IE9wdGlvbkl0ZW1Db21wb25lbnQgfSBmcm9tICcuL29wdGlvbi1pdGVtL29wdGlvbi1pdGVtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBPcHRpb25QbGFjZWhvbGRlckNvbXBvbmVudCB9IGZyb20gJy4vb3B0aW9uLXBsYWNlaG9sZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBPcHRpb25Db21wb25lbnQgfSBmcm9tICcuL29wdGlvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7IEluY2x1ZGVzRGlyZWN0aXZlIH0gZnJvbSAnLi92YWxpZGF0b3JzJztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBJbnB1dE1vZHVsZSxcbiAgICBJMThuTW9kdWxlLFxuICAgIEljb25Nb2R1bGUsXG4gICAgVG9vbHRpcE1vZHVsZSxcbiAgICBUYWdNb2R1bGUsXG4gICAgU2Nyb2xsaW5nTW9kdWxlLFxuICAgIFBvcnRhbE1vZHVsZSxcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgU2VsZWN0Q29tcG9uZW50LFxuICAgIE9wdGlvbkNvbXBvbmVudCxcbiAgICBPcHRpb25JdGVtQ29tcG9uZW50LFxuICAgIE9wdGlvbkdyb3VwQ29tcG9uZW50LFxuICAgIE9wdGlvblBsYWNlaG9sZGVyQ29tcG9uZW50LFxuICAgIE11bHRpU2VsZWN0Q29tcG9uZW50LFxuICAgIEluY2x1ZGVzRGlyZWN0aXZlLFxuICAgIE9wdGlvbkdyb3VwVGl0bGVEaXJlY3RpdmUsXG4gICAgT3B0aW9uQ29udGVudERpcmVjdGl2ZSxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIFNlbGVjdENvbXBvbmVudCxcbiAgICBPcHRpb25Db21wb25lbnQsXG4gICAgT3B0aW9uR3JvdXBDb21wb25lbnQsXG4gICAgT3B0aW9uUGxhY2Vob2xkZXJDb21wb25lbnQsXG4gICAgTXVsdGlTZWxlY3RDb21wb25lbnQsXG4gICAgSW5jbHVkZXNEaXJlY3RpdmUsXG4gICAgT3B0aW9uR3JvdXBUaXRsZURpcmVjdGl2ZSxcbiAgICBPcHRpb25Db250ZW50RGlyZWN0aXZlLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBTZWxlY3RNb2R1bGUge31cbiJdfQ==
@@ -4,4 +4,4 @@ export var SelectAllStatus;
4
4
  SelectAllStatus["Checked"] = "checked";
5
5
  SelectAllStatus["Indeterminate"] = "indeterminate";
6
6
  })(SelectAllStatus || (SelectAllStatus = {}));
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3NlbGVjdC9zZWxlY3QudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkJBLE1BQU0sQ0FBTixJQUFZLGVBSVg7QUFKRCxXQUFZLGVBQWU7SUFDekIsNkJBQVUsQ0FBQTtJQUNWLHNDQUFtQixDQUFBO0lBQ25CLGtEQUErQixDQUFBO0FBQ2pDLENBQUMsRUFKVyxlQUFlLEtBQWYsZUFBZSxRQUkxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VsZWN0T3B0aW9uIHtcbiAgbGFiZWw6IHN0cmluZyB8IFRlbXBsYXRlUmVmPHVua25vd24+O1xuICBsYWJlbENvbnRleHQ/OiB1bmtub3duO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNlbGVjdEZpbHRlck9wdGlvbjxUPiBleHRlbmRzIFNlbGVjdE9wdGlvbiB7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgdmFsdWU6IFQ7XG59XG5cbmV4cG9ydCB0eXBlIE9wdGlvbkZpbHRlckZuPFQ+ID0gKFxuICBmaWx0ZXI6IHN0cmluZyxcbiAgb3B0aW9uOiBTZWxlY3RGaWx0ZXJPcHRpb248VD4sXG4pID0+IGJvb2xlYW47XG5cbmV4cG9ydCB0eXBlIFRyYWNrRm48VCwgUiA9IHVua25vd24+ID0gKHZhbHVlOiBUKSA9PiBSO1xuXG5leHBvcnQgdHlwZSBUYWdDbGFzc0ZuPFxuICBWLFxuICBUIGV4dGVuZHMgc3RyaW5nIHwgVGVtcGxhdGVSZWY8dW5rbm93bj4gPSBzdHJpbmcgfCBUZW1wbGF0ZVJlZjx1bmtub3duPixcbj4gPSAoXG4gIGxhYmVsOiBULFxuICB2YWx1ZTogVixcbikgPT4gc3RyaW5nIHwgc3RyaW5nW10gfCBTZXQ8c3RyaW5nPiB8IHsgW2NsYXNzTmFtZTogc3RyaW5nXTogdW5rbm93biB9O1xuXG5leHBvcnQgZW51bSBTZWxlY3RBbGxTdGF0dXMge1xuICBFbXB0eSA9ICcnLFxuICBDaGVja2VkID0gJ2NoZWNrZWQnLFxuICBJbmRldGVybWluYXRlID0gJ2luZGV0ZXJtaW5hdGUnLFxufVxuIl19
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3NlbGVjdC9zZWxlY3QudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUNBLE1BQU0sQ0FBTixJQUFZLGVBSVg7QUFKRCxXQUFZLGVBQWU7SUFDekIsNkJBQVUsQ0FBQTtJQUNWLHNDQUFtQixDQUFBO0lBQ25CLGtEQUErQixDQUFBO0FBQ2pDLENBQUMsRUFKVyxlQUFlLEtBQWYsZUFBZSxRQUkxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVsZW1lbnRSZWYsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VsZWN0T3B0aW9uIHtcbiAgbGFiZWw/OiBzdHJpbmcgfCBUZW1wbGF0ZVJlZjx1bmtub3duPjtcbiAgbGFiZWxDb250ZXh0PzogdW5rbm93bjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTZWxlY3RGaWx0ZXJPcHRpb248VD4gZXh0ZW5kcyBTZWxlY3RPcHRpb24ge1xuICBkaXNhYmxlZD86IGJvb2xlYW47XG4gIHZhbHVlOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERpc3BsYXlPcHRpb248VD4gZXh0ZW5kcyBTZWxlY3RGaWx0ZXJPcHRpb248VD4ge1xuICBzZWxlY3RlZD86IGJvb2xlYW47XG4gIGdyb3VwVGl0bGU/OiBFbGVtZW50UmVmO1xuICBjb250ZW50VGVtcGxhdGU/OiBUZW1wbGF0ZVJlZjxhbnk+O1xufVxuXG5leHBvcnQgdHlwZSBPcHRpb25GaWx0ZXJGbjxUPiA9IChcbiAgZmlsdGVyOiBzdHJpbmcsXG4gIG9wdGlvbjogU2VsZWN0RmlsdGVyT3B0aW9uPFQ+LFxuKSA9PiBib29sZWFuO1xuXG5leHBvcnQgdHlwZSBUcmFja0ZuPFQsIFIgPSB1bmtub3duPiA9ICh2YWx1ZTogVCkgPT4gUjtcblxuZXhwb3J0IHR5cGUgQ3JlYXRlRm48VD4gPSAoaW5wdXQ6IHN0cmluZykgPT4gRGlzcGxheU9wdGlvbjxUPjtcblxuZXhwb3J0IHR5cGUgVGFnQ2xhc3NGbjxcbiAgVixcbiAgVCBleHRlbmRzIHN0cmluZyB8IFRlbXBsYXRlUmVmPHVua25vd24+ID0gc3RyaW5nIHwgVGVtcGxhdGVSZWY8dW5rbm93bj4sXG4+ID0gKFxuICBsYWJlbDogVCxcbiAgdmFsdWU6IFYsXG4pID0+IHN0cmluZyB8IHN0cmluZ1tdIHwgU2V0PHN0cmluZz4gfCB7IFtjbGFzc05hbWU6IHN0cmluZ106IHVua25vd24gfTtcblxuZXhwb3J0IGVudW0gU2VsZWN0QWxsU3RhdHVzIHtcbiAgRW1wdHkgPSAnJyxcbiAgQ2hlY2tlZCA9ICdjaGVja2VkJyxcbiAgSW5kZXRlcm1pbmF0ZSA9ICdpbmRldGVybWluYXRlJyxcbn1cbiJdfQ==