@sankhyalabs/ezui 5.22.0-dev.14 → 5.22.0-dev.140

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 (439) hide show
  1. package/dist/cjs/{CSSVarsUtils-10c9d5b4.js → CSSVarsUtils-f20973d1.js} +1 -0
  2. package/dist/cjs/FocusResolver-885f2173.js +35 -0
  3. package/dist/cjs/FormLayout-18853e70.js +27 -0
  4. package/dist/cjs/{constants-2714478b.js → constants-569271bc.js} +4 -0
  5. package/dist/cjs/ez-actions-button.cjs.entry.js +6 -5
  6. package/dist/cjs/ez-avatar.cjs.entry.js +50 -0
  7. package/dist/cjs/ez-badge.cjs.entry.js +14 -2
  8. package/dist/cjs/ez-button.cjs.entry.js +11 -5
  9. package/dist/cjs/ez-card-item_2.cjs.entry.js +267 -0
  10. package/dist/cjs/ez-chart.cjs.entry.js +3 -3
  11. package/dist/cjs/ez-check.cjs.entry.js +18 -10
  12. package/dist/cjs/ez-chip.cjs.entry.js +1 -1
  13. package/dist/cjs/ez-collapsible-box.cjs.entry.js +2 -2
  14. package/dist/cjs/ez-combo-box-list_3.cjs.entry.js +387 -0
  15. package/dist/cjs/ez-combo-box.cjs.entry.js +80 -158
  16. package/dist/cjs/ez-date-input.cjs.entry.js +16 -19
  17. package/dist/cjs/ez-date-time-input.cjs.entry.js +15 -20
  18. package/dist/cjs/ez-dialog.cjs.entry.js +18 -8
  19. package/dist/cjs/ez-double-list.cjs.entry.js +287 -0
  20. package/dist/cjs/ez-dropdown.cjs.entry.js +14 -8
  21. package/dist/cjs/ez-filter-input.cjs.entry.js +129 -0
  22. package/dist/cjs/ez-form-view.cjs.entry.js +41 -27
  23. package/dist/cjs/ez-form.cjs.entry.js +89 -327
  24. package/dist/cjs/ez-grid.cjs.entry.js +15312 -69830
  25. package/dist/cjs/ez-icon.cjs.entry.js +12 -6
  26. package/dist/cjs/ez-list.cjs.entry.js +258 -211
  27. package/dist/cjs/ez-modal-container.cjs.entry.js +7 -3
  28. package/dist/cjs/ez-modal.cjs.entry.js +17 -4
  29. package/dist/cjs/ez-multi-selection-list.cjs.entry.js +2 -2
  30. package/dist/cjs/ez-number-input.cjs.entry.js +16 -3
  31. package/dist/cjs/ez-popover-plus_3.cjs.entry.js +238 -0
  32. package/dist/cjs/ez-popup.cjs.entry.js +29 -3
  33. package/dist/cjs/ez-scroller_2.cjs.entry.js +3 -3
  34. package/dist/cjs/ez-search-plus.cjs.entry.js +397 -0
  35. package/dist/cjs/ez-search-result-list.cjs.entry.js +97 -0
  36. package/dist/cjs/ez-search.cjs.entry.js +134 -191
  37. package/dist/cjs/ez-sidebar-navigator.cjs.entry.js +1 -1
  38. package/dist/cjs/ez-skeleton.cjs.entry.js +118 -36
  39. package/dist/cjs/ez-split-button.cjs.entry.js +16 -7
  40. package/dist/cjs/ez-split-item.cjs.entry.js +7 -4
  41. package/dist/cjs/ez-split-panel.cjs.entry.js +68 -6
  42. package/dist/cjs/ez-text-area.cjs.entry.js +91 -8
  43. package/dist/cjs/ez-text-input.cjs.entry.js +150 -31
  44. package/dist/cjs/ez-time-input.cjs.entry.js +9 -2
  45. package/dist/cjs/ez-tooltip.cjs.entry.js +135 -0
  46. package/dist/cjs/ez-tree.cjs.entry.js +5 -4
  47. package/dist/cjs/ezListHelper-0d3970b4.js +90 -0
  48. package/dist/cjs/ezui.cjs.js +1 -1
  49. package/dist/cjs/filter-column.cjs.entry.js +24 -52
  50. package/dist/cjs/floating-ui.dom.esm-017acce4.js +1404 -0
  51. package/dist/cjs/index-a7b0c73d.js +36 -8
  52. package/dist/cjs/loader.cjs.js +1 -1
  53. package/dist/cjs/search-column-27d1f72f.js +505 -0
  54. package/dist/cjs/searchFormatters-b7e1ed1e.js +23 -0
  55. package/dist/collection/collection-manifest.json +21 -2
  56. package/dist/collection/components/ez-actions-button/ez-actions-button.css +2 -0
  57. package/dist/collection/components/ez-actions-button/ez-actions-button.js +3 -2
  58. package/dist/collection/components/ez-avatar/ez-avatar.css +139 -0
  59. package/dist/collection/components/ez-avatar/ez-avatar.js +143 -0
  60. package/dist/collection/components/ez-badge/ez-badge.css +12 -1
  61. package/dist/collection/components/ez-badge/ez-badge.js +31 -1
  62. package/dist/collection/components/ez-button/ez-button.css +24 -14
  63. package/dist/collection/components/ez-button/ez-button.js +12 -6
  64. package/dist/collection/components/ez-card-item/ez-card-item.css +58 -10
  65. package/dist/collection/components/ez-card-item/ez-card-item.js +30 -3
  66. package/dist/collection/components/ez-chart/ez-chart.js +2 -2
  67. package/dist/collection/components/ez-chart/interfaces/ChartTypeValue.js +1 -0
  68. package/dist/collection/components/ez-chart/types/BaseHighChartsRender.js +3 -3
  69. package/dist/collection/components/ez-check/ez-check.css +10 -6
  70. package/dist/collection/components/ez-check/ez-check.js +34 -9
  71. package/dist/collection/components/ez-chip/ez-chip.css +5 -1
  72. package/dist/collection/components/ez-collapsible-box/ez-collapsible-box.css +1 -1
  73. package/dist/collection/components/ez-combo-box/ez-combo-box-list/ez-combo-box-list.css +205 -0
  74. package/dist/collection/components/ez-combo-box/ez-combo-box-list/ez-combo-box-list.js +426 -0
  75. package/dist/collection/components/ez-combo-box/ez-combo-box.css +8 -246
  76. package/dist/collection/components/ez-combo-box/ez-combo-box.js +141 -167
  77. package/dist/collection/components/ez-date-input/ez-date-input.css +1 -1
  78. package/dist/collection/components/ez-date-input/ez-date-input.js +58 -19
  79. package/dist/collection/components/ez-date-time-input/ez-date-time-input.css +1 -1
  80. package/dist/collection/components/ez-date-time-input/ez-date-time-input.js +57 -20
  81. package/dist/collection/components/ez-dialog/ez-dialog.css +27 -24
  82. package/dist/collection/components/ez-dialog/ez-dialog.js +18 -17
  83. package/dist/collection/components/ez-double-list/doubleListHelper.js +82 -0
  84. package/dist/collection/components/ez-double-list/ez-double-list.css +62 -0
  85. package/dist/collection/components/ez-double-list/ez-double-list.js +440 -0
  86. package/dist/collection/components/ez-dropdown/ez-dropdown.js +33 -8
  87. package/dist/collection/components/ez-filter-input/ez-filter-input.css +1 -1
  88. package/dist/collection/components/ez-filter-input/ez-filter-input.js +35 -4
  89. package/dist/collection/components/ez-form/ez-form.js +125 -4
  90. package/dist/collection/components/ez-form-view/custom-input/ez-custom-form-input.js +49 -6
  91. package/dist/collection/components/ez-form-view/ez-form-view.css +13 -2
  92. package/dist/collection/components/ez-form-view/ez-form-view.js +21 -2
  93. package/dist/collection/components/ez-form-view/fieldbuilder/FieldBuilder.js +5 -2
  94. package/dist/collection/components/ez-form-view/fieldbuilder/templates/CheckBox.tpl.js +1 -1
  95. package/dist/collection/components/ez-form-view/fieldbuilder/templates/ComboBox.tpl.js +1 -1
  96. package/dist/collection/components/ez-form-view/fieldbuilder/templates/DateInput.tpl.js +8 -4
  97. package/dist/collection/components/ez-form-view/fieldbuilder/templates/FileInput.tpl.js +1 -1
  98. package/dist/collection/components/ez-form-view/fieldbuilder/templates/NumberInput.tpl.js +1 -1
  99. package/dist/collection/components/ez-form-view/fieldbuilder/templates/SearchInput.tpl.js +1 -1
  100. package/dist/collection/components/ez-form-view/fieldbuilder/templates/SearchInputPlus.tpl.js +6 -0
  101. package/dist/collection/components/ez-form-view/fieldbuilder/templates/TextArea.tpl.js +1 -1
  102. package/dist/collection/components/ez-form-view/fieldbuilder/templates/TextInput.tpl.js +2 -2
  103. package/dist/collection/components/ez-grid/controller/ag-grid/AgGridController.js +443 -76
  104. package/dist/collection/components/ez-grid/controller/ag-grid/DataSource.js +172 -33
  105. package/dist/collection/components/ez-grid/controller/ag-grid/DataSourceInterceptor.js +2 -1
  106. package/dist/collection/components/ez-grid/controller/ag-grid/GridEditionManager.js +248 -43
  107. package/dist/collection/components/ez-grid/controller/ag-grid/components/EzGridCustomCellEditor.js +16 -0
  108. package/dist/collection/components/ez-grid/controller/ag-grid/components/EzGridCustomHeader.js +1 -1
  109. package/dist/collection/components/ez-grid/controller/ag-grid/editor/EzCellEditor.js +10 -0
  110. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/ComboBox.tpl.js +2 -0
  111. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/DateInput.tpl.js +1 -0
  112. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/NumberInput.tpl.js +1 -0
  113. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/Search.tpl.js +8 -1
  114. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/SearchPlus.tpl.js +15 -0
  115. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/TextInput.tpl.js +4 -1
  116. package/dist/collection/components/ez-grid/controller/ag-grid/test/constants/GridEditionMock.js +2 -0
  117. package/dist/collection/components/ez-grid/ez-grid.css +107 -10
  118. package/dist/collection/components/ez-grid/ez-grid.js +478 -22
  119. package/dist/collection/components/ez-grid/subcomponents/filter-column.css +4 -0
  120. package/dist/collection/components/ez-grid/subcomponents/filter-column.js +23 -51
  121. package/dist/collection/components/ez-grid/utils/ColumnFilterManager.js +7 -54
  122. package/dist/collection/components/ez-grid/utils/InMemoryFilterColumnDataSource.js +20 -4
  123. package/dist/collection/components/ez-icon/ez-icon.css +156 -149
  124. package/dist/collection/components/ez-icon/ez-icon.js +28 -5
  125. package/dist/collection/components/ez-list/ez-list.css +6 -4
  126. package/dist/collection/components/ez-list/ez-list.js +301 -212
  127. package/dist/collection/components/ez-list/ezListHelper.js +85 -0
  128. package/dist/collection/components/ez-modal/ez-modal.css +7 -2
  129. package/dist/collection/components/ez-modal/ez-modal.js +18 -5
  130. package/dist/collection/components/ez-modal-container/ez-modal-container.css +3 -1
  131. package/dist/collection/components/ez-modal-container/ez-modal-container.js +6 -2
  132. package/dist/collection/components/ez-multi-selection-list/ez-multi-selection-list.css +3 -3
  133. package/dist/collection/components/ez-multi-selection-list/ez-multi-selection-list.js +1 -1
  134. package/dist/collection/components/ez-multi-selection-list/interfaces/IStaticOptionsFetchConfig.js +1 -0
  135. package/dist/collection/components/ez-number-input/ez-number-input.css +8 -0
  136. package/dist/collection/components/ez-number-input/ez-number-input.js +67 -1
  137. package/dist/collection/components/ez-popover-plus/ez-popover-plus.css +3 -0
  138. package/dist/collection/components/ez-popover-plus/ez-popover-plus.js +434 -0
  139. package/dist/collection/components/ez-popover-plus/subcomponent/ez-popover-core.css +67 -0
  140. package/dist/collection/components/ez-popover-plus/subcomponent/ez-popover-core.js +524 -0
  141. package/dist/collection/components/ez-popup/ez-popup.css +8 -3
  142. package/dist/collection/components/ez-popup/ez-popup.js +48 -4
  143. package/dist/collection/components/ez-scroller/ez-scroller.css +4 -0
  144. package/dist/collection/components/ez-search/ez-search.css +2 -210
  145. package/dist/collection/components/ez-search/ez-search.js +234 -204
  146. package/dist/collection/components/ez-search/subcomponent/search-list/search-list.css +227 -0
  147. package/dist/collection/components/ez-search/subcomponent/search-list/search-list.js +318 -0
  148. package/dist/collection/components/ez-search/utils/searchFormatters.js +18 -0
  149. package/dist/collection/components/ez-search-plus/ez-search-plus.css +373 -0
  150. package/dist/collection/components/ez-search-plus/ez-search-plus.js +960 -0
  151. package/dist/collection/components/ez-search-plus/subcomponent/ez-search-result-list/ez-search-result-list.css +221 -0
  152. package/dist/collection/components/ez-search-plus/subcomponent/ez-search-result-list/ez-search-result-list.js +278 -0
  153. package/dist/collection/components/ez-sidebar-button/ez-sidebar-button.css +3 -0
  154. package/dist/collection/components/ez-sidebar-button/ez-sidebar-button.js +1 -1
  155. package/dist/collection/components/ez-sidebar-navigator/ez-sidebar-navigator.css +4 -1
  156. package/dist/collection/components/ez-skeleton/ez-skeleton.constants.js +25 -1
  157. package/dist/collection/components/ez-skeleton/ez-skeleton.css +140 -78
  158. package/dist/collection/components/ez-skeleton/ez-skeleton.js +210 -46
  159. package/dist/collection/components/ez-split-button/ez-split-button.css +53 -15
  160. package/dist/collection/components/ez-split-button/ez-split-button.js +90 -13
  161. package/dist/collection/components/ez-split-panel/ez-split-panel.css +15 -0
  162. package/dist/collection/components/ez-split-panel/ez-split-panel.js +106 -5
  163. package/dist/collection/components/ez-split-panel/interfaces/IPanelSizeInfo.js +1 -0
  164. package/dist/collection/components/ez-split-panel/structure/item/ez-split-item.css +14 -2
  165. package/dist/collection/components/ez-split-panel/structure/item/ez-split-item.js +22 -1
  166. package/dist/collection/components/ez-text-area/ez-text-area.css +78 -29
  167. package/dist/collection/components/ez-text-area/ez-text-area.js +151 -6
  168. package/dist/collection/components/ez-text-input/ez-text-input.css +133 -93
  169. package/dist/collection/components/ez-text-input/ez-text-input.js +231 -29
  170. package/dist/collection/components/ez-time-input/ez-time-input.js +43 -1
  171. package/dist/collection/components/ez-tooltip/ez-tooltip.css +62 -0
  172. package/dist/collection/components/ez-tooltip/ez-tooltip.js +310 -0
  173. package/dist/collection/components/ez-tree/ez-tree.js +21 -1
  174. package/dist/collection/components/ez-tree/subcomponents/TreeItem.js +3 -3
  175. package/dist/collection/sw.js +46 -0
  176. package/dist/collection/utils/CSSVarsUtils.js +1 -0
  177. package/dist/collection/utils/FocusResolver.js +31 -0
  178. package/dist/collection/utils/constants.js +2 -0
  179. package/dist/collection/utils/form/DataBinder.js +65 -21
  180. package/dist/collection/utils/form/FormMetadata.js +2 -1
  181. package/dist/collection/utils/form/interfaces/FormLayout.js +5 -0
  182. package/dist/collection/utils/form/interfaces/index.js +1 -1
  183. package/dist/collection/utils/form/test/DataBinder.test.js +14 -0
  184. package/dist/collection/utils/index.js +3 -0
  185. package/dist/collection/utils/interfaces/AbstractFieldMetadata.js +1 -1
  186. package/dist/collection/utils/search/types.js +7 -0
  187. package/dist/collection/utils/searchColumn/search-column.js +35 -0
  188. package/dist/collection/utils/validators/recordvalidator/IInvalidCells.js +1 -0
  189. package/dist/collection/utils/validators/recordvalidator/RecordValidationProcessor.js +7 -1
  190. package/dist/custom-elements/index.d.ts +54 -0
  191. package/dist/custom-elements/index.js +20058 -70949
  192. package/dist/esm/{CSSVarsUtils-71ce76be.js → CSSVarsUtils-acba92d7.js} +1 -0
  193. package/dist/esm/FocusResolver-1ccbf850.js +33 -0
  194. package/dist/esm/FormLayout-071d324c.js +27 -0
  195. package/dist/esm/constants-b036528f.js +7 -0
  196. package/dist/esm/ez-actions-button.entry.js +6 -5
  197. package/dist/esm/ez-avatar.entry.js +46 -0
  198. package/dist/esm/ez-badge.entry.js +14 -2
  199. package/dist/esm/ez-button.entry.js +11 -5
  200. package/dist/esm/ez-card-item_2.entry.js +262 -0
  201. package/dist/esm/ez-chart.entry.js +3 -3
  202. package/dist/esm/ez-check.entry.js +18 -10
  203. package/dist/esm/ez-chip.entry.js +1 -1
  204. package/dist/esm/ez-collapsible-box.entry.js +2 -2
  205. package/dist/esm/ez-combo-box-list_3.entry.js +381 -0
  206. package/dist/esm/ez-combo-box.entry.js +81 -159
  207. package/dist/esm/ez-date-input.entry.js +16 -19
  208. package/dist/esm/ez-date-time-input.entry.js +15 -20
  209. package/dist/esm/ez-dialog.entry.js +19 -9
  210. package/dist/esm/ez-double-list.entry.js +283 -0
  211. package/dist/esm/ez-dropdown.entry.js +14 -8
  212. package/dist/esm/ez-filter-input.entry.js +125 -0
  213. package/dist/esm/ez-form-view.entry.js +42 -28
  214. package/dist/esm/ez-form.entry.js +88 -326
  215. package/dist/esm/ez-grid.entry.js +15275 -69793
  216. package/dist/esm/ez-icon.entry.js +12 -6
  217. package/dist/esm/ez-list.entry.js +258 -211
  218. package/dist/esm/ez-modal-container.entry.js +7 -3
  219. package/dist/esm/ez-modal.entry.js +17 -4
  220. package/dist/esm/ez-multi-selection-list.entry.js +2 -2
  221. package/dist/esm/ez-number-input.entry.js +16 -3
  222. package/dist/esm/ez-popover-plus_3.entry.js +232 -0
  223. package/dist/esm/ez-popup.entry.js +29 -3
  224. package/dist/esm/ez-scroller_2.entry.js +3 -3
  225. package/dist/esm/ez-search-plus.entry.js +393 -0
  226. package/dist/esm/ez-search-result-list.entry.js +93 -0
  227. package/dist/esm/ez-search.entry.js +135 -192
  228. package/dist/esm/ez-sidebar-navigator.entry.js +1 -1
  229. package/dist/esm/ez-skeleton.entry.js +118 -36
  230. package/dist/esm/ez-split-button.entry.js +16 -7
  231. package/dist/esm/ez-split-item.entry.js +7 -4
  232. package/dist/esm/ez-split-panel.entry.js +69 -7
  233. package/dist/esm/ez-text-area.entry.js +91 -8
  234. package/dist/esm/ez-text-input.entry.js +150 -31
  235. package/dist/esm/ez-time-input.entry.js +9 -2
  236. package/dist/esm/ez-tooltip.entry.js +131 -0
  237. package/dist/esm/ez-tree.entry.js +5 -4
  238. package/dist/esm/ezListHelper-00fb9b8d.js +87 -0
  239. package/dist/esm/ezui.js +1 -1
  240. package/dist/esm/filter-column.entry.js +24 -52
  241. package/dist/esm/floating-ui.dom.esm-5d3da819.js +1398 -0
  242. package/dist/esm/index-baa5e267.js +36 -8
  243. package/dist/esm/loader.js +1 -1
  244. package/dist/esm/search-column-e609d513.js +495 -0
  245. package/dist/esm/searchFormatters-8229207e.js +20 -0
  246. package/dist/ezui/ezui.esm.js +1 -1
  247. package/dist/ezui/p-07894c4a.entry.js +1 -0
  248. package/dist/ezui/p-0d9856a4.entry.js +1 -0
  249. package/dist/ezui/p-1bcfd88c.entry.js +1 -0
  250. package/dist/ezui/p-1eb34cad.entry.js +1 -0
  251. package/dist/ezui/p-20c024f7.entry.js +1 -0
  252. package/dist/ezui/p-26685c50.entry.js +1 -0
  253. package/dist/ezui/p-288631d1.entry.js +1 -0
  254. package/dist/ezui/p-2b42abbb.entry.js +1 -0
  255. package/dist/ezui/p-2b4df33d.entry.js +1 -0
  256. package/dist/ezui/p-30ffb9ed.js +1 -0
  257. package/dist/ezui/p-33326ac5.entry.js +1 -0
  258. package/dist/ezui/p-341da682.entry.js +1 -0
  259. package/dist/ezui/p-35115d5d.entry.js +1 -0
  260. package/dist/ezui/p-3ba9565c.entry.js +1 -0
  261. package/dist/ezui/p-40a60148.js +1 -0
  262. package/dist/ezui/p-496f7832.entry.js +1 -0
  263. package/dist/ezui/p-4b67138e.entry.js +1 -0
  264. package/dist/ezui/p-4bd6dd6a.entry.js +1 -0
  265. package/dist/ezui/p-4d30b703.entry.js +1 -0
  266. package/dist/ezui/p-57363cfd.entry.js +1 -0
  267. package/dist/ezui/p-58f69d24.entry.js +1 -0
  268. package/dist/ezui/{p-84e439b9.entry.js → p-5dde9df3.entry.js} +1 -1
  269. package/dist/ezui/p-5eea9886.js +1 -0
  270. package/dist/ezui/p-69937816.entry.js +1 -0
  271. package/dist/ezui/p-7019f782.entry.js +1 -0
  272. package/dist/ezui/p-79044c3e.entry.js +1 -0
  273. package/dist/ezui/p-7e677b7b.entry.js +1 -0
  274. package/dist/ezui/p-7eae6986.entry.js +1 -0
  275. package/dist/ezui/p-80dfc50b.js +1 -0
  276. package/dist/ezui/p-9478b13b.entry.js +1 -0
  277. package/dist/ezui/p-9567b31a.entry.js +1 -0
  278. package/dist/ezui/p-97c7cf51.entry.js +1 -0
  279. package/dist/ezui/p-998afb6a.entry.js +1 -0
  280. package/dist/ezui/p-9c5cd3b2.entry.js +1 -0
  281. package/dist/ezui/p-a148e994.entry.js +1 -0
  282. package/dist/ezui/p-a3bf8cf1.entry.js +1 -0
  283. package/dist/ezui/p-b81881ac.entry.js +1 -0
  284. package/dist/ezui/p-bac0f920.entry.js +1 -0
  285. package/dist/ezui/p-bff24a7b.js +1 -0
  286. package/dist/ezui/p-cb75eb46.entry.js +1 -0
  287. package/dist/ezui/{p-5b205c80.entry.js → p-d47dabdf.entry.js} +1 -1
  288. package/dist/ezui/p-da1b4a38.entry.js +1 -0
  289. package/dist/ezui/p-dc628ed3.js +1 -0
  290. package/dist/ezui/p-dc73e1fe.entry.js +1 -0
  291. package/dist/ezui/{p-17be134a.entry.js → p-e06a9886.entry.js} +1 -1
  292. package/dist/ezui/p-e07e4671.js +1 -0
  293. package/dist/ezui/p-e09514b6.entry.js +309 -0
  294. package/dist/ezui/p-e6a9041d.entry.js +1 -0
  295. package/dist/ezui/p-e75c7a23.entry.js +1 -0
  296. package/dist/ezui/p-ec7db713.js +1 -0
  297. package/dist/ezui/p-fa6732f2.entry.js +1 -0
  298. package/dist/types/components/ez-avatar/ez-avatar.d.ts +24 -0
  299. package/dist/types/components/ez-badge/ez-badge.d.ts +5 -0
  300. package/dist/types/components/ez-button/ez-button.d.ts +2 -1
  301. package/dist/types/components/ez-calendar/ez-calendar.d.ts +3 -3
  302. package/dist/types/components/ez-card-item/ez-card-item.d.ts +5 -0
  303. package/dist/types/components/ez-chart/interfaces/ChartAxis.d.ts +2 -0
  304. package/dist/types/components/ez-chart/interfaces/ChartTypeValue.d.ts +1 -0
  305. package/dist/types/components/ez-check/ez-check.d.ts +7 -2
  306. package/dist/types/components/ez-combo-box/ez-combo-box-list/ez-combo-box-list.d.ts +104 -0
  307. package/dist/types/components/ez-combo-box/ez-combo-box.d.ts +19 -15
  308. package/dist/types/components/ez-date-input/ez-date-input.d.ts +12 -3
  309. package/dist/types/components/ez-date-time-input/ez-date-time-input.d.ts +12 -3
  310. package/dist/types/components/ez-dialog/ez-dialog.d.ts +3 -1
  311. package/dist/types/components/ez-double-list/doubleListHelper.d.ts +10 -0
  312. package/dist/types/components/ez-double-list/ez-double-list.d.ts +87 -0
  313. package/dist/types/components/ez-dropdown/ez-dropdown.d.ts +4 -0
  314. package/dist/types/components/ez-dropdown/structure/DropdownItem.d.ts +4 -4
  315. package/dist/types/components/ez-filter-input/ez-filter-input.d.ts +6 -1
  316. package/dist/types/components/ez-form/ez-form.d.ts +23 -1
  317. package/dist/types/components/ez-form-view/custom-input/ez-custom-form-input.d.ts +7 -1
  318. package/dist/types/components/ez-form-view/ez-form-view.d.ts +4 -0
  319. package/dist/types/components/ez-form-view/fieldbuilder/templates/DateInput.tpl.d.ts +2 -1
  320. package/dist/types/components/ez-form-view/fieldbuilder/templates/SearchInputPlus.tpl.d.ts +2 -0
  321. package/dist/types/components/ez-form-view/fieldbuilder/templates/TextInput.tpl.d.ts +1 -1
  322. package/dist/types/components/ez-grid/controller/EzGridController.d.ts +84 -5
  323. package/dist/types/components/ez-grid/controller/ag-grid/AgGridController.d.ts +47 -7
  324. package/dist/types/components/ez-grid/controller/ag-grid/DataSource.d.ts +26 -2
  325. package/dist/types/components/ez-grid/controller/ag-grid/GridEditionManager.d.ts +34 -7
  326. package/dist/types/components/ez-grid/controller/ag-grid/components/EzGridCustomCellEditor.d.ts +4 -1
  327. package/dist/types/components/ez-grid/controller/ag-grid/components/EzGridCustomCellRender.d.ts +1 -1
  328. package/dist/types/components/ez-grid/controller/ag-grid/components/EzGridCustomHeader.d.ts +1 -1
  329. package/dist/types/components/ez-grid/controller/ag-grid/components/cellRendererStatus.d.ts +1 -1
  330. package/dist/types/components/ez-grid/controller/ag-grid/components/selectionHeader.d.ts +1 -1
  331. package/dist/types/components/ez-grid/controller/ag-grid/editor/EzCellEditor.d.ts +2 -1
  332. package/dist/types/components/ez-grid/controller/ag-grid/editor/EzCellRender.d.ts +1 -1
  333. package/dist/types/components/ez-grid/controller/ag-grid/editor/IUICellEditor.d.ts +1 -0
  334. package/dist/types/components/ez-grid/controller/ag-grid/editor/templates/SearchPlus.tpl.d.ts +3 -0
  335. package/dist/types/components/ez-grid/controller/ag-grid/mock/Server.d.ts +1 -1
  336. package/dist/types/components/ez-grid/ez-grid.d.ts +74 -1
  337. package/dist/types/components/ez-grid/subcomponents/filter-column.d.ts +1 -11
  338. package/dist/types/components/ez-grid/utils/ColumnFilterManager.d.ts +1 -1
  339. package/dist/types/components/ez-grid/utils/InMemoryFilterColumnDataSource.d.ts +3 -0
  340. package/dist/types/components/ez-icon/ez-icon.d.ts +5 -0
  341. package/dist/types/components/ez-list/ez-list.d.ts +23 -2
  342. package/dist/types/components/ez-list/ezListHelper.d.ts +20 -0
  343. package/dist/types/components/ez-modal/ez-modal.d.ts +4 -1
  344. package/dist/types/components/ez-modal-container/ez-modal-container.d.ts +2 -0
  345. package/dist/types/components/ez-multi-selection-list/interfaces/IMultiSelectionListDataSource.d.ts +2 -1
  346. package/dist/types/components/ez-multi-selection-list/interfaces/IStaticOptionsFetchConfig.d.ts +3 -0
  347. package/dist/types/components/ez-number-input/ez-number-input.d.ts +12 -0
  348. package/dist/types/components/ez-popover-plus/ez-popover-plus.d.ts +74 -0
  349. package/dist/types/components/ez-popover-plus/subcomponent/ez-popover-core.d.ts +89 -0
  350. package/dist/types/components/ez-popup/ez-popup.d.ts +10 -1
  351. package/dist/types/components/ez-search/ez-search.d.ts +37 -18
  352. package/dist/types/components/ez-search/subcomponent/search-list/search-list.d.ts +29 -0
  353. package/dist/types/components/ez-search/utils/searchFormatters.d.ts +2 -0
  354. package/dist/types/components/ez-search-plus/ez-search-plus.d.ts +186 -0
  355. package/dist/types/components/ez-search-plus/subcomponent/ez-search-result-list/ez-search-result-list.d.ts +26 -0
  356. package/dist/types/components/ez-skeleton/ez-skeleton.constants.d.ts +55 -1
  357. package/dist/types/components/ez-skeleton/ez-skeleton.d.ts +50 -22
  358. package/dist/types/components/ez-split-button/ez-split-button.d.ts +15 -3
  359. package/dist/types/components/ez-split-panel/ez-split-panel.d.ts +11 -0
  360. package/dist/types/components/ez-split-panel/interfaces/IPanelSizeInfo.d.ts +9 -0
  361. package/dist/types/components/ez-split-panel/structure/item/ez-split-item.d.ts +5 -0
  362. package/dist/types/components/ez-text-area/ez-text-area.d.ts +25 -0
  363. package/dist/types/components/ez-text-input/ez-text-input.d.ts +37 -3
  364. package/dist/types/components/ez-time-input/ez-time-input.d.ts +8 -0
  365. package/dist/types/components/ez-tooltip/ez-tooltip.d.ts +57 -0
  366. package/dist/types/components/ez-tree/ez-tree.d.ts +4 -0
  367. package/dist/types/components/ez-tree/interfaces/ITreeItem.d.ts +1 -0
  368. package/dist/types/components/ez-tree/subcomponents/TreeItem.d.ts +1 -0
  369. package/dist/types/components.d.ts +1386 -58
  370. package/dist/types/utils/FocusResolver.d.ts +5 -0
  371. package/dist/types/utils/constants.d.ts +2 -0
  372. package/dist/types/utils/customEditor/interfaces/ICustomEditor.d.ts +2 -0
  373. package/dist/types/utils/form/DataBinder.d.ts +7 -2
  374. package/dist/types/utils/form/interfaces/FormLayout.d.ts +4 -0
  375. package/dist/types/utils/form/interfaces/index.d.ts +1 -0
  376. package/dist/types/utils/index.d.ts +3 -0
  377. package/dist/types/utils/search/types.d.ts +12 -0
  378. package/dist/types/utils/searchColumn/search-column.d.ts +9 -0
  379. package/dist/types/utils/validators/recordvalidator/IInvalidCells.d.ts +5 -0
  380. package/dist/types/utils/validators/recordvalidator/RecordValidationProcessor.d.ts +1 -1
  381. package/package.json +16 -7
  382. package/react/components.d.ts +63 -54
  383. package/react/components.js +9 -0
  384. package/react/components.js.map +1 -1
  385. package/react/react-component-lib/createComponent.d.ts +1 -1
  386. package/react/react-component-lib/createComponent.js.map +1 -1
  387. package/react/react-component-lib/createOverlayComponent.js.map +1 -1
  388. package/react/react-component-lib/interfaces.js +1 -0
  389. package/react/react-component-lib/utils/attachProps.d.ts +1 -1
  390. package/react/react-component-lib/utils/attachProps.js.map +1 -1
  391. package/react/react-component-lib/utils/dev.js.map +1 -1
  392. package/react/react-component-lib/utils/index.d.ts +2 -2
  393. package/react/react-component-lib/utils/index.js.map +1 -1
  394. package/dist/cjs/ICustomRender-6fafffce.js +0 -13
  395. package/dist/cjs/RecordValidationProcessor-4c893e04.js +0 -102
  396. package/dist/cjs/ez-card-item_3.cjs.entry.js +0 -183
  397. package/dist/cjs/ez-custom-form-input_2.cjs.entry.js +0 -206
  398. package/dist/esm/ICustomRender-875b5a40.js +0 -13
  399. package/dist/esm/RecordValidationProcessor-b00b8b77.js +0 -99
  400. package/dist/esm/constants-4e0d35b7.js +0 -5
  401. package/dist/esm/ez-card-item_3.entry.js +0 -177
  402. package/dist/esm/ez-custom-form-input_2.entry.js +0 -201
  403. package/dist/ezui/p-04f24913.js +0 -1
  404. package/dist/ezui/p-05e1f4e7.js +0 -1
  405. package/dist/ezui/p-072e6347.entry.js +0 -1
  406. package/dist/ezui/p-1285c902.entry.js +0 -1
  407. package/dist/ezui/p-13d2fe2d.entry.js +0 -1
  408. package/dist/ezui/p-2097d0cf.entry.js +0 -1
  409. package/dist/ezui/p-32e553e5.entry.js +0 -304
  410. package/dist/ezui/p-34b6916c.entry.js +0 -1
  411. package/dist/ezui/p-3b4eeeb6.entry.js +0 -1
  412. package/dist/ezui/p-3faa2b46.entry.js +0 -1
  413. package/dist/ezui/p-42533ea4.entry.js +0 -1
  414. package/dist/ezui/p-4607fb89.js +0 -1
  415. package/dist/ezui/p-49456b34.entry.js +0 -1
  416. package/dist/ezui/p-4d5235f1.entry.js +0 -1
  417. package/dist/ezui/p-5bd5e68f.entry.js +0 -1
  418. package/dist/ezui/p-650e4b6d.entry.js +0 -1
  419. package/dist/ezui/p-784fe207.entry.js +0 -1
  420. package/dist/ezui/p-7922142b.entry.js +0 -1
  421. package/dist/ezui/p-7af81663.entry.js +0 -1
  422. package/dist/ezui/p-7bc07c31.entry.js +0 -1
  423. package/dist/ezui/p-85c8baae.entry.js +0 -1
  424. package/dist/ezui/p-8888d9ed.entry.js +0 -1
  425. package/dist/ezui/p-9050d2cd.entry.js +0 -1
  426. package/dist/ezui/p-922ac38b.entry.js +0 -1
  427. package/dist/ezui/p-9e11fc7b.js +0 -1
  428. package/dist/ezui/p-a31b9c90.entry.js +0 -1
  429. package/dist/ezui/p-aba3da00.entry.js +0 -1
  430. package/dist/ezui/p-af95cd16.entry.js +0 -1
  431. package/dist/ezui/p-bae4e180.entry.js +0 -1
  432. package/dist/ezui/p-baf80b13.entry.js +0 -1
  433. package/dist/ezui/p-bcb53f27.entry.js +0 -1
  434. package/dist/ezui/p-bf79aaa1.entry.js +0 -1
  435. package/dist/ezui/p-cdc472cc.entry.js +0 -1
  436. package/dist/ezui/p-d9401ea0.entry.js +0 -1
  437. package/dist/ezui/p-e85c48d7.entry.js +0 -1
  438. package/dist/ezui/p-ecc2c1ec.entry.js +0 -1
  439. package/dist/ezui/p-fcf0acce.entry.js +0 -1
@@ -1,5 +1,6 @@
1
1
  import { ElementIDUtils, StringUtils } from '@sankhyalabs/core';
2
2
  import { Fragment, Host, h } from '@stencil/core';
3
+ import { processListOnDrop } from './ezListHelper';
3
4
  export class EzList {
4
5
  constructor() {
5
6
  this._listItemsHistory = [];
@@ -13,6 +14,7 @@ export class EzList {
13
14
  this.itemSlotBuilder = undefined;
14
15
  this.itemLeftSlotBuilder = undefined;
15
16
  this.hoverFeedback = false;
17
+ this.enableMultipleSelection = false;
16
18
  }
17
19
  /**
18
20
  * Limpa o histórico da lista.
@@ -25,65 +27,108 @@ export class EzList {
25
27
  */
26
28
  async scrollToTop() {
27
29
  if (this.useGroups) {
28
- this._element.shadowRoot.querySelector('.group-container').scrollTop = 0;
30
+ this._element.querySelector('.group-container').scrollTop = 0;
29
31
  }
30
32
  else {
31
- this._element.shadowRoot.querySelector('.items-container').scrollTop = 0;
33
+ this._element.querySelector('.items-container').scrollTop = 0;
32
34
  }
33
35
  }
34
36
  /**
35
37
  * Aplica seleção nas linhas da lista.
36
38
  */
37
- async setSelection(selectedItem, scrollToOption) {
38
- if (selectedItem && this.ezSelectable) {
39
- this.ezSelectItem.emit(selectedItem);
40
- if (this.useGroups) {
41
- let newList = [...this._listGroupItems];
42
- newList.forEach(groupItem => {
43
- groupItem.items.forEach(item => {
44
- item.selected = item.id === selectedItem.id;
45
- });
46
- });
47
- this._listGroupItems = newList;
48
- }
49
- else {
50
- let newList = [...this._listItems];
51
- newList.forEach(item => {
52
- item.selected = item.id === selectedItem.id;
53
- });
54
- this._listItems = newList;
55
- }
56
- if (scrollToOption) {
57
- let liElem = this.useGroups
58
- ? this._groupContainer.querySelector('li#item_' + selectedItem.id)
59
- : this._itemContainer.querySelector('li#item_' + selectedItem.id);
60
- if (liElem) {
61
- liElem.scrollIntoView();
62
- }
63
- }
64
- }
65
- else {
39
+ async setSelection(selectedItem, scrollToOption, shitkey, ctrlKey) {
40
+ if (!selectedItem || !this.ezSelectable) {
66
41
  await this.removeSelection();
42
+ return;
43
+ }
44
+ if (this.useGroups) {
45
+ this.setSelectionWithGroups(selectedItem, scrollToOption);
46
+ return;
47
+ }
48
+ if (this.enableMultipleSelection && ctrlKey) {
49
+ this.setSelectionMultiple(selectedItem);
50
+ return;
51
+ }
52
+ if (this.enableMultipleSelection && shitkey) {
53
+ this.setSelectionRange(selectedItem);
54
+ return;
67
55
  }
56
+ this.setSelectionSingleItem(selectedItem, scrollToOption);
57
+ this.emitSelectedItems(selectedItem);
58
+ }
59
+ emitSelectedItems(singleItem, listItem) {
60
+ this.ezSelectItem.emit(singleItem);
61
+ this.ezSelectMultipleItems.emit(listItem !== null && listItem !== void 0 ? listItem : [singleItem]);
62
+ }
63
+ setSelectionRange(selectedItem) {
64
+ const lastSelectedIndex = this._listItems.findIndex(item => item.selected);
65
+ const seletedItemIndex = this._listItems.findIndex(item => item.id === selectedItem.id);
66
+ if (lastSelectedIndex < 0 || lastSelectedIndex === seletedItemIndex) {
67
+ this.setSelectionSingleItem(selectedItem);
68
+ return;
69
+ }
70
+ const minorIndex = Math.min(lastSelectedIndex, seletedItemIndex);
71
+ const majorIndex = Math.max(lastSelectedIndex, seletedItemIndex);
72
+ let newList = [...this._listItems];
73
+ newList.forEach((item, index) => {
74
+ item.selected = (index >= minorIndex && index <= majorIndex);
75
+ });
76
+ this._listItems = [...newList];
77
+ const selectedList = this._listItems.filter(item => item.selected);
78
+ this.emitSelectedItems(selectedItem, selectedList);
79
+ }
80
+ setSelectionMultiple(selectedItem) {
81
+ let newList = [...this._listItems];
82
+ newList.forEach(item => {
83
+ item.selected = (item.id === selectedItem.id) ? !item.selected : item.selected;
84
+ });
85
+ this._listItems = [...newList];
86
+ const selectedList = this._listItems.filter(item => item.selected);
87
+ this.emitSelectedItems(selectedItem, selectedList);
88
+ }
89
+ setSelectionSingleItem(selectedItem, scrollToOption) {
90
+ this.emitSelectedItems(selectedItem);
91
+ let newList = [...this._listItems];
92
+ newList.forEach(item => {
93
+ item.selected = item.id === selectedItem.id;
94
+ });
95
+ this._listItems = newList;
96
+ if (!scrollToOption)
97
+ return;
98
+ let liElem = this._itemContainer.querySelector('li#item_' + selectedItem.id);
99
+ if (liElem)
100
+ liElem.scrollIntoView();
101
+ }
102
+ setSelectionWithGroups(selectedItem, scrollToOption) {
103
+ this.emitSelectedItems(selectedItem);
104
+ let newList = [...this._listGroupItems];
105
+ newList.forEach(groupItem => {
106
+ groupItem.items.forEach(item => {
107
+ item.selected = item.id === selectedItem.id;
108
+ });
109
+ });
110
+ this._listGroupItems = newList;
111
+ if (!scrollToOption)
112
+ return;
113
+ let liElem = this._groupContainer.querySelector('li#item_' + selectedItem.id);
114
+ if (liElem)
115
+ liElem.scrollIntoView();
68
116
  }
69
117
  /**
70
118
  * Obtém o item selecionado.
71
119
  */
72
120
  async getSelection() {
121
+ if (!this.useGroups)
122
+ return this._listItems.find(item => item.selected == true);
73
123
  let selectedItem;
74
- if (this.useGroups) {
75
- this._listGroupItems.every(group => {
76
- let item = group.items.find(item => item.selected == true);
77
- if (item) {
78
- selectedItem = item;
79
- return false;
80
- }
81
- return true;
82
- });
83
- }
84
- else {
85
- selectedItem = this._listItems.find(item => item.selected == true);
86
- }
124
+ this._listGroupItems.every(group => {
125
+ let item = group.items.find(item => item.selected == true);
126
+ if (item) {
127
+ selectedItem = item;
128
+ return false;
129
+ }
130
+ return true;
131
+ });
87
132
  return selectedItem;
88
133
  }
89
134
  /**
@@ -107,14 +152,11 @@ export class EzList {
107
152
  });
108
153
  });
109
154
  this._listGroupItems = newList;
155
+ return;
110
156
  }
111
- else {
112
- let newList = [...this._listItems];
113
- newList.forEach(item => {
114
- item.selected = false;
115
- });
116
- this._listItems = newList;
117
- }
157
+ let newList = [...this._listItems];
158
+ newList.forEach(item => item.selected = false);
159
+ this._listItems = newList;
118
160
  }
119
161
  applyUUID(item) {
120
162
  if (!item.id) {
@@ -148,8 +190,7 @@ export class EzList {
148
190
  }
149
191
  }
150
192
  buildIdDraggableListAndSelectable() {
151
- const shadow = this._element.shadowRoot;
152
- const draggableList = shadow.querySelectorAll('.draggable-list');
193
+ const draggableList = this._element.querySelectorAll('.draggable-list');
153
194
  draggableList === null || draggableList === void 0 ? void 0 : draggableList.forEach((draggable, index) => {
154
195
  var _a, _b;
155
196
  let suffix = 'draggableList';
@@ -159,7 +200,7 @@ export class EzList {
159
200
  }
160
201
  ElementIDUtils.addIDInfoIfNotExists(draggable, suffix);
161
202
  });
162
- const selectable = shadow.querySelectorAll('.selectable-container');
203
+ const selectable = this._element.querySelectorAll('.selectable-container');
163
204
  selectable === null || selectable === void 0 ? void 0 : selectable.forEach((item) => {
164
205
  ElementIDUtils.addIDInfoIfNotExists(item, 'selectable');
165
206
  });
@@ -177,78 +218,88 @@ export class EzList {
177
218
  ElementIDUtils.addIDInfo(this._element);
178
219
  }
179
220
  onDrop(ev, dragEndItem) {
221
+ ev.stopPropagation();
180
222
  this.removeOverClass();
223
+ if (!this._dragStartItem)
224
+ return;
225
+ if (this.useGroups) {
226
+ this.onDropWithGroups(dragEndItem);
227
+ return;
228
+ }
229
+ this._listItems = [...processListOnDrop(this.buildDragHandlerConfig(dragEndItem.index, false))];
230
+ this._listItemsHistory = [...this._listItems];
231
+ this.ezChange.emit(this._listItems);
232
+ }
233
+ buildDragHandlerConfig(targetIndex, moveToFinal) {
234
+ return {
235
+ listItems: this._listItems,
236
+ dragItem: this._dragStartItem,
237
+ enableMultipleSelection: this.enableMultipleSelection,
238
+ targetIndex,
239
+ moveToFinal,
240
+ clearSelection: () => this.setSelection(undefined)
241
+ };
242
+ }
243
+ ;
244
+ onDropWithGroups(dragEndItem) {
181
245
  this.setSelection(undefined);
182
- if (this._dragStartItem) {
183
- if (this.useGroups) {
184
- let newList = [...this._listGroupItems];
185
- let groupEnd = this._listGroupItems.find(group => dragEndItem.groupName == group.group);
186
- //Remove item arrastado
187
- newList.find(group => group.group == this._dragStartItem.groupName).items.splice(this._dragStartItem.index, 1);
188
- //Adiciona item arrastado
189
- if (groupEnd.sort) {
190
- newList.find(group => group.group == dragEndItem.groupName).items.push(this._dragStartItem.item);
191
- newList
192
- .find(group => group.group == dragEndItem.groupName)
193
- .items.sort(function (a, b) {
194
- return a.label < b.label ? -1 : a.label > b.label ? 1 : 0;
195
- });
196
- if (groupEnd.sort === 'DSC') {
197
- newList.find(group => group.group == dragEndItem.groupName).items.reverse();
198
- }
199
- }
200
- else {
201
- let indexForAdd = dragEndItem.index > this._dragStartItem.index ? dragEndItem.index - 1 : dragEndItem.index;
202
- newList.find(group => group.group == dragEndItem.groupName).items.splice(indexForAdd, 0, this._dragStartItem.item);
203
- }
204
- this._listGroupItems = newList;
205
- this.ezChange.emit(this._listGroupItems);
206
- }
207
- else {
208
- let newList = [...this._listItems];
209
- newList.splice(this._dragStartItem.index, 1);
210
- newList.splice(dragEndItem.index, 0, this._dragStartItem.item);
211
- this._listItems = newList;
212
- this._listItemsHistory = newList;
213
- this.ezChange.emit(this._listItems);
246
+ let newList = [...this._listGroupItems];
247
+ let groupEnd = this._listGroupItems.find(group => dragEndItem.groupName == group.group);
248
+ //Remove item arrastado
249
+ newList.find(group => group.group == this._dragStartItem.groupName).items.splice(this._dragStartItem.index, 1);
250
+ //Adiciona item arrastado
251
+ if (groupEnd.sort) {
252
+ newList.find(group => group.group == dragEndItem.groupName).items.push(this._dragStartItem.item);
253
+ newList
254
+ .find(group => group.group == dragEndItem.groupName)
255
+ .items.sort(function (a, b) {
256
+ return a.label < b.label ? -1 : a.label > b.label ? 1 : 0;
257
+ });
258
+ if (groupEnd.sort === 'DSC') {
259
+ newList.find(group => group.group == dragEndItem.groupName).items.reverse();
214
260
  }
215
261
  }
216
- ev.stopPropagation();
262
+ else {
263
+ let indexForAdd = dragEndItem.index > this._dragStartItem.index ? dragEndItem.index - 1 : dragEndItem.index;
264
+ newList.find(group => group.group == dragEndItem.groupName).items.splice(indexForAdd, 0, this._dragStartItem.item);
265
+ }
266
+ this._listGroupItems = newList;
267
+ this.ezChange.emit(this._listGroupItems);
217
268
  }
218
269
  onDropLastIndex(ev, groupDropped) {
270
+ ev.stopPropagation();
219
271
  this.removeOverClass();
272
+ if (!this._dragStartItem)
273
+ return;
274
+ if (this.useGroups) {
275
+ this.onDropLastItemWithGroups(groupDropped);
276
+ return;
277
+ }
278
+ const lastIndex = this._listItems.length - 1;
279
+ this._listItems = [...processListOnDrop(this.buildDragHandlerConfig(lastIndex, true))];
280
+ this._listItemsHistory = [...this._listItems];
281
+ this.ezChange.emit(this._listItems);
282
+ }
283
+ onDropLastItemWithGroups(groupDropped) {
220
284
  this.setSelection(undefined);
221
- if (this._dragStartItem) {
222
- if (this.useGroups) {
223
- let newList = [...this._listGroupItems];
224
- let groupEnd = this._listGroupItems.find(group => groupDropped.group == group.group);
225
- //Remove item arrastado
226
- newList.find(group => group.group == this._dragStartItem.groupName).items.splice(this._dragStartItem.index, 1);
227
- //Adiciona item arrastado
228
- newList.find(group => group.group == groupDropped.group).items.push(this._dragStartItem.item);
229
- if (groupEnd.sort) {
230
- newList
231
- .find(group => group.group == groupDropped.group)
232
- .items.sort(function (a, b) {
233
- return a.label < b.label ? -1 : a.label > b.label ? 1 : 0;
234
- });
235
- if (groupEnd.sort === 'DSC') {
236
- newList.find(group => group.group == groupDropped.group).items.reverse();
237
- }
238
- }
239
- this._listGroupItems = newList;
240
- this.ezChange.emit(this._listGroupItems);
241
- }
242
- else {
243
- let newList = [...this._listItems];
244
- newList.splice(this._dragStartItem.index, 1);
245
- newList.push(this._dragStartItem.item);
246
- this._listItems = newList;
247
- this._listItemsHistory = newList;
248
- this.ezChange.emit(this._listItems);
285
+ let newList = [...this._listGroupItems];
286
+ let groupEnd = this._listGroupItems.find(group => groupDropped.group == group.group);
287
+ //Remove item arrastado
288
+ newList.find(group => group.group == this._dragStartItem.groupName).items.splice(this._dragStartItem.index, 1);
289
+ //Adiciona item arrastado
290
+ newList.find(group => group.group == groupDropped.group).items.push(this._dragStartItem.item);
291
+ if (groupEnd.sort) {
292
+ newList
293
+ .find(group => group.group == groupDropped.group)
294
+ .items.sort(function (a, b) {
295
+ return a.label < b.label ? -1 : a.label > b.label ? 1 : 0;
296
+ });
297
+ if (groupEnd.sort === 'DSC') {
298
+ newList.find(group => group.group == groupDropped.group).items.reverse();
249
299
  }
250
300
  }
251
- ev.stopPropagation();
301
+ this._listGroupItems = newList;
302
+ this.ezChange.emit(this._listGroupItems);
252
303
  }
253
304
  onDropGroup(groupSelected) {
254
305
  var _a;
@@ -286,19 +337,13 @@ export class EzList {
286
337
  if (this.useGroups) {
287
338
  this.hideOverlays();
288
339
  }
289
- if (this._draggingElement) {
290
- try {
291
- this._element.shadowRoot.removeChild(this._draggingElement);
292
- }
293
- catch (err) { }
294
- this._draggingElement = undefined;
295
- }
296
340
  }
297
341
  addOverClass(element) {
298
342
  if ((element === null || element === void 0 ? void 0 : element.__proto__) == HTMLDivElement.prototype && element.classList.contains('draggable')) {
299
343
  element.classList.add('over');
344
+ return;
300
345
  }
301
- else if ((element === null || element === void 0 ? void 0 : element.parentElement) && !element.parentElement.classList.contains('draggable-list')) {
346
+ if ((element === null || element === void 0 ? void 0 : element.parentElement) && !element.parentElement.classList.contains('draggable-list')) {
302
347
  this.addOverClass(element.parentElement);
303
348
  }
304
349
  }
@@ -354,84 +399,94 @@ export class EzList {
354
399
  window.clearTimeout(this._changeDeboucingTimeout);
355
400
  }
356
401
  if (this.useGroups) {
357
- this._dragStartItem = { groupName: group.group, item: item, index: index };
358
- this._changeDeboucingTimeout = window.setTimeout(() => {
359
- this.showOverlays(group);
360
- }, 10);
361
- }
362
- else {
363
- this._dragStartItem = { item: item.item, index: item.index };
402
+ this.onDragStartWithGroups(group, item, index);
403
+ return;
364
404
  }
405
+ this._dragStartItem = { item: item.item, index: item.index };
406
+ }
407
+ onDragStartWithGroups(group, item, index) {
408
+ this._dragStartItem = { groupName: group.group, item: item, index: index };
409
+ this._changeDeboucingTimeout = window.setTimeout(() => {
410
+ this.showOverlays(group);
411
+ }, 10);
365
412
  }
366
413
  selectFirstItem() {
367
414
  if (this.useGroups) {
368
415
  this.setSelection(this._listGroupItems[0].items[0]);
369
416
  }
370
- {
417
+ else {
371
418
  this.setSelection(this._listItems[0]);
372
419
  }
373
420
  }
374
421
  nextOption(selectedItem) {
375
- let nextItem = undefined;
376
422
  if (this.useGroups) {
377
- this._listGroupItems.every((group, groupIndex, listGroupItems) => {
378
- let item = undefined;
379
- let itemIndex = group.items.findIndex(item => item.id == selectedItem.id);
380
- if (itemIndex != undefined && itemIndex != -1) {
381
- if (itemIndex === group.items.length - 1) {
382
- if (groupIndex + 1 <= listGroupItems.length - 1) {
383
- item = { label: listGroupItems[groupIndex + 1].items[0].label };
384
- }
385
- }
386
- else {
387
- item = { label: group.items[itemIndex + 1].label };
423
+ this.setSelection(this.nextOptionWithGroups(selectedItem), true);
424
+ return;
425
+ }
426
+ let nextItem = undefined;
427
+ let itemIndex = this._listItems.findIndex(item => item.id === selectedItem.id);
428
+ if (itemIndex >= 0 && itemIndex < this._listItems.length) {
429
+ nextItem = this._listItems[itemIndex + 1];
430
+ }
431
+ this.setSelection(nextItem, true);
432
+ }
433
+ nextOptionWithGroups(selectedItem) {
434
+ let nextItem = undefined;
435
+ this._listGroupItems.every((group, groupIndex, listGroupItems) => {
436
+ let item = undefined;
437
+ let itemIndex = group.items.findIndex(item => item.id == selectedItem.id);
438
+ if (itemIndex != undefined && itemIndex != -1) {
439
+ if (itemIndex === group.items.length - 1) {
440
+ if (groupIndex + 1 <= listGroupItems.length - 1) {
441
+ item = { label: listGroupItems[groupIndex + 1].items[0].label };
388
442
  }
389
443
  }
390
- if (item != undefined) {
391
- nextItem = item;
392
- return false;
444
+ else {
445
+ item = { label: group.items[itemIndex + 1].label };
393
446
  }
394
- return true;
395
- });
396
- }
397
- else {
398
- let itemIndex = this._listItems.findIndex(item => item.id === selectedItem.id);
399
- if (itemIndex >= 0 && itemIndex < this._listItems.length) {
400
- nextItem = this._listItems[itemIndex + 1];
401
447
  }
402
- }
403
- this.setSelection(nextItem, true);
448
+ if (item != undefined) {
449
+ nextItem = item;
450
+ return false;
451
+ }
452
+ return true;
453
+ });
454
+ return nextItem;
404
455
  }
405
456
  previousOption(selectedItem) {
406
- let previousItem = undefined;
407
457
  if (this.useGroups) {
408
- this._listGroupItems.every((group, groupIndex, listGroupItems) => {
409
- let item = undefined;
410
- let itemIndex = group.items.findIndex(item => item.id === selectedItem.id);
411
- if (itemIndex != undefined && itemIndex != -1) {
412
- if (itemIndex === 0) {
413
- if (groupIndex - 1 >= 0) {
414
- item = { label: listGroupItems[groupIndex - 1].items[listGroupItems[groupIndex - 1].items.length - 1].label };
415
- }
416
- }
417
- else {
418
- item = { label: group.items[itemIndex - 1].label };
458
+ this.setSelection(this.previousOptionWithGroups(selectedItem), true);
459
+ return;
460
+ }
461
+ let previousItem = undefined;
462
+ let itemIndex = this._listItems.findIndex(item => item.id === selectedItem.id);
463
+ if (itemIndex > 0 && itemIndex < this._listItems.length) {
464
+ previousItem = this._listItems[itemIndex - 1];
465
+ }
466
+ this.setSelection(previousItem, true);
467
+ }
468
+ previousOptionWithGroups(selectedItem) {
469
+ let previousItem = undefined;
470
+ this._listGroupItems.every((group, groupIndex, listGroupItems) => {
471
+ let item = undefined;
472
+ let itemIndex = group.items.findIndex(item => item.id === selectedItem.id);
473
+ if (itemIndex != undefined && itemIndex != -1) {
474
+ if (itemIndex === 0) {
475
+ if (groupIndex - 1 >= 0) {
476
+ item = { label: listGroupItems[groupIndex - 1].items[listGroupItems[groupIndex - 1].items.length - 1].label };
419
477
  }
420
478
  }
421
- if (item != undefined) {
422
- previousItem = item;
423
- return false;
479
+ else {
480
+ item = { label: group.items[itemIndex - 1].label };
424
481
  }
425
- return true;
426
- });
427
- }
428
- else {
429
- let itemIndex = this._listItems.findIndex(item => item.id === selectedItem.id);
430
- if (itemIndex > 0 && itemIndex < this._listItems.length) {
431
- previousItem = this._listItems[itemIndex - 1];
432
482
  }
433
- }
434
- this.setSelection(previousItem, true);
483
+ if (item != undefined) {
484
+ previousItem = item;
485
+ return false;
486
+ }
487
+ return true;
488
+ });
489
+ return previousItem;
435
490
  }
436
491
  keyDownHandler(event) {
437
492
  if (!event.ctrlKey) {
@@ -473,11 +528,11 @@ export class EzList {
473
528
  }
474
529
  }
475
530
  onDragOverItem(event) {
476
- if (this._dragStartItem) {
477
- event.preventDefault();
478
- this.addOverClass(event.target);
479
- event.stopPropagation();
480
- }
531
+ if (!this._dragStartItem)
532
+ return;
533
+ event.preventDefault();
534
+ this.addOverClass(event.target);
535
+ event.stopPropagation();
481
536
  }
482
537
  onDragOverLastIndex(ev) {
483
538
  ev.preventDefault();
@@ -517,41 +572,32 @@ export class EzList {
517
572
  doubleClickItem(item) {
518
573
  this.ezDoubleClick.emit(item);
519
574
  }
520
- render() {
521
- return (h(Host, { ref: el => (this._element = el) }, this.useGroups ? (h("div", { class: "group-container", ref: el => (this._groupContainer = el), tabIndex: 0, onKeyDown: event => {
522
- this.keyDownHandler(event);
523
- } }, this._listGroupItems.map(group => {
524
- return (h("div", { id: this.getDivGroupId(group.group), class: "group", key: group.group + group.items.length, onDrop: () => this.onDropGroup(group) }, h("label", { draggable: false, class: "group-name", title: group.group }, group.group), h("section", { class: "section-container", onDragOver: ev => ev.preventDefault() }, h("div", { class: "group-items-container" }, h("div", { class: "draggable-list" }, group.items.map((item, index) => (h("li", Object.assign({ id: 'item_' + item.id, class: {
575
+ buildItem(item, evt) {
576
+ return { id: item.id, label: item.label, check: evt.detail };
577
+ }
578
+ renderListWithGroups() {
579
+ return h("div", { class: 'group-container', ref: el => (this._groupContainer = el), tabIndex: this.ezSelectable ? 0 : undefined, onKeyDown: event => this.keyDownHandler(event) }, this._listGroupItems.map(group => {
580
+ return (h("div", { id: this.getDivGroupId(group.group), class: 'group', key: group.group + group.items.length, onDrop: () => this.onDropGroup(group) }, h("label", { draggable: false, class: 'group-name', title: group.group }, group.group), h("section", { class: 'section-container', onDragOver: ev => ev.preventDefault() }, h("div", { class: 'group-items-container' }, h("div", { class: 'draggable-list' }, group.items.map((item, index) => (h("li", Object.assign({ id: 'item_' + item.id, class: {
525
581
  'selectable-container': this.ezSelectable,
526
582
  'hover-feedback': this.hoverFeedback,
527
583
  }, key: 'item_' + item.id }, {
528
584
  [ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME]: ElementIDUtils.getInternalIDInfo(`ezListItem__${StringUtils.replaceAccentuatedChars(item.label)}`),
529
- }), h("div", { class: 'draggable' + (item.selected == true ? ' selected-item ' : '') + (this.ezSelectable == true ? ' selectable ' : ''), onDblClick: () => {
530
- this.doubleClickItem(item);
531
- }, onClick: () => {
532
- this.setSelection(item);
533
- }, onDragLeave: () => {
534
- group.sort ? undefined : this.removeOverClass();
535
- }, onDragEnd: () => this.onDragEnd(), onDragStart: () => this.onDragStart(item, group, index), onDragOver: event => {
536
- group.sort ? undefined : this.onDragOverItem(event);
537
- }, onDrop: event => this.onDrop(event, { groupName: group.group, item: item, index: index }), draggable: this.ezDraggable }, h("div", { class: "item-content" }, this.ezDraggable ? h("span", { class: "draggable-icon" }) : undefined, this.listMode === 'regular' ? (h(Fragment, null, !!this.itemLeftSlotBuilder && this.getContainerItemBuilder('left', item, group), h("p", { title: item.label, class: "person-name text--ellipsis" }, item.label))) : (h("ez-check", { label: item.label, value: item.check, onEzChange: evt => this.ezCheckChange.emit({ id: item.id, label: item.label, check: evt.detail }) }))), !!this.itemSlotBuilder && this.getContainerItemBuilder('right', item, group, 'slot-item')))))), h("div", { class: "last-droppable-space", onDragLeave: () => this.removeOverClass(), onDragOver: event => {
538
- this.onDragOverLastIndex(event);
539
- }, onDragEnd: () => this.onDragEnd(), onDrop: event => this.onDropLastIndex(event, group) })), group.sort ? (h("div", { id: this.getGroupOverlayId(group.group), class: "group-overlay" }, "Mover para ", group.group)) : undefined)));
540
- }))) : (h("div", { class: "items-container", ref: el => (this._itemContainer = el), tabIndex: 0, onKeyDown: event => {
585
+ }), h("div", { class: 'draggable' + (item.selected == true ? ' selected-item ' : '') + (this.ezSelectable == true ? ' selectable ' : ''), onDblClick: () => this.doubleClickItem(item), onClick: () => this.setSelection(item), onDragLeave: () => group.sort ? undefined : this.removeOverClass(), onDragEnd: () => this.onDragEnd(), onDragStart: () => this.onDragStart(item, group, index), onDragOver: event => group.sort ? undefined : this.onDragOverItem(event), onDrop: event => this.onDrop(event, { groupName: group.group, item: item, index: index }), draggable: this.ezDraggable }, h("div", { class: 'item-content' }, this.ezDraggable ? h("span", { class: 'draggable-icon' }) : undefined, this.listMode === 'regular' ? (h(Fragment, null, !!this.itemLeftSlotBuilder && this.getContainerItemBuilder('left', item, group), h("p", { title: item.label, class: 'person-name text--ellipsis' }, item.label))) : (h("ez-check", { label: item.label, value: item.check, onEzChange: evt => this.ezCheckChange.emit(this.buildItem(item, evt)) }))), !!this.itemSlotBuilder && this.getContainerItemBuilder('right', item, group, 'slot-item')))))), h("div", { class: 'last-droppable-space', onDragLeave: () => this.removeOverClass(), onDragOver: event => this.onDragOverLastIndex(event), onDragEnd: () => this.onDragEnd(), onDrop: event => this.onDropLastIndex(event, group) })), group.sort ? (h("div", { id: this.getGroupOverlayId(group.group), class: 'group-overlay' }, "Mover para ", group.group)) : undefined)));
586
+ }));
587
+ }
588
+ renderList() {
589
+ return h("div", { class: 'items-container', ref: el => (this._itemContainer = el), tabIndex: this.ezSelectable ? 0 : undefined, onKeyDown: event => {
541
590
  this.keyDownHandler(event);
542
- } }, h("div", { class: "draggable-list" }, this._listItems.map((item, index) => (h("li", Object.assign({ id: 'item_' + item.id, class: {
591
+ } }, h("div", { class: 'draggable-list' }, this._listItems.map((item, index) => (h("li", Object.assign({ id: 'item_' + item.id, class: {
543
592
  'selectable-container': this.ezSelectable,
544
593
  'hover-feedback': this.hoverFeedback,
545
- }, key: 'item_' + item.id }, { [ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME]: ElementIDUtils.getInternalIDInfo(`ezListItem__${StringUtils.replaceAccentuatedChars(item.label)}`) }), h("div", { class: 'draggable' + (item.selected == true ? ' selected-item ' : '') + (this.ezSelectable == true ? ' selectable ' : ''), onDragStart: () => this.onDragStart({ item: item, index: index }), onDblClick: () => {
546
- this.doubleClickItem(item);
547
- }, onClick: () => {
548
- this.setSelection(item);
549
- }, onDragLeave: () => this.removeOverClass(), onDragOver: event => this.onDragOverItem(event), onDragEnd: () => this.onDragEnd(), onDrop: event => this.onDrop(event, { item: item, index: index }), draggable: this.ezDraggable }, h("div", { class: "item-content" }, this.listMode === 'regular' ? (h(Fragment, null, this.ezDraggable ? h("span", { class: "draggable-icon" }) : undefined, !!this.itemLeftSlotBuilder && this.getContainerItemBuilder('left', item), h("p", { title: item.label, class: "person-name text--ellipsis" }, item.label))) : (h(Fragment, null, this.ezDraggable ? h("span", { class: "draggable-icon" }) : undefined, h("ez-check", { label: item.label, value: item.check, onEzChange: evt => this.ezCheckChange.emit({ id: item.id, label: item.label, check: evt.detail }) })))), !!this.itemSlotBuilder && this.getContainerItemBuilder('right', item))))), h("div", { class: "last-droppable-space", onDragLeave: () => this.removeOverClass(), onDragOver: event => {
550
- this.onDragOverLastIndex(event);
551
- }, onDragEnd: () => this.onDragEnd(), onDrop: event => this.onDropLastIndex(event) }))))));
594
+ }, key: 'item_' + item.id }, { [ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME]: ElementIDUtils.getInternalIDInfo(`ezListItem__${StringUtils.replaceAccentuatedChars(item.label)}`) }), h("div", { class: 'draggable' + (item.selected == true ? ' selected-item ' : '') + (this.ezSelectable == true ? ' selectable ' : ''), onDblClick: () => this.doubleClickItem(item), onClick: (event) => this.setSelection(item, false, event.shiftKey, (event.altKey || event.metaKey)), onDragStart: () => this.onDragStart({ item: item, index: index }), onDragOver: event => this.onDragOverItem(event), onDragLeave: () => this.removeOverClass(), onDragEnd: () => this.onDragEnd(), onDrop: event => this.onDrop(event, { item: item, index: index }), draggable: this.ezDraggable }, h("div", { class: 'item-content' }, this.listMode === 'regular' ? (h(Fragment, null, this.ezDraggable ? h("span", { class: 'draggable-icon' }) : undefined, !!this.itemLeftSlotBuilder && this.getContainerItemBuilder('left', item), h("p", { title: item.label, class: 'person-name text--ellipsis' }, item.label))) : (h(Fragment, null, this.ezDraggable ? h("span", { class: 'draggable-icon' }) : undefined, h("ez-check", { label: item.label, value: item.check, onEzChange: evt => this.ezCheckChange.emit({ id: item.id, label: item.label, check: evt.detail }) })))), !!this.itemSlotBuilder && this.getContainerItemBuilder('right', item))))), h("div", { class: 'last-droppable-space', onDragLeave: () => this.removeOverClass(), onDragOver: event => this.onDragOverLastIndex(event), onDragEnd: () => this.onDragEnd(), onDrop: event => this.onDropLastIndex(event) })));
595
+ }
596
+ render() {
597
+ return (h(Host, { ref: el => (this._element = el) }, this.useGroups ? this.renderListWithGroups() : this.renderList()));
552
598
  }
553
599
  static get is() { return "ez-list"; }
554
- static get encapsulation() { return "shadow"; }
600
+ static get encapsulation() { return "scoped"; }
555
601
  static get originalStyleUrls() {
556
602
  return {
557
603
  "$": ["ez-list.css"]
@@ -721,6 +767,24 @@ export class EzList {
721
767
  "attribute": "hover-feedback",
722
768
  "reflect": false,
723
769
  "defaultValue": "false"
770
+ },
771
+ "enableMultipleSelection": {
772
+ "type": "boolean",
773
+ "mutable": false,
774
+ "complexType": {
775
+ "original": "boolean",
776
+ "resolved": "boolean",
777
+ "references": {}
778
+ },
779
+ "required": false,
780
+ "optional": false,
781
+ "docs": {
782
+ "tags": [],
783
+ "text": "Habilita sele\u00E7\u00E3o de m\u00FAltiplos items."
784
+ },
785
+ "attribute": "enable-multiple-selection",
786
+ "reflect": false,
787
+ "defaultValue": "false"
724
788
  }
725
789
  };
726
790
  }
@@ -775,6 +839,25 @@ export class EzList {
775
839
  }
776
840
  }
777
841
  }
842
+ }, {
843
+ "method": "ezSelectMultipleItems",
844
+ "name": "ezSelectMultipleItems",
845
+ "bubbles": true,
846
+ "cancelable": true,
847
+ "composed": true,
848
+ "docs": {
849
+ "tags": [],
850
+ "text": "Emitido sempre que um ou v\u00E1rios item da lista for selecionado."
851
+ },
852
+ "complexType": {
853
+ "original": "ListItem[]",
854
+ "resolved": "ListItem[]",
855
+ "references": {
856
+ "ListItem": {
857
+ "location": "local"
858
+ }
859
+ }
860
+ }
778
861
  }, {
779
862
  "method": "ezCheckChange",
780
863
  "name": "ezCheckChange",
@@ -851,13 +934,19 @@ export class EzList {
851
934
  },
852
935
  "setSelection": {
853
936
  "complexType": {
854
- "signature": "(selectedItem: ListItem, scrollToOption?: boolean) => Promise<void>",
937
+ "signature": "(selectedItem: ListItem, scrollToOption?: boolean, shitkey?: boolean, ctrlKey?: boolean) => Promise<void>",
855
938
  "parameters": [{
856
939
  "tags": [],
857
940
  "text": ""
858
941
  }, {
859
942
  "tags": [],
860
943
  "text": ""
944
+ }, {
945
+ "tags": [],
946
+ "text": ""
947
+ }, {
948
+ "tags": [],
949
+ "text": ""
861
950
  }],
862
951
  "references": {
863
952
  "Promise": {