@aquera/nile-elements 1.3.4-beta-1 → 1.3.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 +3 -0
- package/demo/index.html +27 -20
- package/dist/{fixture-54600b35.cjs.js → fixture-1c49c014.cjs.js} +2 -2
- package/dist/{fixture-73855806.cjs.js.map → fixture-1c49c014.cjs.js.map} +1 -1
- package/dist/{fixture-9871e8a9.esm.js → fixture-985bba12.esm.js} +1 -1
- package/dist/index.js +3 -2
- 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.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.cjs.js +1 -1
- package/dist/nile-chip/nile-chip.cjs.js.map +1 -1
- package/dist/nile-chip/nile-chip.esm.js +3 -2
- 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-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-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-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-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-textarea/nile-textarea.test.cjs.js +1 -1
- package/dist/nile-textarea/nile-textarea.test.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/src/nile-chip/nile-chip.js +8 -0
- package/dist/src/nile-chip/nile-chip.js.map +1 -1
- package/dist/src/version.js +1 -1
- package/dist/src/version.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/src/nile-chip/nile-chip.ts +9 -0
- package/dist/fixture-54600b35.cjs.js.map +0 -1
- package/dist/fixture-5b79f853.cjs.js +0 -395
- package/dist/fixture-5b79f853.cjs.js.map +0 -1
- package/dist/fixture-73855806.cjs.js +0 -395
- package/dist/fixture-90b199c4.esm.js +0 -569
- package/dist/fixture-c1d78368.cjs.js +0 -395
- package/dist/fixture-c1d78368.cjs.js.map +0 -1
- package/dist/fixture-cf7bfcf5.esm.js +0 -569
- package/dist/fixture-dbd66009.cjs.js +0 -395
- package/dist/fixture-dbd66009.cjs.js.map +0 -1
- package/dist/nile-code-editor/backup_nile-code-editor copy.cjs.js +0 -2
- package/dist/nile-code-editor/backup_nile-code-editor copy.cjs.js.map +0 -1
- package/dist/nile-code-editor/backup_nile-code-editor copy.esm.js +0 -1
- package/dist/nile-grid/nile-grid.types.cjs.js +0 -2
- package/dist/nile-grid/nile-grid.types.cjs.js.map +0 -1
- package/dist/nile-grid/nile-grid.types.esm.js +0 -1
- package/dist/nile-grid-body/index.cjs.js +0 -2
- package/dist/nile-grid-body/index.cjs.js.map +0 -1
- package/dist/nile-grid-body/index.esm.js +0 -1
- package/dist/nile-grid-body/nile-grid-body.cjs.js +0 -2
- package/dist/nile-grid-body/nile-grid-body.cjs.js.map +0 -1
- package/dist/nile-grid-body/nile-grid-body.css.cjs.js +0 -2
- package/dist/nile-grid-body/nile-grid-body.css.cjs.js.map +0 -1
- package/dist/nile-grid-body/nile-grid-body.css.esm.js +0 -10
- package/dist/nile-grid-body/nile-grid-body.esm.js +0 -5
- package/dist/nile-grid-cell-item/index.cjs.js +0 -2
- package/dist/nile-grid-cell-item/index.cjs.js.map +0 -1
- package/dist/nile-grid-cell-item/index.esm.js +0 -1
- package/dist/nile-grid-cell-item/nile-grid-cell-item.cjs.js +0 -2
- package/dist/nile-grid-cell-item/nile-grid-cell-item.cjs.js.map +0 -1
- package/dist/nile-grid-cell-item/nile-grid-cell-item.css.cjs.js +0 -2
- package/dist/nile-grid-cell-item/nile-grid-cell-item.css.cjs.js.map +0 -1
- package/dist/nile-grid-cell-item/nile-grid-cell-item.css.esm.js +0 -35
- package/dist/nile-grid-cell-item/nile-grid-cell-item.esm.js +0 -12
- package/dist/nile-grid-cell-item/nile-grid-cell-item.utils.cjs.js +0 -2
- package/dist/nile-grid-cell-item/nile-grid-cell-item.utils.cjs.js.map +0 -1
- package/dist/nile-grid-cell-item/nile-grid-cell-item.utils.esm.js +0 -1
- package/dist/nile-grid-head/index.cjs.js +0 -2
- package/dist/nile-grid-head/index.cjs.js.map +0 -1
- package/dist/nile-grid-head/index.esm.js +0 -1
- package/dist/nile-grid-head/nile-grid-head.cjs.js +0 -2
- package/dist/nile-grid-head/nile-grid-head.cjs.js.map +0 -1
- package/dist/nile-grid-head/nile-grid-head.css.cjs.js +0 -2
- package/dist/nile-grid-head/nile-grid-head.css.cjs.js.map +0 -1
- package/dist/nile-grid-head/nile-grid-head.css.esm.js +0 -7
- package/dist/nile-grid-head/nile-grid-head.esm.js +0 -5
- package/dist/nile-grid-head-item/index.cjs.js +0 -2
- package/dist/nile-grid-head-item/index.cjs.js.map +0 -1
- package/dist/nile-grid-head-item/index.esm.js +0 -1
- package/dist/nile-grid-head-item/nile-grid-head-item.cjs.js +0 -2
- package/dist/nile-grid-head-item/nile-grid-head-item.cjs.js.map +0 -1
- package/dist/nile-grid-head-item/nile-grid-head-item.css.cjs.js +0 -2
- package/dist/nile-grid-head-item/nile-grid-head-item.css.cjs.js.map +0 -1
- package/dist/nile-grid-head-item/nile-grid-head-item.css.esm.js +0 -34
- package/dist/nile-grid-head-item/nile-grid-head-item.esm.js +0 -12
- package/dist/nile-grid-head-item/nile-grid-head-item.utils.cjs.js +0 -2
- package/dist/nile-grid-head-item/nile-grid-head-item.utils.cjs.js.map +0 -1
- package/dist/nile-grid-head-item/nile-grid-head-item.utils.esm.js +0 -1
- package/dist/nile-grid-row/index.cjs.js +0 -2
- package/dist/nile-grid-row/index.cjs.js.map +0 -1
- package/dist/nile-grid-row/index.esm.js +0 -1
- package/dist/nile-grid-row/nile-grid-row.cjs.js +0 -2
- package/dist/nile-grid-row/nile-grid-row.cjs.js.map +0 -1
- package/dist/nile-grid-row/nile-grid-row.css.cjs.js +0 -2
- package/dist/nile-grid-row/nile-grid-row.css.cjs.js.map +0 -1
- package/dist/nile-grid-row/nile-grid-row.css.esm.js +0 -15
- package/dist/nile-grid-row/nile-grid-row.esm.js +0 -7
- package/dist/nile-rich-text-editor/utils.cjs.js +0 -2
- package/dist/nile-rich-text-editor/utils.cjs.js.map +0 -1
- package/dist/nile-rich-text-editor/utils.esm.js +0 -1
- package/dist/nile-sidebar/index.cjs.js +0 -2
- package/dist/nile-sidebar/index.cjs.js.map +0 -1
- package/dist/nile-sidebar/index.esm.js +0 -75
- package/dist/nile-sidebar-menu/index.cjs.js +0 -2
- package/dist/nile-sidebar-menu/index.cjs.js.map +0 -1
- package/dist/nile-sidebar-menu/index.esm.js +0 -1
- package/dist/nile-sidebar-menu/nile-sidebar-menu.cjs.js +0 -2
- package/dist/nile-sidebar-menu/nile-sidebar-menu.cjs.js.map +0 -1
- package/dist/nile-sidebar-menu/nile-sidebar-menu.css.cjs.js +0 -2
- package/dist/nile-sidebar-menu/nile-sidebar-menu.css.cjs.js.map +0 -1
- package/dist/nile-sidebar-menu/nile-sidebar-menu.css.esm.js +0 -38
- package/dist/nile-sidebar-menu/nile-sidebar-menu.esm.js +0 -10
- package/dist/nile-sidebar-menu-items/index.cjs.js +0 -2
- package/dist/nile-sidebar-menu-items/index.cjs.js.map +0 -1
- package/dist/nile-sidebar-menu-items/index.esm.js +0 -1
- package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.cjs.js +0 -2
- package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.cjs.js.map +0 -1
- package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.css.cjs.js +0 -2
- package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.css.cjs.js.map +0 -1
- package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.css.esm.js +0 -36
- package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.esm.js +0 -15
- package/dist/nile-sidebar-wrapper/index.cjs.js +0 -2
- package/dist/nile-sidebar-wrapper/index.cjs.js.map +0 -1
- package/dist/nile-sidebar-wrapper/index.esm.js +0 -1
- package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.cjs.js +0 -2
- package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.cjs.js.map +0 -1
- package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.css.cjs.js +0 -2
- package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.css.cjs.js.map +0 -1
- package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.css.esm.js +0 -105
- package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.esm.js +0 -16
- package/dist/nile-virtual-select/group-manager.cjs.js +0 -2
- package/dist/nile-virtual-select/group-manager.cjs.js.map +0 -1
- package/dist/nile-virtual-select/group-manager.esm.js +0 -1
- package/dist/nile-virtual-select/temp_nile-virtual-select copy.cjs.js +0 -2
- package/dist/nile-virtual-select/temp_nile-virtual-select copy.cjs.js.map +0 -1
- package/dist/nile-virtual-select/temp_nile-virtual-select copy.esm.js +0 -231
- package/dist/scopedElementsWrapper-1bff26ef.cjs.js +0 -2
- package/dist/scopedElementsWrapper-1bff26ef.cjs.js.map +0 -1
- package/dist/scopedElementsWrapper-4c29be11.esm.js +0 -7
- package/dist/scopedElementsWrapper-a112fc73.cjs.js +0 -6
- package/dist/scopedElementsWrapper-a112fc73.cjs.js.map +0 -1
- package/dist/scopedElementsWrapper-c815042c.cjs.js +0 -2
- package/dist/scopedElementsWrapper-c815042c.cjs.js.map +0 -1
- package/dist/src/internal/portal-manager.d.ts +0 -53
- package/dist/src/internal/portal-manager.js +0 -196
- package/dist/src/internal/portal-manager.js.map +0 -1
- package/dist/src/internal/portal.d.ts +0 -60
- package/dist/src/internal/portal.js +0 -199
- package/dist/src/internal/portal.js.map +0 -1
- package/dist/src/internal/resizable-helper.d.ts +0 -59
- package/dist/src/internal/resizable-helper.js +0 -115
- package/dist/src/internal/resizable-helper.js.map +0 -1
- package/dist/src/internal/resizable-styles.d.ts +0 -16
- package/dist/src/internal/resizable-styles.js +0 -144
- package/dist/src/internal/resizable-styles.js.map +0 -1
- package/dist/src/internal/virtualizer-error-handler.d.ts +0 -30
- package/dist/src/internal/virtualizer-error-handler.js +0 -82
- package/dist/src/internal/virtualizer-error-handler.js.map +0 -1
- package/dist/src/lib/index.d.ts +0 -7
- package/dist/src/lib/index.js +0 -8
- package/dist/src/lib/index.js.map +0 -1
- package/dist/src/lib/virtualize.d.ts +0 -32
- package/dist/src/lib/virtualize.js +0 -105
- package/dist/src/lib/virtualize.js.map +0 -1
- package/dist/src/lib/virtualize.test.d.ts +0 -7
- package/dist/src/lib/virtualize.test.js +0 -57
- package/dist/src/lib/virtualize.test.js.map +0 -1
- package/dist/src/nile-badge/__snapshots__/nile-badge.test.snap.js +0 -17
- package/dist/src/nile-calendar/__snapshots__/nile-calendar.test.snap.js +0 -310
- package/dist/src/nile-card/__snapshots__/nile-card.test.snap.js +0 -34
- package/dist/src/nile-checkbox/__snapshots__/nile-checkbox.test.snap.js +0 -31
- package/dist/src/nile-code-editor/Old_theme copy.d.ts +0 -191
- package/dist/src/nile-code-editor/Old_theme copy.js +0 -193
- package/dist/src/nile-code-editor/Old_theme copy.js.map +0 -1
- 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 +0 -675
- package/dist/src/nile-code-editor/backup_nile-code-editor copy.js.map +0 -1
- package/dist/src/nile-code-editor/theme copy.d.ts +0 -191
- package/dist/src/nile-code-editor/theme copy.js +0 -193
- package/dist/src/nile-code-editor/theme copy.js.map +0 -1
- package/dist/src/nile-floating-panel/anchor-manager.d.ts +0 -26
- package/dist/src/nile-floating-panel/anchor-manager.js +0 -49
- package/dist/src/nile-floating-panel/anchor-manager.js.map +0 -1
- package/dist/src/nile-floating-panel/content-manager.d.ts +0 -23
- package/dist/src/nile-floating-panel/content-manager.js +0 -67
- package/dist/src/nile-floating-panel/content-manager.js.map +0 -1
- package/dist/src/nile-floating-panel/event-manager.d.ts +0 -38
- package/dist/src/nile-floating-panel/event-manager.js +0 -81
- package/dist/src/nile-floating-panel/event-manager.js.map +0 -1
- package/dist/src/nile-floating-panel/index.d.ts +0 -1
- package/dist/src/nile-floating-panel/index.js +0 -2
- package/dist/src/nile-floating-panel/index.js.map +0 -1
- package/dist/src/nile-floating-panel/nile-floating-panel.css.d.ts +0 -17
- package/dist/src/nile-floating-panel/nile-floating-panel.css.js +0 -51
- package/dist/src/nile-floating-panel/nile-floating-panel.css.js.map +0 -1
- package/dist/src/nile-floating-panel/nile-floating-panel.d.ts +0 -67
- package/dist/src/nile-floating-panel/nile-floating-panel.js +0 -203
- package/dist/src/nile-floating-panel/nile-floating-panel.js.map +0 -1
- package/dist/src/nile-floating-panel/position-manager.d.ts +0 -47
- package/dist/src/nile-floating-panel/position-manager.js +0 -94
- package/dist/src/nile-floating-panel/position-manager.js.map +0 -1
- package/dist/src/nile-floating-panel/style-manager.d.ts +0 -31
- package/dist/src/nile-floating-panel/style-manager.js +0 -74
- package/dist/src/nile-floating-panel/style-manager.js.map +0 -1
- package/dist/src/nile-floating-panel/types.d.ts +0 -29
- package/dist/src/nile-floating-panel/types.js +0 -8
- package/dist/src/nile-floating-panel/types.js.map +0 -1
- package/dist/src/nile-grid/data-processor.d.ts +0 -37
- package/dist/src/nile-grid/data-processor.js +0 -122
- package/dist/src/nile-grid/data-processor.js.map +0 -1
- package/dist/src/nile-grid/event-handlers.d.ts +0 -35
- package/dist/src/nile-grid/event-handlers.js +0 -158
- package/dist/src/nile-grid/event-handlers.js.map +0 -1
- package/dist/src/nile-grid/nile-grid.types.d.ts +0 -3
- package/dist/src/nile-grid/nile-grid.types.js +0 -2
- package/dist/src/nile-grid/nile-grid.types.js.map +0 -1
- package/dist/src/nile-grid/renderer.d.ts +0 -8
- package/dist/src/nile-grid/renderer.js +0 -78
- package/dist/src/nile-grid/renderer.js.map +0 -1
- package/dist/src/nile-grid/resize-handler.d.ts +0 -4
- package/dist/src/nile-grid/resize-handler.js +0 -36
- package/dist/src/nile-grid/resize-handler.js.map +0 -1
- package/dist/src/nile-grid/types.d.ts +0 -32
- package/dist/src/nile-grid/types.js +0 -2
- package/dist/src/nile-grid/types.js.map +0 -1
- package/dist/src/nile-grid/utils.d.ts +0 -4
- package/dist/src/nile-grid/utils.js +0 -32
- package/dist/src/nile-grid/utils.js.map +0 -1
- package/dist/src/nile-grid-body/index.d.ts +0 -1
- package/dist/src/nile-grid-body/index.js +0 -2
- package/dist/src/nile-grid-body/index.js.map +0 -1
- package/dist/src/nile-grid-body/nile-grid-body.css.d.ts +0 -12
- package/dist/src/nile-grid-body/nile-grid-body.css.js +0 -22
- package/dist/src/nile-grid-body/nile-grid-body.css.js.map +0 -1
- package/dist/src/nile-grid-body/nile-grid-body.d.ts +0 -29
- package/dist/src/nile-grid-body/nile-grid-body.js +0 -43
- package/dist/src/nile-grid-body/nile-grid-body.js.map +0 -1
- package/dist/src/nile-grid-cell-item/index.d.ts +0 -1
- package/dist/src/nile-grid-cell-item/index.js +0 -2
- package/dist/src/nile-grid-cell-item/index.js.map +0 -1
- package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.d.ts +0 -12
- package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.js +0 -47
- package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.js.map +0 -1
- package/dist/src/nile-grid-cell-item/nile-grid-cell-item.d.ts +0 -36
- package/dist/src/nile-grid-cell-item/nile-grid-cell-item.js +0 -93
- package/dist/src/nile-grid-cell-item/nile-grid-cell-item.js.map +0 -1
- package/dist/src/nile-grid-cell-item/nile-grid-cell-item.utils.d.ts +0 -10
- package/dist/src/nile-grid-cell-item/nile-grid-cell-item.utils.js +0 -34
- package/dist/src/nile-grid-cell-item/nile-grid-cell-item.utils.js.map +0 -1
- package/dist/src/nile-grid-head/index.d.ts +0 -1
- package/dist/src/nile-grid-head/index.js +0 -2
- package/dist/src/nile-grid-head/index.js.map +0 -1
- package/dist/src/nile-grid-head/nile-grid-head.css.d.ts +0 -12
- package/dist/src/nile-grid-head/nile-grid-head.css.js +0 -19
- package/dist/src/nile-grid-head/nile-grid-head.css.js.map +0 -1
- package/dist/src/nile-grid-head/nile-grid-head.d.ts +0 -28
- package/dist/src/nile-grid-head/nile-grid-head.js +0 -41
- package/dist/src/nile-grid-head/nile-grid-head.js.map +0 -1
- package/dist/src/nile-grid-head-item/index.d.ts +0 -1
- package/dist/src/nile-grid-head-item/index.js +0 -2
- package/dist/src/nile-grid-head-item/index.js.map +0 -1
- package/dist/src/nile-grid-head-item/nile-grid-head-item.css.d.ts +0 -12
- package/dist/src/nile-grid-head-item/nile-grid-head-item.css.js +0 -46
- package/dist/src/nile-grid-head-item/nile-grid-head-item.css.js.map +0 -1
- package/dist/src/nile-grid-head-item/nile-grid-head-item.d.ts +0 -37
- package/dist/src/nile-grid-head-item/nile-grid-head-item.js +0 -100
- package/dist/src/nile-grid-head-item/nile-grid-head-item.js.map +0 -1
- package/dist/src/nile-grid-head-item/nile-grid-head-item.utils.d.ts +0 -10
- package/dist/src/nile-grid-head-item/nile-grid-head-item.utils.js +0 -34
- package/dist/src/nile-grid-head-item/nile-grid-head-item.utils.js.map +0 -1
- package/dist/src/nile-grid-row/index.d.ts +0 -1
- package/dist/src/nile-grid-row/index.js +0 -2
- package/dist/src/nile-grid-row/index.js.map +0 -1
- package/dist/src/nile-grid-row/nile-grid-row.css.d.ts +0 -12
- package/dist/src/nile-grid-row/nile-grid-row.css.js +0 -27
- package/dist/src/nile-grid-row/nile-grid-row.css.js.map +0 -1
- package/dist/src/nile-grid-row/nile-grid-row.d.ts +0 -29
- package/dist/src/nile-grid-row/nile-grid-row.js +0 -45
- package/dist/src/nile-grid-row/nile-grid-row.js.map +0 -1
- package/dist/src/nile-hero/__snapshots__/nile-hero.test.snap.js +0 -47
- package/dist/src/nile-icon/__snapshots__/nile-icon.test.snap.js +0 -16
- package/dist/src/nile-input/__snapshots__/nile-input.test.snap.js +0 -75
- package/dist/src/nile-menu/portal-manager.d.ts +0 -39
- package/dist/src/nile-menu/portal-manager.js +0 -340
- package/dist/src/nile-menu/portal-manager.js.map +0 -1
- package/dist/src/nile-menu/portal-utils.d.ts +0 -21
- package/dist/src/nile-menu/portal-utils.js +0 -128
- package/dist/src/nile-menu/portal-utils.js.map +0 -1
- package/dist/src/nile-popover/__snapshots__/nile-popover.test.snap.js +0 -22
- package/dist/src/nile-popover/popover-portal-handler.d.ts +0 -21
- package/dist/src/nile-popover/popover-portal-handler.js +0 -106
- package/dist/src/nile-popover/popover-portal-handler.js.map +0 -1
- package/dist/src/nile-portal-wrapper/index.d.ts +0 -1
- package/dist/src/nile-portal-wrapper/index.js +0 -2
- package/dist/src/nile-portal-wrapper/index.js.map +0 -1
- package/dist/src/nile-portal-wrapper/nile-portal-wrapper.d.ts +0 -47
- package/dist/src/nile-portal-wrapper/nile-portal-wrapper.js +0 -451
- package/dist/src/nile-portal-wrapper/nile-portal-wrapper.js.map +0 -1
- package/dist/src/nile-rich-text-editor/utils.d.ts +0 -13
- package/dist/src/nile-rich-text-editor/utils.js +0 -538
- package/dist/src/nile-rich-text-editor/utils.js.map +0 -1
- package/dist/src/nile-select/body-append-manager.d.ts +0 -90
- package/dist/src/nile-select/body-append-manager.js +0 -298
- package/dist/src/nile-select/body-append-manager.js.map +0 -1
- package/dist/src/nile-sidebar/index.d.ts +0 -28
- package/dist/src/nile-sidebar/index.js +0 -116
- package/dist/src/nile-sidebar/index.js.map +0 -1
- package/dist/src/nile-sidebar-menu/index.d.ts +0 -1
- package/dist/src/nile-sidebar-menu/index.js +0 -2
- package/dist/src/nile-sidebar-menu/index.js.map +0 -1
- package/dist/src/nile-sidebar-menu/nile-sidebar-menu.css.d.ts +0 -12
- package/dist/src/nile-sidebar-menu/nile-sidebar-menu.css.js +0 -47
- package/dist/src/nile-sidebar-menu/nile-sidebar-menu.css.js.map +0 -1
- package/dist/src/nile-sidebar-menu/nile-sidebar-menu.d.ts +0 -37
- package/dist/src/nile-sidebar-menu/nile-sidebar-menu.js +0 -84
- package/dist/src/nile-sidebar-menu/nile-sidebar-menu.js.map +0 -1
- package/dist/src/nile-sidebar-menu-items/index.d.ts +0 -1
- package/dist/src/nile-sidebar-menu-items/index.js +0 -2
- package/dist/src/nile-sidebar-menu-items/index.js.map +0 -1
- package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.css.d.ts +0 -12
- package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.css.js +0 -45
- package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.css.js.map +0 -1
- package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.d.ts +0 -35
- package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.js +0 -78
- package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.js.map +0 -1
- package/dist/src/nile-sidebar-wrapper/index.d.ts +0 -1
- package/dist/src/nile-sidebar-wrapper/index.js +0 -2
- package/dist/src/nile-sidebar-wrapper/index.js.map +0 -1
- package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.css.d.ts +0 -12
- package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.css.js +0 -114
- package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.css.js.map +0 -1
- package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.d.ts +0 -35
- package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.js +0 -89
- package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.js.map +0 -1
- package/dist/src/nile-table-body/virtual-scroll-helper.d.ts +0 -9
- package/dist/src/nile-table-body/virtual-scroll-helper.js +0 -24
- package/dist/src/nile-table-body/virtual-scroll-helper.js.map +0 -1
- package/dist/src/nile-virtual-select/body-append-helper.d.ts +0 -16
- package/dist/src/nile-virtual-select/body-append-helper.js +0 -95
- package/dist/src/nile-virtual-select/body-append-helper.js.map +0 -1
- package/dist/src/nile-virtual-select/group-manager.d.ts +0 -32
- package/dist/src/nile-virtual-select/group-manager.js +0 -134
- package/dist/src/nile-virtual-select/group-manager.js.map +0 -1
- package/dist/src/nile-virtual-select/portal-utils.d.ts +0 -65
- package/dist/src/nile-virtual-select/portal-utils.js +0 -376
- package/dist/src/nile-virtual-select/portal-utils.js.map +0 -1
- package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.d.ts +0 -273
- package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.js +0 -1305
- package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.js.map +0 -1
- package/dist/src/nile-virtual-select/virtualizer-error-handler.d.ts +0 -21
- package/dist/src/nile-virtual-select/virtualizer-error-handler.js +0 -56
- package/dist/src/nile-virtual-select/virtualizer-error-handler.js.map +0 -1
- package/dist/src/nile-virtual-select-disabled/index.d.ts +0 -1
- package/dist/src/nile-virtual-select-disabled/index.js +0 -2
- package/dist/src/nile-virtual-select-disabled/index.js.map +0 -1
- package/dist/src/nile-virtual-select-disabled/nile-virtual-select.css.d.ts +0 -12
- package/dist/src/nile-virtual-select-disabled/nile-virtual-select.css.js +0 -538
- package/dist/src/nile-virtual-select-disabled/nile-virtual-select.css.js.map +0 -1
- package/dist/src/nile-virtual-select-disabled/nile-virtual-select.d.ts +0 -299
- package/dist/src/nile-virtual-select-disabled/nile-virtual-select.js +0 -1441
- package/dist/src/nile-virtual-select-disabled/nile-virtual-select.js.map +0 -1
- package/dist/src/nile-virtual-select-disabled/nile-virtual-select.test.d.ts +0 -7
- package/dist/src/nile-virtual-select-disabled/nile-virtual-select.test.js +0 -631
- package/dist/src/nile-virtual-select-disabled/nile-virtual-select.test.js.map +0 -1
- package/dist/src/nile-virtual-select-disabled/portal-manager.d.ts +0 -45
- package/dist/src/nile-virtual-select-disabled/portal-manager.js +0 -333
- package/dist/src/nile-virtual-select-disabled/portal-manager.js.map +0 -1
- package/dist/src/nile-virtual-select-disabled/renderer.d.ts +0 -16
- package/dist/src/nile-virtual-select-disabled/renderer.js +0 -79
- package/dist/src/nile-virtual-select-disabled/renderer.js.map +0 -1
- package/dist/src/nile-virtual-select-disabled/search-manager.d.ts +0 -12
- package/dist/src/nile-virtual-select-disabled/search-manager.js +0 -40
- package/dist/src/nile-virtual-select-disabled/search-manager.js.map +0 -1
- package/dist/src/nile-virtual-select-disabled/selection-manager.d.ts +0 -12
- package/dist/src/nile-virtual-select-disabled/selection-manager.js +0 -64
- package/dist/src/nile-virtual-select-disabled/selection-manager.js.map +0 -1
- package/dist/src/nile-virtual-select-disabled/types.d.ts +0 -50
- package/dist/src/nile-virtual-select-disabled/types.js +0 -8
- package/dist/src/nile-virtual-select-disabled/types.js.map +0 -1
- package/dist/src/nile-virtual-table-body/index.d.ts +0 -2
- package/dist/src/nile-virtual-table-body/index.js +0 -3
- package/dist/src/nile-virtual-table-body/index.js.map +0 -1
- package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.d.ts +0 -1
- package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.js +0 -44
- package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.js.map +0 -1
- package/dist/src/nile-virtual-table-body/nile-virtual-table-body.d.ts +0 -50
- package/dist/src/nile-virtual-table-body/nile-virtual-table-body.js +0 -135
- package/dist/src/nile-virtual-table-body/nile-virtual-table-body.js.map +0 -1
- package/dist/src/nile-virtual-table-body/renderer.d.ts +0 -16
- package/dist/src/nile-virtual-table-body/renderer.js +0 -49
- package/dist/src/nile-virtual-table-body/renderer.js.map +0 -1
- package/dist/src/utilities/stepper-utils.d.ts +0 -71
- package/dist/src/utilities/stepper-utils.js +0 -108
- package/dist/src/utilities/stepper-utils.js.map +0 -1
|
@@ -1,376 +0,0 @@
|
|
|
1
|
-
export class PortalUtils {
|
|
2
|
-
static calculateAvailableSpace(referenceElement) {
|
|
3
|
-
const rect = referenceElement.getBoundingClientRect();
|
|
4
|
-
const viewportHeight = window.innerHeight;
|
|
5
|
-
const spaceBelow = viewportHeight - rect.bottom;
|
|
6
|
-
const spaceAbove = rect.top;
|
|
7
|
-
return { spaceAbove, spaceBelow, viewportHeight };
|
|
8
|
-
}
|
|
9
|
-
static getOptimalPlacement(referenceElement) {
|
|
10
|
-
const { spaceAbove, spaceBelow } = this.calculateAvailableSpace(referenceElement);
|
|
11
|
-
if (spaceBelow < 200 && spaceAbove > spaceBelow) {
|
|
12
|
-
return 'top';
|
|
13
|
-
}
|
|
14
|
-
return 'bottom';
|
|
15
|
-
}
|
|
16
|
-
static findBoundaryElements(component) {
|
|
17
|
-
const boundaryElements = [];
|
|
18
|
-
let currentElement = component.parentElement;
|
|
19
|
-
while (currentElement && currentElement !== document.body) {
|
|
20
|
-
const computedStyle = window.getComputedStyle(currentElement);
|
|
21
|
-
const overflow = computedStyle.overflow;
|
|
22
|
-
const overflowY = computedStyle.overflowY;
|
|
23
|
-
const overflowX = computedStyle.overflowX;
|
|
24
|
-
if (overflow === 'auto' || overflow === 'scroll' ||
|
|
25
|
-
overflowY === 'auto' || overflowY === 'scroll' ||
|
|
26
|
-
overflowX === 'auto' || overflowX === 'scroll') {
|
|
27
|
-
boundaryElements.push(currentElement);
|
|
28
|
-
}
|
|
29
|
-
if (currentElement.hasAttribute('data-floating-boundary') ||
|
|
30
|
-
currentElement.classList.contains('floating-boundary') ||
|
|
31
|
-
currentElement.classList.contains('scroll-container')) {
|
|
32
|
-
boundaryElements.push(currentElement);
|
|
33
|
-
}
|
|
34
|
-
currentElement = currentElement.parentElement;
|
|
35
|
-
}
|
|
36
|
-
return boundaryElements.length > 0 ? boundaryElements : undefined;
|
|
37
|
-
}
|
|
38
|
-
static calculateOptimalHeight(referenceRect, viewportHeight, placement) {
|
|
39
|
-
const spaceBelow = viewportHeight - (referenceRect.y + referenceRect.height);
|
|
40
|
-
const spaceAbove = referenceRect.y;
|
|
41
|
-
if (spaceAbove > spaceBelow) {
|
|
42
|
-
return Math.max(spaceAbove - 20, 100);
|
|
43
|
-
}
|
|
44
|
-
else if (spaceBelow > spaceAbove) {
|
|
45
|
-
return Math.max(spaceBelow - 20, 100);
|
|
46
|
-
}
|
|
47
|
-
return Math.max(Math.min(spaceAbove, spaceBelow) - 20, 100);
|
|
48
|
-
}
|
|
49
|
-
static extractStylesAsCSS(styles) {
|
|
50
|
-
if (typeof styles === 'string') {
|
|
51
|
-
return styles;
|
|
52
|
-
}
|
|
53
|
-
if (Array.isArray(styles)) {
|
|
54
|
-
return styles.map(style => this.extractStylesAsCSS(style)).join('\n');
|
|
55
|
-
}
|
|
56
|
-
if (styles && typeof styles === 'object' && styles.cssText) {
|
|
57
|
-
return styles.cssText;
|
|
58
|
-
}
|
|
59
|
-
return '';
|
|
60
|
-
}
|
|
61
|
-
static generateStyleId() {
|
|
62
|
-
return `nile-select-styles-${Math.random().toString(36).substring(2, 11)}`;
|
|
63
|
-
}
|
|
64
|
-
static isPositioningOptimal(placement, referenceElement) {
|
|
65
|
-
const { spaceAbove, spaceBelow } = this.calculateAvailableSpace(referenceElement);
|
|
66
|
-
const isAbove = placement.startsWith('top');
|
|
67
|
-
const isBelow = placement.startsWith('bottom');
|
|
68
|
-
if (isAbove && spaceBelow > spaceAbove)
|
|
69
|
-
return false;
|
|
70
|
-
if (isBelow && spaceAbove > spaceBelow)
|
|
71
|
-
return false;
|
|
72
|
-
return true;
|
|
73
|
-
}
|
|
74
|
-
static applyCollisionData(element, middlewareData, placement) {
|
|
75
|
-
if (middlewareData.flip) {
|
|
76
|
-
const { overflows } = middlewareData.flip;
|
|
77
|
-
element.setAttribute('data-placement', placement);
|
|
78
|
-
if (overflows && overflows.length > 0) {
|
|
79
|
-
const overflowPlacements = overflows.map(overflow => overflow.placement).join(',');
|
|
80
|
-
element.setAttribute('data-overflow', overflowPlacements);
|
|
81
|
-
}
|
|
82
|
-
else {
|
|
83
|
-
element.removeAttribute('data-overflow');
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
if (middlewareData.shift) {
|
|
87
|
-
const { x, y } = middlewareData.shift;
|
|
88
|
-
if (x !== undefined && y !== undefined && (x !== 0 || y !== 0)) {
|
|
89
|
-
element.setAttribute('data-shift', `${x},${y}`);
|
|
90
|
-
}
|
|
91
|
-
else {
|
|
92
|
-
element.removeAttribute('data-shift');
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
if (middlewareData.size) {
|
|
96
|
-
const { availableWidth, availableHeight } = middlewareData.size;
|
|
97
|
-
if (availableWidth !== undefined) {
|
|
98
|
-
element.setAttribute('data-available-width', availableWidth.toString());
|
|
99
|
-
}
|
|
100
|
-
if (availableHeight !== undefined) {
|
|
101
|
-
element.setAttribute('data-available-height', availableHeight.toString());
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
static createFloatingUIMiddleware(boundary, onSizeApply) {
|
|
106
|
-
return [];
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
export class PortalContentUtils {
|
|
110
|
-
static createBaseListbox(component) {
|
|
111
|
-
const listbox = document.createElement('div');
|
|
112
|
-
listbox.className = `select__listbox ${component.searchEnabled ? 'select__search-enabled ' : ''}`;
|
|
113
|
-
listbox.setAttribute('tabindex', '-1');
|
|
114
|
-
return listbox;
|
|
115
|
-
}
|
|
116
|
-
static addSearchSection(listbox, component) {
|
|
117
|
-
if (!component.searchEnabled)
|
|
118
|
-
return;
|
|
119
|
-
const searchDiv = document.createElement('div');
|
|
120
|
-
searchDiv.className = 'select__search';
|
|
121
|
-
searchDiv.innerHTML = `
|
|
122
|
-
<nile-input size="small" clearable value="${component.searchValue}" placeholder="${component.internalSearchPlaceHolder}">
|
|
123
|
-
<nile-icon name="var(--nile-icon-search, var(--ng-icon-search-lg))" method="var(--nile-svg-method-fill, var(--ng-svg-method-stroke))" slot="suffix"></nile-icon>
|
|
124
|
-
</nile-input>
|
|
125
|
-
`;
|
|
126
|
-
listbox.appendChild(searchDiv);
|
|
127
|
-
}
|
|
128
|
-
static addLoadingSection(listbox, component) {
|
|
129
|
-
if (!component.optionsLoading)
|
|
130
|
-
return;
|
|
131
|
-
const loaderSpan = document.createElement('span');
|
|
132
|
-
loaderSpan.className = 'select__loader';
|
|
133
|
-
loaderSpan.innerHTML = `
|
|
134
|
-
<nile-icon class="select__loader--icon" name="var(--nile-icon-button-loading-blue, var(--ng-icon-button-loading-blue))" method="var(--nile-svg-method-fill, var(--ng-svg-method-stroke))"></nile-icon>
|
|
135
|
-
`;
|
|
136
|
-
listbox.appendChild(loaderSpan);
|
|
137
|
-
}
|
|
138
|
-
static addOptionsSection(listbox, component) {
|
|
139
|
-
const optionsContainer = document.createElement('div');
|
|
140
|
-
optionsContainer.className = `select__options ${component.searchEnabled ? 'select__options__search-enabled' : ''}`;
|
|
141
|
-
this.addNoResultsMessage(optionsContainer, component);
|
|
142
|
-
this.addClonedOptions(optionsContainer, component);
|
|
143
|
-
listbox.appendChild(optionsContainer);
|
|
144
|
-
}
|
|
145
|
-
static addNoResultsMessage(container, component) {
|
|
146
|
-
if (!component.showNoResults)
|
|
147
|
-
return;
|
|
148
|
-
const noResultsDiv = document.createElement('div');
|
|
149
|
-
noResultsDiv.className = 'select__no-results';
|
|
150
|
-
noResultsDiv.textContent = component.noResultsMessage;
|
|
151
|
-
container.appendChild(noResultsDiv);
|
|
152
|
-
}
|
|
153
|
-
static addClonedOptions(container, component) {
|
|
154
|
-
const options = Array.from(component.querySelectorAll('nile-option'));
|
|
155
|
-
options.forEach((option) => {
|
|
156
|
-
const clonedOption = this.cloneOption(option);
|
|
157
|
-
container.appendChild(clonedOption);
|
|
158
|
-
});
|
|
159
|
-
}
|
|
160
|
-
static cloneOption(option) {
|
|
161
|
-
const clonedOption = option.cloneNode(true);
|
|
162
|
-
Array.from(option.attributes).forEach((attr) => {
|
|
163
|
-
clonedOption.setAttribute(attr.name, attr.value);
|
|
164
|
-
});
|
|
165
|
-
this.copyOptionProperties(option, clonedOption);
|
|
166
|
-
return clonedOption;
|
|
167
|
-
}
|
|
168
|
-
static copyOptionProperties(originalOption, clonedOption) {
|
|
169
|
-
const properties = ['selected', 'disabled', 'current', 'hidden'];
|
|
170
|
-
properties.forEach(prop => {
|
|
171
|
-
if (originalOption[prop] !== undefined) {
|
|
172
|
-
clonedOption[prop] = originalOption[prop];
|
|
173
|
-
}
|
|
174
|
-
});
|
|
175
|
-
}
|
|
176
|
-
static addFooterSection(listbox, component) {
|
|
177
|
-
if (!component.multiple)
|
|
178
|
-
return;
|
|
179
|
-
const footerDiv = this.createFooter(component);
|
|
180
|
-
listbox.appendChild(footerDiv);
|
|
181
|
-
}
|
|
182
|
-
static createFooter(component) {
|
|
183
|
-
const footerDiv = document.createElement('div');
|
|
184
|
-
footerDiv.setAttribute('part', 'footer');
|
|
185
|
-
footerDiv.className = 'select__footer';
|
|
186
|
-
this.addShowSelectedToggle(footerDiv, component);
|
|
187
|
-
this.addClearAllButton(footerDiv, component);
|
|
188
|
-
return footerDiv;
|
|
189
|
-
}
|
|
190
|
-
static addShowSelectedToggle(footer, component) {
|
|
191
|
-
const showSelectedSpan = document.createElement('span');
|
|
192
|
-
showSelectedSpan.style.cursor = 'pointer';
|
|
193
|
-
const checkbox = document.createElement('nile-checkbox');
|
|
194
|
-
checkbox.disabled = component.selectedOptions.length === 0;
|
|
195
|
-
checkbox.checked = component.showSelected;
|
|
196
|
-
checkbox.innerHTML = ' Show Selected';
|
|
197
|
-
showSelectedSpan.appendChild(checkbox);
|
|
198
|
-
footer.appendChild(showSelectedSpan);
|
|
199
|
-
}
|
|
200
|
-
static addClearAllButton(footer, component) {
|
|
201
|
-
if (component.selectedOptions.length === 0)
|
|
202
|
-
return;
|
|
203
|
-
const clearAllSpan = document.createElement('span');
|
|
204
|
-
clearAllSpan.className = 'select__clear';
|
|
205
|
-
clearAllSpan.textContent = 'Clear All';
|
|
206
|
-
clearAllSpan.style.cursor = 'pointer';
|
|
207
|
-
footer.appendChild(clearAllSpan);
|
|
208
|
-
}
|
|
209
|
-
static updateClonedOptions(clonedListbox, component) {
|
|
210
|
-
const optionsContainer = clonedListbox.querySelector('.select__options');
|
|
211
|
-
if (!optionsContainer)
|
|
212
|
-
return;
|
|
213
|
-
const originalOptions = Array.from(component.querySelectorAll('nile-option'));
|
|
214
|
-
const clonedOptions = Array.from(optionsContainer.querySelectorAll('nile-option'));
|
|
215
|
-
originalOptions.forEach((originalOption, index) => {
|
|
216
|
-
const clonedOption = clonedOptions[index];
|
|
217
|
-
if (clonedOption) {
|
|
218
|
-
this.updateClonedOption(originalOption, clonedOption);
|
|
219
|
-
}
|
|
220
|
-
});
|
|
221
|
-
}
|
|
222
|
-
static updateClonedOption(originalOption, clonedOption) {
|
|
223
|
-
clonedOption.selected = originalOption.selected;
|
|
224
|
-
clonedOption.disabled = originalOption.disabled;
|
|
225
|
-
clonedOption.current = originalOption.current;
|
|
226
|
-
clonedOption.hidden = originalOption.hidden;
|
|
227
|
-
this.updateClonedOptionAttributes(originalOption, clonedOption);
|
|
228
|
-
}
|
|
229
|
-
static updateClonedOptionAttributes(originalOption, clonedOption) {
|
|
230
|
-
const attributes = [
|
|
231
|
-
{ prop: 'selected', attr: 'selected' },
|
|
232
|
-
{ prop: 'disabled', attr: 'disabled' },
|
|
233
|
-
{ prop: 'current', attr: 'current' },
|
|
234
|
-
{ prop: 'hidden', attr: 'hidden' }
|
|
235
|
-
];
|
|
236
|
-
attributes.forEach(({ prop, attr }) => {
|
|
237
|
-
if (originalOption[prop]) {
|
|
238
|
-
clonedOption.setAttribute(attr, '');
|
|
239
|
-
}
|
|
240
|
-
else {
|
|
241
|
-
clonedOption.removeAttribute(attr);
|
|
242
|
-
}
|
|
243
|
-
});
|
|
244
|
-
}
|
|
245
|
-
static createPortalListbox(component) {
|
|
246
|
-
const listbox = this.createBaseListbox(component);
|
|
247
|
-
this.addSearchSection(listbox, component);
|
|
248
|
-
this.addLoadingSection(listbox, component);
|
|
249
|
-
this.addOptionsSection(listbox, component);
|
|
250
|
-
this.addFooterSection(listbox, component);
|
|
251
|
-
return listbox;
|
|
252
|
-
}
|
|
253
|
-
}
|
|
254
|
-
export class PortalEventUtils {
|
|
255
|
-
static setupPortalEventListeners(clonedListbox, component) {
|
|
256
|
-
if (!clonedListbox)
|
|
257
|
-
return;
|
|
258
|
-
this.setupOptionClickListeners(clonedListbox, component);
|
|
259
|
-
this.setupScrollListeners(clonedListbox, component);
|
|
260
|
-
this.setupSearchListeners(clonedListbox, component);
|
|
261
|
-
this.setupFooterListeners(clonedListbox, component);
|
|
262
|
-
this.setupSlotListeners(clonedListbox, component);
|
|
263
|
-
}
|
|
264
|
-
static setupOptionClickListeners(clonedListbox, component) {
|
|
265
|
-
if (!clonedListbox)
|
|
266
|
-
return;
|
|
267
|
-
clonedListbox.addEventListener('mouseup', (event) => {
|
|
268
|
-
const target = event.target;
|
|
269
|
-
const option = target.closest('nile-option');
|
|
270
|
-
if (option) {
|
|
271
|
-
this.handleOptionClick(option, component);
|
|
272
|
-
}
|
|
273
|
-
});
|
|
274
|
-
}
|
|
275
|
-
static handleOptionClick(option, component) {
|
|
276
|
-
const originalOption = component.querySelector(`nile-option[value="${option.getAttribute('value')}"]`);
|
|
277
|
-
if (originalOption) {
|
|
278
|
-
const syntheticEvent = new MouseEvent('mouseup', {
|
|
279
|
-
bubbles: true,
|
|
280
|
-
cancelable: true,
|
|
281
|
-
view: window
|
|
282
|
-
});
|
|
283
|
-
Object.defineProperty(syntheticEvent, 'target', {
|
|
284
|
-
value: originalOption,
|
|
285
|
-
writable: false
|
|
286
|
-
});
|
|
287
|
-
if (component.handleOptionClick) {
|
|
288
|
-
component.handleOptionClick(syntheticEvent);
|
|
289
|
-
}
|
|
290
|
-
}
|
|
291
|
-
}
|
|
292
|
-
static setupScrollListeners(clonedListbox, component) {
|
|
293
|
-
if (!clonedListbox)
|
|
294
|
-
return;
|
|
295
|
-
clonedListbox.addEventListener('scroll', (event) => {
|
|
296
|
-
if (component.handleScroll) {
|
|
297
|
-
component.handleScroll(event);
|
|
298
|
-
}
|
|
299
|
-
});
|
|
300
|
-
}
|
|
301
|
-
static setupSearchListeners(clonedListbox, component) {
|
|
302
|
-
if (!clonedListbox)
|
|
303
|
-
return;
|
|
304
|
-
const searchInput = clonedListbox.querySelector('nile-input');
|
|
305
|
-
if (searchInput) {
|
|
306
|
-
searchInput.addEventListener('nile-input', (event) => {
|
|
307
|
-
if (component.handleSearchChange) {
|
|
308
|
-
component.handleSearchChange(event);
|
|
309
|
-
}
|
|
310
|
-
});
|
|
311
|
-
searchInput.addEventListener('nile-focus', (event) => {
|
|
312
|
-
if (component.handleSearchFocus) {
|
|
313
|
-
component.handleSearchFocus();
|
|
314
|
-
}
|
|
315
|
-
});
|
|
316
|
-
searchInput.addEventListener('nile-blur', (event) => {
|
|
317
|
-
if (component.handleSearchBlur) {
|
|
318
|
-
component.handleSearchBlur();
|
|
319
|
-
}
|
|
320
|
-
});
|
|
321
|
-
}
|
|
322
|
-
}
|
|
323
|
-
static setupFooterListeners(clonedListbox, component) {
|
|
324
|
-
if (!clonedListbox)
|
|
325
|
-
return;
|
|
326
|
-
const footer = clonedListbox.querySelector('.select__footer');
|
|
327
|
-
if (footer) {
|
|
328
|
-
this.setupFooterClickHandlers(footer);
|
|
329
|
-
this.setupShowSelectedToggle(footer, component);
|
|
330
|
-
this.setupClearAllHandler(footer, component);
|
|
331
|
-
}
|
|
332
|
-
}
|
|
333
|
-
static setupFooterClickHandlers(footer) {
|
|
334
|
-
footer.addEventListener('click', (event) => {
|
|
335
|
-
event.stopPropagation();
|
|
336
|
-
event.preventDefault();
|
|
337
|
-
});
|
|
338
|
-
}
|
|
339
|
-
static setupShowSelectedToggle(footer, component) {
|
|
340
|
-
const showSelectedSpan = footer.querySelector('span[style*="cursor: pointer"]');
|
|
341
|
-
if (showSelectedSpan) {
|
|
342
|
-
showSelectedSpan.addEventListener('click', (event) => {
|
|
343
|
-
event.stopPropagation();
|
|
344
|
-
event.preventDefault();
|
|
345
|
-
if (component.toggleShowSelected) {
|
|
346
|
-
component.toggleShowSelected(event);
|
|
347
|
-
}
|
|
348
|
-
});
|
|
349
|
-
}
|
|
350
|
-
}
|
|
351
|
-
static setupClearAllHandler(footer, component) {
|
|
352
|
-
footer.addEventListener('click', (event) => {
|
|
353
|
-
const target = event.target;
|
|
354
|
-
if (target.classList.contains('select__clear')) {
|
|
355
|
-
event.stopPropagation();
|
|
356
|
-
event.preventDefault();
|
|
357
|
-
if (component.unSlectAll) {
|
|
358
|
-
component.unSlectAll();
|
|
359
|
-
}
|
|
360
|
-
}
|
|
361
|
-
});
|
|
362
|
-
}
|
|
363
|
-
static setupSlotListeners(clonedListbox, component) {
|
|
364
|
-
if (!clonedListbox)
|
|
365
|
-
return;
|
|
366
|
-
const slot = clonedListbox.querySelector('slot');
|
|
367
|
-
if (slot) {
|
|
368
|
-
slot.addEventListener('slotchange', () => {
|
|
369
|
-
if (component.updatePortalContent) {
|
|
370
|
-
component.updatePortalContent();
|
|
371
|
-
}
|
|
372
|
-
});
|
|
373
|
-
}
|
|
374
|
-
}
|
|
375
|
-
}
|
|
376
|
-
//# sourceMappingURL=portal-utils.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"portal-utils.js","sourceRoot":"","sources":["../../../src/nile-virtual-select/portal-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { \n type Placement,\n type MiddlewareData,\n type ComputePositionConfig,\n type Boundary\n } from '@floating-ui/dom';\n \n export class PortalUtils {\n static calculateAvailableSpace(referenceElement: HTMLElement): {\n spaceAbove: number;\n spaceBelow: number;\n viewportHeight: number;\n } {\n const rect = referenceElement.getBoundingClientRect();\n const viewportHeight = window.innerHeight;\n const spaceBelow = viewportHeight - rect.bottom;\n const spaceAbove = rect.top;\n \n return { spaceAbove, spaceBelow, viewportHeight };\n }\n \n static getOptimalPlacement(referenceElement: HTMLElement): Placement {\n const { spaceAbove, spaceBelow } = this.calculateAvailableSpace(referenceElement);\n \n if (spaceBelow < 200 && spaceAbove > spaceBelow) {\n return 'top';\n }\n \n return 'bottom';\n }\n \n static findBoundaryElements(component: HTMLElement): Element[] | undefined {\n const boundaryElements: Element[] = [];\n \n let currentElement = component.parentElement;\n \n while (currentElement && currentElement !== document.body) {\n const computedStyle = window.getComputedStyle(currentElement);\n const overflow = computedStyle.overflow;\n const overflowY = computedStyle.overflowY;\n const overflowX = computedStyle.overflowX;\n \n if (overflow === 'auto' || overflow === 'scroll' || \n overflowY === 'auto' || overflowY === 'scroll' ||\n overflowX === 'auto' || overflowX === 'scroll') {\n boundaryElements.push(currentElement);\n }\n \n if (currentElement.hasAttribute('data-floating-boundary') ||\n currentElement.classList.contains('floating-boundary') ||\n currentElement.classList.contains('scroll-container')) {\n boundaryElements.push(currentElement);\n }\n \n currentElement = currentElement.parentElement;\n }\n \n return boundaryElements.length > 0 ? boundaryElements : undefined;\n }\n \n static calculateOptimalHeight(\n referenceRect: { x: number; y: number; width: number; height: number },\n viewportHeight: number,\n placement: Placement\n ): number {\n const spaceBelow = viewportHeight - (referenceRect.y + referenceRect.height);\n const spaceAbove = referenceRect.y;\n \n if (spaceAbove > spaceBelow) {\n return Math.max(spaceAbove - 20, 100);\n }\n else if (spaceBelow > spaceAbove) {\n return Math.max(spaceBelow - 20, 100);\n }\n \n return Math.max(Math.min(spaceAbove, spaceBelow) - 20, 100);\n }\n \n static extractStylesAsCSS(styles: any): string {\n if (typeof styles === 'string') {\n return styles;\n }\n \n if (Array.isArray(styles)) {\n return styles.map(style => this.extractStylesAsCSS(style)).join('\\n');\n }\n \n if (styles && typeof styles === 'object' && styles.cssText) {\n return styles.cssText;\n }\n \n return '';\n }\n \n static generateStyleId(): string {\n return `nile-select-styles-${Math.random().toString(36).substring(2, 11)}`;\n }\n \n static isPositioningOptimal(\n placement: Placement,\n referenceElement: HTMLElement\n ): boolean {\n const { spaceAbove, spaceBelow } = this.calculateAvailableSpace(referenceElement);\n \n const isAbove = placement.startsWith('top');\n const isBelow = placement.startsWith('bottom');\n \n if (isAbove && spaceBelow > spaceAbove) return false;\n if (isBelow && spaceAbove > spaceBelow) return false;\n \n return true;\n }\n \n static applyCollisionData(\n element: HTMLElement,\n middlewareData: MiddlewareData,\n placement: Placement\n ): void {\n if (middlewareData.flip) {\n const { overflows } = middlewareData.flip;\n \n element.setAttribute('data-placement', placement);\n \n if (overflows && overflows.length > 0) {\n const overflowPlacements = overflows.map(overflow => overflow.placement).join(',');\n element.setAttribute('data-overflow', overflowPlacements);\n } else {\n element.removeAttribute('data-overflow');\n }\n }\n \n if (middlewareData.shift) {\n const { x, y } = middlewareData.shift;\n \n if (x !== undefined && y !== undefined && (x !== 0 || y !== 0)) {\n element.setAttribute('data-shift', `${x},${y}`);\n } else {\n element.removeAttribute('data-shift');\n }\n }\n \n if (middlewareData.size) {\n const { availableWidth, availableHeight } = middlewareData.size;\n \n if (availableWidth !== undefined) {\n element.setAttribute('data-available-width', availableWidth.toString());\n }\n if (availableHeight !== undefined) {\n element.setAttribute('data-available-height', availableHeight.toString());\n }\n }\n }\n \n static createFloatingUIMiddleware(\n boundary: Boundary,\n onSizeApply: (params: {\n availableWidth: number;\n availableHeight: number;\n elements: { floating: HTMLElement };\n rects: { reference: { x: number; y: number; width: number; height: number } };\n }) => void\n ): ComputePositionConfig['middleware'] {\n return [];\n }\n }\n \n export class PortalContentUtils {\n static createBaseListbox(component: any): HTMLElement {\n const listbox = document.createElement('div');\n listbox.className = `select__listbox ${component.searchEnabled ? 'select__search-enabled ' : ''}`;\n listbox.setAttribute('tabindex', '-1');\n \n return listbox;\n }\n \n static addSearchSection(listbox: HTMLElement, component: any): void {\n if (!component.searchEnabled) return;\n \n const searchDiv = document.createElement('div');\n searchDiv.className = 'select__search';\n searchDiv.innerHTML = `\n <nile-input size=\"small\" clearable value=\"${component.searchValue}\" placeholder=\"${component.internalSearchPlaceHolder}\">\n <nile-icon name=\"var(--nile-icon-search, var(--ng-icon-search-lg))\" method=\"var(--nile-svg-method-fill, var(--ng-svg-method-stroke))\" slot=\"suffix\"></nile-icon>\n </nile-input>\n `;\n listbox.appendChild(searchDiv);\n }\n \n static addLoadingSection(listbox: HTMLElement, component: any): void {\n if (!component.optionsLoading) return;\n \n const loaderSpan = document.createElement('span');\n loaderSpan.className = 'select__loader';\n loaderSpan.innerHTML = `\n <nile-icon class=\"select__loader--icon\" name=\"var(--nile-icon-button-loading-blue, var(--ng-icon-button-loading-blue))\" method=\"var(--nile-svg-method-fill, var(--ng-svg-method-stroke))\"></nile-icon>\n `;\n listbox.appendChild(loaderSpan);\n }\n \n static addOptionsSection(listbox: HTMLElement, component: any): void {\n const optionsContainer = document.createElement('div');\n optionsContainer.className = `select__options ${component.searchEnabled ? 'select__options__search-enabled' : ''}`;\n \n this.addNoResultsMessage(optionsContainer, component);\n this.addClonedOptions(optionsContainer, component);\n \n listbox.appendChild(optionsContainer);\n }\n \n static addNoResultsMessage(container: HTMLElement, component: any): void {\n if (!component.showNoResults) return;\n \n const noResultsDiv = document.createElement('div');\n noResultsDiv.className = 'select__no-results';\n noResultsDiv.textContent = component.noResultsMessage;\n container.appendChild(noResultsDiv);\n }\n \n static addClonedOptions(container: HTMLElement, component: any): void {\n const options = Array.from(component.querySelectorAll('nile-option'));\n \n options.forEach((option: Element) => {\n const clonedOption = this.cloneOption(option as HTMLElement);\n container.appendChild(clonedOption);\n });\n }\n \n static cloneOption(option: HTMLElement): HTMLElement {\n const clonedOption = option.cloneNode(true) as HTMLElement;\n \n Array.from(option.attributes).forEach((attr: Attr) => {\n clonedOption.setAttribute(attr.name, attr.value);\n });\n \n this.copyOptionProperties(option, clonedOption);\n \n return clonedOption;\n }\n \n static copyOptionProperties(originalOption: HTMLElement, clonedOption: HTMLElement): void {\n const properties = ['selected', 'disabled', 'current', 'hidden'];\n \n properties.forEach(prop => {\n if ((originalOption as any)[prop] !== undefined) {\n (clonedOption as any)[prop] = (originalOption as any)[prop];\n }\n });\n }\n \n static addFooterSection(listbox: HTMLElement, component: any): void {\n if (!component.multiple) return;\n \n const footerDiv = this.createFooter(component);\n listbox.appendChild(footerDiv);\n }\n \n static createFooter(component: any): HTMLElement {\n const footerDiv = document.createElement('div');\n footerDiv.setAttribute('part', 'footer');\n footerDiv.className = 'select__footer';\n \n this.addShowSelectedToggle(footerDiv, component);\n this.addClearAllButton(footerDiv, component);\n \n return footerDiv;\n }\n \n static addShowSelectedToggle(footer: HTMLElement, component: any): void {\n const showSelectedSpan = document.createElement('span');\n showSelectedSpan.style.cursor = 'pointer';\n \n const checkbox = document.createElement('nile-checkbox');\n checkbox.disabled = component.selectedOptions.length === 0;\n checkbox.checked = component.showSelected;\n checkbox.innerHTML = ' Show Selected';\n \n showSelectedSpan.appendChild(checkbox);\n footer.appendChild(showSelectedSpan);\n }\n \n static addClearAllButton(footer: HTMLElement, component: any): void {\n if (component.selectedOptions.length === 0) return;\n \n const clearAllSpan = document.createElement('span');\n clearAllSpan.className = 'select__clear';\n clearAllSpan.textContent = 'Clear All';\n clearAllSpan.style.cursor = 'pointer';\n footer.appendChild(clearAllSpan);\n }\n \n static updateClonedOptions(clonedListbox: HTMLElement, component: any): void {\n const optionsContainer = clonedListbox.querySelector('.select__options') as HTMLElement;\n if (!optionsContainer) return;\n \n const originalOptions = Array.from(component.querySelectorAll('nile-option'));\n \n const clonedOptions = Array.from(optionsContainer.querySelectorAll('nile-option'));\n \n originalOptions.forEach((originalOption: Element, index: number) => {\n const clonedOption = clonedOptions[index] as HTMLElement;\n if (clonedOption) {\n this.updateClonedOption(originalOption as HTMLElement, clonedOption);\n }\n });\n }\n \n static updateClonedOption(originalOption: HTMLElement, clonedOption: HTMLElement): void {\n (clonedOption as any).selected = (originalOption as any).selected;\n (clonedOption as any).disabled = (originalOption as any).disabled;\n (clonedOption as any).current = (originalOption as any).current;\n (clonedOption as any).hidden = (originalOption as any).hidden;\n \n this.updateClonedOptionAttributes(originalOption, clonedOption);\n }\n \n static updateClonedOptionAttributes(originalOption: HTMLElement, clonedOption: HTMLElement): void {\n const attributes = [\n { prop: 'selected', attr: 'selected' },\n { prop: 'disabled', attr: 'disabled' },\n { prop: 'current', attr: 'current' },\n { prop: 'hidden', attr: 'hidden' }\n ];\n \n attributes.forEach(({ prop, attr }) => {\n if ((originalOption as any)[prop]) {\n clonedOption.setAttribute(attr, '');\n } else {\n clonedOption.removeAttribute(attr);\n }\n });\n }\n \n static createPortalListbox(component: any): HTMLElement {\n const listbox = this.createBaseListbox(component);\n \n this.addSearchSection(listbox, component);\n this.addLoadingSection(listbox, component);\n this.addOptionsSection(listbox, component);\n this.addFooterSection(listbox, component);\n \n return listbox;\n }\n }\n \n export class PortalEventUtils {\n static setupPortalEventListeners(clonedListbox: HTMLElement, component: any): void {\n if (!clonedListbox) return;\n \n this.setupOptionClickListeners(clonedListbox, component);\n this.setupScrollListeners(clonedListbox, component);\n this.setupSearchListeners(clonedListbox, component);\n this.setupFooterListeners(clonedListbox, component);\n this.setupSlotListeners(clonedListbox, component);\n }\n \n static setupOptionClickListeners(clonedListbox: HTMLElement, component: any): void {\n if (!clonedListbox) return;\n \n clonedListbox.addEventListener('mouseup', (event) => {\n const target = event.target as HTMLElement;\n const option = target.closest('nile-option');\n \n if (option) {\n this.handleOptionClick(option as HTMLElement, component);\n }\n });\n }\n \n static handleOptionClick(option: HTMLElement, component: any): void {\n const originalOption = component.querySelector(`nile-option[value=\"${option.getAttribute('value')}\"]`) as HTMLElement;\n if (originalOption) {\n const syntheticEvent = new MouseEvent('mouseup', {\n bubbles: true,\n cancelable: true,\n view: window\n });\n \n Object.defineProperty(syntheticEvent, 'target', {\n value: originalOption,\n writable: false\n });\n \n if (component.handleOptionClick) {\n component.handleOptionClick(syntheticEvent);\n }\n }\n }\n \n static setupScrollListeners(clonedListbox: HTMLElement, component: any): void {\n if (!clonedListbox) return;\n \n clonedListbox.addEventListener('scroll', (event) => {\n if (component.handleScroll) {\n component.handleScroll(event);\n }\n });\n }\n \n static setupSearchListeners(clonedListbox: HTMLElement, component: any): void {\n if (!clonedListbox) return;\n \n const searchInput = clonedListbox.querySelector('nile-input') as HTMLElement;\n if (searchInput) {\n searchInput.addEventListener('nile-input', (event) => {\n if (component.handleSearchChange) {\n component.handleSearchChange(event);\n }\n });\n \n searchInput.addEventListener('nile-focus', (event) => {\n if (component.handleSearchFocus) {\n component.handleSearchFocus();\n }\n });\n \n searchInput.addEventListener('nile-blur', (event) => {\n if (component.handleSearchBlur) {\n component.handleSearchBlur();\n }\n });\n }\n }\n \n static setupFooterListeners(clonedListbox: HTMLElement, component: any): void {\n if (!clonedListbox) return;\n \n const footer = clonedListbox.querySelector('.select__footer') as HTMLElement;\n if (footer) {\n this.setupFooterClickHandlers(footer);\n this.setupShowSelectedToggle(footer, component);\n this.setupClearAllHandler(footer, component);\n }\n }\n \n static setupFooterClickHandlers(footer: HTMLElement): void {\n footer.addEventListener('click', (event) => {\n event.stopPropagation();\n event.preventDefault();\n });\n }\n \n static setupShowSelectedToggle(footer: HTMLElement, component: any): void {\n const showSelectedSpan = footer.querySelector('span[style*=\"cursor: pointer\"]');\n if (showSelectedSpan) {\n showSelectedSpan.addEventListener('click', (event) => {\n event.stopPropagation();\n event.preventDefault();\n if (component.toggleShowSelected) {\n component.toggleShowSelected(event);\n }\n });\n }\n }\n \n static setupClearAllHandler(footer: HTMLElement, component: any): void {\n footer.addEventListener('click', (event) => {\n const target = event.target as HTMLElement;\n if (target.classList.contains('select__clear')) {\n event.stopPropagation();\n event.preventDefault();\n if (component.unSlectAll) {\n component.unSlectAll();\n }\n }\n });\n }\n \n static setupSlotListeners(clonedListbox: HTMLElement, component: any): void {\n if (!clonedListbox) return;\n \n const slot = clonedListbox.querySelector('slot');\n if (slot) {\n slot.addEventListener('slotchange', () => {\n if (component.updatePortalContent) {\n component.updatePortalContent();\n }\n });\n }\n }\n }\n"]}
|