@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.
@@ -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
- value.forEach((item) => {
17
- this.activeItems.add(item);
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9zZWxlY3QtYnV0dG9uL3NlbGVjdC1idXR0b24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHbkYsT0FBTyxFQUF3QixpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBWXpFLElBQWEscUJBQXFCLDZCQUFsQyxNQUFhLHFCQUFxQjtJQUFsQztRQUtXLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFHakIsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBc0IsQ0FBQztRQUd0RCxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFvQixDQUFDO1FBRW5ELGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDakIsZ0JBQVcsR0FBRyxJQUFJLEdBQUcsRUFBb0IsQ0FBQztJQXNDckQsQ0FBQztJQWxDVSxVQUFVLENBQUMsS0FBMEI7UUFDeEMsSUFBSSxDQUFDLEtBQUs7WUFBRSxPQUFPO1FBRW5CLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFzQixFQUFFLEVBQUU7WUFDckMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDL0IsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU0sZ0JBQWdCLENBQUMsUUFBNkM7UUFDakUsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7SUFDN0IsQ0FBQztJQUVNLGlCQUFpQixDQUFDLFNBQThDO1FBQ25FLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO0lBQy9CLENBQUM7SUFFTSxnQkFBZ0IsQ0FBQyxRQUFpQjtRQUNyQyxJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztJQUM3QixDQUFDO0lBRU0sWUFBWSxDQUFDLElBQXNCOztRQUN0QyxJQUFJLElBQUksQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLFFBQVE7WUFBRSxPQUFPO1FBRTNDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRTVCLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2hCLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDNUI7UUFDRCxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMzQixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUM7UUFFOUMsTUFBQSxJQUFJLENBQUMsUUFBUSwrQ0FBYixJQUFJLEVBQVksQ0FBQyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsRUFBRTtRQUN2QyxNQUFBLElBQUksQ0FBQyxTQUFTLCtDQUFkLElBQUksRUFBYSxDQUFDLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxFQUFFO0lBQzVDLENBQUM7Q0FDSixDQUFBO0FBbERHO0lBREMsS0FBSyxFQUFFO29EQUN5QjtBQUdqQztJQURDLEtBQUssRUFBRTt1REFDZ0I7QUFHeEI7SUFEQyxNQUFNLEVBQUU7MkRBQ29EO0FBRzdEO0lBREMsTUFBTSxFQUFFOzBEQUNpRDtBQVhqRCxxQkFBcUI7SUFWakMsU0FBUyxDQUFDO1FBQ1AsUUFBUSxFQUFFLGlCQUFpQjtRQUMzQiwyY0FBNkM7UUFFN0MsU0FBUyxFQUFFLENBQUM7Z0JBQ1IsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyx1QkFBcUIsQ0FBQztnQkFDcEQsS0FBSyxFQUFFLElBQUk7YUFDZCxDQUFDOztLQUNMLENBQUM7R0FDVyxxQkFBcUIsQ0FvRGpDO1NBcERZLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0LCBmb3J3YXJkUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuaW1wb3J0IHsgU2VsZWN0QnV0dG9uSXRlbSB9IGZyb20gXCIuL21vZGVsc1wiO1xuaW1wb3J0IHsgQ29udHJvbFZhbHVlQWNjZXNzb3IsIE5HX1ZBTFVFX0FDQ0VTU09SIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiBcInMtc2VsZWN0LWJ1dHRvblwiLFxuICAgIHRlbXBsYXRlVXJsOiBcIi4vc2VsZWN0LWJ1dHRvbi5jb21wb25lbnQuaHRtbFwiLFxuICAgIHN0eWxlVXJsczogW1wiLi9zZWxlY3QtYnV0dG9uLmNvbXBvbmVudC5zY3NzXCJdLFxuICAgIHByb3ZpZGVyczogW3tcbiAgICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IFNlbGVjdEJ1dHRvbkNvbXBvbmVudCksXG4gICAgICAgIG11bHRpOiB0cnVlLFxuICAgIH1dLFxufSlcbmV4cG9ydCBjbGFzcyBTZWxlY3RCdXR0b25Db21wb25lbnQgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciB7XG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgaXRlbXM6IFNlbGVjdEJ1dHRvbkl0ZW1bXTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIG11bHRpcGxlID0gZmFsc2U7XG5cbiAgICBAT3V0cHV0KClcbiAgICBwdWJsaWMgaXRlbVNlbGVjdGVkID0gbmV3IEV2ZW50RW1pdHRlcjxTZWxlY3RCdXR0b25JdGVtW10+KCk7XG5cbiAgICBAT3V0cHV0KClcbiAgICBwdWJsaWMgaXRlbUNsaWNrZWQgPSBuZXcgRXZlbnRFbWl0dGVyPFNlbGVjdEJ1dHRvbkl0ZW0+KCk7XG5cbiAgICBwdWJsaWMgZGlzYWJsZWQgPSBmYWxzZTtcbiAgICBwdWJsaWMgYWN0aXZlSXRlbXMgPSBuZXcgU2V0PFNlbGVjdEJ1dHRvbkl0ZW0+KCk7XG4gICAgcHVibGljIG9uQ2hhbmdlOiAodmFsdWU6IFNlbGVjdEJ1dHRvbkl0ZW1bXSkgPT4gdm9pZDtcbiAgICBwdWJsaWMgb25Ub3VjaGVkOiAodmFsdWU6IFNlbGVjdEJ1dHRvbkl0ZW1bXSkgPT4gdm9pZDtcblxuICAgIHB1YmxpYyB3cml0ZVZhbHVlKHZhbHVlPzogU2VsZWN0QnV0dG9uSXRlbVtdKTogdm9pZCB7XG4gICAgICAgIGlmICghdmFsdWUpIHJldHVybjtcblxuICAgICAgICB2YWx1ZS5mb3JFYWNoKChpdGVtOiBTZWxlY3RCdXR0b25JdGVtKSA9PiB7XG4gICAgICAgICAgICB0aGlzLmFjdGl2ZUl0ZW1zLmFkZChpdGVtKTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHVibGljIHJlZ2lzdGVyT25DaGFuZ2Uob25DaGFuZ2U6ICh2YWx1ZTogU2VsZWN0QnV0dG9uSXRlbVtdKSA9PiB2b2lkKTogdm9pZCB7XG4gICAgICAgIHRoaXMub25DaGFuZ2UgPSBvbkNoYW5nZTtcbiAgICB9XG5cbiAgICBwdWJsaWMgcmVnaXN0ZXJPblRvdWNoZWQob25Ub3VjaGVkOiAodmFsdWU6IFNlbGVjdEJ1dHRvbkl0ZW1bXSkgPT4gdm9pZCk6IHZvaWQge1xuICAgICAgICB0aGlzLm9uVG91Y2hlZCA9IG9uVG91Y2hlZDtcbiAgICB9XG5cbiAgICBwdWJsaWMgc2V0RGlzYWJsZWRTdGF0ZShkaXNhYmxlZDogYm9vbGVhbik6IHZvaWQge1xuICAgICAgICB0aGlzLmRpc2FibGVkID0gZGlzYWJsZWQ7XG4gICAgfVxuXG4gICAgcHVibGljIG9uSXRlbVNlbGVjdChpdGVtOiBTZWxlY3RCdXR0b25JdGVtKTogdm9pZCB7XG4gICAgICAgIGlmICh0aGlzLmRpc2FibGVkIHx8IGl0ZW0uZGlzYWJsZWQpIHJldHVybjtcblxuICAgICAgICB0aGlzLml0ZW1DbGlja2VkLmVtaXQoaXRlbSk7XG5cbiAgICAgICAgaWYgKCF0aGlzLm11bHRpcGxlKSB7XG4gICAgICAgICAgICB0aGlzLmFjdGl2ZUl0ZW1zLmNsZWFyKCk7XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5hY3RpdmVJdGVtcy5hZGQoaXRlbSk7XG4gICAgICAgIHRoaXMuaXRlbVNlbGVjdGVkLmVtaXQoWy4uLnRoaXMuYWN0aXZlSXRlbXNdKTtcblxuICAgICAgICB0aGlzLm9uQ2hhbmdlPy4oWy4uLnRoaXMuYWN0aXZlSXRlbXNdKTtcbiAgICAgICAgdGhpcy5vblRvdWNoZWQ/LihbLi4udGhpcy5hY3RpdmVJdGVtc10pO1xuICAgIH1cbn1cbiJdfQ==
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
- value.forEach(function (item) {
18
- _this.activeItems.add(item);
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9zZWxlY3QtYnV0dG9uL3NlbGVjdC1idXR0b24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUduRixPQUFPLEVBQXdCLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFZekU7SUFBQTtRQUtXLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFHakIsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBc0IsQ0FBQztRQUd0RCxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFvQixDQUFDO1FBRW5ELGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDakIsZ0JBQVcsR0FBRyxJQUFJLEdBQUcsRUFBb0IsQ0FBQztJQXNDckQsQ0FBQzs4QkFwRFkscUJBQXFCO0lBa0J2QiwwQ0FBVSxHQUFqQixVQUFrQixLQUEwQjtRQUE1QyxpQkFNQztRQUxHLElBQUksQ0FBQyxLQUFLO1lBQUUsT0FBTztRQUVuQixLQUFLLENBQUMsT0FBTyxDQUFDLFVBQUMsSUFBc0I7WUFDakMsS0FBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDL0IsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU0sZ0RBQWdCLEdBQXZCLFVBQXdCLFFBQTZDO1FBQ2pFLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO0lBQzdCLENBQUM7SUFFTSxpREFBaUIsR0FBeEIsVUFBeUIsU0FBOEM7UUFDbkUsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7SUFDL0IsQ0FBQztJQUVNLGdEQUFnQixHQUF2QixVQUF3QixRQUFpQjtRQUNyQyxJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztJQUM3QixDQUFDO0lBRU0sNENBQVksR0FBbkIsVUFBb0IsSUFBc0I7O1FBQ3RDLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsUUFBUTtZQUFFLE9BQU87UUFFM0MsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFNUIsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDaEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUUsQ0FBQztTQUM1QjtRQUNELElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzNCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxVQUFLLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUU5QyxNQUFBLElBQUksQ0FBQyxRQUFRLCtDQUFiLElBQUksV0FBZ0IsSUFBSSxDQUFDLFdBQVcsR0FBRztRQUN2QyxNQUFBLElBQUksQ0FBQyxTQUFTLCtDQUFkLElBQUksV0FBaUIsSUFBSSxDQUFDLFdBQVcsR0FBRztJQUM1QyxDQUFDOztJQWpERDtRQURDLEtBQUssRUFBRTt3REFDeUI7SUFHakM7UUFEQyxLQUFLLEVBQUU7MkRBQ2dCO0lBR3hCO1FBREMsTUFBTSxFQUFFOytEQUNvRDtJQUc3RDtRQURDLE1BQU0sRUFBRTs4REFDaUQ7SUFYakQscUJBQXFCO1FBVmpDLFNBQVMsQ0FBQztZQUNQLFFBQVEsRUFBRSxpQkFBaUI7WUFDM0IsMmNBQTZDO1lBRTdDLFNBQVMsRUFBRSxDQUFDO29CQUNSLE9BQU8sRUFBRSxpQkFBaUI7b0JBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsY0FBTSxPQUFBLHVCQUFxQixFQUFyQixDQUFxQixDQUFDO29CQUNwRCxLQUFLLEVBQUUsSUFBSTtpQkFDZCxDQUFDOztTQUNMLENBQUM7T0FDVyxxQkFBcUIsQ0FvRGpDO0lBQUQsNEJBQUM7Q0FBQSxBQXBERCxJQW9EQztTQXBEWSxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCwgZm9yd2FyZFJlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbmltcG9ydCB7IFNlbGVjdEJ1dHRvbkl0ZW0gfSBmcm9tIFwiLi9tb2RlbHNcIjtcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogXCJzLXNlbGVjdC1idXR0b25cIixcbiAgICB0ZW1wbGF0ZVVybDogXCIuL3NlbGVjdC1idXR0b24uY29tcG9uZW50Lmh0bWxcIixcbiAgICBzdHlsZVVybHM6IFtcIi4vc2VsZWN0LWJ1dHRvbi5jb21wb25lbnQuc2Nzc1wiXSxcbiAgICBwcm92aWRlcnM6IFt7XG4gICAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxuICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBTZWxlY3RCdXR0b25Db21wb25lbnQpLFxuICAgICAgICBtdWx0aTogdHJ1ZSxcbiAgICB9XSxcbn0pXG5leHBvcnQgY2xhc3MgU2VsZWN0QnV0dG9uQ29tcG9uZW50IGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3Ige1xuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGl0ZW1zOiBTZWxlY3RCdXR0b25JdGVtW107XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBtdWx0aXBsZSA9IGZhbHNlO1xuXG4gICAgQE91dHB1dCgpXG4gICAgcHVibGljIGl0ZW1TZWxlY3RlZCA9IG5ldyBFdmVudEVtaXR0ZXI8U2VsZWN0QnV0dG9uSXRlbVtdPigpO1xuXG4gICAgQE91dHB1dCgpXG4gICAgcHVibGljIGl0ZW1DbGlja2VkID0gbmV3IEV2ZW50RW1pdHRlcjxTZWxlY3RCdXR0b25JdGVtPigpO1xuXG4gICAgcHVibGljIGRpc2FibGVkID0gZmFsc2U7XG4gICAgcHVibGljIGFjdGl2ZUl0ZW1zID0gbmV3IFNldDxTZWxlY3RCdXR0b25JdGVtPigpO1xuICAgIHB1YmxpYyBvbkNoYW5nZTogKHZhbHVlOiBTZWxlY3RCdXR0b25JdGVtW10pID0+IHZvaWQ7XG4gICAgcHVibGljIG9uVG91Y2hlZDogKHZhbHVlOiBTZWxlY3RCdXR0b25JdGVtW10pID0+IHZvaWQ7XG5cbiAgICBwdWJsaWMgd3JpdGVWYWx1ZSh2YWx1ZT86IFNlbGVjdEJ1dHRvbkl0ZW1bXSk6IHZvaWQge1xuICAgICAgICBpZiAoIXZhbHVlKSByZXR1cm47XG5cbiAgICAgICAgdmFsdWUuZm9yRWFjaCgoaXRlbTogU2VsZWN0QnV0dG9uSXRlbSkgPT4ge1xuICAgICAgICAgICAgdGhpcy5hY3RpdmVJdGVtcy5hZGQoaXRlbSk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIHB1YmxpYyByZWdpc3Rlck9uQ2hhbmdlKG9uQ2hhbmdlOiAodmFsdWU6IFNlbGVjdEJ1dHRvbkl0ZW1bXSkgPT4gdm9pZCk6IHZvaWQge1xuICAgICAgICB0aGlzLm9uQ2hhbmdlID0gb25DaGFuZ2U7XG4gICAgfVxuXG4gICAgcHVibGljIHJlZ2lzdGVyT25Ub3VjaGVkKG9uVG91Y2hlZDogKHZhbHVlOiBTZWxlY3RCdXR0b25JdGVtW10pID0+IHZvaWQpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5vblRvdWNoZWQgPSBvblRvdWNoZWQ7XG4gICAgfVxuXG4gICAgcHVibGljIHNldERpc2FibGVkU3RhdGUoZGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICAgICAgdGhpcy5kaXNhYmxlZCA9IGRpc2FibGVkO1xuICAgIH1cblxuICAgIHB1YmxpYyBvbkl0ZW1TZWxlY3QoaXRlbTogU2VsZWN0QnV0dG9uSXRlbSk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5kaXNhYmxlZCB8fCBpdGVtLmRpc2FibGVkKSByZXR1cm47XG5cbiAgICAgICAgdGhpcy5pdGVtQ2xpY2tlZC5lbWl0KGl0ZW0pO1xuXG4gICAgICAgIGlmICghdGhpcy5tdWx0aXBsZSkge1xuICAgICAgICAgICAgdGhpcy5hY3RpdmVJdGVtcy5jbGVhcigpO1xuICAgICAgICB9XG4gICAgICAgIHRoaXMuYWN0aXZlSXRlbXMuYWRkKGl0ZW0pO1xuICAgICAgICB0aGlzLml0ZW1TZWxlY3RlZC5lbWl0KFsuLi50aGlzLmFjdGl2ZUl0ZW1zXSk7XG5cbiAgICAgICAgdGhpcy5vbkNoYW5nZT8uKFsuLi50aGlzLmFjdGl2ZUl0ZW1zXSk7XG4gICAgICAgIHRoaXMub25Ub3VjaGVkPy4oWy4uLnRoaXMuYWN0aXZlSXRlbXNdKTtcbiAgICB9XG59XG4iXX0=
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
- value.forEach((item) => {
14265
- this.activeItems.add(item);
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);