@carbon/web-components 2.47.0 → 2.48.0
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/custom-elements.json +963 -145
- package/es/components/accordion/accordion-item.d.ts +28 -12
- package/es/components/accordion/accordion-item.js +7 -5
- package/es/components/accordion/accordion-item.js.map +1 -1
- package/es/components/accordion/accordion-skeleton.d.ts +1 -1
- package/es/components/accordion/accordion-skeleton.js +7 -5
- package/es/components/accordion/accordion-skeleton.js.map +1 -1
- package/es/components/accordion/accordion.d.ts +1 -1
- package/es/components/accordion/accordion.js +7 -5
- package/es/components/accordion/accordion.js.map +1 -1
- package/es/components/ai-label/ai-label.d.ts +1 -1
- package/es/components/ai-label/ai-label.js +6 -5
- package/es/components/ai-label/ai-label.js.map +1 -1
- package/es/components/button/button.d.ts +56 -22
- package/es/components/checkbox/checkbox-group.d.ts +2 -0
- package/es/components/checkbox/checkbox.d.ts +57 -23
- package/es/components/checkbox/checkbox.js +7 -5
- package/es/components/checkbox/checkbox.js.map +1 -1
- package/es/components/code-snippet/code-snippet.d.ts +29 -11
- package/es/components/code-snippet/code-snippet.js +15 -14
- package/es/components/code-snippet/code-snippet.js.map +1 -1
- package/es/components/combo-box/combo-box.scss.js +1 -1
- package/es/components/combo-button/combo-button.d.ts +27 -11
- package/es/components/content-switcher/content-switcher-item.d.ts +29 -11
- package/es/components/copy-button/copy-button.d.ts +27 -11
- package/es/components/data-table/table-expanded-row.d.ts +28 -12
- package/es/components/data-table/table-expanded-row.js +7 -5
- package/es/components/data-table/table-expanded-row.js.map +1 -1
- package/es/components/data-table/table-header-cell.d.ts +29 -11
- package/es/components/data-table/table-row.d.ts +54 -22
- package/es/components/data-table/table-toolbar-search.d.ts +29 -11
- package/es/components/data-table/table.d.ts +28 -12
- package/es/components/data-table/table.js +9 -8
- package/es/components/data-table/table.js.map +1 -1
- package/es/components/date-picker/date-picker-input.d.ts +29 -11
- package/es/components/date-picker/date-picker.d.ts +54 -22
- package/es/components/dropdown/dropdown.d.ts +110 -44
- package/es/components/dropdown/dropdown.js +8 -6
- package/es/components/dropdown/dropdown.js.map +1 -1
- package/es/components/file-uploader/file-uploader-button.d.ts +27 -11
- package/es/components/file-uploader/file-uploader-drop-container.d.ts +27 -11
- package/es/components/floating-menu/floating-menu.d.ts +56 -22
- package/es/components/fluid-select/fluid-select.d.ts +5 -0
- package/es/components/fluid-select/fluid-select.js +50 -1
- package/es/components/fluid-select/fluid-select.js.map +1 -1
- package/es/components/fluid-textarea/fluid-textarea-skeleton.d.ts +3 -3
- package/es/components/fluid-textarea/fluid-textarea-skeleton.js +3 -3
- package/es/components/fluid-textarea/fluid-textarea-skeleton.js.map +1 -1
- package/es/components/fluid-time-picker/fluid-time-picker-select.d.ts +21 -0
- package/es/components/fluid-time-picker/fluid-time-picker-select.js +53 -0
- package/es/components/fluid-time-picker/fluid-time-picker-select.js.map +1 -0
- package/es/components/fluid-time-picker/fluid-time-picker-skeleton.d.ts +23 -0
- package/es/components/fluid-time-picker/fluid-time-picker-skeleton.js +63 -0
- package/es/components/fluid-time-picker/fluid-time-picker-skeleton.js.map +1 -0
- package/es/components/fluid-time-picker/fluid-time-picker.d.ts +32 -0
- package/es/components/fluid-time-picker/fluid-time-picker.js +239 -0
- package/es/components/fluid-time-picker/fluid-time-picker.js.map +1 -0
- package/es/components/fluid-time-picker/fluid-time-picker.scss.js +13 -0
- package/es/components/fluid-time-picker/fluid-time-picker.scss.js.map +1 -0
- package/es/components/fluid-time-picker/index.d.ts +9 -0
- package/es/components/fluid-time-picker/index.js +11 -0
- package/es/components/fluid-time-picker/index.js.map +1 -0
- package/es/components/grid/column.d.ts +3 -1
- package/es/components/grid/column.js +6 -0
- package/es/components/grid/column.js.map +1 -1
- package/es/components/icon-button/icon-button.d.ts +1 -1
- package/es/components/icon-button/icon-button.js +6 -5
- package/es/components/icon-button/icon-button.js.map +1 -1
- package/es/components/link/link.d.ts +29 -11
- package/es/components/menu/menu-item-selectable.d.ts +5 -3
- package/es/components/menu/menu-item-selectable.js +3 -3
- package/es/components/menu/menu-item-selectable.js.map +1 -1
- package/es/components/menu/menu-item.d.ts +68 -23
- package/es/components/menu/menu-item.js +37 -2
- package/es/components/menu/menu-item.js.map +1 -1
- package/es/components/menu/menu.d.ts +27 -11
- package/es/components/menu-button/menu-button.d.ts +27 -11
- package/es/components/modal/modal-close-button.d.ts +29 -11
- package/es/components/modal/modal.d.ts +27 -11
- package/es/components/modal/modal.js +6 -4
- package/es/components/modal/modal.js.map +1 -1
- package/es/components/multi-select/multi-select.js +12 -8
- package/es/components/multi-select/multi-select.js.map +1 -1
- package/es/components/notification/actionable-notification.d.ts +27 -11
- package/es/components/notification/actionable-notification.scss.js +1 -1
- package/es/components/notification/inline-notification.d.ts +27 -11
- package/es/components/notification/inline-notification.scss.js +1 -1
- package/es/components/notification/toast-notification.scss.js +1 -1
- package/es/components/number-input/number-input.d.ts +2 -0
- package/es/components/overflow-menu/overflow-menu-item.d.ts +29 -11
- package/es/components/overflow-menu/overflow-menu.d.ts +54 -22
- package/es/components/pagination/pagination.d.ts +56 -22
- package/es/components/pagination-nav/defs.d.ts +61 -0
- package/es/components/pagination-nav/defs.js +74 -0
- package/es/components/pagination-nav/defs.js.map +1 -0
- package/es/components/pagination-nav/index.d.ts +7 -0
- package/es/components/pagination-nav/index.js +9 -0
- package/es/components/pagination-nav/index.js.map +1 -0
- package/es/components/pagination-nav/pagination-nav.d.ts +109 -0
- package/es/components/pagination-nav/pagination-nav.js +427 -0
- package/es/components/pagination-nav/pagination-nav.js.map +1 -0
- package/es/components/pagination-nav/pagination-nav.scss.js +13 -0
- package/es/components/pagination-nav/pagination-nav.scss.js.map +1 -0
- package/es/components/password-input/password-input.d.ts +2 -0
- package/es/components/popover/popover.d.ts +27 -11
- package/es/components/popover/popover.js +1 -1
- package/es/components/popover/popover.js.map +1 -1
- package/es/components/progress-indicator/progress-step.d.ts +29 -11
- package/es/components/radio-button/radio-button-group.d.ts +54 -22
- package/es/components/radio-button/radio-button.d.ts +57 -23
- package/es/components/radio-button/radio-button.js +7 -5
- package/es/components/radio-button/radio-button.js.map +1 -1
- package/es/components/search/search.d.ts +83 -33
- package/es/components/select/select.d.ts +29 -11
- package/es/components/side-panel/side-panel.d.ts +27 -11
- package/es/components/skip-to-content/skip-to-content.d.ts +29 -11
- package/es/components/slider/slider-input.d.ts +29 -11
- package/es/components/slider/slider.d.ts +84 -34
- package/es/components/slider/slider.js +9 -7
- package/es/components/slider/slider.js.map +1 -1
- package/es/components/slug/slug.d.ts +1 -1
- package/es/components/slug/slug.js +6 -4
- package/es/components/slug/slug.js.map +1 -1
- package/es/components/structured-list/structured-list-row.d.ts +27 -11
- package/es/components/structured-list/structured-list.d.ts +30 -12
- package/es/components/structured-list/structured-list.js +7 -5
- package/es/components/structured-list/structured-list.js.map +1 -1
- package/es/components/tabs/tabs.d.ts +27 -11
- package/es/components/tag/dismissible-tag.d.ts +54 -22
- package/es/components/tag/operational-tag.d.ts +54 -22
- package/es/components/tag/selectable-tag.d.ts +54 -22
- package/es/components/tag/tag.d.ts +54 -22
- package/es/components/tearsheet/tearsheet.d.ts +27 -11
- package/es/components/text-input/text-input.d.ts +56 -22
- package/es/components/textarea/textarea.d.ts +2 -0
- package/es/components/tile/expandable-tile.d.ts +54 -22
- package/es/components/tile/selectable-tile.d.ts +56 -22
- package/es/components/tile/tile-group.d.ts +27 -11
- package/es/components/time-picker/time-picker-select.d.ts +29 -11
- package/es/components/time-picker/time-picker.d.ts +56 -22
- package/es/components/toggle/toggle.d.ts +27 -11
- package/es/components/toggle-tip/toggletip.d.ts +57 -23
- package/es/components/toggle-tip/toggletip.js +7 -5
- package/es/components/toggle-tip/toggletip.js.map +1 -1
- package/es/components/tooltip/tooltip.d.ts +28 -12
- package/es/components/tooltip/tooltip.js +7 -5
- package/es/components/tooltip/tooltip.js.map +1 -1
- package/es/components/tree-view/tree-view.d.ts +28 -12
- package/es/components/tree-view/tree-view.js +7 -5
- package/es/components/tree-view/tree-view.js.map +1 -1
- package/es/components/ui-shell/header-global-action.d.ts +2 -0
- package/es/components/ui-shell/header-menu-button.d.ts +29 -11
- package/es/components/ui-shell/header-menu.d.ts +56 -22
- package/es/components/ui-shell/header-name.d.ts +29 -11
- package/es/components/ui-shell/header-nav-item.d.ts +29 -11
- package/es/components/ui-shell/header-panel.d.ts +2 -0
- package/es/components/ui-shell/side-nav-link.d.ts +29 -11
- package/es/components/ui-shell/side-nav-menu-item.d.ts +29 -11
- package/es/components/ui-shell/side-nav-menu.d.ts +29 -11
- package/es/components/ui-shell/side-nav.d.ts +27 -11
- package/es/components/ui-shell/switcher-item.d.ts +29 -11
- package/es/components/ui-shell/switcher.d.ts +2 -0
- package/es/globals/mixins/focus.d.ts +27 -11
- package/es/globals/mixins/form.d.ts +27 -11
- package/es/globals/mixins/host-listener.d.ts +27 -11
- package/es/globals/mixins/validity.d.ts +27 -11
- package/es-custom/components/accordion/accordion-item.d.ts +28 -12
- package/es-custom/components/accordion/accordion-item.js +7 -5
- package/es-custom/components/accordion/accordion-item.js.map +1 -1
- package/es-custom/components/accordion/accordion-skeleton.d.ts +1 -1
- package/es-custom/components/accordion/accordion-skeleton.js +7 -5
- package/es-custom/components/accordion/accordion-skeleton.js.map +1 -1
- package/es-custom/components/accordion/accordion.d.ts +1 -1
- package/es-custom/components/accordion/accordion.js +7 -5
- package/es-custom/components/accordion/accordion.js.map +1 -1
- package/es-custom/components/ai-label/ai-label.d.ts +1 -1
- package/es-custom/components/ai-label/ai-label.js +6 -5
- package/es-custom/components/ai-label/ai-label.js.map +1 -1
- package/es-custom/components/button/button.d.ts +56 -22
- package/es-custom/components/checkbox/checkbox-group.d.ts +2 -0
- package/es-custom/components/checkbox/checkbox.d.ts +57 -23
- package/es-custom/components/checkbox/checkbox.js +7 -5
- package/es-custom/components/checkbox/checkbox.js.map +1 -1
- package/es-custom/components/code-snippet/code-snippet.d.ts +29 -11
- package/es-custom/components/code-snippet/code-snippet.js +15 -14
- package/es-custom/components/code-snippet/code-snippet.js.map +1 -1
- package/es-custom/components/combo-box/combo-box.scss.js +1 -1
- package/es-custom/components/combo-button/combo-button.d.ts +27 -11
- package/es-custom/components/content-switcher/content-switcher-item.d.ts +29 -11
- package/es-custom/components/copy-button/copy-button.d.ts +27 -11
- package/es-custom/components/data-table/table-expanded-row.d.ts +28 -12
- package/es-custom/components/data-table/table-expanded-row.js +7 -5
- package/es-custom/components/data-table/table-expanded-row.js.map +1 -1
- package/es-custom/components/data-table/table-header-cell.d.ts +29 -11
- package/es-custom/components/data-table/table-row.d.ts +54 -22
- package/es-custom/components/data-table/table-toolbar-search.d.ts +29 -11
- package/es-custom/components/data-table/table.d.ts +28 -12
- package/es-custom/components/data-table/table.js +9 -8
- package/es-custom/components/data-table/table.js.map +1 -1
- package/es-custom/components/date-picker/date-picker-input.d.ts +29 -11
- package/es-custom/components/date-picker/date-picker.d.ts +54 -22
- package/es-custom/components/dropdown/dropdown.d.ts +110 -44
- package/es-custom/components/dropdown/dropdown.js +8 -6
- package/es-custom/components/dropdown/dropdown.js.map +1 -1
- package/es-custom/components/file-uploader/file-uploader-button.d.ts +27 -11
- package/es-custom/components/file-uploader/file-uploader-drop-container.d.ts +27 -11
- package/es-custom/components/floating-menu/floating-menu.d.ts +56 -22
- package/es-custom/components/fluid-select/fluid-select.d.ts +5 -0
- package/es-custom/components/fluid-select/fluid-select.js +50 -1
- package/es-custom/components/fluid-select/fluid-select.js.map +1 -1
- package/es-custom/components/fluid-textarea/fluid-textarea-skeleton.d.ts +3 -3
- package/es-custom/components/fluid-textarea/fluid-textarea-skeleton.js +3 -3
- package/es-custom/components/fluid-textarea/fluid-textarea-skeleton.js.map +1 -1
- package/es-custom/components/fluid-time-picker/fluid-time-picker-select.d.ts +21 -0
- package/es-custom/components/fluid-time-picker/fluid-time-picker-select.js +53 -0
- package/es-custom/components/fluid-time-picker/fluid-time-picker-select.js.map +1 -0
- package/es-custom/components/fluid-time-picker/fluid-time-picker-skeleton.d.ts +23 -0
- package/es-custom/components/fluid-time-picker/fluid-time-picker-skeleton.js +63 -0
- package/es-custom/components/fluid-time-picker/fluid-time-picker-skeleton.js.map +1 -0
- package/es-custom/components/fluid-time-picker/fluid-time-picker.d.ts +32 -0
- package/es-custom/components/fluid-time-picker/fluid-time-picker.js +239 -0
- package/es-custom/components/fluid-time-picker/fluid-time-picker.js.map +1 -0
- package/es-custom/components/fluid-time-picker/fluid-time-picker.scss.js +13 -0
- package/es-custom/components/fluid-time-picker/fluid-time-picker.scss.js.map +1 -0
- package/es-custom/components/fluid-time-picker/index.d.ts +9 -0
- package/es-custom/components/fluid-time-picker/index.js +11 -0
- package/es-custom/components/fluid-time-picker/index.js.map +1 -0
- package/es-custom/components/grid/column.d.ts +3 -1
- package/es-custom/components/grid/column.js +6 -0
- package/es-custom/components/grid/column.js.map +1 -1
- package/es-custom/components/icon-button/icon-button.d.ts +1 -1
- package/es-custom/components/icon-button/icon-button.js +6 -5
- package/es-custom/components/icon-button/icon-button.js.map +1 -1
- package/es-custom/components/link/link.d.ts +29 -11
- package/es-custom/components/menu/menu-item-selectable.d.ts +5 -3
- package/es-custom/components/menu/menu-item-selectable.js +3 -3
- package/es-custom/components/menu/menu-item-selectable.js.map +1 -1
- package/es-custom/components/menu/menu-item.d.ts +68 -23
- package/es-custom/components/menu/menu-item.js +37 -2
- package/es-custom/components/menu/menu-item.js.map +1 -1
- package/es-custom/components/menu/menu.d.ts +27 -11
- package/es-custom/components/menu-button/menu-button.d.ts +27 -11
- package/es-custom/components/modal/modal-close-button.d.ts +29 -11
- package/es-custom/components/modal/modal.d.ts +27 -11
- package/es-custom/components/modal/modal.js +6 -4
- package/es-custom/components/modal/modal.js.map +1 -1
- package/es-custom/components/multi-select/multi-select.js +12 -8
- package/es-custom/components/multi-select/multi-select.js.map +1 -1
- package/es-custom/components/notification/actionable-notification.d.ts +27 -11
- package/es-custom/components/notification/actionable-notification.scss.js +1 -1
- package/es-custom/components/notification/inline-notification.d.ts +27 -11
- package/es-custom/components/notification/inline-notification.scss.js +1 -1
- package/es-custom/components/notification/toast-notification.scss.js +1 -1
- package/es-custom/components/number-input/number-input.d.ts +2 -0
- package/es-custom/components/overflow-menu/overflow-menu-item.d.ts +29 -11
- package/es-custom/components/overflow-menu/overflow-menu.d.ts +54 -22
- package/es-custom/components/pagination/pagination.d.ts +56 -22
- package/es-custom/components/pagination-nav/defs.d.ts +61 -0
- package/es-custom/components/pagination-nav/defs.js +74 -0
- package/es-custom/components/pagination-nav/defs.js.map +1 -0
- package/es-custom/components/pagination-nav/index.d.ts +7 -0
- package/es-custom/components/pagination-nav/index.js +9 -0
- package/es-custom/components/pagination-nav/index.js.map +1 -0
- package/es-custom/components/pagination-nav/pagination-nav.d.ts +109 -0
- package/es-custom/components/pagination-nav/pagination-nav.js +427 -0
- package/es-custom/components/pagination-nav/pagination-nav.js.map +1 -0
- package/es-custom/components/pagination-nav/pagination-nav.scss.js +13 -0
- package/es-custom/components/pagination-nav/pagination-nav.scss.js.map +1 -0
- package/es-custom/components/password-input/password-input.d.ts +2 -0
- package/es-custom/components/popover/popover.d.ts +27 -11
- package/es-custom/components/popover/popover.js +1 -1
- package/es-custom/components/popover/popover.js.map +1 -1
- package/es-custom/components/progress-indicator/progress-step.d.ts +29 -11
- package/es-custom/components/radio-button/radio-button-group.d.ts +54 -22
- package/es-custom/components/radio-button/radio-button.d.ts +57 -23
- package/es-custom/components/radio-button/radio-button.js +7 -5
- package/es-custom/components/radio-button/radio-button.js.map +1 -1
- package/es-custom/components/search/search.d.ts +83 -33
- package/es-custom/components/select/select.d.ts +29 -11
- package/es-custom/components/side-panel/side-panel.d.ts +27 -11
- package/es-custom/components/skip-to-content/skip-to-content.d.ts +29 -11
- package/es-custom/components/slider/slider-input.d.ts +29 -11
- package/es-custom/components/slider/slider.d.ts +84 -34
- package/es-custom/components/slider/slider.js +9 -7
- package/es-custom/components/slider/slider.js.map +1 -1
- package/es-custom/components/slug/slug.d.ts +1 -1
- package/es-custom/components/slug/slug.js +6 -4
- package/es-custom/components/slug/slug.js.map +1 -1
- package/es-custom/components/structured-list/structured-list-row.d.ts +27 -11
- package/es-custom/components/structured-list/structured-list.d.ts +30 -12
- package/es-custom/components/structured-list/structured-list.js +7 -5
- package/es-custom/components/structured-list/structured-list.js.map +1 -1
- package/es-custom/components/tabs/tabs.d.ts +27 -11
- package/es-custom/components/tag/dismissible-tag.d.ts +54 -22
- package/es-custom/components/tag/operational-tag.d.ts +54 -22
- package/es-custom/components/tag/selectable-tag.d.ts +54 -22
- package/es-custom/components/tag/tag.d.ts +54 -22
- package/es-custom/components/tearsheet/tearsheet.d.ts +27 -11
- package/es-custom/components/text-input/text-input.d.ts +56 -22
- package/es-custom/components/textarea/textarea.d.ts +2 -0
- package/es-custom/components/tile/expandable-tile.d.ts +54 -22
- package/es-custom/components/tile/selectable-tile.d.ts +56 -22
- package/es-custom/components/tile/tile-group.d.ts +27 -11
- package/es-custom/components/time-picker/time-picker-select.d.ts +29 -11
- package/es-custom/components/time-picker/time-picker.d.ts +56 -22
- package/es-custom/components/toggle/toggle.d.ts +27 -11
- package/es-custom/components/toggle-tip/toggletip.d.ts +57 -23
- package/es-custom/components/toggle-tip/toggletip.js +7 -5
- package/es-custom/components/toggle-tip/toggletip.js.map +1 -1
- package/es-custom/components/tooltip/tooltip.d.ts +28 -12
- package/es-custom/components/tooltip/tooltip.js +7 -5
- package/es-custom/components/tooltip/tooltip.js.map +1 -1
- package/es-custom/components/tree-view/tree-view.d.ts +28 -12
- package/es-custom/components/tree-view/tree-view.js +7 -5
- package/es-custom/components/tree-view/tree-view.js.map +1 -1
- package/es-custom/components/ui-shell/header-global-action.d.ts +2 -0
- package/es-custom/components/ui-shell/header-menu-button.d.ts +29 -11
- package/es-custom/components/ui-shell/header-menu.d.ts +56 -22
- package/es-custom/components/ui-shell/header-name.d.ts +29 -11
- package/es-custom/components/ui-shell/header-nav-item.d.ts +29 -11
- package/es-custom/components/ui-shell/header-panel.d.ts +2 -0
- package/es-custom/components/ui-shell/side-nav-link.d.ts +29 -11
- package/es-custom/components/ui-shell/side-nav-menu-item.d.ts +29 -11
- package/es-custom/components/ui-shell/side-nav-menu.d.ts +29 -11
- package/es-custom/components/ui-shell/side-nav.d.ts +27 -11
- package/es-custom/components/ui-shell/switcher-item.d.ts +29 -11
- package/es-custom/components/ui-shell/switcher.d.ts +2 -0
- package/es-custom/globals/mixins/focus.d.ts +27 -11
- package/es-custom/globals/mixins/form.d.ts +27 -11
- package/es-custom/globals/mixins/host-listener.d.ts +27 -11
- package/es-custom/globals/mixins/validity.d.ts +27 -11
- package/lib/components/accordion/accordion-item.d.ts +28 -12
- package/lib/components/accordion/accordion-skeleton.d.ts +1 -1
- package/lib/components/accordion/accordion.d.ts +1 -1
- package/lib/components/ai-label/ai-label.d.ts +1 -1
- package/lib/components/button/button.d.ts +56 -22
- package/lib/components/checkbox/checkbox-group.d.ts +2 -0
- package/lib/components/checkbox/checkbox.d.ts +57 -23
- package/lib/components/code-snippet/code-snippet.d.ts +29 -11
- package/lib/components/combo-button/combo-button.d.ts +27 -11
- package/lib/components/content-switcher/content-switcher-item.d.ts +29 -11
- package/lib/components/copy-button/copy-button.d.ts +27 -11
- package/lib/components/data-table/table-expanded-row.d.ts +28 -12
- package/lib/components/data-table/table-header-cell.d.ts +29 -11
- package/lib/components/data-table/table-row.d.ts +54 -22
- package/lib/components/data-table/table-toolbar-search.d.ts +29 -11
- package/lib/components/data-table/table.d.ts +28 -12
- package/lib/components/date-picker/date-picker-input.d.ts +29 -11
- package/lib/components/date-picker/date-picker.d.ts +54 -22
- package/lib/components/dropdown/dropdown.d.ts +110 -44
- package/lib/components/file-uploader/file-uploader-button.d.ts +27 -11
- package/lib/components/file-uploader/file-uploader-drop-container.d.ts +27 -11
- package/lib/components/floating-menu/floating-menu.d.ts +56 -22
- package/lib/components/fluid-select/fluid-select.d.ts +5 -0
- package/lib/components/fluid-textarea/fluid-textarea-skeleton.d.ts +3 -3
- package/lib/components/fluid-time-picker/fluid-time-picker-select.d.ts +21 -0
- package/lib/components/fluid-time-picker/fluid-time-picker-skeleton.d.ts +23 -0
- package/lib/components/fluid-time-picker/fluid-time-picker.d.ts +32 -0
- package/lib/components/fluid-time-picker/index.d.ts +9 -0
- package/lib/components/grid/column.d.ts +3 -1
- package/lib/components/icon-button/icon-button.d.ts +1 -1
- package/lib/components/link/link.d.ts +29 -11
- package/lib/components/menu/menu-item-selectable.d.ts +5 -3
- package/lib/components/menu/menu-item.d.ts +68 -23
- package/lib/components/menu/menu.d.ts +27 -11
- package/lib/components/menu-button/menu-button.d.ts +27 -11
- package/lib/components/modal/modal-close-button.d.ts +29 -11
- package/lib/components/modal/modal.d.ts +27 -11
- package/lib/components/notification/actionable-notification.d.ts +27 -11
- package/lib/components/notification/inline-notification.d.ts +27 -11
- package/lib/components/number-input/number-input.d.ts +2 -0
- package/lib/components/overflow-menu/overflow-menu-item.d.ts +29 -11
- package/lib/components/overflow-menu/overflow-menu.d.ts +54 -22
- package/lib/components/pagination/pagination.d.ts +56 -22
- package/lib/components/pagination-nav/defs.d.ts +61 -0
- package/lib/components/pagination-nav/defs.js +74 -0
- package/lib/components/pagination-nav/defs.js.map +1 -0
- package/lib/components/pagination-nav/index.d.ts +7 -0
- package/lib/components/pagination-nav/pagination-nav.d.ts +109 -0
- package/lib/components/password-input/password-input.d.ts +2 -0
- package/lib/components/popover/popover.d.ts +27 -11
- package/lib/components/progress-indicator/progress-step.d.ts +29 -11
- package/lib/components/radio-button/radio-button-group.d.ts +54 -22
- package/lib/components/radio-button/radio-button.d.ts +57 -23
- package/lib/components/search/search.d.ts +83 -33
- package/lib/components/select/select.d.ts +29 -11
- package/lib/components/side-panel/side-panel.d.ts +27 -11
- package/lib/components/skip-to-content/skip-to-content.d.ts +29 -11
- package/lib/components/slider/slider-input.d.ts +29 -11
- package/lib/components/slider/slider.d.ts +84 -34
- package/lib/components/slug/slug.d.ts +1 -1
- package/lib/components/structured-list/structured-list-row.d.ts +27 -11
- package/lib/components/structured-list/structured-list.d.ts +30 -12
- package/lib/components/tabs/tabs.d.ts +27 -11
- package/lib/components/tag/dismissible-tag.d.ts +54 -22
- package/lib/components/tag/operational-tag.d.ts +54 -22
- package/lib/components/tag/selectable-tag.d.ts +54 -22
- package/lib/components/tag/tag.d.ts +54 -22
- package/lib/components/tearsheet/tearsheet.d.ts +27 -11
- package/lib/components/text-input/text-input.d.ts +56 -22
- package/lib/components/textarea/textarea.d.ts +2 -0
- package/lib/components/tile/expandable-tile.d.ts +54 -22
- package/lib/components/tile/selectable-tile.d.ts +56 -22
- package/lib/components/tile/tile-group.d.ts +27 -11
- package/lib/components/time-picker/time-picker-select.d.ts +29 -11
- package/lib/components/time-picker/time-picker.d.ts +56 -22
- package/lib/components/toggle/toggle.d.ts +27 -11
- package/lib/components/toggle-tip/toggletip.d.ts +57 -23
- package/lib/components/tooltip/tooltip.d.ts +28 -12
- package/lib/components/tree-view/tree-view.d.ts +28 -12
- package/lib/components/ui-shell/header-global-action.d.ts +2 -0
- package/lib/components/ui-shell/header-menu-button.d.ts +29 -11
- package/lib/components/ui-shell/header-menu.d.ts +56 -22
- package/lib/components/ui-shell/header-name.d.ts +29 -11
- package/lib/components/ui-shell/header-nav-item.d.ts +29 -11
- package/lib/components/ui-shell/header-panel.d.ts +2 -0
- package/lib/components/ui-shell/side-nav-link.d.ts +29 -11
- package/lib/components/ui-shell/side-nav-menu-item.d.ts +29 -11
- package/lib/components/ui-shell/side-nav-menu.d.ts +29 -11
- package/lib/components/ui-shell/side-nav.d.ts +27 -11
- package/lib/components/ui-shell/switcher-item.d.ts +29 -11
- package/lib/components/ui-shell/switcher.d.ts +2 -0
- package/lib/globals/mixins/focus.d.ts +27 -11
- package/lib/globals/mixins/form.d.ts +27 -11
- package/lib/globals/mixins/host-listener.d.ts +27 -11
- package/lib/globals/mixins/validity.d.ts +27 -11
- package/package.json +7 -7
- package/scss/components/combo-box/combo-box.scss +1 -1
- package/scss/components/fluid-time-picker/fluid-time-picker.scss +198 -0
- package/scss/components/pagination-nav/pagination-nav.scss +29 -0
- package/telemetry.yml +16 -8
|
@@ -0,0 +1,427 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright IBM Corp. 2024
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import { __decorate } from 'tslib';
|
|
9
|
+
import { LitElement, html } from 'lit';
|
|
10
|
+
import { state, property } from 'lit/decorators.js';
|
|
11
|
+
import { carbonElement } from '../../globals/decorators/carbon-element.js';
|
|
12
|
+
import { prefix } from '../../globals/settings.js';
|
|
13
|
+
import styles from './pagination-nav.scss.js';
|
|
14
|
+
import { classMap } from 'lit/directives/class-map.js';
|
|
15
|
+
import CaretLeft16 from '@carbon/icons/es/caret--left/16.js';
|
|
16
|
+
import CaretRight16 from '@carbon/icons/es/caret--right/16.js';
|
|
17
|
+
import OverflowMenuHorizontal16 from '@carbon/icons/es/overflow-menu--horizontal/16.js';
|
|
18
|
+
import { iconLoader } from '../../globals/internal/icon-loader.js';
|
|
19
|
+
import '../icon-button/icon-button.js';
|
|
20
|
+
import { PAGINATION_NAV_SIZE, PAGINATION_TOOLTIP_ALIGNMENT, PAGINATION_TOOLTIP_POSITION } from './defs.js';
|
|
21
|
+
import { ifDefined } from 'lit/directives/if-defined.js';
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
*
|
|
25
|
+
* Copyright IBM Corp. 2026
|
|
26
|
+
*
|
|
27
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
|
28
|
+
* LICENSE file in the root directory of this source tree.
|
|
29
|
+
*/
|
|
30
|
+
/**
|
|
31
|
+
* Translation IDs and default translations
|
|
32
|
+
*/
|
|
33
|
+
const translationIds = {
|
|
34
|
+
'carbon.pagination-nav.next': 'carbon.pagination-nav.next',
|
|
35
|
+
'carbon.pagination-nav.previous': 'carbon.pagination-nav.previous',
|
|
36
|
+
'carbon.pagination-nav.item': 'carbon.pagination-nav.item',
|
|
37
|
+
'carbon.pagination-nav.active': 'carbon.pagination-nav.active',
|
|
38
|
+
'carbon.pagination-nav.of': 'carbon.pagination-nav.of',
|
|
39
|
+
};
|
|
40
|
+
const defaultTranslations = {
|
|
41
|
+
[translationIds['carbon.pagination-nav.next']]: 'Next',
|
|
42
|
+
[translationIds['carbon.pagination-nav.previous']]: 'Previous',
|
|
43
|
+
[translationIds['carbon.pagination-nav.item']]: 'Page',
|
|
44
|
+
[translationIds['carbon.pagination-nav.active']]: 'Active',
|
|
45
|
+
[translationIds['carbon.pagination-nav.of']]: 'of',
|
|
46
|
+
};
|
|
47
|
+
/**
|
|
48
|
+
* Default translation function
|
|
49
|
+
*/
|
|
50
|
+
const defaultTranslateWithId = (messageId) => {
|
|
51
|
+
return defaultTranslations[messageId];
|
|
52
|
+
};
|
|
53
|
+
/**
|
|
54
|
+
* Pagination Navigation.
|
|
55
|
+
*
|
|
56
|
+
* @element cds-custom-pagination-nav
|
|
57
|
+
* @fires cds-custom-page-changed - The custom event fired when the the page has been changed.
|
|
58
|
+
*/
|
|
59
|
+
let CDSPaginationNav = class CDSPaginationNav extends LitElement {
|
|
60
|
+
constructor() {
|
|
61
|
+
super(...arguments);
|
|
62
|
+
/**
|
|
63
|
+
* Internal state for cuts
|
|
64
|
+
*/
|
|
65
|
+
this.cuts = { front: 0, back: 0 };
|
|
66
|
+
/**
|
|
67
|
+
* Internal state for previous page
|
|
68
|
+
*/
|
|
69
|
+
this.prevPage = null;
|
|
70
|
+
/**
|
|
71
|
+
* The number of items to be shown (minimum of 4 unless props.items < 4).
|
|
72
|
+
*/
|
|
73
|
+
this.itemsShown = 10;
|
|
74
|
+
/**
|
|
75
|
+
* Whether user should be able to loop through the items when reaching first / last.
|
|
76
|
+
*/
|
|
77
|
+
this.loop = false;
|
|
78
|
+
/**
|
|
79
|
+
* The index of current page.
|
|
80
|
+
*/
|
|
81
|
+
this.page = 0;
|
|
82
|
+
/**
|
|
83
|
+
* The total number of items.
|
|
84
|
+
*/
|
|
85
|
+
this.totalItems = 1;
|
|
86
|
+
/**
|
|
87
|
+
* Specify the size of the PaginationNav.
|
|
88
|
+
*/
|
|
89
|
+
this.size = PAGINATION_NAV_SIZE.LARGE;
|
|
90
|
+
/**
|
|
91
|
+
* Specify the alignment of the tooltip for the icon-only next/prev buttons.
|
|
92
|
+
* Can be one of: start, center, or end.
|
|
93
|
+
*/
|
|
94
|
+
this.tooltipAlignment = PAGINATION_TOOLTIP_ALIGNMENT.CENTER;
|
|
95
|
+
/**
|
|
96
|
+
* Specify the position of the tooltip for the icon-only next/prev buttons.
|
|
97
|
+
* Can be one of: top, right, bottom, or left.
|
|
98
|
+
*/
|
|
99
|
+
this.tooltipPosition = PAGINATION_TOOLTIP_POSITION.BOTTOM;
|
|
100
|
+
/**
|
|
101
|
+
* Translates component strings using your i18n tool.
|
|
102
|
+
*/
|
|
103
|
+
this.translateWithId = defaultTranslateWithId;
|
|
104
|
+
}
|
|
105
|
+
_calculateCuts(page, totalItems, itemsDisplayedOnPage, splitPoint = null) {
|
|
106
|
+
if (itemsDisplayedOnPage >= totalItems) {
|
|
107
|
+
return { front: 0, back: 0 };
|
|
108
|
+
}
|
|
109
|
+
const split = splitPoint || Math.ceil(itemsDisplayedOnPage / 2) - 1;
|
|
110
|
+
let frontHidden = page + 1 - split;
|
|
111
|
+
let backHidden = totalItems - page - (itemsDisplayedOnPage - split) + 1;
|
|
112
|
+
if (frontHidden <= 1) {
|
|
113
|
+
backHidden -= frontHidden <= 0 ? Math.abs(frontHidden) + 1 : 0;
|
|
114
|
+
frontHidden = 0;
|
|
115
|
+
}
|
|
116
|
+
if (backHidden <= 1) {
|
|
117
|
+
frontHidden -= backHidden <= 0 ? Math.abs(backHidden) + 1 : 0;
|
|
118
|
+
backHidden = 0;
|
|
119
|
+
}
|
|
120
|
+
return { front: frontHidden, back: backHidden };
|
|
121
|
+
}
|
|
122
|
+
_pageWouldBeHidden(page) {
|
|
123
|
+
const startOffset = this.itemsDisplayedOnPage <= 4 && this.page > 1 ? 0 : 1;
|
|
124
|
+
const wouldBeHiddenInFront = (page >= startOffset && page <= this.cuts.front) || page === 0;
|
|
125
|
+
const wouldBeHiddenInBack = page >= this.totalItems - this.cuts.back - 1 &&
|
|
126
|
+
page <= this.totalItems - 2;
|
|
127
|
+
return wouldBeHiddenInFront || wouldBeHiddenInBack;
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Sets the current page to a specified index.
|
|
131
|
+
*/
|
|
132
|
+
_setIndex(index) {
|
|
133
|
+
if (index >= 0 && index < this.totalItems) {
|
|
134
|
+
this.page = index;
|
|
135
|
+
this.dispatchEvent(new CustomEvent(this.constructor.eventChange, {
|
|
136
|
+
bubbles: true,
|
|
137
|
+
composed: true,
|
|
138
|
+
detail: {
|
|
139
|
+
page: index,
|
|
140
|
+
},
|
|
141
|
+
}));
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* Reduce current page by one, but no lower than 0.
|
|
146
|
+
*/
|
|
147
|
+
_decrementIndex() {
|
|
148
|
+
const { loop, page, totalItems } = this;
|
|
149
|
+
const wouldLoop = page - 1 < 0;
|
|
150
|
+
if (loop) {
|
|
151
|
+
this.page = wouldLoop ? totalItems - 1 : page - 1;
|
|
152
|
+
}
|
|
153
|
+
else {
|
|
154
|
+
this.page = Math.max(this.page - 1, 0);
|
|
155
|
+
}
|
|
156
|
+
this.dispatchEvent(new CustomEvent(this.constructor.eventChange, {
|
|
157
|
+
bubbles: true,
|
|
158
|
+
composed: true,
|
|
159
|
+
detail: {
|
|
160
|
+
page: this.page,
|
|
161
|
+
},
|
|
162
|
+
}));
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* Increase current page by one, but no higher than (this.totalItems - 1).
|
|
166
|
+
*/
|
|
167
|
+
_incrementIndex() {
|
|
168
|
+
const { loop, page, totalItems } = this;
|
|
169
|
+
const wouldLoop = page + 1 >= totalItems;
|
|
170
|
+
if (loop) {
|
|
171
|
+
this.page = wouldLoop ? 0 : page + 1;
|
|
172
|
+
}
|
|
173
|
+
else {
|
|
174
|
+
this.page = Math.min(this.page + 1, this.totalItems - 1);
|
|
175
|
+
}
|
|
176
|
+
this.dispatchEvent(new CustomEvent(this.constructor.eventChange, {
|
|
177
|
+
bubbles: true,
|
|
178
|
+
composed: true,
|
|
179
|
+
detail: {
|
|
180
|
+
page: this.page,
|
|
181
|
+
},
|
|
182
|
+
}));
|
|
183
|
+
}
|
|
184
|
+
/**
|
|
185
|
+
* Renders a single pagination item & button.
|
|
186
|
+
*/
|
|
187
|
+
_renderPaginationItem(itemPage, isActive = false) {
|
|
188
|
+
const { translateWithId: t } = this;
|
|
189
|
+
const itemLabel = t('carbon.pagination-nav.item');
|
|
190
|
+
const classes = {
|
|
191
|
+
[`${prefix}--pagination-nav__page`]: true,
|
|
192
|
+
[`${prefix}--pagination-nav__page--active`]: isActive,
|
|
193
|
+
};
|
|
194
|
+
return html `
|
|
195
|
+
<li class="${prefix}--pagination-nav__list-item">
|
|
196
|
+
<button
|
|
197
|
+
class=${classMap(classes)}
|
|
198
|
+
type="button"
|
|
199
|
+
@click=${() => this._setIndex(itemPage)}
|
|
200
|
+
data-page="${itemPage + 1}"
|
|
201
|
+
aria-current=${ifDefined(isActive ? 'page' : undefined)}>
|
|
202
|
+
<span class="${prefix}--pagination-nav__accessibility-label">
|
|
203
|
+
${isActive
|
|
204
|
+
? `${t('carbon.pagination-nav.active')}, ${itemLabel}`
|
|
205
|
+
: itemLabel}
|
|
206
|
+
</span>
|
|
207
|
+
${itemPage + 1}
|
|
208
|
+
</button>
|
|
209
|
+
</li>
|
|
210
|
+
`;
|
|
211
|
+
}
|
|
212
|
+
/**
|
|
213
|
+
* Renders overflow items in a select list.
|
|
214
|
+
*
|
|
215
|
+
*/
|
|
216
|
+
_renderPaginationOverflow(fromIndex, count) {
|
|
217
|
+
const { translateWithId: t } = this;
|
|
218
|
+
if (count > 1) {
|
|
219
|
+
return html `
|
|
220
|
+
<li class="${prefix}--pagination-nav__list-item">
|
|
221
|
+
<div class="${prefix}--pagination-nav__select">
|
|
222
|
+
<select
|
|
223
|
+
class="${prefix}--pagination-nav__page ${prefix}--pagination-nav__page--select"
|
|
224
|
+
aria-label="Select ${t('carbon.pagination-nav.item')} number"
|
|
225
|
+
?disabled="${this.disableOverflow}"
|
|
226
|
+
@change=${(e) => {
|
|
227
|
+
const target = e.target;
|
|
228
|
+
const index = Number(target.value);
|
|
229
|
+
this._setIndex(index);
|
|
230
|
+
e.target.value = '';
|
|
231
|
+
}}>
|
|
232
|
+
<option value="" hidden></option>
|
|
233
|
+
${Array.from({ length: count }).map((_, i) => html `
|
|
234
|
+
<option
|
|
235
|
+
value="${fromIndex + i}"
|
|
236
|
+
data-page="${fromIndex + i + 1}"
|
|
237
|
+
key="overflow-${fromIndex + i}">
|
|
238
|
+
${fromIndex + i + 1}
|
|
239
|
+
</option>
|
|
240
|
+
`)}
|
|
241
|
+
</select>
|
|
242
|
+
<div class="${prefix}--pagination-nav__select-icon-wrapper">
|
|
243
|
+
${iconLoader(OverflowMenuHorizontal16, {
|
|
244
|
+
class: `${prefix}--pagination-nav__select-icon`,
|
|
245
|
+
})}
|
|
246
|
+
</div>
|
|
247
|
+
</div>
|
|
248
|
+
</li>
|
|
249
|
+
`;
|
|
250
|
+
}
|
|
251
|
+
else if (count === 1) {
|
|
252
|
+
return this._renderPaginationItem(fromIndex);
|
|
253
|
+
}
|
|
254
|
+
else {
|
|
255
|
+
return html ``;
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
render() {
|
|
259
|
+
const { loop, page, totalItems, _incrementIndex: incrementIndex, _decrementIndex: decrementIndex, translateWithId: t, size, tooltipAlignment, tooltipPosition, } = this;
|
|
260
|
+
const backwardButtonDisabled = !loop && page <= 0;
|
|
261
|
+
const forwardButtonDisabled = !loop && page >= totalItems - 1;
|
|
262
|
+
const startOffset = this.itemsDisplayedOnPage <= 4 && this.page > 1 ? 0 : 1;
|
|
263
|
+
const align = tooltipAlignment === 'center'
|
|
264
|
+
? tooltipPosition
|
|
265
|
+
: `${tooltipPosition}-${tooltipAlignment}`;
|
|
266
|
+
const navClasses = classMap({
|
|
267
|
+
[`${prefix}--pagination-nav`]: true,
|
|
268
|
+
[`${prefix}--layout--size-${size}`]: size,
|
|
269
|
+
});
|
|
270
|
+
return html `
|
|
271
|
+
<nav class="${navClasses}" aria-label="pagination">
|
|
272
|
+
<ul class="${prefix}--pagination-nav__list">
|
|
273
|
+
<li class="${prefix}--pagination-nav__list-item">
|
|
274
|
+
<cds-custom-icon-button
|
|
275
|
+
kind="ghost"
|
|
276
|
+
align="${align}"
|
|
277
|
+
size="${size}"
|
|
278
|
+
?disabled=${backwardButtonDisabled}
|
|
279
|
+
@click=${decrementIndex}>
|
|
280
|
+
<span slot="tooltip-content"
|
|
281
|
+
>${this.translateWithId('carbon.pagination-nav.previous')}</span
|
|
282
|
+
>
|
|
283
|
+
${iconLoader(CaretLeft16, { slot: 'icon' })}
|
|
284
|
+
</cds-custom-icon-button>
|
|
285
|
+
</li>
|
|
286
|
+
|
|
287
|
+
${
|
|
288
|
+
// render first item if at least 5 items can be displayed or
|
|
289
|
+
// 4 items can be displayed and the current page is either 0 or 1
|
|
290
|
+
this.itemsDisplayedOnPage >= 5 ||
|
|
291
|
+
(this.itemsDisplayedOnPage <= 4 && this.page <= 1)
|
|
292
|
+
? this._renderPaginationItem(0, this.page === 0)
|
|
293
|
+
: ''}
|
|
294
|
+
${
|
|
295
|
+
/* render first overflow */
|
|
296
|
+
this._renderPaginationOverflow(startOffset, this.cuts.front)}
|
|
297
|
+
${
|
|
298
|
+
// render items between overflows
|
|
299
|
+
Array.from({ length: this.totalItems })
|
|
300
|
+
.map((_, i) => i)
|
|
301
|
+
.slice(startOffset + this.cuts.front, (1 + this.cuts.back) * -1)
|
|
302
|
+
.map((item) => this._renderPaginationItem(item, this.page === item))}
|
|
303
|
+
${
|
|
304
|
+
/* render second overflow */
|
|
305
|
+
this._renderPaginationOverflow(this.totalItems - this.cuts.back - 1, this.cuts.back)}
|
|
306
|
+
${
|
|
307
|
+
// render last item unless there is only one in total
|
|
308
|
+
this.totalItems > 1
|
|
309
|
+
? this._renderPaginationItem(this.totalItems - 1, this.page === this.totalItems - 1)
|
|
310
|
+
: ''}
|
|
311
|
+
<li class="${prefix}--pagination-nav__list-item">
|
|
312
|
+
<cds-custom-icon-button
|
|
313
|
+
kind="ghost"
|
|
314
|
+
align="${align}"
|
|
315
|
+
size="${size}"
|
|
316
|
+
?disabled=${forwardButtonDisabled}
|
|
317
|
+
@click=${incrementIndex}>
|
|
318
|
+
<span slot="tooltip-content"
|
|
319
|
+
>${this.translateWithId('carbon.pagination-nav.next')}</span
|
|
320
|
+
>
|
|
321
|
+
${iconLoader(CaretRight16, { slot: 'icon' })}
|
|
322
|
+
</cds-custom-icon-button>
|
|
323
|
+
</li>
|
|
324
|
+
</ul>
|
|
325
|
+
<div
|
|
326
|
+
aria-live="polite"
|
|
327
|
+
aria-atomic="true"
|
|
328
|
+
class="${prefix}--pagination-nav__accessibility-label">
|
|
329
|
+
${`${t('carbon.pagination-nav.item')} ${this.page + 1} ${t('carbon.pagination-nav.of')} ${this.totalItems}`}
|
|
330
|
+
</div>
|
|
331
|
+
</nav>
|
|
332
|
+
`;
|
|
333
|
+
}
|
|
334
|
+
shouldUpdate(changedProperties) {
|
|
335
|
+
// Prevent setting "page" outside bounds of available pages.
|
|
336
|
+
if (changedProperties.has('totalItems') || changedProperties.has('page')) {
|
|
337
|
+
if (this.page > this.totalItems) {
|
|
338
|
+
this.page = this.totalItems - 1;
|
|
339
|
+
}
|
|
340
|
+
if (this.page < 0) {
|
|
341
|
+
this.page = 0;
|
|
342
|
+
}
|
|
343
|
+
}
|
|
344
|
+
return true;
|
|
345
|
+
}
|
|
346
|
+
updated(changedProperties) {
|
|
347
|
+
if (changedProperties.has('page')) {
|
|
348
|
+
this.prevPage = changedProperties.get('page');
|
|
349
|
+
}
|
|
350
|
+
if (changedProperties.has('totalItems') ||
|
|
351
|
+
changedProperties.has('itemsShown') ||
|
|
352
|
+
changedProperties.has('size')) {
|
|
353
|
+
let numberOfPages;
|
|
354
|
+
switch (this.size) {
|
|
355
|
+
case PAGINATION_NAV_SIZE.MEDIUM:
|
|
356
|
+
numberOfPages = this.itemsShown === 4 ? this.itemsShown : 5;
|
|
357
|
+
break;
|
|
358
|
+
case PAGINATION_NAV_SIZE.SMALL:
|
|
359
|
+
numberOfPages = Math.min(Math.max(4, this.itemsShown), 7);
|
|
360
|
+
break;
|
|
361
|
+
default:
|
|
362
|
+
numberOfPages = 4;
|
|
363
|
+
break;
|
|
364
|
+
}
|
|
365
|
+
this.itemsDisplayedOnPage = Math.max(this.itemsShown >= 4 ? this.itemsShown : numberOfPages, 4);
|
|
366
|
+
this.cuts = this._calculateCuts(this.page, this.totalItems, this.itemsDisplayedOnPage);
|
|
367
|
+
}
|
|
368
|
+
if (changedProperties.has('page') && this._pageWouldBeHidden(this.page)) {
|
|
369
|
+
const delta = this.page - (this.prevPage || 0);
|
|
370
|
+
if (delta > 0) {
|
|
371
|
+
const splitPoint = this.itemsDisplayedOnPage - 3;
|
|
372
|
+
this.cuts = this._calculateCuts(this.page, this.totalItems, this.itemsDisplayedOnPage, splitPoint);
|
|
373
|
+
}
|
|
374
|
+
else {
|
|
375
|
+
const splitPoint = this.itemsDisplayedOnPage > 4 ? 2 : 1;
|
|
376
|
+
this.cuts = this._calculateCuts(this.page, this.totalItems, this.itemsDisplayedOnPage, splitPoint);
|
|
377
|
+
}
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
static get eventChange() {
|
|
381
|
+
return `${prefix}-page-changed`;
|
|
382
|
+
}
|
|
383
|
+
};
|
|
384
|
+
CDSPaginationNav.styles = styles;
|
|
385
|
+
__decorate([
|
|
386
|
+
state()
|
|
387
|
+
], CDSPaginationNav.prototype, "itemsDisplayedOnPage", void 0);
|
|
388
|
+
__decorate([
|
|
389
|
+
state()
|
|
390
|
+
], CDSPaginationNav.prototype, "cuts", void 0);
|
|
391
|
+
__decorate([
|
|
392
|
+
state()
|
|
393
|
+
], CDSPaginationNav.prototype, "prevPage", void 0);
|
|
394
|
+
__decorate([
|
|
395
|
+
property({ attribute: 'items-shown', reflect: true, type: Number })
|
|
396
|
+
], CDSPaginationNav.prototype, "itemsShown", void 0);
|
|
397
|
+
__decorate([
|
|
398
|
+
property({ attribute: 'loop', type: Boolean })
|
|
399
|
+
], CDSPaginationNav.prototype, "loop", void 0);
|
|
400
|
+
__decorate([
|
|
401
|
+
property({ attribute: 'page', reflect: true, type: Number })
|
|
402
|
+
], CDSPaginationNav.prototype, "page", void 0);
|
|
403
|
+
__decorate([
|
|
404
|
+
property({ attribute: 'total-items', reflect: true, type: Number })
|
|
405
|
+
], CDSPaginationNav.prototype, "totalItems", void 0);
|
|
406
|
+
__decorate([
|
|
407
|
+
property({ reflect: true })
|
|
408
|
+
], CDSPaginationNav.prototype, "size", void 0);
|
|
409
|
+
__decorate([
|
|
410
|
+
property({ attribute: 'tooltip-alignment', reflect: true })
|
|
411
|
+
], CDSPaginationNav.prototype, "tooltipAlignment", void 0);
|
|
412
|
+
__decorate([
|
|
413
|
+
property({ attribute: 'tooltip-position', reflect: true })
|
|
414
|
+
], CDSPaginationNav.prototype, "tooltipPosition", void 0);
|
|
415
|
+
__decorate([
|
|
416
|
+
property({ attribute: 'disable-overflow', reflect: true, type: Boolean })
|
|
417
|
+
], CDSPaginationNav.prototype, "disableOverflow", void 0);
|
|
418
|
+
__decorate([
|
|
419
|
+
property({ attribute: false })
|
|
420
|
+
], CDSPaginationNav.prototype, "translateWithId", void 0);
|
|
421
|
+
CDSPaginationNav = __decorate([
|
|
422
|
+
carbonElement(`${prefix}-pagination-nav`)
|
|
423
|
+
], CDSPaginationNav);
|
|
424
|
+
var CDSPaginationNav$1 = CDSPaginationNav;
|
|
425
|
+
|
|
426
|
+
export { CDSPaginationNav$1 as default };
|
|
427
|
+
//# sourceMappingURL=pagination-nav.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pagination-nav.js","sources":["../../../src/components/pagination-nav/pagination-nav.ts"],"sourcesContent":["/**\n *\n * Copyright IBM Corp. 2026\n *\n * This source code is licensed under the Apache-2.0 license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { LitElement, html } from 'lit';\nimport { property, state } from 'lit/decorators.js';\nimport { carbonElement as customElement } from '../../globals/decorators/carbon-element';\nimport { prefix } from '../../globals/settings';\nimport styles from './pagination-nav.scss?lit';\nimport { classMap } from 'lit/directives/class-map.js';\nimport CaretLeft16 from '@carbon/icons/es/caret--left/16.js';\nimport CaretRight16 from '@carbon/icons/es/caret--right/16.js';\nimport OverflowMenu from '@carbon/icons/es/overflow-menu--horizontal/16.js';\nimport { iconLoader } from '../../globals/internal/icon-loader';\nimport '../icon-button';\nimport {\n PAGINATION_NAV_SIZE,\n PAGINATION_TOOLTIP_ALIGNMENT,\n PAGINATION_TOOLTIP_POSITION,\n} from './defs';\nimport { ifDefined } from 'lit/directives/if-defined.js';\n\n/**\n * Translation IDs and default translations\n */\nconst translationIds = {\n 'carbon.pagination-nav.next': 'carbon.pagination-nav.next',\n 'carbon.pagination-nav.previous': 'carbon.pagination-nav.previous',\n 'carbon.pagination-nav.item': 'carbon.pagination-nav.item',\n 'carbon.pagination-nav.active': 'carbon.pagination-nav.active',\n 'carbon.pagination-nav.of': 'carbon.pagination-nav.of',\n} as const;\n\ntype TranslationKey = keyof typeof translationIds;\n\nconst defaultTranslations: Record<TranslationKey, string> = {\n [translationIds['carbon.pagination-nav.next']]: 'Next',\n [translationIds['carbon.pagination-nav.previous']]: 'Previous',\n [translationIds['carbon.pagination-nav.item']]: 'Page',\n [translationIds['carbon.pagination-nav.active']]: 'Active',\n [translationIds['carbon.pagination-nav.of']]: 'of',\n};\n\n/**\n * Default translation function\n */\nconst defaultTranslateWithId = (messageId: TranslationKey): string => {\n return defaultTranslations[messageId];\n};\n\n/**\n * Pagination Navigation.\n *\n * @element cds-custom-pagination-nav\n * @fires cds-custom-page-changed - The custom event fired when the the page has been changed.\n */\n@customElement(`${prefix}-pagination-nav`)\nclass CDSPaginationNav extends LitElement {\n /**\n * Internal state for items displayed on page\n */\n @state()\n private itemsDisplayedOnPage!: number;\n\n /**\n * Internal state for cuts\n */\n @state()\n private cuts = { front: 0, back: 0 };\n\n /**\n * Internal state for previous page\n */\n @state()\n private prevPage: number | null = null;\n\n /**\n * The number of items to be shown (minimum of 4 unless props.items < 4).\n */\n @property({ attribute: 'items-shown', reflect: true, type: Number })\n itemsShown = 10;\n\n /**\n * Whether user should be able to loop through the items when reaching first / last.\n */\n @property({ attribute: 'loop', type: Boolean })\n loop = false;\n\n /**\n * The index of current page.\n */\n @property({ attribute: 'page', reflect: true, type: Number })\n page = 0;\n\n /**\n * The total number of items.\n */\n @property({ attribute: 'total-items', reflect: true, type: Number })\n totalItems = 1;\n\n /**\n * Specify the size of the PaginationNav.\n */\n @property({ reflect: true })\n size = PAGINATION_NAV_SIZE.LARGE;\n\n /**\n * Specify the alignment of the tooltip for the icon-only next/prev buttons.\n * Can be one of: start, center, or end.\n */\n @property({ attribute: 'tooltip-alignment', reflect: true })\n tooltipAlignment = PAGINATION_TOOLTIP_ALIGNMENT.CENTER;\n\n /**\n * Specify the position of the tooltip for the icon-only next/prev buttons.\n * Can be one of: top, right, bottom, or left.\n */\n @property({ attribute: 'tooltip-position', reflect: true })\n tooltipPosition = PAGINATION_TOOLTIP_POSITION.BOTTOM;\n\n /**\n * If true, the '...' pagination overflow will not render page links between the first and last rendered buttons.\n * Set this to true if you are having performance problems with large data sets.\n */\n @property({ attribute: 'disable-overflow', reflect: true, type: Boolean })\n disableOverflow?: boolean;\n\n /**\n * Translates component strings using your i18n tool.\n */\n @property({ attribute: false })\n translateWithId: (messageId: TranslationKey) => string =\n defaultTranslateWithId;\n\n private _calculateCuts(\n page: number,\n totalItems: number,\n itemsDisplayedOnPage: number,\n splitPoint: number | null = null\n ) {\n if (itemsDisplayedOnPage >= totalItems) {\n return { front: 0, back: 0 };\n }\n\n const split = splitPoint || Math.ceil(itemsDisplayedOnPage / 2) - 1;\n\n let frontHidden = page + 1 - split;\n let backHidden = totalItems - page - (itemsDisplayedOnPage - split) + 1;\n\n if (frontHidden <= 1) {\n backHidden -= frontHidden <= 0 ? Math.abs(frontHidden) + 1 : 0;\n frontHidden = 0;\n }\n\n if (backHidden <= 1) {\n frontHidden -= backHidden <= 0 ? Math.abs(backHidden) + 1 : 0;\n backHidden = 0;\n }\n\n return { front: frontHidden, back: backHidden };\n }\n\n private _pageWouldBeHidden(page: number) {\n const startOffset = this.itemsDisplayedOnPage <= 4 && this.page > 1 ? 0 : 1;\n\n const wouldBeHiddenInFront =\n (page >= startOffset && page <= this.cuts.front) || page === 0;\n const wouldBeHiddenInBack =\n page >= this.totalItems - this.cuts.back - 1 &&\n page <= this.totalItems - 2;\n\n return wouldBeHiddenInFront || wouldBeHiddenInBack;\n }\n\n /**\n * Sets the current page to a specified index.\n */\n private _setIndex(index: number) {\n if (index >= 0 && index < this.totalItems) {\n this.page = index;\n this.dispatchEvent(\n new CustomEvent(\n (this.constructor as typeof CDSPaginationNav).eventChange,\n {\n bubbles: true,\n composed: true,\n detail: {\n page: index,\n },\n }\n )\n );\n }\n }\n\n /**\n * Reduce current page by one, but no lower than 0.\n */\n private _decrementIndex() {\n const { loop, page, totalItems } = this;\n const wouldLoop = page - 1 < 0;\n\n if (loop) {\n this.page = wouldLoop ? totalItems - 1 : page - 1;\n } else {\n this.page = Math.max(this.page - 1, 0);\n }\n this.dispatchEvent(\n new CustomEvent(\n (this.constructor as typeof CDSPaginationNav).eventChange,\n {\n bubbles: true,\n composed: true,\n detail: {\n page: this.page,\n },\n }\n )\n );\n }\n\n /**\n * Increase current page by one, but no higher than (this.totalItems - 1).\n */\n private _incrementIndex() {\n const { loop, page, totalItems } = this;\n const wouldLoop = page + 1 >= totalItems;\n\n if (loop) {\n this.page = wouldLoop ? 0 : page + 1;\n } else {\n this.page = Math.min(this.page + 1, this.totalItems - 1);\n }\n this.dispatchEvent(\n new CustomEvent(\n (this.constructor as typeof CDSPaginationNav).eventChange,\n {\n bubbles: true,\n composed: true,\n detail: {\n page: this.page,\n },\n }\n )\n );\n }\n\n /**\n * Renders a single pagination item & button.\n */\n private _renderPaginationItem(itemPage: number, isActive = false) {\n const { translateWithId: t } = this;\n const itemLabel = t('carbon.pagination-nav.item');\n const classes = {\n [`${prefix}--pagination-nav__page`]: true,\n [`${prefix}--pagination-nav__page--active`]: isActive,\n };\n\n return html`\n <li class=\"${prefix}--pagination-nav__list-item\">\n <button\n class=${classMap(classes)}\n type=\"button\"\n @click=${() => this._setIndex(itemPage)}\n data-page=\"${itemPage + 1}\"\n aria-current=${ifDefined(isActive ? 'page' : undefined)}>\n <span class=\"${prefix}--pagination-nav__accessibility-label\">\n ${isActive\n ? `${t('carbon.pagination-nav.active')}, ${itemLabel}`\n : itemLabel}\n </span>\n ${itemPage + 1}\n </button>\n </li>\n `;\n }\n\n /**\n * Renders overflow items in a select list.\n *\n */\n private _renderPaginationOverflow(fromIndex: number, count: number) {\n const { translateWithId: t } = this;\n\n if (count > 1) {\n return html`\n <li class=\"${prefix}--pagination-nav__list-item\">\n <div class=\"${prefix}--pagination-nav__select\">\n <select\n class=\"${prefix}--pagination-nav__page ${prefix}--pagination-nav__page--select\"\n aria-label=\"Select ${t('carbon.pagination-nav.item')} number\"\n ?disabled=\"${this.disableOverflow}\"\n @change=${(e: Event) => {\n const target = e.target as HTMLSelectElement;\n const index = Number(target.value);\n this._setIndex(index);\n (e.target as HTMLSelectElement).value = '';\n }}>\n <option value=\"\" hidden></option>\n ${Array.from({ length: count }).map(\n (_, i) => html`\n <option\n value=\"${fromIndex + i}\"\n data-page=\"${fromIndex + i + 1}\"\n key=\"overflow-${fromIndex + i}\">\n ${fromIndex + i + 1}\n </option>\n `\n )}\n </select>\n <div class=\"${prefix}--pagination-nav__select-icon-wrapper\">\n ${iconLoader(OverflowMenu, {\n class: `${prefix}--pagination-nav__select-icon`,\n })}\n </div>\n </div>\n </li>\n `;\n } else if (count === 1) {\n return this._renderPaginationItem(fromIndex);\n } else {\n return html``;\n }\n }\n\n render() {\n const {\n loop,\n page,\n totalItems,\n _incrementIndex: incrementIndex,\n _decrementIndex: decrementIndex,\n translateWithId: t,\n size,\n tooltipAlignment,\n tooltipPosition,\n } = this;\n const backwardButtonDisabled = !loop && page <= 0;\n const forwardButtonDisabled = !loop && page >= totalItems - 1;\n\n const startOffset = this.itemsDisplayedOnPage <= 4 && this.page > 1 ? 0 : 1;\n\n const align =\n tooltipAlignment === 'center'\n ? tooltipPosition\n : `${tooltipPosition}-${tooltipAlignment}`;\n\n const navClasses = classMap({\n [`${prefix}--pagination-nav`]: true,\n [`${prefix}--layout--size-${size}`]: size,\n });\n\n return html`\n <nav class=\"${navClasses}\" aria-label=\"pagination\">\n <ul class=\"${prefix}--pagination-nav__list\">\n <li class=\"${prefix}--pagination-nav__list-item\">\n <cds-custom-icon-button\n kind=\"ghost\"\n align=\"${align}\"\n size=\"${size}\"\n ?disabled=${backwardButtonDisabled}\n @click=${decrementIndex}>\n <span slot=\"tooltip-content\"\n >${this.translateWithId('carbon.pagination-nav.previous')}</span\n >\n ${iconLoader(CaretLeft16, { slot: 'icon' })}\n </cds-custom-icon-button>\n </li>\n\n ${\n // render first item if at least 5 items can be displayed or\n // 4 items can be displayed and the current page is either 0 or 1\n this.itemsDisplayedOnPage >= 5 ||\n (this.itemsDisplayedOnPage <= 4 && this.page <= 1)\n ? this._renderPaginationItem(0, this.page === 0)\n : ''\n }\n ${\n /* render first overflow */\n this._renderPaginationOverflow(startOffset, this.cuts.front)\n }\n ${\n // render items between overflows\n Array.from({ length: this.totalItems })\n .map((_, i) => i)\n .slice(startOffset + this.cuts.front, (1 + this.cuts.back) * -1)\n .map((item) =>\n this._renderPaginationItem(item, this.page === item)\n )\n }\n ${\n /* render second overflow */\n this._renderPaginationOverflow(\n this.totalItems - this.cuts.back - 1,\n this.cuts.back\n )\n }\n ${\n // render last item unless there is only one in total\n this.totalItems > 1\n ? this._renderPaginationItem(\n this.totalItems - 1,\n this.page === this.totalItems - 1\n )\n : ''\n }\n <li class=\"${prefix}--pagination-nav__list-item\">\n <cds-custom-icon-button\n kind=\"ghost\"\n align=\"${align}\"\n size=\"${size}\"\n ?disabled=${forwardButtonDisabled}\n @click=${incrementIndex}>\n <span slot=\"tooltip-content\"\n >${this.translateWithId('carbon.pagination-nav.next')}</span\n >\n ${iconLoader(CaretRight16, { slot: 'icon' })}\n </cds-custom-icon-button>\n </li>\n </ul>\n <div\n aria-live=\"polite\"\n aria-atomic=\"true\"\n class=\"${prefix}--pagination-nav__accessibility-label\">\n ${`${t('carbon.pagination-nav.item')} ${\n this.page + 1\n } ${t('carbon.pagination-nav.of')} ${this.totalItems}`}\n </div>\n </nav>\n `;\n }\n\n shouldUpdate(changedProperties) {\n // Prevent setting \"page\" outside bounds of available pages.\n if (changedProperties.has('totalItems') || changedProperties.has('page')) {\n if (this.page > this.totalItems) {\n this.page = this.totalItems - 1;\n }\n if (this.page < 0) {\n this.page = 0;\n }\n }\n\n return true;\n }\n\n updated(changedProperties) {\n if (changedProperties.has('page')) {\n this.prevPage = changedProperties.get('page');\n }\n\n if (\n changedProperties.has('totalItems') ||\n changedProperties.has('itemsShown') ||\n changedProperties.has('size')\n ) {\n let numberOfPages: number;\n\n switch (this.size) {\n case PAGINATION_NAV_SIZE.MEDIUM:\n numberOfPages = this.itemsShown === 4 ? this.itemsShown : 5;\n break;\n\n case PAGINATION_NAV_SIZE.SMALL:\n numberOfPages = Math.min(Math.max(4, this.itemsShown), 7);\n break;\n\n default:\n numberOfPages = 4;\n break;\n }\n\n this.itemsDisplayedOnPage = Math.max(\n this.itemsShown >= 4 ? this.itemsShown : numberOfPages,\n 4\n );\n\n this.cuts = this._calculateCuts(\n this.page,\n this.totalItems,\n this.itemsDisplayedOnPage\n );\n }\n\n if (changedProperties.has('page') && this._pageWouldBeHidden(this.page)) {\n const delta = this.page - (this.prevPage || 0);\n\n if (delta > 0) {\n const splitPoint = this.itemsDisplayedOnPage - 3;\n this.cuts = this._calculateCuts(\n this.page,\n this.totalItems,\n this.itemsDisplayedOnPage,\n splitPoint\n );\n } else {\n const splitPoint = this.itemsDisplayedOnPage > 4 ? 2 : 1;\n this.cuts = this._calculateCuts(\n this.page,\n this.totalItems,\n this.itemsDisplayedOnPage,\n splitPoint\n );\n }\n }\n }\n\n static get eventChange() {\n return `${prefix}-page-changed`;\n }\n\n static styles = styles;\n}\n\nexport default CDSPaginationNav;\n"],"names":["OverflowMenu","customElement"],"mappings":"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"}
|