cps-ui-kit 0.163.0 → 0.164.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/cps-tab-group/cps-tab-group.component.mjs +21 -15
- package/fesm2015/cps-ui-kit.mjs +20 -14
- package/fesm2015/cps-ui-kit.mjs.map +1 -1
- package/fesm2020/cps-ui-kit.mjs +20 -14
- package/fesm2020/cps-ui-kit.mjs.map +1 -1
- package/lib/components/cps-tab-group/cps-tab-group.component.d.ts +1 -1
- package/package.json +1 -1
|
@@ -90,7 +90,7 @@ export class CpsTabGroupComponent {
|
|
|
90
90
|
}
|
|
91
91
|
}
|
|
92
92
|
ngAfterContentInit() {
|
|
93
|
-
this.selectTab();
|
|
93
|
+
this.selectTab(true);
|
|
94
94
|
}
|
|
95
95
|
ngAfterViewInit() {
|
|
96
96
|
this._updateNavBtnsState();
|
|
@@ -110,7 +110,7 @@ export class CpsTabGroupComponent {
|
|
|
110
110
|
this.selectedIndex = index;
|
|
111
111
|
this.selectTab();
|
|
112
112
|
}
|
|
113
|
-
selectTab() {
|
|
113
|
+
selectTab(silent = false) {
|
|
114
114
|
const _tabs = this.tabs.toArray();
|
|
115
115
|
const currentSelectedTab = _tabs && _tabs[this._previousTabIndex];
|
|
116
116
|
currentSelectedTab && (currentSelectedTab.active = false);
|
|
@@ -119,28 +119,34 @@ export class CpsTabGroupComponent {
|
|
|
119
119
|
if (this._currentTabIndex === this._previousTabIndex) {
|
|
120
120
|
return;
|
|
121
121
|
}
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
122
|
+
if (!silent) {
|
|
123
|
+
this.beforeTabChanged.emit({
|
|
124
|
+
previousIndex: this._previousTabIndex,
|
|
125
|
+
newIndex: this._currentTabIndex
|
|
126
|
+
});
|
|
127
|
+
}
|
|
126
128
|
if (this.animationType === 'slide') {
|
|
127
129
|
this.animationState =
|
|
128
130
|
this._currentTabIndex < this._previousTabIndex
|
|
129
131
|
? 'slideLeft'
|
|
130
132
|
: 'slideRight';
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
133
|
+
if (!silent) {
|
|
134
|
+
this.afterTabChanged.emit({
|
|
135
|
+
previousIndex: this._previousTabIndex,
|
|
136
|
+
newIndex: this._currentTabIndex
|
|
137
|
+
});
|
|
138
|
+
}
|
|
135
139
|
}
|
|
136
140
|
else if (this.animationType === 'fade') {
|
|
137
141
|
this.animationState = 'fadeOut';
|
|
138
142
|
setTimeout(() => {
|
|
139
143
|
this.animationState = 'fadeIn';
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
+
if (!silent) {
|
|
145
|
+
this.afterTabChanged.emit({
|
|
146
|
+
previousIndex: this._previousTabIndex,
|
|
147
|
+
newIndex: this._currentTabIndex
|
|
148
|
+
});
|
|
149
|
+
}
|
|
144
150
|
}, 100);
|
|
145
151
|
}
|
|
146
152
|
}
|
|
@@ -276,4 +282,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
276
282
|
type: ContentChildren,
|
|
277
283
|
args: [CpsTabComponent]
|
|
278
284
|
}] } });
|
|
279
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-tab-group.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-tab-group/cps-tab-group.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-tab-group/cps-tab-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  animate,\n  state,\n  style,\n  transition,\n  trigger\n} from '@angular/animations';\nimport { CommonModule } from '@angular/common';\nimport {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { CpsIconComponent } from '../cps-icon/cps-icon.component';\nimport { CpsTabComponent } from './cps-tab/cps-tab.component';\nimport { CpsTooltipDirective } from '../../directives/cps-tooltip.directive';\nimport { getCSSColor } from '../../utils/colors-utils';\nimport {\n  Subscription,\n  debounceTime,\n  distinctUntilChanged,\n  fromEvent\n} from 'rxjs';\n\nexport interface TabChangeEvent {\n  previousIndex: number;\n  newIndex: number;\n}\n\nexport type CpsTabsAnimationType = 'slide' | 'fade';\nexport type CpsTabsAlignmentType = 'left' | 'center' | 'right';\n\n/**\n * CpsTabGroupComponent is a navigation component that displays items as tab headers.\n * @group Components\n */\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    CpsIconComponent,\n    CpsTabComponent,\n    CpsTooltipDirective\n  ],\n  selector: 'cps-tab-group',\n  templateUrl: './cps-tab-group.component.html',\n  styleUrls: ['./cps-tab-group.component.scss'],\n  animations: [\n    trigger('slideInOut', [\n      state('slideLeft', style({ transform: 'translateX(0)' })),\n      state('slideRight', style({ transform: 'translateX(0)' })),\n      transition('* => slideLeft', [\n        style({ transform: 'translateX(-100%)' }),\n        animate('200ms ease-in')\n      ]),\n      transition('* => slideRight', [\n        style({ transform: 'translateX(100%)' }),\n        animate('200ms ease-in')\n      ])\n    ]),\n    trigger('fadeInOut', [\n      state('fadeIn', style({ opacity: 1 })),\n      state('fadeOut', style({ opacity: 0 })),\n      transition('fadeOut => fadeIn', [\n        style({ opacity: 0 }),\n        animate('100ms ease-in')\n      ]),\n      transition('fadeIn => fadeOut', [\n        animate('0ms ease-out', style({ opacity: 0 }))\n      ])\n    ])\n  ]\n})\nexport class CpsTabGroupComponent\n  implements OnInit, AfterContentInit, AfterViewInit, OnChanges, OnDestroy\n{\n  /**\n   * Index of the selected tab.\n   * @group Props\n   */\n  @Input() set selectedIndex(value: number) {\n    this._previousTabIndex = this._currentTabIndex;\n    this._currentTabIndex = value;\n  }\n\n  get selectedIndex(): number {\n    return this._currentTabIndex;\n  }\n\n  /**\n   * Determines whether to apply an alternative 'subtabs' styling.\n   * @group Props\n   */\n  @Input() isSubTabs = false;\n\n  /**\n   * Horizontal alignment of tabs.\n   * @group Props\n   */\n  @Input() alignment: CpsTabsAlignmentType = 'left';\n\n  /**\n   * Determines whether to stretch tabs to fill the available horizontal space.\n   * @group Props\n   */\n  @Input() stretched = false;\n\n  /**\n   * Transition options of how content appears, it can be \"slide\" or \"fade\".\n   * @group Props\n   */\n  @Input() animationType: CpsTabsAnimationType = 'slide';\n\n  /**\n   * Background color of navigation buttons.\n   * @group Props\n   */\n  @Input() navButtonsBackground = 'inherit';\n\n  /**\n   * Background color of tabs.\n   * @group Props\n   */\n  @Input() tabsBackground = 'inherit';\n\n  /**\n   * Callback to invoke before tab change.\n   * @param {TabChangeEvent} any - tab change event.\n   * @group Emits\n   */\n  @Output() beforeTabChanged = new EventEmitter<TabChangeEvent>();\n\n  /**\n   * Callback to invoke after tab change.\n   * @param {TabChangeEvent} any - tab change event.\n   * @group Emits\n   */\n  @Output() afterTabChanged = new EventEmitter<TabChangeEvent>();\n\n  @ViewChild('tabsList') tabsList!: ElementRef;\n  @ViewChild('backBtn') backBtn?: ElementRef;\n  @ViewChild('forwardBtn') forwardBtn?: ElementRef;\n\n  @ContentChildren(CpsTabComponent) tabs!: QueryList<CpsTabComponent>;\n\n  backBtnVisible = false;\n  forwardBtnVisible = false;\n  animationState: 'slideLeft' | 'slideRight' | 'fadeIn' | 'fadeOut' = 'fadeIn';\n\n  windowResize$: Subscription = Subscription.EMPTY;\n  listScroll$: Subscription = Subscription.EMPTY;\n\n  private _currentTabIndex = 0;\n  private _previousTabIndex = 0;\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(private cdRef: ChangeDetectorRef) {}\n\n  ngOnInit(): void {\n    this.tabsBackground = getCSSColor(this.tabsBackground);\n    this.navButtonsBackground = getCSSColor(this.navButtonsBackground);\n\n    this.windowResize$ = fromEvent(window, 'resize')\n      .pipe(debounceTime(50), distinctUntilChanged())\n      .subscribe(() => this.onResize());\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.selectedIndex && !changes.selectedIndex.firstChange) {\n      this.selectTab();\n    }\n  }\n\n  ngAfterContentInit() {\n    this.selectTab();\n  }\n\n  ngAfterViewInit() {\n    this._updateNavBtnsState();\n\n    this.listScroll$ = fromEvent(this.tabsList.nativeElement, 'scroll')\n      .pipe(debounceTime(50), distinctUntilChanged())\n      .subscribe((event: any) => this.onScroll(event));\n\n    this.cdRef.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n    this.windowResize$?.unsubscribe();\n    this.listScroll$?.unsubscribe();\n  }\n\n  get selectedTab(): CpsTabComponent | undefined {\n    return this.tabs.find((t) => t.active);\n  }\n\n  onTabClick(index: number) {\n    this.selectedIndex = index;\n    this.selectTab();\n  }\n\n  selectTab() {\n    const _tabs = this.tabs.toArray();\n    const currentSelectedTab = _tabs && _tabs[this._previousTabIndex];\n\n    currentSelectedTab && (currentSelectedTab.active = false);\n    const newSelectedTab = _tabs && _tabs[this._currentTabIndex];\n    newSelectedTab && (newSelectedTab.active = true);\n    if (this._currentTabIndex === this._previousTabIndex) {\n      return;\n    }\n\n    this.beforeTabChanged.emit({\n      previousIndex: this._previousTabIndex,\n      newIndex: this._currentTabIndex\n    });\n\n    if (this.animationType === 'slide') {\n      this.animationState =\n        this._currentTabIndex < this._previousTabIndex\n          ? 'slideLeft'\n          : 'slideRight';\n\n      this.afterTabChanged.emit({\n        previousIndex: this._previousTabIndex,\n        newIndex: this._currentTabIndex\n      });\n    } else if (this.animationType === 'fade') {\n      this.animationState = 'fadeOut';\n      setTimeout(() => {\n        this.animationState = 'fadeIn';\n        this.afterTabChanged.emit({\n          previousIndex: this._previousTabIndex,\n          newIndex: this._currentTabIndex\n        });\n      }, 100);\n    }\n  }\n\n  onScroll(event: any) {\n    this._updateNavBtnsState();\n    event.preventDefault();\n  }\n\n  onResize() {\n    this._updateNavBtnsState();\n  }\n\n  navBackward() {\n    const content = this.tabsList.nativeElement;\n    const width = this._getWidth(content) - this._getVisibleButtonWidths();\n    const pos = content.scrollLeft - width;\n    content.scrollLeft = pos <= 0 ? 0 : pos;\n  }\n\n  navForward() {\n    const content = this.tabsList.nativeElement;\n    const width = this._getWidth(content) - this._getVisibleButtonWidths();\n    const pos = content.scrollLeft + width;\n    const lastPos = content.scrollWidth - width;\n    content.scrollLeft = pos >= lastPos ? lastPos : pos;\n  }\n\n  private _updateNavBtnsState() {\n    const content = this.tabsList.nativeElement;\n    const { scrollLeft, scrollWidth } = content;\n\n    const width = this._getWidth(content);\n\n    this.backBtnVisible = scrollLeft === 0;\n    this.forwardBtnVisible = Math.abs(scrollLeft - scrollWidth + width) < 2;\n  }\n\n  private _getVisibleButtonWidths() {\n    return [this.backBtn?.nativeElement, this.forwardBtn?.nativeElement].reduce(\n      (acc, el) => (el ? acc + this._getWidth(el) : acc),\n      0\n    );\n  }\n\n  private _getWidth(el: any): number {\n    let width = el.offsetWidth;\n    if (!width) return width;\n\n    const style = getComputedStyle(el);\n\n    width -=\n      parseFloat(style.paddingLeft) +\n      parseFloat(style.paddingRight) +\n      parseFloat(style.borderLeftWidth) +\n      parseFloat(style.borderRightWidth);\n\n    return width;\n  }\n}\n","<div\n  class=\"cps-tabs\"\n  [ngClass]=\"{\n    'cps-tabs-subtabs': isSubTabs,\n    'cps-tabs-center-aligned': alignment === 'center',\n    'cps-tabs-right-aligned': alignment === 'right',\n    'cps-tabs-stretched': stretched\n  }\"\n  [ngStyle]=\"{ 'background-color': tabsBackground }\">\n  <div\n    class=\"nav-btn nav-btn-back\"\n    [ngStyle]=\"{ 'background-color': navButtonsBackground }\"\n    *ngIf=\"!backBtnVisible\"\n    #backBtn\n    (click)=\"navBackward()\">\n    <cps-icon icon=\"chevron-down\" color=\"text-dark\"></cps-icon>\n  </div>\n  <ul #tabsList class=\"cps-tabs-list\">\n    <ng-container *ngFor=\"let tab of tabs; let tabIndex = index\">\n      <li\n        *ngIf=\"tab.tooltipText\"\n        class=\"cps-tab\"\n        (click)=\"!tab.disabled ? onTabClick(tabIndex) : ''\"\n        [ngClass]=\"{ active: tab.active, disabled: tab.disabled }\"\n        [cpsTooltip]=\"tab.tooltipText\"\n        tooltipOpenDelay=\"1000\"\n        tooltipCloseDelay=\"0\"\n        tooltipPosition=\"bottom\"\n        [tooltipMaxWidth]=\"tab.tooltipMaxWidth\"\n        [tooltipPersistent]=\"tab.tooltipPersistent\"\n        [tooltipContentClass]=\"tab.tooltipContentClass\">\n        <ng-container\n          *ngTemplateOutlet=\"\n            tabHeaderTemplate;\n            context: {\n              tab: tab\n            }\n          \"></ng-container>\n      </li>\n      <li\n        *ngIf=\"!tab.tooltipText\"\n        class=\"cps-tab\"\n        (click)=\"!tab.disabled ? onTabClick(tabIndex) : ''\"\n        [ngClass]=\"{ active: tab.active, disabled: tab.disabled }\">\n        <ng-container\n          *ngTemplateOutlet=\"\n            tabHeaderTemplate;\n            context: {\n              tab: tab\n            }\n          \"></ng-container>\n      </li>\n    </ng-container>\n  </ul>\n  <div\n    class=\"nav-btn nav-btn-forward\"\n    [ngStyle]=\"{ 'background-color': navButtonsBackground }\"\n    *ngIf=\"!forwardBtnVisible\"\n    #forwardBtn\n    (click)=\"navForward()\">\n    <cps-icon icon=\"chevron-down\" color=\"text-dark\"></cps-icon>\n  </div>\n</div>\n<div\n  class=\"cps-tab-content\"\n  [ngClass]=\"{ 'cps-tab-content-subtabs': isSubTabs }\">\n  <ng-container *ngFor=\"let tab of tabs\">\n    <div\n      [@slideInOut]=\"animationState\"\n      *ngIf=\"tab.active && animationType === 'slide'\">\n      <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n    </div>\n    <div\n      [@fadeInOut]=\"animationState\"\n      *ngIf=\"tab.active && animationType === 'fade'\">\n      <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n    </div>\n  </ng-container>\n</div>\n\n<ng-template #tabHeaderTemplate let-tab=\"tab\">\n  <cps-icon *ngIf=\"tab.icon\" class=\"cps-tab-icon\" [icon]=\"tab.icon\"> </cps-icon>\n  <a class=\"cps-tab-link\">{{ tab.label }}</a>\n  <ng-container *ngIf=\"tab.badgeValue\">\n    <div\n      *ngIf=\"tab.badgeTooltip\"\n      class=\"cps-tab-badge\"\n      [cpsTooltip]=\"tab.badgeTooltip\">\n      <span>{{ tab.badgeValue }}</span>\n    </div>\n    <div *ngIf=\"!tab.badgeTooltip\" class=\"cps-tab-badge\">\n      <span>{{ tab.badgeValue }}</span>\n    </div>\n  </ng-container>\n</ng-template>\n"]}
|
|
285
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-tab-group.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-tab-group/cps-tab-group.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-tab-group/cps-tab-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  animate,\n  state,\n  style,\n  transition,\n  trigger\n} from '@angular/animations';\nimport { CommonModule } from '@angular/common';\nimport {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { CpsIconComponent } from '../cps-icon/cps-icon.component';\nimport { CpsTabComponent } from './cps-tab/cps-tab.component';\nimport { CpsTooltipDirective } from '../../directives/cps-tooltip.directive';\nimport { getCSSColor } from '../../utils/colors-utils';\nimport {\n  Subscription,\n  debounceTime,\n  distinctUntilChanged,\n  fromEvent\n} from 'rxjs';\n\nexport interface TabChangeEvent {\n  previousIndex: number;\n  newIndex: number;\n}\n\nexport type CpsTabsAnimationType = 'slide' | 'fade';\nexport type CpsTabsAlignmentType = 'left' | 'center' | 'right';\n\n/**\n * CpsTabGroupComponent is a navigation component that displays items as tab headers.\n * @group Components\n */\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    CpsIconComponent,\n    CpsTabComponent,\n    CpsTooltipDirective\n  ],\n  selector: 'cps-tab-group',\n  templateUrl: './cps-tab-group.component.html',\n  styleUrls: ['./cps-tab-group.component.scss'],\n  animations: [\n    trigger('slideInOut', [\n      state('slideLeft', style({ transform: 'translateX(0)' })),\n      state('slideRight', style({ transform: 'translateX(0)' })),\n      transition('* => slideLeft', [\n        style({ transform: 'translateX(-100%)' }),\n        animate('200ms ease-in')\n      ]),\n      transition('* => slideRight', [\n        style({ transform: 'translateX(100%)' }),\n        animate('200ms ease-in')\n      ])\n    ]),\n    trigger('fadeInOut', [\n      state('fadeIn', style({ opacity: 1 })),\n      state('fadeOut', style({ opacity: 0 })),\n      transition('fadeOut => fadeIn', [\n        style({ opacity: 0 }),\n        animate('100ms ease-in')\n      ]),\n      transition('fadeIn => fadeOut', [\n        animate('0ms ease-out', style({ opacity: 0 }))\n      ])\n    ])\n  ]\n})\nexport class CpsTabGroupComponent\n  implements OnInit, AfterContentInit, AfterViewInit, OnChanges, OnDestroy\n{\n  /**\n   * Index of the selected tab.\n   * @group Props\n   */\n  @Input() set selectedIndex(value: number) {\n    this._previousTabIndex = this._currentTabIndex;\n    this._currentTabIndex = value;\n  }\n\n  get selectedIndex(): number {\n    return this._currentTabIndex;\n  }\n\n  /**\n   * Determines whether to apply an alternative 'subtabs' styling.\n   * @group Props\n   */\n  @Input() isSubTabs = false;\n\n  /**\n   * Horizontal alignment of tabs.\n   * @group Props\n   */\n  @Input() alignment: CpsTabsAlignmentType = 'left';\n\n  /**\n   * Determines whether to stretch tabs to fill the available horizontal space.\n   * @group Props\n   */\n  @Input() stretched = false;\n\n  /**\n   * Transition options of how content appears, it can be \"slide\" or \"fade\".\n   * @group Props\n   */\n  @Input() animationType: CpsTabsAnimationType = 'slide';\n\n  /**\n   * Background color of navigation buttons.\n   * @group Props\n   */\n  @Input() navButtonsBackground = 'inherit';\n\n  /**\n   * Background color of tabs.\n   * @group Props\n   */\n  @Input() tabsBackground = 'inherit';\n\n  /**\n   * Callback to invoke before tab change.\n   * @param {TabChangeEvent} any - tab change event.\n   * @group Emits\n   */\n  @Output() beforeTabChanged = new EventEmitter<TabChangeEvent>();\n\n  /**\n   * Callback to invoke after tab change.\n   * @param {TabChangeEvent} any - tab change event.\n   * @group Emits\n   */\n  @Output() afterTabChanged = new EventEmitter<TabChangeEvent>();\n\n  @ViewChild('tabsList') tabsList!: ElementRef;\n  @ViewChild('backBtn') backBtn?: ElementRef;\n  @ViewChild('forwardBtn') forwardBtn?: ElementRef;\n\n  @ContentChildren(CpsTabComponent) tabs!: QueryList<CpsTabComponent>;\n\n  backBtnVisible = false;\n  forwardBtnVisible = false;\n  animationState: 'slideLeft' | 'slideRight' | 'fadeIn' | 'fadeOut' = 'fadeIn';\n\n  windowResize$: Subscription = Subscription.EMPTY;\n  listScroll$: Subscription = Subscription.EMPTY;\n\n  private _currentTabIndex = 0;\n  private _previousTabIndex = 0;\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(private cdRef: ChangeDetectorRef) {}\n\n  ngOnInit(): void {\n    this.tabsBackground = getCSSColor(this.tabsBackground);\n    this.navButtonsBackground = getCSSColor(this.navButtonsBackground);\n\n    this.windowResize$ = fromEvent(window, 'resize')\n      .pipe(debounceTime(50), distinctUntilChanged())\n      .subscribe(() => this.onResize());\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.selectedIndex && !changes.selectedIndex.firstChange) {\n      this.selectTab();\n    }\n  }\n\n  ngAfterContentInit() {\n    this.selectTab(true);\n  }\n\n  ngAfterViewInit() {\n    this._updateNavBtnsState();\n\n    this.listScroll$ = fromEvent(this.tabsList.nativeElement, 'scroll')\n      .pipe(debounceTime(50), distinctUntilChanged())\n      .subscribe((event: any) => this.onScroll(event));\n\n    this.cdRef.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n    this.windowResize$?.unsubscribe();\n    this.listScroll$?.unsubscribe();\n  }\n\n  get selectedTab(): CpsTabComponent | undefined {\n    return this.tabs.find((t) => t.active);\n  }\n\n  onTabClick(index: number) {\n    this.selectedIndex = index;\n    this.selectTab();\n  }\n\n  selectTab(silent = false) {\n    const _tabs = this.tabs.toArray();\n    const currentSelectedTab = _tabs && _tabs[this._previousTabIndex];\n\n    currentSelectedTab && (currentSelectedTab.active = false);\n    const newSelectedTab = _tabs && _tabs[this._currentTabIndex];\n    newSelectedTab && (newSelectedTab.active = true);\n    if (this._currentTabIndex === this._previousTabIndex) {\n      return;\n    }\n\n    if (!silent) {\n      this.beforeTabChanged.emit({\n        previousIndex: this._previousTabIndex,\n        newIndex: this._currentTabIndex\n      });\n    }\n\n    if (this.animationType === 'slide') {\n      this.animationState =\n        this._currentTabIndex < this._previousTabIndex\n          ? 'slideLeft'\n          : 'slideRight';\n\n      if (!silent) {\n        this.afterTabChanged.emit({\n          previousIndex: this._previousTabIndex,\n          newIndex: this._currentTabIndex\n        });\n      }\n    } else if (this.animationType === 'fade') {\n      this.animationState = 'fadeOut';\n      setTimeout(() => {\n        this.animationState = 'fadeIn';\n        if (!silent) {\n          this.afterTabChanged.emit({\n            previousIndex: this._previousTabIndex,\n            newIndex: this._currentTabIndex\n          });\n        }\n      }, 100);\n    }\n  }\n\n  onScroll(event: any) {\n    this._updateNavBtnsState();\n    event.preventDefault();\n  }\n\n  onResize() {\n    this._updateNavBtnsState();\n  }\n\n  navBackward() {\n    const content = this.tabsList.nativeElement;\n    const width = this._getWidth(content) - this._getVisibleButtonWidths();\n    const pos = content.scrollLeft - width;\n    content.scrollLeft = pos <= 0 ? 0 : pos;\n  }\n\n  navForward() {\n    const content = this.tabsList.nativeElement;\n    const width = this._getWidth(content) - this._getVisibleButtonWidths();\n    const pos = content.scrollLeft + width;\n    const lastPos = content.scrollWidth - width;\n    content.scrollLeft = pos >= lastPos ? lastPos : pos;\n  }\n\n  private _updateNavBtnsState() {\n    const content = this.tabsList.nativeElement;\n    const { scrollLeft, scrollWidth } = content;\n\n    const width = this._getWidth(content);\n\n    this.backBtnVisible = scrollLeft === 0;\n    this.forwardBtnVisible = Math.abs(scrollLeft - scrollWidth + width) < 2;\n  }\n\n  private _getVisibleButtonWidths() {\n    return [this.backBtn?.nativeElement, this.forwardBtn?.nativeElement].reduce(\n      (acc, el) => (el ? acc + this._getWidth(el) : acc),\n      0\n    );\n  }\n\n  private _getWidth(el: any): number {\n    let width = el.offsetWidth;\n    if (!width) return width;\n\n    const style = getComputedStyle(el);\n\n    width -=\n      parseFloat(style.paddingLeft) +\n      parseFloat(style.paddingRight) +\n      parseFloat(style.borderLeftWidth) +\n      parseFloat(style.borderRightWidth);\n\n    return width;\n  }\n}\n","<div\n  class=\"cps-tabs\"\n  [ngClass]=\"{\n    'cps-tabs-subtabs': isSubTabs,\n    'cps-tabs-center-aligned': alignment === 'center',\n    'cps-tabs-right-aligned': alignment === 'right',\n    'cps-tabs-stretched': stretched\n  }\"\n  [ngStyle]=\"{ 'background-color': tabsBackground }\">\n  <div\n    class=\"nav-btn nav-btn-back\"\n    [ngStyle]=\"{ 'background-color': navButtonsBackground }\"\n    *ngIf=\"!backBtnVisible\"\n    #backBtn\n    (click)=\"navBackward()\">\n    <cps-icon icon=\"chevron-down\" color=\"text-dark\"></cps-icon>\n  </div>\n  <ul #tabsList class=\"cps-tabs-list\">\n    <ng-container *ngFor=\"let tab of tabs; let tabIndex = index\">\n      <li\n        *ngIf=\"tab.tooltipText\"\n        class=\"cps-tab\"\n        (click)=\"!tab.disabled ? onTabClick(tabIndex) : ''\"\n        [ngClass]=\"{ active: tab.active, disabled: tab.disabled }\"\n        [cpsTooltip]=\"tab.tooltipText\"\n        tooltipOpenDelay=\"1000\"\n        tooltipCloseDelay=\"0\"\n        tooltipPosition=\"bottom\"\n        [tooltipMaxWidth]=\"tab.tooltipMaxWidth\"\n        [tooltipPersistent]=\"tab.tooltipPersistent\"\n        [tooltipContentClass]=\"tab.tooltipContentClass\">\n        <ng-container\n          *ngTemplateOutlet=\"\n            tabHeaderTemplate;\n            context: {\n              tab: tab\n            }\n          \"></ng-container>\n      </li>\n      <li\n        *ngIf=\"!tab.tooltipText\"\n        class=\"cps-tab\"\n        (click)=\"!tab.disabled ? onTabClick(tabIndex) : ''\"\n        [ngClass]=\"{ active: tab.active, disabled: tab.disabled }\">\n        <ng-container\n          *ngTemplateOutlet=\"\n            tabHeaderTemplate;\n            context: {\n              tab: tab\n            }\n          \"></ng-container>\n      </li>\n    </ng-container>\n  </ul>\n  <div\n    class=\"nav-btn nav-btn-forward\"\n    [ngStyle]=\"{ 'background-color': navButtonsBackground }\"\n    *ngIf=\"!forwardBtnVisible\"\n    #forwardBtn\n    (click)=\"navForward()\">\n    <cps-icon icon=\"chevron-down\" color=\"text-dark\"></cps-icon>\n  </div>\n</div>\n<div\n  class=\"cps-tab-content\"\n  [ngClass]=\"{ 'cps-tab-content-subtabs': isSubTabs }\">\n  <ng-container *ngFor=\"let tab of tabs\">\n    <div\n      [@slideInOut]=\"animationState\"\n      *ngIf=\"tab.active && animationType === 'slide'\">\n      <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n    </div>\n    <div\n      [@fadeInOut]=\"animationState\"\n      *ngIf=\"tab.active && animationType === 'fade'\">\n      <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n    </div>\n  </ng-container>\n</div>\n\n<ng-template #tabHeaderTemplate let-tab=\"tab\">\n  <cps-icon *ngIf=\"tab.icon\" class=\"cps-tab-icon\" [icon]=\"tab.icon\"> </cps-icon>\n  <a class=\"cps-tab-link\">{{ tab.label }}</a>\n  <ng-container *ngIf=\"tab.badgeValue\">\n    <div\n      *ngIf=\"tab.badgeTooltip\"\n      class=\"cps-tab-badge\"\n      [cpsTooltip]=\"tab.badgeTooltip\">\n      <span>{{ tab.badgeValue }}</span>\n    </div>\n    <div *ngIf=\"!tab.badgeTooltip\" class=\"cps-tab-badge\">\n      <span>{{ tab.badgeValue }}</span>\n    </div>\n  </ng-container>\n</ng-template>\n"]}
|
package/fesm2015/cps-ui-kit.mjs
CHANGED
|
@@ -10324,7 +10324,7 @@ class CpsTabGroupComponent {
|
|
|
10324
10324
|
}
|
|
10325
10325
|
}
|
|
10326
10326
|
ngAfterContentInit() {
|
|
10327
|
-
this.selectTab();
|
|
10327
|
+
this.selectTab(true);
|
|
10328
10328
|
}
|
|
10329
10329
|
ngAfterViewInit() {
|
|
10330
10330
|
this._updateNavBtnsState();
|
|
@@ -10345,7 +10345,7 @@ class CpsTabGroupComponent {
|
|
|
10345
10345
|
this.selectedIndex = index;
|
|
10346
10346
|
this.selectTab();
|
|
10347
10347
|
}
|
|
10348
|
-
selectTab() {
|
|
10348
|
+
selectTab(silent = false) {
|
|
10349
10349
|
const _tabs = this.tabs.toArray();
|
|
10350
10350
|
const currentSelectedTab = _tabs && _tabs[this._previousTabIndex];
|
|
10351
10351
|
currentSelectedTab && (currentSelectedTab.active = false);
|
|
@@ -10354,28 +10354,34 @@ class CpsTabGroupComponent {
|
|
|
10354
10354
|
if (this._currentTabIndex === this._previousTabIndex) {
|
|
10355
10355
|
return;
|
|
10356
10356
|
}
|
|
10357
|
-
|
|
10358
|
-
|
|
10359
|
-
|
|
10360
|
-
|
|
10357
|
+
if (!silent) {
|
|
10358
|
+
this.beforeTabChanged.emit({
|
|
10359
|
+
previousIndex: this._previousTabIndex,
|
|
10360
|
+
newIndex: this._currentTabIndex
|
|
10361
|
+
});
|
|
10362
|
+
}
|
|
10361
10363
|
if (this.animationType === 'slide') {
|
|
10362
10364
|
this.animationState =
|
|
10363
10365
|
this._currentTabIndex < this._previousTabIndex
|
|
10364
10366
|
? 'slideLeft'
|
|
10365
10367
|
: 'slideRight';
|
|
10366
|
-
|
|
10367
|
-
|
|
10368
|
-
|
|
10369
|
-
|
|
10368
|
+
if (!silent) {
|
|
10369
|
+
this.afterTabChanged.emit({
|
|
10370
|
+
previousIndex: this._previousTabIndex,
|
|
10371
|
+
newIndex: this._currentTabIndex
|
|
10372
|
+
});
|
|
10373
|
+
}
|
|
10370
10374
|
}
|
|
10371
10375
|
else if (this.animationType === 'fade') {
|
|
10372
10376
|
this.animationState = 'fadeOut';
|
|
10373
10377
|
setTimeout(() => {
|
|
10374
10378
|
this.animationState = 'fadeIn';
|
|
10375
|
-
|
|
10376
|
-
|
|
10377
|
-
|
|
10378
|
-
|
|
10379
|
+
if (!silent) {
|
|
10380
|
+
this.afterTabChanged.emit({
|
|
10381
|
+
previousIndex: this._previousTabIndex,
|
|
10382
|
+
newIndex: this._currentTabIndex
|
|
10383
|
+
});
|
|
10384
|
+
}
|
|
10379
10385
|
}, 100);
|
|
10380
10386
|
}
|
|
10381
10387
|
}
|