@sankhyalabs/sankhyablocks 8.15.0-dev.30 → 8.15.0-dev.31
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/dist/cjs/SnkMultiSelectionListDataSource-5213120b.js +140 -0
- package/dist/cjs/index-f9e81701.js +2 -10
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/cjs/{pesquisa-fetcher-c416a6b7.js → pesquisa-fetcher-94f6b316.js} +231 -20
- package/dist/cjs/sankhyablocks.cjs.js +1 -1
- package/dist/cjs/{snk-actions-button_2.cjs.entry.js → snk-actions-button_4.cjs.entry.js} +517 -2
- package/dist/cjs/snk-application.cjs.entry.js +1 -2
- package/dist/cjs/snk-attach.cjs.entry.js +3 -4
- package/dist/cjs/snk-crud.cjs.entry.js +2 -3
- package/dist/cjs/snk-detail-view.cjs.entry.js +4 -5
- package/dist/cjs/snk-form-config.cjs.entry.js +6 -0
- package/dist/cjs/snk-form.cjs.entry.js +1 -1
- package/dist/cjs/snk-grid.cjs.entry.js +10 -19
- package/dist/cjs/{snk-guides-viewer-bd69fce4.js → snk-guides-viewer-c7293cfa.js} +2 -3
- package/dist/cjs/snk-guides-viewer.cjs.entry.js +3 -4
- package/dist/cjs/snk-personalized-filter-editor.cjs.entry.js +3 -1
- package/dist/cjs/snk-simple-crud.cjs.entry.js +147 -16
- package/dist/collection/collection-manifest.json +6 -6
- package/dist/collection/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.js +2 -2
- package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.js +1 -1
- package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-personalized-filter-editor/snk-personalized-filter-editor.js +3 -1
- package/dist/collection/components/snk-form/snk-form.js +1 -1
- package/dist/collection/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.js +11 -5
- package/dist/collection/components/snk-grid/snk-grid.js +5 -16
- package/dist/collection/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.js +130 -123
- package/dist/collection/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.js +1 -1
- package/dist/collection/components/snk-simple-crud/snk-simple-crud.css +5 -0
- package/dist/collection/components/snk-simple-crud/snk-simple-crud.js +226 -14
- package/dist/collection/lib/http/data-fetcher/fetchers/pesquisa-fetcher.js +1 -8
- package/dist/collection/lib/utils/CrudUtils.js +13 -1
- package/dist/components/dataunit-fetcher.js +1 -8
- package/dist/components/field-search.js +93 -3
- package/dist/components/index.d.ts +6 -6
- package/dist/components/snk-attach2.js +54 -12
- package/dist/components/snk-detail-view2.js +29 -4
- package/dist/components/snk-form-config2.js +7 -1
- package/dist/components/snk-grid-config2.js +128 -102
- package/dist/components/snk-grid2.js +10 -17
- package/dist/components/snk-personalized-filter-editor.js +3 -1
- package/dist/components/snk-simple-crud2.js +204 -24
- package/dist/esm/SnkMultiSelectionListDataSource-7e7eada5.js +133 -0
- package/dist/esm/index-a7d3d3f1.js +2 -10
- package/dist/esm/loader.js +1 -1
- package/dist/esm/{pesquisa-fetcher-ab16a2e8.js → pesquisa-fetcher-f05a12ca.js} +222 -12
- package/dist/esm/sankhyablocks.js +1 -1
- package/dist/esm/{snk-actions-button_2.entry.js → snk-actions-button_4.entry.js} +516 -3
- package/dist/esm/snk-application.entry.js +1 -2
- package/dist/esm/snk-attach.entry.js +2 -3
- package/dist/esm/snk-crud.entry.js +2 -3
- package/dist/esm/snk-detail-view.entry.js +4 -5
- package/dist/esm/snk-form-config.entry.js +7 -1
- package/dist/esm/snk-form.entry.js +1 -1
- package/dist/esm/snk-grid.entry.js +11 -20
- package/dist/esm/{snk-guides-viewer-fde82cc1.js → snk-guides-viewer-47443f7c.js} +2 -3
- package/dist/esm/snk-guides-viewer.entry.js +3 -4
- package/dist/esm/snk-personalized-filter-editor.entry.js +3 -1
- package/dist/esm/snk-simple-crud.entry.js +148 -17
- package/dist/sankhyablocks/p-2897fb8c.js +1 -0
- package/dist/sankhyablocks/p-30735d1e.entry.js +1 -0
- package/dist/sankhyablocks/p-3c5b7cfc.entry.js +1 -0
- package/dist/sankhyablocks/p-6ae58da0.js +1 -0
- package/dist/sankhyablocks/{p-fcdcb0e2.entry.js → p-746fc99e.entry.js} +1 -1
- package/dist/sankhyablocks/p-99b1926b.entry.js +1 -0
- package/dist/sankhyablocks/p-9fb97691.entry.js +1 -0
- package/dist/sankhyablocks/p-b11aa1e0.entry.js +1 -0
- package/dist/sankhyablocks/p-b281e9e9.entry.js +1 -0
- package/dist/sankhyablocks/p-d78d4062.js +65 -0
- package/dist/sankhyablocks/{p-fd0a8d68.entry.js → p-ec18c04e.entry.js} +3 -3
- package/dist/sankhyablocks/p-eefe9954.entry.js +1 -0
- package/dist/sankhyablocks/p-fca66dda.entry.js +1 -0
- package/dist/sankhyablocks/p-fe741404.entry.js +1 -0
- package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
- package/dist/types/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.d.ts +1 -1
- package/dist/types/components/snk-crud/subcomponents/snk-guides-viewer.d.ts +1 -1
- package/dist/types/components/snk-form/snk-form.d.ts +1 -1
- package/dist/types/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.d.ts +4 -3
- package/dist/types/components/snk-grid/snk-grid.d.ts +0 -1
- package/dist/types/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.d.ts +11 -6
- package/dist/types/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.d.ts +1 -1
- package/dist/types/components/snk-simple-crud/snk-simple-crud.d.ts +46 -1
- package/dist/types/components.d.ts +26 -10
- package/dist/types/lib/utils/CrudUtils.d.ts +3 -0
- package/package.json +1 -1
- package/dist/cjs/PreloadManager-84466da6.js +0 -224
- package/dist/cjs/SnkMultiSelectionListDataSource-ba5838c2.js +0 -49
- package/dist/cjs/snk-grid-config.cjs.entry.js +0 -483
- package/dist/cjs/snk-select-box.cjs.entry.js +0 -25
- package/dist/esm/PreloadManager-c1c2f2b4.js +0 -222
- package/dist/esm/SnkMultiSelectionListDataSource-44494b0e.js +0 -43
- package/dist/esm/snk-grid-config.entry.js +0 -479
- package/dist/esm/snk-select-box.entry.js +0 -21
- package/dist/sankhyablocks/p-094c30cb.js +0 -1
- package/dist/sankhyablocks/p-0b0b36ac.entry.js +0 -1
- package/dist/sankhyablocks/p-11ad137d.entry.js +0 -1
- package/dist/sankhyablocks/p-57212bb5.js +0 -1
- package/dist/sankhyablocks/p-5f5b58b6.entry.js +0 -1
- package/dist/sankhyablocks/p-84bb8f47.entry.js +0 -1
- package/dist/sankhyablocks/p-91b7f78a.entry.js +0 -1
- package/dist/sankhyablocks/p-98674137.entry.js +0 -1
- package/dist/sankhyablocks/p-b7004423.entry.js +0 -1
- package/dist/sankhyablocks/p-c22c1d8e.js +0 -1
- package/dist/sankhyablocks/p-c6247955.js +0 -65
- package/dist/sankhyablocks/p-c758265f.entry.js +0 -1
- package/dist/sankhyablocks/p-d4802f81.entry.js +0 -1
- package/dist/sankhyablocks/p-e3bd000e.entry.js +0 -1
- package/dist/sankhyablocks/p-fb842329.entry.js +0 -1
- /package/dist/cjs/{SnkFormConfigManager-3621bfc4.js → SnkFormConfigManager-0ffd098d.js} +0 -0
- /package/dist/collection/components/{snk-form → snk-form-config}/SnkFormConfigManager.js +0 -0
- /package/dist/collection/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.css +0 -0
- /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.css +0 -0
- /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.js +0 -0
- /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.css +0 -0
- /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.js +0 -0
- /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.css +0 -0
- /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.js +0 -0
- /package/dist/collection/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.css +0 -0
- /package/dist/collection/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.css +0 -0
- /package/dist/esm/{SnkFormConfigManager-692e20c7.js → SnkFormConfigManager-dd450734.js} +0 -0
- /package/dist/sankhyablocks/{p-725d04ba.js → p-9ea14b61.js} +0 -0
- /package/dist/types/components/{snk-form → snk-form-config}/SnkFormConfigManager.d.ts +0 -0
- /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.d.ts +0 -0
- /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.d.ts +0 -0
- /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.d.ts +0 -0
@@ -1,222 +0,0 @@
|
|
1
|
-
import { FieldComparator, SortMode, DataUnit } from '@sankhyalabs/core';
|
2
|
-
import { ColumnFilterManager } from '@sankhyalabs/ezui/dist/collection/components/ez-grid/utils';
|
3
|
-
|
4
|
-
class ArrayRepository {
|
5
|
-
constructor(equalsFunction) {
|
6
|
-
this._list = [];
|
7
|
-
this._equalsFunction = equalsFunction;
|
8
|
-
}
|
9
|
-
async load(filterFunction, sortingFunction, offset, limit) {
|
10
|
-
let result = [].concat(this._list);
|
11
|
-
if (filterFunction != undefined) {
|
12
|
-
result = this._list.filter(item => filterFunction(item));
|
13
|
-
}
|
14
|
-
if (sortingFunction != undefined) {
|
15
|
-
result = result.sort(sortingFunction);
|
16
|
-
}
|
17
|
-
const count = result.length;
|
18
|
-
if (limit != undefined) {
|
19
|
-
const start = offset || 0;
|
20
|
-
const end = limit ? start + limit : result.length;
|
21
|
-
result = result.slice(start, end);
|
22
|
-
}
|
23
|
-
return Promise.resolve({ result, count });
|
24
|
-
}
|
25
|
-
async distict(itemProcessor) {
|
26
|
-
const processedItems = [];
|
27
|
-
let hasEmpty = false;
|
28
|
-
for (const item of this._list) {
|
29
|
-
const processedItem = itemProcessor(item);
|
30
|
-
if (processedItem == undefined) {
|
31
|
-
continue;
|
32
|
-
}
|
33
|
-
if (processedItem.value == undefined) {
|
34
|
-
hasEmpty = true;
|
35
|
-
continue;
|
36
|
-
}
|
37
|
-
processedItems.push(processedItem);
|
38
|
-
}
|
39
|
-
if (hasEmpty) {
|
40
|
-
processedItems.push({ key: "", value: null });
|
41
|
-
}
|
42
|
-
return Promise.resolve(new Map(processedItems.map(item => [item.key, item.value])));
|
43
|
-
}
|
44
|
-
async push(items) {
|
45
|
-
this._list.push(...items);
|
46
|
-
}
|
47
|
-
async clear() {
|
48
|
-
this._list = [];
|
49
|
-
}
|
50
|
-
async delete(items) {
|
51
|
-
this._list = this._list.filter(item => {
|
52
|
-
for (const removed of items) {
|
53
|
-
if (this._equalsFunction(item, removed)) {
|
54
|
-
return false;
|
55
|
-
}
|
56
|
-
}
|
57
|
-
return true;
|
58
|
-
});
|
59
|
-
}
|
60
|
-
async update(items) {
|
61
|
-
this._list = this._list.map(existingItem => {
|
62
|
-
const newItem = items.find(newItem => this._equalsFunction(existingItem, newItem));
|
63
|
-
return newItem == undefined ? existingItem : newItem;
|
64
|
-
});
|
65
|
-
}
|
66
|
-
async insert(itemReference, items) {
|
67
|
-
const itemPosition = this._list.indexOf(itemReference);
|
68
|
-
if (itemPosition == -1) {
|
69
|
-
this._list.push(...items);
|
70
|
-
return;
|
71
|
-
}
|
72
|
-
this._list = this._list.slice(0, itemPosition).concat(items).concat(this._list.slice(itemPosition));
|
73
|
-
}
|
74
|
-
isOperating() {
|
75
|
-
return true;
|
76
|
-
}
|
77
|
-
async isEmpty() {
|
78
|
-
return Promise.resolve(this._list.length === 0);
|
79
|
-
}
|
80
|
-
async count() {
|
81
|
-
return Promise.resolve(this._list.length);
|
82
|
-
}
|
83
|
-
}
|
84
|
-
|
85
|
-
class PreloadManager {
|
86
|
-
static setLoadingStatus(dataUnit, loadingInProgress) {
|
87
|
-
this._loadingStatus.set(dataUnit.name, loadingInProgress);
|
88
|
-
}
|
89
|
-
static isCacheEnabled(_dataUnit) {
|
90
|
-
return true;
|
91
|
-
}
|
92
|
-
static cacheRecords(dataUnit, records, resetDatabase, loadingInProgress) {
|
93
|
-
PreloadManager.setLoadingStatus(dataUnit, loadingInProgress);
|
94
|
-
if (PreloadManager.isCacheEnabled(dataUnit)) {
|
95
|
-
this.getRepository(dataUnit).push(records);
|
96
|
-
}
|
97
|
-
else {
|
98
|
-
if (resetDatabase) {
|
99
|
-
this._repositories.delete(dataUnit.name);
|
100
|
-
}
|
101
|
-
}
|
102
|
-
}
|
103
|
-
static getSortingFunction(dataUnit, sorting) {
|
104
|
-
if (sorting == undefined || sorting.length == 0) {
|
105
|
-
return undefined;
|
106
|
-
}
|
107
|
-
return (recordA, recordB) => {
|
108
|
-
for (const sort of sorting) {
|
109
|
-
const result = FieldComparator.compare(dataUnit.getField(sort.field), recordA, recordB, sort.mode === SortMode.ASC);
|
110
|
-
if (result != 0) {
|
111
|
-
return result;
|
112
|
-
}
|
113
|
-
}
|
114
|
-
};
|
115
|
-
}
|
116
|
-
static async getDistinct(dataUnit, fieldName) {
|
117
|
-
if (!PreloadManager.isCacheEnabled(dataUnit)) {
|
118
|
-
return Promise.resolve(ColumnFilterManager.compileDistinct(fieldName, dataUnit));
|
119
|
-
}
|
120
|
-
let filterFunction;
|
121
|
-
const request = dataUnit.getLastLoadRequest();
|
122
|
-
if (request != undefined) {
|
123
|
-
const columnFilters = ColumnFilterManager.getColumnFilters(request.filters, fieldName);
|
124
|
-
filterFunction = ColumnFilterManager.getFilterFunction(dataUnit, Array.from(columnFilters.values()));
|
125
|
-
}
|
126
|
-
return new Promise((accept, reject) => {
|
127
|
-
PreloadManager.getRepository(dataUnit).distict(record => {
|
128
|
-
if (filterFunction != undefined && !filterFunction(record)) {
|
129
|
-
return undefined;
|
130
|
-
}
|
131
|
-
const fieldValue = record[fieldName];
|
132
|
-
if (fieldValue == undefined) {
|
133
|
-
return { key: null, value: null };
|
134
|
-
}
|
135
|
-
const value = fieldValue.value != undefined ? fieldValue.value : fieldValue;
|
136
|
-
return { key: dataUnit.getFormattedValue(fieldName, fieldValue), value };
|
137
|
-
})
|
138
|
-
.then(result => {
|
139
|
-
if (result == undefined) {
|
140
|
-
accept(undefined);
|
141
|
-
return;
|
142
|
-
}
|
143
|
-
accept(Array.from(result.entries()).map(([label, value]) => ({ label, value, check: true })));
|
144
|
-
})
|
145
|
-
.catch(reason => reject(reason));
|
146
|
-
});
|
147
|
-
}
|
148
|
-
static async loadData(dataUnit, request, loadFromServer) {
|
149
|
-
try {
|
150
|
-
if (PreloadManager.isCacheEnabled(dataUnit)) {
|
151
|
-
let useCache = request.source === "EZ_GRID_LOADING_SOURCE" || request.source === DataUnit.CHANGING_PAGE_LOADING_SOURCE;
|
152
|
-
if (useCache) {
|
153
|
-
const isCacheEmpty = await PreloadManager.getRepository(dataUnit).isEmpty();
|
154
|
-
if (!isCacheEmpty) {
|
155
|
-
return PreloadManager.loadFromCache(dataUnit, request);
|
156
|
-
}
|
157
|
-
}
|
158
|
-
//Como não vamos aproveitar o cache, ele precisa ser limpo.
|
159
|
-
PreloadManager.getRepository(dataUnit).clear().catch(() => { });
|
160
|
-
}
|
161
|
-
return loadFromServer(dataUnit, request);
|
162
|
-
}
|
163
|
-
catch (error) {
|
164
|
-
console.error(error);
|
165
|
-
return Promise.reject(error);
|
166
|
-
}
|
167
|
-
}
|
168
|
-
static insertRecords(dataUnit, reference, records) {
|
169
|
-
if (PreloadManager.isCacheEnabled(dataUnit)) {
|
170
|
-
PreloadManager.getRepository(dataUnit).insert(reference, records);
|
171
|
-
}
|
172
|
-
}
|
173
|
-
static updateRecords(dataUnit, records) {
|
174
|
-
if (PreloadManager.isCacheEnabled(dataUnit)) {
|
175
|
-
PreloadManager.getRepository(dataUnit).update(records);
|
176
|
-
}
|
177
|
-
}
|
178
|
-
static removeRecords(dataUnit, records) {
|
179
|
-
if (PreloadManager.isCacheEnabled(dataUnit)) {
|
180
|
-
PreloadManager.getRepository(dataUnit).delete(records);
|
181
|
-
}
|
182
|
-
}
|
183
|
-
static async countRecords(dataUnit) {
|
184
|
-
if (PreloadManager.isCacheEnabled(dataUnit)) {
|
185
|
-
return PreloadManager.getRepository(dataUnit).count();
|
186
|
-
}
|
187
|
-
return Promise.resolve(0);
|
188
|
-
}
|
189
|
-
static getRepository(dataUnit) {
|
190
|
-
const name = dataUnit.name;
|
191
|
-
if (!PreloadManager._repositories.has(name)) {
|
192
|
-
PreloadManager._repositories.set(name, new ArrayRepository((recordA, recordB) => recordA.__record__id__ === recordB.__record__id__));
|
193
|
-
}
|
194
|
-
return PreloadManager._repositories.get(name);
|
195
|
-
}
|
196
|
-
static async loadFromCache(dataUnit, request) {
|
197
|
-
return new Promise((accept, reject) => {
|
198
|
-
const columnFilters = ColumnFilterManager.getColumnFilters(request.filters, "");
|
199
|
-
const { limit, offset, sort } = request;
|
200
|
-
PreloadManager.getRepository(dataUnit)
|
201
|
-
.load(ColumnFilterManager.getFilterFunction(dataUnit, Array.from(columnFilters.values())), PreloadManager.getSortingFunction(dataUnit, sort), offset, limit)
|
202
|
-
.then(loadResult => {
|
203
|
-
const stillLoading = PreloadManager._loadingStatus.get(dataUnit.name);
|
204
|
-
const { count, result: records } = loadResult;
|
205
|
-
const firstRecord = count == 0 ? 0 : offset + 1;
|
206
|
-
const lastRecord = offset + Math.min(records.length, limit);
|
207
|
-
const currentPage = offset / limit;
|
208
|
-
const paginationInfo = {
|
209
|
-
count, currentPage, firstRecord, lastRecord,
|
210
|
-
hasMore: stillLoading || (lastRecord < count),
|
211
|
-
total: stillLoading ? undefined : count
|
212
|
-
};
|
213
|
-
accept({ records, paginationInfo });
|
214
|
-
})
|
215
|
-
.catch(reason => reject(reason));
|
216
|
-
});
|
217
|
-
}
|
218
|
-
}
|
219
|
-
PreloadManager._repositories = new Map();
|
220
|
-
PreloadManager._loadingStatus = new Map();
|
221
|
-
|
222
|
-
export { PreloadManager as P };
|
@@ -1,43 +0,0 @@
|
|
1
|
-
import { UserInterface, DateUtils } from '@sankhyalabs/core';
|
2
|
-
import InMemoryFilterColumnDataSource from '@sankhyalabs/ezui/dist/collection/components/ez-grid/utils/InMemoryFilterColumnDataSource';
|
3
|
-
import { P as PreloadManager } from './PreloadManager-c1c2f2b4.js';
|
4
|
-
|
5
|
-
class SnkMultiSelectionListDataSource {
|
6
|
-
setDataUnit(dataUnit) {
|
7
|
-
this._dataUnit = dataUnit;
|
8
|
-
}
|
9
|
-
setApplication(application) {
|
10
|
-
this._application = application;
|
11
|
-
}
|
12
|
-
formatLabel(fieldName, value) {
|
13
|
-
const { userInterface } = this._dataUnit.getField(fieldName);
|
14
|
-
if (userInterface === UserInterface.DATETIME) {
|
15
|
-
return DateUtils.formatDate(this._dataUnit.valueFromString(fieldName, value));
|
16
|
-
}
|
17
|
-
return String(this._dataUnit.getFormattedValue(fieldName, value));
|
18
|
-
}
|
19
|
-
async getStaticOptions(fieldName) {
|
20
|
-
if (fieldName == undefined) {
|
21
|
-
return Promise.resolve(undefined);
|
22
|
-
}
|
23
|
-
return Promise.resolve(await PreloadManager.getDistinct(this._dataUnit, fieldName));
|
24
|
-
}
|
25
|
-
fetchData(filterTerm, fieldName) {
|
26
|
-
return new Promise(resolve => {
|
27
|
-
this._application.executeSelectDistinct(this._dataUnit, fieldName, filterTerm).then(result => {
|
28
|
-
resolve(result.map(item => {
|
29
|
-
const field = this._dataUnit.getField(fieldName);
|
30
|
-
if (field.userInterface === UserInterface.SEARCH) {
|
31
|
-
return Object.assign(Object.assign({}, JSON.parse(item)), { check: true });
|
32
|
-
}
|
33
|
-
return { value: item, label: this.formatLabel(fieldName, item), check: true };
|
34
|
-
}));
|
35
|
-
});
|
36
|
-
});
|
37
|
-
}
|
38
|
-
sortItems(fieldName, items) {
|
39
|
-
return InMemoryFilterColumnDataSource.defaultSorterMultSelectionOption(this._dataUnit, fieldName, items);
|
40
|
-
}
|
41
|
-
}
|
42
|
-
|
43
|
-
export { SnkMultiSelectionListDataSource as S };
|