@seniorsistemas/angular-components 17.30.1 → 17.31.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/bundles/seniorsistemas-angular-components.umd.js +53 -31
- package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
- package/components/accordion/accordion.component.d.ts +13 -11
- package/esm2015/components/accordion/accordion.component.js +41 -31
- package/esm5/components/accordion/accordion.component.js +55 -33
- package/fesm2015/seniorsistemas-angular-components.js +40 -30
- package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
- package/fesm5/seniorsistemas-angular-components.js +54 -32
- package/fesm5/seniorsistemas-angular-components.js.map +1 -1
- package/package.json +1 -1
- package/seniorsistemas-angular-components.metadata.json +1 -1
|
@@ -1,18 +1,20 @@
|
|
|
1
|
-
import { AfterContentInit, OnChanges, QueryList, SimpleChanges, OnDestroy } from "@angular/core";
|
|
1
|
+
import { AfterContentInit, OnChanges, QueryList, SimpleChanges, OnDestroy, OnInit } from "@angular/core";
|
|
2
2
|
import { AccordionPanelComponent } from "./components/accordion-panel/accordion-panel.component";
|
|
3
|
-
export declare class AccordionComponent implements AfterContentInit, OnChanges, OnDestroy {
|
|
4
|
-
activeIndex: number;
|
|
3
|
+
export declare class AccordionComponent implements AfterContentInit, OnInit, OnChanges, OnDestroy {
|
|
4
|
+
activeIndex: number | number[];
|
|
5
5
|
multiple: boolean;
|
|
6
6
|
panelsComponents: QueryList<AccordionPanelComponent>;
|
|
7
|
-
private
|
|
8
|
-
private
|
|
9
|
-
private
|
|
7
|
+
private unsubscribe$;
|
|
8
|
+
private panels;
|
|
9
|
+
private openSubs;
|
|
10
|
+
ngOnInit(): void;
|
|
10
11
|
ngAfterContentInit(): void;
|
|
11
12
|
ngOnChanges(changes: SimpleChanges): void;
|
|
12
13
|
ngOnDestroy(): void;
|
|
13
|
-
private
|
|
14
|
-
private
|
|
15
|
-
private
|
|
16
|
-
private
|
|
17
|
-
private
|
|
14
|
+
private validateInputs;
|
|
15
|
+
private setupTabs;
|
|
16
|
+
private closeOtherTabs;
|
|
17
|
+
private setBehavior;
|
|
18
|
+
private enableSinglePanelBehavior;
|
|
19
|
+
private enableMultiplePanelBehavior;
|
|
18
20
|
}
|
|
@@ -6,66 +6,76 @@ import { takeUntil } from "rxjs/operators";
|
|
|
6
6
|
let AccordionComponent = class AccordionComponent {
|
|
7
7
|
constructor() {
|
|
8
8
|
this.multiple = false;
|
|
9
|
-
this.
|
|
10
|
-
this.
|
|
9
|
+
this.unsubscribe$ = new Subject();
|
|
10
|
+
this.panels = [];
|
|
11
|
+
}
|
|
12
|
+
ngOnInit() {
|
|
13
|
+
this.validateInputs();
|
|
11
14
|
}
|
|
12
15
|
ngAfterContentInit() {
|
|
13
|
-
this.
|
|
14
|
-
this.
|
|
15
|
-
this.
|
|
16
|
-
this.
|
|
16
|
+
this.panels = this.panelsComponents.toArray();
|
|
17
|
+
this.openSubs = new Array(this.panels.length);
|
|
18
|
+
this.setBehavior(this.multiple);
|
|
19
|
+
this.setupTabs();
|
|
17
20
|
}
|
|
18
21
|
ngOnChanges(changes) {
|
|
19
22
|
if (changes.multiple) {
|
|
20
|
-
this.
|
|
23
|
+
this.setBehavior(changes.multiple.currentValue);
|
|
21
24
|
}
|
|
22
25
|
}
|
|
23
26
|
ngOnDestroy() {
|
|
24
|
-
this.
|
|
25
|
-
this.
|
|
27
|
+
this.unsubscribe$.next();
|
|
28
|
+
this.unsubscribe$.complete();
|
|
29
|
+
}
|
|
30
|
+
validateInputs() {
|
|
31
|
+
if (!this.multiple && Array.isArray(this.activeIndex)) {
|
|
32
|
+
throw new Error("The activeIndex should not be an array when multiple is set to false.");
|
|
33
|
+
}
|
|
26
34
|
}
|
|
27
|
-
|
|
35
|
+
setupTabs() {
|
|
28
36
|
var _a;
|
|
29
|
-
if ((_a = this.
|
|
37
|
+
if ((_a = this.panels) === null || _a === void 0 ? void 0 : _a.length) {
|
|
30
38
|
if (this.activeIndex !== undefined && this.activeIndex !== null) {
|
|
31
|
-
const
|
|
32
|
-
|
|
39
|
+
const activeTabs = Array.isArray(this.activeIndex)
|
|
40
|
+
? this.panels.filter((_, index) => this.activeIndex.includes(index))
|
|
41
|
+
: [this.panels[this.activeIndex]];
|
|
42
|
+
if (activeTabs.length === 0) {
|
|
33
43
|
throw new Error("activeIndex does not represent any panel.");
|
|
34
44
|
}
|
|
35
|
-
|
|
36
|
-
|
|
45
|
+
for (const activeTab of activeTabs) {
|
|
46
|
+
if (!activeTab.disabled) {
|
|
47
|
+
activeTab.isOpen = true;
|
|
48
|
+
}
|
|
37
49
|
}
|
|
38
50
|
}
|
|
39
51
|
}
|
|
40
52
|
}
|
|
41
|
-
|
|
42
|
-
this.
|
|
53
|
+
closeOtherTabs(exception) {
|
|
54
|
+
this.panels.forEach((panel, index) => {
|
|
43
55
|
if (index !== exception) {
|
|
44
56
|
panel.isOpen = false;
|
|
45
57
|
}
|
|
46
58
|
});
|
|
47
59
|
}
|
|
48
|
-
|
|
60
|
+
setBehavior(multiple) {
|
|
49
61
|
if (multiple) {
|
|
50
|
-
this.
|
|
62
|
+
this.enableMultiplePanelBehavior();
|
|
51
63
|
}
|
|
52
64
|
else {
|
|
53
|
-
this.
|
|
65
|
+
this.enableSinglePanelBehavior();
|
|
54
66
|
}
|
|
55
67
|
}
|
|
56
|
-
|
|
57
|
-
this.
|
|
58
|
-
this.
|
|
59
|
-
.
|
|
60
|
-
.subscribe(() => {
|
|
61
|
-
this._closeOtherTabs(index);
|
|
68
|
+
enableSinglePanelBehavior() {
|
|
69
|
+
this.panels.forEach((panel, index) => {
|
|
70
|
+
this.openSubs[index] = panel.panelOpened.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {
|
|
71
|
+
this.closeOtherTabs(index);
|
|
62
72
|
});
|
|
63
73
|
});
|
|
64
74
|
}
|
|
65
|
-
|
|
66
|
-
this.
|
|
67
|
-
if (this.
|
|
68
|
-
this.
|
|
75
|
+
enableMultiplePanelBehavior() {
|
|
76
|
+
this.panels.forEach((_, index) => {
|
|
77
|
+
if (this.openSubs[index]) {
|
|
78
|
+
this.openSubs[index].unsubscribe();
|
|
69
79
|
}
|
|
70
80
|
});
|
|
71
81
|
}
|
|
@@ -87,4 +97,4 @@ AccordionComponent = __decorate([
|
|
|
87
97
|
})
|
|
88
98
|
], AccordionComponent);
|
|
89
99
|
export { AccordionComponent };
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/accordion/accordion.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, OnChanges, Component, ContentChildren, Input, QueryList, SimpleChanges, OnDestroy, OnInit } from \"@angular/core\";\n\nimport { AccordionPanelComponent } from \"./components/accordion-panel/accordion-panel.component\";\nimport { Subject, Subscription } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\n\n@Component({\n    selector: \"s-accordion\",\n    templateUrl: \"./accordion.component.html\",\n    styleUrls: [\"./accordion.component.scss\"],\n})\nexport class AccordionComponent implements AfterContentInit, OnInit, OnChanges, OnDestroy {\n    @Input()\n    public activeIndex: number | number[];\n\n    @Input()\n    public multiple = false;\n\n    @ContentChildren(AccordionPanelComponent)\n    public panelsComponents: QueryList<AccordionPanelComponent>;\n\n    private unsubscribe$ = new Subject<void>();\n    private panels: AccordionPanelComponent[] = [];\n    private openSubs: Subscription[];\n\n    ngOnInit(): void {\n        this.validateInputs();\n    }\n\n    public ngAfterContentInit(): void {\n        this.panels = this.panelsComponents.toArray();\n        this.openSubs = new Array(this.panels.length);\n\n        this.setBehavior(this.multiple);\n        this.setupTabs();\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes.multiple) {\n            this.setBehavior(changes.multiple.currentValue);\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.unsubscribe$.next();\n        this.unsubscribe$.complete();\n    }\n\n    private validateInputs(): void {\n        if (!this.multiple && Array.isArray(this.activeIndex)) {\n            throw new Error(\"The activeIndex should not be an array when multiple is set to false.\");\n        }\n    }\n\n    private setupTabs(): void {\n        if (this.panels?.length) {\n            if (this.activeIndex !== undefined && this.activeIndex !== null) {\n                const activeTabs = Array.isArray(this.activeIndex)\n                    ? this.panels.filter((_, index) => (this.activeIndex as number[]).includes(index))\n                    : [this.panels[this.activeIndex]];\n\n                if (activeTabs.length === 0) {\n                    throw new Error(\"activeIndex does not represent any panel.\");\n                }\n\n                for (const activeTab of activeTabs) {\n                    if (!activeTab.disabled) {\n                        activeTab.isOpen = true;\n                    }\n                }\n            }\n        }\n    }\n\n    private closeOtherTabs(exception: number) {\n        this.panels.forEach((panel, index) => {\n            if (index !== exception) {\n                panel.isOpen = false;\n            }\n        });\n    }\n\n    private setBehavior(multiple: boolean): void {\n        if (multiple) {\n            this.enableMultiplePanelBehavior();\n        } else {\n            this.enableSinglePanelBehavior();\n        }\n    }\n\n    private enableSinglePanelBehavior() {\n        this.panels.forEach((panel, index) => {\n            this.openSubs[index] = panel.panelOpened.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n                this.closeOtherTabs(index);\n            });\n        });\n    }\n\n    private enableMultiplePanelBehavior() {\n        this.panels.forEach((_, index) => {\n            if (this.openSubs[index]) {\n                this.openSubs[index].unsubscribe();\n            }\n        });\n    }\n}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { __decorate } from "tslib";
|
|
1
|
+
import { __decorate, __values } from "tslib";
|
|
2
2
|
import { Component, ContentChildren, Input } from "@angular/core";
|
|
3
3
|
import { AccordionPanelComponent } from "./components/accordion-panel/accordion-panel.component";
|
|
4
4
|
import { Subject } from "rxjs";
|
|
@@ -6,68 +6,90 @@ import { takeUntil } from "rxjs/operators";
|
|
|
6
6
|
var AccordionComponent = /** @class */ (function () {
|
|
7
7
|
function AccordionComponent() {
|
|
8
8
|
this.multiple = false;
|
|
9
|
-
this.
|
|
10
|
-
this.
|
|
9
|
+
this.unsubscribe$ = new Subject();
|
|
10
|
+
this.panels = [];
|
|
11
11
|
}
|
|
12
|
+
AccordionComponent.prototype.ngOnInit = function () {
|
|
13
|
+
this.validateInputs();
|
|
14
|
+
};
|
|
12
15
|
AccordionComponent.prototype.ngAfterContentInit = function () {
|
|
13
|
-
this.
|
|
14
|
-
this.
|
|
15
|
-
this.
|
|
16
|
-
this.
|
|
16
|
+
this.panels = this.panelsComponents.toArray();
|
|
17
|
+
this.openSubs = new Array(this.panels.length);
|
|
18
|
+
this.setBehavior(this.multiple);
|
|
19
|
+
this.setupTabs();
|
|
17
20
|
};
|
|
18
21
|
AccordionComponent.prototype.ngOnChanges = function (changes) {
|
|
19
22
|
if (changes.multiple) {
|
|
20
|
-
this.
|
|
23
|
+
this.setBehavior(changes.multiple.currentValue);
|
|
21
24
|
}
|
|
22
25
|
};
|
|
23
26
|
AccordionComponent.prototype.ngOnDestroy = function () {
|
|
24
|
-
this.
|
|
25
|
-
this.
|
|
27
|
+
this.unsubscribe$.next();
|
|
28
|
+
this.unsubscribe$.complete();
|
|
29
|
+
};
|
|
30
|
+
AccordionComponent.prototype.validateInputs = function () {
|
|
31
|
+
if (!this.multiple && Array.isArray(this.activeIndex)) {
|
|
32
|
+
throw new Error("The activeIndex should not be an array when multiple is set to false.");
|
|
33
|
+
}
|
|
26
34
|
};
|
|
27
|
-
AccordionComponent.prototype.
|
|
28
|
-
var _a;
|
|
29
|
-
|
|
35
|
+
AccordionComponent.prototype.setupTabs = function () {
|
|
36
|
+
var e_1, _a;
|
|
37
|
+
var _this = this;
|
|
38
|
+
var _b;
|
|
39
|
+
if ((_b = this.panels) === null || _b === void 0 ? void 0 : _b.length) {
|
|
30
40
|
if (this.activeIndex !== undefined && this.activeIndex !== null) {
|
|
31
|
-
var
|
|
32
|
-
|
|
41
|
+
var activeTabs = Array.isArray(this.activeIndex)
|
|
42
|
+
? this.panels.filter(function (_, index) { return _this.activeIndex.includes(index); })
|
|
43
|
+
: [this.panels[this.activeIndex]];
|
|
44
|
+
if (activeTabs.length === 0) {
|
|
33
45
|
throw new Error("activeIndex does not represent any panel.");
|
|
34
46
|
}
|
|
35
|
-
|
|
36
|
-
|
|
47
|
+
try {
|
|
48
|
+
for (var activeTabs_1 = __values(activeTabs), activeTabs_1_1 = activeTabs_1.next(); !activeTabs_1_1.done; activeTabs_1_1 = activeTabs_1.next()) {
|
|
49
|
+
var activeTab = activeTabs_1_1.value;
|
|
50
|
+
if (!activeTab.disabled) {
|
|
51
|
+
activeTab.isOpen = true;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
56
|
+
finally {
|
|
57
|
+
try {
|
|
58
|
+
if (activeTabs_1_1 && !activeTabs_1_1.done && (_a = activeTabs_1.return)) _a.call(activeTabs_1);
|
|
59
|
+
}
|
|
60
|
+
finally { if (e_1) throw e_1.error; }
|
|
37
61
|
}
|
|
38
62
|
}
|
|
39
63
|
}
|
|
40
64
|
};
|
|
41
|
-
AccordionComponent.prototype.
|
|
42
|
-
this.
|
|
65
|
+
AccordionComponent.prototype.closeOtherTabs = function (exception) {
|
|
66
|
+
this.panels.forEach(function (panel, index) {
|
|
43
67
|
if (index !== exception) {
|
|
44
68
|
panel.isOpen = false;
|
|
45
69
|
}
|
|
46
70
|
});
|
|
47
71
|
};
|
|
48
|
-
AccordionComponent.prototype.
|
|
72
|
+
AccordionComponent.prototype.setBehavior = function (multiple) {
|
|
49
73
|
if (multiple) {
|
|
50
|
-
this.
|
|
74
|
+
this.enableMultiplePanelBehavior();
|
|
51
75
|
}
|
|
52
76
|
else {
|
|
53
|
-
this.
|
|
77
|
+
this.enableSinglePanelBehavior();
|
|
54
78
|
}
|
|
55
79
|
};
|
|
56
|
-
AccordionComponent.prototype.
|
|
80
|
+
AccordionComponent.prototype.enableSinglePanelBehavior = function () {
|
|
57
81
|
var _this = this;
|
|
58
|
-
this.
|
|
59
|
-
_this.
|
|
60
|
-
.
|
|
61
|
-
.subscribe(function () {
|
|
62
|
-
_this._closeOtherTabs(index);
|
|
82
|
+
this.panels.forEach(function (panel, index) {
|
|
83
|
+
_this.openSubs[index] = panel.panelOpened.pipe(takeUntil(_this.unsubscribe$)).subscribe(function () {
|
|
84
|
+
_this.closeOtherTabs(index);
|
|
63
85
|
});
|
|
64
86
|
});
|
|
65
87
|
};
|
|
66
|
-
AccordionComponent.prototype.
|
|
88
|
+
AccordionComponent.prototype.enableMultiplePanelBehavior = function () {
|
|
67
89
|
var _this = this;
|
|
68
|
-
this.
|
|
69
|
-
if (_this.
|
|
70
|
-
_this.
|
|
90
|
+
this.panels.forEach(function (_, index) {
|
|
91
|
+
if (_this.openSubs[index]) {
|
|
92
|
+
_this.openSubs[index].unsubscribe();
|
|
71
93
|
}
|
|
72
94
|
});
|
|
73
95
|
};
|
|
@@ -90,4 +112,4 @@ var AccordionComponent = /** @class */ (function () {
|
|
|
90
112
|
return AccordionComponent;
|
|
91
113
|
}());
|
|
92
114
|
export { AccordionComponent };
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/accordion/accordion.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, OnChanges, Component, ContentChildren, Input, QueryList, SimpleChanges, OnDestroy, OnInit } from \"@angular/core\";\n\nimport { AccordionPanelComponent } from \"./components/accordion-panel/accordion-panel.component\";\nimport { Subject, Subscription } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\n\n@Component({\n    selector: \"s-accordion\",\n    templateUrl: \"./accordion.component.html\",\n    styleUrls: [\"./accordion.component.scss\"],\n})\nexport class AccordionComponent implements AfterContentInit, OnInit, OnChanges, OnDestroy {\n    @Input()\n    public activeIndex: number | number[];\n\n    @Input()\n    public multiple = false;\n\n    @ContentChildren(AccordionPanelComponent)\n    public panelsComponents: QueryList<AccordionPanelComponent>;\n\n    private unsubscribe$ = new Subject<void>();\n    private panels: AccordionPanelComponent[] = [];\n    private openSubs: Subscription[];\n\n    ngOnInit(): void {\n        this.validateInputs();\n    }\n\n    public ngAfterContentInit(): void {\n        this.panels = this.panelsComponents.toArray();\n        this.openSubs = new Array(this.panels.length);\n\n        this.setBehavior(this.multiple);\n        this.setupTabs();\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes.multiple) {\n            this.setBehavior(changes.multiple.currentValue);\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.unsubscribe$.next();\n        this.unsubscribe$.complete();\n    }\n\n    private validateInputs(): void {\n        if (!this.multiple && Array.isArray(this.activeIndex)) {\n            throw new Error(\"The activeIndex should not be an array when multiple is set to false.\");\n        }\n    }\n\n    private setupTabs(): void {\n        if (this.panels?.length) {\n            if (this.activeIndex !== undefined && this.activeIndex !== null) {\n                const activeTabs = Array.isArray(this.activeIndex)\n                    ? this.panels.filter((_, index) => (this.activeIndex as number[]).includes(index))\n                    : [this.panels[this.activeIndex]];\n\n                if (activeTabs.length === 0) {\n                    throw new Error(\"activeIndex does not represent any panel.\");\n                }\n\n                for (const activeTab of activeTabs) {\n                    if (!activeTab.disabled) {\n                        activeTab.isOpen = true;\n                    }\n                }\n            }\n        }\n    }\n\n    private closeOtherTabs(exception: number) {\n        this.panels.forEach((panel, index) => {\n            if (index !== exception) {\n                panel.isOpen = false;\n            }\n        });\n    }\n\n    private setBehavior(multiple: boolean): void {\n        if (multiple) {\n            this.enableMultiplePanelBehavior();\n        } else {\n            this.enableSinglePanelBehavior();\n        }\n    }\n\n    private enableSinglePanelBehavior() {\n        this.panels.forEach((panel, index) => {\n            this.openSubs[index] = panel.panelOpened.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n                this.closeOtherTabs(index);\n            });\n        });\n    }\n\n    private enableMultiplePanelBehavior() {\n        this.panels.forEach((_, index) => {\n            if (this.openSubs[index]) {\n                this.openSubs[index].unsubscribe();\n            }\n        });\n    }\n}\n"]}
|
|
@@ -176,66 +176,76 @@ AccordionPanelComponent = __decorate([
|
|
|
176
176
|
let AccordionComponent = class AccordionComponent {
|
|
177
177
|
constructor() {
|
|
178
178
|
this.multiple = false;
|
|
179
|
-
this.
|
|
180
|
-
this.
|
|
179
|
+
this.unsubscribe$ = new Subject();
|
|
180
|
+
this.panels = [];
|
|
181
|
+
}
|
|
182
|
+
ngOnInit() {
|
|
183
|
+
this.validateInputs();
|
|
181
184
|
}
|
|
182
185
|
ngAfterContentInit() {
|
|
183
|
-
this.
|
|
184
|
-
this.
|
|
185
|
-
this.
|
|
186
|
-
this.
|
|
186
|
+
this.panels = this.panelsComponents.toArray();
|
|
187
|
+
this.openSubs = new Array(this.panels.length);
|
|
188
|
+
this.setBehavior(this.multiple);
|
|
189
|
+
this.setupTabs();
|
|
187
190
|
}
|
|
188
191
|
ngOnChanges(changes) {
|
|
189
192
|
if (changes.multiple) {
|
|
190
|
-
this.
|
|
193
|
+
this.setBehavior(changes.multiple.currentValue);
|
|
191
194
|
}
|
|
192
195
|
}
|
|
193
196
|
ngOnDestroy() {
|
|
194
|
-
this.
|
|
195
|
-
this.
|
|
197
|
+
this.unsubscribe$.next();
|
|
198
|
+
this.unsubscribe$.complete();
|
|
196
199
|
}
|
|
197
|
-
|
|
200
|
+
validateInputs() {
|
|
201
|
+
if (!this.multiple && Array.isArray(this.activeIndex)) {
|
|
202
|
+
throw new Error("The activeIndex should not be an array when multiple is set to false.");
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
setupTabs() {
|
|
198
206
|
var _a;
|
|
199
|
-
if ((_a = this.
|
|
207
|
+
if ((_a = this.panels) === null || _a === void 0 ? void 0 : _a.length) {
|
|
200
208
|
if (this.activeIndex !== undefined && this.activeIndex !== null) {
|
|
201
|
-
const
|
|
202
|
-
|
|
209
|
+
const activeTabs = Array.isArray(this.activeIndex)
|
|
210
|
+
? this.panels.filter((_, index) => this.activeIndex.includes(index))
|
|
211
|
+
: [this.panels[this.activeIndex]];
|
|
212
|
+
if (activeTabs.length === 0) {
|
|
203
213
|
throw new Error("activeIndex does not represent any panel.");
|
|
204
214
|
}
|
|
205
|
-
|
|
206
|
-
|
|
215
|
+
for (const activeTab of activeTabs) {
|
|
216
|
+
if (!activeTab.disabled) {
|
|
217
|
+
activeTab.isOpen = true;
|
|
218
|
+
}
|
|
207
219
|
}
|
|
208
220
|
}
|
|
209
221
|
}
|
|
210
222
|
}
|
|
211
|
-
|
|
212
|
-
this.
|
|
223
|
+
closeOtherTabs(exception) {
|
|
224
|
+
this.panels.forEach((panel, index) => {
|
|
213
225
|
if (index !== exception) {
|
|
214
226
|
panel.isOpen = false;
|
|
215
227
|
}
|
|
216
228
|
});
|
|
217
229
|
}
|
|
218
|
-
|
|
230
|
+
setBehavior(multiple) {
|
|
219
231
|
if (multiple) {
|
|
220
|
-
this.
|
|
232
|
+
this.enableMultiplePanelBehavior();
|
|
221
233
|
}
|
|
222
234
|
else {
|
|
223
|
-
this.
|
|
235
|
+
this.enableSinglePanelBehavior();
|
|
224
236
|
}
|
|
225
237
|
}
|
|
226
|
-
|
|
227
|
-
this.
|
|
228
|
-
this.
|
|
229
|
-
.
|
|
230
|
-
.subscribe(() => {
|
|
231
|
-
this._closeOtherTabs(index);
|
|
238
|
+
enableSinglePanelBehavior() {
|
|
239
|
+
this.panels.forEach((panel, index) => {
|
|
240
|
+
this.openSubs[index] = panel.panelOpened.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {
|
|
241
|
+
this.closeOtherTabs(index);
|
|
232
242
|
});
|
|
233
243
|
});
|
|
234
244
|
}
|
|
235
|
-
|
|
236
|
-
this.
|
|
237
|
-
if (this.
|
|
238
|
-
this.
|
|
245
|
+
enableMultiplePanelBehavior() {
|
|
246
|
+
this.panels.forEach((_, index) => {
|
|
247
|
+
if (this.openSubs[index]) {
|
|
248
|
+
this.openSubs[index].unsubscribe();
|
|
239
249
|
}
|
|
240
250
|
});
|
|
241
251
|
}
|