@sankhyalabs/ezui 7.1.0-dev.21 → 7.1.0-dev.23

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 (274) hide show
  1. package/dist/cjs/{ApplicationUtils-4fb87a9e.js → ApplicationUtils-006ca96f.js} +1 -1
  2. package/dist/cjs/FormLayout-fe8da83c.js +9 -0
  3. package/dist/cjs/{app-globals-cb31a206.js → app-globals-5cb12916.js} +1 -1
  4. package/dist/cjs/{ez-combo-box-list_5.cjs.entry.js → classic-search-list_7.cjs.entry.js} +212 -5
  5. package/dist/cjs/ez-actions-button.cjs.entry.js +4 -3
  6. package/dist/cjs/ez-alert-list.cjs.entry.js +1 -1
  7. package/dist/cjs/ez-avatar.cjs.entry.js +1 -1
  8. package/dist/cjs/ez-calendar.cjs.entry.js +1 -1
  9. package/dist/cjs/ez-classic-combo-box.cjs.entry.js +36 -15
  10. package/dist/cjs/ez-classic-date-input.cjs.entry.js +201 -0
  11. package/dist/cjs/ez-classic-date-time-input.cjs.entry.js +246 -0
  12. package/dist/cjs/ez-classic-input.cjs.entry.js +99 -18
  13. package/dist/cjs/ez-classic-number-input.cjs.entry.js +205 -0
  14. package/dist/cjs/ez-classic-search-plus.cjs.entry.js +407 -0
  15. package/dist/cjs/ez-classic-search.cjs.entry.js +683 -0
  16. package/dist/cjs/ez-classic-text-area.cjs.entry.js +1 -1
  17. package/dist/cjs/ez-classic-time-input.cjs.entry.js +197 -0
  18. package/dist/cjs/ez-collapsible-box.cjs.entry.js +4 -3
  19. package/dist/cjs/ez-combo-box.cjs.entry.js +4 -3
  20. package/dist/cjs/ez-date-input.cjs.entry.js +1 -1
  21. package/dist/cjs/ez-date-time-input.cjs.entry.js +1 -1
  22. package/dist/cjs/ez-dialog.cjs.entry.js +1 -1
  23. package/dist/cjs/ez-double-list.cjs.entry.js +1 -1
  24. package/dist/cjs/ez-file-item.cjs.entry.js +1 -1
  25. package/dist/cjs/ez-form-view.cjs.entry.js +121 -35
  26. package/dist/cjs/ez-form.cjs.entry.js +11 -7
  27. package/dist/cjs/ez-grid.cjs.entry.js +7 -6
  28. package/dist/cjs/ez-guide-navigator.cjs.entry.js +1 -1
  29. package/dist/cjs/ez-icon.cjs.entry.js +1 -1
  30. package/dist/cjs/ez-link-builder_6.cjs.entry.js +1 -1
  31. package/dist/cjs/ez-list.cjs.entry.js +1 -1
  32. package/dist/cjs/ez-modal-container.cjs.entry.js +1 -1
  33. package/dist/cjs/ez-modal.cjs.entry.js +1 -1
  34. package/dist/cjs/ez-multi-selection-list.cjs.entry.js +1 -1
  35. package/dist/cjs/ez-number-input.cjs.entry.js +1 -1
  36. package/dist/cjs/ez-pagination.cjs.entry.js +1 -1
  37. package/dist/cjs/ez-popup.cjs.entry.js +1 -1
  38. package/dist/cjs/ez-search-plus.cjs.entry.js +7 -6
  39. package/dist/cjs/ez-search-result-list.cjs.entry.js +1 -1
  40. package/dist/cjs/ez-search.cjs.entry.js +10 -9
  41. package/dist/cjs/ez-sidebar-navigator.cjs.entry.js +1 -1
  42. package/dist/cjs/ez-skeleton.cjs.entry.js +1 -1
  43. package/dist/cjs/ez-sortable-list.cjs.entry.js +1 -1
  44. package/dist/cjs/ez-spinner.cjs.entry.js +1 -1
  45. package/dist/cjs/ez-split-button.cjs.entry.js +13 -14
  46. package/dist/cjs/ez-split-item.cjs.entry.js +4 -3
  47. package/dist/cjs/ez-text-input.cjs.entry.js +37 -0
  48. package/dist/cjs/ez-time-input.cjs.entry.js +1 -1
  49. package/dist/cjs/ez-tree.cjs.entry.js +1 -1
  50. package/dist/cjs/ez-upload.cjs.entry.js +2 -2
  51. package/dist/cjs/ezui.cjs.js +3 -3
  52. package/dist/cjs/filter-column.cjs.entry.js +1 -1
  53. package/dist/cjs/{index-e61642ff.js → index-350d0fa0.js} +30 -0
  54. package/dist/cjs/index-a7b0c73d.js +42 -18
  55. package/dist/cjs/loader.cjs.js +3 -3
  56. package/dist/cjs/{search-column-51e50b59.js → search-column-fbf680d7.js} +10 -5
  57. package/dist/cjs/searchFormatters-051f8677.js +23 -0
  58. package/dist/cjs/{FormLayout-18853e70.js → types-6a5df0c7.js} +0 -6
  59. package/dist/collection/collection-manifest.json +58 -5
  60. package/dist/collection/components/ez-classic-combo-box/ez-classic-combo-box.css +5 -0
  61. package/dist/collection/components/ez-classic-combo-box/ez-classic-combo-box.js +77 -18
  62. package/dist/collection/components/ez-classic-date-input/ez-classic-date-input.css +44 -0
  63. package/dist/collection/components/ez-classic-date-input/ez-classic-date-input.js +541 -0
  64. package/dist/collection/components/ez-classic-date-time-input/ez-classic-date-time-input.css +44 -0
  65. package/dist/collection/components/ez-classic-date-time-input/ez-classic-date-time-input.js +586 -0
  66. package/dist/collection/components/ez-classic-input/ez-classic-input.css +33 -5
  67. package/dist/collection/components/ez-classic-input/ez-classic-input.js +155 -19
  68. package/dist/collection/components/ez-classic-number-input/ez-classic-number-input.css +16 -0
  69. package/dist/collection/components/ez-classic-number-input/ez-classic-number-input.js +583 -0
  70. package/dist/collection/components/ez-classic-search/ez-classic-search.css +126 -0
  71. package/dist/collection/components/ez-classic-search/ez-classic-search.js +1330 -0
  72. package/dist/collection/components/ez-classic-search/subcomponent/classic-search-list/classic-search-list.css +227 -0
  73. package/dist/collection/components/ez-classic-search/subcomponent/classic-search-list/classic-search-list.js +316 -0
  74. package/dist/collection/components/ez-classic-search/utils/searchFormatters.js +18 -0
  75. package/dist/collection/components/ez-classic-search-plus/ez-classic-search-plus.css +406 -0
  76. package/dist/collection/components/ez-classic-search-plus/ez-classic-search-plus.js +988 -0
  77. package/dist/collection/components/ez-classic-search-plus/subcomponent/ez-search-result-list/ez-classic-search-result-list.css +221 -0
  78. package/dist/collection/components/ez-classic-search-plus/subcomponent/ez-search-result-list/ez-classic-search-result-list.js +298 -0
  79. package/dist/collection/components/ez-classic-text-area/ez-classic-text-area.css +1 -0
  80. package/dist/collection/components/ez-classic-time-input/ez-classic-time-input.css +14 -0
  81. package/dist/collection/components/ez-classic-time-input/ez-classic-time-input.js +511 -0
  82. package/dist/collection/components/ez-form/ez-form.js +9 -5
  83. package/dist/collection/components/ez-form-view/ez-form-view.css +8 -3
  84. package/dist/collection/components/ez-form-view/ez-form-view.js +40 -4
  85. package/dist/collection/components/ez-form-view/fieldbuilder/FieldBuilder.js +6 -3
  86. package/dist/collection/components/ez-form-view/fieldbuilder/templates/CheckBox.tpl.js +9 -6
  87. package/dist/collection/components/ez-form-view/fieldbuilder/templates/ComboBox.tpl.js +8 -1
  88. package/dist/collection/components/ez-form-view/fieldbuilder/templates/DateInput.tpl.js +30 -6
  89. package/dist/collection/components/ez-form-view/fieldbuilder/templates/FileInput.tpl.js +1 -1
  90. package/dist/collection/components/ez-form-view/fieldbuilder/templates/NumberInput.tpl.js +12 -5
  91. package/dist/collection/components/ez-form-view/fieldbuilder/templates/RichText.tpl.js +1 -1
  92. package/dist/collection/components/ez-form-view/fieldbuilder/templates/SearchInput.tpl.js +9 -3
  93. package/dist/collection/components/ez-form-view/fieldbuilder/templates/SearchInputPlus.tpl.js +8 -1
  94. package/dist/collection/components/ez-form-view/fieldbuilder/templates/TextArea.tpl.js +7 -1
  95. package/dist/collection/components/ez-form-view/fieldbuilder/templates/TextInput.tpl.js +8 -1
  96. package/dist/collection/components/ez-form-view/structure/index.js +1 -1
  97. package/dist/collection/components/ez-icon/ez-icon.css +1 -0
  98. package/dist/collection/components/ez-rich-text/ez-rich-text.js +2 -3
  99. package/dist/collection/components/ez-split-button/ez-split-button.js +18 -13
  100. package/dist/collection/components/ez-text-input/ez-text-input.js +38 -1
  101. package/dist/collection/utils/form/DataBinder.js +2 -2
  102. package/dist/collection/utils/form/interfaces/FormLayout.js +3 -1
  103. package/dist/collection/utils/i18n/locales/en-us.js +10 -0
  104. package/dist/collection/utils/i18n/locales/es-es.js +10 -0
  105. package/dist/collection/utils/i18n/locales/pt-br.js +10 -0
  106. package/dist/collection/utils/searchColumn/search-column.js +6 -1
  107. package/dist/custom-elements/index.d.ts +48 -0
  108. package/dist/custom-elements/index.js +2722 -337
  109. package/dist/esm/{ApplicationUtils-985c24ae.js → ApplicationUtils-0c5cb207.js} +1 -1
  110. package/dist/esm/FormLayout-bda67973.js +9 -0
  111. package/dist/esm/{app-globals-75f8a758.js → app-globals-1db10325.js} +1 -1
  112. package/dist/esm/{ez-combo-box-list_5.entry.js → classic-search-list_7.entry.js} +212 -7
  113. package/dist/esm/ez-actions-button.entry.js +4 -3
  114. package/dist/esm/ez-alert-list.entry.js +1 -1
  115. package/dist/esm/ez-avatar.entry.js +1 -1
  116. package/dist/esm/ez-calendar.entry.js +1 -1
  117. package/dist/esm/ez-classic-combo-box.entry.js +36 -15
  118. package/dist/esm/ez-classic-date-input.entry.js +197 -0
  119. package/dist/esm/ez-classic-date-time-input.entry.js +242 -0
  120. package/dist/esm/ez-classic-input.entry.js +100 -19
  121. package/dist/esm/ez-classic-number-input.entry.js +201 -0
  122. package/dist/esm/ez-classic-search-plus.entry.js +403 -0
  123. package/dist/esm/ez-classic-search.entry.js +679 -0
  124. package/dist/esm/ez-classic-text-area.entry.js +1 -1
  125. package/dist/esm/ez-classic-time-input.entry.js +193 -0
  126. package/dist/esm/ez-collapsible-box.entry.js +4 -3
  127. package/dist/esm/ez-combo-box.entry.js +4 -3
  128. package/dist/esm/ez-date-input.entry.js +1 -1
  129. package/dist/esm/ez-date-time-input.entry.js +1 -1
  130. package/dist/esm/ez-dialog.entry.js +1 -1
  131. package/dist/esm/ez-double-list.entry.js +1 -1
  132. package/dist/esm/ez-file-item.entry.js +1 -1
  133. package/dist/esm/ez-form-view.entry.js +121 -35
  134. package/dist/esm/ez-form.entry.js +11 -7
  135. package/dist/esm/ez-grid.entry.js +5 -4
  136. package/dist/esm/ez-guide-navigator.entry.js +1 -1
  137. package/dist/esm/ez-icon.entry.js +1 -1
  138. package/dist/esm/ez-link-builder_6.entry.js +1 -1
  139. package/dist/esm/ez-list.entry.js +1 -1
  140. package/dist/esm/ez-modal-container.entry.js +1 -1
  141. package/dist/esm/ez-modal.entry.js +1 -1
  142. package/dist/esm/ez-multi-selection-list.entry.js +1 -1
  143. package/dist/esm/ez-number-input.entry.js +1 -1
  144. package/dist/esm/ez-pagination.entry.js +1 -1
  145. package/dist/esm/ez-popup.entry.js +1 -1
  146. package/dist/esm/ez-search-plus.entry.js +4 -3
  147. package/dist/esm/ez-search-result-list.entry.js +1 -1
  148. package/dist/esm/ez-search.entry.js +4 -3
  149. package/dist/esm/ez-sidebar-navigator.entry.js +1 -1
  150. package/dist/esm/ez-skeleton.entry.js +1 -1
  151. package/dist/esm/ez-sortable-list.entry.js +1 -1
  152. package/dist/esm/ez-spinner.entry.js +1 -1
  153. package/dist/esm/ez-split-button.entry.js +13 -14
  154. package/dist/esm/ez-split-item.entry.js +4 -3
  155. package/dist/esm/ez-text-input.entry.js +37 -0
  156. package/dist/esm/ez-time-input.entry.js +1 -1
  157. package/dist/esm/ez-tree.entry.js +1 -1
  158. package/dist/esm/ez-upload.entry.js +2 -2
  159. package/dist/esm/ezui.js +3 -3
  160. package/dist/esm/filter-column.entry.js +1 -1
  161. package/dist/esm/{index-a3b24b5d.js → index-225aa0c3.js} +30 -0
  162. package/dist/esm/index-baa5e267.js +42 -18
  163. package/dist/esm/loader.js +3 -3
  164. package/dist/esm/{search-column-0c42248b.js → search-column-40a78cac.js} +10 -5
  165. package/dist/esm/searchFormatters-6d9b06e4.js +20 -0
  166. package/dist/esm/{FormLayout-071d324c.js → types-6f6b2650.js} +1 -7
  167. package/dist/ezui/ezui.esm.js +1 -1
  168. package/dist/ezui/{p-1c3f43e8.entry.js → p-0248846f.entry.js} +1 -1
  169. package/dist/ezui/p-0625743b.entry.js +1 -0
  170. package/dist/ezui/p-07fb22c3.entry.js +1 -0
  171. package/dist/ezui/p-26cd4c2e.entry.js +1 -0
  172. package/dist/ezui/{p-2fd16ff2.entry.js → p-2da9faf1.entry.js} +1 -1
  173. package/dist/ezui/{p-1bf40959.entry.js → p-34d459e4.entry.js} +1 -1
  174. package/dist/ezui/p-44183c39.entry.js +1 -0
  175. package/dist/ezui/p-47e4a8ce.js +1 -0
  176. package/dist/ezui/p-4af745e1.entry.js +1 -0
  177. package/dist/ezui/{p-6c484770.entry.js → p-4c2a4435.entry.js} +1 -1
  178. package/dist/ezui/{p-782fe2e3.entry.js → p-4c76b365.entry.js} +1 -1
  179. package/dist/ezui/p-4e576bb9.entry.js +1 -0
  180. package/dist/ezui/{p-5e6de2c1.entry.js → p-4e869617.entry.js} +1 -1
  181. package/dist/ezui/{p-0e325699.entry.js → p-4f7ad3ee.entry.js} +1 -1
  182. package/dist/ezui/{p-582c3f90.entry.js → p-544605c4.entry.js} +1 -1
  183. package/dist/ezui/p-556bf329.entry.js +1 -0
  184. package/dist/ezui/{p-2676e2a3.entry.js → p-56565777.entry.js} +1 -1
  185. package/dist/ezui/p-57b68d43.entry.js +1 -0
  186. package/dist/ezui/p-5895e687.js +1 -0
  187. package/dist/ezui/{p-714452c7.entry.js → p-5abb220b.entry.js} +1 -1
  188. package/dist/ezui/p-619225ce.entry.js +1 -0
  189. package/dist/ezui/p-679a2942.entry.js +1 -0
  190. package/dist/ezui/{p-474076b3.js → p-6a794336.js} +1 -1
  191. package/dist/ezui/{p-4ea5c8a7.entry.js → p-6ac056d7.entry.js} +1 -1
  192. package/dist/ezui/p-7134726a.entry.js +1 -0
  193. package/dist/ezui/{p-67f9fadb.entry.js → p-729bd1be.entry.js} +1 -1
  194. package/dist/ezui/p-7953ecb9.entry.js +1 -0
  195. package/dist/ezui/{p-e2e0dd76.entry.js → p-7edc3ef7.entry.js} +1 -1
  196. package/dist/ezui/p-88a115b3.js +1 -0
  197. package/dist/ezui/{p-f45ddc1f.entry.js → p-8e5f1c74.entry.js} +1 -1
  198. package/dist/ezui/p-951b32a1.entry.js +1 -0
  199. package/dist/ezui/{p-9568a93d.entry.js → p-97312709.entry.js} +1 -1
  200. package/dist/ezui/{p-0ec5c128.js → p-9825c1d2.js} +1 -1
  201. package/dist/ezui/p-987185c4.entry.js +1 -0
  202. package/dist/ezui/p-a0f51b99.entry.js +1 -0
  203. package/dist/ezui/p-a3bad8f8.entry.js +1 -0
  204. package/dist/ezui/{p-6570ca10.entry.js → p-a4351519.entry.js} +1 -1
  205. package/dist/ezui/{p-7624767b.entry.js → p-a872c642.entry.js} +1 -1
  206. package/dist/ezui/p-b0a716ef.entry.js +1 -0
  207. package/dist/ezui/p-b36475f9.entry.js +1 -0
  208. package/dist/ezui/{p-2b23906a.entry.js → p-b705b342.entry.js} +1 -1
  209. package/dist/ezui/{p-9771ea3c.entry.js → p-b8078832.entry.js} +1 -1
  210. package/dist/ezui/p-c0ae79fa.entry.js +1 -0
  211. package/dist/ezui/{p-98218fbc.js → p-c178730b.js} +1 -1
  212. package/dist/ezui/{p-a1a63294.entry.js → p-c56ee8c0.entry.js} +1 -1
  213. package/dist/ezui/{p-3d71e8e1.entry.js → p-cd8be0c7.entry.js} +1 -1
  214. package/dist/ezui/{p-a13e65a4.entry.js → p-ce0a0036.entry.js} +1 -1
  215. package/dist/ezui/{p-0aafbc30.entry.js → p-df802548.entry.js} +1 -1
  216. package/dist/ezui/p-e2689b33.entry.js +1 -0
  217. package/dist/ezui/{p-dc192d01.entry.js → p-e2972977.entry.js} +1 -1
  218. package/dist/ezui/{p-47d9256e.entry.js → p-e3a42f47.entry.js} +1 -1
  219. package/dist/ezui/p-e3cd5080.entry.js +1 -0
  220. package/dist/ezui/{p-28af6826.entry.js → p-e493ad57.entry.js} +1 -1
  221. package/dist/ezui/{p-3fcf79c7.entry.js → p-f5552540.entry.js} +1 -1
  222. package/dist/ezui/p-ff4312d5.js +1 -0
  223. package/dist/types/components/ez-classic-combo-box/ez-classic-combo-box.d.ts +9 -3
  224. package/dist/types/components/ez-classic-date-input/ez-classic-date-input.d.ts +91 -0
  225. package/dist/types/components/ez-classic-date-time-input/ez-classic-date-time-input.d.ts +95 -0
  226. package/dist/types/components/ez-classic-input/ez-classic-input.d.ts +18 -1
  227. package/dist/types/components/ez-classic-number-input/ez-classic-number-input.d.ts +101 -0
  228. package/dist/types/components/ez-classic-search/ez-classic-search.d.ts +219 -0
  229. package/dist/types/components/ez-classic-search/subcomponent/classic-search-list/classic-search-list.d.ts +29 -0
  230. package/dist/types/components/ez-classic-search/utils/searchFormatters.d.ts +2 -0
  231. package/dist/types/components/ez-classic-search-plus/ez-classic-search-plus.d.ts +186 -0
  232. package/dist/types/components/ez-classic-search-plus/subcomponent/ez-search-result-list/ez-classic-search-result-list.d.ts +29 -0
  233. package/dist/types/components/ez-form/ez-form.d.ts +1 -0
  234. package/dist/types/components/ez-form-view/ez-form-view.d.ts +7 -0
  235. package/dist/types/components/ez-form-view/fieldbuilder/FieldBuilder.d.ts +7 -2
  236. package/dist/types/components/ez-form-view/fieldbuilder/templates/CheckBox.tpl.d.ts +3 -2
  237. package/dist/types/components/ez-form-view/fieldbuilder/templates/ComboBox.tpl.d.ts +2 -1
  238. package/dist/types/components/ez-form-view/fieldbuilder/templates/DateInput.tpl.d.ts +5 -4
  239. package/dist/types/components/ez-form-view/fieldbuilder/templates/FileInput.tpl.d.ts +2 -1
  240. package/dist/types/components/ez-form-view/fieldbuilder/templates/NumberInput.tpl.d.ts +3 -2
  241. package/dist/types/components/ez-form-view/fieldbuilder/templates/RichText.tpl.d.ts +2 -1
  242. package/dist/types/components/ez-form-view/fieldbuilder/templates/SearchInput.tpl.d.ts +2 -1
  243. package/dist/types/components/ez-form-view/fieldbuilder/templates/SearchInputPlus.tpl.d.ts +2 -1
  244. package/dist/types/components/ez-form-view/fieldbuilder/templates/TextArea.tpl.d.ts +2 -1
  245. package/dist/types/components/ez-form-view/fieldbuilder/templates/TextInput.tpl.d.ts +2 -1
  246. package/dist/types/components/ez-split-button/ez-split-button.d.ts +1 -2
  247. package/dist/types/components/ez-text-input/ez-text-input.d.ts +4 -0
  248. package/dist/types/components.d.ts +2967 -1814
  249. package/dist/types/utils/form/interfaces/FormLayout.d.ts +3 -1
  250. package/dist/types/utils/i18n/locales/en-us.d.ts +10 -0
  251. package/dist/types/utils/i18n/locales/es-es.d.ts +10 -0
  252. package/dist/types/utils/i18n/locales/pt-br.d.ts +10 -0
  253. package/dist/types/utils/i18n/translations.d.ts +30 -0
  254. package/package.json +1 -1
  255. package/react/components.d.ts +8 -0
  256. package/react/components.js +8 -0
  257. package/react/components.js.map +1 -1
  258. package/dist/ezui/p-2e5de2a7.entry.js +0 -1
  259. package/dist/ezui/p-30ffb9ed.js +0 -1
  260. package/dist/ezui/p-48effc69.entry.js +0 -1
  261. package/dist/ezui/p-6a982147.js +0 -1
  262. package/dist/ezui/p-6d7f2fdc.entry.js +0 -1
  263. package/dist/ezui/p-6f466aec.entry.js +0 -1
  264. package/dist/ezui/p-7fe97ef5.entry.js +0 -1
  265. package/dist/ezui/p-8709c4f6.entry.js +0 -1
  266. package/dist/ezui/p-8a8006e6.entry.js +0 -1
  267. package/dist/ezui/p-8d626d2b.entry.js +0 -1
  268. package/dist/ezui/p-9b2e6438.entry.js +0 -1
  269. package/dist/ezui/p-9d004e22.entry.js +0 -1
  270. package/dist/ezui/p-c711900a.entry.js +0 -1
  271. package/dist/ezui/p-dee18824.entry.js +0 -1
  272. package/dist/ezui/p-e4a579f2.entry.js +0 -1
  273. package/dist/ezui/p-e82a12c6.entry.js +0 -1
  274. package/dist/ezui/p-f1bbf23f.entry.js +0 -1
@@ -0,0 +1,205 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-a7b0c73d.js');
6
+ const core = require('@sankhyalabs/core');
7
+ const CSSVarsUtils = require('./CSSVarsUtils-f20973d1.js');
8
+ const index$1 = require('./index-350d0fa0.js');
9
+
10
+ const ezClassicNumberInputCss = ":host{--ez-classic-number-input__min-width:0px;--ez-classic-number-input__max-width:100%;display:block;width:100%}.number__input{height:100%;min-width:var(--ez-classic-number-input__min-width);max-width:var(--ez-classic-number-input__max-width)}";
11
+
12
+ const EzClassicNumberInput = class {
13
+ constructor(hostRef) {
14
+ index.registerInstance(this, hostRef);
15
+ this.ezChange = index.createEvent(this, "ezChange", 7);
16
+ this.ezStartChange = index.createEvent(this, "ezStartChange", 7);
17
+ this.ezCancelWaitingChange = index.createEvent(this, "ezCancelWaitingChange", 7);
18
+ this._focused = false;
19
+ this._changePending = false;
20
+ this._valuePromiseCallbacks = [];
21
+ this._value = undefined;
22
+ this.label = undefined;
23
+ this.value = undefined;
24
+ this.enabled = true;
25
+ this.required = false;
26
+ this.canShowError = true;
27
+ this.errorMessage = undefined;
28
+ this.allowNegative = true;
29
+ this.precision = undefined;
30
+ this.prettyPrecision = undefined;
31
+ this.mode = "regular";
32
+ this.size = "default";
33
+ this.autoFocus = false;
34
+ this.alternativePlaceholder = undefined;
35
+ }
36
+ /**
37
+ * Aplica o foco no campo.
38
+ */
39
+ async setFocus(options) {
40
+ this._textInput.setFocus(options);
41
+ }
42
+ /**
43
+ * Remove o foco do campo.
44
+ */
45
+ async setBlur() {
46
+ this._textInput.setBlur();
47
+ }
48
+ /**
49
+ * Retorna se o conteúdo é inválido.
50
+ */
51
+ async isInvalid() {
52
+ return typeof this.errorMessage === "string" && this.errorMessage.trim() !== "";
53
+ }
54
+ /*
55
+ * Retorna uma promise com o valor da opção selecionada,
56
+ * que será resolvida quando o backend devolver este dado.
57
+ */
58
+ async getValueAsync() {
59
+ if (this._changePending) {
60
+ return new Promise(accept => {
61
+ this._valuePromiseCallbacks.push(accept);
62
+ });
63
+ }
64
+ return Promise.resolve(this.value);
65
+ }
66
+ observeLabel() {
67
+ if (this._textInput) {
68
+ this._textInput.label = this.label;
69
+ }
70
+ }
71
+ observeErrorMessage() {
72
+ var _a;
73
+ if (this._textInput) {
74
+ this._textInput.errorMessage = this.errorMessage;
75
+ if (!((_a = this.errorMessage) === null || _a === void 0 ? void 0 : _a.trim())) {
76
+ this.setInputValue();
77
+ }
78
+ }
79
+ }
80
+ observeValue(newValue, oldValue) {
81
+ if (this._textInput && newValue != oldValue) {
82
+ this.handleNewValue(newValue, oldValue);
83
+ }
84
+ this._changePending = false;
85
+ }
86
+ observePrecision() {
87
+ if (this._textInput) {
88
+ this.setInputValue();
89
+ }
90
+ }
91
+ handleNewValue(newValue, oldValue) {
92
+ const newValueValidated = this.validateValue(newValue);
93
+ const oldValueValidated = this.validateValue(oldValue);
94
+ if (newValueValidated === null) {
95
+ this._value = '';
96
+ }
97
+ if (newValueValidated === oldValueValidated) {
98
+ return;
99
+ }
100
+ const textValue = this.getTextValue(newValueValidated) || '';
101
+ const parsedNumber = this.getParsedNumber(textValue);
102
+ if ((this._value || '') !== textValue && (parsedNumber !== undefined || !this._focused)) {
103
+ this._value = textValue;
104
+ this._focused = false;
105
+ this.errorMessage = "";
106
+ }
107
+ const valueEmitted = newValueValidated === null ? undefined : newValueValidated;
108
+ this.ezChange.emit(valueEmitted);
109
+ }
110
+ validateValue(value) {
111
+ return isNaN(value) || value === undefined ? null : value;
112
+ }
113
+ getTextValue(value) {
114
+ if (value == undefined)
115
+ return undefined;
116
+ let textValue = this.precision >= 0 ? core.NumberUtils.format(value.toString(), Number(this.precision), Number(this.prettyPrecision)) : value.toString();
117
+ return (this.precision === 0) ? core.StringUtils.replaceAll(textValue, ".", "") : textValue;
118
+ }
119
+ changeValue(newValue) {
120
+ this.errorMessage = "";
121
+ if (this.value != newValue) {
122
+ this.value = newValue === undefined ? null : newValue;
123
+ }
124
+ else {
125
+ this.setInputValue();
126
+ this.ezCancelWaitingChange.emit();
127
+ }
128
+ }
129
+ setError(msg) {
130
+ this.value = null;
131
+ this.errorMessage = msg;
132
+ this.ezCancelWaitingChange.emit();
133
+ }
134
+ handleBlur() {
135
+ if (!this._changePending) {
136
+ return;
137
+ }
138
+ try {
139
+ const parsedNumber = this.getParsedNumber();
140
+ if (parsedNumber !== undefined && isNaN(parsedNumber)) {
141
+ this.setError(this.i18n("ez-classic-number-input.invalidNumber"));
142
+ }
143
+ else {
144
+ try {
145
+ this.changeValue(parsedNumber);
146
+ }
147
+ catch (e) {
148
+ this.setError(e.message);
149
+ return;
150
+ }
151
+ }
152
+ }
153
+ finally {
154
+ for (const callback of this._valuePromiseCallbacks) {
155
+ callback(this.value);
156
+ }
157
+ this._valuePromiseCallbacks = [];
158
+ }
159
+ }
160
+ handleInput() {
161
+ const parsedNumber = this.getParsedNumber();
162
+ if (parsedNumber !== this.value) {
163
+ this._focused = true;
164
+ this._changePending = true;
165
+ this.ezStartChange.emit({ waitmessage: "", blocking: false });
166
+ }
167
+ }
168
+ getParsedNumber(value = this._textInput.value) {
169
+ return (value === null || value === void 0 ? void 0 : value.trim()) ? core.NumberUtils.stringToNumber(value) : undefined;
170
+ }
171
+ setInputValue() {
172
+ const textValue = this.getTextValue(this.value) || '';
173
+ if ((this._value || '') !== textValue) {
174
+ this._value = textValue;
175
+ this._textInput.value = this._value;
176
+ }
177
+ }
178
+ async componentWillLoad() {
179
+ this.i18n = await index$1.initI18n();
180
+ }
181
+ componentDidLoad() {
182
+ CSSVarsUtils.CSSVarsUtils.applyVarsTextInput(this._elem, this._textInput);
183
+ this.setInputValue();
184
+ if (this.autoFocus) {
185
+ requestAnimationFrame(() => {
186
+ this.setFocus({ selectText: true });
187
+ });
188
+ }
189
+ }
190
+ render() {
191
+ core.ElementIDUtils.addIDInfoIfNotExists(this._elem, 'input');
192
+ return (index.h("ez-classic-input", { class: "number__input", "data-element-id": core.ElementIDUtils.getInternalIDInfo("textInput"), ref: (elem) => this._textInput = elem, "data-slave-mode": "true", label: this.label, onBlur: () => this.handleBlur(), onInput: () => this.handleInput(), enabled: this.enabled, errorMessage: this.errorMessage, size: this.size, value: this._value, required: this.required, onEzChange: (event) => event.stopPropagation() }));
193
+ }
194
+ get _elem() { return index.getElement(this); }
195
+ static get watchers() { return {
196
+ "label": ["observeLabel"],
197
+ "errorMessage": ["observeErrorMessage"],
198
+ "value": ["observeValue"],
199
+ "precision": ["observePrecision"],
200
+ "prettyPrecision": ["observePrecision"]
201
+ }; }
202
+ };
203
+ EzClassicNumberInput.style = ezClassicNumberInputCss;
204
+
205
+ exports.ez_classic_number_input = EzClassicNumberInput;
@@ -0,0 +1,407 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-a7b0c73d.js');
6
+ const core = require('@sankhyalabs/core');
7
+ require('./ApplicationUtils-006ca96f.js');
8
+ const CSSVarsUtils = require('./CSSVarsUtils-f20973d1.js');
9
+ require('./DialogType-2114c337.js');
10
+ require('./CheckMode-ecb90b87.js');
11
+ const index$1 = require('./index-350d0fa0.js');
12
+ const types = require('./types-6a5df0c7.js');
13
+ require('./FormLayout-fe8da83c.js');
14
+
15
+ 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}";
16
+
17
+ const EzClassicSearchPlus = class {
18
+ constructor(hostRef) {
19
+ index.registerInstance(this, hostRef);
20
+ this.ezChange = index.createEvent(this, "ezChange", 7);
21
+ this.SEARCH_DESCRIPTION_TIMEOUT = 2000;
22
+ this.INTERVAL_TO_RETRY_ASYNC_VALUE = 100;
23
+ this._ignoreNextValue = false;
24
+ this.value = undefined;
25
+ this.enabled = true;
26
+ this.disableCodeInput = false;
27
+ this.disableDescriptionInput = false;
28
+ this.label = undefined;
29
+ this.hideDescriptionInput = false;
30
+ this.canShowError = true;
31
+ this.errorMessage = undefined;
32
+ this.mode = "regular";
33
+ this.size = "default";
34
+ this.required = false;
35
+ this.contextProperties = undefined;
36
+ this.optionLoader = undefined;
37
+ this.showOptionValue = true;
38
+ this.stopPropagateEnterKeyEvent = false;
39
+ this.autoFocus = false;
40
+ this.showSelectedValue = true;
41
+ this.suppressEmptyOption = false;
42
+ this.hideErrorOnFocusOut = true;
43
+ this.listOptionsPosition = undefined;
44
+ this.isTextSearch = false;
45
+ this.ignoreLimitCharsToSearch = false;
46
+ this.suppressSearch = false;
47
+ this.suppressPreLoad = true;
48
+ this.ensureClearButtonVisible = false;
49
+ this.descriptionValue = "";
50
+ this.codeValue = "";
51
+ this.isLoadingDescription = false;
52
+ this.searchDescriptionIsOpen = false;
53
+ this.visibleOptions = undefined;
54
+ this.showLoading = true;
55
+ }
56
+ async observeValue(newValue, oldValue) {
57
+ var _a;
58
+ if (this._ignoreNextValue) {
59
+ this._ignoreNextValue = false;
60
+ return;
61
+ }
62
+ const newNormalizedValue = this.normalizeValueToCodeValue(newValue);
63
+ const oldNormalizedValue = this.normalizeValueToCodeValue(oldValue);
64
+ if (newNormalizedValue === oldNormalizedValue) {
65
+ return;
66
+ }
67
+ if (newNormalizedValue === undefined) {
68
+ this.codeValue = undefined;
69
+ this.descriptionValue = undefined;
70
+ this.ezChange.emit(undefined);
71
+ return;
72
+ }
73
+ this.codeValue = newNormalizedValue;
74
+ try {
75
+ this.descriptionValue = await this.normalizeCodeToDescriptionValue(newValue);
76
+ if (this.descriptionValue === null || this.descriptionValue === undefined) {
77
+ throw new Error("Valor não encontrado!");
78
+ }
79
+ }
80
+ catch (err) {
81
+ this._ignoreNextValue = true;
82
+ this.clearSearch();
83
+ console.warn("[EzSearchPlus] Erro ao obter descrição do registro.", err);
84
+ if (((_a = err === null || err === void 0 ? void 0 : err.constructor) === null || _a === void 0 ? void 0 : _a.name) === "WarningException") {
85
+ this.errorMessage = err.message;
86
+ }
87
+ throw err;
88
+ }
89
+ this.value = this.buildCurrentValue();
90
+ this.ezChange.emit(this.value);
91
+ this.errorMessage = null;
92
+ }
93
+ /**
94
+ * Aplica o foco no campo.
95
+ */
96
+ async setFocus(options) {
97
+ var _a;
98
+ if (this.disableCodeInput) {
99
+ (_a = this._textInputDescriptionValue) === null || _a === void 0 ? void 0 : _a.setFocus(options);
100
+ return;
101
+ }
102
+ if (this._latestFocusedInputElement) {
103
+ this._latestFocusedInputElement.setFocus(options);
104
+ return;
105
+ }
106
+ this._textInputCodeValue.setFocus(options);
107
+ }
108
+ /**
109
+ * Obtém o valor do componente só após a compo de apresentação
110
+ * ter sido resolvido pelo option loader quando necessário
111
+ */
112
+ async getValueAsync() {
113
+ if (!this.isLoadingDescription) {
114
+ const currentOpt = this.buildCurrentValue();
115
+ return new Promise(resolve => resolve(currentOpt));
116
+ }
117
+ return new Promise(resolve => {
118
+ let id = setInterval(() => {
119
+ if (!this.isLoadingDescription) {
120
+ clearInterval(id);
121
+ const currentOpt = this.buildCurrentValue();
122
+ resolve(currentOpt);
123
+ }
124
+ }, this.INTERVAL_TO_RETRY_ASYNC_VALUE);
125
+ });
126
+ }
127
+ /**
128
+ * Limpa o valor do campo de pesquisa
129
+ */
130
+ async clearValue() {
131
+ this.clearSearch();
132
+ }
133
+ /**
134
+ * Remove o foco do campo.
135
+ */
136
+ async setBlur() {
137
+ var _a, _b;
138
+ (_a = this._textInputCodeValue) === null || _a === void 0 ? void 0 : _a.setBlur();
139
+ (_b = this._textInputDescriptionValue) === null || _b === void 0 ? void 0 : _b.setBlur();
140
+ }
141
+ /**
142
+ * Retorna se o conteúdo é inválido.
143
+ */
144
+ async isInvalid() {
145
+ return typeof this.errorMessage === "string" && this.errorMessage.trim() !== "";
146
+ }
147
+ async componentWillLoad() {
148
+ this.i18n = await index$1.initI18n();
149
+ if (this.value && core.StringUtils.isEmpty(this.codeValue)) {
150
+ await this.observeValue(this.value, undefined);
151
+ }
152
+ }
153
+ componentDidLoad() {
154
+ CSSVarsUtils.CSSVarsUtils.applyVarsTextInput(this.el, this._textInputCodeValue);
155
+ CSSVarsUtils.CSSVarsUtils.applyVarsTextInput(this.el, this._textInputDescriptionValue);
156
+ }
157
+ connectedCallback() {
158
+ this.initKeyboardManager();
159
+ if (this.autoFocus) {
160
+ requestAnimationFrame(() => {
161
+ this.setFocus({ selectText: true });
162
+ });
163
+ }
164
+ }
165
+ clearSearch() {
166
+ this.value = null;
167
+ this.codeValue = null;
168
+ this.descriptionValue = null;
169
+ if (!this.hideDescriptionInput) {
170
+ this._textInputDescriptionValue.value = null;
171
+ }
172
+ }
173
+ async normalizeCodeToDescriptionValue(valueToNormalize) {
174
+ if (!valueToNormalize) {
175
+ return "";
176
+ }
177
+ if (typeof valueToNormalize == 'string') {
178
+ try {
179
+ valueToNormalize = JSON.parse(valueToNormalize);
180
+ if ((valueToNormalize === null || valueToNormalize === void 0 ? void 0 : valueToNormalize.value) && !(valueToNormalize === null || valueToNormalize === void 0 ? void 0 : valueToNormalize.label)) {
181
+ return await this.loadDescriptionValueByCode(valueToNormalize === null || valueToNormalize === void 0 ? void 0 : valueToNormalize.value);
182
+ }
183
+ }
184
+ catch (e) {
185
+ return await this.loadDescriptionValueByCode(valueToNormalize);
186
+ }
187
+ }
188
+ //Se é diferente de objeto, temos que resolver a descrição
189
+ if (typeof valueToNormalize != 'object') {
190
+ return await this.loadDescriptionValueByCode(valueToNormalize);
191
+ }
192
+ return valueToNormalize === null || valueToNormalize === void 0 ? void 0 : valueToNormalize.label;
193
+ }
194
+ normalizeValueToCodeValue(valueToNormalize) {
195
+ if (!valueToNormalize) {
196
+ return undefined;
197
+ }
198
+ if (typeof valueToNormalize == 'string') {
199
+ try {
200
+ valueToNormalize = JSON.parse(valueToNormalize);
201
+ }
202
+ catch (e) {
203
+ return valueToNormalize;
204
+ }
205
+ }
206
+ if (typeof valueToNormalize != 'object') {
207
+ return typeof valueToNormalize === 'number'
208
+ ? String(valueToNormalize)
209
+ : valueToNormalize;
210
+ }
211
+ return valueToNormalize === null || valueToNormalize === void 0 ? void 0 : valueToNormalize.value;
212
+ }
213
+ async loadDescriptionValueByCode(codeValue) {
214
+ if (!this.optionLoader) {
215
+ console.warn(this.i18n("ez-search-plus.optionLoaderNotDefined"));
216
+ return "";
217
+ }
218
+ try {
219
+ this.isLoadingDescription = true;
220
+ const searchArgument = { mode: types.SearchMode.LOAD_DESCRIPTION, argument: codeValue };
221
+ const loadedOption = await this.optionLoader(searchArgument);
222
+ if (!loadedOption) {
223
+ return "";
224
+ }
225
+ if (Array.isArray(loadedOption)) {
226
+ return loadedOption[0].label;
227
+ }
228
+ return loadedOption.label;
229
+ }
230
+ finally {
231
+ this.isLoadingDescription = false;
232
+ }
233
+ }
234
+ handleCodeInputFocusOut() {
235
+ this.cancelSelection();
236
+ if (this.codeValue == this._textInputCodeValue.value)
237
+ return;
238
+ this.value = this._textInputCodeValue.value;
239
+ }
240
+ handleSearchClick() {
241
+ this.loadAdvancedSearch();
242
+ }
243
+ async loadAdvancedSearch() {
244
+ if (!this.optionLoader) {
245
+ console.warn(this.i18n("ez-search-plus.optionLoaderNotDefined"));
246
+ return;
247
+ }
248
+ const searchArgument = { mode: types.SearchMode.ADVANCED, argument: "" };
249
+ let selectedItem = undefined;
250
+ try {
251
+ selectedItem = await this.optionLoader(searchArgument, this.contextProperties);
252
+ }
253
+ catch (ignore) { }
254
+ if (!selectedItem)
255
+ return;
256
+ this.value = selectedItem;
257
+ }
258
+ buildCurrentValue() {
259
+ if (core.StringUtils.isEmpty(this.codeValue)) {
260
+ return undefined;
261
+ }
262
+ return {
263
+ value: this.codeValue,
264
+ label: this.descriptionValue
265
+ };
266
+ }
267
+ async handleTextInputChangeHandler(event) {
268
+ if (!this.searchDescriptionIsOpen) {
269
+ this._popover.showUnder(this.el);
270
+ }
271
+ const argument = event.target.value;
272
+ await this.debounceLoaderOptions(argument);
273
+ }
274
+ async debounceLoaderOptions(argument) {
275
+ if (this._debounceSearch)
276
+ clearTimeout(this._debounceSearch);
277
+ return new Promise((resolve) => {
278
+ this._debounceSearch = setTimeout(async () => {
279
+ await this.processOptionsLoader(argument);
280
+ resolve();
281
+ }, this.SEARCH_DESCRIPTION_TIMEOUT);
282
+ });
283
+ }
284
+ updateKeyOption(option) {
285
+ return (Object.assign(Object.assign({}, option), { presentationValue: option.value, presentationLabel: option.label }));
286
+ }
287
+ parseSearchOptions(options = []) {
288
+ if (Array.isArray(options)) {
289
+ const firstOption = options[0];
290
+ if (!firstOption) {
291
+ return [];
292
+ }
293
+ if ("label" in firstOption || "value" in firstOption) {
294
+ return options.map((option) => this.updateKeyOption(option));
295
+ }
296
+ return options;
297
+ }
298
+ if ("label" in options || "value" in options) {
299
+ [this.updateKeyOption(options)];
300
+ }
301
+ return [options];
302
+ }
303
+ async processOptionsLoader(argument) {
304
+ try {
305
+ this.showLoading = true;
306
+ const searchArgument = { mode: types.SearchMode.PREDICTIVE, argument };
307
+ const options = await this.optionLoader(searchArgument);
308
+ this.visibleOptions = this.parseSearchOptions(options);
309
+ }
310
+ finally {
311
+ this.showLoading = false;
312
+ }
313
+ }
314
+ handleSelectItem(evt) {
315
+ const currentOpt = evt.detail;
316
+ this.value = currentOpt;
317
+ this._popover.hide();
318
+ window.requestAnimationFrame(() => {
319
+ var _a;
320
+ (_a = this._textInputDescriptionValue) === null || _a === void 0 ? void 0 : _a.setFocus({ selectText: true });
321
+ });
322
+ }
323
+ async handleArrowUp() {
324
+ if (!this.isOptionsVisible()) {
325
+ return;
326
+ }
327
+ await this._classicSearchList.previousOption();
328
+ }
329
+ async handleArrowDown() {
330
+ if (!this.isOptionsVisible()) {
331
+ return;
332
+ }
333
+ await this._classicSearchList.nextOption();
334
+ }
335
+ async selectCurrentItem() {
336
+ var _a;
337
+ await ((_a = this._classicSearchList) === null || _a === void 0 ? void 0 : _a.selectCurrentItem());
338
+ }
339
+ async cancelSelection() {
340
+ var _a, _b, _c;
341
+ const description = typeof this.value === 'object' ? (_a = this.value) === null || _a === void 0 ? void 0 : _a.label : "";
342
+ if (this._textInputDescriptionValue && description && this._textInputDescriptionValue.value != description) {
343
+ this._textInputDescriptionValue.value = description;
344
+ }
345
+ await ((_b = this._classicSearchList) === null || _b === void 0 ? void 0 : _b.cancelSelection());
346
+ (_c = this._popover) === null || _c === void 0 ? void 0 : _c.hide();
347
+ }
348
+ async handleInputTab() {
349
+ await this.cancelSelection();
350
+ }
351
+ async handleInputEsc() {
352
+ var _a;
353
+ await this.cancelSelection();
354
+ await ((_a = this._latestFocusedInputElement) === null || _a === void 0 ? void 0 : _a.setFocus({ selectText: true }));
355
+ }
356
+ async initKeyboardManager() {
357
+ this._keyboardManager = new core.KeyboardManager();
358
+ const defaultOpts = { element: this.el, propagate: true };
359
+ this._keyboardManager
360
+ .bind("ArrowUp", () => this.handleArrowUp(), Object.assign(Object.assign({}, defaultOpts), { propagate: false }))
361
+ .bind("ArrowDown", () => this.handleArrowDown(), Object.assign(Object.assign({}, defaultOpts), { propagate: false }))
362
+ .bind("Enter", () => this.selectCurrentItem(), Object.assign(Object.assign({}, defaultOpts), { propagate: !this.stopPropagateEnterKeyEvent }))
363
+ .bind("Tab", () => this.handleInputTab(), defaultOpts)
364
+ .bind("Escape", () => this.handleInputEsc(), defaultOpts);
365
+ }
366
+ disconnectedCallback() {
367
+ this._keyboardManager
368
+ .unbind("ArrowUp")
369
+ .unbind("ArrowDown")
370
+ .unbind("Enter")
371
+ .unbind("Tab")
372
+ .unbind("Escape");
373
+ }
374
+ isOptionsVisible() {
375
+ return this._popover.opened;
376
+ }
377
+ setLatestFocusedInputElement(el) {
378
+ this._latestFocusedInputElement = el;
379
+ }
380
+ handleCodeInputFocus() {
381
+ this.setLatestFocusedInputElement(this._textInputCodeValue);
382
+ }
383
+ handleDescriptionInputFocus() {
384
+ this.setLatestFocusedInputElement(this._textInputDescriptionValue);
385
+ }
386
+ handleOnEzVisibilityChange(event) {
387
+ event.stopPropagation();
388
+ this.searchDescriptionIsOpen = event.detail;
389
+ }
390
+ render() {
391
+ var _a, _b;
392
+ core.ElementIDUtils.addIDInfoIfNotExists(this.el, 'input');
393
+ 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));
394
+ return (index.h(index.Host, null, index.h("div", { class: "ez-classic-search-plus__wrapper" }, index.h("div", { class: "ez-classic-search-plus__label-container" }, index.h("label", { title: this.label }, this.label), this.required && index.h("span", { class: "required-indicator" }, "*")), index.h("div", { class: "ez-classic-search-plus__container" }, index.h("ez-classic-input", { ref: (elem) => this._textInputCodeValue = elem, class: {
395
+ "ez-classic-search-plus__code-input": !this.hideDescriptionInput,
396
+ "ez-classic-search-plus__code-input-no-border": !this.hideDescriptionInput,
397
+ "ez-classic-search-plus__code-input-full": this.hideDescriptionInput
398
+ }, "data-element-id": core.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 && (index.h("div", { class: "description-input-container" }, index.h("ez-classic-input", { ref: (elem) => this._textInputDescriptionValue = elem, tabIndex: -1, class: { "ez-classic-search-plus__text-input": true }, "data-element-id": core.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() }), index.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") }, index.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) }))))))));
399
+ }
400
+ get el() { return index.getElement(this); }
401
+ static get watchers() { return {
402
+ "value": ["observeValue"]
403
+ }; }
404
+ };
405
+ EzClassicSearchPlus.style = ezClassicSearchPlusCss;
406
+
407
+ exports.ez_classic_search_plus = EzClassicSearchPlus;