@genexus/genexus-ide-ui 0.0.64 → 0.0.65

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 (109) hide show
  1. package/dist/cjs/ch-icon.cjs.entry.js +116 -0
  2. package/dist/cjs/{config-8634e7dd.js → config-8cf5ba3b.js} +4 -0
  3. package/dist/cjs/genexus-ide-ui.cjs.js +1 -1
  4. package/dist/cjs/gx-ide-bpm-app-declaration.cjs.entry.js +1 -1
  5. package/dist/cjs/gx-ide-container_4.cjs.entry.js +3 -0
  6. package/dist/cjs/gx-ide-kb-manager-export.cjs.entry.js +30 -14
  7. package/dist/cjs/gx-ide-kb-manager-import.cjs.entry.js +119 -30
  8. package/dist/cjs/gx-ide-new-environment.cjs.entry.js +1 -1
  9. package/dist/cjs/gx-ide-new-kb.cjs.entry.js +1 -1
  10. package/dist/cjs/gx-ide-new-object.cjs.entry.js +1 -1
  11. package/dist/cjs/gx-ide-object-selector.cjs.entry.js +1 -1
  12. package/dist/cjs/gx-ide-references.cjs.entry.js +1 -1
  13. package/dist/cjs/gx-ide-share-kb.cjs.entry.js +1 -1
  14. package/dist/cjs/{gx-ide-status-buttons_2.cjs.entry.js → gx-ide-status-buttons.cjs.entry.js} +0 -72
  15. package/dist/cjs/gx-ide-team-dev-commit.cjs.entry.js +1 -1
  16. package/dist/cjs/gx-ide-team-dev-select-recent-comment.cjs.entry.js +1 -1
  17. package/dist/cjs/gx-ide-team-dev-update-partial-selection.cjs.entry.js +1 -1
  18. package/dist/cjs/gx-ide-team-dev-update-to-revision.cjs.entry.js +1 -1
  19. package/dist/cjs/gx-ide-team-dev-update.cjs.entry.js +1 -1
  20. package/dist/cjs/gx-ide-template.cjs.entry.js +1 -1
  21. package/dist/cjs/gx-ide-ww-images.cjs.entry.js +1 -1
  22. package/dist/cjs/{gxg-button-group.cjs.entry.js → gxg-button-group_2.cjs.entry.js} +105 -0
  23. package/dist/cjs/{gxg-button.cjs.entry.js → gxg-button_2.cjs.entry.js} +63 -0
  24. package/dist/cjs/gxg-list-box_2.cjs.entry.js +1 -1
  25. package/dist/cjs/gxg-text.cjs.entry.js +1 -1
  26. package/dist/cjs/loader.cjs.js +1 -1
  27. package/dist/collection/common/config.js +4 -0
  28. package/dist/collection/components/kb-manager-export/gx-ide-assets/kb-manager-export/langs/kb-manager-export.lang.en.json +4 -0
  29. package/dist/collection/components/kb-manager-export/kb-manager-export.js +43 -28
  30. package/dist/collection/components/kb-manager-import/gx-ide-assets/kb-manager-import/langs/kb-manager-import.lang.en.json +1 -1
  31. package/dist/collection/components/kb-manager-import/helpers.js +5 -3
  32. package/dist/collection/components/kb-manager-import/kb-manager-import.css +3 -0
  33. package/dist/collection/components/kb-manager-import/kb-manager-import.js +134 -25
  34. package/dist/components/config.js +4 -0
  35. package/dist/components/form-text.js +5 -1
  36. package/dist/components/gx-ide-kb-manager-export.js +77 -42
  37. package/dist/components/gx-ide-kb-manager-import.js +121 -29
  38. package/dist/components/ide-loader.js +75 -14
  39. package/dist/components/list-box-item.js +1 -1
  40. package/dist/components/text.js +1 -1
  41. package/dist/esm/ch-icon.entry.js +112 -0
  42. package/dist/esm/{config-e6f580c8.js → config-2fae16a2.js} +4 -0
  43. package/dist/esm/genexus-ide-ui.js +1 -1
  44. package/dist/esm/gx-ide-bpm-app-declaration.entry.js +1 -1
  45. package/dist/esm/gx-ide-container_4.entry.js +3 -0
  46. package/dist/esm/gx-ide-kb-manager-export.entry.js +30 -14
  47. package/dist/esm/gx-ide-kb-manager-import.entry.js +119 -30
  48. package/dist/esm/gx-ide-new-environment.entry.js +1 -1
  49. package/dist/esm/gx-ide-new-kb.entry.js +1 -1
  50. package/dist/esm/gx-ide-new-object.entry.js +1 -1
  51. package/dist/esm/gx-ide-object-selector.entry.js +1 -1
  52. package/dist/esm/gx-ide-references.entry.js +1 -1
  53. package/dist/esm/gx-ide-share-kb.entry.js +1 -1
  54. package/dist/esm/{gx-ide-status-buttons_2.entry.js → gx-ide-status-buttons.entry.js} +1 -72
  55. package/dist/esm/gx-ide-team-dev-commit.entry.js +1 -1
  56. package/dist/esm/gx-ide-team-dev-select-recent-comment.entry.js +1 -1
  57. package/dist/esm/gx-ide-team-dev-update-partial-selection.entry.js +1 -1
  58. package/dist/esm/gx-ide-team-dev-update-to-revision.entry.js +1 -1
  59. package/dist/esm/gx-ide-team-dev-update.entry.js +1 -1
  60. package/dist/esm/gx-ide-template.entry.js +1 -1
  61. package/dist/esm/gx-ide-ww-images.entry.js +1 -1
  62. package/dist/esm/{gxg-button-group.entry.js → gxg-button-group_2.entry.js} +105 -1
  63. package/dist/esm/{gxg-button.entry.js → gxg-button_2.entry.js} +64 -2
  64. package/dist/esm/gxg-list-box_2.entry.js +1 -1
  65. package/dist/esm/gxg-text.entry.js +1 -1
  66. package/dist/esm/loader.js +1 -1
  67. package/dist/genexus-ide-ui/genexus-ide-ui.esm.js +1 -1
  68. package/dist/genexus-ide-ui/gx-ide-assets/kb-manager-export/langs/kb-manager-export.lang.en.json +4 -0
  69. package/dist/genexus-ide-ui/gx-ide-assets/kb-manager-import/langs/kb-manager-import.lang.en.json +1 -1
  70. package/dist/genexus-ide-ui/{p-61e5b3a7.entry.js → p-00bb2aa7.entry.js} +1 -1
  71. package/dist/genexus-ide-ui/{p-34f4deb8.entry.js → p-02c50994.entry.js} +1 -1
  72. package/dist/genexus-ide-ui/{p-fa4e7177.js → p-13ffa7c0.js} +1 -1
  73. package/dist/genexus-ide-ui/p-232fe7cb.entry.js +1 -0
  74. package/dist/genexus-ide-ui/{p-eb3895cc.entry.js → p-2dc875c2.entry.js} +1 -1
  75. package/dist/genexus-ide-ui/{p-cf421c67.entry.js → p-2ec6d722.entry.js} +1 -1
  76. package/dist/genexus-ide-ui/{p-15f4ca7a.entry.js → p-3dacc147.entry.js} +1 -1
  77. package/dist/genexus-ide-ui/{p-2582e3d7.entry.js → p-4d653456.entry.js} +1 -1
  78. package/dist/genexus-ide-ui/{p-a14dde56.entry.js → p-7c64e541.entry.js} +1 -1
  79. package/dist/genexus-ide-ui/p-7dfeb944.entry.js +1 -0
  80. package/dist/genexus-ide-ui/p-81776364.entry.js +1 -0
  81. package/dist/genexus-ide-ui/{p-16aad0e4.entry.js → p-8d99e6a5.entry.js} +1 -1
  82. package/dist/genexus-ide-ui/{p-c0532785.entry.js → p-a05224f3.entry.js} +1 -1
  83. package/dist/genexus-ide-ui/{p-0cc3af0d.entry.js → p-a06d0915.entry.js} +1 -1
  84. package/dist/genexus-ide-ui/p-a8d037cf.entry.js +1 -0
  85. package/dist/genexus-ide-ui/{p-285f0790.entry.js → p-baabb0be.entry.js} +1 -1
  86. package/dist/genexus-ide-ui/{p-1ad41f2e.entry.js → p-bf5c0727.entry.js} +1 -1
  87. package/dist/genexus-ide-ui/{p-57327cd3.entry.js → p-c3a1a74c.entry.js} +1 -1
  88. package/dist/genexus-ide-ui/{p-4f63438d.entry.js → p-cd285670.entry.js} +1 -1
  89. package/dist/genexus-ide-ui/{p-6fb33e4c.entry.js → p-cd74a437.entry.js} +1 -1
  90. package/dist/genexus-ide-ui/{p-9d73a85c.entry.js → p-d192b1e9.entry.js} +1 -1
  91. package/dist/genexus-ide-ui/{p-2c5289df.entry.js → p-ec9c9f44.entry.js} +1 -1
  92. package/dist/genexus-ide-ui/{p-3b55122b.entry.js → p-eed26277.entry.js} +1 -1
  93. package/dist/genexus-ide-ui/p-fae07693.entry.js +1 -0
  94. package/dist/node_modules/@genexus/gemini/dist/collection/components/ide-loader/ide-loader.css +17 -9
  95. package/dist/node_modules/@genexus/gemini/dist/collection/components/list-box-item/list-box-item.css +2 -2
  96. package/dist/node_modules/@genexus/gemini/dist/collection/components/text/text.css +1 -0
  97. package/dist/types/common/config.d.ts +3 -0
  98. package/dist/types/components/kb-manager-export/kb-manager-export.d.ts +9 -6
  99. package/dist/types/components/kb-manager-import/helpers.d.ts +1 -0
  100. package/dist/types/components/kb-manager-import/kb-manager-import.d.ts +17 -2
  101. package/dist/types/components.d.ts +17 -10
  102. package/package.json +3 -3
  103. package/dist/cjs/ch-icon_2.cjs.entry.js +0 -179
  104. package/dist/esm/ch-icon_2.entry.js +0 -174
  105. package/dist/genexus-ide-ui/p-0371daa4.entry.js +0 -1
  106. package/dist/genexus-ide-ui/p-0d7c0cd1.entry.js +0 -1
  107. package/dist/genexus-ide-ui/p-1bf68774.entry.js +0 -1
  108. package/dist/genexus-ide-ui/p-a99c17b1.entry.js +0 -1
  109. package/dist/genexus-ide-ui/p-c74f5d08.entry.js +0 -1
@@ -209,6 +209,7 @@ gxg-tabs {
209
209
  height: var(--spacing-comp-02);
210
210
  border-radius: 50%;
211
211
  background-color: var(--gray-03);
212
+ margin-inline-end: var(--spacing-comp-01);
212
213
  background-color: var(--color-success-dark);
213
214
  }
214
215
  .main .tree-container--import-status .tree-view-item--warning::part(action) {
@@ -221,6 +222,7 @@ gxg-tabs {
221
222
  height: var(--spacing-comp-02);
222
223
  border-radius: 50%;
223
224
  background-color: var(--gray-03);
225
+ margin-inline-end: var(--spacing-comp-01);
224
226
  background-color: var(--color-warning-dark);
225
227
  }
226
228
  .main .tree-container--import-status .tree-view-item--error::part(action) {
@@ -233,6 +235,7 @@ gxg-tabs {
233
235
  height: var(--spacing-comp-02);
234
236
  border-radius: 50%;
235
237
  background-color: var(--gray-03);
238
+ margin-inline-end: var(--spacing-comp-01);
236
239
  background-color: var(--color-error-dark);
237
240
  }
238
241
  .main .tree-container--no-warnings .tree-view-item--warning {
@@ -4,6 +4,7 @@ import { Host, h } from "@stencil/core";
4
4
  import { Locale } from "../../common/locale";
5
5
  import { config } from "../../common/config";
6
6
  import { convertImportCategoryToTreeView, addImportItemResultDataItem } from "./helpers";
7
+ // import { CheckboxInfo } from "@genexus/gemini/dist/types/components/form-checkbox/form-checkbox";
7
8
  import { countTreeItems } from "../../common/helpers";
8
9
  import { KB_OBJECT } from "./helpers";
9
10
  export class GxIdeKbManagerImport {
@@ -13,6 +14,34 @@ export class GxIdeKbManagerImport {
13
14
  this.importCategoryData = [];
14
15
  this.objectsInFileTotalNodes = 0;
15
16
  // 9.LOCAL METHODS //
17
+ this.evaluateImportStatusMessage = () => {
18
+ this.someStatusVisible =
19
+ this.statusInfo.error.display ||
20
+ this.statusInfo.warning.display ||
21
+ this.statusInfo.success.display;
22
+ };
23
+ this.countMessages = () => {
24
+ /* totally inefficient way to count. This has to be improved*/
25
+ let errors = 0;
26
+ let warnings = 0;
27
+ let successes = 0;
28
+ this.importTreeState.forEach(category => {
29
+ category.items.forEach(object => {
30
+ if (object.class.includes("tree-view-item--error")) {
31
+ errors += object.items.length;
32
+ }
33
+ else if (object.class.includes("tree-view-item--warning")) {
34
+ warnings += object.items.length;
35
+ }
36
+ else if (object.class.includes("tree-view-item--success")) {
37
+ successes += object.items.length;
38
+ }
39
+ });
40
+ });
41
+ this.statusInfo.error.number = errors;
42
+ this.statusInfo.warning.number = warnings;
43
+ this.statusInfo.success.number = successes;
44
+ };
16
45
  this.evaluateObjects = () => {
17
46
  var _a;
18
47
  this.noObjects = !!(((_a = this.objectsTreeState) === null || _a === void 0 ? void 0 : _a.length) === 0 || !this.objectsTreeState);
@@ -41,7 +70,7 @@ export class GxIdeKbManagerImport {
41
70
  this.evaluateHeaderActiveButton = () => {
42
71
  if (!this.selectedFile) {
43
72
  this.headerButtonsGroup.activeButtonId = "select-file-btn";
44
- this.fileInputEl.value = undefined;
73
+ this.fileInputEl.clearInput();
45
74
  }
46
75
  else {
47
76
  this.headerButtonsGroup.activeButtonId = "load-file-btn";
@@ -59,7 +88,7 @@ export class GxIdeKbManagerImport {
59
88
  }
60
89
  };
61
90
  this.objectsTreeCheckedItemsChangedHandler = (event) => {
62
- /* Begin of evaluate 'select/unselect checkbox' state*/
91
+ /* 1. Begin of evaluate 'select/unselect checkbox' state*/
63
92
  if (event.detail == null) {
64
93
  this.toggleObjectsCheckboxEl.checked = false;
65
94
  this.toggleObjectsCheckboxEl.indeterminate = false;
@@ -76,19 +105,56 @@ export class GxIdeKbManagerImport {
76
105
  this.toggleObjectsCheckboxEl.checked = firstItemCheckedValue;
77
106
  this.toggleObjectsCheckboxEl.indeterminate =
78
107
  !allItemsHaveTheSameCheckedValue;
79
- /* End of evaluate 'select/unselect checkbox' state*/
108
+ /* /End of evaluate 'select/unselect checkbox' state*/
109
+ /* 2. Begin of checked items evaluation*/
80
110
  const checkedItems = allItemsWithCheckbox.filter(node => node.item.checked);
81
111
  // objects checked
82
112
  const checkedObjects = checkedItems.filter(node => node.item.metadata === KB_OBJECT);
83
- console.log("checkedObjects", checkedObjects);
84
113
  const checkedObjectsIds = [];
85
114
  if (checkedObjects.length > 0) {
86
115
  checkedObjects.forEach(objectChecked => {
87
116
  checkedObjectsIds.push(objectChecked.item.id);
88
117
  });
89
118
  }
119
+ /* /End of checked items evaluation*/
120
+ /* 3. Begin of caption update*/
121
+ /* TO DO (when we can differentiate the caption from the number of children)*/
122
+ // const categoryItems = allItemsWithCheckbox.filter(
123
+ // node => node.item.metadata === KB_CATEGORY
124
+ // );
125
+ // categoryItems.forEach(category => {
126
+ // const itemInfo = category.item;
127
+ // // Update the amount of checked values
128
+ // if (itemInfo.leaf !== true) {
129
+ // const totalItems = itemInfo.items.length;
130
+ // const totalItemsChecked = itemInfo.items.filter(
131
+ // itemUIModel => itemUIModel.checked
132
+ // ).length;
133
+ // const newItemCaption =
134
+ // totalItems !== totalItemsChecked
135
+ // ? `${itemInfo.caption} (${totalItemsChecked}/${totalItems})`
136
+ // : `${itemInfo.caption} (${totalItems})`;
137
+ // // Only update the item caption if needed
138
+ // if (newItemCaption !== itemInfo.caption) {
139
+ // this.objectsTreeEl.updateItemsProperties([itemInfo.id], {
140
+ // id: itemInfo.id,
141
+ // caption: newItemCaption
142
+ // });
143
+ // }
144
+ // }
145
+ // });
146
+ /* /End of caption update*/
90
147
  this.checkedObjectsIds = checkedObjectsIds;
91
148
  };
149
+ this.objectsTreeContextMenuHandler = (event) => {
150
+ if (this.objectContextMenuCallback && event.detail.metadata === KB_OBJECT) {
151
+ this.objectContextMenuCallback({
152
+ objectId: event.detail.id,
153
+ screenX: event.detail.contextmenuEvent.screenX,
154
+ screenY: event.detail.contextmenuEvent.screenY
155
+ });
156
+ }
157
+ };
92
158
  this.cancelImportHandler = () => {
93
159
  if (this.cancelCallback) {
94
160
  this.cancelCallback();
@@ -107,23 +173,31 @@ export class GxIdeKbManagerImport {
107
173
  this.statusInfo.warning.number = 0;
108
174
  this.statusInfo.success.number = 0;
109
175
  };
110
- this.toggleSelectionHandler = (e) => {
111
- const checked = e.detail.value;
176
+ this.toggleSelectionClickHandler = (e) => {
177
+ const checked = e.target.checked;
112
178
  this.toggleObjectsCheckboxEl.indeterminate = false;
113
179
  this.objectsTreeEl.updateAllItemsProperties({ checked: checked });
114
180
  };
115
181
  this.statusButtonsSelectionChangedHandler = (e) => {
116
182
  const activeStates = e.detail;
117
- const newStatusInfo = Object.assign({}, this.statusInfo);
118
- newStatusInfo.warning.display = false;
119
- newStatusInfo.error.display = false;
120
- newStatusInfo.success.display = false;
121
- activeStates.forEach(activeState => {
122
- const status = activeState.itemId;
123
- newStatusInfo[status].display = true;
124
- this.statusInfo = newStatusInfo;
125
- });
126
- this.evaluateHiddenImportsMessage();
183
+ const errorIndex = activeStates.findIndex(state => state.itemId === "error");
184
+ const warningIndex = activeStates.findIndex(state => state.itemId === "warning");
185
+ const successIndex = activeStates.findIndex(state => state.itemId === "success");
186
+ this.statusInfo = {
187
+ error: {
188
+ display: errorIndex !== -1,
189
+ number: this.statusInfo.error.number
190
+ },
191
+ warning: {
192
+ display: warningIndex !== -1,
193
+ number: this.statusInfo.warning.number
194
+ },
195
+ success: {
196
+ display: successIndex !== -1,
197
+ number: this.statusInfo.success.number
198
+ }
199
+ };
200
+ this.evaluateImportStatusMessage();
127
201
  };
128
202
  this.evaluateCheckAllValue = () => {
129
203
  let checked = true;
@@ -134,8 +208,8 @@ export class GxIdeKbManagerImport {
134
208
  }
135
209
  return checked;
136
210
  };
137
- this.evaluateHiddenImportsMessage = () => {
138
- /* to do*/
211
+ this.fileClearedHandler = () => {
212
+ this.selectedFile = null;
139
213
  };
140
214
  this.checkedObjectsIds = [];
141
215
  this.noObjects = undefined;
@@ -155,6 +229,8 @@ export class GxIdeKbManagerImport {
155
229
  }
156
230
  };
157
231
  this.objectsTreeState = [];
232
+ this.importStatusMessage = undefined;
233
+ this.someStatusVisible = undefined;
158
234
  this.noImport = undefined;
159
235
  this.importTreeState = [];
160
236
  this.importingObjects = false;
@@ -164,6 +240,7 @@ export class GxIdeKbManagerImport {
164
240
  this.loadCallback = undefined;
165
241
  this.cancelCallback = undefined;
166
242
  this.statusMinimal = false;
243
+ this.objectContextMenuCallback = undefined;
167
244
  }
168
245
  watchObjectsTreeStateHandler(newState) {
169
246
  this.noObjects = !!(newState.length === 0 || !newState);
@@ -171,6 +248,14 @@ export class GxIdeKbManagerImport {
171
248
  }
172
249
  watchImportTreeStateHandler(newState) {
173
250
  this.noImport = !!(newState.length === 0 || !newState);
251
+ if (this.noImport) {
252
+ this.importStatusMessage =
253
+ this._componentLocale.main.importStatus.noImportedFiles;
254
+ }
255
+ else {
256
+ this.importStatusMessage =
257
+ this._componentLocale.main.importStatus.importedButHidden;
258
+ }
174
259
  }
175
260
  watchSelectedFileHandler() {
176
261
  this.evaluateHeaderActiveButton();
@@ -181,6 +266,9 @@ export class GxIdeKbManagerImport {
181
266
  this.componentDidLoadEvent.emit(true);
182
267
  this.evaluateObjects();
183
268
  this.evaluateImport();
269
+ this.importStatusMessage =
270
+ this._componentLocale.main.importStatus.noImportedFiles;
271
+ this.evaluateImportStatusMessage();
184
272
  }
185
273
  componentDidRender() {
186
274
  if (!this.renderedFirstTime) {
@@ -195,27 +283,27 @@ export class GxIdeKbManagerImport {
195
283
  */
196
284
  async addResultItem(item) {
197
285
  this.importTreeState = addImportItemResultDataItem(item, this.importCategoryData, this.importTreeState);
198
- this.statusInfo[`${item.status}`].number += item.messages.length;
286
+ this.countMessages();
199
287
  }
200
288
  // 10.RENDER() FUNCTION //
201
289
  render() {
202
- return (h(Host, { class: "gx-ide-component" }, h("div", { class: "gx-ide-main-wrapper" }, h("gx-ide-container", { noContentPadding: true, noFooterPadding: true, containerTitle: this._componentLocale.componentName }, h("header", { class: "header", slot: "header" }, h("gxg-form-text", { type: "file", class: "select-file", label: this._componentLocale.header.fileNameLabel, placeholder: this._componentLocale.header.fileNamePlaceholder, part: "file-name", acceptFile: ".xpz, .xml", clearButton: true, iconPosition: "start", onFileSelected: this.fileSelectedHandler, ref: (el) => (this.fileInputEl = el) }), h("gxg-button-group", {
290
+ return (h(Host, { class: "gx-ide-component" }, h("div", { class: "gx-ide-main-wrapper" }, h("gx-ide-container", { noContentPadding: true, noFooterPadding: true, containerTitle: this._componentLocale.componentName }, h("header", { class: "header", slot: "header" }, h("gxg-form-text", { type: "file", class: "select-file", label: this._componentLocale.header.fileNameLabel, placeholder: this._componentLocale.header.fileNamePlaceholder, part: "file-name", acceptFile: ".xpz, .xml", clearButton: true, iconPosition: "start", onFileSelected: this.fileSelectedHandler, onClearButtonClicked: this.fileClearedHandler, ref: (el) => (this.fileInputEl = el) }), h("gxg-button-group", {
203
291
  // default-selected-btn-id="select-file-btn"
204
292
  ref: (el) => (this.headerButtonsGroup = el)
205
- }, h("button", { id: "select-file-btn", part: "select-file-button", onClick: this.selectFileHandler }, this._componentLocale.header.selectFileButton), h("button", { id: "load-file-btn", part: "load-file-button", disabled: !this.selectedFile, onClick: this.loadFileHandler }, this._componentLocale.header.loadButton))), h("main", { class: "main" }, h("gx-ide-container", { containerTitle: this._componentLocale.main.objectsInFile.title, noContentPadding: true, noBorderFooter: true, class: "left-grid-item", slimmerFooter: true, inactiveTitle: this.noObjects, footerSubtleShadow: !this.noObjects, titleType: "secondary" }, h("div", { class: {
293
+ }, h("button", { id: "select-file-btn", part: "select-file-button", onClick: this.selectFileHandler, disabled: this.importingObjects }, this._componentLocale.header.selectFileButton), h("button", { id: "load-file-btn", part: "load-file-button", disabled: !this.selectedFile || this.importingObjects, onClick: this.loadFileHandler }, this._componentLocale.header.loadButton))), h("main", { class: "main" }, h("gx-ide-container", { containerTitle: this._componentLocale.main.objectsInFile.title, noContentPadding: true, noBorderFooter: true, class: "left-grid-item", slimmerFooter: true, inactiveTitle: this.noObjects, footerSubtleShadow: !this.noObjects, titleType: "secondary" }, h("div", { class: {
206
294
  "tree-container": true,
207
295
  "tree-container--objects-in-file": true,
208
296
  "tree-container--empty": this.noObjects
209
- } }, !this.noObjects ? (h("gxg-tree-view", { treeModel: this.objectsTreeState, dragDisabled: true, dropDisabled: true, toggleCheckboxes: true, onCheckedItemsChange: this.objectsTreeCheckedItemsChangedHandler, ref: el => (this.objectsTreeEl = el) })) : (h("div", { class: "gx-ide-message" }, h("gxg-text", { textAlign: config.gxgMessage.common.textAlign, padding: config.gxgMessage.common.textAlign, type: config.gxgMessage.common.type, maxWidth: config.gxgMessage.common.maxWidth, part: "objects-in-file-empty-status-message" }, "There are no Objects. ", h("br", null), h("gxg-text", { type: "text-link-no-line", onClick: this.selectFileHandler }, "Begin by selecting a file."))))), h("gxg-form-checkbox", { label: this._componentLocale.main.objectsInFile.selectUnselect, part: "select-all-checkbox", slot: "footer-start", disabled: this.importingObjects || this.objectsTreeState.length === 0, checked: this.evaluateCheckAllValue(), onChange: this.toggleSelectionHandler, ref: (el) => (this.toggleObjectsCheckboxEl =
297
+ } }, !this.noObjects ? (h("gxg-tree-view", { treeModel: this.objectsTreeState, dragDisabled: true, dropDisabled: true, toggleCheckboxes: true, checkbox: true, checked: true, onCheckedItemsChange: this.objectsTreeCheckedItemsChangedHandler, onItemContextmenu: this.objectsTreeContextMenuHandler, ref: el => (this.objectsTreeEl = el) })) : (h("div", { class: "gx-ide-message" }, h("gxg-text", { textAlign: config.gxgMessage.common.textAlign, padding: config.gxgMessage.common.textAlign, type: config.gxgMessage.common.type, maxWidth: config.gxgMessage.common.maxWidth, part: "objects-in-file-empty-status-message" }, "There are no Objects. ", h("br", null), h("gxg-text", { type: "text-link-no-line", onClick: this.selectFileHandler }, "Begin by selecting a file."))))), h("gxg-form-checkbox", { label: this._componentLocale.main.objectsInFile.selectUnselect, part: "select-all-checkbox", slot: "footer-start", disabled: this.importingObjects || this.objectsTreeState.length === 0, checked: this.evaluateCheckAllValue(), onClick: this.toggleSelectionClickHandler, ref: (el) => (this.toggleObjectsCheckboxEl =
210
298
  el) }), h("gxg-button-group", { slot: "footer-end", ref: (el) => (this.objectsButtonsGroup = el) }, h("button", { id: "import-btn", part: "import-button", disabled: this.importingObjects ||
211
299
  this.checkedObjectsIds.length === 0, onClick: this.importObjectsHandler }, this._componentLocale.main.objectsInFile.importButton), h("button", { id: "cancel-import-btn", part: "cancel-import-button", disabled: !this.importingObjects, onClick: this.cancelImportHandler }, this._componentLocale.main.objectsInFile.cancelButton)), h("gxg-button", { type: "secondary-icon-only", icon: "gemini-tools/settings", slot: "footer-end", part: "select-kb-btn", onClick: this.optionsHandler }, this._componentLocale.header.optionsButton)), h("gx-ide-container", { containerTitle: this._componentLocale.main.importStatus.title, noContentPadding: true, noBorderFooter: true, slimmerFooter: true, inactiveTitle: this.noImport, footerSubtleShadow: !this.noImport, titleType: "secondary" }, h("div", { class: {
212
300
  "tree-container": true,
213
301
  "tree-container--import-status": true,
214
- "tree-container--empty": this.noImport,
302
+ "tree-container--empty": this.noImport || !this.someStatusVisible,
215
303
  "tree-container--no-warnings": !this.statusInfo.warning.display,
216
304
  "tree-container--no-errors": !this.statusInfo.error.display,
217
- "tree-container--no-successes": this.statusInfo.success.display === false
218
- } }, !this.noImport ? (h("gxg-tree-view", { treeModel: this.importTreeState, toggleCheckboxes: true, ref: el => (this.objectsTreeEl = el) })) : (h("gxg-text", { textAlign: config.gxgMessage.common.textAlign, padding: config.gxgMessage.common.textAlign, type: config.gxgMessage.common.type, maxWidth: config.gxgMessage.common.maxWidth, part: "objects-in-file-empty-status-message", class: "gx-ide-message" }, "There are no Imported files."))), h("gxg-text", { type: "button-like", slot: "footer-end", part: "select-kb-btn", onClick: this.clearStatusHandler, disabled: this.noImport }, this._componentLocale.main.importStatus.clearButton), h("span", { class: "ghost-element", slot: "footer-start" }))), h("footer", { slot: "footer-start" }, h("gx-ide-status-buttons", { errors: this.statusInfo.error.number, warnings: this.statusInfo.warning.number, successes: this.statusInfo.success.number, compact: true, noBorderTop: true, noBorderBottom: true, noBorderStart: true, minimal: this.statusMinimal, onSelectionChanged: this.statusButtonsSelectionChangedHandler }))), h("gxg-ide-loader", { description: "Importing objects..." }))));
305
+ "tree-container--no-successes": !this.statusInfo.success.display
306
+ } }, !this.noImport && this.someStatusVisible ? (h("gxg-tree-view", { treeModel: this.importTreeState, toggleCheckboxes: true, ref: el => (this.objectsTreeEl = el) })) : (h("gxg-text", { textAlign: config.gxgMessage.common.textAlign, padding: config.gxgMessage.common.textAlign, type: config.gxgMessage.common.type, maxWidth: config.gxgMessage.common.maxWidth, part: "objects-in-file-empty-status-message", class: "gx-ide-message" }, this.importStatusMessage))), h("gxg-text", { type: "button-like", slot: "footer-end", part: "select-kb-btn", onClick: this.clearStatusHandler, disabled: this.noImport || this.importingObjects }, this._componentLocale.main.importStatus.clearButton), h("span", { class: "ghost-element", slot: "footer-start" }))), h("footer", { slot: "footer-start" }, h("gx-ide-status-buttons", { errors: this.statusInfo.error.number, warnings: this.statusInfo.warning.number, successes: this.statusInfo.success.number, compact: true, noBorderTop: true, noBorderBottom: true, noBorderStart: true, minimal: this.statusMinimal, onSelectionChanged: this.statusButtonsSelectionChangedHandler }))), h("gxg-ide-loader", { description: "Importing objects..." }))));
219
307
  }
220
308
  static get is() { return "gx-ide-kb-manager-import"; }
221
309
  static get encapsulation() { return "shadow"; }
@@ -347,6 +435,25 @@ export class GxIdeKbManagerImport {
347
435
  "attribute": "status-minimal",
348
436
  "reflect": false,
349
437
  "defaultValue": "false"
438
+ },
439
+ "objectContextMenuCallback": {
440
+ "type": "unknown",
441
+ "mutable": false,
442
+ "complexType": {
443
+ "original": "ObjectContextMenuCallback",
444
+ "resolved": "(objectContextMenu: ObjectContextMenuInfo) => Promise<void>",
445
+ "references": {
446
+ "ObjectContextMenuCallback": {
447
+ "location": "local"
448
+ }
449
+ }
450
+ },
451
+ "required": false,
452
+ "optional": false,
453
+ "docs": {
454
+ "tags": [],
455
+ "text": "It displays the status buttons (errors, warning, successes) with the minimal ui (no captions)"
456
+ }
350
457
  }
351
458
  };
352
459
  }
@@ -357,6 +464,8 @@ export class GxIdeKbManagerImport {
357
464
  "showHiddenImportsMessage": {},
358
465
  "statusInfo": {},
359
466
  "objectsTreeState": {},
467
+ "importStatusMessage": {},
468
+ "someStatusVisible": {},
360
469
  "noImport": {},
361
470
  "importTreeState": {},
362
471
  "importingObjects": {}
@@ -13,6 +13,10 @@ const config = {
13
13
  },
14
14
  gxIdeContainer: {
15
15
  slimmerFooter: true
16
+ },
17
+ loader: {
18
+ /* The amount of milliseconds the loader will display, before abort because of timeout*/
19
+ timeout: 4000
16
20
  }
17
21
  };
18
22
 
@@ -222,6 +222,9 @@ const GxgFormText = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
222
222
  this.fileInputEl.click();
223
223
  }
224
224
  }
225
+ async clearInput() {
226
+ this.clearButtonFunc();
227
+ }
225
228
  componentWillLoad() {
226
229
  this.evaluateIcon();
227
230
  this.attachExportParts();
@@ -473,7 +476,8 @@ const GxgFormText = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
473
476
  "mouseCoordinates": [32],
474
477
  "rtl": [32],
475
478
  "selectInputText": [64],
476
- "openFile": [64]
479
+ "openFile": [64],
480
+ "clearInput": [64]
477
481
  }]);
478
482
  function defineCustomElement() {
479
483
  if (typeof customElements === "undefined") {
@@ -1,19 +1,22 @@
1
1
  import { proxyCustomElement, HTMLElement, createEvent, h, Host } from '@stencil/core/internal/client';
2
2
  import { L as Locale } from './locale.js';
3
3
  import { c as config } from './config.js';
4
- import { d as defineCustomElement$j } from './checkbox.js';
5
- import { d as defineCustomElement$i } from './icon.js';
6
- import { d as defineCustomElement$h } from './tree-view.js';
7
- import { d as defineCustomElement$g } from './tree-view-item.js';
8
- import { d as defineCustomElement$f } from './tree-view-render.js';
9
- import { d as defineCustomElement$e } from './container.js';
10
- import { d as defineCustomElement$d } from './directory-selector.js';
11
- import { d as defineCustomElement$c } from './title.js';
12
- import { d as defineCustomElement$b } from './button.js';
13
- import { d as defineCustomElement$a } from './button-group.js';
14
- import { d as defineCustomElement$9 } from './form-checkbox.js';
15
- import { d as defineCustomElement$8 } from './form-text.js';
16
- import { d as defineCustomElement$7 } from './icon2.js';
4
+ import { d as defineCustomElement$m } from './checkbox.js';
5
+ import { d as defineCustomElement$l } from './icon.js';
6
+ import { d as defineCustomElement$k } from './tree-view.js';
7
+ import { d as defineCustomElement$j } from './tree-view-item.js';
8
+ import { d as defineCustomElement$i } from './tree-view-render.js';
9
+ import { d as defineCustomElement$h } from './ch-window2.js';
10
+ import { d as defineCustomElement$g } from './ch-window-close2.js';
11
+ import { d as defineCustomElement$f } from './container.js';
12
+ import { d as defineCustomElement$e } from './directory-selector.js';
13
+ import { d as defineCustomElement$d } from './title.js';
14
+ import { d as defineCustomElement$c } from './button.js';
15
+ import { d as defineCustomElement$b } from './button-group.js';
16
+ import { d as defineCustomElement$a } from './form-checkbox.js';
17
+ import { d as defineCustomElement$9 } from './form-text.js';
18
+ import { d as defineCustomElement$8 } from './icon2.js';
19
+ import { d as defineCustomElement$7 } from './ide-loader.js';
17
20
  import { d as defineCustomElement$6 } from './gxg-label2.js';
18
21
  import { d as defineCustomElement$5 } from './text.js';
19
22
  import { d as defineCustomElement$4 } from './title2.js';
@@ -179,7 +182,6 @@ const GxIdeKbManagerExport$1 = /*@__PURE__*/ proxyCustomElement(class extends HT
179
182
  this.__registerHost();
180
183
  this.componentDidLoadEvent = createEvent(this, "componentDidLoadEvent", 7);
181
184
  this.componentDidRenderFirstTime = createEvent(this, "componentDidRenderFirstTime", 7);
182
- this.checkedObjectsIds = [];
183
185
  this.checkedPropertiesIds = [];
184
186
  this.renderedFirstTime = false;
185
187
  this.flattenedObjectTypes = new Map();
@@ -256,6 +258,7 @@ const GxIdeKbManagerExport$1 = /*@__PURE__*/ proxyCustomElement(class extends HT
256
258
  };
257
259
  this.exportCallbackHandler = async () => {
258
260
  if (this.exportCallback) {
261
+ this.exportingIsInProcess = true;
259
262
  const exportAllChecked = this.exportAllCheckboxEl.checked;
260
263
  const fileName = this.fileNameEl.value;
261
264
  const checkedKbPropertiesIds = this.addKbPropertiesIsChecked
@@ -264,7 +267,9 @@ const GxIdeKbManagerExport$1 = /*@__PURE__*/ proxyCustomElement(class extends HT
264
267
  const checkedObjectIds = exportAllChecked
265
268
  ? undefined
266
269
  : this.checkedObjectsIds;
267
- this.exportCallback(fileName, checkedKbPropertiesIds, checkedObjectIds);
270
+ this.exportCallback(fileName, checkedKbPropertiesIds, checkedObjectIds).then(() => {
271
+ this.exportingIsInProcess = false;
272
+ });
268
273
  // returns Promise<boolean> but no procedure was detailed on the spec.
269
274
  }
270
275
  };
@@ -312,14 +317,23 @@ const GxIdeKbManagerExport$1 = /*@__PURE__*/ proxyCustomElement(class extends HT
312
317
  h("gxg-text", { type: "text-link-no-line", textAlign: "center", onClick: this.addObjectsCallbackHandler }, this._componentLocale.main.beginByADdingSomeObjects)
313
318
  ]) : (h("span", null, this._componentLocale.main.exportAllMessage))));
314
319
  };
320
+ this.clearButtonDisabledConditions = () => {
321
+ return this.noObjects || this.checkedObjectsIds.length === 0;
322
+ };
323
+ this.loaderCancelCallbackHandler = () => {
324
+ if (this.cancelCallback) {
325
+ this.cancelCallback();
326
+ }
327
+ };
315
328
  this.exportAllIsChecked = false;
316
- this.exportingIsInProcess = false;
317
329
  this.addKbPropertiesIsChecked = false;
330
+ this.checkedObjectsIds = [];
318
331
  this.fileName = "";
319
332
  this.exportFilePathName = undefined;
320
333
  this.noObjects = undefined;
321
334
  this.treeModel = [];
322
- this.dummyInitialTree = undefined;
335
+ this.exportingIsInProcess = false;
336
+ this.loader = false;
323
337
  this.kbPropertiesTypes = undefined;
324
338
  this.objectTypes = undefined;
325
339
  this.exportFileDirectoryCallback = undefined;
@@ -333,10 +347,15 @@ const GxIdeKbManagerExport$1 = /*@__PURE__*/ proxyCustomElement(class extends HT
333
347
  watchTreeModelHandler(newState) {
334
348
  this.noObjects = !!(newState.length === 0 || !newState);
335
349
  }
336
- watchDummyInitialTreeHandler(newTree) {
337
- this.treeModel = newTree;
350
+ watchExportingIsInProcessHandler(isExporting) {
351
+ if (isExporting && this.loader) {
352
+ this.loaderEl.show = true;
353
+ }
354
+ else if (!isExporting && this.loader) {
355
+ this.loaderEl.show = true;
356
+ }
338
357
  }
339
- watchObjectTypeslHandler(newState) {
358
+ watchObjectTypesHandler(newState) {
340
359
  this.flattenObjectTypes(newState);
341
360
  }
342
361
  // 6.COMPONENT LIFECYCLE EVENTS //
@@ -359,9 +378,9 @@ const GxIdeKbManagerExport$1 = /*@__PURE__*/ proxyCustomElement(class extends HT
359
378
  }
360
379
  // 10.RENDER() FUNCTION //
361
380
  render() {
362
- // console.log("checkedObjectsIds", this.checkedObjectsIds);
363
- // console.log("checkedPropertiesIds", this.checkedPropertiesIds);
364
- return (h(Host, { class: "gx-ide-component" }, h("div", { class: "gx-ide-main-wrapper" }, h("gx-ide-container", { noContentPadding: true, noHeadingPadding: true, headingPaddingTop: true, containerTitle: this._componentLocale.componentName, slimmerFooter: config.gxIdeContainer.slimmerFooter }, h("header", { slot: "header", class: "header" }, h("div", { class: "header__top" }, h("gx-ide-directory-selector", { class: { "select-file-input": true }, value: this.exportFilePathName, part: "xpz-file", label: this._componentLocale.header.exportFileName, ref: el => (this.fileNameEl = el), selectDirectoryCallback: this.exportFileDirectoryCallback }), h("gxg-button-group", { class: "export-cancel-buttons-group", "default-selected-btn-id": "responsive-tablet-btn" }, h("button", { id: "export-kb-btn", part: "export-btn", onClick: this.exportCallbackHandler, disabled: this.noObjects }, this._componentLocale.header.exportButton), h("button", { id: "cancel-kb-export-btn", part: "cancel-button", onClick: this.cancelCallbackHandler, disabled: this.noObjects || this.exportingIsInProcess }, this._componentLocale.header.cancelButton)), h("gxg-button", { type: "secondary-icon-only", icon: "gemini-tools/settings", part: "select-kb-btn", class: { "options-btn": true }, onClick: this.optionsCallbackHandler }, this._componentLocale.header.optionsButton)), h("div", { class: "header__bottom" }, h("div", { class: { "checkboxes-wrapper": true } }, h("gxg-form-checkbox", { label: this._componentLocale.main.addKnowledgeBaseDescription, onChange: this.addKBPropertiesCallbackHandler, part: "add-kb-checkbox" }), h("gxg-form-checkbox", { label: this._componentLocale.main.exportAll, part: "export-all-checkbox", ref: el => (this.exportAllCheckboxEl =
381
+ console.log("this.noObjects", this.noObjects);
382
+ console.log("this.exportingIsInProcess", this.exportingIsInProcess);
383
+ return (h(Host, { class: "gx-ide-component" }, h("div", { class: "gx-ide-main-wrapper" }, h("gx-ide-container", { noContentPadding: true, noHeadingPadding: true, headingPaddingTop: true, containerTitle: this._componentLocale.componentName, slimmerFooter: config.gxIdeContainer.slimmerFooter }, h("header", { slot: "header", class: "header" }, h("div", { class: "header__top" }, h("gx-ide-directory-selector", { class: { "select-file-input": true }, value: this.exportFilePathName, part: "xpz-file", label: this._componentLocale.header.exportFileName, ref: el => (this.fileNameEl = el), selectDirectoryCallback: this.exportFileDirectoryCallback }), h("gxg-button-group", { class: "export-cancel-buttons-group" }, h("button", { id: "export-kb-btn", part: "export-btn", onClick: this.exportCallbackHandler, disabled: this.noObjects }, this._componentLocale.header.exportButton), h("button", { id: "cancel-kb-export-btn", part: "cancel-button", onClick: this.cancelCallbackHandler, disabled: !this.exportingIsInProcess || this.noObjects }, this._componentLocale.header.cancelButton)), h("gxg-button", { type: "secondary-icon-only", icon: "gemini-tools/settings", part: "select-kb-btn", class: { "options-btn": true }, onClick: this.optionsCallbackHandler }, this._componentLocale.header.optionsButton)), h("div", { class: "header__bottom" }, h("div", { class: { "checkboxes-wrapper": true } }, h("gxg-form-checkbox", { label: this._componentLocale.main.addKnowledgeBaseDescription, onChange: this.addKBPropertiesCallbackHandler, part: "add-kb-checkbox" }), h("gxg-form-checkbox", { label: this._componentLocale.main.exportAll, part: "export-all-checkbox", ref: el => (this.exportAllCheckboxEl =
365
384
  el), disabled: this.noObjects, onChange: this.exportAllChangedHandler })))), h("div", { class: {
366
385
  "tree-container": true,
367
386
  "tree-container--empty": this.noObjects ||
@@ -369,18 +388,18 @@ const GxIdeKbManagerExport$1 = /*@__PURE__*/ proxyCustomElement(class extends HT
369
388
  this.exportAllIsChecked &&
370
389
  !this.addKbPropertiesIsChecked)
371
390
  // "tree-container--export-all": this.exportAllIsChecked
372
- } }, this.evaluateContentToDisplay()), h("gxg-text", { type: "button-like", part: "export-button", slot: "footer-start", onClick: this.clearButtonHandler }, this._componentLocale.footer.clearButton), h("div", { class: { "footer-right-wrapper": true }, slot: "footer-end" }, h("gxg-button", { onClick: this.addReferencesCallbackHandler, type: "outlined-text-icon", icon: "general/references", part: "export-button", class: { "cancel-btn": true }, disabled: this.exportAllIsChecked }, this._componentLocale.footer.referencesButton), h("gxg-button", { type: "primary-text-icon", icon: "menus/new-object", part: "export-button", class: { "cancel-btn": true }, onClick: this.addObjectsCallbackHandler, disabled: this.exportAllIsChecked }, this._componentLocale.footer.addButton))))));
391
+ } }, this.evaluateContentToDisplay()), h("gxg-text", { type: "button-like", part: "export-button", slot: "footer-start", onClick: this.clearButtonHandler, disabled: this.clearButtonDisabledConditions() }, this._componentLocale.footer.clearButton), h("div", { class: { "footer-right-wrapper": true }, slot: "footer-end" }, h("gxg-button", { onClick: this.addReferencesCallbackHandler, type: "outlined-text-icon", icon: "general/references", part: "export-button", class: { "cancel-btn": true }, disabled: this.exportAllIsChecked }, this._componentLocale.footer.referencesButton), h("gxg-button", { type: "primary-text-icon", icon: "menus/new-object", part: "export-button", class: { "cancel-btn": true }, onClick: this.addObjectsCallbackHandler, disabled: this.exportAllIsChecked }, this._componentLocale.footer.addButton)))), this.loader ? (h("gxg-ide-loader", { cancelLabel: this._componentLocale.loader.cancelLabel, container: this.el, loaderTitle: this._componentLocale.loader.title, ref: el => (this.loaderEl = el), cancelCallback: this.loaderCancelCallbackHandler })) : null));
373
392
  }
374
393
  static get assetsDirs() { return ["gx-ide-assets/kb-manager-export"]; }
375
394
  get el() { return this; }
376
395
  static get watchers() { return {
377
396
  "treeModel": ["watchTreeModelHandler"],
378
- "dummyInitialTree": ["watchDummyInitialTreeHandler"],
379
- "objectTypes": ["watchObjectTypeslHandler"]
397
+ "exportingIsInProcess": ["watchExportingIsInProcessHandler"],
398
+ "objectTypes": ["watchObjectTypesHandler"]
380
399
  }; }
381
400
  static get style() { return kbManagerExportCss; }
382
401
  }, [0, "gx-ide-kb-manager-export", {
383
- "dummyInitialTree": [16],
402
+ "loader": [4],
384
403
  "kbPropertiesTypes": [16],
385
404
  "objectTypes": [16],
386
405
  "exportFileDirectoryCallback": [16],
@@ -391,18 +410,19 @@ const GxIdeKbManagerExport$1 = /*@__PURE__*/ proxyCustomElement(class extends HT
391
410
  "exportCallback": [16],
392
411
  "cancelCallback": [16],
393
412
  "exportAllIsChecked": [32],
394
- "exportingIsInProcess": [32],
395
413
  "addKbPropertiesIsChecked": [32],
414
+ "checkedObjectsIds": [32],
396
415
  "fileName": [32],
397
416
  "exportFilePathName": [32],
398
417
  "noObjects": [32],
399
- "treeModel": [32]
418
+ "treeModel": [32],
419
+ "exportingIsInProcess": [32]
400
420
  }]);
401
421
  function defineCustomElement$1() {
402
422
  if (typeof customElements === "undefined") {
403
423
  return;
404
424
  }
405
- const components = ["gx-ide-kb-manager-export", "ch-checkbox", "ch-icon", "ch-tree-view", "ch-tree-view-item", "ch-tree-view-render", "gx-ide-container", "gx-ide-directory-selector", "gx-ide-title", "gxg-button", "gxg-button-group", "gxg-form-checkbox", "gxg-form-text", "gxg-icon", "gxg-label", "gxg-text", "gxg-title", "gxg-tooltip", "gxg-tree-view"];
425
+ const components = ["gx-ide-kb-manager-export", "ch-checkbox", "ch-icon", "ch-tree-view", "ch-tree-view-item", "ch-tree-view-render", "ch-window", "ch-window-close", "gx-ide-container", "gx-ide-directory-selector", "gx-ide-title", "gxg-button", "gxg-button-group", "gxg-form-checkbox", "gxg-form-text", "gxg-icon", "gxg-ide-loader", "gxg-label", "gxg-text", "gxg-title", "gxg-tooltip", "gxg-tree-view"];
406
426
  components.forEach(tagName => { switch (tagName) {
407
427
  case "gx-ide-kb-manager-export":
408
428
  if (!customElements.get(tagName)) {
@@ -411,65 +431,80 @@ function defineCustomElement$1() {
411
431
  break;
412
432
  case "ch-checkbox":
413
433
  if (!customElements.get(tagName)) {
414
- defineCustomElement$j();
434
+ defineCustomElement$m();
415
435
  }
416
436
  break;
417
437
  case "ch-icon":
418
438
  if (!customElements.get(tagName)) {
419
- defineCustomElement$i();
439
+ defineCustomElement$l();
420
440
  }
421
441
  break;
422
442
  case "ch-tree-view":
423
443
  if (!customElements.get(tagName)) {
424
- defineCustomElement$h();
444
+ defineCustomElement$k();
425
445
  }
426
446
  break;
427
447
  case "ch-tree-view-item":
428
448
  if (!customElements.get(tagName)) {
429
- defineCustomElement$g();
449
+ defineCustomElement$j();
430
450
  }
431
451
  break;
432
452
  case "ch-tree-view-render":
433
453
  if (!customElements.get(tagName)) {
434
- defineCustomElement$f();
454
+ defineCustomElement$i();
455
+ }
456
+ break;
457
+ case "ch-window":
458
+ if (!customElements.get(tagName)) {
459
+ defineCustomElement$h();
460
+ }
461
+ break;
462
+ case "ch-window-close":
463
+ if (!customElements.get(tagName)) {
464
+ defineCustomElement$g();
435
465
  }
436
466
  break;
437
467
  case "gx-ide-container":
438
468
  if (!customElements.get(tagName)) {
439
- defineCustomElement$e();
469
+ defineCustomElement$f();
440
470
  }
441
471
  break;
442
472
  case "gx-ide-directory-selector":
443
473
  if (!customElements.get(tagName)) {
444
- defineCustomElement$d();
474
+ defineCustomElement$e();
445
475
  }
446
476
  break;
447
477
  case "gx-ide-title":
448
478
  if (!customElements.get(tagName)) {
449
- defineCustomElement$c();
479
+ defineCustomElement$d();
450
480
  }
451
481
  break;
452
482
  case "gxg-button":
453
483
  if (!customElements.get(tagName)) {
454
- defineCustomElement$b();
484
+ defineCustomElement$c();
455
485
  }
456
486
  break;
457
487
  case "gxg-button-group":
458
488
  if (!customElements.get(tagName)) {
459
- defineCustomElement$a();
489
+ defineCustomElement$b();
460
490
  }
461
491
  break;
462
492
  case "gxg-form-checkbox":
463
493
  if (!customElements.get(tagName)) {
464
- defineCustomElement$9();
494
+ defineCustomElement$a();
465
495
  }
466
496
  break;
467
497
  case "gxg-form-text":
468
498
  if (!customElements.get(tagName)) {
469
- defineCustomElement$8();
499
+ defineCustomElement$9();
470
500
  }
471
501
  break;
472
502
  case "gxg-icon":
503
+ if (!customElements.get(tagName)) {
504
+ defineCustomElement$8();
505
+ }
506
+ break;
507
+ case "gxg-ide-loader":
473
508
  if (!customElements.get(tagName)) {
474
509
  defineCustomElement$7();
475
510
  }