@sankhyalabs/ezui 7.1.0-dev.20 → 7.1.0-dev.22

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 (378) hide show
  1. package/dist/cjs/{ApplicationUtils-d04f5c94.js → ApplicationUtils-006ca96f.js} +1 -1
  2. package/dist/cjs/FormLayout-fe8da83c.js +9 -0
  3. package/dist/cjs/{app-globals-c128c97e.js → app-globals-5cb12916.js} +1 -1
  4. package/dist/cjs/{ez-combo-box-list_4.cjs.entry.js → classic-search-list_7.cjs.entry.js} +361 -7
  5. package/dist/cjs/ez-actions-button.cjs.entry.js +5 -4
  6. package/dist/cjs/ez-alert-list.cjs.entry.js +2 -2
  7. package/dist/cjs/ez-alert.cjs.entry.js +1 -1
  8. package/dist/cjs/ez-application.cjs.entry.js +1 -1
  9. package/dist/cjs/ez-avatar.cjs.entry.js +2 -2
  10. package/dist/cjs/ez-badge.cjs.entry.js +1 -1
  11. package/dist/cjs/ez-breadcrumb.cjs.entry.js +1 -1
  12. package/dist/cjs/ez-button.cjs.entry.js +1 -1
  13. package/dist/cjs/ez-calendar.cjs.entry.js +2 -2
  14. package/dist/cjs/ez-card-item.cjs.entry.js +1 -1
  15. package/dist/cjs/ez-chart.cjs.entry.js +1 -1
  16. package/dist/cjs/ez-check.cjs.entry.js +1 -1
  17. package/dist/cjs/ez-chip.cjs.entry.js +1 -1
  18. package/dist/cjs/ez-classic-combo-box.cjs.entry.js +37 -16
  19. package/dist/cjs/ez-classic-date-input.cjs.entry.js +201 -0
  20. package/dist/cjs/ez-classic-date-time-input.cjs.entry.js +246 -0
  21. package/dist/cjs/ez-classic-input.cjs.entry.js +100 -19
  22. package/dist/cjs/ez-classic-number-input.cjs.entry.js +205 -0
  23. package/dist/cjs/ez-classic-search-plus.cjs.entry.js +407 -0
  24. package/dist/cjs/ez-classic-search.cjs.entry.js +683 -0
  25. package/dist/cjs/ez-classic-text-area.cjs.entry.js +2 -2
  26. package/dist/cjs/ez-classic-time-input.cjs.entry.js +197 -0
  27. package/dist/cjs/ez-collapsible-box.cjs.entry.js +5 -4
  28. package/dist/cjs/ez-combo-box.cjs.entry.js +5 -4
  29. package/dist/cjs/ez-date-input.cjs.entry.js +2 -2
  30. package/dist/cjs/ez-date-time-input.cjs.entry.js +2 -2
  31. package/dist/cjs/ez-dialog.cjs.entry.js +2 -2
  32. package/dist/cjs/ez-double-list.cjs.entry.js +2 -2
  33. package/dist/cjs/ez-dropdown.cjs.entry.js +1 -1
  34. package/dist/cjs/ez-empty-card.cjs.entry.js +1 -1
  35. package/dist/cjs/ez-file-item.cjs.entry.js +2 -2
  36. package/dist/cjs/ez-filter-input.cjs.entry.js +1 -1
  37. package/dist/cjs/ez-form-view.cjs.entry.js +130 -37
  38. package/dist/cjs/ez-form.cjs.entry.js +13 -8
  39. package/dist/cjs/ez-grid-view.cjs.entry.js +1 -1
  40. package/dist/cjs/ez-grid.cjs.entry.js +11 -7
  41. package/dist/cjs/ez-guide-navigator.cjs.entry.js +2 -2
  42. package/dist/cjs/ez-icon.cjs.entry.js +2 -2
  43. package/dist/cjs/ez-link-builder_6.cjs.entry.js +2 -2
  44. package/dist/cjs/ez-list-item.cjs.entry.js +1 -1
  45. package/dist/cjs/ez-list.cjs.entry.js +2 -2
  46. package/dist/cjs/ez-loading-bar.cjs.entry.js +1 -1
  47. package/dist/cjs/ez-modal-container.cjs.entry.js +2 -2
  48. package/dist/cjs/ez-modal.cjs.entry.js +2 -2
  49. package/dist/cjs/ez-multi-selection-list.cjs.entry.js +2 -2
  50. package/dist/cjs/ez-number-input.cjs.entry.js +2 -2
  51. package/dist/cjs/ez-pagination.cjs.entry.js +2 -2
  52. package/dist/cjs/ez-popover-core.cjs.entry.js +1 -1
  53. package/dist/cjs/ez-popover-plus_3.cjs.entry.js +1 -1
  54. package/dist/cjs/ez-popover.cjs.entry.js +1 -1
  55. package/dist/cjs/ez-popup.cjs.entry.js +2 -2
  56. package/dist/cjs/ez-progress-bar.cjs.entry.js +1 -1
  57. package/dist/cjs/ez-radio-button.cjs.entry.js +1 -1
  58. package/dist/cjs/ez-rich-toolbar-item.cjs.entry.js +1 -1
  59. package/dist/cjs/ez-scroller_2.cjs.entry.js +1 -1
  60. package/dist/cjs/ez-search-plus.cjs.entry.js +8 -7
  61. package/dist/cjs/ez-search-result-list.cjs.entry.js +2 -2
  62. package/dist/cjs/ez-search.cjs.entry.js +11 -10
  63. package/dist/cjs/ez-sidebar-navigator.cjs.entry.js +2 -2
  64. package/dist/cjs/ez-skeleton.cjs.entry.js +2 -2
  65. package/dist/cjs/ez-sortable-list.cjs.entry.js +2 -2
  66. package/dist/cjs/ez-spinner.cjs.entry.js +2 -2
  67. package/dist/cjs/ez-split-button.cjs.entry.js +2 -2
  68. package/dist/cjs/ez-split-item.cjs.entry.js +5 -4
  69. package/dist/cjs/ez-split-panel.cjs.entry.js +1 -1
  70. package/dist/cjs/ez-tabselector.cjs.entry.js +1 -1
  71. package/dist/cjs/ez-tag-input.cjs.entry.js +1 -1
  72. package/dist/cjs/ez-tag.cjs.entry.js +1 -1
  73. package/dist/cjs/ez-text-area.cjs.entry.js +1 -1
  74. package/dist/cjs/ez-text-input.cjs.entry.js +38 -1
  75. package/dist/cjs/ez-tile-medium.cjs.entry.js +1 -1
  76. package/dist/cjs/ez-tile.cjs.entry.js +1 -1
  77. package/dist/cjs/ez-time-input.cjs.entry.js +2 -2
  78. package/dist/cjs/ez-toast.cjs.entry.js +1 -1
  79. package/dist/cjs/ez-tooltip.cjs.entry.js +1 -1
  80. package/dist/cjs/ez-tree.cjs.entry.js +2 -2
  81. package/dist/cjs/ez-underface.cjs.entry.js +1 -1
  82. package/dist/cjs/ez-upload.cjs.entry.js +3 -3
  83. package/dist/cjs/ez-view-stack.cjs.entry.js +1 -1
  84. package/dist/cjs/ezui.cjs.js +4 -4
  85. package/dist/cjs/filter-column.cjs.entry.js +2 -2
  86. package/dist/cjs/{index-00d0166b.js → index-350d0fa0.js} +54 -0
  87. package/dist/cjs/{index-a7b0c73d.js → index-9e5554cb.js} +45 -18
  88. package/dist/cjs/loader.cjs.js +4 -4
  89. package/dist/cjs/{search-column-8bfee733.js → search-column-9654bf26.js} +5 -5
  90. package/dist/cjs/searchFormatters-051f8677.js +23 -0
  91. package/dist/cjs/{FormLayout-18853e70.js → types-6a5df0c7.js} +0 -6
  92. package/dist/collection/collection-manifest.json +59 -5
  93. package/dist/collection/components/ez-classic-combo-box/ez-classic-combo-box.css +5 -0
  94. package/dist/collection/components/ez-classic-combo-box/ez-classic-combo-box.js +77 -18
  95. package/dist/collection/components/ez-classic-date-input/ez-classic-date-input.css +44 -0
  96. package/dist/collection/components/ez-classic-date-input/ez-classic-date-input.js +541 -0
  97. package/dist/collection/components/ez-classic-date-time-input/ez-classic-date-time-input.css +44 -0
  98. package/dist/collection/components/ez-classic-date-time-input/ez-classic-date-time-input.js +586 -0
  99. package/dist/collection/components/ez-classic-input/ez-classic-input.css +33 -5
  100. package/dist/collection/components/ez-classic-input/ez-classic-input.js +155 -19
  101. package/dist/collection/components/ez-classic-number-input/ez-classic-number-input.css +16 -0
  102. package/dist/collection/components/ez-classic-number-input/ez-classic-number-input.js +583 -0
  103. package/dist/collection/components/ez-classic-search/ez-classic-search.css +126 -0
  104. package/dist/collection/components/ez-classic-search/ez-classic-search.js +1330 -0
  105. package/dist/collection/components/ez-classic-search/subcomponent/classic-search-list/classic-search-list.css +227 -0
  106. package/dist/collection/components/ez-classic-search/subcomponent/classic-search-list/classic-search-list.js +316 -0
  107. package/dist/collection/components/ez-classic-search/utils/searchFormatters.js +18 -0
  108. package/dist/collection/components/ez-classic-search-plus/ez-classic-search-plus.css +406 -0
  109. package/dist/collection/components/ez-classic-search-plus/ez-classic-search-plus.js +988 -0
  110. package/dist/collection/components/ez-classic-search-plus/subcomponent/ez-search-result-list/ez-classic-search-result-list.css +221 -0
  111. package/dist/collection/components/ez-classic-search-plus/subcomponent/ez-search-result-list/ez-classic-search-result-list.js +298 -0
  112. package/dist/collection/components/ez-classic-text-area/ez-classic-text-area.css +1 -0
  113. package/dist/collection/components/ez-classic-time-input/ez-classic-time-input.css +14 -0
  114. package/dist/collection/components/ez-classic-time-input/ez-classic-time-input.js +511 -0
  115. package/dist/collection/components/ez-form/ez-form.js +30 -4
  116. package/dist/collection/components/ez-form-view/ez-form-view.css +8 -3
  117. package/dist/collection/components/ez-form-view/ez-form-view.js +61 -3
  118. package/dist/collection/components/ez-form-view/fieldbuilder/FieldBuilder.js +9 -4
  119. package/dist/collection/components/ez-form-view/fieldbuilder/templates/CheckBox.tpl.js +9 -6
  120. package/dist/collection/components/ez-form-view/fieldbuilder/templates/ComboBox.tpl.js +8 -1
  121. package/dist/collection/components/ez-form-view/fieldbuilder/templates/DateInput.tpl.js +30 -6
  122. package/dist/collection/components/ez-form-view/fieldbuilder/templates/FileInput.tpl.js +1 -1
  123. package/dist/collection/components/ez-form-view/fieldbuilder/templates/ImageInput.tpl.js +4 -0
  124. package/dist/collection/components/ez-form-view/fieldbuilder/templates/NumberInput.tpl.js +12 -5
  125. package/dist/collection/components/ez-form-view/fieldbuilder/templates/RichText.tpl.js +1 -1
  126. package/dist/collection/components/ez-form-view/fieldbuilder/templates/SearchInput.tpl.js +9 -3
  127. package/dist/collection/components/ez-form-view/fieldbuilder/templates/SearchInputPlus.tpl.js +8 -1
  128. package/dist/collection/components/ez-form-view/fieldbuilder/templates/TextArea.tpl.js +7 -1
  129. package/dist/collection/components/ez-form-view/fieldbuilder/templates/TextInput.tpl.js +8 -1
  130. package/dist/collection/components/ez-form-view/structure/index.js +1 -1
  131. package/dist/collection/components/ez-grid/controller/ag-grid/DataSource.js +3 -0
  132. package/dist/collection/components/ez-icon/ez-icon.css +1 -0
  133. package/dist/collection/components/ez-image-input/ez-image-input.css +173 -0
  134. package/dist/collection/components/ez-image-input/ez-image-input.js +324 -0
  135. package/dist/collection/components/ez-rich-text/ez-rich-text.js +2 -3
  136. package/dist/collection/components/ez-text-input/ez-text-input.js +38 -1
  137. package/dist/collection/utils/form/DataBinder.js +2 -2
  138. package/dist/collection/utils/form/interfaces/FormLayout.js +3 -1
  139. package/dist/collection/utils/i18n/locales/en-us.js +18 -0
  140. package/dist/collection/utils/i18n/locales/es-es.js +18 -0
  141. package/dist/collection/utils/i18n/locales/pt-br.js +18 -0
  142. package/dist/custom-elements/index.d.ts +54 -0
  143. package/dist/custom-elements/index.js +2913 -347
  144. package/dist/esm/{ApplicationUtils-12768f5a.js → ApplicationUtils-0c5cb207.js} +1 -1
  145. package/dist/esm/FormLayout-bda67973.js +9 -0
  146. package/dist/esm/{app-globals-9507c20e.js → app-globals-1db10325.js} +1 -1
  147. package/dist/esm/{ez-combo-box-list_4.entry.js → classic-search-list_7.entry.js} +359 -8
  148. package/dist/esm/ez-actions-button.entry.js +5 -4
  149. package/dist/esm/ez-alert-list.entry.js +2 -2
  150. package/dist/esm/ez-alert.entry.js +1 -1
  151. package/dist/esm/ez-application.entry.js +1 -1
  152. package/dist/esm/ez-avatar.entry.js +2 -2
  153. package/dist/esm/ez-badge.entry.js +1 -1
  154. package/dist/esm/ez-breadcrumb.entry.js +1 -1
  155. package/dist/esm/ez-button.entry.js +1 -1
  156. package/dist/esm/ez-calendar.entry.js +2 -2
  157. package/dist/esm/ez-card-item.entry.js +1 -1
  158. package/dist/esm/ez-chart.entry.js +1 -1
  159. package/dist/esm/ez-check.entry.js +1 -1
  160. package/dist/esm/ez-chip.entry.js +1 -1
  161. package/dist/esm/ez-classic-combo-box.entry.js +37 -16
  162. package/dist/esm/ez-classic-date-input.entry.js +197 -0
  163. package/dist/esm/ez-classic-date-time-input.entry.js +242 -0
  164. package/dist/esm/ez-classic-input.entry.js +101 -20
  165. package/dist/esm/ez-classic-number-input.entry.js +201 -0
  166. package/dist/esm/ez-classic-search-plus.entry.js +403 -0
  167. package/dist/esm/ez-classic-search.entry.js +679 -0
  168. package/dist/esm/ez-classic-text-area.entry.js +2 -2
  169. package/dist/esm/ez-classic-time-input.entry.js +193 -0
  170. package/dist/esm/ez-collapsible-box.entry.js +5 -4
  171. package/dist/esm/ez-combo-box.entry.js +5 -4
  172. package/dist/esm/ez-date-input.entry.js +2 -2
  173. package/dist/esm/ez-date-time-input.entry.js +2 -2
  174. package/dist/esm/ez-dialog.entry.js +2 -2
  175. package/dist/esm/ez-double-list.entry.js +2 -2
  176. package/dist/esm/ez-dropdown.entry.js +1 -1
  177. package/dist/esm/ez-empty-card.entry.js +1 -1
  178. package/dist/esm/ez-file-item.entry.js +2 -2
  179. package/dist/esm/ez-filter-input.entry.js +1 -1
  180. package/dist/esm/ez-form-view.entry.js +130 -37
  181. package/dist/esm/ez-form.entry.js +13 -8
  182. package/dist/esm/ez-grid-view.entry.js +1 -1
  183. package/dist/esm/ez-grid.entry.js +9 -5
  184. package/dist/esm/ez-guide-navigator.entry.js +2 -2
  185. package/dist/esm/ez-icon.entry.js +2 -2
  186. package/dist/esm/ez-link-builder_6.entry.js +2 -2
  187. package/dist/esm/ez-list-item.entry.js +1 -1
  188. package/dist/esm/ez-list.entry.js +2 -2
  189. package/dist/esm/ez-loading-bar.entry.js +1 -1
  190. package/dist/esm/ez-modal-container.entry.js +2 -2
  191. package/dist/esm/ez-modal.entry.js +2 -2
  192. package/dist/esm/ez-multi-selection-list.entry.js +2 -2
  193. package/dist/esm/ez-number-input.entry.js +2 -2
  194. package/dist/esm/ez-pagination.entry.js +2 -2
  195. package/dist/esm/ez-popover-core.entry.js +1 -1
  196. package/dist/esm/ez-popover-plus_3.entry.js +1 -1
  197. package/dist/esm/ez-popover.entry.js +1 -1
  198. package/dist/esm/ez-popup.entry.js +2 -2
  199. package/dist/esm/ez-progress-bar.entry.js +1 -1
  200. package/dist/esm/ez-radio-button.entry.js +1 -1
  201. package/dist/esm/ez-rich-toolbar-item.entry.js +1 -1
  202. package/dist/esm/ez-scroller_2.entry.js +1 -1
  203. package/dist/esm/ez-search-plus.entry.js +5 -4
  204. package/dist/esm/ez-search-result-list.entry.js +2 -2
  205. package/dist/esm/ez-search.entry.js +5 -4
  206. package/dist/esm/ez-sidebar-navigator.entry.js +2 -2
  207. package/dist/esm/ez-skeleton.entry.js +2 -2
  208. package/dist/esm/ez-sortable-list.entry.js +2 -2
  209. package/dist/esm/ez-spinner.entry.js +2 -2
  210. package/dist/esm/ez-split-button.entry.js +2 -2
  211. package/dist/esm/ez-split-item.entry.js +5 -4
  212. package/dist/esm/ez-split-panel.entry.js +1 -1
  213. package/dist/esm/ez-tabselector.entry.js +1 -1
  214. package/dist/esm/ez-tag-input.entry.js +1 -1
  215. package/dist/esm/ez-tag.entry.js +1 -1
  216. package/dist/esm/ez-text-area.entry.js +1 -1
  217. package/dist/esm/ez-text-input.entry.js +38 -1
  218. package/dist/esm/ez-tile-medium.entry.js +1 -1
  219. package/dist/esm/ez-tile.entry.js +1 -1
  220. package/dist/esm/ez-time-input.entry.js +2 -2
  221. package/dist/esm/ez-toast.entry.js +1 -1
  222. package/dist/esm/ez-tooltip.entry.js +1 -1
  223. package/dist/esm/ez-tree.entry.js +2 -2
  224. package/dist/esm/ez-underface.entry.js +1 -1
  225. package/dist/esm/ez-upload.entry.js +3 -3
  226. package/dist/esm/ez-view-stack.entry.js +1 -1
  227. package/dist/esm/ezui.js +5 -5
  228. package/dist/esm/filter-column.entry.js +2 -2
  229. package/dist/esm/{index-62fc771e.js → index-225aa0c3.js} +54 -0
  230. package/dist/esm/{index-baa5e267.js → index-5a720e56.js} +45 -19
  231. package/dist/esm/loader.js +5 -5
  232. package/dist/esm/{search-column-c00119ae.js → search-column-c3df6285.js} +5 -5
  233. package/dist/esm/searchFormatters-6d9b06e4.js +20 -0
  234. package/dist/esm/{FormLayout-071d324c.js → types-6f6b2650.js} +1 -7
  235. package/dist/ezui/ezui.esm.js +1 -1
  236. package/dist/ezui/{p-e75c7a23.entry.js → p-000159dc.entry.js} +1 -1
  237. package/dist/ezui/p-05bcbe61.entry.js +1 -0
  238. package/dist/ezui/{p-93e1c917.entry.js → p-05e68ab3.entry.js} +1 -1
  239. package/dist/ezui/{p-288631d1.entry.js → p-06f1b8e4.entry.js} +1 -1
  240. package/dist/ezui/{p-2854f087.entry.js → p-0820f8c3.entry.js} +1 -1
  241. package/dist/ezui/{p-6d596a5a.entry.js → p-0b531233.entry.js} +1 -1
  242. package/dist/ezui/{p-79277e43.entry.js → p-0ba284cd.entry.js} +1 -1
  243. package/dist/ezui/p-0d393a5d.entry.js +1 -0
  244. package/dist/ezui/{p-3fe05d6b.entry.js → p-12cc95dc.entry.js} +1 -1
  245. package/dist/ezui/p-14d6aeb8.entry.js +1 -0
  246. package/dist/ezui/{p-2528e988.entry.js → p-169d460d.entry.js} +1 -1
  247. package/dist/ezui/{p-6f77a359.entry.js → p-1723f728.entry.js} +1 -1
  248. package/dist/ezui/{p-a401041c.entry.js → p-181cb82f.entry.js} +1 -1
  249. package/dist/ezui/{p-eee3c7ff.entry.js → p-24993171.entry.js} +1 -1
  250. package/dist/ezui/{p-377768bd.entry.js → p-25748a4e.entry.js} +2 -2
  251. package/dist/ezui/p-27421015.entry.js +1 -0
  252. package/dist/ezui/p-27c8a9b7.entry.js +1 -0
  253. package/dist/ezui/{p-4f0632b4.js → p-29341f74.js} +1 -1
  254. package/dist/ezui/p-29f0de90.entry.js +1 -0
  255. package/dist/ezui/{p-44ad16df.entry.js → p-2b51d5a9.entry.js} +1 -1
  256. package/dist/ezui/p-2c123fdf.entry.js +1 -0
  257. package/dist/ezui/{p-6a9a20a0.entry.js → p-2fa490f1.entry.js} +1 -1
  258. package/dist/ezui/{p-da585ff3.entry.js → p-3453dad5.entry.js} +1 -1
  259. package/dist/ezui/p-34d596a3.entry.js +1 -0
  260. package/dist/ezui/{p-ef8bd3e8.entry.js → p-35e3715c.entry.js} +1 -1
  261. package/dist/ezui/{p-fa6732f2.entry.js → p-44b39e81.entry.js} +1 -1
  262. package/dist/ezui/{p-124699e0.entry.js → p-458027b5.entry.js} +1 -1
  263. package/dist/ezui/p-47e4a8ce.js +1 -0
  264. package/dist/ezui/{p-4d30b703.entry.js → p-4a876b8b.entry.js} +1 -1
  265. package/dist/ezui/p-4d909730.entry.js +1 -0
  266. package/dist/ezui/{p-e27d7dc2.entry.js → p-4df2edb5.entry.js} +1 -1
  267. package/dist/ezui/{p-6369a0cd.entry.js → p-51e34317.entry.js} +1 -1
  268. package/dist/ezui/{p-957d08cd.entry.js → p-534209bf.entry.js} +1 -1
  269. package/dist/ezui/{p-0c0eb410.entry.js → p-55a9e4ba.entry.js} +1 -1
  270. package/dist/ezui/p-5895e687.js +1 -0
  271. package/dist/ezui/{p-59a98e31.entry.js → p-636ea910.entry.js} +1 -1
  272. package/dist/ezui/{p-1f50fa05.entry.js → p-6b51c9cc.entry.js} +1 -1
  273. package/dist/ezui/p-6ec40dec.entry.js +1 -0
  274. package/dist/ezui/{p-5ed81457.entry.js → p-6fc26622.entry.js} +1 -1
  275. package/dist/ezui/p-70f30bfe.entry.js +1 -0
  276. package/dist/ezui/p-71b341cc.entry.js +1 -0
  277. package/dist/ezui/{p-cd6f5783.entry.js → p-75443a91.entry.js} +1 -1
  278. package/dist/ezui/{p-e8c6c973.entry.js → p-75e650ff.entry.js} +1 -1
  279. package/dist/ezui/p-75e8862c.entry.js +1 -0
  280. package/dist/ezui/{p-d6f50207.entry.js → p-770cf2b8.entry.js} +1 -1
  281. package/dist/ezui/{p-91c9d50e.entry.js → p-78e975b4.entry.js} +1 -1
  282. package/dist/ezui/{p-1e7a8633.entry.js → p-81461d2f.entry.js} +1 -1
  283. package/dist/ezui/p-81a98a7c.entry.js +1 -0
  284. package/dist/ezui/p-82e1d7fc.entry.js +1 -0
  285. package/dist/ezui/{p-8df1ca33.entry.js → p-82fa4b09.entry.js} +1 -1
  286. package/dist/ezui/p-87739608.entry.js +1 -0
  287. package/dist/ezui/p-88a115b3.js +1 -0
  288. package/dist/ezui/p-892e7326.entry.js +1 -0
  289. package/dist/ezui/p-8f7373ab.entry.js +1 -0
  290. package/dist/ezui/{p-f34ec732.entry.js → p-980f1f18.entry.js} +1 -1
  291. package/dist/ezui/{p-5a11cf56.js → p-9825c1d2.js} +1 -1
  292. package/dist/ezui/{p-a3075f52.entry.js → p-9bcfa689.entry.js} +1 -1
  293. package/dist/ezui/{p-e882635e.entry.js → p-9d515e5b.entry.js} +1 -1
  294. package/dist/ezui/{p-1adf7139.entry.js → p-9fb7131e.entry.js} +1 -1
  295. package/dist/ezui/{p-6f119d5f.entry.js → p-a6ea8da3.entry.js} +1 -1
  296. package/dist/ezui/{p-d6742c1e.entry.js → p-a9432878.entry.js} +1 -1
  297. package/dist/ezui/{p-e8c57463.entry.js → p-b21efe83.entry.js} +1 -1
  298. package/dist/ezui/{p-a0bf1fc7.entry.js → p-bc693db6.entry.js} +1 -1
  299. package/dist/ezui/{p-1cde96f9.entry.js → p-be2e39c5.entry.js} +1 -1
  300. package/dist/ezui/{p-641ee538.js → p-c178730b.js} +1 -1
  301. package/dist/ezui/{p-9f5fa3f9.entry.js → p-c2b20f78.entry.js} +1 -1
  302. package/dist/ezui/{p-6020f3d5.entry.js → p-c754774e.entry.js} +1 -1
  303. package/dist/ezui/{p-d2645bdf.entry.js → p-c96e536d.entry.js} +1 -1
  304. package/dist/ezui/{p-cfa26133.entry.js → p-ce2614fc.entry.js} +1 -1
  305. package/dist/ezui/{p-20c024f7.entry.js → p-cf33bc48.entry.js} +1 -1
  306. package/dist/ezui/p-d3aca6aa.entry.js +1 -0
  307. package/dist/ezui/p-d57ea090.entry.js +1 -0
  308. package/dist/ezui/{p-a80b1287.entry.js → p-dfca5946.entry.js} +1 -1
  309. package/dist/ezui/{p-5ab08b60.entry.js → p-e0380234.entry.js} +1 -1
  310. package/dist/ezui/{p-e99cbb51.entry.js → p-e039e049.entry.js} +1 -1
  311. package/dist/ezui/{p-a7eab406.entry.js → p-e0fd2ce5.entry.js} +1 -1
  312. package/dist/ezui/{p-7f792043.entry.js → p-e195eaad.entry.js} +1 -1
  313. package/dist/ezui/{p-7b999377.entry.js → p-e275353b.entry.js} +1 -1
  314. package/dist/ezui/{p-23a36bb6.js → p-e4c7eb39.js} +2 -2
  315. package/dist/ezui/{p-2a70f094.entry.js → p-e94d3af5.entry.js} +1 -1
  316. package/dist/ezui/p-e963cb3f.entry.js +1 -0
  317. package/dist/ezui/{p-e7a7c594.entry.js → p-e9b409c1.entry.js} +1 -1
  318. package/dist/ezui/p-f0425f87.entry.js +1 -0
  319. package/dist/ezui/{p-19cf13bc.entry.js → p-f1b54699.entry.js} +1 -1
  320. package/dist/ezui/{p-a3ada561.entry.js → p-f26b97e9.entry.js} +1 -1
  321. package/dist/ezui/{p-ff4bde07.entry.js → p-f32d5a82.entry.js} +1 -1
  322. package/dist/ezui/{p-411c0222.entry.js → p-f7ca8634.entry.js} +1 -1
  323. package/dist/ezui/{p-294f54fe.entry.js → p-fe0bca65.entry.js} +1 -1
  324. package/dist/ezui/p-ff4312d5.js +1 -0
  325. package/dist/types/components/ez-classic-combo-box/ez-classic-combo-box.d.ts +9 -3
  326. package/dist/types/components/ez-classic-date-input/ez-classic-date-input.d.ts +91 -0
  327. package/dist/types/components/ez-classic-date-time-input/ez-classic-date-time-input.d.ts +95 -0
  328. package/dist/types/components/ez-classic-input/ez-classic-input.d.ts +18 -1
  329. package/dist/types/components/ez-classic-number-input/ez-classic-number-input.d.ts +101 -0
  330. package/dist/types/components/ez-classic-search/ez-classic-search.d.ts +219 -0
  331. package/dist/types/components/ez-classic-search/subcomponent/classic-search-list/classic-search-list.d.ts +29 -0
  332. package/dist/types/components/ez-classic-search/utils/searchFormatters.d.ts +2 -0
  333. package/dist/types/components/ez-classic-search-plus/ez-classic-search-plus.d.ts +186 -0
  334. package/dist/types/components/ez-classic-search-plus/subcomponent/ez-search-result-list/ez-classic-search-result-list.d.ts +29 -0
  335. package/dist/types/components/ez-form/ez-form.d.ts +6 -0
  336. package/dist/types/components/ez-form-view/ez-form-view.d.ts +11 -0
  337. package/dist/types/components/ez-form-view/fieldbuilder/FieldBuilder.d.ts +8 -1
  338. package/dist/types/components/ez-form-view/fieldbuilder/templates/CheckBox.tpl.d.ts +3 -2
  339. package/dist/types/components/ez-form-view/fieldbuilder/templates/ComboBox.tpl.d.ts +2 -1
  340. package/dist/types/components/ez-form-view/fieldbuilder/templates/DateInput.tpl.d.ts +5 -4
  341. package/dist/types/components/ez-form-view/fieldbuilder/templates/FileInput.tpl.d.ts +2 -1
  342. package/dist/types/components/ez-form-view/fieldbuilder/templates/ImageInput.tpl.d.ts +2 -0
  343. package/dist/types/components/ez-form-view/fieldbuilder/templates/NumberInput.tpl.d.ts +3 -2
  344. package/dist/types/components/ez-form-view/fieldbuilder/templates/RichText.tpl.d.ts +2 -1
  345. package/dist/types/components/ez-form-view/fieldbuilder/templates/SearchInput.tpl.d.ts +2 -1
  346. package/dist/types/components/ez-form-view/fieldbuilder/templates/SearchInputPlus.tpl.d.ts +2 -1
  347. package/dist/types/components/ez-form-view/fieldbuilder/templates/TextArea.tpl.d.ts +2 -1
  348. package/dist/types/components/ez-form-view/fieldbuilder/templates/TextInput.tpl.d.ts +2 -1
  349. package/dist/types/components/ez-image-input/ez-image-input.d.ts +42 -0
  350. package/dist/types/components/ez-text-input/ez-text-input.d.ts +4 -0
  351. package/dist/types/components.d.ts +3220 -1969
  352. package/dist/types/utils/form/interfaces/FormLayout.d.ts +3 -1
  353. package/dist/types/utils/i18n/locales/en-us.d.ts +18 -0
  354. package/dist/types/utils/i18n/locales/es-es.d.ts +18 -0
  355. package/dist/types/utils/i18n/locales/pt-br.d.ts +18 -0
  356. package/dist/types/utils/i18n/translations.d.ts +54 -0
  357. package/package.json +1 -1
  358. package/react/components.d.ts +9 -0
  359. package/react/components.js +9 -0
  360. package/react/components.js.map +1 -1
  361. package/dist/ezui/p-1266fe78.entry.js +0 -1
  362. package/dist/ezui/p-14807f4e.js +0 -1
  363. package/dist/ezui/p-1730ee24.entry.js +0 -1
  364. package/dist/ezui/p-30ffb9ed.js +0 -1
  365. package/dist/ezui/p-48effc69.entry.js +0 -1
  366. package/dist/ezui/p-59092a66.entry.js +0 -1
  367. package/dist/ezui/p-7fe97ef5.entry.js +0 -1
  368. package/dist/ezui/p-8d626d2b.entry.js +0 -1
  369. package/dist/ezui/p-8dc267ff.entry.js +0 -1
  370. package/dist/ezui/p-96b33264.entry.js +0 -1
  371. package/dist/ezui/p-9b2e6438.entry.js +0 -1
  372. package/dist/ezui/p-adaa2a81.entry.js +0 -1
  373. package/dist/ezui/p-bc2f844e.entry.js +0 -1
  374. package/dist/ezui/p-c82acfc6.entry.js +0 -1
  375. package/dist/ezui/p-d8cc640d.entry.js +0 -1
  376. package/dist/ezui/p-dee18824.entry.js +0 -1
  377. package/dist/ezui/p-df316d40.entry.js +0 -1
  378. package/dist/ezui/p-eca050b4.entry.js +0 -1
@@ -0,0 +1,679 @@
1
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-5a720e56.js';
2
+ import { C as CSSVarsUtils } from './CSSVarsUtils-acba92d7.js';
3
+ import { ObjectUtils, StringUtils, ElementIDUtils } from '@sankhyalabs/core';
4
+ import { A as ApplicationUtils } from './ApplicationUtils-0c5cb207.js';
5
+ import './DialogType-54a62731.js';
6
+ import './CheckMode-bdb2ec19.js';
7
+ import { i as initI18n } from './index-225aa0c3.js';
8
+ import { S as SearchMode } from './types-6f6b2650.js';
9
+ import './FormLayout-bda67973.js';
10
+ import { r as replaceQuotes, a as replaceHighlight } from './searchFormatters-6d9b06e4.js';
11
+
12
+ const ezClassicSearchCss = ":host{--ez-classic-search--height:42px;--ez-classic-search--width:100%;--ez-classic-search__icon--width:48px;--ez-classic-search--border-radius:var(--border--radius-medium, 12px);--ez-classic-search--border-radius-small:var(--border--radius-small, 6px);--ez-classic-search--font-size:var(--text--medium, 14px);--ez-classic-search--font-family:var(--font-pattern, Arial);--ez-classic-search--font-weight--large:var(--text-weight--large, 500);--ez-classic-search--font-weight--medium:var(--text-weight--medium, 400);--ez-classic-search--background-color--xlight:var(--background--xlight, #fff);--ez-classic-search--background-medium:var(--background--medium, #f0f3f7);--ez-classic-search--line-height:calc(var(--text--medium, 14px) + 4px);--ez-classic-search__input--background-color:var(--background--medium, #e0e0e0);--ez-classic-search__input--border:var(--border--medium, 2px solid);--ez-classic-search__input--border-color:var(--ez-classic-search__input--background-color);--ez-classic-search__input--focus--border-color:var(--color--primary, #008561);--ez-classic-search__input--disabled--background-color:var(--color--disable-secondary, #F2F5F8);--ez-classic-search__input--disabled--color:var(--text--disable, #AFB6C0);--ez-classic-search__input--error--border-color:#CC2936;--ez-classic-search__btn--color:var(--title--primary, #2B3A54);--ez-classic-search__btn-disabled--color:var(--text--disable, #AFB6C0);--ez-classic-search__btn-hover--color:var(--color--primary, #4e4e4e);--ez-classic-search__label--color:var(--title--primary, #2B3A54);--ez-classic-search--space--medium:var(--space--medium, 12px);--ez-classic-search--space--small:var(--space--small, 6px);display:flex;flex-wrap:wrap;position:relative;width:var(--ez-classic-search--width)}ez-icon{--ez-icon--color:inherit;font-weight:var(--text-weight--large, 600)}.suppressed-search-input{--ez-classic-input__input--border-color:var(--color--strokes, #dce0e8);--ez-classic-input__input--disabled--background-color:var(--background--xlight, #fff);--ez-classic-input__input--disabled--color:var(--title--primary, #2B3A54)}.btn{outline:none;border:none;background:none;cursor:pointer;color:var(--ez-classic-search__btn--color)}.btn:disabled{cursor:not-allowed;color:var(--ez-classic-search__btn-disabled--color)}.btn:disabled:hover{cursor:not-allowed;color:var(--ez-classic-search__btn-disabled--color)}.btn:hover{color:var(--ez-classic-search__btn-hover--color)}.btn__close{visibility:hidden}ez-classic-input:hover .btn__close,ez-classic-input:focus .btn__close{visibility:visible}";
13
+
14
+ const EzClassicSearch = class {
15
+ constructor(hostRef) {
16
+ registerInstance(this, hostRef);
17
+ this.ezChange = createEvent(this, "ezChange", 7);
18
+ this._changeDeboucingTimeout = null;
19
+ this._limitCharsToSearch = 3;
20
+ this._deboucingTime = 300;
21
+ this._maxWidthValue = 0;
22
+ this._tabPressed = false;
23
+ this._startHighlightTag = "<span class='card-item__highlight'>";
24
+ this._endHighlightTag = "</span>";
25
+ this._preSelection = undefined;
26
+ this._visibleOptions = undefined;
27
+ this._startLoading = false;
28
+ this._showLoading = true;
29
+ this._criteria = undefined;
30
+ this.value = undefined;
31
+ this.label = undefined;
32
+ this.enabled = true;
33
+ this.errorMessage = undefined;
34
+ this.size = "default";
35
+ this.optionLoader = undefined;
36
+ this.contextProperties = undefined;
37
+ this.showSelectedValue = true;
38
+ this.showOptionValue = true;
39
+ this.suppressEmptyOption = false;
40
+ this.stopPropagateEnterKeyEvent = false;
41
+ this.mode = "regular";
42
+ this.classic = false;
43
+ this.required = false;
44
+ this.canShowError = true;
45
+ this.hideErrorOnFocusOut = true;
46
+ this.listOptionsPosition = undefined;
47
+ this.isTextSearch = false;
48
+ this.ignoreLimitCharsToSearch = false;
49
+ this.options = undefined;
50
+ this.suppressSearch = false;
51
+ this.ensureClearButtonVisible = false;
52
+ this.suppressPreLoad = true;
53
+ this.autoFocus = false;
54
+ this.alternativePlaceholder = undefined;
55
+ this.showMore = undefined;
56
+ this.suppressInputPersist = false;
57
+ this.hideDescriptionInput = false;
58
+ }
59
+ observeErrorMessage() {
60
+ var _a;
61
+ if (this._textInput) {
62
+ this._textInput.errorMessage = this.errorMessage;
63
+ if (!((_a = this.errorMessage) === null || _a === void 0 ? void 0 : _a.trim()) && this.errorMessage) {
64
+ this.setInputValue();
65
+ }
66
+ }
67
+ }
68
+ getValue(val) {
69
+ return typeof val === 'object' ? val === null || val === void 0 ? void 0 : val.value : val;
70
+ }
71
+ validateNewValue(newValue, oldValue) {
72
+ const parsedNewValue = this.getValue(newValue);
73
+ const parsedOldValue = this.getValue(oldValue);
74
+ const newValueIsValid = parsedNewValue !== "[object Object]";
75
+ const valuesIsDifferent = parsedNewValue !== parsedOldValue;
76
+ if (newValueIsValid && valuesIsDifferent) {
77
+ return true;
78
+ }
79
+ return false;
80
+ }
81
+ async observeValue(newValue, oldValue) {
82
+ if (this._textInput && this.validateNewValue(newValue, oldValue)) {
83
+ if (typeof newValue === "string") {
84
+ await this.handleValueAsString(newValue);
85
+ return;
86
+ }
87
+ const newValueSelected = this.getSelectedOption(newValue);
88
+ const currentValue = this.getSelectedOption(this._currentValue);
89
+ if (this.isDifferentValues(currentValue, newValueSelected)) {
90
+ this._currentValue = newValueSelected;
91
+ this.setInputValue();
92
+ const valueEmitted = newValueSelected !== null && newValueSelected !== void 0 ? newValueSelected : undefined;
93
+ this.ezChange.emit(valueEmitted);
94
+ }
95
+ this.resetOptions();
96
+ }
97
+ }
98
+ observeOptions(newOptions, oldOptions) {
99
+ if (!newOptions.length && this.suppressPreLoad)
100
+ return;
101
+ if ((newOptions === null || newOptions === void 0 ? void 0 : newOptions.join('')) === (oldOptions === null || oldOptions === void 0 ? void 0 : oldOptions.join('')))
102
+ return;
103
+ this.loadOptions(SearchMode.PRELOAD);
104
+ }
105
+ /*
106
+ * Retorna uma promise com o valor da opção selecionada,
107
+ * que será resolvida quando o backend devolver este dado.
108
+ */
109
+ async getValueAsync() {
110
+ if (!this._showLoading) {
111
+ return new Promise(resolve => resolve(this.value));
112
+ }
113
+ return new Promise(resolve => {
114
+ let id = setInterval(() => {
115
+ if (!this._showLoading) {
116
+ clearInterval(id);
117
+ resolve(this.value);
118
+ }
119
+ }, 100);
120
+ });
121
+ }
122
+ /**
123
+ * Aplica o foco no campo.
124
+ */
125
+ async setFocus(options) {
126
+ if (this._textInput) {
127
+ this._textInput.setFocus(options);
128
+ }
129
+ }
130
+ /**
131
+ * Remove o foco do campo.
132
+ */
133
+ async setBlur() {
134
+ if (this._textInput) {
135
+ this._textInput.setBlur();
136
+ }
137
+ }
138
+ /**
139
+ * Retorna se o conteúdo é inválido.
140
+ */
141
+ async isInvalid() {
142
+ return typeof this.errorMessage === "string" && this.errorMessage.trim() !== "";
143
+ }
144
+ /**
145
+ * Limpa o valor do campo de pesquisa
146
+ */
147
+ async clearValue() {
148
+ this.clearSearch();
149
+ }
150
+ async handleValueAsString(value) {
151
+ if (this.getSelectedOption(value)) {
152
+ this.setInputValue();
153
+ return;
154
+ }
155
+ await this.loadDescriptionValue(value);
156
+ if (!this._currentValue) {
157
+ return;
158
+ }
159
+ this.setInputValue();
160
+ this.ezChange.emit(this.value);
161
+ this._currentValue = this.value;
162
+ }
163
+ isDifferentValues(firstValue, secondValue) {
164
+ return ObjectUtils.objectToString(firstValue || {}) !== ObjectUtils.objectToString(secondValue || {});
165
+ }
166
+ getFormattedText(currentValue) {
167
+ if (currentValue == undefined) {
168
+ return;
169
+ }
170
+ let text = (!this.showSelectedValue || currentValue.value == undefined) ? currentValue.label : currentValue.label ? `${currentValue.value} - ${currentValue.label}` : currentValue.value;
171
+ text = text === null || text === void 0 ? void 0 : text.replace(new RegExp(this._startHighlightTag, 'g'), '').replace(new RegExp(this._endHighlightTag, 'g'), '');
172
+ return text;
173
+ }
174
+ getText() {
175
+ const currentValue = this.getSelectedOption(this._currentValue);
176
+ const text = this.getFormattedText(currentValue);
177
+ return replaceQuotes(text);
178
+ }
179
+ getSelectedOption(value) {
180
+ if (typeof value === "string" || value instanceof String) {
181
+ return this._visibleOptions.find(o => o.value === value);
182
+ }
183
+ if (value) {
184
+ return Object.assign(Object.assign({}, value), { value: replaceHighlight(value === null || value === void 0 ? void 0 : value.value), label: replaceHighlight(value === null || value === void 0 ? void 0 : value.label) });
185
+ }
186
+ return value;
187
+ }
188
+ updateVisibleOptions() {
189
+ let opts = this._source || [];
190
+ if (this.suppressEmptyOption) {
191
+ this._visibleOptions = opts;
192
+ }
193
+ else {
194
+ this._visibleOptions = [{ value: undefined, label: "" }].concat(opts);
195
+ }
196
+ this._maxWidthValue = this.getMaxWidthValue();
197
+ }
198
+ getMaxWidthValue() {
199
+ var _a;
200
+ const arrValues = [];
201
+ (_a = this._visibleOptions) === null || _a === void 0 ? void 0 : _a.forEach(opt => {
202
+ const widthValue = this.getWidthValue(opt.value);
203
+ if (!arrValues.includes(widthValue)) {
204
+ arrValues.push(widthValue);
205
+ }
206
+ });
207
+ return arrValues.length > 1 ? Math.max(...arrValues) : 0;
208
+ }
209
+ getWidthValue(value) {
210
+ if (this._itemValueBasis != undefined) {
211
+ const span = this._itemValueBasis;
212
+ if (value != undefined) {
213
+ span.innerHTML = value;
214
+ return span.clientWidth > 0 ? (span.clientWidth + 2) : 0;
215
+ }
216
+ else {
217
+ span.innerHTML = "";
218
+ }
219
+ }
220
+ return 0;
221
+ }
222
+ showOptions() {
223
+ if (!this.enabled)
224
+ return;
225
+ if (this.isOptionsVisible()) {
226
+ return;
227
+ }
228
+ this._ezPopOverPlusElement.showUnder(this._textInput);
229
+ }
230
+ hideOptions() {
231
+ this._ezPopOverPlusElement.hide();
232
+ }
233
+ isOptionsVisible() {
234
+ return this._ezPopOverPlusElement.opened;
235
+ }
236
+ selectCurrentOption(focusOnInput = true) {
237
+ if (this._preSelection !== undefined) {
238
+ this.selectOption(this._visibleOptions[this._preSelection], focusOnInput);
239
+ this._preSelection = undefined;
240
+ }
241
+ else {
242
+ this.controlListWithOnlyOne();
243
+ }
244
+ }
245
+ updateSource(source) {
246
+ this._startLoading = false;
247
+ if (source instanceof Promise) {
248
+ this._showLoading = true;
249
+ source.then(result => {
250
+ this.updateSource(result);
251
+ }).finally(() => {
252
+ this._showLoading = false;
253
+ });
254
+ this.updateVisibleOptions();
255
+ }
256
+ else {
257
+ this._showLoading = false;
258
+ if (Array.isArray(source)) {
259
+ this._source = source;
260
+ this.updateVisibleOptions();
261
+ if (this._tabPressed) {
262
+ this._tabPressed = false;
263
+ this.controlEmptySearch(false);
264
+ }
265
+ }
266
+ else {
267
+ this.selectOption(source);
268
+ }
269
+ }
270
+ }
271
+ clearSource() {
272
+ this._source = [];
273
+ this.updateVisibleOptions();
274
+ }
275
+ selectOption(newOption, focusOnInput = true) {
276
+ var _a, _b;
277
+ const currentValue = this.getSelectedOption(this.value);
278
+ const newOptionsReplaced = Object.assign(Object.assign({}, newOption), { value: replaceHighlight(newOption === null || newOption === void 0 ? void 0 : newOption.value), label: replaceHighlight(newOption === null || newOption === void 0 ? void 0 : newOption.label) });
279
+ const newOptionsFormatted = Object.assign(Object.assign({}, newOptionsReplaced), { value: replaceQuotes(newOptionsReplaced === null || newOptionsReplaced === void 0 ? void 0 : newOptionsReplaced.value), label: replaceQuotes(newOptionsReplaced === null || newOptionsReplaced === void 0 ? void 0 : newOptionsReplaced.label) });
280
+ if ((((_a = currentValue === null || currentValue === void 0 ? void 0 : currentValue.value) === null || _a === void 0 ? void 0 : _a.toString()) !== ((_b = newOptionsFormatted === null || newOptionsFormatted === void 0 ? void 0 : newOptionsFormatted.value) === null || _b === void 0 ? void 0 : _b.toString()))
281
+ || (currentValue == undefined && newOptionsFormatted != undefined && "value" in newOptionsFormatted)) {
282
+ const adjustedOpt = !(newOptionsFormatted === null || newOptionsFormatted === void 0 ? void 0 : newOptionsFormatted.value) ? undefined : newOptionsFormatted;
283
+ this.value = adjustedOpt;
284
+ this._currentValue = adjustedOpt;
285
+ }
286
+ else {
287
+ this.setInputValue();
288
+ this.resetOptions();
289
+ }
290
+ this._visibleOptions = [];
291
+ this.clearSource();
292
+ if (focusOnInput) {
293
+ setTimeout(() => {
294
+ this.setFocus();
295
+ }, 0);
296
+ }
297
+ }
298
+ loadOptions(mode, argument = "") {
299
+ this._criteria = argument;
300
+ this._startLoading = true;
301
+ if (this.optionLoader) {
302
+ const searchArgument = { mode, argument };
303
+ this.updateSource(this.optionLoader(searchArgument, this.contextProperties));
304
+ }
305
+ else {
306
+ this.updateSource(this.options);
307
+ }
308
+ }
309
+ cancelPreselection() {
310
+ if (!this._textInput.value && this._currentValue && this._source.length > 0) {
311
+ this.selectOption(undefined);
312
+ }
313
+ else {
314
+ window.setTimeout(() => {
315
+ this.setInputValue();
316
+ }, this._deboucingTime);
317
+ }
318
+ this.resetOptions();
319
+ }
320
+ setInputValue(clearError = true) {
321
+ if (this.suppressInputPersist) {
322
+ this.clearSearch();
323
+ return;
324
+ }
325
+ const textValue = this.getText();
326
+ if ((this._textInput.value || '') !== textValue) {
327
+ this._textInput.value = textValue;
328
+ if (clearError) {
329
+ this.errorMessage = null;
330
+ }
331
+ }
332
+ }
333
+ clearSearch() {
334
+ this.value = null;
335
+ this._currentValue = null;
336
+ this._textInput.value = "";
337
+ }
338
+ controlListWithOnlyOne(focusOnInput = true) {
339
+ var _a, _b;
340
+ const source = (_a = this._visibleOptions) === null || _a === void 0 ? void 0 : _a.filter((opt) => opt.label !== "" && opt.value != undefined);
341
+ if ((source === null || source === void 0 ? void 0 : source.length) > 0) {
342
+ const startHighlight = new RegExp(this._startHighlightTag, 'g');
343
+ const endHighlight = new RegExp(this._endHighlightTag, 'g');
344
+ let title = StringUtils.decodeHtmlEntities(source[0].label);
345
+ const option = {
346
+ value: (_b = source[0].value) === null || _b === void 0 ? void 0 : _b.replace(startHighlight, '').replace(endHighlight, ''),
347
+ label: title === null || title === void 0 ? void 0 : title.replace(startHighlight, '').replace(endHighlight, '')
348
+ };
349
+ this.selectOption(option, focusOnInput);
350
+ }
351
+ }
352
+ controlEmptySearch(focusOnInput = true) {
353
+ var _a;
354
+ if (!((_a = this._visibleOptions) === null || _a === void 0 ? void 0 : _a.length)) {
355
+ this.clearSearch();
356
+ ApplicationUtils.info(this.i18n("ez-classic-search.emptyList"));
357
+ }
358
+ else {
359
+ this.controlListWithOnlyOne(focusOnInput);
360
+ }
361
+ }
362
+ async loadDescriptionValue(argument) {
363
+ var _a, _b, _c;
364
+ if (argument == undefined) {
365
+ return;
366
+ }
367
+ if (((_a = this.options) === null || _a === void 0 ? void 0 : _a.length) > 0) {
368
+ this.loadOptionValue(argument);
369
+ return;
370
+ }
371
+ const searchMode = this.hideDescriptionInput ? SearchMode.LOAD_DESCRIPTION : SearchMode.PREDICTIVE;
372
+ const searchArgument = {
373
+ mode: searchMode,
374
+ argument
375
+ };
376
+ try {
377
+ const source = await ((_b = this.optionLoader) === null || _b === void 0 ? void 0 : _b.call(this, searchArgument, this.contextProperties));
378
+ if (source == undefined) {
379
+ return;
380
+ }
381
+ if (source instanceof Promise) {
382
+ source.then((result) => {
383
+ this.setDescriptionValue(result);
384
+ });
385
+ }
386
+ else {
387
+ this.setDescriptionValue(source);
388
+ }
389
+ }
390
+ catch (error) {
391
+ if (((_c = error === null || error === void 0 ? void 0 : error.constructor) === null || _c === void 0 ? void 0 : _c.name) === "WarningException") {
392
+ this.errorMessage = error.message;
393
+ }
394
+ throw error;
395
+ }
396
+ }
397
+ setDescriptionValue(source) {
398
+ const value = (source === null || source === void 0 ? void 0 : source[0]) || source;
399
+ if (value == undefined || !Object.keys(value).length) {
400
+ this.showNoResultMessage();
401
+ return;
402
+ }
403
+ this._currentValue = value ? Object.assign(Object.assign({}, value), { value: replaceHighlight(value.value), label: replaceHighlight(value.label) }) : value;
404
+ this.value = this._currentValue;
405
+ this.setTextInputValue();
406
+ }
407
+ setTextInputValue() {
408
+ if (this._textInput && (this._textInput.value === null || this._textInput.value === undefined)) {
409
+ if (this.value === undefined || this.value === null)
410
+ return;
411
+ const textValue = (typeof this.value === 'string') ? this.value : this.getFormattedText(this.value);
412
+ this._textInput.value = replaceQuotes(textValue);
413
+ }
414
+ }
415
+ loadOptionValue(argument) {
416
+ var _a;
417
+ const source = (_a = this.options) === null || _a === void 0 ? void 0 : _a.find((opt) => opt.value === argument);
418
+ if (source != undefined) {
419
+ this.selectOption(source);
420
+ }
421
+ else {
422
+ this.showNoResultMessage();
423
+ }
424
+ }
425
+ async showNoResultMessage() {
426
+ this.clearSearch();
427
+ ApplicationUtils.info(this.i18n("ez-classic-search.emptySearch", { field: this.getFieldLabel() }));
428
+ }
429
+ getFieldLabel() {
430
+ var _a;
431
+ return (_a = this.label) === null || _a === void 0 ? void 0 : _a.replace(this.i18n("app.requiredInfo"), "").toUpperCase();
432
+ }
433
+ resetOptions() {
434
+ if (this.showMore) {
435
+ this.handleResetOptionsWithShowMoreVisible();
436
+ return;
437
+ }
438
+ this.hideOptions();
439
+ this._criteria = undefined;
440
+ this._preSelection = undefined;
441
+ this.updateVisibleOptions();
442
+ }
443
+ handleResetOptionsWithShowMoreVisible() {
444
+ //Eh preciso adicionar um timeout para garantir que o evento seja escutado pelo botão de mostrar mais.
445
+ setTimeout(() => {
446
+ this.hideOptions();
447
+ this._criteria = undefined;
448
+ this._preSelection = undefined;
449
+ this.updateVisibleOptions();
450
+ }, 100);
451
+ }
452
+ async handleInitialValue() {
453
+ const valueIsValid = !!this.getValue(this.value);
454
+ if (!valueIsValid) {
455
+ return;
456
+ }
457
+ if (typeof this.value === "string") {
458
+ await this.handleValueAsString(this.value);
459
+ return;
460
+ }
461
+ let text = this.getFormattedText(this.value);
462
+ text = replaceQuotes(text);
463
+ this._textInput.value = text;
464
+ }
465
+ //---------------------------------------------
466
+ // Lifecycle web component
467
+ //---------------------------------------------
468
+ async componentWillLoad() {
469
+ this.i18n = await initI18n();
470
+ if (this.options === undefined) {
471
+ this.options = [];
472
+ const optionsTags = this.el.querySelectorAll("option");
473
+ if (optionsTags) {
474
+ optionsTags.forEach(e => {
475
+ let label = e.innerText;
476
+ let value = e.getAttribute("value");
477
+ let details = e.getAttribute("details");
478
+ if (!value) {
479
+ value = label;
480
+ }
481
+ this.options.push({ label, value, details });
482
+ e.hidden = true;
483
+ });
484
+ }
485
+ }
486
+ this.updateSource([]);
487
+ }
488
+ componentDidRender() {
489
+ var _a;
490
+ (_a = this._optionsList) === null || _a === void 0 ? void 0 : _a.querySelectorAll(".item").forEach((elem) => {
491
+ ElementIDUtils.addIDInfoIfNotExists(elem, "itemSearch");
492
+ });
493
+ }
494
+ async componentDidLoad() {
495
+ this._currentValue = this.value;
496
+ CSSVarsUtils.applyVarsTextInput(this.el, this._textInput);
497
+ this._resizeObserver = new ResizeObserver((entries) => {
498
+ window.requestAnimationFrame(() => {
499
+ if (!Array.isArray(entries) || !entries.length)
500
+ return;
501
+ });
502
+ });
503
+ this._intersectionObserver = new IntersectionObserver((entries) => {
504
+ entries.forEach(entry => {
505
+ if (!entry.isIntersecting && this._ezPopOverPlusElement) {
506
+ this._ezPopOverPlusElement.hide();
507
+ }
508
+ });
509
+ }, { threshold: 0.1 });
510
+ if (this._textInput) {
511
+ this._intersectionObserver.observe(this._textInput);
512
+ }
513
+ await this.handleInitialValue();
514
+ if (this.autoFocus) {
515
+ requestAnimationFrame(() => {
516
+ this.setFocus({ selectText: true });
517
+ });
518
+ }
519
+ }
520
+ disconnectedCallback() {
521
+ var _a, _b;
522
+ (_a = this._resizeObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
523
+ (_b = this._intersectionObserver) === null || _b === void 0 ? void 0 : _b.disconnect();
524
+ }
525
+ //---------------------------------------------
526
+ // Event handlers
527
+ //---------------------------------------------
528
+ handleClassicIconClick(event) {
529
+ const { icon } = event.detail;
530
+ if (icon === "left") {
531
+ this.loadOptions(SearchMode.ADVANCED);
532
+ return;
533
+ }
534
+ this.clearSearch();
535
+ }
536
+ buildNumberArgument(argument) {
537
+ if (this.isTextSearch) {
538
+ return NaN;
539
+ }
540
+ return Number(argument || undefined);
541
+ }
542
+ onTextInputChangeHandler(event) {
543
+ var _a;
544
+ this.clearDeboucingTimeout();
545
+ if (this._startLoading) {
546
+ this._changeDeboucingTimeout = window.setTimeout(() => {
547
+ this.onTextInputChangeHandler(event);
548
+ }, this._deboucingTime);
549
+ return;
550
+ }
551
+ const argument = (_a = event.target.value) === null || _a === void 0 ? void 0 : _a.trim();
552
+ const argumentNumber = this.buildNumberArgument(argument);
553
+ if (!this._criteria) {
554
+ this._textInput.value = event.data || argument;
555
+ }
556
+ this._criteria = argument;
557
+ if (argument) {
558
+ this._showLoading = false;
559
+ this.clearSource();
560
+ if (this.ignoreLimitCharsToSearch || !isNaN(argumentNumber) || argument.length >= this._limitCharsToSearch) {
561
+ this._showLoading = true;
562
+ this._changeDeboucingTimeout = window.setTimeout(() => {
563
+ this.loadOptions(SearchMode.PREDICTIVE, isNaN(argumentNumber) ? argument : argumentNumber.toString());
564
+ }, this._deboucingTime);
565
+ this.showOptions();
566
+ }
567
+ else {
568
+ this.hideOptions();
569
+ }
570
+ }
571
+ else {
572
+ this.hideOptions();
573
+ this._showLoading = false;
574
+ this.clearSource();
575
+ }
576
+ }
577
+ clearDeboucingTimeout() {
578
+ if (this._changeDeboucingTimeout) {
579
+ window.clearTimeout(this._changeDeboucingTimeout);
580
+ this._changeDeboucingTimeout = null;
581
+ }
582
+ }
583
+ async keyDownHandler(event) {
584
+ this._tabPressed = false;
585
+ if (event.ctrlKey) {
586
+ if (event.key === "f" || event.key === "F") {
587
+ this.loadOptions(SearchMode.ADVANCED);
588
+ //ATENÇÃO: Ctrl + F tem ação específica nos browsers
589
+ //nesse caso, como vamos abrir o popup de busca avançada,
590
+ //não é interessante deixar o evento propagar;
591
+ event.stopPropagation();
592
+ event.stopImmediatePropagation();
593
+ event.preventDefault();
594
+ }
595
+ }
596
+ switch (event.key) {
597
+ case "ArrowDown":
598
+ event.stopPropagation();
599
+ if (this.canShowListOptions()) {
600
+ event.preventDefault();
601
+ }
602
+ if (!this.isOptionsVisible()) {
603
+ this.showOptions();
604
+ }
605
+ await this._classicSearchList.nextOption();
606
+ break;
607
+ case "ArrowUp":
608
+ event.stopPropagation();
609
+ if (this.canShowListOptions()) {
610
+ event.preventDefault();
611
+ }
612
+ await this._classicSearchList.previousOption();
613
+ break;
614
+ case "Enter":
615
+ this.handleEventPropagation(event);
616
+ this.selectCurrentOption();
617
+ break;
618
+ case "Escape":
619
+ this.cancelPreselection();
620
+ break;
621
+ case "Tab":
622
+ this._tabPressed = true;
623
+ this.selectCurrentOption(false);
624
+ break;
625
+ }
626
+ //ATENÇÃO: Existe a necessidade de propagar o evento de teclado.
627
+ //Por exemplo, quando o usuário dá um Enter, além de selecionar
628
+ //um valor, também significa que a ateração finalizou,
629
+ //e o contexto pode reagir (fechar um popup por exemplo).
630
+ //event.stopPropagation();
631
+ }
632
+ //O evento deve ter sua propagação interrompida, apenas se a lista de opções estiver sendo exibida.
633
+ handleEventPropagation(event) {
634
+ if (this._ezPopOverPlusElement.opened && this.stopPropagateEnterKeyEvent) {
635
+ event.stopPropagation();
636
+ }
637
+ }
638
+ onTextInputFocusOutHandler() {
639
+ if (this.hideErrorOnFocusOut)
640
+ this.cancelPreselection();
641
+ }
642
+ canShowListOptions() {
643
+ return !this._showLoading && this._visibleOptions.length > 0;
644
+ }
645
+ onChangePreSelection(value) {
646
+ this._preSelection = value;
647
+ }
648
+ async handleClickShowMore() {
649
+ var _a, _b;
650
+ if (!this.optionLoader)
651
+ return;
652
+ const argument = (_b = (_a = this._textInput) === null || _a === void 0 ? void 0 : _a.value) !== null && _b !== void 0 ? _b : "";
653
+ const searchArgument = { mode: SearchMode.ADVANCED, argument };
654
+ const selectedOption = await this.optionLoader(searchArgument, this.contextProperties);
655
+ if (selectedOption && !Array.isArray(selectedOption)) {
656
+ this.selectOption(selectedOption);
657
+ }
658
+ }
659
+ renderShowMore() {
660
+ if (!this.showMore || this._showLoading)
661
+ return;
662
+ return (h("div", { style: { display: "flex", justifyContent: "center" }, "data-element-id": ElementIDUtils.getInternalIDInfo("showMore") }, h("ez-button", { onClick: async () => await this.handleClickShowMore(), variant: "tertiary", style: { width: "100%", justifyContent: "center" }, label: this.i18n("ez-classic-search.showMore") })));
663
+ }
664
+ render() {
665
+ var _a;
666
+ ElementIDUtils.addIDInfoIfNotExists(this.el, 'input');
667
+ const canClearSearch = !!(((_a = this._textInput) === null || _a === void 0 ? void 0 : _a.value) && (this._criteria || this.value)) || this.ensureClearButtonVisible;
668
+ return (h(Host, null, h("ez-classic-input", { "data-element-id": 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, helpText: this.canShowError ? this.errorMessage : undefined, state: this.errorMessage && this.canShowError ? "error" : "default", size: this.size, placeholder: this.alternativePlaceholder, leftIconName: "search", leftIconClickable: true, rightIconName: canClearSearch ? "close" : null, rightIconClickable: true, required: this.required, onIconClick: (event) => this.handleClassicIconClick(event), onEzChange: (event) => event.stopPropagation() }), h("ez-popover-plus", { ref: elem => this._ezPopOverPlusElement = elem, autoClose: false, overlayType: "none", useAnchorSize: true, anchorElement: [this._textInput, this.el], "data-element-id": this.el.getAttribute("data-element-id"), onEzVisibilityChange: (event) => event.stopPropagation() }, h("div", null, h("classic-search-list", { ref: (ref) => this._classicSearchList = ref, showLoading: this._showLoading, visibleOptions: this._visibleOptions, textEmptyList: this.i18n("ez-classic-search.emptyList"), canShowListOptions: this.canShowListOptions(), value: this.value, showOptionValue: this.showOptionValue, preSelection: this._preSelection, onChangeValue: ({ detail }) => this.selectOption(detail), onChangePreSelection: ({ detail }) => this.onChangePreSelection(detail) }), this.renderShowMore()))));
669
+ }
670
+ get el() { return getElement(this); }
671
+ static get watchers() { return {
672
+ "errorMessage": ["observeErrorMessage"],
673
+ "value": ["observeValue"],
674
+ "options": ["observeOptions"]
675
+ }; }
676
+ };
677
+ EzClassicSearch.style = ezClassicSearchCss;
678
+
679
+ export { EzClassicSearch as ez_classic_search };