@alauda/ui 6.4.1-beta.8 → 6.4.2-beta
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 +2 -3
- package/esm2020/autocomplete/suggestion/suggestion.component.mjs +5 -6
- package/esm2020/autocomplete/suggestion-group/suggestion-group.component.mjs +4 -4
- package/esm2020/back-top/back-top.component.mjs +2 -3
- package/esm2020/breadcrumb/breadcrumb-item.component.mjs +2 -2
- package/esm2020/checkbox/checkbox.component.mjs +2 -3
- package/esm2020/dialog/confirm-dialog/confirm-dialog.component.mjs +3 -4
- package/esm2020/drawer/component/drawer.component.mjs +2 -3
- package/esm2020/drawer/drawer.service.mjs +2 -3
- package/esm2020/dropdown/dropdown.directive.mjs +2 -2
- package/esm2020/form/form-item/form-item.component.mjs +4 -4
- package/esm2020/form/form.directive.mjs +2 -3
- package/esm2020/icon/icon-register.service.mjs +8 -5
- package/esm2020/input/autosize.directive.mjs +2 -3
- package/esm2020/radio/base-radio.mjs +2 -3
- package/esm2020/radio/radio-button/radio-button.component.mjs +2 -2
- package/esm2020/radio/radio-group/radio-group.component.mjs +2 -3
- package/esm2020/scrolling/fixed-size-table-virtual-scroll-strategy.mjs +2 -3
- package/esm2020/scrolling/fixed-size-table-virtual-scroll.directive.mjs +2 -3
- package/esm2020/select/base-select.mjs +7 -8
- package/esm2020/select/multi-select/multi-select.component.mjs +5 -6
- package/esm2020/select/option/option.component.mjs +5 -6
- package/esm2020/select/option-group/option-group.component.mjs +4 -4
- package/esm2020/select/select.component.mjs +5 -6
- package/esm2020/steps/steps.component.mjs +2 -3
- package/esm2020/table/table-scroll.directive.mjs +2 -3
- package/esm2020/table/table.component.mjs +2 -2
- 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 +71 -55
- package/fesm2015/alauda-ui.mjs.map +1 -1
- package/fesm2020/alauda-ui.mjs +71 -55
- package/fesm2020/alauda-ui.mjs.map +1 -1
- package/package.json +1 -1
- package/theme/_pattern.scss +1 -0
- package/utils/index.d.ts +1 -0
- package/utils/operators.d.ts +8 -0
|
@@ -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":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  QueryList,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Observable, combineLatest, of } from 'rxjs';\nimport {\n  distinctUntilChanged,\n  map,\n  publishReplay,\n  refCount,\n  startWith,\n  switchMap,\n} from 'rxjs/operators';\n\nimport { InputComponent } from '../input';\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"]}
|
|
@@ -47,7 +47,7 @@ TableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version
|
|
|
47
47
|
provide: _COALESCED_STYLE_SCHEDULER,
|
|
48
48
|
useClass: _CoalescedStyleScheduler,
|
|
49
49
|
},
|
|
50
|
-
], queries: [{ propertyName: "_placeholderDef", first: true, predicate: TablePlaceholderDefDirective, descendants: true, static: true }], viewQueries: [{ propertyName: "_placeholderOutlet", first: true, predicate: TablePlaceholderOutletDirective, descendants: true, static: true }], exportAs: ["auiTable"], usesInheritance: true, ngImport: i0, template: "\n <ng-content select=\"caption\"></ng-content>\n <ng-content select=\"colgroup, col\"></ng-content>\n <ng-container headerRowOutlet></ng-container>\n <ng-container rowOutlet></ng-container>\n <ng-container noDataRowOutlet></ng-container>\n <ng-container footerRowOutlet></ng-container>\n<ng-container auiTablePlaceholderOutlet></ng-container>", isInline: true, styles: [".aui-table{display:block;padding:0 12px 12px;font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);color:rgb(var(--aui-color-main-text));background-color:rgb(var(--aui-color-n-9));border-radius:var(--aui-border-radius-l);overflow:auto}.aui-table::-webkit-scrollbar{width:4px;height:4px}.aui-table::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-table__row,.aui-table__header-row{display:flex;align-items:center}.aui-table__row.hasPanel,.aui-table__header-row.hasPanel{flex-wrap:wrap}.aui-table__header-row+.aui-table__row{border-top-left-radius:var(--aui-border-radius-l);border-top-right-radius:var(--aui-border-radius-l)}.aui-table__row{position:relative;border-width:1px;border-style:solid;border-color:rgb(var(--aui-color-n-8));border-bottom-width:0;background-color:rgb(var(--aui-color-n-10));padding:0 9px;min-height:58px;box-sizing:content-box}.aui-table__row:first-child{border-top-left-radius:var(--aui-border-radius-l);border-top-right-radius:var(--aui-border-radius-l)}.aui-table__row:last-child{border-bottom-width:1px;min-height:58px;border-bottom-left-radius:var(--aui-border-radius-l);border-bottom-right-radius:var(--aui-border-radius-l)}.aui-table__row.isDisabled:before{content:\"\";z-index:2;position:absolute;top:0;left:0;width:100%;height:100%;background-color:rgb(var(--aui-color-n-10));opacity:.7;cursor:not-allowed}.aui-table__header-row{background-color:rgb(var(--aui-color-n-9));padding:0 10px}.aui-table__cell,.aui-table__header-cell{flex:1}.aui-table__cell{padding:15px 10px;background-color:rgb(var(--aui-color-n-10));overflow:hidden;word-wrap:break-word}.aui-table__header-cell{padding:12px 10px;font-weight:var(--aui-font-weight-bold);background-color:rgb(var(--aui-color-n-9));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.aui-table__column-expand-button{display:flex;align-items:center;max-width:calc(10px * 2 + var(--aui-icon-size-m))}.aui-table__column-expand-button.aui-table__cell{height:58px}.aui-table__column-expand-button .aui-expand-button{display:inline-flex;justify-content:center;align-items:center;width:var(--aui-icon-size-m);height:var(--aui-icon-size-m);font-size:var(--aui-icon-size-m);line-height:var(--aui-icon-size-m);color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-p-6));border-radius:50%;border:none;cursor:pointer;transition:transform .1s ease-in-out}.aui-table__column-expand-button .aui-expand-button aui-icon{display:block;width:var(--aui-icon-size-m);height:var(--aui-icon-size-m)}.aui-table__column-expand-button .aui-expand-button:hover{background-color:rgb(var(--aui-color-p-7))}.aui-table__column-expand-button .aui-expand-button:active{background-color:rgb(var(--aui-color-p-5))}.aui-table__column-expand-button .aui-expand-button.isExpanded{transform:rotate(90deg);color:#fff;background-color:rgb(var(--aui-color-primary))}.aui-table__column-expand-button .aui-expand-button.isExpanded:hover{background-color:rgb(var(--aui-color-p-1))}.aui-table__column-expand-button .aui-expand-button.isExpanded:active{background-color:rgb(var(--aui-color-p-0))}.aui-table__column-expand-button .aui-expand-button[disabled],.aui-table__column-expand-button .aui-expand-button.isExpanded[disabled]{background-color:rgb(var(--aui-color-n-8));color:rgb(var(--aui-color-n-6));cursor:not-allowed}.aui-table__column-expand-panel{margin-top:-6px}.aui-table__column-expand-panel.aui-table__header-cell{display:none}.aui-table__column-expand-panel.aui-table__cell{width:100%;flex-shrink:0;flex-basis:100%;padding:0 10px;overflow:hidden}.aui-table__column-expand-panel.aui-table__cell .aui-table__cell-expand-panel{border-radius:var(--aui-border-radius-l);overflow:hidden}.aui-table__column-expand-panel.aui-table__cell .aui-table__cell-expand-panel-content.hasBackground{padding:16px;background-color:rgb(var(--aui-color-n-9))}\n", ".aui-table__scroll-wrapper{background-color:rgb(var(--aui-color-n-9));padding:0 12px 12px;border-radius:var(--aui-border-radius-l)}.aui-table__scroll-wrapper::-webkit-scrollbar{width:4px;height:4px}.aui-table__scroll-wrapper::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-table__scroll-wrapper .aui-table{padding:0;border-radius:0}.aui-table__scroll-wrapper .aui-table__scroll-shadow.hasTableTopShadow:before,.aui-table__scroll-wrapper .aui-table__scroll-shadow.hasTableBottomShadow:after{transform:none;width:100%;left:0}.aui-table__scroll-shadow.hasTableTopShadow:before{content:\"\";position:sticky;display:block;width:calc(100% + 24px);height:16px;margin-top:-16px;transform:translate(-12px);z-index:99;top:28px}:root .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-1),.16)}html[aui-theme-mode=light] .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-1),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-9),.75)}}html[aui-theme-mode=dark] .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-9),.75)}.aui-table__scroll-shadow.hasTableBottomShadow:after{content:\"\";position:sticky;display:block;width:calc(100% + 24px);height:16px;transform:translate(-12px,12px);z-index:99;bottom:0;margin-top:-16px}:root .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-1),.16) inset}html[aui-theme-mode=light] .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-1),.16) inset}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-9),.75) inset}}html[aui-theme-mode=dark] .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-9),.75) inset}.aui-table__scroll-shadow .aui-table__header-row{margin:0;padding:0;align-items:stretch}.aui-table__scroll-shadow .aui-table__header-row .aui-table__header-cell:first-of-type{padding-left:20px}.aui-table__scroll-shadow .aui-table__header-row .aui-table__header-cell:last-of-type{padding-right:20px}.aui-table__scroll-shadow .aui-table__header-row+.aui-table__row .aui-table__cell:first-of-type{border-top-left-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__header-row+.aui-table__row .aui-table__cell:last-of-type{border-top-right-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__row{border:none;padding:0;align-items:stretch}.aui-table__scroll-shadow .aui-table__row .aui-table__cell{border-width:1px 0;border-style:solid;border-color:rgb(var(--aui-color-n-8))}.aui-table__scroll-shadow .aui-table__row .aui-table__cell:first-of-type{border-left-width:1px;padding-left:19px}.aui-table__scroll-shadow .aui-table__row .aui-table__cell:last-of-type{border-right-width:1px;padding-right:19px}.aui-table__scroll-shadow .aui-table__row:last-child .aui-table__cell:first-of-type{border-bottom-left-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__row:last-child .aui-table__cell:last-of-type{border-bottom-right-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__row:not(.aui-table__scroll-shadow .aui-table__row:last-child) .aui-table__cell{border-bottom-width:0}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:after,.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:after{position:absolute;top:0;bottom:-1px;width:20px;transition:box-shadow .3s;content:\"\";pointer-events:none}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:before,.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:before{position:absolute;top:0;bottom:-1px;content:\"\";background:linear-gradient(to bottom,rgb(var(--aui-color-n-7)),rgb(var(--aui-color-n-7)) 8px,transparent 6px,transparent);width:1px;background-size:100% 14px;height:100%}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left{padding-right:30px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:after{right:-10px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:before{right:10px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right{padding-left:30px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:after{left:-10px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:before{left:10px}:root .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}html[aui-theme-mode=light] .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}}html[aui-theme-mode=dark] .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}.aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):before{background:linear-gradient(to bottom,rgb(var(--aui-color-primary)),rgb(var(--aui-color-primary)) 8px,transparent 6px,transparent);width:1px;background-size:100% 14px;height:100%}:root .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}html[aui-theme-mode=light] .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}}html[aui-theme-mode=dark] .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}.aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):before{background:linear-gradient(to bottom,rgb(var(--aui-color-primary)),rgb(var(--aui-color-primary)) 8px,transparent 6px,transparent);width:1px;background-size:100% 14px;height:100%}\n"], directives: [{ type: i1.HeaderRowOutlet, selector: "[headerRowOutlet]" }, { type: i1.DataRowOutlet, selector: "[rowOutlet]" }, { type: i1.NoDataRowOutlet, selector: "[noDataRowOutlet]" }, { type: i1.FooterRowOutlet, selector: "[footerRowOutlet]" }, { type: i2.TablePlaceholderOutletDirective, selector: "[auiTablePlaceholderOutlet]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
50
|
+
], queries: [{ propertyName: "_placeholderDef", first: true, predicate: TablePlaceholderDefDirective, descendants: true, static: true }], viewQueries: [{ propertyName: "_placeholderOutlet", first: true, predicate: TablePlaceholderOutletDirective, descendants: true, static: true }], exportAs: ["auiTable"], usesInheritance: true, ngImport: i0, template: "\n <ng-content select=\"caption\"></ng-content>\n <ng-content select=\"colgroup, col\"></ng-content>\n <ng-container headerRowOutlet></ng-container>\n <ng-container rowOutlet></ng-container>\n <ng-container noDataRowOutlet></ng-container>\n <ng-container footerRowOutlet></ng-container>\n<ng-container auiTablePlaceholderOutlet></ng-container>", isInline: true, styles: [".aui-table{display:block;padding:0 12px 12px;font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);color:rgb(var(--aui-color-main-text));background-color:rgb(var(--aui-color-n-9));border-radius:var(--aui-border-radius-l);overflow:auto}.aui-table::-webkit-scrollbar{width:4px;height:4px}.aui-table::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-table__row,.aui-table__header-row{display:flex;align-items:center}.aui-table__row.hasPanel,.aui-table__header-row.hasPanel{flex-wrap:wrap}.aui-table__header-row+.aui-table__row{border-top-left-radius:var(--aui-border-radius-l);border-top-right-radius:var(--aui-border-radius-l)}.aui-table__row{position:relative;border-width:1px;border-style:solid;border-color:rgb(var(--aui-color-n-8));border-bottom-width:0;background-color:rgb(var(--aui-color-n-10));padding:0 9px;min-height:58px;box-sizing:content-box}.aui-table__row:first-child{border-top-left-radius:var(--aui-border-radius-l);border-top-right-radius:var(--aui-border-radius-l)}.aui-table__row:last-of-type{border-bottom-width:1px;min-height:58px;border-bottom-left-radius:var(--aui-border-radius-l);border-bottom-right-radius:var(--aui-border-radius-l)}.aui-table__row.isDisabled:before{content:\"\";z-index:2;position:absolute;top:0;left:0;width:100%;height:100%;background-color:rgb(var(--aui-color-n-10));opacity:.7;cursor:not-allowed}.aui-table__header-row{background-color:rgb(var(--aui-color-n-9));padding:0 10px}.aui-table__cell,.aui-table__header-cell{flex:1}.aui-table__cell{padding:15px 10px;background-color:rgb(var(--aui-color-n-10));overflow:hidden;word-wrap:break-word}.aui-table__header-cell{padding:12px 10px;font-weight:var(--aui-font-weight-bold);background-color:rgb(var(--aui-color-n-9));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.aui-table__column-expand-button{display:flex;align-items:center;max-width:calc(10px * 2 + var(--aui-icon-size-m))}.aui-table__column-expand-button.aui-table__cell{height:58px}.aui-table__column-expand-button .aui-expand-button{display:inline-flex;justify-content:center;align-items:center;width:var(--aui-icon-size-m);height:var(--aui-icon-size-m);font-size:var(--aui-icon-size-m);line-height:var(--aui-icon-size-m);color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-p-6));border-radius:50%;border:none;cursor:pointer;transition:transform .1s ease-in-out}.aui-table__column-expand-button .aui-expand-button aui-icon{display:block;width:var(--aui-icon-size-m);height:var(--aui-icon-size-m)}.aui-table__column-expand-button .aui-expand-button:hover{background-color:rgb(var(--aui-color-p-7))}.aui-table__column-expand-button .aui-expand-button:active{background-color:rgb(var(--aui-color-p-5))}.aui-table__column-expand-button .aui-expand-button.isExpanded{transform:rotate(90deg);color:#fff;background-color:rgb(var(--aui-color-primary))}.aui-table__column-expand-button .aui-expand-button.isExpanded:hover{background-color:rgb(var(--aui-color-p-1))}.aui-table__column-expand-button .aui-expand-button.isExpanded:active{background-color:rgb(var(--aui-color-p-0))}.aui-table__column-expand-button .aui-expand-button[disabled],.aui-table__column-expand-button .aui-expand-button.isExpanded[disabled]{background-color:rgb(var(--aui-color-n-8));color:rgb(var(--aui-color-n-6));cursor:not-allowed}.aui-table__column-expand-panel{margin-top:-6px}.aui-table__column-expand-panel.aui-table__header-cell{display:none}.aui-table__column-expand-panel.aui-table__cell{width:100%;flex-shrink:0;flex-basis:100%;padding:0 10px;overflow:hidden}.aui-table__column-expand-panel.aui-table__cell .aui-table__cell-expand-panel{border-radius:var(--aui-border-radius-l);overflow:hidden}.aui-table__column-expand-panel.aui-table__cell .aui-table__cell-expand-panel-content.hasBackground{padding:16px;background-color:rgb(var(--aui-color-n-9))}\n", ".aui-table__scroll-wrapper{background-color:rgb(var(--aui-color-n-9));padding:0 12px 12px;border-radius:var(--aui-border-radius-l)}.aui-table__scroll-wrapper::-webkit-scrollbar{width:4px;height:4px}.aui-table__scroll-wrapper::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-table__scroll-wrapper .aui-table{padding:0;border-radius:0}.aui-table__scroll-wrapper .aui-table__scroll-shadow.hasTableTopShadow:before,.aui-table__scroll-wrapper .aui-table__scroll-shadow.hasTableBottomShadow:after{transform:none;width:100%;left:0}.aui-table__scroll-shadow.hasTableTopShadow:before{content:\"\";position:sticky;display:block;width:calc(100% + 24px);height:16px;margin-top:-16px;transform:translate(-12px);z-index:99;top:28px}:root .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-1),.16)}html[aui-theme-mode=light] .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-1),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-9),.75)}}html[aui-theme-mode=dark] .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-9),.75)}.aui-table__scroll-shadow.hasTableBottomShadow:after{content:\"\";position:sticky;display:block;width:calc(100% + 24px);height:16px;transform:translate(-12px,12px);z-index:99;bottom:0;margin-top:-16px}:root .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-1),.16) inset}html[aui-theme-mode=light] .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-1),.16) inset}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-9),.75) inset}}html[aui-theme-mode=dark] .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-9),.75) inset}.aui-table__scroll-shadow .aui-table__header-row{margin:0;padding:0;align-items:stretch}.aui-table__scroll-shadow .aui-table__header-row .aui-table__header-cell:first-of-type{padding-left:20px}.aui-table__scroll-shadow .aui-table__header-row .aui-table__header-cell:last-of-type{padding-right:20px}.aui-table__scroll-shadow .aui-table__header-row+.aui-table__row .aui-table__cell:first-of-type{border-top-left-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__header-row+.aui-table__row .aui-table__cell:last-of-type{border-top-right-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__row{border:none;padding:0;align-items:stretch}.aui-table__scroll-shadow .aui-table__row .aui-table__cell{border-width:1px 0;border-style:solid;border-color:rgb(var(--aui-color-n-8))}.aui-table__scroll-shadow .aui-table__row .aui-table__cell:first-of-type{border-left-width:1px;padding-left:19px}.aui-table__scroll-shadow .aui-table__row .aui-table__cell:last-of-type{border-right-width:1px;padding-right:19px}.aui-table__scroll-shadow .aui-table__row:last-child .aui-table__cell:first-of-type{border-bottom-left-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__row:last-child .aui-table__cell:last-of-type{border-bottom-right-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__row:not(.aui-table__scroll-shadow .aui-table__row:last-child) .aui-table__cell{border-bottom-width:0}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:after,.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:after{position:absolute;top:0;bottom:-1px;width:20px;transition:box-shadow .3s;content:\"\";pointer-events:none}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:before,.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:before{position:absolute;top:0;bottom:-1px;content:\"\";background:linear-gradient(to bottom,rgb(var(--aui-color-n-7)),rgb(var(--aui-color-n-7)) 8px,transparent 6px,transparent);width:1px;background-size:100% 14px;height:100%}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left{padding-right:30px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:after{right:-10px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:before{right:10px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right{padding-left:30px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:after{left:-10px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:before{left:10px}:root .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}html[aui-theme-mode=light] .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}}html[aui-theme-mode=dark] .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}.aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):before{background:linear-gradient(to bottom,rgb(var(--aui-color-primary)),rgb(var(--aui-color-primary)) 8px,transparent 6px,transparent);width:1px;background-size:100% 14px;height:100%}:root .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}html[aui-theme-mode=light] .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}}html[aui-theme-mode=dark] .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}.aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):before{background:linear-gradient(to bottom,rgb(var(--aui-color-primary)),rgb(var(--aui-color-primary)) 8px,transparent 6px,transparent);width:1px;background-size:100% 14px;height:100%}\n"], directives: [{ type: i1.HeaderRowOutlet, selector: "[headerRowOutlet]" }, { type: i1.DataRowOutlet, selector: "[rowOutlet]" }, { type: i1.NoDataRowOutlet, selector: "[noDataRowOutlet]" }, { type: i1.FooterRowOutlet, selector: "[footerRowOutlet]" }, { type: i2.TablePlaceholderOutletDirective, selector: "[auiTablePlaceholderOutlet]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
51
51
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: TableComponent, decorators: [{
|
|
52
52
|
type: Component,
|
|
53
53
|
args: [{ selector: 'aui-table', exportAs: 'auiTable', encapsulation: ViewEncapsulation.None, template: CDK_TABLE_TEMPLATE +
|
|
@@ -66,7 +66,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
66
66
|
provide: _COALESCED_STYLE_SCHEDULER,
|
|
67
67
|
useClass: _CoalescedStyleScheduler,
|
|
68
68
|
},
|
|
69
|
-
], styles: [".aui-table{display:block;padding:0 12px 12px;font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);color:rgb(var(--aui-color-main-text));background-color:rgb(var(--aui-color-n-9));border-radius:var(--aui-border-radius-l);overflow:auto}.aui-table::-webkit-scrollbar{width:4px;height:4px}.aui-table::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-table__row,.aui-table__header-row{display:flex;align-items:center}.aui-table__row.hasPanel,.aui-table__header-row.hasPanel{flex-wrap:wrap}.aui-table__header-row+.aui-table__row{border-top-left-radius:var(--aui-border-radius-l);border-top-right-radius:var(--aui-border-radius-l)}.aui-table__row{position:relative;border-width:1px;border-style:solid;border-color:rgb(var(--aui-color-n-8));border-bottom-width:0;background-color:rgb(var(--aui-color-n-10));padding:0 9px;min-height:58px;box-sizing:content-box}.aui-table__row:first-child{border-top-left-radius:var(--aui-border-radius-l);border-top-right-radius:var(--aui-border-radius-l)}.aui-table__row:last-child{border-bottom-width:1px;min-height:58px;border-bottom-left-radius:var(--aui-border-radius-l);border-bottom-right-radius:var(--aui-border-radius-l)}.aui-table__row.isDisabled:before{content:\"\";z-index:2;position:absolute;top:0;left:0;width:100%;height:100%;background-color:rgb(var(--aui-color-n-10));opacity:.7;cursor:not-allowed}.aui-table__header-row{background-color:rgb(var(--aui-color-n-9));padding:0 10px}.aui-table__cell,.aui-table__header-cell{flex:1}.aui-table__cell{padding:15px 10px;background-color:rgb(var(--aui-color-n-10));overflow:hidden;word-wrap:break-word}.aui-table__header-cell{padding:12px 10px;font-weight:var(--aui-font-weight-bold);background-color:rgb(var(--aui-color-n-9));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.aui-table__column-expand-button{display:flex;align-items:center;max-width:calc(10px * 2 + var(--aui-icon-size-m))}.aui-table__column-expand-button.aui-table__cell{height:58px}.aui-table__column-expand-button .aui-expand-button{display:inline-flex;justify-content:center;align-items:center;width:var(--aui-icon-size-m);height:var(--aui-icon-size-m);font-size:var(--aui-icon-size-m);line-height:var(--aui-icon-size-m);color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-p-6));border-radius:50%;border:none;cursor:pointer;transition:transform .1s ease-in-out}.aui-table__column-expand-button .aui-expand-button aui-icon{display:block;width:var(--aui-icon-size-m);height:var(--aui-icon-size-m)}.aui-table__column-expand-button .aui-expand-button:hover{background-color:rgb(var(--aui-color-p-7))}.aui-table__column-expand-button .aui-expand-button:active{background-color:rgb(var(--aui-color-p-5))}.aui-table__column-expand-button .aui-expand-button.isExpanded{transform:rotate(90deg);color:#fff;background-color:rgb(var(--aui-color-primary))}.aui-table__column-expand-button .aui-expand-button.isExpanded:hover{background-color:rgb(var(--aui-color-p-1))}.aui-table__column-expand-button .aui-expand-button.isExpanded:active{background-color:rgb(var(--aui-color-p-0))}.aui-table__column-expand-button .aui-expand-button[disabled],.aui-table__column-expand-button .aui-expand-button.isExpanded[disabled]{background-color:rgb(var(--aui-color-n-8));color:rgb(var(--aui-color-n-6));cursor:not-allowed}.aui-table__column-expand-panel{margin-top:-6px}.aui-table__column-expand-panel.aui-table__header-cell{display:none}.aui-table__column-expand-panel.aui-table__cell{width:100%;flex-shrink:0;flex-basis:100%;padding:0 10px;overflow:hidden}.aui-table__column-expand-panel.aui-table__cell .aui-table__cell-expand-panel{border-radius:var(--aui-border-radius-l);overflow:hidden}.aui-table__column-expand-panel.aui-table__cell .aui-table__cell-expand-panel-content.hasBackground{padding:16px;background-color:rgb(var(--aui-color-n-9))}\n", ".aui-table__scroll-wrapper{background-color:rgb(var(--aui-color-n-9));padding:0 12px 12px;border-radius:var(--aui-border-radius-l)}.aui-table__scroll-wrapper::-webkit-scrollbar{width:4px;height:4px}.aui-table__scroll-wrapper::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-table__scroll-wrapper .aui-table{padding:0;border-radius:0}.aui-table__scroll-wrapper .aui-table__scroll-shadow.hasTableTopShadow:before,.aui-table__scroll-wrapper .aui-table__scroll-shadow.hasTableBottomShadow:after{transform:none;width:100%;left:0}.aui-table__scroll-shadow.hasTableTopShadow:before{content:\"\";position:sticky;display:block;width:calc(100% + 24px);height:16px;margin-top:-16px;transform:translate(-12px);z-index:99;top:28px}:root .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-1),.16)}html[aui-theme-mode=light] .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-1),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-9),.75)}}html[aui-theme-mode=dark] .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-9),.75)}.aui-table__scroll-shadow.hasTableBottomShadow:after{content:\"\";position:sticky;display:block;width:calc(100% + 24px);height:16px;transform:translate(-12px,12px);z-index:99;bottom:0;margin-top:-16px}:root .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-1),.16) inset}html[aui-theme-mode=light] .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-1),.16) inset}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-9),.75) inset}}html[aui-theme-mode=dark] .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-9),.75) inset}.aui-table__scroll-shadow .aui-table__header-row{margin:0;padding:0;align-items:stretch}.aui-table__scroll-shadow .aui-table__header-row .aui-table__header-cell:first-of-type{padding-left:20px}.aui-table__scroll-shadow .aui-table__header-row .aui-table__header-cell:last-of-type{padding-right:20px}.aui-table__scroll-shadow .aui-table__header-row+.aui-table__row .aui-table__cell:first-of-type{border-top-left-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__header-row+.aui-table__row .aui-table__cell:last-of-type{border-top-right-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__row{border:none;padding:0;align-items:stretch}.aui-table__scroll-shadow .aui-table__row .aui-table__cell{border-width:1px 0;border-style:solid;border-color:rgb(var(--aui-color-n-8))}.aui-table__scroll-shadow .aui-table__row .aui-table__cell:first-of-type{border-left-width:1px;padding-left:19px}.aui-table__scroll-shadow .aui-table__row .aui-table__cell:last-of-type{border-right-width:1px;padding-right:19px}.aui-table__scroll-shadow .aui-table__row:last-child .aui-table__cell:first-of-type{border-bottom-left-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__row:last-child .aui-table__cell:last-of-type{border-bottom-right-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__row:not(.aui-table__scroll-shadow .aui-table__row:last-child) .aui-table__cell{border-bottom-width:0}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:after,.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:after{position:absolute;top:0;bottom:-1px;width:20px;transition:box-shadow .3s;content:\"\";pointer-events:none}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:before,.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:before{position:absolute;top:0;bottom:-1px;content:\"\";background:linear-gradient(to bottom,rgb(var(--aui-color-n-7)),rgb(var(--aui-color-n-7)) 8px,transparent 6px,transparent);width:1px;background-size:100% 14px;height:100%}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left{padding-right:30px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:after{right:-10px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:before{right:10px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right{padding-left:30px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:after{left:-10px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:before{left:10px}:root .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}html[aui-theme-mode=light] .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}}html[aui-theme-mode=dark] .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}.aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):before{background:linear-gradient(to bottom,rgb(var(--aui-color-primary)),rgb(var(--aui-color-primary)) 8px,transparent 6px,transparent);width:1px;background-size:100% 14px;height:100%}:root .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}html[aui-theme-mode=light] .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}}html[aui-theme-mode=dark] .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}.aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):before{background:linear-gradient(to bottom,rgb(var(--aui-color-primary)),rgb(var(--aui-color-primary)) 8px,transparent 6px,transparent);width:1px;background-size:100% 14px;height:100%}\n"] }]
|
|
69
|
+
], styles: [".aui-table{display:block;padding:0 12px 12px;font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);color:rgb(var(--aui-color-main-text));background-color:rgb(var(--aui-color-n-9));border-radius:var(--aui-border-radius-l);overflow:auto}.aui-table::-webkit-scrollbar{width:4px;height:4px}.aui-table::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-table__row,.aui-table__header-row{display:flex;align-items:center}.aui-table__row.hasPanel,.aui-table__header-row.hasPanel{flex-wrap:wrap}.aui-table__header-row+.aui-table__row{border-top-left-radius:var(--aui-border-radius-l);border-top-right-radius:var(--aui-border-radius-l)}.aui-table__row{position:relative;border-width:1px;border-style:solid;border-color:rgb(var(--aui-color-n-8));border-bottom-width:0;background-color:rgb(var(--aui-color-n-10));padding:0 9px;min-height:58px;box-sizing:content-box}.aui-table__row:first-child{border-top-left-radius:var(--aui-border-radius-l);border-top-right-radius:var(--aui-border-radius-l)}.aui-table__row:last-of-type{border-bottom-width:1px;min-height:58px;border-bottom-left-radius:var(--aui-border-radius-l);border-bottom-right-radius:var(--aui-border-radius-l)}.aui-table__row.isDisabled:before{content:\"\";z-index:2;position:absolute;top:0;left:0;width:100%;height:100%;background-color:rgb(var(--aui-color-n-10));opacity:.7;cursor:not-allowed}.aui-table__header-row{background-color:rgb(var(--aui-color-n-9));padding:0 10px}.aui-table__cell,.aui-table__header-cell{flex:1}.aui-table__cell{padding:15px 10px;background-color:rgb(var(--aui-color-n-10));overflow:hidden;word-wrap:break-word}.aui-table__header-cell{padding:12px 10px;font-weight:var(--aui-font-weight-bold);background-color:rgb(var(--aui-color-n-9));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.aui-table__column-expand-button{display:flex;align-items:center;max-width:calc(10px * 2 + var(--aui-icon-size-m))}.aui-table__column-expand-button.aui-table__cell{height:58px}.aui-table__column-expand-button .aui-expand-button{display:inline-flex;justify-content:center;align-items:center;width:var(--aui-icon-size-m);height:var(--aui-icon-size-m);font-size:var(--aui-icon-size-m);line-height:var(--aui-icon-size-m);color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-p-6));border-radius:50%;border:none;cursor:pointer;transition:transform .1s ease-in-out}.aui-table__column-expand-button .aui-expand-button aui-icon{display:block;width:var(--aui-icon-size-m);height:var(--aui-icon-size-m)}.aui-table__column-expand-button .aui-expand-button:hover{background-color:rgb(var(--aui-color-p-7))}.aui-table__column-expand-button .aui-expand-button:active{background-color:rgb(var(--aui-color-p-5))}.aui-table__column-expand-button .aui-expand-button.isExpanded{transform:rotate(90deg);color:#fff;background-color:rgb(var(--aui-color-primary))}.aui-table__column-expand-button .aui-expand-button.isExpanded:hover{background-color:rgb(var(--aui-color-p-1))}.aui-table__column-expand-button .aui-expand-button.isExpanded:active{background-color:rgb(var(--aui-color-p-0))}.aui-table__column-expand-button .aui-expand-button[disabled],.aui-table__column-expand-button .aui-expand-button.isExpanded[disabled]{background-color:rgb(var(--aui-color-n-8));color:rgb(var(--aui-color-n-6));cursor:not-allowed}.aui-table__column-expand-panel{margin-top:-6px}.aui-table__column-expand-panel.aui-table__header-cell{display:none}.aui-table__column-expand-panel.aui-table__cell{width:100%;flex-shrink:0;flex-basis:100%;padding:0 10px;overflow:hidden}.aui-table__column-expand-panel.aui-table__cell .aui-table__cell-expand-panel{border-radius:var(--aui-border-radius-l);overflow:hidden}.aui-table__column-expand-panel.aui-table__cell .aui-table__cell-expand-panel-content.hasBackground{padding:16px;background-color:rgb(var(--aui-color-n-9))}\n", ".aui-table__scroll-wrapper{background-color:rgb(var(--aui-color-n-9));padding:0 12px 12px;border-radius:var(--aui-border-radius-l)}.aui-table__scroll-wrapper::-webkit-scrollbar{width:4px;height:4px}.aui-table__scroll-wrapper::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-table__scroll-wrapper .aui-table{padding:0;border-radius:0}.aui-table__scroll-wrapper .aui-table__scroll-shadow.hasTableTopShadow:before,.aui-table__scroll-wrapper .aui-table__scroll-shadow.hasTableBottomShadow:after{transform:none;width:100%;left:0}.aui-table__scroll-shadow.hasTableTopShadow:before{content:\"\";position:sticky;display:block;width:calc(100% + 24px);height:16px;margin-top:-16px;transform:translate(-12px);z-index:99;top:28px}:root .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-1),.16)}html[aui-theme-mode=light] .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-1),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-9),.75)}}html[aui-theme-mode=dark] .aui-table__scroll-shadow.hasTableTopShadow:before{box-shadow:0 10px 10px -4px rgba(var(--aui-color-n-9),.75)}.aui-table__scroll-shadow.hasTableBottomShadow:after{content:\"\";position:sticky;display:block;width:calc(100% + 24px);height:16px;transform:translate(-12px,12px);z-index:99;bottom:0;margin-top:-16px}:root .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-1),.16) inset}html[aui-theme-mode=light] .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-1),.16) inset}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-9),.75) inset}}html[aui-theme-mode=dark] .aui-table__scroll-shadow.hasTableBottomShadow:after{box-shadow:0 -10px 10px -4px rgba(var(--aui-color-n-9),.75) inset}.aui-table__scroll-shadow .aui-table__header-row{margin:0;padding:0;align-items:stretch}.aui-table__scroll-shadow .aui-table__header-row .aui-table__header-cell:first-of-type{padding-left:20px}.aui-table__scroll-shadow .aui-table__header-row .aui-table__header-cell:last-of-type{padding-right:20px}.aui-table__scroll-shadow .aui-table__header-row+.aui-table__row .aui-table__cell:first-of-type{border-top-left-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__header-row+.aui-table__row .aui-table__cell:last-of-type{border-top-right-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__row{border:none;padding:0;align-items:stretch}.aui-table__scroll-shadow .aui-table__row .aui-table__cell{border-width:1px 0;border-style:solid;border-color:rgb(var(--aui-color-n-8))}.aui-table__scroll-shadow .aui-table__row .aui-table__cell:first-of-type{border-left-width:1px;padding-left:19px}.aui-table__scroll-shadow .aui-table__row .aui-table__cell:last-of-type{border-right-width:1px;padding-right:19px}.aui-table__scroll-shadow .aui-table__row:last-child .aui-table__cell:first-of-type{border-bottom-left-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__row:last-child .aui-table__cell:last-of-type{border-bottom-right-radius:var(--aui-border-radius-l)}.aui-table__scroll-shadow .aui-table__row:not(.aui-table__scroll-shadow .aui-table__row:last-child) .aui-table__cell{border-bottom-width:0}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:after,.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:after{position:absolute;top:0;bottom:-1px;width:20px;transition:box-shadow .3s;content:\"\";pointer-events:none}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:before,.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:before{position:absolute;top:0;bottom:-1px;content:\"\";background:linear-gradient(to bottom,rgb(var(--aui-color-n-7)),rgb(var(--aui-color-n-7)) 8px,transparent 6px,transparent);width:1px;background-size:100% 14px;height:100%}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left{padding-right:30px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:after{right:-10px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-left:before{right:10px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right{padding-left:30px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:after{left:-10px}.aui-table__scroll-shadow--has-scroll .aui-table-sticky-border-elem-right:before{left:10px}:root .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}html[aui-theme-mode=light] .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}}html[aui-theme-mode=dark] .aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):after{box-shadow:inset 8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}.aui-table__scroll-shadow--scrolling .aui-table-sticky-border-elem-left:not(.aui-table__header-row):before{background:linear-gradient(to bottom,rgb(var(--aui-color-primary)),rgb(var(--aui-color-primary)) 8px,transparent 6px,transparent);width:1px;background-size:100% 14px;height:100%}:root .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}html[aui-theme-mode=light] .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-1),.16)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}}html[aui-theme-mode=dark] .aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):after{box-shadow:inset -8px 0 4px -4px rgba(var(--aui-color-n-9),.75)}.aui-table__scroll-shadow--before-end .aui-table-sticky-border-elem-right:not(.aui-table__header-row):before{background:linear-gradient(to bottom,rgb(var(--aui-color-primary)),rgb(var(--aui-color-primary)) 8px,transparent 6px,transparent);width:1px;background-size:100% 14px;height:100%}\n"] }]
|
|
70
70
|
}], propDecorators: { enableScrollWrapper: [{
|
|
71
71
|
type: Input
|
|
72
72
|
}], _placeholderOutlet: [{
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { Directive, EventEmitter, HostListener, Output, } from '@angular/core';
|
|
2
|
-
import { EMPTY, Subject, animationFrameScheduler, of, } from 'rxjs';
|
|
3
|
-
import { debounceTime, endWith, map, observeOn, repeat, startWith, switchMap, takeUntil, takeWhile, tap, } from 'rxjs/operators';
|
|
2
|
+
import { EMPTY, Subject, animationFrameScheduler, of, debounceTime, endWith, map, observeOn, repeat, startWith, switchMap, takeUntil, takeWhile, tap, } from 'rxjs';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
4
|
export class TocContainerDirective {
|
|
6
5
|
constructor(elementRef, cdr) {
|
|
@@ -107,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
107
106
|
type: HostListener,
|
|
108
107
|
args: ['scroll']
|
|
109
108
|
}] } });
|
|
110
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toc-container.directive.js","sourceRoot":"","sources":["../../../src/table-of-contents/toc-container.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  OnDestroy,\n  Output,\n} from '@angular/core';\nimport {\n  EMPTY,\n  Subject,\n  Subscription,\n  animationFrameScheduler,\n  of,\n} from 'rxjs';\nimport {\n  debounceTime,\n  endWith,\n  map,\n  observeOn,\n  repeat,\n  startWith,\n  switchMap,\n  takeUntil,\n  takeWhile,\n  tap,\n} from 'rxjs/operators';\n\nimport { TocContentDirective } from './toc-content.directive';\n\n@Directive({\n  selector: '[auiTocContainer]',\n  exportAs: 'auiTocContainer',\n})\nexport class TocContainerDirective implements AfterContentInit, OnDestroy {\n  @Output()\n  activedChange = new EventEmitter<string>();\n\n  private _contents: TocContentDirective[] = [];\n  private readonly _scrollTop$ = new Subject<number>();\n  private readonly _scrollTo$ = new Subject<string>();\n  private readonly _onDestroy$ = new Subject<void>();\n  private readonly _subs: Subscription[] = [];\n  private _nativeElement: HTMLElement;\n\n  get scrollTop(): number {\n    return this._nativeElement.scrollTop || 0;\n  }\n\n  set scrollTop(value: number) {\n    this._nativeElement.scrollTop = value;\n  }\n\n  get isScrollEnd() {\n    return (\n      this._nativeElement.scrollHeight - this._nativeElement.scrollTop ===\n      this._nativeElement.clientHeight\n    );\n  }\n\n  constructor(\n    elementRef: ElementRef<HTMLElement>,\n    private readonly cdr: ChangeDetectorRef,\n  ) {\n    this._nativeElement = elementRef.nativeElement;\n  }\n\n  getOffsetTop(element: HTMLElement): number {\n    if (element.parentElement === this._nativeElement) {\n      return element.offsetTop;\n    }\n    return element.offsetTop + this.getOffsetTop(element.parentElement);\n  }\n\n  private getMinContent(scrollTop: number) {\n    return (minContent: TocContentDirective, content: TocContentDirective) => {\n      if (\n        Math.abs(scrollTop - this.getOffsetTop(content.nativeElement)) <\n        Math.abs(scrollTop - this.getOffsetTop(minContent.nativeElement))\n      ) {\n        minContent = content;\n      }\n      return minContent;\n    };\n  }\n\n  private getMaxContent(\n    maxContent: TocContentDirective,\n    content: TocContentDirective,\n  ) {\n    if (\n      this.getOffsetTop(content.nativeElement) >\n      this.getOffsetTop(maxContent.nativeElement)\n    ) {\n      maxContent = content;\n    }\n    return maxContent;\n  }\n\n  @HostListener('scroll')\n  onScroll() {\n    this._scrollTop$.next(this.scrollTop);\n  }\n\n  ngAfterContentInit() {\n    const actived$ = this._scrollTop$\n      .pipe(\n        startWith(this.scrollTop),\n        debounceTime(200),\n        map(scrollTop =>\n          this._contents.reduce(\n            this.isScrollEnd\n              ? this.getMaxContent.bind(this)\n              : this.getMinContent(scrollTop),\n          ),\n        ),\n        map(actived => actived.auiTocContent),\n      )\n      .pipe(\n        tap(actived => {\n          this._contents.forEach(content => {\n            content.active = actived === content.auiTocContent;\n          });\n          this.cdr.detectChanges();\n        }),\n      );\n\n    const scrollTween$ = this._scrollTo$.pipe(\n      switchMap(name => {\n        const target = this._contents.find(\n          content => content.auiTocContent === name,\n        );\n\n        if (!target) {\n          return EMPTY;\n        }\n        const destination = this.getOffsetTop(target.nativeElement);\n\n        const start = performance.now();\n        const source = this.scrollTop;\n        const duration = 500;\n\n        return of(0).pipe(\n          observeOn(animationFrameScheduler),\n          repeat(),\n          map(() => (performance.now() - start) / duration),\n          takeWhile(t => t < 1),\n          endWith(1),\n          map(t => t * t * t),\n          map(t => source * (1 - t) + destination * t),\n        );\n      }),\n      takeUntil(this._onDestroy$),\n    );\n\n    this._subs.push(\n      actived$.subscribe(this.activedChange),\n      scrollTween$.subscribe(tweenValue => {\n        this.scrollTop = tweenValue;\n      }),\n    );\n  }\n\n  ngOnDestroy() {\n    this._subs.forEach(sub => sub.unsubscribe());\n    this._onDestroy$.next();\n  }\n\n  scrollTo(content: string | string[]) {\n    if (Array.isArray(content)) {\n      this._scrollTo$.next(content[0]);\n    } else {\n      this._scrollTo$.next(content);\n    }\n  }\n\n  registerContent(tocContent: TocContentDirective) {\n    this._contents = [...this._contents, tocContent];\n  }\n\n  deregisterContent(tocContent: TocContentDirective) {\n    this._contents = this._contents.filter(\n      content => content.auiTocContent !== tocContent.auiTocContent,\n    );\n  }\n}\n"]}
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toc-container.directive.js","sourceRoot":"","sources":["../../../src/table-of-contents/toc-container.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  OnDestroy,\n  Output,\n} from '@angular/core';\nimport {\n  EMPTY,\n  Subject,\n  Subscription,\n  animationFrameScheduler,\n  of,\n  debounceTime,\n  endWith,\n  map,\n  observeOn,\n  repeat,\n  startWith,\n  switchMap,\n  takeUntil,\n  takeWhile,\n  tap,\n} from 'rxjs';\n\nimport { TocContentDirective } from './toc-content.directive';\n\n@Directive({\n  selector: '[auiTocContainer]',\n  exportAs: 'auiTocContainer',\n})\nexport class TocContainerDirective implements AfterContentInit, OnDestroy {\n  @Output()\n  activedChange = new EventEmitter<string>();\n\n  private _contents: TocContentDirective[] = [];\n  private readonly _scrollTop$ = new Subject<number>();\n  private readonly _scrollTo$ = new Subject<string>();\n  private readonly _onDestroy$ = new Subject<void>();\n  private readonly _subs: Subscription[] = [];\n  private _nativeElement: HTMLElement;\n\n  get scrollTop(): number {\n    return this._nativeElement.scrollTop || 0;\n  }\n\n  set scrollTop(value: number) {\n    this._nativeElement.scrollTop = value;\n  }\n\n  get isScrollEnd() {\n    return (\n      this._nativeElement.scrollHeight - this._nativeElement.scrollTop ===\n      this._nativeElement.clientHeight\n    );\n  }\n\n  constructor(\n    elementRef: ElementRef<HTMLElement>,\n    private readonly cdr: ChangeDetectorRef,\n  ) {\n    this._nativeElement = elementRef.nativeElement;\n  }\n\n  getOffsetTop(element: HTMLElement): number {\n    if (element.parentElement === this._nativeElement) {\n      return element.offsetTop;\n    }\n    return element.offsetTop + this.getOffsetTop(element.parentElement);\n  }\n\n  private getMinContent(scrollTop: number) {\n    return (minContent: TocContentDirective, content: TocContentDirective) => {\n      if (\n        Math.abs(scrollTop - this.getOffsetTop(content.nativeElement)) <\n        Math.abs(scrollTop - this.getOffsetTop(minContent.nativeElement))\n      ) {\n        minContent = content;\n      }\n      return minContent;\n    };\n  }\n\n  private getMaxContent(\n    maxContent: TocContentDirective,\n    content: TocContentDirective,\n  ) {\n    if (\n      this.getOffsetTop(content.nativeElement) >\n      this.getOffsetTop(maxContent.nativeElement)\n    ) {\n      maxContent = content;\n    }\n    return maxContent;\n  }\n\n  @HostListener('scroll')\n  onScroll() {\n    this._scrollTop$.next(this.scrollTop);\n  }\n\n  ngAfterContentInit() {\n    const actived$ = this._scrollTop$\n      .pipe(\n        startWith(this.scrollTop),\n        debounceTime(200),\n        map(scrollTop =>\n          this._contents.reduce(\n            this.isScrollEnd\n              ? this.getMaxContent.bind(this)\n              : this.getMinContent(scrollTop),\n          ),\n        ),\n        map(actived => actived.auiTocContent),\n      )\n      .pipe(\n        tap(actived => {\n          this._contents.forEach(content => {\n            content.active = actived === content.auiTocContent;\n          });\n          this.cdr.detectChanges();\n        }),\n      );\n\n    const scrollTween$ = this._scrollTo$.pipe(\n      switchMap(name => {\n        const target = this._contents.find(\n          content => content.auiTocContent === name,\n        );\n\n        if (!target) {\n          return EMPTY;\n        }\n        const destination = this.getOffsetTop(target.nativeElement);\n\n        const start = performance.now();\n        const source = this.scrollTop;\n        const duration = 500;\n\n        return of(0).pipe(\n          observeOn(animationFrameScheduler),\n          repeat(),\n          map(() => (performance.now() - start) / duration),\n          takeWhile(t => t < 1),\n          endWith(1),\n          map(t => t * t * t),\n          map(t => source * (1 - t) + destination * t),\n        );\n      }),\n      takeUntil(this._onDestroy$),\n    );\n\n    this._subs.push(\n      actived$.subscribe(this.activedChange),\n      scrollTween$.subscribe(tweenValue => {\n        this.scrollTop = tweenValue;\n      }),\n    );\n  }\n\n  ngOnDestroy() {\n    this._subs.forEach(sub => sub.unsubscribe());\n    this._onDestroy$.next();\n  }\n\n  scrollTo(content: string | string[]) {\n    if (Array.isArray(content)) {\n      this._scrollTo$.next(content[0]);\n    } else {\n      this._scrollTo$.next(content);\n    }\n  }\n\n  registerContent(tocContent: TocContentDirective) {\n    this._contents = [...this._contents, tocContent];\n  }\n\n  deregisterContent(tocContent: TocContentDirective) {\n    this._contents = this._contents.filter(\n      content => content.auiTocContent !== tocContent.auiTocContent,\n    );\n  }\n}\n"]}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { Injectable, Optional, SkipSelf } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject, combineLatest } from 'rxjs';
|
|
3
|
-
import { distinctUntilChanged, map } from 'rxjs/operators';
|
|
2
|
+
import { BehaviorSubject, combineLatest, distinctUntilChanged, map, } from 'rxjs';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
4
|
export class TabContextService {
|
|
6
5
|
constructor(_parent) {
|
|
@@ -29,4 +28,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
29
28
|
}, {
|
|
30
29
|
type: SkipSelf
|
|
31
30
|
}] }]; } });
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLWNvbnRleHQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90YWJzL3RhYi1jb250ZXh0LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9ELE9BQU8sRUFDTCxlQUFlLEVBRWYsYUFBYSxFQUNiLG9CQUFvQixFQUNwQixHQUFHLEdBQ0osTUFBTSxNQUFNLENBQUM7O0FBR2QsTUFBTSxPQUFPLGlCQUFpQjtJQWdCNUIsWUFHVyxPQUEwQjtRQUExQixZQUFPLEdBQVAsT0FBTyxDQUFtQjtRQWxCcEIsYUFBUSxHQUFHLElBQUksZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBb0JyRCxJQUFJLENBQUMsT0FBTyxHQUFHLENBQ2IsT0FBTztZQUNMLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FDbEQsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FDeEI7WUFDSCxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FDbEIsQ0FBQyxJQUFJLENBQUMsb0JBQW9CLEVBQUUsQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUF6QkQ7O09BRUc7SUFDSCxJQUFJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDO0lBQzdCLENBQUM7SUFFRCxJQUFJLFFBQVEsQ0FBQyxRQUFpQjtRQUM1QixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUMvQixDQUFDOzs4R0FaVSxpQkFBaUIsa0JBbUJSLGlCQUFpQjtrSEFuQjFCLGlCQUFpQjsyRkFBakIsaUJBQWlCO2tCQUQ3QixVQUFVOzBEQW9CVyxpQkFBaUI7MEJBRmxDLFFBQVE7OzBCQUNSLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBPcHRpb25hbCwgU2tpcFNlbGYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIEJlaGF2aW9yU3ViamVjdCxcbiAgT2JzZXJ2YWJsZSxcbiAgY29tYmluZUxhdGVzdCxcbiAgZGlzdGluY3RVbnRpbENoYW5nZWQsXG4gIG1hcCxcbn0gZnJvbSAncnhqcyc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBUYWJDb250ZXh0U2VydmljZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgYWN0aXZlJCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0KGZhbHNlKTtcblxuICAvKipcbiAgICogV2hldGhlciB0aGUgdGFiIGlzIGN1cnJlbnRseSBhY3RpdmUuXG4gICAqL1xuICBnZXQgaXNBY3RpdmUoKSB7XG4gICAgcmV0dXJuIHRoaXMuYWN0aXZlJCQudmFsdWU7XG4gIH1cblxuICBzZXQgaXNBY3RpdmUoaXNBY3RpdmU6IGJvb2xlYW4pIHtcbiAgICB0aGlzLmFjdGl2ZSQkLm5leHQoaXNBY3RpdmUpO1xuICB9XG5cbiAgcmVhZG9ubHkgYWN0aXZlJDogT2JzZXJ2YWJsZTxib29sZWFuPjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBAT3B0aW9uYWwoKVxuICAgIEBTa2lwU2VsZigpXG4gICAgcmVhZG9ubHkgX3BhcmVudDogVGFiQ29udGV4dFNlcnZpY2UsXG4gICkge1xuICAgIHRoaXMuYWN0aXZlJCA9IChcbiAgICAgIF9wYXJlbnRcbiAgICAgICAgPyBjb21iaW5lTGF0ZXN0KFtfcGFyZW50LmFjdGl2ZSQsIHRoaXMuYWN0aXZlJCRdKS5waXBlKFxuICAgICAgICAgICAgbWFwKChbYSwgYl0pID0+IGEgJiYgYiksXG4gICAgICAgICAgKVxuICAgICAgICA6IHRoaXMuYWN0aXZlJCRcbiAgICApLnBpcGUoZGlzdGluY3RVbnRpbENoYW5nZWQoKSk7XG4gIH1cbn1cbiJdfQ==
|