@alauda/ui 6.4.1-beta → 6.4.1-beta.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/autocomplete/autocomplete.directive.d.ts +1 -1
- package/esm2020/accordion/accordion-item/accordion-item.component.mjs +2 -2
- package/esm2020/anchor/anchor.component.mjs +2 -3
- package/esm2020/anchor/anchor.directive.mjs +2 -3
- package/esm2020/autocomplete/autocomplete.component.mjs +9 -6
- package/esm2020/autocomplete/autocomplete.directive.mjs +8 -5
- package/esm2020/autocomplete/suggestion/suggestion.component.mjs +5 -6
- package/esm2020/autocomplete/suggestion-group/suggestion-group.component.mjs +4 -4
- package/esm2020/back-top/back-top.component.mjs +2 -3
- package/esm2020/checkbox/checkbox.component.mjs +2 -3
- package/esm2020/dialog/confirm-dialog/confirm-dialog.component.mjs +3 -4
- package/esm2020/drawer/component/drawer.component.mjs +2 -3
- package/esm2020/drawer/drawer.service.mjs +2 -3
- package/esm2020/dropdown/dropdown.directive.mjs +2 -2
- package/esm2020/form/form-item/form-item.component.mjs +4 -4
- package/esm2020/form/form.directive.mjs +2 -3
- package/esm2020/icon/icon-register.service.mjs +8 -5
- package/esm2020/input/autosize.directive.mjs +2 -3
- package/esm2020/radio/base-radio.mjs +2 -3
- package/esm2020/radio/radio-button/radio-button.component.mjs +4 -4
- package/esm2020/radio/radio-group/radio-group.component.mjs +2 -3
- package/esm2020/scrolling/fixed-size-table-virtual-scroll-strategy.mjs +2 -3
- package/esm2020/scrolling/fixed-size-table-virtual-scroll.directive.mjs +2 -3
- package/esm2020/select/base-select.mjs +7 -8
- package/esm2020/select/multi-select/multi-select.component.mjs +5 -6
- package/esm2020/select/option/option.component.mjs +5 -6
- package/esm2020/select/option-group/option-group.component.mjs +4 -4
- package/esm2020/select/select.component.mjs +5 -6
- package/esm2020/steps/steps.component.mjs +2 -3
- package/esm2020/table/table-scroll.directive.mjs +2 -3
- package/esm2020/table-of-contents/toc-container.directive.mjs +2 -3
- package/esm2020/tabs/tab-context.service.mjs +2 -3
- package/esm2020/tabs/tab-header.component.mjs +2 -3
- package/esm2020/theme/theme.pipe.mjs +2 -3
- package/esm2020/theme/theme.service.mjs +2 -3
- package/esm2020/tooltip/base-tooltip.mjs +2 -3
- package/esm2020/tooltip/tooltip.component.mjs +7 -8
- package/esm2020/tree-select/tree-select.component.mjs +6 -6
- package/esm2020/utils/index.mjs +2 -1
- package/esm2020/utils/operators.mjs +12 -0
- package/esm2020/utils/watch-content-exist.mjs +4 -3
- package/fesm2015/alauda-ui.mjs +75 -55
- package/fesm2015/alauda-ui.mjs.map +1 -1
- package/fesm2020/alauda-ui.mjs +75 -55
- package/fesm2020/alauda-ui.mjs.map +1 -1
- package/package.json +1 -1
- package/utils/index.d.ts +1 -0
- package/utils/operators.d.ts +8 -0
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewChild, ViewEncapsulation, forwardRef, } from '@angular/core';
|
|
2
2
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
-
import { combineLatest, of } from 'rxjs';
|
|
4
|
-
import { map, publishReplay, refCount, startWith, switchMap, tap, } from 'rxjs/operators';
|
|
3
|
+
import { combineLatest, of, map, startWith, switchMap, tap, } from 'rxjs';
|
|
5
4
|
import { createWithMaxRowCount } from '../../input/tags-input/with-max-row-count';
|
|
6
5
|
import { ComponentSize } from '../../types';
|
|
7
|
-
import { buildBem, coerceAttrBoolean, coerceString } from '../../utils';
|
|
6
|
+
import { buildBem, coerceAttrBoolean, coerceString, publishRef, } from '../../utils';
|
|
8
7
|
import { BaseSelect } from '../base-select';
|
|
9
8
|
import { SelectAllStatus, } from '../select.types';
|
|
10
9
|
import * as i0 from "@angular/core";
|
|
@@ -104,7 +103,7 @@ export class MultiSelectComponent extends BaseSelect {
|
|
|
104
103
|
return 1;
|
|
105
104
|
}
|
|
106
105
|
return 0;
|
|
107
|
-
})),
|
|
106
|
+
})), publishRef());
|
|
108
107
|
}
|
|
109
108
|
ngAfterViewInit() {
|
|
110
109
|
super.ngAfterViewInit();
|
|
@@ -122,7 +121,7 @@ export class MultiSelectComponent extends BaseSelect {
|
|
|
122
121
|
: selected.length !== statuses.length
|
|
123
122
|
? SelectAllStatus.Indeterminate
|
|
124
123
|
: SelectAllStatus.Checked;
|
|
125
|
-
}), startWith(SelectAllStatus.Empty), tap(selectAllStatus => (this.selectAllStatus = selectAllStatus)),
|
|
124
|
+
}), startWith(SelectAllStatus.Empty), tap(selectAllStatus => (this.selectAllStatus = selectAllStatus)), publishRef());
|
|
126
125
|
this.hasEnabledOptions$ = combineLatest([
|
|
127
126
|
this.allOptions$,
|
|
128
127
|
this.filterString$,
|
|
@@ -306,4 +305,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
306
305
|
type: HostBinding,
|
|
307
306
|
args: ['style.display']
|
|
308
307
|
}] } });
|
|
309
|
-
//# 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  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  override model: T[] = [];\n\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.model.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  }\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(Boolean);\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.model.length > 0\n    ) {\n      this.removeValue(this.model[this.model.length - 1]);\n      event.stopPropagation();\n      event.preventDefault();\n    } else if (event.key === 'Enter') {\n      if (\n        this.model\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  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.model.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.model.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\n    if (this.selectAllStatus === SelectAllStatus.Checked) {\n      this.emitValue(\n        this.model.filter(value => !this.includes(visibleOptionsValue, value)),\n      );\n    } else {\n      this.emitValue(\n        this.model.concat(visibleOptionsValue).reduce<T[]>((acc, curr) => {\n          if (!this.includes(acc, curr)) {\n            acc.push(curr);\n          }\n          return acc;\n        }, []),\n      );\n    }\n  }\n\n  private includes(values: T[], value: T) {\n    return values.some(v => this.trackFn(v) === this.trackFn(value));\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  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]=\"model.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\n    #inputValueMirror\n    [class]=\"bem.element('mirror')\"\n  >\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\n      #optionListRef\n      class=\"aui-option-container__content\"\n    >\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"]}
|
|
308
|
+
//# 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 {\n  Observable,\n  combineLatest,\n  of,\n  map,\n  startWith,\n  switchMap,\n  tap,\n} from 'rxjs';\n\nimport { createWithMaxRowCount } from '../../input/tags-input/with-max-row-count';\nimport { ComponentSize } from '../../types';\nimport {\n  Bem,\n  buildBem,\n  coerceAttrBoolean,\n  coerceString,\n  publishRef,\n} 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  override model: T[] = [];\n\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.model.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  }\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      publishRef(),\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(Boolean);\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      publishRef(),\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.model.length > 0\n    ) {\n      this.removeValue(this.model[this.model.length - 1]);\n      event.stopPropagation();\n      event.preventDefault();\n    } else if (event.key === 'Enter') {\n      if (\n        this.model\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  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.model.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.model.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\n    if (this.selectAllStatus === SelectAllStatus.Checked) {\n      this.emitValue(\n        this.model.filter(value => !this.includes(visibleOptionsValue, value)),\n      );\n    } else {\n      this.emitValue(\n        this.model.concat(visibleOptionsValue).reduce<T[]>((acc, curr) => {\n          if (!this.includes(acc, curr)) {\n            acc.push(curr);\n          }\n          return acc;\n        }, []),\n      );\n    }\n  }\n\n  private includes(values: T[], value: T) {\n    return values.some(v => this.trackFn(v) === this.trackFn(value));\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  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]=\"model.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\n    #inputValueMirror\n    [class]=\"bem.element('mirror')\"\n  >\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\n      #optionListRef\n      class=\"aui-option-container__content\"\n    >\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"]}
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, Inject, Input, ViewChild, ViewEncapsulation, forwardRef, } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject, combineLatest } from 'rxjs';
|
|
3
|
-
import { distinctUntilChanged, map, publishReplay, refCount, tap, } from 'rxjs/operators';
|
|
2
|
+
import { BehaviorSubject, combineLatest, distinctUntilChanged, map, tap, } from 'rxjs';
|
|
4
3
|
import { ComponentSize } from '../../types';
|
|
5
|
-
import { buildBem, coerceAttrBoolean } from '../../utils';
|
|
4
|
+
import { buildBem, coerceAttrBoolean, publishRef } from '../../utils';
|
|
6
5
|
import { BaseSelect } from '../base-select';
|
|
7
6
|
import * as i0 from "@angular/core";
|
|
8
7
|
import * as i1 from "../../icon/icon.component";
|
|
@@ -33,7 +32,7 @@ export class OptionComponent {
|
|
|
33
32
|
?.map(this.select.trackFn)
|
|
34
33
|
.includes(this.select.trackFn(selfValue))), distinctUntilChanged(), tap(selected => {
|
|
35
34
|
this.selected = selected;
|
|
36
|
-
}),
|
|
35
|
+
}), publishRef());
|
|
37
36
|
this.size$ = this.select.size$.pipe(tap(size => {
|
|
38
37
|
this.size = size;
|
|
39
38
|
}));
|
|
@@ -42,7 +41,7 @@ export class OptionComponent {
|
|
|
42
41
|
combineLatest([this.label$, this.value$, this.labelContext$]).pipe(map(([label, value, labelContext]) => ({ label, value, labelContext }))),
|
|
43
42
|
]).pipe(map(([filterString, option]) => this.select.filterFn(filterString, option)), distinctUntilChanged(), tap(visible => {
|
|
44
43
|
this.visible = visible;
|
|
45
|
-
}),
|
|
44
|
+
}), publishRef());
|
|
46
45
|
}
|
|
47
46
|
get label() {
|
|
48
47
|
return this._label;
|
|
@@ -110,4 +109,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
110
109
|
type: ViewChild,
|
|
111
110
|
args: ['elRef', { static: true }]
|
|
112
111
|
}] } });
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option.component.js","sourceRoot":"","sources":["../../../../src/select/option/option.component.ts","../../../../src/select/option/option.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { BehaviorSubject, Observable, combineLatest } from 'rxjs';\nimport {\n  distinctUntilChanged,\n  map,\n  publishReplay,\n  refCount,\n  tap,\n} from 'rxjs/operators';\n\nimport { ComponentSize } from '../../types';\nimport { Bem, buildBem, coerceAttrBoolean } from '../../utils';\nimport { BaseSelect } from '../base-select';\n\n@Component({\n  selector: 'aui-option',\n  templateUrl: './option.component.html',\n  styleUrls: ['./option.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n})\nexport class OptionComponent<T> {\n  bem: Bem = buildBem('aui-option');\n\n  private _disabled = false;\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  private readonly disabled$$ = new BehaviorSubject(this.disabled);\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  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  set disabled(val: boolean | '') {\n    this._disabled = coerceAttrBoolean(val);\n    this.disabled$$.next(this._disabled);\n  }\n\n  isMulti = false;\n\n  @ViewChild('elRef', { static: true })\n  elRef: ElementRef<HTMLDivElement>;\n\n  private readonly select: BaseSelect<T>;\n  selected = false;\n  visible = true;\n  size: ComponentSize = ComponentSize.Medium;\n  focused = false;\n\n  value$ = this.value$$.asObservable();\n  label$ = this.label$$.asObservable();\n  labelContext$ = this.labelContext$$.asObservable();\n  disabled$ = this.disabled$$.asObservable();\n\n  selected$: Observable<boolean>;\n  size$: Observable<ComponentSize>;\n  visible$: Observable<boolean>;\n\n  constructor(\n    private readonly cdr: ChangeDetectorRef,\n    @Inject(forwardRef(() => BaseSelect))\n    select: any, // FIXME: workaround temporarily\n  ) {\n    this.isMulti = select.isMulti;\n    this.select = select;\n    this.selected$ = combineLatest([this.select.values$, this.value$$]).pipe(\n      map(([selectValue, selfValue]) =>\n        selectValue\n          ?.map(this.select.trackFn)\n          .includes(this.select.trackFn(selfValue)),\n      ),\n      distinctUntilChanged(),\n      tap(selected => {\n        this.selected = selected;\n      }),\n      publishReplay(1),\n      refCount(),\n    );\n    this.size$ = this.select.size$.pipe(\n      tap(size => {\n        this.size = size;\n      }),\n    );\n    this.visible$ = combineLatest([\n      this.select.filterString$,\n      combineLatest([this.label$, this.value$, this.labelContext$]).pipe(\n        map(([label, value, labelContext]) => ({ label, value, labelContext })),\n      ),\n    ]).pipe(\n      map(([filterString, option]) =>\n        this.select.filterFn(filterString, option),\n      ),\n      distinctUntilChanged(),\n      tap(visible => {\n        this.visible = visible;\n      }),\n      publishReplay(1),\n      refCount(),\n    );\n  }\n\n  onClick() {\n    if (this.disabled) {\n      return;\n    }\n    this.select.onOptionClick(this);\n  }\n\n  focus() {\n    if (this.disabled) {\n      return;\n    }\n    this.focused = true;\n    this.cdr.markForCheck();\n  }\n\n  blur() {\n    this.focused = false;\n    this.cdr.markForCheck();\n  }\n}\n","<div\n  #elRef\n  [hidden]=\"!(visible$ | async)\"\n  [class]=\"bem.block(size$ | async)\"\n  [class.isDisabled]=\"disabled\"\n  [class.isSelected]=\"selected$ | async\"\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$ | async)\"\n      icon=\"check_s\"\n    ></aui-icon>\n  </i>\n  <ng-content></ng-content>\n</div>\n"]}
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option.component.js","sourceRoot":"","sources":["../../../../src/select/option/option.component.ts","../../../../src/select/option/option.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport {\n  BehaviorSubject,\n  Observable,\n  combineLatest,\n  distinctUntilChanged,\n  map,\n  tap,\n} from 'rxjs';\n\nimport { ComponentSize } from '../../types';\nimport { Bem, buildBem, coerceAttrBoolean, publishRef } from '../../utils';\nimport { BaseSelect } from '../base-select';\n\n@Component({\n  selector: 'aui-option',\n  templateUrl: './option.component.html',\n  styleUrls: ['./option.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n})\nexport class OptionComponent<T> {\n  bem: Bem = buildBem('aui-option');\n\n  private _disabled = false;\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  private readonly disabled$$ = new BehaviorSubject(this.disabled);\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  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  set disabled(val: boolean | '') {\n    this._disabled = coerceAttrBoolean(val);\n    this.disabled$$.next(this._disabled);\n  }\n\n  isMulti = false;\n\n  @ViewChild('elRef', { static: true })\n  elRef: ElementRef<HTMLDivElement>;\n\n  private readonly select: BaseSelect<T>;\n  selected = false;\n  visible = true;\n  size: ComponentSize = ComponentSize.Medium;\n  focused = false;\n\n  value$ = this.value$$.asObservable();\n  label$ = this.label$$.asObservable();\n  labelContext$ = this.labelContext$$.asObservable();\n  disabled$ = this.disabled$$.asObservable();\n\n  selected$: Observable<boolean>;\n  size$: Observable<ComponentSize>;\n  visible$: Observable<boolean>;\n\n  constructor(\n    private readonly cdr: ChangeDetectorRef,\n    @Inject(forwardRef(() => BaseSelect))\n    select: any, // FIXME: workaround temporarily\n  ) {\n    this.isMulti = select.isMulti;\n    this.select = select;\n    this.selected$ = combineLatest([this.select.values$, this.value$$]).pipe(\n      map(([selectValue, selfValue]) =>\n        selectValue\n          ?.map(this.select.trackFn)\n          .includes(this.select.trackFn(selfValue)),\n      ),\n      distinctUntilChanged(),\n      tap(selected => {\n        this.selected = selected;\n      }),\n      publishRef(),\n    );\n    this.size$ = this.select.size$.pipe(\n      tap(size => {\n        this.size = size;\n      }),\n    );\n    this.visible$ = combineLatest([\n      this.select.filterString$,\n      combineLatest([this.label$, this.value$, this.labelContext$]).pipe(\n        map(([label, value, labelContext]) => ({ label, value, labelContext })),\n      ),\n    ]).pipe(\n      map(([filterString, option]) =>\n        this.select.filterFn(filterString, option),\n      ),\n      distinctUntilChanged(),\n      tap(visible => {\n        this.visible = visible;\n      }),\n      publishRef(),\n    );\n  }\n\n  onClick() {\n    if (this.disabled) {\n      return;\n    }\n    this.select.onOptionClick(this);\n  }\n\n  focus() {\n    if (this.disabled) {\n      return;\n    }\n    this.focused = true;\n    this.cdr.markForCheck();\n  }\n\n  blur() {\n    this.focused = false;\n    this.cdr.markForCheck();\n  }\n}\n","<div\n  #elRef\n  [hidden]=\"!(visible$ | async)\"\n  [class]=\"bem.block(size$ | async)\"\n  [class.isDisabled]=\"disabled\"\n  [class.isSelected]=\"selected$ | async\"\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$ | async)\"\n      icon=\"check_s\"\n    ></aui-icon>\n  </i>\n  <ng-content></ng-content>\n</div>\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, ContentChildren, ViewEncapsulation, forwardRef, } from '@angular/core';
|
|
2
|
-
import { combineLatest, of } from 'rxjs';
|
|
3
|
-
import {
|
|
2
|
+
import { combineLatest, of, map, startWith, switchMap } from 'rxjs';
|
|
3
|
+
import { publishRef } from '../../utils';
|
|
4
4
|
import { OptionComponent } from '../option/option.component';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/common";
|
|
@@ -8,7 +8,7 @@ export class OptionGroupComponent {
|
|
|
8
8
|
ngAfterContentInit() {
|
|
9
9
|
this.hasVisibleOption$ = this.options.changes.pipe(startWith(this.options), switchMap((options) => options.length > 0
|
|
10
10
|
? combineLatest(options.map(node => node.visible$))
|
|
11
|
-
: of([false])), map(visible => visible.some(Boolean)),
|
|
11
|
+
: of([false])), map(visible => visible.some(Boolean)), publishRef());
|
|
12
12
|
}
|
|
13
13
|
}
|
|
14
14
|
OptionGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: OptionGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -20,4 +20,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
20
20
|
type: ContentChildren,
|
|
21
21
|
args: [forwardRef(() => OptionComponent)]
|
|
22
22
|
}] } });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLWdyb3VwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9zZWxlY3Qvb3B0aW9uLWdyb3VwL29wdGlvbi1ncm91cC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvc2VsZWN0L29wdGlvbi1ncm91cC9vcHRpb24tZ3JvdXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsZUFBZSxFQUVmLGlCQUFpQixFQUNqQixVQUFVLEdBQ1gsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFjLGFBQWEsRUFBRSxFQUFFLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFaEYsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7OztBQVU3RCxNQUFNLE9BQU8sb0JBQW9CO0lBTS9CLGtCQUFrQjtRQUNoQixJQUFJLENBQUMsaUJBQWlCLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUNoRCxTQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxFQUN2QixTQUFTLENBQUMsQ0FBQyxPQUFzQyxFQUFFLEVBQUUsQ0FDbkQsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDO1lBQ2hCLENBQUMsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUNuRCxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FDaEIsRUFDRCxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEVBQ3JDLFVBQVUsRUFBRSxDQUNiLENBQUM7SUFDSixDQUFDOztpSEFqQlUsb0JBQW9CO3FHQUFwQixvQkFBb0IsbUhBQ0csZUFBZSxpQ0N2Qm5ELHdPQU9BOzJGRGVhLG9CQUFvQjtrQkFSaEMsU0FBUzsrQkFDRSxrQkFBa0IsbUJBR1gsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSx1QkFDaEIsS0FBSzs4QkFJMUIsT0FBTztzQkFETixlQUFlO3VCQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBZnRlckNvbnRlbnRJbml0LFxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBDb250ZW50Q2hpbGRyZW4sXG4gIFF1ZXJ5TGlzdCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG4gIGZvcndhcmRSZWYsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgY29tYmluZUxhdGVzdCwgb2YsIG1hcCwgc3RhcnRXaXRoLCBzd2l0Y2hNYXAgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgcHVibGlzaFJlZiB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IE9wdGlvbkNvbXBvbmVudCB9IGZyb20gJy4uL29wdGlvbi9vcHRpb24uY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXVpLW9wdGlvbi1ncm91cCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9vcHRpb24tZ3JvdXAuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9vcHRpb24tZ3JvdXAuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIHByZXNlcnZlV2hpdGVzcGFjZXM6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBPcHRpb25Hcm91cENvbXBvbmVudDxUPiBpbXBsZW1lbnRzIEFmdGVyQ29udGVudEluaXQge1xuICBAQ29udGVudENoaWxkcmVuKGZvcndhcmRSZWYoKCkgPT4gT3B0aW9uQ29tcG9uZW50KSlcbiAgb3B0aW9uczogUXVlcnlMaXN0PE9wdGlvbkNvbXBvbmVudDxUPj47XG5cbiAgaGFzVmlzaWJsZU9wdGlvbiQ6IE9ic2VydmFibGU8Ym9vbGVhbj47XG5cbiAgbmdBZnRlckNvbnRlbnRJbml0KCkge1xuICAgIHRoaXMuaGFzVmlzaWJsZU9wdGlvbiQgPSB0aGlzLm9wdGlvbnMuY2hhbmdlcy5waXBlKFxuICAgICAgc3RhcnRXaXRoKHRoaXMub3B0aW9ucyksXG4gICAgICBzd2l0Y2hNYXAoKG9wdGlvbnM6IFF1ZXJ5TGlzdDxPcHRpb25Db21wb25lbnQ8VD4+KSA9PlxuICAgICAgICBvcHRpb25zLmxlbmd0aCA+IDBcbiAgICAgICAgICA/IGNvbWJpbmVMYXRlc3Qob3B0aW9ucy5tYXAobm9kZSA9PiBub2RlLnZpc2libGUkKSlcbiAgICAgICAgICA6IG9mKFtmYWxzZV0pLFxuICAgICAgKSxcbiAgICAgIG1hcCh2aXNpYmxlID0+IHZpc2libGUuc29tZShCb29sZWFuKSksXG4gICAgICBwdWJsaXNoUmVmKCksXG4gICAgKTtcbiAgfVxufVxuIiwiPGRpdlxuICBbaGlkZGVuXT1cIiEoaGFzVmlzaWJsZU9wdGlvbiQgfCBhc3luYylcIlxuICBjbGFzcz1cImF1aS1vcHRpb24tZ3JvdXBcIlxuPlxuICA8bmctY29udGVudCBzZWxlY3Q9XCJbYXVpT3B0aW9uR3JvdXBUaXRsZV1cIj48L25nLWNvbnRlbnQ+XG4gIDxkaXYgY2xhc3M9XCJhdWktb3B0aW9uLWdyb3VwX19jb250ZW50XCI+PG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PjwvZGl2PlxuPC9kaXY+XG4iXX0=
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, ViewChild, ViewEncapsulation, forwardRef, } from '@angular/core';
|
|
2
2
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
-
import { combineLatest, of } from 'rxjs';
|
|
4
|
-
import {
|
|
5
|
-
import { coerceString } from '../utils';
|
|
3
|
+
import { combineLatest, of, distinctUntilChanged, map, startWith, switchMap, } from 'rxjs';
|
|
4
|
+
import { coerceString, publishRef } from '../utils';
|
|
6
5
|
import { BaseSelect } from './base-select';
|
|
7
6
|
import * as i0 from "@angular/core";
|
|
8
7
|
import * as i1 from "../input/input-group/input-group.component";
|
|
@@ -51,8 +50,8 @@ export class SelectComponent extends BaseSelect {
|
|
|
51
50
|
}
|
|
52
51
|
: {
|
|
53
52
|
label: this.labelFn?.(value) || coerceString(this.trackFn(value)),
|
|
54
|
-
}),
|
|
55
|
-
this.hasSelected$ = this.selectedOption$.pipe(map(({ label }) => !!label),
|
|
53
|
+
}), publishRef());
|
|
54
|
+
this.hasSelected$ = this.selectedOption$.pipe(map(({ label }) => !!label), publishRef());
|
|
56
55
|
}
|
|
57
56
|
onShowOptions() {
|
|
58
57
|
super.onShowOptions();
|
|
@@ -104,4 +103,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
104
103
|
type: ViewChild,
|
|
105
104
|
args: ['inputRef', { static: true }]
|
|
106
105
|
}] } });
|
|
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":"AAAA,OAAO,EAEL,uBAAuB,EACvB,SAAS,EAET,SAAS,EACT,iBAAiB,EACjB,UAAU,GACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAc,aAAa,EAAE,EAAE,EAAE,MAAM,MAAM,CAAC;AACrD,OAAO,EACL,oBAAoB,EACpB,GAAG,EACH,aAAa,EACb,QAAQ,EACR,SAAS,EACT,SAAS,GACV,MAAM,gBAAgB,CAAC;AAGxB,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAExC,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;;;;;;;;;AAuB3C,MAAM,OAAO,eACX,SAAQ,UAAa;IApBvB;;QA0BE,YAAO,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAc7D,gBAAW,GAAG,CAAC,WAAoB,EAAE,EAAE,CACrC,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,SAAS,IAAI,WAAW,CAAC;KAsFnD;IA/FC,IAAI,SAAS;QACX,OAAO,0BAA0B,IAAI,CAAC,IAAI,EAAE,CAAC;IAC/C,CAAC;IAED,IAAI,cAAc;QAChB,OAAO,8CAA8C,IAAI,CAAC,IAAI,EAAE,CAAC;IACnE,CAAC;IAKQ,kBAAkB;QACzB,KAAK,CAAC,kBAAkB,EAAE,CAAC;QAE3B,IAAI,CAAC,eAAe,GAAG,aAAa,CAAC;YAEjC,IAAI,CAAC,cAAc,CAAC,OACrB,CAAC,IAAI,CACJ,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,EAC9B,SAAS,CAAC,OAAO,CAAC,EAAE,CAClB,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CACzD,SAAS,CAAC,IAAY,CAAC,EACvB,GAAG,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,EAClD,oBAAoB,EAAE,EACtB,SAAS,CAAC,MAAM,CAAC,EAAE,CACjB,MAAM;gBACJ,CAAC,CAAC,aAAa,CAAC;oBACZ,MAAM,CAAC,MAAM;oBACb,MAAM,CAAC,MAAM;oBACb,MAAM,CAAC,aAAa;iBACrB,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,YAAY,CAAC,EAAE,EAAE,CAAC,CAAC;oBACrC,KAAK;oBACL,KAAK;oBACL,YAAY;iBACb,CAAC,CAAC,CACJ;gBACH,CAAC,CAAC,EAAE,CAAC,IAAY,CAAC,CACrB,CACF,CACF,CACF;YACD,IAAI,CAAC,MAAM;SACZ,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,EAAE,CACtB,MAAM;YACJ,CAAC,CAAC;gBACE,KAAK,EACH,MAAM,CAAC,KAAK;oBACZ,IAAI,CAAC,OAAO,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC;oBAC5B,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBAC1C,kDAAkD;gBAClD,YAAY,EAAE;oBACZ,GAAI,MAAM,CAAC,YAAwC;iBACpD;aACF;YACH,CAAC,CAAC;gBACE,KAAK,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC,IAAI,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;aAClE,CACN,EACD,aAAa,CAAC,CAAC,CAAC,EAChB,QAAQ,EAAE,CACX,CAAC;QAEF,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAC3C,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,EAC3B,aAAa,CAAC,CAAC,CAAC,EAChB,QAAQ,EAAE,CACX,CAAC;IACJ,CAAC;IAEQ,aAAa;QACpB,KAAK,CAAC,aAAa,EAAE,CAAC;IACxB,CAAC;IAEQ,aAAa;QACpB,KAAK,CAAC,aAAa,EAAE,CAAC;QACtB,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;IACpD,CAAC;IAEkB,OAAO,CAAC,CAAI;QAC7B,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,OAAO,CAAC,CAAC;IACX,CAAC;IAED,YAAY,CAAC,MAA0B;QACrC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAC7B,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,UAAU,CAAC,KAAY;QACrB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QACrB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,KAAK,CAAC,cAAc,EAAE,CAAC;IACzB,CAAC;;4GA3GU,eAAe;gGAAf,eAAe,qCAZf;QACT;YACE,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC;YAC9C,KAAK,EAAE,IAAI;SACZ;QACD;YACE,OAAO,EAAE,UAAU;YACnB,WAAW,EAAE,eAAe;SAC7B;KACF,qKC5CH,ulGAyGA;2FD3Da,eAAe;kBAnB3B,SAAS;+BACE,YAAY,mBAGL,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,uBAChB,KAAK,aACf;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,gBAAgB,CAAC;4BAC9C,KAAK,EAAE,IAAI;yBACZ;wBACD;4BACE,OAAO,EAAE,UAAU;4BACnB,WAAW,iBAAiB;yBAC7B;qBACF;8BAOD,QAAQ;sBADP,SAAS;uBAAC,UAAU,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","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';\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\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=\"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\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"]}
|
|
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=\"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\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"]}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject, Subject } from 'rxjs';
|
|
3
|
-
import { takeUntil } from 'rxjs/operators';
|
|
2
|
+
import { BehaviorSubject, Subject, takeUntil } from 'rxjs';
|
|
4
3
|
import { StepState } from './types';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "../icon/icon.component";
|
|
@@ -179,4 +178,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
179
178
|
}], selectedIndexChange: [{
|
|
180
179
|
type: Output
|
|
181
180
|
}] } });
|
|
182
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"steps.component.js","sourceRoot":"","sources":["../../../src/steps/steps.component.ts","../../../src/steps/steps.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { BehaviorSubject, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { StepItem, StepState, StepsOrientation, StepsType } from './types';\n\nconst StepDefaultIcon = {\n  [StepState.Default]: 'number',\n  [StepState.Done]: 'check_circle',\n  [StepState.Error]: 'close_circle',\n  [StepState.Pending]: 'sync_circle',\n};\n\nconst StepSelectedIcon = {\n  [StepState.Default]: 'number',\n  [StepState.Done]: 'check_circle_s',\n  [StepState.Error]: 'close_circle_s',\n  [StepState.Pending]: 'sync_circle_s',\n};\n\n@Component({\n  selector: 'aui-steps',\n  exportAs: 'auiSteps',\n  templateUrl: './steps.component.html',\n  styleUrls: ['./steps.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class StepsComponent implements OnInit, OnDestroy {\n  _currentIndex: number;\n  private _steps: StepItem[] = [];\n  @Input()\n  get steps() {\n    return this._steps;\n  }\n\n  set steps(val: StepItem[]) {\n    this._steps = val;\n    this.stepsChange$$.next(val);\n  }\n\n  /**\n   * @deprecated type 为 step 时一般在使用上下文中控制是否可以进行下一步；type 为 progress 时强制按顺序执行\n   */\n  @Input()\n  linear = false;\n\n  @Input()\n  get currentIndex() {\n    return this._currentIndex;\n  }\n\n  set currentIndex(index: number) {\n    this.currentIndexChange$$.next(index);\n  }\n\n  @Input()\n  orientation: StepsOrientation = 'horizontal';\n\n  @Input()\n  type: StepsType = 'step';\n\n  @Input()\n  selectable = false;\n\n  @Output()\n  currentIndexChange = new EventEmitter<number>();\n\n  @Output()\n  selectedIndexChange = new EventEmitter<number>();\n\n  currentIndexChange$$ = new BehaviorSubject<number>(0);\n  stepsChange$$ = new BehaviorSubject<StepItem[]>([]);\n\n  selectedIndex: number;\n\n  private readonly destroy$$ = new Subject<void>();\n\n  ngOnInit() {\n    this.currentIndexChange$$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(index => {\n        if (this.type === 'step') {\n          this.setCurrentIndex(index);\n        }\n      });\n    this.stepsChange$$.pipe(takeUntil(this.destroy$$)).subscribe(steps => {\n      if (this.type === 'progress') {\n        this.getProgressCurrentIndex(steps);\n      }\n    });\n  }\n\n  private setCurrentIndex(index: number) {\n    if (this.linear) {\n      if (this.steps?.length) {\n        const ret = Math.min(Math.max(0, index), this.steps.length - 1);\n        const reversedPrevSteps = this.steps.slice(0, ret).reverse();\n        const doneIndex = reversedPrevSteps.findIndex(\n          step => step.state === StepState.Done || step.optional,\n        );\n        const lastDoneStepIndex =\n          doneIndex > -1 ? reversedPrevSteps.length - doneIndex : 0;\n        this._currentIndex = this.selectedIndex = Math.min(\n          lastDoneStepIndex,\n          ret,\n        );\n      }\n    } else {\n      this._currentIndex = this.selectedIndex = index;\n    }\n  }\n\n  private getProgressCurrentIndex(steps: StepItem[]) {\n    if (!steps?.length) {\n      if (this._currentIndex !== 0) {\n        this.currentIndexChange.emit(0);\n      }\n      this._currentIndex = 0;\n    } else {\n      const reversedSteps = this.steps.slice(0).reverse();\n      const doneStepIndex = reversedSteps.findIndex(\n        step => step.state === StepState.Done,\n      );\n      const lastDoneStepIndex =\n        doneStepIndex > -1 ? reversedSteps.length - doneStepIndex : 0;\n      const newIndex = Math.min(lastDoneStepIndex, steps.length - 1);\n      if (this._currentIndex !== newIndex) {\n        this.currentIndexChange.emit(newIndex);\n      }\n      this._currentIndex =\n        this._currentIndex === this.selectedIndex\n          ? (this.selectedIndex = newIndex)\n          : newIndex;\n    }\n  }\n\n  get isVertical() {\n    return this.orientation === 'vertical';\n  }\n\n  get isProgress() {\n    return this.type === 'progress';\n  }\n\n  getIcon(i: number, state?: StepState): string {\n    if (!state) {\n      return StepDefaultIcon.default;\n    }\n    return this.getActiveIndex() === i\n      ? StepSelectedIcon[state]\n      : StepDefaultIcon[state];\n  }\n\n  select(i: number) {\n    if (this.isSelectable(i)) {\n      if (this.isProgress) {\n        this.selectedIndexChange.emit(i);\n        this.selectedIndex = i;\n      } else {\n        this.currentIndexChange.emit(i);\n        this._currentIndex = i;\n        this.selectedIndex = i;\n      }\n    }\n  }\n\n  isSelectable(i: number) {\n    const currentStep = this.steps[this._currentIndex];\n    if (!this.selectable || this.selectedIndex === i) {\n      return false;\n    }\n    const isLinear = this.isProgress ? true : this.linear;\n    if (\n      isLinear &&\n      !currentStep.optional &&\n      ((currentStep.state === StepState.Done && i > this._currentIndex + 1) ||\n        (currentStep.state !== StepState.Done && i > this._currentIndex))\n    ) {\n      return false;\n    }\n    // eslint-disable-next-line sonarjs/prefer-single-boolean-return\n    if (i < this._currentIndex && !this.selectable) {\n      return false;\n    }\n    return true;\n  }\n\n  getActiveIndex() {\n    return this.selectedIndex !== undefined\n      ? this.selectedIndex\n      : this._currentIndex;\n  }\n\n  isLastActive(i: number, steps: StepItem[]) {\n    const firstDefaultIndex = steps.findIndex(\n      step => !step.state || step.state === StepState.Default,\n    );\n    return i === this.selectedIndex\n      ? true\n      : firstDefaultIndex === 0\n      ? false\n      : firstDefaultIndex === i;\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n  }\n}\n","<div\n  class=\"aui-steps aui-steps--{{ orientation || 'horizontal' }} aui-steps--{{\n    type || 'step'\n  }}\"\n>\n  <ng-container *ngFor=\"let step of steps; let i = index; let isLast = last\">\n    <div\n      class=\"aui-step\"\n      (click)=\"select(i)\"\n      [class.isLastActive]=\"isLastActive(i, steps)\"\n      [class.clickable]=\"isSelectable(i)\"\n    >\n      <div class=\"aui-step__indicator\">\n        <ng-container *ngIf=\"isProgress\">\n          <ng-container [ngSwitch]=\"getIcon(i, step.state)\">\n            <span\n              class=\"aui-step__indicator-number aui-step__indicator-number--{{\n                step.state\n              }}\"\n              *ngSwitchCase=\"'number'\"\n              [class.selected]=\"getActiveIndex() === i\"\n            >\n              {{ i + 1 }}\n            </span>\n            <aui-icon\n              class=\"aui-step__indicator-icon aui-step__indicator-icon--{{\n                step.state\n              }}\"\n              *ngSwitchDefault\n              [class.selected]=\"getActiveIndex() === i\"\n              [icon]=\"getIcon(i, step.state)\"\n            ></aui-icon>\n          </ng-container>\n        </ng-container>\n        <ng-container *ngIf=\"!isProgress\">\n          <span\n            class=\"aui-step__indicator-number\"\n            [class.selected]=\"_currentIndex === i\"\n            *ngIf=\"i >= _currentIndex\"\n          >\n            {{ i + 1 }}\n          </span>\n          <aui-icon\n            class=\"aui-step__indicator-icon aui-step__indicator-icon--done\"\n            [class.selected]=\"_currentIndex === i\"\n            *ngIf=\"i < _currentIndex\"\n            [icon]=\"getIcon(i, 'done')\"\n          ></aui-icon>\n        </ng-container>\n        <div\n          *ngIf=\"!isLast && isVertical\"\n          class=\"aui-steps__vertical-line aui-steps__vertical-line--{{\n            step.state\n          }}\"\n        ></div>\n      </div>\n      <div\n        class=\"aui-step__info aui-step__info--{{\n          isProgress\n            ? step.state || 'default'\n            : i < _currentIndex\n            ? 'done'\n            : 'default'\n        }}\"\n        [class.aui-step__info--selected]=\"getActiveIndex() === i\"\n      >\n        <div class=\"aui-step__name\">\n          {{ step.label }}\n        </div>\n        <div\n          class=\"aui-step__description\"\n          *ngIf=\"step.description\"\n        >\n          {{ step.description }}\n        </div>\n      </div>\n    </div>\n    <div\n      *ngIf=\"!isLast && !isVertical\"\n      class=\"aui-steps__horizontal-line\"\n    ></div>\n  </ng-container>\n</div>\n"]}
|
|
181
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"steps.component.js","sourceRoot":"","sources":["../../../src/steps/steps.component.ts","../../../src/steps/steps.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { BehaviorSubject, Subject, takeUntil } from 'rxjs';\n\nimport { StepItem, StepState, StepsOrientation, StepsType } from './types';\n\nconst StepDefaultIcon = {\n  [StepState.Default]: 'number',\n  [StepState.Done]: 'check_circle',\n  [StepState.Error]: 'close_circle',\n  [StepState.Pending]: 'sync_circle',\n};\n\nconst StepSelectedIcon = {\n  [StepState.Default]: 'number',\n  [StepState.Done]: 'check_circle_s',\n  [StepState.Error]: 'close_circle_s',\n  [StepState.Pending]: 'sync_circle_s',\n};\n\n@Component({\n  selector: 'aui-steps',\n  exportAs: 'auiSteps',\n  templateUrl: './steps.component.html',\n  styleUrls: ['./steps.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class StepsComponent implements OnInit, OnDestroy {\n  _currentIndex: number;\n  private _steps: StepItem[] = [];\n  @Input()\n  get steps() {\n    return this._steps;\n  }\n\n  set steps(val: StepItem[]) {\n    this._steps = val;\n    this.stepsChange$$.next(val);\n  }\n\n  /**\n   * @deprecated type 为 step 时一般在使用上下文中控制是否可以进行下一步；type 为 progress 时强制按顺序执行\n   */\n  @Input()\n  linear = false;\n\n  @Input()\n  get currentIndex() {\n    return this._currentIndex;\n  }\n\n  set currentIndex(index: number) {\n    this.currentIndexChange$$.next(index);\n  }\n\n  @Input()\n  orientation: StepsOrientation = 'horizontal';\n\n  @Input()\n  type: StepsType = 'step';\n\n  @Input()\n  selectable = false;\n\n  @Output()\n  currentIndexChange = new EventEmitter<number>();\n\n  @Output()\n  selectedIndexChange = new EventEmitter<number>();\n\n  currentIndexChange$$ = new BehaviorSubject<number>(0);\n  stepsChange$$ = new BehaviorSubject<StepItem[]>([]);\n\n  selectedIndex: number;\n\n  private readonly destroy$$ = new Subject<void>();\n\n  ngOnInit() {\n    this.currentIndexChange$$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(index => {\n        if (this.type === 'step') {\n          this.setCurrentIndex(index);\n        }\n      });\n    this.stepsChange$$.pipe(takeUntil(this.destroy$$)).subscribe(steps => {\n      if (this.type === 'progress') {\n        this.getProgressCurrentIndex(steps);\n      }\n    });\n  }\n\n  private setCurrentIndex(index: number) {\n    if (this.linear) {\n      if (this.steps?.length) {\n        const ret = Math.min(Math.max(0, index), this.steps.length - 1);\n        const reversedPrevSteps = this.steps.slice(0, ret).reverse();\n        const doneIndex = reversedPrevSteps.findIndex(\n          step => step.state === StepState.Done || step.optional,\n        );\n        const lastDoneStepIndex =\n          doneIndex > -1 ? reversedPrevSteps.length - doneIndex : 0;\n        this._currentIndex = this.selectedIndex = Math.min(\n          lastDoneStepIndex,\n          ret,\n        );\n      }\n    } else {\n      this._currentIndex = this.selectedIndex = index;\n    }\n  }\n\n  private getProgressCurrentIndex(steps: StepItem[]) {\n    if (!steps?.length) {\n      if (this._currentIndex !== 0) {\n        this.currentIndexChange.emit(0);\n      }\n      this._currentIndex = 0;\n    } else {\n      const reversedSteps = this.steps.slice(0).reverse();\n      const doneStepIndex = reversedSteps.findIndex(\n        step => step.state === StepState.Done,\n      );\n      const lastDoneStepIndex =\n        doneStepIndex > -1 ? reversedSteps.length - doneStepIndex : 0;\n      const newIndex = Math.min(lastDoneStepIndex, steps.length - 1);\n      if (this._currentIndex !== newIndex) {\n        this.currentIndexChange.emit(newIndex);\n      }\n      this._currentIndex =\n        this._currentIndex === this.selectedIndex\n          ? (this.selectedIndex = newIndex)\n          : newIndex;\n    }\n  }\n\n  get isVertical() {\n    return this.orientation === 'vertical';\n  }\n\n  get isProgress() {\n    return this.type === 'progress';\n  }\n\n  getIcon(i: number, state?: StepState): string {\n    if (!state) {\n      return StepDefaultIcon.default;\n    }\n    return this.getActiveIndex() === i\n      ? StepSelectedIcon[state]\n      : StepDefaultIcon[state];\n  }\n\n  select(i: number) {\n    if (this.isSelectable(i)) {\n      if (this.isProgress) {\n        this.selectedIndexChange.emit(i);\n        this.selectedIndex = i;\n      } else {\n        this.currentIndexChange.emit(i);\n        this._currentIndex = i;\n        this.selectedIndex = i;\n      }\n    }\n  }\n\n  isSelectable(i: number) {\n    const currentStep = this.steps[this._currentIndex];\n    if (!this.selectable || this.selectedIndex === i) {\n      return false;\n    }\n    const isLinear = this.isProgress ? true : this.linear;\n    if (\n      isLinear &&\n      !currentStep.optional &&\n      ((currentStep.state === StepState.Done && i > this._currentIndex + 1) ||\n        (currentStep.state !== StepState.Done && i > this._currentIndex))\n    ) {\n      return false;\n    }\n    // eslint-disable-next-line sonarjs/prefer-single-boolean-return\n    if (i < this._currentIndex && !this.selectable) {\n      return false;\n    }\n    return true;\n  }\n\n  getActiveIndex() {\n    return this.selectedIndex !== undefined\n      ? this.selectedIndex\n      : this._currentIndex;\n  }\n\n  isLastActive(i: number, steps: StepItem[]) {\n    const firstDefaultIndex = steps.findIndex(\n      step => !step.state || step.state === StepState.Default,\n    );\n    return i === this.selectedIndex\n      ? true\n      : firstDefaultIndex === 0\n      ? false\n      : firstDefaultIndex === i;\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n  }\n}\n","<div\n  class=\"aui-steps aui-steps--{{ orientation || 'horizontal' }} aui-steps--{{\n    type || 'step'\n  }}\"\n>\n  <ng-container *ngFor=\"let step of steps; let i = index; let isLast = last\">\n    <div\n      class=\"aui-step\"\n      (click)=\"select(i)\"\n      [class.isLastActive]=\"isLastActive(i, steps)\"\n      [class.clickable]=\"isSelectable(i)\"\n    >\n      <div class=\"aui-step__indicator\">\n        <ng-container *ngIf=\"isProgress\">\n          <ng-container [ngSwitch]=\"getIcon(i, step.state)\">\n            <span\n              class=\"aui-step__indicator-number aui-step__indicator-number--{{\n                step.state\n              }}\"\n              *ngSwitchCase=\"'number'\"\n              [class.selected]=\"getActiveIndex() === i\"\n            >\n              {{ i + 1 }}\n            </span>\n            <aui-icon\n              class=\"aui-step__indicator-icon aui-step__indicator-icon--{{\n                step.state\n              }}\"\n              *ngSwitchDefault\n              [class.selected]=\"getActiveIndex() === i\"\n              [icon]=\"getIcon(i, step.state)\"\n            ></aui-icon>\n          </ng-container>\n        </ng-container>\n        <ng-container *ngIf=\"!isProgress\">\n          <span\n            class=\"aui-step__indicator-number\"\n            [class.selected]=\"_currentIndex === i\"\n            *ngIf=\"i >= _currentIndex\"\n          >\n            {{ i + 1 }}\n          </span>\n          <aui-icon\n            class=\"aui-step__indicator-icon aui-step__indicator-icon--done\"\n            [class.selected]=\"_currentIndex === i\"\n            *ngIf=\"i < _currentIndex\"\n            [icon]=\"getIcon(i, 'done')\"\n          ></aui-icon>\n        </ng-container>\n        <div\n          *ngIf=\"!isLast && isVertical\"\n          class=\"aui-steps__vertical-line aui-steps__vertical-line--{{\n            step.state\n          }}\"\n        ></div>\n      </div>\n      <div\n        class=\"aui-step__info aui-step__info--{{\n          isProgress\n            ? step.state || 'default'\n            : i < _currentIndex\n            ? 'done'\n            : 'default'\n        }}\"\n        [class.aui-step__info--selected]=\"getActiveIndex() === i\"\n      >\n        <div class=\"aui-step__name\">\n          {{ step.label }}\n        </div>\n        <div\n          class=\"aui-step__description\"\n          *ngIf=\"step.description\"\n        >\n          {{ step.description }}\n        </div>\n      </div>\n    </div>\n    <div\n      *ngIf=\"!isLast && !isVertical\"\n      class=\"aui-steps__horizontal-line\"\n    ></div>\n  </ng-container>\n</div>\n"]}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { Directive, Host, HostBinding, } from '@angular/core';
|
|
2
|
-
import { Subject, fromEvent, merge } from 'rxjs';
|
|
3
|
-
import { startWith, takeUntil } from 'rxjs/operators';
|
|
2
|
+
import { Subject, fromEvent, merge, startWith, takeUntil } from 'rxjs';
|
|
4
3
|
import { observeResizeOn } from '../utils';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "./table.component";
|
|
@@ -88,4 +87,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
88
87
|
type: HostBinding,
|
|
89
88
|
args: [`class.${SHADOW_CLASS}`]
|
|
90
89
|
}] } });
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-scroll.directive.js","sourceRoot":"","sources":["../../../src/table/table-scroll.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  Host,\n  HostBinding,\n  OnDestroy,\n} from '@angular/core';\nimport { Subject, fromEvent, merge, startWith, takeUntil } from 'rxjs';\n\nimport { observeResizeOn } from '../utils';\n\nimport { TableComponent } from './table.component';\n\nconst CLASS_PREFIX = 'aui-table';\nconst SHADOW_CLASS = `${CLASS_PREFIX}__scroll-shadow`;\nconst HAS_SCROLL_CLASS = `${SHADOW_CLASS}--has-scroll`;\nconst SCROLLING_CLASS = `${SHADOW_CLASS}--scrolling`;\nconst SCROLL_BEFORE_END_CLASS = `${SHADOW_CLASS}--before-end`;\n\nconst HAS_TABLE_TOP_SHADOW = 'hasTableTopShadow';\nconst HAS_TABLE_BOTTOM_SHADOW = 'hasTableBottomShadow';\nconst HAS_TABLE_VERTICAL_SCROLL = 'hasTableVerticalScroll';\n\n@Directive({\n  selector: '[auiTableScrollWrapper]',\n  host: {\n    class: 'aui-table__scroll-wrapper',\n  },\n})\nexport class TableScrollWrapperDirective {}\n@Directive({\n  selector: '[auiTableScrollShadow]',\n})\nexport class TableScrollShadowDirective implements AfterViewInit, OnDestroy {\n  destroy$$ = new Subject<void>();\n  constructor(\n    private readonly el: ElementRef<HTMLElement>,\n    @Host() private readonly table: TableComponent<unknown>,\n  ) {}\n\n  @HostBinding(`class.${SCROLL_BEFORE_END_CLASS}`)\n  SCROLL_BEFORE_END_CLASS = true;\n\n  @HostBinding(`class.${SHADOW_CLASS}`)\n  SHADOW_CLASS = true;\n\n  get containerEl() {\n    return this.el.nativeElement;\n  }\n\n  ngAfterViewInit() {\n    requestAnimationFrame(() => {\n      this.viewMutation();\n    });\n  }\n\n  viewMutation() {\n    merge(\n      observeResizeOn(this.containerEl),\n      fromEvent(this.containerEl, 'scroll'),\n    )\n      .pipe(startWith(null), takeUntil(this.destroy$$))\n      .subscribe(() => {\n        this.mutateVerticalScroll();\n        this.mutateHorizontalScroll();\n      });\n  }\n\n  mutateVerticalScroll() {\n    const scrollDis =\n      this.containerEl.scrollHeight - this.containerEl.offsetHeight;\n\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollDis > 0,\n      HAS_TABLE_VERTICAL_SCROLL,\n    );\n\n    const scrollTop = this.containerEl.scrollTop;\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollTop > 0,\n      HAS_TABLE_TOP_SHADOW,\n    );\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollTop < scrollDis,\n      HAS_TABLE_BOTTOM_SHADOW,\n    );\n\n    // 兼容屏幕缩放是 sticky多列的样式问题\n    this.table.updateStickyColumnStyles();\n  }\n\n  mutateHorizontalScroll() {\n    const scrollDis =\n      this.containerEl.scrollWidth - this.containerEl.offsetWidth;\n\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollDis > 0,\n      HAS_SCROLL_CLASS,\n    );\n\n    const scrollLeft = this.containerEl.scrollLeft;\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollLeft > 0,\n      SCROLLING_CLASS,\n    );\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollLeft < scrollDis,\n      SCROLL_BEFORE_END_CLASS,\n    );\n  }\n\n  placeClassList(\n    classList: DOMTokenList,\n    condition: boolean,\n    className: string,\n  ) {\n    classList[condition ? 'add' : 'remove'](className);\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n  }\n}\n"]}
|