@ukic/canary-web-components 2.0.0-canary.14 → 2.0.0-canary.16

Sign up to get free protection for your applications and to get access to all the features.
Files changed (516) hide show
  1. package/dist/cjs/core.cjs.js +1 -1
  2. package/dist/cjs/{helpers-6d736902.js → helpers-4f5f087e.js} +59 -99
  3. package/dist/cjs/helpers-4f5f087e.js.map +1 -0
  4. package/dist/cjs/{helpers-f75cf7cf.js → helpers-fc9441f8.js} +34 -1
  5. package/dist/cjs/helpers-fc9441f8.js.map +1 -0
  6. package/dist/cjs/ic-accordion-group.cjs.entry.js +3 -1
  7. package/dist/cjs/ic-accordion-group.cjs.entry.js.map +1 -1
  8. package/dist/cjs/ic-accordion.cjs.entry.js +1 -1
  9. package/dist/cjs/ic-alert.cjs.entry.js +1 -1
  10. package/dist/cjs/ic-back-to-top.cjs.entry.js +15 -9
  11. package/dist/cjs/ic-back-to-top.cjs.entry.js.map +1 -1
  12. package/dist/cjs/ic-badge.cjs.entry.js +55 -77
  13. package/dist/cjs/ic-badge.cjs.entry.js.map +1 -1
  14. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js +3 -1
  15. package/dist/cjs/ic-breadcrumb-group.cjs.entry.js.map +1 -1
  16. package/dist/cjs/ic-breadcrumb.cjs.entry.js +1 -1
  17. package/dist/cjs/ic-button_3.cjs.entry.js +14 -14
  18. package/dist/cjs/ic-button_3.cjs.entry.js.map +1 -1
  19. package/dist/cjs/ic-card.cjs.entry.js +1 -1
  20. package/dist/cjs/ic-card.cjs.entry.js.map +1 -1
  21. package/dist/cjs/ic-checkbox-group.cjs.entry.js +23 -16
  22. package/dist/cjs/ic-checkbox-group.cjs.entry.js.map +1 -1
  23. package/dist/cjs/ic-checkbox.cjs.entry.js +33 -31
  24. package/dist/cjs/ic-checkbox.cjs.entry.js.map +1 -1
  25. package/dist/cjs/ic-chip.cjs.entry.js +21 -31
  26. package/dist/cjs/ic-chip.cjs.entry.js.map +1 -1
  27. package/dist/cjs/ic-data-row.cjs.entry.js +1 -1
  28. package/dist/cjs/ic-data-table-title-bar.cjs.entry.js +57 -0
  29. package/dist/cjs/ic-data-table-title-bar.cjs.entry.js.map +1 -0
  30. package/dist/cjs/ic-data-table.cjs.entry.js +163 -36
  31. package/dist/cjs/ic-data-table.cjs.entry.js.map +1 -1
  32. package/dist/cjs/ic-date-input.cjs.entry.js +1 -1
  33. package/dist/cjs/ic-date-picker.cjs.entry.js +1 -1
  34. package/dist/cjs/ic-dialog.cjs.entry.js +4 -2
  35. package/dist/cjs/ic-dialog.cjs.entry.js.map +1 -1
  36. package/dist/cjs/ic-divider.cjs.entry.js +1 -1
  37. package/dist/cjs/ic-empty-state_2.cjs.entry.js +345 -0
  38. package/dist/cjs/ic-empty-state_2.cjs.entry.js.map +1 -0
  39. package/dist/cjs/ic-footer-link-group.cjs.entry.js +2 -2
  40. package/dist/cjs/ic-footer-link-group.cjs.entry.js.map +1 -1
  41. package/dist/cjs/ic-footer-link.cjs.entry.js +1 -1
  42. package/dist/cjs/ic-footer.cjs.entry.js +2 -2
  43. package/dist/cjs/ic-footer.cjs.entry.js.map +1 -1
  44. package/dist/cjs/ic-hero.cjs.entry.js +3 -2
  45. package/dist/cjs/ic-hero.cjs.entry.js.map +1 -1
  46. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js +2 -3
  47. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js.map +1 -1
  48. package/dist/cjs/ic-input-component-container_4.cjs.entry.js +2 -2
  49. package/dist/cjs/ic-input-component-container_4.cjs.entry.js.map +1 -1
  50. package/dist/cjs/ic-link.cjs.entry.js +2 -2
  51. package/dist/cjs/ic-link.cjs.entry.js.map +1 -1
  52. package/dist/cjs/ic-menu-group.cjs.entry.js +1 -1
  53. package/dist/cjs/ic-menu-item.cjs.entry.js +4 -10
  54. package/dist/cjs/ic-menu-item.cjs.entry.js.map +1 -1
  55. package/dist/cjs/ic-menu-with-multi.cjs.entry.js +176 -35
  56. package/dist/cjs/ic-menu-with-multi.cjs.entry.js.map +1 -1
  57. package/dist/cjs/ic-menu.cjs.entry.js +4 -4
  58. package/dist/cjs/ic-menu.cjs.entry.js.map +1 -1
  59. package/dist/cjs/ic-navigation-button.cjs.entry.js +1 -1
  60. package/dist/cjs/ic-navigation-group.cjs.entry.js +1 -1
  61. package/dist/cjs/ic-navigation-item.cjs.entry.js +2 -2
  62. package/dist/cjs/ic-navigation-item.cjs.entry.js.map +1 -1
  63. package/dist/cjs/ic-navigation-menu.cjs.entry.js +1 -1
  64. package/dist/cjs/ic-page-header.cjs.entry.js +1 -1
  65. package/dist/cjs/ic-pagination_4.cjs.entry.js +54 -29
  66. package/dist/cjs/ic-pagination_4.cjs.entry.js.map +1 -1
  67. package/dist/cjs/ic-popover-menu.cjs.entry.js +13 -18
  68. package/dist/cjs/ic-popover-menu.cjs.entry.js.map +1 -1
  69. package/dist/cjs/ic-radio-group.cjs.entry.js +12 -16
  70. package/dist/cjs/ic-radio-group.cjs.entry.js.map +1 -1
  71. package/dist/cjs/ic-radio-option.cjs.entry.js +37 -37
  72. package/dist/cjs/ic-radio-option.cjs.entry.js.map +1 -1
  73. package/dist/cjs/ic-search-bar.cjs.entry.js +1 -1
  74. package/dist/cjs/ic-select-with-multi.cjs.entry.js +1 -1
  75. package/dist/cjs/ic-side-navigation.cjs.entry.js +1 -1
  76. package/dist/cjs/ic-skeleton.cjs.entry.js +16 -35
  77. package/dist/cjs/ic-skeleton.cjs.entry.js.map +1 -1
  78. package/dist/cjs/ic-status-tag.cjs.entry.js +1 -1
  79. package/dist/cjs/ic-status-tag.cjs.entry.js.map +1 -1
  80. package/dist/cjs/ic-step.cjs.entry.js +1 -1
  81. package/dist/cjs/ic-stepper.cjs.entry.js +1 -1
  82. package/dist/cjs/ic-switch.cjs.entry.js +2 -2
  83. package/dist/cjs/ic-switch.cjs.entry.js.map +1 -1
  84. package/dist/cjs/ic-tab-group.cjs.entry.js +1 -1
  85. package/dist/cjs/ic-tab-panel.cjs.entry.js +1 -1
  86. package/dist/cjs/ic-tab.cjs.entry.js +2 -2
  87. package/dist/cjs/ic-tab.cjs.entry.js.map +1 -1
  88. package/dist/cjs/ic-theme.cjs.entry.js +13 -15
  89. package/dist/cjs/ic-theme.cjs.entry.js.map +1 -1
  90. package/dist/cjs/ic-toast.cjs.entry.js +1 -1
  91. package/dist/cjs/ic-toggle-button.cjs.entry.js +2 -2
  92. package/dist/cjs/ic-toggle-button.cjs.entry.js.map +1 -1
  93. package/dist/cjs/ic-top-navigation.cjs.entry.js +15 -24
  94. package/dist/cjs/ic-top-navigation.cjs.entry.js.map +1 -1
  95. package/dist/cjs/ic-typography.cjs.entry.js +2 -2
  96. package/dist/cjs/ic-typography.cjs.entry.js.map +1 -1
  97. package/dist/cjs/index-4cf27b16.js +8 -8
  98. package/dist/cjs/loader.cjs.js +1 -1
  99. package/dist/collection/collection-manifest.json +1 -0
  100. package/dist/collection/components/ic-data-table/ic-data-table.css +76 -1
  101. package/dist/collection/components/ic-data-table/ic-data-table.js +372 -53
  102. package/dist/collection/components/ic-data-table/ic-data-table.js.map +1 -1
  103. package/dist/collection/components/ic-data-table/ic-data-table.types.js.map +1 -1
  104. package/dist/collection/components/ic-data-table/story-data.js +262 -4
  105. package/dist/collection/components/ic-data-table/story-data.js.map +1 -1
  106. package/dist/collection/components/ic-data-table/test/basic/ic-data-table.spec.js +324 -3
  107. package/dist/collection/components/ic-data-table/test/basic/ic-data-table.spec.js.map +1 -1
  108. package/dist/collection/components/ic-data-table-title-bar/ic-data-table-title-bar.css +91 -0
  109. package/dist/collection/components/ic-data-table-title-bar/ic-data-table-title-bar.js +160 -0
  110. package/dist/collection/components/ic-data-table-title-bar/ic-data-table-title-bar.js.map +1 -0
  111. package/dist/collection/components/ic-data-table-title-bar/test/a11y/ic-data-table-title-bar.test.a11y.js +11 -0
  112. package/dist/collection/components/ic-data-table-title-bar/test/a11y/ic-data-table-title-bar.test.a11y.js.map +1 -0
  113. package/dist/collection/components/ic-data-table-title-bar/test/basic/ic-data-table-title-bar.spec.js +70 -0
  114. package/dist/collection/components/ic-data-table-title-bar/test/basic/ic-data-table-title-bar.spec.js.map +1 -0
  115. package/dist/collection/components/ic-menu-with-multi/ic-menu.js +176 -35
  116. package/dist/collection/components/ic-menu-with-multi/ic-menu.js.map +1 -1
  117. package/dist/collection/components/ic-menu-with-multi/test/basic/ic-menu.spec.js +226 -49
  118. package/dist/collection/components/ic-menu-with-multi/test/basic/ic-menu.spec.js.map +1 -1
  119. package/dist/collection/components/ic-pagination-bar/ic-pagination-bar.js +180 -119
  120. package/dist/collection/components/ic-pagination-bar/ic-pagination-bar.js.map +1 -1
  121. package/dist/collection/components/ic-pagination-bar/test/basic/ic-pagination-bar.spec.js +56 -11
  122. package/dist/collection/components/ic-pagination-bar/test/basic/ic-pagination-bar.spec.js.map +1 -1
  123. package/dist/collection/utils/helpers.js +4 -1
  124. package/dist/collection/utils/helpers.js.map +1 -1
  125. package/dist/collection/utils/types.js.map +1 -1
  126. package/dist/components/helpers.js +57 -97
  127. package/dist/components/helpers.js.map +1 -1
  128. package/dist/components/helpers2.js +31 -1
  129. package/dist/components/helpers2.js.map +1 -1
  130. package/dist/components/ic-accordion-group.js +2 -1
  131. package/dist/components/ic-accordion-group.js.map +1 -1
  132. package/dist/components/ic-back-to-top.js +22 -9
  133. package/dist/components/ic-back-to-top.js.map +1 -1
  134. package/dist/components/ic-badge.js +59 -77
  135. package/dist/components/ic-badge.js.map +1 -1
  136. package/dist/components/ic-breadcrumb-group.js +2 -0
  137. package/dist/components/ic-breadcrumb-group.js.map +1 -1
  138. package/dist/components/ic-button2.js +11 -11
  139. package/dist/components/ic-button2.js.map +1 -1
  140. package/dist/components/ic-card.js.map +1 -1
  141. package/dist/components/ic-checkbox-group.js +26 -16
  142. package/dist/components/ic-checkbox-group.js.map +1 -1
  143. package/dist/components/ic-checkbox.js +33 -31
  144. package/dist/components/ic-checkbox.js.map +1 -1
  145. package/dist/components/ic-chip.js +21 -31
  146. package/dist/components/ic-chip.js.map +1 -1
  147. package/dist/components/ic-data-table-title-bar.d.ts +11 -0
  148. package/dist/components/ic-data-table-title-bar.js +136 -0
  149. package/dist/components/ic-data-table-title-bar.js.map +1 -0
  150. package/dist/components/ic-data-table.js +189 -43
  151. package/dist/components/ic-data-table.js.map +1 -1
  152. package/dist/components/ic-date-input2.js +1 -1
  153. package/dist/components/ic-date-picker.js +1 -1
  154. package/dist/components/ic-dialog.js +4 -2
  155. package/dist/components/ic-dialog.js.map +1 -1
  156. package/dist/components/ic-divider2.js +1 -1
  157. package/dist/components/ic-empty-state.js +1 -57
  158. package/dist/components/ic-empty-state.js.map +1 -1
  159. package/dist/{esm/ic-empty-state.entry.js → components/ic-empty-state2.js} +38 -11
  160. package/dist/components/ic-empty-state2.js.map +1 -0
  161. package/dist/components/ic-footer-link-group.js +2 -2
  162. package/dist/components/ic-footer-link-group.js.map +1 -1
  163. package/dist/components/ic-footer-link.js +1 -1
  164. package/dist/components/ic-footer.js +2 -2
  165. package/dist/components/ic-footer.js.map +1 -1
  166. package/dist/components/ic-hero.js +3 -2
  167. package/dist/components/ic-hero.js.map +1 -1
  168. package/dist/components/ic-horizontal-scroll2.js +1 -2
  169. package/dist/components/ic-horizontal-scroll2.js.map +1 -1
  170. package/dist/components/ic-input-component-container2.js +2 -2
  171. package/dist/components/ic-input-component-container2.js.map +1 -1
  172. package/dist/components/ic-link2.js +1 -1
  173. package/dist/components/ic-link2.js.map +1 -1
  174. package/dist/components/ic-loading-indicator2.js +1 -1
  175. package/dist/components/ic-loading-indicator2.js.map +1 -1
  176. package/dist/components/ic-menu-item2.js +4 -10
  177. package/dist/components/ic-menu-item2.js.map +1 -1
  178. package/dist/components/ic-menu2.js +3 -3
  179. package/dist/components/ic-menu2.js.map +1 -1
  180. package/dist/components/ic-menu3.js +177 -36
  181. package/dist/components/ic-menu3.js.map +1 -1
  182. package/dist/components/ic-navigation-button.js +1 -1
  183. package/dist/components/ic-navigation-group.js +1 -1
  184. package/dist/components/ic-navigation-item.js +2 -2
  185. package/dist/components/ic-navigation-item.js.map +1 -1
  186. package/dist/components/ic-pagination-bar2.js +160 -103
  187. package/dist/components/ic-pagination-bar2.js.map +1 -1
  188. package/dist/components/ic-pagination-item2.js +22 -12
  189. package/dist/components/ic-pagination-item2.js.map +1 -1
  190. package/dist/components/ic-pagination2.js +23 -8
  191. package/dist/components/ic-pagination2.js.map +1 -1
  192. package/dist/components/ic-popover-menu.js +12 -17
  193. package/dist/components/ic-popover-menu.js.map +1 -1
  194. package/dist/components/ic-radio-group.js +11 -15
  195. package/dist/components/ic-radio-group.js.map +1 -1
  196. package/dist/components/ic-radio-option.js +37 -37
  197. package/dist/components/ic-radio-option.js.map +1 -1
  198. package/dist/components/ic-search-bar.js +1 -1
  199. package/dist/components/ic-select-with-multi.js +1 -1
  200. package/dist/components/ic-select2.js +10 -6
  201. package/dist/components/ic-select2.js.map +1 -1
  202. package/dist/components/ic-side-navigation.js +1 -1
  203. package/dist/components/ic-skeleton.js +17 -40
  204. package/dist/components/ic-skeleton.js.map +1 -1
  205. package/dist/components/ic-status-tag.js.map +1 -1
  206. package/dist/components/ic-switch.js +1 -1
  207. package/dist/components/ic-switch.js.map +1 -1
  208. package/dist/components/ic-tab.js +1 -1
  209. package/dist/components/ic-tab.js.map +1 -1
  210. package/dist/components/ic-text-field2.js +8 -8
  211. package/dist/components/ic-text-field2.js.map +1 -1
  212. package/dist/components/ic-theme.js +13 -15
  213. package/dist/components/ic-theme.js.map +1 -1
  214. package/dist/components/ic-toggle-button.js +1 -1
  215. package/dist/components/ic-toggle-button.js.map +1 -1
  216. package/dist/components/ic-tooltip2.js +1 -1
  217. package/dist/components/ic-tooltip2.js.map +1 -1
  218. package/dist/components/ic-top-navigation.js +15 -24
  219. package/dist/components/ic-top-navigation.js.map +1 -1
  220. package/dist/components/ic-typography2.js +1 -1
  221. package/dist/components/ic-typography2.js.map +1 -1
  222. package/dist/core/core.css +2 -2
  223. package/dist/core/core.esm.js +1 -1
  224. package/dist/core/core.esm.js.map +1 -1
  225. package/dist/core/p-0e51d58e.entry.js +2 -0
  226. package/dist/core/p-0e51d58e.entry.js.map +1 -0
  227. package/dist/core/{p-4fd58768.entry.js → p-11b243c9.entry.js} +2 -2
  228. package/dist/core/{p-4bd13376.entry.js → p-185e91f0.entry.js} +2 -2
  229. package/dist/core/p-185e91f0.entry.js.map +1 -0
  230. package/dist/core/p-1a45f961.entry.js +2 -0
  231. package/dist/core/{p-e8151d13.entry.js.map → p-1a45f961.entry.js.map} +1 -1
  232. package/dist/core/p-1b4f852c.js +2 -0
  233. package/dist/core/p-1b4f852c.js.map +1 -0
  234. package/dist/core/{p-4ad3012a.entry.js → p-1fb48c84.entry.js} +2 -2
  235. package/dist/core/{p-6dce8e88.entry.js → p-1fff20ce.entry.js} +2 -2
  236. package/dist/core/p-1fff20ce.entry.js.map +1 -0
  237. package/dist/core/{p-1a91e842.entry.js → p-201ec29e.entry.js} +2 -2
  238. package/dist/core/{p-1a91e842.entry.js.map → p-201ec29e.entry.js.map} +1 -1
  239. package/dist/core/p-20d4ded5.js +2 -0
  240. package/dist/core/p-20d4ded5.js.map +1 -0
  241. package/dist/core/p-20f244ad.entry.js +2 -0
  242. package/dist/core/p-20f244ad.entry.js.map +1 -0
  243. package/dist/core/p-2536b95b.entry.js +2 -0
  244. package/dist/core/p-2536b95b.entry.js.map +1 -0
  245. package/dist/core/{p-730f058b.entry.js → p-25bbf4be.entry.js} +2 -2
  246. package/dist/core/p-25bbf4be.entry.js.map +1 -0
  247. package/dist/core/p-303dc008.entry.js +2 -0
  248. package/dist/core/p-303dc008.entry.js.map +1 -0
  249. package/dist/core/p-3484b15b.entry.js +2 -0
  250. package/dist/core/p-3484b15b.entry.js.map +1 -0
  251. package/dist/core/{p-aabab75f.entry.js → p-3fa986f8.entry.js} +2 -2
  252. package/dist/core/{p-f8f36680.entry.js → p-450f72b2.entry.js} +2 -2
  253. package/dist/core/{p-8b820365.entry.js → p-48c39d2a.entry.js} +2 -2
  254. package/dist/core/{p-a2dc10d8.entry.js → p-4aac2373.entry.js} +2 -2
  255. package/dist/core/{p-db3a35fb.entry.js → p-5201cd2b.entry.js} +2 -2
  256. package/dist/core/{p-db3a35fb.entry.js.map → p-5201cd2b.entry.js.map} +1 -1
  257. package/dist/core/p-53aeca18.entry.js +2 -0
  258. package/dist/core/p-53aeca18.entry.js.map +1 -0
  259. package/dist/core/{p-6eb58b0a.entry.js → p-5447f2fd.entry.js} +2 -2
  260. package/dist/core/{p-e1963c78.entry.js → p-5a5a52d3.entry.js} +2 -2
  261. package/dist/core/p-5a5a52d3.entry.js.map +1 -0
  262. package/dist/core/{p-946625a3.entry.js → p-60494f69.entry.js} +2 -2
  263. package/dist/core/p-60494f69.entry.js.map +1 -0
  264. package/dist/core/p-646b886c.entry.js +2 -0
  265. package/dist/core/p-646b886c.entry.js.map +1 -0
  266. package/dist/core/p-6996b750.entry.js +2 -0
  267. package/dist/core/p-6996b750.entry.js.map +1 -0
  268. package/dist/core/{p-849f43c3.entry.js → p-7114ae3b.entry.js} +2 -2
  269. package/dist/core/{p-494c3cbe.entry.js → p-71ddb6d9.entry.js} +2 -2
  270. package/dist/core/{p-baf81f30.entry.js → p-787ffd96.entry.js} +2 -2
  271. package/dist/core/p-787ffd96.entry.js.map +1 -0
  272. package/dist/core/p-7c569c2d.entry.js +2 -0
  273. package/dist/core/p-7c569c2d.entry.js.map +1 -0
  274. package/dist/core/{p-c621d6b0.entry.js → p-7f6de032.entry.js} +2 -2
  275. package/dist/core/p-7f6de032.entry.js.map +1 -0
  276. package/dist/core/{p-c14a897d.entry.js → p-7fe37432.entry.js} +2 -2
  277. package/dist/core/{p-9567c117.entry.js → p-86e679ab.entry.js} +2 -2
  278. package/dist/core/{p-a8c15117.entry.js → p-87075008.entry.js} +2 -2
  279. package/dist/core/p-895472da.entry.js +2 -0
  280. package/dist/core/p-895472da.entry.js.map +1 -0
  281. package/dist/core/{p-00bd7919.entry.js → p-8a67e960.entry.js} +2 -2
  282. package/dist/core/{p-9d8883d7.entry.js → p-8ccb23bd.entry.js} +2 -2
  283. package/dist/core/{p-9d8883d7.entry.js.map → p-8ccb23bd.entry.js.map} +1 -1
  284. package/dist/core/{p-d2d63a61.entry.js → p-9c22b14f.entry.js} +2 -2
  285. package/dist/core/{p-d2d63a61.entry.js.map → p-9c22b14f.entry.js.map} +1 -1
  286. package/dist/core/{p-19c1e271.entry.js → p-a1df23b4.entry.js} +2 -2
  287. package/dist/core/p-a1df23b4.entry.js.map +1 -0
  288. package/dist/core/{p-3dcc61cc.entry.js → p-a821c21f.entry.js} +2 -2
  289. package/dist/core/{p-3dcc61cc.entry.js.map → p-a821c21f.entry.js.map} +1 -1
  290. package/dist/core/{p-cca482e2.entry.js → p-b3b834b3.entry.js} +2 -2
  291. package/dist/core/p-b3b834b3.entry.js.map +1 -0
  292. package/dist/core/p-b4949e9a.entry.js +2 -0
  293. package/dist/core/p-b4949e9a.entry.js.map +1 -0
  294. package/dist/core/p-b7c644d1.entry.js +2 -0
  295. package/dist/core/p-b7c644d1.entry.js.map +1 -0
  296. package/dist/core/{p-0af27517.entry.js → p-b94ef8de.entry.js} +2 -2
  297. package/dist/core/p-ba1c1804.entry.js +2 -0
  298. package/dist/core/p-ba1c1804.entry.js.map +1 -0
  299. package/dist/core/{p-7fda2f94.entry.js → p-bbb1ce94.entry.js} +2 -2
  300. package/dist/core/p-bda7d350.entry.js +2 -0
  301. package/dist/core/p-bda7d350.entry.js.map +1 -0
  302. package/dist/core/{p-8b1f9648.entry.js → p-c5147498.entry.js} +2 -2
  303. package/dist/core/{p-ff6f1e3a.entry.js → p-d3a13342.entry.js} +2 -2
  304. package/dist/core/{p-843bdaae.entry.js → p-d4fed5f6.entry.js} +2 -2
  305. package/dist/core/p-d4fed5f6.entry.js.map +1 -0
  306. package/dist/core/p-d6ad82d8.entry.js +2 -0
  307. package/dist/core/p-d6ad82d8.entry.js.map +1 -0
  308. package/dist/core/{p-a05755b1.entry.js → p-d79bfead.entry.js} +2 -2
  309. package/dist/core/{p-a05755b1.entry.js.map → p-d79bfead.entry.js.map} +1 -1
  310. package/dist/core/p-db5c4969.entry.js +2 -0
  311. package/dist/core/{p-06c27edb.entry.js.map → p-db5c4969.entry.js.map} +1 -1
  312. package/dist/core/{p-957de939.entry.js → p-dd787b5b.entry.js} +2 -2
  313. package/dist/core/p-e42b66d5.entry.js +2 -0
  314. package/dist/core/p-e42b66d5.entry.js.map +1 -0
  315. package/dist/core/{p-9528b29e.entry.js → p-e4e89a4d.entry.js} +2 -2
  316. package/dist/core/{p-e16f73ba.entry.js → p-f704629e.entry.js} +2 -2
  317. package/dist/core/p-f704629e.entry.js.map +1 -0
  318. package/dist/core/p-fae5b518.entry.js +2 -0
  319. package/dist/core/p-fae5b518.entry.js.map +1 -0
  320. package/dist/core/{p-00c5639e.entry.js → p-ff697d68.entry.js} +2 -2
  321. package/dist/core/p-ff697d68.entry.js.map +1 -0
  322. package/dist/esm/core.js +1 -1
  323. package/dist/esm/{helpers-f328a7b6.js → helpers-1cd71f8a.js} +32 -2
  324. package/dist/esm/helpers-1cd71f8a.js.map +1 -0
  325. package/dist/esm/{helpers-c34e4042.js → helpers-84d21612.js} +58 -98
  326. package/dist/esm/helpers-84d21612.js.map +1 -0
  327. package/dist/esm/ic-accordion-group.entry.js +3 -1
  328. package/dist/esm/ic-accordion-group.entry.js.map +1 -1
  329. package/dist/esm/ic-accordion.entry.js +1 -1
  330. package/dist/esm/ic-alert.entry.js +1 -1
  331. package/dist/esm/ic-back-to-top.entry.js +15 -9
  332. package/dist/esm/ic-back-to-top.entry.js.map +1 -1
  333. package/dist/esm/ic-badge.entry.js +55 -77
  334. package/dist/esm/ic-badge.entry.js.map +1 -1
  335. package/dist/esm/ic-breadcrumb-group.entry.js +3 -1
  336. package/dist/esm/ic-breadcrumb-group.entry.js.map +1 -1
  337. package/dist/esm/ic-breadcrumb.entry.js +1 -1
  338. package/dist/esm/ic-button_3.entry.js +14 -14
  339. package/dist/esm/ic-button_3.entry.js.map +1 -1
  340. package/dist/esm/ic-card.entry.js +1 -1
  341. package/dist/esm/ic-card.entry.js.map +1 -1
  342. package/dist/esm/ic-checkbox-group.entry.js +23 -16
  343. package/dist/esm/ic-checkbox-group.entry.js.map +1 -1
  344. package/dist/esm/ic-checkbox.entry.js +33 -31
  345. package/dist/esm/ic-checkbox.entry.js.map +1 -1
  346. package/dist/esm/ic-chip.entry.js +21 -31
  347. package/dist/esm/ic-chip.entry.js.map +1 -1
  348. package/dist/esm/ic-data-row.entry.js +1 -1
  349. package/dist/esm/ic-data-table-title-bar.entry.js +53 -0
  350. package/dist/esm/ic-data-table-title-bar.entry.js.map +1 -0
  351. package/dist/esm/ic-data-table.entry.js +164 -37
  352. package/dist/esm/ic-data-table.entry.js.map +1 -1
  353. package/dist/esm/ic-date-input.entry.js +1 -1
  354. package/dist/esm/ic-date-picker.entry.js +1 -1
  355. package/dist/esm/ic-dialog.entry.js +4 -2
  356. package/dist/esm/ic-dialog.entry.js.map +1 -1
  357. package/dist/esm/ic-divider.entry.js +1 -1
  358. package/dist/esm/ic-empty-state_2.entry.js +340 -0
  359. package/dist/esm/ic-empty-state_2.entry.js.map +1 -0
  360. package/dist/esm/ic-footer-link-group.entry.js +2 -2
  361. package/dist/esm/ic-footer-link-group.entry.js.map +1 -1
  362. package/dist/esm/ic-footer-link.entry.js +1 -1
  363. package/dist/esm/ic-footer.entry.js +2 -2
  364. package/dist/esm/ic-footer.entry.js.map +1 -1
  365. package/dist/esm/ic-hero.entry.js +3 -2
  366. package/dist/esm/ic-hero.entry.js.map +1 -1
  367. package/dist/esm/ic-horizontal-scroll.entry.js +2 -3
  368. package/dist/esm/ic-horizontal-scroll.entry.js.map +1 -1
  369. package/dist/esm/ic-input-component-container_4.entry.js +2 -2
  370. package/dist/esm/ic-input-component-container_4.entry.js.map +1 -1
  371. package/dist/esm/ic-link.entry.js +2 -2
  372. package/dist/esm/ic-link.entry.js.map +1 -1
  373. package/dist/esm/ic-menu-group.entry.js +1 -1
  374. package/dist/esm/ic-menu-item.entry.js +4 -10
  375. package/dist/esm/ic-menu-item.entry.js.map +1 -1
  376. package/dist/esm/ic-menu-with-multi.entry.js +176 -35
  377. package/dist/esm/ic-menu-with-multi.entry.js.map +1 -1
  378. package/dist/esm/ic-menu.entry.js +4 -4
  379. package/dist/esm/ic-menu.entry.js.map +1 -1
  380. package/dist/esm/ic-navigation-button.entry.js +1 -1
  381. package/dist/esm/ic-navigation-group.entry.js +1 -1
  382. package/dist/esm/ic-navigation-item.entry.js +2 -2
  383. package/dist/esm/ic-navigation-item.entry.js.map +1 -1
  384. package/dist/esm/ic-navigation-menu.entry.js +1 -1
  385. package/dist/esm/ic-page-header.entry.js +1 -1
  386. package/dist/esm/ic-pagination_4.entry.js +54 -29
  387. package/dist/esm/ic-pagination_4.entry.js.map +1 -1
  388. package/dist/esm/ic-popover-menu.entry.js +13 -18
  389. package/dist/esm/ic-popover-menu.entry.js.map +1 -1
  390. package/dist/esm/ic-radio-group.entry.js +12 -16
  391. package/dist/esm/ic-radio-group.entry.js.map +1 -1
  392. package/dist/esm/ic-radio-option.entry.js +37 -37
  393. package/dist/esm/ic-radio-option.entry.js.map +1 -1
  394. package/dist/esm/ic-search-bar.entry.js +1 -1
  395. package/dist/esm/ic-select-with-multi.entry.js +1 -1
  396. package/dist/esm/ic-side-navigation.entry.js +1 -1
  397. package/dist/esm/ic-skeleton.entry.js +16 -35
  398. package/dist/esm/ic-skeleton.entry.js.map +1 -1
  399. package/dist/esm/ic-status-tag.entry.js +1 -1
  400. package/dist/esm/ic-status-tag.entry.js.map +1 -1
  401. package/dist/esm/ic-step.entry.js +1 -1
  402. package/dist/esm/ic-stepper.entry.js +1 -1
  403. package/dist/esm/ic-switch.entry.js +2 -2
  404. package/dist/esm/ic-switch.entry.js.map +1 -1
  405. package/dist/esm/ic-tab-group.entry.js +1 -1
  406. package/dist/esm/ic-tab-panel.entry.js +1 -1
  407. package/dist/esm/ic-tab.entry.js +2 -2
  408. package/dist/esm/ic-tab.entry.js.map +1 -1
  409. package/dist/esm/ic-theme.entry.js +13 -15
  410. package/dist/esm/ic-theme.entry.js.map +1 -1
  411. package/dist/esm/ic-toast.entry.js +1 -1
  412. package/dist/esm/ic-toggle-button.entry.js +2 -2
  413. package/dist/esm/ic-toggle-button.entry.js.map +1 -1
  414. package/dist/esm/ic-top-navigation.entry.js +15 -24
  415. package/dist/esm/ic-top-navigation.entry.js.map +1 -1
  416. package/dist/esm/ic-typography.entry.js +2 -2
  417. package/dist/esm/ic-typography.entry.js.map +1 -1
  418. package/dist/esm/index-93509377.js +8 -8
  419. package/dist/esm/loader.js +1 -1
  420. package/dist/types/components/ic-data-table/ic-data-table.d.ts +79 -13
  421. package/dist/types/components/ic-data-table/ic-data-table.types.d.ts +9 -0
  422. package/dist/types/components/ic-data-table/story-data.d.ts +59 -0
  423. package/dist/types/components/ic-data-table-title-bar/ic-data-table-title-bar.d.ts +36 -0
  424. package/dist/types/components/ic-data-table-title-bar/test/a11y/ic-data-table-title-bar.test.a11y.d.ts +1 -0
  425. package/dist/types/components/ic-menu-with-multi/ic-menu.d.ts +10 -0
  426. package/dist/types/components/ic-pagination-bar/ic-pagination-bar.d.ts +33 -13
  427. package/dist/types/components.d.ts +211 -46
  428. package/dist/types/utils/helpers.d.ts +1 -0
  429. package/dist/types/utils/types.d.ts +21 -5
  430. package/hydrate/index.js +1414 -1058
  431. package/package.json +3 -3
  432. package/dist/cjs/helpers-6d736902.js.map +0 -1
  433. package/dist/cjs/helpers-f75cf7cf.js.map +0 -1
  434. package/dist/cjs/ic-empty-state.cjs.entry.js +0 -38
  435. package/dist/cjs/ic-empty-state.cjs.entry.js.map +0 -1
  436. package/dist/cjs/ic-pagination-bar.cjs.entry.js +0 -269
  437. package/dist/cjs/ic-pagination-bar.cjs.entry.js.map +0 -1
  438. package/dist/collection/components/ic-pagination/ic-pagination.types.js +0 -2
  439. package/dist/collection/components/ic-pagination/ic-pagination.types.js.map +0 -1
  440. package/dist/core/p-00c5639e.entry.js.map +0 -1
  441. package/dist/core/p-06c27edb.entry.js +0 -2
  442. package/dist/core/p-162f3e36.entry.js +0 -2
  443. package/dist/core/p-162f3e36.entry.js.map +0 -1
  444. package/dist/core/p-19c1e271.entry.js.map +0 -1
  445. package/dist/core/p-1c3bd46d.entry.js +0 -2
  446. package/dist/core/p-1c3bd46d.entry.js.map +0 -1
  447. package/dist/core/p-2c9d6334.entry.js +0 -2
  448. package/dist/core/p-2c9d6334.entry.js.map +0 -1
  449. package/dist/core/p-3e9a8977.entry.js +0 -2
  450. package/dist/core/p-3e9a8977.entry.js.map +0 -1
  451. package/dist/core/p-41b682dc.entry.js +0 -2
  452. package/dist/core/p-41b682dc.entry.js.map +0 -1
  453. package/dist/core/p-4bd13376.entry.js.map +0 -1
  454. package/dist/core/p-6dce8e88.entry.js.map +0 -1
  455. package/dist/core/p-730f058b.entry.js.map +0 -1
  456. package/dist/core/p-7f53d1be.entry.js +0 -2
  457. package/dist/core/p-7f53d1be.entry.js.map +0 -1
  458. package/dist/core/p-843bdaae.entry.js.map +0 -1
  459. package/dist/core/p-946625a3.entry.js.map +0 -1
  460. package/dist/core/p-99bf38e3.entry.js +0 -2
  461. package/dist/core/p-99bf38e3.entry.js.map +0 -1
  462. package/dist/core/p-9e3178e8.entry.js +0 -2
  463. package/dist/core/p-9e3178e8.entry.js.map +0 -1
  464. package/dist/core/p-a1556d97.entry.js +0 -2
  465. package/dist/core/p-a1556d97.entry.js.map +0 -1
  466. package/dist/core/p-baf81f30.entry.js.map +0 -1
  467. package/dist/core/p-c621d6b0.entry.js.map +0 -1
  468. package/dist/core/p-c7590421.entry.js +0 -2
  469. package/dist/core/p-c7590421.entry.js.map +0 -1
  470. package/dist/core/p-c953edb9.entry.js +0 -2
  471. package/dist/core/p-c953edb9.entry.js.map +0 -1
  472. package/dist/core/p-cca482e2.entry.js.map +0 -1
  473. package/dist/core/p-cd799087.js +0 -2
  474. package/dist/core/p-cd799087.js.map +0 -1
  475. package/dist/core/p-d32d331b.entry.js +0 -2
  476. package/dist/core/p-d32d331b.entry.js.map +0 -1
  477. package/dist/core/p-dc5e1f8f.entry.js +0 -2
  478. package/dist/core/p-dc5e1f8f.entry.js.map +0 -1
  479. package/dist/core/p-e16f73ba.entry.js.map +0 -1
  480. package/dist/core/p-e189f1d0.entry.js +0 -2
  481. package/dist/core/p-e189f1d0.entry.js.map +0 -1
  482. package/dist/core/p-e1963c78.entry.js.map +0 -1
  483. package/dist/core/p-e8151d13.entry.js +0 -2
  484. package/dist/core/p-ee765ad5.js +0 -2
  485. package/dist/core/p-ee765ad5.js.map +0 -1
  486. package/dist/core/p-f2147136.entry.js +0 -2
  487. package/dist/core/p-f2147136.entry.js.map +0 -1
  488. package/dist/core/p-fca46bd9.entry.js +0 -2
  489. package/dist/core/p-fca46bd9.entry.js.map +0 -1
  490. package/dist/core/p-ff3a01f3.entry.js +0 -2
  491. package/dist/core/p-ff3a01f3.entry.js.map +0 -1
  492. package/dist/esm/helpers-c34e4042.js.map +0 -1
  493. package/dist/esm/helpers-f328a7b6.js.map +0 -1
  494. package/dist/esm/ic-empty-state.entry.js.map +0 -1
  495. package/dist/esm/ic-pagination-bar.entry.js +0 -265
  496. package/dist/esm/ic-pagination-bar.entry.js.map +0 -1
  497. package/dist/types/components/ic-pagination/ic-pagination.types.d.ts +0 -6
  498. /package/dist/core/{p-4fd58768.entry.js.map → p-11b243c9.entry.js.map} +0 -0
  499. /package/dist/core/{p-4ad3012a.entry.js.map → p-1fb48c84.entry.js.map} +0 -0
  500. /package/dist/core/{p-aabab75f.entry.js.map → p-3fa986f8.entry.js.map} +0 -0
  501. /package/dist/core/{p-f8f36680.entry.js.map → p-450f72b2.entry.js.map} +0 -0
  502. /package/dist/core/{p-8b820365.entry.js.map → p-48c39d2a.entry.js.map} +0 -0
  503. /package/dist/core/{p-a2dc10d8.entry.js.map → p-4aac2373.entry.js.map} +0 -0
  504. /package/dist/core/{p-6eb58b0a.entry.js.map → p-5447f2fd.entry.js.map} +0 -0
  505. /package/dist/core/{p-849f43c3.entry.js.map → p-7114ae3b.entry.js.map} +0 -0
  506. /package/dist/core/{p-494c3cbe.entry.js.map → p-71ddb6d9.entry.js.map} +0 -0
  507. /package/dist/core/{p-c14a897d.entry.js.map → p-7fe37432.entry.js.map} +0 -0
  508. /package/dist/core/{p-9567c117.entry.js.map → p-86e679ab.entry.js.map} +0 -0
  509. /package/dist/core/{p-a8c15117.entry.js.map → p-87075008.entry.js.map} +0 -0
  510. /package/dist/core/{p-00bd7919.entry.js.map → p-8a67e960.entry.js.map} +0 -0
  511. /package/dist/core/{p-0af27517.entry.js.map → p-b94ef8de.entry.js.map} +0 -0
  512. /package/dist/core/{p-7fda2f94.entry.js.map → p-bbb1ce94.entry.js.map} +0 -0
  513. /package/dist/core/{p-8b1f9648.entry.js.map → p-c5147498.entry.js.map} +0 -0
  514. /package/dist/core/{p-ff6f1e3a.entry.js.map → p-d3a13342.entry.js.map} +0 -0
  515. /package/dist/core/{p-957de939.entry.js.map → p-dd787b5b.entry.js.map} +0 -0
  516. /package/dist/core/{p-9528b29e.entry.js.map → p-e4e89a4d.entry.js.map} +0 -0
@@ -1,87 +1,67 @@
1
1
  import { h, } from "@stencil/core";
2
- import { checkResizeObserver } from "../../utils/helpers";
2
+ import { checkResizeObserver, capitalize } from "../../utils/helpers";
3
3
  export class PaginationBar {
4
4
  constructor() {
5
- this.PAGINATION = "ic-pagination";
6
- this.TEXT_FIELD = "ic-text-field";
7
- this.TOOLTIP = "ic-tooltip";
8
5
  this.PAGE_INPUT_FIELD_ID = "go-to-page-input";
9
6
  this.INVALID_PAGE_ERROR = "Please enter a valid page";
10
7
  this.NAN_ERROR = "Please enter a number";
11
8
  this.resizeObserver = null;
12
9
  this.changeItemsPerPage = () => {
13
- const select = this.el.shadowRoot.querySelector("ic-select");
14
- const value = select.value;
15
- this.itemsPerPage = value;
16
- this.setNumberPages();
17
- this.setUpperBound();
18
- const pagination = this.el.shadowRoot.querySelector(this.PAGINATION);
19
- if (this.currentPage > this.totalPages) {
20
- pagination.setCurrentPage(this.totalPages);
21
- this.currentPage = this.totalPages;
22
- }
23
- this.icItemsPerPageChange.emit({ value: Number(this.itemsPerPage) });
24
- this.icPageChange.emit({ value: this.currentPage });
10
+ this.setItemsPerPage(Number(this.pageDropdownEl.value));
25
11
  };
26
12
  this.changePage = (page) => {
27
13
  this.currentPage = page;
28
- this.lowerBound =
29
- page !== 1 ? (page - 1) * Number(this.itemsPerPage) + 1 : page;
14
+ this.lowerBound = page !== 1 ? (page - 1) * this.itemsPerPage + 1 : page;
30
15
  this.setUpperBound();
31
16
  };
17
+ this.focusElFromLabel = (el) => {
18
+ var _a;
19
+ (_a = this.paginationBarEl.querySelector(el)) === null || _a === void 0 ? void 0 : _a.setFocus();
20
+ };
32
21
  this.goToPage = () => {
33
- const input = this.el.shadowRoot.querySelector(this.TEXT_FIELD);
22
+ const input = this.pageInputEl;
34
23
  const page = Number(input.value);
35
- const tooltip = this.el.shadowRoot.querySelector("ic-tooltip");
36
24
  if (page <= this.totalPages && page > 0) {
37
25
  this.changePage(page);
38
- const pagination = this.el.shadowRoot.querySelector(this.PAGINATION);
39
- pagination.setCurrentPage(page);
26
+ this.paginationEl.setCurrentPage(page);
40
27
  this.currentPage = page;
41
28
  input.value = "";
42
29
  this.icPageChange.emit({ value: page });
43
- tooltip.displayTooltip(false, false);
30
+ this.pageInputTooltipEl.displayTooltip(false, false);
44
31
  input.validationStatus = "";
45
32
  }
46
33
  else {
47
- this.inputError = this.INVALID_PAGE_ERROR;
48
- input.validationStatus = "error";
49
- input.setFocus();
34
+ this.setInputError(input, this.INVALID_PAGE_ERROR);
50
35
  }
51
36
  };
37
+ this.goToPageLabelClickHandler = () => {
38
+ this.focusElFromLabel("ic-text-field");
39
+ };
52
40
  this.handleBlur = () => {
53
- var _a, _b;
54
- const textField = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(this.TEXT_FIELD);
55
- const tooltip = (_b = this.el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector(this.TOOLTIP);
41
+ const textField = this.pageInputEl;
56
42
  if ((Number(textField.value) <= this.totalPages &&
57
43
  Number(textField.value) > 0) ||
58
44
  textField.value === "") {
59
45
  textField.validationStatus = "";
60
46
  }
61
- tooltip.displayTooltip(false, false);
47
+ this.pageInputTooltipEl.displayTooltip(false, false);
62
48
  };
63
49
  this.handleFocus = () => {
64
- var _a, _b;
65
- const textField = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(this.TEXT_FIELD);
66
- const tooltip = (_b = this.el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector(this.TOOLTIP);
67
- if (textField.validationStatus === "error") {
68
- tooltip.displayTooltip(true, true);
50
+ if (this.pageInputEl.validationStatus === "error") {
51
+ this.pageInputTooltipEl.displayTooltip(true, true);
69
52
  }
70
53
  };
71
54
  this.handleInputChange = () => {
72
- const tooltip = this.el.shadowRoot.querySelector(this.TOOLTIP);
73
- const textField = this.el.shadowRoot.querySelector(this.TEXT_FIELD);
55
+ const textField = this.pageInputEl;
74
56
  const inputValue = parseInt(textField.value);
75
57
  if (inputValue > this.totalPages || inputValue <= 0) {
76
- this.inputError = this.INVALID_PAGE_ERROR;
77
- tooltip.displayTooltip(true, true);
78
- textField.validationStatus = "error";
79
- textField.focus();
58
+ this.setInputError(textField, this.INVALID_PAGE_ERROR);
59
+ this.pageInputTooltipEl.displayTooltip(true, true);
80
60
  }
81
61
  };
82
62
  this.handleKeydown = (ev) => {
83
- const tooltip = this.el.shadowRoot.querySelector(this.TOOLTIP);
84
- const textField = this.el.shadowRoot.querySelector(this.TEXT_FIELD);
63
+ const tooltip = this.pageInputTooltipEl;
64
+ const textField = this.pageInputEl;
85
65
  if (ev.key === "Enter") {
86
66
  if (textField.validationStatus === "error") {
87
67
  tooltip.displayTooltip(true, true);
@@ -96,23 +76,23 @@ export class PaginationBar {
96
76
  }
97
77
  };
98
78
  this.handleKeyUp = (ev) => {
99
- const tooltip = this.el.shadowRoot.querySelector(this.TOOLTIP);
100
- const textField = this.el.shadowRoot.querySelector(this.TEXT_FIELD);
79
+ const textField = this.pageInputEl;
101
80
  const inputValue = parseInt(textField.value);
102
81
  if (Number.isNaN(inputValue) &&
103
82
  ev.key !== "Backspace" &&
104
83
  ev.key !== "Enter" &&
105
84
  ev.key !== "Tab" &&
106
85
  ev.key !== "Shift") {
107
- this.inputError = this.NAN_ERROR;
108
- tooltip.displayTooltip(true, false);
109
- textField.validationStatus = "error";
86
+ this.setInputError(textField, this.NAN_ERROR, false);
87
+ this.pageInputTooltipEl.displayTooltip(true, false);
110
88
  }
111
89
  };
90
+ this.itemsPerPageLabelClickHandler = () => {
91
+ this.focusElFromLabel("ic-select");
92
+ };
112
93
  this.paginationShouldWrap = () => {
113
- const pagination = this.el.shadowRoot.querySelector(this.PAGINATION);
114
- if (this.paginationControl === "simple") {
115
- if (pagination.clientHeight > 63) {
94
+ if (this.type === "simple") {
95
+ if (this.paginationEl.clientHeight > 63) {
116
96
  this.paginationWrapped = true;
117
97
  }
118
98
  else {
@@ -134,24 +114,25 @@ export class PaginationBar {
134
114
  });
135
115
  this.resizeObserver.observe(this.paginationBarEl);
136
116
  };
137
- this.setDefaultItemsPerPage = () => {
138
- this.itemsPerPage = this.itemsPerPageOptions[0].value;
139
- };
140
- this.setDefaultItemsPerPageOptions = () => {
141
- this.itemsPerPageOptions =
142
- this.totalItems <= 100
143
- ? [
144
- { label: "10", value: "10" },
145
- { label: "25", value: "25" },
146
- { label: "50", value: "50" },
147
- { label: "All", value: String(this.totalItems) },
148
- ]
149
- : [
150
- { label: "25", value: "25" },
151
- { label: "100", value: "100" },
152
- { label: "1000", value: "1000" },
153
- { label: "All", value: String(this.totalItems) },
154
- ];
117
+ this.setDisplayedItemsPerPageOptions = () => {
118
+ if (this.itemsPerPageOptions === undefined ||
119
+ this.itemsPerPageOptions === null) {
120
+ this.displayedItemsPerPageOptions =
121
+ this.totalItems <= 100
122
+ ? [
123
+ { label: "10", value: "10" },
124
+ { label: "25", value: "25" },
125
+ { label: "50", value: "50" },
126
+ ]
127
+ : [
128
+ { label: "25", value: "25" },
129
+ { label: "100", value: "100" },
130
+ { label: "1000", value: "1000" },
131
+ ];
132
+ }
133
+ else {
134
+ this.displayedItemsPerPageOptions = this.itemsPerPageOptions.slice(0, 3);
135
+ }
155
136
  };
156
137
  this.setGoToPageInputStyles = () => {
157
138
  var _a, _b;
@@ -164,28 +145,81 @@ export class PaginationBar {
164
145
  }
165
146
  }
166
147
  };
148
+ this.setInputError = (el, error, focus = true) => {
149
+ this.inputError = error;
150
+ el.validationStatus = "error";
151
+ if (focus)
152
+ el.setFocus();
153
+ };
154
+ this.setItemsPerPage = (newValue) => {
155
+ if (this.itemsPerPage !== newValue) {
156
+ this.itemsPerPage = newValue;
157
+ this.itemsPerPageString = newValue.toString();
158
+ this.icItemsPerPageChange.emit({ value: this.itemsPerPage });
159
+ }
160
+ this.setNumberPages();
161
+ this.setUpperBound();
162
+ if (this.currentPage > this.totalPages) {
163
+ this.paginationEl.setCurrentPage(this.totalPages);
164
+ this.currentPage = this.totalPages;
165
+ }
166
+ this.icPageChange.emit({ value: this.currentPage });
167
+ };
167
168
  this.setNumberPages = () => {
168
- this.totalPages = Math.ceil(this.totalItems / Number(this.itemsPerPage));
169
+ const numItemsPerPage = this.itemsPerPage;
170
+ if (this.totalItems <= numItemsPerPage) {
171
+ this.totalPages = 1;
172
+ }
173
+ else {
174
+ this.totalPages = Math.ceil(this.totalItems / numItemsPerPage);
175
+ }
176
+ };
177
+ this.setPaginationBarContent = () => {
178
+ this.setDisplayedItemsPerPageOptions();
179
+ this.trimItemsPerPageOptions();
180
+ this.updateItemsPerPage();
169
181
  };
170
182
  this.setUpperBound = () => {
171
- this.upperBound = Math.min(this.lowerBound + Number(this.itemsPerPage) - 1, this.totalItems);
183
+ this.upperBound = Math.min(this.lowerBound + this.itemsPerPage - 1, this.totalItems);
172
184
  };
173
185
  this.trimItemsPerPageOptions = () => {
174
- this.itemsPerPageOptions = this.itemsPerPageOptions.slice(0, 3);
175
- this.itemsPerPageOptions.push({
186
+ this.displayedItemsPerPageOptions.push({
176
187
  label: "All",
177
188
  value: String(this.totalItems),
178
189
  });
179
- for (let i = 0; i < this.itemsPerPageOptions.length - 1; i++) {
180
- if (this.totalItems <= Number(this.itemsPerPageOptions[i].value)) {
181
- this.itemsPerPageOptions.splice(i, this.itemsPerPageOptions.length - (i + 1));
190
+ for (let i = 0; i < this.displayedItemsPerPageOptions.length - 1; i++) {
191
+ if (this.totalItems <= Number(this.displayedItemsPerPageOptions[i].value)) {
192
+ this.displayedItemsPerPageOptions.splice(i, this.displayedItemsPerPageOptions.length - (i + 1));
182
193
  }
183
194
  }
184
195
  };
196
+ this.updateItemsPerPage = () => {
197
+ let newItemsPerPage = this.itemsPerPage;
198
+ let updated = false;
199
+ let lastOptionValue = 0;
200
+ for (let i = 0; i < this.displayedItemsPerPageOptions.length; i++) {
201
+ lastOptionValue = Number(this.displayedItemsPerPageOptions[i].value);
202
+ if (this.itemsPerPage <= lastOptionValue) {
203
+ newItemsPerPage = lastOptionValue;
204
+ updated = true;
205
+ i = this.displayedItemsPerPageOptions.length;
206
+ }
207
+ }
208
+ if (!updated && this.itemsPerPage > lastOptionValue) {
209
+ newItemsPerPage = lastOptionValue;
210
+ }
211
+ this.setItemsPerPage(newItemsPerPage);
212
+ };
213
+ this.capitalizedItemLabel = undefined;
214
+ this.capitalizedPageLabel = undefined;
185
215
  this.currentPage = 1;
216
+ this.displayedItemsPerPageOptions = undefined;
186
217
  this.inputError = "Please enter a valid page";
187
- this.itemsPerPage = undefined;
218
+ this.itemsPerPage = 0;
219
+ this.itemsPerPageString = "0";
188
220
  this.lowerBound = 1;
221
+ this.lowerCaseItemLabel = undefined;
222
+ this.lowerCasePageLabel = undefined;
189
223
  this.paginationWidth = undefined;
190
224
  this.paginationWrapped = false;
191
225
  this.totalPages = undefined;
@@ -194,28 +228,37 @@ export class PaginationBar {
194
228
  this.appearance = "default";
195
229
  this.itemLabel = "Item";
196
230
  this.itemsPerPageOptions = undefined;
197
- this.paginationControl = "simple";
198
- this.paginationType = "page";
231
+ this.type = "simple";
232
+ this.rangeLabelType = "page";
199
233
  this.pageLabel = "Page";
200
234
  this.showGoToPageControl = false;
201
- this.showItemsPerPage = true;
235
+ this.hideRangeLabel = false;
202
236
  this.showItemsPerPageControl = false;
203
237
  this.totalItems = undefined;
204
238
  }
239
+ watchItemLabelHandler() {
240
+ this.capitalizedItemLabel = capitalize(this.itemLabel);
241
+ this.lowerCaseItemLabel = this.itemLabel.toLowerCase();
242
+ }
243
+ watchItemsPerPageOptionsHandler() {
244
+ this.setPaginationBarContent();
245
+ }
246
+ watchPageLabelHandler() {
247
+ this.capitalizedPageLabel = capitalize(this.pageLabel);
248
+ this.lowerCasePageLabel = this.pageLabel.toLowerCase();
249
+ }
250
+ watchTotalItemsHandler() {
251
+ this.setPaginationBarContent();
252
+ }
205
253
  disconnectedCallback() {
206
254
  if (this.resizeObserver !== null) {
207
255
  this.resizeObserver.disconnect();
208
256
  }
209
257
  }
210
258
  componentWillLoad() {
211
- if (this.itemsPerPageOptions === undefined ||
212
- this.itemsPerPageOptions === null) {
213
- this.setDefaultItemsPerPageOptions();
214
- }
215
- this.trimItemsPerPageOptions();
216
- this.setDefaultItemsPerPage();
217
- this.setNumberPages();
218
- this.setUpperBound();
259
+ this.watchPageLabelHandler();
260
+ this.watchItemLabelHandler();
261
+ this.setPaginationBarContent();
219
262
  }
220
263
  componentDidLoad() {
221
264
  this.paginationWidth = this.paginationBarEl.clientWidth;
@@ -228,27 +271,24 @@ export class PaginationBar {
228
271
  this.changePage(page);
229
272
  }
230
273
  render() {
231
- const { appearance, alignment, itemsPerPageOptions, PAGE_INPUT_FIELD_ID, paginationControl, paginationType, showItemsPerPage, showItemsPerPageControl, showGoToPageControl, } = this;
232
- const focusElFromLabel = (el) => {
233
- var _a;
234
- (_a = this.paginationBarEl.querySelector(el)) === null || _a === void 0 ? void 0 : _a.setFocus();
235
- };
274
+ const { appearance, alignment, displayedItemsPerPageOptions, PAGE_INPUT_FIELD_ID, type, rangeLabelType, hideRangeLabel, showItemsPerPageControl, showGoToPageControl, pageLabel, capitalizedPageLabel, lowerCasePageLabel, capitalizedItemLabel, lowerCaseItemLabel, totalPages, currentPage, itemsPerPageString, } = this;
236
275
  return (h("div", { class: {
237
276
  ["pagination-bar"]: true,
238
277
  [`pagination-bar-${alignment}`]: true,
239
- }, ref: (el) => (this.paginationBarEl = el) }, (showItemsPerPage || showItemsPerPageControl) && (h("div", { class: "item-controls" }, showItemsPerPageControl && (h("div", { class: "items-per-page-holder" }, h("ic-typography", { class: {
278
+ }, ref: (el) => (this.paginationBarEl = el) }, (!hideRangeLabel || showItemsPerPageControl) && (h("div", { class: "item-controls" }, showItemsPerPageControl && (h("div", { class: "items-per-page-holder" }, h("ic-typography", { class: {
240
279
  [`pagination-text-${appearance}`]: true,
241
280
  ["items-per-page-control-label"]: true,
242
- }, variant: "label", onClick: () => focusElFromLabel("ic-select") }, this.itemLabel, "s per ", this.pageLabel.toLowerCase()), h("ic-select", { small: true, label: "items-per-page-input", class: "items-per-page-input", hideLabel: true, options: itemsPerPageOptions, value: this.itemsPerPage, onIcChange: () => this.changeItemsPerPage() }))), showItemsPerPage && paginationType === "data" ? (h("ic-typography", { class: {
281
+ }, variant: "label", onClick: this.itemsPerPageLabelClickHandler }, capitalizedItemLabel, "s per ", lowerCasePageLabel), h("ic-select", { small: true, label: "items-per-page-input", class: "items-per-page-input", hideLabel: true, options: displayedItemsPerPageOptions, value: itemsPerPageString, onIcChange: this.changeItemsPerPage, ref: (el) => (this.pageDropdownEl = el) }))), !hideRangeLabel && rangeLabelType === "data" ? (h("ic-typography", { class: {
243
282
  [`pagination-text-${appearance}`]: true,
244
283
  ["item-pagination-label"]: true,
245
- }, variant: "label", "aria-live": "polite" }, this.lowerBound, " - ", this.upperBound, " of ", this.totalItems, " ", this.itemLabel.toLowerCase(), this.totalItems > 1 ? "s" : "")) : (showItemsPerPage && (h("ic-typography", { class: {
284
+ }, variant: "label", "aria-live": "polite" }, this.upperBound === 0 && `0 ${lowerCaseItemLabel}s`, this.upperBound > 0 &&
285
+ `${this.lowerBound} - ${this.upperBound} of ${this.totalItems} ${lowerCaseItemLabel}${this.totalItems > 1 ? "s" : ""}`)) : (!hideRangeLabel && (h("ic-typography", { class: {
246
286
  [`pagination-text-${appearance}`]: true,
247
287
  ["page-pagination-label"]: true,
248
- }, variant: "label", "aria-live": "polite" }, this.pageLabel, " ", this.currentPage, " of ", this.totalPages))))), h("div", { class: {
288
+ }, variant: "label", "aria-live": "polite" }, capitalizedPageLabel, " ", currentPage, " of ", totalPages))))), h("div", { class: {
249
289
  ["pagination-controls"]: true,
250
290
  ["pagination-controls-wrap"]: this.paginationWrapped,
251
- } }, h("div", { class: "pagination-holder" }, h("ic-pagination", { appearance: appearance, type: paginationControl, pages: this.totalPages })), showGoToPageControl && (h("div", { class: "go-to-page-holder" }, h("ic-typography", { class: { [`pagination-text-${appearance}`]: true }, variant: "label", onClick: () => focusElFromLabel("ic-text-field") }, "Go to ", this.pageLabel.toLowerCase()), h("ic-tooltip", { label: this.inputError, target: `#${PAGE_INPUT_FIELD_ID}`, disableHover: true, disableClick: true }, h("ic-text-field", { type: "number", size: "small", label: PAGE_INPUT_FIELD_ID, class: PAGE_INPUT_FIELD_ID, id: PAGE_INPUT_FIELD_ID, hideLabel: true, onKeyDown: (ev) => this.handleKeydown(ev), onKeyUp: (ev) => this.handleKeyUp(ev), onInput: () => this.handleInputChange(), max: this.totalPages, min: "1", validationInlineInternal: true, onBlur: () => this.handleBlur(), onFocus: () => this.handleFocus() })), h("ic-button", { appearance: appearance, variant: "secondary", onClick: () => this.goToPage(), size: "small", class: "go-to-page-button" }, "Go"))))));
291
+ } }, h("div", { class: "pagination-holder" }, h("ic-pagination", { appearance: appearance, type: type, pages: totalPages, label: pageLabel, ref: (el) => (this.paginationEl = el) })), showGoToPageControl && (h("div", { class: "go-to-page-holder" }, h("ic-typography", { class: { [`pagination-text-${appearance}`]: true }, variant: "label", onClick: this.goToPageLabelClickHandler }, "Go to ", lowerCasePageLabel), h("ic-tooltip", { label: this.inputError, target: `#${PAGE_INPUT_FIELD_ID}`, disableHover: true, disableClick: true, ref: (el) => (this.pageInputTooltipEl = el) }, h("ic-text-field", { type: "number", size: "small", label: PAGE_INPUT_FIELD_ID, class: PAGE_INPUT_FIELD_ID, id: PAGE_INPUT_FIELD_ID, hideLabel: true, onKeyDown: this.handleKeydown, onKeyUp: this.handleKeyUp, onInput: this.handleInputChange, max: totalPages, min: "1", validationInlineInternal: true, onBlur: this.handleBlur, onFocus: this.handleFocus, ref: (el) => (this.pageInputEl = el) })), h("ic-button", { appearance: appearance, variant: "secondary", onClick: this.goToPage, size: "small", class: "go-to-page-button" }, "Go"))))));
252
292
  }
253
293
  static get is() { return "ic-pagination-bar"; }
254
294
  static get encapsulation() { return "shadow"; }
@@ -273,8 +313,8 @@ export class PaginationBar {
273
313
  "references": {
274
314
  "IcPaginationAlignmentOptions": {
275
315
  "location": "import",
276
- "path": "../ic-pagination/ic-pagination.types",
277
- "id": "src/components/ic-pagination/ic-pagination.types.ts::IcPaginationAlignmentOptions"
316
+ "path": "@ukic/web-components/dist/types/components/ic-pagination/ic-pagination.types",
317
+ "id": "../web-components/dist/types/components/ic-pagination/ic-pagination.types.d.ts::IcPaginationAlignmentOptions"
278
318
  }
279
319
  }
280
320
  },
@@ -324,7 +364,7 @@ export class PaginationBar {
324
364
  "optional": true,
325
365
  "docs": {
326
366
  "tags": [],
327
- "text": "The label which will be used in place of 'items' if paginationType is data. Should be capitalised."
367
+ "text": "The text which will be used in place of 'Item' on the pagination bar."
328
368
  },
329
369
  "attribute": "item-label",
330
370
  "reflect": false,
@@ -332,7 +372,7 @@ export class PaginationBar {
332
372
  },
333
373
  "itemsPerPageOptions": {
334
374
  "type": "unknown",
335
- "mutable": true,
375
+ "mutable": false,
336
376
  "complexType": {
337
377
  "original": "{\n label: string;\n value: string;\n }[]",
338
378
  "resolved": "{ label: string; value: string; }[]",
@@ -345,17 +385,17 @@ export class PaginationBar {
345
385
  "text": "The options which will be displayed for 'items per page' select input. Set a maximum of 4 options including a required 'All' option with value equal to total number of items."
346
386
  }
347
387
  },
348
- "paginationControl": {
388
+ "type": {
349
389
  "type": "string",
350
390
  "mutable": false,
351
391
  "complexType": {
352
- "original": "IcPaginationControlTypes",
392
+ "original": "IcPaginationTypes",
353
393
  "resolved": "\"complex\" | \"simple\"",
354
394
  "references": {
355
- "IcPaginationControlTypes": {
395
+ "IcPaginationTypes": {
356
396
  "location": "import",
357
- "path": "../ic-pagination/ic-pagination.types",
358
- "id": "src/components/ic-pagination/ic-pagination.types.ts::IcPaginationControlTypes"
397
+ "path": "@ukic/web-components/dist/types/components/ic-pagination/ic-pagination.types",
398
+ "id": "../web-components/dist/types/components/ic-pagination/ic-pagination.types.d.ts::IcPaginationTypes"
359
399
  }
360
400
  }
361
401
  },
@@ -365,21 +405,21 @@ export class PaginationBar {
365
405
  "tags": [],
366
406
  "text": "Whether the displayed pagination is simple or complex."
367
407
  },
368
- "attribute": "pagination-control",
408
+ "attribute": "type",
369
409
  "reflect": false,
370
410
  "defaultValue": "\"simple\""
371
411
  },
372
- "paginationType": {
412
+ "rangeLabelType": {
373
413
  "type": "string",
374
414
  "mutable": false,
375
415
  "complexType": {
376
- "original": "IcPaginationTypes",
416
+ "original": "IcPaginationLabelTypes",
377
417
  "resolved": "\"data\" | \"page\"",
378
418
  "references": {
379
- "IcPaginationTypes": {
419
+ "IcPaginationLabelTypes": {
380
420
  "location": "import",
381
- "path": "../ic-pagination/ic-pagination.types",
382
- "id": "src/components/ic-pagination/ic-pagination.types.ts::IcPaginationTypes"
421
+ "path": "@ukic/web-components/dist/types/components/ic-pagination/ic-pagination.types",
422
+ "id": "../web-components/dist/types/components/ic-pagination/ic-pagination.types.d.ts::IcPaginationLabelTypes"
383
423
  }
384
424
  }
385
425
  },
@@ -389,7 +429,7 @@ export class PaginationBar {
389
429
  "tags": [],
390
430
  "text": "Whether total number of items and current item range or total number of pages and current page is displayed."
391
431
  },
392
- "attribute": "pagination-type",
432
+ "attribute": "range-label-type",
393
433
  "reflect": false,
394
434
  "defaultValue": "\"page\""
395
435
  },
@@ -405,7 +445,7 @@ export class PaginationBar {
405
445
  "optional": true,
406
446
  "docs": {
407
447
  "tags": [],
408
- "text": "The label which will be used in place of 'Page' if paginationType is page. Should be capitalised."
448
+ "text": "The text which will be used in place of 'Page' on the pagination bar."
409
449
  },
410
450
  "attribute": "page-label",
411
451
  "reflect": false,
@@ -429,7 +469,7 @@ export class PaginationBar {
429
469
  "reflect": false,
430
470
  "defaultValue": "false"
431
471
  },
432
- "showItemsPerPage": {
472
+ "hideRangeLabel": {
433
473
  "type": "boolean",
434
474
  "mutable": false,
435
475
  "complexType": {
@@ -441,11 +481,11 @@ export class PaginationBar {
441
481
  "optional": true,
442
482
  "docs": {
443
483
  "tags": [],
444
- "text": "If `true`, the number of total items and current item range or number of total pages and current page should be displayed."
484
+ "text": "If `true`, the number of total items and current item range or number of total pages and current page will be hidden."
445
485
  },
446
- "attribute": "show-items-per-page",
486
+ "attribute": "hide-range-label",
447
487
  "reflect": false,
448
- "defaultValue": "true"
488
+ "defaultValue": "false"
449
489
  },
450
490
  "showItemsPerPageControl": {
451
491
  "type": "boolean",
@@ -486,10 +526,16 @@ export class PaginationBar {
486
526
  }
487
527
  static get states() {
488
528
  return {
529
+ "capitalizedItemLabel": {},
530
+ "capitalizedPageLabel": {},
489
531
  "currentPage": {},
532
+ "displayedItemsPerPageOptions": {},
490
533
  "inputError": {},
491
534
  "itemsPerPage": {},
535
+ "itemsPerPageString": {},
492
536
  "lowerBound": {},
537
+ "lowerCaseItemLabel": {},
538
+ "lowerCasePageLabel": {},
493
539
  "paginationWidth": {},
494
540
  "paginationWrapped": {},
495
541
  "totalPages": {},
@@ -530,6 +576,21 @@ export class PaginationBar {
530
576
  }];
531
577
  }
532
578
  static get elementRef() { return "el"; }
579
+ static get watchers() {
580
+ return [{
581
+ "propName": "itemLabel",
582
+ "methodName": "watchItemLabelHandler"
583
+ }, {
584
+ "propName": "itemsPerPageOptions",
585
+ "methodName": "watchItemsPerPageOptionsHandler"
586
+ }, {
587
+ "propName": "pageLabel",
588
+ "methodName": "watchPageLabelHandler"
589
+ }, {
590
+ "propName": "totalItems",
591
+ "methodName": "watchTotalItemsHandler"
592
+ }];
593
+ }
533
594
  static get listeners() {
534
595
  return [{
535
596
  "name": "icPageChange",