@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.
- package/README.md +9 -0
- package/demo/index.html +16 -314
- package/demo/nxtgen.css +7 -2
- package/dist/{fixture-3bfb4490.cjs.js → fixture-5b79f853.cjs.js} +2 -2
- package/dist/{fixture-3bfb4490.cjs.js.map → fixture-5b79f853.cjs.js.map} +1 -1
- package/dist/{fixture-ba65262e.esm.js → fixture-90b199c4.esm.js} +2 -2
- package/dist/{fixture-8edec91c.esm.js → fixture-9871e8a9.esm.js} +1 -1
- package/dist/{fixture-d1470b58.cjs.js → fixture-c1d78368.cjs.js} +2 -2
- package/dist/{fixture-d1470b58.cjs.js.map → fixture-c1d78368.cjs.js.map} +1 -1
- package/dist/{fixture-985bba12.esm.js → fixture-cf7bfcf5.esm.js} +1 -1
- package/dist/{fixture-e3592de4.cjs.js → fixture-dbd66009.cjs.js} +4 -4
- package/dist/fixture-dbd66009.cjs.js.map +1 -0
- package/dist/index.cjs.js +1 -1
- package/dist/index.esm.js +1 -1
- package/dist/index.js +698 -1272
- package/dist/nile-accordion/nile-accordian.test.cjs.js +1 -1
- package/dist/nile-accordion/nile-accordian.test.esm.js +1 -1
- package/dist/nile-auto-complete/nile-auto-complete.test.cjs.js +1 -1
- package/dist/nile-auto-complete/nile-auto-complete.test.esm.js +1 -1
- package/dist/nile-avatar/nile-avatar.test.cjs.js +1 -1
- package/dist/nile-avatar/nile-avatar.test.esm.js +1 -1
- package/dist/nile-badge/nile-badge.test.cjs.js +1 -1
- package/dist/nile-badge/nile-badge.test.esm.js +1 -1
- package/dist/nile-button/nile-button.css.cjs.js +1 -1
- package/dist/nile-button/nile-button.css.cjs.js.map +1 -1
- package/dist/nile-button/nile-button.css.esm.js +66 -12
- package/dist/nile-button/nile-button.test.cjs.js +1 -1
- package/dist/nile-button/nile-button.test.esm.js +1 -1
- package/dist/nile-button-toggle-group/nile-button-toggle-group.test.cjs.js +1 -1
- package/dist/nile-button-toggle-group/nile-button-toggle-group.test.esm.js +1 -1
- package/dist/nile-calendar/nile-calendar.test.cjs.js +1 -1
- package/dist/nile-calendar/nile-calendar.test.esm.js +1 -1
- package/dist/nile-card/nile-card.test.cjs.js +1 -1
- package/dist/nile-card/nile-card.test.esm.js +1 -1
- package/dist/nile-checkbox/nile-checkbox.test.cjs.js +1 -1
- package/dist/nile-checkbox/nile-checkbox.test.esm.js +1 -1
- package/dist/nile-chip/nile-chip.test.cjs.js +1 -1
- package/dist/nile-chip/nile-chip.test.esm.js +1 -1
- package/dist/nile-code-editor/backup_nile-code-editor copy.cjs.js +2 -0
- package/dist/nile-code-editor/backup_nile-code-editor copy.cjs.js.map +1 -0
- package/dist/nile-code-editor/backup_nile-code-editor copy.esm.js +1 -0
- package/dist/nile-dialog/nile-dialog.test.cjs.js +1 -1
- package/dist/nile-dialog/nile-dialog.test.esm.js +1 -1
- package/dist/nile-drawer/nile-drawer.test.cjs.js +1 -1
- package/dist/nile-drawer/nile-drawer.test.esm.js +1 -1
- package/dist/nile-dropdown/nile-dropdown.test.cjs.js +1 -1
- package/dist/nile-dropdown/nile-dropdown.test.esm.js +1 -1
- package/dist/nile-empty-state/nile-empty-state.test.cjs.js +1 -1
- package/dist/nile-empty-state/nile-empty-state.test.esm.js +1 -1
- package/dist/nile-error-message/nile-error-message.test.cjs.js +1 -1
- package/dist/nile-error-message/nile-error-message.test.esm.js +1 -1
- package/dist/nile-file-preview/nile-file-preview.test.cjs.js +1 -1
- package/dist/nile-file-preview/nile-file-preview.test.esm.js +1 -1
- package/dist/nile-file-upload/nile-file-upload.test.cjs.js +1 -1
- package/dist/nile-file-upload/nile-file-upload.test.esm.js +1 -1
- package/dist/nile-filter-chip/nile-filter-chip.test.cjs.js +1 -1
- package/dist/nile-filter-chip/nile-filter-chip.test.esm.js +1 -1
- package/dist/nile-form-group/nile-form-group.test.cjs.js +1 -1
- package/dist/nile-form-group/nile-form-group.test.esm.js +1 -1
- package/dist/nile-form-help-text/nile-form-help-text.test.cjs.js +1 -1
- package/dist/nile-form-help-text/nile-form-help-text.test.esm.js +1 -1
- package/dist/nile-grid/nile-grid.cjs.js +1 -1
- package/dist/nile-grid/nile-grid.cjs.js.map +1 -1
- package/dist/nile-grid/nile-grid.css.cjs.js +1 -1
- package/dist/nile-grid/nile-grid.css.cjs.js.map +1 -1
- package/dist/nile-grid/nile-grid.css.esm.js +8 -4
- package/dist/nile-grid/nile-grid.esm.js +6 -6
- package/dist/nile-grid/nile-grid.types.cjs.js +2 -0
- package/dist/nile-grid/nile-grid.types.cjs.js.map +1 -0
- package/dist/nile-grid/nile-grid.types.esm.js +1 -0
- package/dist/nile-grid/nile-grid.utils.cjs.js +1 -1
- package/dist/nile-grid/nile-grid.utils.cjs.js.map +1 -1
- package/dist/nile-grid/nile-grid.utils.esm.js +1 -1
- package/dist/nile-grid-body/nile-grid-body.cjs.js +1 -1
- package/dist/nile-grid-body/nile-grid-body.cjs.js.map +1 -1
- package/dist/nile-grid-body/nile-grid-body.css.cjs.js +1 -1
- package/dist/nile-grid-body/nile-grid-body.css.cjs.js.map +1 -1
- package/dist/nile-grid-body/nile-grid-body.css.esm.js +0 -4
- package/dist/nile-grid-body/nile-grid-body.esm.js +3 -3
- package/dist/nile-grid-cell-item/nile-grid-cell-item.cjs.js +1 -1
- package/dist/nile-grid-cell-item/nile-grid-cell-item.cjs.js.map +1 -1
- package/dist/nile-grid-cell-item/nile-grid-cell-item.css.cjs.js +1 -1
- package/dist/nile-grid-cell-item/nile-grid-cell-item.css.cjs.js.map +1 -1
- package/dist/nile-grid-cell-item/nile-grid-cell-item.css.esm.js +18 -3
- package/dist/nile-grid-cell-item/nile-grid-cell-item.esm.js +3 -3
- package/dist/nile-grid-head/nile-grid-head.cjs.js +1 -1
- package/dist/nile-grid-head/nile-grid-head.cjs.js.map +1 -1
- package/dist/nile-grid-head/nile-grid-head.css.cjs.js +1 -1
- package/dist/nile-grid-head/nile-grid-head.css.cjs.js.map +1 -1
- package/dist/nile-grid-head/nile-grid-head.css.esm.js +1 -1
- package/dist/nile-grid-head/nile-grid-head.esm.js +3 -3
- package/dist/nile-grid-head-item/nile-grid-head-item.cjs.js +1 -1
- package/dist/nile-grid-head-item/nile-grid-head-item.cjs.js.map +1 -1
- package/dist/nile-grid-head-item/nile-grid-head-item.css.cjs.js +1 -1
- package/dist/nile-grid-head-item/nile-grid-head-item.css.cjs.js.map +1 -1
- package/dist/nile-grid-head-item/nile-grid-head-item.css.esm.js +20 -5
- package/dist/nile-grid-head-item/nile-grid-head-item.esm.js +4 -3
- package/dist/nile-grid-row/nile-grid-row.cjs.js +1 -1
- package/dist/nile-grid-row/nile-grid-row.cjs.js.map +1 -1
- package/dist/nile-grid-row/nile-grid-row.css.cjs.js +1 -1
- package/dist/nile-grid-row/nile-grid-row.css.cjs.js.map +1 -1
- package/dist/nile-grid-row/nile-grid-row.css.esm.js +17 -5
- package/dist/nile-grid-row/nile-grid-row.esm.js +4 -5
- package/dist/nile-hero/nile-hero.test.cjs.js +1 -1
- package/dist/nile-hero/nile-hero.test.esm.js +1 -1
- package/dist/nile-icon/nile-icon.test.cjs.js +1 -1
- package/dist/nile-icon/nile-icon.test.esm.js +1 -1
- package/dist/nile-input/nile-input.test.cjs.js +1 -1
- package/dist/nile-input/nile-input.test.esm.js +1 -1
- package/dist/nile-link/nile-link.test.cjs.js +1 -1
- package/dist/nile-link/nile-link.test.esm.js +1 -1
- package/dist/nile-loader/nile-loader.test.cjs.js +1 -1
- package/dist/nile-loader/nile-loader.test.esm.js +1 -1
- package/dist/nile-popover/nile-popover.test.cjs.js +1 -1
- package/dist/nile-popover/nile-popover.test.esm.js +1 -1
- package/dist/nile-popup/nile-popup.test.cjs.js +1 -1
- package/dist/nile-popup/nile-popup.test.esm.js +1 -1
- package/dist/nile-progress-bar/nile-progress-bar.test.cjs.js +1 -1
- package/dist/nile-progress-bar/nile-progress-bar.test.esm.js +1 -1
- package/dist/nile-radio/nile-radio.test.cjs.js +1 -1
- package/dist/nile-radio/nile-radio.test.esm.js +1 -1
- package/dist/nile-radio-group/nile-radio-group.test.cjs.js +1 -1
- package/dist/nile-radio-group/nile-radio-group.test.esm.js +1 -1
- package/dist/nile-select/nile-select.test.cjs.js +1 -1
- package/dist/nile-select/nile-select.test.esm.js +1 -1
- package/dist/nile-sidebar/index.cjs.js.map +1 -1
- package/dist/nile-sidebar-menu/nile-sidebar-menu.cjs.js.map +1 -1
- package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.cjs.js.map +1 -1
- package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.cjs.js.map +1 -1
- package/dist/nile-slide-toggle/nile-slide-toggle.test.cjs.js +1 -1
- package/dist/nile-slide-toggle/nile-slide-toggle.test.esm.js +1 -1
- package/dist/nile-stepper/index.cjs.js +1 -1
- package/dist/nile-stepper/index.esm.js +1 -1
- package/dist/nile-stepper/nile-stepper.cjs.js +1 -1
- package/dist/nile-stepper/nile-stepper.cjs.js.map +1 -1
- package/dist/nile-stepper/nile-stepper.esm.js +3 -3
- package/dist/nile-stepper-item/nile-stepper-item.cjs.js +1 -1
- package/dist/nile-stepper-item/nile-stepper-item.cjs.js.map +1 -1
- package/dist/nile-stepper-item/nile-stepper-item.esm.js +2 -2
- package/dist/nile-tab-group/nile-tab-group.test.cjs.js +1 -1
- package/dist/nile-tab-group/nile-tab-group.test.esm.js +1 -1
- package/dist/nile-table-body/index.cjs.js +1 -1
- package/dist/nile-table-body/index.esm.js +1 -1
- package/dist/nile-table-body/nile-table-body.cjs.js +1 -1
- package/dist/nile-table-body/nile-table-body.cjs.js.map +1 -1
- package/dist/nile-table-body/nile-table-body.esm.js +3 -3
- package/dist/nile-table-header-item/nile-table-header-item.css.cjs.js +1 -1
- package/dist/nile-table-header-item/nile-table-header-item.css.cjs.js.map +1 -1
- package/dist/nile-table-header-item/nile-table-header-item.css.esm.js +0 -4
- package/dist/nile-textarea/nile-textarea.test.cjs.js +1 -1
- package/dist/nile-textarea/nile-textarea.test.esm.js +1 -1
- package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.cjs.js +1 -1
- package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.cjs.js.map +1 -1
- package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.esm.js +7 -7
- package/dist/nile-virtual-select/nile-virtual-select.cjs.js +1 -1
- package/dist/nile-virtual-select/nile-virtual-select.cjs.js.map +1 -1
- package/dist/nile-virtual-select/nile-virtual-select.esm.js +1 -1
- package/dist/nile-virtual-select/nile-virtual-select.test.cjs.js +1 -1
- package/dist/nile-virtual-select/nile-virtual-select.test.esm.js +1 -1
- package/dist/nile-virtual-select/temp_nile-virtual-select copy.cjs.js +2 -0
- package/dist/nile-virtual-select/temp_nile-virtual-select copy.cjs.js.map +1 -0
- package/dist/nile-virtual-select/temp_nile-virtual-select copy.esm.js +231 -0
- package/dist/src/index.d.ts +4 -17
- package/dist/src/index.js +4 -17
- package/dist/src/index.js.map +1 -1
- package/dist/src/internal/resizable-helper.d.ts +59 -0
- package/dist/src/internal/resizable-helper.js +115 -0
- package/dist/src/internal/resizable-helper.js.map +1 -0
- package/dist/src/internal/resizable-styles.d.ts +16 -0
- package/dist/src/internal/resizable-styles.js +144 -0
- package/dist/src/internal/resizable-styles.js.map +1 -0
- package/dist/src/internal/virtualizer-error-handler.d.ts +30 -0
- package/dist/src/internal/virtualizer-error-handler.js +82 -0
- package/dist/src/internal/virtualizer-error-handler.js.map +1 -0
- package/dist/src/lib/index.d.ts +7 -0
- package/dist/src/lib/index.js +8 -0
- package/dist/src/lib/index.js.map +1 -0
- package/dist/src/lib/virtualize.d.ts +32 -0
- package/dist/src/lib/virtualize.js +105 -0
- package/dist/src/lib/virtualize.js.map +1 -0
- package/dist/src/lib/virtualize.test.d.ts +7 -0
- package/dist/src/lib/virtualize.test.js +57 -0
- package/dist/src/lib/virtualize.test.js.map +1 -0
- package/dist/src/nile-badge/__snapshots__/nile-badge.test.snap.js +17 -0
- package/dist/src/nile-button/nile-button.css.js +66 -12
- package/dist/src/nile-button/nile-button.css.js.map +1 -1
- package/dist/src/nile-calendar/__snapshots__/nile-calendar.test.snap.js +310 -0
- package/dist/src/nile-card/__snapshots__/nile-card.test.snap.js +34 -0
- package/dist/src/nile-checkbox/__snapshots__/nile-checkbox.test.snap.js +31 -0
- package/dist/src/nile-code-editor/Old_theme copy.d.ts +191 -0
- package/dist/src/nile-code-editor/Old_theme copy.js +193 -0
- package/dist/src/nile-code-editor/Old_theme copy.js.map +1 -0
- package/dist/src/nile-code-editor/backup_nile-code-editor copy.d.ts +0 -0
- package/dist/src/nile-code-editor/backup_nile-code-editor copy.js +675 -0
- package/dist/src/nile-code-editor/backup_nile-code-editor copy.js.map +1 -0
- package/dist/src/nile-code-editor/theme copy.d.ts +191 -0
- package/dist/src/nile-code-editor/theme copy.js +193 -0
- package/dist/src/nile-code-editor/theme copy.js.map +1 -0
- package/dist/src/nile-grid/data-processor.d.ts +37 -0
- package/dist/src/nile-grid/data-processor.js +122 -0
- package/dist/src/nile-grid/data-processor.js.map +1 -0
- package/dist/src/nile-grid/event-handlers.d.ts +35 -0
- package/dist/src/nile-grid/event-handlers.js +158 -0
- package/dist/src/nile-grid/event-handlers.js.map +1 -0
- package/dist/src/nile-grid/nile-grid.css.js +6 -2
- package/dist/src/nile-grid/nile-grid.css.js.map +1 -1
- package/dist/src/nile-grid/nile-grid.d.ts +9 -3
- package/dist/src/nile-grid/nile-grid.js +96 -20
- package/dist/src/nile-grid/nile-grid.js.map +1 -1
- package/dist/src/nile-grid/nile-grid.types.d.ts +3 -0
- package/dist/src/nile-grid/nile-grid.types.js +2 -0
- package/dist/src/nile-grid/nile-grid.types.js.map +1 -0
- package/dist/src/nile-grid/nile-grid.utils.d.ts +3 -2
- package/dist/src/nile-grid/nile-grid.utils.js +223 -81
- package/dist/src/nile-grid/nile-grid.utils.js.map +1 -1
- package/dist/src/nile-grid/renderer.d.ts +8 -0
- package/dist/src/nile-grid/renderer.js +78 -0
- package/dist/src/nile-grid/renderer.js.map +1 -0
- package/dist/src/nile-grid/resize-handler.d.ts +4 -0
- package/dist/src/nile-grid/resize-handler.js +36 -0
- package/dist/src/nile-grid/resize-handler.js.map +1 -0
- package/dist/src/nile-grid/types.d.ts +32 -0
- package/dist/src/nile-grid/types.js +2 -0
- package/dist/src/nile-grid/types.js.map +1 -0
- package/dist/src/nile-grid/utils.d.ts +4 -0
- package/dist/src/nile-grid/utils.js +32 -0
- package/dist/src/nile-grid/utils.js.map +1 -0
- package/dist/src/nile-grid-body/nile-grid-body.css.js +0 -4
- package/dist/src/nile-grid-body/nile-grid-body.css.js.map +1 -1
- package/dist/src/nile-grid-body/nile-grid-body.js +1 -1
- package/dist/src/nile-grid-body/nile-grid-body.js.map +1 -1
- package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.js +17 -2
- package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.js.map +1 -1
- package/dist/src/nile-grid-cell-item/nile-grid-cell-item.d.ts +0 -3
- package/dist/src/nile-grid-cell-item/nile-grid-cell-item.js +1 -11
- package/dist/src/nile-grid-cell-item/nile-grid-cell-item.js.map +1 -1
- package/dist/src/nile-grid-head/nile-grid-head.css.js +1 -1
- package/dist/src/nile-grid-head/nile-grid-head.css.js.map +1 -1
- package/dist/src/nile-grid-head/nile-grid-head.js +1 -1
- package/dist/src/nile-grid-head/nile-grid-head.js.map +1 -1
- package/dist/src/nile-grid-head-item/nile-grid-head-item.css.js +18 -3
- package/dist/src/nile-grid-head-item/nile-grid-head-item.css.js.map +1 -1
- package/dist/src/nile-grid-head-item/nile-grid-head-item.d.ts +3 -2
- package/dist/src/nile-grid-head-item/nile-grid-head-item.js +14 -11
- package/dist/src/nile-grid-head-item/nile-grid-head-item.js.map +1 -1
- package/dist/src/nile-grid-row/nile-grid-row.css.js +17 -5
- package/dist/src/nile-grid-row/nile-grid-row.css.js.map +1 -1
- package/dist/src/nile-grid-row/nile-grid-row.d.ts +4 -1
- package/dist/src/nile-grid-row/nile-grid-row.js +19 -4
- package/dist/src/nile-grid-row/nile-grid-row.js.map +1 -1
- package/dist/src/nile-hero/__snapshots__/nile-hero.test.snap.js +47 -0
- package/dist/src/nile-icon/__snapshots__/nile-icon.test.snap.js +16 -0
- package/dist/src/nile-input/__snapshots__/nile-input.test.snap.js +75 -0
- package/dist/src/nile-popover/__snapshots__/nile-popover.test.snap.js +22 -0
- package/dist/src/nile-sidebar/index.d.ts +1 -1
- package/dist/src/nile-stepper/nile-stepper.d.ts +1 -0
- package/dist/src/nile-stepper/nile-stepper.js +61 -40
- package/dist/src/nile-stepper/nile-stepper.js.map +1 -1
- package/dist/src/nile-stepper-item/nile-stepper-item.d.ts +3 -0
- package/dist/src/nile-stepper-item/nile-stepper-item.js +14 -2
- package/dist/src/nile-stepper-item/nile-stepper-item.js.map +1 -1
- package/dist/src/nile-table-body/nile-table-body.js +2 -1
- package/dist/src/nile-table-body/nile-table-body.js.map +1 -1
- package/dist/src/nile-table-body/virtual-scroll-helper.d.ts +9 -0
- package/dist/src/nile-table-body/virtual-scroll-helper.js +24 -0
- package/dist/src/nile-table-body/virtual-scroll-helper.js.map +1 -0
- package/dist/src/nile-table-header-item/nile-table-header-item.css.js +0 -4
- package/dist/src/nile-table-header-item/nile-table-header-item.css.js.map +1 -1
- package/dist/src/nile-vertical-stepper-item/nile-vertical-stepper-item.d.ts +3 -0
- package/dist/src/nile-vertical-stepper-item/nile-vertical-stepper-item.js +14 -2
- package/dist/src/nile-vertical-stepper-item/nile-vertical-stepper-item.js.map +1 -1
- package/dist/src/nile-virtual-select/nile-virtual-select.d.ts +1 -0
- package/dist/src/nile-virtual-select/nile-virtual-select.js +18 -13
- package/dist/src/nile-virtual-select/nile-virtual-select.js.map +1 -1
- package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.d.ts +273 -0
- package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.js +1305 -0
- package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.js.map +1 -0
- package/dist/src/nile-virtual-select/virtualizer-error-handler.d.ts +21 -0
- package/dist/src/nile-virtual-select/virtualizer-error-handler.js +56 -0
- package/dist/src/nile-virtual-select/virtualizer-error-handler.js.map +1 -0
- package/dist/src/nile-virtual-table-body/index.d.ts +2 -0
- package/dist/src/nile-virtual-table-body/index.js +3 -0
- package/dist/src/nile-virtual-table-body/index.js.map +1 -0
- package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.d.ts +1 -0
- package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.js +44 -0
- package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.js.map +1 -0
- package/dist/src/nile-virtual-table-body/nile-virtual-table-body.d.ts +50 -0
- package/dist/src/nile-virtual-table-body/nile-virtual-table-body.js +135 -0
- package/dist/src/nile-virtual-table-body/nile-virtual-table-body.js.map +1 -0
- package/dist/src/nile-virtual-table-body/renderer.d.ts +16 -0
- package/dist/src/nile-virtual-table-body/renderer.js +49 -0
- package/dist/src/nile-virtual-table-body/renderer.js.map +1 -0
- package/dist/src/utilities/stepper-utils.d.ts +71 -0
- package/dist/src/utilities/stepper-utils.js +108 -0
- package/dist/src/utilities/stepper-utils.js.map +1 -0
- package/dist/src/version.js +2 -2
- package/dist/src/version.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +3 -20
- package/src/index.ts +4 -18
- package/src/nile-button/nile-button.css.ts +66 -12
- package/src/nile-grid/nile-grid.css.ts +6 -2
- package/src/nile-grid/nile-grid.ts +124 -21
- package/src/nile-grid/nile-grid.types.ts +1 -0
- package/src/nile-grid/nile-grid.utils.ts +353 -98
- package/src/nile-grid-body/nile-grid-body.css.ts +0 -4
- package/src/nile-grid-body/nile-grid-body.ts +2 -2
- package/src/nile-grid-cell-item/nile-grid-cell-item.css.ts +17 -2
- package/src/nile-grid-cell-item/nile-grid-cell-item.ts +3 -11
- package/src/nile-grid-head/nile-grid-head.css.ts +1 -1
- package/src/nile-grid-head/nile-grid-head.ts +2 -2
- package/src/nile-grid-head-item/nile-grid-head-item.css.ts +18 -3
- package/src/nile-grid-head-item/nile-grid-head-item.ts +8 -16
- package/src/nile-grid-row/nile-grid-row.css.ts +17 -5
- package/src/nile-grid-row/nile-grid-row.ts +9 -6
- package/src/nile-sidebar/index.ts +133 -0
- package/src/nile-sidebar/logo.svg +1 -0
- package/src/nile-sidebar-menu/index.ts +1 -0
- package/src/nile-sidebar-menu/nile-sidebar-menu.css.ts +52 -0
- package/src/nile-sidebar-menu/nile-sidebar-menu.ts +97 -0
- package/src/nile-sidebar-menu-items/index.ts +1 -0
- package/src/nile-sidebar-menu-items/nile-sidebar-menu-items.css.ts +50 -0
- package/src/nile-sidebar-menu-items/nile-sidebar-menu-items.ts +81 -0
- package/src/nile-sidebar-wrapper/index.ts +1 -0
- package/src/nile-sidebar-wrapper/nile-sidebar-wrapper.css.ts +119 -0
- package/src/nile-sidebar-wrapper/nile-sidebar-wrapper.ts +97 -0
- package/src/nile-stepper/nile-stepper.ts +56 -39
- package/src/nile-stepper/stepper-utils.ts +49 -0
- package/src/nile-stepper-item/nile-stepper-item.ts +6 -3
- package/src/nile-table-body/nile-table-body.ts +2 -1
- package/src/nile-table-header-item/nile-table-header-item.css.ts +0 -4
- package/src/nile-vertical-stepper-item/nile-vertical-stepper-item.ts +6 -3
- package/src/nile-virtual-select/nile-virtual-select.ts +8 -2
- package/vscode-html-custom-data.json +89 -382
- package/dist/axe.min-140df6c2.cjs.js +0 -2
- package/dist/axe.min-140df6c2.cjs.js.map +0 -1
- package/dist/axe.min-591c52c3.esm.js +0 -1
- package/dist/css-tag-3c4464f5.esm.js +0 -6
- package/dist/css-tag-b6258454.cjs.js +0 -6
- package/dist/css-tag-b6258454.cjs.js.map +0 -1
- package/dist/fixture-e3592de4.cjs.js.map +0 -1
- package/dist/flow-3e83b6f4.esm.js +0 -17
- package/dist/flow-ca47f938.cjs.js +0 -14
- package/dist/flow-ca47f938.cjs.js.map +0 -1
- package/dist/lit-html-21bc9a48.cjs.js +0 -6
- package/dist/lit-html-21bc9a48.cjs.js.map +0 -1
- package/dist/lit-html-82603fd0.esm.js +0 -6
- package/dist/nile-icon/icons/svg/ng-link-external-02.cjs.js +0 -2
- package/dist/nile-icon/icons/svg/ng-link-external-02.cjs.js.map +0 -1
- package/dist/nile-icon/icons/svg/ng-link-external-02.esm.js +0 -1
- package/dist/nile-side-bar/index.cjs.js +0 -2
- package/dist/nile-side-bar/index.cjs.js.map +0 -1
- package/dist/nile-side-bar/index.esm.js +0 -1
- package/dist/nile-side-bar/nile-side-bar.cjs.js +0 -2
- package/dist/nile-side-bar/nile-side-bar.cjs.js.map +0 -1
- package/dist/nile-side-bar/nile-side-bar.css.cjs.js +0 -2
- package/dist/nile-side-bar/nile-side-bar.css.cjs.js.map +0 -1
- package/dist/nile-side-bar/nile-side-bar.css.esm.js +0 -100
- package/dist/nile-side-bar/nile-side-bar.esm.js +0 -1
- package/dist/nile-side-bar-action/index.cjs.js +0 -2
- package/dist/nile-side-bar-action/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-action/index.esm.js +0 -1
- package/dist/nile-side-bar-action/nile-side-bar-action.cjs.js +0 -2
- package/dist/nile-side-bar-action/nile-side-bar-action.cjs.js.map +0 -1
- package/dist/nile-side-bar-action/nile-side-bar-action.css.cjs.js +0 -2
- package/dist/nile-side-bar-action/nile-side-bar-action.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-action/nile-side-bar-action.css.esm.js +0 -51
- package/dist/nile-side-bar-action/nile-side-bar-action.esm.js +0 -34
- package/dist/nile-side-bar-action-menu/index.cjs.js +0 -2
- package/dist/nile-side-bar-action-menu/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-action-menu/index.esm.js +0 -1
- package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.cjs.js +0 -2
- package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.cjs.js.map +0 -1
- package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.css.cjs.js +0 -2
- package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.css.esm.js +0 -61
- package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.esm.js +0 -40
- package/dist/nile-side-bar-action-menu-item/index.cjs.js +0 -2
- package/dist/nile-side-bar-action-menu-item/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-action-menu-item/index.esm.js +0 -1
- package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.cjs.js +0 -2
- package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.cjs.js.map +0 -1
- package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.css.cjs.js +0 -2
- package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.css.esm.js +0 -128
- package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.esm.js +0 -36
- package/dist/nile-side-bar-content/index.cjs.js +0 -2
- package/dist/nile-side-bar-content/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-content/index.esm.js +0 -1
- package/dist/nile-side-bar-content/nile-side-bar-content.cjs.js +0 -2
- package/dist/nile-side-bar-content/nile-side-bar-content.cjs.js.map +0 -1
- package/dist/nile-side-bar-content/nile-side-bar-content.css.cjs.js +0 -2
- package/dist/nile-side-bar-content/nile-side-bar-content.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-content/nile-side-bar-content.css.esm.js +0 -5
- package/dist/nile-side-bar-content/nile-side-bar-content.esm.js +0 -3
- package/dist/nile-side-bar-expand/index.cjs.js +0 -2
- package/dist/nile-side-bar-expand/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-expand/index.esm.js +0 -1
- package/dist/nile-side-bar-expand/nile-side-bar-expand.cjs.js +0 -2
- package/dist/nile-side-bar-expand/nile-side-bar-expand.cjs.js.map +0 -1
- package/dist/nile-side-bar-expand/nile-side-bar-expand.css.cjs.js +0 -2
- package/dist/nile-side-bar-expand/nile-side-bar-expand.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-expand/nile-side-bar-expand.css.esm.js +0 -33
- package/dist/nile-side-bar-expand/nile-side-bar-expand.esm.js +0 -6
- package/dist/nile-side-bar-footer/index.cjs.js +0 -2
- package/dist/nile-side-bar-footer/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-footer/index.esm.js +0 -1
- package/dist/nile-side-bar-footer/nile-side-bar-footer.cjs.js +0 -2
- package/dist/nile-side-bar-footer/nile-side-bar-footer.cjs.js.map +0 -1
- package/dist/nile-side-bar-footer/nile-side-bar-footer.css.cjs.js +0 -2
- package/dist/nile-side-bar-footer/nile-side-bar-footer.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-footer/nile-side-bar-footer.css.esm.js +0 -40
- package/dist/nile-side-bar-footer/nile-side-bar-footer.esm.js +0 -5
- package/dist/nile-side-bar-footer-icon/index.cjs.js +0 -2
- package/dist/nile-side-bar-footer-icon/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-footer-icon/index.esm.js +0 -1
- package/dist/nile-side-bar-footer-icon/nile-side-bar-footer-icon.cjs.js +0 -2
- package/dist/nile-side-bar-footer-icon/nile-side-bar-footer-icon.cjs.js.map +0 -1
- package/dist/nile-side-bar-footer-icon/nile-side-bar-footer-icon.css.cjs.js +0 -2
- package/dist/nile-side-bar-footer-icon/nile-side-bar-footer-icon.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-footer-icon/nile-side-bar-footer-icon.css.esm.js +0 -5
- package/dist/nile-side-bar-footer-icon/nile-side-bar-footer-icon.esm.js +0 -3
- package/dist/nile-side-bar-footer-item/index.cjs.js +0 -2
- package/dist/nile-side-bar-footer-item/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-footer-item/index.esm.js +0 -1
- package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.cjs.js +0 -2
- package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.cjs.js.map +0 -1
- package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.css.cjs.js +0 -2
- package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.css.esm.js +0 -72
- package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.esm.js +0 -7
- package/dist/nile-side-bar-footer-text/index.cjs.js +0 -2
- package/dist/nile-side-bar-footer-text/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-footer-text/index.esm.js +0 -1
- package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.cjs.js +0 -2
- package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.cjs.js.map +0 -1
- package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.css.cjs.js +0 -2
- package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.css.esm.js +0 -29
- package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.esm.js +0 -6
- package/dist/nile-side-bar-group/index.cjs.js +0 -2
- package/dist/nile-side-bar-group/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-group/index.esm.js +0 -1
- package/dist/nile-side-bar-group/nile-side-bar-group.cjs.js +0 -2
- package/dist/nile-side-bar-group/nile-side-bar-group.cjs.js.map +0 -1
- package/dist/nile-side-bar-group/nile-side-bar-group.css.cjs.js +0 -2
- package/dist/nile-side-bar-group/nile-side-bar-group.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-group/nile-side-bar-group.css.esm.js +0 -48
- package/dist/nile-side-bar-group/nile-side-bar-group.esm.js +0 -12
- package/dist/nile-side-bar-group-item/index.cjs.js +0 -2
- package/dist/nile-side-bar-group-item/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-group-item/index.esm.js +0 -1
- package/dist/nile-side-bar-group-item/nile-side-bar-group-item.cjs.js +0 -2
- package/dist/nile-side-bar-group-item/nile-side-bar-group-item.cjs.js.map +0 -1
- package/dist/nile-side-bar-group-item/nile-side-bar-group-item.css.cjs.js +0 -2
- package/dist/nile-side-bar-group-item/nile-side-bar-group-item.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-group-item/nile-side-bar-group-item.css.esm.js +0 -54
- package/dist/nile-side-bar-group-item/nile-side-bar-group-item.esm.js +0 -37
- package/dist/nile-side-bar-group-item-content/index.cjs.js +0 -2
- package/dist/nile-side-bar-group-item-content/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-group-item-content/index.esm.js +0 -1
- package/dist/nile-side-bar-group-item-content/nile-side-bar-group-item-content.cjs.js +0 -2
- package/dist/nile-side-bar-group-item-content/nile-side-bar-group-item-content.cjs.js.map +0 -1
- package/dist/nile-side-bar-group-item-content/nile-side-bar-group-item-content.css.cjs.js +0 -2
- package/dist/nile-side-bar-group-item-content/nile-side-bar-group-item-content.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-group-item-content/nile-side-bar-group-item-content.css.esm.js +0 -5
- package/dist/nile-side-bar-group-item-content/nile-side-bar-group-item-content.esm.js +0 -3
- package/dist/nile-side-bar-group-item-icon/index.cjs.js +0 -2
- package/dist/nile-side-bar-group-item-icon/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-group-item-icon/index.esm.js +0 -1
- package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.cjs.js +0 -2
- package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.cjs.js.map +0 -1
- package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.css.cjs.js +0 -2
- package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.css.esm.js +0 -31
- package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.esm.js +0 -11
- package/dist/nile-side-bar-group-item-text/index.cjs.js +0 -2
- package/dist/nile-side-bar-group-item-text/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-group-item-text/index.esm.js +0 -1
- package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.cjs.js +0 -2
- package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.cjs.js.map +0 -1
- package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.cjs.js +0 -2
- package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.esm.js +0 -24
- package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.esm.js +0 -1
- package/dist/nile-side-bar-header/index.cjs.js +0 -2
- package/dist/nile-side-bar-header/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-header/index.esm.js +0 -1
- package/dist/nile-side-bar-header/nile-side-bar-header.cjs.js +0 -2
- package/dist/nile-side-bar-header/nile-side-bar-header.cjs.js.map +0 -1
- package/dist/nile-side-bar-header/nile-side-bar-header.css.cjs.js +0 -2
- package/dist/nile-side-bar-header/nile-side-bar-header.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-header/nile-side-bar-header.css.esm.js +0 -52
- package/dist/nile-side-bar-header/nile-side-bar-header.esm.js +0 -6
- package/dist/nile-side-bar-logo/index.cjs.js +0 -2
- package/dist/nile-side-bar-logo/index.cjs.js.map +0 -1
- package/dist/nile-side-bar-logo/index.esm.js +0 -1
- package/dist/nile-side-bar-logo/nile-side-bar-logo.cjs.js +0 -2
- package/dist/nile-side-bar-logo/nile-side-bar-logo.cjs.js.map +0 -1
- package/dist/nile-side-bar-logo/nile-side-bar-logo.css.cjs.js +0 -2
- package/dist/nile-side-bar-logo/nile-side-bar-logo.css.cjs.js.map +0 -1
- package/dist/nile-side-bar-logo/nile-side-bar-logo.css.esm.js +0 -35
- package/dist/nile-side-bar-logo/nile-side-bar-logo.esm.js +0 -4
- package/dist/scopedElementsWrapper-abad3c53.cjs.js +0 -2
- package/dist/scopedElementsWrapper-abad3c53.cjs.js.map +0 -1
- package/dist/scopedElementsWrapper-ef11f868.esm.js +0 -1
- package/dist/sinon-esm-283dcc9b.cjs.js +0 -2
- package/dist/sinon-esm-283dcc9b.cjs.js.map +0 -1
- package/dist/sinon-esm-abe9b0ec.esm.js +0 -1
- package/dist/src/nile-icon/icons/svg/ng-link-external-02.d.ts +0 -5
- package/dist/src/nile-icon/icons/svg/ng-link-external-02.js +0 -5
- package/dist/src/nile-icon/icons/svg/ng-link-external-02.js.map +0 -1
- package/dist/src/nile-side-bar/index.d.ts +0 -1
- package/dist/src/nile-side-bar/index.js +0 -2
- package/dist/src/nile-side-bar/index.js.map +0 -1
- package/dist/src/nile-side-bar/nile-side-bar.css.d.ts +0 -12
- package/dist/src/nile-side-bar/nile-side-bar.css.js +0 -112
- package/dist/src/nile-side-bar/nile-side-bar.css.js.map +0 -1
- package/dist/src/nile-side-bar/nile-side-bar.d.ts +0 -40
- package/dist/src/nile-side-bar/nile-side-bar.js +0 -67
- package/dist/src/nile-side-bar/nile-side-bar.js.map +0 -1
- package/dist/src/nile-side-bar-action/index.d.ts +0 -1
- package/dist/src/nile-side-bar-action/index.js +0 -2
- package/dist/src/nile-side-bar-action/index.js.map +0 -1
- package/dist/src/nile-side-bar-action/nile-side-bar-action.css.d.ts +0 -3
- package/dist/src/nile-side-bar-action/nile-side-bar-action.css.js +0 -54
- package/dist/src/nile-side-bar-action/nile-side-bar-action.css.js.map +0 -1
- package/dist/src/nile-side-bar-action/nile-side-bar-action.d.ts +0 -75
- package/dist/src/nile-side-bar-action/nile-side-bar-action.js +0 -338
- package/dist/src/nile-side-bar-action/nile-side-bar-action.js.map +0 -1
- package/dist/src/nile-side-bar-action-menu/index.d.ts +0 -1
- package/dist/src/nile-side-bar-action-menu/index.js +0 -2
- package/dist/src/nile-side-bar-action-menu/index.js.map +0 -1
- package/dist/src/nile-side-bar-action-menu/nile-side-bar-action-menu.css.d.ts +0 -12
- package/dist/src/nile-side-bar-action-menu/nile-side-bar-action-menu.css.js +0 -73
- package/dist/src/nile-side-bar-action-menu/nile-side-bar-action-menu.css.js.map +0 -1
- package/dist/src/nile-side-bar-action-menu/nile-side-bar-action-menu.d.ts +0 -49
- package/dist/src/nile-side-bar-action-menu/nile-side-bar-action-menu.js +0 -223
- package/dist/src/nile-side-bar-action-menu/nile-side-bar-action-menu.js.map +0 -1
- package/dist/src/nile-side-bar-action-menu-item/index.d.ts +0 -1
- package/dist/src/nile-side-bar-action-menu-item/index.js +0 -2
- package/dist/src/nile-side-bar-action-menu-item/index.js.map +0 -1
- package/dist/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.css.d.ts +0 -12
- package/dist/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.css.js +0 -140
- package/dist/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.css.js.map +0 -1
- package/dist/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.d.ts +0 -64
- package/dist/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.js +0 -198
- package/dist/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.js.map +0 -1
- package/dist/src/nile-side-bar-content/index.d.ts +0 -1
- package/dist/src/nile-side-bar-content/index.js +0 -2
- package/dist/src/nile-side-bar-content/index.js.map +0 -1
- package/dist/src/nile-side-bar-content/nile-side-bar-content.css.d.ts +0 -12
- package/dist/src/nile-side-bar-content/nile-side-bar-content.css.js +0 -17
- package/dist/src/nile-side-bar-content/nile-side-bar-content.css.js.map +0 -1
- package/dist/src/nile-side-bar-content/nile-side-bar-content.d.ts +0 -32
- package/dist/src/nile-side-bar-content/nile-side-bar-content.js +0 -43
- package/dist/src/nile-side-bar-content/nile-side-bar-content.js.map +0 -1
- package/dist/src/nile-side-bar-expand/index.d.ts +0 -1
- package/dist/src/nile-side-bar-expand/index.js +0 -2
- package/dist/src/nile-side-bar-expand/index.js.map +0 -1
- package/dist/src/nile-side-bar-expand/nile-side-bar-expand.css.d.ts +0 -12
- package/dist/src/nile-side-bar-expand/nile-side-bar-expand.css.js +0 -45
- package/dist/src/nile-side-bar-expand/nile-side-bar-expand.css.js.map +0 -1
- package/dist/src/nile-side-bar-expand/nile-side-bar-expand.d.ts +0 -21
- package/dist/src/nile-side-bar-expand/nile-side-bar-expand.js +0 -55
- package/dist/src/nile-side-bar-expand/nile-side-bar-expand.js.map +0 -1
- package/dist/src/nile-side-bar-footer/index.d.ts +0 -1
- package/dist/src/nile-side-bar-footer/index.js +0 -2
- package/dist/src/nile-side-bar-footer/index.js.map +0 -1
- package/dist/src/nile-side-bar-footer/nile-side-bar-footer.css.d.ts +0 -6
- package/dist/src/nile-side-bar-footer/nile-side-bar-footer.css.js +0 -46
- package/dist/src/nile-side-bar-footer/nile-side-bar-footer.css.js.map +0 -1
- package/dist/src/nile-side-bar-footer/nile-side-bar-footer.d.ts +0 -26
- package/dist/src/nile-side-bar-footer/nile-side-bar-footer.js +0 -37
- package/dist/src/nile-side-bar-footer/nile-side-bar-footer.js.map +0 -1
- package/dist/src/nile-side-bar-footer-icon/index.d.ts +0 -1
- package/dist/src/nile-side-bar-footer-icon/index.js +0 -2
- package/dist/src/nile-side-bar-footer-icon/index.js.map +0 -1
- package/dist/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.css.d.ts +0 -12
- package/dist/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.css.js +0 -17
- package/dist/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.css.js.map +0 -1
- package/dist/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.d.ts +0 -32
- package/dist/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.js +0 -43
- package/dist/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.js.map +0 -1
- package/dist/src/nile-side-bar-footer-item/index.d.ts +0 -1
- package/dist/src/nile-side-bar-footer-item/index.js +0 -2
- package/dist/src/nile-side-bar-footer-item/index.js.map +0 -1
- package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.css.d.ts +0 -3
- package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.css.js +0 -75
- package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.css.js.map +0 -1
- package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.d.ts +0 -27
- package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.js +0 -46
- package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.js.map +0 -1
- package/dist/src/nile-side-bar-footer-text/index.d.ts +0 -1
- package/dist/src/nile-side-bar-footer-text/index.js +0 -2
- package/dist/src/nile-side-bar-footer-text/index.js.map +0 -1
- package/dist/src/nile-side-bar-footer-text/nile-side-bar-footer-text.css.d.ts +0 -3
- package/dist/src/nile-side-bar-footer-text/nile-side-bar-footer-text.css.js +0 -32
- package/dist/src/nile-side-bar-footer-text/nile-side-bar-footer-text.css.js.map +0 -1
- package/dist/src/nile-side-bar-footer-text/nile-side-bar-footer-text.d.ts +0 -30
- package/dist/src/nile-side-bar-footer-text/nile-side-bar-footer-text.js +0 -53
- package/dist/src/nile-side-bar-footer-text/nile-side-bar-footer-text.js.map +0 -1
- package/dist/src/nile-side-bar-group/index.d.ts +0 -1
- package/dist/src/nile-side-bar-group/index.js +0 -2
- package/dist/src/nile-side-bar-group/index.js.map +0 -1
- package/dist/src/nile-side-bar-group/nile-side-bar-group.css.d.ts +0 -6
- package/dist/src/nile-side-bar-group/nile-side-bar-group.css.js +0 -54
- package/dist/src/nile-side-bar-group/nile-side-bar-group.css.js.map +0 -1
- package/dist/src/nile-side-bar-group/nile-side-bar-group.d.ts +0 -42
- package/dist/src/nile-side-bar-group/nile-side-bar-group.js +0 -76
- package/dist/src/nile-side-bar-group/nile-side-bar-group.js.map +0 -1
- package/dist/src/nile-side-bar-group-item/index.d.ts +0 -1
- package/dist/src/nile-side-bar-group-item/index.js +0 -2
- package/dist/src/nile-side-bar-group-item/index.js.map +0 -1
- package/dist/src/nile-side-bar-group-item/nile-side-bar-group-item.css.d.ts +0 -12
- package/dist/src/nile-side-bar-group-item/nile-side-bar-group-item.css.js +0 -66
- package/dist/src/nile-side-bar-group-item/nile-side-bar-group-item.css.js.map +0 -1
- package/dist/src/nile-side-bar-group-item/nile-side-bar-group-item.d.ts +0 -54
- package/dist/src/nile-side-bar-group-item/nile-side-bar-group-item.js +0 -143
- package/dist/src/nile-side-bar-group-item/nile-side-bar-group-item.js.map +0 -1
- package/dist/src/nile-side-bar-group-item-content/index.d.ts +0 -1
- package/dist/src/nile-side-bar-group-item-content/index.js +0 -2
- package/dist/src/nile-side-bar-group-item-content/index.js.map +0 -1
- package/dist/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.css.d.ts +0 -12
- package/dist/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.css.js +0 -17
- package/dist/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.css.js.map +0 -1
- package/dist/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.d.ts +0 -32
- package/dist/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.js +0 -43
- package/dist/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.js.map +0 -1
- package/dist/src/nile-side-bar-group-item-icon/index.d.ts +0 -1
- package/dist/src/nile-side-bar-group-item-icon/index.js +0 -2
- package/dist/src/nile-side-bar-group-item-icon/index.js.map +0 -1
- package/dist/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.css.d.ts +0 -3
- package/dist/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.css.js +0 -34
- package/dist/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.css.js.map +0 -1
- package/dist/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.d.ts +0 -40
- package/dist/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.js +0 -89
- package/dist/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.js.map +0 -1
- package/dist/src/nile-side-bar-group-item-text/index.d.ts +0 -1
- package/dist/src/nile-side-bar-group-item-text/index.js +0 -2
- package/dist/src/nile-side-bar-group-item-text/index.js.map +0 -1
- package/dist/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.d.ts +0 -6
- package/dist/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.js +0 -30
- package/dist/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.js.map +0 -1
- package/dist/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.d.ts +0 -30
- package/dist/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.js +0 -42
- package/dist/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.js.map +0 -1
- package/dist/src/nile-side-bar-header/index.d.ts +0 -1
- package/dist/src/nile-side-bar-header/index.js +0 -2
- package/dist/src/nile-side-bar-header/index.js.map +0 -1
- package/dist/src/nile-side-bar-header/nile-side-bar-header.css.d.ts +0 -12
- package/dist/src/nile-side-bar-header/nile-side-bar-header.css.js +0 -64
- package/dist/src/nile-side-bar-header/nile-side-bar-header.css.js.map +0 -1
- package/dist/src/nile-side-bar-header/nile-side-bar-header.d.ts +0 -32
- package/dist/src/nile-side-bar-header/nile-side-bar-header.js +0 -46
- package/dist/src/nile-side-bar-header/nile-side-bar-header.js.map +0 -1
- package/dist/src/nile-side-bar-logo/index.d.ts +0 -1
- package/dist/src/nile-side-bar-logo/index.js +0 -2
- package/dist/src/nile-side-bar-logo/index.js.map +0 -1
- package/dist/src/nile-side-bar-logo/nile-side-bar-logo.css.d.ts +0 -12
- package/dist/src/nile-side-bar-logo/nile-side-bar-logo.css.js +0 -47
- package/dist/src/nile-side-bar-logo/nile-side-bar-logo.css.js.map +0 -1
- package/dist/src/nile-side-bar-logo/nile-side-bar-logo.d.ts +0 -34
- package/dist/src/nile-side-bar-logo/nile-side-bar-logo.js +0 -53
- package/dist/src/nile-side-bar-logo/nile-side-bar-logo.js.map +0 -1
- package/dist/src/nile-side-bar-menu/index.d.ts +0 -1
- package/dist/src/nile-side-bar-menu/index.js +0 -2
- package/dist/src/nile-side-bar-menu/index.js.map +0 -1
- package/dist/src/nile-side-bar-menu/nile-side-bar-menu.css.d.ts +0 -12
- package/dist/src/nile-side-bar-menu/nile-side-bar-menu.css.js +0 -17
- package/dist/src/nile-side-bar-menu/nile-side-bar-menu.css.js.map +0 -1
- package/dist/src/nile-side-bar-menu/nile-side-bar-menu.d.ts +0 -32
- package/dist/src/nile-side-bar-menu/nile-side-bar-menu.js +0 -43
- package/dist/src/nile-side-bar-menu/nile-side-bar-menu.js.map +0 -1
- package/dist/src/nile-side-bar-menu-item/index.d.ts +0 -1
- package/dist/src/nile-side-bar-menu-item/index.js +0 -2
- package/dist/src/nile-side-bar-menu-item/index.js.map +0 -1
- package/dist/src/nile-side-bar-menu-item/nile-side-bar-menu-item.css.d.ts +0 -12
- package/dist/src/nile-side-bar-menu-item/nile-side-bar-menu-item.css.js +0 -17
- package/dist/src/nile-side-bar-menu-item/nile-side-bar-menu-item.css.js.map +0 -1
- package/dist/src/nile-side-bar-menu-item/nile-side-bar-menu-item.d.ts +0 -32
- package/dist/src/nile-side-bar-menu-item/nile-side-bar-menu-item.js +0 -43
- package/dist/src/nile-side-bar-menu-item/nile-side-bar-menu-item.js.map +0 -1
- package/dist/src/nile-table-row-content/index.d.ts +0 -1
- package/dist/src/nile-table-row-content/index.js +0 -2
- package/dist/src/nile-table-row-content/index.js.map +0 -1
- package/dist/src/nile-table-row-content/nile-table-row-content.css.d.ts +0 -12
- package/dist/src/nile-table-row-content/nile-table-row-content.css.js +0 -30
- package/dist/src/nile-table-row-content/nile-table-row-content.css.js.map +0 -1
- package/dist/src/nile-table-row-content/nile-table-row-content.d.ts +0 -32
- package/dist/src/nile-table-row-content/nile-table-row-content.js +0 -46
- package/dist/src/nile-table-row-content/nile-table-row-content.js.map +0 -1
- package/dist/src/nile-test/index.d.ts +0 -1
- package/dist/src/nile-test/index.js +0 -2
- package/dist/src/nile-test/index.js.map +0 -1
- package/dist/src/nile-test/nile-test.css.d.ts +0 -12
- package/dist/src/nile-test/nile-test.css.js +0 -17
- package/dist/src/nile-test/nile-test.css.js.map +0 -1
- package/dist/src/nile-test/nile-test.d.ts +0 -32
- package/dist/src/nile-test/nile-test.js +0 -43
- package/dist/src/nile-test/nile-test.js.map +0 -1
- package/dist/src/nile-tooltip/nile-tooltip-utils.d.ts +0 -18
- package/dist/src/nile-tooltip/nile-tooltip-utils.js +0 -216
- package/dist/src/nile-tooltip/nile-tooltip-utils.js.map +0 -1
- package/dist/src/nile-tooltip/nile-tooltip.test.d.ts +0 -1
- package/dist/src/nile-tooltip/nile-tooltip.test.js +0 -148
- package/dist/src/nile-tooltip/nile-tooltip.test.js.map +0 -1
- package/dist/virtualize-73f68d08.esm.js +0 -22
- package/dist/virtualize-eb33a9a0.cjs.js +0 -18
- package/dist/virtualize-eb33a9a0.cjs.js.map +0 -1
- package/src/nile-side-bar/index.ts +0 -1
- package/src/nile-side-bar/nile-side-bar.css.ts +0 -114
- package/src/nile-side-bar/nile-side-bar.ts +0 -66
- package/src/nile-side-bar-action/index.ts +0 -1
- package/src/nile-side-bar-action/nile-side-bar-action.css.ts +0 -55
- package/src/nile-side-bar-action/nile-side-bar-action.ts +0 -367
- package/src/nile-side-bar-action-menu/index.ts +0 -1
- package/src/nile-side-bar-action-menu/nile-side-bar-action-menu.css.ts +0 -75
- package/src/nile-side-bar-action-menu/nile-side-bar-action-menu.ts +0 -239
- package/src/nile-side-bar-action-menu-item/index.ts +0 -1
- package/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.css.ts +0 -142
- package/src/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.ts +0 -203
- package/src/nile-side-bar-content/index.ts +0 -1
- package/src/nile-side-bar-content/nile-side-bar-content.css.ts +0 -19
- package/src/nile-side-bar-content/nile-side-bar-content.ts +0 -54
- package/src/nile-side-bar-expand/index.ts +0 -1
- package/src/nile-side-bar-expand/nile-side-bar-expand.css.ts +0 -47
- package/src/nile-side-bar-expand/nile-side-bar-expand.ts +0 -55
- package/src/nile-side-bar-footer/index.ts +0 -1
- package/src/nile-side-bar-footer/nile-side-bar-footer.css.ts +0 -47
- package/src/nile-side-bar-footer/nile-side-bar-footer.ts +0 -42
- package/src/nile-side-bar-footer-icon/index.ts +0 -1
- package/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.css.ts +0 -19
- package/src/nile-side-bar-footer-icon/nile-side-bar-footer-icon.ts +0 -54
- package/src/nile-side-bar-footer-item/index.ts +0 -1
- package/src/nile-side-bar-footer-item/nile-side-bar-footer-item.css.ts +0 -76
- package/src/nile-side-bar-footer-item/nile-side-bar-footer-item.ts +0 -45
- package/src/nile-side-bar-footer-text/index.ts +0 -1
- package/src/nile-side-bar-footer-text/nile-side-bar-footer-text.css.ts +0 -33
- package/src/nile-side-bar-footer-text/nile-side-bar-footer-text.ts +0 -51
- package/src/nile-side-bar-group/index.ts +0 -1
- package/src/nile-side-bar-group/nile-side-bar-group.css.ts +0 -55
- package/src/nile-side-bar-group/nile-side-bar-group.ts +0 -74
- package/src/nile-side-bar-group-item/index.ts +0 -1
- package/src/nile-side-bar-group-item/nile-side-bar-group-item.css.ts +0 -68
- package/src/nile-side-bar-group-item/nile-side-bar-group-item.ts +0 -146
- package/src/nile-side-bar-group-item-content/index.ts +0 -1
- package/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.css.ts +0 -19
- package/src/nile-side-bar-group-item-content/nile-side-bar-group-item-content.ts +0 -54
- package/src/nile-side-bar-group-item-icon/index.ts +0 -1
- package/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.css.ts +0 -35
- package/src/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.ts +0 -97
- package/src/nile-side-bar-group-item-text/index.ts +0 -1
- package/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.ts +0 -31
- package/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.ts +0 -49
- package/src/nile-side-bar-header/index.ts +0 -1
- package/src/nile-side-bar-header/nile-side-bar-header.css.ts +0 -66
- package/src/nile-side-bar-header/nile-side-bar-header.ts +0 -57
- package/src/nile-side-bar-logo/index.ts +0 -1
- package/src/nile-side-bar-logo/nile-side-bar-logo.css.ts +0 -49
- 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":"AAAA;;;;;GAKG;AAKH,MAAM,OAAO,iBAAiB;IAS5B,YAAY,OAAoB,EAAE,aAAgC;QAN1D,iBAAY,GAAkB,EAAE,CAAC;QACjC,eAAU,GAAY,KAAK,CAAC;QAC5B,mBAAc,GAAyB,IAAI,CAAC;QAC5C,eAAU,GAAW,CAAC,CAAC;QACvB,mBAAc,GAAW,CAAC,CAAC;QAGjC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;IACrC,CAAC;IAED,UAAU,CAAC,OAAoB;QAC7B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IACzC,CAAC;IAED,aAAa,CAAC,KAAoB;QAChC,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,IAAI,KAAK,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YACzD,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;IAED,WAAW,CAAC,KAAiB,EAAE,sBAAkC;QAC/D,IAAI,IAAI,CAAC,OAAO,CAAC,sBAAsB,EAAE,CAAC;YACxC,sBAAsB,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,gBAAgB,CAAC,MAAqB,EAAE,MAA0D;QAChG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa;YAAE,OAAO;QAExC,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;QACvD,MAAM,gBAAgB,GAAG,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE,CAAC;QAE/D,IAAI,YAA4B,CAAC;QACjC,IAAI,YAAY,KAAK,MAAM,CAAC,KAAK,EAAE,CAAC;YAClC,YAAY,GAAG,gBAAgB,KAAK,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC;QAC7D,CAAC;aAAM,CAAC;YACN,YAAY,GAAG,KAAK,CAAC;QACvB,CAAC;QAED,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC;QAElD,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;IACrC,CAAC;IAED,kBAAkB,CAAC,MAAqB,EAAE,KAAa,EAAE,QAAoB;QAC3E,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,eAAe;YAAE,OAAO;QAE1C,MAAM,CAAC,WAAW,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACxC,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;QAErC,QAAQ,EAAE,CAAC;IACb,CAAC;IAED,kBAAkB,CAAC,GAAgB,EAAE,KAAY,EAAE,WAA0B,EAAE,iBAA6B;QAC1G,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,kBAAkB;YAAE,OAAO;QAE7C,MAAM,QAAQ,GAAG,KAAK,CAAC,MAA0B,CAAC;QAElD,IAAI,IAAI,CAAC,OAAO,CAAC,uBAAuB,EAAE,CAAC;YACzC,IAAI,QAAQ,CAAC,OAAO,EAAE,CAAC;gBACrB,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC;oBAClD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;oBAC5B,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACtB,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC;gBAChE,IAAI,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC;oBACf,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;oBACnC,GAAG,CAAC,QAAQ,GAAG,KAAK,CAAC;gBACvB,CAAC;YACH,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YAClD,kCAAkC;YAClC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBACtB,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;YAC1D,CAAC,CAAC,CAAC;QACL,CAAC;QAED,iBAAiB,EAAE,CAAC;IACtB,CAAC;IAED,2BAA2B,CAAC,KAAY,EAAE,WAA0B,EAAE,iBAA6B;QACjG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,kBAAkB;YAAE,OAAO;QAE7C,MAAM,QAAQ,GAAG,KAAK,CAAC,MAA0B,CAAC;QAClD,MAAM,SAAS,GAAG,QAAQ,CAAC,OAAO,CAAC;QAEnC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACxB,GAAG,CAAC,QAAQ,GAAG,SAAS,CAAC;QAC3B,CAAC,CAAC,CAAC;QAEH,IAAI,SAAS,EAAE,CAAC;YACd,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,WAAW,CAAC,CAAC;QACvC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACzB,CAAC;QAED,iBAAiB,EAAE,CAAC;IACtB,CAAC;IAED,cAAc,CAAC,GAAgB,EAAE,KAAY;QAC3C,IAAI,IAAI,CAAC,OAAO,CAAC,yBAAyB;YAAE,OAAO;QAEnD,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;QAC3C,IAAI,MAAM,CAAC,OAAO,KAAK,OAAO,IAAI,MAAM,CAAC,OAAO,CAAC,gBAAgB,CAAC;YAAE,OAAO;QAE3E,uBAAuB;QACvB,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC;IACnD,CAAC;IAED,cAAc,CAAC,GAAgB,EAAE,MAAqB,EAAE,KAAU,EAAE,UAA2F;QAC7J,IAAI,CAAC,MAAM,CAAC,QAAQ;YAAE,OAAO;QAE7B,MAAM,QAAQ,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACnC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;QAE1B,UAAU,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;IAC3C,CAAC;IAED,uBAAuB,CAAC,MAAqB,EAAE,KAAiB;QAC9D,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,kBAAkB;YAAE,OAAO;QAE7C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;QAC7B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC;QAChC,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,KAAK,IAAI,GAAG,CAAC;QAE1C,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAC/E,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAC9E,CAAC;IAEO,sBAAsB,CAAC,KAAiB;QAC9C,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,cAAc;YAAE,OAAO;QAErD,MAAM,MAAM,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CACvB,IAAI,CAAC,cAAc,CAAC,QAAQ,IAAI,EAAE,EAClC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,IAAI,GAAG,EAAE,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,CAC5E,CAAC;QAEF,IAAI,CAAC,cAAc,CAAC,KAAK,GAAG,QAAQ,CAAC;IACvC,CAAC;IAEO,qBAAqB;QAC3B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAE3B,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAClF,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACjF,CAAC;IAEO,wBAAwB,CAAC,GAAW;QAC1C,iCAAiC;QACjC,IAAI,CAAC,IAAI,CAAC,0BAA0B,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;IACjD,CAAC;IAEO,IAAI,CAAC,SAAiB,EAAE,MAAW;QACzC,iDAAiD;QACjD,+DAA+D;IACjE,CAAC;IAED,UAAU;IACV,eAAe;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,iBAAiB;QACf,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;CACF","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:
|
|
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
|
|
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
|
-
|
|
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 = [
|
|
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
|
-
|
|
35
|
-
|
|
36
|
-
|
|
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
|
-
|
|
103
|
+
this.columnWidths[col] = newW;
|
|
40
104
|
}
|
|
41
|
-
this.
|
|
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.
|
|
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
|
-
|
|
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);
|