@alauda/ui 6.3.1-beta.8 → 6.3.1-beta.9

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 (34) hide show
  1. package/checkbox/checkbox-group/checkbox-group.component.d.ts +0 -1
  2. package/checkbox/checkbox.component.d.ts +0 -1
  3. package/color-picker/color-picker.component.d.ts +0 -1
  4. package/esm2020/checkbox/checkbox-group/checkbox-group.component.mjs +3 -6
  5. package/esm2020/checkbox/checkbox.component.mjs +10 -12
  6. package/esm2020/color-picker/color-picker.component.mjs +4 -8
  7. package/esm2020/date-picker/calendar/date-picker-panel/component.mjs +3 -3
  8. package/esm2020/date-picker/calendar/range-picker-panel/component.mjs +3 -3
  9. package/esm2020/date-picker/date-picker/date-picker.component.mjs +4 -4
  10. package/esm2020/date-picker/range-picker/range-picker.component.mjs +4 -4
  11. package/esm2020/form/common-form.mjs +13 -14
  12. package/esm2020/input/number-input/number-input.component.mjs +8 -8
  13. package/esm2020/input/tags-input/tags-input.component.mjs +14 -19
  14. package/esm2020/radio/base-radio.mjs +2 -2
  15. package/esm2020/radio/radio-group/radio-group.component.mjs +2 -5
  16. package/esm2020/select/multi-select/multi-select.component.mjs +10 -12
  17. package/esm2020/select/select.component.mjs +7 -7
  18. package/esm2020/switch/switch.component.mjs +4 -7
  19. package/esm2020/time-picker/component.mjs +2 -2
  20. package/esm2020/time-picker/panel/panel.component.mjs +8 -8
  21. package/esm2020/tree-select/tree-select.component.mjs +7 -7
  22. package/fesm2015/alauda-ui.mjs +90 -110
  23. package/fesm2015/alauda-ui.mjs.map +1 -1
  24. package/fesm2020/alauda-ui.mjs +90 -110
  25. package/fesm2020/alauda-ui.mjs.map +1 -1
  26. package/form/common-form.d.ts +13 -16
  27. package/input/number-input/number-input.component.d.ts +1 -1
  28. package/input/tags-input/tags-input.component.d.ts +1 -6
  29. package/package.json +1 -1
  30. package/radio/radio-group/radio-group.component.d.ts +0 -1
  31. package/select/multi-select/multi-select.component.d.ts +2 -2
  32. package/select/select.component.d.ts +1 -1
  33. package/switch/switch.component.d.ts +0 -1
  34. package/tree-select/tree-select.component.d.ts +1 -1
@@ -23,7 +23,7 @@ export class MultiSelectComponent extends BaseSelect {
23
23
  this._allowSelectAll = false;
24
24
  this.isMulti = true;
25
25
  this.selectedValues = [];
26
- this.values$ = this.value$$.asObservable();
26
+ this.values$ = this.model$;
27
27
  this.maxRowCount = 0;
28
28
  this.customRowHeight = 0; // 0: use default style const value, > 1: for ```tagClassFn``` maybe affect lineHeight
29
29
  this.inputValue = '';
@@ -69,7 +69,7 @@ export class MultiSelectComponent extends BaseSelect {
69
69
  ngAfterContentInit() {
70
70
  super.ngAfterContentInit();
71
71
  this.selectedOptions$ = combineLatest([
72
- this.value$,
72
+ this.model$,
73
73
  this.contentOptions.changes.pipe(startWith(this.contentOptions), switchMap((options) => options.length > 0
74
74
  ? combineLatest(options.map(option => combineLatest([
75
75
  option.value$,
@@ -175,12 +175,12 @@ export class MultiSelectComponent extends BaseSelect {
175
175
  super.onKeyDown(event);
176
176
  }
177
177
  }
178
- writeValue(val) {
179
- this.value$$.next(val || []);
178
+ valueIn(v) {
180
179
  this.resetInput();
181
180
  requestAnimationFrame(() => {
182
181
  this.tooltipRef.updatePosition();
183
182
  });
183
+ return v;
184
184
  }
185
185
  selectOption(option) {
186
186
  if (option.selected) {
@@ -196,7 +196,7 @@ export class MultiSelectComponent extends BaseSelect {
196
196
  }
197
197
  addValue(value) {
198
198
  const values = this.selectedValues.concat(value);
199
- this.emitValueChange(values);
199
+ this.emitValue(values);
200
200
  if (this.onChange) {
201
201
  this.resetInput();
202
202
  requestAnimationFrame(() => {
@@ -206,7 +206,7 @@ export class MultiSelectComponent extends BaseSelect {
206
206
  }
207
207
  removeValue(value) {
208
208
  const values = this.selectedValues.filter(item => this.trackFn(item) !== this.trackFn(value));
209
- this.emitValueChange(values);
209
+ this.emitValue(values);
210
210
  if (this.onChange) {
211
211
  this.resetInput();
212
212
  requestAnimationFrame(() => {
@@ -215,7 +215,7 @@ export class MultiSelectComponent extends BaseSelect {
215
215
  }
216
216
  }
217
217
  clearValue(event) {
218
- this.emitValueChange([]);
218
+ this.emitValue([]);
219
219
  event.stopPropagation();
220
220
  event.preventDefault();
221
221
  }
@@ -227,12 +227,10 @@ export class MultiSelectComponent extends BaseSelect {
227
227
  .filter(({ visible, disabled }) => visible && !disabled)
228
228
  .map(({ value }) => value);
229
229
  if (this.selectAllStatus === SelectAllStatus.Checked) {
230
- this.emitValueChange(this.snapshot.value.filter(value => !visibleOptionsValue.includes(value)));
230
+ this.emitValue(this.model.filter(value => !visibleOptionsValue.includes(value)));
231
231
  }
232
232
  else {
233
- this.emitValueChange([
234
- ...new Set(this.snapshot.value.concat(visibleOptionsValue)),
235
- ]);
233
+ this.emitValue([...new Set(this.model.concat(visibleOptionsValue))]);
236
234
  }
237
235
  }
238
236
  resetInput() {
@@ -303,4 +301,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
303
301
  type: HostBinding,
304
302
  args: ['style.display']
305
303
  }] } });
306
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select.component.js","sourceRoot":"","sources":["../../../../src/select/multi-select/multi-select.component.ts","../../../../src/select/multi-select/multi-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  QueryList,\n  Renderer2,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Observable, combineLatest, of } from 'rxjs';\nimport {\n  map,\n  publishReplay,\n  refCount,\n  startWith,\n  switchMap,\n  takeUntil,\n  tap,\n} from 'rxjs/operators';\n\nimport { createWithMaxRowCount } from '../../input/tags-input/with-max-row-count';\nimport { ComponentSize } from '../../types';\nimport { Bem, buildBem, coerceAttrBoolean, coerceString } from '../../utils';\nimport { BaseSelect } from '../base-select';\nimport { OptionComponent } from '../option/option.component';\nimport {\n  SelectAllStatus,\n  SelectFilterOption,\n  TagClassFn,\n} from '../select.types';\n\n@Component({\n  selector: 'aui-multi-select',\n  templateUrl: './multi-select.component.html',\n  styleUrls: [\n    '../../input/input.component.scss',\n    '../../tag/tag.component.scss',\n    './multi-select.component.scss',\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => MultiSelectComponent),\n      multi: true,\n    },\n    {\n      provide: BaseSelect,\n      useExisting: MultiSelectComponent,\n    },\n  ],\n})\nexport class MultiSelectComponent<T = unknown>\n  extends BaseSelect<T, T[]>\n  implements AfterContentInit, AfterViewInit\n{\n  bem: Bem = buildBem('aui-multi-select');\n  bemSelectAll: Bem = buildBem('aui-option');\n  selectedOptions$: Observable<Array<SelectFilterOption<T>>>;\n  selectAllStatus$: Observable<SelectAllStatus>;\n  selectAllStatus: SelectAllStatus;\n  hasEnabledOptions$: Observable<boolean>;\n\n  private _allowSelectAll = false;\n  override isMulti = true;\n  selectedValues: T[] = [];\n  values$ = this.value$$.asObservable();\n\n  @Input()\n  tagClassFn: TagClassFn<T>;\n\n  @Input()\n  maxRowCount = 0;\n\n  @Input()\n  customRowHeight = 0; // 0: use default style const value, > 1: for ```tagClassFn``` maybe affect lineHeight\n\n  @Input()\n  get allowSelectAll() {\n    return this._allowSelectAll;\n  }\n\n  set allowSelectAll(val: boolean | '') {\n    this._allowSelectAll = coerceAttrBoolean(val);\n  }\n\n  @ViewChild('inputRef', { static: true })\n  inputRef: ElementRef<HTMLInputElement>;\n\n  @ViewChild('inputValueMirror', { static: true })\n  inputValueMirror: ElementRef<HTMLElement>;\n\n  @HostBinding('style.position')\n  get hostPosition() {\n    return this.withMaxRowCount.hostPosition();\n  }\n\n  @HostBinding('style.display')\n  get hostDisplay() {\n    return this.withMaxRowCount.hostDisplay();\n  }\n\n  inputValue = '';\n\n  get rootClass() {\n    const size = this.size || ComponentSize.Medium;\n    return `aui-input ${this.bem.block(size)} ${\n      this.disabled ? 'isDisabled' : ''\n    } ${this.focused ? 'isFocused' : ''} ${\n      this.displayClearBtn ? 'isClearable' : ''\n    } ${this.maxRowCount > 0 ? 'withHeightLimit' : ''}`;\n  }\n\n  get tagSize() {\n    return this.size === ComponentSize.Large\n      ? ComponentSize.Medium\n      : ComponentSize.Mini;\n  }\n\n  get inputClass() {\n    return `${this.bem.element('input', {\n      hidden: this.inputReadonly,\n    })} aui-tag aui-tag--${this.tagSize}`;\n  }\n\n  get displayClearBtn() {\n    return !this.disabled && this.clearable && this.selectedValues.length;\n  }\n\n  get maxHeight() {\n    return this.withMaxRowCount.maxHeight();\n  }\n\n  private readonly withMaxRowCount = createWithMaxRowCount(this);\n\n  focused = false;\n\n  trackByValue = (_: number, item: SelectFilterOption<T>) =>\n    this.trackFn(item.value);\n\n  constructor(cdr: ChangeDetectorRef, private readonly renderer: Renderer2) {\n    super(cdr);\n    this.values$.pipe(takeUntil(this.destroy$$)).subscribe(values => {\n      this.selectedValues = values;\n    });\n  }\n\n  override ngAfterContentInit() {\n    super.ngAfterContentInit();\n\n    this.selectedOptions$ = combineLatest([\n      this.value$,\n      (\n        this.contentOptions.changes as Observable<QueryList<OptionComponent<T>>>\n      ).pipe(\n        startWith(this.contentOptions),\n        switchMap((options: QueryList<OptionComponent<T>>) =>\n          options.length > 0\n            ? combineLatest(\n                options.map(option =>\n                  combineLatest([\n                    option.value$,\n                    option.label$,\n                    option.labelContext$,\n                    option.disabled$,\n                  ]).pipe(\n                    map(([value, label, labelContext, disabled]) => ({\n                      value,\n                      label,\n                      labelContext,\n                      disabled,\n                    })),\n                  ),\n                ),\n              )\n            : of([] as Array<SelectFilterOption<T>>),\n        ),\n      ),\n    ]).pipe(\n      map(([values, options]) =>\n        values\n          .map(value => {\n            const option = options.find(\n              option => this.trackFn(option.value) === this.trackFn(value),\n            );\n            return option\n              ? {\n                  label:\n                    option.label || coerceString(this.trackFn(option.value)),\n                  labelContext: option.labelContext,\n                  value: option.value,\n                  disabled: option.disabled,\n                }\n              : {\n                  label:\n                    this.labelFn?.(value) || coerceString(this.trackFn(value)),\n                  value,\n                };\n          })\n          // sort disabled options as first\n          .sort((a, b) => {\n            if (a.disabled) {\n              return -1;\n            }\n\n            if (b.disabled) {\n              return 1;\n            }\n\n            return 0;\n          }),\n      ),\n      publishReplay(1),\n      refCount(),\n    );\n  }\n\n  override ngAfterViewInit() {\n    super.ngAfterViewInit();\n    this.selectAllStatus$ = combineLatest([\n      this.allOptions$,\n      this.filterString$,\n    ]).pipe(\n      switchMap(([allOptions]) =>\n        combineLatest([\n          ...(allOptions ?? [])\n            .filter(({ visible, disabled }) => visible && !disabled)\n            .map(({ selected$ }) => selected$),\n        ]),\n      ),\n      map(statuses => {\n        const selected = statuses.filter(i => i);\n        return selected.length === 0\n          ? SelectAllStatus.Empty\n          : selected.length !== statuses.length\n          ? SelectAllStatus.Indeterminate\n          : SelectAllStatus.Checked;\n      }),\n      startWith(SelectAllStatus.Empty),\n      tap(selectAllStatus => (this.selectAllStatus = selectAllStatus)),\n      publishReplay(1),\n      refCount(),\n    );\n    this.hasEnabledOptions$ = combineLatest([\n      this.allOptions$,\n      this.filterString$,\n    ]).pipe(\n      map(\n        ([allOptions]) =>\n          !!allOptions.filter(({ visible, disabled }) => visible && !disabled)\n            .length,\n      ),\n    );\n  }\n\n  override onShowOptions() {\n    super.onShowOptions();\n    this.inputRef.nativeElement.focus();\n  }\n\n  override onHideOptions() {\n    super.onHideOptions();\n    this.inputRef.nativeElement.value = '';\n    this.renderer.removeStyle(this.inputRef.nativeElement, 'width');\n  }\n\n  override onInput(event: Event) {\n    super.onInput(event);\n    this.setInputWidth();\n    this.tooltipRef.updatePosition();\n  }\n\n  onInputFocus() {\n    this.focused = true;\n  }\n\n  onInputBlur() {\n    this.focused = false;\n    this.closeOption();\n  }\n\n  override onKeyDown(event: KeyboardEvent) {\n    if (\n      event.key === 'Backspace' &&\n      this.filterString === '' &&\n      this.selectedValues.length > 0\n    ) {\n      this.removeValue(this.selectedValues[this.selectedValues.length - 1]);\n      event.stopPropagation();\n      event.preventDefault();\n    } else if (event.key === 'Enter') {\n      if (\n        this.selectedValues\n          .map(value => this.trackFn(value))\n          .includes((event.target as HTMLInputElement).value)\n      ) {\n        return;\n      }\n      this.selectFocusedOption();\n      event.stopPropagation();\n      event.preventDefault();\n    } else {\n      super.onKeyDown(event);\n    }\n  }\n\n  override writeValue(val: T[]) {\n    this.value$$.next(val || []);\n    this.resetInput();\n    requestAnimationFrame(() => {\n      this.tooltipRef.updatePosition();\n    });\n  }\n\n  selectOption(option: OptionComponent<T>) {\n    if (option.selected) {\n      this.removeValue(option.value);\n    } else {\n      this.addValue(option.value);\n    }\n    const isCustom = !this.contentOptions.some(\n      ({ value }) => value === option.value,\n    );\n    if (isCustom) {\n      this.resetFocusedOption();\n    }\n  }\n\n  addValue(value: T) {\n    const values = this.selectedValues.concat(value);\n    this.emitValueChange(values);\n    if (this.onChange) {\n      this.resetInput();\n      requestAnimationFrame(() => {\n        this.tooltipRef.updatePosition();\n      });\n    }\n  }\n\n  removeValue(value: T) {\n    const values = this.selectedValues.filter(\n      item => this.trackFn(item) !== this.trackFn(value),\n    );\n    this.emitValueChange(values);\n    if (this.onChange) {\n      this.resetInput();\n      requestAnimationFrame(() => {\n        this.tooltipRef.updatePosition();\n      });\n    }\n  }\n\n  clearValue(event: Event) {\n    this.emitValueChange([]);\n    event.stopPropagation();\n    event.preventDefault();\n  }\n\n  onSelectAllClick() {\n    if (this.disabled) {\n      return;\n    }\n    const visibleOptionsValue = this.allOptions\n      .filter(({ visible, disabled }) => visible && !disabled)\n      .map(({ value }) => value);\n    if (this.selectAllStatus === SelectAllStatus.Checked) {\n      this.emitValueChange(\n        this.snapshot.value.filter(\n          value => !visibleOptionsValue.includes(value),\n        ),\n      );\n    } else {\n      this.emitValueChange([\n        ...new Set(this.snapshot.value.concat(visibleOptionsValue)),\n      ]);\n    }\n  }\n\n  private resetInput() {\n    this.inputRef.nativeElement.value = '';\n    this.setInputWidth();\n    this.filterString = '';\n  }\n\n  // calculate input element width according to its value\n  private setInputWidth() {\n    const { value } = this.inputRef.nativeElement;\n    if (!value.length) {\n      this.inputValue = '';\n      requestAnimationFrame(() => {\n        this.renderer.removeStyle(this.inputRef.nativeElement, 'width');\n      });\n    } else {\n      this.inputValue = value;\n      requestAnimationFrame(() => {\n        this.renderer.setStyle(\n          this.inputRef.nativeElement,\n          'width',\n          `${this.inputValueMirror.nativeElement.scrollWidth}px`,\n        );\n      });\n    }\n  }\n}\n","<div\n  [class]=\"rootClass\"\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  (mousedown)=\"$event.preventDefault()\"\n  [style.max-height]=\"maxHeight\"\n>\n  <div class=\"aui-multi-select__suffix\">\n    <span class=\"aui-multi-select__icon-container\">\n      <aui-icon\n        class=\"aui-multi-select__indicator\"\n        [icon]=\"loading ? 'spinner' : 'caret_down_s'\"\n      ></aui-icon>\n      <aui-icon\n        class=\"aui-multi-select__clear\"\n        icon=\"close_small\"\n        (click)=\"clearValue($event)\"\n      ></aui-icon>\n    </span>\n  </div>\n  <span\n    [hidden]=\"selectedValues.length || inputRef.value.length\"\n    [class]=\"bem.element('placeholder')\"\n  >\n    {{ placeholder }}\n  </span>\n  <aui-tag\n    *ngFor=\"let option of selectedOptions$ | async; trackBy: trackByValue\"\n    type=\"info\"\n    [round]=\"true\"\n    [border]=\"true\"\n    [size]=\"tagSize\"\n    [closeable]=\"!disabled && !option.disabled\"\n    (close)=\"removeValue(option.value)\"\n    [ngClass]=\"tagClassFn && tagClassFn(option.label, option.value)\"\n  >\n    <ng-container\n      *ngIf=\"isTemplateRef(option.label); else label\"\n      [ngTemplateOutlet]=\"option.label\"\n      [ngTemplateOutletContext]=\"option.labelContext\"\n    ></ng-container>\n    <ng-template #label>\n      {{ option.label }}\n    </ng-template>\n  </aui-tag>\n  <input\n    #inputRef\n    autocomplete=\"off\"\n    [readonly]=\"inputReadonly\"\n    [class]=\"inputClass\"\n    (focus)=\"onInputFocus()\"\n    (blur)=\"onInputBlur()\"\n    (keydown)=\"onKeyDown($event)\"\n    (input)=\"onInput($event)\"\n  />\n  <span #inputValueMirror [class]=\"bem.element('mirror')\">\n    {{ inputValue }}\n  </span>\n</div>\n\n<ng-template #templateRef>\n  <div\n    class=\"aui-option-container\"\n    [style.minWidth]=\"containerWidth\"\n    (mousedown)=\"$event.preventDefault()\"\n  >\n    <div #optionListRef class=\"aui-option-container__content\">\n      <ng-container\n        *ngIf=\"\n          allowSelectAll &&\n          (hasEnabledOptions$ | async) &&\n          ((hasVisibleOption$ | async) ||\n            (allowCreate && (customCreatedOptions$ | async).length) ||\n            (allowCreate && filterString))\n        \"\n      >\n        <div\n          class=\"aui-option\"\n          [class]=\"bemSelectAll.block(size$ | async)\"\n          [class.isDisabled]=\"disabled\"\n          [class.isSelected]=\"!!(selectAllStatus$ | async)\"\n          [class.isMulti]=\"true\"\n          (click)=\"onSelectAllClick()\"\n        >\n          <i class=\"aui-option__pointer\">\n            <aui-icon\n              [icon]=\"\n                (selectAllStatus$ | async) === 'checked'\n                  ? 'check_s'\n                  : 'square_s'\n              \"\n              [hidden]=\"!(selectAllStatus$ | async)\"\n            ></aui-icon>\n          </i>\n          {{ 'select_all' | auiI18n }}\n        </div>\n        <hr class=\"divider\" />\n      </ng-container>\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"]}
304
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select.component.js","sourceRoot":"","sources":["../../../../src/select/multi-select/multi-select.component.ts","../../../../src/select/multi-select/multi-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  QueryList,\n  Renderer2,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Observable, combineLatest, of } from 'rxjs';\nimport {\n  map,\n  publishReplay,\n  refCount,\n  startWith,\n  switchMap,\n  takeUntil,\n  tap,\n} from 'rxjs/operators';\n\nimport { createWithMaxRowCount } from '../../input/tags-input/with-max-row-count';\nimport { ComponentSize } from '../../types';\nimport { Bem, buildBem, coerceAttrBoolean, coerceString } from '../../utils';\nimport { BaseSelect } from '../base-select';\nimport { OptionComponent } from '../option/option.component';\nimport {\n  SelectAllStatus,\n  SelectFilterOption,\n  TagClassFn,\n} from '../select.types';\n\n@Component({\n  selector: 'aui-multi-select',\n  templateUrl: './multi-select.component.html',\n  styleUrls: [\n    '../../input/input.component.scss',\n    '../../tag/tag.component.scss',\n    './multi-select.component.scss',\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => MultiSelectComponent),\n      multi: true,\n    },\n    {\n      provide: BaseSelect,\n      useExisting: MultiSelectComponent,\n    },\n  ],\n})\nexport class MultiSelectComponent<T = unknown>\n  extends BaseSelect<T, T[]>\n  implements AfterContentInit, AfterViewInit\n{\n  bem: Bem = buildBem('aui-multi-select');\n  bemSelectAll: Bem = buildBem('aui-option');\n  selectedOptions$: Observable<Array<SelectFilterOption<T>>>;\n  selectAllStatus$: Observable<SelectAllStatus>;\n  selectAllStatus: SelectAllStatus;\n  hasEnabledOptions$: Observable<boolean>;\n\n  private _allowSelectAll = false;\n  override isMulti = true;\n  selectedValues: T[] = [];\n  values$ = this.model$;\n\n  @Input()\n  tagClassFn: TagClassFn<T>;\n\n  @Input()\n  maxRowCount = 0;\n\n  @Input()\n  customRowHeight = 0; // 0: use default style const value, > 1: for ```tagClassFn``` maybe affect lineHeight\n\n  @Input()\n  get allowSelectAll() {\n    return this._allowSelectAll;\n  }\n\n  set allowSelectAll(val: boolean | '') {\n    this._allowSelectAll = coerceAttrBoolean(val);\n  }\n\n  @ViewChild('inputRef', { static: true })\n  inputRef: ElementRef<HTMLInputElement>;\n\n  @ViewChild('inputValueMirror', { static: true })\n  inputValueMirror: ElementRef<HTMLElement>;\n\n  @HostBinding('style.position')\n  get hostPosition() {\n    return this.withMaxRowCount.hostPosition();\n  }\n\n  @HostBinding('style.display')\n  get hostDisplay() {\n    return this.withMaxRowCount.hostDisplay();\n  }\n\n  inputValue = '';\n\n  get rootClass() {\n    const size = this.size || ComponentSize.Medium;\n    return `aui-input ${this.bem.block(size)} ${\n      this.disabled ? 'isDisabled' : ''\n    } ${this.focused ? 'isFocused' : ''} ${\n      this.displayClearBtn ? 'isClearable' : ''\n    } ${this.maxRowCount > 0 ? 'withHeightLimit' : ''}`;\n  }\n\n  get tagSize() {\n    return this.size === ComponentSize.Large\n      ? ComponentSize.Medium\n      : ComponentSize.Mini;\n  }\n\n  get inputClass() {\n    return `${this.bem.element('input', {\n      hidden: this.inputReadonly,\n    })} aui-tag aui-tag--${this.tagSize}`;\n  }\n\n  get displayClearBtn() {\n    return !this.disabled && this.clearable && this.selectedValues.length;\n  }\n\n  get maxHeight() {\n    return this.withMaxRowCount.maxHeight();\n  }\n\n  private readonly withMaxRowCount = createWithMaxRowCount(this);\n\n  focused = false;\n\n  trackByValue = (_: number, item: SelectFilterOption<T>) =>\n    this.trackFn(item.value);\n\n  constructor(cdr: ChangeDetectorRef, private readonly renderer: Renderer2) {\n    super(cdr);\n    this.values$.pipe(takeUntil(this.destroy$$)).subscribe(values => {\n      this.selectedValues = values;\n    });\n  }\n\n  override ngAfterContentInit() {\n    super.ngAfterContentInit();\n\n    this.selectedOptions$ = combineLatest([\n      this.model$,\n      (\n        this.contentOptions.changes as Observable<QueryList<OptionComponent<T>>>\n      ).pipe(\n        startWith(this.contentOptions),\n        switchMap((options: QueryList<OptionComponent<T>>) =>\n          options.length > 0\n            ? combineLatest(\n                options.map(option =>\n                  combineLatest([\n                    option.value$,\n                    option.label$,\n                    option.labelContext$,\n                    option.disabled$,\n                  ]).pipe(\n                    map(([value, label, labelContext, disabled]) => ({\n                      value,\n                      label,\n                      labelContext,\n                      disabled,\n                    })),\n                  ),\n                ),\n              )\n            : of([] as Array<SelectFilterOption<T>>),\n        ),\n      ),\n    ]).pipe(\n      map(([values, options]) =>\n        values\n          .map(value => {\n            const option = options.find(\n              option => this.trackFn(option.value) === this.trackFn(value),\n            );\n            return option\n              ? {\n                  label:\n                    option.label || coerceString(this.trackFn(option.value)),\n                  labelContext: option.labelContext,\n                  value: option.value,\n                  disabled: option.disabled,\n                }\n              : {\n                  label:\n                    this.labelFn?.(value) || coerceString(this.trackFn(value)),\n                  value,\n                };\n          })\n          // sort disabled options as first\n          .sort((a, b) => {\n            if (a.disabled) {\n              return -1;\n            }\n\n            if (b.disabled) {\n              return 1;\n            }\n\n            return 0;\n          }),\n      ),\n      publishReplay(1),\n      refCount(),\n    );\n  }\n\n  override ngAfterViewInit() {\n    super.ngAfterViewInit();\n    this.selectAllStatus$ = combineLatest([\n      this.allOptions$,\n      this.filterString$,\n    ]).pipe(\n      switchMap(([allOptions]) =>\n        combineLatest([\n          ...(allOptions ?? [])\n            .filter(({ visible, disabled }) => visible && !disabled)\n            .map(({ selected$ }) => selected$),\n        ]),\n      ),\n      map(statuses => {\n        const selected = statuses.filter(i => i);\n        return selected.length === 0\n          ? SelectAllStatus.Empty\n          : selected.length !== statuses.length\n          ? SelectAllStatus.Indeterminate\n          : SelectAllStatus.Checked;\n      }),\n      startWith(SelectAllStatus.Empty),\n      tap(selectAllStatus => (this.selectAllStatus = selectAllStatus)),\n      publishReplay(1),\n      refCount(),\n    );\n    this.hasEnabledOptions$ = combineLatest([\n      this.allOptions$,\n      this.filterString$,\n    ]).pipe(\n      map(\n        ([allOptions]) =>\n          !!allOptions.filter(({ visible, disabled }) => visible && !disabled)\n            .length,\n      ),\n    );\n  }\n\n  override onShowOptions() {\n    super.onShowOptions();\n    this.inputRef.nativeElement.focus();\n  }\n\n  override onHideOptions() {\n    super.onHideOptions();\n    this.inputRef.nativeElement.value = '';\n    this.renderer.removeStyle(this.inputRef.nativeElement, 'width');\n  }\n\n  override onInput(event: Event) {\n    super.onInput(event);\n    this.setInputWidth();\n    this.tooltipRef.updatePosition();\n  }\n\n  onInputFocus() {\n    this.focused = true;\n  }\n\n  onInputBlur() {\n    this.focused = false;\n    this.closeOption();\n  }\n\n  override onKeyDown(event: KeyboardEvent) {\n    if (\n      event.key === 'Backspace' &&\n      this.filterString === '' &&\n      this.selectedValues.length > 0\n    ) {\n      this.removeValue(this.selectedValues[this.selectedValues.length - 1]);\n      event.stopPropagation();\n      event.preventDefault();\n    } else if (event.key === 'Enter') {\n      if (\n        this.selectedValues\n          .map(value => this.trackFn(value))\n          .includes((event.target as HTMLInputElement).value)\n      ) {\n        return;\n      }\n      this.selectFocusedOption();\n      event.stopPropagation();\n      event.preventDefault();\n    } else {\n      super.onKeyDown(event);\n    }\n  }\n\n  protected override valueIn(v: T[]): T[] {\n    this.resetInput();\n    requestAnimationFrame(() => {\n      this.tooltipRef.updatePosition();\n    });\n    return v;\n  }\n\n  selectOption(option: OptionComponent<T>) {\n    if (option.selected) {\n      this.removeValue(option.value);\n    } else {\n      this.addValue(option.value);\n    }\n    const isCustom = !this.contentOptions.some(\n      ({ value }) => value === option.value,\n    );\n    if (isCustom) {\n      this.resetFocusedOption();\n    }\n  }\n\n  addValue(value: T) {\n    const values = this.selectedValues.concat(value);\n    this.emitValue(values);\n    if (this.onChange) {\n      this.resetInput();\n      requestAnimationFrame(() => {\n        this.tooltipRef.updatePosition();\n      });\n    }\n  }\n\n  removeValue(value: T) {\n    const values = this.selectedValues.filter(\n      item => this.trackFn(item) !== this.trackFn(value),\n    );\n    this.emitValue(values);\n    if (this.onChange) {\n      this.resetInput();\n      requestAnimationFrame(() => {\n        this.tooltipRef.updatePosition();\n      });\n    }\n  }\n\n  clearValue(event: Event) {\n    this.emitValue([]);\n    event.stopPropagation();\n    event.preventDefault();\n  }\n\n  onSelectAllClick() {\n    if (this.disabled) {\n      return;\n    }\n    const visibleOptionsValue = this.allOptions\n      .filter(({ visible, disabled }) => visible && !disabled)\n      .map(({ value }) => value);\n    if (this.selectAllStatus === SelectAllStatus.Checked) {\n      this.emitValue(\n        this.model.filter(value => !visibleOptionsValue.includes(value)),\n      );\n    } else {\n      this.emitValue([...new Set(this.model.concat(visibleOptionsValue))]);\n    }\n  }\n\n  private resetInput() {\n    this.inputRef.nativeElement.value = '';\n    this.setInputWidth();\n    this.filterString = '';\n  }\n\n  // calculate input element width according to its value\n  private setInputWidth() {\n    const { value } = this.inputRef.nativeElement;\n    if (!value.length) {\n      this.inputValue = '';\n      requestAnimationFrame(() => {\n        this.renderer.removeStyle(this.inputRef.nativeElement, 'width');\n      });\n    } else {\n      this.inputValue = value;\n      requestAnimationFrame(() => {\n        this.renderer.setStyle(\n          this.inputRef.nativeElement,\n          'width',\n          `${this.inputValueMirror.nativeElement.scrollWidth}px`,\n        );\n      });\n    }\n  }\n}\n","<div\n  [class]=\"rootClass\"\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  (mousedown)=\"$event.preventDefault()\"\n  [style.max-height]=\"maxHeight\"\n>\n  <div class=\"aui-multi-select__suffix\">\n    <span class=\"aui-multi-select__icon-container\">\n      <aui-icon\n        class=\"aui-multi-select__indicator\"\n        [icon]=\"loading ? 'spinner' : 'caret_down_s'\"\n      ></aui-icon>\n      <aui-icon\n        class=\"aui-multi-select__clear\"\n        icon=\"close_small\"\n        (click)=\"clearValue($event)\"\n      ></aui-icon>\n    </span>\n  </div>\n  <span\n    [hidden]=\"selectedValues.length || inputRef.value.length\"\n    [class]=\"bem.element('placeholder')\"\n  >\n    {{ placeholder }}\n  </span>\n  <aui-tag\n    *ngFor=\"let option of selectedOptions$ | async; trackBy: trackByValue\"\n    type=\"info\"\n    [round]=\"true\"\n    [border]=\"true\"\n    [size]=\"tagSize\"\n    [closeable]=\"!disabled && !option.disabled\"\n    (close)=\"removeValue(option.value)\"\n    [ngClass]=\"tagClassFn && tagClassFn(option.label, option.value)\"\n  >\n    <ng-container\n      *ngIf=\"isTemplateRef(option.label); else label\"\n      [ngTemplateOutlet]=\"option.label\"\n      [ngTemplateOutletContext]=\"option.labelContext\"\n    ></ng-container>\n    <ng-template #label>\n      {{ option.label }}\n    </ng-template>\n  </aui-tag>\n  <input\n    #inputRef\n    autocomplete=\"off\"\n    [readonly]=\"inputReadonly\"\n    [class]=\"inputClass\"\n    (focus)=\"onInputFocus()\"\n    (blur)=\"onInputBlur()\"\n    (keydown)=\"onKeyDown($event)\"\n    (input)=\"onInput($event)\"\n  />\n  <span #inputValueMirror [class]=\"bem.element('mirror')\">\n    {{ inputValue }}\n  </span>\n</div>\n\n<ng-template #templateRef>\n  <div\n    class=\"aui-option-container\"\n    [style.minWidth]=\"containerWidth\"\n    (mousedown)=\"$event.preventDefault()\"\n  >\n    <div #optionListRef class=\"aui-option-container__content\">\n      <ng-container\n        *ngIf=\"\n          allowSelectAll &&\n          (hasEnabledOptions$ | async) &&\n          ((hasVisibleOption$ | async) ||\n            (allowCreate && (customCreatedOptions$ | async).length) ||\n            (allowCreate && filterString))\n        \"\n      >\n        <div\n          class=\"aui-option\"\n          [class]=\"bemSelectAll.block(size$ | async)\"\n          [class.isDisabled]=\"disabled\"\n          [class.isSelected]=\"!!(selectAllStatus$ | async)\"\n          [class.isMulti]=\"true\"\n          (click)=\"onSelectAllClick()\"\n        >\n          <i class=\"aui-option__pointer\">\n            <aui-icon\n              [icon]=\"\n                (selectAllStatus$ | async) === 'checked'\n                  ? 'check_s'\n                  : 'square_s'\n              \"\n              [hidden]=\"!(selectAllStatus$ | async)\"\n            ></aui-icon>\n          </i>\n          {{ 'select_all' | auiI18n }}\n        </div>\n        <hr class=\"divider\" />\n      </ng-container>\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"]}
@@ -15,7 +15,7 @@ import * as i7 from "@angular/common";
15
15
  export class SelectComponent extends BaseSelect {
16
16
  constructor() {
17
17
  super(...arguments);
18
- this.values$ = this.value$$.asObservable().pipe(map(val => [val]));
18
+ this.values$ = this.model$.asObservable().pipe(map(val => [val]));
19
19
  this.isClearable = (hasSelected) => !this.disabled && this.clearable && hasSelected;
20
20
  }
21
21
  get rootClass() {
@@ -38,7 +38,7 @@ export class SelectComponent extends BaseSelect {
38
38
  labelContext,
39
39
  })))
40
40
  : of(null))))),
41
- this.value$,
41
+ this.model$,
42
42
  ]).pipe(map(([option, value]) => option
43
43
  ? {
44
44
  label: option.label ||
@@ -61,16 +61,16 @@ export class SelectComponent extends BaseSelect {
61
61
  super.onHideOptions();
62
62
  this.inputRef.elementRef.nativeElement.value = '';
63
63
  }
64
- writeValue(val) {
65
- this.value$$.next(val);
64
+ valueIn(v) {
66
65
  this.closeOption();
66
+ return v;
67
67
  }
68
68
  selectOption(option) {
69
- this.emitValueChange(option.value);
69
+ this.emitValue(option.value);
70
70
  this.closeOption();
71
71
  }
72
72
  clearValue(event) {
73
- this.emitValueChange(null);
73
+ this.emitValue(null);
74
74
  event.stopPropagation();
75
75
  event.preventDefault();
76
76
  }
@@ -104,4 +104,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
104
104
  type: ViewChild,
105
105
  args: ['inputRef', { static: true }]
106
106
  }] } });
107
- //# 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 { Observable, combineLatest, of } from 'rxjs';\nimport {\n  distinctUntilChanged,\n  map,\n  publishReplay,\n  refCount,\n  startWith,\n  switchMap,\n} from 'rxjs/operators';\n\nimport { InputComponent } from '../input/public-api';\nimport { coerceString } 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.value$$.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.value$,\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      publishReplay(1),\n      refCount(),\n    );\n\n    this.hasSelected$ = this.selectedOption$.pipe(\n      map(({ label }) => !!label),\n      publishReplay(1),\n      refCount(),\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  override writeValue(val: T) {\n    this.value$$.next(val);\n    this.closeOption();\n  }\n\n  selectOption(option: OptionComponent<T>) {\n    this.emitValueChange(option.value);\n    this.closeOption();\n  }\n\n  clearValue(event: Event) {\n    this.emitValueChange(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 auiInputSuffix class=\"aui-select__icon-container\">\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=\"close_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 #optionListRef class=\"aui-option-container__content\">\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"]}
107
+ //# 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 { Observable, combineLatest, of } from 'rxjs';\nimport {\n  distinctUntilChanged,\n  map,\n  publishReplay,\n  refCount,\n  startWith,\n  switchMap,\n} from 'rxjs/operators';\n\nimport { InputComponent } from '../input/public-api';\nimport { coerceString } 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      publishReplay(1),\n      refCount(),\n    );\n\n    this.hasSelected$ = this.selectedOption$.pipe(\n      map(({ label }) => !!label),\n      publishReplay(1),\n      refCount(),\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 auiInputSuffix class=\"aui-select__icon-container\">\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=\"close_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 #optionListRef class=\"aui-option-container__content\">\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"]}
@@ -11,14 +11,11 @@ export class SwitchComponent extends CommonFormControl {
11
11
  this.bem = buildBem(prefix);
12
12
  this.loading = false;
13
13
  }
14
- writeValue(value) {
15
- this.value$$.next(value);
16
- }
17
14
  onSwitch() {
18
15
  if (this.disabled) {
19
16
  return;
20
17
  }
21
- this.emitValueChange(!this.snapshot.value);
18
+ this.emitValue(!this.model);
22
19
  }
23
20
  onBlur() {
24
21
  if (this.onTouched) {
@@ -33,7 +30,7 @@ SwitchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", versio
33
30
  useExisting: forwardRef(() => SwitchComponent),
34
31
  multi: true,
35
32
  },
36
- ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"aui-switch\"\n [class.isLoading]=\"loading\"\n [class.isDisabled]=\"disabled\"\n [class.isChecked]=\"value$ | async\"\n (click)=\"onSwitch()\"\n>\n <input\n #input\n [ngClass]=\"bem.element('input')\"\n type=\"checkbox\"\n [disabled]=\"disabled\"\n [checked]=\"value$ | async\"\n (blur)=\"onBlur()\"\n />\n <span [ngClass]=\"bem.element('bar')\">\n <i [ngClass]=\"bem.element('dot')\"></i>\n </span>\n</div>\n", styles: ["@charset \"UTF-8\";.aui-switch{display:inline-flex;position:relative;vertical-align:text-bottom;color:rgb(var(--aui-color-n-4));cursor:pointer}.aui-switch__input{position:absolute;width:0;height:0;opacity:0;margin:0}:root .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.16)}html[aui-theme-mode=light] .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.3)}}html[aui-theme-mode=dark] .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.3)}.aui-switch__bar{display:inline-block;width:30px;height:16px;border-radius:8px;background-color:currentColor;transition:background-color .3s;position:relative;vertical-align:middle;-webkit-user-select:none;user-select:none}.aui-switch__dot{background-color:#fff;border-radius:50%;width:12px;height:12px;position:absolute;top:2px;left:2px;transition:left .3s}.aui-switch.isDisabled{color:rgb(var(--aui-color-n-7));cursor:not-allowed}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-switch.isDisabled .aui-switch__dot{background-color:rgb(var(--aui-color-n-4))}}html[aui-theme-mode=dark] .aui-switch.isDisabled .aui-switch__dot{background-color:rgb(var(--aui-color-n-4))}.aui-switch.isChecked{color:rgb(var(--aui-color-primary))}.aui-switch.isChecked.isDisabled{color:rgb(var(--aui-color-p-4))}.aui-switch.isChecked .aui-switch__dot{left:16px}.aui-switch.isLoading .aui-switch__dot:after{content:\"\";position:absolute;top:2px;bottom:2px;left:2px;right:2px;border:1px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin 1s infinite linear}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"], directives: [{ type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "async": i1.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
33
+ ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"aui-switch\"\n [class.isLoading]=\"loading\"\n [class.isDisabled]=\"disabled\"\n [class.isChecked]=\"model\"\n (click)=\"onSwitch()\"\n>\n <input\n #input\n [ngClass]=\"bem.element('input')\"\n type=\"checkbox\"\n [disabled]=\"disabled\"\n [checked]=\"model\"\n (blur)=\"onBlur()\"\n />\n <span [ngClass]=\"bem.element('bar')\">\n <i [ngClass]=\"bem.element('dot')\"></i>\n </span>\n</div>\n", styles: ["@charset \"UTF-8\";.aui-switch{display:inline-flex;position:relative;vertical-align:text-bottom;color:rgb(var(--aui-color-n-4));cursor:pointer}.aui-switch__input{position:absolute;width:0;height:0;opacity:0;margin:0}:root .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.16)}html[aui-theme-mode=light] .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.3)}}html[aui-theme-mode=dark] .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.3)}.aui-switch__bar{display:inline-block;width:30px;height:16px;border-radius:8px;background-color:currentColor;transition:background-color .3s;position:relative;vertical-align:middle;-webkit-user-select:none;user-select:none}.aui-switch__dot{background-color:#fff;border-radius:50%;width:12px;height:12px;position:absolute;top:2px;left:2px;transition:left .3s}.aui-switch.isDisabled{color:rgb(var(--aui-color-n-7));cursor:not-allowed}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-switch.isDisabled .aui-switch__dot{background-color:rgb(var(--aui-color-n-4))}}html[aui-theme-mode=dark] .aui-switch.isDisabled .aui-switch__dot{background-color:rgb(var(--aui-color-n-4))}.aui-switch.isChecked{color:rgb(var(--aui-color-primary))}.aui-switch.isChecked.isDisabled{color:rgb(var(--aui-color-p-4))}.aui-switch.isChecked .aui-switch__dot{left:16px}.aui-switch.isLoading .aui-switch__dot:after{content:\"\";position:absolute;top:2px;bottom:2px;left:2px;right:2px;border:1px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin 1s infinite linear}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"], directives: [{ type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
37
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: SwitchComponent, decorators: [{
38
35
  type: Component,
39
36
  args: [{ selector: 'aui-switch', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, preserveWhitespaces: false, providers: [
@@ -42,8 +39,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
42
39
  useExisting: forwardRef(() => SwitchComponent),
43
40
  multi: true,
44
41
  },
45
- ], template: "<div\n class=\"aui-switch\"\n [class.isLoading]=\"loading\"\n [class.isDisabled]=\"disabled\"\n [class.isChecked]=\"value$ | async\"\n (click)=\"onSwitch()\"\n>\n <input\n #input\n [ngClass]=\"bem.element('input')\"\n type=\"checkbox\"\n [disabled]=\"disabled\"\n [checked]=\"value$ | async\"\n (blur)=\"onBlur()\"\n />\n <span [ngClass]=\"bem.element('bar')\">\n <i [ngClass]=\"bem.element('dot')\"></i>\n </span>\n</div>\n", styles: ["@charset \"UTF-8\";.aui-switch{display:inline-flex;position:relative;vertical-align:text-bottom;color:rgb(var(--aui-color-n-4));cursor:pointer}.aui-switch__input{position:absolute;width:0;height:0;opacity:0;margin:0}:root .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.16)}html[aui-theme-mode=light] .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.3)}}html[aui-theme-mode=dark] .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.3)}.aui-switch__bar{display:inline-block;width:30px;height:16px;border-radius:8px;background-color:currentColor;transition:background-color .3s;position:relative;vertical-align:middle;-webkit-user-select:none;user-select:none}.aui-switch__dot{background-color:#fff;border-radius:50%;width:12px;height:12px;position:absolute;top:2px;left:2px;transition:left .3s}.aui-switch.isDisabled{color:rgb(var(--aui-color-n-7));cursor:not-allowed}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-switch.isDisabled .aui-switch__dot{background-color:rgb(var(--aui-color-n-4))}}html[aui-theme-mode=dark] .aui-switch.isDisabled .aui-switch__dot{background-color:rgb(var(--aui-color-n-4))}.aui-switch.isChecked{color:rgb(var(--aui-color-primary))}.aui-switch.isChecked.isDisabled{color:rgb(var(--aui-color-p-4))}.aui-switch.isChecked .aui-switch__dot{left:16px}.aui-switch.isLoading .aui-switch__dot:after{content:\"\";position:absolute;top:2px;bottom:2px;left:2px;right:2px;border:1px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin 1s infinite linear}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"] }]
42
+ ], template: "<div\n class=\"aui-switch\"\n [class.isLoading]=\"loading\"\n [class.isDisabled]=\"disabled\"\n [class.isChecked]=\"model\"\n (click)=\"onSwitch()\"\n>\n <input\n #input\n [ngClass]=\"bem.element('input')\"\n type=\"checkbox\"\n [disabled]=\"disabled\"\n [checked]=\"model\"\n (blur)=\"onBlur()\"\n />\n <span [ngClass]=\"bem.element('bar')\">\n <i [ngClass]=\"bem.element('dot')\"></i>\n </span>\n</div>\n", styles: ["@charset \"UTF-8\";.aui-switch{display:inline-flex;position:relative;vertical-align:text-bottom;color:rgb(var(--aui-color-n-4));cursor:pointer}.aui-switch__input{position:absolute;width:0;height:0;opacity:0;margin:0}:root .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.16)}html[aui-theme-mode=light] .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.3)}}html[aui-theme-mode=dark] .aui-switch__input:focus+.aui-switch__bar{box-shadow:0 0 0 2px rgba(var(--aui-color-primary),.3)}.aui-switch__bar{display:inline-block;width:30px;height:16px;border-radius:8px;background-color:currentColor;transition:background-color .3s;position:relative;vertical-align:middle;-webkit-user-select:none;user-select:none}.aui-switch__dot{background-color:#fff;border-radius:50%;width:12px;height:12px;position:absolute;top:2px;left:2px;transition:left .3s}.aui-switch.isDisabled{color:rgb(var(--aui-color-n-7));cursor:not-allowed}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-switch.isDisabled .aui-switch__dot{background-color:rgb(var(--aui-color-n-4))}}html[aui-theme-mode=dark] .aui-switch.isDisabled .aui-switch__dot{background-color:rgb(var(--aui-color-n-4))}.aui-switch.isChecked{color:rgb(var(--aui-color-primary))}.aui-switch.isChecked.isDisabled{color:rgb(var(--aui-color-p-4))}.aui-switch.isChecked .aui-switch__dot{left:16px}.aui-switch.isLoading .aui-switch__dot:after{content:\"\";position:absolute;top:2px;bottom:2px;left:2px;right:2px;border:1px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin 1s infinite linear}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"] }]
46
43
  }], propDecorators: { loading: [{
47
44
  type: Input
48
45
  }] } });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zd2l0Y2gvc3dpdGNoLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uL3NyYy9zd2l0Y2gvc3dpdGNoLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULEtBQUssRUFDTCxpQkFBaUIsRUFDakIsVUFBVSxHQUNYLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRW5ELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3ZELE9BQU8sRUFBTyxRQUFRLEVBQUUsTUFBTSxVQUFVLENBQUM7OztBQUV6QyxNQUFNLE1BQU0sR0FBRyxZQUFZLENBQUM7QUFpQjVCLE1BQU0sT0FBTyxlQUFnQixTQUFRLGlCQUEwQjtJQWYvRDs7UUFnQkUsUUFBRyxHQUFRLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUc1QixZQUFPLEdBQUcsS0FBSyxDQUFDO0tBa0JqQjtJQWhCVSxVQUFVLENBQUMsS0FBYztRQUNoQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMzQixDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNqQixPQUFPO1NBQ1I7UUFDRCxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsTUFBTTtRQUNKLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUNsQixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7U0FDbEI7SUFDSCxDQUFDOzs0R0FyQlUsZUFBZTtnR0FBZixlQUFlLHFFQVJmO1FBQ1Q7WUFDRSxPQUFPLEVBQUUsaUJBQWlCO1lBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsZUFBZSxDQUFDO1lBQzlDLEtBQUssRUFBRSxJQUFJO1NBQ1o7S0FDRixpREMzQkgsd2NBbUJBOzJGRFVhLGVBQWU7a0JBZjNCLFNBQVM7K0JBQ0UsWUFBWSxpQkFHUCxpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNLHVCQUMxQixLQUFLLGFBQ2Y7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsZ0JBQWdCLENBQUM7NEJBQzlDLEtBQUssRUFBRSxJQUFJO3lCQUNaO3FCQUNGOzhCQU1ELE9BQU87c0JBRE4sS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIElucHV0LFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbiAgZm9yd2FyZFJlZixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuaW1wb3J0IHsgQ29tbW9uRm9ybUNvbnRyb2wgfSBmcm9tICcuLi9mb3JtL3B1YmxpYy1hcGknO1xuaW1wb3J0IHsgQmVtLCBidWlsZEJlbSB9IGZyb20gJy4uL3V0aWxzJztcblxuY29uc3QgcHJlZml4ID0gJ2F1aS1zd2l0Y2gnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhdWktc3dpdGNoJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3N3aXRjaC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3N3aXRjaC5jb21wb25lbnQuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgcHJlc2VydmVXaGl0ZXNwYWNlczogZmFsc2UsXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxuICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gU3dpdGNoQ29tcG9uZW50KSxcbiAgICAgIG11bHRpOiB0cnVlLFxuICAgIH0sXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIFN3aXRjaENvbXBvbmVudCBleHRlbmRzIENvbW1vbkZvcm1Db250cm9sPGJvb2xlYW4+IHtcbiAgYmVtOiBCZW0gPSBidWlsZEJlbShwcmVmaXgpO1xuXG4gIEBJbnB1dCgpXG4gIGxvYWRpbmcgPSBmYWxzZTtcblxuICBvdmVycmlkZSB3cml0ZVZhbHVlKHZhbHVlOiBib29sZWFuKSB7XG4gICAgdGhpcy52YWx1ZSQkLm5leHQodmFsdWUpO1xuICB9XG5cbiAgb25Td2l0Y2goKSB7XG4gICAgaWYgKHRoaXMuZGlzYWJsZWQpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgdGhpcy5lbWl0VmFsdWVDaGFuZ2UoIXRoaXMuc25hcHNob3QudmFsdWUpO1xuICB9XG5cbiAgb25CbHVyKCkge1xuICAgIGlmICh0aGlzLm9uVG91Y2hlZCkge1xuICAgICAgdGhpcy5vblRvdWNoZWQoKTtcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXZcbiAgY2xhc3M9XCJhdWktc3dpdGNoXCJcbiAgW2NsYXNzLmlzTG9hZGluZ109XCJsb2FkaW5nXCJcbiAgW2NsYXNzLmlzRGlzYWJsZWRdPVwiZGlzYWJsZWRcIlxuICBbY2xhc3MuaXNDaGVja2VkXT1cInZhbHVlJCB8IGFzeW5jXCJcbiAgKGNsaWNrKT1cIm9uU3dpdGNoKClcIlxuPlxuICA8aW5wdXRcbiAgICAjaW5wdXRcbiAgICBbbmdDbGFzc109XCJiZW0uZWxlbWVudCgnaW5wdXQnKVwiXG4gICAgdHlwZT1cImNoZWNrYm94XCJcbiAgICBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIlxuICAgIFtjaGVja2VkXT1cInZhbHVlJCB8IGFzeW5jXCJcbiAgICAoYmx1cik9XCJvbkJsdXIoKVwiXG4gIC8+XG4gIDxzcGFuIFtuZ0NsYXNzXT1cImJlbS5lbGVtZW50KCdiYXInKVwiPlxuICAgIDxpIFtuZ0NsYXNzXT1cImJlbS5lbGVtZW50KCdkb3QnKVwiPjwvaT5cbiAgPC9zcGFuPlxuPC9kaXY+XG4iXX0=
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zd2l0Y2gvc3dpdGNoLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uL3NyYy9zd2l0Y2gvc3dpdGNoLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULEtBQUssRUFDTCxpQkFBaUIsRUFDakIsVUFBVSxHQUNYLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRW5ELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3ZELE9BQU8sRUFBTyxRQUFRLEVBQUUsTUFBTSxVQUFVLENBQUM7OztBQUV6QyxNQUFNLE1BQU0sR0FBRyxZQUFZLENBQUM7QUFpQjVCLE1BQU0sT0FBTyxlQUFnQixTQUFRLGlCQUEwQjtJQWYvRDs7UUFnQkUsUUFBRyxHQUFRLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUc1QixZQUFPLEdBQUcsS0FBSyxDQUFDO0tBY2pCO0lBWkMsUUFBUTtRQUNOLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNqQixPQUFPO1NBQ1I7UUFDRCxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFFRCxNQUFNO1FBQ0osSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQ2xCLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztTQUNsQjtJQUNILENBQUM7OzRHQWpCVSxlQUFlO2dHQUFmLGVBQWUscUVBUmY7UUFDVDtZQUNFLE9BQU8sRUFBRSxpQkFBaUI7WUFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxlQUFlLENBQUM7WUFDOUMsS0FBSyxFQUFFLElBQUk7U0FDWjtLQUNGLGlEQzNCSCxzYkFtQkE7MkZEVWEsZUFBZTtrQkFmM0IsU0FBUzsrQkFDRSxZQUFZLGlCQUdQLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0sdUJBQzFCLEtBQUssYUFDZjt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxnQkFBZ0IsQ0FBQzs0QkFDOUMsS0FBSyxFQUFFLElBQUk7eUJBQ1o7cUJBQ0Y7OEJBTUQsT0FBTztzQkFETixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgSW5wdXQsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxuICBmb3J3YXJkUmVmLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5HX1ZBTFVFX0FDQ0VTU09SIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5pbXBvcnQgeyBDb21tb25Gb3JtQ29udHJvbCB9IGZyb20gJy4uL2Zvcm0vcHVibGljLWFwaSc7XG5pbXBvcnQgeyBCZW0sIGJ1aWxkQmVtIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5jb25zdCBwcmVmaXggPSAnYXVpLXN3aXRjaCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2F1aS1zd2l0Y2gnLFxuICB0ZW1wbGF0ZVVybDogJy4vc3dpdGNoLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vc3dpdGNoLmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBwcmVzZXJ2ZVdoaXRlc3BhY2VzOiBmYWxzZSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBTd2l0Y2hDb21wb25lbnQpLFxuICAgICAgbXVsdGk6IHRydWUsXG4gICAgfSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgU3dpdGNoQ29tcG9uZW50IGV4dGVuZHMgQ29tbW9uRm9ybUNvbnRyb2w8Ym9vbGVhbj4ge1xuICBiZW06IEJlbSA9IGJ1aWxkQmVtKHByZWZpeCk7XG5cbiAgQElucHV0KClcbiAgbG9hZGluZyA9IGZhbHNlO1xuXG4gIG9uU3dpdGNoKCkge1xuICAgIGlmICh0aGlzLmRpc2FibGVkKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHRoaXMuZW1pdFZhbHVlKCF0aGlzLm1vZGVsKTtcbiAgfVxuXG4gIG9uQmx1cigpIHtcbiAgICBpZiAodGhpcy5vblRvdWNoZWQpIHtcbiAgICAgIHRoaXMub25Ub3VjaGVkKCk7XG4gICAgfVxuICB9XG59XG4iLCI8ZGl2XG4gIGNsYXNzPVwiYXVpLXN3aXRjaFwiXG4gIFtjbGFzcy5pc0xvYWRpbmddPVwibG9hZGluZ1wiXG4gIFtjbGFzcy5pc0Rpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgW2NsYXNzLmlzQ2hlY2tlZF09XCJtb2RlbFwiXG4gIChjbGljayk9XCJvblN3aXRjaCgpXCJcbj5cbiAgPGlucHV0XG4gICAgI2lucHV0XG4gICAgW25nQ2xhc3NdPVwiYmVtLmVsZW1lbnQoJ2lucHV0JylcIlxuICAgIHR5cGU9XCJjaGVja2JveFwiXG4gICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgICBbY2hlY2tlZF09XCJtb2RlbFwiXG4gICAgKGJsdXIpPVwib25CbHVyKClcIlxuICAvPlxuICA8c3BhbiBbbmdDbGFzc109XCJiZW0uZWxlbWVudCgnYmFyJylcIj5cbiAgICA8aSBbbmdDbGFzc109XCJiZW0uZWxlbWVudCgnZG90JylcIj48L2k+XG4gIDwvc3Bhbj5cbjwvZGl2PlxuIl19
@@ -109,7 +109,7 @@ export class TimePickerComponent extends CommonFormControl {
109
109
  }
110
110
  submit(close = true, value) {
111
111
  const refer = value ?? this.timeValue;
112
- this.emitValue(refer
112
+ this.emitModel(refer
113
113
  ? {
114
114
  second: refer.second(),
115
115
  minute: refer.minute(),
@@ -170,4 +170,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
170
170
  type: ViewChild,
171
171
  args: ['tooltipRef']
172
172
  }] } });
173
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../src/time-picker/component.ts","../../../src/time-picker/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport dayjs, { Dayjs } from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\n\nimport { updateDateByTimeModel } from '../date-picker/calendar/util';\nimport { CommonFormControl } from '../form/common-form';\nimport { TooltipDirective } from '../tooltip/public-api';\nimport { ComponentSize } from '../types';\n\nimport {\n  TimePickerDataLike,\n  TimePickerModel,\n  isTimePickerModel,\n} from './time-picker.type';\n\ndayjs.extend(customParseFormat);\n\n@Component({\n  selector: 'aui-time-picker',\n  templateUrl: './template.html',\n  styleUrls: ['./style.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => TimePickerComponent),\n      multi: true,\n    },\n  ],\n})\nexport class TimePickerComponent extends CommonFormControl<\n  TimePickerDataLike,\n  TimePickerModel\n> {\n  @Input()\n  format = 'HH:mm:ss';\n\n  @Input()\n  size: ComponentSize = ComponentSize.Medium;\n\n  @Input()\n  placeholder = '';\n\n  @Input()\n  clearable = true;\n\n  @Input()\n  showIcon = true;\n\n  @Input()\n  disableHours: () => number[];\n\n  @Input()\n  disableMinutes: (hour?: number) => number[];\n\n  @Input()\n  disableSeconds: (hour?: number, minute?: number) => number[];\n\n  @Input()\n  hourStep = 1;\n\n  @Input()\n  minuteStep = 1;\n\n  @Input()\n  secondStep = 1;\n\n  @Input()\n  footerTemplate: TemplateRef<void>;\n\n  @Output()\n  readonly open = new EventEmitter<void>();\n\n  @Output()\n  readonly close = new EventEmitter<void>();\n\n  @ViewChild('tooltipRef')\n  tooltipRef: TooltipDirective;\n\n  timeValue: Dayjs = null;\n  timeFormatValue = '';\n\n  override writeValue(value: TimePickerDataLike) {\n    super.writeValue(value);\n    if (!value) {\n      return this.setValue(null);\n    }\n    let result: Dayjs;\n    if (isTimePickerModel(value)) {\n      result = updateDateByTimeModel(dayjs(), value);\n    } else {\n      result = dayjs(value);\n      this.submit(false, result);\n    }\n    this.setValue(result);\n  }\n\n  setValue(value: Dayjs) {\n    this.timeValue = value;\n    this.timeFormatValue = value ? dayjs(value).format(this.format) : null;\n    this.cdr.markForCheck();\n  }\n\n  changeFromPanel(value: Dayjs) {\n    this.timeFormatValue = value?.format(this.format);\n  }\n\n  changeFromInput(source: string) {\n    if (!source) {\n      this.timeValue = null;\n    } else {\n      const afterParsed = dayjs(source, this.format);\n      if (afterParsed.isValid()) {\n        this.timeValue = afterParsed;\n      }\n    }\n  }\n\n  onKeyDown(event: KeyboardEvent) {\n    switch (event.key) {\n      case 'Enter':\n        this.openPanel();\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n      case 'Escape':\n        this.closePanel();\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n    }\n  }\n\n  onBlur() {\n    if (this.onTouched) {\n      this.onTouched();\n    }\n    this.setValue(this.timeValue);\n    this.submit();\n  }\n\n  openPanel() {\n    if (this.tooltipRef.isCreated) {\n      return;\n    }\n    this.tooltipRef.createTooltip();\n    this.open.next();\n  }\n\n  closePanel() {\n    if (!this.tooltipRef.isCreated) {\n      return;\n    }\n    this.tooltipRef.disposeTooltip();\n    this.close.next();\n  }\n\n  clearValue(event: Event) {\n    this.setValue(null);\n    this.submit();\n    event.stopPropagation();\n    event.preventDefault();\n  }\n\n  submit(close = true, value?: Dayjs) {\n    const refer = value ?? this.timeValue;\n    this.emitValue(\n      refer\n        ? {\n            second: refer.second(),\n            minute: refer.minute(),\n            hour: refer.hour(),\n          }\n        : null,\n    );\n    if (close) {\n      this.closePanel();\n    }\n  }\n}\n","<div\n  class=\"aui-time-picker\"\n  [class.isDisabled]=\"disabled\"\n  [class.isClearable]=\"clearable && timeFormatValue\"\n  #tooltipRef=\"auiTooltip\"\n  [auiTooltip]=\"template\"\n  auiTooltipType=\"plain\"\n  auiTooltipTrigger=\"click\"\n  auiTooltipPosition=\"bottom start\"\n  [auiTooltipDisabled]=\"disabled\"\n  (auiTooltipShow)=\"open.emit()\"\n  (auiTooltipHide)=\"close.emit()\"\n>\n  <aui-input-group>\n    <input\n      aui-input\n      autocomplete=\"off\"\n      [size]=\"size\"\n      [placeholder]=\"placeholder\"\n      [disabled]=\"disabled\"\n      [(ngModel)]=\"timeFormatValue\"\n      (ngModelChange)=\"changeFromInput($event)\"\n      (keydown)=\"onKeyDown($event)\"\n      (blur)=\"onBlur()\"\n    />\n    <span\n      *ngIf=\"showIcon\"\n      auiInputSuffix\n      class=\"aui-time-picker__icon-container\"\n    >\n      <aui-icon class=\"aui-time-picker__indicator\" icon=\"time\"></aui-icon>\n      <aui-icon\n        class=\"aui-time-picker__clear\"\n        icon=\"close_small\"\n        (click)=\"clearValue($event)\"\n      ></aui-icon>\n    </span>\n  </aui-input-group>\n</div>\n\n<ng-template #template>\n  <aui-time-picker-panel\n    [disabled]=\"disabled\"\n    [disableHours]=\"disableHours\"\n    [disableMinutes]=\"disableMinutes\"\n    [disableSeconds]=\"disableSeconds\"\n    [hourStep]=\"hourStep\"\n    [minuteStep]=\"minuteStep\"\n    [secondStep]=\"secondStep\"\n    [format]=\"format\"\n    [footerTemplate]=\"footerTemplate\"\n    [(ngModel)]=\"timeValue\"\n    (ngModelChange)=\"changeFromPanel($event)\"\n    (confirm)=\"submit()\"\n    (click)=\"$event.stopPropagation()\"\n    (mousedown)=\"$event.preventDefault()\"\n  ></aui-time-picker-panel>\n</ng-template>\n"]}
173
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../src/time-picker/component.ts","../../../src/time-picker/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport dayjs, { Dayjs } from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\n\nimport { updateDateByTimeModel } from '../date-picker/calendar/util';\nimport { CommonFormControl } from '../form/common-form';\nimport { TooltipDirective } from '../tooltip/public-api';\nimport { ComponentSize } from '../types';\n\nimport {\n  TimePickerDataLike,\n  TimePickerModel,\n  isTimePickerModel,\n} from './time-picker.type';\n\ndayjs.extend(customParseFormat);\n\n@Component({\n  selector: 'aui-time-picker',\n  templateUrl: './template.html',\n  styleUrls: ['./style.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => TimePickerComponent),\n      multi: true,\n    },\n  ],\n})\nexport class TimePickerComponent extends CommonFormControl<\n  TimePickerDataLike,\n  TimePickerModel\n> {\n  @Input()\n  format = 'HH:mm:ss';\n\n  @Input()\n  size: ComponentSize = ComponentSize.Medium;\n\n  @Input()\n  placeholder = '';\n\n  @Input()\n  clearable = true;\n\n  @Input()\n  showIcon = true;\n\n  @Input()\n  disableHours: () => number[];\n\n  @Input()\n  disableMinutes: (hour?: number) => number[];\n\n  @Input()\n  disableSeconds: (hour?: number, minute?: number) => number[];\n\n  @Input()\n  hourStep = 1;\n\n  @Input()\n  minuteStep = 1;\n\n  @Input()\n  secondStep = 1;\n\n  @Input()\n  footerTemplate: TemplateRef<void>;\n\n  @Output()\n  readonly open = new EventEmitter<void>();\n\n  @Output()\n  readonly close = new EventEmitter<void>();\n\n  @ViewChild('tooltipRef')\n  tooltipRef: TooltipDirective;\n\n  timeValue: Dayjs = null;\n  timeFormatValue = '';\n\n  override writeValue(value: TimePickerDataLike) {\n    super.writeValue(value);\n    if (!value) {\n      return this.setValue(null);\n    }\n    let result: Dayjs;\n    if (isTimePickerModel(value)) {\n      result = updateDateByTimeModel(dayjs(), value);\n    } else {\n      result = dayjs(value);\n      this.submit(false, result);\n    }\n    this.setValue(result);\n  }\n\n  setValue(value: Dayjs) {\n    this.timeValue = value;\n    this.timeFormatValue = value ? dayjs(value).format(this.format) : null;\n    this.cdr.markForCheck();\n  }\n\n  changeFromPanel(value: Dayjs) {\n    this.timeFormatValue = value?.format(this.format);\n  }\n\n  changeFromInput(source: string) {\n    if (!source) {\n      this.timeValue = null;\n    } else {\n      const afterParsed = dayjs(source, this.format);\n      if (afterParsed.isValid()) {\n        this.timeValue = afterParsed;\n      }\n    }\n  }\n\n  onKeyDown(event: KeyboardEvent) {\n    switch (event.key) {\n      case 'Enter':\n        this.openPanel();\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n      case 'Escape':\n        this.closePanel();\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n    }\n  }\n\n  onBlur() {\n    if (this.onTouched) {\n      this.onTouched();\n    }\n    this.setValue(this.timeValue);\n    this.submit();\n  }\n\n  openPanel() {\n    if (this.tooltipRef.isCreated) {\n      return;\n    }\n    this.tooltipRef.createTooltip();\n    this.open.next();\n  }\n\n  closePanel() {\n    if (!this.tooltipRef.isCreated) {\n      return;\n    }\n    this.tooltipRef.disposeTooltip();\n    this.close.next();\n  }\n\n  clearValue(event: Event) {\n    this.setValue(null);\n    this.submit();\n    event.stopPropagation();\n    event.preventDefault();\n  }\n\n  submit(close = true, value?: Dayjs) {\n    const refer = value ?? this.timeValue;\n    this.emitModel(\n      refer\n        ? {\n            second: refer.second(),\n            minute: refer.minute(),\n            hour: refer.hour(),\n          }\n        : null,\n    );\n    if (close) {\n      this.closePanel();\n    }\n  }\n}\n","<div\n  class=\"aui-time-picker\"\n  [class.isDisabled]=\"disabled\"\n  [class.isClearable]=\"clearable && timeFormatValue\"\n  #tooltipRef=\"auiTooltip\"\n  [auiTooltip]=\"template\"\n  auiTooltipType=\"plain\"\n  auiTooltipTrigger=\"click\"\n  auiTooltipPosition=\"bottom start\"\n  [auiTooltipDisabled]=\"disabled\"\n  (auiTooltipShow)=\"open.emit()\"\n  (auiTooltipHide)=\"close.emit()\"\n>\n  <aui-input-group>\n    <input\n      aui-input\n      autocomplete=\"off\"\n      [size]=\"size\"\n      [placeholder]=\"placeholder\"\n      [disabled]=\"disabled\"\n      [(ngModel)]=\"timeFormatValue\"\n      (ngModelChange)=\"changeFromInput($event)\"\n      (keydown)=\"onKeyDown($event)\"\n      (blur)=\"onBlur()\"\n    />\n    <span\n      *ngIf=\"showIcon\"\n      auiInputSuffix\n      class=\"aui-time-picker__icon-container\"\n    >\n      <aui-icon class=\"aui-time-picker__indicator\" icon=\"time\"></aui-icon>\n      <aui-icon\n        class=\"aui-time-picker__clear\"\n        icon=\"close_small\"\n        (click)=\"clearValue($event)\"\n      ></aui-icon>\n    </span>\n  </aui-input-group>\n</div>\n\n<ng-template #template>\n  <aui-time-picker-panel\n    [disabled]=\"disabled\"\n    [disableHours]=\"disableHours\"\n    [disableMinutes]=\"disableMinutes\"\n    [disableSeconds]=\"disableSeconds\"\n    [hourStep]=\"hourStep\"\n    [minuteStep]=\"minuteStep\"\n    [secondStep]=\"secondStep\"\n    [format]=\"format\"\n    [footerTemplate]=\"footerTemplate\"\n    [(ngModel)]=\"timeValue\"\n    (ngModelChange)=\"changeFromPanel($event)\"\n    (confirm)=\"submit()\"\n    (click)=\"$event.stopPropagation()\"\n    (mousedown)=\"$event.preventDefault()\"\n  ></aui-time-picker-panel>\n</ng-template>\n"]}