@seniorsistemas/angular-components 17.15.5 → 17.16.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (30) hide show
  1. package/bundles/seniorsistemas-angular-components.umd.js +372 -1
  2. package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
  3. package/bundles/seniorsistemas-angular-components.umd.min.js +2 -2
  4. package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
  5. package/components/index.d.ts +1 -0
  6. package/components/picklist/index.d.ts +4 -0
  7. package/components/picklist/picklist/models/picklist-models.d.ts +8 -0
  8. package/components/picklist/picklist/picklist.component.d.ts +71 -0
  9. package/components/picklist/picklist.module.d.ts +2 -0
  10. package/esm2015/components/index.js +2 -1
  11. package/esm2015/components/picklist/index.js +5 -0
  12. package/esm2015/components/picklist/picklist/models/picklist-models.js +6 -0
  13. package/esm2015/components/picklist/picklist/picklist.component.js +305 -0
  14. package/esm2015/components/picklist/picklist.module.js +25 -0
  15. package/esm2015/locale/fallback.js +7 -2
  16. package/esm2015/seniorsistemas-angular-components.js +2 -1
  17. package/esm5/components/index.js +2 -1
  18. package/esm5/components/picklist/index.js +5 -0
  19. package/esm5/components/picklist/picklist/models/picklist-models.js +6 -0
  20. package/esm5/components/picklist/picklist/picklist.component.js +339 -0
  21. package/esm5/components/picklist/picklist.module.js +28 -0
  22. package/esm5/locale/fallback.js +7 -2
  23. package/esm5/seniorsistemas-angular-components.js +2 -1
  24. package/fesm2015/seniorsistemas-angular-components.js +328 -3
  25. package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
  26. package/fesm5/seniorsistemas-angular-components.js +365 -3
  27. package/fesm5/seniorsistemas-angular-components.js.map +1 -1
  28. package/package.json +1 -1
  29. package/seniorsistemas-angular-components.d.ts +1 -0
  30. package/seniorsistemas-angular-components.metadata.json +1 -1
@@ -0,0 +1,339 @@
1
+ import { __decorate } from "tslib";
2
+ import { AfterViewInit, ChangeDetectorRef, Component, ContentChildren, EventEmitter, Input, OnChanges, Output, QueryList, SimpleChanges, TemplateRef } from '@angular/core';
3
+ import { pipe } from 'rxjs';
4
+ import { TemplateDirective } from './../../template/template.directive';
5
+ import { PicklistTemplateTypes } from './models/picklist-models';
6
+ var PicklistComponent = /** @class */ (function () {
7
+ function PicklistComponent(cdr) {
8
+ this.cdr = cdr;
9
+ this.itensToSelect = [];
10
+ this.selectedItens = [];
11
+ this.showCheckbox = false;
12
+ this.filterBy = '';
13
+ this.selectedItensChange = new EventEmitter();
14
+ this.itensToSelectChange = new EventEmitter();
15
+ this.availableItensFilter = '';
16
+ this.selectedItensFilter = '';
17
+ this.itensToSelectFilterUtil = {
18
+ rawItensToSelect: [],
19
+ filteredItensToSelect: [],
20
+ };
21
+ this.selectedItensFilterUtil = {
22
+ rawSelectedItens: [],
23
+ filteredSelectedItens: [],
24
+ };
25
+ this.selectedItensMap = new Set();
26
+ this.itensToSelectId = randomHash('itensToSelect');
27
+ this.selectedItensId = randomHash('selectedItens');
28
+ }
29
+ PicklistComponent.prototype.ngAfterViewInit = function () {
30
+ var _a, _b;
31
+ this.itemToSelectTemplate = (_a = this.templates.find(function (x) { return x.type === PicklistTemplateTypes.ItemToSelect; })) === null || _a === void 0 ? void 0 : _a.template;
32
+ this.itemSelectedTemplate = (_b = this.templates.find(function (x) { return x.type === PicklistTemplateTypes.SelectedItem; })) === null || _b === void 0 ? void 0 : _b.template;
33
+ if (!this.itemToSelectTemplate) {
34
+ console.error("Missing template for " + PicklistTemplateTypes.ItemToSelect + " add this template using sTemplate directive.");
35
+ }
36
+ if (!this.itemSelectedTemplate) {
37
+ console.error("Missing template for " + PicklistTemplateTypes.SelectedItem + " add this template using sTemplate directive.");
38
+ }
39
+ this.cdr.detectChanges();
40
+ };
41
+ PicklistComponent.prototype.ngOnChanges = function (changes) {
42
+ if (changes.itensToSelect && changes.itensToSelect.firstChange) {
43
+ this.itensToSelectFilterUtil = {
44
+ rawItensToSelect: this.itensToSelect,
45
+ filteredItensToSelect: this.itensToSelect,
46
+ };
47
+ }
48
+ if (changes.selectedItens && changes.selectedItens.firstChange) {
49
+ this.selectedItensFilterUtil = {
50
+ filteredSelectedItens: this.selectedItens,
51
+ rawSelectedItens: this.selectedItens
52
+ };
53
+ }
54
+ };
55
+ PicklistComponent.prototype.toggleSelected = function (internalPicklistItem, containerListId) {
56
+ if (internalPicklistItem.disabled) {
57
+ return;
58
+ }
59
+ this.unselectedItensByListId(this.getOppositiveId(containerListId));
60
+ internalPicklistItem.selected = !internalPicklistItem.selected;
61
+ if (internalPicklistItem.selected) {
62
+ this.selectedItensMap.add(internalPicklistItem);
63
+ }
64
+ else {
65
+ this.selectedItensMap.delete(internalPicklistItem);
66
+ }
67
+ this.cdr.detectChanges();
68
+ };
69
+ PicklistComponent.prototype.remove = function (all) {
70
+ var _this = this;
71
+ if (all === void 0) { all = false; }
72
+ var itens = filterEnabled((all ? this.selectedItensFilterUtil.rawSelectedItens : this.selectedItensMap));
73
+ if (!itens.length) {
74
+ return;
75
+ }
76
+ itens.forEach(function (itemRemove) {
77
+ _this.itensToSelect.push(itemRemove);
78
+ itemRemove.selected = false;
79
+ _this.selectedItensMap.delete(itemRemove);
80
+ });
81
+ this.selectedItens = this.selectedItens.filter(function (x) { return !itens.includes(x); });
82
+ this.selectedItensFilterUtil.rawSelectedItens = this.selectedItens;
83
+ this.filterSelectedItens();
84
+ this.filterItensToSelect();
85
+ this.emitData();
86
+ this.cdr.detectChanges();
87
+ };
88
+ PicklistComponent.prototype.add = function (all) {
89
+ var _this = this;
90
+ if (all === void 0) { all = false; }
91
+ var itens = filterEnabled((all ? this.itensToSelectFilterUtil.rawItensToSelect : this.selectedItensMap));
92
+ if (!itens.length) {
93
+ return;
94
+ }
95
+ itens.forEach(function (itemRemove) {
96
+ _this.selectedItens.push(itemRemove);
97
+ itemRemove.selected = false;
98
+ _this.selectedItensMap.delete(itemRemove);
99
+ });
100
+ this.itensToSelect = this.itensToSelect.filter(function (x) { return !itens.includes(x); });
101
+ this.itensToSelectFilterUtil.rawItensToSelect = this.itensToSelect;
102
+ this.filterSelectedItens();
103
+ this.filterItensToSelect();
104
+ this.emitData();
105
+ this.cdr.detectChanges();
106
+ };
107
+ PicklistComponent.prototype.filterItensToSelect = function () {
108
+ var _this = this;
109
+ var searchTerm = this.availableItensFilter;
110
+ searchTerm = searchTerm.trim();
111
+ if (searchTerm) {
112
+ this.itensToSelectFilterUtil.filteredItensToSelect = this.itensToSelectFilterUtil.rawItensToSelect
113
+ .filter(function (item) { return compareStrings(item.data[_this.filterBy], searchTerm); });
114
+ }
115
+ else {
116
+ this.itensToSelectFilterUtil.filteredItensToSelect = this.itensToSelectFilterUtil.rawItensToSelect;
117
+ }
118
+ this.cdr.detectChanges();
119
+ };
120
+ PicklistComponent.prototype.filterSelectedItens = function () {
121
+ var _this = this;
122
+ var searchTerm = this.selectedItensFilter;
123
+ searchTerm = searchTerm.trim();
124
+ if (searchTerm) {
125
+ this.selectedItensFilterUtil.filteredSelectedItens = this.selectedItensFilterUtil.rawSelectedItens
126
+ .filter(function (item) { return compareStrings(item.data[_this.filterBy], searchTerm); });
127
+ }
128
+ else {
129
+ this.selectedItensFilterUtil.filteredSelectedItens = this.selectedItensFilterUtil.rawSelectedItens;
130
+ }
131
+ };
132
+ PicklistComponent.prototype.drop = function (event) {
133
+ var isDifferentContainer = event.container !== event.previousContainer;
134
+ if (!isDifferentContainer) {
135
+ return;
136
+ }
137
+ var isRemovedItens = event.previousContainer.id === this.selectedItensId;
138
+ if (isRemovedItens) {
139
+ this.remove();
140
+ }
141
+ else {
142
+ this.add();
143
+ }
144
+ this.cdr.detectChanges();
145
+ };
146
+ PicklistComponent.prototype.onDragStart = function (event, dragListId) {
147
+ this.unselectedItensByListId(this.getOppositiveId(dragListId));
148
+ event.source.data.selected = true;
149
+ this.selectedItensMap.add(event.source.data);
150
+ this.selectedItensMap.forEach(function (x) { return x.invisible = true; });
151
+ this.cdr.detectChanges();
152
+ };
153
+ PicklistComponent.prototype.onDragRelease = function () {
154
+ this.selectedItensMap.forEach(function (item) { return item.invisible = false; });
155
+ };
156
+ PicklistComponent.prototype.checkAllAvailableItensChange = function (checked) {
157
+ this._checkAllSelectedItensChange(checked, this.itensToSelectFilterUtil.filteredItensToSelect, this.itensToSelectId);
158
+ };
159
+ PicklistComponent.prototype.checkAllSelectedItensChange = function (checked) {
160
+ this._checkAllSelectedItensChange(checked, this.selectedItensFilterUtil.filteredSelectedItens, this.selectedItensId);
161
+ };
162
+ Object.defineProperty(PicklistComponent.prototype, "disableSelectedItensCheckbox", {
163
+ get: function () {
164
+ return filterEnabled(this.selectedItensFilterUtil.filteredSelectedItens).length === 0;
165
+ },
166
+ enumerable: true,
167
+ configurable: true
168
+ });
169
+ Object.defineProperty(PicklistComponent.prototype, "disableItensToSelectCheckbox", {
170
+ get: function () {
171
+ return filterEnabled(this.itensToSelectFilterUtil.filteredItensToSelect).length === 0;
172
+ },
173
+ enumerable: true,
174
+ configurable: true
175
+ });
176
+ Object.defineProperty(PicklistComponent.prototype, "itensToSelectAllSelected", {
177
+ get: function () {
178
+ return this._checkAllSelectedByList(this.itensToSelectFilterUtil.filteredItensToSelect);
179
+ },
180
+ enumerable: true,
181
+ configurable: true
182
+ });
183
+ Object.defineProperty(PicklistComponent.prototype, "selectedItensAllSelected", {
184
+ get: function () {
185
+ return this._checkAllSelectedByList(this.selectedItensFilterUtil.filteredSelectedItens);
186
+ },
187
+ enumerable: true,
188
+ configurable: true
189
+ });
190
+ Object.defineProperty(PicklistComponent.prototype, "canAddItens", {
191
+ get: function () {
192
+ return this.itensToSelect.filter(function (x) { return x === null || x === void 0 ? void 0 : x.selected; }).length > 0;
193
+ },
194
+ enumerable: true,
195
+ configurable: true
196
+ });
197
+ Object.defineProperty(PicklistComponent.prototype, "canRemoveItens", {
198
+ get: function () {
199
+ return this.selectedItens.filter(function (x) { return x === null || x === void 0 ? void 0 : x.selected; }).length > 0;
200
+ },
201
+ enumerable: true,
202
+ configurable: true
203
+ });
204
+ PicklistComponent.prototype._checkAllSelectedByList = function (list) {
205
+ var _listItens = filterEnabled(list);
206
+ if (!_listItens.length) {
207
+ return false;
208
+ }
209
+ else {
210
+ return _listItens.every(function (x) { return x.selected; });
211
+ }
212
+ };
213
+ PicklistComponent.prototype._checkAllSelectedItensChange = function (checked, list, listId) {
214
+ var _this = this;
215
+ this.unselectedItensByListId(listId === this.selectedItensId ? this.itensToSelectId : this.selectedItensId);
216
+ filterEnabled(list).forEach(function (item) {
217
+ item.selected = checked;
218
+ _this.selectedItensMap.add(item);
219
+ });
220
+ this.cdr.detectChanges();
221
+ };
222
+ PicklistComponent.prototype.unselectedItensByListId = function (listId) {
223
+ var _this = this;
224
+ var clearList = this.getAllElementsByListId(listId);
225
+ clearList.forEach(function (x) {
226
+ x.selected = false;
227
+ _this.selectedItensMap.delete(x);
228
+ });
229
+ this.cdr.detectChanges();
230
+ };
231
+ PicklistComponent.prototype.getAllElementsByListId = function (listId) {
232
+ return listId === this.selectedItensId ? this.selectedItensFilterUtil.rawSelectedItens : this.itensToSelectFilterUtil.rawItensToSelect;
233
+ };
234
+ PicklistComponent.prototype.getOppositiveId = function (listId) {
235
+ return listId === this.selectedItensId ? this.itensToSelectId : this.selectedItensId;
236
+ };
237
+ PicklistComponent.prototype.emitData = function () {
238
+ this.itensToSelectChange.emit(parseValueEmit(this.itensToSelect));
239
+ this.selectedItensChange.emit(parseValueEmit(this.selectedItens));
240
+ };
241
+ PicklistComponent.ctorParameters = function () { return [
242
+ { type: ChangeDetectorRef }
243
+ ]; };
244
+ __decorate([
245
+ Input()
246
+ ], PicklistComponent.prototype, "itensToSelect", void 0);
247
+ __decorate([
248
+ Input()
249
+ ], PicklistComponent.prototype, "selectedItens", void 0);
250
+ __decorate([
251
+ Input()
252
+ ], PicklistComponent.prototype, "availableItensLabel", void 0);
253
+ __decorate([
254
+ Input()
255
+ ], PicklistComponent.prototype, "availableItensPlaceholder", void 0);
256
+ __decorate([
257
+ Input()
258
+ ], PicklistComponent.prototype, "addSelectedItensLabel", void 0);
259
+ __decorate([
260
+ Input()
261
+ ], PicklistComponent.prototype, "addAllItensLabel", void 0);
262
+ __decorate([
263
+ Input()
264
+ ], PicklistComponent.prototype, "selectedItensLabel", void 0);
265
+ __decorate([
266
+ Input()
267
+ ], PicklistComponent.prototype, "selectedItensPlaceholder", void 0);
268
+ __decorate([
269
+ Input()
270
+ ], PicklistComponent.prototype, "removeSelectedItemsLabel", void 0);
271
+ __decorate([
272
+ Input()
273
+ ], PicklistComponent.prototype, "removeAllItemsLabel", void 0);
274
+ __decorate([
275
+ Input()
276
+ ], PicklistComponent.prototype, "showCheckbox", void 0);
277
+ __decorate([
278
+ Input()
279
+ ], PicklistComponent.prototype, "filterBy", void 0);
280
+ __decorate([
281
+ Output()
282
+ ], PicklistComponent.prototype, "selectedItensChange", void 0);
283
+ __decorate([
284
+ Output()
285
+ ], PicklistComponent.prototype, "itensToSelectChange", void 0);
286
+ __decorate([
287
+ ContentChildren(TemplateDirective)
288
+ ], PicklistComponent.prototype, "templates", void 0);
289
+ PicklistComponent = __decorate([
290
+ Component({
291
+ selector: 's-picklist',
292
+ template: "<ng-template #previewRender let-itens=\"itens\" let-template=\"template\">\n <section class=\"picklist-items\">\n <ng-container *ngFor=\"let item of itens\">\n <ng-container *ngTemplateOutlet=\"template; context: { item: item.data }\"></ng-container>\n </ng-container>\n </section>\n</ng-template>\n\n<ng-template #picklistItensRender let-id=\"id\" let-itens=\"itens\" let-template=\"template\" let-listConnectedTo=\"listConnectedTo\">\n <div\n class=\"picklist-items\"\n cdkDropList\n [id]=\"id\"\n [cdkDropListSortingDisabled]=\"true\"\n [cdkDropListData]=\"itens\"\n [cdkDropListConnectedTo]=\"listConnectedTo\"\n (cdkDropListDropped)=\"drop($event)\">\n <div\n *ngFor=\"let item of itens\"\n cdkDrag\n [cdkDragDisabled]=\"item.disabled\"\n [cdkDragData]=\"item\"\n (click)=\"toggleSelected(item, id)\"\n (cdkDragStarted)=\"onDragStart($event, id)\"\n (cdkDragReleased)=\"onDragRelease()\"\n class=\"picklist-item\"\n [class.picklist-disabled]=\"item.disabled\"\n [class.picklist-item-invisible]=\"item.invisible\"\n [class.picklist-item-active]=\"item.selected\">\n <input\n type=\"checkbox\"\n class=\"input-checkbox\"\n [(ngModel)]=\"item.selected\"\n [disabled]=\"item.disabled\"\n *ngIf=\"showCheckbox\">\n <div class=\"picklist-content\">\n <ng-container *ngTemplateOutlet=\"template; context: { item: item.data, selected: item.selected, disabled: item.disabled }\"></ng-container>\n </div>\n <ng-container *cdkDragPreview>\n <ng-container *ngTemplateOutlet=\"previewRender; context: { itens: selectedItensMap, template: template }\"></ng-container>\n </ng-container>\n </div>\n</div>\n</ng-template>\n\n<ng-template #checkboxTitleRender let-disabled=\"disabled\" let-checked=\"checked\" let-changeFn=\"changeFn\">\n <input\n *ngIf=\"showCheckbox\"\n class=\"input-checkbox\"\n type=\"checkbox\"\n [disabled]=\"disabled\"\n [checked]=\"checked\"\n (change)=\"changeFn($event.target.checked)\">\n</ng-template>\n\n<div class=\"picklist-container\">\n <div class=\"picklist-item-container\">\n <div class=\"picklist-box\">\n <div class=\"picklist-title-container\">\n <ng-container *ngIf=\"!filterBy\">\n <ng-container *ngTemplateOutlet=\"checkboxTitleRender; context: { disabled: disableItensToSelectCheckbox, checked: itensToSelectAllSelected, changeFn: checkAllAvailableItensChange.bind(this) }\"></ng-container>\n </ng-container>\n <span class=\"picklist-title\">\n {{ availableItensLabel || 'platform.angular_components.available-items' | translate }}\n </span>\n </div>\n <div class=\"picklist-filter\" *ngIf=\"filterBy && showCheckbox\">\n <ng-container *ngTemplateOutlet=\"checkboxTitleRender; context: { disabled: disableItensToSelectCheckbox, checked: itensToSelectAllSelected, changeFn: checkAllAvailableItensChange.bind(this) }\"></ng-container>\n <input\n *ngIf=\"filterBy\"\n type=\"text\"\n class=\"input-search\"\n [(ngModel)]=\"availableItensFilter\"\n (ngModelChange)=\"filterItensToSelect()\"\n [placeholder]=\"availableItensPlaceholder || 'plataform.angular_components.picklist-placeholder' | translate\">\n </div>\n <ng-container *ngTemplateOutlet=\"picklistItensRender;\n context: {\n id: itensToSelectId,\n itens: itensToSelectFilterUtil.filteredItensToSelect,\n template: itemToSelectTemplate,\n listConnectedTo: selectedItensId\n }\">\n </ng-container>\n </div>\n <div class=\"buttons-container\">\n <s-button\n [label]=\"addSelectedItensLabel || 'platform.angular_components.add' | translate\"\n priority=\"primary\"\n rightIconClass=\"fa fa-fw fa-arrow-right\"\n [disabled]=\"!canAddItens\"\n (onClick)=\"add()\"\n [auxiliary]=\"false\"\n [caret]=\"false\">\n </s-button>\n <s-button\n [label]=\"addAllItensLabel || 'platform.angular_components.add_all' | translate\"\n priority=\"link\"\n (onClick)=\"add(true)\"\n [auxiliary]=\"false\">\n </s-button>\n </div>\n </div>\n <div class=\"picklist-item-container\">\n <div class=\"picklist-box\">\n <div class=\"picklist-title-container\">\n <ng-container *ngIf=\"!filterBy\">\n <ng-container *ngTemplateOutlet=\"checkboxTitleRender; context: { disabled: disableSelectedItensCheckbox, checked: selectedItensAllSelected, changeFn: checkAllSelectedItensChange.bind(this) }\"></ng-container>\n </ng-container>\n <span class=\"picklist-title\">\n {{ selectedItensLabel || 'platform.angular_components.selected-items' | translate }}\n </span>\n </div>\n <div class=\"picklist-filter\" *ngIf=\"filterBy && showCheckbox\">\n <ng-container *ngTemplateOutlet=\"checkboxTitleRender; context: { disabled: disableSelectedItensCheckbox, checked: selectedItensAllSelected, changeFn: checkAllSelectedItensChange.bind(this) }\"></ng-container>\n <input\n *ngIf=\"filterBy\"\n type=\"text\"\n class=\"input-search\"\n [(ngModel)]=\"selectedItensFilter\"\n (ngModelChange)=\"filterSelectedItens()\"\n [placeholder]=\"selectedItensPlaceholder || 'plataform.angular_components.picklist-placeholder' | translate\">\n </div>\n <ng-container *ngTemplateOutlet=\"picklistItensRender;\n context: {\n id: selectedItensId,\n itens: selectedItensFilterUtil.filteredSelectedItens,\n template: itemSelectedTemplate,\n listConnectedTo: itensToSelectId\n }\">\n\n </ng-container>\n </div>\n <div class=\"buttons-container\">\n <s-button\n [label]=\"removeSelectedItemsLabel || 'platform.angular_components.remove' | translate\"\n priority=\"primary\"\n iconClass=\"fa fa-fw fa-arrow-left\"\n [disabled]=\"!canRemoveItens\"\n [auxiliary]=\"false\"\n (onClick)=\"remove()\"\n [caret]=\"false\">\n </s-button>\n <s-button\n [label]=\"removeAllItemsLabel || 'platform.angular_components.remove_all' | translate\"\n priority=\"link\"\n (onClick)=\"remove(true)\"\n [auxiliary]=\"false\">\n </s-button>\n </div>\n </div>\n</div>\n",
293
+ styles: [".picklist-container{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;border-radius:4px solid #dedce5;width:100%;background-color:#fff;gap:20px;padding:8px}.picklist-container .picklist-item-container{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex:1;flex:1}.picklist-container .picklist-item-container .picklist-box{border:1px solid #dedce5;padding:8px;height:100%;min-width:200px}.picklist-container .picklist-item-container .picklist-box .picklist-filter{display:-ms-flexbox;display:flex;width:100%}.picklist-container .picklist-item-container .picklist-box .picklist-filter .input-search{border:1px solid #dedce5;min-height:35px;width:100%;border-radius:3px;margin-bottom:10px;margin-top:10px;padding:0 8px;-ms-flex:1;flex:1}.picklist-container .picklist-item-container .picklist-box .picklist-title-container{width:100%;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}.picklist-container .picklist-item-container .picklist-box .picklist-title-container .picklist-title{font-family:Open Sans;font-size:14px;font-weight:700;line-height:21px;text-underline-position:from-font;-webkit-text-decoration-skip-ink:none;text-decoration-skip-ink:none}.picklist-container .picklist-item-container .picklist-box .picklist-items{max-height:23em;overflow:auto;height:100%;min-height:55px}.picklist-container .picklist-item-container .picklist-box .picklist-items .picklist-content{width:100%;height:100%;padding-right:8px;border-radius:3px;margin-bottom:8px}.picklist-container .picklist-item-container .picklist-box .picklist-items .picklist-item{height:55px;border:3px;display:-ms-flexbox;display:flex}.picklist-container .picklist-item-container .picklist-box .picklist-items .picklist-item:not(.picklist-disabled){cursor:pointer}.picklist-container .picklist-item-container .picklist-box .picklist-items .picklist-item:hover:not(.picklist-disabled,.picklist-item-active,.picklist-item-invisible){background-color:#f1f7f8}.picklist-container .picklist-item-container .picklist-box .picklist-items .picklist-item-active:not(.picklist-item-invisible){background-color:#d5e8ec}.picklist-container .picklist-item-container .picklist-box .picklist-items .picklist-disabled{opacity:.5;background-color:#fbfafc}.picklist-container .picklist-item-container .picklist-box .picklist-items .picklist-item-invisible{display:none!important}.picklist-container .picklist-item-container .buttons-container{padding-top:10px;display:-ms-flexbox;display:flex}.picklist-container .picklist-item-container .input-checkbox{margin:12px}"]
294
+ })
295
+ ], PicklistComponent);
296
+ return PicklistComponent;
297
+ }());
298
+ export { PicklistComponent };
299
+ var normalizeString = function (str) {
300
+ return str.normalize("NFD").replace(/[\u0300-\u036f]/g, "").toLowerCase();
301
+ };
302
+ var ɵ0 = normalizeString;
303
+ /**
304
+ * Compares two strings by normalizing them to a case-insensitive and accent-free form,
305
+ * and checks if the main string contains the substring.
306
+ *
307
+ * @param mainString - The string to be searched.
308
+ * @param substring - The string to search for within the main string.
309
+ * @returns A boolean indicating whether the normalized main string contains the normalized substring.
310
+ */
311
+ var compareStrings = function (mainString, substring) {
312
+ return normalizeString(mainString).includes(normalizeString(substring));
313
+ };
314
+ var ɵ1 = compareStrings;
315
+ var randomHash = function (prefix) {
316
+ if (prefix === void 0) { prefix = 'id'; }
317
+ return prefix + "-" + Math.random().toString(36).substring(2, 9) + "-" + Date.now().toString(36);
318
+ };
319
+ var ɵ2 = randomHash;
320
+ var filterEnabled = function (list) {
321
+ var _list = list instanceof Set ? Array.from(list) : list;
322
+ return _list.filter(function (x) { return !x.disabled; });
323
+ };
324
+ var ɵ3 = filterEnabled;
325
+ var mapData = function (list) {
326
+ return list.map(function (x) { return x.data; });
327
+ };
328
+ var ɵ4 = mapData;
329
+ var parseValueEmit = pipe(filterEnabled, mapData);
330
+ export var parseItensPickList = function (array, disabledFn) {
331
+ return array.map(function (x) {
332
+ return {
333
+ data: x,
334
+ disabled: disabledFn ? disabledFn(x) : false
335
+ };
336
+ });
337
+ };
338
+ export { ɵ0, ɵ1, ɵ2, ɵ3, ɵ4 };
339
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"picklist.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/picklist/picklist/picklist.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkDrag, CdkDragDrop } from '@angular/cdk/drag-drop';\nimport { AfterViewInit, ChangeDetectorRef, Component, ContentChildren, EventEmitter, Input, OnChanges, Output, QueryList, SimpleChanges, TemplateRef } from '@angular/core';\nimport { pipe } from 'rxjs';\nimport { TemplateDirective } from './../../template/template.directive';\nimport { PicklistTemplateTypes, PickListItem } from './models/picklist-models';\n\ninterface InternalPicklistItem<T = any> extends PickListItem<T> {\n  invisible?: boolean\n  selected?: boolean\n}\n\ntype CdkDragEvent = { source: CdkDrag<InternalPicklistItem<any>> };\n\n@Component({\n  selector: 's-picklist',\n  templateUrl: './picklist.component.html',\n  styleUrls: ['./picklist.component.scss']\n})\nexport class PicklistComponent implements AfterViewInit, OnChanges {\n  @Input() itensToSelect: PickListItem<any>[] = [];\n  @Input() selectedItens: PickListItem<any>[] = [];\n  @Input() availableItensLabel: string;\n  @Input() availableItensPlaceholder: string;\n  @Input() addSelectedItensLabel: string;\n  @Input() addAllItensLabel: string;\n  @Input() selectedItensLabel: string;\n  @Input() selectedItensPlaceholder: string;\n  @Input() removeSelectedItemsLabel: string;\n  @Input() removeAllItemsLabel: string;\n  @Input() showCheckbox = false;\n  @Input() filterBy = '';\n  @Output() selectedItensChange = new EventEmitter<any[]>();\n  @Output() itensToSelectChange = new EventEmitter<any[]>();\n  availableItensFilter = '';\n  selectedItensFilter = '';\n  itemToSelectTemplate: TemplateRef<any>;\n  itemSelectedTemplate: TemplateRef<any>;\n  itensToSelectFilterUtil: {\n    rawItensToSelect: InternalPicklistItem[],\n    filteredItensToSelect: InternalPicklistItem[],\n  } = {\n      rawItensToSelect: [],\n      filteredItensToSelect: [],\n    }\n\n  selectedItensFilterUtil: {\n    rawSelectedItens: InternalPicklistItem[]\n    filteredSelectedItens: InternalPicklistItem[],\n  } = {\n      rawSelectedItens: [],\n      filteredSelectedItens: [],\n    }\n  selectedItensMap: Set<InternalPicklistItem> = new Set();\n  itensToSelectId = randomHash('itensToSelect');\n  selectedItensId = randomHash('selectedItens');\n  private lastSelected: 'toSelect' | 'selected';\n\n  @ContentChildren(TemplateDirective) private templates: QueryList<TemplateDirective>;\n  constructor(private cdr: ChangeDetectorRef) { }\n\n  ngAfterViewInit(): void {\n    this.itemToSelectTemplate = this.templates.find(x => x.type === PicklistTemplateTypes.ItemToSelect)?.template;\n    this.itemSelectedTemplate = this.templates.find(x => x.type === PicklistTemplateTypes.SelectedItem)?.template;\n    if (!this.itemToSelectTemplate) {\n      console.error(`Missing template for ${PicklistTemplateTypes.ItemToSelect} add this template using sTemplate directive.`);\n    }\n    if (!this.itemSelectedTemplate) {\n      console.error(`Missing template for ${PicklistTemplateTypes.SelectedItem} add this template using sTemplate directive.`);\n    }\n    this.cdr.detectChanges();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.itensToSelect && changes.itensToSelect.firstChange) {\n      this.itensToSelectFilterUtil = {\n        rawItensToSelect: this.itensToSelect,\n        filteredItensToSelect: this.itensToSelect,\n      }\n    }\n\n    if (changes.selectedItens && changes.selectedItens.firstChange) {\n      this.selectedItensFilterUtil = {\n        filteredSelectedItens: this.selectedItens,\n        rawSelectedItens: this.selectedItens\n      }\n    }\n  }\n\n  toggleSelected(internalPicklistItem: InternalPicklistItem, containerListId: string) {\n    if (internalPicklistItem.disabled) {\n      return;\n    }\n    this.unselectedItensByListId(this.getOppositiveId(containerListId));\n    internalPicklistItem.selected = !internalPicklistItem.selected;\n    if (internalPicklistItem.selected) {\n      this.selectedItensMap.add(internalPicklistItem);\n    } else {\n      this.selectedItensMap.delete(internalPicklistItem);\n    }\n    this.cdr.detectChanges();\n  }\n\n  remove(all = false) {\n    const itens = filterEnabled((all ? this.selectedItensFilterUtil.rawSelectedItens : this.selectedItensMap));\n    if (!itens.length) {\n      return;\n    }\n    itens.forEach((itemRemove) => {\n      this.itensToSelect.push(itemRemove);\n      itemRemove.selected = false;\n      this.selectedItensMap.delete(itemRemove);\n    })\n    this.selectedItens = this.selectedItens.filter(x => !itens.includes(x));\n    this.selectedItensFilterUtil.rawSelectedItens = this.selectedItens;\n    this.filterSelectedItens();\n    this.filterItensToSelect();\n    this.emitData();\n    this.cdr.detectChanges();\n  }\n\n  add(all = false) {\n    const itens = filterEnabled((all ? this.itensToSelectFilterUtil.rawItensToSelect : this.selectedItensMap));\n    if (!itens.length) {\n      return;\n    }\n    itens.forEach((itemRemove) => {\n      this.selectedItens.push(itemRemove);\n      itemRemove.selected = false;\n      this.selectedItensMap.delete(itemRemove);\n    })\n    this.itensToSelect = this.itensToSelect.filter(x => !itens.includes(x));\n    this.itensToSelectFilterUtil.rawItensToSelect = this.itensToSelect;\n    this.filterSelectedItens();\n    this.filterItensToSelect();\n    this.emitData();\n    this.cdr.detectChanges();\n  }\n\n  filterItensToSelect() {\n    let searchTerm = this.availableItensFilter;\n    searchTerm = searchTerm.trim();\n    if (searchTerm) {\n      this.itensToSelectFilterUtil.filteredItensToSelect = this.itensToSelectFilterUtil.rawItensToSelect\n        .filter((item) => compareStrings(item.data[this.filterBy], searchTerm));\n    } else {\n      this.itensToSelectFilterUtil.filteredItensToSelect = this.itensToSelectFilterUtil.rawItensToSelect;\n    }\n    this.cdr.detectChanges();\n  }\n\n  filterSelectedItens() {\n    let searchTerm = this.selectedItensFilter;\n    searchTerm = searchTerm.trim();\n    if (searchTerm) {\n      this.selectedItensFilterUtil.filteredSelectedItens = this.selectedItensFilterUtil.rawSelectedItens\n        .filter((item) => compareStrings(item.data[this.filterBy], searchTerm));\n    } else {\n      this.selectedItensFilterUtil.filteredSelectedItens = this.selectedItensFilterUtil.rawSelectedItens;\n    }\n  }\n\n  drop(event: CdkDragDrop<InternalPicklistItem[]>) {\n    const isDifferentContainer = event.container !== event.previousContainer;\n    if (!isDifferentContainer) {\n      return;\n    }\n\n    const isRemovedItens = event.previousContainer.id === this.selectedItensId;\n    if (isRemovedItens) {\n      this.remove();\n    } else {\n      this.add();\n    }\n    this.cdr.detectChanges();\n  }\n\n  onDragStart(event: CdkDragEvent, dragListId: string) {\n    this.unselectedItensByListId(this.getOppositiveId(dragListId));\n    event.source.data.selected = true;\n    this.selectedItensMap.add(event.source.data);\n    this.selectedItensMap.forEach((x) => x.invisible = true);\n    this.cdr.detectChanges();\n  }\n\n  onDragRelease() {\n    this.selectedItensMap.forEach((item) => item.invisible = false);\n  }\n\n  checkAllAvailableItensChange(checked: boolean) {\n    this._checkAllSelectedItensChange(checked, this.itensToSelectFilterUtil.filteredItensToSelect, this.itensToSelectId);\n  }\n\n  checkAllSelectedItensChange(checked: boolean) {\n    this._checkAllSelectedItensChange(checked, this.selectedItensFilterUtil.filteredSelectedItens, this.selectedItensId);\n  }\n\n  get disableSelectedItensCheckbox() {\n    return filterEnabled(this.selectedItensFilterUtil.filteredSelectedItens).length === 0;\n  }\n\n  get disableItensToSelectCheckbox() {\n    return filterEnabled(this.itensToSelectFilterUtil.filteredItensToSelect).length === 0;\n  }\n\n  get itensToSelectAllSelected() {\n    return this._checkAllSelectedByList(this.itensToSelectFilterUtil.filteredItensToSelect);\n  }\n\n  get selectedItensAllSelected() {\n    return this._checkAllSelectedByList(this.selectedItensFilterUtil.filteredSelectedItens);\n  }\n\n  get canAddItens() {\n    return (this.itensToSelect as InternalPicklistItem[]).filter((x) => x?.selected).length > 0;\n  }\n\n  get canRemoveItens() {\n    return (this.selectedItens as InternalPicklistItem[]).filter((x) => x?.selected).length > 0;\n  }\n\n  private _checkAllSelectedByList(list: InternalPicklistItem[]) {\n    const _listItens = filterEnabled(list);\n    if (!_listItens.length) {\n      return false;\n    } else {\n      return _listItens.every((x) => x.selected);\n    }\n  }\n\n  private _checkAllSelectedItensChange(checked: boolean, list: InternalPicklistItem[], listId: string) {\n    this.unselectedItensByListId(listId === this.selectedItensId ? this.itensToSelectId : this.selectedItensId);\n    filterEnabled(list).forEach((item) => {\n      item.selected = checked;\n      this.selectedItensMap.add(item);\n    })\n    this.cdr.detectChanges();\n  }\n\n  private unselectedItensByListId(listId: string) {\n    const clearList = this.getAllElementsByListId(listId);\n    clearList.forEach((x) => {\n      x.selected = false;\n      this.selectedItensMap.delete(x);\n    })\n    this.cdr.detectChanges();\n  }\n\n  private getAllElementsByListId(listId: string) {\n    return listId === this.selectedItensId ? this.selectedItensFilterUtil.rawSelectedItens : this.itensToSelectFilterUtil.rawItensToSelect;\n  }\n\n  private getOppositiveId(listId: string) {\n    return listId === this.selectedItensId ? this.itensToSelectId : this.selectedItensId;\n  }\n\n  private emitData() {\n    this.itensToSelectChange.emit(parseValueEmit(this.itensToSelect));\n    this.selectedItensChange.emit(parseValueEmit(this.selectedItens));\n  }\n}\n\nconst normalizeString = (str: string) => {\n  return str.normalize(\"NFD\").replace(/[\\u0300-\\u036f]/g, \"\").toLowerCase();\n}\n\n/**\n * Compares two strings by normalizing them to a case-insensitive and accent-free form,\n * and checks if the main string contains the substring.\n *\n * @param mainString - The string to be searched.\n * @param substring - The string to search for within the main string.\n * @returns A boolean indicating whether the normalized main string contains the normalized substring.\n */\n\nconst compareStrings = (mainString: string, substring: string) => {\n  return normalizeString(mainString).includes(normalizeString(substring));\n}\n\nconst randomHash = (prefix = 'id') => {\n  return `${prefix}-${Math.random().toString(36).substring(2, 9)}-${Date.now().toString(36)}`\n}\n\nconst filterEnabled = (list: PickListItem<any>[] | Set<InternalPicklistItem>): InternalPicklistItem[] => {\n  const _list = list instanceof Set ? Array.from(list) : list;\n  return _list.filter((x) => !x.disabled);\n}\n\nconst mapData = (list: PickListItem<any>[]) => {\n  return list.map((x) => x.data);\n}\n\nconst parseValueEmit = pipe(filterEnabled, mapData)\n\nexport const parseItensPickList = <T>(array: T[], disabledFn?: (item: T) => boolean): PickListItem<T>[] => {\n  return array.map((x) => {\n    return {\n      data: x,\n      disabled: disabledFn ? disabledFn(x) : false\n    }\n  })\n}\n"]}
@@ -0,0 +1,28 @@
1
+ import { __decorate } from "tslib";
2
+ import { DragDropModule } from '@angular/cdk/drag-drop';
3
+ import { CommonModule } from '@angular/common';
4
+ import { NgModule } from '@angular/core';
5
+ import { FormsModule } from '@angular/forms';
6
+ import { TranslateModule } from '@ngx-translate/core';
7
+ import { ButtonModule } from '../button';
8
+ import { PicklistComponent } from './picklist/picklist.component';
9
+ var PicklistModule = /** @class */ (function () {
10
+ function PicklistModule() {
11
+ }
12
+ PicklistModule = __decorate([
13
+ NgModule({
14
+ declarations: [PicklistComponent],
15
+ imports: [
16
+ CommonModule,
17
+ TranslateModule,
18
+ DragDropModule,
19
+ FormsModule,
20
+ ButtonModule,
21
+ ],
22
+ exports: [PicklistComponent]
23
+ })
24
+ ], PicklistModule);
25
+ return PicklistModule;
26
+ }());
27
+ export { PicklistModule };
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGlja2xpc3QubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvcGlja2xpc3QvcGlja2xpc3QubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDeEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBY2xFO0lBQUE7SUFBOEIsQ0FBQztJQUFsQixjQUFjO1FBWDFCLFFBQVEsQ0FBQztZQUNSLFlBQVksRUFBRSxDQUFDLGlCQUFpQixDQUFDO1lBQ2pDLE9BQU8sRUFBRTtnQkFDUCxZQUFZO2dCQUNaLGVBQWU7Z0JBQ2YsY0FBYztnQkFDZCxXQUFXO2dCQUNYLFlBQVk7YUFDYjtZQUNELE9BQU8sRUFBRSxDQUFDLGlCQUFpQixDQUFDO1NBQzdCLENBQUM7T0FDVyxjQUFjLENBQUk7SUFBRCxxQkFBQztDQUFBLEFBQS9CLElBQStCO1NBQWxCLGNBQWMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEcmFnRHJvcE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9kcmFnLWRyb3AnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHsgQnV0dG9uTW9kdWxlIH0gZnJvbSAnLi4vYnV0dG9uJztcbmltcG9ydCB7IFBpY2tsaXN0Q29tcG9uZW50IH0gZnJvbSAnLi9waWNrbGlzdC9waWNrbGlzdC5jb21wb25lbnQnO1xuXG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1BpY2tsaXN0Q29tcG9uZW50XSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBUcmFuc2xhdGVNb2R1bGUsXG4gICAgRHJhZ0Ryb3BNb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgQnV0dG9uTW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbUGlja2xpc3RDb21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIFBpY2tsaXN0TW9kdWxlIHsgfVxuIl19