@sankhyalabs/ezui 5.22.0-dev.8 → 5.22.0-dev.81

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 (370) hide show
  1. package/dist/cjs/{CSSVarsUtils-10c9d5b4.js → CSSVarsUtils-f20973d1.js} +1 -0
  2. package/dist/cjs/DataBinder-e92314c2.js +445 -0
  3. package/dist/cjs/FocusResolver-885f2173.js +35 -0
  4. package/dist/cjs/ez-actions-button.cjs.entry.js +5 -4
  5. package/dist/cjs/ez-alert-list.cjs.entry.js +1 -1
  6. package/dist/cjs/ez-alert.cjs.entry.js +1 -1
  7. package/dist/cjs/ez-application.cjs.entry.js +1 -1
  8. package/dist/cjs/ez-badge.cjs.entry.js +1 -1
  9. package/dist/cjs/ez-breadcrumb.cjs.entry.js +1 -1
  10. package/dist/cjs/ez-button.cjs.entry.js +12 -6
  11. package/dist/cjs/ez-calendar.cjs.entry.js +1 -1
  12. package/dist/cjs/ez-card-item_2.cjs.entry.js +76 -0
  13. package/dist/cjs/ez-chart.cjs.entry.js +1 -1
  14. package/dist/cjs/ez-check.cjs.entry.js +2 -2
  15. package/dist/cjs/ez-chip.cjs.entry.js +1 -1
  16. package/dist/cjs/ez-collapsible-box.cjs.entry.js +2 -2
  17. package/dist/cjs/ez-combo-box.cjs.entry.js +68 -15
  18. package/dist/cjs/ez-custom-form-input_2.cjs.entry.js +37 -7
  19. package/dist/cjs/ez-date-input.cjs.entry.js +14 -5
  20. package/dist/cjs/ez-date-time-input.cjs.entry.js +11 -5
  21. package/dist/cjs/ez-dialog.cjs.entry.js +15 -8
  22. package/dist/cjs/ez-double-list.cjs.entry.js +287 -0
  23. package/dist/cjs/{ez-dropdown.cjs.entry.js → ez-dropdown_2.cjs.entry.js} +76 -9
  24. package/dist/cjs/ez-file-item.cjs.entry.js +1 -1
  25. package/dist/cjs/ez-filter-input.cjs.entry.js +129 -0
  26. package/dist/cjs/ez-form-view.cjs.entry.js +29 -22
  27. package/dist/cjs/ez-form.cjs.entry.js +7 -326
  28. package/dist/cjs/ez-grid.cjs.entry.js +14862 -69697
  29. package/dist/cjs/ez-guide-navigator.cjs.entry.js +1 -1
  30. package/dist/cjs/ez-icon.cjs.entry.js +2 -2
  31. package/dist/cjs/ez-list.cjs.entry.js +259 -212
  32. package/dist/cjs/ez-loading-bar.cjs.entry.js +1 -1
  33. package/dist/cjs/ez-modal-container.cjs.entry.js +3 -2
  34. package/dist/cjs/ez-modal.cjs.entry.js +20 -5
  35. package/dist/cjs/ez-multi-selection-list.cjs.entry.js +3 -3
  36. package/dist/cjs/ez-number-input.cjs.entry.js +16 -4
  37. package/dist/cjs/ez-popover.cjs.entry.js +1 -1
  38. package/dist/cjs/ez-popup.cjs.entry.js +25 -3
  39. package/dist/cjs/ez-radio-button.cjs.entry.js +1 -1
  40. package/dist/cjs/ez-scroller_2.cjs.entry.js +4 -4
  41. package/dist/cjs/ez-search.cjs.entry.js +109 -49
  42. package/dist/cjs/ez-sidebar-navigator.cjs.entry.js +2 -2
  43. package/dist/cjs/ez-split-button.cjs.entry.js +3 -3
  44. package/dist/cjs/ez-split-item.cjs.entry.js +7 -4
  45. package/dist/cjs/ez-split-panel.cjs.entry.js +69 -7
  46. package/dist/cjs/ez-tabselector.cjs.entry.js +1 -1
  47. package/dist/cjs/ez-text-area.cjs.entry.js +69 -7
  48. package/dist/cjs/ez-text-input.cjs.entry.js +153 -17
  49. package/dist/cjs/ez-time-input.cjs.entry.js +8 -2
  50. package/dist/cjs/ez-toast.cjs.entry.js +1 -1
  51. package/dist/cjs/ez-tooltip.cjs.entry.js +55 -0
  52. package/dist/cjs/ez-tree.cjs.entry.js +6 -5
  53. package/dist/cjs/ez-upload.cjs.entry.js +1 -1
  54. package/dist/cjs/ez-view-stack.cjs.entry.js +1 -1
  55. package/dist/cjs/ezListHelper-0d3970b4.js +90 -0
  56. package/dist/cjs/ezui.cjs.js +2 -2
  57. package/dist/cjs/filter-column.cjs.entry.js +3 -3
  58. package/dist/cjs/{index-a7b0c73d.js → index-9e5554cb.js} +19 -8
  59. package/dist/cjs/loader.cjs.js +2 -2
  60. package/dist/collection/collection-manifest.json +3 -1
  61. package/dist/collection/components/ez-actions-button/ez-actions-button.js +3 -2
  62. package/dist/collection/components/ez-button/ez-button.css +23 -13
  63. package/dist/collection/components/ez-button/ez-button.js +12 -6
  64. package/dist/collection/components/ez-card-item/ez-card-item.css +60 -10
  65. package/dist/collection/components/ez-card-item/ez-card-item.js +30 -3
  66. package/dist/collection/components/ez-check/ez-check.css +1 -6
  67. package/dist/collection/components/ez-collapsible-box/ez-collapsible-box.css +2 -2
  68. package/dist/collection/components/ez-combo-box/ez-combo-box.css +13 -1
  69. package/dist/collection/components/ez-combo-box/ez-combo-box.js +111 -15
  70. package/dist/collection/components/ez-date-input/ez-date-input.css +1 -1
  71. package/dist/collection/components/ez-date-input/ez-date-input.js +38 -4
  72. package/dist/collection/components/ez-date-time-input/ez-date-time-input.css +1 -1
  73. package/dist/collection/components/ez-date-time-input/ez-date-time-input.js +35 -4
  74. package/dist/collection/components/ez-dialog/ez-dialog.css +3 -3
  75. package/dist/collection/components/ez-dialog/ez-dialog.js +14 -16
  76. package/dist/collection/components/ez-double-list/doubleListHelper.js +82 -0
  77. package/dist/collection/components/ez-double-list/ez-double-list.css +62 -0
  78. package/dist/collection/components/ez-double-list/ez-double-list.js +440 -0
  79. package/dist/collection/components/ez-dropdown/ez-dropdown.js +33 -8
  80. package/dist/collection/components/ez-filter-input/ez-filter-input.js +35 -4
  81. package/dist/collection/components/ez-form/ez-form.js +1 -0
  82. package/dist/collection/components/ez-form-view/custom-input/ez-custom-form-input.js +49 -6
  83. package/dist/collection/components/ez-form-view/ez-form-view.css +5 -2
  84. package/dist/collection/components/ez-form-view/fieldbuilder/FieldBuilder.js +2 -1
  85. package/dist/collection/components/ez-form-view/fieldbuilder/templates/CheckBox.tpl.js +1 -1
  86. package/dist/collection/components/ez-form-view/fieldbuilder/templates/ComboBox.tpl.js +1 -1
  87. package/dist/collection/components/ez-form-view/fieldbuilder/templates/DateInput.tpl.js +8 -4
  88. package/dist/collection/components/ez-form-view/fieldbuilder/templates/FileInput.tpl.js +1 -1
  89. package/dist/collection/components/ez-form-view/fieldbuilder/templates/NumberInput.tpl.js +1 -1
  90. package/dist/collection/components/ez-form-view/fieldbuilder/templates/SearchInput.tpl.js +3 -2
  91. package/dist/collection/components/ez-form-view/fieldbuilder/templates/TextArea.tpl.js +1 -1
  92. package/dist/collection/components/ez-form-view/fieldbuilder/templates/TextInput.tpl.js +2 -2
  93. package/dist/collection/components/ez-grid/controller/ag-grid/AgGridController.js +292 -63
  94. package/dist/collection/components/ez-grid/controller/ag-grid/DataSource.js +151 -31
  95. package/dist/collection/components/ez-grid/controller/ag-grid/DataSourceInterceptor.js +2 -1
  96. package/dist/collection/components/ez-grid/controller/ag-grid/GridEditionManager.js +219 -42
  97. package/dist/collection/components/ez-grid/controller/ag-grid/components/EzGridCustomCellEditor.js +16 -0
  98. package/dist/collection/components/ez-grid/controller/ag-grid/editor/EzCellEditor.js +8 -0
  99. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/ComboBox.tpl.js +2 -0
  100. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/DateInput.tpl.js +1 -0
  101. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/NumberInput.tpl.js +1 -0
  102. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/Search.tpl.js +8 -1
  103. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/TextInput.tpl.js +4 -1
  104. package/dist/collection/components/ez-grid/controller/ag-grid/test/constants/GridEditionMock.js +2 -0
  105. package/dist/collection/components/ez-grid/ez-grid.css +47 -8
  106. package/dist/collection/components/ez-grid/ez-grid.js +280 -9
  107. package/dist/collection/components/ez-grid/subcomponents/filter-column.css +4 -0
  108. package/dist/collection/components/ez-grid/subcomponents/filter-column.js +1 -1
  109. package/dist/collection/components/ez-icon/ez-icon.css +155 -149
  110. package/dist/collection/components/ez-list/ez-list.css +2 -1
  111. package/dist/collection/components/ez-list/ez-list.js +301 -212
  112. package/dist/collection/components/ez-list/ezListHelper.js +85 -0
  113. package/dist/collection/components/ez-modal/ez-modal.css +5 -1
  114. package/dist/collection/components/ez-modal/ez-modal.js +38 -5
  115. package/dist/collection/components/ez-modal-container/ez-modal-container.js +20 -1
  116. package/dist/collection/components/ez-multi-selection-list/ez-multi-selection-list.css +2 -3
  117. package/dist/collection/components/ez-multi-selection-list/ez-multi-selection-list.js +1 -1
  118. package/dist/collection/components/ez-number-input/ez-number-input.css +8 -0
  119. package/dist/collection/components/ez-number-input/ez-number-input.js +49 -1
  120. package/dist/collection/components/ez-popup/ez-popup.css +8 -3
  121. package/dist/collection/components/ez-popup/ez-popup.js +43 -3
  122. package/dist/collection/components/ez-scroller/ez-scroller.css +1 -0
  123. package/dist/collection/components/ez-search/ez-search.css +21 -10
  124. package/dist/collection/components/ez-search/ez-search.js +192 -53
  125. package/dist/collection/components/ez-sidebar-button/ez-sidebar-button.css +3 -0
  126. package/dist/collection/components/ez-sidebar-button/ez-sidebar-button.js +1 -1
  127. package/dist/collection/components/ez-sidebar-navigator/ez-sidebar-navigator.css +3 -1
  128. package/dist/collection/components/ez-skeleton/ez-skeleton.css +54 -34
  129. package/dist/collection/components/ez-split-button/ez-split-button.css +50 -14
  130. package/dist/collection/components/ez-split-button/ez-split-button.js +3 -3
  131. package/dist/collection/components/ez-split-panel/ez-split-panel.css +15 -0
  132. package/dist/collection/components/ez-split-panel/ez-split-panel.js +106 -5
  133. package/dist/collection/components/ez-split-panel/interfaces/IPanelSizeInfo.js +1 -0
  134. package/dist/collection/components/ez-split-panel/structure/item/ez-split-item.css +14 -2
  135. package/dist/collection/components/ez-split-panel/structure/item/ez-split-item.js +22 -1
  136. package/dist/collection/components/ez-text-area/ez-text-area.css +78 -29
  137. package/dist/collection/components/ez-text-area/ez-text-area.js +104 -4
  138. package/dist/collection/components/ez-text-input/ez-text-input.css +106 -91
  139. package/dist/collection/components/ez-text-input/ez-text-input.js +166 -15
  140. package/dist/collection/components/ez-time-input/ez-time-input.js +24 -0
  141. package/dist/collection/components/ez-tooltip/ez-tooltip.css +20 -0
  142. package/dist/collection/components/ez-tooltip/ez-tooltip.js +116 -0
  143. package/dist/collection/components/ez-tree/ez-tree.js +21 -1
  144. package/dist/collection/components/ez-tree/subcomponents/TreeItem.js +3 -3
  145. package/dist/collection/sw.js +46 -0
  146. package/dist/collection/utils/CSSVarsUtils.js +1 -0
  147. package/dist/collection/utils/FocusResolver.js +31 -0
  148. package/dist/collection/utils/ResponsiveInputUtils.js +26 -0
  149. package/dist/collection/utils/form/DataBinder.js +22 -7
  150. package/dist/collection/utils/form/FormMetadata.js +2 -1
  151. package/dist/collection/utils/interfaces/AbstractFieldMetadata.js +1 -1
  152. package/dist/collection/utils/validators/recordvalidator/IInvalidCells.js +1 -0
  153. package/dist/collection/utils/validators/recordvalidator/RecordValidationProcessor.js +7 -1
  154. package/dist/custom-elements/index.d.ts +12 -0
  155. package/dist/custom-elements/index.js +16490 -70289
  156. package/dist/esm/{CSSVarsUtils-71ce76be.js → CSSVarsUtils-acba92d7.js} +1 -0
  157. package/dist/esm/DataBinder-9c877244.js +441 -0
  158. package/dist/esm/FocusResolver-1ccbf850.js +33 -0
  159. package/dist/esm/ez-actions-button.entry.js +5 -4
  160. package/dist/esm/ez-alert-list.entry.js +1 -1
  161. package/dist/esm/ez-alert.entry.js +1 -1
  162. package/dist/esm/ez-application.entry.js +1 -1
  163. package/dist/esm/ez-badge.entry.js +1 -1
  164. package/dist/esm/ez-breadcrumb.entry.js +1 -1
  165. package/dist/esm/ez-button.entry.js +12 -6
  166. package/dist/esm/ez-calendar.entry.js +1 -1
  167. package/dist/esm/ez-card-item_2.entry.js +71 -0
  168. package/dist/esm/ez-chart.entry.js +1 -1
  169. package/dist/esm/ez-check.entry.js +2 -2
  170. package/dist/esm/ez-chip.entry.js +1 -1
  171. package/dist/esm/ez-collapsible-box.entry.js +2 -2
  172. package/dist/esm/ez-combo-box.entry.js +69 -16
  173. package/dist/esm/ez-custom-form-input_2.entry.js +38 -8
  174. package/dist/esm/ez-date-input.entry.js +14 -5
  175. package/dist/esm/ez-date-time-input.entry.js +11 -5
  176. package/dist/esm/ez-dialog.entry.js +16 -9
  177. package/dist/esm/ez-double-list.entry.js +283 -0
  178. package/dist/esm/{ez-dropdown.entry.js → ez-dropdown_2.entry.js} +76 -10
  179. package/dist/esm/ez-file-item.entry.js +1 -1
  180. package/dist/esm/ez-filter-input.entry.js +125 -0
  181. package/dist/esm/ez-form-view.entry.js +29 -22
  182. package/dist/esm/ez-form.entry.js +6 -325
  183. package/dist/esm/ez-grid.entry.js +14892 -69727
  184. package/dist/esm/ez-guide-navigator.entry.js +1 -1
  185. package/dist/esm/ez-icon.entry.js +2 -2
  186. package/dist/esm/ez-list.entry.js +259 -212
  187. package/dist/esm/ez-loading-bar.entry.js +1 -1
  188. package/dist/esm/ez-modal-container.entry.js +3 -2
  189. package/dist/esm/ez-modal.entry.js +20 -5
  190. package/dist/esm/ez-multi-selection-list.entry.js +3 -3
  191. package/dist/esm/ez-number-input.entry.js +16 -4
  192. package/dist/esm/ez-popover.entry.js +1 -1
  193. package/dist/esm/ez-popup.entry.js +25 -3
  194. package/dist/esm/ez-radio-button.entry.js +1 -1
  195. package/dist/esm/ez-scroller_2.entry.js +4 -4
  196. package/dist/esm/ez-search.entry.js +109 -49
  197. package/dist/esm/ez-sidebar-navigator.entry.js +2 -2
  198. package/dist/esm/ez-split-button.entry.js +3 -3
  199. package/dist/esm/ez-split-item.entry.js +7 -4
  200. package/dist/esm/ez-split-panel.entry.js +69 -7
  201. package/dist/esm/ez-tabselector.entry.js +1 -1
  202. package/dist/esm/ez-text-area.entry.js +69 -7
  203. package/dist/esm/ez-text-input.entry.js +153 -17
  204. package/dist/esm/ez-time-input.entry.js +8 -2
  205. package/dist/esm/ez-toast.entry.js +1 -1
  206. package/dist/esm/ez-tooltip.entry.js +51 -0
  207. package/dist/esm/ez-tree.entry.js +6 -5
  208. package/dist/esm/ez-upload.entry.js +1 -1
  209. package/dist/esm/ez-view-stack.entry.js +1 -1
  210. package/dist/esm/ezListHelper-00fb9b8d.js +87 -0
  211. package/dist/esm/ezui.js +3 -3
  212. package/dist/esm/filter-column.entry.js +3 -3
  213. package/dist/esm/{index-baa5e267.js → index-5a720e56.js} +19 -9
  214. package/dist/esm/loader.js +3 -3
  215. package/dist/ezui/ezui.esm.js +1 -1
  216. package/dist/ezui/{p-44caad9a.entry.js → p-0378416a.entry.js} +1 -1
  217. package/dist/ezui/p-03b0ed5a.entry.js +1 -0
  218. package/dist/ezui/p-043b97b5.entry.js +1 -0
  219. package/dist/ezui/{p-5b205c80.entry.js → p-044d46d5.entry.js} +1 -1
  220. package/dist/ezui/{p-77a4bd35.entry.js → p-11bfeca3.entry.js} +1 -1
  221. package/dist/ezui/p-2069c78a.entry.js +1 -0
  222. package/dist/ezui/p-24b42f3d.entry.js +1 -0
  223. package/dist/ezui/p-2f53435e.entry.js +1 -0
  224. package/dist/ezui/p-3791d9c8.entry.js +1 -0
  225. package/dist/ezui/p-3af64edd.entry.js +1 -0
  226. package/dist/ezui/p-44b39e81.entry.js +1 -0
  227. package/dist/ezui/p-4818b8ce.entry.js +1 -0
  228. package/dist/ezui/p-4f7d3e72.entry.js +1 -0
  229. package/dist/ezui/p-5010315a.entry.js +1 -0
  230. package/dist/ezui/p-554522db.entry.js +1 -0
  231. package/dist/ezui/p-5548c9ab.entry.js +1 -0
  232. package/dist/ezui/p-68b2e579.entry.js +1 -0
  233. package/dist/ezui/{p-1f50fa05.entry.js → p-6b51c9cc.entry.js} +1 -1
  234. package/dist/ezui/p-6bda82d1.entry.js +1 -0
  235. package/dist/ezui/p-6d31c43c.entry.js +1 -0
  236. package/dist/ezui/p-6d8b3298.entry.js +1 -0
  237. package/dist/ezui/p-6ec40dec.entry.js +1 -0
  238. package/dist/ezui/{p-5ed81457.entry.js → p-6fc26622.entry.js} +1 -1
  239. package/dist/ezui/p-708b196e.entry.js +1 -0
  240. package/dist/ezui/p-735b7c7e.entry.js +309 -0
  241. package/dist/ezui/{p-555c9018.entry.js → p-7567ccdd.entry.js} +1 -1
  242. package/dist/ezui/p-80dfc50b.js +1 -0
  243. package/dist/ezui/{p-1e7a8633.entry.js → p-81461d2f.entry.js} +1 -1
  244. package/dist/ezui/{p-8df1ca33.entry.js → p-82fa4b09.entry.js} +1 -1
  245. package/dist/ezui/{p-09de35a2.entry.js → p-91ccae0c.entry.js} +1 -1
  246. package/dist/ezui/{p-c0d9c4f8.entry.js → p-92748142.entry.js} +1 -1
  247. package/dist/ezui/p-92fbaf2b.entry.js +1 -0
  248. package/dist/ezui/p-a921e3e7.entry.js +1 -0
  249. package/dist/ezui/p-acddfb2e.js +1 -0
  250. package/dist/ezui/p-b22889ea.entry.js +1 -0
  251. package/dist/ezui/{p-17be134a.entry.js → p-b2f6bc0a.entry.js} +1 -1
  252. package/dist/ezui/p-b6241ea3.entry.js +1 -0
  253. package/dist/ezui/p-b858fc6e.entry.js +1 -0
  254. package/dist/ezui/{p-84e439b9.entry.js → p-bef7daac.entry.js} +1 -1
  255. package/dist/ezui/{p-9f5fa3f9.entry.js → p-c2b20f78.entry.js} +1 -1
  256. package/dist/ezui/p-c96fbbef.entry.js +1 -0
  257. package/dist/ezui/p-ca8936df.entry.js +1 -0
  258. package/dist/ezui/p-cf33bc48.entry.js +1 -0
  259. package/dist/ezui/p-d32125d1.entry.js +1 -0
  260. package/dist/ezui/p-dc628ed3.js +1 -0
  261. package/dist/ezui/{p-a80b1287.entry.js → p-dfca5946.entry.js} +1 -1
  262. package/dist/ezui/p-e18d9e6a.entry.js +1 -0
  263. package/dist/ezui/p-e3f8660b.entry.js +1 -0
  264. package/dist/ezui/{p-23a36bb6.js → p-e4c7eb39.js} +2 -2
  265. package/dist/ezui/{p-0306dff7.entry.js → p-e6b38ade.entry.js} +1 -1
  266. package/dist/ezui/p-ec7db713.js +1 -0
  267. package/dist/ezui/{p-650e4b6d.entry.js → p-f1c2c19e.entry.js} +1 -1
  268. package/dist/ezui/p-f30e0590.entry.js +1 -0
  269. package/dist/ezui/p-f3e31f9f.entry.js +1 -0
  270. package/dist/ezui/p-f4da7e1e.entry.js +1 -0
  271. package/dist/ezui/{p-baf80b13.entry.js → p-fad4f1dd.entry.js} +1 -1
  272. package/dist/ezui/{p-6e429cff.entry.js → p-fc194825.entry.js} +1 -1
  273. package/dist/types/components/ez-button/ez-button.d.ts +2 -1
  274. package/dist/types/components/ez-card-item/ez-card-item.d.ts +5 -0
  275. package/dist/types/components/ez-combo-box/ez-combo-box.d.ts +12 -1
  276. package/dist/types/components/ez-date-input/ez-date-input.d.ts +6 -1
  277. package/dist/types/components/ez-date-time-input/ez-date-time-input.d.ts +6 -1
  278. package/dist/types/components/ez-dialog/ez-dialog.d.ts +2 -1
  279. package/dist/types/components/ez-double-list/doubleListHelper.d.ts +10 -0
  280. package/dist/types/components/ez-double-list/ez-double-list.d.ts +87 -0
  281. package/dist/types/components/ez-dropdown/ez-dropdown.d.ts +4 -0
  282. package/dist/types/components/ez-dropdown/structure/DropdownItem.d.ts +1 -1
  283. package/dist/types/components/ez-filter-input/ez-filter-input.d.ts +6 -1
  284. package/dist/types/components/ez-form-view/custom-input/ez-custom-form-input.d.ts +7 -1
  285. package/dist/types/components/ez-form-view/fieldbuilder/templates/DateInput.tpl.d.ts +2 -1
  286. package/dist/types/components/ez-form-view/fieldbuilder/templates/SearchInput.tpl.d.ts +1 -1
  287. package/dist/types/components/ez-form-view/fieldbuilder/templates/TextInput.tpl.d.ts +1 -1
  288. package/dist/types/components/ez-grid/controller/EzGridController.d.ts +71 -4
  289. package/dist/types/components/ez-grid/controller/ag-grid/AgGridController.d.ts +36 -4
  290. package/dist/types/components/ez-grid/controller/ag-grid/DataSource.d.ts +25 -2
  291. package/dist/types/components/ez-grid/controller/ag-grid/GridEditionManager.d.ts +33 -7
  292. package/dist/types/components/ez-grid/controller/ag-grid/components/EzGridCustomCellEditor.d.ts +4 -1
  293. package/dist/types/components/ez-grid/controller/ag-grid/components/EzGridCustomCellRender.d.ts +1 -1
  294. package/dist/types/components/ez-grid/controller/ag-grid/components/EzGridCustomHeader.d.ts +1 -1
  295. package/dist/types/components/ez-grid/controller/ag-grid/components/cellRendererStatus.d.ts +1 -1
  296. package/dist/types/components/ez-grid/controller/ag-grid/components/selectionHeader.d.ts +1 -1
  297. package/dist/types/components/ez-grid/controller/ag-grid/editor/EzCellEditor.d.ts +2 -1
  298. package/dist/types/components/ez-grid/controller/ag-grid/editor/EzCellRender.d.ts +1 -1
  299. package/dist/types/components/ez-grid/controller/ag-grid/editor/IUICellEditor.d.ts +1 -0
  300. package/dist/types/components/ez-grid/controller/ag-grid/mock/Server.d.ts +1 -1
  301. package/dist/types/components/ez-grid/ez-grid.d.ts +49 -1
  302. package/dist/types/components/ez-list/ez-list.d.ts +23 -2
  303. package/dist/types/components/ez-list/ezListHelper.d.ts +20 -0
  304. package/dist/types/components/ez-modal/ez-modal.d.ts +7 -1
  305. package/dist/types/components/ez-modal-container/ez-modal-container.d.ts +4 -0
  306. package/dist/types/components/ez-number-input/ez-number-input.d.ts +8 -0
  307. package/dist/types/components/ez-popup/ez-popup.d.ts +8 -1
  308. package/dist/types/components/ez-search/ez-search.d.ts +30 -6
  309. package/dist/types/components/ez-split-button/ez-split-button.d.ts +1 -1
  310. package/dist/types/components/ez-split-panel/ez-split-panel.d.ts +11 -0
  311. package/dist/types/components/ez-split-panel/interfaces/IPanelSizeInfo.d.ts +9 -0
  312. package/dist/types/components/ez-split-panel/structure/item/ez-split-item.d.ts +5 -0
  313. package/dist/types/components/ez-text-area/ez-text-area.d.ts +17 -0
  314. package/dist/types/components/ez-text-input/ez-text-input.d.ts +24 -2
  315. package/dist/types/components/ez-time-input/ez-time-input.d.ts +4 -0
  316. package/dist/types/components/ez-tooltip/ez-tooltip.d.ts +21 -0
  317. package/dist/types/components/ez-tree/ez-tree.d.ts +4 -0
  318. package/dist/types/components/ez-tree/interfaces/ITreeItem.d.ts +1 -0
  319. package/dist/types/components/ez-tree/subcomponents/TreeItem.d.ts +1 -0
  320. package/dist/types/components.d.ts +422 -27
  321. package/dist/types/utils/FocusResolver.d.ts +5 -0
  322. package/dist/types/utils/ResponsiveInputUtils.d.ts +6 -0
  323. package/dist/types/utils/customEditor/interfaces/ICustomEditor.d.ts +2 -0
  324. package/dist/types/utils/form/DataBinder.d.ts +3 -0
  325. package/dist/types/utils/validators/recordvalidator/IInvalidCells.d.ts +5 -0
  326. package/dist/types/utils/validators/recordvalidator/RecordValidationProcessor.d.ts +1 -1
  327. package/package.json +12 -4
  328. package/react/components.d.ts +2 -0
  329. package/react/components.js +2 -0
  330. package/react/components.js.map +1 -1
  331. package/dist/cjs/RecordValidationProcessor-4c893e04.js +0 -102
  332. package/dist/cjs/ez-card-item_3.cjs.entry.js +0 -183
  333. package/dist/cjs/ez-skeleton.cjs.entry.js +0 -67
  334. package/dist/esm/RecordValidationProcessor-b00b8b77.js +0 -99
  335. package/dist/esm/ez-card-item_3.entry.js +0 -177
  336. package/dist/esm/ez-skeleton.entry.js +0 -63
  337. package/dist/ezui/p-04f24913.js +0 -1
  338. package/dist/ezui/p-072e6347.entry.js +0 -1
  339. package/dist/ezui/p-1285c902.entry.js +0 -1
  340. package/dist/ezui/p-13d2fe2d.entry.js +0 -1
  341. package/dist/ezui/p-2097d0cf.entry.js +0 -1
  342. package/dist/ezui/p-30775e7f.entry.js +0 -1
  343. package/dist/ezui/p-32e553e5.entry.js +0 -304
  344. package/dist/ezui/p-3b4eeeb6.entry.js +0 -1
  345. package/dist/ezui/p-3faa2b46.entry.js +0 -1
  346. package/dist/ezui/p-49456b34.entry.js +0 -1
  347. package/dist/ezui/p-4d5235f1.entry.js +0 -1
  348. package/dist/ezui/p-5bd5e68f.entry.js +0 -1
  349. package/dist/ezui/p-784fe207.entry.js +0 -1
  350. package/dist/ezui/p-7922142b.entry.js +0 -1
  351. package/dist/ezui/p-7af81663.entry.js +0 -1
  352. package/dist/ezui/p-7bc07c31.entry.js +0 -1
  353. package/dist/ezui/p-85c8baae.entry.js +0 -1
  354. package/dist/ezui/p-8888d9ed.entry.js +0 -1
  355. package/dist/ezui/p-8f0144f6.entry.js +0 -1
  356. package/dist/ezui/p-9050d2cd.entry.js +0 -1
  357. package/dist/ezui/p-922ac38b.entry.js +0 -1
  358. package/dist/ezui/p-9ab22a07.entry.js +0 -1
  359. package/dist/ezui/p-9e11fc7b.js +0 -1
  360. package/dist/ezui/p-a31b9c90.entry.js +0 -1
  361. package/dist/ezui/p-af95cd16.entry.js +0 -1
  362. package/dist/ezui/p-bae4e180.entry.js +0 -1
  363. package/dist/ezui/p-bc2f844e.entry.js +0 -1
  364. package/dist/ezui/p-bcb53f27.entry.js +0 -1
  365. package/dist/ezui/p-bf79aaa1.entry.js +0 -1
  366. package/dist/ezui/p-d9401ea0.entry.js +0 -1
  367. package/dist/ezui/p-e85c48d7.entry.js +0 -1
  368. package/dist/ezui/p-ecc2c1ec.entry.js +0 -1
  369. package/dist/ezui/p-f3c526cc.entry.js +0 -1
  370. 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: 0, 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: 0, 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": {