@seniorsistemas/angular-components 17.6.1 → 17.6.3
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 +57 -4
- 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/select-button/select-button.component.d.ts +2 -1
- package/esm2015/components/select-button/select-button.component.js +47 -5
- package/esm5/components/select-button/select-button.component.js +59 -6
- package/fesm2015/seniorsistemas-angular-components.js +46 -4
- package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
- package/fesm5/seniorsistemas-angular-components.js +57 -4
- package/fesm5/seniorsistemas-angular-components.js.map +1 -1
- package/package.json +1 -1
- package/seniorsistemas-angular-components.metadata.json +1 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { EventEmitter } from "@angular/core";
|
|
2
|
-
import { SelectButtonItem } from "./models";
|
|
3
2
|
import { ControlValueAccessor } from "@angular/forms";
|
|
3
|
+
import { SelectButtonItem } from "./models";
|
|
4
4
|
export declare class SelectButtonComponent implements ControlValueAccessor {
|
|
5
5
|
items: SelectButtonItem[];
|
|
6
6
|
multiple: boolean;
|
|
@@ -15,4 +15,5 @@ export declare class SelectButtonComponent implements ControlValueAccessor {
|
|
|
15
15
|
registerOnTouched(onTouched: (value: SelectButtonItem[]) => void): void;
|
|
16
16
|
setDisabledState(disabled: boolean): void;
|
|
17
17
|
onItemSelect(item: SelectButtonItem): void;
|
|
18
|
+
private _compareItems;
|
|
18
19
|
}
|
|
@@ -15,10 +15,20 @@ let SelectButtonComponent = SelectButtonComponent_1 = class SelectButtonComponen
|
|
|
15
15
|
return;
|
|
16
16
|
this.activeItems.clear();
|
|
17
17
|
if (Array.isArray(value)) {
|
|
18
|
-
value.forEach((item) =>
|
|
18
|
+
value.forEach((item) => {
|
|
19
|
+
this.items.forEach((iItem) => {
|
|
20
|
+
if (this._compareItems(item, iItem)) {
|
|
21
|
+
this.activeItems.add(iItem);
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
});
|
|
19
25
|
}
|
|
20
26
|
else {
|
|
21
|
-
this.
|
|
27
|
+
this.items.forEach((iItem) => {
|
|
28
|
+
if (this._compareItems(value, iItem)) {
|
|
29
|
+
this.activeItems.add(iItem);
|
|
30
|
+
}
|
|
31
|
+
});
|
|
22
32
|
}
|
|
23
33
|
}
|
|
24
34
|
registerOnChange(onChange) {
|
|
@@ -43,6 +53,36 @@ let SelectButtonComponent = SelectButtonComponent_1 = class SelectButtonComponen
|
|
|
43
53
|
(_a = this.onChange) === null || _a === void 0 ? void 0 : _a.call(this, [...this.activeItems]);
|
|
44
54
|
(_b = this.onTouched) === null || _b === void 0 ? void 0 : _b.call(this, [...this.activeItems]);
|
|
45
55
|
}
|
|
56
|
+
_compareItems(item1, item2) {
|
|
57
|
+
const _compare = (a, b) => {
|
|
58
|
+
if (a === b) {
|
|
59
|
+
return true;
|
|
60
|
+
}
|
|
61
|
+
if (a === undefined || b === undefined || typeof a !== "object" || a === null || typeof b !== "object" || b === null) {
|
|
62
|
+
return false;
|
|
63
|
+
}
|
|
64
|
+
if (Array.isArray(a) !== Array.isArray(b)) {
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
let keysA = Object.keys(a);
|
|
68
|
+
let keysB = Object.keys(b);
|
|
69
|
+
if (keysA.length !== keysB.length) {
|
|
70
|
+
return false;
|
|
71
|
+
}
|
|
72
|
+
for (let key of keysA) {
|
|
73
|
+
if (!keysB.includes(key) || !_compare(a[key], b[key])) {
|
|
74
|
+
return false;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
for (let key in a) {
|
|
78
|
+
if (a.hasOwnProperty(key) !== b.hasOwnProperty(key)) {
|
|
79
|
+
return false;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
return true;
|
|
83
|
+
};
|
|
84
|
+
return _compare(item1, item2);
|
|
85
|
+
}
|
|
46
86
|
};
|
|
47
87
|
__decorate([
|
|
48
88
|
Input()
|
|
@@ -60,13 +100,15 @@ SelectButtonComponent = SelectButtonComponent_1 = __decorate([
|
|
|
60
100
|
Component({
|
|
61
101
|
selector: "s-select-button",
|
|
62
102
|
template: "<div\n class=\"select-button\"\n [ngClass]=\"{ 'select-button--disabled': disabled }\">\n <s-select-button-item\n *ngFor=\"let item of items; index as i\"\n [label]=\"item.label\"\n [active]=\"activeItems?.has(item)\"\n [disabled]=\"disabled || item.disabled\"\n [first]=\"i === 0\"\n [last]=\"i === items.length - 1\"\n (click)=\"onItemSelect(item)\">\n </s-select-button-item>\n</div>",
|
|
63
|
-
providers: [
|
|
103
|
+
providers: [
|
|
104
|
+
{
|
|
64
105
|
provide: NG_VALUE_ACCESSOR,
|
|
65
106
|
useExisting: forwardRef(() => SelectButtonComponent_1),
|
|
66
107
|
multi: true,
|
|
67
|
-
}
|
|
108
|
+
},
|
|
109
|
+
],
|
|
68
110
|
styles: [".select-button{overflow:hidden}"]
|
|
69
111
|
})
|
|
70
112
|
], SelectButtonComponent);
|
|
71
113
|
export { SelectButtonComponent };
|
|
72
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
114
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-button.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/select-button/select-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, forwardRef } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\nimport { SelectButtonItem } from \"./models\";\n\n@Component({\n    selector: \"s-select-button\",\n    templateUrl: \"./select-button.component.html\",\n    styleUrls: [\"./select-button.component.scss\"],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => SelectButtonComponent),\n            multi: true,\n        },\n    ],\n})\nexport class SelectButtonComponent implements ControlValueAccessor {\n    @Input()\n    public items: SelectButtonItem[];\n\n    @Input()\n    public multiple = false;\n\n    @Output()\n    public itemSelected = new EventEmitter<SelectButtonItem[]>();\n\n    @Output()\n    public itemClicked = new EventEmitter<SelectButtonItem>();\n\n    public disabled = false;\n    public activeItems = new Set<SelectButtonItem>();\n    public onChange: (value: SelectButtonItem[]) => void;\n    public onTouched: (value: SelectButtonItem[]) => void;\n\n    public writeValue(value?: SelectButtonItem | SelectButtonItem[]): void {\n        if (!value) return;\n\n        this.activeItems.clear();\n\n        if (Array.isArray(value)) {\n            value.forEach((item: SelectButtonItem) => {\n                this.items.forEach((iItem: SelectButtonItem) => {\n                    if (this._compareItems(item, iItem)) {\n                        this.activeItems.add(iItem);\n                    }\n                });\n            });\n        } else {\n            this.items.forEach((iItem: SelectButtonItem) => {\n                if (this._compareItems(value, iItem)) {\n                    this.activeItems.add(iItem);\n                }\n            });\n        }\n    }\n\n    public registerOnChange(onChange: (value: SelectButtonItem[]) => void): void {\n        this.onChange = onChange;\n    }\n\n    public registerOnTouched(onTouched: (value: SelectButtonItem[]) => void): void {\n        this.onTouched = onTouched;\n    }\n\n    public setDisabledState(disabled: boolean): void {\n        this.disabled = disabled;\n    }\n\n    public onItemSelect(item: SelectButtonItem): void {\n        if (this.disabled || item.disabled) return;\n\n        this.itemClicked.emit(item);\n\n        if (!this.multiple) {\n            this.activeItems.clear();\n        }\n        this.activeItems.add(item);\n        this.itemSelected.emit([...this.activeItems]);\n\n        this.onChange?.([...this.activeItems]);\n        this.onTouched?.([...this.activeItems]);\n    }\n\n    private _compareItems(item1: SelectButtonItem, item2: SelectButtonItem): boolean {\n        const _compare = (a: any, b: any): boolean => {\n            if (a === b) {\n                return true;\n            }\n\n            if (a === undefined || b === undefined || typeof a !== \"object\" || a === null || typeof b !== \"object\" || b === null) {\n                return false;\n            }\n\n            if (Array.isArray(a) !== Array.isArray(b)) {\n                return false;\n            }\n\n            let keysA = Object.keys(a);\n            let keysB = Object.keys(b);\n\n            if (keysA.length !== keysB.length) {\n                return false;\n            }\n\n            for (let key of keysA) {\n                if (!keysB.includes(key) || !_compare(a[key], b[key])) {\n                    return false;\n                }\n            }\n\n            for (let key in a) {\n                if (a.hasOwnProperty(key) !== b.hasOwnProperty(key)) {\n                    return false;\n                }\n            }\n\n            return true;\n        };\n\n        return _compare(item1, item2);\n    }\n}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { __decorate, __read, __spread } from "tslib";
|
|
1
|
+
import { __decorate, __read, __spread, __values } from "tslib";
|
|
2
2
|
import { Component, EventEmitter, Input, Output, forwardRef } from "@angular/core";
|
|
3
3
|
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
4
4
|
var SelectButtonComponent = /** @class */ (function () {
|
|
@@ -16,10 +16,20 @@ var SelectButtonComponent = /** @class */ (function () {
|
|
|
16
16
|
return;
|
|
17
17
|
this.activeItems.clear();
|
|
18
18
|
if (Array.isArray(value)) {
|
|
19
|
-
value.forEach(function (item) {
|
|
19
|
+
value.forEach(function (item) {
|
|
20
|
+
_this.items.forEach(function (iItem) {
|
|
21
|
+
if (_this._compareItems(item, iItem)) {
|
|
22
|
+
_this.activeItems.add(iItem);
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
});
|
|
20
26
|
}
|
|
21
27
|
else {
|
|
22
|
-
this.
|
|
28
|
+
this.items.forEach(function (iItem) {
|
|
29
|
+
if (_this._compareItems(value, iItem)) {
|
|
30
|
+
_this.activeItems.add(iItem);
|
|
31
|
+
}
|
|
32
|
+
});
|
|
23
33
|
}
|
|
24
34
|
};
|
|
25
35
|
SelectButtonComponent.prototype.registerOnChange = function (onChange) {
|
|
@@ -44,6 +54,47 @@ var SelectButtonComponent = /** @class */ (function () {
|
|
|
44
54
|
(_a = this.onChange) === null || _a === void 0 ? void 0 : _a.call(this, __spread(this.activeItems));
|
|
45
55
|
(_b = this.onTouched) === null || _b === void 0 ? void 0 : _b.call(this, __spread(this.activeItems));
|
|
46
56
|
};
|
|
57
|
+
SelectButtonComponent.prototype._compareItems = function (item1, item2) {
|
|
58
|
+
var _compare = function (a, b) {
|
|
59
|
+
var e_1, _a;
|
|
60
|
+
if (a === b) {
|
|
61
|
+
return true;
|
|
62
|
+
}
|
|
63
|
+
if (a === undefined || b === undefined || typeof a !== "object" || a === null || typeof b !== "object" || b === null) {
|
|
64
|
+
return false;
|
|
65
|
+
}
|
|
66
|
+
if (Array.isArray(a) !== Array.isArray(b)) {
|
|
67
|
+
return false;
|
|
68
|
+
}
|
|
69
|
+
var keysA = Object.keys(a);
|
|
70
|
+
var keysB = Object.keys(b);
|
|
71
|
+
if (keysA.length !== keysB.length) {
|
|
72
|
+
return false;
|
|
73
|
+
}
|
|
74
|
+
try {
|
|
75
|
+
for (var keysA_1 = __values(keysA), keysA_1_1 = keysA_1.next(); !keysA_1_1.done; keysA_1_1 = keysA_1.next()) {
|
|
76
|
+
var key = keysA_1_1.value;
|
|
77
|
+
if (!keysB.includes(key) || !_compare(a[key], b[key])) {
|
|
78
|
+
return false;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
83
|
+
finally {
|
|
84
|
+
try {
|
|
85
|
+
if (keysA_1_1 && !keysA_1_1.done && (_a = keysA_1.return)) _a.call(keysA_1);
|
|
86
|
+
}
|
|
87
|
+
finally { if (e_1) throw e_1.error; }
|
|
88
|
+
}
|
|
89
|
+
for (var key in a) {
|
|
90
|
+
if (a.hasOwnProperty(key) !== b.hasOwnProperty(key)) {
|
|
91
|
+
return false;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
return true;
|
|
95
|
+
};
|
|
96
|
+
return _compare(item1, item2);
|
|
97
|
+
};
|
|
47
98
|
var SelectButtonComponent_1;
|
|
48
99
|
__decorate([
|
|
49
100
|
Input()
|
|
@@ -61,15 +112,17 @@ var SelectButtonComponent = /** @class */ (function () {
|
|
|
61
112
|
Component({
|
|
62
113
|
selector: "s-select-button",
|
|
63
114
|
template: "<div\n class=\"select-button\"\n [ngClass]=\"{ 'select-button--disabled': disabled }\">\n <s-select-button-item\n *ngFor=\"let item of items; index as i\"\n [label]=\"item.label\"\n [active]=\"activeItems?.has(item)\"\n [disabled]=\"disabled || item.disabled\"\n [first]=\"i === 0\"\n [last]=\"i === items.length - 1\"\n (click)=\"onItemSelect(item)\">\n </s-select-button-item>\n</div>",
|
|
64
|
-
providers: [
|
|
115
|
+
providers: [
|
|
116
|
+
{
|
|
65
117
|
provide: NG_VALUE_ACCESSOR,
|
|
66
118
|
useExisting: forwardRef(function () { return SelectButtonComponent_1; }),
|
|
67
119
|
multi: true,
|
|
68
|
-
}
|
|
120
|
+
},
|
|
121
|
+
],
|
|
69
122
|
styles: [".select-button{overflow:hidden}"]
|
|
70
123
|
})
|
|
71
124
|
], SelectButtonComponent);
|
|
72
125
|
return SelectButtonComponent;
|
|
73
126
|
}());
|
|
74
127
|
export { SelectButtonComponent };
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-button.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/select-button/select-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, forwardRef } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\nimport { SelectButtonItem } from \"./models\";\n\n@Component({\n    selector: \"s-select-button\",\n    templateUrl: \"./select-button.component.html\",\n    styleUrls: [\"./select-button.component.scss\"],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => SelectButtonComponent),\n            multi: true,\n        },\n    ],\n})\nexport class SelectButtonComponent implements ControlValueAccessor {\n    @Input()\n    public items: SelectButtonItem[];\n\n    @Input()\n    public multiple = false;\n\n    @Output()\n    public itemSelected = new EventEmitter<SelectButtonItem[]>();\n\n    @Output()\n    public itemClicked = new EventEmitter<SelectButtonItem>();\n\n    public disabled = false;\n    public activeItems = new Set<SelectButtonItem>();\n    public onChange: (value: SelectButtonItem[]) => void;\n    public onTouched: (value: SelectButtonItem[]) => void;\n\n    public writeValue(value?: SelectButtonItem | SelectButtonItem[]): void {\n        if (!value) return;\n\n        this.activeItems.clear();\n\n        if (Array.isArray(value)) {\n            value.forEach((item: SelectButtonItem) => {\n                this.items.forEach((iItem: SelectButtonItem) => {\n                    if (this._compareItems(item, iItem)) {\n                        this.activeItems.add(iItem);\n                    }\n                });\n            });\n        } else {\n            this.items.forEach((iItem: SelectButtonItem) => {\n                if (this._compareItems(value, iItem)) {\n                    this.activeItems.add(iItem);\n                }\n            });\n        }\n    }\n\n    public registerOnChange(onChange: (value: SelectButtonItem[]) => void): void {\n        this.onChange = onChange;\n    }\n\n    public registerOnTouched(onTouched: (value: SelectButtonItem[]) => void): void {\n        this.onTouched = onTouched;\n    }\n\n    public setDisabledState(disabled: boolean): void {\n        this.disabled = disabled;\n    }\n\n    public onItemSelect(item: SelectButtonItem): void {\n        if (this.disabled || item.disabled) return;\n\n        this.itemClicked.emit(item);\n\n        if (!this.multiple) {\n            this.activeItems.clear();\n        }\n        this.activeItems.add(item);\n        this.itemSelected.emit([...this.activeItems]);\n\n        this.onChange?.([...this.activeItems]);\n        this.onTouched?.([...this.activeItems]);\n    }\n\n    private _compareItems(item1: SelectButtonItem, item2: SelectButtonItem): boolean {\n        const _compare = (a: any, b: any): boolean => {\n            if (a === b) {\n                return true;\n            }\n\n            if (a === undefined || b === undefined || typeof a !== \"object\" || a === null || typeof b !== \"object\" || b === null) {\n                return false;\n            }\n\n            if (Array.isArray(a) !== Array.isArray(b)) {\n                return false;\n            }\n\n            let keysA = Object.keys(a);\n            let keysB = Object.keys(b);\n\n            if (keysA.length !== keysB.length) {\n                return false;\n            }\n\n            for (let key of keysA) {\n                if (!keysB.includes(key) || !_compare(a[key], b[key])) {\n                    return false;\n                }\n            }\n\n            for (let key in a) {\n                if (a.hasOwnProperty(key) !== b.hasOwnProperty(key)) {\n                    return false;\n                }\n            }\n\n            return true;\n        };\n\n        return _compare(item1, item2);\n    }\n}\n"]}
|
|
@@ -14263,10 +14263,20 @@ let SelectButtonComponent = SelectButtonComponent_1 = class SelectButtonComponen
|
|
|
14263
14263
|
return;
|
|
14264
14264
|
this.activeItems.clear();
|
|
14265
14265
|
if (Array.isArray(value)) {
|
|
14266
|
-
value.forEach((item) =>
|
|
14266
|
+
value.forEach((item) => {
|
|
14267
|
+
this.items.forEach((iItem) => {
|
|
14268
|
+
if (this._compareItems(item, iItem)) {
|
|
14269
|
+
this.activeItems.add(iItem);
|
|
14270
|
+
}
|
|
14271
|
+
});
|
|
14272
|
+
});
|
|
14267
14273
|
}
|
|
14268
14274
|
else {
|
|
14269
|
-
this.
|
|
14275
|
+
this.items.forEach((iItem) => {
|
|
14276
|
+
if (this._compareItems(value, iItem)) {
|
|
14277
|
+
this.activeItems.add(iItem);
|
|
14278
|
+
}
|
|
14279
|
+
});
|
|
14270
14280
|
}
|
|
14271
14281
|
}
|
|
14272
14282
|
registerOnChange(onChange) {
|
|
@@ -14291,6 +14301,36 @@ let SelectButtonComponent = SelectButtonComponent_1 = class SelectButtonComponen
|
|
|
14291
14301
|
(_a = this.onChange) === null || _a === void 0 ? void 0 : _a.call(this, [...this.activeItems]);
|
|
14292
14302
|
(_b = this.onTouched) === null || _b === void 0 ? void 0 : _b.call(this, [...this.activeItems]);
|
|
14293
14303
|
}
|
|
14304
|
+
_compareItems(item1, item2) {
|
|
14305
|
+
const _compare = (a, b) => {
|
|
14306
|
+
if (a === b) {
|
|
14307
|
+
return true;
|
|
14308
|
+
}
|
|
14309
|
+
if (a === undefined || b === undefined || typeof a !== "object" || a === null || typeof b !== "object" || b === null) {
|
|
14310
|
+
return false;
|
|
14311
|
+
}
|
|
14312
|
+
if (Array.isArray(a) !== Array.isArray(b)) {
|
|
14313
|
+
return false;
|
|
14314
|
+
}
|
|
14315
|
+
let keysA = Object.keys(a);
|
|
14316
|
+
let keysB = Object.keys(b);
|
|
14317
|
+
if (keysA.length !== keysB.length) {
|
|
14318
|
+
return false;
|
|
14319
|
+
}
|
|
14320
|
+
for (let key of keysA) {
|
|
14321
|
+
if (!keysB.includes(key) || !_compare(a[key], b[key])) {
|
|
14322
|
+
return false;
|
|
14323
|
+
}
|
|
14324
|
+
}
|
|
14325
|
+
for (let key in a) {
|
|
14326
|
+
if (a.hasOwnProperty(key) !== b.hasOwnProperty(key)) {
|
|
14327
|
+
return false;
|
|
14328
|
+
}
|
|
14329
|
+
}
|
|
14330
|
+
return true;
|
|
14331
|
+
};
|
|
14332
|
+
return _compare(item1, item2);
|
|
14333
|
+
}
|
|
14294
14334
|
};
|
|
14295
14335
|
__decorate([
|
|
14296
14336
|
Input()
|
|
@@ -14308,11 +14348,13 @@ SelectButtonComponent = SelectButtonComponent_1 = __decorate([
|
|
|
14308
14348
|
Component({
|
|
14309
14349
|
selector: "s-select-button",
|
|
14310
14350
|
template: "<div\n class=\"select-button\"\n [ngClass]=\"{ 'select-button--disabled': disabled }\">\n <s-select-button-item\n *ngFor=\"let item of items; index as i\"\n [label]=\"item.label\"\n [active]=\"activeItems?.has(item)\"\n [disabled]=\"disabled || item.disabled\"\n [first]=\"i === 0\"\n [last]=\"i === items.length - 1\"\n (click)=\"onItemSelect(item)\">\n </s-select-button-item>\n</div>",
|
|
14311
|
-
providers: [
|
|
14351
|
+
providers: [
|
|
14352
|
+
{
|
|
14312
14353
|
provide: NG_VALUE_ACCESSOR,
|
|
14313
14354
|
useExisting: forwardRef(() => SelectButtonComponent_1),
|
|
14314
14355
|
multi: true,
|
|
14315
|
-
}
|
|
14356
|
+
},
|
|
14357
|
+
],
|
|
14316
14358
|
styles: [".select-button{overflow:hidden}"]
|
|
14317
14359
|
})
|
|
14318
14360
|
], SelectButtonComponent);
|