@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,403 @@
1
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-5a720e56.js';
2
+ import { StringUtils, KeyboardManager, ElementIDUtils } from '@sankhyalabs/core';
3
+ import './ApplicationUtils-0c5cb207.js';
4
+ import { C as CSSVarsUtils } from './CSSVarsUtils-acba92d7.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
+
11
+ const ezClassicSearchPlusCss = ":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__list-title--primary:var(--title--primary, #2B3A54);--ez-classic-search__list-text--primary:var(--text--primary, #626e82);--ez-classic-search__list-height:calc(var(--ez-classic-search--font-size) + var(--ez-classic-search--space--medium) + 4px);--ez-classic-search__list-min-width:64px;--ez-classic-search--space--medium:var(--space--medium, 12px);--ez-classic-search--space--small:var(--space--small, 6px);--ez-classic-search__scrollbar--color-default:var(--scrollbar--default, #626e82);--ez-classic-search__scrollbar--color-background:var(--scrollbar--background, #E5EAF0);--ez-classic-search__scrollbar--color-hover:var(--scrollbar--hover, #2B3A54);--ez-classic-search__scrollbar--color-clicked:var(--scrollbar--clicked, #a2abb9);--ez-classic-search__scrollbar--border-radius:var(--border--radius-small, 6px);--ez-classic-search__scrollbar--width:var(--space--medium, 12px);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)}.list-container{min-width:var(--ez-classic-search__list-min-width);overflow:auto;position:relative;width:100%}.list-wrapper{display:flex;flex-direction:column;box-sizing:border-box;width:0;z-index:var(--more-visible, 2);max-height:350px;min-width:150px;background-color:var(--ez-classic-search--background-color--xlight);border-radius:var(--ez-classic-search--border-radius);box-shadow:var(--shadow, 0px 0px 16px 0px #000)}.list-options{margin-top:0px;box-sizing:border-box;width:100%;height:100%;padding:0;display:flex;flex-direction:column;scroll-behavior:smooth;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--ez-classic-search__scrollbar--color-clicked) var(--ez-classic-search__scrollbar--color-background)}.list-options::-webkit-scrollbar{background-color:var(--scrollbar--background);width:var(--space--small);max-width:var(--space--small);min-width:var(--space--small);height:var(--space--small);max-height:var(--space--small);min-height:var(--space--small)}.list-options::-webkit-scrollbar-track{background-color:var(--ez-classic-search__scrollbar--color-background);border-radius:var(--ez-classic-search__scrollbar--border-radius)}.list-options::-webkit-scrollbar-thumb{background-color:var(--ez-classic-search__scrollbar--color-default);border-radius:var(--ez-classic-search__scrollbar--border-radius)}.list-options::-webkit-scrollbar-thumb:vertical:hover,.list-options::-webkit-scrollbar-thumb:horizontal:hover{background-color:var(--ez-classic-search__scrollbar--color-hover)}.list-options::-webkit-scrollbar-thumb:vertical:active,.list-options::-webkit-scrollbar-thumb:horizontal:active{background-color:var(--ez-classic-search__scrollbar--color-clicked)}.item{display:flex;align-items:center;width:100%;box-sizing:border-box;list-style-type:none;cursor:pointer;border-radius:var(--ez-classic-search--border-radius-small);gap:var(--space--small, 6px)}.item__value,.item__label{flex-basis:auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--ez-classic-search__list-title--primary);font-family:var(--ez-classic-search--font-family);font-size:var(--ez-classic-search--font-size);line-height:var(--ez-classic-search--line-height)}.item__label{font-weight:var(--ez-classic-search--font-weight--medium)}.item__label--bold{font-weight:var(--ez-classic-search--font-weight--large)}.item__value{text-align:center;color:var(--ez-classic-search__list-text--primary);font-weight:var(--ez-classic-search--font-weight--large)}.item__value--hidden{visibility:hidden;position:absolute;white-space:nowrap;z-index:-1;top:0;left:0}.item__label{text-align:left}.message{text-align:center;display:flex;justify-content:center;align-items:center;list-style-type:none;min-height:var(--ez-classic-search__list-height)}.message__no-result{color:var(--ez-classic-search__list-title--primary);font-family:var(--ez-classic-search--font-family);font-size:var(--ez-classic-search--font-size)}.message__loading{border-radius:50%;width:14px;height:14px;-webkit-animation:spin 1s linear infinite;animation:spin 1s linear infinite;border:3px solid var(--ez-classic-search__list-title--primary);border-top:3px solid transparent}.item__list>li:hover{background-color:var(--ez-classic-search--background-medium)}.preselected{background-color:var(--background--medium)}.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-c-input:focus .btn__close{visibility:visible}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg)}100%{-webkit-transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}@supports not (scrollbar-width: thin){.item{padding-right:8px}}.ez-classic-search-plus__container{display:flex;flex-grow:1;gap:3px}.ez-classic-search-plus__wrapper{display:flex;flex-direction:column;flex-grow:1;overflow:hidden}.ez-classic-search-plus__label-container{display:flex;flex-grow:1;gap:3px;overflow:hidden}.ez-classic-search-plus__label-container label{overflow:hidden;text-overflow:ellipsis;font-family:var(--font--pattern, Arial, sans-serif);font-size:var(--font-size--default, 14px);white-space:nowrap}.ez-classic-search-plus__text-input{--ez-classic-input--border-top-left-radius:0px;--ez-classic-input--border-bottom-left-radius:0px;outline:none}.ez-classic-search-plus__code-input-no-border{--ez-classic-input--border-top-right-radius:0px;--ez-classic-input--border-bottom-right-radius:0px}.ez-classic-search-plus__code-input{max-width:85px;--ez-classic-input--padding-inline:6px;--ez-classic-input--gap:6px}.ez-classic-search-plus__code-input-full{width:100%}.description-input-container{width:100%;outline:none}.required-indicator{font-size:var(--font--size--default, 14px);font-family:var(--font--pattern, 'Roboto');color:var(--color--red-600, #BD0025);margin-left:var(--space--4, 4px);vertical-align:top}";
12
+
13
+ const EzClassicSearchPlus = class {
14
+ constructor(hostRef) {
15
+ registerInstance(this, hostRef);
16
+ this.ezChange = createEvent(this, "ezChange", 7);
17
+ this.SEARCH_DESCRIPTION_TIMEOUT = 2000;
18
+ this.INTERVAL_TO_RETRY_ASYNC_VALUE = 100;
19
+ this._ignoreNextValue = false;
20
+ this.value = undefined;
21
+ this.enabled = true;
22
+ this.disableCodeInput = false;
23
+ this.disableDescriptionInput = false;
24
+ this.label = undefined;
25
+ this.hideDescriptionInput = false;
26
+ this.canShowError = true;
27
+ this.errorMessage = undefined;
28
+ this.mode = "regular";
29
+ this.size = "default";
30
+ this.required = false;
31
+ this.contextProperties = undefined;
32
+ this.optionLoader = undefined;
33
+ this.showOptionValue = true;
34
+ this.stopPropagateEnterKeyEvent = false;
35
+ this.autoFocus = false;
36
+ this.showSelectedValue = true;
37
+ this.suppressEmptyOption = false;
38
+ this.hideErrorOnFocusOut = true;
39
+ this.listOptionsPosition = undefined;
40
+ this.isTextSearch = false;
41
+ this.ignoreLimitCharsToSearch = false;
42
+ this.suppressSearch = false;
43
+ this.suppressPreLoad = true;
44
+ this.ensureClearButtonVisible = false;
45
+ this.descriptionValue = "";
46
+ this.codeValue = "";
47
+ this.isLoadingDescription = false;
48
+ this.searchDescriptionIsOpen = false;
49
+ this.visibleOptions = undefined;
50
+ this.showLoading = true;
51
+ }
52
+ async observeValue(newValue, oldValue) {
53
+ var _a;
54
+ if (this._ignoreNextValue) {
55
+ this._ignoreNextValue = false;
56
+ return;
57
+ }
58
+ const newNormalizedValue = this.normalizeValueToCodeValue(newValue);
59
+ const oldNormalizedValue = this.normalizeValueToCodeValue(oldValue);
60
+ if (newNormalizedValue === oldNormalizedValue) {
61
+ return;
62
+ }
63
+ if (newNormalizedValue === undefined) {
64
+ this.codeValue = undefined;
65
+ this.descriptionValue = undefined;
66
+ this.ezChange.emit(undefined);
67
+ return;
68
+ }
69
+ this.codeValue = newNormalizedValue;
70
+ try {
71
+ this.descriptionValue = await this.normalizeCodeToDescriptionValue(newValue);
72
+ if (this.descriptionValue === null || this.descriptionValue === undefined) {
73
+ throw new Error("Valor não encontrado!");
74
+ }
75
+ }
76
+ catch (err) {
77
+ this._ignoreNextValue = true;
78
+ this.clearSearch();
79
+ console.warn("[EzSearchPlus] Erro ao obter descrição do registro.", err);
80
+ if (((_a = err === null || err === void 0 ? void 0 : err.constructor) === null || _a === void 0 ? void 0 : _a.name) === "WarningException") {
81
+ this.errorMessage = err.message;
82
+ }
83
+ throw err;
84
+ }
85
+ this.value = this.buildCurrentValue();
86
+ this.ezChange.emit(this.value);
87
+ this.errorMessage = null;
88
+ }
89
+ /**
90
+ * Aplica o foco no campo.
91
+ */
92
+ async setFocus(options) {
93
+ var _a;
94
+ if (this.disableCodeInput) {
95
+ (_a = this._textInputDescriptionValue) === null || _a === void 0 ? void 0 : _a.setFocus(options);
96
+ return;
97
+ }
98
+ if (this._latestFocusedInputElement) {
99
+ this._latestFocusedInputElement.setFocus(options);
100
+ return;
101
+ }
102
+ this._textInputCodeValue.setFocus(options);
103
+ }
104
+ /**
105
+ * Obtém o valor do componente só após a compo de apresentação
106
+ * ter sido resolvido pelo option loader quando necessário
107
+ */
108
+ async getValueAsync() {
109
+ if (!this.isLoadingDescription) {
110
+ const currentOpt = this.buildCurrentValue();
111
+ return new Promise(resolve => resolve(currentOpt));
112
+ }
113
+ return new Promise(resolve => {
114
+ let id = setInterval(() => {
115
+ if (!this.isLoadingDescription) {
116
+ clearInterval(id);
117
+ const currentOpt = this.buildCurrentValue();
118
+ resolve(currentOpt);
119
+ }
120
+ }, this.INTERVAL_TO_RETRY_ASYNC_VALUE);
121
+ });
122
+ }
123
+ /**
124
+ * Limpa o valor do campo de pesquisa
125
+ */
126
+ async clearValue() {
127
+ this.clearSearch();
128
+ }
129
+ /**
130
+ * Remove o foco do campo.
131
+ */
132
+ async setBlur() {
133
+ var _a, _b;
134
+ (_a = this._textInputCodeValue) === null || _a === void 0 ? void 0 : _a.setBlur();
135
+ (_b = this._textInputDescriptionValue) === null || _b === void 0 ? void 0 : _b.setBlur();
136
+ }
137
+ /**
138
+ * Retorna se o conteúdo é inválido.
139
+ */
140
+ async isInvalid() {
141
+ return typeof this.errorMessage === "string" && this.errorMessage.trim() !== "";
142
+ }
143
+ async componentWillLoad() {
144
+ this.i18n = await initI18n();
145
+ if (this.value && StringUtils.isEmpty(this.codeValue)) {
146
+ await this.observeValue(this.value, undefined);
147
+ }
148
+ }
149
+ componentDidLoad() {
150
+ CSSVarsUtils.applyVarsTextInput(this.el, this._textInputCodeValue);
151
+ CSSVarsUtils.applyVarsTextInput(this.el, this._textInputDescriptionValue);
152
+ }
153
+ connectedCallback() {
154
+ this.initKeyboardManager();
155
+ if (this.autoFocus) {
156
+ requestAnimationFrame(() => {
157
+ this.setFocus({ selectText: true });
158
+ });
159
+ }
160
+ }
161
+ clearSearch() {
162
+ this.value = null;
163
+ this.codeValue = null;
164
+ this.descriptionValue = null;
165
+ if (!this.hideDescriptionInput) {
166
+ this._textInputDescriptionValue.value = null;
167
+ }
168
+ }
169
+ async normalizeCodeToDescriptionValue(valueToNormalize) {
170
+ if (!valueToNormalize) {
171
+ return "";
172
+ }
173
+ if (typeof valueToNormalize == 'string') {
174
+ try {
175
+ valueToNormalize = JSON.parse(valueToNormalize);
176
+ if ((valueToNormalize === null || valueToNormalize === void 0 ? void 0 : valueToNormalize.value) && !(valueToNormalize === null || valueToNormalize === void 0 ? void 0 : valueToNormalize.label)) {
177
+ return await this.loadDescriptionValueByCode(valueToNormalize === null || valueToNormalize === void 0 ? void 0 : valueToNormalize.value);
178
+ }
179
+ }
180
+ catch (e) {
181
+ return await this.loadDescriptionValueByCode(valueToNormalize);
182
+ }
183
+ }
184
+ //Se é diferente de objeto, temos que resolver a descrição
185
+ if (typeof valueToNormalize != 'object') {
186
+ return await this.loadDescriptionValueByCode(valueToNormalize);
187
+ }
188
+ return valueToNormalize === null || valueToNormalize === void 0 ? void 0 : valueToNormalize.label;
189
+ }
190
+ normalizeValueToCodeValue(valueToNormalize) {
191
+ if (!valueToNormalize) {
192
+ return undefined;
193
+ }
194
+ if (typeof valueToNormalize == 'string') {
195
+ try {
196
+ valueToNormalize = JSON.parse(valueToNormalize);
197
+ }
198
+ catch (e) {
199
+ return valueToNormalize;
200
+ }
201
+ }
202
+ if (typeof valueToNormalize != 'object') {
203
+ return typeof valueToNormalize === 'number'
204
+ ? String(valueToNormalize)
205
+ : valueToNormalize;
206
+ }
207
+ return valueToNormalize === null || valueToNormalize === void 0 ? void 0 : valueToNormalize.value;
208
+ }
209
+ async loadDescriptionValueByCode(codeValue) {
210
+ if (!this.optionLoader) {
211
+ console.warn(this.i18n("ez-search-plus.optionLoaderNotDefined"));
212
+ return "";
213
+ }
214
+ try {
215
+ this.isLoadingDescription = true;
216
+ const searchArgument = { mode: SearchMode.LOAD_DESCRIPTION, argument: codeValue };
217
+ const loadedOption = await this.optionLoader(searchArgument);
218
+ if (!loadedOption) {
219
+ return "";
220
+ }
221
+ if (Array.isArray(loadedOption)) {
222
+ return loadedOption[0].label;
223
+ }
224
+ return loadedOption.label;
225
+ }
226
+ finally {
227
+ this.isLoadingDescription = false;
228
+ }
229
+ }
230
+ handleCodeInputFocusOut() {
231
+ this.cancelSelection();
232
+ if (this.codeValue == this._textInputCodeValue.value)
233
+ return;
234
+ this.value = this._textInputCodeValue.value;
235
+ }
236
+ handleSearchClick() {
237
+ this.loadAdvancedSearch();
238
+ }
239
+ async loadAdvancedSearch() {
240
+ if (!this.optionLoader) {
241
+ console.warn(this.i18n("ez-search-plus.optionLoaderNotDefined"));
242
+ return;
243
+ }
244
+ const searchArgument = { mode: SearchMode.ADVANCED, argument: "" };
245
+ let selectedItem = undefined;
246
+ try {
247
+ selectedItem = await this.optionLoader(searchArgument, this.contextProperties);
248
+ }
249
+ catch (ignore) { }
250
+ if (!selectedItem)
251
+ return;
252
+ this.value = selectedItem;
253
+ }
254
+ buildCurrentValue() {
255
+ if (StringUtils.isEmpty(this.codeValue)) {
256
+ return undefined;
257
+ }
258
+ return {
259
+ value: this.codeValue,
260
+ label: this.descriptionValue
261
+ };
262
+ }
263
+ async handleTextInputChangeHandler(event) {
264
+ if (!this.searchDescriptionIsOpen) {
265
+ this._popover.showUnder(this.el);
266
+ }
267
+ const argument = event.target.value;
268
+ await this.debounceLoaderOptions(argument);
269
+ }
270
+ async debounceLoaderOptions(argument) {
271
+ if (this._debounceSearch)
272
+ clearTimeout(this._debounceSearch);
273
+ return new Promise((resolve) => {
274
+ this._debounceSearch = setTimeout(async () => {
275
+ await this.processOptionsLoader(argument);
276
+ resolve();
277
+ }, this.SEARCH_DESCRIPTION_TIMEOUT);
278
+ });
279
+ }
280
+ updateKeyOption(option) {
281
+ return (Object.assign(Object.assign({}, option), { presentationValue: option.value, presentationLabel: option.label }));
282
+ }
283
+ parseSearchOptions(options = []) {
284
+ if (Array.isArray(options)) {
285
+ const firstOption = options[0];
286
+ if (!firstOption) {
287
+ return [];
288
+ }
289
+ if ("label" in firstOption || "value" in firstOption) {
290
+ return options.map((option) => this.updateKeyOption(option));
291
+ }
292
+ return options;
293
+ }
294
+ if ("label" in options || "value" in options) {
295
+ [this.updateKeyOption(options)];
296
+ }
297
+ return [options];
298
+ }
299
+ async processOptionsLoader(argument) {
300
+ try {
301
+ this.showLoading = true;
302
+ const searchArgument = { mode: SearchMode.PREDICTIVE, argument };
303
+ const options = await this.optionLoader(searchArgument);
304
+ this.visibleOptions = this.parseSearchOptions(options);
305
+ }
306
+ finally {
307
+ this.showLoading = false;
308
+ }
309
+ }
310
+ handleSelectItem(evt) {
311
+ const currentOpt = evt.detail;
312
+ this.value = currentOpt;
313
+ this._popover.hide();
314
+ window.requestAnimationFrame(() => {
315
+ var _a;
316
+ (_a = this._textInputDescriptionValue) === null || _a === void 0 ? void 0 : _a.setFocus({ selectText: true });
317
+ });
318
+ }
319
+ async handleArrowUp() {
320
+ if (!this.isOptionsVisible()) {
321
+ return;
322
+ }
323
+ await this._classicSearchList.previousOption();
324
+ }
325
+ async handleArrowDown() {
326
+ if (!this.isOptionsVisible()) {
327
+ return;
328
+ }
329
+ await this._classicSearchList.nextOption();
330
+ }
331
+ async selectCurrentItem() {
332
+ var _a;
333
+ await ((_a = this._classicSearchList) === null || _a === void 0 ? void 0 : _a.selectCurrentItem());
334
+ }
335
+ async cancelSelection() {
336
+ var _a, _b, _c;
337
+ const description = typeof this.value === 'object' ? (_a = this.value) === null || _a === void 0 ? void 0 : _a.label : "";
338
+ if (this._textInputDescriptionValue && description && this._textInputDescriptionValue.value != description) {
339
+ this._textInputDescriptionValue.value = description;
340
+ }
341
+ await ((_b = this._classicSearchList) === null || _b === void 0 ? void 0 : _b.cancelSelection());
342
+ (_c = this._popover) === null || _c === void 0 ? void 0 : _c.hide();
343
+ }
344
+ async handleInputTab() {
345
+ await this.cancelSelection();
346
+ }
347
+ async handleInputEsc() {
348
+ var _a;
349
+ await this.cancelSelection();
350
+ await ((_a = this._latestFocusedInputElement) === null || _a === void 0 ? void 0 : _a.setFocus({ selectText: true }));
351
+ }
352
+ async initKeyboardManager() {
353
+ this._keyboardManager = new KeyboardManager();
354
+ const defaultOpts = { element: this.el, propagate: true };
355
+ this._keyboardManager
356
+ .bind("ArrowUp", () => this.handleArrowUp(), Object.assign(Object.assign({}, defaultOpts), { propagate: false }))
357
+ .bind("ArrowDown", () => this.handleArrowDown(), Object.assign(Object.assign({}, defaultOpts), { propagate: false }))
358
+ .bind("Enter", () => this.selectCurrentItem(), Object.assign(Object.assign({}, defaultOpts), { propagate: !this.stopPropagateEnterKeyEvent }))
359
+ .bind("Tab", () => this.handleInputTab(), defaultOpts)
360
+ .bind("Escape", () => this.handleInputEsc(), defaultOpts);
361
+ }
362
+ disconnectedCallback() {
363
+ this._keyboardManager
364
+ .unbind("ArrowUp")
365
+ .unbind("ArrowDown")
366
+ .unbind("Enter")
367
+ .unbind("Tab")
368
+ .unbind("Escape");
369
+ }
370
+ isOptionsVisible() {
371
+ return this._popover.opened;
372
+ }
373
+ setLatestFocusedInputElement(el) {
374
+ this._latestFocusedInputElement = el;
375
+ }
376
+ handleCodeInputFocus() {
377
+ this.setLatestFocusedInputElement(this._textInputCodeValue);
378
+ }
379
+ handleDescriptionInputFocus() {
380
+ this.setLatestFocusedInputElement(this._textInputDescriptionValue);
381
+ }
382
+ handleOnEzVisibilityChange(event) {
383
+ event.stopPropagation();
384
+ this.searchDescriptionIsOpen = event.detail;
385
+ }
386
+ render() {
387
+ var _a, _b;
388
+ ElementIDUtils.addIDInfoIfNotExists(this.el, 'input');
389
+ const canShowClearButton = !this.ensureClearButtonVisible && (!this.value && !((_a = this._textInputCodeValue) === null || _a === void 0 ? void 0 : _a.value) && !((_b = this._textInputDescriptionValue) === null || _b === void 0 ? void 0 : _b.value));
390
+ return (h(Host, null, h("div", { class: "ez-classic-search-plus__wrapper" }, h("div", { class: "ez-classic-search-plus__label-container" }, h("label", { title: this.label }, this.label), this.required && h("span", { class: "required-indicator" }, "*")), h("div", { class: "ez-classic-search-plus__container" }, h("ez-classic-input", { ref: (elem) => this._textInputCodeValue = elem, class: {
391
+ "ez-classic-search-plus__code-input": !this.hideDescriptionInput,
392
+ "ez-classic-search-plus__code-input-no-border": !this.hideDescriptionInput,
393
+ "ez-classic-search-plus__code-input-full": this.hideDescriptionInput
394
+ }, "data-element-id": ElementIDUtils.getInternalIDInfo("codeInput"), "data-slave-mode": "true", enabled: !this.disableCodeInput && this.enabled, size: this.size, label: null, errorMessage: this.hideDescriptionInput ? this.errorMessage : "", value: this.codeValue, onFocusout: () => this.handleCodeInputFocusOut(), onFocus: () => this.handleCodeInputFocus(), leftIconName: "search", leftIconClickable: this.enabled, onIconClick: () => this.handleSearchClick(), onEzChange: (event) => event.stopPropagation() }), !this.hideDescriptionInput && (h("div", { class: "description-input-container" }, h("ez-classic-input", { ref: (elem) => this._textInputDescriptionValue = elem, tabIndex: -1, class: { "ez-classic-search-plus__text-input": true }, "data-element-id": ElementIDUtils.getInternalIDInfo("textInput"), "data-slave-mode": "true", enabled: !this.disableDescriptionInput && this.enabled, label: null, errorMessage: this.errorMessage, size: this.size, value: this.descriptionValue, onInput: (event) => this.handleTextInputChangeHandler(event), onFocus: () => this.handleDescriptionInputFocus(), rightIconName: canShowClearButton ? "close" : null, rightIconClickable: this.enabled, onIconClick: () => this.clearSearch(), onEzChange: (event) => event.stopPropagation() }), h("ez-popover-plus", { ref: elem => this._popover = elem, anchorElement: this.el, autoClose: true, boxWidth: 'fit-content', overlayType: 'none', useAnchorSize: true, onEzVisibilityChange: (event) => this.handleOnEzVisibilityChange(event), "data-element-id": this.el.getAttribute("data-element-id") }, h("ez-classic-search-result-list", { ref: (ref) => this._classicSearchList = ref, showLoading: this.showLoading, visibleOptions: this.visibleOptions, value: this.value, showOptionValue: this.showOptionValue, onChangeValue: (evt) => this.handleSelectItem(evt) }))))))));
395
+ }
396
+ get el() { return getElement(this); }
397
+ static get watchers() { return {
398
+ "value": ["observeValue"]
399
+ }; }
400
+ };
401
+ EzClassicSearchPlus.style = ezClassicSearchPlusCss;
402
+
403
+ export { EzClassicSearchPlus as ez_classic_search_plus };