@ukic/canary-web-components 3.0.0-canary.1 → 3.0.0-canary.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (522) hide show
  1. package/dist/cjs/core.cjs.js +1 -1
  2. package/dist/cjs/ic-accordion.cjs.entry.js +1 -1
  3. package/dist/cjs/ic-accordion.cjs.entry.js.map +1 -1
  4. package/dist/cjs/ic-alert.cjs.entry.js +1 -1
  5. package/dist/cjs/ic-alert.cjs.entry.js.map +1 -1
  6. package/dist/cjs/ic-badge.cjs.entry.js +1 -1
  7. package/dist/cjs/ic-badge.cjs.entry.js.map +1 -1
  8. package/dist/cjs/ic-breadcrumb.cjs.entry.js +1 -1
  9. package/dist/cjs/ic-breadcrumb.cjs.entry.js.map +1 -1
  10. package/dist/cjs/ic-button_3.cjs.entry.js +16 -15
  11. package/dist/cjs/ic-button_3.cjs.entry.js.map +1 -1
  12. package/dist/cjs/ic-card-horizontal.cjs.entry.js +1 -1
  13. package/dist/cjs/ic-card-horizontal.cjs.entry.js.map +1 -1
  14. package/dist/cjs/ic-card-vertical.cjs.entry.js +1 -1
  15. package/dist/cjs/ic-card-vertical.cjs.entry.js.map +1 -1
  16. package/dist/cjs/ic-checkbox-group.cjs.entry.js +1 -1
  17. package/dist/cjs/ic-checkbox-group.cjs.entry.js.map +1 -1
  18. package/dist/cjs/ic-checkbox.cjs.entry.js +1 -1
  19. package/dist/cjs/ic-checkbox.cjs.entry.js.map +1 -1
  20. package/dist/cjs/ic-chip.cjs.entry.js +20 -13
  21. package/dist/cjs/ic-chip.cjs.entry.js.map +1 -1
  22. package/dist/cjs/ic-classification-banner.cjs.entry.js +1 -1
  23. package/dist/cjs/ic-classification-banner.cjs.entry.js.map +1 -1
  24. package/dist/cjs/ic-data-table-title-bar.cjs.entry.js +1 -1
  25. package/dist/cjs/ic-data-table-title-bar.cjs.entry.js.map +1 -1
  26. package/dist/cjs/ic-data-table.cjs.entry.js +8 -6
  27. package/dist/cjs/ic-data-table.cjs.entry.js.map +1 -1
  28. package/dist/cjs/ic-date-input.cjs.entry.js +1 -1
  29. package/dist/cjs/ic-date-input.cjs.entry.js.map +1 -1
  30. package/dist/cjs/ic-date-picker.cjs.entry.js +1 -1
  31. package/dist/cjs/ic-date-picker.cjs.entry.js.map +1 -1
  32. package/dist/cjs/ic-divider.cjs.entry.js +1 -1
  33. package/dist/cjs/ic-divider.cjs.entry.js.map +1 -1
  34. package/dist/cjs/ic-empty-state_2.cjs.entry.js +15 -9
  35. package/dist/cjs/ic-empty-state_2.cjs.entry.js.map +1 -1
  36. package/dist/cjs/ic-footer-link-group.cjs.entry.js +1 -1
  37. package/dist/cjs/ic-footer-link-group.cjs.entry.js.map +1 -1
  38. package/dist/cjs/ic-footer-link.cjs.entry.js +1 -1
  39. package/dist/cjs/ic-footer-link.cjs.entry.js.map +1 -1
  40. package/dist/cjs/ic-footer.cjs.entry.js +1 -1
  41. package/dist/cjs/ic-footer.cjs.entry.js.map +1 -1
  42. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js +1 -1
  43. package/dist/cjs/ic-horizontal-scroll.cjs.entry.js.map +1 -1
  44. package/dist/cjs/ic-input-component-container_4.cjs.entry.js +3 -3
  45. package/dist/cjs/ic-input-component-container_4.cjs.entry.js.map +1 -1
  46. package/dist/cjs/ic-link.cjs.entry.js +1 -1
  47. package/dist/cjs/ic-link.cjs.entry.js.map +1 -1
  48. package/dist/cjs/ic-menu-group.cjs.entry.js +1 -1
  49. package/dist/cjs/ic-menu-group.cjs.entry.js.map +1 -1
  50. package/dist/cjs/ic-menu-item.cjs.entry.js +1 -1
  51. package/dist/cjs/ic-menu-item.cjs.entry.js.map +1 -1
  52. package/dist/cjs/ic-menu-with-multi.cjs.entry.js +1 -1
  53. package/dist/cjs/ic-menu-with-multi.cjs.entry.js.map +1 -1
  54. package/dist/cjs/ic-menu.cjs.entry.js +1 -1
  55. package/dist/cjs/ic-menu.cjs.entry.js.map +1 -1
  56. package/dist/cjs/ic-navigation-group.cjs.entry.js +1 -1
  57. package/dist/cjs/ic-navigation-group.cjs.entry.js.map +1 -1
  58. package/dist/cjs/ic-navigation-item.cjs.entry.js +1 -1
  59. package/dist/cjs/ic-navigation-item.cjs.entry.js.map +1 -1
  60. package/dist/cjs/ic-navigation-menu.cjs.entry.js +1 -1
  61. package/dist/cjs/ic-navigation-menu.cjs.entry.js.map +1 -1
  62. package/dist/cjs/ic-pagination_4.cjs.entry.js +6 -6
  63. package/dist/cjs/ic-pagination_4.cjs.entry.js.map +1 -1
  64. package/dist/cjs/ic-popover-menu.cjs.entry.js +19 -13
  65. package/dist/cjs/ic-popover-menu.cjs.entry.js.map +1 -1
  66. package/dist/cjs/ic-radio-group.cjs.entry.js +18 -8
  67. package/dist/cjs/ic-radio-group.cjs.entry.js.map +1 -1
  68. package/dist/cjs/ic-radio-option.cjs.entry.js +1 -1
  69. package/dist/cjs/ic-radio-option.cjs.entry.js.map +1 -1
  70. package/dist/cjs/ic-search-bar.cjs.entry.js +11 -24
  71. package/dist/cjs/ic-search-bar.cjs.entry.js.map +1 -1
  72. package/dist/cjs/ic-select-with-multi.cjs.entry.js +1 -1
  73. package/dist/cjs/ic-select-with-multi.cjs.entry.js.map +1 -1
  74. package/dist/cjs/ic-side-navigation.cjs.entry.js +1 -1
  75. package/dist/cjs/ic-side-navigation.cjs.entry.js.map +1 -1
  76. package/dist/cjs/ic-skeleton.cjs.entry.js +4 -4
  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 +3 -4
  81. package/dist/cjs/ic-step.cjs.entry.js.map +1 -1
  82. package/dist/cjs/ic-stepper.cjs.entry.js +11 -1
  83. package/dist/cjs/ic-stepper.cjs.entry.js.map +1 -1
  84. package/dist/cjs/ic-switch.cjs.entry.js +1 -1
  85. package/dist/cjs/ic-switch.cjs.entry.js.map +1 -1
  86. package/dist/cjs/ic-tab-context.cjs.entry.js +58 -122
  87. package/dist/cjs/ic-tab-context.cjs.entry.js.map +1 -1
  88. package/dist/cjs/ic-tab-panel.cjs.entry.js +1 -1
  89. package/dist/cjs/ic-tab-panel.cjs.entry.js.map +1 -1
  90. package/dist/cjs/ic-tab.cjs.entry.js +5 -6
  91. package/dist/cjs/ic-tab.cjs.entry.js.map +1 -1
  92. package/dist/cjs/ic-toast.cjs.entry.js +2 -2
  93. package/dist/cjs/ic-toast.cjs.entry.js.map +1 -1
  94. package/dist/cjs/ic-toggle-button.cjs.entry.js +1 -1
  95. package/dist/cjs/ic-toggle-button.cjs.entry.js.map +1 -1
  96. package/dist/cjs/ic-top-navigation.cjs.entry.js +1 -1
  97. package/dist/cjs/ic-top-navigation.cjs.entry.js.map +1 -1
  98. package/dist/cjs/ic-tree-item.cjs.entry.js +1 -1
  99. package/dist/cjs/ic-tree-item.cjs.entry.js.map +1 -1
  100. package/dist/cjs/ic-typography.cjs.entry.js +4 -2
  101. package/dist/cjs/ic-typography.cjs.entry.js.map +1 -1
  102. package/dist/cjs/loader.cjs.js +1 -1
  103. package/dist/collection/components/ic-card-horizontal/ic-card-horizontal.css +8 -8
  104. package/dist/collection/components/ic-data-table/ic-data-table.css +20 -4
  105. package/dist/collection/components/ic-data-table/ic-data-table.js +11 -9
  106. package/dist/collection/components/ic-data-table/ic-data-table.js.map +1 -1
  107. package/dist/collection/components/ic-data-table/story-data.js +46 -5
  108. package/dist/collection/components/ic-data-table/story-data.js.map +1 -1
  109. package/dist/collection/components/ic-data-table-title-bar/ic-data-table-title-bar.css +3 -3
  110. package/dist/collection/components/ic-date-input/ic-date-input.css +3 -3
  111. package/dist/collection/components/ic-date-picker/ic-date-picker.css +6 -6
  112. package/dist/collection/components/ic-menu-with-multi/ic-menu.css +9 -9
  113. package/dist/collection/components/ic-pagination-bar/ic-pagination-bar.js +46 -14
  114. package/dist/collection/components/ic-pagination-bar/ic-pagination-bar.js.map +1 -1
  115. package/dist/collection/components/ic-pagination-bar/ic-pagination-bar.types.js +2 -0
  116. package/dist/collection/components/ic-pagination-bar/ic-pagination-bar.types.js.map +1 -0
  117. package/dist/collection/components/ic-pagination-bar/test/basic/ic-pagination-bar.spec.js +20 -2
  118. package/dist/collection/components/ic-pagination-bar/test/basic/ic-pagination-bar.spec.js.map +1 -1
  119. package/dist/collection/components/ic-select-with-multi/ic-select.css +7 -7
  120. package/dist/collection/components/ic-tree-item/ic-tree-item.css +2 -2
  121. package/dist/components/ic-accordion.js +1 -1
  122. package/dist/components/ic-accordion.js.map +1 -1
  123. package/dist/components/ic-alert.js +1 -1
  124. package/dist/components/ic-alert.js.map +1 -1
  125. package/dist/components/ic-badge.js +1 -1
  126. package/dist/components/ic-badge.js.map +1 -1
  127. package/dist/components/ic-breadcrumb2.js +1 -1
  128. package/dist/components/ic-breadcrumb2.js.map +1 -1
  129. package/dist/components/ic-button2.js +6 -7
  130. package/dist/components/ic-button2.js.map +1 -1
  131. package/dist/components/ic-card-horizontal.js +1 -1
  132. package/dist/components/ic-card-horizontal.js.map +1 -1
  133. package/dist/components/ic-card-vertical.js +1 -1
  134. package/dist/components/ic-card-vertical.js.map +1 -1
  135. package/dist/components/ic-checkbox-group.js +1 -1
  136. package/dist/components/ic-checkbox-group.js.map +1 -1
  137. package/dist/components/ic-checkbox.js +1 -1
  138. package/dist/components/ic-checkbox.js.map +1 -1
  139. package/dist/components/ic-chip.js +23 -14
  140. package/dist/components/ic-chip.js.map +1 -1
  141. package/dist/components/ic-classification-banner.js +1 -1
  142. package/dist/components/ic-classification-banner.js.map +1 -1
  143. package/dist/components/ic-data-table-title-bar.js +1 -1
  144. package/dist/components/ic-data-table-title-bar.js.map +1 -1
  145. package/dist/components/ic-data-table.js +8 -6
  146. package/dist/components/ic-data-table.js.map +1 -1
  147. package/dist/components/ic-date-input2.js +1 -1
  148. package/dist/components/ic-date-input2.js.map +1 -1
  149. package/dist/components/ic-date-picker.js +1 -1
  150. package/dist/components/ic-date-picker.js.map +1 -1
  151. package/dist/components/ic-divider2.js +1 -1
  152. package/dist/components/ic-divider2.js.map +1 -1
  153. package/dist/components/ic-footer-link-group.js +1 -1
  154. package/dist/components/ic-footer-link-group.js.map +1 -1
  155. package/dist/components/ic-footer-link.js +1 -1
  156. package/dist/components/ic-footer-link.js.map +1 -1
  157. package/dist/components/ic-footer.js +1 -1
  158. package/dist/components/ic-footer.js.map +1 -1
  159. package/dist/components/ic-horizontal-scroll2.js +1 -1
  160. package/dist/components/ic-horizontal-scroll2.js.map +1 -1
  161. package/dist/components/ic-input-component-container2.js +1 -1
  162. package/dist/components/ic-input-component-container2.js.map +1 -1
  163. package/dist/components/ic-input-label2.js +1 -1
  164. package/dist/components/ic-input-label2.js.map +1 -1
  165. package/dist/components/ic-input-validation2.js +1 -1
  166. package/dist/components/ic-input-validation2.js.map +1 -1
  167. package/dist/components/ic-link2.js +1 -1
  168. package/dist/components/ic-link2.js.map +1 -1
  169. package/dist/components/ic-loading-indicator2.js +11 -9
  170. package/dist/components/ic-loading-indicator2.js.map +1 -1
  171. package/dist/components/ic-menu-group.js +1 -1
  172. package/dist/components/ic-menu-group.js.map +1 -1
  173. package/dist/components/ic-menu-item2.js +1 -1
  174. package/dist/components/ic-menu-item2.js.map +1 -1
  175. package/dist/components/ic-menu2.js +1 -1
  176. package/dist/components/ic-menu2.js.map +1 -1
  177. package/dist/components/ic-menu3.js +1 -1
  178. package/dist/components/ic-menu3.js.map +1 -1
  179. package/dist/components/ic-navigation-group.js +1 -1
  180. package/dist/components/ic-navigation-group.js.map +1 -1
  181. package/dist/components/ic-navigation-item.js +1 -1
  182. package/dist/components/ic-navigation-item.js.map +1 -1
  183. package/dist/components/ic-navigation-menu2.js +1 -1
  184. package/dist/components/ic-navigation-menu2.js.map +1 -1
  185. package/dist/components/ic-pagination-bar2.js +18 -10
  186. package/dist/components/ic-pagination-bar2.js.map +1 -1
  187. package/dist/components/ic-pagination-item2.js +1 -1
  188. package/dist/components/ic-pagination-item2.js.map +1 -1
  189. package/dist/components/ic-popover-menu.js +21 -14
  190. package/dist/components/ic-popover-menu.js.map +1 -1
  191. package/dist/components/ic-radio-group.js +18 -8
  192. package/dist/components/ic-radio-group.js.map +1 -1
  193. package/dist/components/ic-radio-option.js +1 -1
  194. package/dist/components/ic-radio-option.js.map +1 -1
  195. package/dist/components/ic-search-bar.js +11 -24
  196. package/dist/components/ic-search-bar.js.map +1 -1
  197. package/dist/components/ic-select-with-multi.js +1 -1
  198. package/dist/components/ic-select-with-multi.js.map +1 -1
  199. package/dist/components/ic-select2.js +3 -3
  200. package/dist/components/ic-select2.js.map +1 -1
  201. package/dist/components/ic-side-navigation.js +1 -1
  202. package/dist/components/ic-side-navigation.js.map +1 -1
  203. package/dist/components/ic-skeleton.js +5 -5
  204. package/dist/components/ic-skeleton.js.map +1 -1
  205. package/dist/components/ic-status-tag.js +1 -1
  206. package/dist/components/ic-status-tag.js.map +1 -1
  207. package/dist/components/ic-step.js +4 -4
  208. package/dist/components/ic-step.js.map +1 -1
  209. package/dist/components/ic-stepper.js +13 -2
  210. package/dist/components/ic-stepper.js.map +1 -1
  211. package/dist/components/ic-switch.js +1 -1
  212. package/dist/components/ic-switch.js.map +1 -1
  213. package/dist/components/ic-tab-context.js +58 -122
  214. package/dist/components/ic-tab-context.js.map +1 -1
  215. package/dist/components/ic-tab-panel.js +1 -1
  216. package/dist/components/ic-tab-panel.js.map +1 -1
  217. package/dist/components/ic-tab.js +5 -6
  218. package/dist/components/ic-tab.js.map +1 -1
  219. package/dist/components/ic-text-field2.js +2 -2
  220. package/dist/components/ic-text-field2.js.map +1 -1
  221. package/dist/components/ic-toast.js +2 -2
  222. package/dist/components/ic-toast.js.map +1 -1
  223. package/dist/components/ic-toggle-button.js +1 -1
  224. package/dist/components/ic-toggle-button.js.map +1 -1
  225. package/dist/components/ic-tooltip2.js +1 -1
  226. package/dist/components/ic-tooltip2.js.map +1 -1
  227. package/dist/components/ic-top-navigation.js +1 -1
  228. package/dist/components/ic-top-navigation.js.map +1 -1
  229. package/dist/components/ic-tree-item.js +1 -1
  230. package/dist/components/ic-tree-item.js.map +1 -1
  231. package/dist/components/ic-typography2.js +4 -2
  232. package/dist/components/ic-typography2.js.map +1 -1
  233. package/dist/core/core.css +91 -37
  234. package/dist/core/core.esm.js +1 -1
  235. package/dist/core/core.esm.js.map +1 -1
  236. package/dist/core/p-0894cab1.entry.js +2 -0
  237. package/dist/core/p-0894cab1.entry.js.map +1 -0
  238. package/dist/core/{p-266341f5.entry.js → p-0ab10600.entry.js} +2 -2
  239. package/dist/core/{p-266341f5.entry.js.map → p-0ab10600.entry.js.map} +1 -1
  240. package/dist/core/{p-108a9029.entry.js → p-1109636a.entry.js} +2 -2
  241. package/dist/core/p-1109636a.entry.js.map +1 -0
  242. package/dist/core/p-130a05cf.entry.js +2 -0
  243. package/dist/core/p-130a05cf.entry.js.map +1 -0
  244. package/dist/core/{p-a91340b4.entry.js → p-1e2aa8a6.entry.js} +2 -2
  245. package/dist/core/p-1e2aa8a6.entry.js.map +1 -0
  246. package/dist/core/{p-306def43.entry.js → p-1fe35de1.entry.js} +2 -2
  247. package/dist/core/p-1fe35de1.entry.js.map +1 -0
  248. package/dist/core/p-28323849.entry.js +2 -0
  249. package/dist/core/p-28323849.entry.js.map +1 -0
  250. package/dist/core/p-2e49fb22.entry.js +2 -0
  251. package/dist/core/p-2e49fb22.entry.js.map +1 -0
  252. package/dist/core/p-2ff4e283.entry.js +2 -0
  253. package/dist/core/p-2ff4e283.entry.js.map +1 -0
  254. package/dist/core/p-3db785f0.entry.js +2 -0
  255. package/dist/core/p-3db785f0.entry.js.map +1 -0
  256. package/dist/core/p-42883e4c.entry.js +2 -0
  257. package/dist/core/p-42883e4c.entry.js.map +1 -0
  258. package/dist/core/p-42e0f3bd.entry.js +2 -0
  259. package/dist/core/p-42e0f3bd.entry.js.map +1 -0
  260. package/dist/core/p-44ee5375.entry.js +2 -0
  261. package/dist/core/p-44ee5375.entry.js.map +1 -0
  262. package/dist/core/{p-c21d0db8.entry.js → p-486d8d43.entry.js} +2 -2
  263. package/dist/core/p-486d8d43.entry.js.map +1 -0
  264. package/dist/core/{p-f743b0eb.entry.js → p-4dcc37e7.entry.js} +2 -2
  265. package/dist/core/{p-f743b0eb.entry.js.map → p-4dcc37e7.entry.js.map} +1 -1
  266. package/dist/core/{p-bf670360.entry.js → p-4e28ef60.entry.js} +2 -2
  267. package/dist/core/{p-bf670360.entry.js.map → p-4e28ef60.entry.js.map} +1 -1
  268. package/dist/core/{p-d8563643.entry.js → p-50019ede.entry.js} +2 -2
  269. package/dist/core/p-50019ede.entry.js.map +1 -0
  270. package/dist/core/p-53e00a8a.entry.js +2 -0
  271. package/dist/core/p-53e00a8a.entry.js.map +1 -0
  272. package/dist/core/p-5accf0bb.entry.js +2 -0
  273. package/dist/core/p-5accf0bb.entry.js.map +1 -0
  274. package/dist/core/p-5b7dfe57.entry.js +2 -0
  275. package/dist/core/p-5b7dfe57.entry.js.map +1 -0
  276. package/dist/core/p-603fea14.entry.js +2 -0
  277. package/dist/core/p-603fea14.entry.js.map +1 -0
  278. package/dist/core/p-64933069.entry.js +2 -0
  279. package/dist/core/p-64933069.entry.js.map +1 -0
  280. package/dist/core/{p-f98b1afc.entry.js → p-6beffd0e.entry.js} +2 -2
  281. package/dist/core/{p-f98b1afc.entry.js.map → p-6beffd0e.entry.js.map} +1 -1
  282. package/dist/core/p-7c268030.entry.js +2 -0
  283. package/dist/core/p-7c268030.entry.js.map +1 -0
  284. package/dist/core/p-7c78f6c6.entry.js +2 -0
  285. package/dist/core/p-7c78f6c6.entry.js.map +1 -0
  286. package/dist/core/p-7c80d79c.entry.js +2 -0
  287. package/dist/core/{p-aee8d45b.entry.js.map → p-7c80d79c.entry.js.map} +1 -1
  288. package/dist/core/{p-5f5403e2.entry.js → p-7e1603cc.entry.js} +2 -2
  289. package/dist/core/p-7e1603cc.entry.js.map +1 -0
  290. package/dist/core/p-8ca2e329.entry.js +2 -0
  291. package/dist/core/p-8ca2e329.entry.js.map +1 -0
  292. package/dist/core/p-8df49808.entry.js +2 -0
  293. package/dist/core/p-8df49808.entry.js.map +1 -0
  294. package/dist/core/p-8f12659d.entry.js +2 -0
  295. package/dist/core/p-8f12659d.entry.js.map +1 -0
  296. package/dist/core/p-903ee57e.entry.js +2 -0
  297. package/dist/core/p-903ee57e.entry.js.map +1 -0
  298. package/dist/core/p-92e3ccb9.entry.js +2 -0
  299. package/dist/core/p-92e3ccb9.entry.js.map +1 -0
  300. package/dist/core/p-a9151d0b.entry.js +2 -0
  301. package/dist/core/p-a9151d0b.entry.js.map +1 -0
  302. package/dist/core/p-acc76b80.entry.js +2 -0
  303. package/dist/core/p-acc76b80.entry.js.map +1 -0
  304. package/dist/core/p-aeb6016c.entry.js +2 -0
  305. package/dist/core/p-aeb6016c.entry.js.map +1 -0
  306. package/dist/core/p-b0751bd9.entry.js +2 -0
  307. package/dist/core/p-b0751bd9.entry.js.map +1 -0
  308. package/dist/core/{p-5f313e1a.entry.js → p-bb1252fa.entry.js} +2 -2
  309. package/dist/core/{p-5f313e1a.entry.js.map → p-bb1252fa.entry.js.map} +1 -1
  310. package/dist/core/p-c1698936.entry.js +2 -0
  311. package/dist/core/p-c1698936.entry.js.map +1 -0
  312. package/dist/core/p-c1e90c85.entry.js +2 -0
  313. package/dist/core/p-c1e90c85.entry.js.map +1 -0
  314. package/dist/core/p-cb63e656.entry.js +2 -0
  315. package/dist/core/p-cb63e656.entry.js.map +1 -0
  316. package/dist/core/{p-cb6cebdd.entry.js → p-d2e7a256.entry.js} +2 -2
  317. package/dist/core/{p-cb6cebdd.entry.js.map → p-d2e7a256.entry.js.map} +1 -1
  318. package/dist/core/p-d3c0bffb.entry.js +2 -0
  319. package/dist/core/p-d3c0bffb.entry.js.map +1 -0
  320. package/dist/core/p-d5ca3bcb.entry.js +2 -0
  321. package/dist/core/p-d5ca3bcb.entry.js.map +1 -0
  322. package/dist/core/p-da3e8c54.entry.js +2 -0
  323. package/dist/core/p-da3e8c54.entry.js.map +1 -0
  324. package/dist/core/{p-73b40c79.entry.js → p-eb65e556.entry.js} +2 -2
  325. package/dist/core/{p-73b40c79.entry.js.map → p-eb65e556.entry.js.map} +1 -1
  326. package/dist/core/p-ec53b435.entry.js +2 -0
  327. package/dist/core/p-ec53b435.entry.js.map +1 -0
  328. package/dist/core/p-ed4cde5a.entry.js +2 -0
  329. package/dist/core/p-ed4cde5a.entry.js.map +1 -0
  330. package/dist/core/{p-f1072c28.entry.js → p-f64abdff.entry.js} +2 -2
  331. package/dist/core/p-f64abdff.entry.js.map +1 -0
  332. package/dist/core/p-f9810621.entry.js +2 -0
  333. package/dist/core/p-f9810621.entry.js.map +1 -0
  334. package/dist/core/p-fb7b99dd.entry.js +2 -0
  335. package/dist/core/p-fb7b99dd.entry.js.map +1 -0
  336. package/dist/esm/core.js +1 -1
  337. package/dist/esm/ic-accordion.entry.js +1 -1
  338. package/dist/esm/ic-accordion.entry.js.map +1 -1
  339. package/dist/esm/ic-alert.entry.js +1 -1
  340. package/dist/esm/ic-alert.entry.js.map +1 -1
  341. package/dist/esm/ic-badge.entry.js +1 -1
  342. package/dist/esm/ic-badge.entry.js.map +1 -1
  343. package/dist/esm/ic-breadcrumb.entry.js +1 -1
  344. package/dist/esm/ic-breadcrumb.entry.js.map +1 -1
  345. package/dist/esm/ic-button_3.entry.js +16 -15
  346. package/dist/esm/ic-button_3.entry.js.map +1 -1
  347. package/dist/esm/ic-card-horizontal.entry.js +1 -1
  348. package/dist/esm/ic-card-horizontal.entry.js.map +1 -1
  349. package/dist/esm/ic-card-vertical.entry.js +1 -1
  350. package/dist/esm/ic-card-vertical.entry.js.map +1 -1
  351. package/dist/esm/ic-checkbox-group.entry.js +1 -1
  352. package/dist/esm/ic-checkbox-group.entry.js.map +1 -1
  353. package/dist/esm/ic-checkbox.entry.js +1 -1
  354. package/dist/esm/ic-checkbox.entry.js.map +1 -1
  355. package/dist/esm/ic-chip.entry.js +21 -14
  356. package/dist/esm/ic-chip.entry.js.map +1 -1
  357. package/dist/esm/ic-classification-banner.entry.js +1 -1
  358. package/dist/esm/ic-classification-banner.entry.js.map +1 -1
  359. package/dist/esm/ic-data-table-title-bar.entry.js +1 -1
  360. package/dist/esm/ic-data-table-title-bar.entry.js.map +1 -1
  361. package/dist/esm/ic-data-table.entry.js +8 -6
  362. package/dist/esm/ic-data-table.entry.js.map +1 -1
  363. package/dist/esm/ic-date-input.entry.js +1 -1
  364. package/dist/esm/ic-date-input.entry.js.map +1 -1
  365. package/dist/esm/ic-date-picker.entry.js +1 -1
  366. package/dist/esm/ic-date-picker.entry.js.map +1 -1
  367. package/dist/esm/ic-divider.entry.js +1 -1
  368. package/dist/esm/ic-divider.entry.js.map +1 -1
  369. package/dist/esm/ic-empty-state_2.entry.js +15 -9
  370. package/dist/esm/ic-empty-state_2.entry.js.map +1 -1
  371. package/dist/esm/ic-footer-link-group.entry.js +1 -1
  372. package/dist/esm/ic-footer-link-group.entry.js.map +1 -1
  373. package/dist/esm/ic-footer-link.entry.js +1 -1
  374. package/dist/esm/ic-footer-link.entry.js.map +1 -1
  375. package/dist/esm/ic-footer.entry.js +1 -1
  376. package/dist/esm/ic-footer.entry.js.map +1 -1
  377. package/dist/esm/ic-horizontal-scroll.entry.js +1 -1
  378. package/dist/esm/ic-horizontal-scroll.entry.js.map +1 -1
  379. package/dist/esm/ic-input-component-container_4.entry.js +3 -3
  380. package/dist/esm/ic-input-component-container_4.entry.js.map +1 -1
  381. package/dist/esm/ic-link.entry.js +1 -1
  382. package/dist/esm/ic-link.entry.js.map +1 -1
  383. package/dist/esm/ic-menu-group.entry.js +1 -1
  384. package/dist/esm/ic-menu-group.entry.js.map +1 -1
  385. package/dist/esm/ic-menu-item.entry.js +1 -1
  386. package/dist/esm/ic-menu-item.entry.js.map +1 -1
  387. package/dist/esm/ic-menu-with-multi.entry.js +1 -1
  388. package/dist/esm/ic-menu-with-multi.entry.js.map +1 -1
  389. package/dist/esm/ic-menu.entry.js +1 -1
  390. package/dist/esm/ic-menu.entry.js.map +1 -1
  391. package/dist/esm/ic-navigation-group.entry.js +1 -1
  392. package/dist/esm/ic-navigation-group.entry.js.map +1 -1
  393. package/dist/esm/ic-navigation-item.entry.js +1 -1
  394. package/dist/esm/ic-navigation-item.entry.js.map +1 -1
  395. package/dist/esm/ic-navigation-menu.entry.js +1 -1
  396. package/dist/esm/ic-navigation-menu.entry.js.map +1 -1
  397. package/dist/esm/ic-pagination_4.entry.js +6 -6
  398. package/dist/esm/ic-pagination_4.entry.js.map +1 -1
  399. package/dist/esm/ic-popover-menu.entry.js +19 -13
  400. package/dist/esm/ic-popover-menu.entry.js.map +1 -1
  401. package/dist/esm/ic-radio-group.entry.js +18 -8
  402. package/dist/esm/ic-radio-group.entry.js.map +1 -1
  403. package/dist/esm/ic-radio-option.entry.js +1 -1
  404. package/dist/esm/ic-radio-option.entry.js.map +1 -1
  405. package/dist/esm/ic-search-bar.entry.js +11 -24
  406. package/dist/esm/ic-search-bar.entry.js.map +1 -1
  407. package/dist/esm/ic-select-with-multi.entry.js +1 -1
  408. package/dist/esm/ic-select-with-multi.entry.js.map +1 -1
  409. package/dist/esm/ic-side-navigation.entry.js +1 -1
  410. package/dist/esm/ic-side-navigation.entry.js.map +1 -1
  411. package/dist/esm/ic-skeleton.entry.js +4 -4
  412. package/dist/esm/ic-skeleton.entry.js.map +1 -1
  413. package/dist/esm/ic-status-tag.entry.js +1 -1
  414. package/dist/esm/ic-status-tag.entry.js.map +1 -1
  415. package/dist/esm/ic-step.entry.js +3 -4
  416. package/dist/esm/ic-step.entry.js.map +1 -1
  417. package/dist/esm/ic-stepper.entry.js +11 -1
  418. package/dist/esm/ic-stepper.entry.js.map +1 -1
  419. package/dist/esm/ic-switch.entry.js +1 -1
  420. package/dist/esm/ic-switch.entry.js.map +1 -1
  421. package/dist/esm/ic-tab-context.entry.js +58 -122
  422. package/dist/esm/ic-tab-context.entry.js.map +1 -1
  423. package/dist/esm/ic-tab-panel.entry.js +1 -1
  424. package/dist/esm/ic-tab-panel.entry.js.map +1 -1
  425. package/dist/esm/ic-tab.entry.js +5 -6
  426. package/dist/esm/ic-tab.entry.js.map +1 -1
  427. package/dist/esm/ic-toast.entry.js +2 -2
  428. package/dist/esm/ic-toast.entry.js.map +1 -1
  429. package/dist/esm/ic-toggle-button.entry.js +1 -1
  430. package/dist/esm/ic-toggle-button.entry.js.map +1 -1
  431. package/dist/esm/ic-top-navigation.entry.js +1 -1
  432. package/dist/esm/ic-top-navigation.entry.js.map +1 -1
  433. package/dist/esm/ic-tree-item.entry.js +1 -1
  434. package/dist/esm/ic-tree-item.entry.js.map +1 -1
  435. package/dist/esm/ic-typography.entry.js +4 -2
  436. package/dist/esm/ic-typography.entry.js.map +1 -1
  437. package/dist/esm/loader.js +1 -1
  438. package/dist/types/components/ic-data-table/ic-data-table.d.ts +2 -0
  439. package/dist/types/components/ic-data-table/story-data.d.ts +15 -0
  440. package/dist/types/components/ic-pagination-bar/ic-pagination-bar.d.ts +9 -4
  441. package/dist/types/components/ic-pagination-bar/ic-pagination-bar.types.d.ts +4 -0
  442. package/dist/types/components.d.ts +17 -3
  443. package/hydrate/index.js +248 -277
  444. package/package.json +3 -3
  445. package/dist/core/p-06eeb7f2.entry.js +0 -2
  446. package/dist/core/p-06eeb7f2.entry.js.map +0 -1
  447. package/dist/core/p-0922c552.entry.js +0 -2
  448. package/dist/core/p-0922c552.entry.js.map +0 -1
  449. package/dist/core/p-0bc0e852.entry.js +0 -2
  450. package/dist/core/p-0bc0e852.entry.js.map +0 -1
  451. package/dist/core/p-108a9029.entry.js.map +0 -1
  452. package/dist/core/p-13100d3c.entry.js +0 -2
  453. package/dist/core/p-13100d3c.entry.js.map +0 -1
  454. package/dist/core/p-1769df1d.entry.js +0 -2
  455. package/dist/core/p-1769df1d.entry.js.map +0 -1
  456. package/dist/core/p-306def43.entry.js.map +0 -1
  457. package/dist/core/p-3778cc5e.entry.js +0 -2
  458. package/dist/core/p-3778cc5e.entry.js.map +0 -1
  459. package/dist/core/p-383a5a76.entry.js +0 -2
  460. package/dist/core/p-383a5a76.entry.js.map +0 -1
  461. package/dist/core/p-3a0510e2.entry.js +0 -2
  462. package/dist/core/p-3a0510e2.entry.js.map +0 -1
  463. package/dist/core/p-3ace51f5.entry.js +0 -2
  464. package/dist/core/p-3ace51f5.entry.js.map +0 -1
  465. package/dist/core/p-3f0391c1.entry.js +0 -2
  466. package/dist/core/p-3f0391c1.entry.js.map +0 -1
  467. package/dist/core/p-41fecc61.entry.js +0 -2
  468. package/dist/core/p-41fecc61.entry.js.map +0 -1
  469. package/dist/core/p-46cb94a2.entry.js +0 -2
  470. package/dist/core/p-46cb94a2.entry.js.map +0 -1
  471. package/dist/core/p-4e67f127.entry.js +0 -2
  472. package/dist/core/p-4e67f127.entry.js.map +0 -1
  473. package/dist/core/p-50e48f4d.entry.js +0 -2
  474. package/dist/core/p-50e48f4d.entry.js.map +0 -1
  475. package/dist/core/p-56e7459a.entry.js +0 -2
  476. package/dist/core/p-56e7459a.entry.js.map +0 -1
  477. package/dist/core/p-5e6fd734.entry.js +0 -2
  478. package/dist/core/p-5e6fd734.entry.js.map +0 -1
  479. package/dist/core/p-5f5403e2.entry.js.map +0 -1
  480. package/dist/core/p-710c6a42.entry.js +0 -2
  481. package/dist/core/p-710c6a42.entry.js.map +0 -1
  482. package/dist/core/p-7a9de008.entry.js +0 -2
  483. package/dist/core/p-7a9de008.entry.js.map +0 -1
  484. package/dist/core/p-801414e2.entry.js +0 -2
  485. package/dist/core/p-801414e2.entry.js.map +0 -1
  486. package/dist/core/p-82ba744d.entry.js +0 -2
  487. package/dist/core/p-82ba744d.entry.js.map +0 -1
  488. package/dist/core/p-9af6adb1.entry.js +0 -2
  489. package/dist/core/p-9af6adb1.entry.js.map +0 -1
  490. package/dist/core/p-a57cd616.entry.js +0 -2
  491. package/dist/core/p-a57cd616.entry.js.map +0 -1
  492. package/dist/core/p-a5eaed1a.entry.js +0 -2
  493. package/dist/core/p-a5eaed1a.entry.js.map +0 -1
  494. package/dist/core/p-a91340b4.entry.js.map +0 -1
  495. package/dist/core/p-aee8d45b.entry.js +0 -2
  496. package/dist/core/p-badd4c8d.entry.js +0 -2
  497. package/dist/core/p-badd4c8d.entry.js.map +0 -1
  498. package/dist/core/p-c07af2d8.entry.js +0 -2
  499. package/dist/core/p-c07af2d8.entry.js.map +0 -1
  500. package/dist/core/p-c21d0db8.entry.js.map +0 -1
  501. package/dist/core/p-c678f73d.entry.js +0 -2
  502. package/dist/core/p-c678f73d.entry.js.map +0 -1
  503. package/dist/core/p-c6ae9bad.entry.js +0 -2
  504. package/dist/core/p-c6ae9bad.entry.js.map +0 -1
  505. package/dist/core/p-c6c1e08e.entry.js +0 -2
  506. package/dist/core/p-c6c1e08e.entry.js.map +0 -1
  507. package/dist/core/p-d16f364a.entry.js +0 -2
  508. package/dist/core/p-d16f364a.entry.js.map +0 -1
  509. package/dist/core/p-d239c33b.entry.js +0 -2
  510. package/dist/core/p-d239c33b.entry.js.map +0 -1
  511. package/dist/core/p-d8563643.entry.js.map +0 -1
  512. package/dist/core/p-da40757f.entry.js +0 -2
  513. package/dist/core/p-da40757f.entry.js.map +0 -1
  514. package/dist/core/p-de052137.entry.js +0 -2
  515. package/dist/core/p-de052137.entry.js.map +0 -1
  516. package/dist/core/p-e89bb650.entry.js +0 -2
  517. package/dist/core/p-e89bb650.entry.js.map +0 -1
  518. package/dist/core/p-f1072c28.entry.js.map +0 -1
  519. package/dist/core/p-f37df214.entry.js +0 -2
  520. package/dist/core/p-f37df214.entry.js.map +0 -1
  521. package/dist/core/p-fe13f1ba.entry.js +0 -2
  522. package/dist/core/p-fe13f1ba.entry.js.map +0 -1
@@ -9,7 +9,7 @@ export class PaginationBar {
9
9
  this.setItemsPerPage(Number(this.pageDropdownEl.value));
10
10
  };
11
11
  this.changePage = (page) => {
12
- this.currentPage = page;
12
+ this.activePage = page;
13
13
  this.lowerBound = page !== 1 ? (page - 1) * this.itemsPerPage + 1 : page;
14
14
  this.setUpperBound();
15
15
  };
@@ -23,7 +23,7 @@ export class PaginationBar {
23
23
  if (page <= this.totalPages && page > 0) {
24
24
  this.changePage(page);
25
25
  this.paginationEl.setCurrentPage(page);
26
- this.currentPage = page;
26
+ this.activePage = page;
27
27
  input.value = "";
28
28
  this.icPageChange.emit({ value: page });
29
29
  this.pageInputTooltipEl.displayTooltip(false, false);
@@ -117,11 +117,11 @@ export class PaginationBar {
117
117
  ? Math.ceil(this.totalItems / this.itemsPerPage)
118
118
  : 1;
119
119
  this.setUpperBound();
120
- if (this.currentPage > this.totalPages) {
120
+ if (this.activePage > this.totalPages) {
121
121
  this.paginationEl.setCurrentPage(this.totalPages);
122
- this.currentPage = this.totalPages;
122
+ this.activePage = this.totalPages;
123
123
  }
124
- this.icPageChange.emit({ value: this.currentPage });
124
+ this.icPageChange.emit({ value: this.activePage, fromItemsPerPage: true });
125
125
  };
126
126
  this.setPaginationBarContent = () => {
127
127
  var _a;
@@ -156,7 +156,7 @@ export class PaginationBar {
156
156
  };
157
157
  this.capitalizedItemLabel = undefined;
158
158
  this.capitalizedPageLabel = undefined;
159
- this.currentPage = 1;
159
+ this.activePage = 1;
160
160
  this.displayedItemsPerPageOptions = undefined;
161
161
  this.inputError = "Please enter a valid page";
162
162
  this.itemsPerPage = 0;
@@ -170,6 +170,7 @@ export class PaginationBar {
170
170
  this.upperBound = undefined;
171
171
  this.alignment = "right";
172
172
  this.appearance = "default";
173
+ this.currentPage = 1;
173
174
  this.itemLabel = "Item";
174
175
  this.itemsPerPageOptions = undefined;
175
176
  this.type = "simple";
@@ -180,6 +181,9 @@ export class PaginationBar {
180
181
  this.showItemsPerPageControl = false;
181
182
  this.totalItems = undefined;
182
183
  }
184
+ watchPageNumberHandler() {
185
+ this.activePage = this.currentPage;
186
+ }
183
187
  watchItemLabelHandler() {
184
188
  this.capitalizedItemLabel = capitalize(this.itemLabel);
185
189
  this.lowerCaseItemLabel = this.itemLabel.toLowerCase();
@@ -201,6 +205,7 @@ export class PaginationBar {
201
205
  (_a = this.resizeObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
202
206
  }
203
207
  componentWillLoad() {
208
+ this.watchPageNumberHandler();
204
209
  this.watchPageLabelHandler();
205
210
  this.watchItemLabelHandler();
206
211
  this.setPaginationBarContent();
@@ -224,7 +229,7 @@ export class PaginationBar {
224
229
  this.changePage(page);
225
230
  }
226
231
  render() {
227
- const { appearance, alignment, displayedItemsPerPageOptions, PAGE_INPUT_FIELD_ID, type, rangeLabelType, hideRangeLabel, showItemsPerPageControl, showGoToPageControl, pageLabel, capitalizedPageLabel, lowerCasePageLabel, capitalizedItemLabel, lowerCaseItemLabel, totalPages, currentPage, itemsPerPageString, } = this;
232
+ const { appearance, alignment, displayedItemsPerPageOptions, PAGE_INPUT_FIELD_ID, type, rangeLabelType, hideRangeLabel, showItemsPerPageControl, showGoToPageControl, pageLabel, capitalizedPageLabel, lowerCasePageLabel, capitalizedItemLabel, lowerCaseItemLabel, totalPages, activePage, itemsPerPageString, } = this;
228
233
  return (h("div", { class: {
229
234
  ["pagination-bar"]: true,
230
235
  [`pagination-bar-${alignment}`]: true,
@@ -239,10 +244,10 @@ export class PaginationBar {
239
244
  `${this.lowerBound} - ${this.upperBound} of ${this.totalItems} ${lowerCaseItemLabel}${this.totalItems > 1 ? "s" : ""}`)) : (h("ic-typography", { class: {
240
245
  [`pagination-text-${appearance}`]: true,
241
246
  ["page-pagination-label"]: true,
242
- }, variant: "label", "aria-live": "polite" }, capitalizedPageLabel, " ", currentPage, " of ", totalPages))))), h("div", { class: {
247
+ }, variant: "label", "aria-live": "polite" }, capitalizedPageLabel, " ", activePage, " of ", totalPages))))), h("div", { class: {
243
248
  ["pagination-controls"]: true,
244
249
  ["pagination-controls-wrap"]: this.paginationWrapped,
245
- } }, 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"))))));
250
+ } }, h("div", { class: "pagination-holder" }, h("ic-pagination", { appearance: appearance, type: type, pages: totalPages, label: pageLabel, ref: (el) => (this.paginationEl = el), currentPage: activePage })), 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"))))));
246
251
  }
247
252
  static get is() { return "ic-pagination-bar"; }
248
253
  static get encapsulation() { return "shadow"; }
@@ -306,6 +311,24 @@ export class PaginationBar {
306
311
  "reflect": false,
307
312
  "defaultValue": "\"default\""
308
313
  },
314
+ "currentPage": {
315
+ "type": "number",
316
+ "mutable": false,
317
+ "complexType": {
318
+ "original": "number",
319
+ "resolved": "number",
320
+ "references": {}
321
+ },
322
+ "required": false,
323
+ "optional": true,
324
+ "docs": {
325
+ "tags": [],
326
+ "text": "The current page number to be displayed on the pagination bar."
327
+ },
328
+ "attribute": "current-page",
329
+ "reflect": false,
330
+ "defaultValue": "1"
331
+ },
309
332
  "itemLabel": {
310
333
  "type": "string",
311
334
  "mutable": false,
@@ -482,7 +505,7 @@ export class PaginationBar {
482
505
  return {
483
506
  "capitalizedItemLabel": {},
484
507
  "capitalizedPageLabel": {},
485
- "currentPage": {},
508
+ "activePage": {},
486
509
  "displayedItemsPerPageOptions": {},
487
510
  "inputError": {},
488
511
  "itemsPerPage": {},
@@ -505,12 +528,18 @@ export class PaginationBar {
505
528
  "composed": true,
506
529
  "docs": {
507
530
  "tags": [],
508
- "text": "Emitted when a page is navigated to via the 'go to' input."
531
+ "text": "Emitted when a page is navigated to via the 'go to' input.\nThe `detail` property contains `value` (i.e. the page number) and a `fromItemsPerPage` flag to indicate if the event was triggered by the `icItemsPerPageChange` event also occurring."
509
532
  },
510
533
  "complexType": {
511
- "original": "{ value: number }",
512
- "resolved": "{ value: number; }",
513
- "references": {}
534
+ "original": "IcPageChangeEventDetail",
535
+ "resolved": "IcPageChangeEventDetail",
536
+ "references": {
537
+ "IcPageChangeEventDetail": {
538
+ "location": "import",
539
+ "path": "./ic-pagination-bar.types",
540
+ "id": "src/components/ic-pagination-bar/ic-pagination-bar.types.ts::IcPageChangeEventDetail"
541
+ }
542
+ }
514
543
  }
515
544
  }, {
516
545
  "method": "icItemsPerPageChange",
@@ -532,6 +561,9 @@ export class PaginationBar {
532
561
  static get elementRef() { return "el"; }
533
562
  static get watchers() {
534
563
  return [{
564
+ "propName": "currentPage",
565
+ "methodName": "watchPageNumberHandler"
566
+ }, {
535
567
  "propName": "itemLabel",
536
568
  "methodName": "watchItemLabelHandler"
537
569
  }, {
@@ -1 +1 @@
1
- {"version":3,"file":"ic-pagination-bar.js","sourceRoot":"","sources":["../../../src/components/ic-pagination-bar/ic-pagination-bar.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\n Component,\n Prop,\n Element,\n Event,\n EventEmitter,\n State,\n Listen,\n h,\n Watch,\n} from \"@stencil/core\";\nimport { IcThemeForeground } from \"@ukic/web-components/dist/types/interface\";\nimport { checkResizeObserver, capitalize } from \"../../utils/helpers\";\nimport {\n IcPaginationAlignmentOptions,\n IcPaginationLabelTypes,\n IcPaginationTypes,\n} from \"@ukic/web-components/dist/types/components/ic-pagination/ic-pagination.types\";\n\n@Component({\n tag: \"ic-pagination-bar\",\n styleUrl: \"ic-pagination-bar.css\",\n shadow: true,\n})\nexport class PaginationBar {\n private PAGE_INPUT_FIELD_ID = \"go-to-page-input\";\n\n private INVALID_PAGE_ERROR = \"Please enter a valid page\";\n\n private resizeObserver: ResizeObserver = null;\n private pageDropdownEl: HTMLIcSelectElement;\n private pageInputEl: HTMLIcTextFieldElement;\n private pageInputTooltipEl: HTMLIcTooltipElement;\n private paginationBarEl: HTMLElement;\n private paginationEl: HTMLIcPaginationElement;\n\n @Element() el: HTMLIcPaginationBarElement;\n\n @State() capitalizedItemLabel: string;\n\n @State() capitalizedPageLabel: string;\n\n @State() currentPage: number = 1;\n\n @State() displayedItemsPerPageOptions?: {\n label: string;\n value: string;\n }[];\n\n @State() inputError: string = \"Please enter a valid page\";\n\n @State() itemsPerPage: number = 0;\n\n @State() itemsPerPageString: string = \"0\";\n\n @State() lowerBound: number = 1;\n\n @State() lowerCaseItemLabel: string;\n\n @State() lowerCasePageLabel: string;\n\n @State() paginationWidth: number;\n\n @State() paginationWrapped: boolean = false;\n\n @State() totalPages: number;\n\n @State() upperBound: number;\n\n /**\n * Sets the alignment of the items in the pagination bar.\n */\n @Prop() alignment?: IcPaginationAlignmentOptions = \"right\";\n\n /**\n * Sets the styling for the items in the pagination bar.\n */\n @Prop() appearance?: IcThemeForeground = \"default\";\n\n /**\n * The text which will be used in place of 'Item' on the pagination bar.\n */\n @Prop() itemLabel?: string = \"Item\";\n\n @Watch(\"itemLabel\")\n watchItemLabelHandler(): void {\n this.capitalizedItemLabel = capitalize(this.itemLabel);\n this.lowerCaseItemLabel = this.itemLabel.toLowerCase();\n }\n\n /**\n * 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.\n */\n @Prop() itemsPerPageOptions?: {\n label: string;\n value: string;\n }[];\n\n @Watch(\"itemsPerPageOptions\")\n watchItemsPerPageOptionsHandler(\n newVal: {\n label: string;\n value: string;\n }[],\n oldVal: {\n label: string;\n value: string;\n }[]\n ): void {\n if (JSON.stringify(newVal) === JSON.stringify(oldVal)) return;\n this.setPaginationBarContent();\n }\n\n /**\n * Whether the displayed pagination is simple or complex.\n */\n @Prop() type?: IcPaginationTypes = \"simple\";\n\n /**\n * Whether total number of items and current item range or total number of pages and current page is displayed.\n */\n @Prop() rangeLabelType?: IcPaginationLabelTypes = \"page\";\n\n /**\n * The text which will be used in place of 'Page' on the pagination bar.\n */\n @Prop() pageLabel?: string = \"Page\";\n\n @Watch(\"pageLabel\")\n watchPageLabelHandler(): void {\n this.capitalizedPageLabel = capitalize(this.pageLabel);\n this.lowerCasePageLabel = this.pageLabel.toLowerCase();\n }\n\n /**\n * If `true`, the 'go to page' control should be displayed.\n */\n @Prop() showGoToPageControl?: boolean = false;\n\n /**\n * If `true`, the number of total items and current item range or number of total pages and current page will be hidden.\n */\n @Prop() hideRangeLabel?: boolean = false;\n\n /**\n * If `true`, the select input to control 'items per page' should be displayed.\n */\n @Prop() showItemsPerPageControl?: boolean = false;\n\n /**\n * Total number of items to be displayed across all pages.\n */\n @Prop() totalItems!: number;\n\n @Watch(\"totalItems\")\n watchTotalItemsHandler(): void {\n this.setPaginationBarContent();\n }\n\n /**\n * Emitted when a page is navigated to via the 'go to' input.\n */\n @Event() icPageChange: EventEmitter<{ value: number }>;\n\n /**\n * Emitted when the items per page option is changed.\n */\n @Event() icItemsPerPageChange: EventEmitter<{ value: number }>;\n\n disconnectedCallback(): void {\n this.resizeObserver?.disconnect();\n }\n\n componentWillLoad(): void {\n this.watchPageLabelHandler();\n this.watchItemLabelHandler();\n this.setPaginationBarContent();\n }\n\n componentDidLoad(): void {\n this.paginationWidth = this.paginationBarEl.clientWidth;\n checkResizeObserver(this.runResizeObserver);\n const textField = this.el.shadowRoot?.querySelector(\n `.${this.PAGE_INPUT_FIELD_ID}`\n );\n if (textField) {\n const input = textField?.shadowRoot?.querySelector(\"input\");\n if (input) {\n input.style.textAlign = \"center\";\n input.style.padding = \"0\";\n }\n }\n this.paginationShouldWrap();\n }\n\n @Listen(\"icPageChange\")\n pageChangeHandler(ev: CustomEvent): void {\n const page = ev.detail.value;\n this.changePage(page);\n }\n\n private changeItemsPerPage = () => {\n this.setItemsPerPage(Number(this.pageDropdownEl.value));\n };\n\n private changePage = (page: number) => {\n this.currentPage = page;\n this.lowerBound = page !== 1 ? (page - 1) * this.itemsPerPage + 1 : page;\n this.setUpperBound();\n };\n\n private focusElFromLabel = (el: \"ic-select\" | \"ic-text-field\") => {\n this.paginationBarEl.querySelector(el)?.setFocus();\n };\n\n private goToPage = () => {\n const input = this.pageInputEl;\n const page = Number(input.value);\n if (page <= this.totalPages && page > 0) {\n this.changePage(page);\n this.paginationEl.setCurrentPage(page);\n this.currentPage = page;\n input.value = \"\";\n this.icPageChange.emit({ value: page });\n this.pageInputTooltipEl.displayTooltip(false, false);\n input.validationStatus = \"\";\n } else {\n this.setInputError(input, this.INVALID_PAGE_ERROR);\n }\n };\n\n private goToPageLabelClickHandler = () => {\n this.focusElFromLabel(\"ic-text-field\");\n };\n\n private handleBlur = () => {\n const textField = this.pageInputEl;\n if (\n (Number(textField.value) <= this.totalPages &&\n Number(textField.value) > 0) ||\n textField.value === \"\"\n ) {\n textField.validationStatus = \"\";\n }\n this.pageInputTooltipEl.displayTooltip(false, false);\n };\n\n private handleFocus = () => {\n if (this.pageInputEl.validationStatus === \"error\") {\n this.pageInputTooltipEl.displayTooltip(true, true);\n }\n };\n\n private handleInputChange = () => {\n const inputValue = parseInt(this.pageInputEl.value);\n\n if (inputValue > this.totalPages || inputValue <= 0) {\n this.setInputError(this.pageInputEl, this.INVALID_PAGE_ERROR);\n this.pageInputTooltipEl.displayTooltip(true, true);\n }\n };\n\n private handleKeydown = (ev: KeyboardEvent) => {\n if (ev.key === \"Enter\") {\n if (this.pageInputEl.validationStatus === \"error\") {\n this.pageInputTooltipEl.displayTooltip(true, true);\n } else {\n this.goToPage();\n }\n } else {\n this.pageInputTooltipEl.displayTooltip(false, false);\n this.pageInputEl.validationStatus = \"\";\n }\n };\n\n private handleKeyUp = (ev: KeyboardEvent) => {\n if (\n Number.isNaN(parseInt(this.pageInputEl.value)) &&\n ev.key !== \"Backspace\" &&\n ev.key !== \"Enter\" &&\n ev.key !== \"Tab\" &&\n ev.key !== \"Shift\"\n ) {\n this.setInputError(this.pageInputEl, \"Please enter a number\", false);\n this.pageInputTooltipEl.displayTooltip(true, false);\n }\n };\n\n private itemsPerPageLabelClickHandler = () => {\n this.focusElFromLabel(\"ic-select\");\n };\n\n private paginationShouldWrap = () => {\n if (this.type === \"simple\") {\n this.paginationWrapped = this.paginationEl.clientHeight > 63;\n }\n };\n\n private runResizeObserver = () => {\n this.resizeObserver = new ResizeObserver(() => {\n const { clientWidth } = this.paginationBarEl;\n if (\n clientWidth - this.paginationWidth > 50 ||\n clientWidth - this.paginationWidth < -50\n ) {\n this.paginationWidth = clientWidth;\n this.paginationShouldWrap();\n }\n });\n\n this.resizeObserver.observe(this.paginationBarEl);\n };\n\n private setInputError = (\n el: HTMLIcTextFieldElement,\n error: string,\n focus = true\n ) => {\n this.inputError = error;\n el.validationStatus = \"error\";\n if (focus) el.setFocus();\n };\n\n private setItemsPerPage = (newValue: number) => {\n if (this.itemsPerPage !== newValue) {\n this.itemsPerPage = newValue;\n this.itemsPerPageString = newValue.toString();\n this.icItemsPerPageChange.emit({ value: this.itemsPerPage });\n }\n\n this.totalPages =\n this.totalItems > this.itemsPerPage\n ? Math.ceil(this.totalItems / this.itemsPerPage)\n : 1;\n\n this.setUpperBound();\n if (this.currentPage > this.totalPages) {\n this.paginationEl.setCurrentPage(this.totalPages);\n this.currentPage = this.totalPages;\n }\n this.icPageChange.emit({ value: this.currentPage });\n };\n\n private setPaginationBarContent = (): void => {\n const displayedItemsPerPageOptions =\n this.itemsPerPageOptions?.slice(0, 3) ||\n (this.totalItems <= 100\n ? [\n { label: \"10\", value: \"10\" },\n { label: \"25\", value: \"25\" },\n { label: \"50\", value: \"50\" },\n ]\n : [\n { label: \"25\", value: \"25\" },\n { label: \"100\", value: \"100\" },\n { label: \"1000\", value: \"1000\" },\n ]);\n displayedItemsPerPageOptions.push({\n label: \"All\",\n value: String(this.totalItems),\n });\n\n this.displayedItemsPerPageOptions = displayedItemsPerPageOptions.filter(\n ({ value }) => this.totalItems >= Number(value)\n );\n\n let lastOptionValue = 0;\n const updated = this.displayedItemsPerPageOptions.some(({ value }) => {\n lastOptionValue = Number(value);\n return this.itemsPerPage <= lastOptionValue;\n });\n\n this.setItemsPerPage(\n updated || (!updated && this.itemsPerPage > lastOptionValue)\n ? lastOptionValue\n : this.itemsPerPage\n );\n };\n\n private setUpperBound = () => {\n this.upperBound = Math.min(\n this.lowerBound + this.itemsPerPage - 1,\n this.totalItems\n );\n };\n\n render() {\n const {\n appearance,\n alignment,\n displayedItemsPerPageOptions,\n PAGE_INPUT_FIELD_ID,\n type,\n rangeLabelType,\n hideRangeLabel,\n showItemsPerPageControl,\n showGoToPageControl,\n pageLabel,\n capitalizedPageLabel,\n lowerCasePageLabel,\n capitalizedItemLabel,\n lowerCaseItemLabel,\n totalPages,\n currentPage,\n itemsPerPageString,\n } = this;\n\n return (\n <div\n class={{\n [\"pagination-bar\"]: true,\n [`pagination-bar-${alignment}`]: true,\n }}\n ref={(el) => (this.paginationBarEl = el)}\n >\n {(!hideRangeLabel || showItemsPerPageControl) && (\n <div class=\"item-controls\">\n {showItemsPerPageControl && (\n <div class=\"items-per-page-holder\">\n <ic-typography\n class={{\n [`pagination-text-${appearance}`]: true,\n [\"items-per-page-control-label\"]: true,\n }}\n variant=\"label\"\n onClick={this.itemsPerPageLabelClickHandler}\n >\n {capitalizedItemLabel}s per {lowerCasePageLabel}\n </ic-typography>\n <ic-select\n size=\"small\"\n label=\"items-per-page-input\"\n class=\"items-per-page-input\"\n hideLabel\n options={displayedItemsPerPageOptions}\n value={itemsPerPageString}\n onIcChange={this.changeItemsPerPage}\n ref={(el: HTMLIcSelectElement) => (this.pageDropdownEl = el)}\n ></ic-select>\n </div>\n )}\n {!hideRangeLabel &&\n (rangeLabelType === \"data\" ? (\n <ic-typography\n class={{\n [`pagination-text-${appearance}`]: true,\n [\"item-pagination-label\"]: true,\n }}\n variant=\"label\"\n aria-live=\"polite\"\n >\n {this.upperBound === 0 && `0 ${lowerCaseItemLabel}s`}\n {this.upperBound > 0 &&\n `${this.lowerBound} - ${this.upperBound} of ${\n this.totalItems\n } ${lowerCaseItemLabel}${this.totalItems > 1 ? \"s\" : \"\"}`}\n </ic-typography>\n ) : (\n <ic-typography\n class={{\n [`pagination-text-${appearance}`]: true,\n [\"page-pagination-label\"]: true,\n }}\n variant=\"label\"\n aria-live=\"polite\"\n >\n {capitalizedPageLabel} {currentPage} of {totalPages}\n </ic-typography>\n ))}\n </div>\n )}\n <div\n class={{\n [\"pagination-controls\"]: true,\n [\"pagination-controls-wrap\"]: this.paginationWrapped,\n }}\n >\n <div class=\"pagination-holder\">\n <ic-pagination\n appearance={appearance}\n type={type}\n pages={totalPages}\n label={pageLabel}\n ref={(el: HTMLIcPaginationElement) => (this.paginationEl = el)}\n ></ic-pagination>\n </div>\n {showGoToPageControl && (\n <div class=\"go-to-page-holder\">\n <ic-typography\n class={{ [`pagination-text-${appearance}`]: true }}\n variant=\"label\"\n onClick={this.goToPageLabelClickHandler}\n >\n Go to {lowerCasePageLabel}\n </ic-typography>\n <ic-tooltip\n label={this.inputError}\n target={`#${PAGE_INPUT_FIELD_ID}`}\n disableHover\n disableClick\n ref={(el: HTMLIcTooltipElement) =>\n (this.pageInputTooltipEl = el)\n }\n >\n <ic-text-field\n type=\"number\"\n size=\"small\"\n label={PAGE_INPUT_FIELD_ID}\n class={PAGE_INPUT_FIELD_ID}\n id={PAGE_INPUT_FIELD_ID}\n hideLabel\n onKeyDown={this.handleKeydown}\n onKeyUp={this.handleKeyUp}\n onInput={this.handleInputChange}\n max={totalPages}\n min=\"1\"\n validationInlineInternal\n onBlur={this.handleBlur}\n onFocus={this.handleFocus}\n ref={(el: HTMLIcTextFieldElement) => (this.pageInputEl = el)}\n ></ic-text-field>\n </ic-tooltip>\n <ic-button\n appearance={appearance}\n variant=\"secondary\"\n onClick={this.goToPage}\n size=\"small\"\n class=\"go-to-page-button\"\n >\n Go\n </ic-button>\n </div>\n )}\n </div>\n </div>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"ic-pagination-bar.js","sourceRoot":"","sources":["../../../src/components/ic-pagination-bar/ic-pagination-bar.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\n Component,\n Prop,\n Element,\n Event,\n EventEmitter,\n State,\n Listen,\n h,\n Watch,\n} from \"@stencil/core\";\nimport { IcThemeForeground } from \"@ukic/web-components/dist/types/interface\";\nimport { checkResizeObserver, capitalize } from \"../../utils/helpers\";\nimport { IcPageChangeEventDetail } from \"./ic-pagination-bar.types\";\nimport {\n IcPaginationAlignmentOptions,\n IcPaginationLabelTypes,\n IcPaginationTypes,\n} from \"@ukic/web-components/dist/types/components/ic-pagination/ic-pagination.types\";\n\n@Component({\n tag: \"ic-pagination-bar\",\n styleUrl: \"ic-pagination-bar.css\",\n shadow: true,\n})\nexport class PaginationBar {\n private PAGE_INPUT_FIELD_ID = \"go-to-page-input\";\n\n private INVALID_PAGE_ERROR = \"Please enter a valid page\";\n\n private resizeObserver: ResizeObserver = null;\n private pageDropdownEl: HTMLIcSelectElement;\n private pageInputEl: HTMLIcTextFieldElement;\n private pageInputTooltipEl: HTMLIcTooltipElement;\n private paginationBarEl: HTMLElement;\n private paginationEl: HTMLIcPaginationElement;\n\n @Element() el: HTMLIcPaginationBarElement;\n\n @State() capitalizedItemLabel: string;\n\n @State() capitalizedPageLabel: string;\n\n @State() activePage: number = 1;\n\n @State() displayedItemsPerPageOptions?: {\n label: string;\n value: string;\n }[];\n\n @State() inputError: string = \"Please enter a valid page\";\n\n @State() itemsPerPage: number = 0;\n\n @State() itemsPerPageString: string = \"0\";\n\n @State() lowerBound: number = 1;\n\n @State() lowerCaseItemLabel: string;\n\n @State() lowerCasePageLabel: string;\n\n @State() paginationWidth: number;\n\n @State() paginationWrapped: boolean = false;\n\n @State() totalPages: number;\n\n @State() upperBound: number;\n\n /**\n * Sets the alignment of the items in the pagination bar.\n */\n @Prop() alignment?: IcPaginationAlignmentOptions = \"right\";\n\n /**\n * Sets the styling for the items in the pagination bar.\n */\n @Prop() appearance?: IcThemeForeground = \"default\";\n\n /**\n * The current page number to be displayed on the pagination bar.\n */\n @Prop() currentPage?: number = 1;\n @Watch(\"currentPage\")\n watchPageNumberHandler(): void {\n this.activePage = this.currentPage;\n }\n\n /**\n * The text which will be used in place of 'Item' on the pagination bar.\n */\n @Prop() itemLabel?: string = \"Item\";\n\n @Watch(\"itemLabel\")\n watchItemLabelHandler(): void {\n this.capitalizedItemLabel = capitalize(this.itemLabel);\n this.lowerCaseItemLabel = this.itemLabel.toLowerCase();\n }\n\n /**\n * 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.\n */\n @Prop() itemsPerPageOptions?: {\n label: string;\n value: string;\n }[];\n\n @Watch(\"itemsPerPageOptions\")\n watchItemsPerPageOptionsHandler(\n newVal: {\n label: string;\n value: string;\n }[],\n oldVal: {\n label: string;\n value: string;\n }[]\n ): void {\n if (JSON.stringify(newVal) === JSON.stringify(oldVal)) return;\n this.setPaginationBarContent();\n }\n\n /**\n * Whether the displayed pagination is simple or complex.\n */\n @Prop() type?: IcPaginationTypes = \"simple\";\n\n /**\n * Whether total number of items and current item range or total number of pages and current page is displayed.\n */\n @Prop() rangeLabelType?: IcPaginationLabelTypes = \"page\";\n\n /**\n * The text which will be used in place of 'Page' on the pagination bar.\n */\n @Prop() pageLabel?: string = \"Page\";\n\n @Watch(\"pageLabel\")\n watchPageLabelHandler(): void {\n this.capitalizedPageLabel = capitalize(this.pageLabel);\n this.lowerCasePageLabel = this.pageLabel.toLowerCase();\n }\n\n /**\n * If `true`, the 'go to page' control should be displayed.\n */\n @Prop() showGoToPageControl?: boolean = false;\n\n /**\n * If `true`, the number of total items and current item range or number of total pages and current page will be hidden.\n */\n @Prop() hideRangeLabel?: boolean = false;\n\n /**\n * If `true`, the select input to control 'items per page' should be displayed.\n */\n @Prop() showItemsPerPageControl?: boolean = false;\n\n /**\n * Total number of items to be displayed across all pages.\n */\n @Prop() totalItems!: number;\n\n @Watch(\"totalItems\")\n watchTotalItemsHandler(): void {\n this.setPaginationBarContent();\n }\n\n /**\n * Emitted when a page is navigated to via the 'go to' input.\n * The `detail` property contains `value` (i.e. the page number) and a `fromItemsPerPage` flag to indicate if the event was triggered by the `icItemsPerPageChange` event also occurring.\n */\n @Event() icPageChange: EventEmitter<IcPageChangeEventDetail>;\n\n /**\n * Emitted when the items per page option is changed.\n */\n @Event() icItemsPerPageChange: EventEmitter<{ value: number }>;\n\n disconnectedCallback(): void {\n this.resizeObserver?.disconnect();\n }\n\n componentWillLoad(): void {\n this.watchPageNumberHandler();\n this.watchPageLabelHandler();\n this.watchItemLabelHandler();\n this.setPaginationBarContent();\n }\n\n componentDidLoad(): void {\n this.paginationWidth = this.paginationBarEl.clientWidth;\n checkResizeObserver(this.runResizeObserver);\n const textField = this.el.shadowRoot?.querySelector(\n `.${this.PAGE_INPUT_FIELD_ID}`\n );\n if (textField) {\n const input = textField?.shadowRoot?.querySelector(\"input\");\n if (input) {\n input.style.textAlign = \"center\";\n input.style.padding = \"0\";\n }\n }\n this.paginationShouldWrap();\n }\n\n @Listen(\"icPageChange\")\n pageChangeHandler(ev: CustomEvent): void {\n const page = ev.detail.value;\n this.changePage(page);\n }\n\n private changeItemsPerPage = () => {\n this.setItemsPerPage(Number(this.pageDropdownEl.value));\n };\n\n private changePage = (page: number) => {\n this.activePage = page;\n this.lowerBound = page !== 1 ? (page - 1) * this.itemsPerPage + 1 : page;\n this.setUpperBound();\n };\n\n private focusElFromLabel = (el: \"ic-select\" | \"ic-text-field\") => {\n this.paginationBarEl.querySelector(el)?.setFocus();\n };\n\n private goToPage = () => {\n const input = this.pageInputEl;\n const page = Number(input.value);\n if (page <= this.totalPages && page > 0) {\n this.changePage(page);\n this.paginationEl.setCurrentPage(page);\n this.activePage = page;\n input.value = \"\";\n this.icPageChange.emit({ value: page });\n this.pageInputTooltipEl.displayTooltip(false, false);\n input.validationStatus = \"\";\n } else {\n this.setInputError(input, this.INVALID_PAGE_ERROR);\n }\n };\n\n private goToPageLabelClickHandler = () => {\n this.focusElFromLabel(\"ic-text-field\");\n };\n\n private handleBlur = () => {\n const textField = this.pageInputEl;\n if (\n (Number(textField.value) <= this.totalPages &&\n Number(textField.value) > 0) ||\n textField.value === \"\"\n ) {\n textField.validationStatus = \"\";\n }\n this.pageInputTooltipEl.displayTooltip(false, false);\n };\n\n private handleFocus = () => {\n if (this.pageInputEl.validationStatus === \"error\") {\n this.pageInputTooltipEl.displayTooltip(true, true);\n }\n };\n\n private handleInputChange = () => {\n const inputValue = parseInt(this.pageInputEl.value);\n\n if (inputValue > this.totalPages || inputValue <= 0) {\n this.setInputError(this.pageInputEl, this.INVALID_PAGE_ERROR);\n this.pageInputTooltipEl.displayTooltip(true, true);\n }\n };\n\n private handleKeydown = (ev: KeyboardEvent) => {\n if (ev.key === \"Enter\") {\n if (this.pageInputEl.validationStatus === \"error\") {\n this.pageInputTooltipEl.displayTooltip(true, true);\n } else {\n this.goToPage();\n }\n } else {\n this.pageInputTooltipEl.displayTooltip(false, false);\n this.pageInputEl.validationStatus = \"\";\n }\n };\n\n private handleKeyUp = (ev: KeyboardEvent) => {\n if (\n Number.isNaN(parseInt(this.pageInputEl.value)) &&\n ev.key !== \"Backspace\" &&\n ev.key !== \"Enter\" &&\n ev.key !== \"Tab\" &&\n ev.key !== \"Shift\"\n ) {\n this.setInputError(this.pageInputEl, \"Please enter a number\", false);\n this.pageInputTooltipEl.displayTooltip(true, false);\n }\n };\n\n private itemsPerPageLabelClickHandler = () => {\n this.focusElFromLabel(\"ic-select\");\n };\n\n private paginationShouldWrap = () => {\n if (this.type === \"simple\") {\n this.paginationWrapped = this.paginationEl.clientHeight > 63;\n }\n };\n\n private runResizeObserver = () => {\n this.resizeObserver = new ResizeObserver(() => {\n const { clientWidth } = this.paginationBarEl;\n if (\n clientWidth - this.paginationWidth > 50 ||\n clientWidth - this.paginationWidth < -50\n ) {\n this.paginationWidth = clientWidth;\n this.paginationShouldWrap();\n }\n });\n\n this.resizeObserver.observe(this.paginationBarEl);\n };\n\n private setInputError = (\n el: HTMLIcTextFieldElement,\n error: string,\n focus = true\n ) => {\n this.inputError = error;\n el.validationStatus = \"error\";\n if (focus) el.setFocus();\n };\n\n private setItemsPerPage = (newValue: number) => {\n if (this.itemsPerPage !== newValue) {\n this.itemsPerPage = newValue;\n this.itemsPerPageString = newValue.toString();\n this.icItemsPerPageChange.emit({ value: this.itemsPerPage });\n }\n\n this.totalPages =\n this.totalItems > this.itemsPerPage\n ? Math.ceil(this.totalItems / this.itemsPerPage)\n : 1;\n\n this.setUpperBound();\n if (this.activePage > this.totalPages) {\n this.paginationEl.setCurrentPage(this.totalPages);\n this.activePage = this.totalPages;\n }\n this.icPageChange.emit({ value: this.activePage, fromItemsPerPage: true });\n };\n\n private setPaginationBarContent = (): void => {\n const displayedItemsPerPageOptions =\n this.itemsPerPageOptions?.slice(0, 3) ||\n (this.totalItems <= 100\n ? [\n { label: \"10\", value: \"10\" },\n { label: \"25\", value: \"25\" },\n { label: \"50\", value: \"50\" },\n ]\n : [\n { label: \"25\", value: \"25\" },\n { label: \"100\", value: \"100\" },\n { label: \"1000\", value: \"1000\" },\n ]);\n displayedItemsPerPageOptions.push({\n label: \"All\",\n value: String(this.totalItems),\n });\n\n this.displayedItemsPerPageOptions = displayedItemsPerPageOptions.filter(\n ({ value }) => this.totalItems >= Number(value)\n );\n\n let lastOptionValue = 0;\n const updated = this.displayedItemsPerPageOptions.some(({ value }) => {\n lastOptionValue = Number(value);\n return this.itemsPerPage <= lastOptionValue;\n });\n\n this.setItemsPerPage(\n updated || (!updated && this.itemsPerPage > lastOptionValue)\n ? lastOptionValue\n : this.itemsPerPage\n );\n };\n\n private setUpperBound = () => {\n this.upperBound = Math.min(\n this.lowerBound + this.itemsPerPage - 1,\n this.totalItems\n );\n };\n\n render() {\n const {\n appearance,\n alignment,\n displayedItemsPerPageOptions,\n PAGE_INPUT_FIELD_ID,\n type,\n rangeLabelType,\n hideRangeLabel,\n showItemsPerPageControl,\n showGoToPageControl,\n pageLabel,\n capitalizedPageLabel,\n lowerCasePageLabel,\n capitalizedItemLabel,\n lowerCaseItemLabel,\n totalPages,\n activePage,\n itemsPerPageString,\n } = this;\n\n return (\n <div\n class={{\n [\"pagination-bar\"]: true,\n [`pagination-bar-${alignment}`]: true,\n }}\n ref={(el) => (this.paginationBarEl = el)}\n >\n {(!hideRangeLabel || showItemsPerPageControl) && (\n <div class=\"item-controls\">\n {showItemsPerPageControl && (\n <div class=\"items-per-page-holder\">\n <ic-typography\n class={{\n [`pagination-text-${appearance}`]: true,\n [\"items-per-page-control-label\"]: true,\n }}\n variant=\"label\"\n onClick={this.itemsPerPageLabelClickHandler}\n >\n {capitalizedItemLabel}s per {lowerCasePageLabel}\n </ic-typography>\n <ic-select\n size=\"small\"\n label=\"items-per-page-input\"\n class=\"items-per-page-input\"\n hideLabel\n options={displayedItemsPerPageOptions}\n value={itemsPerPageString}\n onIcChange={this.changeItemsPerPage}\n ref={(el: HTMLIcSelectElement) => (this.pageDropdownEl = el)}\n ></ic-select>\n </div>\n )}\n {!hideRangeLabel &&\n (rangeLabelType === \"data\" ? (\n <ic-typography\n class={{\n [`pagination-text-${appearance}`]: true,\n [\"item-pagination-label\"]: true,\n }}\n variant=\"label\"\n aria-live=\"polite\"\n >\n {this.upperBound === 0 && `0 ${lowerCaseItemLabel}s`}\n {this.upperBound > 0 &&\n `${this.lowerBound} - ${this.upperBound} of ${\n this.totalItems\n } ${lowerCaseItemLabel}${this.totalItems > 1 ? \"s\" : \"\"}`}\n </ic-typography>\n ) : (\n <ic-typography\n class={{\n [`pagination-text-${appearance}`]: true,\n [\"page-pagination-label\"]: true,\n }}\n variant=\"label\"\n aria-live=\"polite\"\n >\n {capitalizedPageLabel} {activePage} of {totalPages}\n </ic-typography>\n ))}\n </div>\n )}\n <div\n class={{\n [\"pagination-controls\"]: true,\n [\"pagination-controls-wrap\"]: this.paginationWrapped,\n }}\n >\n <div class=\"pagination-holder\">\n <ic-pagination\n appearance={appearance}\n type={type}\n pages={totalPages}\n label={pageLabel}\n ref={(el: HTMLIcPaginationElement) => (this.paginationEl = el)}\n currentPage={activePage}\n ></ic-pagination>\n </div>\n {showGoToPageControl && (\n <div class=\"go-to-page-holder\">\n <ic-typography\n class={{ [`pagination-text-${appearance}`]: true }}\n variant=\"label\"\n onClick={this.goToPageLabelClickHandler}\n >\n Go to {lowerCasePageLabel}\n </ic-typography>\n <ic-tooltip\n label={this.inputError}\n target={`#${PAGE_INPUT_FIELD_ID}`}\n disableHover\n disableClick\n ref={(el: HTMLIcTooltipElement) =>\n (this.pageInputTooltipEl = el)\n }\n >\n <ic-text-field\n type=\"number\"\n size=\"small\"\n label={PAGE_INPUT_FIELD_ID}\n class={PAGE_INPUT_FIELD_ID}\n id={PAGE_INPUT_FIELD_ID}\n hideLabel\n onKeyDown={this.handleKeydown}\n onKeyUp={this.handleKeyUp}\n onInput={this.handleInputChange}\n max={totalPages}\n min=\"1\"\n validationInlineInternal\n onBlur={this.handleBlur}\n onFocus={this.handleFocus}\n ref={(el: HTMLIcTextFieldElement) => (this.pageInputEl = el)}\n ></ic-text-field>\n </ic-tooltip>\n <ic-button\n appearance={appearance}\n variant=\"secondary\"\n onClick={this.goToPage}\n size=\"small\"\n class=\"go-to-page-button\"\n >\n Go\n </ic-button>\n </div>\n )}\n </div>\n </div>\n );\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=ic-pagination-bar.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ic-pagination-bar.types.js","sourceRoot":"","sources":["../../../src/components/ic-pagination-bar/ic-pagination-bar.types.ts"],"names":[],"mappings":"","sourcesContent":["export interface IcPageChangeEventDetail {\n value: number;\n fromItemsPerPage?: boolean;\n}\n"]}
@@ -135,7 +135,6 @@ describe("ic-pagination-bar", () => {
135
135
  { label: "100", value: "100" },
136
136
  { label: "All", value: "150" },
137
137
  ];
138
- page.rootInstance.trimItemsPerPageOptions();
139
138
  await page.waitForChanges();
140
139
  expect(page.rootInstance.displayedItemsPerPageOptions).toEqual([
141
140
  { label: "25", value: "25" },
@@ -164,6 +163,16 @@ describe("ic-pagination-bar", () => {
164
163
  { label: "All", value: "100" },
165
164
  ]);
166
165
  });
166
+ it("should update page details when currentPage prop is changed", async () => {
167
+ const page = await newSpecPage({
168
+ components: [PaginationBar, IcPagination],
169
+ html: `<ic-pagination-bar total-items="100"></ic-pagination-bar>`,
170
+ });
171
+ expect(page.root).toMatchSnapshot();
172
+ page.root.currentPage = 4;
173
+ await page.waitForChanges();
174
+ expect(page.root).toMatchSnapshot();
175
+ });
167
176
  it("should wrap pagination when the device size is small", async () => {
168
177
  const page = await newSpecPage({
169
178
  components: [PaginationBar, IcPagination],
@@ -187,12 +196,21 @@ describe("ic-pagination-bar", () => {
187
196
  const select = paginationBar.shadowRoot.querySelector("ic-select");
188
197
  const text = paginationBar.shadowRoot.querySelector(".page-pagination-label");
189
198
  expect(text.textContent).toEqual("Page 1 of 10");
199
+ const eventSpy = jest.fn();
200
+ paginationBar.addEventListener("icPageChange", eventSpy);
190
201
  select.value = "25";
202
+ expect(eventSpy).toHaveBeenCalledTimes(0);
191
203
  page.rootInstance.changeItemsPerPage();
192
- page.rootInstance.setNumberPages();
193
204
  await page.waitForChanges();
194
205
  expect(select.value).toEqual("25");
195
206
  expect(text.textContent).toEqual("Page 1 of 4");
207
+ expect(eventSpy).toHaveBeenCalledTimes(1);
208
+ expect(eventSpy).toHaveBeenCalledWith(expect.objectContaining({
209
+ detail: expect.objectContaining({
210
+ value: 1,
211
+ fromItemsPerPage: true,
212
+ }),
213
+ }));
196
214
  });
197
215
  it("should change page when the pagination controls are clicked", async () => {
198
216
  const page = await newSpecPage({
@@ -1 +1 @@
1
- {"version":3,"file":"ic-pagination-bar.spec.js","sourceRoot":"","sources":["../../../../../src/components/ic-pagination-bar/test/basic/ic-pagination-bar.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import { PaginationBar } from \"../../ic-pagination-bar\";\nimport { IcPagination } from \"@ukic/web-components/dist/components/ic-pagination\";\nimport { IcButton } from \"@ukic/web-components/dist/components/ic-button\";\nimport { IcTooltip } from \"@ukic/web-components/dist/components/ic-tooltip\";\nimport { IcTextField } from \"@ukic/web-components/dist/components/ic-text-field\";\nimport { DEVICE_SIZES } from \"@ukic/web-components/dist/types/utils/helpers\";\nimport { waitForTimeout } from \"../../../../testspec.setup\";\nimport { newSpecPage } from \"@stencil/core/testing\";\nimport { IcSelect } from \"@ukic/web-components/dist/components/ic-select\";\nimport { IcTypography } from \"@ukic/web-components/dist/components/ic-typography\";\n\ndescribe(\"ic-pagination-bar\", () => {\n it(\"should render\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with items per page controls\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" show-items-per-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with go to page controls\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with data pagination type\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" range-label-type=\"data\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with complex pagination controls\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination],\n html: `<ic-pagination-bar total-items=\"100\" type=\"complex\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with a custom page label\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" page-label=\"Sheet\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n\n expect(page.rootInstance.lowerCasePageLabel).toBe(\"sheet\");\n\n page.root.itemLabel = \"sheet\";\n await page.waitForChanges();\n\n expect(page.rootInstance.capitalizedPageLabel).toBe(\"Sheet\");\n });\n\n it(\"should render with a custom item label\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" range-label-type=\"data\" item-label=\"Row\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n expect(page.rootInstance.lowerCaseItemLabel).toBe(\"row\");\n\n page.root.itemLabel = \"row\";\n await page.waitForChanges();\n\n expect(page.rootInstance.capitalizedItemLabel).toBe(\"Row\");\n });\n\n it(\"should render without range text\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" hide-range-label=\"true\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with left alignment\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" alignment=\"left\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with space between alignment\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" alignment=\"space-between\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with light appearance\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" appearance=\"light\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with dark appearance\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" apperance=\"dark\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with custom items per page options\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" show-items-per-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n paginationBar.itemsPerPageOptions = [\n { label: \"15\", value: \"15\" },\n { label: \"30\", value: \"30\" },\n { label: \"60\", value: \"60\" },\n { label: \"All\", value: \"100\" },\n ];\n\n await page.waitForChanges();\n\n expect(page.rootInstance.displayedItemsPerPageOptions).toEqual([\n { label: \"15\", value: \"15\" },\n { label: \"30\", value: \"30\" },\n { label: \"60\", value: \"60\" },\n { label: \"All\", value: \"100\" },\n ]);\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should only allow a maximum of 4 custom items per page options\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"150\" show-items-per-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n paginationBar.itemsPerPageOptions = [\n { label: \"25\", value: \"25\" },\n { label: \"50\", value: \"50\" },\n { label: \"75\", value: \"75\" },\n { label: \"100\", value: \"100\" },\n { label: \"All\", value: \"150\" },\n ];\n\n page.rootInstance.trimItemsPerPageOptions();\n\n await page.waitForChanges();\n\n expect(page.rootInstance.displayedItemsPerPageOptions).toEqual([\n { label: \"25\", value: \"25\" },\n { label: \"50\", value: \"50\" },\n { label: \"75\", value: \"75\" },\n { label: \"All\", value: \"150\" },\n ]);\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should remove items per page options larger than the maximum number of items\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" show-items-per-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n paginationBar.itemsPerPageOptions = [\n { label: \"25\", value: \"25\" },\n { label: \"50\", value: \"50\" },\n { label: \"150\", value: \"150\" },\n { label: \"All\", value: \"100\" },\n ];\n\n await page.waitForChanges();\n\n expect(page.rootInstance.displayedItemsPerPageOptions).toEqual([\n { label: \"25\", value: \"25\" },\n { label: \"50\", value: \"50\" },\n { label: \"All\", value: \"100\" },\n ]);\n });\n\n it(\"should wrap pagination when the device size is small\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n await page.rootInstance.runResizeObserver();\n\n await page.waitForChanges();\n\n await page.rootInstance.resizeObserverCallback(DEVICE_SIZES.S);\n\n await page.waitForChanges();\n\n await page.rootInstance.paginationShouldWrap();\n\n await page.waitForChanges();\n\n expect(page).toMatchSnapshot();\n\n await page.rootInstance.disconnectedCallback();\n });\n\n it(\"should adjust the total page count when items per page is changed\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination],\n html: `<ic-pagination-bar total-items=\"100\" show-items-per-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const select = paginationBar.shadowRoot.querySelector(\"ic-select\");\n\n const text = paginationBar.shadowRoot.querySelector(\n \".page-pagination-label\"\n );\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n\n select.value = \"25\";\n\n page.rootInstance.changeItemsPerPage();\n\n page.rootInstance.setNumberPages();\n\n await page.waitForChanges();\n\n expect(select.value).toEqual(\"25\");\n\n expect(text.textContent).toEqual(\"Page 1 of 4\");\n });\n\n it(\"should change page when the pagination controls are clicked\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcButton],\n html: `<ic-pagination-bar total-items=\"100\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const pagination = paginationBar.shadowRoot.querySelector(\"ic-pagination\");\n\n const nextButton = pagination.shadowRoot.querySelector(\n \"#next-page-button\"\n ) as HTMLElement;\n\n const text = paginationBar.shadowRoot.querySelector(\n \".page-pagination-label\"\n );\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n\n await nextButton.click();\n\n page.rootInstance.changePage(2);\n\n await page.waitForChanges();\n\n expect(text.textContent).toEqual(\"Page 2 of 10\");\n });\n\n it(\"should change page when the go to page button is clicked\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const button = paginationBar.shadowRoot.querySelector(\"ic-button\");\n\n const text = paginationBar.shadowRoot.querySelector(\n \".page-pagination-label\"\n );\n\n const currentPage = page.rootInstance.currentPage;\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n\n expect(currentPage).toEqual(1);\n\n input.value = \"3\";\n\n button.click();\n\n await page.waitForChanges();\n\n expect(text.textContent).toEqual(\"Page 3 of 10\");\n });\n\n it(\"should change page when enter is pressed on the go to page input\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const text = paginationBar.shadowRoot.querySelector(\n \".page-pagination-label\"\n );\n\n const currentPage = page.rootInstance.currentPage;\n\n const event = new KeyboardEvent(\"keydown\", { key: \"Enter\" });\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n\n expect(currentPage).toEqual(1);\n\n input.value = \"3\";\n\n input.focus();\n\n await page.rootInstance.handleKeydown(event);\n\n await waitForTimeout(100);\n\n await page.waitForChanges();\n\n expect(text.textContent).toEqual(\"Page 3 of 10\");\n });\n\n it(\"should error immediately when an invalid page is entered before it is submitted\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip, IcTextField],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n expect(input.validationStatus).toBe(\"\");\n\n input.value = \"15\";\n\n input.focus();\n\n await page.rootInstance.handleInputChange();\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"error\");\n });\n\n it(\"should remain in error state if enter is pressed while in error state\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip, IcTextField],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const event = new KeyboardEvent(\"keydown\", { key: \"Enter\" });\n\n expect(input.validationStatus).toBe(\"\");\n\n input.value = \"15\";\n\n input.focus();\n\n await page.rootInstance.handleInputChange();\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"error\");\n\n page.rootInstance.handleKeydown(event);\n\n await waitForTimeout(100);\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"error\");\n });\n\n it(\"should not change page when the go to page button is clicked with an invalid page\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTextField],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const button = paginationBar.shadowRoot.querySelector(\"ic-button\");\n\n const text = paginationBar.shadowRoot.querySelector(\n \".page-pagination-label\"\n );\n\n const currentPage = page.rootInstance.currentPage;\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n\n expect(currentPage).toEqual(1);\n\n input.value = \"15\";\n\n button.click();\n\n await page.waitForChanges();\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n });\n\n it(\"should not change page when enter is pressed on the go to page input with an invalid page\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip, IcTextField],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const text = paginationBar.shadowRoot.querySelector(\n \".page-pagination-label\"\n );\n\n const currentPage = page.rootInstance.currentPage;\n\n const event = new KeyboardEvent(\"keydown\", { key: \"Enter\" });\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n\n expect(currentPage).toEqual(1);\n\n input.value = \"15\";\n\n input.focus();\n\n await page.rootInstance.handleKeydown(event);\n\n await waitForTimeout(100);\n\n await page.waitForChanges();\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n });\n\n it(\"should hide the tooltip when the input loses focus\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const tooltip = paginationBar.shadowRoot.querySelector(\"ic-tooltip\");\n\n expect(tooltip.getAttribute(\"data-show\")).toBeNull();\n\n input.focus();\n\n input.value = \"15\";\n\n tooltip.displayTooltip(true, false);\n\n await page.waitForChanges();\n\n input.blur();\n\n await page.waitForChanges();\n\n expect(tooltip.getAttribute(\"data-show\")).toBeNull();\n });\n\n it(\"should remove the error status when the input loses focus if the value is not invalid\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n input.focus();\n\n input.value = \"\";\n\n input.validationStatus = \"error\";\n\n await page.waitForChanges();\n\n input.blur();\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toBe(\"\");\n });\n\n it(\"should show the tooltip when the input is focussed if it is in an error state\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n input.focus();\n\n input.value = \"15\";\n\n input.validationStatus = \"error\";\n\n await page.waitForChanges();\n\n input.blur();\n\n await page.waitForChanges();\n\n input.focus();\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toBe(\"error\");\n });\n\n it(\"should error when a non numeric value is entered\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const event = new KeyboardEvent(\"keydown\", { key: \"a\" });\n\n expect(input.validationStatus).toBeUndefined();\n\n input.focus();\n\n await page.rootInstance.handleKeyUp(event);\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"error\");\n });\n\n it(\"should remove the non-numeric error when a number is entered\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const errorEvent = new KeyboardEvent(\"keydown\", { key: \"a\" });\n\n const successEvent = new KeyboardEvent(\"keydown\", { key: \"5\" });\n\n expect(input.validationStatus).toBeUndefined();\n\n input.focus();\n\n await page.rootInstance.handleKeyUp(errorEvent);\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"error\");\n\n await page.rootInstance.handleKeydown(successEvent);\n\n await waitForTimeout(100);\n\n await page.rootInstance.handleInputChange();\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"\");\n });\n\n it(\"should remove the error state when backspace is pressed\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const event = new KeyboardEvent(\"keydown\", { key: \"Backspace\" });\n\n expect(input.validationStatus).toBeUndefined();\n\n input.focus();\n\n input.value = \"15\";\n\n input.validationStatus = \"error\";\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"error\");\n\n await page.rootInstance.handleKeydown(event);\n\n await waitForTimeout(100);\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"\");\n });\n\n it(\"should focus the number of items select when clicking its label\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcSelect, IcTypography],\n html: `<ic-pagination-bar total-items=\"100\" show-items-per-page-control=\"true\"></ic-pagination-bar>`,\n });\n const label = document\n .querySelector(\"ic-pagination-bar\")\n .shadowRoot.querySelector(\n \".items-per-page-control-label\"\n ) as HTMLIcTypographyElement;\n\n const event = jest.spyOn(IcSelect.prototype, \"setFocus\");\n label.click();\n\n await page.waitForChanges();\n\n expect(event).toHaveBeenCalled();\n });\n\n // this test currently fails - will need to be fixed before component is moved from canary\n it.skip(\"should focus the go to page text-field when clicking its label\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTextField, IcTypography],\n html: `<ic-pagination-bar total-items=\"100\" show-items-per-page=\"false\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n const label = document\n .querySelector(\"ic-pagination-bar\")\n .shadowRoot.querySelector(\"ic-typography\");\n\n const event = jest.spyOn(IcTextField.prototype, \"setFocus\");\n label.click();\n\n await page.waitForChanges();\n\n expect(event).toHaveBeenCalled();\n });\n\n it(\"should update pagination when number of item changes\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"0\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n\n page.root.totalItems = \"100\";\n\n await page.waitForChanges();\n\n expect(page.root).toMatchSnapshot();\n\n page.root.totalItems = \"50\";\n\n await page.waitForChanges();\n\n expect(page.root).toMatchSnapshot();\n });\n});\n"]}
1
+ {"version":3,"file":"ic-pagination-bar.spec.js","sourceRoot":"","sources":["../../../../../src/components/ic-pagination-bar/test/basic/ic-pagination-bar.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import { PaginationBar } from \"../../ic-pagination-bar\";\nimport { IcPagination } from \"@ukic/web-components/dist/components/ic-pagination\";\nimport { IcButton } from \"@ukic/web-components/dist/components/ic-button\";\nimport { IcTooltip } from \"@ukic/web-components/dist/components/ic-tooltip\";\nimport { IcTextField } from \"@ukic/web-components/dist/components/ic-text-field\";\nimport { DEVICE_SIZES } from \"@ukic/web-components/dist/types/utils/helpers\";\nimport { waitForTimeout } from \"../../../../testspec.setup\";\nimport { newSpecPage } from \"@stencil/core/testing\";\nimport { IcSelect } from \"@ukic/web-components/dist/components/ic-select\";\nimport { IcTypography } from \"@ukic/web-components/dist/components/ic-typography\";\n\ndescribe(\"ic-pagination-bar\", () => {\n it(\"should render\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with items per page controls\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" show-items-per-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with go to page controls\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with data pagination type\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" range-label-type=\"data\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with complex pagination controls\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination],\n html: `<ic-pagination-bar total-items=\"100\" type=\"complex\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with a custom page label\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" page-label=\"Sheet\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n\n expect(page.rootInstance.lowerCasePageLabel).toBe(\"sheet\");\n\n page.root.itemLabel = \"sheet\";\n await page.waitForChanges();\n\n expect(page.rootInstance.capitalizedPageLabel).toBe(\"Sheet\");\n });\n\n it(\"should render with a custom item label\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" range-label-type=\"data\" item-label=\"Row\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n expect(page.rootInstance.lowerCaseItemLabel).toBe(\"row\");\n\n page.root.itemLabel = \"row\";\n await page.waitForChanges();\n\n expect(page.rootInstance.capitalizedItemLabel).toBe(\"Row\");\n });\n\n it(\"should render without range text\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" hide-range-label=\"true\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with left alignment\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" alignment=\"left\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with space between alignment\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" alignment=\"space-between\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with light appearance\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" appearance=\"light\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with dark appearance\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" apperance=\"dark\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should render with custom items per page options\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" show-items-per-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n paginationBar.itemsPerPageOptions = [\n { label: \"15\", value: \"15\" },\n { label: \"30\", value: \"30\" },\n { label: \"60\", value: \"60\" },\n { label: \"All\", value: \"100\" },\n ];\n\n await page.waitForChanges();\n\n expect(page.rootInstance.displayedItemsPerPageOptions).toEqual([\n { label: \"15\", value: \"15\" },\n { label: \"30\", value: \"30\" },\n { label: \"60\", value: \"60\" },\n { label: \"All\", value: \"100\" },\n ]);\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should only allow a maximum of 4 custom items per page options\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"150\" show-items-per-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n paginationBar.itemsPerPageOptions = [\n { label: \"25\", value: \"25\" },\n { label: \"50\", value: \"50\" },\n { label: \"75\", value: \"75\" },\n { label: \"100\", value: \"100\" },\n { label: \"All\", value: \"150\" },\n ];\n\n await page.waitForChanges();\n\n expect(page.rootInstance.displayedItemsPerPageOptions).toEqual([\n { label: \"25\", value: \"25\" },\n { label: \"50\", value: \"50\" },\n { label: \"75\", value: \"75\" },\n { label: \"All\", value: \"150\" },\n ]);\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should remove items per page options larger than the maximum number of items\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"100\" show-items-per-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n paginationBar.itemsPerPageOptions = [\n { label: \"25\", value: \"25\" },\n { label: \"50\", value: \"50\" },\n { label: \"150\", value: \"150\" },\n { label: \"All\", value: \"100\" },\n ];\n\n await page.waitForChanges();\n\n expect(page.rootInstance.displayedItemsPerPageOptions).toEqual([\n { label: \"25\", value: \"25\" },\n { label: \"50\", value: \"50\" },\n { label: \"All\", value: \"100\" },\n ]);\n });\n\n it(\"should update page details when currentPage prop is changed\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination],\n html: `<ic-pagination-bar total-items=\"100\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n\n page.root.currentPage = 4;\n\n await page.waitForChanges();\n\n expect(page.root).toMatchSnapshot();\n });\n\n it(\"should wrap pagination when the device size is small\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n await page.rootInstance.runResizeObserver();\n\n await page.waitForChanges();\n\n await page.rootInstance.resizeObserverCallback(DEVICE_SIZES.S);\n\n await page.waitForChanges();\n\n await page.rootInstance.paginationShouldWrap();\n\n await page.waitForChanges();\n\n expect(page).toMatchSnapshot();\n\n await page.rootInstance.disconnectedCallback();\n });\n\n it(\"should adjust the total page count when items per page is changed\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination],\n html: `<ic-pagination-bar total-items=\"100\" show-items-per-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const select = paginationBar.shadowRoot.querySelector(\"ic-select\");\n\n const text = paginationBar.shadowRoot.querySelector(\n \".page-pagination-label\"\n );\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n\n const eventSpy = jest.fn();\n\n paginationBar.addEventListener(\"icPageChange\", eventSpy);\n\n select.value = \"25\";\n expect(eventSpy).toHaveBeenCalledTimes(0);\n\n page.rootInstance.changeItemsPerPage();\n\n await page.waitForChanges();\n\n expect(select.value).toEqual(\"25\");\n\n expect(text.textContent).toEqual(\"Page 1 of 4\");\n\n expect(eventSpy).toHaveBeenCalledTimes(1);\n\n expect(eventSpy).toHaveBeenCalledWith(\n expect.objectContaining({\n detail: expect.objectContaining({\n value: 1,\n fromItemsPerPage: true,\n }),\n })\n );\n });\n\n it(\"should change page when the pagination controls are clicked\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcButton],\n html: `<ic-pagination-bar total-items=\"100\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const pagination = paginationBar.shadowRoot.querySelector(\"ic-pagination\");\n\n const nextButton = pagination.shadowRoot.querySelector(\n \"#next-page-button\"\n ) as HTMLElement;\n\n const text = paginationBar.shadowRoot.querySelector(\n \".page-pagination-label\"\n );\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n\n await nextButton.click();\n\n page.rootInstance.changePage(2);\n\n await page.waitForChanges();\n\n expect(text.textContent).toEqual(\"Page 2 of 10\");\n });\n\n it(\"should change page when the go to page button is clicked\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const button = paginationBar.shadowRoot.querySelector(\"ic-button\");\n\n const text = paginationBar.shadowRoot.querySelector(\n \".page-pagination-label\"\n );\n\n const currentPage = page.rootInstance.currentPage;\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n\n expect(currentPage).toEqual(1);\n\n input.value = \"3\";\n\n button.click();\n\n await page.waitForChanges();\n\n expect(text.textContent).toEqual(\"Page 3 of 10\");\n });\n\n it(\"should change page when enter is pressed on the go to page input\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const text = paginationBar.shadowRoot.querySelector(\n \".page-pagination-label\"\n );\n\n const currentPage = page.rootInstance.currentPage;\n\n const event = new KeyboardEvent(\"keydown\", { key: \"Enter\" });\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n\n expect(currentPage).toEqual(1);\n\n input.value = \"3\";\n\n input.focus();\n\n await page.rootInstance.handleKeydown(event);\n\n await waitForTimeout(100);\n\n await page.waitForChanges();\n\n expect(text.textContent).toEqual(\"Page 3 of 10\");\n });\n\n it(\"should error immediately when an invalid page is entered before it is submitted\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip, IcTextField],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n expect(input.validationStatus).toBe(\"\");\n\n input.value = \"15\";\n\n input.focus();\n\n await page.rootInstance.handleInputChange();\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"error\");\n });\n\n it(\"should remain in error state if enter is pressed while in error state\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip, IcTextField],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const event = new KeyboardEvent(\"keydown\", { key: \"Enter\" });\n\n expect(input.validationStatus).toBe(\"\");\n\n input.value = \"15\";\n\n input.focus();\n\n await page.rootInstance.handleInputChange();\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"error\");\n\n page.rootInstance.handleKeydown(event);\n\n await waitForTimeout(100);\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"error\");\n });\n\n it(\"should not change page when the go to page button is clicked with an invalid page\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTextField],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const button = paginationBar.shadowRoot.querySelector(\"ic-button\");\n\n const text = paginationBar.shadowRoot.querySelector(\n \".page-pagination-label\"\n );\n\n const currentPage = page.rootInstance.currentPage;\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n\n expect(currentPage).toEqual(1);\n\n input.value = \"15\";\n\n button.click();\n\n await page.waitForChanges();\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n });\n\n it(\"should not change page when enter is pressed on the go to page input with an invalid page\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip, IcTextField],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const text = paginationBar.shadowRoot.querySelector(\n \".page-pagination-label\"\n );\n\n const currentPage = page.rootInstance.currentPage;\n\n const event = new KeyboardEvent(\"keydown\", { key: \"Enter\" });\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n\n expect(currentPage).toEqual(1);\n\n input.value = \"15\";\n\n input.focus();\n\n await page.rootInstance.handleKeydown(event);\n\n await waitForTimeout(100);\n\n await page.waitForChanges();\n\n expect(text.textContent).toEqual(\"Page 1 of 10\");\n });\n\n it(\"should hide the tooltip when the input loses focus\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const tooltip = paginationBar.shadowRoot.querySelector(\"ic-tooltip\");\n\n expect(tooltip.getAttribute(\"data-show\")).toBeNull();\n\n input.focus();\n\n input.value = \"15\";\n\n tooltip.displayTooltip(true, false);\n\n await page.waitForChanges();\n\n input.blur();\n\n await page.waitForChanges();\n\n expect(tooltip.getAttribute(\"data-show\")).toBeNull();\n });\n\n it(\"should remove the error status when the input loses focus if the value is not invalid\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n input.focus();\n\n input.value = \"\";\n\n input.validationStatus = \"error\";\n\n await page.waitForChanges();\n\n input.blur();\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toBe(\"\");\n });\n\n it(\"should show the tooltip when the input is focussed if it is in an error state\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n input.focus();\n\n input.value = \"15\";\n\n input.validationStatus = \"error\";\n\n await page.waitForChanges();\n\n input.blur();\n\n await page.waitForChanges();\n\n input.focus();\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toBe(\"error\");\n });\n\n it(\"should error when a non numeric value is entered\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const event = new KeyboardEvent(\"keydown\", { key: \"a\" });\n\n expect(input.validationStatus).toBeUndefined();\n\n input.focus();\n\n await page.rootInstance.handleKeyUp(event);\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"error\");\n });\n\n it(\"should remove the non-numeric error when a number is entered\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const errorEvent = new KeyboardEvent(\"keydown\", { key: \"a\" });\n\n const successEvent = new KeyboardEvent(\"keydown\", { key: \"5\" });\n\n expect(input.validationStatus).toBeUndefined();\n\n input.focus();\n\n await page.rootInstance.handleKeyUp(errorEvent);\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"error\");\n\n await page.rootInstance.handleKeydown(successEvent);\n\n await waitForTimeout(100);\n\n await page.rootInstance.handleInputChange();\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"\");\n });\n\n it(\"should remove the error state when backspace is pressed\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTooltip],\n html: `<ic-pagination-bar total-items=\"100\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n\n const paginationBar = document.querySelector(\"ic-pagination-bar\");\n\n const input = paginationBar.shadowRoot.querySelector(\"ic-text-field\");\n\n const event = new KeyboardEvent(\"keydown\", { key: \"Backspace\" });\n\n expect(input.validationStatus).toBeUndefined();\n\n input.focus();\n\n input.value = \"15\";\n\n input.validationStatus = \"error\";\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"error\");\n\n await page.rootInstance.handleKeydown(event);\n\n await waitForTimeout(100);\n\n await page.waitForChanges();\n\n expect(input.validationStatus).toEqual(\"\");\n });\n\n it(\"should focus the number of items select when clicking its label\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcSelect, IcTypography],\n html: `<ic-pagination-bar total-items=\"100\" show-items-per-page-control=\"true\"></ic-pagination-bar>`,\n });\n const label = document\n .querySelector(\"ic-pagination-bar\")\n .shadowRoot.querySelector(\n \".items-per-page-control-label\"\n ) as HTMLIcTypographyElement;\n\n const event = jest.spyOn(IcSelect.prototype, \"setFocus\");\n label.click();\n\n await page.waitForChanges();\n\n expect(event).toHaveBeenCalled();\n });\n\n // this test currently fails - will need to be fixed before component is moved from canary\n it.skip(\"should focus the go to page text-field when clicking its label\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar, IcPagination, IcTextField, IcTypography],\n html: `<ic-pagination-bar total-items=\"100\" show-items-per-page=\"false\" show-go-to-page-control=\"true\"></ic-pagination-bar>`,\n });\n const label = document\n .querySelector(\"ic-pagination-bar\")\n .shadowRoot.querySelector(\"ic-typography\");\n\n const event = jest.spyOn(IcTextField.prototype, \"setFocus\");\n label.click();\n\n await page.waitForChanges();\n\n expect(event).toHaveBeenCalled();\n });\n\n it(\"should update pagination when number of item changes\", async () => {\n const page = await newSpecPage({\n components: [PaginationBar],\n html: `<ic-pagination-bar total-items=\"0\"></ic-pagination-bar>`,\n });\n\n expect(page.root).toMatchSnapshot();\n\n page.root.totalItems = \"100\";\n\n await page.waitForChanges();\n\n expect(page.root).toMatchSnapshot();\n\n page.root.totalItems = \"50\";\n\n await page.waitForChanges();\n\n expect(page.root).toMatchSnapshot();\n });\n});\n"]}
@@ -463,9 +463,9 @@ ic-input-component-container:hover {
463
463
  }
464
464
 
465
465
  ic-input-component-container:active {
466
- --border-color: var(--ic-action-dark-active);
466
+ --border-color: var(--ic-action-dark-pressed);
467
467
 
468
- color: var(--ic-action-dark-active);
468
+ color: var(--ic-action-dark-pressed);
469
469
  }
470
470
 
471
471
  ic-input-component-container.menu-open {
@@ -493,7 +493,7 @@ select {
493
493
  border: 0;
494
494
  border-radius: var(--ic-border-radius);
495
495
  background-color: var(--ic-architectural-white);
496
- color: var(--ic-color-primary-text);
496
+ color: var(--ic-color-text-primary);
497
497
  line-height: 1.5rem;
498
498
  letter-spacing: 0.005rem;
499
499
  width: 100%;
@@ -509,7 +509,7 @@ select {
509
509
 
510
510
  select option,
511
511
  .select-option-selected {
512
- color: var(--ic-color-primary-text);
512
+ color: var(--ic-color-text-primary);
513
513
  }
514
514
 
515
515
  select:disabled {
@@ -632,7 +632,7 @@ select:not([disabled]) {
632
632
 
633
633
  :host(.ic-select-disabled) .value-text,
634
634
  .placeholder {
635
- color: var(--ic-color-tertiary-text);
635
+ color: var(--ic-color-text-tertiary);
636
636
  }
637
637
 
638
638
  .select-input-end {
@@ -669,8 +669,8 @@ select:not([disabled]) {
669
669
  }
670
670
 
671
671
  .clear-button:focus {
672
- background-color: var(--ic-focus-blue);
673
- box-shadow: inset 0 0 0 0.125rem var(--ic-focus-glow);
672
+ background-color: var(--ic-color-focus-inner);
673
+ box-shadow: inset 0 0 0 0.125rem var(--ic-color-focus-outer);
674
674
  border-radius: 0.25rem;
675
675
  }
676
676