@aquera/nile-elements 1.1.3-beta-1.2 → 1.1.3-beta-1.4

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 (761) hide show
  1. package/README.md +9 -0
  2. package/demo/index.html +16 -314
  3. package/demo/nxtgen.css +7 -2
  4. package/dist/{fixture-3bfb4490.cjs.js → fixture-5b79f853.cjs.js} +2 -2
  5. package/dist/{fixture-3bfb4490.cjs.js.map → fixture-5b79f853.cjs.js.map} +1 -1
  6. package/dist/{fixture-ba65262e.esm.js → fixture-90b199c4.esm.js} +2 -2
  7. package/dist/{fixture-8edec91c.esm.js → fixture-9871e8a9.esm.js} +1 -1
  8. package/dist/{fixture-d1470b58.cjs.js → fixture-c1d78368.cjs.js} +2 -2
  9. package/dist/{fixture-d1470b58.cjs.js.map → fixture-c1d78368.cjs.js.map} +1 -1
  10. package/dist/{fixture-985bba12.esm.js → fixture-cf7bfcf5.esm.js} +1 -1
  11. package/dist/{fixture-e3592de4.cjs.js → fixture-dbd66009.cjs.js} +4 -4
  12. package/dist/fixture-dbd66009.cjs.js.map +1 -0
  13. package/dist/index.cjs.js +1 -1
  14. package/dist/index.esm.js +1 -1
  15. package/dist/index.js +698 -1272
  16. package/dist/nile-accordion/nile-accordian.test.cjs.js +1 -1
  17. package/dist/nile-accordion/nile-accordian.test.esm.js +1 -1
  18. package/dist/nile-auto-complete/nile-auto-complete.test.cjs.js +1 -1
  19. package/dist/nile-auto-complete/nile-auto-complete.test.esm.js +1 -1
  20. package/dist/nile-avatar/nile-avatar.test.cjs.js +1 -1
  21. package/dist/nile-avatar/nile-avatar.test.esm.js +1 -1
  22. package/dist/nile-badge/nile-badge.test.cjs.js +1 -1
  23. package/dist/nile-badge/nile-badge.test.esm.js +1 -1
  24. package/dist/nile-button/nile-button.css.cjs.js +1 -1
  25. package/dist/nile-button/nile-button.css.cjs.js.map +1 -1
  26. package/dist/nile-button/nile-button.css.esm.js +66 -12
  27. package/dist/nile-button/nile-button.test.cjs.js +1 -1
  28. package/dist/nile-button/nile-button.test.esm.js +1 -1
  29. package/dist/nile-button-toggle-group/nile-button-toggle-group.test.cjs.js +1 -1
  30. package/dist/nile-button-toggle-group/nile-button-toggle-group.test.esm.js +1 -1
  31. package/dist/nile-calendar/nile-calendar.test.cjs.js +1 -1
  32. package/dist/nile-calendar/nile-calendar.test.esm.js +1 -1
  33. package/dist/nile-card/nile-card.test.cjs.js +1 -1
  34. package/dist/nile-card/nile-card.test.esm.js +1 -1
  35. package/dist/nile-checkbox/nile-checkbox.test.cjs.js +1 -1
  36. package/dist/nile-checkbox/nile-checkbox.test.esm.js +1 -1
  37. package/dist/nile-chip/nile-chip.test.cjs.js +1 -1
  38. package/dist/nile-chip/nile-chip.test.esm.js +1 -1
  39. package/dist/nile-code-editor/backup_nile-code-editor copy.cjs.js +2 -0
  40. package/dist/nile-code-editor/backup_nile-code-editor copy.cjs.js.map +1 -0
  41. package/dist/nile-code-editor/backup_nile-code-editor copy.esm.js +1 -0
  42. package/dist/nile-dialog/nile-dialog.test.cjs.js +1 -1
  43. package/dist/nile-dialog/nile-dialog.test.esm.js +1 -1
  44. package/dist/nile-drawer/nile-drawer.test.cjs.js +1 -1
  45. package/dist/nile-drawer/nile-drawer.test.esm.js +1 -1
  46. package/dist/nile-dropdown/nile-dropdown.test.cjs.js +1 -1
  47. package/dist/nile-dropdown/nile-dropdown.test.esm.js +1 -1
  48. package/dist/nile-empty-state/nile-empty-state.test.cjs.js +1 -1
  49. package/dist/nile-empty-state/nile-empty-state.test.esm.js +1 -1
  50. package/dist/nile-error-message/nile-error-message.test.cjs.js +1 -1
  51. package/dist/nile-error-message/nile-error-message.test.esm.js +1 -1
  52. package/dist/nile-file-preview/nile-file-preview.test.cjs.js +1 -1
  53. package/dist/nile-file-preview/nile-file-preview.test.esm.js +1 -1
  54. package/dist/nile-file-upload/nile-file-upload.test.cjs.js +1 -1
  55. package/dist/nile-file-upload/nile-file-upload.test.esm.js +1 -1
  56. package/dist/nile-filter-chip/nile-filter-chip.test.cjs.js +1 -1
  57. package/dist/nile-filter-chip/nile-filter-chip.test.esm.js +1 -1
  58. package/dist/nile-form-group/nile-form-group.test.cjs.js +1 -1
  59. package/dist/nile-form-group/nile-form-group.test.esm.js +1 -1
  60. package/dist/nile-form-help-text/nile-form-help-text.test.cjs.js +1 -1
  61. package/dist/nile-form-help-text/nile-form-help-text.test.esm.js +1 -1
  62. package/dist/nile-grid/nile-grid.cjs.js +1 -1
  63. package/dist/nile-grid/nile-grid.cjs.js.map +1 -1
  64. package/dist/nile-grid/nile-grid.css.cjs.js +1 -1
  65. package/dist/nile-grid/nile-grid.css.cjs.js.map +1 -1
  66. package/dist/nile-grid/nile-grid.css.esm.js +8 -4
  67. package/dist/nile-grid/nile-grid.esm.js +6 -6
  68. package/dist/nile-grid/nile-grid.types.cjs.js +2 -0
  69. package/dist/nile-grid/nile-grid.types.cjs.js.map +1 -0
  70. package/dist/nile-grid/nile-grid.types.esm.js +1 -0
  71. package/dist/nile-grid/nile-grid.utils.cjs.js +1 -1
  72. package/dist/nile-grid/nile-grid.utils.cjs.js.map +1 -1
  73. package/dist/nile-grid/nile-grid.utils.esm.js +1 -1
  74. package/dist/nile-grid-body/nile-grid-body.cjs.js +1 -1
  75. package/dist/nile-grid-body/nile-grid-body.cjs.js.map +1 -1
  76. package/dist/nile-grid-body/nile-grid-body.css.cjs.js +1 -1
  77. package/dist/nile-grid-body/nile-grid-body.css.cjs.js.map +1 -1
  78. package/dist/nile-grid-body/nile-grid-body.css.esm.js +0 -4
  79. package/dist/nile-grid-body/nile-grid-body.esm.js +3 -3
  80. package/dist/nile-grid-cell-item/nile-grid-cell-item.cjs.js +1 -1
  81. package/dist/nile-grid-cell-item/nile-grid-cell-item.cjs.js.map +1 -1
  82. package/dist/nile-grid-cell-item/nile-grid-cell-item.css.cjs.js +1 -1
  83. package/dist/nile-grid-cell-item/nile-grid-cell-item.css.cjs.js.map +1 -1
  84. package/dist/nile-grid-cell-item/nile-grid-cell-item.css.esm.js +18 -3
  85. package/dist/nile-grid-cell-item/nile-grid-cell-item.esm.js +3 -3
  86. package/dist/nile-grid-head/nile-grid-head.cjs.js +1 -1
  87. package/dist/nile-grid-head/nile-grid-head.cjs.js.map +1 -1
  88. package/dist/nile-grid-head/nile-grid-head.css.cjs.js +1 -1
  89. package/dist/nile-grid-head/nile-grid-head.css.cjs.js.map +1 -1
  90. package/dist/nile-grid-head/nile-grid-head.css.esm.js +1 -1
  91. package/dist/nile-grid-head/nile-grid-head.esm.js +3 -3
  92. package/dist/nile-grid-head-item/nile-grid-head-item.cjs.js +1 -1
  93. package/dist/nile-grid-head-item/nile-grid-head-item.cjs.js.map +1 -1
  94. package/dist/nile-grid-head-item/nile-grid-head-item.css.cjs.js +1 -1
  95. package/dist/nile-grid-head-item/nile-grid-head-item.css.cjs.js.map +1 -1
  96. package/dist/nile-grid-head-item/nile-grid-head-item.css.esm.js +20 -5
  97. package/dist/nile-grid-head-item/nile-grid-head-item.esm.js +4 -3
  98. package/dist/nile-grid-row/nile-grid-row.cjs.js +1 -1
  99. package/dist/nile-grid-row/nile-grid-row.cjs.js.map +1 -1
  100. package/dist/nile-grid-row/nile-grid-row.css.cjs.js +1 -1
  101. package/dist/nile-grid-row/nile-grid-row.css.cjs.js.map +1 -1
  102. package/dist/nile-grid-row/nile-grid-row.css.esm.js +17 -5
  103. package/dist/nile-grid-row/nile-grid-row.esm.js +4 -5
  104. package/dist/nile-hero/nile-hero.test.cjs.js +1 -1
  105. package/dist/nile-hero/nile-hero.test.esm.js +1 -1
  106. package/dist/nile-icon/nile-icon.test.cjs.js +1 -1
  107. package/dist/nile-icon/nile-icon.test.esm.js +1 -1
  108. package/dist/nile-input/nile-input.test.cjs.js +1 -1
  109. package/dist/nile-input/nile-input.test.esm.js +1 -1
  110. package/dist/nile-link/nile-link.test.cjs.js +1 -1
  111. package/dist/nile-link/nile-link.test.esm.js +1 -1
  112. package/dist/nile-loader/nile-loader.test.cjs.js +1 -1
  113. package/dist/nile-loader/nile-loader.test.esm.js +1 -1
  114. package/dist/nile-popover/nile-popover.test.cjs.js +1 -1
  115. package/dist/nile-popover/nile-popover.test.esm.js +1 -1
  116. package/dist/nile-popup/nile-popup.test.cjs.js +1 -1
  117. package/dist/nile-popup/nile-popup.test.esm.js +1 -1
  118. package/dist/nile-progress-bar/nile-progress-bar.test.cjs.js +1 -1
  119. package/dist/nile-progress-bar/nile-progress-bar.test.esm.js +1 -1
  120. package/dist/nile-radio/nile-radio.test.cjs.js +1 -1
  121. package/dist/nile-radio/nile-radio.test.esm.js +1 -1
  122. package/dist/nile-radio-group/nile-radio-group.test.cjs.js +1 -1
  123. package/dist/nile-radio-group/nile-radio-group.test.esm.js +1 -1
  124. package/dist/nile-select/nile-select.test.cjs.js +1 -1
  125. package/dist/nile-select/nile-select.test.esm.js +1 -1
  126. package/dist/nile-sidebar/index.cjs.js.map +1 -1
  127. package/dist/nile-sidebar-menu/nile-sidebar-menu.cjs.js.map +1 -1
  128. package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.cjs.js.map +1 -1
  129. package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.cjs.js.map +1 -1
  130. package/dist/nile-slide-toggle/nile-slide-toggle.test.cjs.js +1 -1
  131. package/dist/nile-slide-toggle/nile-slide-toggle.test.esm.js +1 -1
  132. package/dist/nile-stepper/index.cjs.js +1 -1
  133. package/dist/nile-stepper/index.esm.js +1 -1
  134. package/dist/nile-stepper/nile-stepper.cjs.js +1 -1
  135. package/dist/nile-stepper/nile-stepper.cjs.js.map +1 -1
  136. package/dist/nile-stepper/nile-stepper.esm.js +3 -3
  137. package/dist/nile-stepper-item/nile-stepper-item.cjs.js +1 -1
  138. package/dist/nile-stepper-item/nile-stepper-item.cjs.js.map +1 -1
  139. package/dist/nile-stepper-item/nile-stepper-item.esm.js +2 -2
  140. package/dist/nile-tab-group/nile-tab-group.test.cjs.js +1 -1
  141. package/dist/nile-tab-group/nile-tab-group.test.esm.js +1 -1
  142. package/dist/nile-table-body/index.cjs.js +1 -1
  143. package/dist/nile-table-body/index.esm.js +1 -1
  144. package/dist/nile-table-body/nile-table-body.cjs.js +1 -1
  145. package/dist/nile-table-body/nile-table-body.cjs.js.map +1 -1
  146. package/dist/nile-table-body/nile-table-body.esm.js +3 -3
  147. package/dist/nile-table-header-item/nile-table-header-item.css.cjs.js +1 -1
  148. package/dist/nile-table-header-item/nile-table-header-item.css.cjs.js.map +1 -1
  149. package/dist/nile-table-header-item/nile-table-header-item.css.esm.js +0 -4
  150. package/dist/nile-textarea/nile-textarea.test.cjs.js +1 -1
  151. package/dist/nile-textarea/nile-textarea.test.esm.js +1 -1
  152. package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.cjs.js +1 -1
  153. package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.cjs.js.map +1 -1
  154. package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.esm.js +7 -7
  155. package/dist/nile-virtual-select/nile-virtual-select.cjs.js +1 -1
  156. package/dist/nile-virtual-select/nile-virtual-select.cjs.js.map +1 -1
  157. package/dist/nile-virtual-select/nile-virtual-select.esm.js +1 -1
  158. package/dist/nile-virtual-select/nile-virtual-select.test.cjs.js +1 -1
  159. package/dist/nile-virtual-select/nile-virtual-select.test.esm.js +1 -1
  160. package/dist/nile-virtual-select/temp_nile-virtual-select copy.cjs.js +2 -0
  161. package/dist/nile-virtual-select/temp_nile-virtual-select copy.cjs.js.map +1 -0
  162. package/dist/nile-virtual-select/temp_nile-virtual-select copy.esm.js +231 -0
  163. package/dist/src/index.d.ts +4 -17
  164. package/dist/src/index.js +4 -17
  165. package/dist/src/index.js.map +1 -1
  166. package/dist/src/internal/resizable-helper.d.ts +59 -0
  167. package/dist/src/internal/resizable-helper.js +115 -0
  168. package/dist/src/internal/resizable-helper.js.map +1 -0
  169. package/dist/src/internal/resizable-styles.d.ts +16 -0
  170. package/dist/src/internal/resizable-styles.js +144 -0
  171. package/dist/src/internal/resizable-styles.js.map +1 -0
  172. package/dist/src/internal/virtualizer-error-handler.d.ts +30 -0
  173. package/dist/src/internal/virtualizer-error-handler.js +82 -0
  174. package/dist/src/internal/virtualizer-error-handler.js.map +1 -0
  175. package/dist/src/lib/index.d.ts +7 -0
  176. package/dist/src/lib/index.js +8 -0
  177. package/dist/src/lib/index.js.map +1 -0
  178. package/dist/src/lib/virtualize.d.ts +32 -0
  179. package/dist/src/lib/virtualize.js +105 -0
  180. package/dist/src/lib/virtualize.js.map +1 -0
  181. package/dist/src/lib/virtualize.test.d.ts +7 -0
  182. package/dist/src/lib/virtualize.test.js +57 -0
  183. package/dist/src/lib/virtualize.test.js.map +1 -0
  184. package/dist/src/nile-badge/__snapshots__/nile-badge.test.snap.js +17 -0
  185. package/dist/src/nile-button/nile-button.css.js +66 -12
  186. package/dist/src/nile-button/nile-button.css.js.map +1 -1
  187. package/dist/src/nile-calendar/__snapshots__/nile-calendar.test.snap.js +310 -0
  188. package/dist/src/nile-card/__snapshots__/nile-card.test.snap.js +34 -0
  189. package/dist/src/nile-checkbox/__snapshots__/nile-checkbox.test.snap.js +31 -0
  190. package/dist/src/nile-code-editor/Old_theme copy.d.ts +191 -0
  191. package/dist/src/nile-code-editor/Old_theme copy.js +193 -0
  192. package/dist/src/nile-code-editor/Old_theme copy.js.map +1 -0
  193. package/dist/src/nile-code-editor/backup_nile-code-editor copy.d.ts +0 -0
  194. package/dist/src/nile-code-editor/backup_nile-code-editor copy.js +675 -0
  195. package/dist/src/nile-code-editor/backup_nile-code-editor copy.js.map +1 -0
  196. package/dist/src/nile-code-editor/theme copy.d.ts +191 -0
  197. package/dist/src/nile-code-editor/theme copy.js +193 -0
  198. package/dist/src/nile-code-editor/theme copy.js.map +1 -0
  199. package/dist/src/nile-grid/data-processor.d.ts +37 -0
  200. package/dist/src/nile-grid/data-processor.js +122 -0
  201. package/dist/src/nile-grid/data-processor.js.map +1 -0
  202. package/dist/src/nile-grid/event-handlers.d.ts +35 -0
  203. package/dist/src/nile-grid/event-handlers.js +158 -0
  204. package/dist/src/nile-grid/event-handlers.js.map +1 -0
  205. package/dist/src/nile-grid/nile-grid.css.js +6 -2
  206. package/dist/src/nile-grid/nile-grid.css.js.map +1 -1
  207. package/dist/src/nile-grid/nile-grid.d.ts +9 -3
  208. package/dist/src/nile-grid/nile-grid.js +96 -20
  209. package/dist/src/nile-grid/nile-grid.js.map +1 -1
  210. package/dist/src/nile-grid/nile-grid.types.d.ts +3 -0
  211. package/dist/src/nile-grid/nile-grid.types.js +2 -0
  212. package/dist/src/nile-grid/nile-grid.types.js.map +1 -0
  213. package/dist/src/nile-grid/nile-grid.utils.d.ts +3 -2
  214. package/dist/src/nile-grid/nile-grid.utils.js +223 -81
  215. package/dist/src/nile-grid/nile-grid.utils.js.map +1 -1
  216. package/dist/src/nile-grid/renderer.d.ts +8 -0
  217. package/dist/src/nile-grid/renderer.js +78 -0
  218. package/dist/src/nile-grid/renderer.js.map +1 -0
  219. package/dist/src/nile-grid/resize-handler.d.ts +4 -0
  220. package/dist/src/nile-grid/resize-handler.js +36 -0
  221. package/dist/src/nile-grid/resize-handler.js.map +1 -0
  222. package/dist/src/nile-grid/types.d.ts +32 -0
  223. package/dist/src/nile-grid/types.js +2 -0
  224. package/dist/src/nile-grid/types.js.map +1 -0
  225. package/dist/src/nile-grid/utils.d.ts +4 -0
  226. package/dist/src/nile-grid/utils.js +32 -0
  227. package/dist/src/nile-grid/utils.js.map +1 -0
  228. package/dist/src/nile-grid-body/nile-grid-body.css.js +0 -4
  229. package/dist/src/nile-grid-body/nile-grid-body.css.js.map +1 -1
  230. package/dist/src/nile-grid-body/nile-grid-body.js +1 -1
  231. package/dist/src/nile-grid-body/nile-grid-body.js.map +1 -1
  232. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.js +17 -2
  233. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.js.map +1 -1
  234. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.d.ts +0 -3
  235. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.js +1 -11
  236. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.js.map +1 -1
  237. package/dist/src/nile-grid-head/nile-grid-head.css.js +1 -1
  238. package/dist/src/nile-grid-head/nile-grid-head.css.js.map +1 -1
  239. package/dist/src/nile-grid-head/nile-grid-head.js +1 -1
  240. package/dist/src/nile-grid-head/nile-grid-head.js.map +1 -1
  241. package/dist/src/nile-grid-head-item/nile-grid-head-item.css.js +18 -3
  242. package/dist/src/nile-grid-head-item/nile-grid-head-item.css.js.map +1 -1
  243. package/dist/src/nile-grid-head-item/nile-grid-head-item.d.ts +3 -2
  244. package/dist/src/nile-grid-head-item/nile-grid-head-item.js +14 -11
  245. package/dist/src/nile-grid-head-item/nile-grid-head-item.js.map +1 -1
  246. package/dist/src/nile-grid-row/nile-grid-row.css.js +17 -5
  247. package/dist/src/nile-grid-row/nile-grid-row.css.js.map +1 -1
  248. package/dist/src/nile-grid-row/nile-grid-row.d.ts +4 -1
  249. package/dist/src/nile-grid-row/nile-grid-row.js +19 -4
  250. package/dist/src/nile-grid-row/nile-grid-row.js.map +1 -1
  251. package/dist/src/nile-hero/__snapshots__/nile-hero.test.snap.js +47 -0
  252. package/dist/src/nile-icon/__snapshots__/nile-icon.test.snap.js +16 -0
  253. package/dist/src/nile-input/__snapshots__/nile-input.test.snap.js +75 -0
  254. package/dist/src/nile-popover/__snapshots__/nile-popover.test.snap.js +22 -0
  255. package/dist/src/nile-sidebar/index.d.ts +1 -1
  256. package/dist/src/nile-stepper/nile-stepper.d.ts +1 -0
  257. package/dist/src/nile-stepper/nile-stepper.js +61 -40
  258. package/dist/src/nile-stepper/nile-stepper.js.map +1 -1
  259. package/dist/src/nile-stepper-item/nile-stepper-item.d.ts +3 -0
  260. package/dist/src/nile-stepper-item/nile-stepper-item.js +14 -2
  261. package/dist/src/nile-stepper-item/nile-stepper-item.js.map +1 -1
  262. package/dist/src/nile-table-body/nile-table-body.js +2 -1
  263. package/dist/src/nile-table-body/nile-table-body.js.map +1 -1
  264. package/dist/src/nile-table-body/virtual-scroll-helper.d.ts +9 -0
  265. package/dist/src/nile-table-body/virtual-scroll-helper.js +24 -0
  266. package/dist/src/nile-table-body/virtual-scroll-helper.js.map +1 -0
  267. package/dist/src/nile-table-header-item/nile-table-header-item.css.js +0 -4
  268. package/dist/src/nile-table-header-item/nile-table-header-item.css.js.map +1 -1
  269. package/dist/src/nile-vertical-stepper-item/nile-vertical-stepper-item.d.ts +3 -0
  270. package/dist/src/nile-vertical-stepper-item/nile-vertical-stepper-item.js +14 -2
  271. package/dist/src/nile-vertical-stepper-item/nile-vertical-stepper-item.js.map +1 -1
  272. package/dist/src/nile-virtual-select/nile-virtual-select.d.ts +1 -0
  273. package/dist/src/nile-virtual-select/nile-virtual-select.js +18 -13
  274. package/dist/src/nile-virtual-select/nile-virtual-select.js.map +1 -1
  275. package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.d.ts +273 -0
  276. package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.js +1305 -0
  277. package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.js.map +1 -0
  278. package/dist/src/nile-virtual-select/virtualizer-error-handler.d.ts +21 -0
  279. package/dist/src/nile-virtual-select/virtualizer-error-handler.js +56 -0
  280. package/dist/src/nile-virtual-select/virtualizer-error-handler.js.map +1 -0
  281. package/dist/src/nile-virtual-table-body/index.d.ts +2 -0
  282. package/dist/src/nile-virtual-table-body/index.js +3 -0
  283. package/dist/src/nile-virtual-table-body/index.js.map +1 -0
  284. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.d.ts +1 -0
  285. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.js +44 -0
  286. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.js.map +1 -0
  287. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.d.ts +50 -0
  288. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.js +135 -0
  289. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.js.map +1 -0
  290. package/dist/src/nile-virtual-table-body/renderer.d.ts +16 -0
  291. package/dist/src/nile-virtual-table-body/renderer.js +49 -0
  292. package/dist/src/nile-virtual-table-body/renderer.js.map +1 -0
  293. package/dist/src/utilities/stepper-utils.d.ts +71 -0
  294. package/dist/src/utilities/stepper-utils.js +108 -0
  295. package/dist/src/utilities/stepper-utils.js.map +1 -0
  296. package/dist/src/version.js +2 -2
  297. package/dist/src/version.js.map +1 -1
  298. package/dist/tsconfig.tsbuildinfo +1 -1
  299. package/package.json +3 -20
  300. package/src/index.ts +4 -18
  301. package/src/nile-button/nile-button.css.ts +66 -12
  302. package/src/nile-grid/nile-grid.css.ts +6 -2
  303. package/src/nile-grid/nile-grid.ts +124 -21
  304. package/src/nile-grid/nile-grid.types.ts +1 -0
  305. package/src/nile-grid/nile-grid.utils.ts +353 -98
  306. package/src/nile-grid-body/nile-grid-body.css.ts +0 -4
  307. package/src/nile-grid-body/nile-grid-body.ts +2 -2
  308. package/src/nile-grid-cell-item/nile-grid-cell-item.css.ts +17 -2
  309. package/src/nile-grid-cell-item/nile-grid-cell-item.ts +3 -11
  310. package/src/nile-grid-head/nile-grid-head.css.ts +1 -1
  311. package/src/nile-grid-head/nile-grid-head.ts +2 -2
  312. package/src/nile-grid-head-item/nile-grid-head-item.css.ts +18 -3
  313. package/src/nile-grid-head-item/nile-grid-head-item.ts +8 -16
  314. package/src/nile-grid-row/nile-grid-row.css.ts +17 -5
  315. package/src/nile-grid-row/nile-grid-row.ts +9 -6
  316. package/src/nile-sidebar/index.ts +133 -0
  317. package/src/nile-sidebar/logo.svg +1 -0
  318. package/src/nile-sidebar-menu/index.ts +1 -0
  319. package/src/nile-sidebar-menu/nile-sidebar-menu.css.ts +52 -0
  320. package/src/nile-sidebar-menu/nile-sidebar-menu.ts +97 -0
  321. package/src/nile-sidebar-menu-items/index.ts +1 -0
  322. package/src/nile-sidebar-menu-items/nile-sidebar-menu-items.css.ts +50 -0
  323. package/src/nile-sidebar-menu-items/nile-sidebar-menu-items.ts +81 -0
  324. package/src/nile-sidebar-wrapper/index.ts +1 -0
  325. package/src/nile-sidebar-wrapper/nile-sidebar-wrapper.css.ts +119 -0
  326. package/src/nile-sidebar-wrapper/nile-sidebar-wrapper.ts +97 -0
  327. package/src/nile-stepper/nile-stepper.ts +56 -39
  328. package/src/nile-stepper/stepper-utils.ts +49 -0
  329. package/src/nile-stepper-item/nile-stepper-item.ts +6 -3
  330. package/src/nile-table-body/nile-table-body.ts +2 -1
  331. package/src/nile-table-header-item/nile-table-header-item.css.ts +0 -4
  332. package/src/nile-vertical-stepper-item/nile-vertical-stepper-item.ts +6 -3
  333. package/src/nile-virtual-select/nile-virtual-select.ts +8 -2
  334. package/vscode-html-custom-data.json +89 -382
  335. package/dist/axe.min-140df6c2.cjs.js +0 -2
  336. package/dist/axe.min-140df6c2.cjs.js.map +0 -1
  337. package/dist/axe.min-591c52c3.esm.js +0 -1
  338. package/dist/css-tag-3c4464f5.esm.js +0 -6
  339. package/dist/css-tag-b6258454.cjs.js +0 -6
  340. package/dist/css-tag-b6258454.cjs.js.map +0 -1
  341. package/dist/fixture-e3592de4.cjs.js.map +0 -1
  342. package/dist/flow-3e83b6f4.esm.js +0 -17
  343. package/dist/flow-ca47f938.cjs.js +0 -14
  344. package/dist/flow-ca47f938.cjs.js.map +0 -1
  345. package/dist/lit-html-21bc9a48.cjs.js +0 -6
  346. package/dist/lit-html-21bc9a48.cjs.js.map +0 -1
  347. package/dist/lit-html-82603fd0.esm.js +0 -6
  348. package/dist/nile-icon/icons/svg/ng-link-external-02.cjs.js +0 -2
  349. package/dist/nile-icon/icons/svg/ng-link-external-02.cjs.js.map +0 -1
  350. package/dist/nile-icon/icons/svg/ng-link-external-02.esm.js +0 -1
  351. package/dist/nile-side-bar/index.cjs.js +0 -2
  352. package/dist/nile-side-bar/index.cjs.js.map +0 -1
  353. package/dist/nile-side-bar/index.esm.js +0 -1
  354. package/dist/nile-side-bar/nile-side-bar.cjs.js +0 -2
  355. package/dist/nile-side-bar/nile-side-bar.cjs.js.map +0 -1
  356. package/dist/nile-side-bar/nile-side-bar.css.cjs.js +0 -2
  357. package/dist/nile-side-bar/nile-side-bar.css.cjs.js.map +0 -1
  358. package/dist/nile-side-bar/nile-side-bar.css.esm.js +0 -100
  359. package/dist/nile-side-bar/nile-side-bar.esm.js +0 -1
  360. package/dist/nile-side-bar-action/index.cjs.js +0 -2
  361. package/dist/nile-side-bar-action/index.cjs.js.map +0 -1
  362. package/dist/nile-side-bar-action/index.esm.js +0 -1
  363. package/dist/nile-side-bar-action/nile-side-bar-action.cjs.js +0 -2
  364. package/dist/nile-side-bar-action/nile-side-bar-action.cjs.js.map +0 -1
  365. package/dist/nile-side-bar-action/nile-side-bar-action.css.cjs.js +0 -2
  366. package/dist/nile-side-bar-action/nile-side-bar-action.css.cjs.js.map +0 -1
  367. package/dist/nile-side-bar-action/nile-side-bar-action.css.esm.js +0 -51
  368. package/dist/nile-side-bar-action/nile-side-bar-action.esm.js +0 -34
  369. package/dist/nile-side-bar-action-menu/index.cjs.js +0 -2
  370. package/dist/nile-side-bar-action-menu/index.cjs.js.map +0 -1
  371. package/dist/nile-side-bar-action-menu/index.esm.js +0 -1
  372. package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.cjs.js +0 -2
  373. package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.cjs.js.map +0 -1
  374. package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.css.cjs.js +0 -2
  375. package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.css.cjs.js.map +0 -1
  376. package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.css.esm.js +0 -61
  377. package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.esm.js +0 -40
  378. package/dist/nile-side-bar-action-menu-item/index.cjs.js +0 -2
  379. package/dist/nile-side-bar-action-menu-item/index.cjs.js.map +0 -1
  380. package/dist/nile-side-bar-action-menu-item/index.esm.js +0 -1
  381. package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.cjs.js +0 -2
  382. package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.cjs.js.map +0 -1
  383. package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.css.cjs.js +0 -2
  384. package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.css.cjs.js.map +0 -1
  385. package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.css.esm.js +0 -128
  386. package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.esm.js +0 -36
  387. package/dist/nile-side-bar-content/index.cjs.js +0 -2
  388. package/dist/nile-side-bar-content/index.cjs.js.map +0 -1
  389. package/dist/nile-side-bar-content/index.esm.js +0 -1
  390. package/dist/nile-side-bar-content/nile-side-bar-content.cjs.js +0 -2
  391. package/dist/nile-side-bar-content/nile-side-bar-content.cjs.js.map +0 -1
  392. package/dist/nile-side-bar-content/nile-side-bar-content.css.cjs.js +0 -2
  393. package/dist/nile-side-bar-content/nile-side-bar-content.css.cjs.js.map +0 -1
  394. package/dist/nile-side-bar-content/nile-side-bar-content.css.esm.js +0 -5
  395. package/dist/nile-side-bar-content/nile-side-bar-content.esm.js +0 -3
  396. package/dist/nile-side-bar-expand/index.cjs.js +0 -2
  397. package/dist/nile-side-bar-expand/index.cjs.js.map +0 -1
  398. package/dist/nile-side-bar-expand/index.esm.js +0 -1
  399. package/dist/nile-side-bar-expand/nile-side-bar-expand.cjs.js +0 -2
  400. package/dist/nile-side-bar-expand/nile-side-bar-expand.cjs.js.map +0 -1
  401. package/dist/nile-side-bar-expand/nile-side-bar-expand.css.cjs.js +0 -2
  402. package/dist/nile-side-bar-expand/nile-side-bar-expand.css.cjs.js.map +0 -1
  403. package/dist/nile-side-bar-expand/nile-side-bar-expand.css.esm.js +0 -33
  404. package/dist/nile-side-bar-expand/nile-side-bar-expand.esm.js +0 -6
  405. package/dist/nile-side-bar-footer/index.cjs.js +0 -2
  406. package/dist/nile-side-bar-footer/index.cjs.js.map +0 -1
  407. package/dist/nile-side-bar-footer/index.esm.js +0 -1
  408. package/dist/nile-side-bar-footer/nile-side-bar-footer.cjs.js +0 -2
  409. package/dist/nile-side-bar-footer/nile-side-bar-footer.cjs.js.map +0 -1
  410. package/dist/nile-side-bar-footer/nile-side-bar-footer.css.cjs.js +0 -2
  411. package/dist/nile-side-bar-footer/nile-side-bar-footer.css.cjs.js.map +0 -1
  412. package/dist/nile-side-bar-footer/nile-side-bar-footer.css.esm.js +0 -40
  413. package/dist/nile-side-bar-footer/nile-side-bar-footer.esm.js +0 -5
  414. package/dist/nile-side-bar-footer-icon/index.cjs.js +0 -2
  415. package/dist/nile-side-bar-footer-icon/index.cjs.js.map +0 -1
  416. package/dist/nile-side-bar-footer-icon/index.esm.js +0 -1
  417. package/dist/nile-side-bar-footer-icon/nile-side-bar-footer-icon.cjs.js +0 -2
  418. package/dist/nile-side-bar-footer-icon/nile-side-bar-footer-icon.cjs.js.map +0 -1
  419. package/dist/nile-side-bar-footer-icon/nile-side-bar-footer-icon.css.cjs.js +0 -2
  420. package/dist/nile-side-bar-footer-icon/nile-side-bar-footer-icon.css.cjs.js.map +0 -1
  421. package/dist/nile-side-bar-footer-icon/nile-side-bar-footer-icon.css.esm.js +0 -5
  422. package/dist/nile-side-bar-footer-icon/nile-side-bar-footer-icon.esm.js +0 -3
  423. package/dist/nile-side-bar-footer-item/index.cjs.js +0 -2
  424. package/dist/nile-side-bar-footer-item/index.cjs.js.map +0 -1
  425. package/dist/nile-side-bar-footer-item/index.esm.js +0 -1
  426. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.cjs.js +0 -2
  427. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.cjs.js.map +0 -1
  428. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.css.cjs.js +0 -2
  429. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.css.cjs.js.map +0 -1
  430. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.css.esm.js +0 -72
  431. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.esm.js +0 -7
  432. package/dist/nile-side-bar-footer-text/index.cjs.js +0 -2
  433. package/dist/nile-side-bar-footer-text/index.cjs.js.map +0 -1
  434. package/dist/nile-side-bar-footer-text/index.esm.js +0 -1
  435. package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.cjs.js +0 -2
  436. package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.cjs.js.map +0 -1
  437. package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.css.cjs.js +0 -2
  438. package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.css.cjs.js.map +0 -1
  439. package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.css.esm.js +0 -29
  440. package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.esm.js +0 -6
  441. package/dist/nile-side-bar-group/index.cjs.js +0 -2
  442. package/dist/nile-side-bar-group/index.cjs.js.map +0 -1
  443. package/dist/nile-side-bar-group/index.esm.js +0 -1
  444. package/dist/nile-side-bar-group/nile-side-bar-group.cjs.js +0 -2
  445. package/dist/nile-side-bar-group/nile-side-bar-group.cjs.js.map +0 -1
  446. package/dist/nile-side-bar-group/nile-side-bar-group.css.cjs.js +0 -2
  447. package/dist/nile-side-bar-group/nile-side-bar-group.css.cjs.js.map +0 -1
  448. package/dist/nile-side-bar-group/nile-side-bar-group.css.esm.js +0 -48
  449. package/dist/nile-side-bar-group/nile-side-bar-group.esm.js +0 -12
  450. package/dist/nile-side-bar-group-item/index.cjs.js +0 -2
  451. package/dist/nile-side-bar-group-item/index.cjs.js.map +0 -1
  452. package/dist/nile-side-bar-group-item/index.esm.js +0 -1
  453. package/dist/nile-side-bar-group-item/nile-side-bar-group-item.cjs.js +0 -2
  454. package/dist/nile-side-bar-group-item/nile-side-bar-group-item.cjs.js.map +0 -1
  455. package/dist/nile-side-bar-group-item/nile-side-bar-group-item.css.cjs.js +0 -2
  456. package/dist/nile-side-bar-group-item/nile-side-bar-group-item.css.cjs.js.map +0 -1
  457. package/dist/nile-side-bar-group-item/nile-side-bar-group-item.css.esm.js +0 -54
  458. package/dist/nile-side-bar-group-item/nile-side-bar-group-item.esm.js +0 -37
  459. package/dist/nile-side-bar-group-item-content/index.cjs.js +0 -2
  460. package/dist/nile-side-bar-group-item-content/index.cjs.js.map +0 -1
  461. package/dist/nile-side-bar-group-item-content/index.esm.js +0 -1
  462. package/dist/nile-side-bar-group-item-content/nile-side-bar-group-item-content.cjs.js +0 -2
  463. package/dist/nile-side-bar-group-item-content/nile-side-bar-group-item-content.cjs.js.map +0 -1
  464. package/dist/nile-side-bar-group-item-content/nile-side-bar-group-item-content.css.cjs.js +0 -2
  465. package/dist/nile-side-bar-group-item-content/nile-side-bar-group-item-content.css.cjs.js.map +0 -1
  466. package/dist/nile-side-bar-group-item-content/nile-side-bar-group-item-content.css.esm.js +0 -5
  467. package/dist/nile-side-bar-group-item-content/nile-side-bar-group-item-content.esm.js +0 -3
  468. package/dist/nile-side-bar-group-item-icon/index.cjs.js +0 -2
  469. package/dist/nile-side-bar-group-item-icon/index.cjs.js.map +0 -1
  470. package/dist/nile-side-bar-group-item-icon/index.esm.js +0 -1
  471. package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.cjs.js +0 -2
  472. package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.cjs.js.map +0 -1
  473. package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.css.cjs.js +0 -2
  474. package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.css.cjs.js.map +0 -1
  475. package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.css.esm.js +0 -31
  476. package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.esm.js +0 -11
  477. package/dist/nile-side-bar-group-item-text/index.cjs.js +0 -2
  478. package/dist/nile-side-bar-group-item-text/index.cjs.js.map +0 -1
  479. package/dist/nile-side-bar-group-item-text/index.esm.js +0 -1
  480. package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.cjs.js +0 -2
  481. package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.cjs.js.map +0 -1
  482. package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.cjs.js +0 -2
  483. package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.cjs.js.map +0 -1
  484. package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.esm.js +0 -24
  485. package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.esm.js +0 -1
  486. package/dist/nile-side-bar-header/index.cjs.js +0 -2
  487. package/dist/nile-side-bar-header/index.cjs.js.map +0 -1
  488. package/dist/nile-side-bar-header/index.esm.js +0 -1
  489. package/dist/nile-side-bar-header/nile-side-bar-header.cjs.js +0 -2
  490. package/dist/nile-side-bar-header/nile-side-bar-header.cjs.js.map +0 -1
  491. package/dist/nile-side-bar-header/nile-side-bar-header.css.cjs.js +0 -2
  492. package/dist/nile-side-bar-header/nile-side-bar-header.css.cjs.js.map +0 -1
  493. package/dist/nile-side-bar-header/nile-side-bar-header.css.esm.js +0 -52
  494. package/dist/nile-side-bar-header/nile-side-bar-header.esm.js +0 -6
  495. package/dist/nile-side-bar-logo/index.cjs.js +0 -2
  496. package/dist/nile-side-bar-logo/index.cjs.js.map +0 -1
  497. package/dist/nile-side-bar-logo/index.esm.js +0 -1
  498. package/dist/nile-side-bar-logo/nile-side-bar-logo.cjs.js +0 -2
  499. package/dist/nile-side-bar-logo/nile-side-bar-logo.cjs.js.map +0 -1
  500. package/dist/nile-side-bar-logo/nile-side-bar-logo.css.cjs.js +0 -2
  501. package/dist/nile-side-bar-logo/nile-side-bar-logo.css.cjs.js.map +0 -1
  502. package/dist/nile-side-bar-logo/nile-side-bar-logo.css.esm.js +0 -35
  503. package/dist/nile-side-bar-logo/nile-side-bar-logo.esm.js +0 -4
  504. package/dist/scopedElementsWrapper-abad3c53.cjs.js +0 -2
  505. package/dist/scopedElementsWrapper-abad3c53.cjs.js.map +0 -1
  506. package/dist/scopedElementsWrapper-ef11f868.esm.js +0 -1
  507. package/dist/sinon-esm-283dcc9b.cjs.js +0 -2
  508. package/dist/sinon-esm-283dcc9b.cjs.js.map +0 -1
  509. package/dist/sinon-esm-abe9b0ec.esm.js +0 -1
  510. package/dist/src/nile-icon/icons/svg/ng-link-external-02.d.ts +0 -5
  511. package/dist/src/nile-icon/icons/svg/ng-link-external-02.js +0 -5
  512. package/dist/src/nile-icon/icons/svg/ng-link-external-02.js.map +0 -1
  513. package/dist/src/nile-side-bar/index.d.ts +0 -1
  514. package/dist/src/nile-side-bar/index.js +0 -2
  515. package/dist/src/nile-side-bar/index.js.map +0 -1
  516. package/dist/src/nile-side-bar/nile-side-bar.css.d.ts +0 -12
  517. package/dist/src/nile-side-bar/nile-side-bar.css.js +0 -112
  518. package/dist/src/nile-side-bar/nile-side-bar.css.js.map +0 -1
  519. package/dist/src/nile-side-bar/nile-side-bar.d.ts +0 -40
  520. package/dist/src/nile-side-bar/nile-side-bar.js +0 -67
  521. package/dist/src/nile-side-bar/nile-side-bar.js.map +0 -1
  522. package/dist/src/nile-side-bar-action/index.d.ts +0 -1
  523. package/dist/src/nile-side-bar-action/index.js +0 -2
  524. package/dist/src/nile-side-bar-action/index.js.map +0 -1
  525. package/dist/src/nile-side-bar-action/nile-side-bar-action.css.d.ts +0 -3
  526. package/dist/src/nile-side-bar-action/nile-side-bar-action.css.js +0 -54
  527. package/dist/src/nile-side-bar-action/nile-side-bar-action.css.js.map +0 -1
  528. package/dist/src/nile-side-bar-action/nile-side-bar-action.d.ts +0 -75
  529. package/dist/src/nile-side-bar-action/nile-side-bar-action.js +0 -338
  530. package/dist/src/nile-side-bar-action/nile-side-bar-action.js.map +0 -1
  531. package/dist/src/nile-side-bar-action-menu/index.d.ts +0 -1
  532. package/dist/src/nile-side-bar-action-menu/index.js +0 -2
  533. package/dist/src/nile-side-bar-action-menu/index.js.map +0 -1
  534. package/dist/src/nile-side-bar-action-menu/nile-side-bar-action-menu.css.d.ts +0 -12
  535. package/dist/src/nile-side-bar-action-menu/nile-side-bar-action-menu.css.js +0 -73
  536. package/dist/src/nile-side-bar-action-menu/nile-side-bar-action-menu.css.js.map +0 -1
  537. package/dist/src/nile-side-bar-action-menu/nile-side-bar-action-menu.d.ts +0 -49
  538. package/dist/src/nile-side-bar-action-menu/nile-side-bar-action-menu.js +0 -223
  539. package/dist/src/nile-side-bar-action-menu/nile-side-bar-action-menu.js.map +0 -1
  540. package/dist/src/nile-side-bar-action-menu-item/index.d.ts +0 -1
  541. package/dist/src/nile-side-bar-action-menu-item/index.js +0 -2
  542. package/dist/src/nile-side-bar-action-menu-item/index.js.map +0 -1
  543. package/dist/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.css.d.ts +0 -12
  544. package/dist/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.css.js +0 -140
  545. package/dist/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.css.js.map +0 -1
  546. package/dist/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.d.ts +0 -64
  547. package/dist/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.js +0 -198
  548. package/dist/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.js.map +0 -1
  549. package/dist/src/nile-side-bar-content/index.d.ts +0 -1
  550. package/dist/src/nile-side-bar-content/index.js +0 -2
  551. package/dist/src/nile-side-bar-content/index.js.map +0 -1
  552. package/dist/src/nile-side-bar-content/nile-side-bar-content.css.d.ts +0 -12
  553. package/dist/src/nile-side-bar-content/nile-side-bar-content.css.js +0 -17
  554. package/dist/src/nile-side-bar-content/nile-side-bar-content.css.js.map +0 -1
  555. package/dist/src/nile-side-bar-content/nile-side-bar-content.d.ts +0 -32
  556. package/dist/src/nile-side-bar-content/nile-side-bar-content.js +0 -43
  557. package/dist/src/nile-side-bar-content/nile-side-bar-content.js.map +0 -1
  558. package/dist/src/nile-side-bar-expand/index.d.ts +0 -1
  559. package/dist/src/nile-side-bar-expand/index.js +0 -2
  560. package/dist/src/nile-side-bar-expand/index.js.map +0 -1
  561. package/dist/src/nile-side-bar-expand/nile-side-bar-expand.css.d.ts +0 -12
  562. package/dist/src/nile-side-bar-expand/nile-side-bar-expand.css.js +0 -45
  563. package/dist/src/nile-side-bar-expand/nile-side-bar-expand.css.js.map +0 -1
  564. package/dist/src/nile-side-bar-expand/nile-side-bar-expand.d.ts +0 -21
  565. package/dist/src/nile-side-bar-expand/nile-side-bar-expand.js +0 -55
  566. package/dist/src/nile-side-bar-expand/nile-side-bar-expand.js.map +0 -1
  567. package/dist/src/nile-side-bar-footer/index.d.ts +0 -1
  568. package/dist/src/nile-side-bar-footer/index.js +0 -2
  569. package/dist/src/nile-side-bar-footer/index.js.map +0 -1
  570. package/dist/src/nile-side-bar-footer/nile-side-bar-footer.css.d.ts +0 -6
  571. package/dist/src/nile-side-bar-footer/nile-side-bar-footer.css.js +0 -46
  572. package/dist/src/nile-side-bar-footer/nile-side-bar-footer.css.js.map +0 -1
  573. package/dist/src/nile-side-bar-footer/nile-side-bar-footer.d.ts +0 -26
  574. package/dist/src/nile-side-bar-footer/nile-side-bar-footer.js +0 -37
  575. package/dist/src/nile-side-bar-footer/nile-side-bar-footer.js.map +0 -1
  576. package/dist/src/nile-side-bar-footer-icon/index.d.ts +0 -1
  577. package/dist/src/nile-side-bar-footer-icon/index.js +0 -2
  578. package/dist/src/nile-side-bar-footer-icon/index.js.map +0 -1
  579. package/dist/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.css.d.ts +0 -12
  580. package/dist/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.css.js +0 -17
  581. package/dist/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.css.js.map +0 -1
  582. package/dist/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.d.ts +0 -32
  583. package/dist/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.js +0 -43
  584. package/dist/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.js.map +0 -1
  585. package/dist/src/nile-side-bar-footer-item/index.d.ts +0 -1
  586. package/dist/src/nile-side-bar-footer-item/index.js +0 -2
  587. package/dist/src/nile-side-bar-footer-item/index.js.map +0 -1
  588. package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.css.d.ts +0 -3
  589. package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.css.js +0 -75
  590. package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.css.js.map +0 -1
  591. package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.d.ts +0 -27
  592. package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.js +0 -46
  593. package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.js.map +0 -1
  594. package/dist/src/nile-side-bar-footer-text/index.d.ts +0 -1
  595. package/dist/src/nile-side-bar-footer-text/index.js +0 -2
  596. package/dist/src/nile-side-bar-footer-text/index.js.map +0 -1
  597. package/dist/src/nile-side-bar-footer-text/nile-side-bar-footer-text.css.d.ts +0 -3
  598. package/dist/src/nile-side-bar-footer-text/nile-side-bar-footer-text.css.js +0 -32
  599. package/dist/src/nile-side-bar-footer-text/nile-side-bar-footer-text.css.js.map +0 -1
  600. package/dist/src/nile-side-bar-footer-text/nile-side-bar-footer-text.d.ts +0 -30
  601. package/dist/src/nile-side-bar-footer-text/nile-side-bar-footer-text.js +0 -53
  602. package/dist/src/nile-side-bar-footer-text/nile-side-bar-footer-text.js.map +0 -1
  603. package/dist/src/nile-side-bar-group/index.d.ts +0 -1
  604. package/dist/src/nile-side-bar-group/index.js +0 -2
  605. package/dist/src/nile-side-bar-group/index.js.map +0 -1
  606. package/dist/src/nile-side-bar-group/nile-side-bar-group.css.d.ts +0 -6
  607. package/dist/src/nile-side-bar-group/nile-side-bar-group.css.js +0 -54
  608. package/dist/src/nile-side-bar-group/nile-side-bar-group.css.js.map +0 -1
  609. package/dist/src/nile-side-bar-group/nile-side-bar-group.d.ts +0 -42
  610. package/dist/src/nile-side-bar-group/nile-side-bar-group.js +0 -76
  611. package/dist/src/nile-side-bar-group/nile-side-bar-group.js.map +0 -1
  612. package/dist/src/nile-side-bar-group-item/index.d.ts +0 -1
  613. package/dist/src/nile-side-bar-group-item/index.js +0 -2
  614. package/dist/src/nile-side-bar-group-item/index.js.map +0 -1
  615. package/dist/src/nile-side-bar-group-item/nile-side-bar-group-item.css.d.ts +0 -12
  616. package/dist/src/nile-side-bar-group-item/nile-side-bar-group-item.css.js +0 -66
  617. package/dist/src/nile-side-bar-group-item/nile-side-bar-group-item.css.js.map +0 -1
  618. package/dist/src/nile-side-bar-group-item/nile-side-bar-group-item.d.ts +0 -54
  619. package/dist/src/nile-side-bar-group-item/nile-side-bar-group-item.js +0 -143
  620. package/dist/src/nile-side-bar-group-item/nile-side-bar-group-item.js.map +0 -1
  621. package/dist/src/nile-side-bar-group-item-content/index.d.ts +0 -1
  622. package/dist/src/nile-side-bar-group-item-content/index.js +0 -2
  623. package/dist/src/nile-side-bar-group-item-content/index.js.map +0 -1
  624. package/dist/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.css.d.ts +0 -12
  625. package/dist/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.css.js +0 -17
  626. package/dist/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.css.js.map +0 -1
  627. package/dist/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.d.ts +0 -32
  628. package/dist/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.js +0 -43
  629. package/dist/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.js.map +0 -1
  630. package/dist/src/nile-side-bar-group-item-icon/index.d.ts +0 -1
  631. package/dist/src/nile-side-bar-group-item-icon/index.js +0 -2
  632. package/dist/src/nile-side-bar-group-item-icon/index.js.map +0 -1
  633. package/dist/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.css.d.ts +0 -3
  634. package/dist/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.css.js +0 -34
  635. package/dist/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.css.js.map +0 -1
  636. package/dist/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.d.ts +0 -40
  637. package/dist/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.js +0 -89
  638. package/dist/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.js.map +0 -1
  639. package/dist/src/nile-side-bar-group-item-text/index.d.ts +0 -1
  640. package/dist/src/nile-side-bar-group-item-text/index.js +0 -2
  641. package/dist/src/nile-side-bar-group-item-text/index.js.map +0 -1
  642. package/dist/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.d.ts +0 -6
  643. package/dist/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.js +0 -30
  644. package/dist/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.js.map +0 -1
  645. package/dist/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.d.ts +0 -30
  646. package/dist/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.js +0 -42
  647. package/dist/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.js.map +0 -1
  648. package/dist/src/nile-side-bar-header/index.d.ts +0 -1
  649. package/dist/src/nile-side-bar-header/index.js +0 -2
  650. package/dist/src/nile-side-bar-header/index.js.map +0 -1
  651. package/dist/src/nile-side-bar-header/nile-side-bar-header.css.d.ts +0 -12
  652. package/dist/src/nile-side-bar-header/nile-side-bar-header.css.js +0 -64
  653. package/dist/src/nile-side-bar-header/nile-side-bar-header.css.js.map +0 -1
  654. package/dist/src/nile-side-bar-header/nile-side-bar-header.d.ts +0 -32
  655. package/dist/src/nile-side-bar-header/nile-side-bar-header.js +0 -46
  656. package/dist/src/nile-side-bar-header/nile-side-bar-header.js.map +0 -1
  657. package/dist/src/nile-side-bar-logo/index.d.ts +0 -1
  658. package/dist/src/nile-side-bar-logo/index.js +0 -2
  659. package/dist/src/nile-side-bar-logo/index.js.map +0 -1
  660. package/dist/src/nile-side-bar-logo/nile-side-bar-logo.css.d.ts +0 -12
  661. package/dist/src/nile-side-bar-logo/nile-side-bar-logo.css.js +0 -47
  662. package/dist/src/nile-side-bar-logo/nile-side-bar-logo.css.js.map +0 -1
  663. package/dist/src/nile-side-bar-logo/nile-side-bar-logo.d.ts +0 -34
  664. package/dist/src/nile-side-bar-logo/nile-side-bar-logo.js +0 -53
  665. package/dist/src/nile-side-bar-logo/nile-side-bar-logo.js.map +0 -1
  666. package/dist/src/nile-side-bar-menu/index.d.ts +0 -1
  667. package/dist/src/nile-side-bar-menu/index.js +0 -2
  668. package/dist/src/nile-side-bar-menu/index.js.map +0 -1
  669. package/dist/src/nile-side-bar-menu/nile-side-bar-menu.css.d.ts +0 -12
  670. package/dist/src/nile-side-bar-menu/nile-side-bar-menu.css.js +0 -17
  671. package/dist/src/nile-side-bar-menu/nile-side-bar-menu.css.js.map +0 -1
  672. package/dist/src/nile-side-bar-menu/nile-side-bar-menu.d.ts +0 -32
  673. package/dist/src/nile-side-bar-menu/nile-side-bar-menu.js +0 -43
  674. package/dist/src/nile-side-bar-menu/nile-side-bar-menu.js.map +0 -1
  675. package/dist/src/nile-side-bar-menu-item/index.d.ts +0 -1
  676. package/dist/src/nile-side-bar-menu-item/index.js +0 -2
  677. package/dist/src/nile-side-bar-menu-item/index.js.map +0 -1
  678. package/dist/src/nile-side-bar-menu-item/nile-side-bar-menu-item.css.d.ts +0 -12
  679. package/dist/src/nile-side-bar-menu-item/nile-side-bar-menu-item.css.js +0 -17
  680. package/dist/src/nile-side-bar-menu-item/nile-side-bar-menu-item.css.js.map +0 -1
  681. package/dist/src/nile-side-bar-menu-item/nile-side-bar-menu-item.d.ts +0 -32
  682. package/dist/src/nile-side-bar-menu-item/nile-side-bar-menu-item.js +0 -43
  683. package/dist/src/nile-side-bar-menu-item/nile-side-bar-menu-item.js.map +0 -1
  684. package/dist/src/nile-table-row-content/index.d.ts +0 -1
  685. package/dist/src/nile-table-row-content/index.js +0 -2
  686. package/dist/src/nile-table-row-content/index.js.map +0 -1
  687. package/dist/src/nile-table-row-content/nile-table-row-content.css.d.ts +0 -12
  688. package/dist/src/nile-table-row-content/nile-table-row-content.css.js +0 -30
  689. package/dist/src/nile-table-row-content/nile-table-row-content.css.js.map +0 -1
  690. package/dist/src/nile-table-row-content/nile-table-row-content.d.ts +0 -32
  691. package/dist/src/nile-table-row-content/nile-table-row-content.js +0 -46
  692. package/dist/src/nile-table-row-content/nile-table-row-content.js.map +0 -1
  693. package/dist/src/nile-test/index.d.ts +0 -1
  694. package/dist/src/nile-test/index.js +0 -2
  695. package/dist/src/nile-test/index.js.map +0 -1
  696. package/dist/src/nile-test/nile-test.css.d.ts +0 -12
  697. package/dist/src/nile-test/nile-test.css.js +0 -17
  698. package/dist/src/nile-test/nile-test.css.js.map +0 -1
  699. package/dist/src/nile-test/nile-test.d.ts +0 -32
  700. package/dist/src/nile-test/nile-test.js +0 -43
  701. package/dist/src/nile-test/nile-test.js.map +0 -1
  702. package/dist/src/nile-tooltip/nile-tooltip-utils.d.ts +0 -18
  703. package/dist/src/nile-tooltip/nile-tooltip-utils.js +0 -216
  704. package/dist/src/nile-tooltip/nile-tooltip-utils.js.map +0 -1
  705. package/dist/src/nile-tooltip/nile-tooltip.test.d.ts +0 -1
  706. package/dist/src/nile-tooltip/nile-tooltip.test.js +0 -148
  707. package/dist/src/nile-tooltip/nile-tooltip.test.js.map +0 -1
  708. package/dist/virtualize-73f68d08.esm.js +0 -22
  709. package/dist/virtualize-eb33a9a0.cjs.js +0 -18
  710. package/dist/virtualize-eb33a9a0.cjs.js.map +0 -1
  711. package/src/nile-side-bar/index.ts +0 -1
  712. package/src/nile-side-bar/nile-side-bar.css.ts +0 -114
  713. package/src/nile-side-bar/nile-side-bar.ts +0 -66
  714. package/src/nile-side-bar-action/index.ts +0 -1
  715. package/src/nile-side-bar-action/nile-side-bar-action.css.ts +0 -55
  716. package/src/nile-side-bar-action/nile-side-bar-action.ts +0 -367
  717. package/src/nile-side-bar-action-menu/index.ts +0 -1
  718. package/src/nile-side-bar-action-menu/nile-side-bar-action-menu.css.ts +0 -75
  719. package/src/nile-side-bar-action-menu/nile-side-bar-action-menu.ts +0 -239
  720. package/src/nile-side-bar-action-menu-item/index.ts +0 -1
  721. package/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.css.ts +0 -142
  722. package/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.ts +0 -203
  723. package/src/nile-side-bar-content/index.ts +0 -1
  724. package/src/nile-side-bar-content/nile-side-bar-content.css.ts +0 -19
  725. package/src/nile-side-bar-content/nile-side-bar-content.ts +0 -54
  726. package/src/nile-side-bar-expand/index.ts +0 -1
  727. package/src/nile-side-bar-expand/nile-side-bar-expand.css.ts +0 -47
  728. package/src/nile-side-bar-expand/nile-side-bar-expand.ts +0 -55
  729. package/src/nile-side-bar-footer/index.ts +0 -1
  730. package/src/nile-side-bar-footer/nile-side-bar-footer.css.ts +0 -47
  731. package/src/nile-side-bar-footer/nile-side-bar-footer.ts +0 -42
  732. package/src/nile-side-bar-footer-icon/index.ts +0 -1
  733. package/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.css.ts +0 -19
  734. package/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.ts +0 -54
  735. package/src/nile-side-bar-footer-item/index.ts +0 -1
  736. package/src/nile-side-bar-footer-item/nile-side-bar-footer-item.css.ts +0 -76
  737. package/src/nile-side-bar-footer-item/nile-side-bar-footer-item.ts +0 -45
  738. package/src/nile-side-bar-footer-text/index.ts +0 -1
  739. package/src/nile-side-bar-footer-text/nile-side-bar-footer-text.css.ts +0 -33
  740. package/src/nile-side-bar-footer-text/nile-side-bar-footer-text.ts +0 -51
  741. package/src/nile-side-bar-group/index.ts +0 -1
  742. package/src/nile-side-bar-group/nile-side-bar-group.css.ts +0 -55
  743. package/src/nile-side-bar-group/nile-side-bar-group.ts +0 -74
  744. package/src/nile-side-bar-group-item/index.ts +0 -1
  745. package/src/nile-side-bar-group-item/nile-side-bar-group-item.css.ts +0 -68
  746. package/src/nile-side-bar-group-item/nile-side-bar-group-item.ts +0 -146
  747. package/src/nile-side-bar-group-item-content/index.ts +0 -1
  748. package/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.css.ts +0 -19
  749. package/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.ts +0 -54
  750. package/src/nile-side-bar-group-item-icon/index.ts +0 -1
  751. package/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.css.ts +0 -35
  752. package/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.ts +0 -97
  753. package/src/nile-side-bar-group-item-text/index.ts +0 -1
  754. package/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.ts +0 -31
  755. package/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.ts +0 -49
  756. package/src/nile-side-bar-header/index.ts +0 -1
  757. package/src/nile-side-bar-header/nile-side-bar-header.css.ts +0 -66
  758. package/src/nile-side-bar-header/nile-side-bar-header.ts +0 -57
  759. package/src/nile-side-bar-logo/index.ts +0 -1
  760. package/src/nile-side-bar-logo/nile-side-bar-logo.css.ts +0 -49
  761. package/src/nile-side-bar-logo/nile-side-bar-logo.ts +0 -52
@@ -0,0 +1,122 @@
1
+ /**
2
+ * Copyright Aquera Inc 2023
3
+ *
4
+ * This source code is licensed under the BSD-3-Clause license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+ export class GridDataProcessor {
8
+ constructor(options, pageSize = 20) {
9
+ this.options = options;
10
+ this.pageSize = pageSize;
11
+ this.currentPage = 1;
12
+ this.sortField = '';
13
+ this.sortDirection = 'asc';
14
+ this.filterText = '';
15
+ }
16
+ setOptions(options) {
17
+ this.options = options;
18
+ }
19
+ setPageSize(pageSize) {
20
+ this.pageSize = pageSize;
21
+ }
22
+ setCurrentPage(page) {
23
+ this.currentPage = page;
24
+ }
25
+ setSortField(field) {
26
+ this.sortField = field;
27
+ }
28
+ setSortDirection(direction) {
29
+ this.sortDirection = direction;
30
+ }
31
+ setFilterText(text) {
32
+ this.filterText = text;
33
+ }
34
+ processData(data, columns) {
35
+ // Apply filtering
36
+ const filteredData = this.applyFilters(data, columns);
37
+ // Apply sorting
38
+ const sortedData = this.applySorting(filteredData, columns);
39
+ // Apply pagination
40
+ const totalPages = Math.ceil(sortedData.length / this.pageSize);
41
+ const paginatedData = this.applyPagination(sortedData);
42
+ return {
43
+ filteredData,
44
+ sortedData,
45
+ paginatedData,
46
+ totalPages
47
+ };
48
+ }
49
+ applyFilters(data, columns) {
50
+ if (!this.filterText || !this.options.enableFiltering) {
51
+ return data;
52
+ }
53
+ return data.filter(row => {
54
+ return columns.some(column => {
55
+ const value = row[column.field];
56
+ if (value == null)
57
+ return false;
58
+ return String(value).toLowerCase().includes(this.filterText.toLowerCase());
59
+ });
60
+ });
61
+ }
62
+ applySorting(data, columns) {
63
+ if (!this.sortField || !this.options.enableSorting) {
64
+ return data;
65
+ }
66
+ const column = columns.find(col => col.field === this.sortField);
67
+ if (!column)
68
+ return data;
69
+ return [...data].sort((a, b) => {
70
+ const aVal = a[column.field];
71
+ const bVal = b[column.field];
72
+ if (aVal == null && bVal == null)
73
+ return 0;
74
+ if (aVal == null)
75
+ return 1;
76
+ if (bVal == null)
77
+ return -1;
78
+ if (typeof aVal === 'string' && typeof bVal === 'string') {
79
+ return this.sortDirection === 'asc'
80
+ ? aVal.localeCompare(bVal)
81
+ : bVal.localeCompare(aVal);
82
+ }
83
+ if (typeof aVal === 'number' && typeof bVal === 'number') {
84
+ return this.sortDirection === 'asc' ? aVal - bVal : bVal - aVal;
85
+ }
86
+ return 0;
87
+ });
88
+ }
89
+ applyPagination(data) {
90
+ if (!this.options.enablePagination) {
91
+ return data;
92
+ }
93
+ const startIndex = (this.currentPage - 1) * this.pageSize;
94
+ const endIndex = startIndex + this.pageSize;
95
+ return data.slice(startIndex, endIndex);
96
+ }
97
+ getSortClass(column) {
98
+ if (this.sortField !== column.field)
99
+ return '';
100
+ return this.sortDirection === 'asc' ? 'sort-asc' : 'sort-desc';
101
+ }
102
+ getSortIcon(column) {
103
+ if (this.sortField !== column.field)
104
+ return '↕';
105
+ return this.sortDirection === 'asc' ? '↑' : '↓';
106
+ }
107
+ isAllSelected(paginatedData) {
108
+ return paginatedData.length > 0 && paginatedData.every(row => row.selected);
109
+ }
110
+ isPartiallySelected(paginatedData) {
111
+ const selectedCount = paginatedData.filter(row => row.selected).length;
112
+ return selectedCount > 0 && selectedCount < paginatedData.length;
113
+ }
114
+ // Getters for event handlers
115
+ getSortField() {
116
+ return this.sortField;
117
+ }
118
+ getSortDirection() {
119
+ return this.sortDirection;
120
+ }
121
+ }
122
+ //# sourceMappingURL=data-processor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-processor.js","sourceRoot":"","sources":["../../../src/nile-grid/data-processor.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright Aquera Inc 2023\n *\n * This source code is licensed under the BSD-3-Clause license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport type { GridColumnDef, GridRowData, GridOptions } from './types.js';\n\nexport class GridDataProcessor {\n private options: GridOptions;\n private pageSize: number;\n private currentPage: number;\n private sortField: string;\n private sortDirection: 'asc' | 'desc';\n private filterText: string;\n\n constructor(options: GridOptions, pageSize: number = 20) {\n this.options = options;\n this.pageSize = pageSize;\n this.currentPage = 1;\n this.sortField = '';\n this.sortDirection = 'asc';\n this.filterText = '';\n }\n\n setOptions(options: GridOptions): void {\n this.options = options;\n }\n\n setPageSize(pageSize: number): void {\n this.pageSize = pageSize;\n }\n\n setCurrentPage(page: number): void {\n this.currentPage = page;\n }\n\n setSortField(field: string): void {\n this.sortField = field;\n }\n\n setSortDirection(direction: 'asc' | 'desc'): void {\n this.sortDirection = direction;\n }\n\n setFilterText(text: string): void {\n this.filterText = text;\n }\n\n processData(data: GridRowData[], columns: GridColumnDef[]): {\n filteredData: GridRowData[];\n sortedData: GridRowData[];\n paginatedData: GridRowData[];\n totalPages: number;\n } {\n // Apply filtering\n const filteredData = this.applyFilters(data, columns);\n \n // Apply sorting\n const sortedData = this.applySorting(filteredData, columns);\n \n // Apply pagination\n const totalPages = Math.ceil(sortedData.length / this.pageSize);\n const paginatedData = this.applyPagination(sortedData);\n\n return {\n filteredData,\n sortedData,\n paginatedData,\n totalPages\n };\n }\n\n private applyFilters(data: GridRowData[], columns: GridColumnDef[]): GridRowData[] {\n if (!this.filterText || !this.options.enableFiltering) {\n return data;\n }\n\n return data.filter(row => {\n return columns.some(column => {\n const value = row[column.field];\n if (value == null) return false;\n return String(value).toLowerCase().includes(this.filterText.toLowerCase());\n });\n });\n }\n\n private applySorting(data: GridRowData[], columns: GridColumnDef[]): GridRowData[] {\n if (!this.sortField || !this.options.enableSorting) {\n return data;\n }\n\n const column = columns.find(col => col.field === this.sortField);\n if (!column) return data;\n\n return [...data].sort((a, b) => {\n const aVal = a[column.field];\n const bVal = b[column.field];\n \n if (aVal == null && bVal == null) return 0;\n if (aVal == null) return 1;\n if (bVal == null) return -1;\n\n if (typeof aVal === 'string' && typeof bVal === 'string') {\n return this.sortDirection === 'asc' \n ? aVal.localeCompare(bVal)\n : bVal.localeCompare(aVal);\n }\n\n if (typeof aVal === 'number' && typeof bVal === 'number') {\n return this.sortDirection === 'asc' ? aVal - bVal : bVal - aVal;\n }\n\n return 0;\n });\n }\n\n private applyPagination(data: GridRowData[]): GridRowData[] {\n if (!this.options.enablePagination) {\n return data;\n }\n\n const startIndex = (this.currentPage - 1) * this.pageSize;\n const endIndex = startIndex + this.pageSize;\n return data.slice(startIndex, endIndex);\n }\n\n getSortClass(column: GridColumnDef): string {\n if (this.sortField !== column.field) return '';\n return this.sortDirection === 'asc' ? 'sort-asc' : 'sort-desc';\n }\n\n getSortIcon(column: GridColumnDef): string {\n if (this.sortField !== column.field) return '↕';\n return this.sortDirection === 'asc' ? '↑' : '↓';\n }\n\n isAllSelected(paginatedData: GridRowData[]): boolean {\n return paginatedData.length > 0 && paginatedData.every(row => row.selected);\n }\n\n isPartiallySelected(paginatedData: GridRowData[]): boolean {\n const selectedCount = paginatedData.filter(row => row.selected).length;\n return selectedCount > 0 && selectedCount < paginatedData.length;\n }\n\n // Getters for event handlers\n getSortField(): string {\n return this.sortField;\n }\n\n getSortDirection(): 'asc' | 'desc' {\n return this.sortDirection;\n }\n}\n"]}
@@ -0,0 +1,35 @@
1
+ /**
2
+ * Copyright Aquera Inc 2023
3
+ *
4
+ * This source code is licensed under the BSD-3-Clause license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+ import type { GridColumnDef, GridRowData, GridOptions } from './types.js';
8
+ import type { GridDataProcessor } from './data-processor.js';
9
+ export declare class GridEventHandlers {
10
+ private options;
11
+ private dataProcessor;
12
+ private selectedRows;
13
+ private isResizing;
14
+ private resizingColumn;
15
+ private dragStartX;
16
+ private dragStartWidth;
17
+ constructor(options: GridOptions, dataProcessor: GridDataProcessor);
18
+ setOptions(options: GridOptions): void;
19
+ handleKeyDown(event: KeyboardEvent): void;
20
+ handleWheel(event: WheelEvent, updateVirtualScrolling: () => void): void;
21
+ handleColumnSort(column: GridColumnDef, onSort: (field: string, direction: 'asc' | 'desc') => void): void;
22
+ handleColumnFilter(column: GridColumnDef, value: string, onFilter: () => void): void;
23
+ handleRowSelection(row: GridRowData, event: Event, currentData: GridRowData[], onSelectionChange: () => void): void;
24
+ handleHeaderSelectionChange(event: Event, currentData: GridRowData[], onSelectionChange: () => void): void;
25
+ handleRowClick(row: GridRowData, event: Event): void;
26
+ handleCellEdit(row: GridRowData, column: GridColumnDef, value: any, onCellEdit: (row: GridRowData, column: GridColumnDef, oldValue: any, newValue: any) => void): void;
27
+ handleColumnResizeStart(column: GridColumnDef, event: MouseEvent): void;
28
+ private handleColumnResizeMove;
29
+ private handleColumnResizeEnd;
30
+ private handleArrowKeyNavigation;
31
+ private emit;
32
+ getSelectedRows(): GridRowData[];
33
+ isResizingColumn(): boolean;
34
+ getResizingColumn(): GridColumnDef | null;
35
+ }
@@ -0,0 +1,158 @@
1
+ /**
2
+ * Copyright Aquera Inc 2023
3
+ *
4
+ * This source code is licensed under the BSD-3-Clause license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+ export class GridEventHandlers {
8
+ constructor(options, dataProcessor) {
9
+ this.selectedRows = [];
10
+ this.isResizing = false;
11
+ this.resizingColumn = null;
12
+ this.dragStartX = 0;
13
+ this.dragStartWidth = 0;
14
+ this.options = options;
15
+ this.dataProcessor = dataProcessor;
16
+ }
17
+ setOptions(options) {
18
+ this.options = options;
19
+ this.dataProcessor.setOptions(options);
20
+ }
21
+ handleKeyDown(event) {
22
+ if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {
23
+ event.preventDefault();
24
+ this.handleArrowKeyNavigation(event.key);
25
+ }
26
+ }
27
+ handleWheel(event, updateVirtualScrolling) {
28
+ if (this.options.enableVirtualScrolling) {
29
+ updateVirtualScrolling();
30
+ }
31
+ }
32
+ handleColumnSort(column, onSort) {
33
+ if (!this.options.enableSorting)
34
+ return;
35
+ const currentField = this.dataProcessor.getSortField();
36
+ const currentDirection = this.dataProcessor.getSortDirection();
37
+ let newDirection;
38
+ if (currentField === column.field) {
39
+ newDirection = currentDirection === 'asc' ? 'desc' : 'asc';
40
+ }
41
+ else {
42
+ newDirection = 'asc';
43
+ }
44
+ this.dataProcessor.setSortField(column.field);
45
+ this.dataProcessor.setSortDirection(newDirection);
46
+ onSort(column.field, newDirection);
47
+ }
48
+ handleColumnFilter(column, value, onFilter) {
49
+ if (!this.options.enableFiltering)
50
+ return;
51
+ column.filterValue = value;
52
+ this.dataProcessor.setFilterText(value);
53
+ this.dataProcessor.setCurrentPage(1);
54
+ onFilter();
55
+ }
56
+ handleRowSelection(row, event, currentData, onSelectionChange) {
57
+ if (!this.options.enableRowSelection)
58
+ return;
59
+ const checkbox = event.target;
60
+ if (this.options.enableMultiRowSelection) {
61
+ if (checkbox.checked) {
62
+ if (!this.selectedRows.find(r => r.id === row.id)) {
63
+ this.selectedRows.push(row);
64
+ row.selected = true;
65
+ }
66
+ }
67
+ else {
68
+ const index = this.selectedRows.findIndex(r => r.id === row.id);
69
+ if (index > -1) {
70
+ this.selectedRows.splice(index, 1);
71
+ row.selected = false;
72
+ }
73
+ }
74
+ }
75
+ else {
76
+ this.selectedRows = checkbox.checked ? [row] : [];
77
+ // Update all rows selection state
78
+ currentData.forEach(r => {
79
+ r.selected = r.id === row.id ? checkbox.checked : false;
80
+ });
81
+ }
82
+ onSelectionChange();
83
+ }
84
+ handleHeaderSelectionChange(event, currentData, onSelectionChange) {
85
+ if (!this.options.enableRowSelection)
86
+ return;
87
+ const checkbox = event.target;
88
+ const isChecked = checkbox.checked;
89
+ currentData.forEach(row => {
90
+ row.selected = isChecked;
91
+ });
92
+ if (isChecked) {
93
+ this.selectedRows = [...currentData];
94
+ }
95
+ else {
96
+ this.selectedRows = [];
97
+ }
98
+ onSelectionChange();
99
+ }
100
+ handleRowClick(row, event) {
101
+ if (this.options.suppressRowClickSelection)
102
+ return;
103
+ const target = event.target;
104
+ if (target.tagName === 'INPUT' || target.closest('.checkbox-cell'))
105
+ return;
106
+ // Emit row click event
107
+ this.emit('nile-grid-row-click', { row, event });
108
+ }
109
+ handleCellEdit(row, column, value, onCellEdit) {
110
+ if (!column.editable)
111
+ return;
112
+ const oldValue = row[column.field];
113
+ row[column.field] = value;
114
+ onCellEdit(row, column, oldValue, value);
115
+ }
116
+ handleColumnResizeStart(column, event) {
117
+ if (!this.options.enableColumnResize)
118
+ return;
119
+ this.isResizing = true;
120
+ this.resizingColumn = column;
121
+ this.dragStartX = event.clientX;
122
+ this.dragStartWidth = column.width || 150;
123
+ document.addEventListener('mousemove', this.handleColumnResizeMove.bind(this));
124
+ document.addEventListener('mouseup', this.handleColumnResizeEnd.bind(this));
125
+ }
126
+ handleColumnResizeMove(event) {
127
+ if (!this.isResizing || !this.resizingColumn)
128
+ return;
129
+ const deltaX = event.clientX - this.dragStartX;
130
+ const newWidth = Math.max(this.resizingColumn.minWidth || 50, Math.min(this.resizingColumn.maxWidth || 500, this.dragStartWidth + deltaX));
131
+ this.resizingColumn.width = newWidth;
132
+ }
133
+ handleColumnResizeEnd() {
134
+ this.isResizing = false;
135
+ this.resizingColumn = null;
136
+ document.removeEventListener('mousemove', this.handleColumnResizeMove.bind(this));
137
+ document.removeEventListener('mouseup', this.handleColumnResizeEnd.bind(this));
138
+ }
139
+ handleArrowKeyNavigation(key) {
140
+ // Emit keyboard navigation event
141
+ this.emit('nile-grid-key-navigation', { key });
142
+ }
143
+ emit(eventName, detail) {
144
+ // This will be implemented by the main component
145
+ // The main component will listen to these events and emit them
146
+ }
147
+ // Getters
148
+ getSelectedRows() {
149
+ return this.selectedRows;
150
+ }
151
+ isResizingColumn() {
152
+ return this.isResizing;
153
+ }
154
+ getResizingColumn() {
155
+ return this.resizingColumn;
156
+ }
157
+ }
158
+ //# sourceMappingURL=event-handlers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"event-handlers.js","sourceRoot":"","sources":["../../../src/nile-grid/event-handlers.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright Aquera Inc 2023\n *\n * This source code is licensed under the BSD-3-Clause license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport type { GridColumnDef, GridRowData, GridOptions } from './types.js';\nimport type { GridDataProcessor } from './data-processor.js';\n\nexport class GridEventHandlers {\n private options: GridOptions;\n private dataProcessor: GridDataProcessor;\n private selectedRows: GridRowData[] = [];\n private isResizing: boolean = false;\n private resizingColumn: GridColumnDef | null = null;\n private dragStartX: number = 0;\n private dragStartWidth: number = 0;\n\n constructor(options: GridOptions, dataProcessor: GridDataProcessor) {\n this.options = options;\n this.dataProcessor = dataProcessor;\n }\n\n setOptions(options: GridOptions): void {\n this.options = options;\n this.dataProcessor.setOptions(options);\n }\n\n handleKeyDown(event: KeyboardEvent): void {\n if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n event.preventDefault();\n this.handleArrowKeyNavigation(event.key);\n }\n }\n\n handleWheel(event: WheelEvent, updateVirtualScrolling: () => void): void {\n if (this.options.enableVirtualScrolling) {\n updateVirtualScrolling();\n }\n }\n\n handleColumnSort(column: GridColumnDef, onSort: (field: string, direction: 'asc' | 'desc') => void): void {\n if (!this.options.enableSorting) return;\n\n const currentField = this.dataProcessor.getSortField();\n const currentDirection = this.dataProcessor.getSortDirection();\n\n let newDirection: 'asc' | 'desc';\n if (currentField === column.field) {\n newDirection = currentDirection === 'asc' ? 'desc' : 'asc';\n } else {\n newDirection = 'asc';\n }\n\n this.dataProcessor.setSortField(column.field);\n this.dataProcessor.setSortDirection(newDirection);\n \n onSort(column.field, newDirection);\n }\n\n handleColumnFilter(column: GridColumnDef, value: string, onFilter: () => void): void {\n if (!this.options.enableFiltering) return;\n\n column.filterValue = value;\n this.dataProcessor.setFilterText(value);\n this.dataProcessor.setCurrentPage(1);\n \n onFilter();\n }\n\n handleRowSelection(row: GridRowData, event: Event, currentData: GridRowData[], onSelectionChange: () => void): void {\n if (!this.options.enableRowSelection) return;\n\n const checkbox = event.target as HTMLInputElement;\n \n if (this.options.enableMultiRowSelection) {\n if (checkbox.checked) {\n if (!this.selectedRows.find(r => r.id === row.id)) {\n this.selectedRows.push(row);\n row.selected = true;\n }\n } else {\n const index = this.selectedRows.findIndex(r => r.id === row.id);\n if (index > -1) {\n this.selectedRows.splice(index, 1);\n row.selected = false;\n }\n }\n } else {\n this.selectedRows = checkbox.checked ? [row] : [];\n // Update all rows selection state\n currentData.forEach(r => {\n r.selected = r.id === row.id ? checkbox.checked : false;\n });\n }\n\n onSelectionChange();\n }\n\n handleHeaderSelectionChange(event: Event, currentData: GridRowData[], onSelectionChange: () => void): void {\n if (!this.options.enableRowSelection) return;\n\n const checkbox = event.target as HTMLInputElement;\n const isChecked = checkbox.checked;\n \n currentData.forEach(row => {\n row.selected = isChecked;\n });\n\n if (isChecked) {\n this.selectedRows = [...currentData];\n } else {\n this.selectedRows = [];\n }\n\n onSelectionChange();\n }\n\n handleRowClick(row: GridRowData, event: Event): void {\n if (this.options.suppressRowClickSelection) return;\n\n const target = event.target as HTMLElement;\n if (target.tagName === 'INPUT' || target.closest('.checkbox-cell')) return;\n\n // Emit row click event\n this.emit('nile-grid-row-click', { row, event });\n }\n\n handleCellEdit(row: GridRowData, column: GridColumnDef, value: any, onCellEdit: (row: GridRowData, column: GridColumnDef, oldValue: any, newValue: any) => void): void {\n if (!column.editable) return;\n\n const oldValue = row[column.field];\n row[column.field] = value;\n\n onCellEdit(row, column, oldValue, value);\n }\n\n handleColumnResizeStart(column: GridColumnDef, event: MouseEvent): void {\n if (!this.options.enableColumnResize) return;\n\n this.isResizing = true;\n this.resizingColumn = column;\n this.dragStartX = event.clientX;\n this.dragStartWidth = column.width || 150;\n\n document.addEventListener('mousemove', this.handleColumnResizeMove.bind(this));\n document.addEventListener('mouseup', this.handleColumnResizeEnd.bind(this));\n }\n\n private handleColumnResizeMove(event: MouseEvent): void {\n if (!this.isResizing || !this.resizingColumn) return;\n\n const deltaX = event.clientX - this.dragStartX;\n const newWidth = Math.max(\n this.resizingColumn.minWidth || 50,\n Math.min(this.resizingColumn.maxWidth || 500, this.dragStartWidth + deltaX)\n );\n\n this.resizingColumn.width = newWidth;\n }\n\n private handleColumnResizeEnd(): void {\n this.isResizing = false;\n this.resizingColumn = null;\n \n document.removeEventListener('mousemove', this.handleColumnResizeMove.bind(this));\n document.removeEventListener('mouseup', this.handleColumnResizeEnd.bind(this));\n }\n\n private handleArrowKeyNavigation(key: string): void {\n // Emit keyboard navigation event\n this.emit('nile-grid-key-navigation', { key });\n }\n\n private emit(eventName: string, detail: any): void {\n // This will be implemented by the main component\n // The main component will listen to these events and emit them\n }\n\n // Getters\n getSelectedRows(): GridRowData[] {\n return this.selectedRows;\n }\n\n isResizingColumn(): boolean {\n return this.isResizing;\n }\n\n getResizingColumn(): GridColumnDef | null {\n return this.resizingColumn;\n }\n}\n"]}
@@ -7,6 +7,7 @@
7
7
  import { css } from 'lit';
8
8
  export const styles = css `
9
9
  :host {
10
+ --min-width: 180px;
10
11
  display: grid;
11
12
  grid-template-rows: auto;
12
13
  overflow: auto;
@@ -17,18 +18,21 @@ export const styles = css `
17
18
  border: 1px solid var(--nile-colors-neutral-400);
18
19
  border-radius: var(--nile-radius-radius-xl);
19
20
  max-height: 100%;
21
+ width: 100%;
22
+ min-width: var(--min-width);
23
+ box-shadow: 0px 1px 3px 0px rgba(16, 24, 40, 0.1),
24
+ 0px 1px 2px 0px rgba(16, 24, 40, 0.06);
20
25
  }
21
26
 
22
27
  ::slotted(nile-grid-head),
23
28
  ::slotted(nile-grid-body) {
24
29
  inline-size: 100%;
25
- display: grid;
26
30
  }
27
31
 
28
32
  .nile-resize-start,
29
33
  .nile-resize-end {
30
34
  position: fixed;
31
- z-index: 2;
35
+ z-index: 4;
32
36
  background-color: var(--nile-colors-neutral-400);
33
37
  width: 2px;
34
38
  height: 100%;
@@ -1 +1 @@
1
- {"version":3,"file":"nile-grid.css.js","sourceRoot":"","sources":["../../../src/nile-grid/nile-grid.css.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA+BxB,CAAC;AAEF,eAAe,CAAC,MAAM,CAAC,CAAC","sourcesContent":["/**\n * Copyright Aquera Inc 2025\n *\n * This source code is licensed under the BSD-3-Clause license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { css } from 'lit';\n\nexport const styles = css`\n :host {\n display: grid;\n grid-template-rows: auto;\n overflow: auto;\n inline-size: 100%;\n position: relative;\n contain: content;\n box-sizing: border-box;\n border: 1px solid var(--nile-colors-neutral-400);\n border-radius: var(--nile-radius-radius-xl);\n max-height: 100%;\n }\n\n ::slotted(nile-grid-head),\n ::slotted(nile-grid-body) {\n inline-size: 100%;\n display: grid;\n }\n\n .nile-resize-start,\n .nile-resize-end {\n position: fixed;\n z-index: 2;\n background-color: var(--nile-colors-neutral-400);\n width: 2px;\n height: 100%;\n top: 0;\n display: none;\n bottom: 0;\n }\n`;\n\nexport default [styles];\n"]}
1
+ {"version":3,"file":"nile-grid.css.js","sourceRoot":"","sources":["../../../src/nile-grid/nile-grid.css.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAmCxB,CAAC;AAEF,eAAe,CAAC,MAAM,CAAC,CAAC","sourcesContent":["/**\n * Copyright Aquera Inc 2025\n *\n * This source code is licensed under the BSD-3-Clause license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { css } from 'lit';\n\nexport const styles = css`\n :host {\n --min-width: 180px;\n display: grid;\n grid-template-rows: auto;\n overflow: auto;\n inline-size: 100%;\n position: relative;\n contain: content;\n box-sizing: border-box;\n border: 1px solid var(--nile-colors-neutral-400);\n border-radius: var(--nile-radius-radius-xl);\n max-height: 100%;\n width: 100%;\n min-width: var(--min-width);\n box-shadow: 0px 1px 3px 0px rgba(16, 24, 40, 0.1),\n 0px 1px 2px 0px rgba(16, 24, 40, 0.06);\n }\n\n ::slotted(nile-grid-head),\n ::slotted(nile-grid-body) {\n inline-size: 100%;\n }\n\n .nile-resize-start,\n .nile-resize-end {\n position: fixed;\n z-index: 4;\n background-color: var(--nile-colors-neutral-400);\n width: 2px;\n height: 100%;\n top: 0;\n display: none;\n bottom: 0;\n }\n`;\n\nexport default [styles];\n"]}
@@ -18,22 +18,28 @@ export declare class NileGrid extends NileElement {
18
18
  * @remarks If you are extending this class you can extend the base styles with super. Eg `return [super(), myCustomStyles]`
19
19
  */
20
20
  static get styles(): CSSResultArray;
21
- /** User can pass custom widths for the columns */
22
- customWidths: number[];
23
21
  /** To set the grid template columns in rebuildTemplate method */
24
22
  colTemplate: string;
25
23
  /** To store the column widths in the beginning and after resizing */
26
- private columnWidths;
24
+ columnWidths: number[];
27
25
  /** To get the slot element */
28
26
  private slotEl;
29
27
  /** To get the first resize line to show the resize handle */
30
28
  resizeStart: HTMLElement;
31
29
  /** To get the last resize line to show the resize handle */
32
30
  resizeEnd: HTMLElement;
31
+ /** To enable horizontal scrolling when user is resizing */
32
+ enableResizeScroll: boolean;
33
33
  /** To store the mutation observer */
34
34
  private mo?;
35
+ /** To store the resize observer */
36
+ private resizeObserver?;
35
37
  /** To store the request animation frame */
36
38
  private raf;
39
+ /** To store the sticky index's */
40
+ stickyLeftIndexes: number[];
41
+ /** To store the sticky index's */
42
+ stickyRightIndexes: number[];
37
43
  private scheduleLayout;
38
44
  private ensureWidths;
39
45
  private onResize;
@@ -9,7 +9,7 @@ import { html } from 'lit';
9
9
  import { customElement, property, query, state } from 'lit/decorators.js';
10
10
  import { styles } from './nile-grid.css';
11
11
  import NileElement from '../internal/nile-element';
12
- import { resizeLinesHandler, listenToEventListeners, removeEventListeners, getHead, getBody, rebuildTemplate, applyTemplate, layout, } from './nile-grid.utils';
12
+ import { resizeLinesHandler, listenToEventListeners, removeEventListeners, getHead, getBody, rebuildTemplate, applyTemplate, layout, applyColumnsTemplate, } from './nile-grid.utils';
13
13
  /**
14
14
  * Nile grid component.
15
15
  *
@@ -19,29 +19,93 @@ import { resizeLinesHandler, listenToEventListeners, removeEventListeners, getHe
19
19
  let NileGrid = class NileGrid extends NileElement {
20
20
  constructor() {
21
21
  super(...arguments);
22
- /** User can pass custom widths for the columns */
23
- this.customWidths = [];
24
22
  /** To set the grid template columns in rebuildTemplate method */
25
23
  this.colTemplate = '';
26
24
  /** To store the column widths in the beginning and after resizing */
27
- this.columnWidths = [...this.customWidths];
25
+ this.columnWidths = [];
26
+ /** To enable horizontal scrolling when user is resizing */
27
+ this.enableResizeScroll = false;
28
28
  /** To store the request animation frame */
29
29
  this.raf = 0;
30
+ /** To store the sticky index's */
31
+ this.stickyLeftIndexes = [];
32
+ /** To store the sticky index's */
33
+ this.stickyRightIndexes = [];
30
34
  this.onResize = (e) => {
31
35
  const { col, widthPx } = e.detail;
32
- let w;
33
36
  const floor = 60;
34
- if (e.target.getAttribute('colspan') &&
35
- parseInt(e.target.getAttribute('colspan')) > 1) {
36
- w = Math.max(floor, Math.round(widthPx - this.columnWidths[col - 1]));
37
+ const tgt = e.target;
38
+ const hasSpan = !!tgt.getAttribute('colspan') &&
39
+ parseInt(tgt.getAttribute('colspan'), 10) > 1;
40
+ const prevW = this.columnWidths[col] ?? floor;
41
+ const newWraw = hasSpan
42
+ ? widthPx - (this.columnWidths[col - 1] ?? 0)
43
+ : widthPx;
44
+ const newW = Math.max(floor, Math.round(Number.isFinite(newWraw) ? newWraw : prevW));
45
+ let delta = newW - prevW;
46
+ if (delta === 0) {
47
+ resizeLinesHandler(this.resizeStart, this.resizeEnd, col, this.scrollHeight, this.columnWidths);
48
+ return;
49
+ }
50
+ const takeFromRight = (start, needInit) => {
51
+ let need = needInit;
52
+ for (let i = start; i < this.columnWidths.length && need > 0; i++) {
53
+ const reducible = Math.max(0, this.columnWidths[i] - floor);
54
+ const cut = Math.min(reducible, need);
55
+ if (cut > 0) {
56
+ this.columnWidths[i] -= cut;
57
+ need -= cut;
58
+ }
59
+ }
60
+ return need;
61
+ };
62
+ const giveToRight = (start, giveInit) => {
63
+ let give = giveInit;
64
+ if (start < this.columnWidths.length && give > 0) {
65
+ this.columnWidths[start] += give;
66
+ give = 0;
67
+ }
68
+ return give;
69
+ };
70
+ if (!this.enableResizeScroll) {
71
+ if (delta > 0) {
72
+ let rightReducible = 0;
73
+ for (let i = col + 1; i < this.columnWidths.length; i++) {
74
+ rightReducible += Math.max(0, this.columnWidths[i] - floor);
75
+ }
76
+ if (rightReducible <= 0) {
77
+ delta = 0;
78
+ }
79
+ else if (delta > rightReducible) {
80
+ delta = rightReducible;
81
+ }
82
+ this.columnWidths[col] = prevW + delta;
83
+ if (delta > 0) {
84
+ takeFromRight(col + 1, delta);
85
+ }
86
+ }
87
+ else {
88
+ if (col === this.columnWidths.length - 1) {
89
+ delta = 0;
90
+ }
91
+ else {
92
+ const shrink = -delta;
93
+ this.columnWidths[col] = Math.max(floor, prevW - shrink);
94
+ const remaining = giveToRight(col + 1, shrink);
95
+ if (remaining > 0) {
96
+ this.columnWidths[col] = prevW;
97
+ delta = 0;
98
+ }
99
+ }
100
+ }
37
101
  }
38
102
  else {
39
- w = Math.max(floor, Math.round(widthPx));
103
+ this.columnWidths[col] = newW;
40
104
  }
41
- this.columnWidths[col] = w;
42
- resizeLinesHandler(this.resizeStart, this.resizeEnd, col, widthPx, this.scrollHeight, this.columnWidths, e);
105
+ resizeLinesHandler(this.resizeStart, this.resizeEnd, col, this.scrollHeight, this.columnWidths);
43
106
  this.colTemplate = rebuildTemplate(this.columnWidths.length, this.columnWidths);
44
107
  applyTemplate(getHead(this.slotEl), getBody(this.slotEl), this.colTemplate);
108
+ applyColumnsTemplate(this, this.columnWidths, this.slotEl);
45
109
  };
46
110
  /* #endregion */
47
111
  }
@@ -57,7 +121,7 @@ let NileGrid = class NileGrid extends NileElement {
57
121
  cancelAnimationFrame(this.raf);
58
122
  this.raf = requestAnimationFrame(() => {
59
123
  this.raf = 0;
60
- layout(this, this.slotEl, this.ensureWidths.bind(this), rebuildTemplate, applyTemplate, this.columnWidths);
124
+ layout(this, this.slotEl, this.ensureWidths.bind(this), rebuildTemplate, applyTemplate, this.stickyLeftIndexes, this.stickyRightIndexes);
61
125
  });
62
126
  }
63
127
  ensureWidths(colCount) {
@@ -74,6 +138,10 @@ let NileGrid = class NileGrid extends NileElement {
74
138
  this.mo = new MutationObserver(() => {
75
139
  this.scheduleLayout();
76
140
  });
141
+ this.resizeObserver?.disconnect();
142
+ this.resizeObserver = new ResizeObserver(() => {
143
+ layout(this, this.slotEl, this.ensureWidths.bind(this), rebuildTemplate, applyTemplate, this.stickyLeftIndexes, this.stickyRightIndexes);
144
+ });
77
145
  const head = getHead(this.slotEl);
78
146
  const body = getBody(this.slotEl);
79
147
  if (!head && !body)
@@ -85,28 +153,27 @@ let NileGrid = class NileGrid extends NileElement {
85
153
  attributes: true,
86
154
  attributeFilter: ['colspan', 'rowspan'],
87
155
  });
88
- layout(this, this.slotEl, this.ensureWidths.bind(this), rebuildTemplate, applyTemplate, this.columnWidths);
156
+ this.resizeObserver?.observe(this);
157
+ layout(this, this.slotEl, this.ensureWidths.bind(this), rebuildTemplate, applyTemplate, this.stickyLeftIndexes, this.stickyRightIndexes);
89
158
  }
90
159
  render() {
91
160
  return html `
92
- <div>
93
- <slot></slot>
94
- <div class="nile-resize-start"></div>
95
- <div class="nile-resize-end"></div>
161
+ <div part="grid-base" class="nile-grid-base">
162
+ <slot part="grid-slot"></slot>
163
+ <div part="resize-start" class="nile-resize-start"></div>
164
+ <div part="resize-end" class="nile-resize-end"></div>
96
165
  </div>
97
166
  `;
98
167
  }
99
168
  disconnectedCallback() {
100
169
  super.disconnectedCallback?.();
101
170
  this.mo?.disconnect();
171
+ this.resizeObserver?.disconnect();
102
172
  if (this.raf)
103
173
  cancelAnimationFrame(this.raf);
104
174
  removeEventListeners(this, this.onResize, this.slotEl, this._attachObserverAndLayout.bind(this));
105
175
  }
106
176
  };
107
- __decorate([
108
- property({ type: Array, attribute: true })
109
- ], NileGrid.prototype, "customWidths", void 0);
110
177
  __decorate([
111
178
  state()
112
179
  ], NileGrid.prototype, "colTemplate", void 0);
@@ -122,6 +189,15 @@ __decorate([
122
189
  __decorate([
123
190
  query('.nile-resize-end')
124
191
  ], NileGrid.prototype, "resizeEnd", void 0);
192
+ __decorate([
193
+ property({ type: Boolean, attribute: true, reflect: true })
194
+ ], NileGrid.prototype, "enableResizeScroll", void 0);
195
+ __decorate([
196
+ state()
197
+ ], NileGrid.prototype, "stickyLeftIndexes", void 0);
198
+ __decorate([
199
+ state()
200
+ ], NileGrid.prototype, "stickyRightIndexes", void 0);
125
201
  NileGrid = __decorate([
126
202
  customElement('nile-grid')
127
203
  ], NileGrid);