@seniorsistemas/angular-components 17.15.4 → 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.
- package/bundles/seniorsistemas-angular-components.umd.js +378 -6
- package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js +2 -2
- package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
- package/components/index.d.ts +1 -0
- package/components/picklist/index.d.ts +4 -0
- package/components/picklist/picklist/models/picklist-models.d.ts +8 -0
- package/components/picklist/picklist/picklist.component.d.ts +71 -0
- package/components/picklist/picklist.module.d.ts +2 -0
- package/components/table/table-column/table-columns.component.d.ts +8 -5
- package/esm2015/components/index.js +2 -1
- package/esm2015/components/picklist/index.js +5 -0
- package/esm2015/components/picklist/picklist/models/picklist-models.js +6 -0
- package/esm2015/components/picklist/picklist/picklist.component.js +305 -0
- package/esm2015/components/picklist/picklist.module.js +25 -0
- package/esm2015/components/table/table-column/table-columns.component.js +7 -6
- package/esm2015/locale/fallback.js +7 -2
- package/esm2015/seniorsistemas-angular-components.js +2 -1
- package/esm5/components/index.js +2 -1
- package/esm5/components/picklist/index.js +5 -0
- package/esm5/components/picklist/picklist/models/picklist-models.js +6 -0
- package/esm5/components/picklist/picklist/picklist.component.js +339 -0
- package/esm5/components/picklist/picklist.module.js +28 -0
- package/esm5/components/table/table-column/table-columns.component.js +7 -6
- package/esm5/locale/fallback.js +7 -2
- package/esm5/seniorsistemas-angular-components.js +2 -1
- package/fesm2015/seniorsistemas-angular-components.js +334 -8
- package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
- package/fesm5/seniorsistemas-angular-components.js +371 -8
- package/fesm5/seniorsistemas-angular-components.js.map +1 -1
- package/package.json +1 -1
- package/seniorsistemas-angular-components.d.ts +1 -0
- 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
|