@sankhyalabs/ezui 5.20.0-dev.2 → 5.20.0-dev.4

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 (62) hide show
  1. package/README.md +4 -5
  2. package/dist/cjs/ez-alert-list.cjs.entry.js +33 -28
  3. package/dist/cjs/ez-card-item.cjs.entry.js +52 -0
  4. package/dist/cjs/ez-combo-box.cjs.entry.js +155 -11
  5. package/dist/cjs/ez-filter-input_2.cjs.entry.js +137 -0
  6. package/dist/cjs/ez-form-view.cjs.entry.js +4 -2
  7. package/dist/cjs/ez-grid.cjs.entry.js +3 -3
  8. package/dist/cjs/ez-icon.cjs.entry.js +1 -1
  9. package/dist/cjs/ez-search.cjs.entry.js +31 -611
  10. package/dist/cjs/ez-split-panel.cjs.entry.js +3 -2
  11. package/dist/cjs/ezui.cjs.js +1 -1
  12. package/dist/cjs/index-a7b0c73d.js +6 -2
  13. package/dist/cjs/loader.cjs.js +1 -1
  14. package/dist/collection/collection-manifest.json +2 -2
  15. package/dist/collection/components/ez-alert-list/ez-alert-list.js +33 -28
  16. package/dist/collection/components/ez-card-item/ez-card-item.css +0 -16
  17. package/dist/collection/components/ez-combo-box/ez-combo-box.js +173 -12
  18. package/dist/collection/components/ez-form-view/fieldbuilder/templates/FileInput.tpl.js +4 -2
  19. package/dist/collection/components/ez-grid/ez-grid.css +1 -0
  20. package/dist/collection/components/ez-grid/ez-grid.js +2 -2
  21. package/dist/collection/components/ez-icon/ez-icon.css +1 -1
  22. package/dist/collection/components/ez-search/ez-search.css +0 -330
  23. package/dist/collection/components/ez-search/ez-search.js +55 -689
  24. package/dist/collection/components/ez-split-panel/ez-split-panel.css +7 -0
  25. package/dist/collection/components/ez-split-panel/ez-split-panel.js +19 -1
  26. package/dist/custom-elements/index.js +240 -665
  27. package/dist/esm/ez-alert-list.entry.js +33 -28
  28. package/dist/esm/ez-card-item.entry.js +48 -0
  29. package/dist/esm/ez-combo-box.entry.js +156 -12
  30. package/dist/esm/ez-filter-input_2.entry.js +132 -0
  31. package/dist/esm/ez-form-view.entry.js +4 -2
  32. package/dist/esm/ez-grid.entry.js +3 -3
  33. package/dist/esm/ez-icon.entry.js +1 -1
  34. package/dist/esm/ez-search.entry.js +33 -613
  35. package/dist/esm/ez-split-panel.entry.js +3 -2
  36. package/dist/esm/ezui.js +1 -1
  37. package/dist/esm/index-baa5e267.js +6 -2
  38. package/dist/esm/loader.js +1 -1
  39. package/dist/ezui/ezui.esm.js +1 -1
  40. package/dist/ezui/p-05f5a778.entry.js +1 -0
  41. package/dist/ezui/p-13dbad96.entry.js +1 -0
  42. package/dist/ezui/p-5613fe63.entry.js +1 -0
  43. package/dist/ezui/p-60848ef6.entry.js +1 -0
  44. package/dist/ezui/{p-6e2f8e6b.entry.js → p-844ee673.entry.js} +1 -1
  45. package/dist/ezui/{p-f56dd1da.entry.js → p-93c3df4f.entry.js} +1 -1
  46. package/dist/ezui/p-940ed30b.entry.js +1 -0
  47. package/dist/ezui/p-a32aaac6.entry.js +1 -0
  48. package/dist/ezui/p-a5ac7151.entry.js +1 -0
  49. package/dist/types/components/ez-alert-list/ez-alert-list.d.ts +1 -1
  50. package/dist/types/components/ez-combo-box/ez-combo-box.d.ts +15 -0
  51. package/dist/types/components/ez-search/ez-search.d.ts +10 -100
  52. package/dist/types/components.d.ts +22 -23
  53. package/dist/types/utils/interfaces/AbstractFieldMetadata.d.ts +1 -2
  54. package/package.json +16 -8
  55. package/dist/cjs/ez-card-item_3.cjs.entry.js +0 -182
  56. package/dist/esm/ez-card-item_3.entry.js +0 -176
  57. package/dist/ezui/p-133fae4a.entry.js +0 -1
  58. package/dist/ezui/p-43b03119.entry.js +0 -1
  59. package/dist/ezui/p-4a7f113d.entry.js +0 -1
  60. package/dist/ezui/p-76ba9d67.entry.js +0 -1
  61. package/dist/ezui/p-796c1a88.entry.js +0 -1
  62. package/dist/ezui/p-ba875f37.entry.js +0 -1
@@ -5,32 +5,13 @@ Object.defineProperty(exports, '__esModule', { value: true });
5
5
  const index = require('./index-a7b0c73d.js');
6
6
  const CSSVarsUtils = require('./CSSVarsUtils-b136a156.js');
7
7
  const core = require('@sankhyalabs/core');
8
- const ApplicationUtils = require('./ApplicationUtils-c9d1205c.js');
9
- require('./DialogType-2114c337.js');
10
- require('./CheckMode-ecb90b87.js');
11
- const constants = require('./constants-2714478b.js');
12
8
 
13
- const ezSearchCss = ":host{--ez-search--height:42px;--ez-search--width:100%;--ez-search__icon--width:48px;--ez-search--border-radius:var(--border--radius-medium, 12px);--ez-search--border-radius-small:var(--border--radius-small, 6px);--ez-search--font-size:var(--text--medium, 14px);--ez-search--font-family:var(--font-pattern, Arial);--ez-search--font-weight--large:var(--text-weight--large, 500);--ez-search--font-weight--medium:var(--text-weight--medium, 400);--ez-search--background-color--xlight:var(--background--xlight, #fff);--ez-search--background-medium:var(--background--medium, #f0f3f7);--ez-search--line-height:calc(var(--text--medium, 14px) + 4px);--ez-search__input--background-color:var(--background--medium, #e0e0e0);--ez-search__input--border:var(--border--medium, 2px solid);--ez-search__input--border-color:var(--ez-search__input--background-color);--ez-search__input--focus--border-color:var(--color--primary, #008561);--ez-search__input--disabled--background-color:var(--color--disable-secondary, #F2F5F8);--ez-search__input--disabled--color:var(--text--disable, #AFB6C0);--ez-search__input--error--border-color:#CC2936;--ez-search__btn--color:var(--title--primary, #2B3A54);--ez-search__btn-disabled--color:var(--text--disable, #AFB6C0);--ez-search__btn-hover--color:var(--color--primary, #4e4e4e);--ez-search__label--color:var(--title--primary, #2B3A54);--ez-search__list-title--primary:var(--title--primary, #2B3A54);--ez-search__list-text--primary:var(--text--primary, #626e82);--ez-search__list-height:calc(var(--ez-search--font-size) + var(--ez-search--space--medium) + 4px);--ez-search__list-min-width:64px;--ez-search--space--medium:var(--space--medium, 12px);--ez-search--space--small:var(--space--small, 6px);--ez-search__scrollbar--color-default:var(--scrollbar--default, #626e82);--ez-search__scrollbar--color-background:var(--scrollbar--background, #E5EAF0);--ez-search__scrollbar--color-hover:var(--scrollbar--hover, #2B3A54);--ez-search__scrollbar--color-clicked:var(--scrollbar--clicked, #a2abb9);--ez-search__scrollbar--border-radius:var(--border--radius-small, 6px);--ez-search__scrollbar--width:var(--space--medium, 12px);display:flex;flex-wrap:wrap;position:relative;width:var(--ez-search--width)}ez-icon{--ez-icon--color:inherit;font-weight:var(--text-weight--large, 600)}.suppressed-search-input{--ez-text-input__input--border-color:var(--color--strokes, #dce0e8);--ez-text-input__input--disabled--background-color:var(--background--xlight, #fff);--ez-text-input__input--disabled--color:var(--title--primary, #2B3A54)}.list-container{min-width:var(--ez-search__list-min-width);position:relative;width:100%}.list-wrapper{display:flex;flex-direction:column;box-sizing:border-box;width:0;z-index:var(--more-visible, 2);max-height:350px;background-color:var(--ez-search--background-color--xlight);border-radius:var(--ez-search--border-radius);box-shadow:var(--shadow, 0px 0px 16px 0px #000);padding:var(--ez-search--space--small)}.list-options{box-sizing:border-box;width:100%;height:100%;padding:0;display:flex;flex-direction:column;scroll-behavior:smooth;overflow:auto;scrollbar-width:thin;gap:3px;scrollbar-color:var(--ez-search__scrollbar--color-clicked) var(--ez-search__scrollbar--color-background)}.list-options::-webkit-scrollbar{background-color:var(--ez-search__scrollbar--color-background);width:var(--ez-search__scrollbar--width);max-width:var(--ez-search__scrollbar--width);min-width:var(--ez-search__scrollbar--width)}.list-options::-webkit-scrollbar-track{background-color:var(--ez-search__scrollbar--color-background);border-radius:var(--ez-search__scrollbar--border-radius)}.list-options::-webkit-scrollbar-thumb{background-color:var(--ez-search__scrollbar--color-default);border-radius:var(--ez-search__scrollbar--border-radius)}.list-options::-webkit-scrollbar-thumb:vertical:hover,.list-options::-webkit-scrollbar-thumb:horizontal:hover{background-color:var(--ez-search__scrollbar--color-hover)}.list-options::-webkit-scrollbar-thumb:vertical:active,.list-options::-webkit-scrollbar-thumb:horizontal:active{background-color:var(--ez-search__scrollbar--color-clicked)}.item{display:flex;align-items:center;width:100%;box-sizing:border-box;list-style-type:none;cursor:pointer;border-radius:var(--ez-search--border-radius-small);padding:var(--ez-search--space--small);min-height:var(--ez-search__list-height);gap:var(--space--small, 6px)}.item__value,.item__label{flex-basis:auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--ez-search__list-title--primary);font-family:var(--ez-search--font-family);font-size:var(--ez-search--font-size);line-height:var(--ez-search--line-height)}.item__label{font-weight:var(--ez-search--font-weight--medium)}.item__label--bold{font-weight:var(--ez-search--font-weight--large)}.item__value{text-align:center;color:var(--ez-search__list-text--primary);font-weight:var(--ez-search--font-weight--large)}.item__value--hidden{visibility:hidden;position:absolute;white-space:nowrap;z-index:-1;top:0;left:0}.item__label{text-align:left}.message{text-align:center;display:flex;justify-content:center;align-items:center;list-style-type:none;min-height:var(--ez-search__list-height)}.message__no-result{color:var(--ez-search__list-title--primary);font-family:var(--ez-search--font-family);font-size:var(--ez-search--font-size)}.message__loading{border-radius:50%;width:14px;height:14px;-webkit-animation:spin 1s linear infinite;animation:spin 1s linear infinite;border:3px solid var(--ez-search__list-title--primary);border-top:3px solid transparent}.item__list>li:hover{background-color:var(--ez-search--background-medium)}.preselected{background-color:var(--background--medium)}.btn{outline:none;border:none;background:none;cursor:pointer;color:var(--ez-search__btn--color)}.btn:disabled{cursor:unset;color:var(--ez-search__btn-disabled--color)}.btn:disabled:hover{cursor:unset;color:var(--ez-search__btn-disabled--color)}.btn:hover{color:var(--ez-search__btn-hover--color)}.btn__close{visibility:hidden}ez-text-input:hover .btn__close,ez-text-input:focus .btn__close{visibility:visible}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg)}100%{-webkit-transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}";
9
+ const ezSearchCss = ":host{width:100%}";
14
10
 
15
11
  const EzSearch = class {
16
12
  constructor(hostRef) {
17
13
  index.registerInstance(this, hostRef);
18
14
  this.ezChange = index.createEvent(this, "ezChange", 7);
19
- this._changeDeboucingTimeout = null;
20
- this._limitCharsToSearch = 3;
21
- this._deboucingTime = 300;
22
- this._maxWidthValue = 0;
23
- this._tabPressed = false;
24
- this._textEmptyList = "Nenhum resultado encontrado";
25
- this._textEmptySearch = "Nenhum resultado de {0} encontrado";
26
- this._lookupMode = false;
27
- this._startHighlightTag = "<span class='card-item__highlight'>";
28
- this._endHighlightTag = "</span>";
29
- this._preSelection = undefined;
30
- this._visibleOptions = undefined;
31
- this._startLoading = false;
32
- this._showLoading = true;
33
- this._criteria = undefined;
34
15
  this.value = undefined;
35
16
  this.label = undefined;
36
17
  this.enabled = true;
@@ -45,82 +26,28 @@ const EzSearch = class {
45
26
  this.listOptionsPosition = undefined;
46
27
  this.isTextSearch = false;
47
28
  this.ignoreLimitCharsToSearch = false;
48
- this.options = undefined;
49
- this.suppressSearch = false;
50
29
  }
51
30
  observeErrorMessage() {
52
- var _a;
53
- if (this._textInput) {
54
- this._textInput.errorMessage = this.errorMessage;
55
- if (!((_a = this.errorMessage) === null || _a === void 0 ? void 0 : _a.trim())) {
56
- this.setInputValue();
57
- }
58
- }
59
- }
60
- observeValue(newValue, oldValue) {
61
- if (this._textInput && newValue != oldValue) {
62
- try {
63
- if (newValue === "string") {
64
- this.setInputValue();
65
- return;
66
- }
67
- const newValueSelected = this.getSelectedOption(newValue);
68
- const oldValueSelected = this.getSelectedOption(oldValue);
69
- const currentValue = this.getSelectedOption(this.value);
70
- if (this.isDifferentValues(currentValue, newValueSelected)) {
71
- this.value = newValueSelected;
72
- }
73
- if (this.isDifferentValues(newValueSelected, oldValueSelected)) {
74
- this.setInputValue();
75
- const valueEmitted = newValueSelected === null ? undefined : newValueSelected;
76
- if (!this._lookupMode) {
77
- this.ezChange.emit(valueEmitted);
78
- }
79
- }
80
- this.resetOptions();
81
- }
82
- finally {
83
- this._lookupMode = false;
84
- }
31
+ if (this._comboElement) {
32
+ this._comboElement.errorMessage = this.errorMessage;
85
33
  }
86
34
  }
87
- observeOptions(newOptions, oldOptions) {
88
- if ((newOptions === null || newOptions === void 0 ? void 0 : newOptions.join('')) === (oldOptions === null || oldOptions === void 0 ? void 0 : oldOptions.join('')))
89
- return;
90
- this.loadOptions(SearchMode.PRELOAD);
91
- }
92
- /*
93
- * Retorna uma promise com o valor da opção selecionada,
94
- * que será resolvida quando o backend devolver este dado.
95
- */
96
- async getValueAsync() {
97
- if (!this._showLoading) {
98
- return new Promise(resolve => resolve(this.value));
35
+ observeValue() {
36
+ if (this._comboElement) {
37
+ this._comboElement.value = this.value;
99
38
  }
100
- return new Promise(resolve => {
101
- let id = setInterval(() => {
102
- if (!this._showLoading) {
103
- clearInterval(id);
104
- resolve(this.value);
105
- }
106
- }, 100);
107
- });
108
39
  }
109
40
  /**
110
- * Aplica o foco no campo.
111
- */
41
+ * Aplica o foco no campo.
42
+ */
112
43
  async setFocus() {
113
- if (this._textInput) {
114
- this._textInput.setFocus();
115
- }
44
+ this._comboElement.setFocus();
116
45
  }
117
46
  /**
118
- * Remove o foco do campo.
119
- */
47
+ * Remove o foco do campo.
48
+ */
120
49
  async setBlur() {
121
- if (this._textInput) {
122
- this._textInput.setBlur();
123
- }
50
+ this._comboElement.setBlur();
124
51
  }
125
52
  /**
126
53
  * Retorna se o conteúdo é inválido.
@@ -132,546 +59,39 @@ const EzSearch = class {
132
59
  * Limpa o valor do campo de pesquisa
133
60
  */
134
61
  async clearValue() {
135
- this.clearSearch();
136
- }
137
- scrollListener() {
138
- var _a;
139
- if (this._floatingID == undefined) {
140
- return;
141
- }
142
- if ((_a = this.listOptionsPosition) === null || _a === void 0 ? void 0 : _a.hardPosition) {
143
- this.hideOptions();
144
- }
145
- else {
146
- window.requestAnimationFrame(() => {
147
- this.updateListPosition();
148
- });
149
- }
150
- }
151
- updateListPosition() {
152
- let { verticalPosition, horizontalPosition, fromBottom, fromRight, bottomLimit, hardPosition } = this.getListPosition();
153
- const elementRect = this._listWrapper.getBoundingClientRect();
154
- const containerRect = this._listContainer.getBoundingClientRect();
155
- const textInputRect = this._textInput.getBoundingClientRect();
156
- const limitHeight = bottomLimit || window.innerHeight;
157
- const neededHeight = containerRect.bottom + elementRect.height;
158
- if (!fromBottom && (elementRect.top < 0 || neededHeight > limitHeight)) {
159
- fromBottom = true;
160
- }
161
- if (!hardPosition) {
162
- verticalPosition = verticalPosition || 0;
163
- horizontalPosition = horizontalPosition || 0;
164
- if (fromBottom) {
165
- verticalPosition = window.innerHeight - textInputRect.top + verticalPosition;
166
- }
167
- else {
168
- verticalPosition += containerRect.top;
169
- }
170
- if (fromRight) {
171
- horizontalPosition = window.innerWidth - textInputRect.right + horizontalPosition;
172
- }
173
- else {
174
- horizontalPosition += containerRect.left;
175
- }
176
- }
177
- if (verticalPosition != undefined) {
178
- this._listWrapper.style[fromBottom ? "bottom" : "top"] = `${verticalPosition}px`;
179
- this._listWrapper.style[fromBottom ? "top" : "bottom"] = "";
180
- }
181
- if (horizontalPosition != undefined) {
182
- this._listWrapper.style[fromRight ? "right" : "left"] = `${horizontalPosition}px`;
183
- this._listWrapper.style[fromRight ? "left" : "right"] = "";
184
- }
185
- }
186
- getListPosition() {
187
- if (this.listOptionsPosition) {
188
- return this.listOptionsPosition;
189
- }
190
- return {
191
- verticalPosition: (this.errorMessage || !this.canShowError || this.mode === "slim") ? 6 : -13
192
- };
193
- }
194
- isDifferentValues(firstValue, secondValue) {
195
- return core.ObjectUtils.objectToString(firstValue || {}) !== core.ObjectUtils.objectToString(secondValue || {});
196
- }
197
- getFormattedText(currentValue) {
198
- if (currentValue == undefined) {
199
- return;
200
- }
201
- if (!this.showSelectedValue || currentValue.value == undefined) {
202
- return currentValue.label;
203
- }
204
- return currentValue.label ? `${currentValue.value} - ${currentValue.label}` : currentValue.value;
205
- }
206
- getText() {
207
- const currentValue = this.getSelectedOption(this.value);
208
- const text = this.getFormattedText(currentValue);
209
- if (text == undefined) {
210
- return;
211
- }
212
- return String(text)
213
- .replace(/&amp;/g, '&')
214
- .replace(/&lt;/g, '<')
215
- .replace(/&gt;/g, '>')
216
- .replace(/&quot;/g, '"');
217
- }
218
- getSelectedOption(value) {
219
- if (typeof value === "string" || value instanceof String) {
220
- return this._visibleOptions.find(o => o.value === value);
221
- }
222
- return value;
223
- }
224
- updateVisibleOptions() {
225
- let opts = this._source || [];
226
- if (this.suppressEmptyOption) {
227
- this._visibleOptions = opts;
228
- }
229
- else {
230
- this._visibleOptions = [{ value: undefined, label: "" }].concat(opts);
231
- }
232
- this._maxWidthValue = this.getMaxWidthValue();
233
- }
234
- getMaxWidthValue() {
235
- var _a;
236
- const arrValues = [];
237
- (_a = this._visibleOptions) === null || _a === void 0 ? void 0 : _a.forEach(opt => {
238
- const widthValue = this.getWidthValue(opt.value);
239
- if (!arrValues.includes(widthValue)) {
240
- arrValues.push(widthValue);
241
- }
242
- });
243
- return arrValues.length > 1 ? Math.max(...arrValues) : 0;
244
- }
245
- getWidthValue(value) {
246
- if (this._itemValueBasis != undefined) {
247
- const span = this._itemValueBasis;
248
- if (value != undefined) {
249
- span.innerHTML = value;
250
- return span.clientWidth > 0 ? (span.clientWidth + 2) : 0;
251
- }
252
- else {
253
- span.innerHTML = "";
254
- }
255
- }
256
- return 0;
257
- }
258
- createOption(detail) {
259
- let { key, title } = detail;
260
- const startHighlight = new RegExp(this._startHighlightTag, 'g');
261
- const endHighlight = new RegExp(this._endHighlightTag, 'g');
262
- title = core.StringUtils.decodeHtmlEntities(title);
263
- const option = {
264
- value: key === null || key === void 0 ? void 0 : key.replace(startHighlight, '').replace(endHighlight, ''),
265
- label: title === null || title === void 0 ? void 0 : title.replace(startHighlight, '').replace(endHighlight, '')
266
- };
267
- this.selectOption(option);
268
- }
269
- buildItem(opt, index$1) {
270
- opt.label = opt.label || opt.value;
271
- const card = {
272
- key: opt.value,
273
- title: opt.label,
274
- details: opt.details
275
- };
276
- return index.h("div", { style: { "height": "100%" }, onMouseDown: () => this.createOption(card), onMouseOver: () => this._preSelection = index$1 }, index.h("ez-card-item", { item: card }));
277
- }
278
- showOptions() {
279
- if (!this.enabled)
280
- return;
281
- if (this.isOptionsVisible()) {
282
- return;
283
- }
284
- if (!!this._resizeObserver)
285
- this._resizeObserver.observe(this._textInput);
286
- this._floatingID = core.FloatingManager.float(this._listWrapper, this._listContainer, { autoClose: false, isFixed: true, backClickListener: () => this.hideOptions() });
287
- this.setFocus();
288
- window.requestAnimationFrame(() => {
289
- this.updateListPosition();
290
- if (!this.listOptionsPosition) {
291
- this._listWrapper.scrollIntoView({ behavior: "smooth", block: "nearest", inline: "nearest" });
292
- }
293
- });
294
- }
295
- hideOptions() {
296
- if (this._floatingID !== undefined) {
297
- core.FloatingManager.close(this._floatingID);
298
- }
299
- this._floatingID = undefined;
300
- if (!!this._resizeObserver)
301
- this._resizeObserver.unobserve(this._textInput);
302
- }
303
- isOptionsVisible() {
304
- return this._floatingID !== undefined && core.FloatingManager.isFloating(this._floatingID);
305
- }
306
- nextOption() {
307
- if (!this.isOptionsVisible()) {
308
- return;
309
- }
310
- this.showOptions();
311
- this._preSelection = this._preSelection === undefined ? 0 : Math.min(this._preSelection + 1, this._visibleOptions.length - 1);
312
- this.scrollToOption(this._visibleOptions[this._preSelection]);
313
- }
314
- previousOption() {
315
- this._preSelection = this._preSelection === undefined ? 0 : Math.max(this._preSelection - 1, 0);
316
- this.scrollToOption(this._visibleOptions[this._preSelection]);
317
- }
318
- scrollToOption(opt) {
319
- window.requestAnimationFrame(() => {
320
- const liElem = (opt === null || opt === void 0 ? void 0 : opt.value) ? this._optionsList.querySelector(`li#item_${opt.value.replace(/[<>\[\]#=]/g, '\\$&').replace(/:/g, '\\:')}`) : undefined;
321
- if (liElem)
322
- liElem.scrollIntoView({ behavior: "smooth", block: "nearest" });
323
- });
324
- }
325
- selectCurrentOption() {
326
- if (this._preSelection !== undefined) {
327
- this.selectOption(this._visibleOptions[this._preSelection]);
328
- this._preSelection = undefined;
329
- }
330
- else {
331
- this.controlListWithOnlyOne();
332
- }
333
- }
334
- updateSource(source) {
335
- this._startLoading = false;
336
- if (source instanceof Promise) {
337
- this._showLoading = true;
338
- source.then(result => {
339
- this._showLoading = false;
340
- this.updateSource(result);
341
- }).catch(() => this._showLoading = false);
342
- this.updateVisibleOptions();
343
- }
344
- else {
345
- this._showLoading = false;
346
- if (Array.isArray(source)) {
347
- this._source = source;
348
- this.updateVisibleOptions();
349
- if (this._tabPressed) {
350
- this._tabPressed = false;
351
- this.controlEmptySearch();
352
- }
353
- }
354
- else {
355
- this.selectOption(source);
356
- }
357
- }
358
- }
359
- clearSource() {
360
- this._source = [];
361
- this.updateVisibleOptions();
362
- }
363
- selectOption(newOption) {
364
62
  var _a, _b;
365
- const currentValue = this.getSelectedOption(this.value);
366
- if ((((_a = currentValue === null || currentValue === void 0 ? void 0 : currentValue.value) === null || _a === void 0 ? void 0 : _a.toString()) !== ((_b = newOption === null || newOption === void 0 ? void 0 : newOption.value) === null || _b === void 0 ? void 0 : _b.toString()))
367
- || (currentValue == undefined && newOption != undefined && "value" in newOption)) {
368
- const adjustedOpt = !(newOption === null || newOption === void 0 ? void 0 : newOption.value) ? undefined : newOption;
369
- this.value = adjustedOpt;
370
- }
371
- else {
372
- this.resetOptions();
373
- }
374
- this._visibleOptions = [];
375
- this.clearSource();
63
+ (_b = (_a = this._comboElement) === null || _a === void 0 ? void 0 : _a['clearValue']) === null || _b === void 0 ? void 0 : _b.call(_a);
376
64
  }
377
- loadOptions(mode, argument = "") {
378
- this._criteria = argument;
379
- this._startLoading = true;
380
- if (this.optionLoader) {
381
- const searchArgument = { mode, argument };
382
- this.updateSource(this.optionLoader(searchArgument));
383
- }
384
- else {
385
- this.updateSource(this.options);
386
- }
387
- }
388
- cancelPreselection() {
389
- if (!this._textInput.value && this.value) {
390
- this.selectOption(undefined);
391
- }
392
- else {
393
- window.setTimeout(() => {
394
- this.setInputValue();
395
- }, this._deboucingTime);
396
- }
397
- this.resetOptions();
398
- }
399
- setInputValue(clearError = true) {
400
- const textValue = this.getText();
401
- if ((this._textInput.value || '') !== textValue) {
402
- this._textInput.value = textValue;
403
- if (clearError) {
404
- this.errorMessage = null;
405
- }
406
- }
407
- }
408
- clearSearch() {
409
- this.value = null;
410
- }
411
- controlListWithOnlyOne() {
412
- var _a, _b;
413
- const source = (_a = this._visibleOptions) === null || _a === void 0 ? void 0 : _a.filter((opt) => opt.label !== "" && opt.value != undefined);
414
- if ((source === null || source === void 0 ? void 0 : source.length) > 0) {
415
- const startHighlight = new RegExp(this._startHighlightTag, 'g');
416
- const endHighlight = new RegExp(this._endHighlightTag, 'g');
417
- let title = core.StringUtils.decodeHtmlEntities(source[0].label);
418
- const option = {
419
- value: (_b = source[0].value) === null || _b === void 0 ? void 0 : _b.replace(startHighlight, '').replace(endHighlight, ''),
420
- label: title === null || title === void 0 ? void 0 : title.replace(startHighlight, '').replace(endHighlight, '')
421
- };
422
- this.selectOption(option);
423
- }
424
- }
425
- controlEmptySearch() {
426
- var _a;
427
- if (!((_a = this._visibleOptions) === null || _a === void 0 ? void 0 : _a.length)) {
428
- this.clearSearch();
429
- ApplicationUtils.ApplicationUtils.info(this._textEmptyList);
430
- }
431
- else {
432
- this.controlListWithOnlyOne();
433
- }
434
- }
435
- validateDescriptionValue() {
436
- if (core.StringUtils.isEmpty(this.value)) {
437
- return;
438
- }
439
- let value = this.value;
440
- if (typeof value === "object") {
441
- return;
442
- }
443
- if (core.StringUtils.isEmpty(value)) {
444
- return;
445
- }
446
- this.loadDescriptionValue(value);
447
- }
448
- async loadDescriptionValue(argument) {
449
- var _a, _b;
450
- if (argument == undefined) {
451
- return;
452
- }
453
- if (((_a = this.options) === null || _a === void 0 ? void 0 : _a.length) > 0) {
454
- this.loadOptionValue(argument);
455
- return;
456
- }
457
- const searchArgument = {
458
- mode: SearchMode.PREDICTIVE,
459
- argument
460
- };
461
- const source = await ((_b = this.optionLoader) === null || _b === void 0 ? void 0 : _b.call(this, searchArgument));
462
- if (source == undefined) {
463
- return;
464
- }
465
- if (source instanceof Promise) {
466
- source.then((result) => {
467
- this.setDescriptionValue(result);
468
- });
469
- }
470
- else {
471
- this.setDescriptionValue(source);
472
- }
473
- }
474
- setDescriptionValue(source) {
475
- const value = (source === null || source === void 0 ? void 0 : source[0]) || source;
476
- if (value == undefined || !Object.keys(value).length) {
477
- this.showNoResultMessage();
478
- return;
479
- }
480
- this._lookupMode = true;
481
- this.value = value;
482
- }
483
- loadOptionValue(argument) {
484
- var _a;
485
- const source = (_a = this.options) === null || _a === void 0 ? void 0 : _a.find((opt) => opt.value === argument);
486
- if (source != undefined) {
487
- this.selectOption(source);
488
- }
489
- else {
490
- this.showNoResultMessage();
491
- }
492
- }
493
- async showNoResultMessage() {
494
- this.clearSearch();
495
- ApplicationUtils.ApplicationUtils.info(this._textEmptySearch.replace("{0}", this.getFieldLabel()));
496
- }
497
- getFieldLabel() {
65
+ /*
66
+ * Retorna uma promise com o valor da opção selecionada,
67
+ * que será resolvida quando o backend devolver este dado.
68
+ */
69
+ async getValueAsync() {
498
70
  var _a;
499
- return (_a = this.label) === null || _a === void 0 ? void 0 : _a.replace(constants.REQUIRED_INFO, "").toUpperCase();
500
- }
501
- resetOptions() {
502
- this.hideOptions();
503
- this._criteria = undefined;
504
- this._preSelection = undefined;
505
- this.updateVisibleOptions();
71
+ return (_a = this._comboElement) === null || _a === void 0 ? void 0 : _a.getValueAsync();
506
72
  }
507
- //---------------------------------------------
508
- // Lifecycle web component
509
- //---------------------------------------------
510
- componentWillLoad() {
511
- if (this.options === undefined) {
512
- this.options = [];
513
- const optionsTags = this.el.querySelectorAll("option");
514
- if (optionsTags) {
515
- optionsTags.forEach(e => {
516
- let label = e.innerText;
517
- let value = e.getAttribute("value");
518
- let details = e.getAttribute("details");
519
- if (!value) {
520
- value = label;
521
- }
522
- this.options.push({ label, value, details });
523
- e.hidden = true;
524
- });
525
- }
73
+ onComboChange(event) {
74
+ event.stopPropagation();
75
+ this.value = event.detail;
76
+ this.ezChange.emit(event.detail);
77
+ if (this.errorMessage !== this._comboElement.errorMessage) {
78
+ this.errorMessage = this._comboElement.errorMessage;
526
79
  }
527
- this.updateSource([]);
528
- }
529
- componentDidRender() {
530
- var _a;
531
- if (this._floatingID === undefined) {
532
- this._listWrapper.remove();
533
- }
534
- (_a = this._optionsList) === null || _a === void 0 ? void 0 : _a.querySelectorAll(".item").forEach((elem) => {
535
- core.ElementIDUtils.addIDInfoIfNotExists(elem, "itemSearch");
536
- });
537
- this.validateDescriptionValue();
538
80
  }
539
81
  componentDidLoad() {
540
- CSSVarsUtils.CSSVarsUtils.applyVarsTextInput(this.el, this._textInput);
541
- this.setInputValue(false);
542
- this._resizeObserver = new ResizeObserver((entries) => {
543
- window.requestAnimationFrame(() => {
544
- if (!Array.isArray(entries) || !entries.length)
545
- return;
546
- const { clientWidth } = this._listContainer;
547
- if (clientWidth > 0 && !!this._listWrapper) {
548
- this._listWrapper.style.width = `${clientWidth}px`;
549
- }
550
- });
551
- });
552
- }
553
- //---------------------------------------------
554
- // Event handlers
555
- //---------------------------------------------
556
- handlerIconClick() {
557
- this.loadOptions(SearchMode.ADVANCED);
558
- }
559
- buildNumberArgument(argument) {
560
- if (this.isTextSearch) {
561
- return NaN;
562
- }
563
- return Number(argument || undefined);
564
- }
565
- onTextInputChangeHandler(event) {
566
- var _a;
567
- this.clearDeboucingTimeout();
568
- if (this._startLoading) {
569
- this._changeDeboucingTimeout = window.setTimeout(() => {
570
- this.onTextInputChangeHandler(event);
571
- }, this._deboucingTime);
572
- return;
573
- }
574
- const argument = (_a = event.target.value) === null || _a === void 0 ? void 0 : _a.trim();
575
- const argumentNumber = this.buildNumberArgument(argument);
576
- if (!this._criteria) {
577
- this._textInput.value = event.data || argument;
578
- }
579
- this._criteria = argument;
580
- if (argument) {
581
- this._showLoading = false;
582
- this.clearSource();
583
- if (!isNaN(argumentNumber) || argument.length >= this._limitCharsToSearch) {
584
- this._showLoading = true;
585
- this._changeDeboucingTimeout = window.setTimeout(() => {
586
- this.loadOptions(SearchMode.PREDICTIVE, isNaN(argumentNumber) ? argument : argumentNumber.toString());
587
- }, this._deboucingTime);
588
- this.showOptions();
589
- }
590
- else {
591
- this.hideOptions();
592
- }
593
- }
594
- else {
595
- this.hideOptions();
596
- this._showLoading = false;
597
- this.clearSource();
598
- }
599
- }
600
- clearDeboucingTimeout() {
601
- if (this._changeDeboucingTimeout) {
602
- window.clearTimeout(this._changeDeboucingTimeout);
603
- this._changeDeboucingTimeout = null;
604
- }
605
- }
606
- keyDownHandler(event) {
607
- this._tabPressed = false;
608
- if (event.ctrlKey) {
609
- if (event.key === "f" || event.key === "F") {
610
- this.loadOptions(SearchMode.ADVANCED);
611
- //ATENÇÃO: Ctrl + F tem ação específica nos browsers
612
- //nesse caso, como vamos abrir o popup de busca avançada,
613
- //não é interessante deixar o evento propagar;
614
- event.stopPropagation();
615
- event.stopImmediatePropagation();
616
- event.preventDefault();
617
- }
618
- }
619
- switch (event.key) {
620
- case "ArrowDown":
621
- this.nextOption();
622
- event.stopPropagation();
623
- break;
624
- case "ArrowUp":
625
- this.previousOption();
626
- event.stopPropagation();
627
- break;
628
- case "Enter":
629
- this.selectCurrentOption();
630
- break;
631
- case "Escape":
632
- this.cancelPreselection();
633
- break;
634
- case "Tab":
635
- this._tabPressed = true;
636
- this.controlListWithOnlyOne();
637
- break;
638
- }
639
- //ATENÇÃO: Existe a necessidade de propagar o evento de teclado.
640
- //Por exemplo, quando o usuário dá um Enter, além de selecionar
641
- //um valor, também significa que a ateração finalizou,
642
- //e o contexto pode reagir (fechar um popup por exemplo).
643
- //event.stopPropagation();
644
- }
645
- onTextInputFocusOutHandler() {
646
- if (this.hideErrorOnFocusOut)
647
- this.cancelPreselection();
648
- }
649
- canShowListOptions() {
650
- return !this._showLoading && this._visibleOptions.length > 0;
82
+ CSSVarsUtils.CSSVarsUtils.applyVarsTextInput(this._elem, this._comboElement);
651
83
  }
652
84
  render() {
653
- var _a;
654
- core.ElementIDUtils.addIDInfoIfNotExists(this.el, 'input');
655
- return (index.h(index.Host, null, index.h("ez-text-input", { "data-element-id": core.ElementIDUtils.getInternalIDInfo("textInput"), class: this.suppressSearch ? "suppressed-search-input" : "", ref: elem => this._textInput = elem, "data-slave-mode": "true", enabled: this.enabled && !this.suppressSearch, onInput: event => this.onTextInputChangeHandler(event), onFocusout: () => this.onTextInputFocusOutHandler(), onKeyDown: event => this.keyDownHandler(event), label: this.label, canShowError: this.canShowError, errorMessage: this.errorMessage, mode: this.mode }, index.h("button", { class: "btn", slot: "leftIcon", disabled: !this.enabled, tabindex: -1, onClick: () => this.handlerIconClick() }, index.h("ez-icon", { iconName: "search" })), ((_a = this._textInput) === null || _a === void 0 ? void 0 : _a.value) && (this._criteria || this.value)
656
- ? index.h("button", { class: "btn btn__close", slot: "rightIcon", disabled: !this.enabled, tabindex: -1, onClick: () => this.clearSearch() }, index.h("ez-icon", { iconName: "close" }))
657
- : undefined), index.h("section", { class: "list-container", ref: elem => this._listContainer = elem }, index.h("div", { class: "list-wrapper", ref: elem => this._listWrapper = elem }, index.h("ul", { class: "list-options", ref: elem => this._optionsList = elem }, !this._showLoading
658
- && this._visibleOptions.length === 0
659
- && index.h("div", { class: "message" }, index.h("span", { class: "message__no-result" }, this._textEmptyList)), this._showLoading
660
- && index.h("div", { class: "message" }, index.h("div", { class: "message__loading" })), index.h("span", { class: "item__value item__value--hidden", ref: elem => this._itemValueBasis = elem }), this.canShowListOptions() && this._visibleOptions.map((opt, index) => this.buildItem(opt, index)))))));
85
+ core.ElementIDUtils.addIDInfoIfNotExists(this._elem, 'input');
86
+ return (index.h("ez-combo-box", { "data-element-id": core.ElementIDUtils.getInternalIDInfo("combo"), ref: elem => this._comboElement = elem, value: this.value, label: this.label, enabled: this.enabled, errorMessage: this.errorMessage, hideErrorOnFocusOut: this.hideErrorOnFocusOut, optionLoader: this.optionLoader, searchMode: true, onEzChange: event => this.onComboChange(event), showSelectedValue: this.showSelectedValue, showOptionValue: this.showOptionValue, suppressEmptyOption: this.suppressEmptyOption, mode: this.mode, canShowError: this.canShowError, listOptionsPosition: this.listOptionsPosition, isTextSearch: this.isTextSearch, limitCharsToSearch: this.ignoreLimitCharsToSearch ? 0 : 3 }));
661
87
  }
662
- get el() { return index.getElement(this); }
88
+ ;
89
+ get _elem() { return index.getElement(this); }
663
90
  static get watchers() { return {
664
91
  "errorMessage": ["observeErrorMessage"],
665
- "value": ["observeValue"],
666
- "options": ["observeOptions"]
92
+ "value": ["observeValue"]
667
93
  }; }
668
94
  };
669
- var SearchMode;
670
- (function (SearchMode) {
671
- SearchMode["ADVANCED"] = "ADVANCED";
672
- SearchMode["PRELOAD"] = "PRELOAD";
673
- SearchMode["PREDICTIVE"] = "PREDICTIVE";
674
- })(SearchMode || (SearchMode = {}));
675
95
  EzSearch.style = ezSearchCss;
676
96
 
677
97
  exports.ez_search = EzSearch;