@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.
Files changed (431) hide show
  1. package/custom-elements.json +963 -145
  2. package/es/components/accordion/accordion-item.d.ts +28 -12
  3. package/es/components/accordion/accordion-item.js +7 -5
  4. package/es/components/accordion/accordion-item.js.map +1 -1
  5. package/es/components/accordion/accordion-skeleton.d.ts +1 -1
  6. package/es/components/accordion/accordion-skeleton.js +7 -5
  7. package/es/components/accordion/accordion-skeleton.js.map +1 -1
  8. package/es/components/accordion/accordion.d.ts +1 -1
  9. package/es/components/accordion/accordion.js +7 -5
  10. package/es/components/accordion/accordion.js.map +1 -1
  11. package/es/components/ai-label/ai-label.d.ts +1 -1
  12. package/es/components/ai-label/ai-label.js +6 -5
  13. package/es/components/ai-label/ai-label.js.map +1 -1
  14. package/es/components/button/button.d.ts +56 -22
  15. package/es/components/checkbox/checkbox-group.d.ts +2 -0
  16. package/es/components/checkbox/checkbox.d.ts +57 -23
  17. package/es/components/checkbox/checkbox.js +7 -5
  18. package/es/components/checkbox/checkbox.js.map +1 -1
  19. package/es/components/code-snippet/code-snippet.d.ts +29 -11
  20. package/es/components/code-snippet/code-snippet.js +15 -14
  21. package/es/components/code-snippet/code-snippet.js.map +1 -1
  22. package/es/components/combo-box/combo-box.scss.js +1 -1
  23. package/es/components/combo-button/combo-button.d.ts +27 -11
  24. package/es/components/content-switcher/content-switcher-item.d.ts +29 -11
  25. package/es/components/copy-button/copy-button.d.ts +27 -11
  26. package/es/components/data-table/table-expanded-row.d.ts +28 -12
  27. package/es/components/data-table/table-expanded-row.js +7 -5
  28. package/es/components/data-table/table-expanded-row.js.map +1 -1
  29. package/es/components/data-table/table-header-cell.d.ts +29 -11
  30. package/es/components/data-table/table-row.d.ts +54 -22
  31. package/es/components/data-table/table-toolbar-search.d.ts +29 -11
  32. package/es/components/data-table/table.d.ts +28 -12
  33. package/es/components/data-table/table.js +9 -8
  34. package/es/components/data-table/table.js.map +1 -1
  35. package/es/components/date-picker/date-picker-input.d.ts +29 -11
  36. package/es/components/date-picker/date-picker.d.ts +54 -22
  37. package/es/components/dropdown/dropdown.d.ts +110 -44
  38. package/es/components/dropdown/dropdown.js +8 -6
  39. package/es/components/dropdown/dropdown.js.map +1 -1
  40. package/es/components/file-uploader/file-uploader-button.d.ts +27 -11
  41. package/es/components/file-uploader/file-uploader-drop-container.d.ts +27 -11
  42. package/es/components/floating-menu/floating-menu.d.ts +56 -22
  43. package/es/components/fluid-select/fluid-select.d.ts +5 -0
  44. package/es/components/fluid-select/fluid-select.js +50 -1
  45. package/es/components/fluid-select/fluid-select.js.map +1 -1
  46. package/es/components/fluid-textarea/fluid-textarea-skeleton.d.ts +3 -3
  47. package/es/components/fluid-textarea/fluid-textarea-skeleton.js +3 -3
  48. package/es/components/fluid-textarea/fluid-textarea-skeleton.js.map +1 -1
  49. package/es/components/fluid-time-picker/fluid-time-picker-select.d.ts +21 -0
  50. package/es/components/fluid-time-picker/fluid-time-picker-select.js +53 -0
  51. package/es/components/fluid-time-picker/fluid-time-picker-select.js.map +1 -0
  52. package/es/components/fluid-time-picker/fluid-time-picker-skeleton.d.ts +23 -0
  53. package/es/components/fluid-time-picker/fluid-time-picker-skeleton.js +63 -0
  54. package/es/components/fluid-time-picker/fluid-time-picker-skeleton.js.map +1 -0
  55. package/es/components/fluid-time-picker/fluid-time-picker.d.ts +32 -0
  56. package/es/components/fluid-time-picker/fluid-time-picker.js +239 -0
  57. package/es/components/fluid-time-picker/fluid-time-picker.js.map +1 -0
  58. package/es/components/fluid-time-picker/fluid-time-picker.scss.js +13 -0
  59. package/es/components/fluid-time-picker/fluid-time-picker.scss.js.map +1 -0
  60. package/es/components/fluid-time-picker/index.d.ts +9 -0
  61. package/es/components/fluid-time-picker/index.js +11 -0
  62. package/es/components/fluid-time-picker/index.js.map +1 -0
  63. package/es/components/grid/column.d.ts +3 -1
  64. package/es/components/grid/column.js +6 -0
  65. package/es/components/grid/column.js.map +1 -1
  66. package/es/components/icon-button/icon-button.d.ts +1 -1
  67. package/es/components/icon-button/icon-button.js +6 -5
  68. package/es/components/icon-button/icon-button.js.map +1 -1
  69. package/es/components/link/link.d.ts +29 -11
  70. package/es/components/menu/menu-item-selectable.d.ts +5 -3
  71. package/es/components/menu/menu-item-selectable.js +3 -3
  72. package/es/components/menu/menu-item-selectable.js.map +1 -1
  73. package/es/components/menu/menu-item.d.ts +68 -23
  74. package/es/components/menu/menu-item.js +37 -2
  75. package/es/components/menu/menu-item.js.map +1 -1
  76. package/es/components/menu/menu.d.ts +27 -11
  77. package/es/components/menu-button/menu-button.d.ts +27 -11
  78. package/es/components/modal/modal-close-button.d.ts +29 -11
  79. package/es/components/modal/modal.d.ts +27 -11
  80. package/es/components/modal/modal.js +6 -4
  81. package/es/components/modal/modal.js.map +1 -1
  82. package/es/components/multi-select/multi-select.js +12 -8
  83. package/es/components/multi-select/multi-select.js.map +1 -1
  84. package/es/components/notification/actionable-notification.d.ts +27 -11
  85. package/es/components/notification/actionable-notification.scss.js +1 -1
  86. package/es/components/notification/inline-notification.d.ts +27 -11
  87. package/es/components/notification/inline-notification.scss.js +1 -1
  88. package/es/components/notification/toast-notification.scss.js +1 -1
  89. package/es/components/number-input/number-input.d.ts +2 -0
  90. package/es/components/overflow-menu/overflow-menu-item.d.ts +29 -11
  91. package/es/components/overflow-menu/overflow-menu.d.ts +54 -22
  92. package/es/components/pagination/pagination.d.ts +56 -22
  93. package/es/components/pagination-nav/defs.d.ts +61 -0
  94. package/es/components/pagination-nav/defs.js +74 -0
  95. package/es/components/pagination-nav/defs.js.map +1 -0
  96. package/es/components/pagination-nav/index.d.ts +7 -0
  97. package/es/components/pagination-nav/index.js +9 -0
  98. package/es/components/pagination-nav/index.js.map +1 -0
  99. package/es/components/pagination-nav/pagination-nav.d.ts +109 -0
  100. package/es/components/pagination-nav/pagination-nav.js +427 -0
  101. package/es/components/pagination-nav/pagination-nav.js.map +1 -0
  102. package/es/components/pagination-nav/pagination-nav.scss.js +13 -0
  103. package/es/components/pagination-nav/pagination-nav.scss.js.map +1 -0
  104. package/es/components/password-input/password-input.d.ts +2 -0
  105. package/es/components/popover/popover.d.ts +27 -11
  106. package/es/components/popover/popover.js +1 -1
  107. package/es/components/popover/popover.js.map +1 -1
  108. package/es/components/progress-indicator/progress-step.d.ts +29 -11
  109. package/es/components/radio-button/radio-button-group.d.ts +54 -22
  110. package/es/components/radio-button/radio-button.d.ts +57 -23
  111. package/es/components/radio-button/radio-button.js +7 -5
  112. package/es/components/radio-button/radio-button.js.map +1 -1
  113. package/es/components/search/search.d.ts +83 -33
  114. package/es/components/select/select.d.ts +29 -11
  115. package/es/components/side-panel/side-panel.d.ts +27 -11
  116. package/es/components/skip-to-content/skip-to-content.d.ts +29 -11
  117. package/es/components/slider/slider-input.d.ts +29 -11
  118. package/es/components/slider/slider.d.ts +84 -34
  119. package/es/components/slider/slider.js +9 -7
  120. package/es/components/slider/slider.js.map +1 -1
  121. package/es/components/slug/slug.d.ts +1 -1
  122. package/es/components/slug/slug.js +6 -4
  123. package/es/components/slug/slug.js.map +1 -1
  124. package/es/components/structured-list/structured-list-row.d.ts +27 -11
  125. package/es/components/structured-list/structured-list.d.ts +30 -12
  126. package/es/components/structured-list/structured-list.js +7 -5
  127. package/es/components/structured-list/structured-list.js.map +1 -1
  128. package/es/components/tabs/tabs.d.ts +27 -11
  129. package/es/components/tag/dismissible-tag.d.ts +54 -22
  130. package/es/components/tag/operational-tag.d.ts +54 -22
  131. package/es/components/tag/selectable-tag.d.ts +54 -22
  132. package/es/components/tag/tag.d.ts +54 -22
  133. package/es/components/tearsheet/tearsheet.d.ts +27 -11
  134. package/es/components/text-input/text-input.d.ts +56 -22
  135. package/es/components/textarea/textarea.d.ts +2 -0
  136. package/es/components/tile/expandable-tile.d.ts +54 -22
  137. package/es/components/tile/selectable-tile.d.ts +56 -22
  138. package/es/components/tile/tile-group.d.ts +27 -11
  139. package/es/components/time-picker/time-picker-select.d.ts +29 -11
  140. package/es/components/time-picker/time-picker.d.ts +56 -22
  141. package/es/components/toggle/toggle.d.ts +27 -11
  142. package/es/components/toggle-tip/toggletip.d.ts +57 -23
  143. package/es/components/toggle-tip/toggletip.js +7 -5
  144. package/es/components/toggle-tip/toggletip.js.map +1 -1
  145. package/es/components/tooltip/tooltip.d.ts +28 -12
  146. package/es/components/tooltip/tooltip.js +7 -5
  147. package/es/components/tooltip/tooltip.js.map +1 -1
  148. package/es/components/tree-view/tree-view.d.ts +28 -12
  149. package/es/components/tree-view/tree-view.js +7 -5
  150. package/es/components/tree-view/tree-view.js.map +1 -1
  151. package/es/components/ui-shell/header-global-action.d.ts +2 -0
  152. package/es/components/ui-shell/header-menu-button.d.ts +29 -11
  153. package/es/components/ui-shell/header-menu.d.ts +56 -22
  154. package/es/components/ui-shell/header-name.d.ts +29 -11
  155. package/es/components/ui-shell/header-nav-item.d.ts +29 -11
  156. package/es/components/ui-shell/header-panel.d.ts +2 -0
  157. package/es/components/ui-shell/side-nav-link.d.ts +29 -11
  158. package/es/components/ui-shell/side-nav-menu-item.d.ts +29 -11
  159. package/es/components/ui-shell/side-nav-menu.d.ts +29 -11
  160. package/es/components/ui-shell/side-nav.d.ts +27 -11
  161. package/es/components/ui-shell/switcher-item.d.ts +29 -11
  162. package/es/components/ui-shell/switcher.d.ts +2 -0
  163. package/es/globals/mixins/focus.d.ts +27 -11
  164. package/es/globals/mixins/form.d.ts +27 -11
  165. package/es/globals/mixins/host-listener.d.ts +27 -11
  166. package/es/globals/mixins/validity.d.ts +27 -11
  167. package/es-custom/components/accordion/accordion-item.d.ts +28 -12
  168. package/es-custom/components/accordion/accordion-item.js +7 -5
  169. package/es-custom/components/accordion/accordion-item.js.map +1 -1
  170. package/es-custom/components/accordion/accordion-skeleton.d.ts +1 -1
  171. package/es-custom/components/accordion/accordion-skeleton.js +7 -5
  172. package/es-custom/components/accordion/accordion-skeleton.js.map +1 -1
  173. package/es-custom/components/accordion/accordion.d.ts +1 -1
  174. package/es-custom/components/accordion/accordion.js +7 -5
  175. package/es-custom/components/accordion/accordion.js.map +1 -1
  176. package/es-custom/components/ai-label/ai-label.d.ts +1 -1
  177. package/es-custom/components/ai-label/ai-label.js +6 -5
  178. package/es-custom/components/ai-label/ai-label.js.map +1 -1
  179. package/es-custom/components/button/button.d.ts +56 -22
  180. package/es-custom/components/checkbox/checkbox-group.d.ts +2 -0
  181. package/es-custom/components/checkbox/checkbox.d.ts +57 -23
  182. package/es-custom/components/checkbox/checkbox.js +7 -5
  183. package/es-custom/components/checkbox/checkbox.js.map +1 -1
  184. package/es-custom/components/code-snippet/code-snippet.d.ts +29 -11
  185. package/es-custom/components/code-snippet/code-snippet.js +15 -14
  186. package/es-custom/components/code-snippet/code-snippet.js.map +1 -1
  187. package/es-custom/components/combo-box/combo-box.scss.js +1 -1
  188. package/es-custom/components/combo-button/combo-button.d.ts +27 -11
  189. package/es-custom/components/content-switcher/content-switcher-item.d.ts +29 -11
  190. package/es-custom/components/copy-button/copy-button.d.ts +27 -11
  191. package/es-custom/components/data-table/table-expanded-row.d.ts +28 -12
  192. package/es-custom/components/data-table/table-expanded-row.js +7 -5
  193. package/es-custom/components/data-table/table-expanded-row.js.map +1 -1
  194. package/es-custom/components/data-table/table-header-cell.d.ts +29 -11
  195. package/es-custom/components/data-table/table-row.d.ts +54 -22
  196. package/es-custom/components/data-table/table-toolbar-search.d.ts +29 -11
  197. package/es-custom/components/data-table/table.d.ts +28 -12
  198. package/es-custom/components/data-table/table.js +9 -8
  199. package/es-custom/components/data-table/table.js.map +1 -1
  200. package/es-custom/components/date-picker/date-picker-input.d.ts +29 -11
  201. package/es-custom/components/date-picker/date-picker.d.ts +54 -22
  202. package/es-custom/components/dropdown/dropdown.d.ts +110 -44
  203. package/es-custom/components/dropdown/dropdown.js +8 -6
  204. package/es-custom/components/dropdown/dropdown.js.map +1 -1
  205. package/es-custom/components/file-uploader/file-uploader-button.d.ts +27 -11
  206. package/es-custom/components/file-uploader/file-uploader-drop-container.d.ts +27 -11
  207. package/es-custom/components/floating-menu/floating-menu.d.ts +56 -22
  208. package/es-custom/components/fluid-select/fluid-select.d.ts +5 -0
  209. package/es-custom/components/fluid-select/fluid-select.js +50 -1
  210. package/es-custom/components/fluid-select/fluid-select.js.map +1 -1
  211. package/es-custom/components/fluid-textarea/fluid-textarea-skeleton.d.ts +3 -3
  212. package/es-custom/components/fluid-textarea/fluid-textarea-skeleton.js +3 -3
  213. package/es-custom/components/fluid-textarea/fluid-textarea-skeleton.js.map +1 -1
  214. package/es-custom/components/fluid-time-picker/fluid-time-picker-select.d.ts +21 -0
  215. package/es-custom/components/fluid-time-picker/fluid-time-picker-select.js +53 -0
  216. package/es-custom/components/fluid-time-picker/fluid-time-picker-select.js.map +1 -0
  217. package/es-custom/components/fluid-time-picker/fluid-time-picker-skeleton.d.ts +23 -0
  218. package/es-custom/components/fluid-time-picker/fluid-time-picker-skeleton.js +63 -0
  219. package/es-custom/components/fluid-time-picker/fluid-time-picker-skeleton.js.map +1 -0
  220. package/es-custom/components/fluid-time-picker/fluid-time-picker.d.ts +32 -0
  221. package/es-custom/components/fluid-time-picker/fluid-time-picker.js +239 -0
  222. package/es-custom/components/fluid-time-picker/fluid-time-picker.js.map +1 -0
  223. package/es-custom/components/fluid-time-picker/fluid-time-picker.scss.js +13 -0
  224. package/es-custom/components/fluid-time-picker/fluid-time-picker.scss.js.map +1 -0
  225. package/es-custom/components/fluid-time-picker/index.d.ts +9 -0
  226. package/es-custom/components/fluid-time-picker/index.js +11 -0
  227. package/es-custom/components/fluid-time-picker/index.js.map +1 -0
  228. package/es-custom/components/grid/column.d.ts +3 -1
  229. package/es-custom/components/grid/column.js +6 -0
  230. package/es-custom/components/grid/column.js.map +1 -1
  231. package/es-custom/components/icon-button/icon-button.d.ts +1 -1
  232. package/es-custom/components/icon-button/icon-button.js +6 -5
  233. package/es-custom/components/icon-button/icon-button.js.map +1 -1
  234. package/es-custom/components/link/link.d.ts +29 -11
  235. package/es-custom/components/menu/menu-item-selectable.d.ts +5 -3
  236. package/es-custom/components/menu/menu-item-selectable.js +3 -3
  237. package/es-custom/components/menu/menu-item-selectable.js.map +1 -1
  238. package/es-custom/components/menu/menu-item.d.ts +68 -23
  239. package/es-custom/components/menu/menu-item.js +37 -2
  240. package/es-custom/components/menu/menu-item.js.map +1 -1
  241. package/es-custom/components/menu/menu.d.ts +27 -11
  242. package/es-custom/components/menu-button/menu-button.d.ts +27 -11
  243. package/es-custom/components/modal/modal-close-button.d.ts +29 -11
  244. package/es-custom/components/modal/modal.d.ts +27 -11
  245. package/es-custom/components/modal/modal.js +6 -4
  246. package/es-custom/components/modal/modal.js.map +1 -1
  247. package/es-custom/components/multi-select/multi-select.js +12 -8
  248. package/es-custom/components/multi-select/multi-select.js.map +1 -1
  249. package/es-custom/components/notification/actionable-notification.d.ts +27 -11
  250. package/es-custom/components/notification/actionable-notification.scss.js +1 -1
  251. package/es-custom/components/notification/inline-notification.d.ts +27 -11
  252. package/es-custom/components/notification/inline-notification.scss.js +1 -1
  253. package/es-custom/components/notification/toast-notification.scss.js +1 -1
  254. package/es-custom/components/number-input/number-input.d.ts +2 -0
  255. package/es-custom/components/overflow-menu/overflow-menu-item.d.ts +29 -11
  256. package/es-custom/components/overflow-menu/overflow-menu.d.ts +54 -22
  257. package/es-custom/components/pagination/pagination.d.ts +56 -22
  258. package/es-custom/components/pagination-nav/defs.d.ts +61 -0
  259. package/es-custom/components/pagination-nav/defs.js +74 -0
  260. package/es-custom/components/pagination-nav/defs.js.map +1 -0
  261. package/es-custom/components/pagination-nav/index.d.ts +7 -0
  262. package/es-custom/components/pagination-nav/index.js +9 -0
  263. package/es-custom/components/pagination-nav/index.js.map +1 -0
  264. package/es-custom/components/pagination-nav/pagination-nav.d.ts +109 -0
  265. package/es-custom/components/pagination-nav/pagination-nav.js +427 -0
  266. package/es-custom/components/pagination-nav/pagination-nav.js.map +1 -0
  267. package/es-custom/components/pagination-nav/pagination-nav.scss.js +13 -0
  268. package/es-custom/components/pagination-nav/pagination-nav.scss.js.map +1 -0
  269. package/es-custom/components/password-input/password-input.d.ts +2 -0
  270. package/es-custom/components/popover/popover.d.ts +27 -11
  271. package/es-custom/components/popover/popover.js +1 -1
  272. package/es-custom/components/popover/popover.js.map +1 -1
  273. package/es-custom/components/progress-indicator/progress-step.d.ts +29 -11
  274. package/es-custom/components/radio-button/radio-button-group.d.ts +54 -22
  275. package/es-custom/components/radio-button/radio-button.d.ts +57 -23
  276. package/es-custom/components/radio-button/radio-button.js +7 -5
  277. package/es-custom/components/radio-button/radio-button.js.map +1 -1
  278. package/es-custom/components/search/search.d.ts +83 -33
  279. package/es-custom/components/select/select.d.ts +29 -11
  280. package/es-custom/components/side-panel/side-panel.d.ts +27 -11
  281. package/es-custom/components/skip-to-content/skip-to-content.d.ts +29 -11
  282. package/es-custom/components/slider/slider-input.d.ts +29 -11
  283. package/es-custom/components/slider/slider.d.ts +84 -34
  284. package/es-custom/components/slider/slider.js +9 -7
  285. package/es-custom/components/slider/slider.js.map +1 -1
  286. package/es-custom/components/slug/slug.d.ts +1 -1
  287. package/es-custom/components/slug/slug.js +6 -4
  288. package/es-custom/components/slug/slug.js.map +1 -1
  289. package/es-custom/components/structured-list/structured-list-row.d.ts +27 -11
  290. package/es-custom/components/structured-list/structured-list.d.ts +30 -12
  291. package/es-custom/components/structured-list/structured-list.js +7 -5
  292. package/es-custom/components/structured-list/structured-list.js.map +1 -1
  293. package/es-custom/components/tabs/tabs.d.ts +27 -11
  294. package/es-custom/components/tag/dismissible-tag.d.ts +54 -22
  295. package/es-custom/components/tag/operational-tag.d.ts +54 -22
  296. package/es-custom/components/tag/selectable-tag.d.ts +54 -22
  297. package/es-custom/components/tag/tag.d.ts +54 -22
  298. package/es-custom/components/tearsheet/tearsheet.d.ts +27 -11
  299. package/es-custom/components/text-input/text-input.d.ts +56 -22
  300. package/es-custom/components/textarea/textarea.d.ts +2 -0
  301. package/es-custom/components/tile/expandable-tile.d.ts +54 -22
  302. package/es-custom/components/tile/selectable-tile.d.ts +56 -22
  303. package/es-custom/components/tile/tile-group.d.ts +27 -11
  304. package/es-custom/components/time-picker/time-picker-select.d.ts +29 -11
  305. package/es-custom/components/time-picker/time-picker.d.ts +56 -22
  306. package/es-custom/components/toggle/toggle.d.ts +27 -11
  307. package/es-custom/components/toggle-tip/toggletip.d.ts +57 -23
  308. package/es-custom/components/toggle-tip/toggletip.js +7 -5
  309. package/es-custom/components/toggle-tip/toggletip.js.map +1 -1
  310. package/es-custom/components/tooltip/tooltip.d.ts +28 -12
  311. package/es-custom/components/tooltip/tooltip.js +7 -5
  312. package/es-custom/components/tooltip/tooltip.js.map +1 -1
  313. package/es-custom/components/tree-view/tree-view.d.ts +28 -12
  314. package/es-custom/components/tree-view/tree-view.js +7 -5
  315. package/es-custom/components/tree-view/tree-view.js.map +1 -1
  316. package/es-custom/components/ui-shell/header-global-action.d.ts +2 -0
  317. package/es-custom/components/ui-shell/header-menu-button.d.ts +29 -11
  318. package/es-custom/components/ui-shell/header-menu.d.ts +56 -22
  319. package/es-custom/components/ui-shell/header-name.d.ts +29 -11
  320. package/es-custom/components/ui-shell/header-nav-item.d.ts +29 -11
  321. package/es-custom/components/ui-shell/header-panel.d.ts +2 -0
  322. package/es-custom/components/ui-shell/side-nav-link.d.ts +29 -11
  323. package/es-custom/components/ui-shell/side-nav-menu-item.d.ts +29 -11
  324. package/es-custom/components/ui-shell/side-nav-menu.d.ts +29 -11
  325. package/es-custom/components/ui-shell/side-nav.d.ts +27 -11
  326. package/es-custom/components/ui-shell/switcher-item.d.ts +29 -11
  327. package/es-custom/components/ui-shell/switcher.d.ts +2 -0
  328. package/es-custom/globals/mixins/focus.d.ts +27 -11
  329. package/es-custom/globals/mixins/form.d.ts +27 -11
  330. package/es-custom/globals/mixins/host-listener.d.ts +27 -11
  331. package/es-custom/globals/mixins/validity.d.ts +27 -11
  332. package/lib/components/accordion/accordion-item.d.ts +28 -12
  333. package/lib/components/accordion/accordion-skeleton.d.ts +1 -1
  334. package/lib/components/accordion/accordion.d.ts +1 -1
  335. package/lib/components/ai-label/ai-label.d.ts +1 -1
  336. package/lib/components/button/button.d.ts +56 -22
  337. package/lib/components/checkbox/checkbox-group.d.ts +2 -0
  338. package/lib/components/checkbox/checkbox.d.ts +57 -23
  339. package/lib/components/code-snippet/code-snippet.d.ts +29 -11
  340. package/lib/components/combo-button/combo-button.d.ts +27 -11
  341. package/lib/components/content-switcher/content-switcher-item.d.ts +29 -11
  342. package/lib/components/copy-button/copy-button.d.ts +27 -11
  343. package/lib/components/data-table/table-expanded-row.d.ts +28 -12
  344. package/lib/components/data-table/table-header-cell.d.ts +29 -11
  345. package/lib/components/data-table/table-row.d.ts +54 -22
  346. package/lib/components/data-table/table-toolbar-search.d.ts +29 -11
  347. package/lib/components/data-table/table.d.ts +28 -12
  348. package/lib/components/date-picker/date-picker-input.d.ts +29 -11
  349. package/lib/components/date-picker/date-picker.d.ts +54 -22
  350. package/lib/components/dropdown/dropdown.d.ts +110 -44
  351. package/lib/components/file-uploader/file-uploader-button.d.ts +27 -11
  352. package/lib/components/file-uploader/file-uploader-drop-container.d.ts +27 -11
  353. package/lib/components/floating-menu/floating-menu.d.ts +56 -22
  354. package/lib/components/fluid-select/fluid-select.d.ts +5 -0
  355. package/lib/components/fluid-textarea/fluid-textarea-skeleton.d.ts +3 -3
  356. package/lib/components/fluid-time-picker/fluid-time-picker-select.d.ts +21 -0
  357. package/lib/components/fluid-time-picker/fluid-time-picker-skeleton.d.ts +23 -0
  358. package/lib/components/fluid-time-picker/fluid-time-picker.d.ts +32 -0
  359. package/lib/components/fluid-time-picker/index.d.ts +9 -0
  360. package/lib/components/grid/column.d.ts +3 -1
  361. package/lib/components/icon-button/icon-button.d.ts +1 -1
  362. package/lib/components/link/link.d.ts +29 -11
  363. package/lib/components/menu/menu-item-selectable.d.ts +5 -3
  364. package/lib/components/menu/menu-item.d.ts +68 -23
  365. package/lib/components/menu/menu.d.ts +27 -11
  366. package/lib/components/menu-button/menu-button.d.ts +27 -11
  367. package/lib/components/modal/modal-close-button.d.ts +29 -11
  368. package/lib/components/modal/modal.d.ts +27 -11
  369. package/lib/components/notification/actionable-notification.d.ts +27 -11
  370. package/lib/components/notification/inline-notification.d.ts +27 -11
  371. package/lib/components/number-input/number-input.d.ts +2 -0
  372. package/lib/components/overflow-menu/overflow-menu-item.d.ts +29 -11
  373. package/lib/components/overflow-menu/overflow-menu.d.ts +54 -22
  374. package/lib/components/pagination/pagination.d.ts +56 -22
  375. package/lib/components/pagination-nav/defs.d.ts +61 -0
  376. package/lib/components/pagination-nav/defs.js +74 -0
  377. package/lib/components/pagination-nav/defs.js.map +1 -0
  378. package/lib/components/pagination-nav/index.d.ts +7 -0
  379. package/lib/components/pagination-nav/pagination-nav.d.ts +109 -0
  380. package/lib/components/password-input/password-input.d.ts +2 -0
  381. package/lib/components/popover/popover.d.ts +27 -11
  382. package/lib/components/progress-indicator/progress-step.d.ts +29 -11
  383. package/lib/components/radio-button/radio-button-group.d.ts +54 -22
  384. package/lib/components/radio-button/radio-button.d.ts +57 -23
  385. package/lib/components/search/search.d.ts +83 -33
  386. package/lib/components/select/select.d.ts +29 -11
  387. package/lib/components/side-panel/side-panel.d.ts +27 -11
  388. package/lib/components/skip-to-content/skip-to-content.d.ts +29 -11
  389. package/lib/components/slider/slider-input.d.ts +29 -11
  390. package/lib/components/slider/slider.d.ts +84 -34
  391. package/lib/components/slug/slug.d.ts +1 -1
  392. package/lib/components/structured-list/structured-list-row.d.ts +27 -11
  393. package/lib/components/structured-list/structured-list.d.ts +30 -12
  394. package/lib/components/tabs/tabs.d.ts +27 -11
  395. package/lib/components/tag/dismissible-tag.d.ts +54 -22
  396. package/lib/components/tag/operational-tag.d.ts +54 -22
  397. package/lib/components/tag/selectable-tag.d.ts +54 -22
  398. package/lib/components/tag/tag.d.ts +54 -22
  399. package/lib/components/tearsheet/tearsheet.d.ts +27 -11
  400. package/lib/components/text-input/text-input.d.ts +56 -22
  401. package/lib/components/textarea/textarea.d.ts +2 -0
  402. package/lib/components/tile/expandable-tile.d.ts +54 -22
  403. package/lib/components/tile/selectable-tile.d.ts +56 -22
  404. package/lib/components/tile/tile-group.d.ts +27 -11
  405. package/lib/components/time-picker/time-picker-select.d.ts +29 -11
  406. package/lib/components/time-picker/time-picker.d.ts +56 -22
  407. package/lib/components/toggle/toggle.d.ts +27 -11
  408. package/lib/components/toggle-tip/toggletip.d.ts +57 -23
  409. package/lib/components/tooltip/tooltip.d.ts +28 -12
  410. package/lib/components/tree-view/tree-view.d.ts +28 -12
  411. package/lib/components/ui-shell/header-global-action.d.ts +2 -0
  412. package/lib/components/ui-shell/header-menu-button.d.ts +29 -11
  413. package/lib/components/ui-shell/header-menu.d.ts +56 -22
  414. package/lib/components/ui-shell/header-name.d.ts +29 -11
  415. package/lib/components/ui-shell/header-nav-item.d.ts +29 -11
  416. package/lib/components/ui-shell/header-panel.d.ts +2 -0
  417. package/lib/components/ui-shell/side-nav-link.d.ts +29 -11
  418. package/lib/components/ui-shell/side-nav-menu-item.d.ts +29 -11
  419. package/lib/components/ui-shell/side-nav-menu.d.ts +29 -11
  420. package/lib/components/ui-shell/side-nav.d.ts +27 -11
  421. package/lib/components/ui-shell/switcher-item.d.ts +29 -11
  422. package/lib/components/ui-shell/switcher.d.ts +2 -0
  423. package/lib/globals/mixins/focus.d.ts +27 -11
  424. package/lib/globals/mixins/form.d.ts +27 -11
  425. package/lib/globals/mixins/host-listener.d.ts +27 -11
  426. package/lib/globals/mixins/validity.d.ts +27 -11
  427. package/package.json +7 -7
  428. package/scss/components/combo-box/combo-box.scss +1 -1
  429. package/scss/components/fluid-time-picker/fluid-time-picker.scss +198 -0
  430. package/scss/components/pagination-nav/pagination-nav.scss +29 -0
  431. 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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"}