@aquera/nile-elements 0.1.74-beta-1.0 → 0.1.75-beta-1.2

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 (192) hide show
  1. package/README.md +3 -0
  2. package/demo/index.html +117 -22
  3. package/dist/{fixture-3bfb4490.cjs.js → fixture-5b79f853.cjs.js} +2 -2
  4. package/dist/{fixture-3bfb4490.cjs.js.map → fixture-5b79f853.cjs.js.map} +1 -1
  5. package/dist/{fixture-e7023246.esm.js → fixture-90b199c4.esm.js} +1 -1
  6. package/dist/{fixture-8edec91c.esm.js → fixture-cf7bfcf5.esm.js} +1 -1
  7. package/dist/{fixture-7bfb866e.cjs.js → fixture-dbd66009.cjs.js} +2 -2
  8. package/dist/{fixture-fe6c932e.cjs.js.map → fixture-dbd66009.cjs.js.map} +1 -1
  9. package/dist/index.js +10 -5
  10. package/dist/nile-accordion/nile-accordian.test.cjs.js +1 -1
  11. package/dist/nile-accordion/nile-accordian.test.esm.js +1 -1
  12. package/dist/nile-auto-complete/nile-auto-complete.test.cjs.js +1 -1
  13. package/dist/nile-auto-complete/nile-auto-complete.test.esm.js +1 -1
  14. package/dist/nile-avatar/nile-avatar.test.cjs.js +1 -1
  15. package/dist/nile-avatar/nile-avatar.test.esm.js +1 -1
  16. package/dist/nile-badge/nile-badge.test.cjs.js +1 -1
  17. package/dist/nile-badge/nile-badge.test.esm.js +1 -1
  18. package/dist/nile-button/nile-button.test.cjs.js +1 -1
  19. package/dist/nile-button/nile-button.test.esm.js +1 -1
  20. package/dist/nile-button-toggle-group/nile-button-toggle-group.test.cjs.js +1 -1
  21. package/dist/nile-button-toggle-group/nile-button-toggle-group.test.esm.js +1 -1
  22. package/dist/nile-calendar/nile-calendar.test.cjs.js +1 -1
  23. package/dist/nile-calendar/nile-calendar.test.esm.js +1 -1
  24. package/dist/nile-card/nile-card.test.cjs.js +1 -1
  25. package/dist/nile-card/nile-card.test.esm.js +1 -1
  26. package/dist/nile-checkbox/nile-checkbox.test.cjs.js +1 -1
  27. package/dist/nile-checkbox/nile-checkbox.test.esm.js +1 -1
  28. package/dist/nile-chip/nile-chip.test.cjs.js +1 -1
  29. package/dist/nile-chip/nile-chip.test.esm.js +1 -1
  30. package/dist/nile-dialog/nile-dialog.test.cjs.js +1 -1
  31. package/dist/nile-dialog/nile-dialog.test.esm.js +1 -1
  32. package/dist/nile-drawer/nile-drawer.test.cjs.js +1 -1
  33. package/dist/nile-drawer/nile-drawer.test.esm.js +1 -1
  34. package/dist/nile-dropdown/nile-dropdown.test.cjs.js +1 -1
  35. package/dist/nile-dropdown/nile-dropdown.test.esm.js +1 -1
  36. package/dist/nile-empty-state/nile-empty-state.test.cjs.js +1 -1
  37. package/dist/nile-empty-state/nile-empty-state.test.esm.js +1 -1
  38. package/dist/nile-error-message/nile-error-message.test.cjs.js +1 -1
  39. package/dist/nile-error-message/nile-error-message.test.esm.js +1 -1
  40. package/dist/nile-file-preview/nile-file-preview.test.cjs.js +1 -1
  41. package/dist/nile-file-preview/nile-file-preview.test.esm.js +1 -1
  42. package/dist/nile-file-upload/nile-file-upload.test.cjs.js +1 -1
  43. package/dist/nile-file-upload/nile-file-upload.test.esm.js +1 -1
  44. package/dist/nile-filter-chip/nile-filter-chip.test.cjs.js +1 -1
  45. package/dist/nile-filter-chip/nile-filter-chip.test.esm.js +1 -1
  46. package/dist/nile-form-group/nile-form-group.test.cjs.js +1 -1
  47. package/dist/nile-form-group/nile-form-group.test.esm.js +1 -1
  48. package/dist/nile-form-help-text/nile-form-help-text.test.cjs.js +1 -1
  49. package/dist/nile-form-help-text/nile-form-help-text.test.esm.js +1 -1
  50. package/dist/nile-hero/nile-hero.test.cjs.js +1 -1
  51. package/dist/nile-hero/nile-hero.test.esm.js +1 -1
  52. package/dist/nile-icon/nile-icon.test.cjs.js +1 -1
  53. package/dist/nile-icon/nile-icon.test.esm.js +1 -1
  54. package/dist/nile-input/nile-input.test.cjs.js +1 -1
  55. package/dist/nile-input/nile-input.test.esm.js +1 -1
  56. package/dist/nile-link/nile-link.test.cjs.js +1 -1
  57. package/dist/nile-link/nile-link.test.esm.js +1 -1
  58. package/dist/nile-loader/nile-loader.test.cjs.js +1 -1
  59. package/dist/nile-loader/nile-loader.test.esm.js +1 -1
  60. package/dist/nile-popover/nile-popover.test.cjs.js +1 -1
  61. package/dist/nile-popover/nile-popover.test.esm.js +1 -1
  62. package/dist/nile-popup/nile-popup.test.cjs.js +1 -1
  63. package/dist/nile-popup/nile-popup.test.esm.js +1 -1
  64. package/dist/nile-progress-bar/nile-progress-bar.test.cjs.js +1 -1
  65. package/dist/nile-progress-bar/nile-progress-bar.test.esm.js +1 -1
  66. package/dist/nile-radio/nile-radio.test.cjs.js +1 -1
  67. package/dist/nile-radio/nile-radio.test.esm.js +1 -1
  68. package/dist/nile-radio-group/nile-radio-group.test.cjs.js +1 -1
  69. package/dist/nile-radio-group/nile-radio-group.test.esm.js +1 -1
  70. package/dist/nile-select/nile-select.cjs.js +1 -1
  71. package/dist/nile-select/nile-select.cjs.js.map +1 -1
  72. package/dist/nile-select/nile-select.esm.js +1 -1
  73. package/dist/nile-select/nile-select.test.cjs.js +1 -1
  74. package/dist/nile-select/nile-select.test.esm.js +1 -1
  75. package/dist/nile-slide-toggle/nile-slide-toggle.test.cjs.js +1 -1
  76. package/dist/nile-slide-toggle/nile-slide-toggle.test.esm.js +1 -1
  77. package/dist/nile-tab-group/nile-tab-group.test.cjs.js +1 -1
  78. package/dist/nile-tab-group/nile-tab-group.test.esm.js +1 -1
  79. package/dist/nile-textarea/nile-textarea.test.cjs.js +1 -1
  80. package/dist/nile-textarea/nile-textarea.test.esm.js +1 -1
  81. package/dist/nile-virtual-select/nile-virtual-select.cjs.js +1 -1
  82. package/dist/nile-virtual-select/nile-virtual-select.cjs.js.map +1 -1
  83. package/dist/nile-virtual-select/nile-virtual-select.css.cjs.js +1 -1
  84. package/dist/nile-virtual-select/nile-virtual-select.css.cjs.js.map +1 -1
  85. package/dist/nile-virtual-select/nile-virtual-select.css.esm.js +4 -0
  86. package/dist/nile-virtual-select/nile-virtual-select.esm.js +2 -2
  87. package/dist/nile-virtual-select/nile-virtual-select.test.cjs.js +1 -1
  88. package/dist/nile-virtual-select/nile-virtual-select.test.esm.js +1 -1
  89. package/dist/nile-virtual-select/renderer.cjs.js +1 -1
  90. package/dist/nile-virtual-select/renderer.cjs.js.map +1 -1
  91. package/dist/nile-virtual-select/renderer.esm.js +4 -3
  92. package/dist/nile-virtual-select/temp_nile-virtual-select copy.cjs.js +2 -0
  93. package/dist/nile-virtual-select/temp_nile-virtual-select copy.cjs.js.map +1 -0
  94. package/dist/nile-virtual-select/temp_nile-virtual-select copy.esm.js +231 -0
  95. package/dist/src/internal/resizable-helper.d.ts +59 -0
  96. package/dist/src/internal/resizable-helper.js +115 -0
  97. package/dist/src/internal/resizable-helper.js.map +1 -0
  98. package/dist/src/internal/resizable-styles.d.ts +16 -0
  99. package/dist/src/internal/resizable-styles.js +144 -0
  100. package/dist/src/internal/resizable-styles.js.map +1 -0
  101. package/dist/src/internal/virtualizer-error-handler.d.ts +30 -0
  102. package/dist/src/internal/virtualizer-error-handler.js +82 -0
  103. package/dist/src/internal/virtualizer-error-handler.js.map +1 -0
  104. package/dist/src/lib/index.d.ts +7 -0
  105. package/dist/src/lib/index.js +8 -0
  106. package/dist/src/lib/index.js.map +1 -0
  107. package/dist/src/lib/virtualize.d.ts +32 -0
  108. package/dist/src/lib/virtualize.js +105 -0
  109. package/dist/src/lib/virtualize.js.map +1 -0
  110. package/dist/src/lib/virtualize.test.d.ts +7 -0
  111. package/dist/src/lib/virtualize.test.js +57 -0
  112. package/dist/src/lib/virtualize.test.js.map +1 -0
  113. package/dist/src/nile-badge/__snapshots__/nile-badge.test.snap.js +17 -0
  114. package/dist/src/nile-calendar/__snapshots__/nile-calendar.test.snap.js +310 -0
  115. package/dist/src/nile-card/__snapshots__/nile-card.test.snap.js +34 -0
  116. package/dist/src/nile-checkbox/__snapshots__/nile-checkbox.test.snap.js +31 -0
  117. package/dist/src/nile-grid/data-processor.d.ts +37 -0
  118. package/dist/src/nile-grid/data-processor.js +122 -0
  119. package/dist/src/nile-grid/data-processor.js.map +1 -0
  120. package/dist/src/nile-grid/event-handlers.d.ts +35 -0
  121. package/dist/src/nile-grid/event-handlers.js +158 -0
  122. package/dist/src/nile-grid/event-handlers.js.map +1 -0
  123. package/dist/src/nile-grid/index.d.ts +5 -0
  124. package/dist/src/nile-grid/index.js +6 -0
  125. package/dist/src/nile-grid/index.js.map +1 -0
  126. package/dist/src/nile-grid/nile-grid.css.d.ts +1 -0
  127. package/dist/src/nile-grid/nile-grid.css.js +120 -0
  128. package/dist/src/nile-grid/nile-grid.css.js.map +1 -0
  129. package/dist/src/nile-grid/nile-grid.d.ts +39 -0
  130. package/dist/src/nile-grid/nile-grid.js +182 -0
  131. package/dist/src/nile-grid/nile-grid.js.map +1 -0
  132. package/dist/src/nile-grid/renderer.d.ts +8 -0
  133. package/dist/src/nile-grid/renderer.js +78 -0
  134. package/dist/src/nile-grid/renderer.js.map +1 -0
  135. package/dist/src/nile-grid/resize-handler.d.ts +4 -0
  136. package/dist/src/nile-grid/resize-handler.js +36 -0
  137. package/dist/src/nile-grid/resize-handler.js.map +1 -0
  138. package/dist/src/nile-grid/types.d.ts +32 -0
  139. package/dist/src/nile-grid/types.js +2 -0
  140. package/dist/src/nile-grid/types.js.map +1 -0
  141. package/dist/src/nile-grid/utils.d.ts +4 -0
  142. package/dist/src/nile-grid/utils.js +32 -0
  143. package/dist/src/nile-grid/utils.js.map +1 -0
  144. package/dist/src/nile-hero/__snapshots__/nile-hero.test.snap.js +47 -0
  145. package/dist/src/nile-icon/__snapshots__/nile-icon.test.snap.js +16 -0
  146. package/dist/src/nile-input/__snapshots__/nile-input.test.snap.js +75 -0
  147. package/dist/src/nile-popover/__snapshots__/nile-popover.test.snap.js +22 -0
  148. package/dist/src/nile-select/nile-select.js +3 -2
  149. package/dist/src/nile-select/nile-select.js.map +1 -1
  150. package/dist/src/nile-table-body/virtual-scroll-helper.d.ts +9 -0
  151. package/dist/src/nile-table-body/virtual-scroll-helper.js +24 -0
  152. package/dist/src/nile-table-body/virtual-scroll-helper.js.map +1 -0
  153. package/dist/src/nile-virtual-select/nile-virtual-select.css.js +4 -0
  154. package/dist/src/nile-virtual-select/nile-virtual-select.css.js.map +1 -1
  155. package/dist/src/nile-virtual-select/nile-virtual-select.d.ts +10 -1
  156. package/dist/src/nile-virtual-select/nile-virtual-select.js +71 -9
  157. package/dist/src/nile-virtual-select/nile-virtual-select.js.map +1 -1
  158. package/dist/src/nile-virtual-select/renderer.d.ts +2 -2
  159. package/dist/src/nile-virtual-select/renderer.js +6 -5
  160. package/dist/src/nile-virtual-select/renderer.js.map +1 -1
  161. package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.d.ts +273 -0
  162. package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.js +1305 -0
  163. package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.js.map +1 -0
  164. package/dist/src/nile-virtual-select/virtualizer-error-handler.d.ts +21 -0
  165. package/dist/src/nile-virtual-select/virtualizer-error-handler.js +56 -0
  166. package/dist/src/nile-virtual-select/virtualizer-error-handler.js.map +1 -0
  167. package/dist/src/nile-virtual-table-body/index.d.ts +2 -0
  168. package/dist/src/nile-virtual-table-body/index.js +3 -0
  169. package/dist/src/nile-virtual-table-body/index.js.map +1 -0
  170. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.d.ts +1 -0
  171. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.js +44 -0
  172. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.js.map +1 -0
  173. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.d.ts +50 -0
  174. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.js +135 -0
  175. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.js.map +1 -0
  176. package/dist/src/nile-virtual-table-body/renderer.d.ts +16 -0
  177. package/dist/src/nile-virtual-table-body/renderer.js +49 -0
  178. package/dist/src/nile-virtual-table-body/renderer.js.map +1 -0
  179. package/dist/tsconfig.tsbuildinfo +1 -1
  180. package/package.json +1 -1
  181. package/src/nile-select/nile-select.ts +3 -2
  182. package/src/nile-virtual-select/nile-virtual-select.css.ts +4 -0
  183. package/src/nile-virtual-select/nile-virtual-select.ts +86 -11
  184. package/src/nile-virtual-select/renderer.ts +7 -5
  185. package/src/nile-virtual-select/temp_nile-virtual-select copy.ts +1398 -0
  186. package/vscode-html-custom-data.json +246 -1
  187. package/dist/axe.min-2b379f29.cjs.js +0 -12
  188. package/dist/axe.min-2b379f29.cjs.js.map +0 -1
  189. package/dist/axe.min-c2cd8733.esm.js +0 -12
  190. package/dist/fixture-2b5b3aba.esm.js +0 -569
  191. package/dist/fixture-7bfb866e.cjs.js.map +0 -1
  192. package/dist/fixture-fe6c932e.cjs.js +0 -395
@@ -0,0 +1 @@
1
+ {"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../../src/nile-grid/renderer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAkB,MAAM,KAAK,CAAC;AAE3C,OAAO,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEtE,MAAM,OAAO,YAAY;IACvB,MAAM,CAAC,YAAY,CAAC,UAAuB,EAAE,eAAwB,EAAE,aAAqE;QAC1I,OAAO,IAAI,CAAA;+DACgD,sBAAsB,CAAC,UAAU,CAAC;UACvF,UAAU,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAA;;oBAEzB,GAAG,CAAC,UAAU,IAAI,GAAG,CAAC,KAAK;cACjC,IAAI,CAAC,sBAAsB,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;;;6BAGzC,CAAC,CAAa,EAAE,EAAE,CAAC,aAAa,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC;;;aAG/D,CAAC,CAAC,CAAC,EAAE;;SAET,CAAC;;KAEL,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,UAAU,CACf,OAAc,EACd,UAAuB,EACvB,mBAA4B,EAC5B,kBAAkE;QAElE,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,IAAI,CAAA;;;;OAIV,CAAC;QACJ,CAAC;QAED,IAAI,mBAAmB,EAAE,CAAC;YACxB,OAAO,IAAI,CAAA;;YAEL,kBAAkB;;OAEvB,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,CAAA;;UAEL,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,GAAG,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;;KAE1F,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,qBAAqB,CAAC,GAAQ,EAAE,QAAgB,EAAE,UAAuB;QAC9E,MAAM,KAAK,GAAqB,EAAE,CAAC;QACnC,IAAI,eAAe,GAAG,CAAC,CAAC;QAExB,KAAK,IAAI,QAAQ,GAAG,CAAC,EAAE,QAAQ,GAAG,UAAU,CAAC,MAAM,EAAE,QAAQ,EAAE,EAAE,CAAC;YAChE,MAAM,GAAG,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAC;YAEjC,kEAAkE;YAClE,IAAI,eAAe,GAAG,QAAQ,EAAE,CAAC;gBAC/B,SAAS;YACX,CAAC;YAED,wBAAwB;YACxB,MAAM,OAAO,GAAG,gBAAgB,CAAC,GAAG,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;YAE/D,IAAI,OAAO,GAAG,CAAC,EAAE,CAAC;gBAChB,MAAM,SAAS,GAAG,gBAAgB,eAAe,GAAG,CAAC,WAAW,OAAO,GAAG,CAAC;gBAE3E,KAAK,CAAC,IAAI,CAAC,IAAI,CAAA;0CACmB,SAAS;oBAC/B,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC;;SAEzB,CAAC,CAAC;gBAEH,eAAe,IAAI,OAAO,CAAC;YAC7B,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAA;4DAC6C,sBAAsB,CAAC,UAAU,CAAC;UACpF,KAAK;;KAEV,CAAC;IACJ,CAAC;IAEO,MAAM,CAAC,sBAAsB,CAAC,GAAc,EAAE,eAAwB;QAC5E,IAAI,CAAC,eAAe;YAAE,OAAO,KAAK,CAAC;QACnC,IAAI,GAAG,CAAC,SAAS,KAAK,KAAK;YAAE,OAAO,KAAK,CAAC;QAC1C,OAAO,IAAI,CAAC;IACd,CAAC;CACF","sourcesContent":["import { html, TemplateResult } from 'lit';\nimport type { ColumnDef } from './types.js';\nimport { getGridTemplateColumns, calculateColSpan } from './utils.js';\n\nexport class GridRenderer {\n static renderHeader(columnDefs: ColumnDef[], enableColResize: boolean, onResizeStart: (e: MouseEvent, col: ColumnDef, index: number) => void): TemplateResult {\n return html`\n <div class=\"grid-header\" style=\"grid-template-columns: ${getGridTemplateColumns(columnDefs)};\">\n ${columnDefs.map((col, index) => html`\n <div class=\"grid-header-cell\">\n <span>${col.headerName || col.field}</span>\n ${this.shouldShowResizeHandle(col, enableColResize) ? html`\n <div \n class=\"grid-resize-handle\"\n @mousedown=${(e: MouseEvent) => onResizeStart(e, col, index)}\n title=\"Drag to resize column\"\n ></div>\n ` : ''}\n </div>\n `)}\n </div>\n `;\n }\n\n static renderBody(\n rowData: any[], \n columnDefs: ColumnDef[], \n enableVirtualScroll: boolean,\n onVirtualizeRender: (row: any, rowIndex: number) => TemplateResult\n ): TemplateResult {\n if (rowData.length === 0) {\n return html`\n <div class=\"grid-empty\">\n <div class=\"empty-text\">No data available</div>\n </div>\n `;\n }\n\n if (enableVirtualScroll) {\n return html`\n <div class=\"grid-body\">\n ${onVirtualizeRender}\n </div>\n `;\n }\n\n return html`\n <div class=\"grid-body\">\n ${rowData.map((row, rowIndex) => this.renderRowWithSpanning(row, rowIndex, columnDefs))}\n </div>\n `;\n }\n\n static renderRowWithSpanning(row: any, rowIndex: number, columnDefs: ColumnDef[]): TemplateResult {\n const cells: TemplateResult[] = [];\n let currentColIndex = 0;\n\n for (let colIndex = 0; colIndex < columnDefs.length; colIndex++) {\n const col = columnDefs[colIndex];\n \n // Check if this column should be skipped due to previous spanning\n if (currentColIndex > colIndex) {\n continue;\n }\n\n // Calculate column span\n const colSpan = calculateColSpan(col, row, rowIndex, colIndex);\n \n if (colSpan > 0) {\n const cellStyle = `grid-column: ${currentColIndex + 1} / span ${colSpan};`;\n \n cells.push(html`\n <div class=\"grid-cell\" style=\"${cellStyle}\">\n <span>${row[col.field]}</span>\n </div>\n `);\n \n currentColIndex += colSpan;\n }\n }\n\n return html`\n <div class=\"grid-row\" style=\"grid-template-columns: ${getGridTemplateColumns(columnDefs)};\">\n ${cells}\n </div>\n `;\n }\n\n private static shouldShowResizeHandle(col: ColumnDef, enableColResize: boolean): boolean {\n if (!enableColResize) return false;\n if (col.resizable === false) return false;\n return true;\n }\n}\n"]}
@@ -0,0 +1,4 @@
1
+ import type { ColumnDef, GridOptions } from './types.js';
2
+ export declare class ResizeHandler {
3
+ static handleResizeStart(event: MouseEvent, col: ColumnDef, columnIndex: number, columnDefs: ColumnDef[], gridOptions: GridOptions, onUpdate: () => void): void;
4
+ }
@@ -0,0 +1,36 @@
1
+ export class ResizeHandler {
2
+ static handleResizeStart(event, col, columnIndex, columnDefs, gridOptions, onUpdate) {
3
+ event.preventDefault();
4
+ event.stopPropagation();
5
+ const startX = event.clientX;
6
+ const startWidth = col.width || 100;
7
+ const isShiftKey = event.shiftKey || gridOptions.colResizeDefault === 'shift';
8
+ const handleMouseMove = (e) => {
9
+ const deltaX = e.clientX - startX;
10
+ let newWidth = startWidth + deltaX;
11
+ // Ensure minimum width for usability
12
+ newWidth = Math.max(newWidth, 50);
13
+ // Update column width
14
+ col.width = newWidth;
15
+ // If shift resize, adjust adjacent column
16
+ if (isShiftKey && columnIndex < columnDefs.length - 1) {
17
+ const nextCol = columnDefs[columnIndex + 1];
18
+ const totalWidth = (col.width || 0) + (nextCol.width || 0);
19
+ const newNextWidth = totalWidth - newWidth;
20
+ // Ensure adjacent column doesn't get too narrow
21
+ if (newNextWidth >= 50) {
22
+ nextCol.width = newNextWidth;
23
+ }
24
+ }
25
+ // Force complete re-render for virtual scrolling
26
+ onUpdate();
27
+ };
28
+ const handleMouseUp = () => {
29
+ document.removeEventListener('mousemove', handleMouseMove);
30
+ document.removeEventListener('mouseup', handleMouseUp);
31
+ };
32
+ document.addEventListener('mousemove', handleMouseMove);
33
+ document.addEventListener('mouseup', handleMouseUp);
34
+ }
35
+ }
36
+ //# sourceMappingURL=resize-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"resize-handler.js","sourceRoot":"","sources":["../../../src/nile-grid/resize-handler.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,aAAa;IACxB,MAAM,CAAC,iBAAiB,CACtB,KAAiB,EACjB,GAAc,EACd,WAAmB,EACnB,UAAuB,EACvB,WAAwB,EACxB,QAAoB;QAEpB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,MAAM,MAAM,GAAG,KAAK,CAAC,OAAO,CAAC;QAC7B,MAAM,UAAU,GAAG,GAAG,CAAC,KAAK,IAAI,GAAG,CAAC;QACpC,MAAM,UAAU,GAAG,KAAK,CAAC,QAAQ,IAAI,WAAW,CAAC,gBAAgB,KAAK,OAAO,CAAC;QAE9E,MAAM,eAAe,GAAG,CAAC,CAAa,EAAE,EAAE;YACxC,MAAM,MAAM,GAAG,CAAC,CAAC,OAAO,GAAG,MAAM,CAAC;YAClC,IAAI,QAAQ,GAAG,UAAU,GAAG,MAAM,CAAC;YAEnC,qCAAqC;YACrC,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;YAElC,sBAAsB;YACtB,GAAG,CAAC,KAAK,GAAG,QAAQ,CAAC;YAErB,0CAA0C;YAC1C,IAAI,UAAU,IAAI,WAAW,GAAG,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACtD,MAAM,OAAO,GAAG,UAAU,CAAC,WAAW,GAAG,CAAC,CAAC,CAAC;gBAC5C,MAAM,UAAU,GAAG,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC;gBAC3D,MAAM,YAAY,GAAG,UAAU,GAAG,QAAQ,CAAC;gBAE3C,gDAAgD;gBAChD,IAAI,YAAY,IAAI,EAAE,EAAE,CAAC;oBACvB,OAAO,CAAC,KAAK,GAAG,YAAY,CAAC;gBAC/B,CAAC;YACH,CAAC;YAED,iDAAiD;YACjD,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC;QAEF,MAAM,aAAa,GAAG,GAAG,EAAE;YACzB,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;YAC3D,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;QACzD,CAAC,CAAC;QAEF,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;QACxD,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;IACtD,CAAC;CACF","sourcesContent":["import type { ColumnDef, GridOptions } from './types.js';\n\nexport class ResizeHandler {\n static handleResizeStart(\n event: MouseEvent, \n col: ColumnDef, \n columnIndex: number, \n columnDefs: ColumnDef[],\n gridOptions: GridOptions,\n onUpdate: () => void\n ): void {\n event.preventDefault();\n event.stopPropagation();\n \n const startX = event.clientX;\n const startWidth = col.width || 100;\n const isShiftKey = event.shiftKey || gridOptions.colResizeDefault === 'shift';\n \n const handleMouseMove = (e: MouseEvent) => {\n const deltaX = e.clientX - startX;\n let newWidth = startWidth + deltaX;\n \n // Ensure minimum width for usability\n newWidth = Math.max(newWidth, 50);\n \n // Update column width\n col.width = newWidth;\n \n // If shift resize, adjust adjacent column\n if (isShiftKey && columnIndex < columnDefs.length - 1) {\n const nextCol = columnDefs[columnIndex + 1];\n const totalWidth = (col.width || 0) + (nextCol.width || 0);\n const newNextWidth = totalWidth - newWidth;\n \n // Ensure adjacent column doesn't get too narrow\n if (newNextWidth >= 50) {\n nextCol.width = newNextWidth;\n }\n }\n \n // Force complete re-render for virtual scrolling\n onUpdate();\n };\n \n const handleMouseUp = () => {\n document.removeEventListener('mousemove', handleMouseMove);\n document.removeEventListener('mouseup', handleMouseUp);\n };\n \n document.addEventListener('mousemove', handleMouseMove);\n document.addEventListener('mouseup', handleMouseUp);\n }\n}\n"]}
@@ -0,0 +1,32 @@
1
+ export interface ColumnDef {
2
+ field: string;
3
+ headerName?: string;
4
+ sortable?: boolean;
5
+ width?: number;
6
+ resizable?: boolean;
7
+ minWidth?: number;
8
+ maxWidth?: number;
9
+ colSpan?: (params: ColSpanParams) => number;
10
+ }
11
+ export interface GridOptions {
12
+ rowSelection?: 'single' | 'multiple';
13
+ enableSorting?: boolean;
14
+ enableVirtualScroll?: boolean;
15
+ enableColResize?: boolean;
16
+ colResizeDefault?: 'normal' | 'shift';
17
+ }
18
+ export interface ColSpanParams {
19
+ data: any;
20
+ field: string;
21
+ rowIndex: number;
22
+ columnIndex: number;
23
+ }
24
+ export interface GridApi {
25
+ getSelectedRows: () => any[];
26
+ setRowData: (data: any[]) => void;
27
+ setColumnDefs: (defs: ColumnDef[]) => void;
28
+ }
29
+ export interface GridReadyEvent {
30
+ api: GridApi;
31
+ type: 'gridReady';
32
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/nile-grid/types.ts"],"names":[],"mappings":"","sourcesContent":["export interface ColumnDef {\n field: string;\n headerName?: string;\n sortable?: boolean;\n width?: number;\n resizable?: boolean;\n minWidth?: number;\n maxWidth?: number;\n colSpan?: (params: ColSpanParams) => number;\n}\n\nexport interface GridOptions {\n rowSelection?: 'single' | 'multiple';\n enableSorting?: boolean;\n enableVirtualScroll?: boolean;\n enableColResize?: boolean;\n colResizeDefault?: 'normal' | 'shift';\n}\n\nexport interface ColSpanParams {\n data: any;\n field: string;\n rowIndex: number;\n columnIndex: number;\n}\n\nexport interface GridApi {\n getSelectedRows: () => any[];\n setRowData: (data: any[]) => void;\n setColumnDefs: (defs: ColumnDef[]) => void;\n}\n\nexport interface GridReadyEvent {\n api: GridApi;\n type: 'gridReady';\n}\n"]}
@@ -0,0 +1,4 @@
1
+ import type { ColumnDef } from './types.js';
2
+ export declare function getGridTemplateColumns(columnDefs: ColumnDef[]): string;
3
+ export declare function calculateColSpan(col: ColumnDef, row: any, rowIndex: number, colIndex: number): number;
4
+ export declare function shouldShowResizeHandle(col: ColumnDef, enableColResize: boolean): boolean;
@@ -0,0 +1,32 @@
1
+ export function getGridTemplateColumns(columnDefs) {
2
+ return columnDefs.map((col, index) => {
3
+ if (col.width) {
4
+ return `${col.width}px`;
5
+ }
6
+ // Last column takes remaining space
7
+ if (index === columnDefs.length - 1) {
8
+ return '1fr';
9
+ }
10
+ return 'auto';
11
+ }).join(' ');
12
+ }
13
+ export function calculateColSpan(col, row, rowIndex, colIndex) {
14
+ if (col.colSpan) {
15
+ const params = {
16
+ data: row,
17
+ field: col.field,
18
+ rowIndex,
19
+ columnIndex: colIndex
20
+ };
21
+ return col.colSpan(params);
22
+ }
23
+ return 1;
24
+ }
25
+ export function shouldShowResizeHandle(col, enableColResize) {
26
+ if (!enableColResize)
27
+ return false;
28
+ if (col.resizable === false)
29
+ return false;
30
+ return true;
31
+ }
32
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/nile-grid/utils.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,sBAAsB,CAAC,UAAuB;IAC5D,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;QACnC,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;YACd,OAAO,GAAG,GAAG,CAAC,KAAK,IAAI,CAAC;QAC1B,CAAC;QACD,oCAAoC;QACpC,IAAI,KAAK,KAAK,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpC,OAAO,KAAK,CAAC;QACf,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACf,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,GAAc,EAAE,GAAQ,EAAE,QAAgB,EAAE,QAAgB;IAC3F,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;QAChB,MAAM,MAAM,GAAkB;YAC5B,IAAI,EAAE,GAAG;YACT,KAAK,EAAE,GAAG,CAAC,KAAK;YAChB,QAAQ;YACR,WAAW,EAAE,QAAQ;SACtB,CAAC;QACF,OAAO,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAC7B,CAAC;IACD,OAAO,CAAC,CAAC;AACX,CAAC;AAED,MAAM,UAAU,sBAAsB,CAAC,GAAc,EAAE,eAAwB;IAC7E,IAAI,CAAC,eAAe;QAAE,OAAO,KAAK,CAAC;IACnC,IAAI,GAAG,CAAC,SAAS,KAAK,KAAK;QAAE,OAAO,KAAK,CAAC;IAC1C,OAAO,IAAI,CAAC;AACd,CAAC","sourcesContent":["import type { ColumnDef, ColSpanParams } from './types.js';\n\nexport function getGridTemplateColumns(columnDefs: ColumnDef[]): string {\n return columnDefs.map((col, index) => {\n if (col.width) {\n return `${col.width}px`;\n }\n // Last column takes remaining space\n if (index === columnDefs.length - 1) {\n return '1fr';\n }\n return 'auto';\n }).join(' ');\n}\n\nexport function calculateColSpan(col: ColumnDef, row: any, rowIndex: number, colIndex: number): number {\n if (col.colSpan) {\n const params: ColSpanParams = {\n data: row,\n field: col.field,\n rowIndex,\n columnIndex: colIndex\n };\n return col.colSpan(params);\n }\n return 1;\n}\n\nexport function shouldShowResizeHandle(col: ColumnDef, enableColResize: boolean): boolean {\n if (!enableColResize) return false;\n if (col.resizable === false) return false;\n return true;\n}\n"]}
@@ -0,0 +1,47 @@
1
+ /* @web/test-runner snapshot v1 */
2
+ export const snapshots = {};
3
+
4
+ snapshots["NileHero renders correctly with default properties"] =
5
+ `<div
6
+ class="hero__container hero__container--expanded"
7
+ part="nile__hero__container"
8
+ >
9
+ <nile-hero-header
10
+ class="hero__header--collapsed"
11
+ hero-text="Test Hero"
12
+ icon="error"
13
+ part="nile__hero__header"
14
+ style="opacity:0"
15
+ >
16
+ </nile-hero-header>
17
+ <div
18
+ class="hero__slot__container"
19
+ style="opacity:1"
20
+ >
21
+ <div class="hero__slot">
22
+ <span class="icon__container">
23
+ <nile-icon
24
+ method="stroke"
25
+ name="error"
26
+ size="16"
27
+ >
28
+ </nile-icon>
29
+ </span>
30
+ <slot>
31
+ </slot>
32
+ </div>
33
+ </div>
34
+ <div
35
+ class="hero__img__container"
36
+ id="hero__img__container"
37
+ style="opacity:1"
38
+ >
39
+ <img
40
+ class="hero__img"
41
+ src=""
42
+ >
43
+ </div>
44
+ </div>
45
+ `;
46
+ /* end snapshot NileHero renders correctly with default properties */
47
+
@@ -0,0 +1,16 @@
1
+ /* @web/test-runner snapshot v1 */
2
+ export const snapshots = {};
3
+
4
+ snapshots["NileIcon should render the icon with the correct name"] =
5
+ `<nile-icon
6
+ description=""
7
+ method="fill"
8
+ name="info"
9
+ set="local"
10
+ size="16"
11
+ style="--nile-svg-fill: var(--nile-colors-dark-500); --nile-svg-height: 16px; --nile-svg-width: 16px;"
12
+ >
13
+ </nile-icon>
14
+ `;
15
+ /* end snapshot NileIcon should render the icon with the correct name */
16
+
@@ -0,0 +1,75 @@
1
+ /* @web/test-runner snapshot v1 */
2
+ export const snapshots = {};
3
+
4
+ snapshots["nile-input renders correctly"] =
5
+ `<div
6
+ class="form-control form-control--has-label form-control--medium"
7
+ part="form-control"
8
+ >
9
+ <label
10
+ aria-hidden="false"
11
+ class="form-control__label"
12
+ for="input"
13
+ part="form-control-label"
14
+ >
15
+ <slot name="label">
16
+ Test Label
17
+ </slot>
18
+ </label>
19
+ <div
20
+ class="form-control-input"
21
+ part="form-control-input"
22
+ >
23
+ <nile-popup
24
+ distance="5"
25
+ exportparts="input"
26
+ placement="bottom-start"
27
+ strategy="fixed"
28
+ >
29
+ <div
30
+ class="input input--empty input--medium input--standard"
31
+ part="base"
32
+ slot="anchor"
33
+ >
34
+ <slot
35
+ class="input__prefix"
36
+ name="prefix"
37
+ part="prefix"
38
+ >
39
+ </slot>
40
+ <input
41
+ aria-describedby="help-text"
42
+ autocomplete="off"
43
+ class="input__control"
44
+ id="input"
45
+ name=""
46
+ part="input"
47
+ placeholder=""
48
+ spellcheck="true"
49
+ title=""
50
+ type="text"
51
+ >
52
+ <slot
53
+ class="input__suffix"
54
+ name="suffix"
55
+ part="suffix"
56
+ >
57
+ </slot>
58
+ </div>
59
+ <div class="input__non-printable">
60
+ Non-printable character detected.
61
+ <nile-badge
62
+ class="input__remove-non-printable"
63
+ variant="error"
64
+ >
65
+ Remove All
66
+ </nile-badge>
67
+ <div class="input__srtiked-text-container">
68
+ </div>
69
+ </div>
70
+ </nile-popup>
71
+ </div>
72
+ </div>
73
+ `;
74
+ /* end snapshot nile-input renders correctly */
75
+
@@ -0,0 +1,22 @@
1
+ /* @web/test-runner snapshot v1 */
2
+ export const snapshots = {};
3
+
4
+ snapshots["NilePopover renders correctly"] =
5
+ `<nile-popup
6
+ active=""
7
+ arrowplacement="anchor"
8
+ distance="18"
9
+ placement="top"
10
+ shift=""
11
+ strategy="absolute"
12
+ >
13
+ <slot
14
+ aria-describedby="tooltip"
15
+ name="anchor"
16
+ slot="anchor"
17
+ >
18
+ </slot>
19
+ </nile-popup>
20
+ `;
21
+ /* end snapshot NilePopover renders correctly */
22
+
@@ -729,8 +729,9 @@ let NileSelect = class NileSelect extends NileElement {
729
729
  handleValueChange() {
730
730
  const allOptions = this.getAllOptions();
731
731
  const value = Array.isArray(this.value) ? this.value : [this.value];
732
- // Select only the options that match the new value
733
- this.setSelectedOptions(allOptions.filter(el => value.includes(el.value)));
732
+ if (!this.enableVirtualScroll) {
733
+ this.setSelectedOptions(allOptions.filter(el => value.includes(el.value)));
734
+ }
734
735
  }
735
736
  async handleOpenChange() {
736
737
  if (this.open && !this.disabled) {