@genexus/genexus-ide-ui 3.0.2 → 3.1.1

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 (100) hide show
  1. package/dist/cjs/genexus-ide-ui.cjs.js +1 -1
  2. package/dist/cjs/gx-ide-file-item.cjs.entry.js +21 -2
  3. package/dist/cjs/gx-ide-file-item.cjs.entry.js.map +1 -1
  4. package/dist/cjs/gx-ide-file-uploader.cjs.entry.js +11 -8
  5. package/dist/cjs/gx-ide-file-uploader.cjs.entry.js.map +1 -1
  6. package/dist/cjs/gx-ide-launchpad.cjs.entry.js +4 -16
  7. package/dist/cjs/gx-ide-launchpad.cjs.entry.js.map +1 -1
  8. package/dist/cjs/gx-ide-multi-select.cjs.entry.js +113 -0
  9. package/dist/cjs/gx-ide-multi-select.cjs.entry.js.map +1 -0
  10. package/dist/cjs/gx-ide-search.cjs.entry.js +171 -0
  11. package/dist/cjs/gx-ide-search.cjs.entry.js.map +1 -0
  12. package/dist/cjs/gx-ide-ww-files.cjs.entry.js +3 -4
  13. package/dist/cjs/gx-ide-ww-files.cjs.entry.js.map +1 -1
  14. package/dist/cjs/loader.cjs.js +1 -1
  15. package/dist/collection/collection-manifest.json +2 -0
  16. package/dist/collection/components/_helpers/multi-select/gx-ide-multi-select.css +193 -0
  17. package/dist/collection/components/_helpers/multi-select/gx-ide-multi-select.js +209 -0
  18. package/dist/collection/components/_helpers/multi-select/gx-ide-multi-select.js.map +1 -0
  19. package/dist/collection/components/file-uploader/file-item/file-item.css +23 -28
  20. package/dist/collection/components/file-uploader/file-item/file-item.js +37 -1
  21. package/dist/collection/components/file-uploader/file-item/file-item.js.map +1 -1
  22. package/dist/collection/components/file-uploader/file-uploader.css +11 -22
  23. package/dist/collection/components/file-uploader/file-uploader.js +10 -7
  24. package/dist/collection/components/file-uploader/file-uploader.js.map +1 -1
  25. package/dist/collection/components/file-uploader/gx-ide-assets/file-uploader/langs/file-uploader.lang.en.json +7 -3
  26. package/dist/collection/components/file-uploader/gx-ide-assets/file-uploader/langs/file-uploader.lang.ja.json +7 -3
  27. package/dist/collection/components/file-uploader/gx-ide-assets/file-uploader/langs/file-uploader.lang.zh.json +8 -3
  28. package/dist/collection/components/launchpad/root/gx-ide-assets/launchpad/shortcuts.json +1 -26
  29. package/dist/collection/components/launchpad/root/launchpad.js +5 -42
  30. package/dist/collection/components/launchpad/root/launchpad.js.map +1 -1
  31. package/dist/collection/components/search/gx-ide-assets/search/langs/search.lang.en.json +37 -0
  32. package/dist/collection/components/search/gx-ide-assets/search/langs/search.lang.ja.json +37 -0
  33. package/dist/collection/components/search/gx-ide-assets/search/langs/search.lang.zh.json +37 -0
  34. package/dist/collection/components/search/search.css +44 -0
  35. package/dist/collection/components/search/search.js +275 -0
  36. package/dist/collection/components/search/search.js.map +1 -0
  37. package/dist/collection/components/ww-files/ww-files.js +3 -4
  38. package/dist/collection/components/ww-files/ww-files.js.map +1 -1
  39. package/dist/collection/testing/locale.e2e.js +4 -1
  40. package/dist/collection/testing/locale.e2e.js.map +1 -1
  41. package/dist/components/file-item.js +22 -2
  42. package/dist/components/file-item.js.map +1 -1
  43. package/dist/components/gx-ide-file-uploader.js +11 -8
  44. package/dist/components/gx-ide-file-uploader.js.map +1 -1
  45. package/dist/components/gx-ide-launchpad.js +6 -19
  46. package/dist/components/gx-ide-launchpad.js.map +1 -1
  47. package/dist/components/gx-ide-multi-select.d.ts +11 -0
  48. package/dist/components/gx-ide-multi-select.js +132 -0
  49. package/dist/components/gx-ide-multi-select.js.map +1 -0
  50. package/dist/components/gx-ide-search.d.ts +11 -0
  51. package/dist/components/gx-ide-search.js +206 -0
  52. package/dist/components/gx-ide-search.js.map +1 -0
  53. package/dist/components/gx-ide-ww-files.js +3 -4
  54. package/dist/components/gx-ide-ww-files.js.map +1 -1
  55. package/dist/esm/genexus-ide-ui.js +1 -1
  56. package/dist/esm/gx-ide-file-item.entry.js +21 -2
  57. package/dist/esm/gx-ide-file-item.entry.js.map +1 -1
  58. package/dist/esm/gx-ide-file-uploader.entry.js +11 -8
  59. package/dist/esm/gx-ide-file-uploader.entry.js.map +1 -1
  60. package/dist/esm/gx-ide-launchpad.entry.js +5 -17
  61. package/dist/esm/gx-ide-launchpad.entry.js.map +1 -1
  62. package/dist/esm/gx-ide-multi-select.entry.js +109 -0
  63. package/dist/esm/gx-ide-multi-select.entry.js.map +1 -0
  64. package/dist/esm/gx-ide-search.entry.js +167 -0
  65. package/dist/esm/gx-ide-search.entry.js.map +1 -0
  66. package/dist/esm/gx-ide-ww-files.entry.js +3 -4
  67. package/dist/esm/gx-ide-ww-files.entry.js.map +1 -1
  68. package/dist/esm/loader.js +1 -1
  69. package/dist/genexus-ide-ui/genexus-ide-ui.esm.js +1 -1
  70. package/dist/genexus-ide-ui/genexus-ide-ui.esm.js.map +1 -1
  71. package/dist/genexus-ide-ui/gx-ide-assets/file-uploader/langs/file-uploader.lang.en.json +7 -3
  72. package/dist/genexus-ide-ui/gx-ide-assets/file-uploader/langs/file-uploader.lang.ja.json +7 -3
  73. package/dist/genexus-ide-ui/gx-ide-assets/file-uploader/langs/file-uploader.lang.zh.json +8 -3
  74. package/dist/genexus-ide-ui/gx-ide-assets/launchpad/shortcuts.json +1 -26
  75. package/dist/genexus-ide-ui/gx-ide-assets/search/langs/search.lang.en.json +37 -0
  76. package/dist/genexus-ide-ui/gx-ide-assets/search/langs/search.lang.ja.json +37 -0
  77. package/dist/genexus-ide-ui/gx-ide-assets/search/langs/search.lang.zh.json +37 -0
  78. package/dist/genexus-ide-ui/p-0745a565.entry.js +152 -0
  79. package/dist/genexus-ide-ui/p-0745a565.entry.js.map +1 -0
  80. package/dist/genexus-ide-ui/{p-6246204f.entry.js → p-25e749c7.entry.js} +44 -57
  81. package/dist/genexus-ide-ui/p-25e749c7.entry.js.map +1 -0
  82. package/dist/genexus-ide-ui/{p-50dae653.entry.js → p-7bdeae77.entry.js} +211 -213
  83. package/dist/genexus-ide-ui/p-7bdeae77.entry.js.map +1 -0
  84. package/dist/genexus-ide-ui/p-8b5c826b.entry.js +212 -0
  85. package/dist/genexus-ide-ui/p-8b5c826b.entry.js.map +1 -0
  86. package/dist/genexus-ide-ui/p-c460c9e7.entry.js +187 -0
  87. package/dist/genexus-ide-ui/p-c460c9e7.entry.js.map +1 -0
  88. package/dist/genexus-ide-ui/{p-aad714a5.entry.js → p-e2b88bea.entry.js} +70 -67
  89. package/dist/genexus-ide-ui/p-e2b88bea.entry.js.map +1 -0
  90. package/dist/types/components/_helpers/multi-select/gx-ide-multi-select.d.ts +29 -0
  91. package/dist/types/components/file-uploader/file-item/file-item.d.ts +2 -0
  92. package/dist/types/components/launchpad/root/launchpad.d.ts +0 -4
  93. package/dist/types/components/search/search.d.ts +60 -0
  94. package/dist/types/components.d.ts +121 -4
  95. package/package.json +1 -1
  96. package/dist/genexus-ide-ui/p-50dae653.entry.js.map +0 -1
  97. package/dist/genexus-ide-ui/p-6246204f.entry.js.map +0 -1
  98. package/dist/genexus-ide-ui/p-aad714a5.entry.js.map +0 -1
  99. package/dist/genexus-ide-ui/p-f3c3e830.entry.js +0 -163
  100. package/dist/genexus-ide-ui/p-f3c3e830.entry.js.map +0 -1
@@ -41,6 +41,7 @@
41
41
  "components/_helpers/progress-bar/progress-bar.js",
42
42
  "components/references/references.js",
43
43
  "components/restore-version/restore-version.js",
44
+ "components/search/search.js",
44
45
  "components/select-kb-items/select-kb-items.js",
45
46
  "components/select-user-team/select-user-team.js",
46
47
  "components/team-dev/share-kb/share-kb.js",
@@ -63,6 +64,7 @@
63
64
  "components/ww-images/ww-images.js",
64
65
  "components/_helpers/empty-state/gx-ide-empty-state.js",
65
66
  "components/_helpers/entity-selector/entity-selector.js",
67
+ "components/_helpers/multi-select/gx-ide-multi-select.js",
66
68
  "components/_helpers/status-buttons/gx-ide-status-buttons.js",
67
69
  "components/_test/test.js",
68
70
  "components/breadcrumb/breadcrumb.js",
@@ -0,0 +1,193 @@
1
+ /* - - - - - - - - - - - - - - - - -
2
+ New classes for Chameleon + Mercury
3
+ - - - - - - - - - - - - - - - - - */
4
+ :host {
5
+ display: grid;
6
+ block-size: 100%;
7
+ }
8
+
9
+ .opacity-0 {
10
+ opacity: 0;
11
+ }
12
+
13
+ .gxi-hidden {
14
+ display: none !important;
15
+ }
16
+
17
+ .align-center {
18
+ display: flex;
19
+ align-items: center;
20
+ }
21
+
22
+ .align-end {
23
+ display: flex;
24
+ align-items: end;
25
+ }
26
+
27
+ .overflow-auto {
28
+ overflow: auto;
29
+ }
30
+
31
+ /*All components Host should have this class set. !important is set on every rule, since this styles could be overridden by the host user, since they are applied on the host component*/
32
+ :host(.gx-ide-component) {
33
+ height: 100% !important;
34
+ display: flex !important;
35
+ flex-direction: column !important;
36
+ }
37
+
38
+ /* Main wrapper (should be the first element inside the host. Everything should be inside .gx-ide-main-wrapper) */
39
+ .gx-ide-main-wrapper {
40
+ color: var(--gx-ide-component-text-color);
41
+ font-weight: var(--font-style-regular);
42
+ font-size: var(--font-size-body-m);
43
+ font-family: var(--font-family-body);
44
+ height: 100%;
45
+ display: flex;
46
+ flex-direction: column;
47
+ flex-grow: 1;
48
+ box-sizing: border-box;
49
+ }
50
+
51
+ /* - - - - - - - - - - - - - - - - - -
52
+ New : For Mercury
53
+ - - - - - - - - - - - - - - - - - - */
54
+ .buttons-container {
55
+ display: flex;
56
+ gap: var(--spacing-gap-m);
57
+ }
58
+
59
+ /* - - - - - - - - - - - - - - - - - -
60
+ Pill
61
+ - - - - - - - - - - - - - - - - - - */
62
+ .giu-static-pill-icon-and-text, .giu-static-pill {
63
+ background-color: var(--elevation-background-color, var(--color-accent-surface-elevation-1));
64
+ padding-inline: var(--spacing-padding-m);
65
+ color: var(--color-text-neutral-default);
66
+ font-size: var(--font-size-body-s);
67
+ line-height: var(--line-height-relaxed);
68
+ font-weight: var(--font-style-regular);
69
+ border-radius: 4px;
70
+ min-block-size: 25px;
71
+ display: inline-grid;
72
+ align-items: center;
73
+ pointer-events: none;
74
+ inline-size: max-content;
75
+ }
76
+
77
+ .giu-static-pill-icon-and-text {
78
+ display: inline-grid;
79
+ grid-auto-flow: column;
80
+ grid-auto-columns: max-content;
81
+ gap: var(--spacing-gap-m);
82
+ }
83
+
84
+ /* - - - - - - - - - - - - - - - - - -
85
+ Tab
86
+ - - - - - - - - - - - - - - - - - - */
87
+ .tab-full-width-buttons::part(tab-list block-start),
88
+ .tab-full-width-buttons::part(tab-list block-end) {
89
+ grid-auto-columns: 1fr;
90
+ }
91
+
92
+ .tab-full-width-buttons::part(tab block-start) {
93
+ justify-content: center;
94
+ }
95
+
96
+ /* - - - - - - - - - - - - - - - - - -
97
+ Tree
98
+ - - - - - - - - - - - - - - - - - - */
99
+ /* Now the tree-view warning icon, looks gray on disabled items. This is a workaround to change the color to the enabled color, until this is resolved on Mercury. The solution might be to add a colorType for warning, error or success, that is static, meanning, it looks alwaws as "enabled", even if it is disabled. */
100
+ .tree-view::part(item__header) {
101
+ --icon__system_warning_warning--disabled: var(
102
+ --icon__system_warning_warning--enabled
103
+ );
104
+ }
105
+
106
+ /* - - - - - - - - - - - - - - - - - -
107
+ Tabular Grid
108
+ - - - - - - - - - - - - - - - - - - */
109
+ .tabular-grid {
110
+ --focus-outline-width: 1px;
111
+ }
112
+
113
+ ch-popover {
114
+ background-color: var(--color-accent-surface-elevation-1);
115
+ border: 1px solid var(--color-border-surface-on-surface);
116
+ border-radius: var(--border-radius-s);
117
+ box-shadow: var(--shadow-elevation-2);
118
+ }
119
+ ch-popover > div {
120
+ display: flex;
121
+ flex-direction: column;
122
+ gap: 0;
123
+ padding: var(--spacing-padding-m);
124
+ max-block-size: 300px;
125
+ overflow-y: auto;
126
+ }
127
+
128
+ .checkbox-item {
129
+ display: flex;
130
+ inline-size: 100%;
131
+ padding-block: var(--spacing-padding-xs);
132
+ padding-inline: var(--spacing-padding-m);
133
+ cursor: pointer;
134
+ border-radius: var(--border-radius-s);
135
+ }
136
+ .checkbox-item:hover {
137
+ background-color: var(--color-accent-item-selected);
138
+ }
139
+ .checkbox-item::part(checkbox) {
140
+ inline-size: 100%;
141
+ }
142
+ .checkbox-item::part(label) {
143
+ inline-size: 100%;
144
+ cursor: pointer;
145
+ flex: 1;
146
+ }
147
+
148
+ .multi-select__button {
149
+ display: flex;
150
+ align-items: center;
151
+ gap: var(--spacing-gap-s);
152
+ overflow: hidden;
153
+ }
154
+ .multi-select__chevron {
155
+ flex-shrink: 0;
156
+ margin-inline-start: auto;
157
+ }
158
+ .multi-select__placeholder {
159
+ flex: 1;
160
+ overflow: hidden;
161
+ text-overflow: ellipsis;
162
+ white-space: nowrap;
163
+ }
164
+ .multi-select__items {
165
+ display: flex;
166
+ flex-wrap: wrap;
167
+ gap: var(--spacing-gap-xs);
168
+ flex: 1;
169
+ align-items: center;
170
+ }
171
+ .multi-select__item {
172
+ display: inline-flex;
173
+ align-items: center;
174
+ gap: var(--spacing-gap-xs);
175
+ padding: 2px var(--spacing-padding-xs);
176
+ background-color: var(--color-accent-item-pressed);
177
+ border-radius: var(--border-radius-s);
178
+ }
179
+ .multi-select__item button {
180
+ padding: 0;
181
+ }
182
+ .multi-select__caption {
183
+ color: var(--color-text-neutral-on-disabled);
184
+ }
185
+ .multi-select__close {
186
+ padding: 0;
187
+ margin: 0;
188
+ }
189
+
190
+ ch-checkbox.checkbox::part(label) {
191
+ font-weight: var(--font-style-regular);
192
+ color: var(--color-text-neutral-default);
193
+ }
@@ -0,0 +1,209 @@
1
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
2
+ if (kind === "a" && !f)
3
+ throw new TypeError("Private accessor was defined without a getter");
4
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver))
5
+ throw new TypeError("Cannot read private member from an object whose class did not declare it");
6
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
7
+ };
8
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
9
+ if (kind === "m")
10
+ throw new TypeError("Private method is not writable");
11
+ if (kind === "a" && !f)
12
+ throw new TypeError("Private accessor was defined without a setter");
13
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver))
14
+ throw new TypeError("Cannot write private member to an object whose class did not declare it");
15
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
16
+ };
17
+ var _GxIdeMultiSelect_multiButtonEl, _GxIdeMultiSelect_popoverEl, _GxIdeMultiSelect_togglePopover, _GxIdeMultiSelect_checkboxChangeHandler, _GxIdeMultiSelect_removeSelectedItemHandler, _GxIdeMultiSelect_isItemSelected, _GxIdeMultiSelect_renderSelectedItems;
18
+ import { Host, h } from "@stencil/core";
19
+ import { getIconPath } from "@genexus/mercury";
20
+ const CSS_BUNDLES = [
21
+ "resets/box-sizing",
22
+ "components/button",
23
+ "components/icon",
24
+ "components/checkbox",
25
+ "utils/typography",
26
+ "utils/spacing",
27
+ "chameleon/scrollbar",
28
+ "components/combo-box"
29
+ ];
30
+ const CHEVRON_DOWN_ICON = getIconPath({
31
+ category: "navigation",
32
+ name: "chevron-down",
33
+ colorType: "on-interactive"
34
+ });
35
+ const CLOSE_ICON = getIconPath({
36
+ category: "system",
37
+ name: "close",
38
+ colorType: "on-interactive"
39
+ });
40
+ export class GxIdeMultiSelect {
41
+ constructor() {
42
+ _GxIdeMultiSelect_multiButtonEl.set(this, void 0);
43
+ _GxIdeMultiSelect_popoverEl.set(this, void 0);
44
+ _GxIdeMultiSelect_togglePopover.set(this, () => {
45
+ if (!this.disabled) {
46
+ this.showPopover = !this.showPopover;
47
+ }
48
+ });
49
+ _GxIdeMultiSelect_checkboxChangeHandler.set(this, (optionValue, event) => {
50
+ const target = event.target;
51
+ const isChecked = target.value === target.checkedValue;
52
+ let newValue;
53
+ if (isChecked) {
54
+ newValue = [...this.value, optionValue];
55
+ }
56
+ else {
57
+ newValue = this.value.filter(val => val !== optionValue);
58
+ }
59
+ this.gxSelectionChange.emit(newValue);
60
+ });
61
+ _GxIdeMultiSelect_removeSelectedItemHandler.set(this, (itemValue) => {
62
+ const newValue = this.value.filter(val => val !== itemValue);
63
+ this.gxSelectionChange.emit(newValue);
64
+ });
65
+ _GxIdeMultiSelect_isItemSelected.set(this, (itemValue) => {
66
+ return this.value.includes(itemValue);
67
+ });
68
+ _GxIdeMultiSelect_renderSelectedItems.set(this, () => {
69
+ if (this.value.length === 0) {
70
+ return (h("span", { class: "multi-select__placeholder body-italic-m" }, this.placeholder));
71
+ }
72
+ const selectedOptions = this.model.filter(opt => this.value.includes(opt.value));
73
+ return (h("div", { class: "multi-select__items" }, selectedOptions.map(item => (h("div", { class: "multi-select__item", key: item.value }, h("span", { class: "multi-select__caption body-regular-s" }, item.caption), h("button", { type: "button", class: "button-tertiary button-icon-only multi-select__close", onClick: e => {
74
+ e.stopPropagation();
75
+ e.preventDefault();
76
+ __classPrivateFieldGet(this, _GxIdeMultiSelect_removeSelectedItemHandler, "f").call(this, item.value);
77
+ }, "aria-label": `Remove ${item.caption}` }, h("ch-image", { class: "icon-xs", src: CLOSE_ICON, type: "mask" })))))));
78
+ });
79
+ this.showPopover = false;
80
+ this.model = [];
81
+ this.value = [];
82
+ this.placeholder = "Select options";
83
+ this.disabled = false;
84
+ }
85
+ componentDidLoad() {
86
+ if (__classPrivateFieldGet(this, _GxIdeMultiSelect_popoverEl, "f") && __classPrivateFieldGet(this, _GxIdeMultiSelect_multiButtonEl, "f")) {
87
+ __classPrivateFieldGet(this, _GxIdeMultiSelect_popoverEl, "f").actionElement = __classPrivateFieldGet(this, _GxIdeMultiSelect_multiButtonEl, "f");
88
+ }
89
+ }
90
+ render() {
91
+ return (h(Host, null, h("ch-theme", { model: CSS_BUNDLES }), h("button", { class: "combo-box multi-select__button", type: "button", ref: (el) => (__classPrivateFieldSet(this, _GxIdeMultiSelect_multiButtonEl, el, "f")), onClick: __classPrivateFieldGet(this, _GxIdeMultiSelect_togglePopover, "f"), disabled: this.disabled }, __classPrivateFieldGet(this, _GxIdeMultiSelect_renderSelectedItems, "f").call(this), h("ch-image", { class: "icon-m multi-select__chevron", src: CHEVRON_DOWN_ICON, type: "mask" })), h("ch-popover", { ref: (el) => (__classPrivateFieldSet(this, _GxIdeMultiSelect_popoverEl, el, "f")), closeOnClickOutside: true, show: this.showPopover, blockAlign: "outside-end", inlineAlign: "inside-end", inlineSizeMatch: "action-element", class: "scrollable" }, h("div", null, this.model.map(option => (h("ch-checkbox", { class: "checkbox checkbox-item", caption: option.caption, checkedValue: "true", value: __classPrivateFieldGet(this, _GxIdeMultiSelect_isItemSelected, "f").call(this, option.value) ? "true" : "false", startImgSrc: option.startImgSrc, onInput: e => __classPrivateFieldGet(this, _GxIdeMultiSelect_checkboxChangeHandler, "f").call(this, option.value, e) })))))));
92
+ }
93
+ static get is() { return "gx-ide-multi-select"; }
94
+ static get encapsulation() { return "shadow"; }
95
+ static get originalStyleUrls() {
96
+ return {
97
+ "$": ["gx-ide-multi-select.scss"]
98
+ };
99
+ }
100
+ static get styleUrls() {
101
+ return {
102
+ "$": ["gx-ide-multi-select.css"]
103
+ };
104
+ }
105
+ static get properties() {
106
+ return {
107
+ "model": {
108
+ "type": "unknown",
109
+ "mutable": false,
110
+ "complexType": {
111
+ "original": "ComboBoxModel",
112
+ "resolved": "ComboBoxItemModel[]",
113
+ "references": {
114
+ "ComboBoxModel": {
115
+ "location": "import",
116
+ "path": "@genexus/chameleon-controls-library",
117
+ "id": ""
118
+ }
119
+ }
120
+ },
121
+ "required": false,
122
+ "optional": false,
123
+ "docs": {
124
+ "tags": [],
125
+ "text": "Model with available options to select from"
126
+ },
127
+ "defaultValue": "[]"
128
+ },
129
+ "value": {
130
+ "type": "unknown",
131
+ "mutable": false,
132
+ "complexType": {
133
+ "original": "string[]",
134
+ "resolved": "string[]",
135
+ "references": {}
136
+ },
137
+ "required": false,
138
+ "optional": false,
139
+ "docs": {
140
+ "tags": [],
141
+ "text": "Currently selected item values"
142
+ },
143
+ "defaultValue": "[]"
144
+ },
145
+ "placeholder": {
146
+ "type": "string",
147
+ "mutable": false,
148
+ "complexType": {
149
+ "original": "string",
150
+ "resolved": "string",
151
+ "references": {}
152
+ },
153
+ "required": false,
154
+ "optional": false,
155
+ "docs": {
156
+ "tags": [],
157
+ "text": "Placeholder text when no items are selected"
158
+ },
159
+ "attribute": "placeholder",
160
+ "reflect": false,
161
+ "defaultValue": "\"Select options\""
162
+ },
163
+ "disabled": {
164
+ "type": "boolean",
165
+ "mutable": false,
166
+ "complexType": {
167
+ "original": "boolean",
168
+ "resolved": "boolean",
169
+ "references": {}
170
+ },
171
+ "required": false,
172
+ "optional": false,
173
+ "docs": {
174
+ "tags": [],
175
+ "text": "Disabled state"
176
+ },
177
+ "attribute": "disabled",
178
+ "reflect": false,
179
+ "defaultValue": "false"
180
+ }
181
+ };
182
+ }
183
+ static get states() {
184
+ return {
185
+ "showPopover": {}
186
+ };
187
+ }
188
+ static get events() {
189
+ return [{
190
+ "method": "gxSelectionChange",
191
+ "name": "gxSelectionChange",
192
+ "bubbles": true,
193
+ "cancelable": true,
194
+ "composed": true,
195
+ "docs": {
196
+ "tags": [],
197
+ "text": "Emitted when the selection changes"
198
+ },
199
+ "complexType": {
200
+ "original": "string[]",
201
+ "resolved": "string[]",
202
+ "references": {}
203
+ }
204
+ }];
205
+ }
206
+ static get elementRef() { return "el"; }
207
+ }
208
+ _GxIdeMultiSelect_multiButtonEl = new WeakMap(), _GxIdeMultiSelect_popoverEl = new WeakMap(), _GxIdeMultiSelect_togglePopover = new WeakMap(), _GxIdeMultiSelect_checkboxChangeHandler = new WeakMap(), _GxIdeMultiSelect_removeSelectedItemHandler = new WeakMap(), _GxIdeMultiSelect_isItemSelected = new WeakMap(), _GxIdeMultiSelect_renderSelectedItems = new WeakMap();
209
+ //# sourceMappingURL=gx-ide-multi-select.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gx-ide-multi-select.js","sourceRoot":"","sources":["../../../../src/components/_helpers/multi-select/gx-ide-multi-select.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\n Component,\n Host,\n h,\n Prop,\n State,\n Element,\n Event,\n EventEmitter\n} from \"@stencil/core\";\nimport { getIconPath, MercuryBundles } from \"@genexus/mercury\";\nimport { ComboBoxModel } from \"@genexus/chameleon-controls-library\";\n\nconst CSS_BUNDLES: MercuryBundles = [\n \"resets/box-sizing\",\n \"components/button\",\n \"components/icon\",\n \"components/checkbox\",\n \"utils/typography\",\n \"utils/spacing\",\n \"chameleon/scrollbar\",\n \"components/combo-box\"\n];\n\nconst CHEVRON_DOWN_ICON = getIconPath({\n category: \"navigation\",\n name: \"chevron-down\",\n colorType: \"on-interactive\"\n});\n\nconst CLOSE_ICON = getIconPath({\n category: \"system\",\n name: \"close\",\n colorType: \"on-interactive\"\n});\n\n@Component({\n tag: \"gx-ide-multi-select\",\n styleUrl: \"gx-ide-multi-select.scss\",\n shadow: true\n})\nexport class GxIdeMultiSelect {\n #multiButtonEl: HTMLButtonElement;\n #popoverEl: HTMLChPopoverElement;\n\n @Element() el: HTMLGxIdeMultiSelectElement;\n\n @State() showPopover = false;\n\n /**\n * Model with available options to select from\n */\n @Prop() readonly model: ComboBoxModel = [];\n\n /**\n * Currently selected item values\n */\n @Prop() readonly value: string[] = [];\n\n /**\n * Placeholder text when no items are selected\n */\n @Prop() readonly placeholder: string = \"Select options\";\n\n /**\n * Disabled state\n */\n @Prop() readonly disabled: boolean = false;\n\n /**\n * Emitted when the selection changes\n */\n @Event() gxSelectionChange: EventEmitter<string[]>;\n\n componentDidLoad() {\n if (this.#popoverEl && this.#multiButtonEl) {\n this.#popoverEl.actionElement = this.#multiButtonEl;\n }\n }\n\n #togglePopover = () => {\n if (!this.disabled) {\n this.showPopover = !this.showPopover;\n }\n };\n\n #checkboxChangeHandler = (\n optionValue: string,\n event: CustomEvent | InputEvent\n ) => {\n const target = event.target as HTMLChCheckboxElement;\n const isChecked = target.value === target.checkedValue;\n\n let newValue: string[];\n if (isChecked) {\n newValue = [...this.value, optionValue];\n } else {\n newValue = this.value.filter(val => val !== optionValue);\n }\n\n this.gxSelectionChange.emit(newValue);\n };\n\n #removeSelectedItemHandler = (itemValue: string) => {\n const newValue = this.value.filter(val => val !== itemValue);\n this.gxSelectionChange.emit(newValue);\n };\n\n #isItemSelected = (itemValue: string): boolean => {\n return this.value.includes(itemValue);\n };\n\n #renderSelectedItems = () => {\n if (this.value.length === 0) {\n return (\n <span class=\"multi-select__placeholder body-italic-m\">\n {this.placeholder}\n </span>\n );\n }\n\n const selectedOptions = this.model.filter(opt =>\n this.value.includes(opt.value)\n );\n\n return (\n <div class=\"multi-select__items\">\n {selectedOptions.map(item => (\n <div class=\"multi-select__item\" key={item.value}>\n <span class=\"multi-select__caption body-regular-s\">\n {item.caption}\n </span>\n <button\n type=\"button\"\n class=\"button-tertiary button-icon-only multi-select__close\"\n onClick={e => {\n e.stopPropagation();\n e.preventDefault();\n this.#removeSelectedItemHandler(item.value);\n }}\n aria-label={`Remove ${item.caption}`}\n >\n <ch-image class=\"icon-xs\" src={CLOSE_ICON} type=\"mask\"></ch-image>\n </button>\n </div>\n ))}\n </div>\n );\n };\n\n render() {\n return (\n <Host>\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n\n <button\n class=\"combo-box multi-select__button\"\n type=\"button\"\n ref={(el: HTMLButtonElement) => (this.#multiButtonEl = el)}\n onClick={this.#togglePopover}\n disabled={this.disabled}\n >\n {this.#renderSelectedItems()}\n <ch-image\n class=\"icon-m multi-select__chevron\"\n src={CHEVRON_DOWN_ICON}\n type=\"mask\"\n />\n </button>\n\n <ch-popover\n ref={(el: HTMLChPopoverElement) => (this.#popoverEl = el)}\n closeOnClickOutside\n show={this.showPopover}\n blockAlign=\"outside-end\"\n inlineAlign=\"inside-end\"\n inlineSizeMatch=\"action-element\"\n class={\"scrollable\"}\n >\n <div>\n {this.model.map(option => (\n <ch-checkbox\n class=\"checkbox checkbox-item\"\n caption={option.caption}\n checkedValue=\"true\"\n value={this.#isItemSelected(option.value) ? \"true\" : \"false\"}\n startImgSrc={option.startImgSrc}\n onInput={e => this.#checkboxChangeHandler(option.value, e)}\n />\n ))}\n </div>\n </ch-popover>\n </Host>\n );\n }\n}\n"]}
@@ -4,62 +4,61 @@ Found on /common/helpers.tsx hiChar function is used to add a span/class to ever
4
4
  */
5
5
  :host {
6
6
  display: block;
7
- inline-size: 100%;
8
7
  }
9
8
 
10
9
  .file-item {
11
10
  display: grid;
12
- grid-template-columns: auto 1fr auto;
13
- grid-template-rows: auto;
14
- gap: var(--spacing-gap-l);
11
+ column-gap: var(--spacing-gap-l);
12
+ row-gap: var(--spacing-gap-s);
15
13
  align-items: center;
16
- border: 1px solid var(--mer-border__default);
17
- border-radius: 4px;
14
+ border-radius: var(--border-radius-s);
15
+ }
16
+ .file-item--without-actions {
17
+ grid-template-columns: max-content 1fr;
18
+ grid-template-areas: "icon name";
19
+ }
20
+ .file-item--with-actions {
21
+ grid-template-columns: max-content 1fr max-content;
22
+ grid-template-areas: "icon name actions";
18
23
  }
19
24
  .file-item__icon {
20
25
  display: flex;
21
26
  align-items: center;
27
+ grid-area: icon;
28
+ padding-block: calc(32px - var(--ch-image-size));
22
29
  }
23
30
  .file-item__name {
31
+ grid-area: name;
24
32
  overflow: hidden;
25
33
  white-space: nowrap;
26
34
  text-overflow: ellipsis;
27
- inline-size: 100%;
28
- font-weight: var(--font-style-regular);
35
+ min-inline-size: 0;
29
36
  }
30
37
  .file-item__name ch-edit {
31
38
  overflow: hidden;
32
39
  white-space: nowrap;
33
40
  text-overflow: ellipsis;
34
- inline-size: 100%;
35
- font-weight: var(--font-style-regular);
36
41
  }
37
42
  .file-item__name .label {
38
43
  overflow: hidden;
39
44
  white-space: nowrap;
40
45
  text-overflow: ellipsis;
41
- inline-size: 100%;
42
- font-weight: var(--font-style-regular);
43
46
  }
44
47
  .file-item__actions {
48
+ grid-area: actions;
45
49
  display: flex;
46
- gap: var(--spacing-gap-m);
47
50
  }
48
- .file-item__actions button:active, .file-item__actions button:focus, .file-item__actions button:hover {
49
- background-color: var(--mer-surface__hover);
50
- }
51
- .file-item__actions button:active {
52
- background-color: var(--mer-surface__pressed);
51
+ .file-item__cancel-upload {
52
+ transform: translateX(7px);
53
53
  }
54
54
  .file-item__progress-container {
55
55
  grid-column: 1/-1;
56
56
  display: flex;
57
57
  flex-direction: column;
58
58
  gap: var(--spacing-gap-xs);
59
- inline-size: 100%;
60
59
  border: 2px dashed var(--color-border-neutral-default);
61
- border-radius: 8px;
62
- padding: var(--spacing-padding-l);
60
+ border-radius: var(--border-radius-m);
61
+ padding: var(--spacing-padding-xxs) var(--spacing-padding-l) var(--spacing-padding-m) var(--spacing-padding-l);
63
62
  }
64
63
  .file-item__progress-header {
65
64
  display: flex;
@@ -68,21 +67,17 @@ Found on /common/helpers.tsx hiChar function is used to add a span/class to ever
68
67
  gap: var(--spacing-gap-l);
69
68
  }
70
69
  .file-item__uploading-text {
71
- font-style: italic;
72
70
  color: var(--color-text-neutral-disabled);
73
71
  overflow: hidden;
74
72
  white-space: nowrap;
75
73
  text-overflow: ellipsis;
76
74
  max-inline-size: calc(100% - 40px);
77
75
  }
78
- .file-item__progress-bar {
79
- inline-size: 100%;
80
- }
81
76
  .file-item__progress-bar progress {
82
- inline-size: 100%;
83
- height: 8px;
77
+ block-size: 8px;
78
+ line-height: 0;
84
79
  border: none;
85
- border-radius: 4px;
80
+ border-radius: var(--border-radius-s);
86
81
  overflow: hidden;
87
82
  }
88
83
  .file-item__progress-bar progress::-webkit-progress-bar {
@@ -71,6 +71,7 @@ export class FileItem {
71
71
  });
72
72
  this.file = undefined;
73
73
  this.editable = false;
74
+ this.componentLocale = undefined;
74
75
  this.fileDeletedCallback = undefined;
75
76
  this.fileDeletionErrorCallback = undefined;
76
77
  this.isEditing = false;
@@ -84,7 +85,25 @@ export class FileItem {
84
85
  this.currentName = this.file.name;
85
86
  }
86
87
  render() {
87
- return (h("div", { class: "file-item" }, h("ch-theme", { model: CSS_BUNDLES }), h("div", { class: "file-item__icon" }, h("ch-image", { src: FILE_ICON, class: "icon-m" })), h("div", { class: "file-item__name" }, this.isEditing ? (h("ch-edit", { value: this.currentName, autoFocus: true, onInput: __classPrivateFieldGet(this, _FileItem_handleNameChange, "f"), onBlur: __classPrivateFieldGet(this, _FileItem_handleBlur, "f"), class: "input" })) : (h("label", { class: "label" }, this.currentName))), h("div", { class: "file-item__actions" }, !this.file.pending && this.editable && (h("button", { class: "button-tertiary button-icon-only", type: "button", onClick: __classPrivateFieldGet(this, _FileItem_startEditing, "f") }, h("ch-image", { src: EDIT_ICON, class: "icon-m" }))), !this.file.pending && (h("button", { class: "button-tertiary button-icon-only", type: "button", onClick: __classPrivateFieldGet(this, _FileItem_handleDelete, "f"), "aria-label": "Delete file" }, h("ch-image", { src: DELETE_ICON, class: "icon-m" })))), this.file.pending && (h("div", { class: "file-item__progress-container" }, h("div", { class: "file-item__progress-header" }, h("span", { class: "file-item__uploading-text" }, "Uploading ", this.currentName, "..."), h("button", { class: "button-tertiary button-icon-only", type: "button", onClick: __classPrivateFieldGet(this, _FileItem_handleCancelClick, "f") }, h("ch-image", { src: CANCEL_ICON, class: "icon-m" }))), h("div", { class: "file-item__progress-bar" }, h("progress", { class: "elevation-1", value: this.file.progress, max: "100" }))))));
88
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
89
+ const displayItemActions = !this.file.pending;
90
+ const displayProgressContainer = this.file.pending;
91
+ const labelId = "progress-label-" + this.file.id;
92
+ let liAriaLabel;
93
+ if (this.file.pending) {
94
+ liAriaLabel = ((_d = (_c = (_b = (_a = this.componentLocale) === null || _a === void 0 ? void 0 : _a.fileItem) === null || _b === void 0 ? void 0 : _b.uploadingAriaLabel) === null || _c === void 0 ? void 0 : _c.replace("{fileName}", this.currentName)) === null || _d === void 0 ? void 0 : _d.replace("{fileProgress}", this.file.progress.toString())) || this.currentName;
95
+ }
96
+ else if (this.file.remoteId) {
97
+ liAriaLabel = ((_g = (_f = (_e = this.componentLocale) === null || _e === void 0 ? void 0 : _e.fileItem) === null || _f === void 0 ? void 0 : _f.uploadedSuccessfullyAriaLabel) === null || _g === void 0 ? void 0 : _g.replace("{fileName}", this.currentName)) || this.currentName;
98
+ }
99
+ else {
100
+ liAriaLabel = this.currentName;
101
+ }
102
+ return (h("li", { class: {
103
+ "file-item": true,
104
+ "file-item--without-actions": !displayItemActions,
105
+ "file-item--with-actions": displayItemActions
106
+ }, "aria-label": liAriaLabel }, h("ch-theme", { model: CSS_BUNDLES }), h("div", { class: "file-item__icon" }, h("ch-image", { disabled: !this.file.pending, src: FILE_ICON, class: "icon-m" })), h("div", { class: "file-item__name" }, this.isEditing ? (h("ch-edit", { accessibleName: (_k = (_j = (_h = this.componentLocale) === null || _h === void 0 ? void 0 : _h.fileItem) === null || _j === void 0 ? void 0 : _j.editNamePlaceholderAriaLabel) === null || _k === void 0 ? void 0 : _k.replace("{fileName}", this.currentName), value: this.currentName, autoFocus: true, onInput: __classPrivateFieldGet(this, _FileItem_handleNameChange, "f"), onBlur: __classPrivateFieldGet(this, _FileItem_handleBlur, "f"), class: "input", id: labelId })) : (h("span", { class: "label", id: labelId }, this.currentName))), displayItemActions ? (h("div", { class: "file-item__actions" }, !this.file.pending && this.editable && (h("button", { class: "button-tertiary button-icon-only", type: "button", onClick: __classPrivateFieldGet(this, _FileItem_startEditing, "f") }, h("ch-image", { src: EDIT_ICON, class: "icon-m" }))), !this.file.pending && (h("button", { class: "button-tertiary button-icon-only", type: "button", onClick: __classPrivateFieldGet(this, _FileItem_handleDelete, "f"), "aria-label": "Delete file" }, h("ch-image", { src: DELETE_ICON, class: "icon-m" }))))) : (null), displayProgressContainer && (h("div", { class: "file-item__progress-container" }, h("div", { class: "file-item__progress-header" }, h("span", { class: "file-item__uploading-text typography-body-italic-s" }, "Uploading ", this.currentName, "..."), h("button", { "aria-label": ((_o = (_m = (_l = this.componentLocale) === null || _l === void 0 ? void 0 : _l.fileItem) === null || _m === void 0 ? void 0 : _m.cancelUploadButtonAriaLabel) === null || _o === void 0 ? void 0 : _o.replace("{fileName}", this.currentName)) || "Cancel upload", class: "button-tertiary button-icon-only file-item__cancel-upload", type: "button", onClick: __classPrivateFieldGet(this, _FileItem_handleCancelClick, "f") }, h("ch-image", { src: CANCEL_ICON, class: "icon-m" }))), h("div", { class: "file-item__progress-bar" }, h("progress", { class: "elevation-1", value: this.file.progress, max: "100", "aria-labelledby": labelId }))))));
88
107
  }
89
108
  static get is() { return "gx-ide-file-item"; }
90
109
  static get encapsulation() { return "shadow"; }
@@ -139,6 +158,23 @@ export class FileItem {
139
158
  "reflect": false,
140
159
  "defaultValue": "false"
141
160
  },
161
+ "componentLocale": {
162
+ "type": "any",
163
+ "mutable": false,
164
+ "complexType": {
165
+ "original": "any",
166
+ "resolved": "any",
167
+ "references": {}
168
+ },
169
+ "required": false,
170
+ "optional": true,
171
+ "docs": {
172
+ "tags": [],
173
+ "text": "Component locale strings"
174
+ },
175
+ "attribute": "component-locale",
176
+ "reflect": false
177
+ },
142
178
  "fileDeletedCallback": {
143
179
  "type": "unknown",
144
180
  "mutable": false,