@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.
- package/dist/cjs/genexus-ide-ui.cjs.js +1 -1
- package/dist/cjs/gx-ide-file-item.cjs.entry.js +21 -2
- package/dist/cjs/gx-ide-file-item.cjs.entry.js.map +1 -1
- package/dist/cjs/gx-ide-file-uploader.cjs.entry.js +11 -8
- package/dist/cjs/gx-ide-file-uploader.cjs.entry.js.map +1 -1
- package/dist/cjs/gx-ide-launchpad.cjs.entry.js +4 -16
- package/dist/cjs/gx-ide-launchpad.cjs.entry.js.map +1 -1
- package/dist/cjs/gx-ide-multi-select.cjs.entry.js +113 -0
- package/dist/cjs/gx-ide-multi-select.cjs.entry.js.map +1 -0
- package/dist/cjs/gx-ide-search.cjs.entry.js +171 -0
- package/dist/cjs/gx-ide-search.cjs.entry.js.map +1 -0
- package/dist/cjs/gx-ide-ww-files.cjs.entry.js +3 -4
- package/dist/cjs/gx-ide-ww-files.cjs.entry.js.map +1 -1
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/collection/collection-manifest.json +2 -0
- package/dist/collection/components/_helpers/multi-select/gx-ide-multi-select.css +193 -0
- package/dist/collection/components/_helpers/multi-select/gx-ide-multi-select.js +209 -0
- package/dist/collection/components/_helpers/multi-select/gx-ide-multi-select.js.map +1 -0
- package/dist/collection/components/file-uploader/file-item/file-item.css +23 -28
- package/dist/collection/components/file-uploader/file-item/file-item.js +37 -1
- package/dist/collection/components/file-uploader/file-item/file-item.js.map +1 -1
- package/dist/collection/components/file-uploader/file-uploader.css +11 -22
- package/dist/collection/components/file-uploader/file-uploader.js +10 -7
- package/dist/collection/components/file-uploader/file-uploader.js.map +1 -1
- package/dist/collection/components/file-uploader/gx-ide-assets/file-uploader/langs/file-uploader.lang.en.json +7 -3
- package/dist/collection/components/file-uploader/gx-ide-assets/file-uploader/langs/file-uploader.lang.ja.json +7 -3
- package/dist/collection/components/file-uploader/gx-ide-assets/file-uploader/langs/file-uploader.lang.zh.json +8 -3
- package/dist/collection/components/launchpad/root/gx-ide-assets/launchpad/shortcuts.json +1 -26
- package/dist/collection/components/launchpad/root/launchpad.js +5 -42
- package/dist/collection/components/launchpad/root/launchpad.js.map +1 -1
- package/dist/collection/components/search/gx-ide-assets/search/langs/search.lang.en.json +37 -0
- package/dist/collection/components/search/gx-ide-assets/search/langs/search.lang.ja.json +37 -0
- package/dist/collection/components/search/gx-ide-assets/search/langs/search.lang.zh.json +37 -0
- package/dist/collection/components/search/search.css +44 -0
- package/dist/collection/components/search/search.js +275 -0
- package/dist/collection/components/search/search.js.map +1 -0
- package/dist/collection/components/ww-files/ww-files.js +3 -4
- package/dist/collection/components/ww-files/ww-files.js.map +1 -1
- package/dist/collection/testing/locale.e2e.js +4 -1
- package/dist/collection/testing/locale.e2e.js.map +1 -1
- package/dist/components/file-item.js +22 -2
- package/dist/components/file-item.js.map +1 -1
- package/dist/components/gx-ide-file-uploader.js +11 -8
- package/dist/components/gx-ide-file-uploader.js.map +1 -1
- package/dist/components/gx-ide-launchpad.js +6 -19
- package/dist/components/gx-ide-launchpad.js.map +1 -1
- package/dist/components/gx-ide-multi-select.d.ts +11 -0
- package/dist/components/gx-ide-multi-select.js +132 -0
- package/dist/components/gx-ide-multi-select.js.map +1 -0
- package/dist/components/gx-ide-search.d.ts +11 -0
- package/dist/components/gx-ide-search.js +206 -0
- package/dist/components/gx-ide-search.js.map +1 -0
- package/dist/components/gx-ide-ww-files.js +3 -4
- package/dist/components/gx-ide-ww-files.js.map +1 -1
- package/dist/esm/genexus-ide-ui.js +1 -1
- package/dist/esm/gx-ide-file-item.entry.js +21 -2
- package/dist/esm/gx-ide-file-item.entry.js.map +1 -1
- package/dist/esm/gx-ide-file-uploader.entry.js +11 -8
- package/dist/esm/gx-ide-file-uploader.entry.js.map +1 -1
- package/dist/esm/gx-ide-launchpad.entry.js +5 -17
- package/dist/esm/gx-ide-launchpad.entry.js.map +1 -1
- package/dist/esm/gx-ide-multi-select.entry.js +109 -0
- package/dist/esm/gx-ide-multi-select.entry.js.map +1 -0
- package/dist/esm/gx-ide-search.entry.js +167 -0
- package/dist/esm/gx-ide-search.entry.js.map +1 -0
- package/dist/esm/gx-ide-ww-files.entry.js +3 -4
- package/dist/esm/gx-ide-ww-files.entry.js.map +1 -1
- package/dist/esm/loader.js +1 -1
- package/dist/genexus-ide-ui/genexus-ide-ui.esm.js +1 -1
- package/dist/genexus-ide-ui/genexus-ide-ui.esm.js.map +1 -1
- package/dist/genexus-ide-ui/gx-ide-assets/file-uploader/langs/file-uploader.lang.en.json +7 -3
- package/dist/genexus-ide-ui/gx-ide-assets/file-uploader/langs/file-uploader.lang.ja.json +7 -3
- package/dist/genexus-ide-ui/gx-ide-assets/file-uploader/langs/file-uploader.lang.zh.json +8 -3
- package/dist/genexus-ide-ui/gx-ide-assets/launchpad/shortcuts.json +1 -26
- package/dist/genexus-ide-ui/gx-ide-assets/search/langs/search.lang.en.json +37 -0
- package/dist/genexus-ide-ui/gx-ide-assets/search/langs/search.lang.ja.json +37 -0
- package/dist/genexus-ide-ui/gx-ide-assets/search/langs/search.lang.zh.json +37 -0
- package/dist/genexus-ide-ui/p-0745a565.entry.js +152 -0
- package/dist/genexus-ide-ui/p-0745a565.entry.js.map +1 -0
- package/dist/genexus-ide-ui/{p-6246204f.entry.js → p-25e749c7.entry.js} +44 -57
- package/dist/genexus-ide-ui/p-25e749c7.entry.js.map +1 -0
- package/dist/genexus-ide-ui/{p-50dae653.entry.js → p-7bdeae77.entry.js} +211 -213
- package/dist/genexus-ide-ui/p-7bdeae77.entry.js.map +1 -0
- package/dist/genexus-ide-ui/p-8b5c826b.entry.js +212 -0
- package/dist/genexus-ide-ui/p-8b5c826b.entry.js.map +1 -0
- package/dist/genexus-ide-ui/p-c460c9e7.entry.js +187 -0
- package/dist/genexus-ide-ui/p-c460c9e7.entry.js.map +1 -0
- package/dist/genexus-ide-ui/{p-aad714a5.entry.js → p-e2b88bea.entry.js} +70 -67
- package/dist/genexus-ide-ui/p-e2b88bea.entry.js.map +1 -0
- package/dist/types/components/_helpers/multi-select/gx-ide-multi-select.d.ts +29 -0
- package/dist/types/components/file-uploader/file-item/file-item.d.ts +2 -0
- package/dist/types/components/launchpad/root/launchpad.d.ts +0 -4
- package/dist/types/components/search/search.d.ts +60 -0
- package/dist/types/components.d.ts +121 -4
- package/package.json +1 -1
- package/dist/genexus-ide-ui/p-50dae653.entry.js.map +0 -1
- package/dist/genexus-ide-ui/p-6246204f.entry.js.map +0 -1
- package/dist/genexus-ide-ui/p-aad714a5.entry.js.map +0 -1
- package/dist/genexus-ide-ui/p-f3c3e830.entry.js +0 -163
- 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
|
-
|
|
13
|
-
|
|
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:
|
|
17
|
-
|
|
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:
|
|
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-
|
|
49
|
-
|
|
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:
|
|
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
|
-
|
|
83
|
-
height:
|
|
77
|
+
block-size: 8px;
|
|
78
|
+
line-height: 0;
|
|
84
79
|
border: none;
|
|
85
|
-
border-radius:
|
|
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
|
-
|
|
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,
|