@sankhyalabs/ezui 5.22.0-dev.7 → 5.22.0-dev.71

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 (357) hide show
  1. package/dist/cjs/DataBinder-b4ef826a.js +445 -0
  2. package/dist/cjs/FocusResolver-885f2173.js +35 -0
  3. package/dist/cjs/ez-actions-button.cjs.entry.js +4 -3
  4. package/dist/cjs/ez-alert-list.cjs.entry.js +1 -1
  5. package/dist/cjs/ez-alert.cjs.entry.js +1 -1
  6. package/dist/cjs/ez-application.cjs.entry.js +1 -1
  7. package/dist/cjs/ez-badge.cjs.entry.js +1 -1
  8. package/dist/cjs/ez-breadcrumb.cjs.entry.js +1 -1
  9. package/dist/cjs/ez-button.cjs.entry.js +12 -6
  10. package/dist/cjs/ez-calendar.cjs.entry.js +1 -1
  11. package/dist/cjs/ez-card-item_2.cjs.entry.js +76 -0
  12. package/dist/cjs/ez-chart.cjs.entry.js +1 -1
  13. package/dist/cjs/ez-check.cjs.entry.js +2 -2
  14. package/dist/cjs/ez-chip.cjs.entry.js +1 -1
  15. package/dist/cjs/ez-collapsible-box.cjs.entry.js +2 -2
  16. package/dist/cjs/ez-combo-box.cjs.entry.js +68 -14
  17. package/dist/cjs/ez-custom-form-input_2.cjs.entry.js +37 -7
  18. package/dist/cjs/ez-date-input.cjs.entry.js +15 -5
  19. package/dist/cjs/ez-date-time-input.cjs.entry.js +12 -5
  20. package/dist/cjs/ez-dialog.cjs.entry.js +11 -3
  21. package/dist/cjs/ez-double-list.cjs.entry.js +287 -0
  22. package/dist/cjs/{ez-dropdown.cjs.entry.js → ez-dropdown_2.cjs.entry.js} +76 -9
  23. package/dist/cjs/ez-file-item.cjs.entry.js +1 -1
  24. package/dist/cjs/ez-filter-input.cjs.entry.js +130 -0
  25. package/dist/cjs/ez-form-view.cjs.entry.js +30 -23
  26. package/dist/cjs/ez-form.cjs.entry.js +7 -326
  27. package/dist/cjs/ez-grid.cjs.entry.js +14946 -69807
  28. package/dist/cjs/ez-guide-navigator.cjs.entry.js +1 -1
  29. package/dist/cjs/ez-icon.cjs.entry.js +2 -2
  30. package/dist/cjs/ez-list.cjs.entry.js +259 -212
  31. package/dist/cjs/ez-loading-bar.cjs.entry.js +1 -1
  32. package/dist/cjs/ez-modal-container.cjs.entry.js +3 -2
  33. package/dist/cjs/ez-modal.cjs.entry.js +20 -5
  34. package/dist/cjs/ez-multi-selection-list.cjs.entry.js +3 -3
  35. package/dist/cjs/ez-number-input.cjs.entry.js +16 -3
  36. package/dist/cjs/ez-popover.cjs.entry.js +1 -1
  37. package/dist/cjs/ez-popup.cjs.entry.js +25 -3
  38. package/dist/cjs/ez-radio-button.cjs.entry.js +1 -1
  39. package/dist/cjs/ez-scroller_2.cjs.entry.js +4 -4
  40. package/dist/cjs/ez-search.cjs.entry.js +106 -46
  41. package/dist/cjs/ez-sidebar-navigator.cjs.entry.js +2 -2
  42. package/dist/cjs/ez-split-button.cjs.entry.js +3 -3
  43. package/dist/cjs/ez-split-item.cjs.entry.js +4 -3
  44. package/dist/cjs/ez-split-panel.cjs.entry.js +69 -7
  45. package/dist/cjs/ez-tabselector.cjs.entry.js +1 -1
  46. package/dist/cjs/ez-text-area.cjs.entry.js +68 -6
  47. package/dist/cjs/ez-text-input.cjs.entry.js +154 -17
  48. package/dist/cjs/ez-time-input.cjs.entry.js +9 -2
  49. package/dist/cjs/ez-toast.cjs.entry.js +1 -1
  50. package/dist/cjs/ez-tooltip.cjs.entry.js +55 -0
  51. package/dist/cjs/ez-tree.cjs.entry.js +1 -1
  52. package/dist/cjs/ez-upload.cjs.entry.js +1 -1
  53. package/dist/cjs/ez-view-stack.cjs.entry.js +1 -1
  54. package/dist/cjs/ezListHelper-0d3970b4.js +90 -0
  55. package/dist/cjs/ezui.cjs.js +2 -2
  56. package/dist/cjs/filter-column.cjs.entry.js +3 -3
  57. package/dist/cjs/{index-9e5554cb.js → index-a7b0c73d.js} +16 -11
  58. package/dist/cjs/loader.cjs.js +2 -2
  59. package/dist/collection/collection-manifest.json +3 -1
  60. package/dist/collection/components/ez-actions-button/ez-actions-button.js +3 -2
  61. package/dist/collection/components/ez-button/ez-button.css +23 -13
  62. package/dist/collection/components/ez-button/ez-button.js +12 -6
  63. package/dist/collection/components/ez-card-item/ez-card-item.css +60 -10
  64. package/dist/collection/components/ez-card-item/ez-card-item.js +30 -3
  65. package/dist/collection/components/ez-check/ez-check.css +1 -6
  66. package/dist/collection/components/ez-collapsible-box/ez-collapsible-box.css +2 -2
  67. package/dist/collection/components/ez-combo-box/ez-combo-box.css +13 -1
  68. package/dist/collection/components/ez-combo-box/ez-combo-box.js +130 -15
  69. package/dist/collection/components/ez-date-input/ez-date-input.css +1 -1
  70. package/dist/collection/components/ez-date-input/ez-date-input.js +58 -5
  71. package/dist/collection/components/ez-date-time-input/ez-date-time-input.css +1 -1
  72. package/dist/collection/components/ez-date-time-input/ez-date-time-input.js +55 -5
  73. package/dist/collection/components/ez-dialog/ez-dialog.css +3 -3
  74. package/dist/collection/components/ez-dialog/ez-dialog.js +9 -1
  75. package/dist/collection/components/ez-double-list/doubleListHelper.js +82 -0
  76. package/dist/collection/components/ez-double-list/ez-double-list.css +62 -0
  77. package/dist/collection/components/ez-double-list/ez-double-list.js +440 -0
  78. package/dist/collection/components/ez-dropdown/ez-dropdown.js +33 -8
  79. package/dist/collection/components/ez-filter-input/ez-filter-input.js +55 -5
  80. package/dist/collection/components/ez-form/ez-form.js +1 -0
  81. package/dist/collection/components/ez-form-view/custom-input/ez-custom-form-input.js +49 -6
  82. package/dist/collection/components/ez-form-view/ez-form-view.css +5 -2
  83. package/dist/collection/components/ez-form-view/fieldbuilder/FieldBuilder.js +2 -1
  84. package/dist/collection/components/ez-form-view/fieldbuilder/templates/CheckBox.tpl.js +1 -1
  85. package/dist/collection/components/ez-form-view/fieldbuilder/templates/ComboBox.tpl.js +1 -1
  86. package/dist/collection/components/ez-form-view/fieldbuilder/templates/DateInput.tpl.js +8 -4
  87. package/dist/collection/components/ez-form-view/fieldbuilder/templates/FileInput.tpl.js +1 -1
  88. package/dist/collection/components/ez-form-view/fieldbuilder/templates/NumberInput.tpl.js +1 -1
  89. package/dist/collection/components/ez-form-view/fieldbuilder/templates/SearchInput.tpl.js +3 -2
  90. package/dist/collection/components/ez-form-view/fieldbuilder/templates/TextArea.tpl.js +1 -1
  91. package/dist/collection/components/ez-form-view/fieldbuilder/templates/TextInput.tpl.js +2 -2
  92. package/dist/collection/components/ez-grid/controller/ag-grid/AgGridController.js +282 -57
  93. package/dist/collection/components/ez-grid/controller/ag-grid/DataSource.js +107 -5
  94. package/dist/collection/components/ez-grid/controller/ag-grid/DataSourceInterceptor.js +2 -2
  95. package/dist/collection/components/ez-grid/controller/ag-grid/GridEditionManager.js +219 -42
  96. package/dist/collection/components/ez-grid/controller/ag-grid/components/EzGridCustomCellEditor.js +16 -0
  97. package/dist/collection/components/ez-grid/controller/ag-grid/editor/EzCellEditor.js +8 -0
  98. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/ComboBox.tpl.js +2 -0
  99. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/DateInput.tpl.js +1 -0
  100. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/NumberInput.tpl.js +1 -0
  101. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/Search.tpl.js +8 -1
  102. package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/TextInput.tpl.js +4 -1
  103. package/dist/collection/components/ez-grid/controller/ag-grid/test/constants/GridEditionMock.js +2 -0
  104. package/dist/collection/components/ez-grid/ez-grid.css +47 -8
  105. package/dist/collection/components/ez-grid/ez-grid.js +220 -7
  106. package/dist/collection/components/ez-grid/subcomponents/filter-column.css +4 -0
  107. package/dist/collection/components/ez-grid/subcomponents/filter-column.js +1 -1
  108. package/dist/collection/components/ez-icon/ez-icon.css +153 -149
  109. package/dist/collection/components/ez-list/ez-list.css +2 -1
  110. package/dist/collection/components/ez-list/ez-list.js +301 -212
  111. package/dist/collection/components/ez-list/ezListHelper.js +85 -0
  112. package/dist/collection/components/ez-modal/ez-modal.css +5 -1
  113. package/dist/collection/components/ez-modal/ez-modal.js +38 -5
  114. package/dist/collection/components/ez-modal-container/ez-modal-container.js +20 -1
  115. package/dist/collection/components/ez-multi-selection-list/ez-multi-selection-list.css +2 -3
  116. package/dist/collection/components/ez-multi-selection-list/ez-multi-selection-list.js +1 -1
  117. package/dist/collection/components/ez-number-input/ez-number-input.css +8 -0
  118. package/dist/collection/components/ez-number-input/ez-number-input.js +68 -1
  119. package/dist/collection/components/ez-popup/ez-popup.css +8 -3
  120. package/dist/collection/components/ez-popup/ez-popup.js +43 -3
  121. package/dist/collection/components/ez-scroller/ez-scroller.css +1 -0
  122. package/dist/collection/components/ez-search/ez-search.css +21 -10
  123. package/dist/collection/components/ez-search/ez-search.js +189 -49
  124. package/dist/collection/components/ez-sidebar-button/ez-sidebar-button.css +3 -0
  125. package/dist/collection/components/ez-sidebar-button/ez-sidebar-button.js +1 -1
  126. package/dist/collection/components/ez-sidebar-navigator/ez-sidebar-navigator.css +3 -1
  127. package/dist/collection/components/ez-split-button/ez-split-button.css +50 -14
  128. package/dist/collection/components/ez-split-button/ez-split-button.js +3 -3
  129. package/dist/collection/components/ez-split-panel/ez-split-panel.css +15 -0
  130. package/dist/collection/components/ez-split-panel/ez-split-panel.js +106 -5
  131. package/dist/collection/components/ez-split-panel/interfaces/IPanelSizeInfo.js +1 -0
  132. package/dist/collection/components/ez-split-panel/structure/item/ez-split-item.css +14 -2
  133. package/dist/collection/components/ez-split-panel/structure/item/ez-split-item.js +20 -1
  134. package/dist/collection/components/ez-text-area/ez-text-area.css +73 -28
  135. package/dist/collection/components/ez-text-area/ez-text-area.js +103 -3
  136. package/dist/collection/components/ez-text-input/ez-text-input.css +106 -91
  137. package/dist/collection/components/ez-text-input/ez-text-input.js +185 -15
  138. package/dist/collection/components/ez-time-input/ez-time-input.js +44 -1
  139. package/dist/collection/components/ez-tooltip/ez-tooltip.css +20 -0
  140. package/dist/collection/components/ez-tooltip/ez-tooltip.js +116 -0
  141. package/dist/collection/sw.js +46 -0
  142. package/dist/collection/utils/FocusResolver.js +31 -0
  143. package/dist/collection/utils/ResponsiveInputUtils.js +26 -0
  144. package/dist/collection/utils/form/DataBinder.js +20 -5
  145. package/dist/collection/utils/form/FormMetadata.js +2 -1
  146. package/dist/collection/utils/interfaces/AbstractFieldMetadata.js +1 -1
  147. package/dist/collection/utils/validators/recordvalidator/IInvalidCells.js +1 -0
  148. package/dist/collection/utils/validators/recordvalidator/RecordValidationProcessor.js +7 -1
  149. package/dist/custom-elements/index.d.ts +12 -0
  150. package/dist/custom-elements/index.js +16564 -70385
  151. package/dist/esm/DataBinder-d2ecbb0f.js +441 -0
  152. package/dist/esm/FocusResolver-1ccbf850.js +33 -0
  153. package/dist/esm/ez-actions-button.entry.js +4 -3
  154. package/dist/esm/ez-alert-list.entry.js +1 -1
  155. package/dist/esm/ez-alert.entry.js +1 -1
  156. package/dist/esm/ez-application.entry.js +1 -1
  157. package/dist/esm/ez-badge.entry.js +1 -1
  158. package/dist/esm/ez-breadcrumb.entry.js +1 -1
  159. package/dist/esm/ez-button.entry.js +12 -6
  160. package/dist/esm/ez-calendar.entry.js +1 -1
  161. package/dist/esm/ez-card-item_2.entry.js +71 -0
  162. package/dist/esm/ez-chart.entry.js +1 -1
  163. package/dist/esm/ez-check.entry.js +2 -2
  164. package/dist/esm/ez-chip.entry.js +1 -1
  165. package/dist/esm/ez-collapsible-box.entry.js +2 -2
  166. package/dist/esm/ez-combo-box.entry.js +69 -15
  167. package/dist/esm/ez-custom-form-input_2.entry.js +38 -8
  168. package/dist/esm/ez-date-input.entry.js +15 -5
  169. package/dist/esm/ez-date-time-input.entry.js +12 -5
  170. package/dist/esm/ez-dialog.entry.js +11 -3
  171. package/dist/esm/ez-double-list.entry.js +283 -0
  172. package/dist/esm/{ez-dropdown.entry.js → ez-dropdown_2.entry.js} +76 -10
  173. package/dist/esm/ez-file-item.entry.js +1 -1
  174. package/dist/esm/ez-filter-input.entry.js +126 -0
  175. package/dist/esm/ez-form-view.entry.js +30 -23
  176. package/dist/esm/ez-form.entry.js +6 -325
  177. package/dist/esm/ez-grid.entry.js +14945 -69806
  178. package/dist/esm/ez-guide-navigator.entry.js +1 -1
  179. package/dist/esm/ez-icon.entry.js +2 -2
  180. package/dist/esm/ez-list.entry.js +259 -212
  181. package/dist/esm/ez-loading-bar.entry.js +1 -1
  182. package/dist/esm/ez-modal-container.entry.js +3 -2
  183. package/dist/esm/ez-modal.entry.js +20 -5
  184. package/dist/esm/ez-multi-selection-list.entry.js +3 -3
  185. package/dist/esm/ez-number-input.entry.js +16 -3
  186. package/dist/esm/ez-popover.entry.js +1 -1
  187. package/dist/esm/ez-popup.entry.js +25 -3
  188. package/dist/esm/ez-radio-button.entry.js +1 -1
  189. package/dist/esm/ez-scroller_2.entry.js +4 -4
  190. package/dist/esm/ez-search.entry.js +106 -46
  191. package/dist/esm/ez-sidebar-navigator.entry.js +2 -2
  192. package/dist/esm/ez-split-button.entry.js +3 -3
  193. package/dist/esm/ez-split-item.entry.js +4 -3
  194. package/dist/esm/ez-split-panel.entry.js +69 -7
  195. package/dist/esm/ez-tabselector.entry.js +1 -1
  196. package/dist/esm/ez-text-area.entry.js +68 -6
  197. package/dist/esm/ez-text-input.entry.js +154 -17
  198. package/dist/esm/ez-time-input.entry.js +9 -2
  199. package/dist/esm/ez-toast.entry.js +1 -1
  200. package/dist/esm/ez-tooltip.entry.js +51 -0
  201. package/dist/esm/ez-tree.entry.js +1 -1
  202. package/dist/esm/ez-upload.entry.js +1 -1
  203. package/dist/esm/ez-view-stack.entry.js +1 -1
  204. package/dist/esm/ezListHelper-00fb9b8d.js +87 -0
  205. package/dist/esm/ezui.js +3 -3
  206. package/dist/esm/filter-column.entry.js +3 -3
  207. package/dist/esm/{index-5a720e56.js → index-baa5e267.js} +17 -11
  208. package/dist/esm/loader.js +3 -3
  209. package/dist/ezui/ezui.esm.js +1 -1
  210. package/dist/ezui/{p-e6b38ade.entry.js → p-0306dff7.entry.js} +1 -1
  211. package/dist/ezui/{p-91ccae0c.entry.js → p-09de35a2.entry.js} +1 -1
  212. package/dist/ezui/p-14b769d7.entry.js +1 -0
  213. package/dist/ezui/p-16e612fc.entry.js +1 -0
  214. package/dist/ezui/{p-b2f6bc0a.entry.js → p-17be134a.entry.js} +1 -1
  215. package/dist/ezui/p-17eabf46.entry.js +1 -0
  216. package/dist/ezui/p-181b5ae8.entry.js +1 -0
  217. package/dist/ezui/{p-81461d2f.entry.js → p-1e7a8633.entry.js} +1 -1
  218. package/dist/ezui/{p-6b51c9cc.entry.js → p-1f50fa05.entry.js} +1 -1
  219. package/dist/ezui/{p-e4c7eb39.js → p-23a36bb6.js} +2 -2
  220. package/dist/ezui/p-2475fd6e.entry.js +1 -0
  221. package/dist/ezui/p-2bb2a0c4.entry.js +1 -0
  222. package/dist/ezui/p-3175fe8c.entry.js +1 -0
  223. package/dist/ezui/{p-30951bd7.entry.js → p-35d467a8.entry.js} +1 -1
  224. package/dist/ezui/p-3f2dd525.entry.js +1 -0
  225. package/dist/ezui/{p-0378416a.entry.js → p-44caad9a.entry.js} +1 -1
  226. package/dist/ezui/p-50d83a46.entry.js +1 -0
  227. package/dist/ezui/{p-7567ccdd.entry.js → p-555c9018.entry.js} +1 -1
  228. package/dist/ezui/{p-044d46d5.entry.js → p-5b205c80.entry.js} +1 -1
  229. package/dist/ezui/{p-6fc26622.entry.js → p-5ed81457.entry.js} +1 -1
  230. package/dist/ezui/{p-f1c2c19e.entry.js → p-650e4b6d.entry.js} +1 -1
  231. package/dist/ezui/p-654b3f99.entry.js +1 -0
  232. package/dist/ezui/p-65f471bc.entry.js +1 -0
  233. package/dist/ezui/p-66924de6.entry.js +1 -0
  234. package/dist/ezui/p-6cdd3e0a.entry.js +1 -0
  235. package/dist/ezui/p-6d79930d.entry.js +1 -0
  236. package/dist/ezui/{p-fc194825.entry.js → p-6e429cff.entry.js} +1 -1
  237. package/dist/ezui/p-6f22a385.entry.js +1 -0
  238. package/dist/ezui/p-7409eeaa.entry.js +1 -0
  239. package/dist/ezui/{p-11bfeca3.entry.js → p-77a4bd35.entry.js} +1 -1
  240. package/dist/ezui/p-7e677b7b.entry.js +1 -0
  241. package/dist/ezui/p-7ed30844.entry.js +1 -0
  242. package/dist/ezui/p-7fdd479f.entry.js +1 -0
  243. package/dist/ezui/p-80dfc50b.js +1 -0
  244. package/dist/ezui/{p-1b08bf3c.entry.js → p-8888d9ed.entry.js} +1 -1
  245. package/dist/ezui/{p-82fa4b09.entry.js → p-8df1ca33.entry.js} +1 -1
  246. package/dist/ezui/p-990b4318.entry.js +1 -0
  247. package/dist/ezui/{p-c2b20f78.entry.js → p-9f5fa3f9.entry.js} +1 -1
  248. package/dist/ezui/p-a6fe527a.entry.js +1 -0
  249. package/dist/ezui/{p-dfca5946.entry.js → p-a80b1287.entry.js} +1 -1
  250. package/dist/ezui/p-b6a4e6de.entry.js +1 -0
  251. package/dist/ezui/p-bc2f844e.entry.js +1 -0
  252. package/dist/ezui/{p-92748142.entry.js → p-c0d9c4f8.entry.js} +1 -1
  253. package/dist/ezui/p-c3045972.entry.js +1 -0
  254. package/dist/ezui/{p-82ac8b06.entry.js → p-c4320a39.entry.js} +1 -1
  255. package/dist/ezui/p-ca6340a9.entry.js +1 -0
  256. package/dist/ezui/p-ceadecd9.js +1 -0
  257. package/dist/ezui/p-d0ca26fe.entry.js +1 -0
  258. package/dist/ezui/p-d520839d.entry.js +1 -0
  259. package/dist/ezui/p-dc628ed3.js +1 -0
  260. package/dist/ezui/p-dc8b36c3.entry.js +1 -0
  261. package/dist/ezui/p-dd48941c.entry.js +309 -0
  262. package/dist/ezui/{p-9aa27e69.entry.js → p-e347df9c.entry.js} +1 -1
  263. package/dist/ezui/p-e3e3fd7a.entry.js +1 -0
  264. package/dist/ezui/p-fa6732f2.entry.js +1 -0
  265. package/dist/ezui/p-fec696ab.entry.js +1 -0
  266. package/dist/types/components/ez-button/ez-button.d.ts +2 -1
  267. package/dist/types/components/ez-card-item/ez-card-item.d.ts +5 -0
  268. package/dist/types/components/ez-combo-box/ez-combo-box.d.ts +16 -1
  269. package/dist/types/components/ez-date-input/ez-date-input.d.ts +10 -1
  270. package/dist/types/components/ez-date-time-input/ez-date-time-input.d.ts +10 -1
  271. package/dist/types/components/ez-dialog/ez-dialog.d.ts +2 -0
  272. package/dist/types/components/ez-double-list/doubleListHelper.d.ts +10 -0
  273. package/dist/types/components/ez-double-list/ez-double-list.d.ts +87 -0
  274. package/dist/types/components/ez-dropdown/ez-dropdown.d.ts +4 -0
  275. package/dist/types/components/ez-dropdown/structure/DropdownItem.d.ts +1 -1
  276. package/dist/types/components/ez-filter-input/ez-filter-input.d.ts +10 -1
  277. package/dist/types/components/ez-form-view/custom-input/ez-custom-form-input.d.ts +7 -1
  278. package/dist/types/components/ez-form-view/fieldbuilder/templates/DateInput.tpl.d.ts +2 -1
  279. package/dist/types/components/ez-form-view/fieldbuilder/templates/SearchInput.tpl.d.ts +1 -1
  280. package/dist/types/components/ez-form-view/fieldbuilder/templates/TextInput.tpl.d.ts +1 -1
  281. package/dist/types/components/ez-grid/controller/EzGridController.d.ts +60 -4
  282. package/dist/types/components/ez-grid/controller/ag-grid/AgGridController.d.ts +36 -4
  283. package/dist/types/components/ez-grid/controller/ag-grid/DataSource.d.ts +23 -1
  284. package/dist/types/components/ez-grid/controller/ag-grid/GridEditionManager.d.ts +33 -7
  285. package/dist/types/components/ez-grid/controller/ag-grid/components/EzGridCustomCellEditor.d.ts +4 -1
  286. package/dist/types/components/ez-grid/controller/ag-grid/components/EzGridCustomCellRender.d.ts +1 -1
  287. package/dist/types/components/ez-grid/controller/ag-grid/components/EzGridCustomHeader.d.ts +1 -1
  288. package/dist/types/components/ez-grid/controller/ag-grid/components/cellRendererStatus.d.ts +1 -1
  289. package/dist/types/components/ez-grid/controller/ag-grid/components/selectionHeader.d.ts +1 -1
  290. package/dist/types/components/ez-grid/controller/ag-grid/editor/EzCellEditor.d.ts +2 -1
  291. package/dist/types/components/ez-grid/controller/ag-grid/editor/EzCellRender.d.ts +1 -1
  292. package/dist/types/components/ez-grid/controller/ag-grid/editor/IUICellEditor.d.ts +1 -0
  293. package/dist/types/components/ez-grid/controller/ag-grid/mock/Server.d.ts +1 -1
  294. package/dist/types/components/ez-grid/ez-grid.d.ts +37 -1
  295. package/dist/types/components/ez-list/ez-list.d.ts +23 -2
  296. package/dist/types/components/ez-list/ezListHelper.d.ts +20 -0
  297. package/dist/types/components/ez-modal/ez-modal.d.ts +7 -1
  298. package/dist/types/components/ez-modal-container/ez-modal-container.d.ts +4 -0
  299. package/dist/types/components/ez-number-input/ez-number-input.d.ts +12 -0
  300. package/dist/types/components/ez-popup/ez-popup.d.ts +8 -1
  301. package/dist/types/components/ez-search/ez-search.d.ts +29 -5
  302. package/dist/types/components/ez-split-button/ez-split-button.d.ts +1 -1
  303. package/dist/types/components/ez-split-panel/ez-split-panel.d.ts +11 -0
  304. package/dist/types/components/ez-split-panel/interfaces/IPanelSizeInfo.d.ts +9 -0
  305. package/dist/types/components/ez-split-panel/structure/item/ez-split-item.d.ts +4 -0
  306. package/dist/types/components/ez-text-area/ez-text-area.d.ts +17 -0
  307. package/dist/types/components/ez-text-input/ez-text-input.d.ts +28 -2
  308. package/dist/types/components/ez-time-input/ez-time-input.d.ts +8 -0
  309. package/dist/types/components/ez-tooltip/ez-tooltip.d.ts +21 -0
  310. package/dist/types/components.d.ts +448 -25
  311. package/dist/types/utils/FocusResolver.d.ts +5 -0
  312. package/dist/types/utils/ResponsiveInputUtils.d.ts +6 -0
  313. package/dist/types/utils/customEditor/interfaces/ICustomEditor.d.ts +2 -0
  314. package/dist/types/utils/form/DataBinder.d.ts +3 -0
  315. package/dist/types/utils/validators/recordvalidator/IInvalidCells.d.ts +5 -0
  316. package/dist/types/utils/validators/recordvalidator/RecordValidationProcessor.d.ts +1 -1
  317. package/package.json +12 -4
  318. package/react/components.d.ts +2 -0
  319. package/react/components.js +2 -0
  320. package/react/components.js.map +1 -1
  321. package/dist/cjs/RecordValidationProcessor-4c893e04.js +0 -102
  322. package/dist/cjs/ez-card-item_3.cjs.entry.js +0 -183
  323. package/dist/cjs/ez-skeleton.cjs.entry.js +0 -67
  324. package/dist/esm/RecordValidationProcessor-b00b8b77.js +0 -99
  325. package/dist/esm/ez-card-item_3.entry.js +0 -177
  326. package/dist/esm/ez-skeleton.entry.js +0 -63
  327. package/dist/ezui/p-04f24913.js +0 -1
  328. package/dist/ezui/p-11b09aa1.entry.js +0 -1
  329. package/dist/ezui/p-24ca32a3.entry.js +0 -1
  330. package/dist/ezui/p-2af4e2de.entry.js +0 -1
  331. package/dist/ezui/p-31674f8e.entry.js +0 -1
  332. package/dist/ezui/p-33792b2b.entry.js +0 -1
  333. package/dist/ezui/p-33b08253.entry.js +0 -304
  334. package/dist/ezui/p-36180f4d.entry.js +0 -1
  335. package/dist/ezui/p-3f8c33e0.entry.js +0 -1
  336. package/dist/ezui/p-5fefcdc9.entry.js +0 -1
  337. package/dist/ezui/p-6ec40dec.entry.js +0 -1
  338. package/dist/ezui/p-752c4069.entry.js +0 -1
  339. package/dist/ezui/p-81cffa53.entry.js +0 -1
  340. package/dist/ezui/p-81f99ace.entry.js +0 -1
  341. package/dist/ezui/p-868b56f7.entry.js +0 -1
  342. package/dist/ezui/p-8eef0f70.entry.js +0 -1
  343. package/dist/ezui/p-9634631d.entry.js +0 -1
  344. package/dist/ezui/p-9a11e223.entry.js +0 -1
  345. package/dist/ezui/p-9a23d513.entry.js +0 -1
  346. package/dist/ezui/p-9c2e2d68.entry.js +0 -1
  347. package/dist/ezui/p-a35b41e6.entry.js +0 -1
  348. package/dist/ezui/p-acbf0e76.entry.js +0 -1
  349. package/dist/ezui/p-b0e71d23.entry.js +0 -1
  350. package/dist/ezui/p-c3b7a23e.entry.js +0 -1
  351. package/dist/ezui/p-cd1a2e6b.entry.js +0 -1
  352. package/dist/ezui/p-dbeee5aa.entry.js +0 -1
  353. package/dist/ezui/p-de870657.entry.js +0 -1
  354. package/dist/ezui/p-e151e795.entry.js +0 -1
  355. package/dist/ezui/p-ee9315ff.entry.js +0 -1
  356. package/dist/ezui/p-f1c3f85d.entry.js +0 -1
  357. package/dist/ezui/p-f291db18.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": {