@genexus/genexus-ide-ui 1.0.53 → 1.0.54

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 (54) hide show
  1. package/dist/cjs/genexus-ide-ui.cjs.js +1 -1
  2. package/dist/cjs/gx-ide-create-kb-from-server.cjs.entry.js +25 -12
  3. package/dist/cjs/gx-ide-create-kb-from-server.cjs.entry.js.map +1 -1
  4. package/dist/cjs/gx-ide-select-kb-items.cjs.entry.js +395 -0
  5. package/dist/cjs/gx-ide-select-kb-items.cjs.entry.js.map +1 -0
  6. package/dist/cjs/loader.cjs.js +1 -1
  7. package/dist/collection/collection-manifest.json +1 -0
  8. package/dist/collection/components/select-kb-items/gx-ide-assets/select-kb-items/langs/select-kb-items.lang.en.json +19 -0
  9. package/dist/collection/components/select-kb-items/gx-ide-assets/select-kb-items/langs/select-kb-items.lang.ja.json +19 -0
  10. package/dist/collection/components/select-kb-items/gx-ide-assets/select-kb-items/langs/select-kb-items.lang.zh.json +19 -0
  11. package/dist/collection/components/select-kb-items/gx-ide-assets/select-kb-items/shortcuts.json +15 -0
  12. package/dist/collection/components/select-kb-items/helpers.js +167 -0
  13. package/dist/collection/components/select-kb-items/helpers.js.map +1 -0
  14. package/dist/collection/components/select-kb-items/select-kb-items.css +24 -0
  15. package/dist/collection/components/select-kb-items/select-kb-items.js +480 -0
  16. package/dist/collection/components/select-kb-items/select-kb-items.js.map +1 -0
  17. package/dist/collection/components/team-dev/create-kb-from-server/create-kb-from-server.css +8 -0
  18. package/dist/collection/components/team-dev/create-kb-from-server/create-kb-from-server.js +24 -11
  19. package/dist/collection/components/team-dev/create-kb-from-server/create-kb-from-server.js.map +1 -1
  20. package/dist/collection/components/team-dev/create-kb-from-server/gx-ide-assets/create-kb-from-server/langs/create-kb-from-server.lang.en.json +3 -2
  21. package/dist/collection/components/team-dev/create-kb-from-server/gx-ide-assets/create-kb-from-server/langs/create-kb-from-server.lang.ja.json +2 -1
  22. package/dist/collection/components/team-dev/create-kb-from-server/gx-ide-assets/create-kb-from-server/langs/create-kb-from-server.lang.zh.json +2 -1
  23. package/dist/collection/testing/locale.e2e.js +1 -0
  24. package/dist/collection/testing/locale.e2e.js.map +1 -1
  25. package/dist/components/gx-ide-create-kb-from-server.js +25 -12
  26. package/dist/components/gx-ide-create-kb-from-server.js.map +1 -1
  27. package/dist/components/gx-ide-select-kb-items.d.ts +11 -0
  28. package/dist/components/gx-ide-select-kb-items.js +428 -0
  29. package/dist/components/gx-ide-select-kb-items.js.map +1 -0
  30. package/dist/esm/genexus-ide-ui.js +1 -1
  31. package/dist/esm/gx-ide-create-kb-from-server.entry.js +25 -12
  32. package/dist/esm/gx-ide-create-kb-from-server.entry.js.map +1 -1
  33. package/dist/esm/gx-ide-select-kb-items.entry.js +391 -0
  34. package/dist/esm/gx-ide-select-kb-items.entry.js.map +1 -0
  35. package/dist/esm/loader.js +1 -1
  36. package/dist/genexus-ide-ui/genexus-ide-ui.esm.js +1 -1
  37. package/dist/genexus-ide-ui/genexus-ide-ui.esm.js.map +1 -1
  38. package/dist/genexus-ide-ui/gx-ide-assets/create-kb-from-server/langs/create-kb-from-server.lang.en.json +3 -2
  39. package/dist/genexus-ide-ui/gx-ide-assets/create-kb-from-server/langs/create-kb-from-server.lang.ja.json +2 -1
  40. package/dist/genexus-ide-ui/gx-ide-assets/create-kb-from-server/langs/create-kb-from-server.lang.zh.json +2 -1
  41. package/dist/genexus-ide-ui/gx-ide-assets/select-kb-items/langs/select-kb-items.lang.en.json +19 -0
  42. package/dist/genexus-ide-ui/gx-ide-assets/select-kb-items/langs/select-kb-items.lang.ja.json +19 -0
  43. package/dist/genexus-ide-ui/gx-ide-assets/select-kb-items/langs/select-kb-items.lang.zh.json +19 -0
  44. package/dist/genexus-ide-ui/gx-ide-assets/select-kb-items/shortcuts.json +15 -0
  45. package/dist/genexus-ide-ui/{p-2145674e.entry.js → p-67132150.entry.js} +54 -39
  46. package/dist/genexus-ide-ui/p-67132150.entry.js.map +1 -0
  47. package/dist/genexus-ide-ui/p-b95a0250.entry.js +465 -0
  48. package/dist/genexus-ide-ui/p-b95a0250.entry.js.map +1 -0
  49. package/dist/types/components/select-kb-items/helpers.d.ts +9 -0
  50. package/dist/types/components/select-kb-items/select-kb-items.d.ts +100 -0
  51. package/dist/types/components/team-dev/create-kb-from-server/create-kb-from-server.d.ts +2 -2
  52. package/dist/types/components.d.ts +101 -2
  53. package/package.json +1 -1
  54. package/dist/genexus-ide-ui/p-2145674e.entry.js.map +0 -1
@@ -0,0 +1,465 @@
1
+ import { r as t, a as e, h as s, H as i, g as n } from "./p-49712340.js";
2
+
3
+ import { g as o } from "./p-6e4208d8.js";
4
+
5
+ import "./p-ad5caf61.js";
6
+
7
+ import { L as a } from "./p-311eedf3.js";
8
+
9
+ const convertItemsNodeListToFlattenedTreeViewModel = (t, e) => {
10
+ const s = [];
11
+ const processNode = t => {
12
+ var i;
13
+ const n = !((i = t.nodes) === null || i === void 0 ? void 0 : i.length);
14
+ const o = e === "all" || e === "custom" && t.checkbox || e === "leaf" && n;
15
+ const a = JSON.stringify({
16
+ versionType: t.type
17
+ });
18
+ s.push({
19
+ id: t.id.toString(),
20
+ metadata: a,
21
+ caption: t.name,
22
+ checked: t.checked,
23
+ checkbox: o,
24
+ expanded: t.expanded,
25
+ startImgSrc: t.icon,
26
+ items: null,
27
+ leaf: n,
28
+ selected: t.selected
29
+ });
30
+ if (t.nodes) {
31
+ t.nodes.forEach((t => processNode(t)));
32
+ }
33
+ };
34
+ t.forEach((t => processNode(t)));
35
+ return s;
36
+ };
37
+
38
+ const convertItemsListToTreeViewModel = (t, e) => {
39
+ const s = [];
40
+ t.forEach((t => {
41
+ var i;
42
+ const n = !((i = t.nodes) === null || i === void 0 ? void 0 : i.length);
43
+ const o = t.expanded;
44
+ const a = t.icon;
45
+ const c = parseInt(t.id);
46
+ const r = e === "all" || e === "custom" && t.checkbox || e === "leaf" && n;
47
+ const h = JSON.stringify({
48
+ versionType: t.type
49
+ });
50
+ s.push({
51
+ id: t.id.toString(),
52
+ metadata: h,
53
+ caption: t.name,
54
+ checkbox: r,
55
+ checked: t.checked,
56
+ order: c,
57
+ selected: t.selected,
58
+ expanded: o,
59
+ startImgSrc: a,
60
+ items: !n ? convertItemsListToTreeViewModel(t.nodes, e) : null,
61
+ leaf: n
62
+ });
63
+ }));
64
+ return s;
65
+ };
66
+
67
+ const findItemNode = (t, e) => {
68
+ if (e.id === t) {
69
+ return e;
70
+ }
71
+ if (e.nodes) {
72
+ for (const s of e.nodes) {
73
+ const e = findItemNode(t, s);
74
+ if (e) {
75
+ return e;
76
+ }
77
+ }
78
+ }
79
+ return null;
80
+ };
81
+
82
+ function findItemInArray(t, e) {
83
+ for (const s of t) {
84
+ const t = findItemNode(e, s);
85
+ if (t) {
86
+ return t;
87
+ }
88
+ }
89
+ return null;
90
+ }
91
+
92
+ const setAllLeafsCheckedFalse = t => {
93
+ const uncheck = t => {
94
+ var e;
95
+ t.checked = false;
96
+ if ((e = t.nodes) === null || e === void 0 ? void 0 : e.length) {
97
+ t.nodes.forEach((t => uncheck(t)));
98
+ }
99
+ };
100
+ t.forEach((t => uncheck(t)));
101
+ return t;
102
+ };
103
+
104
+ const unselectAllNodes = t => {
105
+ const unselect = t => {
106
+ var e;
107
+ t.selected = false;
108
+ if ((e = t.nodes) === null || e === void 0 ? void 0 : e.length) {
109
+ t.nodes.forEach((t => unselect(t)));
110
+ }
111
+ };
112
+ t.forEach((t => unselect(t)));
113
+ };
114
+
115
+ const checkItems = (t, e) => {
116
+ setAllLeafsCheckedFalse(t);
117
+ e.forEach((e => {
118
+ const s = findItemInArray(t, e);
119
+ if (s) {
120
+ s.checked = true;
121
+ }
122
+ }));
123
+ return t;
124
+ };
125
+
126
+ const expandItems = (t, e) => {
127
+ e.forEach((e => {
128
+ const s = findItemInArray(t, e);
129
+ if (s) {
130
+ s.expanded = true;
131
+ }
132
+ }));
133
+ return t;
134
+ };
135
+
136
+ const selectItems = (t, e) => {
137
+ e.forEach((e => {
138
+ const s = findItemInArray(t, e);
139
+ if (s) {
140
+ s.selected = true;
141
+ }
142
+ }));
143
+ return t;
144
+ };
145
+
146
+ function searchInNode(t, e) {
147
+ var s;
148
+ // If the current node is the searched node, we return an empty list (it has no parents in this branch)
149
+ if (t.id === e) {
150
+ return [];
151
+ }
152
+ // We traverse each child looking for the target node
153
+ if ((s = t.nodes) === null || s === void 0 ? void 0 : s.length) {
154
+ for (const s of t.nodes) {
155
+ const i = searchInNode(s, e);
156
+ if (i !== null) {
157
+ // If we find it, we include the current node at the beginning of the path and return
158
+ return [ t.id, ...i ];
159
+ }
160
+ }
161
+ }
162
+ return null;
163
+ }
164
+
165
+ const searchParentsItems = (t, e) => {
166
+ const s = [];
167
+ for (const i of e) {
168
+ for (const e of t) {
169
+ const t = searchInNode(e, i);
170
+ if (t !== null) {
171
+ t.forEach((t => {
172
+ s.push(t);
173
+ }));
174
+ }
175
+ }
176
+ }
177
+ return s;
178
+ };
179
+
180
+ const c = ":host{display:grid;block-size:100%;grid-template-rows:max-content 1fr max-content}.section{display:contents}.view-mode__toggle-checkboxes{grid-template-columns:max-content max-content}.field__items-view-type{align-items:center}.field__items-view-type .label{margin-block-start:0 !important}.field__toggle-checkboxes .label{margin-block-start:0 !important}";
181
+
182
+ var r = undefined && undefined.__classPrivateFieldSet || function(t, e, s, i, n) {
183
+ if (i === "m") throw new TypeError("Private method is not writable");
184
+ if (i === "a" && !n) throw new TypeError("Private accessor was defined without a setter");
185
+ if (typeof e === "function" ? t !== e || !n : !e.has(t)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
186
+ return i === "a" ? n.call(t, s) : n ? n.value = s : e.set(t, s), s;
187
+ };
188
+
189
+ var h = undefined && undefined.__classPrivateFieldGet || function(t, e, s, i) {
190
+ if (s === "a" && !i) throw new TypeError("Private accessor was defined without a getter");
191
+ if (typeof e === "function" ? t !== e || !i : !e.has(t)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
192
+ return s === "m" ? i : s === "a" ? i.call(t) : i ? i.value : e.get(t);
193
+ };
194
+
195
+ var l, f, d, u, p, m, w, b, g, v, k, y, x, W, M, I, _, C, S, T, j, N;
196
+
197
+ const L = [ "resets/box-sizing", "chameleon/scrollbar", "components/tooltip", "components/tree-view", "utils/form--full", "utils/layout", "utils/spacing", "utils/typography" ];
198
+
199
+ const E = o({
200
+ category: "system",
201
+ name: "search",
202
+ colorType: "on-surface"
203
+ });
204
+
205
+ const A = "tree";
206
+
207
+ const H = "list";
208
+
209
+ const P = "on";
210
+
211
+ const z = class {
212
+ constructor(i) {
213
+ t(this, i);
214
+ l.set(this, void 0);
215
+ f.set(this, []);
216
+ d.set(this, void 0);
217
+ u.set(this, []);
218
+ p.set(this, e(`./gx-ide-assets/select-kb-items/shortcuts.json`));
219
+ m.set(this, []);
220
+ w.set(this, void 0);
221
+ b.set(this, void 0);
222
+ g.set(this, (() => {
223
+ if (this.cancelCallback) {
224
+ this.cancelCallback();
225
+ }
226
+ }));
227
+ v.set(this, (async t => {
228
+ const e = [];
229
+ t.detail.forEach((t => {
230
+ t.item.checked && e.push(t.item.id);
231
+ }));
232
+ r(this, f, e, "f");
233
+ r(this, m, checkItems(this.itemsList, h(this, f, "f")), "f");
234
+ if (this.checkedChanged) {
235
+ this.checkedChanged(h(this, f, "f"));
236
+ }
237
+ }));
238
+ k.set(this, (() => {
239
+ if (this.confirmCallback) {
240
+ this.confirmCallback(h(this, f, "f"));
241
+ }
242
+ }));
243
+ y.set(this, (async t => {
244
+ if (this.itemContextMenuCallback) {
245
+ let e;
246
+ const s = h(this, u, "f").find((e => e === t.detail.id));
247
+ if (!h(this, u, "f").length || !s) {
248
+ await h(this, b, "f").updateItemsProperties(h(this, u, "f"), {
249
+ selected: false
250
+ });
251
+ await h(this, b, "f").updateItemsProperties([ t.detail.id ], {
252
+ selected: true
253
+ });
254
+ e = {
255
+ clientX: t.detail.contextmenuEvent.clientX,
256
+ clientY: t.detail.contextmenuEvent.clientY,
257
+ selection: [ t.detail.id ]
258
+ };
259
+ } else {
260
+ e = {
261
+ clientX: t.detail.contextmenuEvent.clientX,
262
+ clientY: t.detail.contextmenuEvent.clientY,
263
+ selection: h(this, u, "f")
264
+ };
265
+ }
266
+ this.itemContextMenuCallback(e);
267
+ }
268
+ }));
269
+ x.set(this, (t => () => {
270
+ t(h(this, f, "f"), h(this, u, "f"));
271
+ }));
272
+ W.set(this, (t => {
273
+ this.searchPatternValue = t.detail.toString();
274
+ }));
275
+ M.set(this, (() => s("div", null, this.dialogActions.map((t => s("button", {
276
+ class: "button-tertiary",
277
+ part: `button button-${t.name}`,
278
+ onClick: h(this, x, "f").call(this, t.callback)
279
+ }, t.name))))));
280
+ I.set(this, (() => s("footer", {
281
+ class: "footer control-footer-with-border spacing-body-inline spacing-body-block-end control-footer-space-between"
282
+ }, h(this, M, "f").call(this), s("div", {
283
+ class: "buttons-spacer "
284
+ }, this.cancelCallback && s("button", {
285
+ class: "button-secondary",
286
+ part: "cancel-button",
287
+ onClick: h(this, g, "f")
288
+ }, h(this, l, "f").footer.cancel), this.confirmCallback && s("button", {
289
+ class: "button-primary",
290
+ part: "confirm-button",
291
+ onClick: h(this, k, "f")
292
+ }, h(this, l, "f").footer.select)))));
293
+ _.set(this, (t => {
294
+ const e = [];
295
+ unselectAllNodes(this.itemsList);
296
+ t.detail.forEach((t => {
297
+ e.push(t.item.id);
298
+ }));
299
+ r(this, u, e, "f");
300
+ if (this.selectionChanged) {
301
+ this.selectionChanged(h(this, u, "f"));
302
+ }
303
+ r(this, m, selectItems(this.itemsList, e), "f");
304
+ }));
305
+ C.set(this, (async t => {
306
+ const e = searchParentsItems(this.itemsList, t);
307
+ const s = selectItems(this.itemsList, t);
308
+ const i = expandItems(s, e);
309
+ h(this, T, "f").call(this, i);
310
+ }));
311
+ S.set(this, (async t => {
312
+ const e = searchParentsItems(this.itemsList, t);
313
+ const s = expandItems(this.itemsList, e);
314
+ h(this, T, "f").call(this, s);
315
+ }));
316
+ T.set(this, (t => {
317
+ this.nodeVersionsListTreeModel = convertItemsListToTreeViewModel(t, this.checkboxType);
318
+ this.nodeListFlattenedTreeModel = convertItemsNodeListToFlattenedTreeViewModel(t, this.checkboxType);
319
+ }));
320
+ j.set(this, (async t => {
321
+ const e = t.detail;
322
+ this.nodesVersionsViewType = e;
323
+ if (this.nodesVersionsViewType === "tree") {
324
+ await h(this, C, "f").call(this, h(this, u, "f"));
325
+ await h(this, S, "f").call(this, h(this, f, "f"));
326
+ }
327
+ h(this, T, "f").call(this, h(this, m, "f"));
328
+ }));
329
+ N.set(this, (t => {
330
+ this.toggleCheckboxes = t.detail === P;
331
+ }));
332
+ this.nodeListFlattenedTreeModel = [];
333
+ this.nodesVersionsViewType = "tree";
334
+ this.nodeVersionsListTreeModel = [];
335
+ this.searchPatternValue = null;
336
+ this.toggleCheckboxes = true;
337
+ this.cancelCallback = undefined;
338
+ this.checkboxType = undefined;
339
+ this.checkedChanged = undefined;
340
+ this.confirmCallback = undefined;
341
+ this.dialogActions = [];
342
+ this.itemContextMenuCallback = undefined;
343
+ this.itemsList = [];
344
+ this.multiSelection = false;
345
+ this.selectionChanged = undefined;
346
+ }
347
+ watchNodeListHandler(t) {
348
+ h(this, T, "f").call(this, t);
349
+ }
350
+ async componentWillLoad() {
351
+ r(this, l, await a.getComponentStrings(this.el), "f");
352
+ r(this, w, [ {
353
+ value: A,
354
+ caption: h(this, l, "f").main.tree
355
+ }, {
356
+ value: H,
357
+ caption: "List"
358
+ } ], "f");
359
+ this.watchNodeListHandler(this.itemsList);
360
+ }
361
+ /**
362
+ * Suspends or reactivates the shortcuts
363
+ */ async suspendShortcuts(t) {
364
+ if (t) {
365
+ h(this, d, "f").suspend = true;
366
+ } else {
367
+ h(this, d, "f").suspend = false;
368
+ }
369
+ }
370
+ /**
371
+ * Allow to update the selected items
372
+ */ async updateSelection(t) {
373
+ // first clear selected
374
+ h(this, b, "f").updateItemsProperties(h(this, u, "f"), {
375
+ selected: false
376
+ });
377
+ // then select
378
+ h(this, b, "f").updateItemsProperties(t, {
379
+ selected: true
380
+ });
381
+ }
382
+ render() {
383
+ return s(i, {
384
+ class: "widget"
385
+ }, s("ch-theme", {
386
+ model: L
387
+ }), s("ch-shortcuts", {
388
+ src: h(this, p, "f"),
389
+ ref: t => r(this, d, t, "f")
390
+ }), s("section", {
391
+ class: "section"
392
+ }, s("header", {
393
+ class: "control-header field-group spacing-body-block-start spacing-body-inline"
394
+ }, s("div", {
395
+ class: "field-group view-mode__toggle-checkboxes"
396
+ }, s("div", {
397
+ class: "field field-inline field__items-view-type"
398
+ }, s("label", {
399
+ class: "label",
400
+ htmlFor: "view-mode"
401
+ }, "Select view mode:"), s("ch-radio-group-render", {
402
+ class: "radio-group",
403
+ id: "view-mode",
404
+ model: h(this, w, "f"),
405
+ onChange: h(this, j, "f"),
406
+ value: h(this, w, "f")[0].value
407
+ })), s("div", {
408
+ class: "field field-inline field__toggle-checkboxes"
409
+ }, s("label", {
410
+ class: "label",
411
+ htmlFor: "control-id-1",
412
+ htmlfor: "toggle-checkboxes"
413
+ }, "Toggle Checkboxes"), s("ch-checkbox", {
414
+ class: "checkbox",
415
+ id: "toggle-checkboxes",
416
+ checkedValue: P,
417
+ value: P,
418
+ onInput: h(this, N, "f")
419
+ }))), s("ch-edit", {
420
+ class: "input pattern-filter",
421
+ placeholder: h(this, l, "f").header.searchPatternPlaceholder,
422
+ startImgSrc: E,
423
+ onInput: h(this, W, "f")
424
+ })), s("div", {
425
+ class: "spacing-body-inline-start trees"
426
+ }, s("ch-tree-view-render", {
427
+ class: "tree-view",
428
+ model: this.nodesVersionsViewType === "tree" ? this.nodeVersionsListTreeModel : this.nodeListFlattenedTreeModel,
429
+ "show-lines": this.nodesVersionsViewType === "tree" ? "all" : "none",
430
+ expandableButton: this.nodesVersionsViewType === "tree" ? "decorative" : "no",
431
+ onItemContextmenu: h(this, y, "f"),
432
+ onCheckedItemsChange: h(this, v, "f"),
433
+ onSelectedItemsChange: h(this, _, "f"),
434
+ multiSelection: this.multiSelection,
435
+ filter: this.searchPatternValue,
436
+ filterType: "caption",
437
+ toggleCheckboxes: this.toggleCheckboxes,
438
+ ref: t => {
439
+ r(this, b, t, "f");
440
+ }
441
+ })), h(this, I, "f").call(this)));
442
+ }
443
+ static get assetsDirs() {
444
+ return [ "gx-ide-assets/select-kb-items" ];
445
+ }
446
+ get el() {
447
+ return n(this);
448
+ }
449
+ static get watchers() {
450
+ return {
451
+ itemsList: [ "watchNodeListHandler" ]
452
+ };
453
+ }
454
+ };
455
+
456
+ l = new WeakMap, f = new WeakMap, d = new WeakMap, u = new WeakMap, p = new WeakMap,
457
+ m = new WeakMap, w = new WeakMap, b = new WeakMap, g = new WeakMap, v = new WeakMap,
458
+ k = new WeakMap, y = new WeakMap, x = new WeakMap, W = new WeakMap, M = new WeakMap,
459
+ I = new WeakMap, _ = new WeakMap, C = new WeakMap, S = new WeakMap, T = new WeakMap,
460
+ j = new WeakMap, N = new WeakMap;
461
+
462
+ z.style = c;
463
+
464
+ export { z as gx_ide_select_kb_items };
465
+ //# sourceMappingURL=p-b95a0250.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["convertItemsNodeListToFlattenedTreeViewModel","itemsList","checkboxType","itemsListFlattenedTreeViewModel","processNode","item","leaf","_a","nodes","length","checkbox","metaData","JSON","stringify","versionType","type","push","id","toString","metadata","caption","name","checked","expanded","startImgSrc","icon","items","selected","forEach","childNode","convertItemsListToTreeViewModel","itemsListTreeViewModel","order","parseInt","findItemNode","itemNode","result","findItemInArray","itemsNodes","setAllLeafsCheckedFalse","uncheck","unselectAllNodes","unselect","checkItems","idsChecked","itemFind","expandItems","selectItems","idsSelected","searchInNode","node","parents","searchParentsItems","ids","rootItem","results","selectKbItemsCss","CSS_BUNDLES","SYSTEM_SEARCH_ICON","getIconPath","category","colorType","VIEW_AS_TREE_ID","VIEW_AS_LIST_ID","TOGGLE_CHECKBOXES_CHECKED_VALUE","GxIdeSelectKbItems","_GxIdeSelectKbItems__componentLocale","set","this","_GxIdeSelectKbItems_checkedNodesIds","_GxIdeSelectKbItems_chShortcutsEl","_GxIdeSelectKbItems_selectedNodesIds","_GxIdeSelectKbItems_shortcutsSrc","getAssetPath","_GxIdeSelectKbItems_updatedModelList","_GxIdeSelectKbItems_viewItemsAsModel","_GxIdeSelectKbItems_treeViewRenderEl","_GxIdeSelectKbItems_cancelHandler","cancelCallback","_GxIdeSelectKbItems_checkedItemsChangeHandler","async","e","checkedNodesIds","detail","__classPrivateFieldSet","__classPrivateFieldGet","checkedChanged","_GxIdeSelectKbItems_confirmHandler","confirmCallback","_GxIdeSelectKbItems_contextMenuHandler","itemContextMenuCallback","info","isSelected","find","updateItemsProperties","clientX","contextmenuEvent","clientY","selection","_GxIdeSelectKbItems_executeDialogAction","callback","_GxIdeSelectKbItems_patternSearchValueChangedHandler","event","searchPatternValue","_GxIdeSelectKbItems_renderActionButtons","h","dialogActions","map","action","class","part","onClick","call","_GxIdeSelectKbItems_renderFooter","footer","cancel","select","_GxIdeSelectKbItems_selectedItemsChangeHandler","selectedNodesIds","selectionChanged","_GxIdeSelectKbItems_toggleAndSelectNodesInModelItems","selectedItemsIds","nodesToToggle","newItemsSelected","newItemsExpanded","_GxIdeSelectKbItems_updateViews","_GxIdeSelectKbItems_toggleCheckedNodesInModelItems","newItemsList","nodeVersionsListTreeModel","nodeListFlattenedTreeModel","_GxIdeSelectKbItems_viewItemsAsChangedHandler","selectedViewType","nodesVersionsViewType","_GxIdeSelectKbItems_toggleCheckboxesChangedHandler","toggleCheckboxes","watchNodeListHandler","componentWillLoad","Locale","getComponentStrings","el","value","main","tree","suspendShortcuts","suspend","updateSelection","render","Host","model","src","ref","htmlFor","onChange","htmlfor","checkedValue","onInput","placeholder","header","searchPatternPlaceholder","expandableButton","onItemContextmenu","onCheckedItemsChange","onSelectedItemsChange","multiSelection","filter","filterType"],"sources":["src/components/select-kb-items/helpers.tsx","src/components/select-kb-items/select-kb-items.scss?tag=gx-ide-select-kb-items&encapsulation=shadow","src/components/select-kb-items/select-kb-items.tsx"],"sourcesContent":["import { ItemNode, CheckboxType } from \"./select-kb-items\";\nimport { TreeViewItemModel } from \"@genexus/chameleon-controls-library\";\n\nexport const convertItemsNodeListToFlattenedTreeViewModel = (\n itemsList: ItemNode[],\n checkboxType: CheckboxType\n): TreeViewItemModel[] => {\n const itemsListFlattenedTreeViewModel: TreeViewItemModel[] = [];\n\n const processNode = (item: ItemNode) => {\n const leaf = !item.nodes?.length;\n const checkbox =\n checkboxType === \"all\" ||\n (checkboxType === \"custom\" && item.checkbox) ||\n (checkboxType === \"leaf\" && leaf);\n const metaData = JSON.stringify({\n versionType: item.type\n });\n itemsListFlattenedTreeViewModel.push({\n id: item.id.toString(),\n metadata: metaData,\n caption: item.name,\n checked: item.checked,\n checkbox: checkbox,\n expanded: item.expanded,\n startImgSrc: item.icon,\n items: null,\n leaf: leaf,\n selected: item.selected\n });\n\n if (item.nodes) {\n item.nodes.forEach(childNode => processNode(childNode));\n }\n };\n\n itemsList.forEach(item => processNode(item));\n return itemsListFlattenedTreeViewModel;\n};\n\nexport const convertItemsListToTreeViewModel = (\n itemsList: ItemNode[],\n checkboxType: CheckboxType\n): TreeViewItemModel[] => {\n const itemsListTreeViewModel: TreeViewItemModel[] = [];\n itemsList.forEach(item => {\n const leaf = !item.nodes?.length;\n const expanded = item.expanded;\n const icon = item.icon;\n const order = parseInt(item.id);\n const checkbox =\n checkboxType === \"all\" ||\n (checkboxType === \"custom\" && item.checkbox) ||\n (checkboxType === \"leaf\" && leaf);\n const metaData = JSON.stringify({\n versionType: item.type\n });\n itemsListTreeViewModel.push({\n id: item.id.toString(),\n metadata: metaData,\n caption: item.name,\n checkbox: checkbox,\n checked: item.checked,\n order: order,\n selected: item.selected,\n expanded: expanded,\n startImgSrc: icon,\n items: !leaf\n ? convertItemsListToTreeViewModel(item.nodes, checkboxType)\n : null,\n leaf: leaf\n });\n });\n\n return itemsListTreeViewModel;\n};\n\nconst findItemNode = (id: string, item: ItemNode): ItemNode | null => {\n if (item.id === id) {\n return item;\n }\n\n if (item.nodes) {\n for (const itemNode of item.nodes) {\n const result = findItemNode(id, itemNode);\n if (result) {\n return result;\n }\n }\n }\n return null;\n};\n\nfunction findItemInArray(itemsNodes: ItemNode[], id: string): ItemNode | null {\n for (const item of itemsNodes) {\n const result = findItemNode(id, item);\n if (result) {\n return result;\n }\n }\n return null;\n}\nconst setAllLeafsCheckedFalse = (itemsList: ItemNode[]): ItemNode[] => {\n const uncheck = (itemNode: ItemNode) => {\n itemNode.checked = false;\n if (itemNode.nodes?.length) {\n itemNode.nodes.forEach(childNode => uncheck(childNode));\n }\n };\n\n itemsList.forEach(item => uncheck(item));\n return itemsList;\n};\n\nexport const unselectAllNodes = (itemsList: ItemNode[]) => {\n const unselect = (itemNode: ItemNode) => {\n itemNode.selected = false;\n if (itemNode.nodes?.length) {\n itemNode.nodes.forEach(childNode => unselect(childNode));\n }\n };\n\n itemsList.forEach(item => unselect(item));\n};\n\nexport const checkItems = (\n itemsList: ItemNode[],\n idsChecked: string[]\n): ItemNode[] => {\n setAllLeafsCheckedFalse(itemsList);\n idsChecked.forEach(id => {\n const itemFind = findItemInArray(itemsList, id);\n if (itemFind) {\n itemFind.checked = true;\n }\n });\n\n return itemsList;\n};\n\nexport const expandItems = (\n itemsList: ItemNode[],\n idsChecked: string[]\n): ItemNode[] => {\n idsChecked.forEach(id => {\n const itemFind = findItemInArray(itemsList, id);\n if (itemFind) {\n itemFind.expanded = true;\n }\n });\n\n return itemsList;\n};\n\nexport const selectItems = (\n itemsList: ItemNode[],\n idsSelected: string[]\n): ItemNode[] => {\n idsSelected.forEach(id => {\n const itemFind = findItemInArray(itemsList, id);\n if (itemFind) {\n itemFind.selected = true;\n }\n });\n return itemsList;\n};\n\nfunction searchInNode(item: ItemNode, id: string): string[] | null {\n // If the current node is the searched node, we return an empty list (it has no parents in this branch)\n if (item.id === id) {\n return [];\n }\n\n // We traverse each child looking for the target node\n if (item.nodes?.length) {\n for (const node of item.nodes) {\n const parents = searchInNode(node, id);\n if (parents !== null) {\n // If we find it, we include the current node at the beginning of the path and return\n return [item.id, ...parents];\n }\n }\n }\n return null;\n}\n\nexport const searchParentsItems = (\n items: ItemNode[],\n ids: string[]\n): string[] | null => {\n const parents: string[] = [];\n for (const id of ids) {\n for (const rootItem of items) {\n const results = searchInNode(rootItem, id);\n if (results !== null) {\n results.forEach(result => {\n parents.push(result);\n });\n }\n }\n }\n return parents;\n};\n",":host {\n display: grid;\n block-size: 100%;\n grid-template-rows: max-content 1fr max-content;\n}\n\n.section {\n display: contents;\n}\n\n// header\n.view-mode__toggle-checkboxes {\n grid-template-columns: max-content max-content;\n}\n.field__items-view-type {\n align-items: center;\n .label {\n margin-block-start: 0 !important; // WA to center label with radio-group\n }\n}\n.field__toggle-checkboxes {\n .label {\n margin-block-start: 0 !important; // WA to center label with radio-group\n }\n}\n","import {\n Component,\n Element,\n getAssetPath,\n Host,\n h,\n Prop,\n State,\n Watch,\n Method\n} from \"@stencil/core\";\n\nimport {\n ChCheckboxCustomEvent,\n TreeViewItemModel,\n TreeViewItemModelExtended\n} from \"@genexus/chameleon-controls-library\";\n\nimport {\n checkItems,\n convertItemsListToTreeViewModel,\n convertItemsNodeListToFlattenedTreeViewModel,\n expandItems,\n searchParentsItems,\n selectItems,\n unselectAllNodes\n} from \"./helpers\";\nimport { getIconPath, MercuryBundles } from \"@genexus/mercury\";\nimport { Locale } from \"../../common/locale\";\nimport { ContextMenuInfo } from \"../../common/types\";\nimport { RadioGroupItemModel } from \"@genexus/chameleon-controls-library/dist/types/components/radio-group/types\";\n\nconst CSS_BUNDLES: MercuryBundles = [\n \"resets/box-sizing\",\n \"chameleon/scrollbar\",\n \"components/tooltip\",\n \"components/tree-view\",\n \"utils/form--full\",\n \"utils/layout\",\n \"utils/spacing\",\n \"utils/typography\"\n];\n\nconst SYSTEM_SEARCH_ICON = getIconPath({\n category: \"system\",\n name: \"search\",\n colorType: \"on-surface\"\n});\n\nconst VIEW_AS_TREE_ID: NodesVersionsViewType = \"tree\";\nconst VIEW_AS_LIST_ID: NodesVersionsViewType = \"list\";\n\nconst TOGGLE_CHECKBOXES_CHECKED_VALUE = \"on\";\n\n@Component({\n tag: \"gx-ide-select-kb-items\",\n styleUrl: \"select-kb-items.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/select-kb-items\"]\n})\nexport class GxIdeSelectKbItems {\n #_componentLocale: any;\n #checkedNodesIds: string[] = [];\n #chShortcutsEl: HTMLChShortcutsElement;\n #selectedNodesIds: string[] = [];\n #shortcutsSrc = getAssetPath(\n `./gx-ide-assets/select-kb-items/shortcuts.json`\n );\n #updatedModelList: ItemNode[] = [];\n\n #viewItemsAsModel: RadioGroupItemModel[];\n\n @Element() el: HTMLGxIdeSelectKbItemsElement;\n #treeViewRenderEl: HTMLChTreeViewRenderElement;\n\n /**\n * Represents the nodes list model\n */\n @State() nodeListFlattenedTreeModel: TreeViewItemModel[] = [];\n\n /**\n * View type for the nodes.\n */\n @State() nodesVersionsViewType: NodesVersionsViewType = \"tree\";\n\n /**\n * Represents the nodes tree model\n */\n @State() nodeVersionsListTreeModel: TreeViewItemModel[] = [];\n\n /**\n * \"Search Pattern\" input value, used to filter the nodes tree/list.\n */\n @State() searchPatternValue: string = null;\n\n /**\n * It maps to the ch-tree-view-render \"toggleCheckboxes\" property.\n */\n @State() toggleCheckboxes: boolean = true;\n\n /**\n * Callback emitted when the 'cancel' button is pressed\n */\n @Prop() readonly cancelCallback?: () => Promise<void>;\n /**\n * Defines which nodes of the component have checkboxes.\n */\n @Prop() readonly checkboxType: CheckboxType;\n\n /**\n * Callback emitted when the items checked items change\n */\n @Prop() readonly checkedChanged?: (checkedItems: string[]) => Promise<void>;\n\n /**\n * Callback emitted when the 'select' button is pressed\n */\n @Prop() readonly confirmCallback?: (checkedItems: string[]) => Promise<void>;\n\n /**\n * Set of additional actions (callbacks) to those already provided by default by the selector (cancelCallback and selectCallback)\n */\n @Prop() readonly dialogActions: DialogAction[] = [];\n\n /**\n * Callback emitted when the user right click on an item\n */\n @Prop() readonly itemContextMenuCallback: (\n info: ContextMenuInfo\n ) => Promise<void>;\n\n /**\n * Represents the itemLis list model\n */\n @Prop() readonly itemsList: ItemNode[] = [];\n\n @Watch(\"itemsList\")\n watchNodeListHandler(newItemsList: ItemNode[]) {\n this.#updateViews(newItemsList);\n }\n\n /**\n * This define if the selection is unique or not\n */\n @Prop() readonly multiSelection?: boolean = false;\n\n /**\n * Callback emitted when the items selection change\n */\n @Prop() readonly selectionChanged?: (selectedItem: string[]) => Promise<void>;\n\n async componentWillLoad() {\n this.#_componentLocale = await Locale.getComponentStrings(this.el);\n this.#viewItemsAsModel = [\n { value: VIEW_AS_TREE_ID, caption: this.#_componentLocale.main.tree },\n { value: VIEW_AS_LIST_ID, caption: \"List\" }\n ];\n this.watchNodeListHandler(this.itemsList);\n }\n\n /**\n * Suspends or reactivates the shortcuts\n */\n @Method()\n async suspendShortcuts(suspendShortcuts: boolean) {\n if (suspendShortcuts) {\n this.#chShortcutsEl.suspend = true;\n } else {\n this.#chShortcutsEl.suspend = false;\n }\n }\n\n /**\n * Allow to update the selected items\n */\n @Method()\n async updateSelection(selectedItemsIds: string[]) {\n // first clear selected\n this.#treeViewRenderEl.updateItemsProperties(this.#selectedNodesIds, {\n selected: false\n });\n // then select\n this.#treeViewRenderEl.updateItemsProperties(selectedItemsIds, {\n selected: true\n });\n }\n\n #cancelHandler = () => {\n if (this.cancelCallback) {\n this.cancelCallback();\n }\n };\n\n #checkedItemsChangeHandler = async (\n e: CustomEvent<Map<string, TreeViewItemModelExtended>>\n ) => {\n const checkedNodesIds: string[] = [];\n e.detail.forEach(node => {\n node.item.checked && checkedNodesIds.push(node.item.id);\n });\n this.#checkedNodesIds = checkedNodesIds;\n this.#updatedModelList = checkItems(this.itemsList, this.#checkedNodesIds);\n\n if (this.checkedChanged) {\n this.checkedChanged(this.#checkedNodesIds);\n }\n };\n\n #confirmHandler = () => {\n if (this.confirmCallback) {\n this.confirmCallback(this.#checkedNodesIds);\n }\n };\n\n #contextMenuHandler = async (\n e: CustomEvent<{\n id: string;\n itemRef: HTMLChTreeViewItemElement;\n metadata: string;\n contextmenuEvent: PointerEvent;\n }>\n ) => {\n if (this.itemContextMenuCallback) {\n let info: ContextMenuInfo;\n const isSelected = this.#selectedNodesIds.find(id => id === e.detail.id);\n if (!this.#selectedNodesIds.length || !isSelected) {\n await this.#treeViewRenderEl.updateItemsProperties(\n this.#selectedNodesIds,\n { selected: false }\n );\n await this.#treeViewRenderEl.updateItemsProperties([e.detail.id], {\n selected: true\n });\n info = {\n clientX: e.detail.contextmenuEvent.clientX,\n clientY: e.detail.contextmenuEvent.clientY,\n selection: [e.detail.id]\n };\n } else {\n info = {\n clientX: e.detail.contextmenuEvent.clientX,\n clientY: e.detail.contextmenuEvent.clientY,\n selection: this.#selectedNodesIds\n };\n }\n this.itemContextMenuCallback(info);\n }\n };\n\n #executeDialogAction = (\n callback: (checkedNodesIds: string[], selectedNodesIds: string[]) => void\n ) => {\n return () => {\n callback(this.#checkedNodesIds, this.#selectedNodesIds);\n };\n };\n\n #patternSearchValueChangedHandler = (\n event: CustomEvent<string> | InputEvent\n ) => {\n this.searchPatternValue = event.detail.toString();\n };\n\n #renderActionButtons = (): HTMLElement[] => {\n return (\n <div>\n {this.dialogActions.map(action => {\n return (\n <button\n class={\"button-tertiary\"}\n part={`button button-${action.name}`}\n onClick={this.#executeDialogAction(action.callback)}\n >\n {action.name}\n </button>\n );\n })}\n </div>\n );\n };\n\n #renderFooter = (): HTMLElement => {\n return (\n <footer class=\"footer control-footer-with-border spacing-body-inline spacing-body-block-end control-footer-space-between\">\n {this.#renderActionButtons()}\n <div class=\"buttons-spacer \">\n {this.cancelCallback && (\n <button\n class={\"button-secondary\"}\n part={\"cancel-button\"}\n onClick={this.#cancelHandler}\n >\n {this.#_componentLocale.footer.cancel}\n </button>\n )}\n {this.confirmCallback && (\n <button\n class={\"button-primary\"}\n part={\"confirm-button\"}\n onClick={this.#confirmHandler}\n >\n {this.#_componentLocale.footer.select}\n </button>\n )}\n </div>\n </footer>\n );\n };\n\n #selectedItemsChangeHandler = (\n e: CustomEvent<TreeViewItemModelExtended[]>\n ) => {\n const selectedNodesIds: string[] = [];\n unselectAllNodes(this.itemsList);\n e.detail.forEach(node => {\n selectedNodesIds.push(node.item.id);\n });\n this.#selectedNodesIds = selectedNodesIds;\n if (this.selectionChanged) {\n this.selectionChanged(this.#selectedNodesIds);\n }\n\n this.#updatedModelList = selectItems(this.itemsList, selectedNodesIds);\n };\n\n #toggleAndSelectNodesInModelItems = async (selectedItemsIds: string[]) => {\n const nodesToToggle = searchParentsItems(this.itemsList, selectedItemsIds);\n const newItemsSelected = selectItems(this.itemsList, selectedItemsIds);\n const newItemsExpanded = expandItems(newItemsSelected, nodesToToggle);\n this.#updateViews(newItemsExpanded);\n };\n\n #toggleCheckedNodesInModelItems = async (selectedItemsIds: string[]) => {\n const nodesToToggle = searchParentsItems(this.itemsList, selectedItemsIds);\n const newItemsExpanded = expandItems(this.itemsList, nodesToToggle);\n this.#updateViews(newItemsExpanded);\n };\n\n #updateViews = (newItemsList: ItemNode[]) => {\n this.nodeVersionsListTreeModel = convertItemsListToTreeViewModel(\n newItemsList,\n this.checkboxType\n );\n\n this.nodeListFlattenedTreeModel =\n convertItemsNodeListToFlattenedTreeViewModel(\n newItemsList,\n this.checkboxType\n );\n };\n\n #viewItemsAsChangedHandler = async (event: CustomEvent<string>) => {\n const selectedViewType = event.detail as NodesVersionsViewType;\n this.nodesVersionsViewType = selectedViewType;\n if (this.nodesVersionsViewType === \"tree\") {\n await this.#toggleAndSelectNodesInModelItems(this.#selectedNodesIds);\n await this.#toggleCheckedNodesInModelItems(this.#checkedNodesIds);\n }\n this.#updateViews(this.#updatedModelList);\n };\n\n #toggleCheckboxesChangedHandler = (\n event: ChCheckboxCustomEvent<string> | InputEvent\n ) => {\n this.toggleCheckboxes = event.detail === TOGGLE_CHECKBOXES_CHECKED_VALUE;\n };\n\n render() {\n return (\n <Host class=\"widget\">\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n <ch-shortcuts\n src={this.#shortcutsSrc}\n ref={(el: HTMLChShortcutsElement) =>\n (this.#chShortcutsEl = el as HTMLChShortcutsElement)\n }\n ></ch-shortcuts>\n <section class=\"section\">\n <header class=\"control-header field-group spacing-body-block-start spacing-body-inline\">\n <div class=\"field-group view-mode__toggle-checkboxes\">\n <div class=\"field field-inline field__items-view-type\">\n <label class=\"label\" htmlFor=\"view-mode\">\n Select view mode:\n </label>\n <ch-radio-group-render\n class=\"radio-group\"\n id=\"view-mode\"\n model={this.#viewItemsAsModel}\n onChange={this.#viewItemsAsChangedHandler}\n value={this.#viewItemsAsModel[0].value}\n ></ch-radio-group-render>\n </div>\n\n <div class=\"field field-inline field__toggle-checkboxes\">\n <label\n class=\"label\"\n htmlFor=\"control-id-1\"\n htmlfor=\"toggle-checkboxes\"\n >\n Toggle Checkboxes\n </label>\n <ch-checkbox\n class=\"checkbox\"\n id=\"toggle-checkboxes\"\n checkedValue={TOGGLE_CHECKBOXES_CHECKED_VALUE}\n value={TOGGLE_CHECKBOXES_CHECKED_VALUE}\n onInput={this.#toggleCheckboxesChangedHandler}\n ></ch-checkbox>\n </div>\n </div>\n\n <ch-edit\n class=\"input pattern-filter\"\n placeholder={\n this.#_componentLocale.header.searchPatternPlaceholder\n }\n startImgSrc={SYSTEM_SEARCH_ICON}\n onInput={this.#patternSearchValueChangedHandler}\n ></ch-edit>\n </header>\n\n <div class=\"spacing-body-inline-start trees\">\n <ch-tree-view-render\n class=\"tree-view\"\n model={\n this.nodesVersionsViewType === \"tree\"\n ? this.nodeVersionsListTreeModel\n : this.nodeListFlattenedTreeModel\n }\n show-lines={\n this.nodesVersionsViewType === \"tree\" ? \"all\" : \"none\"\n }\n expandableButton={\n this.nodesVersionsViewType === \"tree\" ? \"decorative\" : \"no\"\n }\n onItemContextmenu={this.#contextMenuHandler}\n onCheckedItemsChange={this.#checkedItemsChangeHandler}\n onSelectedItemsChange={this.#selectedItemsChangeHandler}\n multiSelection={this.multiSelection}\n filter={this.searchPatternValue}\n filterType=\"caption\"\n toggleCheckboxes={this.toggleCheckboxes}\n ref={(el: HTMLChTreeViewRenderElement) => {\n this.#treeViewRenderEl = el as HTMLChTreeViewRenderElement;\n }}\n ></ch-tree-view-render>\n </div>\n {this.#renderFooter()}\n </section>\n </Host>\n );\n }\n}\n\nexport type CheckboxType = \"none\" | \"all\" | \"leaf\" | \"custom\";\n\nexport type DialogAction = {\n name: string;\n callback: DialogActionCallback;\n};\n\nexport type DialogActionCallback = (...args: any[]) => void;\n\nexport type ItemCommon = {\n icon: string;\n expanded: boolean;\n};\n\nexport type ItemNode = {\n checkbox?: boolean;\n checked?: boolean;\n expanded?: boolean;\n icon?: string;\n id: string;\n name: string;\n nodes?: ItemNode[];\n selected?: boolean;\n type: ItemType;\n};\n\nexport type ItemType = {\n id: string;\n name: string;\n};\n\ntype NodesVersionsViewType = \"tree\" | \"list\";\n"],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import { ItemNode, CheckboxType } from "./select-kb-items";
2
+ import { TreeViewItemModel } from "@genexus/chameleon-controls-library";
3
+ export declare const convertItemsNodeListToFlattenedTreeViewModel: (itemsList: ItemNode[], checkboxType: CheckboxType) => TreeViewItemModel[];
4
+ export declare const convertItemsListToTreeViewModel: (itemsList: ItemNode[], checkboxType: CheckboxType) => TreeViewItemModel[];
5
+ export declare const unselectAllNodes: (itemsList: ItemNode[]) => void;
6
+ export declare const checkItems: (itemsList: ItemNode[], idsChecked: string[]) => ItemNode[];
7
+ export declare const expandItems: (itemsList: ItemNode[], idsChecked: string[]) => ItemNode[];
8
+ export declare const selectItems: (itemsList: ItemNode[], idsSelected: string[]) => ItemNode[];
9
+ export declare const searchParentsItems: (items: ItemNode[], ids: string[]) => string[] | null;
@@ -0,0 +1,100 @@
1
+ import { TreeViewItemModel } from "@genexus/chameleon-controls-library";
2
+ import { ContextMenuInfo } from "../../common/types";
3
+ export declare class GxIdeSelectKbItems {
4
+ #private;
5
+ el: HTMLGxIdeSelectKbItemsElement;
6
+ /**
7
+ * Represents the nodes list model
8
+ */
9
+ nodeListFlattenedTreeModel: TreeViewItemModel[];
10
+ /**
11
+ * View type for the nodes.
12
+ */
13
+ nodesVersionsViewType: NodesVersionsViewType;
14
+ /**
15
+ * Represents the nodes tree model
16
+ */
17
+ nodeVersionsListTreeModel: TreeViewItemModel[];
18
+ /**
19
+ * "Search Pattern" input value, used to filter the nodes tree/list.
20
+ */
21
+ searchPatternValue: string;
22
+ /**
23
+ * It maps to the ch-tree-view-render "toggleCheckboxes" property.
24
+ */
25
+ toggleCheckboxes: boolean;
26
+ /**
27
+ * Callback emitted when the 'cancel' button is pressed
28
+ */
29
+ readonly cancelCallback?: () => Promise<void>;
30
+ /**
31
+ * Defines which nodes of the component have checkboxes.
32
+ */
33
+ readonly checkboxType: CheckboxType;
34
+ /**
35
+ * Callback emitted when the items checked items change
36
+ */
37
+ readonly checkedChanged?: (checkedItems: string[]) => Promise<void>;
38
+ /**
39
+ * Callback emitted when the 'select' button is pressed
40
+ */
41
+ readonly confirmCallback?: (checkedItems: string[]) => Promise<void>;
42
+ /**
43
+ * Set of additional actions (callbacks) to those already provided by default by the selector (cancelCallback and selectCallback)
44
+ */
45
+ readonly dialogActions: DialogAction[];
46
+ /**
47
+ * Callback emitted when the user right click on an item
48
+ */
49
+ readonly itemContextMenuCallback: (info: ContextMenuInfo) => Promise<void>;
50
+ /**
51
+ * Represents the itemLis list model
52
+ */
53
+ readonly itemsList: ItemNode[];
54
+ watchNodeListHandler(newItemsList: ItemNode[]): void;
55
+ /**
56
+ * This define if the selection is unique or not
57
+ */
58
+ readonly multiSelection?: boolean;
59
+ /**
60
+ * Callback emitted when the items selection change
61
+ */
62
+ readonly selectionChanged?: (selectedItem: string[]) => Promise<void>;
63
+ componentWillLoad(): Promise<void>;
64
+ /**
65
+ * Suspends or reactivates the shortcuts
66
+ */
67
+ suspendShortcuts(suspendShortcuts: boolean): Promise<void>;
68
+ /**
69
+ * Allow to update the selected items
70
+ */
71
+ updateSelection(selectedItemsIds: string[]): Promise<void>;
72
+ render(): any;
73
+ }
74
+ export type CheckboxType = "none" | "all" | "leaf" | "custom";
75
+ export type DialogAction = {
76
+ name: string;
77
+ callback: DialogActionCallback;
78
+ };
79
+ export type DialogActionCallback = (...args: any[]) => void;
80
+ export type ItemCommon = {
81
+ icon: string;
82
+ expanded: boolean;
83
+ };
84
+ export type ItemNode = {
85
+ checkbox?: boolean;
86
+ checked?: boolean;
87
+ expanded?: boolean;
88
+ icon?: string;
89
+ id: string;
90
+ name: string;
91
+ nodes?: ItemNode[];
92
+ selected?: boolean;
93
+ type: ItemType;
94
+ };
95
+ export type ItemType = {
96
+ id: string;
97
+ name: string;
98
+ };
99
+ type NodesVersionsViewType = "tree" | "list";
100
+ export {};
@@ -66,7 +66,7 @@ export type KBData = {
66
66
  export type KBVersion = {
67
67
  id: number;
68
68
  name: string;
69
- type: VersionType;
69
+ type?: VersionType;
70
70
  };
71
71
  export type ConnectionResultData = {
72
72
  formResult: FormSubmitResult;
@@ -76,7 +76,7 @@ export type KnowledgeBaseInfo = {
76
76
  selectedKB: string;
77
77
  versionSelected: VersionOption;
78
78
  localKBName: string;
79
- versionList: string[];
79
+ versionList: KBVersion[];
80
80
  };
81
81
  export type VersionOption = "Trunk" | "All" | "Select";
82
82
  export type VersionType = "Branch" | "Frozen";