@seniorsistemas/angular-components 17.6.0 → 17.6.2
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 +54 -5
- 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 +3 -2
- package/esm2015/components/select-button/select-button.component.js +44 -6
- package/esm5/components/select-button/select-button.component.js +56 -7
- package/fesm2015/seniorsistemas-angular-components.js +43 -5
- package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
- package/fesm5/seniorsistemas-angular-components.js +54 -5
- 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;
|
|
@@ -10,9 +10,10 @@ export declare class SelectButtonComponent implements ControlValueAccessor {
|
|
|
10
10
|
activeItems: Set<SelectButtonItem>;
|
|
11
11
|
onChange: (value: SelectButtonItem[]) => void;
|
|
12
12
|
onTouched: (value: SelectButtonItem[]) => void;
|
|
13
|
-
writeValue(value?: SelectButtonItem[]): void;
|
|
13
|
+
writeValue(value?: SelectButtonItem | SelectButtonItem[]): void;
|
|
14
14
|
registerOnChange(onChange: (value: SelectButtonItem[]) => void): void;
|
|
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
|
}
|
|
@@ -13,9 +13,23 @@ let SelectButtonComponent = SelectButtonComponent_1 = class SelectButtonComponen
|
|
|
13
13
|
writeValue(value) {
|
|
14
14
|
if (!value)
|
|
15
15
|
return;
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
16
|
+
this.activeItems.clear();
|
|
17
|
+
if (Array.isArray(value)) {
|
|
18
|
+
value.forEach((item) => {
|
|
19
|
+
this.items.forEach((iItem) => {
|
|
20
|
+
if (this._compareItems(item, iItem)) {
|
|
21
|
+
this.activeItems.add(iItem);
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
this.items.forEach((iItem) => {
|
|
28
|
+
if (this._compareItems(value, iItem)) {
|
|
29
|
+
this.activeItems.add(iItem);
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
}
|
|
19
33
|
}
|
|
20
34
|
registerOnChange(onChange) {
|
|
21
35
|
this.onChange = onChange;
|
|
@@ -39,6 +53,28 @@ let SelectButtonComponent = SelectButtonComponent_1 = class SelectButtonComponen
|
|
|
39
53
|
(_a = this.onChange) === null || _a === void 0 ? void 0 : _a.call(this, [...this.activeItems]);
|
|
40
54
|
(_b = this.onTouched) === null || _b === void 0 ? void 0 : _b.call(this, [...this.activeItems]);
|
|
41
55
|
}
|
|
56
|
+
_compareItems(item1, item2) {
|
|
57
|
+
const _compare = (a, b) => {
|
|
58
|
+
if (a === b) {
|
|
59
|
+
return true;
|
|
60
|
+
}
|
|
61
|
+
if (typeof a !== "object" || a === null || typeof b !== "object" || b === null) {
|
|
62
|
+
return false;
|
|
63
|
+
}
|
|
64
|
+
let keysA = Object.keys(a);
|
|
65
|
+
let keysB = Object.keys(b);
|
|
66
|
+
if (keysA.length !== keysB.length) {
|
|
67
|
+
return false;
|
|
68
|
+
}
|
|
69
|
+
for (let key of keysA) {
|
|
70
|
+
if (!keysB.includes(key) || !_compare(a[key], b[key])) {
|
|
71
|
+
return false;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
return true;
|
|
75
|
+
};
|
|
76
|
+
return _compare(item1, item2);
|
|
77
|
+
}
|
|
42
78
|
};
|
|
43
79
|
__decorate([
|
|
44
80
|
Input()
|
|
@@ -56,13 +92,15 @@ SelectButtonComponent = SelectButtonComponent_1 = __decorate([
|
|
|
56
92
|
Component({
|
|
57
93
|
selector: "s-select-button",
|
|
58
94
|
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>",
|
|
59
|
-
providers: [
|
|
95
|
+
providers: [
|
|
96
|
+
{
|
|
60
97
|
provide: NG_VALUE_ACCESSOR,
|
|
61
98
|
useExisting: forwardRef(() => SelectButtonComponent_1),
|
|
62
99
|
multi: true,
|
|
63
|
-
}
|
|
100
|
+
},
|
|
101
|
+
],
|
|
64
102
|
styles: [".select-button{overflow:hidden}"]
|
|
65
103
|
})
|
|
66
104
|
], SelectButtonComponent);
|
|
67
105
|
export { SelectButtonComponent };
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
106
|
+
//# 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) {\n        const _compare = (a: any, b: any) => {\n            if (a === b) {\n                return true;\n            }\n\n            if (typeof a !== \"object\" || a === null || typeof b !== \"object\" || b === null) {\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            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 () {
|
|
@@ -14,9 +14,23 @@ var SelectButtonComponent = /** @class */ (function () {
|
|
|
14
14
|
var _this = this;
|
|
15
15
|
if (!value)
|
|
16
16
|
return;
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
17
|
+
this.activeItems.clear();
|
|
18
|
+
if (Array.isArray(value)) {
|
|
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
|
+
});
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
this.items.forEach(function (iItem) {
|
|
29
|
+
if (_this._compareItems(value, iItem)) {
|
|
30
|
+
_this.activeItems.add(iItem);
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
}
|
|
20
34
|
};
|
|
21
35
|
SelectButtonComponent.prototype.registerOnChange = function (onChange) {
|
|
22
36
|
this.onChange = onChange;
|
|
@@ -40,6 +54,39 @@ var SelectButtonComponent = /** @class */ (function () {
|
|
|
40
54
|
(_a = this.onChange) === null || _a === void 0 ? void 0 : _a.call(this, __spread(this.activeItems));
|
|
41
55
|
(_b = this.onTouched) === null || _b === void 0 ? void 0 : _b.call(this, __spread(this.activeItems));
|
|
42
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 (typeof a !== "object" || a === null || typeof b !== "object" || b === null) {
|
|
64
|
+
return false;
|
|
65
|
+
}
|
|
66
|
+
var keysA = Object.keys(a);
|
|
67
|
+
var keysB = Object.keys(b);
|
|
68
|
+
if (keysA.length !== keysB.length) {
|
|
69
|
+
return false;
|
|
70
|
+
}
|
|
71
|
+
try {
|
|
72
|
+
for (var keysA_1 = __values(keysA), keysA_1_1 = keysA_1.next(); !keysA_1_1.done; keysA_1_1 = keysA_1.next()) {
|
|
73
|
+
var key = keysA_1_1.value;
|
|
74
|
+
if (!keysB.includes(key) || !_compare(a[key], b[key])) {
|
|
75
|
+
return false;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
80
|
+
finally {
|
|
81
|
+
try {
|
|
82
|
+
if (keysA_1_1 && !keysA_1_1.done && (_a = keysA_1.return)) _a.call(keysA_1);
|
|
83
|
+
}
|
|
84
|
+
finally { if (e_1) throw e_1.error; }
|
|
85
|
+
}
|
|
86
|
+
return true;
|
|
87
|
+
};
|
|
88
|
+
return _compare(item1, item2);
|
|
89
|
+
};
|
|
43
90
|
var SelectButtonComponent_1;
|
|
44
91
|
__decorate([
|
|
45
92
|
Input()
|
|
@@ -57,15 +104,17 @@ var SelectButtonComponent = /** @class */ (function () {
|
|
|
57
104
|
Component({
|
|
58
105
|
selector: "s-select-button",
|
|
59
106
|
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>",
|
|
60
|
-
providers: [
|
|
107
|
+
providers: [
|
|
108
|
+
{
|
|
61
109
|
provide: NG_VALUE_ACCESSOR,
|
|
62
110
|
useExisting: forwardRef(function () { return SelectButtonComponent_1; }),
|
|
63
111
|
multi: true,
|
|
64
|
-
}
|
|
112
|
+
},
|
|
113
|
+
],
|
|
65
114
|
styles: [".select-button{overflow:hidden}"]
|
|
66
115
|
})
|
|
67
116
|
], SelectButtonComponent);
|
|
68
117
|
return SelectButtonComponent;
|
|
69
118
|
}());
|
|
70
119
|
export { SelectButtonComponent };
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
120
|
+
//# 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) {\n        const _compare = (a: any, b: any) => {\n            if (a === b) {\n                return true;\n            }\n\n            if (typeof a !== \"object\" || a === null || typeof b !== \"object\" || b === null) {\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            return true;\n        };\n\n        return _compare(item1, item2);\n    }\n}\n"]}
|
|
@@ -14261,9 +14261,23 @@ let SelectButtonComponent = SelectButtonComponent_1 = class SelectButtonComponen
|
|
|
14261
14261
|
writeValue(value) {
|
|
14262
14262
|
if (!value)
|
|
14263
14263
|
return;
|
|
14264
|
-
|
|
14265
|
-
|
|
14266
|
-
|
|
14264
|
+
this.activeItems.clear();
|
|
14265
|
+
if (Array.isArray(value)) {
|
|
14266
|
+
value.forEach((item) => {
|
|
14267
|
+
this.items.forEach((iItem) => {
|
|
14268
|
+
if (this._compareItems(item, iItem)) {
|
|
14269
|
+
this.activeItems.add(iItem);
|
|
14270
|
+
}
|
|
14271
|
+
});
|
|
14272
|
+
});
|
|
14273
|
+
}
|
|
14274
|
+
else {
|
|
14275
|
+
this.items.forEach((iItem) => {
|
|
14276
|
+
if (this._compareItems(value, iItem)) {
|
|
14277
|
+
this.activeItems.add(iItem);
|
|
14278
|
+
}
|
|
14279
|
+
});
|
|
14280
|
+
}
|
|
14267
14281
|
}
|
|
14268
14282
|
registerOnChange(onChange) {
|
|
14269
14283
|
this.onChange = onChange;
|
|
@@ -14287,6 +14301,28 @@ let SelectButtonComponent = SelectButtonComponent_1 = class SelectButtonComponen
|
|
|
14287
14301
|
(_a = this.onChange) === null || _a === void 0 ? void 0 : _a.call(this, [...this.activeItems]);
|
|
14288
14302
|
(_b = this.onTouched) === null || _b === void 0 ? void 0 : _b.call(this, [...this.activeItems]);
|
|
14289
14303
|
}
|
|
14304
|
+
_compareItems(item1, item2) {
|
|
14305
|
+
const _compare = (a, b) => {
|
|
14306
|
+
if (a === b) {
|
|
14307
|
+
return true;
|
|
14308
|
+
}
|
|
14309
|
+
if (typeof a !== "object" || a === null || typeof b !== "object" || b === null) {
|
|
14310
|
+
return false;
|
|
14311
|
+
}
|
|
14312
|
+
let keysA = Object.keys(a);
|
|
14313
|
+
let keysB = Object.keys(b);
|
|
14314
|
+
if (keysA.length !== keysB.length) {
|
|
14315
|
+
return false;
|
|
14316
|
+
}
|
|
14317
|
+
for (let key of keysA) {
|
|
14318
|
+
if (!keysB.includes(key) || !_compare(a[key], b[key])) {
|
|
14319
|
+
return false;
|
|
14320
|
+
}
|
|
14321
|
+
}
|
|
14322
|
+
return true;
|
|
14323
|
+
};
|
|
14324
|
+
return _compare(item1, item2);
|
|
14325
|
+
}
|
|
14290
14326
|
};
|
|
14291
14327
|
__decorate([
|
|
14292
14328
|
Input()
|
|
@@ -14304,11 +14340,13 @@ SelectButtonComponent = SelectButtonComponent_1 = __decorate([
|
|
|
14304
14340
|
Component({
|
|
14305
14341
|
selector: "s-select-button",
|
|
14306
14342
|
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>",
|
|
14307
|
-
providers: [
|
|
14343
|
+
providers: [
|
|
14344
|
+
{
|
|
14308
14345
|
provide: NG_VALUE_ACCESSOR,
|
|
14309
14346
|
useExisting: forwardRef(() => SelectButtonComponent_1),
|
|
14310
14347
|
multi: true,
|
|
14311
|
-
}
|
|
14348
|
+
},
|
|
14349
|
+
],
|
|
14312
14350
|
styles: [".select-button{overflow:hidden}"]
|
|
14313
14351
|
})
|
|
14314
14352
|
], SelectButtonComponent);
|