@alauda/ui 6.4.6-beta.3 → 6.4.6-beta.6
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/alauda-ui.d.ts +3 -0
- package/button/button.types.d.ts +9 -0
- package/esm2020/accordion/accordion-item/accordion-item.component.mjs +3 -1
- package/esm2020/alauda-ui.mjs +4 -1
- package/esm2020/anchor/anchor.component.mjs +2 -1
- package/esm2020/back-top/back-top.component.mjs +4 -2
- package/esm2020/button/button.component.mjs +2 -1
- package/esm2020/button/button.types.mjs +10 -1
- package/esm2020/date-picker/calendar/constant.mjs +2 -1
- package/esm2020/date-picker/calendar/header/component.mjs +5 -1
- package/esm2020/date-picker/calendar/panel/picker-panel.mjs +5 -1
- package/esm2020/date-picker/calendar/range-picker-panel/component.mjs +3 -1
- package/esm2020/date-picker/calendar/util.mjs +2 -1
- package/esm2020/dialog/dialog-content/dialog-content.component.mjs +2 -1
- package/esm2020/dialog/dialog.service.mjs +2 -1
- package/esm2020/drawer/component/drawer.component.mjs +4 -1
- package/esm2020/drawer/component/helper-directives.mjs +5 -1
- package/esm2020/form/common-form.mjs +8 -1
- package/esm2020/icon/icon-register.service.mjs +2 -1
- package/esm2020/input/autosize.directive.mjs +7 -2
- package/esm2020/input/input.component.mjs +5 -1
- package/esm2020/input/search/search.component.mjs +2 -2
- package/esm2020/input/tags-input/tags-input.component.mjs +7 -2
- package/esm2020/message/message.config.mjs +6 -1
- package/esm2020/notification/notification.component.mjs +5 -1
- package/esm2020/paginator/paginator-intl.mjs +12 -1
- package/esm2020/paginator/paginator.component.mjs +9 -1
- package/esm2020/radio/radio-button/radio-button.component.mjs +2 -1
- package/esm2020/radio/radio-group/radio-group.component.mjs +4 -1
- package/esm2020/radio/radio.component.mjs +2 -1
- package/esm2020/scrolling/fixed-size-table-virtual-scroll-strategy.mjs +3 -1
- package/esm2020/scrolling/fixed-size-table-virtual-scroll.directive.mjs +3 -1
- package/esm2020/scrolling/fixed-size-virtual-scroll.directive.mjs +2 -1
- package/esm2020/select/base-select.mjs +5 -2
- package/esm2020/select/multi-select/multi-select.component.mjs +4 -2
- package/esm2020/select/select.component.mjs +2 -1
- package/esm2020/select/validators.mjs +6 -2
- package/esm2020/sort/sort-errors.mjs +5 -1
- package/esm2020/sort/sort-header.component.mjs +5 -1
- package/esm2020/sort/sort.directive.mjs +2 -1
- package/esm2020/steps/steps.component.mjs +5 -1
- package/esm2020/table/table-cell-def.directive.mjs +5 -1
- package/esm2020/table/table-cell.directive.mjs +3 -1
- package/esm2020/table/table-column-def.directive.mjs +7 -1
- package/esm2020/table/table-header-cell-def.directive.mjs +5 -1
- package/esm2020/table/table-header-cell.directive.mjs +3 -1
- package/esm2020/table/table-header-row-def.directive.mjs +5 -1
- package/esm2020/table/table-header-row.component.mjs +2 -1
- package/esm2020/table/table-row-def.directive.mjs +6 -1
- package/esm2020/table/table-row.component.mjs +2 -1
- package/esm2020/table/table-scroll.directive.mjs +2 -1
- package/esm2020/table/table.component.mjs +4 -1
- package/esm2020/tabs/tab-body.component.mjs +19 -1
- package/esm2020/tabs/tab-context.service.mjs +4 -1
- package/esm2020/tabs/tab-group.component.mjs +46 -1
- package/esm2020/tabs/tab-header-active-indicator.component.mjs +10 -1
- package/esm2020/tabs/tab-header.component.mjs +106 -3
- package/esm2020/tabs/tab.component.mjs +15 -1
- package/esm2020/tabs/tabs.types.mjs +4 -1
- package/esm2020/tag/tag.component.mjs +2 -1
- package/esm2020/time-picker/panel/panel.component.mjs +3 -1
- package/esm2020/tooltip/tooltip-intl.mjs +7 -1
- package/esm2020/tree-select/tree-select.component.mjs +2 -1
- package/esm2020/types.mjs +4 -1
- package/esm2020/utils/bem.mjs +2 -1
- package/esm2020/utils/coercion.mjs +5 -1
- package/fesm2015/alauda-ui.mjs +375 -10
- package/fesm2015/alauda-ui.mjs.map +1 -1
- package/fesm2020/alauda-ui.mjs +375 -10
- package/fesm2020/alauda-ui.mjs.map +1 -1
- package/form/common-form.d.ts +7 -0
- package/input/autosize.directive.d.ts +3 -0
- package/input/input.component.d.ts +3 -0
- package/message/message.config.d.ts +20 -0
- package/notification/notification.component.d.ts +4 -0
- package/package.json +2 -3
- package/paginator/paginator-intl.d.ts +9 -0
- package/paginator/paginator.component.d.ts +14 -0
- package/radio/radio-group/radio-group.component.d.ts +3 -0
- package/select/base-select.d.ts +3 -0
- package/sort/sort-errors.d.ts +4 -0
- package/steps/steps.component.d.ts +3 -0
- package/steps/types.d.ts +3 -0
- package/table/table-cell-def.directive.d.ts +4 -0
- package/table/table-cell.directive.d.ts +1 -0
- package/table/table-column-def.directive.d.ts +4 -0
- package/table/table-header-cell-def.directive.d.ts +4 -0
- package/table/table-header-cell.directive.d.ts +1 -0
- package/table/table-header-row-def.directive.d.ts +4 -0
- package/table/table-header-row.component.d.ts +1 -0
- package/table/table-row-def.directive.d.ts +5 -0
- package/table/table-row.component.d.ts +1 -0
- package/tabs/tab-body.component.d.ts +16 -0
- package/tabs/tab-context.service.d.ts +3 -0
- package/tabs/tab-group.component.d.ts +28 -0
- package/tabs/tab-header-active-indicator.component.d.ts +9 -0
- package/tabs/tab-header.component.d.ts +83 -0
- package/tabs/tab.component.d.ts +18 -0
- package/tabs/tabs.types.d.ts +3 -0
- package/theme/_theme-preset.scss +2 -0
- package/tooltip/tooltip-intl.d.ts +4 -0
- package/types.d.ts +3 -0
|
@@ -69,6 +69,7 @@ export class TableScrollShadowDirective {
|
|
|
69
69
|
const scrollTop = this.containerEl.scrollTop;
|
|
70
70
|
this.placeClassList(this.containerEl.classList, scrollTop > 0, HAS_TABLE_TOP_SHADOW);
|
|
71
71
|
this.placeClassList(this.containerEl.classList, scrollTop < scrollDis, HAS_TABLE_BOTTOM_SHADOW);
|
|
72
|
+
// 兼容屏幕缩放是 sticky多列的样式问题
|
|
72
73
|
this.table.updateStickyColumnStyles();
|
|
73
74
|
}
|
|
74
75
|
mutateHorizontalScroll() {
|
|
@@ -104,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
104
105
|
type: HostBinding,
|
|
105
106
|
args: [`class.${SHADOW_CLASS}`]
|
|
106
107
|
}] } });
|
|
107
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
108
|
+
//# 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  Input,\n  OnDestroy,\n} from '@angular/core';\nimport {\n  Subject,\n  fromEvent,\n  merge,\n  startWith,\n  takeUntil,\n  switchMap,\n  NEVER,\n} from 'rxjs';\n\nimport { coerceAttrBoolean, 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  @HostBinding('style.max-height')\n  @Input()\n  auiTableScrollWrapper = '100%';\n}\n\n@Directive({\n  selector: '[auiTableScrollShadow]',\n})\nexport class TableScrollShadowDirective implements AfterViewInit, OnDestroy {\n  scrollShadow$$ = new Subject<boolean>();\n\n  destroy$$ = new Subject<void>();\n\n  @Input()\n  set auiTableScrollShadow(scrollShadow: boolean | '') {\n    this.scrollShadow$$.next(coerceAttrBoolean(scrollShadow));\n  }\n\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    this.scrollShadow$$\n      .pipe(\n        switchMap(scrollShadow =>\n          scrollShadow\n            ? merge(\n                observeResizeOn(this.containerEl),\n                fromEvent(this.containerEl, 'scroll'),\n              ).pipe(startWith(null))\n            : NEVER,\n        ),\n      )\n      .pipe(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    this.destroy$$.complete();\n  }\n}\n"]}
|
|
@@ -6,10 +6,13 @@ import * as i0 from "@angular/core";
|
|
|
6
6
|
import * as i1 from "@angular/cdk/table";
|
|
7
7
|
import * as i2 from "./table-placeholder.directive";
|
|
8
8
|
export class TableComponent extends CdkTable {
|
|
9
|
+
// FIXME: workaround to override because it will break constructor if it is field, but why MatTable works?
|
|
10
|
+
// @ts-ignore
|
|
9
11
|
get stickyCssClass() {
|
|
10
12
|
return 'aui-table-sticky';
|
|
11
13
|
}
|
|
12
14
|
set stickyCssClass(_) {
|
|
15
|
+
// nothing
|
|
13
16
|
}
|
|
14
17
|
ngAfterContentInit() {
|
|
15
18
|
this._createPlaceholder();
|
|
@@ -73,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
73
76
|
type: ContentChild,
|
|
74
77
|
args: [TablePlaceholderDefDirective, { static: true }]
|
|
75
78
|
}] } });
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3RhYmxlL3RhYmxlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsNEJBQTRCLEVBQzVCLHVCQUF1QixHQUN4QixNQUFNLDBCQUEwQixDQUFDO0FBQ2xDLE9BQU8sRUFDTCxTQUFTLEVBQ1Qsa0JBQWtCLEVBQ2xCLFFBQVEsRUFDUiwwQkFBMEIsRUFDMUIsd0JBQXdCLEdBQ3pCLE1BQU0sb0JBQW9CLENBQUM7QUFDNUIsT0FBTyxFQUVMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFFTCxTQUFTLEVBQ1QsaUJBQWlCLEdBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFDTCw0QkFBNEIsRUFDNUIsK0JBQStCLEdBQ2hDLE1BQU0sK0JBQStCLENBQUM7Ozs7QUE4QnZDLE1BQU0sT0FBTyxjQUNYLFNBQVEsUUFBVztJQVluQiwwR0FBMEc7SUFDMUcsYUFBYTtJQUNiLElBQWMsY0FBYztRQUMxQixPQUFPLGtCQUFrQixDQUFDO0lBQzVCLENBQUM7SUFFRCxJQUF1QixjQUFjLENBQUMsQ0FBUztRQUM3QyxVQUFVO0lBQ1osQ0FBQztJQUVELGtCQUFrQjtRQUNoQixJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBRU8sa0JBQWtCO1FBQ3hCLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUM7UUFDdkMsSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlLEVBQUU7WUFDekIsT0FBTztTQUNSO1FBRUQsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGFBQWEsQ0FBQztRQUN4RCxTQUFTLENBQUMsa0JBQWtCLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFFTyxpQkFBaUI7UUFDdkIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUNoRCxDQUFDO0lBRVEsV0FBVztRQUNsQixLQUFLLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDcEIsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7SUFDM0IsQ0FBQzs7MkdBNUNVLGNBQWM7K0ZBQWQsY0FBYyxtSUFmZDtRQUNUO1lBQ0UsT0FBTyxFQUFFLFNBQVM7WUFDbEIsV0FBVyxFQUFFLGNBQWM7U0FDNUI7UUFDRDtZQUNFLE9BQU8sRUFBRSx1QkFBdUI7WUFDaEMsUUFBUSxFQUFFLDRCQUE0QjtTQUN2QztRQUNEO1lBQ0UsT0FBTyxFQUFFLDBCQUEwQjtZQUNuQyxRQUFRLEVBQUUsd0JBQXdCO1NBQ25DO0tBQ0YsdUVBWWEsNEJBQTRCLGtIQUgvQiwrQkFBK0I7MkZBUC9CLGNBQWM7a0JBNUIxQixTQUFTOytCQUNFLFdBQVcsWUFDWCxVQUFVLGlCQUNMLGlCQUFpQixDQUFDLElBQUksWUFHbkMsa0JBQWtCO3dCQUNsQix5REFBeUQsUUFDckQ7d0JBQ0osS0FBSyxFQUFFLFdBQVc7cUJBQ25CLHVCQUNvQixLQUFLLG1CQUNULHVCQUF1QixDQUFDLE1BQU0sYUFDcEM7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLFNBQVM7NEJBQ2xCLFdBQVcsZ0JBQWdCO3lCQUM1Qjt3QkFDRDs0QkFDRSxPQUFPLEVBQUUsdUJBQXVCOzRCQUNoQyxRQUFRLEVBQUUsNEJBQTRCO3lCQUN2Qzt3QkFDRDs0QkFDRSxPQUFPLEVBQUUsMEJBQTBCOzRCQUNuQyxRQUFRLEVBQUUsd0JBQXdCO3lCQUNuQztxQkFDRjs4QkFPRCxtQkFBbUI7c0JBRGxCLEtBQUs7Z0JBSU4sa0JBQWtCO3NCQURqQixTQUFTO3VCQUFDLCtCQUErQixFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTtnQkFJNUQsZUFBZTtzQkFEZCxZQUFZO3VCQUFDLDRCQUE0QixFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIF9EaXNwb3NlVmlld1JlcGVhdGVyU3RyYXRlZ3ksXG4gIF9WSUVXX1JFUEVBVEVSX1NUUkFURUdZLFxufSBmcm9tICdAYW5ndWxhci9jZGsvY29sbGVjdGlvbnMnO1xuaW1wb3J0IHtcbiAgQ0RLX1RBQkxFLFxuICBDREtfVEFCTEVfVEVNUExBVEUsXG4gIENka1RhYmxlLFxuICBfQ09BTEVTQ0VEX1NUWUxFX1NDSEVEVUxFUixcbiAgX0NvYWxlc2NlZFN0eWxlU2NoZWR1bGVyLFxufSBmcm9tICdAYW5ndWxhci9jZGsvdGFibGUnO1xuaW1wb3J0IHtcbiAgQWZ0ZXJDb250ZW50SW5pdCxcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgQ29udGVudENoaWxkLFxuICBJbnB1dCxcbiAgT25EZXN0cm95LFxuICBWaWV3Q2hpbGQsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtcbiAgVGFibGVQbGFjZWhvbGRlckRlZkRpcmVjdGl2ZSxcbiAgVGFibGVQbGFjZWhvbGRlck91dGxldERpcmVjdGl2ZSxcbn0gZnJvbSAnLi90YWJsZS1wbGFjZWhvbGRlci5kaXJlY3RpdmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhdWktdGFibGUnLFxuICBleHBvcnRBczogJ2F1aVRhYmxlJyxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgc3R5bGVVcmxzOiBbJ3RhYmxlLmNvbXBvbmVudC5zY3NzJywgJ3RhYmxlLXNjcm9sbC5zY3NzJ10sXG4gIHRlbXBsYXRlOlxuICAgIENES19UQUJMRV9URU1QTEFURSArXG4gICAgJzxuZy1jb250YWluZXIgYXVpVGFibGVQbGFjZWhvbGRlck91dGxldD48L25nLWNvbnRhaW5lcj4nLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdhdWktdGFibGUnLFxuICB9LFxuICBwcmVzZXJ2ZVdoaXRlc3BhY2VzOiBmYWxzZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IENES19UQUJMRSxcbiAgICAgIHVzZUV4aXN0aW5nOiBUYWJsZUNvbXBvbmVudCxcbiAgICB9LFxuICAgIHtcbiAgICAgIHByb3ZpZGU6IF9WSUVXX1JFUEVBVEVSX1NUUkFURUdZLFxuICAgICAgdXNlQ2xhc3M6IF9EaXNwb3NlVmlld1JlcGVhdGVyU3RyYXRlZ3ksXG4gICAgfSxcbiAgICB7XG4gICAgICBwcm92aWRlOiBfQ09BTEVTQ0VEX1NUWUxFX1NDSEVEVUxFUixcbiAgICAgIHVzZUNsYXNzOiBfQ29hbGVzY2VkU3R5bGVTY2hlZHVsZXIsXG4gICAgfSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgVGFibGVDb21wb25lbnQ8VD5cbiAgZXh0ZW5kcyBDZGtUYWJsZTxUPlxuICBpbXBsZW1lbnRzIEFmdGVyQ29udGVudEluaXQsIE9uRGVzdHJveVxue1xuICBASW5wdXQoKVxuICBlbmFibGVTY3JvbGxXcmFwcGVyOiBib29sZWFuO1xuXG4gIEBWaWV3Q2hpbGQoVGFibGVQbGFjZWhvbGRlck91dGxldERpcmVjdGl2ZSwgeyBzdGF0aWM6IHRydWUgfSlcbiAgX3BsYWNlaG9sZGVyT3V0bGV0OiBUYWJsZVBsYWNlaG9sZGVyT3V0bGV0RGlyZWN0aXZlO1xuXG4gIEBDb250ZW50Q2hpbGQoVGFibGVQbGFjZWhvbGRlckRlZkRpcmVjdGl2ZSwgeyBzdGF0aWM6IHRydWUgfSlcbiAgX3BsYWNlaG9sZGVyRGVmOiBUYWJsZVBsYWNlaG9sZGVyRGVmRGlyZWN0aXZlO1xuXG4gIC8vIEZJWE1FOiB3b3JrYXJvdW5kIHRvIG92ZXJyaWRlIGJlY2F1c2UgaXQgd2lsbCBicmVhayBjb25zdHJ1Y3RvciBpZiBpdCBpcyBmaWVsZCwgYnV0IHdoeSBNYXRUYWJsZSB3b3Jrcz9cbiAgLy8gQHRzLWlnbm9yZVxuICBwcm90ZWN0ZWQgZ2V0IHN0aWNreUNzc0NsYXNzKCkge1xuICAgIHJldHVybiAnYXVpLXRhYmxlLXN0aWNreSc7XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgc2V0IHN0aWNreUNzc0NsYXNzKF86IHN0cmluZykge1xuICAgIC8vIG5vdGhpbmdcbiAgfVxuXG4gIG5nQWZ0ZXJDb250ZW50SW5pdCgpIHtcbiAgICB0aGlzLl9jcmVhdGVQbGFjZWhvbGRlcigpO1xuICB9XG5cbiAgcHJpdmF0ZSBfY3JlYXRlUGxhY2Vob2xkZXIoKSB7XG4gICAgY29uc3QgZm9vdGVyUm93ID0gdGhpcy5fcGxhY2Vob2xkZXJEZWY7XG4gICAgaWYgKCF0aGlzLl9wbGFjZWhvbGRlckRlZikge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IGNvbnRhaW5lciA9IHRoaXMuX3BsYWNlaG9sZGVyT3V0bGV0LnZpZXdDb250YWluZXI7XG4gICAgY29udGFpbmVyLmNyZWF0ZUVtYmVkZGVkVmlldyhmb290ZXJSb3cudGVtcGxhdGVSZWYpO1xuICB9XG5cbiAgcHJpdmF0ZSBfY2xlYXJQbGFjZWhvbGRlcigpIHtcbiAgICB0aGlzLl9wbGFjZWhvbGRlck91dGxldC52aWV3Q29udGFpbmVyLmNsZWFyKCk7XG4gIH1cblxuICBvdmVycmlkZSBuZ09uRGVzdHJveSgpIHtcbiAgICBzdXBlci5uZ09uRGVzdHJveSgpO1xuICAgIHRoaXMuX2NsZWFyUGxhY2Vob2xkZXIoKTtcbiAgfVxufVxuIl19
|
|
@@ -7,6 +7,7 @@ export class TabBodyComponent {
|
|
|
7
7
|
constructor() {
|
|
8
8
|
this.content$ = new BehaviorSubject(null);
|
|
9
9
|
}
|
|
10
|
+
/** The tab body content to display. */
|
|
10
11
|
get content() {
|
|
11
12
|
return this._content;
|
|
12
13
|
}
|
|
@@ -31,7 +32,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
31
32
|
}], content: [{
|
|
32
33
|
type: Input
|
|
33
34
|
}] } });
|
|
35
|
+
/** Used to flag tab labels for use with the portal directive */
|
|
34
36
|
export class TabLabelDirective extends CdkPortal {
|
|
37
|
+
// eslint-disable-next-line @typescript-eslint/no-useless-constructor
|
|
35
38
|
constructor(templateRef, viewContainerRef) {
|
|
36
39
|
super(templateRef, viewContainerRef);
|
|
37
40
|
}
|
|
@@ -44,6 +47,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
44
47
|
selector: '[auiTabLabel]',
|
|
45
48
|
}]
|
|
46
49
|
}], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
|
|
50
|
+
/**
|
|
51
|
+
* Lazy load the embedded template for a tab content.
|
|
52
|
+
*/
|
|
47
53
|
export class TabContentDirective {
|
|
48
54
|
constructor(template) {
|
|
49
55
|
this.template = template;
|
|
@@ -57,7 +63,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
57
63
|
selector: '[auiTabContent]',
|
|
58
64
|
}]
|
|
59
65
|
}], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
|
|
66
|
+
/** Used to project additional template from host to the tab header. */
|
|
60
67
|
export class TabHeaderAddonDirective extends CdkPortal {
|
|
68
|
+
// eslint-disable-next-line @typescript-eslint/no-useless-constructor
|
|
61
69
|
constructor(templateRef, viewContainerRef) {
|
|
62
70
|
super(templateRef, viewContainerRef);
|
|
63
71
|
}
|
|
@@ -70,10 +78,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
70
78
|
selector: '[auiTabHeaderAddon]',
|
|
71
79
|
}]
|
|
72
80
|
}], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
|
|
81
|
+
/**
|
|
82
|
+
* Used in the `aui-tab-group` view to display tab labels.
|
|
83
|
+
*/
|
|
73
84
|
export class TabLabelWrapperDirective {
|
|
74
85
|
constructor(elementRef) {
|
|
75
86
|
this.elementRef = elementRef;
|
|
76
87
|
}
|
|
88
|
+
/** Whether or not the tab is disabled */
|
|
77
89
|
get disabled() {
|
|
78
90
|
return this._disabled;
|
|
79
91
|
}
|
|
@@ -86,6 +98,7 @@ export class TabLabelWrapperDirective {
|
|
|
86
98
|
getOffsetWidth() {
|
|
87
99
|
return this.elementRef.nativeElement.offsetWidth;
|
|
88
100
|
}
|
|
101
|
+
/** Sets focus on the wrapper element */
|
|
89
102
|
focus() {
|
|
90
103
|
this.elementRef.nativeElement.focus();
|
|
91
104
|
}
|
|
@@ -105,6 +118,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
105
118
|
type: Input
|
|
106
119
|
}] } });
|
|
107
120
|
export class TabTitleDirective extends CdkPortal {
|
|
121
|
+
// eslint-disable-next-line @typescript-eslint/no-useless-constructor
|
|
108
122
|
constructor(templateRef, viewContainerRef) {
|
|
109
123
|
super(templateRef, viewContainerRef);
|
|
110
124
|
}
|
|
@@ -117,12 +131,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
117
131
|
selector: '[auiTabTitle]',
|
|
118
132
|
}]
|
|
119
133
|
}], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
|
|
134
|
+
/**
|
|
135
|
+
* The portal host directive for the contents of the tab.
|
|
136
|
+
*/
|
|
120
137
|
export class TabBodyPortalDirective extends CdkPortalOutlet {
|
|
121
138
|
constructor(componentFactoryResolver, viewContainerRef, _host) {
|
|
122
139
|
super(componentFactoryResolver, viewContainerRef);
|
|
123
140
|
this._host = _host;
|
|
124
141
|
this._hostSubscription = Subscription.EMPTY;
|
|
125
142
|
}
|
|
143
|
+
/** Set initial visibility or set up subscription for changing visibility. */
|
|
126
144
|
ngOnInit() {
|
|
127
145
|
super.ngOnInit();
|
|
128
146
|
this._hostSubscription = this._host.content$.subscribe(content => {
|
|
@@ -144,4 +162,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
144
162
|
selector: '[auiTabBodyHost]',
|
|
145
163
|
}]
|
|
146
164
|
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.ViewContainerRef }, { type: TabBodyComponent }]; } });
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-body.component.js","sourceRoot":"","sources":["../../../src/tabs/tab-body.component.ts","../../../src/tabs/tab-body.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  CdkPortal,\n  CdkPortalOutlet,\n  TemplatePortal,\n} from '@angular/cdk/portal';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ComponentFactoryResolver,\n  Directive,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { BehaviorSubject, Subscription } from 'rxjs';\n\nimport { coerceAttrBoolean } from '../utils';\n\n@Component({\n  selector: 'aui-tab-body',\n  templateUrl: './tab-body.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n})\nexport class TabBodyComponent implements OnDestroy {\n  private _content: TemplatePortal;\n\n  content$ = new BehaviorSubject<TemplatePortal>(null);\n\n  /** The portal host inside of this container into which the tab body content will be loaded. */\n  @ViewChild(CdkPortalOutlet, { static: true })\n  _portalOutlet: CdkPortalOutlet;\n\n  /** The tab body content to display. */\n  @Input()\n  get content() {\n    return this._content;\n  }\n\n  set content(content: TemplatePortal) {\n    if (this._content !== content) {\n      this.content$.next(content);\n    }\n    this._content = content;\n  }\n\n  ngOnDestroy() {\n    this.content$.complete();\n  }\n}\n\n/** Used to flag tab labels for use with the portal directive */\n@Directive({\n  selector: '[auiTabLabel]',\n})\nexport class TabLabelDirective extends CdkPortal {\n  // eslint-disable-next-line @typescript-eslint/no-useless-constructor\n  constructor(\n    templateRef: TemplateRef<any>,\n    viewContainerRef: ViewContainerRef,\n  ) {\n    super(templateRef, viewContainerRef);\n  }\n}\n\n/**\n * Lazy load the embedded template for a tab content.\n */\n@Directive({\n  selector: '[auiTabContent]',\n})\nexport class TabContentDirective {\n  constructor(public template: TemplateRef<any>) {}\n}\n\n/** Used to project additional template from host to the tab header. */\n@Directive({\n  selector: '[auiTabHeaderAddon]',\n})\nexport class TabHeaderAddonDirective extends CdkPortal {\n  // eslint-disable-next-line @typescript-eslint/no-useless-constructor\n  constructor(\n    templateRef: TemplateRef<any>,\n    viewContainerRef: ViewContainerRef,\n  ) {\n    super(templateRef, viewContainerRef);\n  }\n}\n\n/**\n * Used in the `aui-tab-group` view to display tab labels.\n */\n@Directive({\n  selector: '[auiTabLabelWrapper]',\n  host: {\n    '[class.aui-tab-label]': 'true',\n    '[class.aui-tab-label--disabled]': '!!disabled',\n  },\n})\nexport class TabLabelWrapperDirective {\n  private _disabled: boolean;\n\n  /** Whether or not the tab is disabled  */\n  @Input()\n  get disabled() {\n    return this._disabled;\n  }\n\n  set disabled(value: boolean | '') {\n    this._disabled = coerceAttrBoolean(value);\n  }\n\n  getOffsetLeft(): number {\n    return this.elementRef.nativeElement.offsetLeft;\n  }\n\n  getOffsetWidth(): number {\n    return this.elementRef.nativeElement.offsetWidth;\n  }\n\n  /** Sets focus on the wrapper element */\n  focus(): void {\n    this.elementRef.nativeElement.focus();\n  }\n\n  constructor(public elementRef: ElementRef<HTMLElement>) {}\n}\n\n@Directive({\n  selector: '[auiTabTitle]',\n})\nexport class TabTitleDirective extends CdkPortal {\n  // eslint-disable-next-line @typescript-eslint/no-useless-constructor\n  constructor(\n    templateRef: TemplateRef<any>,\n    viewContainerRef: ViewContainerRef,\n  ) {\n    super(templateRef, viewContainerRef);\n  }\n}\n\n/**\n * The portal host directive for the contents of the tab.\n */\n@Directive({\n  selector: '[auiTabBodyHost]',\n})\nexport class TabBodyPortalDirective\n  extends CdkPortalOutlet\n  implements OnInit, OnDestroy\n{\n  private _hostSubscription = Subscription.EMPTY;\n\n  constructor(\n    componentFactoryResolver: ComponentFactoryResolver,\n    viewContainerRef: ViewContainerRef,\n    private readonly _host: TabBodyComponent,\n  ) {\n    super(componentFactoryResolver, viewContainerRef);\n  }\n\n  /** Set initial visibility or set up subscription for changing visibility. */\n  override ngOnInit(): void {\n    super.ngOnInit();\n    this._hostSubscription = this._host.content$.subscribe(content => {\n      if (this.hasAttached) {\n        this.detach();\n      }\n      this.attach(content);\n    });\n  }\n\n  override ngOnDestroy() {\n    this._hostSubscription.unsubscribe();\n  }\n}\n","<div class=\"aui-tab-body\">\n  <div\n    #content\n    class=\"aui-tab-body__content\"\n  >\n    <ng-template auiTabBodyHost></ng-template>\n  </div>\n</div>\n"]}
|
|
165
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-body.component.js","sourceRoot":"","sources":["../../../src/tabs/tab-body.component.ts","../../../src/tabs/tab-body.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  CdkPortal,\n  CdkPortalOutlet,\n  TemplatePortal,\n} from '@angular/cdk/portal';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ComponentFactoryResolver,\n  Directive,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { BehaviorSubject, Subscription } from 'rxjs';\n\nimport { coerceAttrBoolean } from '../utils';\n\n@Component({\n  selector: 'aui-tab-body',\n  templateUrl: './tab-body.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n})\nexport class TabBodyComponent implements OnDestroy {\n  private _content: TemplatePortal;\n\n  content$ = new BehaviorSubject<TemplatePortal>(null);\n\n  /** The portal host inside of this container into which the tab body content will be loaded. */\n  @ViewChild(CdkPortalOutlet, { static: true })\n  _portalOutlet: CdkPortalOutlet;\n\n  /** The tab body content to display. */\n  @Input()\n  get content() {\n    return this._content;\n  }\n\n  set content(content: TemplatePortal) {\n    if (this._content !== content) {\n      this.content$.next(content);\n    }\n    this._content = content;\n  }\n\n  ngOnDestroy() {\n    this.content$.complete();\n  }\n}\n\n/** Used to flag tab labels for use with the portal directive */\n@Directive({\n  selector: '[auiTabLabel]',\n})\nexport class TabLabelDirective extends CdkPortal {\n  // eslint-disable-next-line @typescript-eslint/no-useless-constructor\n  constructor(\n    templateRef: TemplateRef<any>,\n    viewContainerRef: ViewContainerRef,\n  ) {\n    super(templateRef, viewContainerRef);\n  }\n}\n\n/**\n * Lazy load the embedded template for a tab content.\n */\n@Directive({\n  selector: '[auiTabContent]',\n})\nexport class TabContentDirective {\n  constructor(public template: TemplateRef<any>) {}\n}\n\n/** Used to project additional template from host to the tab header. */\n@Directive({\n  selector: '[auiTabHeaderAddon]',\n})\nexport class TabHeaderAddonDirective extends CdkPortal {\n  // eslint-disable-next-line @typescript-eslint/no-useless-constructor\n  constructor(\n    templateRef: TemplateRef<any>,\n    viewContainerRef: ViewContainerRef,\n  ) {\n    super(templateRef, viewContainerRef);\n  }\n}\n\n/**\n * Used in the `aui-tab-group` view to display tab labels.\n */\n@Directive({\n  selector: '[auiTabLabelWrapper]',\n  host: {\n    '[class.aui-tab-label]': 'true',\n    '[class.aui-tab-label--disabled]': '!!disabled',\n  },\n})\nexport class TabLabelWrapperDirective {\n  private _disabled: boolean;\n\n  /** Whether or not the tab is disabled  */\n  @Input()\n  get disabled() {\n    return this._disabled;\n  }\n\n  set disabled(value: boolean | '') {\n    this._disabled = coerceAttrBoolean(value);\n  }\n\n  getOffsetLeft(): number {\n    return this.elementRef.nativeElement.offsetLeft;\n  }\n\n  getOffsetWidth(): number {\n    return this.elementRef.nativeElement.offsetWidth;\n  }\n\n  /** Sets focus on the wrapper element */\n  focus(): void {\n    this.elementRef.nativeElement.focus();\n  }\n\n  constructor(public elementRef: ElementRef<HTMLElement>) {}\n}\n\n@Directive({\n  selector: '[auiTabTitle]',\n})\nexport class TabTitleDirective extends CdkPortal {\n  // eslint-disable-next-line @typescript-eslint/no-useless-constructor\n  constructor(\n    templateRef: TemplateRef<any>,\n    viewContainerRef: ViewContainerRef,\n  ) {\n    super(templateRef, viewContainerRef);\n  }\n}\n\n/**\n * The portal host directive for the contents of the tab.\n */\n@Directive({\n  selector: '[auiTabBodyHost]',\n})\nexport class TabBodyPortalDirective\n  extends CdkPortalOutlet\n  implements OnInit, OnDestroy\n{\n  private _hostSubscription = Subscription.EMPTY;\n\n  constructor(\n    componentFactoryResolver: ComponentFactoryResolver,\n    viewContainerRef: ViewContainerRef,\n    private readonly _host: TabBodyComponent,\n  ) {\n    super(componentFactoryResolver, viewContainerRef);\n  }\n\n  /** Set initial visibility or set up subscription for changing visibility. */\n  override ngOnInit(): void {\n    super.ngOnInit();\n    this._hostSubscription = this._host.content$.subscribe(content => {\n      if (this.hasAttached) {\n        this.detach();\n      }\n      this.attach(content);\n    });\n  }\n\n  override ngOnDestroy() {\n    this._hostSubscription.unsubscribe();\n  }\n}\n","<div class=\"aui-tab-body\">\n  <div\n    #content\n    class=\"aui-tab-body__content\"\n  >\n    <ng-template auiTabBodyHost></ng-template>\n  </div>\n</div>\n"]}
|
|
@@ -9,6 +9,9 @@ export class TabContextService {
|
|
|
9
9
|
? combineLatest([_parent.active$, this.active$$]).pipe(map(([a, b]) => a && b))
|
|
10
10
|
: this.active$$).pipe(distinctUntilChanged());
|
|
11
11
|
}
|
|
12
|
+
/**
|
|
13
|
+
* Whether the tab is currently active.
|
|
14
|
+
*/
|
|
12
15
|
get isActive() {
|
|
13
16
|
return this.active$$.value;
|
|
14
17
|
}
|
|
@@ -25,4 +28,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
25
28
|
}, {
|
|
26
29
|
type: SkipSelf
|
|
27
30
|
}] }]; } });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLWNvbnRleHQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90YWJzL3RhYi1jb250ZXh0LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9ELE9BQU8sRUFDTCxlQUFlLEVBRWYsYUFBYSxFQUNiLG9CQUFvQixFQUNwQixHQUFHLEdBQ0osTUFBTSxNQUFNLENBQUM7O0FBR2QsTUFBTSxPQUFPLGlCQUFpQjtJQWdCNUIsWUFHVyxPQUEwQjtRQUExQixZQUFPLEdBQVAsT0FBTyxDQUFtQjtRQWxCcEIsYUFBUSxHQUFHLElBQUksZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBb0JyRCxJQUFJLENBQUMsT0FBTyxHQUFHLENBQ2IsT0FBTztZQUNMLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FDbEQsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FDeEI7WUFDSCxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FDbEIsQ0FBQyxJQUFJLENBQUMsb0JBQW9CLEVBQUUsQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUF6QkQ7O09BRUc7SUFDSCxJQUFJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDO0lBQzdCLENBQUM7SUFFRCxJQUFJLFFBQVEsQ0FBQyxRQUFpQjtRQUM1QixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUMvQixDQUFDOzs4R0FaVSxpQkFBaUIsa0JBbUJSLGlCQUFpQjtrSEFuQjFCLGlCQUFpQjsyRkFBakIsaUJBQWlCO2tCQUQ3QixVQUFVOzBEQW9CVyxpQkFBaUI7MEJBRmxDLFFBQVE7OzBCQUNSLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBPcHRpb25hbCwgU2tpcFNlbGYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIEJlaGF2aW9yU3ViamVjdCxcbiAgT2JzZXJ2YWJsZSxcbiAgY29tYmluZUxhdGVzdCxcbiAgZGlzdGluY3RVbnRpbENoYW5nZWQsXG4gIG1hcCxcbn0gZnJvbSAncnhqcyc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBUYWJDb250ZXh0U2VydmljZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgYWN0aXZlJCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0KGZhbHNlKTtcblxuICAvKipcbiAgICogV2hldGhlciB0aGUgdGFiIGlzIGN1cnJlbnRseSBhY3RpdmUuXG4gICAqL1xuICBnZXQgaXNBY3RpdmUoKSB7XG4gICAgcmV0dXJuIHRoaXMuYWN0aXZlJCQudmFsdWU7XG4gIH1cblxuICBzZXQgaXNBY3RpdmUoaXNBY3RpdmU6IGJvb2xlYW4pIHtcbiAgICB0aGlzLmFjdGl2ZSQkLm5leHQoaXNBY3RpdmUpO1xuICB9XG5cbiAgcmVhZG9ubHkgYWN0aXZlJDogT2JzZXJ2YWJsZTxib29sZWFuPjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBAT3B0aW9uYWwoKVxuICAgIEBTa2lwU2VsZigpXG4gICAgcmVhZG9ubHkgX3BhcmVudDogVGFiQ29udGV4dFNlcnZpY2UsXG4gICkge1xuICAgIHRoaXMuYWN0aXZlJCA9IChcbiAgICAgIF9wYXJlbnRcbiAgICAgICAgPyBjb21iaW5lTGF0ZXN0KFtfcGFyZW50LmFjdGl2ZSQsIHRoaXMuYWN0aXZlJCRdKS5waXBlKFxuICAgICAgICAgICAgbWFwKChbYSwgYl0pID0+IGEgJiYgYiksXG4gICAgICAgICAgKVxuICAgICAgICA6IHRoaXMuYWN0aXZlJCRcbiAgICApLnBpcGUoZGlzdGluY3RVbnRpbENoYW5nZWQoKSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
/* eslint-disable no-prototype-builtins */
|
|
1
2
|
import { ChangeDetectionStrategy, Component, ContentChild, ContentChildren, EventEmitter, Input, Output, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
2
3
|
import { Subject, Subscription, merge } from 'rxjs';
|
|
3
4
|
import { buildBem, coerceNumber } from '../utils';
|
|
@@ -12,27 +13,37 @@ import * as i3 from "./tab-body.component";
|
|
|
12
13
|
import * as i4 from "@angular/common";
|
|
13
14
|
import * as i5 from "@angular/cdk/portal";
|
|
14
15
|
import * as i6 from "@angular/cdk/a11y";
|
|
16
|
+
/** A simple change event emitted on focus or selection changes. */
|
|
15
17
|
export class TabChangeEvent {
|
|
16
18
|
}
|
|
17
19
|
export class TabGroupComponent {
|
|
18
20
|
constructor(_changeDetectorRef) {
|
|
19
21
|
this._changeDetectorRef = _changeDetectorRef;
|
|
20
22
|
this.bem = buildBem('aui-tab-group');
|
|
23
|
+
/** The tab index that should be selected after the content has been checked. */
|
|
21
24
|
this._indexToSelect = 0;
|
|
25
|
+
/** Subscription to tabs being added/removed. */
|
|
22
26
|
this._tabsSubscription = Subscription.EMPTY;
|
|
27
|
+
/** Subscription to changes in the tab labels. */
|
|
23
28
|
this._tabLabelSubscription = Subscription.EMPTY;
|
|
24
29
|
this._selectedIndex = null;
|
|
25
30
|
this._tab = null;
|
|
26
31
|
this._type = TabType.Line;
|
|
27
32
|
this._size = TabSize.Medium;
|
|
33
|
+
/** Emits whenever the type changes */
|
|
28
34
|
this._typeChange = new Subject();
|
|
35
|
+
/** Emits whenever the size changes */
|
|
29
36
|
this._sizeChange = new Subject();
|
|
37
|
+
/** Output to enable support for two-way binding on `[(selectedIndex)]` */
|
|
30
38
|
this.selectedIndexChange = new EventEmitter();
|
|
31
39
|
this.tabChange = new EventEmitter();
|
|
40
|
+
/** Event emitted when the tab selection has changed. */
|
|
32
41
|
this.selectedTabChange = new EventEmitter(true);
|
|
42
|
+
/** Event emitted when focus has changed within a tab group. */
|
|
33
43
|
this.focusChange = new EventEmitter();
|
|
34
44
|
this.activatedTabs = [];
|
|
35
45
|
}
|
|
46
|
+
/** The index of the active tab. */
|
|
36
47
|
get selectedIndex() {
|
|
37
48
|
return this._selectedIndex;
|
|
38
49
|
}
|
|
@@ -92,20 +103,34 @@ export class TabGroupComponent {
|
|
|
92
103
|
this._sizeChange.next();
|
|
93
104
|
}
|
|
94
105
|
}
|
|
106
|
+
/**
|
|
107
|
+
* After the content is checked, this component knows what tabs have been defined
|
|
108
|
+
* and what the selected index should be. This is where we can know exactly what position
|
|
109
|
+
* each tab should be in according to the new selected index.
|
|
110
|
+
*/
|
|
95
111
|
ngAfterContentChecked() {
|
|
112
|
+
// Don't clamp the `indexToSelect` immediately in the setter because it can happen that
|
|
113
|
+
// the amount of tabs changes before the actual change detection runs.
|
|
96
114
|
const indexToSelect = (this._indexToSelect = this._clampTabIndex(this._indexToSelect));
|
|
115
|
+
// If there is a change in selected index, emit a change event. Should not trigger if
|
|
116
|
+
// the selected index has not yet been initialized.
|
|
97
117
|
if (this._selectedIndex !== indexToSelect && this._selectedIndex != null) {
|
|
98
118
|
this._changeActivatedTabs();
|
|
99
119
|
const tabChangeEvent = this._createChangeEvent(indexToSelect);
|
|
100
120
|
this.selectedTabChange.emit(tabChangeEvent);
|
|
121
|
+
// Emitting this value after change detection has run
|
|
122
|
+
// since the checked content may contain this variable'
|
|
101
123
|
Promise.resolve().then(() => {
|
|
102
124
|
this.selectedIndexChange.emit(indexToSelect);
|
|
103
125
|
this.tabChange.emit(this._tabs.get(indexToSelect).name);
|
|
104
126
|
});
|
|
105
127
|
}
|
|
128
|
+
// Setup the position for each tab and optionally setup an origin on the next selected tab.
|
|
106
129
|
this._tabs.forEach((tab, index) => {
|
|
107
130
|
tab.position = index - indexToSelect;
|
|
108
131
|
tab.tabContext.isActive = index === indexToSelect;
|
|
132
|
+
// If there is already a selected tab, then set up an origin for the next selected tab
|
|
133
|
+
// if it doesn't have one already.
|
|
109
134
|
if (this._selectedIndex != null && tab.position === 0 && !tab.origin) {
|
|
110
135
|
tab.origin = indexToSelect - this._selectedIndex;
|
|
111
136
|
}
|
|
@@ -125,15 +150,22 @@ export class TabGroupComponent {
|
|
|
125
150
|
}
|
|
126
151
|
this._changeActivatedTabs();
|
|
127
152
|
this._subscribeToTabLabels();
|
|
153
|
+
// Subscribe to changes in the amount of tabs, in order to be
|
|
154
|
+
// able to re-render the content as new tabs are added or removed.
|
|
128
155
|
this._tabsSubscription = this._tabs.changes.subscribe(() => {
|
|
129
156
|
const tabs = this._tabs.toArray();
|
|
130
157
|
if (this._lazy) {
|
|
131
158
|
this.activatedTabs = this.activatedTabs.filter(tab => tabs.includes(tab));
|
|
132
159
|
}
|
|
133
160
|
const indexToSelect = this._clampTabIndex(this._indexToSelect);
|
|
161
|
+
// Maintain the previously-selected tab if a new tab is added or removed and there is no
|
|
162
|
+
// explicit change that selects a different tab.
|
|
134
163
|
if (indexToSelect === this._selectedIndex) {
|
|
135
164
|
for (const [i, tab] of tabs.entries()) {
|
|
136
165
|
if (tab.tabContext.isActive) {
|
|
166
|
+
// Assign both to the `_indexToSelect` and `_selectedIndex` so we don't fire a changed
|
|
167
|
+
// event, otherwise the consumer may end up in an infinite loop in some edge cases like
|
|
168
|
+
// adding a tab within the `selectedIndexChange` event.
|
|
137
169
|
this._indexToSelect = this._selectedIndex = i;
|
|
138
170
|
break;
|
|
139
171
|
}
|
|
@@ -150,6 +182,7 @@ export class TabGroupComponent {
|
|
|
150
182
|
this._typeChange.complete();
|
|
151
183
|
this._sizeChange.complete();
|
|
152
184
|
}
|
|
185
|
+
/** Handle click events, setting new selected index if appropriate. */
|
|
153
186
|
_handleClick(tab, idx) {
|
|
154
187
|
if (!tab.disabled) {
|
|
155
188
|
this.selectedIndex = this._tabHeader.focusIndex = idx;
|
|
@@ -158,6 +191,7 @@ export class TabGroupComponent {
|
|
|
158
191
|
_focusChanged(index) {
|
|
159
192
|
this.focusChange.emit(this._createChangeEvent(index));
|
|
160
193
|
}
|
|
194
|
+
/** Re-aligns the ink bar to the selected tab element. */
|
|
161
195
|
realignActiveIndicator() {
|
|
162
196
|
if (this._tabHeader) {
|
|
163
197
|
this._tabHeader._alignActiveIndicatorToSelectedTab();
|
|
@@ -175,7 +209,11 @@ export class TabGroupComponent {
|
|
|
175
209
|
this.activatedTabs.push(tab);
|
|
176
210
|
}
|
|
177
211
|
}
|
|
212
|
+
/** Clamps the given index to the bounds of 0 and the tabs length. */
|
|
178
213
|
_clampTabIndex(index) {
|
|
214
|
+
// Note the `|| 0`, which ensures that values like NaN can't get through
|
|
215
|
+
// and which would otherwise throw the component into an infinite loop
|
|
216
|
+
// (since Math.max(NaN, 0) === NaN).
|
|
179
217
|
return Math.min(this._tabs.length - 1, Math.max(index || 0, 0));
|
|
180
218
|
}
|
|
181
219
|
_findIndexByTab(name) {
|
|
@@ -189,6 +227,12 @@ export class TabGroupComponent {
|
|
|
189
227
|
}
|
|
190
228
|
return event;
|
|
191
229
|
}
|
|
230
|
+
/**
|
|
231
|
+
* Subscribes to changes in the tab labels. This is needed, because the @Input for the label is
|
|
232
|
+
* on the Tab component, whereas the data binding is inside the TabGroup. In order for the
|
|
233
|
+
* binding to be updated, we need to subscribe to changes in it and trigger change detection
|
|
234
|
+
* manually.
|
|
235
|
+
*/
|
|
192
236
|
_subscribeToTabLabels() {
|
|
193
237
|
if (this._tabLabelSubscription) {
|
|
194
238
|
this._tabLabelSubscription.unsubscribe();
|
|
@@ -198,6 +242,7 @@ export class TabGroupComponent {
|
|
|
198
242
|
this._changeDetectorRef.markForCheck();
|
|
199
243
|
});
|
|
200
244
|
}
|
|
245
|
+
/** Retrieves the tabindex for the tab. */
|
|
201
246
|
_getTabIndex(tab, idx) {
|
|
202
247
|
if (tab.disabled) {
|
|
203
248
|
return null;
|
|
@@ -243,4 +288,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
243
288
|
}], focusChange: [{
|
|
244
289
|
type: Output
|
|
245
290
|
}] } });
|
|
246
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-group.component.js","sourceRoot":"","sources":["../../../src/tabs/tab-group.component.ts","../../../src/tabs/tab-group.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-prototype-builtins */\nimport {\n  AfterContentChecked,\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Subject, Subscription, merge } from 'rxjs';\n\nimport { Bem, buildBem, coerceNumber } from '../utils';\n\nimport {\n  TabHeaderAddonDirective,\n  TabTitleDirective,\n} from './tab-body.component';\nimport { TabHeaderComponent } from './tab-header.component';\nimport { TabComponent } from './tab.component';\nimport { TabSize, TabType } from './tabs.types';\n\n/** A simple change event emitted on focus or selection changes. */\nexport class TabChangeEvent {\n  /** Index of the currently-selected tab. */\n  index: number;\n  /** Reference to the currently-selected tab. */\n  tab: TabComponent;\n}\n\n@Component({\n  selector: 'aui-tab-group',\n  exportAs: 'auiTabGroup',\n  templateUrl: './tab-group.component.html',\n  styleUrls: ['./tab-group.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n})\nexport class TabGroupComponent\n  implements OnChanges, AfterContentChecked, AfterContentInit, OnDestroy\n{\n  bem: Bem = buildBem('aui-tab-group');\n\n  @ContentChildren(TabComponent)\n  _tabs: QueryList<TabComponent>;\n\n  @ContentChild(TabHeaderAddonDirective, { static: false })\n  _headerAddon: TabHeaderAddonDirective;\n\n  @ViewChild(TabHeaderComponent, { static: false })\n  _tabHeader: TabHeaderComponent;\n\n  @ContentChild(TabTitleDirective, { static: false })\n  _tabTitle: TabTitleDirective;\n\n  /** The tab index that should be selected after the content has been checked. */\n  private _indexToSelect: number | null = 0;\n\n  /** Subscription to tabs being added/removed. */\n  private _tabsSubscription = Subscription.EMPTY;\n\n  /** Subscription to changes in the tab labels. */\n  private _tabLabelSubscription = Subscription.EMPTY;\n\n  private _selectedIndex: number | null = null;\n  private _tab: string = null;\n  private _type: TabType = TabType.Line;\n  private _size: TabSize = TabSize.Medium;\n\n  /** true lazy mode for template ref children */\n  private _lazy: boolean;\n\n  private _previousHeaderAddon: TabHeaderAddonDirective;\n\n  /** Emits whenever the type changes */\n  readonly _typeChange = new Subject<void>();\n\n  /** Emits whenever the size changes */\n  readonly _sizeChange = new Subject<void>();\n\n  /** The index of the active tab. */\n  @Input()\n  get selectedIndex(): number | null {\n    return this._selectedIndex;\n  }\n\n  set selectedIndex(value: number | null) {\n    this._indexToSelect = coerceNumber(value, null);\n    this._changeActivatedTabs();\n  }\n\n  @Input()\n  get tab(): string {\n    return this._tab;\n  }\n\n  set tab(value: string) {\n    this._tab = value;\n    if (this._tabs) {\n      this.selectedIndex = this._findIndexByTab(value);\n    }\n  }\n\n  @Input()\n  get type() {\n    return this._type;\n  }\n\n  set type(type: TabType) {\n    this._type = type;\n  }\n\n  @Input()\n  title: string | TemplateRef<unknown>;\n\n  @Input()\n  get size() {\n    return this._size;\n  }\n\n  set size(val) {\n    if (!val || this._size === val) {\n      return;\n    }\n    this._size = val;\n  }\n\n  @Input()\n  get lazy() {\n    return this._lazy;\n  }\n\n  set lazy(lazy: boolean) {\n    if (this._lazy === lazy) {\n      return;\n    }\n    this._lazy = lazy;\n    if (lazy) {\n      this._changeActivatedTabs();\n    } else {\n      this.activatedTabs.length = 0;\n    }\n  }\n\n  /** Output to enable support for two-way binding on `[(selectedIndex)]` */\n  @Output()\n  readonly selectedIndexChange = new EventEmitter<number>();\n\n  @Output()\n  readonly tabChange = new EventEmitter<string>();\n\n  /** Event emitted when the tab selection has changed. */\n  @Output()\n  readonly selectedTabChange = new EventEmitter<TabChangeEvent>(true);\n\n  /** Event emitted when focus has changed within a tab group. */\n  @Output()\n  readonly focusChange: EventEmitter<TabChangeEvent> = new EventEmitter<TabChangeEvent>();\n\n  constructor(private readonly _changeDetectorRef: ChangeDetectorRef) {}\n\n  activatedTabs: TabComponent[] = [];\n\n  get activeTab() {\n    return this._tabs.length > 0 && this.selectedIndex !== null\n      ? this._tabs.toArray()[this.selectedIndex]\n      : null;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.hasOwnProperty('type')) {\n      this._typeChange.next();\n    }\n\n    if (changes.hasOwnProperty('size')) {\n      this._sizeChange.next();\n    }\n  }\n\n  /**\n   * After the content is checked, this component knows what tabs have been defined\n   * and what the selected index should be. This is where we can know exactly what position\n   * each tab should be in according to the new selected index.\n   */\n  ngAfterContentChecked(): void {\n    // Don't clamp the `indexToSelect` immediately in the setter because it can happen that\n    // the amount of tabs changes before the actual change detection runs.\n    const indexToSelect = (this._indexToSelect = this._clampTabIndex(\n      this._indexToSelect,\n    ));\n\n    // If there is a change in selected index, emit a change event. Should not trigger if\n    // the selected index has not yet been initialized.\n    if (this._selectedIndex !== indexToSelect && this._selectedIndex != null) {\n      this._changeActivatedTabs();\n      const tabChangeEvent = this._createChangeEvent(indexToSelect);\n      this.selectedTabChange.emit(tabChangeEvent);\n      // Emitting this value after change detection has run\n      // since the checked content may contain this variable'\n      Promise.resolve().then(() => {\n        this.selectedIndexChange.emit(indexToSelect);\n        this.tabChange.emit(this._tabs.get(indexToSelect).name);\n      });\n    }\n\n    // Setup the position for each tab and optionally setup an origin on the next selected tab.\n    this._tabs.forEach((tab: TabComponent, index: number) => {\n      tab.position = index - indexToSelect;\n      tab.tabContext.isActive = index === indexToSelect;\n      // If there is already a selected tab, then set up an origin for the next selected tab\n      // if it doesn't have one already.\n      if (this._selectedIndex != null && tab.position === 0 && !tab.origin) {\n        tab.origin = indexToSelect - this._selectedIndex;\n      }\n    });\n\n    if (this._selectedIndex !== indexToSelect) {\n      this._selectedIndex = indexToSelect;\n      this._changeDetectorRef.markForCheck();\n    }\n\n    if (this._previousHeaderAddon !== this._headerAddon) {\n      this._previousHeaderAddon = this._headerAddon;\n      this._changeDetectorRef.markForCheck();\n    }\n  }\n\n  ngAfterContentInit() {\n    if (this.tab) {\n      this._indexToSelect = this._findIndexByTab(this.tab);\n    }\n\n    this._changeActivatedTabs();\n    this._subscribeToTabLabels();\n    // Subscribe to changes in the amount of tabs, in order to be\n    // able to re-render the content as new tabs are added or removed.\n    this._tabsSubscription = this._tabs.changes.subscribe(() => {\n      const tabs = this._tabs.toArray();\n      if (this._lazy) {\n        this.activatedTabs = this.activatedTabs.filter(tab =>\n          tabs.includes(tab),\n        );\n      }\n      const indexToSelect = this._clampTabIndex(this._indexToSelect);\n      // Maintain the previously-selected tab if a new tab is added or removed and there is no\n      // explicit change that selects a different tab.\n      if (indexToSelect === this._selectedIndex) {\n        for (const [i, tab] of tabs.entries()) {\n          if (tab.tabContext.isActive) {\n            // Assign both to the `_indexToSelect` and `_selectedIndex` so we don't fire a changed\n            // event, otherwise the consumer may end up in an infinite loop in some edge cases like\n            // adding a tab within the `selectedIndexChange` event.\n            this._indexToSelect = this._selectedIndex = i;\n            break;\n          }\n        }\n      }\n      this._changeActivatedTabs();\n      this._subscribeToTabLabels();\n      this._changeDetectorRef.markForCheck();\n    });\n  }\n\n  ngOnDestroy() {\n    this._tabsSubscription.unsubscribe();\n    this._tabLabelSubscription.unsubscribe();\n\n    this._typeChange.complete();\n    this._sizeChange.complete();\n  }\n\n  /** Handle click events, setting new selected index if appropriate. */\n  _handleClick(tab: TabComponent, idx: number) {\n    if (!tab.disabled) {\n      this.selectedIndex = this._tabHeader.focusIndex = idx;\n    }\n  }\n\n  _focusChanged(index: number) {\n    this.focusChange.emit(this._createChangeEvent(index));\n  }\n\n  /** Re-aligns the ink bar to the selected tab element. */\n  realignActiveIndicator() {\n    if (this._tabHeader) {\n      this._tabHeader._alignActiveIndicatorToSelectedTab();\n    }\n  }\n\n  private _changeActivatedTabs() {\n    if (\n      !this._lazy ||\n      !this._tabs ||\n      this._indexToSelect < 0 ||\n      this._indexToSelect >= this._tabs.length\n    ) {\n      return;\n    }\n    const tab = this._tabs.find((_, index) => index === this._indexToSelect);\n    if (tab && !this.activatedTabs.includes(tab)) {\n      this.activatedTabs.push(tab);\n    }\n  }\n\n  /** Clamps the given index to the bounds of 0 and the tabs length. */\n  private _clampTabIndex(index: number | null): number {\n    // Note the `|| 0`, which ensures that values like NaN can't get through\n    // and which would otherwise throw the component into an infinite loop\n    // (since Math.max(NaN, 0) === NaN).\n    return Math.min(this._tabs.length - 1, Math.max(index || 0, 0));\n  }\n\n  private _findIndexByTab(name: string) {\n    return Math.max(\n      this._tabs.toArray().findIndex(tab => tab.name === name),\n      0,\n    );\n  }\n\n  private _createChangeEvent(index: number): TabChangeEvent {\n    const event = new TabChangeEvent();\n    event.index = index;\n    if (this._tabs?.length > 0) {\n      event.tab = this._tabs.toArray()[index];\n    }\n    return event;\n  }\n\n  /**\n   * Subscribes to changes in the tab labels. This is needed, because the @Input for the label is\n   * on the Tab component, whereas the data binding is inside the TabGroup. In order for the\n   * binding to be updated, we need to subscribe to changes in it and trigger change detection\n   * manually.\n   */\n  private _subscribeToTabLabels() {\n    if (this._tabLabelSubscription) {\n      this._tabLabelSubscription.unsubscribe();\n    }\n    this._tabLabelSubscription = merge(\n      ...this._tabs.map(tab => tab._stateChanges),\n      this._typeChange,\n      this._sizeChange,\n    ).subscribe(() => {\n      this.realignActiveIndicator();\n      this._changeDetectorRef.markForCheck();\n    });\n  }\n\n  /** Retrieves the tabindex for the tab. */\n  _getTabIndex(tab: TabComponent, idx: number): number | null {\n    if (tab.disabled) {\n      return null;\n    }\n    return this.selectedIndex === idx ? 0 : -1;\n  }\n}\n","<div [ngClass]=\"bem.block()\">\n  <aui-tab-header\n    [selectedIndex]=\"selectedIndex\"\n    [type]=\"type\"\n    [size]=\"size\"\n    (indexFocused)=\"_focusChanged($event)\"\n    (selectFocusedIndex)=\"selectedIndex = $event\"\n  >\n    <ng-container *ngIf=\"_tabTitle\">\n      <ng-container *auiTabTitle>\n        <ng-template [cdkPortalOutlet]=\"_tabTitle\"></ng-template>\n      </ng-container>\n    </ng-container>\n    <div\n      role=\"tab\"\n      *ngFor=\"let tab of _tabs; let i = index\"\n      auiTabLabelWrapper\n      cdkMonitorElementFocus\n      [class.isActive]=\"selectedIndex === i\"\n      [class.closeable]=\"tab.closeable && !tab.disabled\"\n      [disabled]=\"tab.disabled\"\n      (click)=\"_handleClick(tab, i)\"\n      [title]=\"tab.textLabel\"\n      [attr.tabIndex]=\"_getTabIndex(tab, i)\"\n      [attr.aria-posinset]=\"i + 1\"\n      [attr.aria-setsize]=\"_tabs.length\"\n      [attr.aria-label]=\"tab.textLabel\"\n    >\n      <div class=\"aui-tab-label__content\">\n        <!-- If there is a label template, use it. -->\n        <ng-template [ngIf]=\"tab.templateLabel\">\n          <ng-template [cdkPortalOutlet]=\"tab.templateLabel\"></ng-template>\n        </ng-template>\n        <!-- If there is not a label template, fall back to the text label. -->\n        <ng-template [ngIf]=\"!tab.templateLabel\">\n          {{ tab.textLabel }}\n        </ng-template>\n      </div>\n\n      <aui-icon\n        *ngIf=\"tab.closeable && !tab.disabled\"\n        class=\"aui-tab-label__close\"\n        icon=\"close_small\"\n        (click)=\"tab.close.emit(); $event.stopPropagation()\"\n      ></aui-icon>\n    </div>\n\n    <ng-container *ngIf=\"_headerAddon\">\n      <ng-container *auiTabHeaderAddon>\n        <ng-template [cdkPortalOutlet]=\"_headerAddon\"></ng-template>\n      </ng-container>\n    </ng-container>\n  </aui-tab-header>\n\n  <div [class]=\"bem.element('body-wrapper')\">\n    <ng-container *ngIf=\"lazy\">\n      <aui-tab-body\n        role=\"tabpanel\"\n        *ngFor=\"let tab of activatedTabs\"\n        [content]=\"tab.content\"\n        [hidden]=\"tab !== activeTab\"\n      ></aui-tab-body>\n    </ng-container>\n    <aui-tab-body\n      role=\"tabpanel\"\n      *ngIf=\"!lazy && activeTab\"\n      [content]=\"activeTab.content\"\n    ></aui-tab-body>\n  </div>\n</div>\n"]}
|
|
291
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-group.component.js","sourceRoot":"","sources":["../../../src/tabs/tab-group.component.ts","../../../src/tabs/tab-group.component.html"],"names":[],"mappings":"AAAA,0CAA0C;AAC1C,OAAO,EAGL,uBAAuB,EAEvB,SAAS,EACT,YAAY,EACZ,eAAe,EACf,YAAY,EACZ,KAAK,EAGL,MAAM,EAIN,SAAS,EACT,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AAEpD,OAAO,EAAO,QAAQ,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAEvD,OAAO,EACL,uBAAuB,EACvB,iBAAiB,GAClB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;;;;;;;;AAEhD,mEAAmE;AACnE,MAAM,OAAO,cAAc;CAK1B;AAWD,MAAM,OAAO,iBAAiB;IAyH5B,YAA6B,kBAAqC;QAArC,uBAAkB,GAAlB,kBAAkB,CAAmB;QAtHlE,QAAG,GAAQ,QAAQ,CAAC,eAAe,CAAC,CAAC;QAcrC,gFAAgF;QACxE,mBAAc,GAAkB,CAAC,CAAC;QAE1C,gDAAgD;QACxC,sBAAiB,GAAG,YAAY,CAAC,KAAK,CAAC;QAE/C,iDAAiD;QACzC,0BAAqB,GAAG,YAAY,CAAC,KAAK,CAAC;QAE3C,mBAAc,GAAkB,IAAI,CAAC;QACrC,SAAI,GAAW,IAAI,CAAC;QACpB,UAAK,GAAY,OAAO,CAAC,IAAI,CAAC;QAC9B,UAAK,GAAY,OAAO,CAAC,MAAM,CAAC;QAOxC,sCAAsC;QAC7B,gBAAW,GAAG,IAAI,OAAO,EAAQ,CAAC;QAE3C,sCAAsC;QAC7B,gBAAW,GAAG,IAAI,OAAO,EAAQ,CAAC;QAkE3C,0EAA0E;QAEjE,wBAAmB,GAAG,IAAI,YAAY,EAAU,CAAC;QAGjD,cAAS,GAAG,IAAI,YAAY,EAAU,CAAC;QAEhD,wDAAwD;QAE/C,sBAAiB,GAAG,IAAI,YAAY,CAAiB,IAAI,CAAC,CAAC;QAEpE,+DAA+D;QAEtD,gBAAW,GAAiC,IAAI,YAAY,EAAkB,CAAC;QAIxF,kBAAa,GAAmB,EAAE,CAAC;IAFkC,CAAC;IA/EtE,mCAAmC;IACnC,IACI,aAAa;QACf,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAED,IAAI,aAAa,CAAC,KAAoB;QACpC,IAAI,CAAC,cAAc,GAAG,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAChD,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED,IACI,GAAG;QACL,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,IAAI,GAAG,CAAC,KAAa;QACnB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;QAClB,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;SAClD;IACH,CAAC;IAED,IACI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,IAAI,IAAI,CAAC,IAAa;QACpB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IAKD,IACI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,IAAI,IAAI,CAAC,GAAG;QACV,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,KAAK,KAAK,GAAG,EAAE;YAC9B,OAAO;SACR;QACD,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;IACnB,CAAC;IAED,IACI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,IAAI,IAAI,CAAC,IAAa;QACpB,IAAI,IAAI,CAAC,KAAK,KAAK,IAAI,EAAE;YACvB,OAAO;SACR;QACD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,IAAI,EAAE;YACR,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC7B;aAAM;YACL,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC;SAC/B;IACH,CAAC;IAqBD,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,aAAa,KAAK,IAAI;YACzD,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC;YAC1C,CAAC,CAAC,IAAI,CAAC;IACX,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE;YAClC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;SACzB;QAED,IAAI,OAAO,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE;YAClC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;SACzB;IACH,CAAC;IAED;;;;OAIG;IACH,qBAAqB;QACnB,uFAAuF;QACvF,sEAAsE;QACtE,MAAM,aAAa,GAAG,CAAC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAC9D,IAAI,CAAC,cAAc,CACpB,CAAC,CAAC;QAEH,qFAAqF;QACrF,mDAAmD;QACnD,IAAI,IAAI,CAAC,cAAc,KAAK,aAAa,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,EAAE;YACxE,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,MAAM,cAAc,GAAG,IAAI,CAAC,kBAAkB,CAAC,aAAa,CAAC,CAAC;YAC9D,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAC5C,qDAAqD;YACrD,uDAAuD;YACvD,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;gBAC1B,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;gBAC7C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,CAAC;YAC1D,CAAC,CAAC,CAAC;SACJ;QAED,2FAA2F;QAC3F,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,GAAiB,EAAE,KAAa,EAAE,EAAE;YACtD,GAAG,CAAC,QAAQ,GAAG,KAAK,GAAG,aAAa,CAAC;YACrC,GAAG,CAAC,UAAU,CAAC,QAAQ,GAAG,KAAK,KAAK,aAAa,CAAC;YAClD,sFAAsF;YACtF,kCAAkC;YAClC,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,IAAI,GAAG,CAAC,QAAQ,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE;gBACpE,GAAG,CAAC,MAAM,GAAG,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC;aAClD;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,cAAc,KAAK,aAAa,EAAE;YACzC,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC;YACpC,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;SACxC;QAED,IAAI,IAAI,CAAC,oBAAoB,KAAK,IAAI,CAAC,YAAY,EAAE;YACnD,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,YAAY,CAAC;YAC9C,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;SACxC;IACH,CAAC;IAED,kBAAkB;QAChB,IAAI,IAAI,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SACtD;QAED,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,6DAA6D;QAC7D,kEAAkE;QAClE,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE;YACzD,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;YAClC,IAAI,IAAI,CAAC,KAAK,EAAE;gBACd,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CACnD,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CACnB,CAAC;aACH;YACD,MAAM,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAC/D,wFAAwF;YACxF,gDAAgD;YAChD,IAAI,aAAa,KAAK,IAAI,CAAC,cAAc,EAAE;gBACzC,KAAK,MAAM,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE;oBACrC,IAAI,GAAG,CAAC,UAAU,CAAC,QAAQ,EAAE;wBAC3B,sFAAsF;wBACtF,uFAAuF;wBACvF,uDAAuD;wBACvD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;wBAC9C,MAAM;qBACP;iBACF;aACF;YACD,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC7B,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;QACzC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW;QACT,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC;QACrC,IAAI,CAAC,qBAAqB,CAAC,WAAW,EAAE,CAAC;QAEzC,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;QAC5B,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;IAC9B,CAAC;IAED,sEAAsE;IACtE,YAAY,CAAC,GAAiB,EAAE,GAAW;QACzC,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,UAAU,GAAG,GAAG,CAAC;SACvD;IACH,CAAC;IAED,aAAa,CAAC,KAAa;QACzB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC;IACxD,CAAC;IAED,yDAAyD;IACzD,sBAAsB;QACpB,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,UAAU,CAAC,kCAAkC,EAAE,CAAC;SACtD;IACH,CAAC;IAEO,oBAAoB;QAC1B,IACE,CAAC,IAAI,CAAC,KAAK;YACX,CAAC,IAAI,CAAC,KAAK;YACX,IAAI,CAAC,cAAc,GAAG,CAAC;YACvB,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,EACxC;YACA,OAAO;SACR;QACD,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,KAAK,IAAI,CAAC,cAAc,CAAC,CAAC;QACzE,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;YAC5C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SAC9B;IACH,CAAC;IAED,qEAAqE;IAC7D,cAAc,CAAC,KAAoB;QACzC,wEAAwE;QACxE,sEAAsE;QACtE,oCAAoC;QACpC,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAClE,CAAC;IAEO,eAAe,CAAC,IAAY;QAClC,OAAO,IAAI,CAAC,GAAG,CACb,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,IAAI,CAAC,EACxD,CAAC,CACF,CAAC;IACJ,CAAC;IAEO,kBAAkB,CAAC,KAAa;QACtC,MAAM,KAAK,GAAG,IAAI,cAAc,EAAE,CAAC;QACnC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;QACpB,IAAI,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,CAAC,EAAE;YAC1B,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;SACzC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;;OAKG;IACK,qBAAqB;QAC3B,IAAI,IAAI,CAAC,qBAAqB,EAAE;YAC9B,IAAI,CAAC,qBAAqB,CAAC,WAAW,EAAE,CAAC;SAC1C;QACD,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAChC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,aAAa,CAAC,EAC3C,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,WAAW,CACjB,CAAC,SAAS,CAAC,GAAG,EAAE;YACf,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAC9B,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;QACzC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,0CAA0C;IAC1C,YAAY,CAAC,GAAiB,EAAE,GAAW;QACzC,IAAI,GAAG,CAAC,QAAQ,EAAE;YAChB,OAAO,IAAI,CAAC;SACb;QACD,OAAO,IAAI,CAAC,aAAa,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7C,CAAC;;8GA5TU,iBAAiB;kGAAjB,iBAAiB,sWAQd,uBAAuB,4EAMvB,iBAAiB,2DATd,YAAY,yEAMlB,kBAAkB,gGC5D/B,+xEAsEA;2FDrBa,iBAAiB;kBAT7B,SAAS;+BACE,eAAe,YACf,aAAa,iBAGR,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,uBAC1B,KAAK;wGAQ1B,KAAK;sBADJ,eAAe;uBAAC,YAAY;gBAI7B,YAAY;sBADX,YAAY;uBAAC,uBAAuB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAIxD,UAAU;sBADT,SAAS;uBAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAIhD,SAAS;sBADR,YAAY;uBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBA8B9C,aAAa;sBADhB,KAAK;gBAWF,GAAG;sBADN,KAAK;gBAaF,IAAI;sBADP,KAAK;gBAUN,KAAK;sBADJ,KAAK;gBAIF,IAAI;sBADP,KAAK;gBAaF,IAAI;sBADP,KAAK;gBAmBG,mBAAmB;sBAD3B,MAAM;gBAIE,SAAS;sBADjB,MAAM;gBAKE,iBAAiB;sBADzB,MAAM;gBAKE,WAAW;sBADnB,MAAM","sourcesContent":["/* eslint-disable no-prototype-builtins */\nimport {\n  AfterContentChecked,\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Subject, Subscription, merge } from 'rxjs';\n\nimport { Bem, buildBem, coerceNumber } from '../utils';\n\nimport {\n  TabHeaderAddonDirective,\n  TabTitleDirective,\n} from './tab-body.component';\nimport { TabHeaderComponent } from './tab-header.component';\nimport { TabComponent } from './tab.component';\nimport { TabSize, TabType } from './tabs.types';\n\n/** A simple change event emitted on focus or selection changes. */\nexport class TabChangeEvent {\n  /** Index of the currently-selected tab. */\n  index: number;\n  /** Reference to the currently-selected tab. */\n  tab: TabComponent;\n}\n\n@Component({\n  selector: 'aui-tab-group',\n  exportAs: 'auiTabGroup',\n  templateUrl: './tab-group.component.html',\n  styleUrls: ['./tab-group.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n})\nexport class TabGroupComponent\n  implements OnChanges, AfterContentChecked, AfterContentInit, OnDestroy\n{\n  bem: Bem = buildBem('aui-tab-group');\n\n  @ContentChildren(TabComponent)\n  _tabs: QueryList<TabComponent>;\n\n  @ContentChild(TabHeaderAddonDirective, { static: false })\n  _headerAddon: TabHeaderAddonDirective;\n\n  @ViewChild(TabHeaderComponent, { static: false })\n  _tabHeader: TabHeaderComponent;\n\n  @ContentChild(TabTitleDirective, { static: false })\n  _tabTitle: TabTitleDirective;\n\n  /** The tab index that should be selected after the content has been checked. */\n  private _indexToSelect: number | null = 0;\n\n  /** Subscription to tabs being added/removed. */\n  private _tabsSubscription = Subscription.EMPTY;\n\n  /** Subscription to changes in the tab labels. */\n  private _tabLabelSubscription = Subscription.EMPTY;\n\n  private _selectedIndex: number | null = null;\n  private _tab: string = null;\n  private _type: TabType = TabType.Line;\n  private _size: TabSize = TabSize.Medium;\n\n  /** true lazy mode for template ref children */\n  private _lazy: boolean;\n\n  private _previousHeaderAddon: TabHeaderAddonDirective;\n\n  /** Emits whenever the type changes */\n  readonly _typeChange = new Subject<void>();\n\n  /** Emits whenever the size changes */\n  readonly _sizeChange = new Subject<void>();\n\n  /** The index of the active tab. */\n  @Input()\n  get selectedIndex(): number | null {\n    return this._selectedIndex;\n  }\n\n  set selectedIndex(value: number | null) {\n    this._indexToSelect = coerceNumber(value, null);\n    this._changeActivatedTabs();\n  }\n\n  @Input()\n  get tab(): string {\n    return this._tab;\n  }\n\n  set tab(value: string) {\n    this._tab = value;\n    if (this._tabs) {\n      this.selectedIndex = this._findIndexByTab(value);\n    }\n  }\n\n  @Input()\n  get type() {\n    return this._type;\n  }\n\n  set type(type: TabType) {\n    this._type = type;\n  }\n\n  @Input()\n  title: string | TemplateRef<unknown>;\n\n  @Input()\n  get size() {\n    return this._size;\n  }\n\n  set size(val) {\n    if (!val || this._size === val) {\n      return;\n    }\n    this._size = val;\n  }\n\n  @Input()\n  get lazy() {\n    return this._lazy;\n  }\n\n  set lazy(lazy: boolean) {\n    if (this._lazy === lazy) {\n      return;\n    }\n    this._lazy = lazy;\n    if (lazy) {\n      this._changeActivatedTabs();\n    } else {\n      this.activatedTabs.length = 0;\n    }\n  }\n\n  /** Output to enable support for two-way binding on `[(selectedIndex)]` */\n  @Output()\n  readonly selectedIndexChange = new EventEmitter<number>();\n\n  @Output()\n  readonly tabChange = new EventEmitter<string>();\n\n  /** Event emitted when the tab selection has changed. */\n  @Output()\n  readonly selectedTabChange = new EventEmitter<TabChangeEvent>(true);\n\n  /** Event emitted when focus has changed within a tab group. */\n  @Output()\n  readonly focusChange: EventEmitter<TabChangeEvent> = new EventEmitter<TabChangeEvent>();\n\n  constructor(private readonly _changeDetectorRef: ChangeDetectorRef) {}\n\n  activatedTabs: TabComponent[] = [];\n\n  get activeTab() {\n    return this._tabs.length > 0 && this.selectedIndex !== null\n      ? this._tabs.toArray()[this.selectedIndex]\n      : null;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.hasOwnProperty('type')) {\n      this._typeChange.next();\n    }\n\n    if (changes.hasOwnProperty('size')) {\n      this._sizeChange.next();\n    }\n  }\n\n  /**\n   * After the content is checked, this component knows what tabs have been defined\n   * and what the selected index should be. This is where we can know exactly what position\n   * each tab should be in according to the new selected index.\n   */\n  ngAfterContentChecked(): void {\n    // Don't clamp the `indexToSelect` immediately in the setter because it can happen that\n    // the amount of tabs changes before the actual change detection runs.\n    const indexToSelect = (this._indexToSelect = this._clampTabIndex(\n      this._indexToSelect,\n    ));\n\n    // If there is a change in selected index, emit a change event. Should not trigger if\n    // the selected index has not yet been initialized.\n    if (this._selectedIndex !== indexToSelect && this._selectedIndex != null) {\n      this._changeActivatedTabs();\n      const tabChangeEvent = this._createChangeEvent(indexToSelect);\n      this.selectedTabChange.emit(tabChangeEvent);\n      // Emitting this value after change detection has run\n      // since the checked content may contain this variable'\n      Promise.resolve().then(() => {\n        this.selectedIndexChange.emit(indexToSelect);\n        this.tabChange.emit(this._tabs.get(indexToSelect).name);\n      });\n    }\n\n    // Setup the position for each tab and optionally setup an origin on the next selected tab.\n    this._tabs.forEach((tab: TabComponent, index: number) => {\n      tab.position = index - indexToSelect;\n      tab.tabContext.isActive = index === indexToSelect;\n      // If there is already a selected tab, then set up an origin for the next selected tab\n      // if it doesn't have one already.\n      if (this._selectedIndex != null && tab.position === 0 && !tab.origin) {\n        tab.origin = indexToSelect - this._selectedIndex;\n      }\n    });\n\n    if (this._selectedIndex !== indexToSelect) {\n      this._selectedIndex = indexToSelect;\n      this._changeDetectorRef.markForCheck();\n    }\n\n    if (this._previousHeaderAddon !== this._headerAddon) {\n      this._previousHeaderAddon = this._headerAddon;\n      this._changeDetectorRef.markForCheck();\n    }\n  }\n\n  ngAfterContentInit() {\n    if (this.tab) {\n      this._indexToSelect = this._findIndexByTab(this.tab);\n    }\n\n    this._changeActivatedTabs();\n    this._subscribeToTabLabels();\n    // Subscribe to changes in the amount of tabs, in order to be\n    // able to re-render the content as new tabs are added or removed.\n    this._tabsSubscription = this._tabs.changes.subscribe(() => {\n      const tabs = this._tabs.toArray();\n      if (this._lazy) {\n        this.activatedTabs = this.activatedTabs.filter(tab =>\n          tabs.includes(tab),\n        );\n      }\n      const indexToSelect = this._clampTabIndex(this._indexToSelect);\n      // Maintain the previously-selected tab if a new tab is added or removed and there is no\n      // explicit change that selects a different tab.\n      if (indexToSelect === this._selectedIndex) {\n        for (const [i, tab] of tabs.entries()) {\n          if (tab.tabContext.isActive) {\n            // Assign both to the `_indexToSelect` and `_selectedIndex` so we don't fire a changed\n            // event, otherwise the consumer may end up in an infinite loop in some edge cases like\n            // adding a tab within the `selectedIndexChange` event.\n            this._indexToSelect = this._selectedIndex = i;\n            break;\n          }\n        }\n      }\n      this._changeActivatedTabs();\n      this._subscribeToTabLabels();\n      this._changeDetectorRef.markForCheck();\n    });\n  }\n\n  ngOnDestroy() {\n    this._tabsSubscription.unsubscribe();\n    this._tabLabelSubscription.unsubscribe();\n\n    this._typeChange.complete();\n    this._sizeChange.complete();\n  }\n\n  /** Handle click events, setting new selected index if appropriate. */\n  _handleClick(tab: TabComponent, idx: number) {\n    if (!tab.disabled) {\n      this.selectedIndex = this._tabHeader.focusIndex = idx;\n    }\n  }\n\n  _focusChanged(index: number) {\n    this.focusChange.emit(this._createChangeEvent(index));\n  }\n\n  /** Re-aligns the ink bar to the selected tab element. */\n  realignActiveIndicator() {\n    if (this._tabHeader) {\n      this._tabHeader._alignActiveIndicatorToSelectedTab();\n    }\n  }\n\n  private _changeActivatedTabs() {\n    if (\n      !this._lazy ||\n      !this._tabs ||\n      this._indexToSelect < 0 ||\n      this._indexToSelect >= this._tabs.length\n    ) {\n      return;\n    }\n    const tab = this._tabs.find((_, index) => index === this._indexToSelect);\n    if (tab && !this.activatedTabs.includes(tab)) {\n      this.activatedTabs.push(tab);\n    }\n  }\n\n  /** Clamps the given index to the bounds of 0 and the tabs length. */\n  private _clampTabIndex(index: number | null): number {\n    // Note the `|| 0`, which ensures that values like NaN can't get through\n    // and which would otherwise throw the component into an infinite loop\n    // (since Math.max(NaN, 0) === NaN).\n    return Math.min(this._tabs.length - 1, Math.max(index || 0, 0));\n  }\n\n  private _findIndexByTab(name: string) {\n    return Math.max(\n      this._tabs.toArray().findIndex(tab => tab.name === name),\n      0,\n    );\n  }\n\n  private _createChangeEvent(index: number): TabChangeEvent {\n    const event = new TabChangeEvent();\n    event.index = index;\n    if (this._tabs?.length > 0) {\n      event.tab = this._tabs.toArray()[index];\n    }\n    return event;\n  }\n\n  /**\n   * Subscribes to changes in the tab labels. This is needed, because the @Input for the label is\n   * on the Tab component, whereas the data binding is inside the TabGroup. In order for the\n   * binding to be updated, we need to subscribe to changes in it and trigger change detection\n   * manually.\n   */\n  private _subscribeToTabLabels() {\n    if (this._tabLabelSubscription) {\n      this._tabLabelSubscription.unsubscribe();\n    }\n    this._tabLabelSubscription = merge(\n      ...this._tabs.map(tab => tab._stateChanges),\n      this._typeChange,\n      this._sizeChange,\n    ).subscribe(() => {\n      this.realignActiveIndicator();\n      this._changeDetectorRef.markForCheck();\n    });\n  }\n\n  /** Retrieves the tabindex for the tab. */\n  _getTabIndex(tab: TabComponent, idx: number): number | null {\n    if (tab.disabled) {\n      return null;\n    }\n    return this.selectedIndex === idx ? 0 : -1;\n  }\n}\n","<div [ngClass]=\"bem.block()\">\n  <aui-tab-header\n    [selectedIndex]=\"selectedIndex\"\n    [type]=\"type\"\n    [size]=\"size\"\n    (indexFocused)=\"_focusChanged($event)\"\n    (selectFocusedIndex)=\"selectedIndex = $event\"\n  >\n    <ng-container *ngIf=\"_tabTitle\">\n      <ng-container *auiTabTitle>\n        <ng-template [cdkPortalOutlet]=\"_tabTitle\"></ng-template>\n      </ng-container>\n    </ng-container>\n    <div\n      role=\"tab\"\n      *ngFor=\"let tab of _tabs; let i = index\"\n      auiTabLabelWrapper\n      cdkMonitorElementFocus\n      [class.isActive]=\"selectedIndex === i\"\n      [class.closeable]=\"tab.closeable && !tab.disabled\"\n      [disabled]=\"tab.disabled\"\n      (click)=\"_handleClick(tab, i)\"\n      [title]=\"tab.textLabel\"\n      [attr.tabIndex]=\"_getTabIndex(tab, i)\"\n      [attr.aria-posinset]=\"i + 1\"\n      [attr.aria-setsize]=\"_tabs.length\"\n      [attr.aria-label]=\"tab.textLabel\"\n    >\n      <div class=\"aui-tab-label__content\">\n        <!-- If there is a label template, use it. -->\n        <ng-template [ngIf]=\"tab.templateLabel\">\n          <ng-template [cdkPortalOutlet]=\"tab.templateLabel\"></ng-template>\n        </ng-template>\n        <!-- If there is not a label template, fall back to the text label. -->\n        <ng-template [ngIf]=\"!tab.templateLabel\">\n          {{ tab.textLabel }}\n        </ng-template>\n      </div>\n\n      <aui-icon\n        *ngIf=\"tab.closeable && !tab.disabled\"\n        class=\"aui-tab-label__close\"\n        icon=\"close_small\"\n        (click)=\"tab.close.emit(); $event.stopPropagation()\"\n      ></aui-icon>\n    </div>\n\n    <ng-container *ngIf=\"_headerAddon\">\n      <ng-container *auiTabHeaderAddon>\n        <ng-template [cdkPortalOutlet]=\"_headerAddon\"></ng-template>\n      </ng-container>\n    </ng-container>\n  </aui-tab-header>\n\n  <div [class]=\"bem.element('body-wrapper')\">\n    <ng-container *ngIf=\"lazy\">\n      <aui-tab-body\n        role=\"tabpanel\"\n        *ngFor=\"let tab of activatedTabs\"\n        [content]=\"tab.content\"\n        [hidden]=\"tab !== activeTab\"\n      ></aui-tab-body>\n    </ng-container>\n    <aui-tab-body\n      role=\"tabpanel\"\n      *ngIf=\"!lazy && activeTab\"\n      [content]=\"activeTab.content\"\n    ></aui-tab-body>\n  </div>\n</div>\n"]}
|
|
@@ -10,6 +10,11 @@ export class TabHeaderActiveIndicatorComponent {
|
|
|
10
10
|
this.type = TabType.Line;
|
|
11
11
|
this.bem = buildBem('aui-tab-header-active-indicator');
|
|
12
12
|
}
|
|
13
|
+
/**
|
|
14
|
+
* Calculates the styles from the provided element in order to align the indicator to that element.
|
|
15
|
+
* Shows the indicator if previously set as hidden.
|
|
16
|
+
* @param element
|
|
17
|
+
*/
|
|
13
18
|
alignToElement(element) {
|
|
14
19
|
if (typeof requestAnimationFrame !== 'undefined') {
|
|
15
20
|
this._ngZone.runOutsideAngular(() => {
|
|
@@ -20,6 +25,10 @@ export class TabHeaderActiveIndicatorComponent {
|
|
|
20
25
|
this._setStyles(element);
|
|
21
26
|
}
|
|
22
27
|
}
|
|
28
|
+
/**
|
|
29
|
+
* Sets the proper styles to the element.
|
|
30
|
+
* @param element
|
|
31
|
+
*/
|
|
23
32
|
_setStyles(element) {
|
|
24
33
|
const positions = this._getElementPosition(element);
|
|
25
34
|
const nativeEl = this._elementRef.nativeElement;
|
|
@@ -41,4 +50,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
41
50
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }]; }, propDecorators: { type: [{
|
|
42
51
|
type: Input
|
|
43
52
|
}] } });
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLWhlYWRlci1hY3RpdmUtaW5kaWNhdG9yLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90YWJzL3RhYi1oZWFkZXItYWN0aXZlLWluZGljYXRvci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi9zcmMvdGFicy90YWItaGVhZGVyLWFjdGl2ZS1pbmRpY2F0b3IuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBRVQsS0FBSyxFQUVMLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQU8sUUFBUSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxjQUFjLENBQUM7OztBQVN2QyxNQUFNLE9BQU8saUNBQWlDO0lBTTVDLFlBQ21CLFdBQW9DLEVBQ3BDLE9BQWU7UUFEZixnQkFBVyxHQUFYLFdBQVcsQ0FBeUI7UUFDcEMsWUFBTyxHQUFQLE9BQU8sQ0FBUTtRQU5sQyxTQUFJLEdBQVksT0FBTyxDQUFDLElBQUksQ0FBQztRQUU3QixRQUFHLEdBQVEsUUFBUSxDQUFDLGlDQUFpQyxDQUFDLENBQUM7SUFLcEQsQ0FBQztJQUVKOzs7O09BSUc7SUFDSCxjQUFjLENBQUMsT0FBb0I7UUFDakMsSUFBSSxPQUFPLHFCQUFxQixLQUFLLFdBQVcsRUFBRTtZQUNoRCxJQUFJLENBQUMsT0FBTyxDQUFDLGlCQUFpQixDQUFDLEdBQUcsRUFBRTtnQkFDbEMscUJBQXFCLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1lBQ3hELENBQUMsQ0FBQyxDQUFDO1NBQ0o7YUFBTTtZQUNMLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUM7U0FDMUI7SUFDSCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ssVUFBVSxDQUFDLE9BQW9CO1FBQ3JDLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNwRCxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQztRQUNoRCxRQUFRLENBQUMsS0FBSyxDQUFDLElBQUksR0FBRyxTQUFTLENBQUMsSUFBSSxDQUFDO1FBQ3JDLFFBQVEsQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLFNBQVMsQ0FBQyxLQUFLLENBQUM7SUFDekMsQ0FBQztJQUVPLG1CQUFtQixDQUFDLE9BQW9CO1FBQzlDLE9BQU87WUFDTCxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxVQUFVLElBQUksQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxHQUFHO1lBQ3RELEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLFdBQVcsSUFBSSxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLEdBQUc7U0FDekQsQ0FBQztJQUNKLENBQUM7OzhIQTFDVSxpQ0FBaUM7a0hBQWpDLGlDQUFpQyxpR0NwQjlDLDZDQUNBOzJGRG1CYSxpQ0FBaUM7a0JBUDdDLFNBQVM7K0JBQ0UsaUNBQWlDLGlCQUU1QixpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNLHVCQUMxQixLQUFLO3NIQUkxQixJQUFJO3NCQURILEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFbGVtZW50UmVmLFxuICBJbnB1dCxcbiAgTmdab25lLFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEJlbSwgYnVpbGRCZW0gfSBmcm9tICcuLi91dGlscyc7XG5cbmltcG9ydCB7IFRhYlR5cGUgfSBmcm9tICcuL3RhYnMudHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhdWktdGFiLWhlYWRlci1hY3RpdmUtaW5kaWNhdG9yJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3RhYi1oZWFkZXItYWN0aXZlLWluZGljYXRvci5jb21wb25lbnQuaHRtbCcsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBwcmVzZXJ2ZVdoaXRlc3BhY2VzOiBmYWxzZSxcbn0pXG5leHBvcnQgY2xhc3MgVGFiSGVhZGVyQWN0aXZlSW5kaWNhdG9yQ29tcG9uZW50IHtcbiAgQElucHV0KClcbiAgdHlwZTogVGFiVHlwZSA9IFRhYlR5cGUuTGluZTtcblxuICBiZW06IEJlbSA9IGJ1aWxkQmVtKCdhdWktdGFiLWhlYWRlci1hY3RpdmUtaW5kaWNhdG9yJyk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSByZWFkb25seSBfZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4sXG4gICAgcHJpdmF0ZSByZWFkb25seSBfbmdab25lOiBOZ1pvbmUsXG4gICkge31cblxuICAvKipcbiAgICogQ2FsY3VsYXRlcyB0aGUgc3R5bGVzIGZyb20gdGhlIHByb3ZpZGVkIGVsZW1lbnQgaW4gb3JkZXIgdG8gYWxpZ24gdGhlIGluZGljYXRvciB0byB0aGF0IGVsZW1lbnQuXG4gICAqIFNob3dzIHRoZSBpbmRpY2F0b3IgaWYgcHJldmlvdXNseSBzZXQgYXMgaGlkZGVuLlxuICAgKiBAcGFyYW0gZWxlbWVudFxuICAgKi9cbiAgYWxpZ25Ub0VsZW1lbnQoZWxlbWVudDogSFRNTEVsZW1lbnQpIHtcbiAgICBpZiAodHlwZW9mIHJlcXVlc3RBbmltYXRpb25GcmFtZSAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgIHRoaXMuX25nWm9uZS5ydW5PdXRzaWRlQW5ndWxhcigoKSA9PiB7XG4gICAgICAgIHJlcXVlc3RBbmltYXRpb25GcmFtZSgoKSA9PiB0aGlzLl9zZXRTdHlsZXMoZWxlbWVudCkpO1xuICAgICAgfSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX3NldFN0eWxlcyhlbGVtZW50KTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogU2V0cyB0aGUgcHJvcGVyIHN0eWxlcyB0byB0aGUgZWxlbWVudC5cbiAgICogQHBhcmFtIGVsZW1lbnRcbiAgICovXG4gIHByaXZhdGUgX3NldFN0eWxlcyhlbGVtZW50OiBIVE1MRWxlbWVudCkge1xuICAgIGNvbnN0IHBvc2l0aW9ucyA9IHRoaXMuX2dldEVsZW1lbnRQb3NpdGlvbihlbGVtZW50KTtcbiAgICBjb25zdCBuYXRpdmVFbCA9IHRoaXMuX2VsZW1lbnRSZWYubmF0aXZlRWxlbWVudDtcbiAgICBuYXRpdmVFbC5zdHlsZS5sZWZ0ID0gcG9zaXRpb25zLmxlZnQ7XG4gICAgbmF0aXZlRWwuc3R5bGUud2lkdGggPSBwb3NpdGlvbnMud2lkdGg7XG4gIH1cblxuICBwcml2YXRlIF9nZXRFbGVtZW50UG9zaXRpb24oZWxlbWVudDogSFRNTEVsZW1lbnQpIHtcbiAgICByZXR1cm4ge1xuICAgICAgbGVmdDogZWxlbWVudCA/IChlbGVtZW50Lm9mZnNldExlZnQgfHwgMCkgKyAncHgnIDogJzAnLFxuICAgICAgd2lkdGg6IGVsZW1lbnQgPyAoZWxlbWVudC5vZmZzZXRXaWR0aCB8fCAwKSArICdweCcgOiAnMCcsXG4gICAgfTtcbiAgfVxufVxuIiwiPGRpdiBbbmdDbGFzc109XCJiZW0uYmxvY2sodHlwZSlcIj48L2Rpdj5cbiJdfQ==
|