cps-ui-kit 0.50.0 → 0.52.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/README.md +1 -0
- package/esm2020/lib/base_components/cps-tree-dropdown-base.component.mjs +72 -45
- package/esm2020/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +62 -42
- package/esm2020/lib/components/cps-datepicker/cps-datepicker.component.mjs +47 -26
- package/esm2020/lib/components/cps-input/cps-input.component.mjs +20 -6
- package/esm2020/lib/components/cps-menu/cps-menu.component.mjs +35 -9
- package/esm2020/lib/components/cps-paginator/cps-paginator.component.mjs +3 -3
- package/esm2020/lib/components/cps-select/cps-select.component.mjs +85 -55
- package/esm2020/lib/components/cps-tab-group/cps-tab/cps-tab.component.mjs +37 -0
- package/esm2020/lib/components/cps-tab-group/cps-tab-group.component.mjs +137 -0
- package/esm2020/lib/components/cps-table/cps-table.component.mjs +3 -3
- package/esm2020/lib/components/cps-table/directives/cps-table-column-filter.directive.mjs +16 -2
- package/esm2020/lib/components/cps-table/table-column-filter/table-column-filter-constraint/table-column-filter-constraint.component.mjs +4 -4
- package/esm2020/lib/components/cps-table/table-column-filter/table-column-filter.component.mjs +3 -3
- package/esm2020/lib/components/cps-table/table-row-menu/table-row-menu.component.mjs +1 -1
- package/esm2020/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.mjs +27 -37
- package/esm2020/lib/components/cps-tree-select/cps-tree-select.component.mjs +14 -22
- package/esm2020/public-api.mjs +3 -1
- package/fesm2015/cps-ui-kit.mjs +2021 -1772
- package/fesm2015/cps-ui-kit.mjs.map +1 -1
- package/fesm2020/cps-ui-kit.mjs +2027 -1782
- package/fesm2020/cps-ui-kit.mjs.map +1 -1
- package/lib/base_components/cps-tree-dropdown-base.component.d.ts +16 -7
- package/lib/components/cps-autocomplete/cps-autocomplete.component.d.ts +14 -7
- package/lib/components/cps-datepicker/cps-datepicker.component.d.ts +10 -4
- package/lib/components/cps-input/cps-input.component.d.ts +7 -3
- package/lib/components/cps-menu/cps-menu.component.d.ts +7 -3
- package/lib/components/cps-select/cps-select.component.d.ts +16 -8
- package/lib/components/cps-tab-group/cps-tab/cps-tab.component.d.ts +14 -0
- package/lib/components/cps-tab-group/cps-tab-group.component.d.ts +25 -0
- package/lib/components/cps-table/directives/cps-table-column-filter.directive.d.ts +1 -0
- package/lib/components/cps-table/table-column-filter/table-column-filter-constraint/table-column-filter-constraint.component.d.ts +1 -1
- package/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.d.ts +5 -8
- package/lib/components/cps-tree-select/cps-tree-select.component.d.ts +4 -7
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- package/styles/cps-tooltip-style.scss +1 -1
- package/esm2020/lib/directives/internal/click-outside.directive.mjs +0 -45
- package/esm2020/lib/utils/internal/position-utils.mjs +0 -12
- package/lib/directives/internal/click-outside.directive.d.ts +0 -11
- package/lib/utils/internal/position-utils.d.ts +0 -1
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, Input, TemplateRef, ViewChild } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
export class CpsTabComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.label = '';
|
|
8
|
+
this.icon = '';
|
|
9
|
+
this.tooltipText = '';
|
|
10
|
+
this.tooltipContentClass = 'cps-tooltip-content';
|
|
11
|
+
this.tooltipMaxWidth = '100%';
|
|
12
|
+
this.tooltipPersistent = false;
|
|
13
|
+
this.active = false;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
CpsTabComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTabComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
17
|
+
CpsTabComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: CpsTabComponent, isStandalone: true, selector: "cps-tab", inputs: { label: "label", icon: "icon", tooltipText: "tooltipText", tooltipContentClass: "tooltipContentClass", tooltipMaxWidth: "tooltipMaxWidth", tooltipPersistent: "tooltipPersistent" }, viewQueries: [{ propertyName: "content", first: true, predicate: TemplateRef, descendants: true }], ngImport: i0, template: "<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n\n<ng-container *ngTemplateOutlet=\"content\"></ng-container>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] });
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTabComponent, decorators: [{
|
|
19
|
+
type: Component,
|
|
20
|
+
args: [{ standalone: true, imports: [CommonModule], selector: 'cps-tab', template: "<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n\n<ng-container *ngTemplateOutlet=\"content\"></ng-container>\n" }]
|
|
21
|
+
}], propDecorators: { label: [{
|
|
22
|
+
type: Input
|
|
23
|
+
}], icon: [{
|
|
24
|
+
type: Input
|
|
25
|
+
}], tooltipText: [{
|
|
26
|
+
type: Input
|
|
27
|
+
}], tooltipContentClass: [{
|
|
28
|
+
type: Input
|
|
29
|
+
}], tooltipMaxWidth: [{
|
|
30
|
+
type: Input
|
|
31
|
+
}], tooltipPersistent: [{
|
|
32
|
+
type: Input
|
|
33
|
+
}], content: [{
|
|
34
|
+
type: ViewChild,
|
|
35
|
+
args: [TemplateRef]
|
|
36
|
+
}] } });
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLXRhYi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9jcHMtdGFiLWdyb3VwL2Nwcy10YWIvY3BzLXRhYi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9jcHMtdGFiLWdyb3VwL2Nwcy10YWIvY3BzLXRhYi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsV0FBVyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBU3pFLE1BQU0sT0FBTyxlQUFlO0lBUDVCO1FBUVcsVUFBSyxHQUFHLEVBQUUsQ0FBQztRQUNYLFNBQUksR0FBRyxFQUFFLENBQUM7UUFDVixnQkFBVyxHQUFHLEVBQUUsQ0FBQztRQUNqQix3QkFBbUIsR0FBRyxxQkFBcUIsQ0FBQztRQUM1QyxvQkFBZSxHQUFvQixNQUFNLENBQUM7UUFDMUMsc0JBQWlCLEdBQUcsS0FBSyxDQUFDO1FBRW5DLFdBQU0sR0FBRyxLQUFLLENBQUM7S0FDaEI7OzRHQVRZLGVBQWU7Z0dBQWYsZUFBZSwwU0FPZixXQUFXLGdEQ2pCeEIsc0lBS0EseUREQVksWUFBWTsyRkFLWCxlQUFlO2tCQVAzQixTQUFTO2lDQUNJLElBQUksV0FDUCxDQUFDLFlBQVksQ0FBQyxZQUNiLFNBQVM7OEJBS1YsS0FBSztzQkFBYixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLG1CQUFtQjtzQkFBM0IsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLO2dCQUNHLGlCQUFpQjtzQkFBekIsS0FBSztnQkFDa0IsT0FBTztzQkFBOUIsU0FBUzt1QkFBQyxXQUFXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIFRlbXBsYXRlUmVmLCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICBzZWxlY3RvcjogJ2Nwcy10YWInLFxuICB0ZW1wbGF0ZVVybDogJy4vY3BzLXRhYi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2Nwcy10YWIuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBDcHNUYWJDb21wb25lbnQge1xuICBASW5wdXQoKSBsYWJlbCA9ICcnO1xuICBASW5wdXQoKSBpY29uID0gJyc7XG4gIEBJbnB1dCgpIHRvb2x0aXBUZXh0ID0gJyc7XG4gIEBJbnB1dCgpIHRvb2x0aXBDb250ZW50Q2xhc3MgPSAnY3BzLXRvb2x0aXAtY29udGVudCc7XG4gIEBJbnB1dCgpIHRvb2x0aXBNYXhXaWR0aDogbnVtYmVyIHwgc3RyaW5nID0gJzEwMCUnO1xuICBASW5wdXQoKSB0b29sdGlwUGVyc2lzdGVudCA9IGZhbHNlO1xuICBAVmlld0NoaWxkKFRlbXBsYXRlUmVmKSBjb250ZW50ITogVGVtcGxhdGVSZWY8YW55PjtcbiAgYWN0aXZlID0gZmFsc2U7XG59XG4iLCI8bmctdGVtcGxhdGUgI2NvbnRlbnQ+XG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvbmctdGVtcGxhdGU+XG5cbjxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJjb250ZW50XCI+PC9uZy1jb250YWluZXI+XG4iXX0=
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import { animate, state, style, transition, trigger } from '@angular/animations';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { Component, ContentChildren, EventEmitter, Input, Output } from '@angular/core';
|
|
4
|
+
import { CpsIconComponent } from '../cps-icon/cps-icon.component';
|
|
5
|
+
import { CpsTabComponent } from './cps-tab/cps-tab.component';
|
|
6
|
+
import { CpsTooltipDirective } from '../../directives/cps-tooltip.directive';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/common";
|
|
9
|
+
export class CpsTabGroupComponent {
|
|
10
|
+
// eslint-disable-next-line no-useless-constructor
|
|
11
|
+
constructor(cdRef) {
|
|
12
|
+
this.cdRef = cdRef;
|
|
13
|
+
this.selectedIndex = 0;
|
|
14
|
+
this.isSubTabs = false; // applies an alternative styling to tabs
|
|
15
|
+
this.animationType = 'slide';
|
|
16
|
+
this.initAllTabsContent = false;
|
|
17
|
+
this.animationState = 'slideLeft';
|
|
18
|
+
this.beforeTabChanged = new EventEmitter();
|
|
19
|
+
this.afterTabChanged = new EventEmitter();
|
|
20
|
+
}
|
|
21
|
+
ngAfterContentInit() {
|
|
22
|
+
this.selectTab(this.selectedIndex);
|
|
23
|
+
}
|
|
24
|
+
ngAfterViewInit() {
|
|
25
|
+
this.cdRef.detectChanges();
|
|
26
|
+
}
|
|
27
|
+
selectTab(newSelectedIndex) {
|
|
28
|
+
const _tabs = this.tabs.toArray();
|
|
29
|
+
const currentSelectedTab = _tabs && _tabs[this.selectedIndex];
|
|
30
|
+
this.beforeTabChanged.emit({
|
|
31
|
+
currentTabIndex: this.selectedIndex,
|
|
32
|
+
newTabIndex: newSelectedIndex
|
|
33
|
+
});
|
|
34
|
+
currentSelectedTab && (currentSelectedTab.active = false);
|
|
35
|
+
const newSelectedTab = _tabs && _tabs[newSelectedIndex];
|
|
36
|
+
newSelectedTab && (newSelectedTab.active = true);
|
|
37
|
+
if (newSelectedIndex === this.selectedIndex) {
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
if (this.animationType === 'slide') {
|
|
41
|
+
this.animationState =
|
|
42
|
+
newSelectedIndex < this.selectedIndex ? 'slideLeft' : 'slideRight';
|
|
43
|
+
this.selectedIndex = newSelectedIndex;
|
|
44
|
+
this.afterTabChanged.emit({
|
|
45
|
+
currentTabIndex: newSelectedIndex
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
else if (this.animationType === 'fade') {
|
|
49
|
+
this.animationState = 'fadeOut';
|
|
50
|
+
setTimeout(() => {
|
|
51
|
+
this.animationState = 'fadeIn';
|
|
52
|
+
this.selectedIndex = newSelectedIndex;
|
|
53
|
+
this.afterTabChanged.emit({
|
|
54
|
+
currentTabIndex: newSelectedIndex
|
|
55
|
+
});
|
|
56
|
+
}, 100);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
get selectedTab() {
|
|
60
|
+
return this.tabs.find((t) => t.active);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
CpsTabGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTabGroupComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
64
|
+
CpsTabGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: CpsTabGroupComponent, isStandalone: true, selector: "cps-tab-group", inputs: { selectedIndex: "selectedIndex", isSubTabs: "isSubTabs", animationType: "animationType", initAllTabsContent: "initAllTabsContent" }, outputs: { beforeTabChanged: "beforeTabChanged", afterTabChanged: "afterTabChanged" }, queries: [{ propertyName: "tabs", predicate: CpsTabComponent }], ngImport: i0, template: "<ul class=\"cps-tabs\" [ngClass]=\"{ 'cps-tabs-subtabs': isSubTabs }\">\n <ng-container *ngFor=\"let tab of tabs; let tabIndex = index\">\n <li\n *ngIf=\"tab.tooltipText\"\n class=\"cps-tab\"\n (click)=\"selectTab(tabIndex)\"\n [ngClass]=\"{ active: tab.active }\"\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 <cps-icon *ngIf=\"tab.icon\" class=\"cps-tab-icon\" [icon]=\"tab.icon\">\n </cps-icon>\n <a class=\"cps-tab-link\">{{ tab.label }}</a>\n </li>\n <li\n *ngIf=\"!tab.tooltipText\"\n class=\"cps-tab\"\n (click)=\"selectTab(tabIndex)\"\n [ngClass]=\"{ active: tab.active }\">\n <cps-icon *ngIf=\"tab.icon\" class=\"cps-tab-icon\" [icon]=\"tab.icon\">\n </cps-icon>\n <a class=\"cps-tab-link\">{{ tab.label }}</a>\n </li>\n </ng-container>\n</ul>\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 && !initAllTabsContent && animationType === 'slide'\">\n <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n </div>\n <div\n [@fadeInOut]=\"animationState\"\n *ngIf=\"tab.active && !initAllTabsContent && animationType === 'fade'\">\n <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n </div>\n <div\n *ngIf=\"initAllTabsContent && animationType === 'slide'\"\n [@slideInOut]=\"animationState\"\n [ngStyle]=\"{ display: tab.active ? null : 'none' }\">\n <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n </div>\n <div\n *ngIf=\"initAllTabsContent && animationType === 'fade'\"\n [@fadeInOut]=\"animationState\"\n [ngStyle]=\"{ display: tab.active ? null : 'none' }\">\n <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n </div>\n </ng-container>\n</div>\n", styles: [":host .cps-tab-content{position:relative;min-height:100px;padding:10px}:host .cps-tabs{display:flex;list-style:none;padding:0;margin:0}:host .cps-tabs .cps-tab{display:inline-flex;align-items:center;justify-content:center;min-width:150px;padding:0 24px;font-family:Source Sans Pro,sans-serif;font-style:normal;font-weight:500;font-size:15px;line-height:20px;color:var(--cps-color-text-dark);opacity:1;cursor:pointer;border-bottom:3px solid transparent}:host .cps-tabs .cps-tab.active{color:var(--cps-color-calm)}:host .cps-tabs .cps-tab-link{text-decoration:none;padding:10px;color:inherit;transition:border-bottom-color .3s}:host .cps-tabs:not(.cps-tabs-subtabs){border-bottom:1px solid rgba(0,0,0,.12)}:host .cps-tabs:not(.cps-tabs-subtabs) .cps-tab.active{color:var(--cps-color-calm);border-bottom:3px solid var(--cps-color-surprise)}:host .cps-tabs:not(.cps-tabs-subtabs) .cps-tab:hover:not(.active){border-bottom:3px solid var(--cps-color-line-light)}:host .cps-tabs.cps-tabs-subtabs .cps-tab{height:33px;background-color:#d7d7d759}:host .cps-tabs.cps-tabs-subtabs .cps-tab.active{background-color:#fff}:host .cps-tabs.cps-tabs-subtabs .cps-tab:hover{color:var(--cps-color-calm)}:host .cps-tab-content.cps-tab-content-subtabs{background-color:#fff}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: CpsIconComponent, selector: "cps-icon", inputs: ["icon", "size", "color"] }, { kind: "directive", type: CpsTooltipDirective, selector: "[cpsTooltip]", inputs: ["cpsTooltip", "tooltipOpenDelay", "tooltipCloseDelay", "tooltipOpenOn", "tooltipPosition", "tooltipPersistent", "tooltipDisabled", "tooltipMaxWidth", "tooltipContentClass"] }], animations: [
|
|
65
|
+
trigger('slideInOut', [
|
|
66
|
+
state('slideLeft', style({ transform: 'translateX(0)' })),
|
|
67
|
+
state('slideRight', style({ transform: 'translateX(0)' })),
|
|
68
|
+
transition('* => slideLeft', [
|
|
69
|
+
style({ transform: 'translateX(-100%)' }),
|
|
70
|
+
animate('200ms ease-in')
|
|
71
|
+
]),
|
|
72
|
+
transition('* => slideRight', [
|
|
73
|
+
style({ transform: 'translateX(100%)' }),
|
|
74
|
+
animate('200ms ease-in')
|
|
75
|
+
])
|
|
76
|
+
]),
|
|
77
|
+
trigger('fadeInOut', [
|
|
78
|
+
state('fadeIn', style({ opacity: 1 })),
|
|
79
|
+
state('fadeOut', style({ opacity: 0 })),
|
|
80
|
+
transition('fadeOut => fadeIn', [
|
|
81
|
+
style({ opacity: 0 }),
|
|
82
|
+
animate('100ms ease-in')
|
|
83
|
+
]),
|
|
84
|
+
transition('fadeIn => fadeOut', [
|
|
85
|
+
animate('0ms ease-out', style({ opacity: 0 }))
|
|
86
|
+
])
|
|
87
|
+
])
|
|
88
|
+
] });
|
|
89
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTabGroupComponent, decorators: [{
|
|
90
|
+
type: Component,
|
|
91
|
+
args: [{ standalone: true, imports: [
|
|
92
|
+
CommonModule,
|
|
93
|
+
CpsIconComponent,
|
|
94
|
+
CpsTabComponent,
|
|
95
|
+
CpsTooltipDirective
|
|
96
|
+
], selector: 'cps-tab-group', animations: [
|
|
97
|
+
trigger('slideInOut', [
|
|
98
|
+
state('slideLeft', style({ transform: 'translateX(0)' })),
|
|
99
|
+
state('slideRight', style({ transform: 'translateX(0)' })),
|
|
100
|
+
transition('* => slideLeft', [
|
|
101
|
+
style({ transform: 'translateX(-100%)' }),
|
|
102
|
+
animate('200ms ease-in')
|
|
103
|
+
]),
|
|
104
|
+
transition('* => slideRight', [
|
|
105
|
+
style({ transform: 'translateX(100%)' }),
|
|
106
|
+
animate('200ms ease-in')
|
|
107
|
+
])
|
|
108
|
+
]),
|
|
109
|
+
trigger('fadeInOut', [
|
|
110
|
+
state('fadeIn', style({ opacity: 1 })),
|
|
111
|
+
state('fadeOut', style({ opacity: 0 })),
|
|
112
|
+
transition('fadeOut => fadeIn', [
|
|
113
|
+
style({ opacity: 0 }),
|
|
114
|
+
animate('100ms ease-in')
|
|
115
|
+
]),
|
|
116
|
+
transition('fadeIn => fadeOut', [
|
|
117
|
+
animate('0ms ease-out', style({ opacity: 0 }))
|
|
118
|
+
])
|
|
119
|
+
])
|
|
120
|
+
], template: "<ul class=\"cps-tabs\" [ngClass]=\"{ 'cps-tabs-subtabs': isSubTabs }\">\n <ng-container *ngFor=\"let tab of tabs; let tabIndex = index\">\n <li\n *ngIf=\"tab.tooltipText\"\n class=\"cps-tab\"\n (click)=\"selectTab(tabIndex)\"\n [ngClass]=\"{ active: tab.active }\"\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 <cps-icon *ngIf=\"tab.icon\" class=\"cps-tab-icon\" [icon]=\"tab.icon\">\n </cps-icon>\n <a class=\"cps-tab-link\">{{ tab.label }}</a>\n </li>\n <li\n *ngIf=\"!tab.tooltipText\"\n class=\"cps-tab\"\n (click)=\"selectTab(tabIndex)\"\n [ngClass]=\"{ active: tab.active }\">\n <cps-icon *ngIf=\"tab.icon\" class=\"cps-tab-icon\" [icon]=\"tab.icon\">\n </cps-icon>\n <a class=\"cps-tab-link\">{{ tab.label }}</a>\n </li>\n </ng-container>\n</ul>\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 && !initAllTabsContent && animationType === 'slide'\">\n <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n </div>\n <div\n [@fadeInOut]=\"animationState\"\n *ngIf=\"tab.active && !initAllTabsContent && animationType === 'fade'\">\n <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n </div>\n <div\n *ngIf=\"initAllTabsContent && animationType === 'slide'\"\n [@slideInOut]=\"animationState\"\n [ngStyle]=\"{ display: tab.active ? null : 'none' }\">\n <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n </div>\n <div\n *ngIf=\"initAllTabsContent && animationType === 'fade'\"\n [@fadeInOut]=\"animationState\"\n [ngStyle]=\"{ display: tab.active ? null : 'none' }\">\n <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n </div>\n </ng-container>\n</div>\n", styles: [":host .cps-tab-content{position:relative;min-height:100px;padding:10px}:host .cps-tabs{display:flex;list-style:none;padding:0;margin:0}:host .cps-tabs .cps-tab{display:inline-flex;align-items:center;justify-content:center;min-width:150px;padding:0 24px;font-family:Source Sans Pro,sans-serif;font-style:normal;font-weight:500;font-size:15px;line-height:20px;color:var(--cps-color-text-dark);opacity:1;cursor:pointer;border-bottom:3px solid transparent}:host .cps-tabs .cps-tab.active{color:var(--cps-color-calm)}:host .cps-tabs .cps-tab-link{text-decoration:none;padding:10px;color:inherit;transition:border-bottom-color .3s}:host .cps-tabs:not(.cps-tabs-subtabs){border-bottom:1px solid rgba(0,0,0,.12)}:host .cps-tabs:not(.cps-tabs-subtabs) .cps-tab.active{color:var(--cps-color-calm);border-bottom:3px solid var(--cps-color-surprise)}:host .cps-tabs:not(.cps-tabs-subtabs) .cps-tab:hover:not(.active){border-bottom:3px solid var(--cps-color-line-light)}:host .cps-tabs.cps-tabs-subtabs .cps-tab{height:33px;background-color:#d7d7d759}:host .cps-tabs.cps-tabs-subtabs .cps-tab.active{background-color:#fff}:host .cps-tabs.cps-tabs-subtabs .cps-tab:hover{color:var(--cps-color-calm)}:host .cps-tab-content.cps-tab-content-subtabs{background-color:#fff}\n"] }]
|
|
121
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { tabs: [{
|
|
122
|
+
type: ContentChildren,
|
|
123
|
+
args: [CpsTabComponent]
|
|
124
|
+
}], selectedIndex: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], isSubTabs: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], animationType: [{
|
|
129
|
+
type: Input
|
|
130
|
+
}], initAllTabsContent: [{
|
|
131
|
+
type: Input
|
|
132
|
+
}], beforeTabChanged: [{
|
|
133
|
+
type: Output
|
|
134
|
+
}], afterTabChanged: [{
|
|
135
|
+
type: Output
|
|
136
|
+
}] } });
|
|
137
|
+
//# 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  EventEmitter,\n  Input,\n  Output,\n  QueryList\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';\n\nexport interface TabChangeEvent {\n  currentTabIndex: number;\n  newTabIndex?: number;\n}\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 implements AfterContentInit, AfterViewInit {\n  @ContentChildren(CpsTabComponent) tabs!: QueryList<CpsTabComponent>;\n\n  @Input() selectedIndex = 0;\n  @Input() isSubTabs = false; // applies an alternative styling to tabs\n  @Input() animationType: 'slide' | 'fade' = 'slide';\n  @Input() initAllTabsContent = false;\n\n  animationState: 'slideLeft' | 'slideRight' | 'fadeIn' | 'fadeOut' =\n    'slideLeft';\n\n  @Output() beforeTabChanged = new EventEmitter<TabChangeEvent>();\n  @Output() afterTabChanged = new EventEmitter<TabChangeEvent>();\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(private cdRef: ChangeDetectorRef) {}\n\n  ngAfterContentInit() {\n    this.selectTab(this.selectedIndex);\n  }\n\n  ngAfterViewInit() {\n    this.cdRef.detectChanges();\n  }\n\n  selectTab(newSelectedIndex: number) {\n    const _tabs = this.tabs.toArray();\n    const currentSelectedTab = _tabs && _tabs[this.selectedIndex];\n\n    this.beforeTabChanged.emit({\n      currentTabIndex: this.selectedIndex,\n      newTabIndex: newSelectedIndex\n    });\n\n    currentSelectedTab && (currentSelectedTab.active = false);\n    const newSelectedTab = _tabs && _tabs[newSelectedIndex];\n    newSelectedTab && (newSelectedTab.active = true);\n    if (newSelectedIndex === this.selectedIndex) {\n      return;\n    }\n\n    if (this.animationType === 'slide') {\n      this.animationState =\n        newSelectedIndex < this.selectedIndex ? 'slideLeft' : 'slideRight';\n      this.selectedIndex = newSelectedIndex;\n\n      this.afterTabChanged.emit({\n        currentTabIndex: newSelectedIndex\n      });\n    } else if (this.animationType === 'fade') {\n      this.animationState = 'fadeOut';\n      setTimeout(() => {\n        this.animationState = 'fadeIn';\n        this.selectedIndex = newSelectedIndex;\n        this.afterTabChanged.emit({\n          currentTabIndex: newSelectedIndex\n        });\n      }, 100);\n    }\n  }\n\n  get selectedTab(): CpsTabComponent | undefined {\n    return this.tabs.find((t) => t.active);\n  }\n}\n","<ul class=\"cps-tabs\" [ngClass]=\"{ 'cps-tabs-subtabs': isSubTabs }\">\n  <ng-container *ngFor=\"let tab of tabs; let tabIndex = index\">\n    <li\n      *ngIf=\"tab.tooltipText\"\n      class=\"cps-tab\"\n      (click)=\"selectTab(tabIndex)\"\n      [ngClass]=\"{ active: tab.active }\"\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      <cps-icon *ngIf=\"tab.icon\" class=\"cps-tab-icon\" [icon]=\"tab.icon\">\n      </cps-icon>\n      <a class=\"cps-tab-link\">{{ tab.label }}</a>\n    </li>\n    <li\n      *ngIf=\"!tab.tooltipText\"\n      class=\"cps-tab\"\n      (click)=\"selectTab(tabIndex)\"\n      [ngClass]=\"{ active: tab.active }\">\n      <cps-icon *ngIf=\"tab.icon\" class=\"cps-tab-icon\" [icon]=\"tab.icon\">\n      </cps-icon>\n      <a class=\"cps-tab-link\">{{ tab.label }}</a>\n    </li>\n  </ng-container>\n</ul>\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 && !initAllTabsContent && animationType === 'slide'\">\n      <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n    </div>\n    <div\n      [@fadeInOut]=\"animationState\"\n      *ngIf=\"tab.active && !initAllTabsContent && animationType === 'fade'\">\n      <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n    </div>\n    <div\n      *ngIf=\"initAllTabsContent && animationType === 'slide'\"\n      [@slideInOut]=\"animationState\"\n      [ngStyle]=\"{ display: tab.active ? null : 'none' }\">\n      <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n    </div>\n    <div\n      *ngIf=\"initAllTabsContent && animationType === 'fade'\"\n      [@fadeInOut]=\"animationState\"\n      [ngStyle]=\"{ display: tab.active ? null : 'none' }\">\n      <ng-container [ngTemplateOutlet]=\"tab.content\"></ng-container>\n    </div>\n  </ng-container>\n</div>\n"]}
|