@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
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"nile-grid.js","sourceRoot":"","sources":["../../../src/nile-grid/nile-grid.ts"],"names":[],"mappings":"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","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 { LitElement, html, CSSResultArray, TemplateResult } from 'lit';\nimport { customElement, property, query, state } from 'lit/decorators.js';\nimport { styles } from './nile-grid.css';\nimport NileElement from '../internal/nile-element';\nimport {\n resizeLinesHandler,\n listenToEventListeners,\n removeEventListeners,\n getHead,\n getBody,\n rebuildTemplate,\n applyTemplate,\n layout,\n} from './nile-grid.utils';\n\n/**\n * Nile grid component.\n *\n * @tag nile-grid\n *\n */\n@customElement('nile-grid')\nexport class NileGrid extends NileElement {\n /**\n * The styles for nile-grid\n * @remarks If you are extending this class you can extend the base styles with super. Eg `return [super(), myCustomStyles]`\n */\n public static get styles(): CSSResultArray {\n return [styles];\n }\n /** User can pass custom widths for the columns */\n @property({ type: Array, attribute: true }) customWidths: number[] = [];\n\n /** To set the grid template columns in rebuildTemplate method */\n @state() public colTemplate = '';\n\n /** To store the column widths in the beginning and after resizing */\n @state() private columnWidths: number[] = [...this.customWidths];\n\n /** To get the slot element */\n @query('slot') private slotEl!: HTMLSlotElement;\n\n /** To get the first resize line to show the resize handle */\n @query('.nile-resize-start') resizeStart: HTMLElement;\n\n /** To get the last resize line to show the resize handle */\n @query('.nile-resize-end') resizeEnd: HTMLElement;\n\n /** To store the mutation observer */\n private mo?: MutationObserver;\n\n /** To store the request animation frame */\n private raf = 0;\n\n private scheduleLayout() {\n if (this.raf) cancelAnimationFrame(this.raf);\n this.raf = requestAnimationFrame(() => {\n this.raf = 0;\n layout(\n this,\n this.slotEl,\n this.ensureWidths.bind(this),\n rebuildTemplate,\n applyTemplate,\n this.columnWidths\n );\n });\n }\n\n private ensureWidths(colCount: number) {\n if (this.columnWidths.length !== colCount) {\n this.columnWidths = Array(colCount).fill('');\n }\n }\n\n private onResize = (e: Event) => {\n const { col, widthPx } = (e as CustomEvent).detail as {\n col: number;\n widthPx: number;\n };\n let w: any;\n const floor = 60;\n\n if (\n (e.target as HTMLElement).getAttribute('colspan') &&\n parseInt((e.target as HTMLElement).getAttribute('colspan')!) > 1\n ) {\n w = Math.max(floor, Math.round(widthPx - this.columnWidths[col - 1]));\n } else {\n w = Math.max(floor, Math.round(widthPx));\n }\n this.columnWidths[col] = w;\n resizeLinesHandler(\n this.resizeStart,\n this.resizeEnd,\n col,\n widthPx,\n this.scrollHeight,\n this.columnWidths,\n e\n );\n this.colTemplate = rebuildTemplate(\n this.columnWidths.length,\n this.columnWidths\n );\n applyTemplate(getHead(this.slotEl), getBody(this.slotEl), this.colTemplate);\n };\n\n protected firstUpdated() {\n this.setAttribute('role', 'table');\n listenToEventListeners(\n this,\n this.onResize,\n this.slotEl,\n this._attachObserverAndLayout.bind(this)\n );\n }\n\n private _attachObserverAndLayout() {\n this.mo?.disconnect();\n this.mo = new MutationObserver(() => {\n this.scheduleLayout();\n });\n\n const head = getHead(this.slotEl);\n const body = getBody(this.slotEl);\n if (!head && !body) return;\n\n const target = body ?? this;\n this.mo.observe(target, {\n subtree: true,\n childList: true,\n attributes: true,\n attributeFilter: ['colspan', 'rowspan'],\n });\n layout(\n this,\n this.slotEl,\n this.ensureWidths.bind(this),\n rebuildTemplate,\n applyTemplate,\n this.columnWidths\n );\n }\n\n public render(): TemplateResult {\n return html`\n <div>\n <slot></slot>\n <div class=\"nile-resize-start\"></div>\n <div class=\"nile-resize-end\"></div>\n </div>\n `;\n }\n\n disconnectedCallback(): void {\n super.disconnectedCallback?.();\n this.mo?.disconnect();\n\n if (this.raf) cancelAnimationFrame(this.raf);\n removeEventListeners(\n this,\n this.onResize,\n this.slotEl,\n this._attachObserverAndLayout.bind(this)\n );\n }\n\n /* #endregion */\n}\n\nexport default NileGrid;\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'nile-grid': NileGrid;\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"nile-grid.js","sourceRoot":"","sources":["../../../src/nile-grid/nile-grid.ts"],"names":[],"mappings":"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","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 { html, CSSResultArray, TemplateResult } from 'lit';\nimport { customElement, property, query, state } from 'lit/decorators.js';\nimport { styles } from './nile-grid.css';\nimport NileElement from '../internal/nile-element';\nimport {\n resizeLinesHandler,\n listenToEventListeners,\n removeEventListeners,\n getHead,\n getBody,\n rebuildTemplate,\n applyTemplate,\n layout,\n applyColumnsTemplate,\n} from './nile-grid.utils';\n\n/**\n * Nile grid component.\n *\n * @tag nile-grid\n *\n */\n@customElement('nile-grid')\nexport class NileGrid extends NileElement {\n /**\n * The styles for nile-grid\n * @remarks If you are extending this class you can extend the base styles with super. Eg `return [super(), myCustomStyles]`\n */\n public static get styles(): CSSResultArray {\n return [styles];\n }\n\n /** To set the grid template columns in rebuildTemplate method */\n @state() public colTemplate = '';\n\n /** To store the column widths in the beginning and after resizing */\n @state() public columnWidths: number[] = [];\n\n /** To get the slot element */\n @query('slot') private slotEl!: HTMLSlotElement;\n\n /** To get the first resize line to show the resize handle */\n @query('.nile-resize-start') resizeStart: HTMLElement;\n\n /** To get the last resize line to show the resize handle */\n @query('.nile-resize-end') resizeEnd: HTMLElement;\n\n /** To enable horizontal scrolling when user is resizing */\n @property({ type: Boolean, attribute: true, reflect: true })\n enableResizeScroll: boolean = false;\n\n /** To store the mutation observer */\n private mo?: MutationObserver;\n\n /** To store the resize observer */\n private resizeObserver?: ResizeObserver;\n\n /** To store the request animation frame */\n private raf = 0;\n\n /** To store the sticky index's */\n @state() public stickyLeftIndexes: number[] = [];\n\n /** To store the sticky index's */\n @state() public stickyRightIndexes: number[] = [];\n\n private scheduleLayout() {\n if (this.raf) cancelAnimationFrame(this.raf);\n this.raf = requestAnimationFrame(() => {\n this.raf = 0;\n layout(\n this,\n this.slotEl,\n this.ensureWidths.bind(this),\n rebuildTemplate,\n applyTemplate,\n this.stickyLeftIndexes,\n this.stickyRightIndexes\n );\n });\n }\n\n private ensureWidths(colCount: number) {\n if (this.columnWidths.length !== colCount) {\n this.columnWidths = Array(colCount).fill('');\n }\n }\n\n private onResize = (e: Event) => {\n const { col, widthPx } = (e as CustomEvent).detail as {\n col: number;\n widthPx: number;\n };\n\n const floor = 60;\n const tgt = e.target as HTMLElement;\n const hasSpan =\n !!tgt.getAttribute('colspan') &&\n parseInt(tgt.getAttribute('colspan')!, 10) > 1;\n\n const prevW = this.columnWidths[col] ?? floor;\n const newWraw = hasSpan\n ? widthPx - (this.columnWidths[col - 1] ?? 0)\n : widthPx;\n\n const newW = Math.max(\n floor,\n Math.round(Number.isFinite(newWraw) ? newWraw : prevW)\n );\n\n let delta = newW - prevW;\n\n if (delta === 0) {\n resizeLinesHandler(\n this.resizeStart,\n this.resizeEnd,\n col,\n this.scrollHeight,\n this.columnWidths,\n );\n return;\n }\n\n const takeFromRight = (start: number, needInit: number) => {\n let need = needInit;\n for (let i = start; i < this.columnWidths.length && need > 0; i++) {\n const reducible = Math.max(0, this.columnWidths[i] - floor);\n const cut = Math.min(reducible, need);\n if (cut > 0) {\n this.columnWidths[i] -= cut;\n need -= cut;\n }\n }\n return need;\n };\n\n const giveToRight = (start: number, giveInit: number) => {\n let give = giveInit;\n if (start < this.columnWidths.length && give > 0) {\n this.columnWidths[start] += give;\n give = 0;\n }\n return give;\n };\n\n if (!this.enableResizeScroll) {\n if (delta > 0) {\n let rightReducible = 0;\n for (let i = col + 1; i < this.columnWidths.length; i++) {\n rightReducible += Math.max(0, this.columnWidths[i] - floor);\n }\n if (rightReducible <= 0) {\n delta = 0;\n } else if (delta > rightReducible) {\n delta = rightReducible;\n }\n\n this.columnWidths[col] = prevW + delta;\n\n if (delta > 0) {\n takeFromRight(col + 1, delta);\n }\n } else {\n if (col === this.columnWidths.length - 1) {\n delta = 0;\n } else {\n const shrink = -delta;\n this.columnWidths[col] = Math.max(floor, prevW - shrink);\n\n const remaining = giveToRight(col + 1, shrink);\n if (remaining > 0) {\n this.columnWidths[col] = prevW;\n delta = 0;\n }\n }\n }\n } else {\n this.columnWidths[col] = newW;\n }\n\n resizeLinesHandler(\n this.resizeStart,\n this.resizeEnd,\n col,\n this.scrollHeight,\n this.columnWidths\n );\n\n this.colTemplate = rebuildTemplate(\n this.columnWidths.length,\n this.columnWidths\n );\n applyTemplate(getHead(this.slotEl), getBody(this.slotEl), this.colTemplate);\n applyColumnsTemplate(this, this.columnWidths, this.slotEl);\n };\n\n protected firstUpdated() {\n this.setAttribute('role', 'table');\n listenToEventListeners(\n this,\n this.onResize,\n this.slotEl,\n this._attachObserverAndLayout.bind(this)\n );\n }\n\n private _attachObserverAndLayout() {\n this.mo?.disconnect();\n this.mo = new MutationObserver(() => {\n this.scheduleLayout();\n });\n this.resizeObserver?.disconnect();\n this.resizeObserver = new ResizeObserver(() => {\n layout(\n this,\n this.slotEl,\n this.ensureWidths.bind(this),\n rebuildTemplate,\n applyTemplate,\n this.stickyLeftIndexes,\n this.stickyRightIndexes\n );\n });\n\n const head = getHead(this.slotEl);\n const body = getBody(this.slotEl);\n if (!head && !body) return;\n\n const target = body ?? this;\n this.mo.observe(target, {\n subtree: true,\n childList: true,\n attributes: true,\n attributeFilter: ['colspan', 'rowspan'],\n });\n this.resizeObserver?.observe(this);\n layout(\n this,\n this.slotEl,\n this.ensureWidths.bind(this),\n rebuildTemplate,\n applyTemplate,\n this.stickyLeftIndexes,\n this.stickyRightIndexes\n );\n }\n\n public render(): TemplateResult {\n return html`\n <div part=\"grid-base\" class=\"nile-grid-base\">\n <slot part=\"grid-slot\"></slot>\n <div part=\"resize-start\" class=\"nile-resize-start\"></div>\n <div part=\"resize-end\" class=\"nile-resize-end\"></div>\n </div>\n `;\n }\n\n disconnectedCallback(): void {\n super.disconnectedCallback?.();\n this.mo?.disconnect();\n this.resizeObserver?.disconnect();\n\n if (this.raf) cancelAnimationFrame(this.raf);\n removeEventListeners(\n this,\n this.onResize,\n this.slotEl,\n this._attachObserverAndLayout.bind(this)\n );\n }\n\n /* #endregion */\n}\n\nexport default NileGrid;\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'nile-grid': NileGrid;\n }\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nile-grid.types.js","sourceRoot":"","sources":["../../../src/nile-grid/nile-grid.types.ts"],"names":[],"mappings":"","sourcesContent":["export type HeadItemEl = HTMLElement & { customWidth?: number | null };\n"]}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { NileGrid } from './nile-grid';
|
|
2
|
-
export declare const resizeLinesHandler: (resizeStart:
|
|
2
|
+
export declare const resizeLinesHandler: (resizeStart: HTMLElement, resizeEnd: HTMLElement, col: number, scrollHeight: number, columnWidths: number[]) => void;
|
|
3
3
|
export declare const listenToEventListeners: (nileGrid: NileGrid, onResize: any, slotEl: any, _attachObserverAndLayout: any) => void;
|
|
4
4
|
export declare const removeEventListeners: (nileGrid: NileGrid, onResize: any, slotEl: any, _attachObserverAndLayout: any) => void;
|
|
5
5
|
export declare const getHead: (slotEl: any) => HTMLElement;
|
|
6
6
|
export declare const getBody: (slotEl: any) => HTMLElement;
|
|
7
7
|
export declare const rebuildTemplate: (colCount: number, columnWidths: number[]) => string;
|
|
8
8
|
export declare const applyTemplate: (head: HTMLElement | null, body: HTMLElement | null, colTemplate: string) => void;
|
|
9
|
-
export declare const layout: (nileGrid: NileGrid, slotEl: any, ensureWidths: any, rebuildTemplate: any, applyTemplate: any,
|
|
9
|
+
export declare const layout: (nileGrid: NileGrid, slotEl: any, ensureWidths: any, rebuildTemplate: any, applyTemplate: any, stickyLeftIndexes: number[], stickyRightIndexes: number[]) => void;
|
|
10
|
+
export declare function applyColumnsTemplate(nileGrid: HTMLElement, columnWidths: number[], slotEl: HTMLElement): void;
|
|
@@ -1,29 +1,20 @@
|
|
|
1
|
-
export const resizeLinesHandler = (resizeStart, resizeEnd, col,
|
|
1
|
+
export const resizeLinesHandler = (resizeStart, resizeEnd, col, scrollHeight, columnWidths) => {
|
|
2
2
|
resizeStart.style.display = 'block';
|
|
3
3
|
resizeEnd.style.display = 'block';
|
|
4
4
|
resizeStart.style.height = scrollHeight + 'px';
|
|
5
5
|
resizeEnd.style.height = scrollHeight + 'px';
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
}
|
|
19
|
-
else {
|
|
20
|
-
for (let i = 0; i < col; i++) {
|
|
21
|
-
totalWidth += columnWidths[i];
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
resizeStart.style.left = `${totalWidth + Math.max(60, widthPx) - 6}px`;
|
|
25
|
-
resizeEnd.style.left = `${totalWidth + Math.max(60, widthPx) - 2}px`;
|
|
26
|
-
}
|
|
6
|
+
const floor = 60;
|
|
7
|
+
const safe = (n) => Math.max(0, Math.round(n || 0));
|
|
8
|
+
const sum = (arr, endExclusive) => safe(arr.slice(0, Math.max(0, endExclusive)).reduce((a, b) => a + (b || 0), 0));
|
|
9
|
+
const totalGridWidth = safe(columnWidths.reduce((a, b) => a + (b || 0), 0));
|
|
10
|
+
const baseLeft = sum(columnWidths, col);
|
|
11
|
+
const appliedColWidth = safe(Math.max(floor, columnWidths[col] ?? floor));
|
|
12
|
+
let handleLeft = baseLeft + appliedColWidth;
|
|
13
|
+
const minEdge = baseLeft + floor;
|
|
14
|
+
const maxEdge = totalGridWidth;
|
|
15
|
+
handleLeft = Math.min(Math.max(handleLeft, minEdge), maxEdge);
|
|
16
|
+
resizeStart.style.left = `${handleLeft - 6}px`;
|
|
17
|
+
resizeEnd.style.left = `${handleLeft - 2}px`;
|
|
27
18
|
};
|
|
28
19
|
export const listenToEventListeners = (nileGrid, onResize, slotEl, _attachObserverAndLayout) => {
|
|
29
20
|
nileGrid.addEventListener('nile-resize', onResize);
|
|
@@ -73,82 +64,184 @@ export const applyTemplate = (head, body, colTemplate) => {
|
|
|
73
64
|
head.style.gridTemplateColumns = colTemplate;
|
|
74
65
|
if (body) {
|
|
75
66
|
body.style.gridTemplateColumns = colTemplate;
|
|
76
|
-
body.style.overflowX = 'auto';
|
|
77
67
|
}
|
|
78
68
|
};
|
|
79
|
-
function
|
|
80
|
-
|
|
69
|
+
function layoutRows(rows, carry, colCount, stickyLeftIndexes, stickyRightIndexes, columnWidths, opts) {
|
|
70
|
+
rows.forEach((row, rIdx) => {
|
|
81
71
|
let c = 1;
|
|
82
|
-
const cells = Array.from(row.querySelectorAll('nile-grid-head-item, nile-grid-cell'));
|
|
83
|
-
const rStart = rIdx + 1;
|
|
84
|
-
cells.forEach(cell => {
|
|
85
|
-
while (carryHead[c - 1] > 0)
|
|
86
|
-
c++;
|
|
87
|
-
const colspan = Math.max(1, Number(cell.getAttribute('colspan')) || 1);
|
|
88
|
-
const rowspan = Math.max(1, Number(cell.getAttribute('rowspan')) || 1);
|
|
89
|
-
const cStart = c, cEnd = c + colspan;
|
|
90
|
-
const rEnd = rStart + rowspan;
|
|
91
|
-
cell.style.gridColumn = `${cStart} / ${cEnd}`;
|
|
92
|
-
cell.style.gridRow = `${rStart} / ${rEnd}`;
|
|
93
|
-
cell.dataset.cStart = String(cStart);
|
|
94
|
-
for (let k = 0; k < colspan; k++) {
|
|
95
|
-
const idx = c - 1 + k;
|
|
96
|
-
carryHead[idx] = Math.max(carryHead[idx] || 0, rowspan);
|
|
97
|
-
}
|
|
98
|
-
c = cEnd;
|
|
99
|
-
colCount = Math.max(colCount, cEnd - 1);
|
|
100
|
-
});
|
|
101
|
-
for (let i = 0; i < carryHead.length; i++)
|
|
102
|
-
if (carryHead[i] > 0)
|
|
103
|
-
carryHead[i]--;
|
|
104
|
-
});
|
|
105
|
-
return colCount;
|
|
106
|
-
}
|
|
107
|
-
function computeBodyLayout(bodyRows, carryBody, colCount) {
|
|
108
|
-
bodyRows.forEach((row, rIdx) => {
|
|
109
|
-
let c = 1;
|
|
110
|
-
const cells = Array.from(row.querySelectorAll('nile-grid-cell, nile-grid-header'));
|
|
111
72
|
const rStart = rIdx + 1;
|
|
112
73
|
let maxRowspan = 1;
|
|
113
|
-
|
|
114
|
-
if (
|
|
115
|
-
bg
|
|
116
|
-
|
|
117
|
-
|
|
74
|
+
let bg = null;
|
|
75
|
+
if (opts.handleRowBg) {
|
|
76
|
+
bg = row.shadowRoot?.querySelector('[data-row-bg]') ?? null;
|
|
77
|
+
if (bg)
|
|
78
|
+
bg.style.gridColumn = `1 / -1`;
|
|
79
|
+
}
|
|
80
|
+
const items = Array.from(row.querySelectorAll(opts.itemSelector));
|
|
81
|
+
items.forEach((el) => {
|
|
82
|
+
while ((carry[c - 1] || 0) > 0)
|
|
118
83
|
c++;
|
|
119
|
-
const colspan = Math.max(1, Number(
|
|
120
|
-
const rowspan = Math.max(1, Number(
|
|
121
|
-
|
|
84
|
+
const colspan = Math.max(1, Number(el.getAttribute('colspan')) || 1);
|
|
85
|
+
const rowspan = Math.max(1, Number(el.getAttribute('rowspan')) || 1);
|
|
86
|
+
if (rowspan > 1) {
|
|
87
|
+
el.style.position = "absolute";
|
|
88
|
+
el.style.height = `${50 * rowspan}px`;
|
|
89
|
+
el.style.zIndex = "1";
|
|
90
|
+
}
|
|
91
|
+
const cStart = c;
|
|
92
|
+
const cEnd = c + colspan;
|
|
122
93
|
const rEnd = rStart + rowspan;
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
94
|
+
el.style.gridColumn = `${cStart} / ${cEnd}`;
|
|
95
|
+
el.style.gridRow = `${rStart} / ${rEnd}`;
|
|
96
|
+
el.dataset.cStart = String(cStart);
|
|
97
|
+
if (opts.useStickyAttr && el.hasAttribute('colSticky')) {
|
|
98
|
+
stickyLeftIndexes.push(cStart - 1);
|
|
99
|
+
}
|
|
100
|
+
if (opts.useStickyAttr && el.hasAttribute('lastColSticky')) {
|
|
101
|
+
stickyRightIndexes.push(cStart - 1);
|
|
102
|
+
}
|
|
103
|
+
applySticky(el, cStart - 1, stickyLeftIndexes, stickyRightIndexes, columnWidths);
|
|
126
104
|
for (let k = 0; k < colspan; k++) {
|
|
127
105
|
const idx = c - 1 + k;
|
|
128
|
-
|
|
106
|
+
carry[idx] = Math.max(carry[idx] || 0, rowspan);
|
|
129
107
|
}
|
|
130
108
|
maxRowspan = Math.max(maxRowspan, rowspan);
|
|
131
109
|
c = cEnd;
|
|
132
110
|
colCount = Math.max(colCount, cEnd - 1);
|
|
133
111
|
});
|
|
134
|
-
if (bg) {
|
|
112
|
+
if (opts.handleRowBg && bg) {
|
|
135
113
|
const rEnd = rStart + maxRowspan;
|
|
136
114
|
bg.style.gridRow = `${rStart} / ${rEnd}`;
|
|
137
115
|
}
|
|
138
|
-
for (let i = 0; i <
|
|
139
|
-
if (
|
|
140
|
-
|
|
116
|
+
for (let i = 0; i < carry.length; i++) {
|
|
117
|
+
if (carry[i] > 0)
|
|
118
|
+
carry[i]--;
|
|
119
|
+
}
|
|
141
120
|
});
|
|
142
121
|
return colCount;
|
|
143
122
|
}
|
|
144
|
-
function
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
123
|
+
function computeHeadLayout(headRows, carryHead, colCount, stickyLeftIndexes, stickyRightIndexes, columnWidths) {
|
|
124
|
+
return layoutRows(headRows, carryHead, colCount, stickyLeftIndexes, stickyRightIndexes, columnWidths, {
|
|
125
|
+
itemSelector: 'nile-grid-head-item',
|
|
126
|
+
useStickyAttr: true,
|
|
127
|
+
handleRowBg: false,
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
function computeBodyLayout(bodyRows, carryBody, colCount, stickyLeftIndexes, stickyRightIndexes, columnWidths) {
|
|
131
|
+
return layoutRows(bodyRows, carryBody, colCount, stickyLeftIndexes, stickyRightIndexes, columnWidths, {
|
|
132
|
+
itemSelector: 'nile-grid-cell-item',
|
|
133
|
+
useStickyAttr: false,
|
|
134
|
+
handleRowBg: true,
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
function computeColumnWidths(nileGrid, colCount, columnWidths, slotEl) {
|
|
138
|
+
const minCol = 60;
|
|
139
|
+
const containerWidth = getContainerWidth(nileGrid);
|
|
140
|
+
const desired = readDesiredFromHead(slotEl, colCount);
|
|
141
|
+
const isSeeded = seedWidthsFromDesired(desired, columnWidths, minCol);
|
|
142
|
+
distributeFlex(columnWidths, isSeeded, containerWidth, minCol);
|
|
143
|
+
normalizeToContainer(columnWidths, containerWidth, minCol);
|
|
144
|
+
clampAndRound(columnWidths, minCol);
|
|
145
|
+
applyColumnsTemplate(nileGrid, columnWidths, slotEl);
|
|
146
|
+
}
|
|
147
|
+
function getContainerWidth(nileGrid) {
|
|
148
|
+
return Math.max(0, (nileGrid.getBoundingClientRect().width || 0) - 4);
|
|
149
|
+
}
|
|
150
|
+
function readDesiredFromHead(slotEl, colCount) {
|
|
151
|
+
const desired = Array(colCount).fill(null);
|
|
152
|
+
const head = getHead(slotEl);
|
|
153
|
+
if (!head)
|
|
154
|
+
return desired;
|
|
155
|
+
const headRows = Array.from(head.children).filter(el => el.tagName.toLowerCase() === 'nile-grid-row');
|
|
156
|
+
for (const row of headRows) {
|
|
157
|
+
const items = Array.from(row.children).filter(el => el.tagName.toLowerCase() === 'nile-grid-head-item');
|
|
158
|
+
items
|
|
159
|
+
.map(h => {
|
|
160
|
+
const cStart = Number(h.dataset?.cStart) || 1;
|
|
161
|
+
const colspan = Math.max(1, Number(h.getAttribute('colspan')) || 1);
|
|
162
|
+
const attr = h.getAttribute('customWidth');
|
|
163
|
+
const cw = attr != null ? Number(attr) : h.customWidth ?? null;
|
|
164
|
+
return { cStart, colspan, cw };
|
|
165
|
+
})
|
|
166
|
+
.filter(x => x.cw != null && !Number.isNaN(x.cw))
|
|
167
|
+
.sort((a, b) => {
|
|
168
|
+
return a.colspan - b.colspan;
|
|
169
|
+
})
|
|
170
|
+
.forEach(({ cStart, colspan, cw }) => {
|
|
171
|
+
const perCol = cw / colspan;
|
|
172
|
+
for (let k = 0; k < colspan; k++) {
|
|
173
|
+
const idx = cStart - 1 + k;
|
|
174
|
+
if (idx >= 0 && idx < colCount && desired[idx] == null) {
|
|
175
|
+
desired[idx] = perCol;
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
});
|
|
179
|
+
}
|
|
180
|
+
return desired;
|
|
181
|
+
}
|
|
182
|
+
function seedWidthsFromDesired(desired, columnWidths, minCol) {
|
|
183
|
+
const isSeeded = Array(desired.length).fill(false);
|
|
184
|
+
for (let i = 0; i < desired.length; i++) {
|
|
185
|
+
const w = desired[i] ?? null;
|
|
186
|
+
columnWidths[i] =
|
|
187
|
+
w != null && !Number.isNaN(w) ? Math.max(minCol, Number(w)) : 0;
|
|
188
|
+
isSeeded[i] = w != null && !Number.isNaN(w);
|
|
189
|
+
}
|
|
190
|
+
return isSeeded;
|
|
191
|
+
}
|
|
192
|
+
function distributeFlex(columnWidths, isSeeded, containerWidth, minCol) {
|
|
193
|
+
const sumSeed = columnWidths.reduce((a, b) => a + b, 0);
|
|
194
|
+
const remaining = containerWidth - sumSeed;
|
|
195
|
+
const flexIdxs = Array.from({ length: columnWidths.length }, (_, i) => i).filter(i => !isSeeded[i]);
|
|
196
|
+
if (flexIdxs.length === 0)
|
|
197
|
+
return;
|
|
198
|
+
const each = remaining / flexIdxs.length;
|
|
199
|
+
for (const i of flexIdxs)
|
|
200
|
+
columnWidths[i] = Math.max(minCol, each);
|
|
201
|
+
}
|
|
202
|
+
function normalizeToContainer(columnWidths, containerWidth, minCol) {
|
|
203
|
+
let total = columnWidths.reduce((a, b) => a + b, 0);
|
|
204
|
+
if (total < containerWidth && columnWidths.length > 0) {
|
|
205
|
+
const add = containerWidth - total;
|
|
206
|
+
const weight = total || 1;
|
|
207
|
+
for (let i = 0; i < columnWidths.length; i++) {
|
|
208
|
+
columnWidths[i] += add * (columnWidths[i] / weight);
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
else if (total > containerWidth) {
|
|
212
|
+
let need = total - containerWidth;
|
|
213
|
+
for (let iter = 0; iter < 8 && need > 0.5; iter++) {
|
|
214
|
+
let weightSum = 0;
|
|
215
|
+
const candidates = [];
|
|
216
|
+
for (let i = 0; i < columnWidths.length; i++) {
|
|
217
|
+
const reducible = Math.max(0, columnWidths[i] - minCol);
|
|
218
|
+
if (reducible > 0) {
|
|
219
|
+
candidates.push(i);
|
|
220
|
+
weightSum += columnWidths[i];
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
if (candidates.length === 0 || weightSum <= 0)
|
|
224
|
+
break;
|
|
225
|
+
let reduced = 0;
|
|
226
|
+
for (const i of candidates) {
|
|
227
|
+
const reducible = Math.max(0, columnWidths[i] - minCol);
|
|
228
|
+
const share = columnWidths[i] / weightSum;
|
|
229
|
+
const cut = Math.min(reducible, need * share);
|
|
230
|
+
columnWidths[i] -= cut;
|
|
231
|
+
reduced += cut;
|
|
232
|
+
}
|
|
233
|
+
need -= reduced;
|
|
234
|
+
if (reduced < 0.5)
|
|
235
|
+
break;
|
|
236
|
+
}
|
|
149
237
|
}
|
|
150
238
|
}
|
|
151
|
-
|
|
239
|
+
function clampAndRound(columnWidths, minCol) {
|
|
240
|
+
for (let i = 0; i < columnWidths.length; i++) {
|
|
241
|
+
columnWidths[i] = Math.max(minCol, Math.round(columnWidths[i]));
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
export const layout = (nileGrid, slotEl, ensureWidths, rebuildTemplate, applyTemplate, stickyLeftIndexes, stickyRightIndexes) => {
|
|
152
245
|
const head = getHead(slotEl);
|
|
153
246
|
const body = getBody(slotEl);
|
|
154
247
|
if (!body)
|
|
@@ -158,13 +251,62 @@ export const layout = (nileGrid, slotEl, ensureWidths, rebuildTemplate, applyTem
|
|
|
158
251
|
: [];
|
|
159
252
|
const bodyRows = Array.from(body.querySelectorAll('nile-grid-row'));
|
|
160
253
|
let colCount = 0;
|
|
161
|
-
colCount = computeHeadLayout(headRows, [], colCount);
|
|
162
|
-
colCount = computeBodyLayout(bodyRows, [], colCount);
|
|
163
|
-
computeColumnWidths(nileGrid, colCount, columnWidths);
|
|
254
|
+
colCount = computeHeadLayout(headRows, [], colCount, stickyLeftIndexes, stickyRightIndexes, nileGrid.columnWidths);
|
|
255
|
+
colCount = computeBodyLayout(bodyRows, [], colCount, stickyLeftIndexes, stickyRightIndexes, nileGrid.columnWidths);
|
|
256
|
+
computeColumnWidths(nileGrid, colCount, nileGrid.columnWidths, slotEl);
|
|
164
257
|
ensureWidths(colCount);
|
|
165
258
|
body.style.gridAutoRows = 'auto';
|
|
166
|
-
|
|
167
|
-
nileGrid.colTemplate = rebuildTemplate(colCount, columnWidths);
|
|
259
|
+
nileGrid.colTemplate = rebuildTemplate(colCount, nileGrid.columnWidths);
|
|
168
260
|
applyTemplate(head, body, nileGrid.colTemplate, nileGrid.colTemplate);
|
|
169
261
|
};
|
|
262
|
+
function applySticky(el, colIndex, stickyLeftIndexes, stickyRightIndexes, columnWidths) {
|
|
263
|
+
const onLeft = stickyLeftIndexes.includes(colIndex);
|
|
264
|
+
const onRight = stickyRightIndexes.includes(colIndex);
|
|
265
|
+
if (!onLeft && !onRight)
|
|
266
|
+
return;
|
|
267
|
+
el.style.position = 'sticky';
|
|
268
|
+
el.style.zIndex = '2';
|
|
269
|
+
if (onLeft && !onRight) {
|
|
270
|
+
const leftOrder = [...stickyLeftIndexes].sort((a, b) => a - b);
|
|
271
|
+
const pos = leftOrder.indexOf(colIndex);
|
|
272
|
+
let left = 0;
|
|
273
|
+
for (let i = 0; i < pos; i++)
|
|
274
|
+
left += columnWidths[leftOrder[i]] ?? 0;
|
|
275
|
+
el.style.left = `${left}px`;
|
|
276
|
+
return;
|
|
277
|
+
}
|
|
278
|
+
const rightOrder = [...stickyRightIndexes].sort((a, b) => b - a);
|
|
279
|
+
const pos = rightOrder.indexOf(colIndex);
|
|
280
|
+
const scroller = el.closest('nile-grid');
|
|
281
|
+
const sb = scroller ? scroller.offsetWidth - scroller.clientWidth : 0;
|
|
282
|
+
let right = sb;
|
|
283
|
+
for (let i = 0; i < pos; i++)
|
|
284
|
+
right += columnWidths[rightOrder[i]] ?? 0;
|
|
285
|
+
el.style.right = `${right - 2}px`;
|
|
286
|
+
}
|
|
287
|
+
export function applyColumnsTemplate(nileGrid, columnWidths, slotEl) {
|
|
288
|
+
const cols = columnWidths
|
|
289
|
+
.map((w, idx) => {
|
|
290
|
+
if (idx === columnWidths.length - 1) {
|
|
291
|
+
return `minmax(${Math.round(w)}px, auto)`;
|
|
292
|
+
}
|
|
293
|
+
return `${Math.max(0, Math.round(w))}px`;
|
|
294
|
+
})
|
|
295
|
+
.join(' ');
|
|
296
|
+
nileGrid.style.setProperty('--nile-grid-columns', cols);
|
|
297
|
+
const head = slotEl.querySelector('nile-grid-head');
|
|
298
|
+
if (head) {
|
|
299
|
+
head.style.setProperty('--nile-grid-columns', cols);
|
|
300
|
+
head
|
|
301
|
+
.querySelectorAll('nile-grid-row')
|
|
302
|
+
.forEach(r => r.style.setProperty('--nile-grid-columns', cols));
|
|
303
|
+
}
|
|
304
|
+
const body = slotEl.querySelector('nile-grid-body');
|
|
305
|
+
if (body) {
|
|
306
|
+
body.style.setProperty('--nile-grid-columns', cols);
|
|
307
|
+
body
|
|
308
|
+
.querySelectorAll('nile-grid-row')
|
|
309
|
+
.forEach(r => r.style.setProperty('--nile-grid-columns', cols));
|
|
310
|
+
}
|
|
311
|
+
}
|
|
170
312
|
//# sourceMappingURL=nile-grid.utils.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"nile-grid.utils.js","sourceRoot":"","sources":["../../../src/nile-grid/nile-grid.utils.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAChC,WAAgB,EAChB,SAAc,EACd,GAAW,EACX,OAAe,EACf,YAAiB,EACjB,YAAiB,EACjB,CAAM,EACN,EAAE;IACF,WAAW,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;IACpC,SAAS,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;IAClC,WAAW,CAAC,KAAK,CAAC,MAAM,GAAG,YAAY,GAAG,IAAI,CAAC;IAC/C,SAAS,CAAC,KAAK,CAAC,MAAM,GAAG,YAAY,GAAG,IAAI,CAAC;IAC7C,IAAI,GAAG,KAAK,CAAC,EAAE,CAAC;QACd,WAAW,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC;QAC1D,SAAS,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC;IAC1D,CAAC;SAAM,CAAC;QACN,IAAI,UAAU,GAAG,CAAC,CAAC;QACnB,IACG,CAAC,CAAC,MAAsB,CAAC,YAAY,CAAC,SAAS,CAAC;YACjD,QAAQ,CAAE,CAAC,CAAC,MAAsB,CAAC,YAAY,CAAC,SAAS,CAAE,CAAC,GAAG,CAAC,EAChE,CAAC;YACD,OAAO,GAAG,OAAO,GAAG,YAAY,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;YAC1C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC7B,UAAU,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC;YAChC,CAAC;QACH,CAAC;aAAM,CAAC;YACN,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC7B,UAAU,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC;YAChC,CAAC;QACH,CAAC;QACD,WAAW,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC;QACvE,SAAS,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC;IACvE,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,sBAAsB,GAAG,CACpC,QAAkB,EAClB,QAAa,EACb,MAAW,EACX,wBAA6B,EAC7B,EAAE;IACF,QAAQ,CAAC,gBAAgB,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;IACnD,QAAQ,CAAC,gBAAgB,CAAC,mBAAmB,EAAE,GAAG,EAAE;QAClD,QAAQ,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;IAC/C,CAAC,CAAC,CAAC;IACH,QAAQ,CAAC,gBAAgB,CAAC,iBAAiB,EAAE,GAAG,EAAE;QAChD,QAAQ,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;QAC5C,QAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;IAC5C,CAAC,CAAC,CAAC;IACH,MAAM,CAAC,gBAAgB,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,wBAAwB,EAAE,CAAC,CAAC;AAC1E,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAClC,QAAkB,EAClB,QAAa,EACb,MAAW,EACX,wBAA6B,EAC7B,EAAE;IACF,QAAQ,CAAC,mBAAmB,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;IACtD,QAAQ,CAAC,mBAAmB,CAAC,mBAAmB,EAAE,GAAG,EAAE;QACrD,QAAQ,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;IAC/C,CAAC,CAAC,CAAC;IACH,QAAQ,CAAC,mBAAmB,CAAC,iBAAiB,EAAE,GAAG,EAAE;QACnD,QAAQ,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;QAC5C,QAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;IAC5C,CAAC,CAAC,CAAC;IACH,MAAM,CAAC,mBAAmB,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,wBAAwB,EAAE,CAAC,CAAC;AAC7E,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,MAAW,EAAE,EAAE;IACrC,MAAM,KAAK,GAAG,MAAM,EAAE,gBAAgB,EAAE,IAAI,EAAE,CAAC;IAC/C,OAAO,CACJ,KAAK,CAAC,IAAI,CACT,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,gBAAgB,CACzC,IAAI,IAAI,CAC1B,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,MAAW,EAAE,EAAE;IACrC,MAAM,KAAK,GAAG,MAAM,EAAE,gBAAgB,EAAE,IAAI,EAAE,CAAC;IAC/C,OAAO,CACJ,KAAK,CAAC,IAAI,CACT,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,gBAAgB,CACzC,IAAI,IAAI,CAC1B,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAC7B,QAAgB,EAChB,YAAsB,EACd,EAAE;IACV,MAAM,KAAK,GAAa,EAAE,CAAC;IAE3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,EAAE,CAAC,EAAE,EAAE,CAAC;QAClC,MAAM,QAAQ,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;QACjC,IAAI,CAAC,KAAK,QAAQ,GAAG,CAAC,EAAE,CAAC;YACvB,KAAK,CAAC,IAAI,CAAC,UAAU,QAAQ,WAAW,CAAC,CAAC;QAC5C,CAAC;aAAM,CAAC;YACN,KAAK,CAAC,IAAI,CAAC,GAAG,QAAQ,IAAI,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACzB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAG,CAC3B,IAAwB,EACxB,IAAwB,EACxB,WAAmB,EACnB,EAAE;IACF,IAAI,IAAI;QAAE,IAAI,CAAC,KAAK,CAAC,mBAAmB,GAAG,WAAW,CAAC;IACvD,IAAI,IAAI,EAAE,CAAC;QACT,IAAI,CAAC,KAAK,CAAC,mBAAmB,GAAG,WAAW,CAAC;QAC7C,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,MAAM,CAAC;IAChC,CAAC;AACH,CAAC,CAAC;AAEF,SAAS,iBAAiB,CACxB,QAAuB,EACvB,SAAmB,EACnB,QAAgB;IAEhB,QAAQ,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;QAC7B,IAAI,CAAC,GAAG,CAAC,CAAC;QACV,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CACtB,GAAG,CAAC,gBAAgB,CAAC,qCAAqC,CAAC,CAC3C,CAAC;QACnB,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,CAAC;QAExB,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACnB,OAAO,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC;gBAAE,CAAC,EAAE,CAAC;YACjC,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;YACvE,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;YAEvE,MAAM,MAAM,GAAG,CAAC,EACd,IAAI,GAAG,CAAC,GAAG,OAAO,CAAC;YACrB,MAAM,IAAI,GAAG,MAAM,GAAG,OAAO,CAAC;YAE9B,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,GAAG,MAAM,MAAM,IAAI,EAAE,CAAC;YAC9C,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,MAAM,MAAM,IAAI,EAAE,CAAC;YAC1C,IAAY,CAAC,OAAO,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;YAE9C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,EAAE,CAAC,EAAE,EAAE,CAAC;gBACjC,MAAM,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;gBACtB,SAAS,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;YAC1D,CAAC;YACD,CAAC,GAAG,IAAI,CAAC;YACT,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;QAEH,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE;YACvC,IAAI,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC;gBAAE,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;IACzC,CAAC,CAAC,CAAC;IACH,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,SAAS,iBAAiB,CACxB,QAAuB,EACvB,SAAmB,EACnB,QAAgB;IAEhB,QAAQ,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;QAC7B,IAAI,CAAC,GAAG,CAAC,CAAC;QACV,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CACtB,GAAG,CAAC,gBAAgB,CAAC,kCAAkC,CAAC,CACxC,CAAC;QACnB,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,CAAC;QACxB,IAAI,UAAU,GAAG,CAAC,CAAC;QAEnB,MAAM,EAAE,GAAG,GAAG,CAAC,UAAU,EAAE,aAAa,CAAc,eAAe,CAAC,CAAC;QACvE,IAAI,EAAE;YAAE,EAAE,CAAC,KAAK,CAAC,UAAU,GAAG,QAAQ,CAAC;QAEvC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACnB,OAAO,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC;gBAAE,CAAC,EAAE,CAAC;YACjC,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;YACvE,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;YAEvE,MAAM,MAAM,GAAG,CAAC,EACd,IAAI,GAAG,CAAC,GAAG,OAAO,CAAC;YACrB,MAAM,IAAI,GAAG,MAAM,GAAG,OAAO,CAAC;YAE9B,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,GAAG,MAAM,MAAM,IAAI,EAAE,CAAC;YAC9C,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,MAAM,MAAM,IAAI,EAAE,CAAC;YAC1C,IAAY,CAAC,OAAO,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;YAE9C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,EAAE,CAAC,EAAE,EAAE,CAAC;gBACjC,MAAM,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;gBACtB,SAAS,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;YAC1D,CAAC;YACD,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;YAC3C,CAAC,GAAG,IAAI,CAAC;YACT,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;QAEH,IAAI,EAAE,EAAE,CAAC;YACP,MAAM,IAAI,GAAG,MAAM,GAAG,UAAU,CAAC;YACjC,EAAE,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,MAAM,MAAM,IAAI,EAAE,CAAC;QAC3C,CAAC;QAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE;YACvC,IAAI,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC;gBAAE,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,SAAS,mBAAmB,CAC1B,QAAkB,EAClB,QAAgB,EAChB,YAAsB;IAEtB,KAAK,IAAI,GAAG,GAAG,CAAC,EAAE,GAAG,GAAG,QAAQ,EAAE,GAAG,EAAE,EAAE,CAAC;QACxC,MAAM,cAAc,GAAG,CAAC,QAAQ,CAAC,qBAAqB,EAAE,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QACzE,YAAY,CAAC,GAAG,CAAC;YACf,QAAQ,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;IACzE,CAAC;AACH,CAAC;AAED,MAAM,CAAC,MAAM,MAAM,GAAG,CACpB,QAAkB,EAClB,MAAW,EACX,YAAiB,EACjB,eAAoB,EACpB,aAAkB,EAClB,YAAiB,EACjB,EAAE;IACF,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAC7B,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAC7B,IAAI,CAAC,IAAI;QAAE,OAAO;IAElB,MAAM,QAAQ,GAAG,IAAI;QACnB,CAAC,CAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAmB;QACvE,CAAC,CAAC,EAAE,CAAC;IACP,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CACzB,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,CACtB,CAAC;IAEnB,IAAI,QAAQ,GAAG,CAAC,CAAC;IAEjB,QAAQ,GAAG,iBAAiB,CAAC,QAAQ,EAAE,EAAE,EAAE,QAAQ,CAAC,CAAC;IACrD,QAAQ,GAAG,iBAAiB,CAAC,QAAQ,EAAE,EAAE,EAAE,QAAQ,CAAC,CAAC;IAErD,mBAAmB,CAAC,QAAQ,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;IAEtD,YAAY,CAAC,QAAQ,CAAC,CAAC;IACvB,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,MAAM,CAAC;IACjC,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,MAAM,CAAC;IAC9B,QAAQ,CAAC,WAAW,GAAG,eAAe,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;IAC/D,aAAa,CAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,CAAC,WAAW,EAAE,QAAQ,CAAC,WAAW,CAAC,CAAC;AACxE,CAAC,CAAC","sourcesContent":["import { NileGrid } from './nile-grid';\n\nexport const resizeLinesHandler = (\n resizeStart: any,\n resizeEnd: any,\n col: number,\n widthPx: number,\n scrollHeight: any,\n columnWidths: any,\n e: any\n) => {\n resizeStart.style.display = 'block';\n resizeEnd.style.display = 'block';\n resizeStart.style.height = scrollHeight + 'px';\n resizeEnd.style.height = scrollHeight + 'px';\n if (col === 0) {\n resizeStart.style.left = `${Math.max(60, widthPx) - 6}px`;\n resizeEnd.style.left = `${Math.max(60, widthPx) - 2}px`;\n } else {\n let totalWidth = 0;\n if (\n (e.target as HTMLElement).getAttribute('colspan') &&\n parseInt((e.target as HTMLElement).getAttribute('colspan')!) > 1\n ) {\n widthPx = widthPx - columnWidths[col - 1];\n for (let i = 0; i < col; i++) {\n totalWidth += columnWidths[i];\n }\n } else {\n for (let i = 0; i < col; i++) {\n totalWidth += columnWidths[i];\n }\n }\n resizeStart.style.left = `${totalWidth + Math.max(60, widthPx) - 6}px`;\n resizeEnd.style.left = `${totalWidth + Math.max(60, widthPx) - 2}px`;\n }\n};\n\nexport const listenToEventListeners = (\n nileGrid: NileGrid,\n onResize: any,\n slotEl: any,\n _attachObserverAndLayout: any\n) => {\n nileGrid.addEventListener('nile-resize', onResize);\n nileGrid.addEventListener('nile-resize-start', () => {\n nileGrid.resizeStart.style.display = 'block';\n });\n nileGrid.addEventListener('nile-resize-end', () => {\n nileGrid.resizeStart.style.display = 'none';\n nileGrid.resizeEnd.style.display = 'none';\n });\n slotEl.addEventListener('slotchange', () => _attachObserverAndLayout());\n};\n\nexport const removeEventListeners = (\n nileGrid: NileGrid,\n onResize: any,\n slotEl: any,\n _attachObserverAndLayout: any\n) => {\n nileGrid.removeEventListener('nile-resize', onResize);\n nileGrid.removeEventListener('nile-resize-start', () => {\n nileGrid.resizeStart.style.display = 'block';\n });\n nileGrid.removeEventListener('nile-resize-end', () => {\n nileGrid.resizeStart.style.display = 'none';\n nileGrid.resizeEnd.style.display = 'none';\n });\n slotEl.removeEventListener('slotchange', () => _attachObserverAndLayout());\n};\n\nexport const getHead = (slotEl: any) => {\n const nodes = slotEl?.assignedElements() ?? [];\n return (\n (nodes.find(\n (n: any) => n.tagName.toLowerCase() === 'nile-grid-head'\n ) as HTMLElement) || null\n );\n};\n\nexport const getBody = (slotEl: any) => {\n const nodes = slotEl?.assignedElements() ?? [];\n return (\n (nodes.find(\n (n: any) => n.tagName.toLowerCase() === 'nile-grid-body'\n ) as HTMLElement) || null\n );\n};\n\nexport const rebuildTemplate = (\n colCount: number,\n columnWidths: number[]\n): string => {\n const parts: string[] = [];\n\n for (let i = 0; i < colCount; i++) {\n const explicit = columnWidths[i];\n if (i === colCount - 1) {\n parts.push(`minmax(${explicit}px, auto)`);\n } else {\n parts.push(`${explicit}px`);\n }\n }\n return parts.join(' ');\n};\n\nexport const applyTemplate = (\n head: HTMLElement | null,\n body: HTMLElement | null,\n colTemplate: string\n) => {\n if (head) head.style.gridTemplateColumns = colTemplate;\n if (body) {\n body.style.gridTemplateColumns = colTemplate;\n body.style.overflowX = 'auto';\n }\n};\n\nfunction computeHeadLayout(\n headRows: HTMLElement[],\n carryHead: number[],\n colCount: number\n): number {\n headRows.forEach((row, rIdx) => {\n let c = 1;\n const cells = Array.from(\n row.querySelectorAll('nile-grid-head-item, nile-grid-cell')\n ) as HTMLElement[];\n const rStart = rIdx + 1;\n\n cells.forEach(cell => {\n while (carryHead[c - 1] > 0) c++;\n const colspan = Math.max(1, Number(cell.getAttribute('colspan')) || 1);\n const rowspan = Math.max(1, Number(cell.getAttribute('rowspan')) || 1);\n\n const cStart = c,\n cEnd = c + colspan;\n const rEnd = rStart + rowspan;\n\n cell.style.gridColumn = `${cStart} / ${cEnd}`;\n cell.style.gridRow = `${rStart} / ${rEnd}`;\n (cell as any).dataset.cStart = String(cStart);\n\n for (let k = 0; k < colspan; k++) {\n const idx = c - 1 + k;\n carryHead[idx] = Math.max(carryHead[idx] || 0, rowspan);\n }\n c = cEnd;\n colCount = Math.max(colCount, cEnd - 1);\n });\n\n for (let i = 0; i < carryHead.length; i++)\n if (carryHead[i] > 0) carryHead[i]--;\n });\n return colCount;\n}\n\nfunction computeBodyLayout(\n bodyRows: HTMLElement[],\n carryBody: number[],\n colCount: number\n) {\n bodyRows.forEach((row, rIdx) => {\n let c = 1;\n const cells = Array.from(\n row.querySelectorAll('nile-grid-cell, nile-grid-header')\n ) as HTMLElement[];\n const rStart = rIdx + 1;\n let maxRowspan = 1;\n\n const bg = row.shadowRoot?.querySelector<HTMLElement>('[data-row-bg]');\n if (bg) bg.style.gridColumn = `1 / -1`;\n\n cells.forEach(cell => {\n while (carryBody[c - 1] > 0) c++;\n const colspan = Math.max(1, Number(cell.getAttribute('colspan')) || 1);\n const rowspan = Math.max(1, Number(cell.getAttribute('rowspan')) || 1);\n\n const cStart = c,\n cEnd = c + colspan;\n const rEnd = rStart + rowspan;\n\n cell.style.gridColumn = `${cStart} / ${cEnd}`;\n cell.style.gridRow = `${rStart} / ${rEnd}`;\n (cell as any).dataset.cStart = String(cStart);\n\n for (let k = 0; k < colspan; k++) {\n const idx = c - 1 + k;\n carryBody[idx] = Math.max(carryBody[idx] || 0, rowspan);\n }\n maxRowspan = Math.max(maxRowspan, rowspan);\n c = cEnd;\n colCount = Math.max(colCount, cEnd - 1);\n });\n\n if (bg) {\n const rEnd = rStart + maxRowspan;\n bg.style.gridRow = `${rStart} / ${rEnd}`;\n }\n\n for (let i = 0; i < carryBody.length; i++)\n if (carryBody[i] > 0) carryBody[i]--;\n });\n\n return colCount;\n}\n\nfunction computeColumnWidths(\n nileGrid: NileGrid,\n colCount: number,\n columnWidths: number[]\n) {\n for (let col = 0; col < colCount; col++) {\n const containerWidth = (nileGrid.getBoundingClientRect().width || 1) - 2;\n columnWidths[col] =\n nileGrid.customWidths[col] || containerWidth / Math.max(colCount, 1);\n }\n}\n\nexport const layout = (\n nileGrid: NileGrid,\n slotEl: any,\n ensureWidths: any,\n rebuildTemplate: any,\n applyTemplate: any,\n columnWidths: any\n) => {\n const head = getHead(slotEl);\n const body = getBody(slotEl);\n if (!body) return;\n\n const headRows = head\n ? (Array.from(head.querySelectorAll('nile-grid-row')) as HTMLElement[])\n : [];\n const bodyRows = Array.from(\n body.querySelectorAll('nile-grid-row')\n ) as HTMLElement[];\n\n let colCount = 0;\n\n colCount = computeHeadLayout(headRows, [], colCount);\n colCount = computeBodyLayout(bodyRows, [], colCount);\n\n computeColumnWidths(nileGrid, colCount, columnWidths);\n\n ensureWidths(colCount);\n body.style.gridAutoRows = 'auto';\n body.style.overflowY = 'auto';\n nileGrid.colTemplate = rebuildTemplate(colCount, columnWidths);\n applyTemplate(head, body, nileGrid.colTemplate, nileGrid.colTemplate);\n};\n"]}
|
|
1
|
+
{"version":3,"file":"nile-grid.utils.js","sourceRoot":"","sources":["../../../src/nile-grid/nile-grid.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { NileGrid } from './nile-grid';\nimport { HeadItemEl } from './nile-grid.types';\n\nexport const resizeLinesHandler = (\n resizeStart: HTMLElement,\n resizeEnd: HTMLElement,\n col: number,\n scrollHeight: number,\n columnWidths: number[],\n) => {\n resizeStart.style.display = 'block';\n resizeEnd.style.display = 'block';\n resizeStart.style.height = scrollHeight + 'px';\n resizeEnd.style.height = scrollHeight + 'px';\n const floor = 60;\n const safe = (n: number) => Math.max(0, Math.round(n || 0));\n\n const sum = (arr: number[], endExclusive: number) =>\n safe(\n arr.slice(0, Math.max(0, endExclusive)).reduce((a, b) => a + (b || 0), 0)\n );\n\n const totalGridWidth = safe(columnWidths.reduce((a, b) => a + (b || 0), 0));\n const baseLeft = sum(columnWidths, col);\n const appliedColWidth = safe(Math.max(floor, columnWidths[col] ?? floor));\n let handleLeft = baseLeft + appliedColWidth;\n\n const minEdge = baseLeft + floor;\n const maxEdge = totalGridWidth;\n handleLeft = Math.min(Math.max(handleLeft, minEdge), maxEdge);\n\n resizeStart.style.left = `${handleLeft - 6}px`;\n resizeEnd.style.left = `${handleLeft - 2}px`;\n};\n\n\nexport const listenToEventListeners = (\n nileGrid: NileGrid,\n onResize: any,\n slotEl: any,\n _attachObserverAndLayout: any\n) => {\n nileGrid.addEventListener('nile-resize', onResize);\n nileGrid.addEventListener('nile-resize-start', () => {\n nileGrid.resizeStart.style.display = 'block';\n });\n nileGrid.addEventListener('nile-resize-end', () => {\n nileGrid.resizeStart.style.display = 'none';\n nileGrid.resizeEnd.style.display = 'none';\n });\n slotEl.addEventListener('slotchange', () => _attachObserverAndLayout());\n};\n\nexport const removeEventListeners = (\n nileGrid: NileGrid,\n onResize: any,\n slotEl: any,\n _attachObserverAndLayout: any\n) => {\n nileGrid.removeEventListener('nile-resize', onResize);\n nileGrid.removeEventListener('nile-resize-start', () => {\n nileGrid.resizeStart.style.display = 'block';\n });\n nileGrid.removeEventListener('nile-resize-end', () => {\n nileGrid.resizeStart.style.display = 'none';\n nileGrid.resizeEnd.style.display = 'none';\n });\n slotEl.removeEventListener('slotchange', () => _attachObserverAndLayout());\n};\n\nexport const getHead = (slotEl: any) => {\n const nodes = slotEl?.assignedElements() ?? [];\n return (\n (nodes.find(\n (n: any) => n.tagName.toLowerCase() === 'nile-grid-head'\n ) as HTMLElement) || null\n );\n};\n\nexport const getBody = (slotEl: any) => {\n const nodes = slotEl?.assignedElements() ?? [];\n return (\n (nodes.find(\n (n: any) => n.tagName.toLowerCase() === 'nile-grid-body'\n ) as HTMLElement) || null\n );\n};\n\nexport const rebuildTemplate = (\n colCount: number,\n columnWidths: number[]\n): string => {\n const parts: string[] = [];\n\n for (let i = 0; i < colCount; i++) {\n const explicit = columnWidths[i];\n if (i === colCount - 1) {\n parts.push(`minmax(${explicit}px, auto)`);\n } else {\n parts.push(`${explicit}px`);\n }\n }\n return parts.join(' ');\n};\n\nexport const applyTemplate = (\n head: HTMLElement | null,\n body: HTMLElement | null,\n colTemplate: string\n) => {\n if (head) head.style.gridTemplateColumns = colTemplate;\n if (body) {\n body.style.gridTemplateColumns = colTemplate;\n }\n};\n\nfunction layoutRows(\n rows: HTMLElement[],\n carry: number[],\n colCount: number,\n stickyLeftIndexes: number[],\n stickyRightIndexes: number[],\n columnWidths: number[],\n opts: {\n itemSelector: string;\n useStickyAttr?: boolean;\n handleRowBg?: boolean;\n }\n): number {\n rows.forEach((row, rIdx) => {\n let c = 1;\n const rStart = rIdx + 1;\n let maxRowspan = 1;\n\n let bg: HTMLElement | null = null;\n if (opts.handleRowBg) {\n bg = row.shadowRoot?.querySelector<HTMLElement>('[data-row-bg]') ?? null;\n if (bg) bg.style.gridColumn = `1 / -1`;\n }\n\n const items = Array.from(\n row.querySelectorAll(opts.itemSelector)\n ) as HTMLElement[];\n\n items.forEach((el) => {\n while ((carry[c - 1] || 0) > 0) c++;\n\n const colspan = Math.max(1, Number(el.getAttribute('colspan')) || 1);\n const rowspan = Math.max(1, Number(el.getAttribute('rowspan')) || 1);\n\n if (rowspan > 1) {\n el.style.position = \"absolute\";\n el.style.height = `${\n 50 * rowspan\n }px`;\n el.style.zIndex = \"1\";\n }\n\n const cStart = c;\n const cEnd = c + colspan;\n const rEnd = rStart + rowspan;\n\n el.style.gridColumn = `${cStart} / ${cEnd}`;\n el.style.gridRow = `${rStart} / ${rEnd}`;\n (el as any).dataset.cStart = String(cStart);\n\n if (opts.useStickyAttr && el.hasAttribute('colSticky')) {\n stickyLeftIndexes.push(cStart - 1);\n }\n\n if (opts.useStickyAttr && el.hasAttribute('lastColSticky')) {\n stickyRightIndexes.push(cStart - 1);\n }\n\n applySticky(el, cStart - 1, stickyLeftIndexes, stickyRightIndexes, columnWidths);\n\n for (let k = 0; k < colspan; k++) {\n const idx = c - 1 + k;\n carry[idx] = Math.max(carry[idx] || 0, rowspan);\n }\n\n maxRowspan = Math.max(maxRowspan, rowspan);\n c = cEnd;\n colCount = Math.max(colCount, cEnd - 1);\n });\n\n if (opts.handleRowBg && bg) {\n const rEnd = rStart + maxRowspan;\n bg.style.gridRow = `${rStart} / ${rEnd}`;\n }\n\n for (let i = 0; i < carry.length; i++) {\n if (carry[i] > 0) carry[i]--;\n }\n });\n\n return colCount;\n}\n\nfunction computeHeadLayout(\n headRows: HTMLElement[],\n carryHead: number[],\n colCount: number,\n stickyLeftIndexes: number[],\n stickyRightIndexes: number[],\n columnWidths: number[]\n): number {\n return layoutRows(\n headRows,\n carryHead,\n colCount,\n stickyLeftIndexes,\n stickyRightIndexes,\n columnWidths,\n {\n itemSelector: 'nile-grid-head-item',\n useStickyAttr: true,\n handleRowBg: false,\n }\n );\n}\n\nfunction computeBodyLayout(\n bodyRows: HTMLElement[],\n carryBody: number[],\n colCount: number,\n stickyLeftIndexes: number[],\n stickyRightIndexes: number[],\n columnWidths: number[]\n): number {\n return layoutRows(\n bodyRows,\n carryBody,\n colCount,\n stickyLeftIndexes,\n stickyRightIndexes,\n columnWidths,\n {\n itemSelector: 'nile-grid-cell-item',\n useStickyAttr: false,\n handleRowBg: true,\n }\n );\n}\n\nfunction computeColumnWidths(\n nileGrid: NileGrid,\n colCount: number,\n columnWidths: number[],\n slotEl: any\n) {\n const minCol = 60;\n const containerWidth = getContainerWidth(nileGrid);\n\n const desired = readDesiredFromHead(slotEl, colCount);\n const isSeeded = seedWidthsFromDesired(desired, columnWidths, minCol);\n\n distributeFlex(columnWidths, isSeeded, containerWidth, minCol);\n\n normalizeToContainer(columnWidths, containerWidth, minCol);\n\n clampAndRound(columnWidths, minCol);\n applyColumnsTemplate(nileGrid, columnWidths, slotEl);\n}\n\n\nfunction getContainerWidth(nileGrid: NileGrid): number {\n return Math.max(0, (nileGrid.getBoundingClientRect().width || 0) - 4);\n}\n\nfunction readDesiredFromHead(slotEl: any, colCount: number): (number | null)[] {\n const desired: (number | null)[] = Array(colCount).fill(null);\n const head = getHead(slotEl) as HTMLElement | null;\n if (!head) return desired;\n\n const headRows = Array.from(head.children).filter(\n el => el.tagName.toLowerCase() === 'nile-grid-row'\n ) as HTMLElement[];\n\n for (const row of headRows) {\n const items = Array.from(row.children).filter(\n el => el.tagName.toLowerCase() === 'nile-grid-head-item'\n ) as Array<HeadItemEl>;\n\n items\n .map(h => {\n const cStart = Number((h as any).dataset?.cStart) || 1;\n const colspan = Math.max(1, Number(h.getAttribute('colspan')) || 1);\n const attr = h.getAttribute('customWidth');\n const cw = attr != null ? Number(attr) : (h as any).customWidth ?? null;\n return { cStart, colspan, cw };\n })\n .filter(x => x.cw != null && !Number.isNaN(x.cw!))\n .sort((a, b) => {\n return a.colspan - b.colspan;\n })\n .forEach(({ cStart, colspan, cw }) => {\n const perCol = (cw as number) / colspan;\n for (let k = 0; k < colspan; k++) {\n const idx = cStart - 1 + k;\n if (idx >= 0 && idx < colCount && desired[idx] == null) {\n desired[idx] = perCol;\n }\n }\n });\n }\n return desired;\n}\n\nfunction seedWidthsFromDesired(\n desired: (number | null)[],\n columnWidths: number[],\n minCol: number\n): boolean[] {\n const isSeeded = Array(desired.length).fill(false);\n for (let i = 0; i < desired.length; i++) {\n const w = desired[i] ?? null;\n columnWidths[i] =\n w != null && !Number.isNaN(w) ? Math.max(minCol, Number(w)) : 0;\n isSeeded[i] = w != null && !Number.isNaN(w);\n }\n return isSeeded;\n}\n\nfunction distributeFlex(\n columnWidths: number[],\n isSeeded: boolean[],\n containerWidth: number,\n minCol: number\n) {\n const sumSeed = columnWidths.reduce((a, b) => a + b, 0);\n const remaining = containerWidth - sumSeed;\n const flexIdxs = Array.from(\n { length: columnWidths.length },\n (_, i) => i\n ).filter(i => !isSeeded[i]);\n if (flexIdxs.length === 0) return;\n\n const each = remaining / flexIdxs.length;\n for (const i of flexIdxs) columnWidths[i] = Math.max(minCol, each);\n}\n\nfunction normalizeToContainer(\n columnWidths: number[],\n containerWidth: number,\n minCol: number\n) {\n let total = columnWidths.reduce((a, b) => a + b, 0);\n\n if (total < containerWidth && columnWidths.length > 0) {\n const add = containerWidth - total;\n const weight = total || 1;\n for (let i = 0; i < columnWidths.length; i++) {\n columnWidths[i] += add * (columnWidths[i] / weight);\n }\n } else if (total > containerWidth) {\n let need = total - containerWidth;\n \n for (let iter = 0; iter < 8 && need > 0.5; iter++) {\n let weightSum = 0;\n const candidates: number[] = [];\n for (let i = 0; i < columnWidths.length; i++) {\n const reducible = Math.max(0, columnWidths[i] - minCol);\n if (reducible > 0) {\n candidates.push(i);\n weightSum += columnWidths[i];\n }\n }\n if (candidates.length === 0 || weightSum <= 0) break;\n\n let reduced = 0;\n for (const i of candidates) {\n const reducible = Math.max(0, columnWidths[i] - minCol);\n const share = columnWidths[i] / weightSum;\n const cut = Math.min(reducible, need * share);\n columnWidths[i] -= cut;\n reduced += cut;\n }\n need -= reduced;\n if (reduced < 0.5) break;\n }\n }\n}\n\nfunction clampAndRound(columnWidths: number[], minCol: number) {\n for (let i = 0; i < columnWidths.length; i++) {\n columnWidths[i] = Math.max(minCol, Math.round(columnWidths[i]));\n }\n}\n\nexport const layout = (\n nileGrid: NileGrid,\n slotEl: any,\n ensureWidths: any,\n rebuildTemplate: any,\n applyTemplate: any,\n stickyLeftIndexes: number[],\n stickyRightIndexes: number[]\n) => {\n const head = getHead(slotEl);\n const body = getBody(slotEl);\n if (!body) return;\n\n const headRows = head\n ? (Array.from(head.querySelectorAll('nile-grid-row')) as HTMLElement[])\n : [];\n const bodyRows = Array.from(\n body.querySelectorAll('nile-grid-row')\n ) as HTMLElement[];\n\n let colCount = 0;\n\n colCount = computeHeadLayout(\n headRows,\n [],\n colCount,\n stickyLeftIndexes,\n stickyRightIndexes,\n nileGrid.columnWidths\n );\n colCount = computeBodyLayout(\n bodyRows,\n [],\n colCount,\n stickyLeftIndexes,\n stickyRightIndexes,\n nileGrid.columnWidths\n );\n computeColumnWidths(nileGrid, colCount, nileGrid.columnWidths, slotEl);\n\n ensureWidths(colCount);\n body.style.gridAutoRows = 'auto';\n nileGrid.colTemplate = rebuildTemplate(colCount, nileGrid.columnWidths);\n applyTemplate(head, body, nileGrid.colTemplate, nileGrid.colTemplate);\n};\n\nfunction applySticky(\n el: HTMLElement,\n colIndex: number,\n stickyLeftIndexes: number[],\n stickyRightIndexes: number[],\n columnWidths: number[]\n) {\n const onLeft = stickyLeftIndexes.includes(colIndex);\n const onRight = stickyRightIndexes.includes(colIndex);\n\n if (!onLeft && !onRight) return;\n\n el.style.position = 'sticky';\n el.style.zIndex = '2';\n\n if (onLeft && !onRight) {\n const leftOrder = [...stickyLeftIndexes].sort((a, b) => a - b);\n const pos = leftOrder.indexOf(colIndex);\n let left = 0;\n for (let i = 0; i < pos; i++) left += columnWidths[leftOrder[i]] ?? 0;\n el.style.left = `${left}px`;\n return;\n }\n\n const rightOrder = [...stickyRightIndexes].sort((a, b) => b - a);\n const pos = rightOrder.indexOf(colIndex);\n\n const scroller = el.closest('nile-grid') as HTMLElement | null;\n const sb = scroller ? scroller.offsetWidth - scroller.clientWidth : 0;\n\n let right = sb;\n for (let i = 0; i < pos; i++) right += columnWidths[rightOrder[i]] ?? 0;\n\n el.style.right = `${right - 2}px`;\n}\n\n\nexport function applyColumnsTemplate(\n nileGrid: HTMLElement,\n columnWidths: number[],\n slotEl: HTMLElement\n) {\n const cols = columnWidths\n .map((w, idx) => {\n if (idx === columnWidths.length - 1) {\n return `minmax(${Math.round(w)}px, auto)`;\n }\n return `${Math.max(0, Math.round(w))}px`;\n })\n .join(' ');\n nileGrid.style.setProperty('--nile-grid-columns', cols);\n\n const head = slotEl.querySelector('nile-grid-head') as HTMLElement | null;\n if (head) {\n head.style.setProperty('--nile-grid-columns', cols);\n head\n .querySelectorAll('nile-grid-row')\n .forEach(r =>\n (r as HTMLElement).style.setProperty('--nile-grid-columns', cols)\n );\n }\n const body = slotEl.querySelector('nile-grid-body') as HTMLElement | null;\n if (body) {\n body.style.setProperty('--nile-grid-columns', cols);\n body\n .querySelectorAll('nile-grid-row')\n .forEach(r =>\n (r as HTMLElement).style.setProperty('--nile-grid-columns', cols)\n );\n }\n}\n"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { TemplateResult } from 'lit';
|
|
2
|
+
import type { ColumnDef } from './types.js';
|
|
3
|
+
export declare class GridRenderer {
|
|
4
|
+
static renderHeader(columnDefs: ColumnDef[], enableColResize: boolean, onResizeStart: (e: MouseEvent, col: ColumnDef, index: number) => void): TemplateResult;
|
|
5
|
+
static renderBody(rowData: any[], columnDefs: ColumnDef[], enableVirtualScroll: boolean, onVirtualizeRender: (row: any, rowIndex: number) => TemplateResult): TemplateResult;
|
|
6
|
+
static renderRowWithSpanning(row: any, rowIndex: number, columnDefs: ColumnDef[]): TemplateResult;
|
|
7
|
+
private static shouldShowResizeHandle;
|
|
8
|
+
}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { html } from 'lit';
|
|
2
|
+
import { getGridTemplateColumns, calculateColSpan } from './utils.js';
|
|
3
|
+
export class GridRenderer {
|
|
4
|
+
static renderHeader(columnDefs, enableColResize, onResizeStart) {
|
|
5
|
+
return html `
|
|
6
|
+
<div class="grid-header" style="grid-template-columns: ${getGridTemplateColumns(columnDefs)};">
|
|
7
|
+
${columnDefs.map((col, index) => html `
|
|
8
|
+
<div class="grid-header-cell">
|
|
9
|
+
<span>${col.headerName || col.field}</span>
|
|
10
|
+
${this.shouldShowResizeHandle(col, enableColResize) ? html `
|
|
11
|
+
<div
|
|
12
|
+
class="grid-resize-handle"
|
|
13
|
+
@mousedown=${(e) => onResizeStart(e, col, index)}
|
|
14
|
+
title="Drag to resize column"
|
|
15
|
+
></div>
|
|
16
|
+
` : ''}
|
|
17
|
+
</div>
|
|
18
|
+
`)}
|
|
19
|
+
</div>
|
|
20
|
+
`;
|
|
21
|
+
}
|
|
22
|
+
static renderBody(rowData, columnDefs, enableVirtualScroll, onVirtualizeRender) {
|
|
23
|
+
if (rowData.length === 0) {
|
|
24
|
+
return html `
|
|
25
|
+
<div class="grid-empty">
|
|
26
|
+
<div class="empty-text">No data available</div>
|
|
27
|
+
</div>
|
|
28
|
+
`;
|
|
29
|
+
}
|
|
30
|
+
if (enableVirtualScroll) {
|
|
31
|
+
return html `
|
|
32
|
+
<div class="grid-body">
|
|
33
|
+
${onVirtualizeRender}
|
|
34
|
+
</div>
|
|
35
|
+
`;
|
|
36
|
+
}
|
|
37
|
+
return html `
|
|
38
|
+
<div class="grid-body">
|
|
39
|
+
${rowData.map((row, rowIndex) => this.renderRowWithSpanning(row, rowIndex, columnDefs))}
|
|
40
|
+
</div>
|
|
41
|
+
`;
|
|
42
|
+
}
|
|
43
|
+
static renderRowWithSpanning(row, rowIndex, columnDefs) {
|
|
44
|
+
const cells = [];
|
|
45
|
+
let currentColIndex = 0;
|
|
46
|
+
for (let colIndex = 0; colIndex < columnDefs.length; colIndex++) {
|
|
47
|
+
const col = columnDefs[colIndex];
|
|
48
|
+
// Check if this column should be skipped due to previous spanning
|
|
49
|
+
if (currentColIndex > colIndex) {
|
|
50
|
+
continue;
|
|
51
|
+
}
|
|
52
|
+
// Calculate column span
|
|
53
|
+
const colSpan = calculateColSpan(col, row, rowIndex, colIndex);
|
|
54
|
+
if (colSpan > 0) {
|
|
55
|
+
const cellStyle = `grid-column: ${currentColIndex + 1} / span ${colSpan};`;
|
|
56
|
+
cells.push(html `
|
|
57
|
+
<div class="grid-cell" style="${cellStyle}">
|
|
58
|
+
<span>${row[col.field]}</span>
|
|
59
|
+
</div>
|
|
60
|
+
`);
|
|
61
|
+
currentColIndex += colSpan;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
return html `
|
|
65
|
+
<div class="grid-row" style="grid-template-columns: ${getGridTemplateColumns(columnDefs)};">
|
|
66
|
+
${cells}
|
|
67
|
+
</div>
|
|
68
|
+
`;
|
|
69
|
+
}
|
|
70
|
+
static shouldShowResizeHandle(col, enableColResize) {
|
|
71
|
+
if (!enableColResize)
|
|
72
|
+
return false;
|
|
73
|
+
if (col.resizable === false)
|
|
74
|
+
return false;
|
|
75
|
+
return true;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=renderer.js.map
|