@sankhyalabs/ezui 5.22.0-dev.37 → 5.22.0-dev.39

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 (221) hide show
  1. package/dist/cjs/DataBinder-aff1dcc7.js +445 -0
  2. package/dist/cjs/FocusResolver-885f2173.js +35 -0
  3. package/dist/cjs/ez-actions-button.cjs.entry.js +1 -1
  4. package/dist/cjs/ez-alert-list.cjs.entry.js +1 -1
  5. package/dist/cjs/ez-alert.cjs.entry.js +1 -1
  6. package/dist/cjs/ez-application.cjs.entry.js +1 -1
  7. package/dist/cjs/ez-badge.cjs.entry.js +1 -1
  8. package/dist/cjs/ez-breadcrumb.cjs.entry.js +1 -1
  9. package/dist/cjs/ez-button.cjs.entry.js +1 -1
  10. package/dist/cjs/ez-calendar.cjs.entry.js +1 -1
  11. package/dist/cjs/ez-card-item_3.cjs.entry.js +9 -3
  12. package/dist/cjs/ez-chart.cjs.entry.js +1 -1
  13. package/dist/cjs/ez-check.cjs.entry.js +1 -1
  14. package/dist/cjs/ez-chip.cjs.entry.js +1 -1
  15. package/dist/cjs/ez-collapsible-box.cjs.entry.js +1 -1
  16. package/dist/cjs/ez-combo-box.cjs.entry.js +47 -11
  17. package/dist/cjs/ez-custom-form-input_2.cjs.entry.js +2 -2
  18. package/dist/cjs/ez-date-input.cjs.entry.js +9 -3
  19. package/dist/cjs/ez-date-time-input.cjs.entry.js +9 -3
  20. package/dist/cjs/ez-dialog.cjs.entry.js +10 -2
  21. package/dist/cjs/ez-dropdown_2.cjs.entry.js +1 -1
  22. package/dist/cjs/ez-file-item.cjs.entry.js +1 -1
  23. package/dist/cjs/ez-form-view.cjs.entry.js +1 -1
  24. package/dist/cjs/ez-form.cjs.entry.js +4 -325
  25. package/dist/cjs/ez-grid.cjs.entry.js +255 -63
  26. package/dist/cjs/ez-guide-navigator.cjs.entry.js +1 -1
  27. package/dist/cjs/ez-icon.cjs.entry.js +1 -1
  28. package/dist/cjs/ez-list.cjs.entry.js +1 -1
  29. package/dist/cjs/ez-loading-bar.cjs.entry.js +1 -1
  30. package/dist/cjs/ez-modal-container.cjs.entry.js +1 -1
  31. package/dist/cjs/ez-modal.cjs.entry.js +1 -1
  32. package/dist/cjs/ez-multi-selection-list.cjs.entry.js +1 -1
  33. package/dist/cjs/ez-number-input.cjs.entry.js +8 -1
  34. package/dist/cjs/ez-popover.cjs.entry.js +1 -1
  35. package/dist/cjs/ez-popup.cjs.entry.js +1 -1
  36. package/dist/cjs/ez-radio-button.cjs.entry.js +1 -1
  37. package/dist/cjs/ez-scroller_2.cjs.entry.js +1 -1
  38. package/dist/cjs/ez-search.cjs.entry.js +29 -13
  39. package/dist/cjs/ez-sidebar-navigator.cjs.entry.js +1 -1
  40. package/dist/cjs/ez-split-button.cjs.entry.js +1 -1
  41. package/dist/cjs/ez-split-item.cjs.entry.js +1 -1
  42. package/dist/cjs/ez-split-panel.cjs.entry.js +1 -1
  43. package/dist/cjs/ez-tabselector.cjs.entry.js +1 -1
  44. package/dist/cjs/ez-text-area.cjs.entry.js +7 -1
  45. package/dist/cjs/ez-text-input.cjs.entry.js +8 -2
  46. package/dist/cjs/ez-time-input.cjs.entry.js +7 -1
  47. package/dist/cjs/ez-toast.cjs.entry.js +1 -1
  48. package/dist/cjs/ez-tree.cjs.entry.js +1 -1
  49. package/dist/cjs/ez-upload.cjs.entry.js +1 -1
  50. package/dist/cjs/ez-view-stack.cjs.entry.js +1 -1
  51. package/dist/cjs/ezui.cjs.js +2 -2
  52. package/dist/cjs/filter-column.cjs.entry.js +1 -1
  53. package/dist/cjs/{index-a7b0c73d.js → index-9e5554cb.js} +3 -0
  54. package/dist/cjs/loader.cjs.js +2 -2
  55. package/dist/collection/collection-manifest.json +1 -1
  56. package/dist/collection/components/ez-combo-box/ez-combo-box.js +75 -14
  57. package/dist/collection/components/ez-date-input/ez-date-input.js +35 -4
  58. package/dist/collection/components/ez-date-time-input/ez-date-time-input.js +35 -4
  59. package/dist/collection/components/ez-dialog/ez-dialog.js +9 -1
  60. package/dist/collection/components/ez-filter-input/ez-filter-input.js +35 -4
  61. package/dist/collection/components/ez-grid/controller/ag-grid/AgGridController.js +52 -14
  62. package/dist/collection/components/ez-grid/controller/ag-grid/DataSource.js +3 -0
  63. package/dist/collection/components/ez-grid/controller/ag-grid/GridEditionManager.js +166 -45
  64. package/dist/collection/components/ez-grid/controller/ag-grid/components/EzGridCustomCellEditor.js +7 -0
  65. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/ComboBox.tpl.js +1 -0
  66. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/DateInput.tpl.js +1 -0
  67. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/NumberInput.tpl.js +1 -0
  68. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/Search.tpl.js +1 -0
  69. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/TextInput.tpl.js +4 -1
  70. package/dist/collection/components/ez-grid/ez-grid.js +83 -1
  71. package/dist/collection/components/ez-number-input/ez-number-input.js +25 -0
  72. package/dist/collection/components/ez-search/ez-search.js +55 -14
  73. package/dist/collection/components/ez-text-area/ez-text-area.js +24 -0
  74. package/dist/collection/components/ez-text-input/ez-text-input.css +14 -38
  75. package/dist/collection/components/ez-text-input/ez-text-input.js +24 -0
  76. package/dist/collection/components/ez-time-input/ez-time-input.js +24 -0
  77. package/dist/collection/utils/FocusResolver.js +31 -0
  78. package/dist/collection/utils/form/DataBinder.js +18 -3
  79. package/dist/custom-elements/index.js +443 -103
  80. package/dist/esm/DataBinder-bd240826.js +441 -0
  81. package/dist/esm/FocusResolver-1ccbf850.js +33 -0
  82. package/dist/esm/ez-actions-button.entry.js +1 -1
  83. package/dist/esm/ez-alert-list.entry.js +1 -1
  84. package/dist/esm/ez-alert.entry.js +1 -1
  85. package/dist/esm/ez-application.entry.js +1 -1
  86. package/dist/esm/ez-badge.entry.js +1 -1
  87. package/dist/esm/ez-breadcrumb.entry.js +1 -1
  88. package/dist/esm/ez-button.entry.js +1 -1
  89. package/dist/esm/ez-calendar.entry.js +1 -1
  90. package/dist/esm/ez-card-item_3.entry.js +9 -3
  91. package/dist/esm/ez-chart.entry.js +1 -1
  92. package/dist/esm/ez-check.entry.js +1 -1
  93. package/dist/esm/ez-chip.entry.js +1 -1
  94. package/dist/esm/ez-collapsible-box.entry.js +1 -1
  95. package/dist/esm/ez-combo-box.entry.js +48 -12
  96. package/dist/esm/ez-custom-form-input_2.entry.js +2 -2
  97. package/dist/esm/ez-date-input.entry.js +9 -3
  98. package/dist/esm/ez-date-time-input.entry.js +9 -3
  99. package/dist/esm/ez-dialog.entry.js +10 -2
  100. package/dist/esm/ez-dropdown_2.entry.js +1 -1
  101. package/dist/esm/ez-file-item.entry.js +1 -1
  102. package/dist/esm/ez-form-view.entry.js +1 -1
  103. package/dist/esm/ez-form.entry.js +3 -324
  104. package/dist/esm/ez-grid.entry.js +254 -62
  105. package/dist/esm/ez-guide-navigator.entry.js +1 -1
  106. package/dist/esm/ez-icon.entry.js +1 -1
  107. package/dist/esm/ez-list.entry.js +1 -1
  108. package/dist/esm/ez-loading-bar.entry.js +1 -1
  109. package/dist/esm/ez-modal-container.entry.js +1 -1
  110. package/dist/esm/ez-modal.entry.js +1 -1
  111. package/dist/esm/ez-multi-selection-list.entry.js +1 -1
  112. package/dist/esm/ez-number-input.entry.js +8 -1
  113. package/dist/esm/ez-popover.entry.js +1 -1
  114. package/dist/esm/ez-popup.entry.js +1 -1
  115. package/dist/esm/ez-radio-button.entry.js +1 -1
  116. package/dist/esm/ez-scroller_2.entry.js +1 -1
  117. package/dist/esm/ez-search.entry.js +29 -13
  118. package/dist/esm/ez-sidebar-navigator.entry.js +1 -1
  119. package/dist/esm/ez-split-button.entry.js +1 -1
  120. package/dist/esm/ez-split-item.entry.js +1 -1
  121. package/dist/esm/ez-split-panel.entry.js +1 -1
  122. package/dist/esm/ez-tabselector.entry.js +1 -1
  123. package/dist/esm/ez-text-area.entry.js +7 -1
  124. package/dist/esm/ez-text-input.entry.js +8 -2
  125. package/dist/esm/ez-time-input.entry.js +7 -1
  126. package/dist/esm/ez-toast.entry.js +1 -1
  127. package/dist/esm/ez-tree.entry.js +1 -1
  128. package/dist/esm/ez-upload.entry.js +1 -1
  129. package/dist/esm/ez-view-stack.entry.js +1 -1
  130. package/dist/esm/ezui.js +3 -3
  131. package/dist/esm/filter-column.entry.js +1 -1
  132. package/dist/esm/{index-baa5e267.js → index-5a720e56.js} +3 -1
  133. package/dist/esm/loader.js +3 -3
  134. package/dist/ezui/ezui.esm.js +1 -1
  135. package/dist/ezui/{p-44caad9a.entry.js → p-0378416a.entry.js} +1 -1
  136. package/dist/ezui/{p-5b205c80.entry.js → p-044d46d5.entry.js} +1 -1
  137. package/dist/ezui/p-076e868b.entry.js +1 -0
  138. package/dist/ezui/{p-b54e17d2.entry.js → p-0e1cc2d1.entry.js} +1 -1
  139. package/dist/ezui/{p-1285c902.entry.js → p-11b09aa1.entry.js} +1 -1
  140. package/dist/ezui/{p-77a4bd35.entry.js → p-11bfeca3.entry.js} +1 -1
  141. package/dist/ezui/p-16e21a40.entry.js +1 -0
  142. package/dist/ezui/{p-8888d9ed.entry.js → p-1b08bf3c.entry.js} +1 -1
  143. package/dist/ezui/p-2c3ac210.entry.js +1 -0
  144. package/dist/ezui/{p-abce5219.entry.js → p-2de9f0aa.entry.js} +1 -1
  145. package/dist/ezui/{p-baf80b13.entry.js → p-30951bd7.entry.js} +1 -1
  146. package/dist/ezui/{p-a2e5b8c3.entry.js → p-3b546374.entry.js} +1 -1
  147. package/dist/ezui/{p-37219d42.entry.js → p-3cc9b84a.entry.js} +1 -1
  148. package/dist/ezui/p-3d38bfea.entry.js +1 -0
  149. package/dist/ezui/{p-7bc07c31.entry.js → p-3f8c33e0.entry.js} +1 -1
  150. package/dist/ezui/{p-cdc472cc.entry.js → p-52100a6e.entry.js} +1 -1
  151. package/dist/ezui/{p-6d79930d.entry.js → p-554522db.entry.js} +1 -1
  152. package/dist/ezui/{p-1f50fa05.entry.js → p-6b51c9cc.entry.js} +1 -1
  153. package/dist/ezui/p-6bc25bc8.entry.js +1 -0
  154. package/dist/ezui/p-6ec40dec.entry.js +1 -0
  155. package/dist/ezui/{p-5ed81457.entry.js → p-6fc26622.entry.js} +1 -1
  156. package/dist/ezui/{p-f9e551de.entry.js → p-70f1c812.entry.js} +1 -1
  157. package/dist/ezui/{p-555c9018.entry.js → p-7567ccdd.entry.js} +1 -1
  158. package/dist/ezui/{p-bfad39eb.entry.js → p-7f5afb1f.entry.js} +1 -1
  159. package/dist/ezui/p-802dc63e.entry.js +1 -0
  160. package/dist/ezui/{p-1e7a8633.entry.js → p-81461d2f.entry.js} +1 -1
  161. package/dist/ezui/p-81f06699.js +1 -0
  162. package/dist/ezui/{p-8df1ca33.entry.js → p-82fa4b09.entry.js} +1 -1
  163. package/dist/ezui/{p-bcb53f27.entry.js → p-868b56f7.entry.js} +1 -1
  164. package/dist/ezui/{p-09de35a2.entry.js → p-91ccae0c.entry.js} +1 -1
  165. package/dist/ezui/{p-c0d9c4f8.entry.js → p-92748142.entry.js} +1 -1
  166. package/dist/ezui/p-940760bf.entry.js +1 -0
  167. package/dist/ezui/{p-c4320a39.entry.js → p-a563df31.entry.js} +1 -1
  168. package/dist/ezui/{p-990b4318.entry.js → p-a921e3e7.entry.js} +1 -1
  169. package/dist/ezui/{p-17be134a.entry.js → p-b2f6bc0a.entry.js} +1 -1
  170. package/dist/ezui/{p-c3045972.entry.js → p-b858fc6e.entry.js} +1 -1
  171. package/dist/ezui/p-be34c77f.entry.js +1 -0
  172. package/dist/ezui/{p-e347df9c.entry.js → p-bef7daac.entry.js} +1 -1
  173. package/dist/ezui/p-bfc30e61.entry.js +1 -0
  174. package/dist/ezui/p-bfc59380.entry.js +1 -0
  175. package/dist/ezui/{p-9f5fa3f9.entry.js → p-c2b20f78.entry.js} +1 -1
  176. package/dist/ezui/p-dc628ed3.js +1 -0
  177. package/dist/ezui/{p-a80b1287.entry.js → p-dfca5946.entry.js} +1 -1
  178. package/dist/ezui/{p-7fdd479f.entry.js → p-e18d9e6a.entry.js} +1 -1
  179. package/dist/ezui/{p-9d9ecb7c.entry.js → p-e3ec7422.entry.js} +1 -1
  180. package/dist/ezui/{p-23a36bb6.js → p-e4c7eb39.js} +2 -2
  181. package/dist/ezui/{p-0306dff7.entry.js → p-e6b38ade.entry.js} +1 -1
  182. package/dist/ezui/{p-90bcd2ba.entry.js → p-e7395eae.entry.js} +1 -1
  183. package/dist/ezui/{p-650e4b6d.entry.js → p-f1c2c19e.entry.js} +1 -1
  184. package/dist/ezui/{p-6e429cff.entry.js → p-fc194825.entry.js} +1 -1
  185. package/dist/ezui/{p-c3c3d640.entry.js → p-fc8b1807.entry.js} +2 -2
  186. package/dist/ezui/p-fe10f986.entry.js +1 -0
  187. package/dist/types/components/ez-combo-box/ez-combo-box.d.ts +7 -1
  188. package/dist/types/components/ez-date-input/ez-date-input.d.ts +6 -1
  189. package/dist/types/components/ez-date-time-input/ez-date-time-input.d.ts +6 -1
  190. package/dist/types/components/ez-dialog/ez-dialog.d.ts +2 -0
  191. package/dist/types/components/ez-filter-input/ez-filter-input.d.ts +6 -1
  192. package/dist/types/components/ez-grid/controller/EzGridController.d.ts +10 -0
  193. package/dist/types/components/ez-grid/controller/ag-grid/AgGridController.d.ts +4 -0
  194. package/dist/types/components/ez-grid/controller/ag-grid/GridEditionManager.d.ts +18 -6
  195. package/dist/types/components/ez-grid/controller/ag-grid/components/EzGridCustomCellEditor.d.ts +2 -0
  196. package/dist/types/components/ez-grid/controller/ag-grid/editor/IUICellEditor.d.ts +1 -0
  197. package/dist/types/components/ez-grid/ez-grid.d.ts +10 -0
  198. package/dist/types/components/ez-number-input/ez-number-input.d.ts +4 -0
  199. package/dist/types/components/ez-search/ez-search.d.ts +6 -1
  200. package/dist/types/components/ez-text-area/ez-text-area.d.ts +4 -0
  201. package/dist/types/components/ez-text-input/ez-text-input.d.ts +4 -0
  202. package/dist/types/components/ez-time-input/ez-time-input.d.ts +4 -0
  203. package/dist/types/components.d.ts +91 -6
  204. package/dist/types/utils/FocusResolver.d.ts +5 -0
  205. package/dist/types/utils/form/DataBinder.d.ts +3 -0
  206. package/package.json +1 -1
  207. package/dist/cjs/RecordValidationProcessor-10846595.js +0 -108
  208. package/dist/esm/RecordValidationProcessor-9c6cc267.js +0 -105
  209. package/dist/ezui/p-0f3b2e67.entry.js +0 -1
  210. package/dist/ezui/p-10820c20.entry.js +0 -1
  211. package/dist/ezui/p-49456b34.entry.js +0 -1
  212. package/dist/ezui/p-5a90d7d1.entry.js +0 -1
  213. package/dist/ezui/p-62732269.entry.js +0 -1
  214. package/dist/ezui/p-b3b94f72.entry.js +0 -1
  215. package/dist/ezui/p-b95632e8.entry.js +0 -1
  216. package/dist/ezui/p-bc2f844e.entry.js +0 -1
  217. package/dist/ezui/p-c25f0e92.entry.js +0 -1
  218. package/dist/ezui/p-d2c06f38.entry.js +0 -1
  219. package/dist/ezui/p-e85c48d7.entry.js +0 -1
  220. package/dist/ezui/p-f299c608.entry.js +0 -1
  221. package/dist/ezui/p-f42855b9.js +0 -1
@@ -0,0 +1,445 @@
1
+ 'use strict';
2
+
3
+ const core = require('@sankhyalabs/core');
4
+ const ApplicationUtils = require('./ApplicationUtils-c9d1205c.js');
5
+
6
+ const buildFieldMetadata = (descriptor, config) => {
7
+ let { name, label, group } = Object.assign({}, config);
8
+ let { readOnly, required } = Object.assign({}, config);
9
+ let props;
10
+ let userInterface;
11
+ if (descriptor) {
12
+ label = label || descriptor.label;
13
+ name = name || descriptor.name;
14
+ required = descriptor.required || (config === null || config === void 0 ? void 0 : config.required);
15
+ readOnly = descriptor.readOnly || (config === null || config === void 0 ? void 0 : config.readOnly);
16
+ props = descriptor.properties;
17
+ userInterface = descriptor.userInterface;
18
+ }
19
+ return {
20
+ name, label, group,
21
+ readOnly, required,
22
+ props,
23
+ userInterface: userInterface || core.UserInterface.SHORTTEXT
24
+ };
25
+ };
26
+
27
+ class RecordValidationProcessor {
28
+ constructor(dataUnit, validationSource, validator) {
29
+ this._dataUnit = dataUnit;
30
+ this._validationSource = validationSource;
31
+ this._validator = validator;
32
+ }
33
+ validate(isSaving = true) {
34
+ return new Promise((accept, reject) => {
35
+ const records = this._dataUnit.getModifiedRecords();
36
+ for (let i = 0; i < records.length; i++) {
37
+ const record = records[i];
38
+ const invalidResults = [];
39
+ let validationResult = this.validateRequired(record);
40
+ if (validationResult && !validationResult.isValid) {
41
+ invalidResults.push(validationResult);
42
+ }
43
+ if (this._validator) {
44
+ validationResult = this._validator.validateRecord(record);
45
+ if (validationResult && !validationResult.isValid) {
46
+ invalidResults.push(validationResult);
47
+ }
48
+ }
49
+ if (invalidResults.length > 0) {
50
+ if (!isSaving && invalidResults[0].invalidFields.length > 0) {
51
+ this._validationSource.markAsInvalid(invalidResults[0].invalidFields[0], record.__record__id__);
52
+ reject();
53
+ break;
54
+ }
55
+ this.processValidationResult(invalidResults, record.__record__id__);
56
+ reject();
57
+ break;
58
+ }
59
+ }
60
+ return accept();
61
+ });
62
+ }
63
+ validateRequired(record) {
64
+ const requiredFields = this._validationSource.getRequiredFields();
65
+ const invalidFields = [];
66
+ new Set(requiredFields).forEach(field => {
67
+ const value = record[field];
68
+ if (value == undefined || value === "") {
69
+ const errorMessage = this._validationSource.getMessageForField(field, record.__record__id__);
70
+ if (errorMessage) {
71
+ invalidFields.push({ name: field, message: errorMessage });
72
+ }
73
+ else {
74
+ invalidFields.push({ name: field, message: "Essa informação é obrigatória" });
75
+ }
76
+ }
77
+ });
78
+ if (invalidFields.length > 0) {
79
+ return { isValid: false, invalidFields, infoMessage: "Há pelo menos um campo obrigatório não preenchido." };
80
+ }
81
+ return undefined;
82
+ }
83
+ processValidationResult(validationResult, recordId) {
84
+ validationResult.forEach(invalidResult => {
85
+ const invalidFields = invalidResult.invalidFields;
86
+ this._dataUnit.savingCanceled(invalidFields, recordId);
87
+ if (invalidFields) {
88
+ invalidFields.forEach(field => {
89
+ this.markAsInvalid(field, recordId);
90
+ });
91
+ }
92
+ if (invalidResult.infoMessage) {
93
+ ApplicationUtils.ApplicationUtils.info(invalidResult.infoMessage);
94
+ }
95
+ if (invalidResult.errorMessage) {
96
+ const { errorTitle, errorMessage } = invalidResult;
97
+ ApplicationUtils.ApplicationUtils.error(errorTitle, errorMessage);
98
+ }
99
+ });
100
+ }
101
+ markAsInvalid(field, recordId) {
102
+ this._dataUnit.setInvalidField(field.name, field.message, recordId);
103
+ this._validationSource.markAsInvalid(field, recordId);
104
+ }
105
+ }
106
+
107
+ class DataBinder {
108
+ constructor(dataUnit) {
109
+ this.onDataUnitEvent = (action) => {
110
+ var _a, _b;
111
+ switch (action.type) {
112
+ case core.Action.DATA_LOADED:
113
+ case core.Action.DATA_SAVED:
114
+ case core.Action.RECORDS_REMOVED:
115
+ case core.Action.RECORDS_ADDED:
116
+ case core.Action.RECORDS_COPIED:
117
+ case core.Action.EDITION_CANCELED:
118
+ case core.Action.SELECTION_CHANGED:
119
+ case core.Action.NEXT_SELECTED:
120
+ case core.Action.PREVIOUS_SELECTED:
121
+ this.clearInvalid();
122
+ case core.Action.DATA_CHANGED:
123
+ case core.Action.CHANGE_UNDONE:
124
+ case core.Action.CHANGE_REDONE:
125
+ case core.Action.RECORD_LOADED:
126
+ (_a = this._fields) === null || _a === void 0 ? void 0 : _a.forEach(field => {
127
+ this.updateValue(field.fieldName, field.field);
128
+ });
129
+ this.clearFieldError(Object.keys(action.payload)[0]);
130
+ break;
131
+ case core.Action.FIELD_INVALIDATED:
132
+ (_b = this._fields) === null || _b === void 0 ? void 0 : _b.forEach(field => {
133
+ this.updateErrorMessage(field.fieldName, field.field);
134
+ });
135
+ break;
136
+ }
137
+ };
138
+ this._uuid = core.StringUtils.generateUUID();
139
+ this._fields = new Map();
140
+ this._dataUnit = dataUnit;
141
+ this.applyDefaultValues();
142
+ this._dataUnit.subscribe(this.onDataUnitEvent);
143
+ this._dataUnit.addInterceptor(this);
144
+ this.setContextDataBinder(dataUnit);
145
+ }
146
+ get dataBinderId() {
147
+ return this._uuid;
148
+ }
149
+ setContextDataBinder(dataUnit) {
150
+ const dataBindersByDataUnit = core.ApplicationContext.getContextValue("__DATABINDER_BY_DATAUNIT__") || new Map();
151
+ const dataBinders = [...(dataBindersByDataUnit.get(dataUnit.dataUnitId) || []), this];
152
+ dataBindersByDataUnit.set(dataUnit.dataUnitId, dataBinders);
153
+ core.ApplicationContext.setContextValue("__DATABINDER_BY_DATAUNIT__", dataBindersByDataUnit);
154
+ }
155
+ applyDefaultValues() {
156
+ const recordIds = (this._dataUnit.getAddedRecords() || []).map(r => r.__record__id__);
157
+ if (recordIds.length > 0) {
158
+ const defaultValues = this.getDefaultValues();
159
+ if (defaultValues) {
160
+ Object.keys(defaultValues).forEach(field => {
161
+ this._dataUnit.setFieldValue(field, defaultValues[field], recordIds);
162
+ });
163
+ }
164
+ }
165
+ }
166
+ bind(fields, currentContextName, formMetadata, recordsValidator) {
167
+ fields.forEach(fieldElement => {
168
+ const { fieldName, contextName } = fieldElement.dataset;
169
+ if (contextName == undefined || contextName === currentContextName) {
170
+ this.updateBind(fieldName, fieldElement);
171
+ }
172
+ });
173
+ this._formMetadata = formMetadata;
174
+ this._recordValidatorProcessor = new RecordValidationProcessor(this._dataUnit, {
175
+ getRequiredFields: () => this.getFormRequiredFields(),
176
+ markAsInvalid: field => this.markInvalid(field),
177
+ getMessageForField: field => this.getErrorMessage(field),
178
+ }, recordsValidator);
179
+ }
180
+ getFormRequiredFields() {
181
+ return this._formMetadata.getRequiredFields();
182
+ }
183
+ disconnectDataUnit() {
184
+ const dataBindersByDataUnit = core.ApplicationContext.getContextValue("__DATABINDER_BY_DATAUNIT__") || new Map();
185
+ const dataBinders = dataBindersByDataUnit.get(this._dataUnit.dataUnitId);
186
+ const dataBindersFiltered = dataBinders.filter((dataBinder) => dataBinder.dataBinderId !== this.dataBinderId);
187
+ dataBindersByDataUnit.set(this._dataUnit.dataUnitId, dataBindersFiltered);
188
+ core.ApplicationContext.setContextValue("__DATABINDER_BY_DATAUNIT__", dataBindersByDataUnit);
189
+ }
190
+ onDisconnectedCallback() {
191
+ this._dataUnit.unsubscribe(this.onDataUnitEvent);
192
+ this._dataUnit.removeInterceptor(this);
193
+ this.disconnectDataUnit();
194
+ }
195
+ getCurrentRecordId() {
196
+ const record = this._dataUnit.getSelectedRecord();
197
+ return record === null || record === void 0 ? void 0 : record.__record__id__;
198
+ }
199
+ markInvalid(field) {
200
+ if (this._fields.has(field.name)) {
201
+ const fieldElement = this._fields.get(field.name).field;
202
+ this.updateErrorMessage(field.name, fieldElement, field.message);
203
+ }
204
+ }
205
+ setFocus(fieldName) {
206
+ if (!this._fields.has(fieldName)) {
207
+ return;
208
+ }
209
+ const fieldElement = this._fields.get(fieldName).field;
210
+ if (typeof fieldElement["setFocus"] != "function") {
211
+ return;
212
+ }
213
+ fieldElement["setFocus"]();
214
+ }
215
+ clearInvalid(recordId) {
216
+ this._dataUnit.clearInvalid(recordId);
217
+ this._fields.forEach(fieldBinder => {
218
+ const fieldElement = fieldBinder.field;
219
+ fieldElement["errorMessage"] = "";
220
+ });
221
+ }
222
+ clearFieldError(fieldName) {
223
+ var _a;
224
+ const field = (_a = this._fields.get(fieldName)) === null || _a === void 0 ? void 0 : _a.field;
225
+ if (field["errorMessage"]) {
226
+ field["errorMessage"] = "";
227
+ this._dataUnit.clearInvalid(this.getCurrentRecordId(), fieldName);
228
+ }
229
+ }
230
+ updateValue(fieldName, field) {
231
+ const bind = this._fields.get(fieldName);
232
+ try {
233
+ if (bind) {
234
+ bind.listen = false;
235
+ }
236
+ field["value"] = this._dataUnit.getFieldValue(fieldName);
237
+ this.updateErrorMessage(fieldName, field);
238
+ }
239
+ finally {
240
+ if (bind) {
241
+ bind.listen = true;
242
+ }
243
+ }
244
+ }
245
+ validate() {
246
+ return this._recordValidatorProcessor.validate();
247
+ }
248
+ static async validateByDataunit(dataUnit) {
249
+ try {
250
+ const dataBinders = this.getDataBindersByDataUnit(dataUnit);
251
+ await Promise.all(dataBinders.map((dataBinder) => dataBinder.validate()));
252
+ return true;
253
+ }
254
+ catch (_a) {
255
+ return false;
256
+ }
257
+ }
258
+ static getDataBindersByDataUnit(dataUnit) {
259
+ const dataBindersByDataUnit = core.ApplicationContext.getContextValue("__DATABINDER_BY_DATAUNIT__");
260
+ return dataBindersByDataUnit.get(dataUnit.dataUnitId) || [];
261
+ }
262
+ updateErrorMessage(fieldName, field, message) {
263
+ if (message == undefined) {
264
+ message = this._dataUnit.getInvalidMessage(this.getCurrentRecordId(), fieldName);
265
+ }
266
+ if (!field["errorMessage"]) {
267
+ field["errorMessage"] = message;
268
+ }
269
+ }
270
+ getErrorMessage(fieldName) {
271
+ if (this._fields.has(fieldName)) {
272
+ const fieldElement = this._fields.get(fieldName).field;
273
+ return fieldElement["errorMessage"];
274
+ }
275
+ return undefined;
276
+ }
277
+ updateBind(fieldName, field) {
278
+ const oldBind = this._fields.get(fieldName);
279
+ if (oldBind) {
280
+ oldBind.destroy();
281
+ }
282
+ this.bindSearchOptionsLoader(fieldName, field);
283
+ field["value"] = this._dataUnit.getFieldValue(fieldName);
284
+ this.updateErrorMessage(fieldName, field);
285
+ this._fields.set(fieldName, Bind.create(fieldName, field, (fieldName, waitingChange) => this.changeStarted(fieldName, waitingChange), (fieldName) => this.cancelWaitingChange(fieldName), (fieldName, newValue) => this.setFieldValue(fieldName, newValue)));
286
+ this.applyEzUploadContext(fieldName, field);
287
+ }
288
+ changeStarted(fieldName, waitingChange) {
289
+ /**
290
+ * se o waitingChange não é blocante, add um event listener pra
291
+ * fazer o accept da promise
292
+ *
293
+ * se não tiver promise no waitingChange, eu crio uma e resolvo no bind
294
+ *
295
+ *
296
+ */
297
+ if (this._dataUnit.records.length === 0) {
298
+ this._dataUnit.addRecord();
299
+ }
300
+ if (!waitingChange.blocking && waitingChange.promise == undefined) {
301
+ const bind = this._fields.get(fieldName);
302
+ if (bind) {
303
+ waitingChange.promise = new Promise((resolve, reject) => {
304
+ bind.waitingChangePromiseResolve = resolve;
305
+ bind.waitingChangePromiseReject = reject;
306
+ });
307
+ }
308
+ }
309
+ this._dataUnit.startChange(fieldName, waitingChange);
310
+ }
311
+ cancelWaitingChange(fieldName) {
312
+ if (this._dataUnit.waitingForChange(fieldName)) {
313
+ this._dataUnit.cancelWaitingChange(fieldName);
314
+ const bind = this._fields.get(fieldName);
315
+ if (bind) {
316
+ bind.rejectWaitingChange(new core.WaitingChangeException("Change canceled", fieldName));
317
+ }
318
+ }
319
+ }
320
+ setFieldValue(fieldName, newValue) {
321
+ if (this._dataUnit.records.length === 0) {
322
+ this._dataUnit.addRecord();
323
+ }
324
+ this._dataUnit.clearInvalid(this.getCurrentRecordId(), fieldName);
325
+ const record = this._dataUnit.getSelectedRecord();
326
+ this._dataUnit.setFieldValue(fieldName, newValue, record ? [record.__record__id__] : undefined);
327
+ if (this._dataUnit.waitingForChange(fieldName)) {
328
+ const bind = this._fields.get(fieldName);
329
+ if (bind) {
330
+ bind.acceptWaitingChange();
331
+ }
332
+ }
333
+ }
334
+ bindSearchOptionsLoader(fieldName, field) {
335
+ if (field.nodeName === "EZ-SEARCH" && field["optionLoader"] == undefined) {
336
+ const loader = core.ApplicationContext.getContextValue("__EZUI__SEARCH__OPTION__LOADER__");
337
+ if (loader) {
338
+ field["optionLoader"] = (arg) => {
339
+ return loader(arg, fieldName, this._dataUnit);
340
+ };
341
+ }
342
+ }
343
+ }
344
+ applyEzUploadContext(fieldName, field) {
345
+ var _a, _b;
346
+ if (field.nodeName === "EZ-UPLOAD") {
347
+ field["urlUpload"] = core.ApplicationContext.getContextValue("__EZUI__UPLOAD__ADD__URL__");
348
+ field["urlDelete"] = core.ApplicationContext.getContextValue("__EZUI__UPLOAD__DEL__URL__");
349
+ const descriptor = this._dataUnit.getField(fieldName);
350
+ const destination = (_a = descriptor.properties) === null || _a === void 0 ? void 0 : _a.DESTINATION;
351
+ if (destination) {
352
+ field["requestHeaders"] = { XTRAINF: `{"destination": "${destination}"}` };
353
+ }
354
+ field["maxFiles"] = ((_b = descriptor.properties) === null || _b === void 0 ? void 0 : _b.MAX_FILES) || 0;
355
+ }
356
+ }
357
+ interceptAction(action) {
358
+ if (action.type === core.Action.RECORDS_COPIED) {
359
+ const cleanFields = this._formMetadata.getCleanOnCopyFields();
360
+ if (cleanFields) {
361
+ const records = action.payload;
362
+ return new core.DataUnitAction(core.Action.RECORDS_COPIED, records.map(record => {
363
+ const newRecord = Object.assign({}, record);
364
+ cleanFields.forEach(fieldName => delete newRecord[fieldName]);
365
+ return newRecord;
366
+ }));
367
+ }
368
+ }
369
+ if (action.type === core.Action.SAVING_DATA) {
370
+ return new Promise((resolve) => {
371
+ this.validate()
372
+ .then(() => resolve(action))
373
+ .catch(() => { });
374
+ });
375
+ }
376
+ if (action.type === core.Action.RECORDS_ADDED) {
377
+ const defaultValues = this.getDefaultValues();
378
+ if (defaultValues) {
379
+ const records = action.payload;
380
+ return new core.DataUnitAction(core.Action.RECORDS_ADDED, records.map(record => {
381
+ return Object.assign(Object.assign({}, record), defaultValues);
382
+ }));
383
+ }
384
+ }
385
+ return action;
386
+ }
387
+ getDefaultValues() {
388
+ var _a;
389
+ const rawDefaultValues = (_a = this._formMetadata) === null || _a === void 0 ? void 0 : _a.getDefaultValues();
390
+ if (rawDefaultValues) {
391
+ const defaultValues = {};
392
+ for (const field in rawDefaultValues) {
393
+ defaultValues[field] = this._dataUnit.valueFromString(field, rawDefaultValues[field]);
394
+ }
395
+ return defaultValues;
396
+ }
397
+ return undefined;
398
+ }
399
+ }
400
+ class Bind {
401
+ constructor() {
402
+ this.listen = true;
403
+ this.startChangeEventName = "ezStartChange";
404
+ this.cancelWaitingChangeEventName = "ezCancelWaitingChange";
405
+ this.changeEventName = "ezChange";
406
+ }
407
+ destroy() {
408
+ this.field.removeEventListener(this.startChangeEventName, this.startChangeListener);
409
+ this.field.removeEventListener(this.cancelWaitingChangeEventName, this.cancelWaitingChangeListener);
410
+ this.field.removeEventListener(this.changeEventName, this.changeListener);
411
+ }
412
+ acceptWaitingChange() {
413
+ if (this.waitingChangePromiseResolve) {
414
+ this.waitingChangePromiseResolve();
415
+ this.waitingChangePromiseReject = undefined;
416
+ this.waitingChangePromiseResolve = undefined;
417
+ }
418
+ }
419
+ rejectWaitingChange(reason) {
420
+ if (this.waitingChangePromiseReject) {
421
+ this.waitingChangePromiseReject(reason);
422
+ this.waitingChangePromiseReject = undefined;
423
+ this.waitingChangePromiseResolve = undefined;
424
+ }
425
+ }
426
+ static create(fieldName, field, startChangeCallback, cancelWaitingChangeCallback, changeCallback) {
427
+ const b = new Bind();
428
+ b.field = field;
429
+ b.fieldName = fieldName;
430
+ b.startChangeListener = (evt) => { if (b.listen)
431
+ startChangeCallback(fieldName, evt.detail); };
432
+ b.field.addEventListener(b.startChangeEventName, b.startChangeListener);
433
+ b.cancelWaitingChangeListener = () => { if (b.listen)
434
+ cancelWaitingChangeCallback(fieldName); };
435
+ b.field.addEventListener(b.cancelWaitingChangeEventName, b.cancelWaitingChangeListener);
436
+ b.changeListener = (evt) => { if (b.listen)
437
+ changeCallback(fieldName, evt.detail); };
438
+ b.field.addEventListener(b.changeEventName, b.changeListener);
439
+ return b;
440
+ }
441
+ }
442
+
443
+ exports.DataBinder = DataBinder;
444
+ exports.RecordValidationProcessor = RecordValidationProcessor;
445
+ exports.buildFieldMetadata = buildFieldMetadata;
@@ -0,0 +1,35 @@
1
+ 'use strict';
2
+
3
+ class FocusResolver {
4
+ static resolveFocus(element, selectText = true) {
5
+ var _a;
6
+ if (!element)
7
+ return;
8
+ (_a = element.focus) === null || _a === void 0 ? void 0 : _a.call(element);
9
+ if (element.setFocus) {
10
+ element.setFocus({ selectText });
11
+ return;
12
+ }
13
+ this.resolveFocusOnChild(element, selectText);
14
+ }
15
+ static resolveFocusOnChild(element, selectText = true) {
16
+ var _a, _b;
17
+ if (this.isGridCell(element) && element.firstElementChild) {
18
+ this.resolveFocusOnChild(element.firstElementChild);
19
+ return;
20
+ }
21
+ if (!element || !element.classList.contains('hydrated'))
22
+ return;
23
+ const firstChild = element.firstElementChild;
24
+ if (!(firstChild === null || firstChild === void 0 ? void 0 : firstChild.focus) && !(firstChild === null || firstChild === void 0 ? void 0 : firstChild.setFocus))
25
+ return;
26
+ (_a = firstChild === null || firstChild === void 0 ? void 0 : firstChild.focus) === null || _a === void 0 ? void 0 : _a.call(firstChild);
27
+ (_b = firstChild === null || firstChild === void 0 ? void 0 : firstChild.setFocus) === null || _b === void 0 ? void 0 : _b.call(firstChild, { selectText });
28
+ }
29
+ static isGridCell(element) {
30
+ var _a;
31
+ return ((_a = element === null || element === void 0 ? void 0 : element.getAttribute) === null || _a === void 0 ? void 0 : _a.call(element, "role")) === 'gridcell';
32
+ }
33
+ }
34
+
35
+ exports.FocusResolver = FocusResolver;
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-a7b0c73d.js');
5
+ const index = require('./index-9e5554cb.js');
6
6
  const core = require('@sankhyalabs/core');
7
7
  require('./ApplicationUtils-c9d1205c.js');
8
8
  const CSSVarsUtils = require('./CSSVarsUtils-10c9d5b4.js');
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-a7b0c73d.js');
5
+ const index = require('./index-9e5554cb.js');
6
6
  const core = require('@sankhyalabs/core');
7
7
 
8
8
  const ezAlertListCss = ":host {\n display: flex;\n\n /* Alert List */\n \n /*@doc Define a largura da lista minimizado */\n --ez-alert-list__container--width: 680px;\n /*@doc Define a altura da lista minimizado */\n --ez-alert-list__container--height: 220px;\n \n /*@doc Define a largura da lista maximizada */\n --ez-alert-list__container--width--expanded: 920px;\n /*@doc Define a altura da lista maximizada */\n --ez-alert-list__container--height--expanded: 540px;\n\n /* Title */\n /*@doc Define a fonte do título do componente */\n --ez-alert-list__title--font-family: var(--font-pattern, \"Roboto\");\n /*@doc Define o tamanho da fonte do título do popup.*/\n --ez-alert-list__title--font-size: var(--title--large, 20px);\n /*@doc Define a cor da fonte do título do popup.*/\n --ez-alert-list__title--color: var(--title--primary, #2b3a54);\n /*@doc Define o peso da fonte do título do popup.*/\n --ez-alert-list__title--font-weight: var(--text-weight--extra-large, 700);\n\n /* @doc Define a borda inferior do item da lista. */\n --ez-list__item--border-bottom: var(--border--small, 1px solid);\n\n /* @doc Define a cor da borda inferior do item da lista. */\n --ez-list__item--border-bottom-color: var(--color--strokes, #DCE0E8);\n\n /* @doc Define o tipo da quebra de linha do item da lista. */\n --ez-list__item--white-space: break-space;\n}\n\n.alert-list__content {\n display: flex;\n flex-direction: column;\n \n gap: var(--space--xs);\n margin: var(--space--large, 24px);\n width: 100%;\n}\n\n.alert-list__container {\n z-index: var(--ez-elevation--8, 8);\n display: flex;\n height: var(--ez-alert-list__container--height);\n width: var(--ez-alert-list__container--width);\n border-radius: var(--border--radius-medium);\n background-color: var(--background--xlight);\n box-shadow: var(--shadow--medium);\n\n &.expanded {\n height: var(--ez-alert-list__container--height--expanded);\n width: var(--ez-alert-list__container--width--expanded);\n }\n\n @media (max-height: 640px) {\n max-height: calc(100vh - var(--space--3xl));\n } \n}\n\n.alert-list__header {\n width: 100%;\n display: flex;\n align-items: center;\n justify-content: space-between;\n}\n\n.alert-list__title {\n font-family: var(--ez-alert-list__title--font-family);\n font-size: var(--ez-alert-list__title--font-size);\n font-weight: var(--ez-alert-list__title--font-weight);\n color: var(--ez-alert-list__title--color);\n}\n\n.alert-list__header__buttons {\n display: flex;\n gap: var(--space--xs);\n}\n\n.alert-list__expandable-content {\n overflow-y: auto;\n scrollbar-width: thin;\n}\n\n";
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-a7b0c73d.js');
5
+ const index = require('./index-9e5554cb.js');
6
6
  const core = require('@sankhyalabs/core');
7
7
 
8
8
  const ezAlertCss = ":host{--ez-alert-alert-container--padding-up-down:var(--space--small, 6px);--ez-alert-alert-container--padding-right-left:var(--space--medium, 12px);--ez-alert-alert-container--gap:var(--space--medium, 12px);--ez-alert-alert-container--border-radius:var(--border--radius-medium, 12px);--ez-alert-alert-container--font-color-warn:var(--color--alert-warning-900, #8C6B00);--ez-alert-alert-container--icon-warn:var(--color--alert-warning-900, #8C6B00);--ez-alert-alert-container--background-color-warn:var(--color--alert-warning-200, #FFF7D5);--ez-alert-alert-container--font-color-critical:var(--color--alert-error, #BD0025);--ez-alert-alert-container--icon-critical:var(--color--alert-error, #BD0025);--ez-alert-alert-container--background-color-critical:var(--color--alert-error-200, #F7E0E5);--ez-alert-alert-container--font-color-success:var(--color--alert-success, #157A00);--ez-alert-alert-container--icon-success:var(--color--alert-success, #157A00);--ez-alert-alert-container--background-color-success:var(--color--alert-success-200, #E7F6E0);font-size:var(--text--small, 12px);font-family:var(--font-pattern, \"Roboto\");width:100%;hyphens:auto;display:block}.alert-container{display:flex;align-items:center;gap:var(--ez-alert-alert-container--gap);padding:var(--ez-alert-alert-container--padding-up-down) var(--ez-alert-alert-container--padding-right-left);border-radius:var(--ez-alert-alert-container--border-radius)}.warn{background-color:var(--ez-alert-alert-container--background-color-warn);color:var(--ez-alert-alert-container--font-color-warn)}.critical{background-color:var(--ez-alert-alert-container--background-color-critical);color:var(--ez-alert-alert-container--font-color-critical)}.success{background-color:var(--ez-alert-alert-container--background-color-success);color:var(--ez-alert-alert-container--font-color-success)}ez-icon{--ez-icon--color:inherit}.alert-container__icon-warn{--ez-icon--color:var(--ez-alert-alert-container--icon-warn)}.alert-container__icon-critical{--ez-icon--color:var(--ez-alert-alert-container--icon-critical)}.alert-container__icon-success{--ez-icon--color:var(--ez-alert-alert-container--icon-success)}";
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-a7b0c73d.js');
5
+ const index = require('./index-9e5554cb.js');
6
6
 
7
7
  const ezApplicationCss = "";
8
8
 
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-a7b0c73d.js');
5
+ const index = require('./index-9e5554cb.js');
6
6
  const core = require('@sankhyalabs/core');
7
7
 
8
8
  var Sizes;
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-a7b0c73d.js');
5
+ const index = require('./index-9e5554cb.js');
6
6
  const core = require('@sankhyalabs/core');
7
7
 
8
8
  const BreadcrumbItem = (props) => {
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-a7b0c73d.js');
5
+ const index = require('./index-9e5554cb.js');
6
6
  const core = require('@sankhyalabs/core');
7
7
 
8
8
  const ezButtonCss = ":host{--ez-button--min-width:100px;--ez-button--width:'auto';--ez-button--height:42px;--ez-button__icon--width:18px;--ez-button__inline__icon--padding:12px;--ez-button--padding-top:0px;--ez-button--padding-bottom:0px;--ez-button--padding-right:var(--space--large, 24px);--ez-button--padding-left:var(--space--large, 24px);--ez-button--color:var(--title--primary, #2B3A54);--ez-button--font-size:var(--text--medium, 14px);--ez-button--font-family:var(--font-pattern, Arial);--ez-button--font-weight:var(--text-weight--large);--ez-button--background-color:var(--background--light, #ffffff);--ez-button--border-radius:var(--border--radius-large, 24px);--ez-button--border:1px solid var(--color--strokes);--ez-button--justify-content:center;--ez-button--hover-color:var(--color--primary-600, #007a5a);--ez-button--hover--background-color:var(--background--light, #ffffff);--ez-button--disabled-color:var(--text--disable);--ez-button--disabled--background-color:var(--color--disable-secondary);--ez-button--focus--border:var(--border--medium, 2px solid) var(--color--primary-300);--ez-button--focus--box-shadow:var(--color--primary-300) 0px 0px 0px 2px;--ez-button--active-color:var(--color--primary-700);--ez-button--active--background-color:var(--background--strong);--ez-button--link-color:var(--color--primary, '#008561');--ez-button--link--hover-color:var(--color--primary-700, '#1C1D22');--ez-button--link-disabled-color:var(--text--secondary, #a2abb9);--ez-button--link--small--font-size:var(--text--small, 12px);--ez-button--link--medium--font-size:var(--text--medium, 14px);--ez-button--link--large--font-size:var(--text--large, 16px)}ez-icon{--ez-icon--color:inherit}button{position:relative;display:flex;align-items:center;margin:0;cursor:pointer;transition:background-color 0.2s linear;white-space:nowrap;min-width:var(--ez-button--min-width);width:var(--ez-button--width);height:var(--ez-button--height);font-family:var(--ez-button--font-family);font-size:var(--ez-button--font-size);font-weight:var(--ez-button--font-weight);padding:var(--ez-button--padding-top) var(--ez-button--padding-right) var(--ez-button--padding-bottom) var(--ez-button--padding-left);border-radius:var(--ez-button--border-radius);background-color:var(--ez-button--background-color);color:var(--ez-button--color);fill:var(--ez-button--color);border:var(--ez-button--border);justify-content:var(--ez-button--justify-content)}button:focus{outline:var(--ez-button--focus--border);box-shadow:none}button:hover{outline:none;background-color:var(--ez-button--hover--background-color);color:var(--ez-button--hover-color);fill:var(--ez-button--hover-color);--ez-icon--color:var(--ez-button--hover-color)}button:active{outline:none;box-shadow:none;background-color:var(--ez-button--active--background-color);color:var(--ez-button--active-color);fill:var(--ez-button--active-color);--ez-icon--color:var(--ez-button--active-color)}button:disabled{background-color:var(--ez-button--disabled--background-color);color:var(--ez-button--disabled-color);fill:var(--ez-button--disabled-color);--ez-icon--color:var(--ez-button--disabled-color);cursor:no-drop}.x-small{height:28px;--ez-button--font-size:var(--text--small, 12px)}.small{height:32px;--ez-button--font-size:var(--text--small, 12px)}.medium{height:42px}.large{height:46px}.btn-icon{padding:0px}.btn-icon--medium{width:42px;min-width:42px;height:42px}.btn-icon--x-small{width:28px;min-width:28px;height:28px}.btn-icon--small{width:32px;min-width:32px;height:32px}.btn-icon--large{width:46px;min-width:46px;height:46px}.label-icon{display:flex;flex-direction:column;align-items:center;color:var(--ez-button--color)}.label-icon:hover{color:var(--ez-button--hover-color);fill:var(--ez-button--hover-color);--ez-icon--color:var(--ez-button--hover-color)}.label-icon:active{color:var(--ez-button--active-color);fill:var(--ez-button--active-color);--ez-icon--color:var(--ez-button--active-color)}.label-icon label{max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;font-family:var(--ez-button--font-family);font-size:var(--ez-button--font-size);font-weight:var(--ez-button--font-weight);user-select:none}button:disabled+label{max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;font-family:var(--ez-button--font-family);font-size:var(--ez-button--font-size);font-weight:var(--ez-button--font-weight);color:var(--ez-button--disabled-color);cursor:no-drop}div.label-icon{cursor:pointer}div.label-icon,button:disabled{cursor:no-drop}a{font-family:var(--ez-button--font-family);font-weight:var(--ez-button--font-weight);color:var(--ez-button--link-color);cursor:pointer;display:flex;align-items:center;justify-content:center;}a:hover{color:var(--ez-button--link--hover-color)}a.small{font-size:var(--ez-button--link--small--font-size);line-height:var(--ez-button--link--small--font-size)}a.medium{font-size:var(--ez-button--link--medium--font-size);line-height:var(--ez-button--link--medium--font-size)}a.large{font-size:var(--ez-button--link--large--font-size);line-height:var(--ez-button--link--large--font-size)}a.disabled{color:var(--ez-button--link-disabled-color);cursor:not-allowed}";
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-a7b0c73d.js');
5
+ const index = require('./index-9e5554cb.js');
6
6
  const core = require('@sankhyalabs/core');
7
7
 
8
8
  const ezCalendarCss = ":host{--ez-calendar--font-family:var(--font-pattern, Arial);--ez-calendar--color:var(--title--primary, #626e82);--ez-calendar--text-shadow:var(--text-shadow, 0 0 0 #353535, 0 0 1px transparent);--ez-calendar__body--background-color:var(--background--xlight, #FFF);--ez-calendar__time--background-color:var(--background--xlight, #FAFAFA);--ez-calendar__body--padding:var(--space--medium, 12px) var(--space--small, 6px);--ez-calendar__body--border-radius:var(--border--radius-medium, 12px);--ez-calendar__body--shadow:var(--shadow, 0px 0px 16px 0px #000);--ez-container--z-index:var(--more-visible, 2);--ez-calendar__header-line--stroke:1px;--ez-calendar__header-line--color:var(--color--strokes, #C0C0C0);--ez-calendar__nav-btn--fill:var(--text--primary, #008561);--ez-calendar__nav-btn--hover--fill:var(--color--primary, #350404);--ez-calendar__nav-btn--width:10px;--ez-calendar__nav-btn--height:16px;--ez-calendar__nav-btn--previous-image:url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" height=\"16px\" width=\"10px\"><path d=\"M 9.7808475,13.860393 3.9204526,8.0000004 9.7808475,2.0624965 7.9301965,0.28895552 0.21915255,8.0000004 7.9301965,15.711044 Z\"/></svg>');--ez-calendar__nav-btn--next-image:url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" height=\"16px\" width=\"10px\"><path d=\"M 0.21915251,13.860393 6.0795475,8.0000007 0.21915251,2.0624968 2.0698036,0.28895588 9.7808475,8.0000007 2.0698036,15.711044 Z\"/></svg>');--ez-calendar__cell--margin:0px 1.5px;--ez-calendar__cell--width:var(--space--large, 24px);--ez-calendar__cell--padding:1.5px 0px;--ez-calendar__cell--border-radius:var(--border--radius-small, 6px);--ez-calendar__cell--over--background-color:var(--color--primary, #E2F4EF);--ez-calendar__cell--over--color:var(--color--primary-300, #008561);--ez-calendar__cell--outset--color:var(--color--disable-primary, #E5EAF0);--ez-calendar__cell--selected--background-color:var(--color--primary, #008561);--ez-calendar__cell--selected--color:var(--color--inverted, #FFF);--ez-calendar__btn-today--color:var(--color--primary);--ez-calendar__btn-today--hover--background-color:var(--color--primary-300, #E2F4EF);--ez-calendar__btn-today--border-radius:var(--border--radius-small, 6px);position:relative;display:flex;user-select:none}.calendar__container{display:flex;z-index:var(--more-visible, 2)}.calendar{display:flex;flex-direction:column;z-index:var(--more-visible, 2);background-color:var(--ez-calendar__body--background-color);padding:var(--ez-calendar__body--padding);border-radius:var(--ez-calendar__body--border-radius);box-shadow:var(--ez-calendar__body--shadow)}.calendar__header{display:flex;justify-content:space-between;padding-bottom:var(--space--small, 6px);margin:0px var(--space--, 12px) var(--space--small, 6px) var(--space--, 12px);font-family:var(--ez-calendar--font-family);color:var(--ez-calendar--color);text-shadow:var(--ez-calendar--text-shadow);border-bottom:solid var(--ez-calendar__header-line--stroke) var(--ez-calendar__header-line--color)}.calendar__btn-next,.calendar__btn-previous{outline:none;border:none;background-color:unset;cursor:pointer;padding:0px}.calendar__btn-next::after,.calendar__btn-previous::after{content:'';display:flex;background-color:var(--ez-calendar__nav-btn--fill);width:var(--ez-calendar__nav-btn--width);height:var(--ez-calendar__nav-btn--height)}.calendar__btn-previous::after{-webkit-mask-image:var(--ez-calendar__nav-btn--previous-image);mask-image:var(--ez-calendar__nav-btn--previous-image)}.calendar__btn-next::after{-webkit-mask-image:var(--ez-calendar__nav-btn--next-image);mask-image:var(--ez-calendar__nav-btn--next-image)}.calendar__btn-next:hover::after,.calendar__btn-previous:hover::after{background-color:var(--ez-calendar__nav-btn--hover--fill)}.calendar__lbl-month{font-weight:var(--text-weight--extra-large, 700);font-size:var(--title--small, 14px);font-family:var(--ez-calendar--font-family);color:var(--ez-calendar--color);text-shadow:var(--ez-calendar--text-shadow)}.calendar__line{display:flex;padding:0px;margin:0px}.calendar__cell{display:flex;justify-content:center;align-content:center;cursor:pointer;font-size:var(--text--extra-small, 10px);font-family:var(--ez-calendar--font-family);color:var(--ez-calendar--color);text-shadow:var(--ez-calendar--text-shadow);padding:var(--ez-calendar__cell--padding);margin:var(--ez-calendar__cell--margin);min-width:var(--ez-calendar__cell--width);border-radius:var(--ez-calendar__cell--border-radius)}.calendar__cell:hover{background-color:var(--ez-calendar__cell--over--background-color);color:var(--ez-calendar__cell--over--color)}.calendar__cell--secondary{color:var(--ez-calendar__cell--outset--color)}.calendar__cell--unselectable:hover{background-color:unset;border-radius:unset;cursor:unset;color:var(--ez-calendar--color)}.calendar__cell--unselectable{font-weight:var(--text-weight--large, 600);font-family:var(--ez-calendar--font-family);color:var(--ez-calendar--color);text-shadow:var(--ez-calendar--text-shadow)}.calendar__cell--selected,.calendar__cell--selected:hover{background-color:var(--ez-calendar__cell--selected--background-color);color:var(--ez-calendar__cell--selected--color)}.calendar__footer{display:flex;flex-direction:column}.calendar__btn-today{border:none;background-color:unset;cursor:pointer;padding:0px;font-weight:var(--text-weight--large, 600);font-size:var(--title--extra-small, 12px);font-family:var(--ez-calendar--font-family);text-shadow:var(--ez-calendar--text-shadow);color:var(--ez-calendar__btn-today--color);border-radius:var(--ez-calendar__btn-today--border-radius)}.calendar__btn-today:hover{background-color:var(--ez-calendar__btn-today--hover--background-color)}section{display:flex}.calendar-time{margin-left:-10px;display:flex;flex-direction:column;padding:12px 0px 0px 10px;background-color:var(--ez-calendar__time--background-color);border-top-right-radius:var(--ez-calendar__body--border-radius);border-bottom-right-radius:var(--ez-calendar__body--border-radius);box-shadow:var(--ez-calendar__body--shadow)}.calendar__column{height:136px;padding:0px;margin:0px;overflow:auto;scrollbar-width:none}.calendar__column::-webkit-scrollbar{width:0px;max-width:0px;min-width:0px}.calendar-time__header{display:flex;justify-content:space-between;padding-left:var(--space--small, 6px);padding-right:var(--space--small, 6px);padding-bottom:var(--space--small, 6px);margin:0px var(--space--, 12px) var(--space--small, 6px) var(--space--, 12px);font-weight:var(--text-weight--extra-large, 700);font-size:var(--title--small, 14px);text-shadow:var(--ez-calendar--text-shadow);border-bottom:solid var(--ez-calendar__header-line--stroke) var(--ez-calendar__header-line--color);font-family:var(--ez-calendar--font-family);color:var(--ez-calendar--color);text-shadow:var(--ez-calendar--text-shadow)}.separatorTime{color:#A2ABB9;padding:0px 1px;line-height:16px;font-size:17px;font-weight:normal}.endHidden{-webkit-mask-image:linear-gradient(180deg, #000 calc(100% - 48px), transparent 100%)}.calendar__column .calendar__cell{margin:0px;padding:1.5px 1.5px}";
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-a7b0c73d.js');
5
+ const index = require('./index-9e5554cb.js');
6
6
  const core = require('@sankhyalabs/core');
7
7
  const CSSVarsUtils = require('./CSSVarsUtils-10c9d5b4.js');
8
8
 
@@ -86,6 +86,7 @@ const EzFilterInput = class {
86
86
  this.mode = "regular";
87
87
  this.asyncSearch = false;
88
88
  this.canShowError = true;
89
+ this.autoFocus = false;
89
90
  }
90
91
  observeLabel() {
91
92
  if (this._textInput) {
@@ -106,8 +107,8 @@ const EzFilterInput = class {
106
107
  /**
107
108
  * Aplica o foco no campo.
108
109
  */
109
- async setFocus() {
110
- this._textInput.setFocus();
110
+ async setFocus(options) {
111
+ this._textInput.setFocus(options);
111
112
  }
112
113
  /**
113
114
  * Remove o foco do campo.
@@ -160,6 +161,11 @@ const EzFilterInput = class {
160
161
  }
161
162
  componentDidLoad() {
162
163
  CSSVarsUtils.CSSVarsUtils.applyVarsTextInput(this._elem, this._textInput);
164
+ if (this.autoFocus) {
165
+ requestAnimationFrame(() => {
166
+ this.setFocus({ selectText: true });
167
+ });
168
+ }
163
169
  }
164
170
  render() {
165
171
  core.ElementIDUtils.addIDInfoIfNotExists(this._elem, 'input');
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-a7b0c73d.js');
5
+ const index = require('./index-9e5554cb.js');
6
6
 
7
7
  class ChartContext {
8
8
  constructor(strategy) {
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-a7b0c73d.js');
5
+ const index = require('./index-9e5554cb.js');
6
6
  const core = require('@sankhyalabs/core');
7
7
  const CheckMode = require('./CheckMode-ecb90b87.js');
8
8
 
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-a7b0c73d.js');
5
+ const index = require('./index-9e5554cb.js');
6
6
  const core = require('@sankhyalabs/core');
7
7
 
8
8
  const ezChipCss = ":host{--ez-label-chip--height:30px;--ez-label-chip__label--font-size:var(--text--medium, 14px);--ez-label-chip__label--font-family:var(--font-pattern, Arial);--ez-label-chip__label--font-weight:var(--text-weight--medium, 400);--ez-label-chip__label--space--medium:var(--space--medium, 12px);--ez-label-chip__label--title--primary:var(--title--primary, #2B3A54);--ez-label-chip__label--text--primary:var(--text--primary, #626e82);--ez-label-chip__label__container--border-radius:var(--border--radius-large, 24px);--ez-label-chip__label__container--border:1px solid;--ez-label-chip__label__container--border-color-strokes:var(--color--strokes, #DCE0E8);--ez-label-chip__label__container--color-primary:var(--color--primary, #008561);--ez-label-chip__label__container-color--disable-secondary:var(--color--disable-secondary, #F2F5F8);--ez-label-chip__label__container--background-color:var(--color--primary-300);--ez-label-chip__label__container--border-color:#0085610F;--ez-label-chip__label__container--default--border-color--active:var(--color--primary, #007a5a);--ez-label-chip__label__container--default--background-color--hover:var(--color--primary-300, #f2faf8);--ez-label-chip__label__container--default--color--hover:var(--color--primary, #f2faf8);--ez-label-chip__label__container--text--disabled:var(--text--disable, #AFB6C0);--ez-label-chip__label__container--default--border-color--active:var(--color--primary)}.lbl{display:flex;white-space:nowrap;align-items:center;cursor:pointer;user-select:none;color:var(--ez-label-chip__label--title--primary);height:var(--ez-label-chip--height);font-family:var(--ez-label-chip__label--font-family);font-size:var(--ez-label-chip__label--font-size);font-weight:var(--ez-label-chip__label--font-weight)}.lbl--active{color:var(--ez-label-chip__label__container--default--color--hover)}.lbl--disabled{color:var(--ez-label-chip__label__container--text--disabled)}.label__container{cursor:pointer;width:max-content;display:flex;flex-wrap:wrap;align-items:center;background-color:#FFFFFF;color:var(--ez-label-chip__label--text--primary);fill:var(--ez-label-chip__label--text--primary);--ez-icon--color:var(--ez-label-chip__label--text--primary);border:var(--ez-label-chip__label__container--border);border-radius:var(--ez-label-chip__label__container--border-radius);border-color:var(--ez-label-chip__label__container--border-color-strokes);padding-right:var(--ez-label-chip__label--space--medium);padding-left:var(--ez-label-chip__label--space--medium);outline-color:var(--ez-label-chip__label__container--default--border-color--active)}.label__content{display:flex;align-items:center;flex-wrap:wrap;--ez-icon--color:var(--ez-label-chip__label--text--primary)}.label__container--disabled{cursor:default;border-color:var(--ez-label-chip__label__container-color--disable-secondary);background-color:var(--ez-label-chip__label__container-color--disable-secondary);fill:var(--ez-label-chip__label__container--text--disabled);color:var(--ez-label-chip__label__container--text--disabled);--ez-icon--color:var(--ez-label-chip__label__container--text--disabled)}.label__container--active{border-color:var(--ez-label-chip__label__container--default--background-color--hover);background-color:var(--ez-label-chip__label__container--default--background-color--hover);color:var(--ez-label-chip__label__container--default--color--hover);fill:var(--ez-label-chip__label__container--default--color--hover);--ez-icon--color:var(--ez-label-chip__label__container--default--color--hover)}.label__container:hover{border-color:var(--ez-label-chip__label__container--default--border-color--active)}.label__container:focus{outline:var(--border--medium) var(--ez-label-chip__label__container--default--border-color--active)}.label__container--disabled:hover{cursor:default;border:var(--ez-label-chip__label__container--border);border-color:var(--ez-label-chip__label__container-color--disable-secondary);background-color:var(--ez-label-chip__label__container-color--disable-secondary);fill:var(--ez-label-chip__label__container--text--disabled);color:var(--ez-label-chip__label__container--text--disabled);--ez-icon--color:var(--ez-label-chip__label__container--text--disabled)}.label__content__icon{display:flex;cursor:pointer;color:var(--ez-label-chip__label--text--primary);fill:var(--ez-label-chip__label--text--primary);--ez-icon--color:var(--ez-label-chip__label--text--primary)}.label__container--row-reverse{flex-direction:row-reverse}.label__container .btn-close{padding:0px 0px 0px 8px}.label__container--row-reverse .btn-close{padding:0px 8px 0px 0px}.cursor-disable{cursor:default}ez-icon{--ez-icon--color:inherit}";