@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.
@@ -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) => this.activeItems.add(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.activeItems.add(value);
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9zZWxlY3QtYnV0dG9uL3NlbGVjdC1idXR0b24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHbkYsT0FBTyxFQUF3QixpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBWXpFLElBQWEscUJBQXFCLDZCQUFsQyxNQUFhLHFCQUFxQjtJQUFsQztRQUtXLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFHakIsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBc0IsQ0FBQztRQUd0RCxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFvQixDQUFDO1FBRW5ELGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDakIsZ0JBQVcsR0FBRyxJQUFJLEdBQUcsRUFBb0IsQ0FBQztJQTBDckQsQ0FBQztJQXRDVSxVQUFVLENBQUMsS0FBNkM7UUFDM0QsSUFBSSxDQUFDLEtBQUs7WUFBRSxPQUFPO1FBRW5CLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFLENBQUM7UUFFekIsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQ3RCLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFzQixFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1NBQ3pFO2FBQU07WUFDSCxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUMvQjtJQUNMLENBQUM7SUFFTSxnQkFBZ0IsQ0FBQyxRQUE2QztRQUNqRSxJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztJQUM3QixDQUFDO0lBRU0saUJBQWlCLENBQUMsU0FBOEM7UUFDbkUsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7SUFDL0IsQ0FBQztJQUVNLGdCQUFnQixDQUFDLFFBQWlCO1FBQ3JDLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO0lBQzdCLENBQUM7SUFFTSxZQUFZLENBQUMsSUFBc0I7O1FBQ3RDLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsUUFBUTtZQUFFLE9BQU87UUFFM0MsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFNUIsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDaEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUUsQ0FBQztTQUM1QjtRQUNELElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzNCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQztRQUU5QyxNQUFBLElBQUksQ0FBQyxRQUFRLCtDQUFiLElBQUksRUFBWSxDQUFDLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxFQUFFO1FBQ3ZDLE1BQUEsSUFBSSxDQUFDLFNBQVMsK0NBQWQsSUFBSSxFQUFhLENBQUMsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEVBQUU7SUFDNUMsQ0FBQztDQUNKLENBQUE7QUF0REc7SUFEQyxLQUFLLEVBQUU7b0RBQ3lCO0FBR2pDO0lBREMsS0FBSyxFQUFFO3VEQUNnQjtBQUd4QjtJQURDLE1BQU0sRUFBRTsyREFDb0Q7QUFHN0Q7SUFEQyxNQUFNLEVBQUU7MERBQ2lEO0FBWGpELHFCQUFxQjtJQVZqQyxTQUFTLENBQUM7UUFDUCxRQUFRLEVBQUUsaUJBQWlCO1FBQzNCLDJjQUE2QztRQUU3QyxTQUFTLEVBQUUsQ0FBQztnQkFDUixPQUFPLEVBQUUsaUJBQWlCO2dCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLHVCQUFxQixDQUFDO2dCQUNwRCxLQUFLLEVBQUUsSUFBSTthQUNkLENBQUM7O0tBQ0wsQ0FBQztHQUNXLHFCQUFxQixDQXdEakM7U0F4RFkscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQsIGZvcndhcmRSZWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5pbXBvcnQgeyBTZWxlY3RCdXR0b25JdGVtIH0gZnJvbSBcIi4vbW9kZWxzXCI7XG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6IFwicy1zZWxlY3QtYnV0dG9uXCIsXG4gICAgdGVtcGxhdGVVcmw6IFwiLi9zZWxlY3QtYnV0dG9uLmNvbXBvbmVudC5odG1sXCIsXG4gICAgc3R5bGVVcmxzOiBbXCIuL3NlbGVjdC1idXR0b24uY29tcG9uZW50LnNjc3NcIl0sXG4gICAgcHJvdmlkZXJzOiBbe1xuICAgICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcbiAgICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gU2VsZWN0QnV0dG9uQ29tcG9uZW50KSxcbiAgICAgICAgbXVsdGk6IHRydWUsXG4gICAgfV0sXG59KVxuZXhwb3J0IGNsYXNzIFNlbGVjdEJ1dHRvbkNvbXBvbmVudCBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBpdGVtczogU2VsZWN0QnV0dG9uSXRlbVtdO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgbXVsdGlwbGUgPSBmYWxzZTtcblxuICAgIEBPdXRwdXQoKVxuICAgIHB1YmxpYyBpdGVtU2VsZWN0ZWQgPSBuZXcgRXZlbnRFbWl0dGVyPFNlbGVjdEJ1dHRvbkl0ZW1bXT4oKTtcblxuICAgIEBPdXRwdXQoKVxuICAgIHB1YmxpYyBpdGVtQ2xpY2tlZCA9IG5ldyBFdmVudEVtaXR0ZXI8U2VsZWN0QnV0dG9uSXRlbT4oKTtcblxuICAgIHB1YmxpYyBkaXNhYmxlZCA9IGZhbHNlO1xuICAgIHB1YmxpYyBhY3RpdmVJdGVtcyA9IG5ldyBTZXQ8U2VsZWN0QnV0dG9uSXRlbT4oKTtcbiAgICBwdWJsaWMgb25DaGFuZ2U6ICh2YWx1ZTogU2VsZWN0QnV0dG9uSXRlbVtdKSA9PiB2b2lkO1xuICAgIHB1YmxpYyBvblRvdWNoZWQ6ICh2YWx1ZTogU2VsZWN0QnV0dG9uSXRlbVtdKSA9PiB2b2lkO1xuXG4gICAgcHVibGljIHdyaXRlVmFsdWUodmFsdWU/OiBTZWxlY3RCdXR0b25JdGVtIHwgU2VsZWN0QnV0dG9uSXRlbVtdKTogdm9pZCB7XG4gICAgICAgIGlmICghdmFsdWUpIHJldHVybjtcblxuICAgICAgICB0aGlzLmFjdGl2ZUl0ZW1zLmNsZWFyKCk7XG5cbiAgICAgICAgaWYgKEFycmF5LmlzQXJyYXkodmFsdWUpKSB7XG4gICAgICAgICAgICB2YWx1ZS5mb3JFYWNoKChpdGVtOiBTZWxlY3RCdXR0b25JdGVtKSA9PiB0aGlzLmFjdGl2ZUl0ZW1zLmFkZChpdGVtKSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLmFjdGl2ZUl0ZW1zLmFkZCh2YWx1ZSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwdWJsaWMgcmVnaXN0ZXJPbkNoYW5nZShvbkNoYW5nZTogKHZhbHVlOiBTZWxlY3RCdXR0b25JdGVtW10pID0+IHZvaWQpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5vbkNoYW5nZSA9IG9uQ2hhbmdlO1xuICAgIH1cblxuICAgIHB1YmxpYyByZWdpc3Rlck9uVG91Y2hlZChvblRvdWNoZWQ6ICh2YWx1ZTogU2VsZWN0QnV0dG9uSXRlbVtdKSA9PiB2b2lkKTogdm9pZCB7XG4gICAgICAgIHRoaXMub25Ub3VjaGVkID0gb25Ub3VjaGVkO1xuICAgIH1cblxuICAgIHB1YmxpYyBzZXREaXNhYmxlZFN0YXRlKGRpc2FibGVkOiBib29sZWFuKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZGlzYWJsZWQgPSBkaXNhYmxlZDtcbiAgICB9XG5cbiAgICBwdWJsaWMgb25JdGVtU2VsZWN0KGl0ZW06IFNlbGVjdEJ1dHRvbkl0ZW0pOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuZGlzYWJsZWQgfHwgaXRlbS5kaXNhYmxlZCkgcmV0dXJuO1xuXG4gICAgICAgIHRoaXMuaXRlbUNsaWNrZWQuZW1pdChpdGVtKTtcblxuICAgICAgICBpZiAoIXRoaXMubXVsdGlwbGUpIHtcbiAgICAgICAgICAgIHRoaXMuYWN0aXZlSXRlbXMuY2xlYXIoKTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLmFjdGl2ZUl0ZW1zLmFkZChpdGVtKTtcbiAgICAgICAgdGhpcy5pdGVtU2VsZWN0ZWQuZW1pdChbLi4udGhpcy5hY3RpdmVJdGVtc10pO1xuXG4gICAgICAgIHRoaXMub25DaGFuZ2U/LihbLi4udGhpcy5hY3RpdmVJdGVtc10pO1xuICAgICAgICB0aGlzLm9uVG91Y2hlZD8uKFsuLi50aGlzLmFjdGl2ZUl0ZW1zXSk7XG4gICAgfVxufVxuIl19
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) { return _this.activeItems.add(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.activeItems.add(value);
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9zZWxlY3QtYnV0dG9uL3NlbGVjdC1idXR0b24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUduRixPQUFPLEVBQXdCLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFZekU7SUFBQTtRQUtXLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFHakIsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBc0IsQ0FBQztRQUd0RCxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFvQixDQUFDO1FBRW5ELGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDakIsZ0JBQVcsR0FBRyxJQUFJLEdBQUcsRUFBb0IsQ0FBQztJQTBDckQsQ0FBQzs4QkF4RFkscUJBQXFCO0lBa0J2QiwwQ0FBVSxHQUFqQixVQUFrQixLQUE2QztRQUEvRCxpQkFVQztRQVRHLElBQUksQ0FBQyxLQUFLO1lBQUUsT0FBTztRQUVuQixJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBRXpCLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUN0QixLQUFLLENBQUMsT0FBTyxDQUFDLFVBQUMsSUFBc0IsSUFBSyxPQUFBLEtBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUExQixDQUEwQixDQUFDLENBQUM7U0FDekU7YUFBTTtZQUNILElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQy9CO0lBQ0wsQ0FBQztJQUVNLGdEQUFnQixHQUF2QixVQUF3QixRQUE2QztRQUNqRSxJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztJQUM3QixDQUFDO0lBRU0saURBQWlCLEdBQXhCLFVBQXlCLFNBQThDO1FBQ25FLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO0lBQy9CLENBQUM7SUFFTSxnREFBZ0IsR0FBdkIsVUFBd0IsUUFBaUI7UUFDckMsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7SUFDN0IsQ0FBQztJQUVNLDRDQUFZLEdBQW5CLFVBQW9CLElBQXNCOztRQUN0QyxJQUFJLElBQUksQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLFFBQVE7WUFBRSxPQUFPO1FBRTNDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRTVCLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2hCLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDNUI7UUFDRCxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMzQixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksVUFBSyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7UUFFOUMsTUFBQSxJQUFJLENBQUMsUUFBUSwrQ0FBYixJQUFJLFdBQWdCLElBQUksQ0FBQyxXQUFXLEdBQUc7UUFDdkMsTUFBQSxJQUFJLENBQUMsU0FBUywrQ0FBZCxJQUFJLFdBQWlCLElBQUksQ0FBQyxXQUFXLEdBQUc7SUFDNUMsQ0FBQzs7SUFyREQ7UUFEQyxLQUFLLEVBQUU7d0RBQ3lCO0lBR2pDO1FBREMsS0FBSyxFQUFFOzJEQUNnQjtJQUd4QjtRQURDLE1BQU0sRUFBRTsrREFDb0Q7SUFHN0Q7UUFEQyxNQUFNLEVBQUU7OERBQ2lEO0lBWGpELHFCQUFxQjtRQVZqQyxTQUFTLENBQUM7WUFDUCxRQUFRLEVBQUUsaUJBQWlCO1lBQzNCLDJjQUE2QztZQUU3QyxTQUFTLEVBQUUsQ0FBQztvQkFDUixPQUFPLEVBQUUsaUJBQWlCO29CQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLGNBQU0sT0FBQSx1QkFBcUIsRUFBckIsQ0FBcUIsQ0FBQztvQkFDcEQsS0FBSyxFQUFFLElBQUk7aUJBQ2QsQ0FBQzs7U0FDTCxDQUFDO09BQ1cscUJBQXFCLENBd0RqQztJQUFELDRCQUFDO0NBQUEsQUF4REQsSUF3REM7U0F4RFkscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQsIGZvcndhcmRSZWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5pbXBvcnQgeyBTZWxlY3RCdXR0b25JdGVtIH0gZnJvbSBcIi4vbW9kZWxzXCI7XG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6IFwicy1zZWxlY3QtYnV0dG9uXCIsXG4gICAgdGVtcGxhdGVVcmw6IFwiLi9zZWxlY3QtYnV0dG9uLmNvbXBvbmVudC5odG1sXCIsXG4gICAgc3R5bGVVcmxzOiBbXCIuL3NlbGVjdC1idXR0b24uY29tcG9uZW50LnNjc3NcIl0sXG4gICAgcHJvdmlkZXJzOiBbe1xuICAgICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcbiAgICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gU2VsZWN0QnV0dG9uQ29tcG9uZW50KSxcbiAgICAgICAgbXVsdGk6IHRydWUsXG4gICAgfV0sXG59KVxuZXhwb3J0IGNsYXNzIFNlbGVjdEJ1dHRvbkNvbXBvbmVudCBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBpdGVtczogU2VsZWN0QnV0dG9uSXRlbVtdO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgbXVsdGlwbGUgPSBmYWxzZTtcblxuICAgIEBPdXRwdXQoKVxuICAgIHB1YmxpYyBpdGVtU2VsZWN0ZWQgPSBuZXcgRXZlbnRFbWl0dGVyPFNlbGVjdEJ1dHRvbkl0ZW1bXT4oKTtcblxuICAgIEBPdXRwdXQoKVxuICAgIHB1YmxpYyBpdGVtQ2xpY2tlZCA9IG5ldyBFdmVudEVtaXR0ZXI8U2VsZWN0QnV0dG9uSXRlbT4oKTtcblxuICAgIHB1YmxpYyBkaXNhYmxlZCA9IGZhbHNlO1xuICAgIHB1YmxpYyBhY3RpdmVJdGVtcyA9IG5ldyBTZXQ8U2VsZWN0QnV0dG9uSXRlbT4oKTtcbiAgICBwdWJsaWMgb25DaGFuZ2U6ICh2YWx1ZTogU2VsZWN0QnV0dG9uSXRlbVtdKSA9PiB2b2lkO1xuICAgIHB1YmxpYyBvblRvdWNoZWQ6ICh2YWx1ZTogU2VsZWN0QnV0dG9uSXRlbVtdKSA9PiB2b2lkO1xuXG4gICAgcHVibGljIHdyaXRlVmFsdWUodmFsdWU/OiBTZWxlY3RCdXR0b25JdGVtIHwgU2VsZWN0QnV0dG9uSXRlbVtdKTogdm9pZCB7XG4gICAgICAgIGlmICghdmFsdWUpIHJldHVybjtcblxuICAgICAgICB0aGlzLmFjdGl2ZUl0ZW1zLmNsZWFyKCk7XG5cbiAgICAgICAgaWYgKEFycmF5LmlzQXJyYXkodmFsdWUpKSB7XG4gICAgICAgICAgICB2YWx1ZS5mb3JFYWNoKChpdGVtOiBTZWxlY3RCdXR0b25JdGVtKSA9PiB0aGlzLmFjdGl2ZUl0ZW1zLmFkZChpdGVtKSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLmFjdGl2ZUl0ZW1zLmFkZCh2YWx1ZSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwdWJsaWMgcmVnaXN0ZXJPbkNoYW5nZShvbkNoYW5nZTogKHZhbHVlOiBTZWxlY3RCdXR0b25JdGVtW10pID0+IHZvaWQpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5vbkNoYW5nZSA9IG9uQ2hhbmdlO1xuICAgIH1cblxuICAgIHB1YmxpYyByZWdpc3Rlck9uVG91Y2hlZChvblRvdWNoZWQ6ICh2YWx1ZTogU2VsZWN0QnV0dG9uSXRlbVtdKSA9PiB2b2lkKTogdm9pZCB7XG4gICAgICAgIHRoaXMub25Ub3VjaGVkID0gb25Ub3VjaGVkO1xuICAgIH1cblxuICAgIHB1YmxpYyBzZXREaXNhYmxlZFN0YXRlKGRpc2FibGVkOiBib29sZWFuKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZGlzYWJsZWQgPSBkaXNhYmxlZDtcbiAgICB9XG5cbiAgICBwdWJsaWMgb25JdGVtU2VsZWN0KGl0ZW06IFNlbGVjdEJ1dHRvbkl0ZW0pOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuZGlzYWJsZWQgfHwgaXRlbS5kaXNhYmxlZCkgcmV0dXJuO1xuXG4gICAgICAgIHRoaXMuaXRlbUNsaWNrZWQuZW1pdChpdGVtKTtcblxuICAgICAgICBpZiAoIXRoaXMubXVsdGlwbGUpIHtcbiAgICAgICAgICAgIHRoaXMuYWN0aXZlSXRlbXMuY2xlYXIoKTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLmFjdGl2ZUl0ZW1zLmFkZChpdGVtKTtcbiAgICAgICAgdGhpcy5pdGVtU2VsZWN0ZWQuZW1pdChbLi4udGhpcy5hY3RpdmVJdGVtc10pO1xuXG4gICAgICAgIHRoaXMub25DaGFuZ2U/LihbLi4udGhpcy5hY3RpdmVJdGVtc10pO1xuICAgICAgICB0aGlzLm9uVG91Y2hlZD8uKFsuLi50aGlzLmFjdGl2ZUl0ZW1zXSk7XG4gICAgfVxufVxuIl19
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) => this.activeItems.add(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.activeItems.add(value);
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);