@furystack/shades-common-components 10.0.35 → 12.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (862) hide show
  1. package/CHANGELOG.md +496 -0
  2. package/esm/components/accordion/accordion-item.d.ts +31 -0
  3. package/esm/components/accordion/accordion-item.d.ts.map +1 -0
  4. package/esm/components/accordion/accordion-item.js +147 -0
  5. package/esm/components/accordion/accordion-item.js.map +1 -0
  6. package/esm/components/accordion/accordion.d.ts +27 -0
  7. package/esm/components/accordion/accordion.d.ts.map +1 -0
  8. package/esm/components/accordion/accordion.js +39 -0
  9. package/esm/components/accordion/accordion.js.map +1 -0
  10. package/esm/components/accordion/accordion.spec.d.ts +2 -0
  11. package/esm/components/accordion/accordion.spec.d.ts.map +1 -0
  12. package/esm/components/accordion/accordion.spec.js +284 -0
  13. package/esm/components/accordion/accordion.spec.js.map +1 -0
  14. package/esm/components/accordion/index.d.ts +3 -0
  15. package/esm/components/accordion/index.d.ts.map +1 -0
  16. package/esm/components/accordion/index.js +3 -0
  17. package/esm/components/accordion/index.js.map +1 -0
  18. package/esm/components/alert.d.ts +21 -0
  19. package/esm/components/alert.d.ts.map +1 -0
  20. package/esm/components/alert.js +131 -0
  21. package/esm/components/alert.js.map +1 -0
  22. package/esm/components/alert.spec.d.ts +2 -0
  23. package/esm/components/alert.spec.d.ts.map +1 -0
  24. package/esm/components/alert.spec.js +177 -0
  25. package/esm/components/alert.spec.js.map +1 -0
  26. package/esm/components/animations.spec.d.ts +2 -0
  27. package/esm/components/animations.spec.d.ts.map +1 -0
  28. package/esm/components/animations.spec.js +201 -0
  29. package/esm/components/animations.spec.js.map +1 -0
  30. package/esm/components/app-bar-link.d.ts +22 -2
  31. package/esm/components/app-bar-link.d.ts.map +1 -1
  32. package/esm/components/app-bar-link.js +36 -22
  33. package/esm/components/app-bar-link.js.map +1 -1
  34. package/esm/components/app-bar-link.spec.d.ts +2 -0
  35. package/esm/components/app-bar-link.spec.d.ts.map +1 -0
  36. package/esm/components/app-bar-link.spec.js +255 -0
  37. package/esm/components/app-bar-link.spec.js.map +1 -0
  38. package/esm/components/app-bar.d.ts +2 -0
  39. package/esm/components/app-bar.d.ts.map +1 -1
  40. package/esm/components/app-bar.js +28 -23
  41. package/esm/components/app-bar.js.map +1 -1
  42. package/esm/components/app-bar.spec.d.ts +2 -0
  43. package/esm/components/app-bar.spec.d.ts.map +1 -0
  44. package/esm/components/app-bar.spec.js +132 -0
  45. package/esm/components/app-bar.spec.js.map +1 -0
  46. package/esm/components/avatar.d.ts +2 -0
  47. package/esm/components/avatar.d.ts.map +1 -1
  48. package/esm/components/avatar.js +50 -51
  49. package/esm/components/avatar.js.map +1 -1
  50. package/esm/components/avatar.spec.d.ts +2 -0
  51. package/esm/components/avatar.spec.d.ts.map +1 -0
  52. package/esm/components/avatar.spec.js +114 -0
  53. package/esm/components/avatar.spec.js.map +1 -0
  54. package/esm/components/badge.d.ts +35 -0
  55. package/esm/components/badge.d.ts.map +1 -0
  56. package/esm/components/badge.js +68 -0
  57. package/esm/components/badge.js.map +1 -0
  58. package/esm/components/badge.spec.d.ts +2 -0
  59. package/esm/components/badge.spec.d.ts.map +1 -0
  60. package/esm/components/badge.spec.js +157 -0
  61. package/esm/components/badge.spec.js.map +1 -0
  62. package/esm/components/breadcrumb.d.ts +103 -0
  63. package/esm/components/breadcrumb.d.ts.map +1 -0
  64. package/esm/components/breadcrumb.js +121 -0
  65. package/esm/components/breadcrumb.js.map +1 -0
  66. package/esm/components/breadcrumb.spec.d.ts +2 -0
  67. package/esm/components/breadcrumb.spec.d.ts.map +1 -0
  68. package/esm/components/breadcrumb.spec.js +251 -0
  69. package/esm/components/breadcrumb.spec.js.map +1 -0
  70. package/esm/components/button-group.d.ts +85 -0
  71. package/esm/components/button-group.d.ts.map +1 -0
  72. package/esm/components/button-group.js +290 -0
  73. package/esm/components/button-group.js.map +1 -0
  74. package/esm/components/button-group.spec.d.ts +2 -0
  75. package/esm/components/button-group.spec.d.ts.map +1 -0
  76. package/esm/components/button-group.spec.js +502 -0
  77. package/esm/components/button-group.spec.js.map +1 -0
  78. package/esm/components/button.d.ts +44 -2
  79. package/esm/components/button.d.ts.map +1 -1
  80. package/esm/components/button.js +151 -153
  81. package/esm/components/button.js.map +1 -1
  82. package/esm/components/button.spec.d.ts +2 -0
  83. package/esm/components/button.spec.d.ts.map +1 -0
  84. package/esm/components/button.spec.js +310 -0
  85. package/esm/components/button.spec.js.map +1 -0
  86. package/esm/components/card.d.ts +117 -0
  87. package/esm/components/card.d.ts.map +1 -0
  88. package/esm/components/card.js +181 -0
  89. package/esm/components/card.js.map +1 -0
  90. package/esm/components/card.spec.d.ts +2 -0
  91. package/esm/components/card.spec.d.ts.map +1 -0
  92. package/esm/components/card.spec.js +278 -0
  93. package/esm/components/card.spec.js.map +1 -0
  94. package/esm/components/carousel.d.ts +50 -0
  95. package/esm/components/carousel.d.ts.map +1 -0
  96. package/esm/components/carousel.js +263 -0
  97. package/esm/components/carousel.js.map +1 -0
  98. package/esm/components/carousel.spec.d.ts +2 -0
  99. package/esm/components/carousel.spec.d.ts.map +1 -0
  100. package/esm/components/carousel.spec.js +677 -0
  101. package/esm/components/carousel.spec.js.map +1 -0
  102. package/esm/components/chip.d.ts +23 -0
  103. package/esm/components/chip.d.ts.map +1 -0
  104. package/esm/components/chip.js +139 -0
  105. package/esm/components/chip.js.map +1 -0
  106. package/esm/components/chip.spec.d.ts +2 -0
  107. package/esm/components/chip.spec.d.ts.map +1 -0
  108. package/esm/components/chip.spec.js +142 -0
  109. package/esm/components/chip.spec.js.map +1 -0
  110. package/esm/components/circular-progress.d.ts +37 -0
  111. package/esm/components/circular-progress.d.ts.map +1 -0
  112. package/esm/components/circular-progress.js +84 -0
  113. package/esm/components/circular-progress.js.map +1 -0
  114. package/esm/components/circular-progress.spec.d.ts +2 -0
  115. package/esm/components/circular-progress.spec.d.ts.map +1 -0
  116. package/esm/components/circular-progress.spec.js +228 -0
  117. package/esm/components/circular-progress.spec.js.map +1 -0
  118. package/esm/components/command-palette/command-palette-input.d.ts +3 -0
  119. package/esm/components/command-palette/command-palette-input.d.ts.map +1 -1
  120. package/esm/components/command-palette/command-palette-input.js +33 -23
  121. package/esm/components/command-palette/command-palette-input.js.map +1 -1
  122. package/esm/components/command-palette/command-palette-input.spec.d.ts +2 -0
  123. package/esm/components/command-palette/command-palette-input.spec.d.ts.map +1 -0
  124. package/esm/components/command-palette/command-palette-input.spec.js +244 -0
  125. package/esm/components/command-palette/command-palette-input.spec.js.map +1 -0
  126. package/esm/components/command-palette/command-palette-manager.spec.d.ts +2 -0
  127. package/esm/components/command-palette/command-palette-manager.spec.d.ts.map +1 -0
  128. package/esm/components/command-palette/command-palette-manager.spec.js +378 -0
  129. package/esm/components/command-palette/command-palette-manager.spec.js.map +1 -0
  130. package/esm/components/command-palette/command-palette-suggestion-list.d.ts +2 -0
  131. package/esm/components/command-palette/command-palette-suggestion-list.d.ts.map +1 -1
  132. package/esm/components/command-palette/command-palette-suggestion-list.js +53 -57
  133. package/esm/components/command-palette/command-palette-suggestion-list.js.map +1 -1
  134. package/esm/components/command-palette/command-palette-suggestion-list.spec.d.ts +2 -0
  135. package/esm/components/command-palette/command-palette-suggestion-list.spec.d.ts.map +1 -0
  136. package/esm/components/command-palette/command-palette-suggestion-list.spec.js +394 -0
  137. package/esm/components/command-palette/command-palette-suggestion-list.spec.js.map +1 -0
  138. package/esm/components/command-palette/index.d.ts +2 -0
  139. package/esm/components/command-palette/index.d.ts.map +1 -1
  140. package/esm/components/command-palette/index.js +41 -120
  141. package/esm/components/command-palette/index.js.map +1 -1
  142. package/esm/components/command-palette/index.spec.d.ts +2 -0
  143. package/esm/components/command-palette/index.spec.d.ts.map +1 -0
  144. package/esm/components/command-palette/index.spec.js +509 -0
  145. package/esm/components/command-palette/index.spec.js.map +1 -0
  146. package/esm/components/context-menu/context-menu-item.d.ts +9 -0
  147. package/esm/components/context-menu/context-menu-item.d.ts.map +1 -0
  148. package/esm/components/context-menu/context-menu-item.js +56 -0
  149. package/esm/components/context-menu/context-menu-item.js.map +1 -0
  150. package/esm/components/context-menu/context-menu-manager.d.ts +52 -0
  151. package/esm/components/context-menu/context-menu-manager.d.ts.map +1 -0
  152. package/esm/components/context-menu/context-menu-manager.js +128 -0
  153. package/esm/components/context-menu/context-menu-manager.js.map +1 -0
  154. package/esm/components/context-menu/context-menu-manager.spec.d.ts +2 -0
  155. package/esm/components/context-menu/context-menu-manager.spec.d.ts.map +1 -0
  156. package/esm/components/context-menu/context-menu-manager.spec.js +332 -0
  157. package/esm/components/context-menu/context-menu-manager.spec.js.map +1 -0
  158. package/esm/components/context-menu/context-menu.d.ts +8 -0
  159. package/esm/components/context-menu/context-menu.d.ts.map +1 -0
  160. package/esm/components/context-menu/context-menu.js +79 -0
  161. package/esm/components/context-menu/context-menu.js.map +1 -0
  162. package/esm/components/context-menu/context-menu.spec.d.ts +2 -0
  163. package/esm/components/context-menu/context-menu.spec.d.ts.map +1 -0
  164. package/esm/components/context-menu/context-menu.spec.js +282 -0
  165. package/esm/components/context-menu/context-menu.spec.js.map +1 -0
  166. package/esm/components/context-menu/index.d.ts +4 -0
  167. package/esm/components/context-menu/index.d.ts.map +1 -0
  168. package/esm/components/context-menu/index.js +4 -0
  169. package/esm/components/context-menu/index.js.map +1 -0
  170. package/esm/components/data-grid/body.js +1 -1
  171. package/esm/components/data-grid/body.js.map +1 -1
  172. package/esm/components/data-grid/body.spec.d.ts +2 -0
  173. package/esm/components/data-grid/body.spec.d.ts.map +1 -0
  174. package/esm/components/data-grid/body.spec.js +238 -0
  175. package/esm/components/data-grid/body.spec.js.map +1 -0
  176. package/esm/components/data-grid/data-grid-row.d.ts.map +1 -1
  177. package/esm/components/data-grid/data-grid-row.js +84 -96
  178. package/esm/components/data-grid/data-grid-row.js.map +1 -1
  179. package/esm/components/data-grid/data-grid-row.spec.d.ts +2 -0
  180. package/esm/components/data-grid/data-grid-row.spec.d.ts.map +1 -0
  181. package/esm/components/data-grid/data-grid-row.spec.js +328 -0
  182. package/esm/components/data-grid/data-grid-row.spec.js.map +1 -0
  183. package/esm/components/data-grid/data-grid.d.ts.map +1 -1
  184. package/esm/components/data-grid/data-grid.js +39 -31
  185. package/esm/components/data-grid/data-grid.js.map +1 -1
  186. package/esm/components/data-grid/data-grid.spec.d.ts +2 -0
  187. package/esm/components/data-grid/data-grid.spec.d.ts.map +1 -0
  188. package/esm/components/data-grid/data-grid.spec.js +569 -0
  189. package/esm/components/data-grid/data-grid.spec.js.map +1 -0
  190. package/esm/components/data-grid/footer.js +21 -15
  191. package/esm/components/data-grid/footer.js.map +1 -1
  192. package/esm/components/data-grid/footer.spec.d.ts +2 -0
  193. package/esm/components/data-grid/footer.spec.d.ts.map +1 -0
  194. package/esm/components/data-grid/footer.spec.js +276 -0
  195. package/esm/components/data-grid/footer.spec.js.map +1 -0
  196. package/esm/components/data-grid/header.d.ts +3 -1
  197. package/esm/components/data-grid/header.d.ts.map +1 -1
  198. package/esm/components/data-grid/header.js +94 -60
  199. package/esm/components/data-grid/header.js.map +1 -1
  200. package/esm/components/data-grid/header.spec.d.ts +2 -0
  201. package/esm/components/data-grid/header.spec.d.ts.map +1 -0
  202. package/esm/components/data-grid/header.spec.js +444 -0
  203. package/esm/components/data-grid/header.spec.js.map +1 -0
  204. package/esm/components/data-grid/selection-cell.d.ts +2 -0
  205. package/esm/components/data-grid/selection-cell.d.ts.map +1 -1
  206. package/esm/components/data-grid/selection-cell.js +15 -13
  207. package/esm/components/data-grid/selection-cell.js.map +1 -1
  208. package/esm/components/data-grid/selection-cell.spec.d.ts +2 -0
  209. package/esm/components/data-grid/selection-cell.spec.d.ts.map +1 -0
  210. package/esm/components/data-grid/selection-cell.spec.js +127 -0
  211. package/esm/components/data-grid/selection-cell.spec.js.map +1 -0
  212. package/esm/components/dialog.d.ts +46 -0
  213. package/esm/components/dialog.d.ts.map +1 -0
  214. package/esm/components/dialog.js +178 -0
  215. package/esm/components/dialog.js.map +1 -0
  216. package/esm/components/dialog.spec.d.ts +2 -0
  217. package/esm/components/dialog.spec.d.ts.map +1 -0
  218. package/esm/components/dialog.spec.js +113 -0
  219. package/esm/components/dialog.spec.js.map +1 -0
  220. package/esm/components/divider.d.ts +22 -0
  221. package/esm/components/divider.d.ts.map +1 -0
  222. package/esm/components/divider.js +113 -0
  223. package/esm/components/divider.js.map +1 -0
  224. package/esm/components/divider.spec.d.ts +2 -0
  225. package/esm/components/divider.spec.d.ts.map +1 -0
  226. package/esm/components/divider.spec.js +136 -0
  227. package/esm/components/divider.spec.js.map +1 -0
  228. package/esm/components/drawer/drawer-toggle-button.d.ts +36 -0
  229. package/esm/components/drawer/drawer-toggle-button.d.ts.map +1 -0
  230. package/esm/components/drawer/drawer-toggle-button.js +94 -0
  231. package/esm/components/drawer/drawer-toggle-button.js.map +1 -0
  232. package/esm/components/drawer/drawer-toggle-button.spec.d.ts +2 -0
  233. package/esm/components/drawer/drawer-toggle-button.spec.d.ts.map +1 -0
  234. package/esm/components/drawer/drawer-toggle-button.spec.js +306 -0
  235. package/esm/components/drawer/drawer-toggle-button.spec.js.map +1 -0
  236. package/esm/components/drawer/index.d.ts +56 -0
  237. package/esm/components/drawer/index.d.ts.map +1 -0
  238. package/esm/components/drawer/index.js +172 -0
  239. package/esm/components/drawer/index.js.map +1 -0
  240. package/esm/components/drawer/index.spec.d.ts +2 -0
  241. package/esm/components/drawer/index.spec.d.ts.map +1 -0
  242. package/esm/components/drawer/index.spec.js +538 -0
  243. package/esm/components/drawer/index.spec.js.map +1 -0
  244. package/esm/components/dropdown.d.ts +15 -0
  245. package/esm/components/dropdown.d.ts.map +1 -0
  246. package/esm/components/dropdown.js +262 -0
  247. package/esm/components/dropdown.js.map +1 -0
  248. package/esm/components/dropdown.spec.d.ts +2 -0
  249. package/esm/components/dropdown.spec.d.ts.map +1 -0
  250. package/esm/components/dropdown.spec.js +372 -0
  251. package/esm/components/dropdown.spec.js.map +1 -0
  252. package/esm/components/fab.d.ts +10 -1
  253. package/esm/components/fab.d.ts.map +1 -1
  254. package/esm/components/fab.js +32 -7
  255. package/esm/components/fab.js.map +1 -1
  256. package/esm/components/fab.spec.d.ts +2 -0
  257. package/esm/components/fab.spec.d.ts.map +1 -0
  258. package/esm/components/fab.spec.js +106 -0
  259. package/esm/components/fab.spec.js.map +1 -0
  260. package/esm/components/form.d.ts.map +1 -1
  261. package/esm/components/form.js +9 -7
  262. package/esm/components/form.js.map +1 -1
  263. package/esm/components/form.spec.d.ts +2 -0
  264. package/esm/components/form.spec.d.ts.map +1 -0
  265. package/esm/components/form.spec.js +324 -0
  266. package/esm/components/form.spec.js.map +1 -0
  267. package/esm/components/grid.d.ts.map +1 -1
  268. package/esm/components/grid.js +43 -40
  269. package/esm/components/grid.js.map +1 -1
  270. package/esm/components/grid.spec.d.ts +2 -0
  271. package/esm/components/grid.spec.d.ts.map +1 -0
  272. package/esm/components/grid.spec.js +340 -0
  273. package/esm/components/grid.spec.js.map +1 -0
  274. package/esm/components/icons/icon-definitions.d.ts +140 -0
  275. package/esm/components/icons/icon-definitions.d.ts.map +1 -0
  276. package/esm/components/icons/icon-definitions.js +432 -0
  277. package/esm/components/icons/icon-definitions.js.map +1 -0
  278. package/esm/components/icons/icon-definitions.spec.d.ts +2 -0
  279. package/esm/components/icons/icon-definitions.spec.d.ts.map +1 -0
  280. package/esm/components/icons/icon-definitions.spec.js +59 -0
  281. package/esm/components/icons/icon-definitions.spec.js.map +1 -0
  282. package/esm/components/icons/icon-types.d.ts +48 -0
  283. package/esm/components/icons/icon-types.d.ts.map +1 -0
  284. package/esm/components/icons/icon-types.js +2 -0
  285. package/esm/components/icons/icon-types.js.map +1 -0
  286. package/esm/components/icons/icon.d.ts +56 -0
  287. package/esm/components/icons/icon.d.ts.map +1 -0
  288. package/esm/components/icons/icon.js +61 -0
  289. package/esm/components/icons/icon.js.map +1 -0
  290. package/esm/components/icons/icon.spec.d.ts +2 -0
  291. package/esm/components/icons/icon.spec.d.ts.map +1 -0
  292. package/esm/components/icons/icon.spec.js +224 -0
  293. package/esm/components/icons/icon.spec.js.map +1 -0
  294. package/esm/components/icons/index.d.ts +5 -0
  295. package/esm/components/icons/index.d.ts.map +1 -0
  296. package/esm/components/icons/index.js +3 -0
  297. package/esm/components/icons/index.js.map +1 -0
  298. package/esm/components/image.d.ts +62 -0
  299. package/esm/components/image.d.ts.map +1 -0
  300. package/esm/components/image.js +348 -0
  301. package/esm/components/image.js.map +1 -0
  302. package/esm/components/image.spec.d.ts +2 -0
  303. package/esm/components/image.spec.d.ts.map +1 -0
  304. package/esm/components/image.spec.js +542 -0
  305. package/esm/components/image.spec.js.map +1 -0
  306. package/esm/components/index.d.ts +32 -4
  307. package/esm/components/index.d.ts.map +1 -1
  308. package/esm/components/index.js +32 -4
  309. package/esm/components/index.js.map +1 -1
  310. package/esm/components/inputs/autocomplete.d.ts +2 -0
  311. package/esm/components/inputs/autocomplete.d.ts.map +1 -1
  312. package/esm/components/inputs/autocomplete.js +10 -6
  313. package/esm/components/inputs/autocomplete.js.map +1 -1
  314. package/esm/components/inputs/autocomplete.spec.d.ts +2 -0
  315. package/esm/components/inputs/autocomplete.spec.d.ts.map +1 -0
  316. package/esm/components/inputs/autocomplete.spec.js +203 -0
  317. package/esm/components/inputs/autocomplete.spec.js.map +1 -0
  318. package/esm/components/inputs/checkbox.d.ts +50 -0
  319. package/esm/components/inputs/checkbox.d.ts.map +1 -0
  320. package/esm/components/inputs/checkbox.js +126 -0
  321. package/esm/components/inputs/checkbox.js.map +1 -0
  322. package/esm/components/inputs/checkbox.spec.d.ts +2 -0
  323. package/esm/components/inputs/checkbox.spec.d.ts.map +1 -0
  324. package/esm/components/inputs/checkbox.spec.js +287 -0
  325. package/esm/components/inputs/checkbox.spec.js.map +1 -0
  326. package/esm/components/inputs/index.d.ts +7 -0
  327. package/esm/components/inputs/index.d.ts.map +1 -1
  328. package/esm/components/inputs/index.js +7 -0
  329. package/esm/components/inputs/index.js.map +1 -1
  330. package/esm/components/inputs/input-number.d.ts +79 -0
  331. package/esm/components/inputs/input-number.d.ts.map +1 -0
  332. package/esm/components/inputs/input-number.js +232 -0
  333. package/esm/components/inputs/input-number.js.map +1 -0
  334. package/esm/components/inputs/input-number.spec.d.ts +2 -0
  335. package/esm/components/inputs/input-number.spec.d.ts.map +1 -0
  336. package/esm/components/inputs/input-number.spec.js +516 -0
  337. package/esm/components/inputs/input-number.spec.js.map +1 -0
  338. package/esm/components/inputs/input.d.ts +2 -1
  339. package/esm/components/inputs/input.d.ts.map +1 -1
  340. package/esm/components/inputs/input.js +179 -177
  341. package/esm/components/inputs/input.js.map +1 -1
  342. package/esm/components/inputs/input.spec.d.ts +2 -0
  343. package/esm/components/inputs/input.spec.d.ts.map +1 -0
  344. package/esm/components/inputs/input.spec.js +611 -0
  345. package/esm/components/inputs/input.spec.js.map +1 -0
  346. package/esm/components/inputs/radio-group.d.ts +38 -0
  347. package/esm/components/inputs/radio-group.d.ts.map +1 -0
  348. package/esm/components/inputs/radio-group.js +58 -0
  349. package/esm/components/inputs/radio-group.js.map +1 -0
  350. package/esm/components/inputs/radio-group.spec.d.ts +2 -0
  351. package/esm/components/inputs/radio-group.spec.d.ts.map +1 -0
  352. package/esm/components/inputs/radio-group.spec.js +201 -0
  353. package/esm/components/inputs/radio-group.spec.js.map +1 -0
  354. package/esm/components/inputs/radio.d.ts +42 -0
  355. package/esm/components/inputs/radio.d.ts.map +1 -0
  356. package/esm/components/inputs/radio.js +134 -0
  357. package/esm/components/inputs/radio.js.map +1 -0
  358. package/esm/components/inputs/radio.spec.d.ts +2 -0
  359. package/esm/components/inputs/radio.spec.d.ts.map +1 -0
  360. package/esm/components/inputs/radio.spec.js +211 -0
  361. package/esm/components/inputs/radio.spec.js.map +1 -0
  362. package/esm/components/inputs/select.d.ts +67 -0
  363. package/esm/components/inputs/select.d.ts.map +1 -0
  364. package/esm/components/inputs/select.js +581 -0
  365. package/esm/components/inputs/select.js.map +1 -0
  366. package/esm/components/inputs/select.spec.d.ts +2 -0
  367. package/esm/components/inputs/select.spec.d.ts.map +1 -0
  368. package/esm/components/inputs/select.spec.js +1009 -0
  369. package/esm/components/inputs/select.spec.js.map +1 -0
  370. package/esm/components/inputs/slider.d.ts +66 -0
  371. package/esm/components/inputs/slider.d.ts.map +1 -0
  372. package/esm/components/inputs/slider.js +526 -0
  373. package/esm/components/inputs/slider.js.map +1 -0
  374. package/esm/components/inputs/slider.spec.d.ts +2 -0
  375. package/esm/components/inputs/slider.spec.d.ts.map +1 -0
  376. package/esm/components/inputs/slider.spec.js +812 -0
  377. package/esm/components/inputs/slider.spec.js.map +1 -0
  378. package/esm/components/inputs/switch.d.ts +50 -0
  379. package/esm/components/inputs/switch.d.ts.map +1 -0
  380. package/esm/components/inputs/switch.js +138 -0
  381. package/esm/components/inputs/switch.js.map +1 -0
  382. package/esm/components/inputs/switch.spec.d.ts +2 -0
  383. package/esm/components/inputs/switch.spec.d.ts.map +1 -0
  384. package/esm/components/inputs/switch.spec.js +313 -0
  385. package/esm/components/inputs/switch.spec.js.map +1 -0
  386. package/esm/components/inputs/text-area.d.ts +2 -0
  387. package/esm/components/inputs/text-area.d.ts.map +1 -1
  388. package/esm/components/inputs/text-area.js +46 -58
  389. package/esm/components/inputs/text-area.js.map +1 -1
  390. package/esm/components/inputs/text-area.spec.d.ts +2 -0
  391. package/esm/components/inputs/text-area.spec.d.ts.map +1 -0
  392. package/esm/components/inputs/text-area.spec.js +229 -0
  393. package/esm/components/inputs/text-area.spec.js.map +1 -0
  394. package/esm/components/linear-progress.d.ts +32 -0
  395. package/esm/components/linear-progress.d.ts.map +1 -0
  396. package/esm/components/linear-progress.js +79 -0
  397. package/esm/components/linear-progress.js.map +1 -0
  398. package/esm/components/linear-progress.spec.d.ts +2 -0
  399. package/esm/components/linear-progress.spec.d.ts.map +1 -0
  400. package/esm/components/linear-progress.spec.js +251 -0
  401. package/esm/components/linear-progress.spec.js.map +1 -0
  402. package/esm/components/list/index.d.ts +3 -0
  403. package/esm/components/list/index.d.ts.map +1 -0
  404. package/esm/components/list/index.js +3 -0
  405. package/esm/components/list/index.js.map +1 -0
  406. package/esm/components/list/list-item.d.ts +13 -0
  407. package/esm/components/list/list-item.d.ts.map +1 -0
  408. package/esm/components/list/list-item.js +81 -0
  409. package/esm/components/list/list-item.js.map +1 -0
  410. package/esm/components/list/list.d.ts +18 -0
  411. package/esm/components/list/list.d.ts.map +1 -0
  412. package/esm/components/list/list.js +42 -0
  413. package/esm/components/list/list.js.map +1 -0
  414. package/esm/components/list/list.spec.d.ts +2 -0
  415. package/esm/components/list/list.spec.d.ts.map +1 -0
  416. package/esm/components/list/list.spec.js +540 -0
  417. package/esm/components/list/list.spec.js.map +1 -0
  418. package/esm/components/loader.d.ts +2 -0
  419. package/esm/components/loader.d.ts.map +1 -1
  420. package/esm/components/loader.js +19 -11
  421. package/esm/components/loader.js.map +1 -1
  422. package/esm/components/loader.spec.d.ts +2 -0
  423. package/esm/components/loader.spec.d.ts.map +1 -0
  424. package/esm/components/loader.spec.js +267 -0
  425. package/esm/components/loader.spec.js.map +1 -0
  426. package/esm/components/menu/index.d.ts +3 -0
  427. package/esm/components/menu/index.d.ts.map +1 -0
  428. package/esm/components/menu/index.js +3 -0
  429. package/esm/components/menu/index.js.map +1 -0
  430. package/esm/components/menu/menu-types.d.ts +27 -0
  431. package/esm/components/menu/menu-types.d.ts.map +1 -0
  432. package/esm/components/menu/menu-types.js +22 -0
  433. package/esm/components/menu/menu-types.js.map +1 -0
  434. package/esm/components/menu/menu-types.spec.d.ts +2 -0
  435. package/esm/components/menu/menu-types.spec.d.ts.map +1 -0
  436. package/esm/components/menu/menu-types.spec.js +103 -0
  437. package/esm/components/menu/menu-types.spec.js.map +1 -0
  438. package/esm/components/menu/menu.d.ts +17 -0
  439. package/esm/components/menu/menu.d.ts.map +1 -0
  440. package/esm/components/menu/menu.js +240 -0
  441. package/esm/components/menu/menu.js.map +1 -0
  442. package/esm/components/menu/menu.spec.d.ts +2 -0
  443. package/esm/components/menu/menu.spec.d.ts.map +1 -0
  444. package/esm/components/menu/menu.spec.js +427 -0
  445. package/esm/components/menu/menu.spec.js.map +1 -0
  446. package/esm/components/modal.d.ts +3 -2
  447. package/esm/components/modal.d.ts.map +1 -1
  448. package/esm/components/modal.js +19 -14
  449. package/esm/components/modal.js.map +1 -1
  450. package/esm/components/modal.spec.d.ts +2 -0
  451. package/esm/components/modal.spec.d.ts.map +1 -0
  452. package/esm/components/modal.spec.js +234 -0
  453. package/esm/components/modal.spec.js.map +1 -0
  454. package/esm/components/noty-list.d.ts +4 -0
  455. package/esm/components/noty-list.d.ts.map +1 -1
  456. package/esm/components/noty-list.js +87 -76
  457. package/esm/components/noty-list.js.map +1 -1
  458. package/esm/components/noty-list.spec.d.ts +2 -0
  459. package/esm/components/noty-list.spec.d.ts.map +1 -0
  460. package/esm/components/noty-list.spec.js +489 -0
  461. package/esm/components/noty-list.spec.js.map +1 -0
  462. package/esm/components/page-container/index.d.ts +54 -0
  463. package/esm/components/page-container/index.d.ts.map +1 -0
  464. package/esm/components/page-container/index.js +63 -0
  465. package/esm/components/page-container/index.js.map +1 -0
  466. package/esm/components/page-container/index.spec.d.ts +2 -0
  467. package/esm/components/page-container/index.spec.d.ts.map +1 -0
  468. package/esm/components/page-container/index.spec.js +217 -0
  469. package/esm/components/page-container/index.spec.js.map +1 -0
  470. package/esm/components/page-container/page-header.d.ts +57 -0
  471. package/esm/components/page-container/page-header.d.ts.map +1 -0
  472. package/esm/components/page-container/page-header.js +93 -0
  473. package/esm/components/page-container/page-header.js.map +1 -0
  474. package/esm/components/page-container/page-header.spec.d.ts +2 -0
  475. package/esm/components/page-container/page-header.spec.d.ts.map +1 -0
  476. package/esm/components/page-container/page-header.spec.js +230 -0
  477. package/esm/components/page-container/page-header.spec.js.map +1 -0
  478. package/esm/components/page-layout/index.d.ts +83 -0
  479. package/esm/components/page-layout/index.d.ts.map +1 -0
  480. package/esm/components/page-layout/index.js +288 -0
  481. package/esm/components/page-layout/index.js.map +1 -0
  482. package/esm/components/page-layout/index.spec.d.ts +2 -0
  483. package/esm/components/page-layout/index.spec.d.ts.map +1 -0
  484. package/esm/components/page-layout/index.spec.js +637 -0
  485. package/esm/components/page-layout/index.spec.js.map +1 -0
  486. package/esm/components/pagination.d.ts +43 -0
  487. package/esm/components/pagination.d.ts.map +1 -0
  488. package/esm/components/pagination.js +165 -0
  489. package/esm/components/pagination.js.map +1 -0
  490. package/esm/components/pagination.spec.d.ts +2 -0
  491. package/esm/components/pagination.spec.d.ts.map +1 -0
  492. package/esm/components/pagination.spec.js +195 -0
  493. package/esm/components/pagination.spec.js.map +1 -0
  494. package/esm/components/paper.d.ts +3 -1
  495. package/esm/components/paper.d.ts.map +1 -1
  496. package/esm/components/paper.js +20 -15
  497. package/esm/components/paper.js.map +1 -1
  498. package/esm/components/paper.spec.d.ts +2 -0
  499. package/esm/components/paper.spec.d.ts.map +1 -0
  500. package/esm/components/paper.spec.js +71 -0
  501. package/esm/components/paper.spec.js.map +1 -0
  502. package/esm/components/rating.d.ts +62 -0
  503. package/esm/components/rating.d.ts.map +1 -0
  504. package/esm/components/rating.js +201 -0
  505. package/esm/components/rating.js.map +1 -0
  506. package/esm/components/rating.spec.d.ts +2 -0
  507. package/esm/components/rating.spec.d.ts.map +1 -0
  508. package/esm/components/rating.spec.js +663 -0
  509. package/esm/components/rating.spec.js.map +1 -0
  510. package/esm/components/result.d.ts +37 -0
  511. package/esm/components/result.d.ts.map +1 -0
  512. package/esm/components/result.js +109 -0
  513. package/esm/components/result.js.map +1 -0
  514. package/esm/components/result.spec.d.ts +2 -0
  515. package/esm/components/result.spec.d.ts.map +1 -0
  516. package/esm/components/result.spec.js +159 -0
  517. package/esm/components/result.spec.js.map +1 -0
  518. package/esm/components/searchable-input-styles.d.ts +8 -0
  519. package/esm/components/searchable-input-styles.d.ts.map +1 -0
  520. package/esm/components/searchable-input-styles.js +71 -0
  521. package/esm/components/searchable-input-styles.js.map +1 -0
  522. package/esm/components/skeleton.d.ts +2 -0
  523. package/esm/components/skeleton.d.ts.map +1 -1
  524. package/esm/components/skeleton.js +20 -7
  525. package/esm/components/skeleton.js.map +1 -1
  526. package/esm/components/skeleton.spec.d.ts +2 -0
  527. package/esm/components/skeleton.spec.d.ts.map +1 -0
  528. package/esm/components/skeleton.spec.js +167 -0
  529. package/esm/components/skeleton.spec.js.map +1 -0
  530. package/esm/components/styles.d.ts.map +1 -1
  531. package/esm/components/styles.js +14 -13
  532. package/esm/components/styles.js.map +1 -1
  533. package/esm/components/styles.spec.d.ts +2 -0
  534. package/esm/components/styles.spec.d.ts.map +1 -0
  535. package/esm/components/styles.spec.js +57 -0
  536. package/esm/components/styles.spec.js.map +1 -0
  537. package/esm/components/suggest/index.d.ts.map +1 -1
  538. package/esm/components/suggest/index.js +32 -102
  539. package/esm/components/suggest/index.js.map +1 -1
  540. package/esm/components/suggest/index.spec.d.ts +2 -0
  541. package/esm/components/suggest/index.spec.d.ts.map +1 -0
  542. package/esm/components/suggest/index.spec.js +539 -0
  543. package/esm/components/suggest/index.spec.js.map +1 -0
  544. package/esm/components/suggest/suggest-input.d.ts +2 -0
  545. package/esm/components/suggest/suggest-input.d.ts.map +1 -1
  546. package/esm/components/suggest/suggest-input.js +24 -23
  547. package/esm/components/suggest/suggest-input.js.map +1 -1
  548. package/esm/components/suggest/suggest-input.spec.d.ts +2 -0
  549. package/esm/components/suggest/suggest-input.spec.d.ts.map +1 -0
  550. package/esm/components/suggest/suggest-input.spec.js +150 -0
  551. package/esm/components/suggest/suggest-input.spec.js.map +1 -0
  552. package/esm/components/suggest/suggest-manager.spec.d.ts +2 -0
  553. package/esm/components/suggest/suggest-manager.spec.d.ts.map +1 -0
  554. package/esm/components/suggest/suggest-manager.spec.js +318 -0
  555. package/esm/components/suggest/suggest-manager.spec.js.map +1 -0
  556. package/esm/components/suggest/suggestion-list.d.ts.map +1 -1
  557. package/esm/components/suggest/suggestion-list.js +52 -58
  558. package/esm/components/suggest/suggestion-list.js.map +1 -1
  559. package/esm/components/suggest/suggestion-list.spec.d.ts +2 -0
  560. package/esm/components/suggest/suggestion-list.spec.d.ts.map +1 -0
  561. package/esm/components/suggest/suggestion-list.spec.js +271 -0
  562. package/esm/components/suggest/suggestion-list.spec.js.map +1 -0
  563. package/esm/components/tabs.d.ts +18 -2
  564. package/esm/components/tabs.d.ts.map +1 -1
  565. package/esm/components/tabs.js +173 -19
  566. package/esm/components/tabs.js.map +1 -1
  567. package/esm/components/tabs.spec.d.ts +2 -0
  568. package/esm/components/tabs.spec.d.ts.map +1 -0
  569. package/esm/components/tabs.spec.js +475 -0
  570. package/esm/components/tabs.spec.js.map +1 -0
  571. package/esm/components/timeline.d.ts +53 -0
  572. package/esm/components/timeline.d.ts.map +1 -0
  573. package/esm/components/timeline.js +162 -0
  574. package/esm/components/timeline.js.map +1 -0
  575. package/esm/components/timeline.spec.d.ts +2 -0
  576. package/esm/components/timeline.spec.d.ts.map +1 -0
  577. package/esm/components/timeline.spec.js +209 -0
  578. package/esm/components/timeline.spec.js.map +1 -0
  579. package/esm/components/tooltip.d.ts +25 -0
  580. package/esm/components/tooltip.d.ts.map +1 -0
  581. package/esm/components/tooltip.js +113 -0
  582. package/esm/components/tooltip.js.map +1 -0
  583. package/esm/components/tooltip.spec.d.ts +2 -0
  584. package/esm/components/tooltip.spec.d.ts.map +1 -0
  585. package/esm/components/tooltip.spec.js +152 -0
  586. package/esm/components/tooltip.spec.js.map +1 -0
  587. package/esm/components/tree/index.d.ts +3 -0
  588. package/esm/components/tree/index.d.ts.map +1 -0
  589. package/esm/components/tree/index.js +3 -0
  590. package/esm/components/tree/index.js.map +1 -0
  591. package/esm/components/tree/tree-item.d.ts +14 -0
  592. package/esm/components/tree/tree-item.d.ts.map +1 -0
  593. package/esm/components/tree/tree-item.js +118 -0
  594. package/esm/components/tree/tree-item.js.map +1 -0
  595. package/esm/components/tree/tree.d.ts +20 -0
  596. package/esm/components/tree/tree.d.ts.map +1 -0
  597. package/esm/components/tree/tree.js +66 -0
  598. package/esm/components/tree/tree.js.map +1 -0
  599. package/esm/components/tree/tree.spec.d.ts +2 -0
  600. package/esm/components/tree/tree.spec.d.ts.map +1 -0
  601. package/esm/components/tree/tree.spec.js +427 -0
  602. package/esm/components/tree/tree.spec.js.map +1 -0
  603. package/esm/components/typography.d.ts +48 -0
  604. package/esm/components/typography.d.ts.map +1 -0
  605. package/esm/components/typography.js +223 -0
  606. package/esm/components/typography.js.map +1 -0
  607. package/esm/components/typography.spec.d.ts +2 -0
  608. package/esm/components/typography.spec.d.ts.map +1 -0
  609. package/esm/components/typography.spec.js +199 -0
  610. package/esm/components/typography.spec.js.map +1 -0
  611. package/esm/components/wizard/index.d.ts +2 -0
  612. package/esm/components/wizard/index.d.ts.map +1 -1
  613. package/esm/components/wizard/index.js +10 -7
  614. package/esm/components/wizard/index.js.map +1 -1
  615. package/esm/components/wizard/index.spec.d.ts +2 -0
  616. package/esm/components/wizard/index.spec.d.ts.map +1 -0
  617. package/esm/components/wizard/index.spec.js +185 -0
  618. package/esm/components/wizard/index.spec.js.map +1 -0
  619. package/esm/services/click-away-service.d.ts +5 -2
  620. package/esm/services/click-away-service.d.ts.map +1 -1
  621. package/esm/services/click-away-service.js +7 -1
  622. package/esm/services/click-away-service.js.map +1 -1
  623. package/esm/services/collection-service.spec.js +391 -2
  624. package/esm/services/collection-service.spec.js.map +1 -1
  625. package/esm/services/css-variable-theme.d.ts +167 -1
  626. package/esm/services/css-variable-theme.d.ts.map +1 -1
  627. package/esm/services/css-variable-theme.js +123 -1
  628. package/esm/services/css-variable-theme.js.map +1 -1
  629. package/esm/services/css-variable-theme.spec.d.ts +2 -0
  630. package/esm/services/css-variable-theme.spec.d.ts.map +1 -0
  631. package/esm/services/css-variable-theme.spec.js +299 -0
  632. package/esm/services/css-variable-theme.spec.js.map +1 -0
  633. package/esm/services/default-dark-theme.d.ts +107 -2
  634. package/esm/services/default-dark-theme.d.ts.map +1 -1
  635. package/esm/services/default-dark-theme.js +87 -1
  636. package/esm/services/default-dark-theme.js.map +1 -1
  637. package/esm/services/default-light-theme.d.ts +107 -2
  638. package/esm/services/default-light-theme.d.ts.map +1 -1
  639. package/esm/services/default-light-theme.js +86 -0
  640. package/esm/services/default-light-theme.js.map +1 -1
  641. package/esm/services/default-palette.d.ts +4 -0
  642. package/esm/services/default-palette.d.ts.map +1 -1
  643. package/esm/services/default-palette.js +22 -0
  644. package/esm/services/default-palette.js.map +1 -1
  645. package/esm/services/index.d.ts +6 -2
  646. package/esm/services/index.d.ts.map +1 -1
  647. package/esm/services/index.js +6 -2
  648. package/esm/services/index.js.map +1 -1
  649. package/esm/services/layout-service.d.ts +217 -0
  650. package/esm/services/layout-service.d.ts.map +1 -0
  651. package/esm/services/layout-service.js +331 -0
  652. package/esm/services/layout-service.js.map +1 -0
  653. package/esm/services/layout-service.spec.d.ts +2 -0
  654. package/esm/services/layout-service.spec.d.ts.map +1 -0
  655. package/esm/services/layout-service.spec.js +425 -0
  656. package/esm/services/layout-service.spec.js.map +1 -0
  657. package/esm/services/list-service.d.ts +31 -0
  658. package/esm/services/list-service.d.ts.map +1 -0
  659. package/esm/services/list-service.js +149 -0
  660. package/esm/services/list-service.js.map +1 -0
  661. package/esm/services/list-service.spec.d.ts +2 -0
  662. package/esm/services/list-service.spec.d.ts.map +1 -0
  663. package/esm/services/list-service.spec.js +254 -0
  664. package/esm/services/list-service.spec.js.map +1 -0
  665. package/esm/services/palette-css-vars.d.ts +12 -0
  666. package/esm/services/palette-css-vars.d.ts.map +1 -0
  667. package/esm/services/palette-css-vars.js +44 -0
  668. package/esm/services/palette-css-vars.js.map +1 -0
  669. package/esm/services/theme-provider-service.d.ts +445 -2
  670. package/esm/services/theme-provider-service.d.ts.map +1 -1
  671. package/esm/services/theme-provider-service.js.map +1 -1
  672. package/esm/services/theme-provider-service.spec.d.ts +2 -0
  673. package/esm/services/theme-provider-service.spec.d.ts.map +1 -0
  674. package/esm/services/theme-provider-service.spec.js +166 -0
  675. package/esm/services/theme-provider-service.spec.js.map +1 -0
  676. package/esm/services/tree-service.d.ts +61 -0
  677. package/esm/services/tree-service.d.ts.map +1 -0
  678. package/esm/services/tree-service.js +149 -0
  679. package/esm/services/tree-service.js.map +1 -0
  680. package/esm/services/tree-service.spec.d.ts +2 -0
  681. package/esm/services/tree-service.spec.d.ts.map +1 -0
  682. package/esm/services/tree-service.spec.js +307 -0
  683. package/esm/services/tree-service.spec.js.map +1 -0
  684. package/esm/utils/promisify-animation.d.ts.map +1 -1
  685. package/esm/utils/promisify-animation.js +6 -1
  686. package/esm/utils/promisify-animation.js.map +1 -1
  687. package/package.json +4 -4
  688. package/src/components/accordion/accordion-item.tsx +197 -0
  689. package/src/components/accordion/accordion.spec.tsx +418 -0
  690. package/src/components/accordion/accordion.tsx +50 -0
  691. package/src/components/accordion/index.ts +2 -0
  692. package/src/components/alert.spec.tsx +256 -0
  693. package/src/components/alert.tsx +186 -0
  694. package/src/components/animations.spec.ts +299 -0
  695. package/src/components/app-bar-link.spec.tsx +344 -0
  696. package/src/components/app-bar-link.tsx +44 -25
  697. package/src/components/app-bar.spec.tsx +157 -0
  698. package/src/components/app-bar.tsx +31 -24
  699. package/src/components/avatar.spec.tsx +146 -0
  700. package/src/components/avatar.tsx +56 -60
  701. package/src/components/badge.spec.tsx +228 -0
  702. package/src/components/badge.tsx +104 -0
  703. package/src/components/breadcrumb.spec.tsx +396 -0
  704. package/src/components/breadcrumb.tsx +188 -0
  705. package/src/components/button-group.spec.tsx +611 -0
  706. package/src/components/button-group.tsx +423 -0
  707. package/src/components/button.spec.tsx +383 -0
  708. package/src/components/button.tsx +211 -196
  709. package/src/components/card.spec.tsx +389 -0
  710. package/src/components/card.tsx +261 -0
  711. package/src/components/carousel.spec.tsx +894 -0
  712. package/src/components/carousel.tsx +376 -0
  713. package/src/components/chip.spec.tsx +200 -0
  714. package/src/components/chip.tsx +188 -0
  715. package/src/components/circular-progress.spec.tsx +289 -0
  716. package/src/components/circular-progress.tsx +145 -0
  717. package/src/components/command-palette/command-palette-input.spec.tsx +331 -0
  718. package/src/components/command-palette/command-palette-input.tsx +40 -27
  719. package/src/components/command-palette/command-palette-manager.spec.ts +485 -0
  720. package/src/components/command-palette/command-palette-suggestion-list.spec.tsx +517 -0
  721. package/src/components/command-palette/command-palette-suggestion-list.tsx +55 -57
  722. package/src/components/command-palette/index.spec.tsx +684 -0
  723. package/src/components/command-palette/index.tsx +42 -148
  724. package/src/components/context-menu/context-menu-item.tsx +85 -0
  725. package/src/components/context-menu/context-menu-manager.spec.ts +478 -0
  726. package/src/components/context-menu/context-menu-manager.ts +148 -0
  727. package/src/components/context-menu/context-menu.spec.tsx +352 -0
  728. package/src/components/context-menu/context-menu.tsx +116 -0
  729. package/src/components/context-menu/index.ts +3 -0
  730. package/src/components/data-grid/body.spec.tsx +354 -0
  731. package/src/components/data-grid/body.tsx +1 -1
  732. package/src/components/data-grid/data-grid-row.spec.tsx +407 -0
  733. package/src/components/data-grid/data-grid-row.tsx +87 -102
  734. package/src/components/data-grid/data-grid.spec.tsx +964 -0
  735. package/src/components/data-grid/data-grid.tsx +45 -38
  736. package/src/components/data-grid/footer.spec.tsx +356 -0
  737. package/src/components/data-grid/footer.tsx +19 -19
  738. package/src/components/data-grid/header.spec.tsx +586 -0
  739. package/src/components/data-grid/header.tsx +104 -76
  740. package/src/components/data-grid/selection-cell.spec.tsx +151 -0
  741. package/src/components/data-grid/selection-cell.tsx +14 -12
  742. package/src/components/dialog.spec.tsx +135 -0
  743. package/src/components/dialog.tsx +277 -0
  744. package/src/components/divider.spec.tsx +197 -0
  745. package/src/components/divider.tsx +147 -0
  746. package/src/components/drawer/drawer-toggle-button.spec.tsx +374 -0
  747. package/src/components/drawer/drawer-toggle-button.tsx +124 -0
  748. package/src/components/drawer/index.spec.tsx +748 -0
  749. package/src/components/drawer/index.tsx +227 -0
  750. package/src/components/dropdown.spec.tsx +445 -0
  751. package/src/components/dropdown.tsx +343 -0
  752. package/src/components/fab.spec.tsx +119 -0
  753. package/src/components/fab.tsx +40 -8
  754. package/src/components/form.spec.tsx +491 -0
  755. package/src/components/form.tsx +10 -7
  756. package/src/components/grid.spec.tsx +427 -0
  757. package/src/components/grid.tsx +60 -66
  758. package/src/components/icons/icon-definitions.spec.ts +68 -0
  759. package/src/components/icons/icon-definitions.ts +509 -0
  760. package/src/components/icons/icon-types.ts +48 -0
  761. package/src/components/icons/icon.spec.tsx +314 -0
  762. package/src/components/icons/icon.tsx +111 -0
  763. package/src/components/icons/index.ts +4 -0
  764. package/src/components/image.spec.tsx +748 -0
  765. package/src/components/image.tsx +520 -0
  766. package/src/components/index.ts +32 -4
  767. package/src/components/inputs/autocomplete.spec.tsx +267 -0
  768. package/src/components/inputs/autocomplete.tsx +13 -7
  769. package/src/components/inputs/checkbox.spec.tsx +377 -0
  770. package/src/components/inputs/checkbox.tsx +198 -0
  771. package/src/components/inputs/index.ts +7 -0
  772. package/src/components/inputs/input-number.spec.tsx +686 -0
  773. package/src/components/inputs/input-number.tsx +387 -0
  774. package/src/components/inputs/input.spec.tsx +844 -0
  775. package/src/components/inputs/input.tsx +191 -218
  776. package/src/components/inputs/radio-group.spec.tsx +281 -0
  777. package/src/components/inputs/radio-group.tsx +108 -0
  778. package/src/components/inputs/radio.spec.tsx +273 -0
  779. package/src/components/inputs/radio.tsx +199 -0
  780. package/src/components/inputs/select.spec.tsx +1237 -0
  781. package/src/components/inputs/select.tsx +775 -0
  782. package/src/components/inputs/slider.spec.tsx +1020 -0
  783. package/src/components/inputs/slider.tsx +696 -0
  784. package/src/components/inputs/switch.spec.tsx +410 -0
  785. package/src/components/inputs/switch.tsx +218 -0
  786. package/src/components/inputs/text-area.spec.tsx +300 -0
  787. package/src/components/inputs/text-area.tsx +47 -79
  788. package/src/components/linear-progress.spec.tsx +320 -0
  789. package/src/components/linear-progress.tsx +127 -0
  790. package/src/components/list/index.ts +2 -0
  791. package/src/components/list/list-item.tsx +106 -0
  792. package/src/components/list/list.spec.tsx +817 -0
  793. package/src/components/list/list.tsx +92 -0
  794. package/src/components/loader.spec.tsx +362 -0
  795. package/src/components/loader.tsx +18 -10
  796. package/src/components/menu/index.ts +2 -0
  797. package/src/components/menu/menu-types.spec.ts +122 -0
  798. package/src/components/menu/menu-types.ts +43 -0
  799. package/src/components/menu/menu.spec.tsx +483 -0
  800. package/src/components/menu/menu.tsx +326 -0
  801. package/src/components/modal.spec.tsx +314 -0
  802. package/src/components/modal.tsx +20 -15
  803. package/src/components/noty-list.spec.tsx +634 -0
  804. package/src/components/noty-list.tsx +98 -101
  805. package/src/components/page-container/index.spec.tsx +274 -0
  806. package/src/components/page-container/index.tsx +82 -0
  807. package/src/components/page-container/page-header.spec.tsx +308 -0
  808. package/src/components/page-container/page-header.tsx +127 -0
  809. package/src/components/page-layout/index.spec.tsx +882 -0
  810. package/src/components/page-layout/index.tsx +392 -0
  811. package/src/components/pagination.spec.tsx +275 -0
  812. package/src/components/pagination.tsx +249 -0
  813. package/src/components/paper.spec.tsx +80 -0
  814. package/src/components/paper.tsx +21 -17
  815. package/src/components/rating.spec.tsx +866 -0
  816. package/src/components/rating.tsx +286 -0
  817. package/src/components/result.spec.tsx +221 -0
  818. package/src/components/result.tsx +155 -0
  819. package/src/components/searchable-input-styles.ts +81 -0
  820. package/src/components/skeleton.spec.tsx +227 -0
  821. package/src/components/skeleton.tsx +24 -7
  822. package/src/components/styles.spec.ts +69 -0
  823. package/src/components/styles.tsx +15 -13
  824. package/src/components/suggest/index.spec.tsx +885 -0
  825. package/src/components/suggest/index.tsx +36 -130
  826. package/src/components/suggest/suggest-input.spec.tsx +195 -0
  827. package/src/components/suggest/suggest-input.tsx +23 -29
  828. package/src/components/suggest/suggest-manager.spec.ts +419 -0
  829. package/src/components/suggest/suggestion-list.spec.tsx +355 -0
  830. package/src/components/suggest/suggestion-list.tsx +54 -58
  831. package/src/components/tabs.spec.tsx +598 -0
  832. package/src/components/tabs.tsx +241 -26
  833. package/src/components/timeline.spec.tsx +294 -0
  834. package/src/components/timeline.tsx +221 -0
  835. package/src/components/tooltip.spec.tsx +223 -0
  836. package/src/components/tooltip.tsx +155 -0
  837. package/src/components/tree/index.ts +2 -0
  838. package/src/components/tree/tree-item.tsx +161 -0
  839. package/src/components/tree/tree.spec.tsx +677 -0
  840. package/src/components/tree/tree.tsx +111 -0
  841. package/src/components/typography.spec.tsx +235 -0
  842. package/src/components/typography.tsx +292 -0
  843. package/src/components/wizard/index.spec.tsx +233 -0
  844. package/src/components/wizard/index.tsx +10 -9
  845. package/src/services/click-away-service.ts +9 -3
  846. package/src/services/collection-service.spec.ts +492 -3
  847. package/src/services/css-variable-theme.spec.ts +372 -0
  848. package/src/services/css-variable-theme.ts +128 -3
  849. package/src/services/default-dark-theme.ts +89 -3
  850. package/src/services/default-light-theme.ts +88 -2
  851. package/src/services/default-palette.ts +22 -0
  852. package/src/services/index.ts +6 -2
  853. package/src/services/layout-service.spec.ts +535 -0
  854. package/src/services/layout-service.ts +391 -0
  855. package/src/services/list-service.spec.ts +364 -0
  856. package/src/services/list-service.ts +169 -0
  857. package/src/services/palette-css-vars.ts +46 -0
  858. package/src/services/theme-provider-service.spec.ts +195 -0
  859. package/src/services/theme-provider-service.ts +305 -2
  860. package/src/services/tree-service.spec.ts +428 -0
  861. package/src/services/tree-service.ts +179 -0
  862. package/src/utils/promisify-animation.ts +7 -1
@@ -0,0 +1,392 @@
1
+ import { ScreenService, Shade, createComponent, type ScreenSize } from '@furystack/shades'
2
+ import type { ValueObserver } from '@furystack/utils'
3
+ import { cssVariableTheme } from '../../services/css-variable-theme.js'
4
+ import { LAYOUT_CSS_VARIABLES, LayoutService } from '../../services/layout-service.js'
5
+
6
+ /**
7
+ * AppBar configuration for PageLayout.
8
+ */
9
+ export type AppBarConfig = {
10
+ /** AppBar visibility behavior */
11
+ variant: 'permanent' | 'auto-hide'
12
+ /** Height of the AppBar (CSS value). Default: '48px' */
13
+ height?: string
14
+ /** The AppBar component to render */
15
+ component: JSX.Element
16
+ }
17
+
18
+ /**
19
+ * Drawer configuration for a single side.
20
+ */
21
+ export type DrawerConfig = {
22
+ /** Drawer behavior variant */
23
+ variant: 'permanent' | 'collapsible' | 'temporary'
24
+ /** Width of the drawer (CSS value). Default: '240px' */
25
+ width?: string
26
+ /** The drawer content component */
27
+ component: JSX.Element
28
+ /** Initial open state for collapsible drawers. Default: true */
29
+ defaultOpen?: boolean
30
+ /** Auto-collapse the drawer below this breakpoint (uses ScreenService) */
31
+ collapseOnBreakpoint?: ScreenSize
32
+ }
33
+
34
+ /**
35
+ * Props for the PageLayout component.
36
+ */
37
+ export type PageLayoutProps = {
38
+ /** AppBar configuration */
39
+ appBar?: AppBarConfig
40
+ /** Drawer configurations for left and/or right sides */
41
+ drawer?: {
42
+ left?: DrawerConfig
43
+ right?: DrawerConfig
44
+ }
45
+ /** Gap between the AppBar and the content area (CSS value). Default: '0px' */
46
+ topGap?: string
47
+ /** Gap between the drawers and the content area (CSS value). Default: '0px' */
48
+ sideGap?: string
49
+ }
50
+
51
+ const DEFAULT_APPBAR_HEIGHT = '48px'
52
+ const DEFAULT_DRAWER_WIDTH = '240px'
53
+
54
+ /**
55
+ * PageLayout component for full-viewport application layouts.
56
+ *
57
+ * Provides a structured layout with:
58
+ * - Optional AppBar (permanent or auto-hide)
59
+ * - Optional left/right drawers (permanent, collapsible, or temporary)
60
+ * - Main content area with automatic margin management
61
+ * - Configurable gaps between AppBar/drawers and content
62
+ * - Responsive drawer collapse via `collapseOnBreakpoint`
63
+ *
64
+ * The LayoutService is scoped to this component, so CSS variables are isolated
65
+ * and automatically cleaned up when navigating away.
66
+ *
67
+ * @example
68
+ * ```tsx
69
+ * <PageLayout
70
+ * appBar={{
71
+ * variant: 'permanent',
72
+ * component: <MyAppBar />,
73
+ * }}
74
+ * drawer={{
75
+ * left: {
76
+ * variant: 'collapsible',
77
+ * component: <Sidebar />,
78
+ * collapseOnBreakpoint: 'md', // Auto-collapse below 900px
79
+ * },
80
+ * }}
81
+ * topGap="16px"
82
+ * sideGap="24px"
83
+ * >
84
+ * <MainContent />
85
+ * </PageLayout>
86
+ * ```
87
+ */
88
+ export const PageLayout = Shade<PageLayoutProps>({
89
+ shadowDomName: 'shade-page-layout',
90
+ css: {
91
+ display: 'block',
92
+ position: 'fixed',
93
+ top: '0',
94
+ left: '0',
95
+ width: '100%',
96
+ height: '100%',
97
+ overflow: 'hidden',
98
+ background: cssVariableTheme.background.default,
99
+
100
+ '& div[is="shade-paper"]': {
101
+ margin: '0',
102
+ },
103
+
104
+ // AppBar container
105
+ '& .page-layout-appbar': {
106
+ position: 'fixed',
107
+ top: '0',
108
+ left: '0',
109
+ right: '0',
110
+ zIndex: cssVariableTheme.zIndex.appBar,
111
+ transition: `top ${cssVariableTheme.transitions.duration.slow} ${cssVariableTheme.transitions.easing.easeInOut}`,
112
+ height: `var(${LAYOUT_CSS_VARIABLES.appBarHeight})`,
113
+ },
114
+
115
+ // Auto-hide AppBar styles (controlled via host data attributes)
116
+ '&[data-appbar-auto-hide] .page-layout-appbar': {
117
+ top: 'calc(-1 * var(--layout-appbar-height, 48px))',
118
+ },
119
+ '&[data-appbar-auto-hide] .page-layout-appbar:hover': {
120
+ top: '0',
121
+ },
122
+ '&[data-appbar-auto-hide][data-appbar-visible] .page-layout-appbar': {
123
+ top: '0',
124
+ },
125
+
126
+ // Drawer containers - use CSS transitions
127
+ '& .page-layout-drawer': {
128
+ position: 'fixed',
129
+ top: 'var(--layout-appbar-height, 48px)',
130
+ bottom: '0',
131
+ zIndex: cssVariableTheme.zIndex.drawer,
132
+ overflow: 'hidden',
133
+ background: cssVariableTheme.background.paper,
134
+ transition: `transform ${cssVariableTheme.transitions.duration.slow} ${cssVariableTheme.transitions.easing.easeInOut}`,
135
+ },
136
+ '& .page-layout-drawer-left': {
137
+ left: '0',
138
+ width: 'var(--layout-drawer-left-configured-width, 240px)',
139
+ borderRight: `1px solid ${cssVariableTheme.divider}`,
140
+ transform: 'translateX(0)',
141
+ },
142
+ '& .page-layout-drawer-right': {
143
+ right: '0',
144
+ width: 'var(--layout-drawer-right-configured-width, 240px)',
145
+ borderLeft: `1px solid ${cssVariableTheme.divider}`,
146
+ transform: 'translateX(0)',
147
+ },
148
+
149
+ // Drawer closed states (controlled via host data attributes)
150
+ '&[data-drawer-left-closed] .page-layout-drawer-left': {
151
+ transform: 'translateX(-100%)',
152
+ pointerEvents: 'none',
153
+ },
154
+ '&[data-drawer-right-closed] .page-layout-drawer-right': {
155
+ transform: 'translateX(100%)',
156
+ pointerEvents: 'none',
157
+ },
158
+
159
+ // Temporary drawer backdrop
160
+ '& .page-layout-drawer-backdrop': {
161
+ position: 'fixed',
162
+ top: '0',
163
+ left: '0',
164
+ right: '0',
165
+ bottom: '0',
166
+ backgroundColor: cssVariableTheme.action.backdrop,
167
+ zIndex: cssVariableTheme.zIndex.drawer,
168
+ opacity: '0',
169
+ pointerEvents: 'none',
170
+ transition: `opacity ${cssVariableTheme.transitions.duration.slow} ${cssVariableTheme.transitions.easing.easeInOut}`,
171
+ },
172
+ '&[data-backdrop-visible] .page-layout-drawer-backdrop': {
173
+ opacity: '1',
174
+ pointerEvents: 'auto',
175
+ },
176
+
177
+ // Content area - uses CSS variables for positioning
178
+ '& .page-layout-content': {
179
+ position: 'absolute',
180
+ top: '0',
181
+ bottom: '0',
182
+ overflow: 'auto',
183
+ paddingTop: 'var(--layout-content-padding-top, 0px)',
184
+ paddingLeft: 'var(--layout-side-gap, 0px)',
185
+ paddingRight: 'var(--layout-side-gap, 0px)',
186
+ left: 'var(--layout-content-margin-left, 0px)',
187
+ right: 'var(--layout-content-margin-right, 0px)',
188
+ transition: `left ${cssVariableTheme.transitions.duration.slow} ${cssVariableTheme.transitions.easing.easeInOut}, right ${cssVariableTheme.transitions.duration.slow} ${cssVariableTheme.transitions.easing.easeInOut}`,
189
+ },
190
+ },
191
+
192
+ render: ({ props, children, injector, useObservable, useDisposable, useHostProps }) => {
193
+ // Create scoped LayoutService (CSS variables are set on the host via useHostProps)
194
+ const layoutService = useDisposable('layoutService', () => new LayoutService())
195
+
196
+ // Create a child injector with the scoped LayoutService
197
+ // This allows child components (like DrawerToggleButton) to access it
198
+ const childInjector = useDisposable('childInjector', () => {
199
+ const child = injector.createChild()
200
+ child.setExplicitInstance(layoutService, LayoutService)
201
+ return child
202
+ })
203
+
204
+ // Propagate the child injector on the host so descendants can find it
205
+ useHostProps({ injector: childInjector })
206
+
207
+ const screenService = injector.getInstance(ScreenService)
208
+
209
+ // Initialize AppBar
210
+ const appBarHeight = props.appBar?.height ?? DEFAULT_APPBAR_HEIGHT
211
+ if (props.appBar) {
212
+ layoutService.appBarHeight.setValue(appBarHeight)
213
+
214
+ // Only reset appBarVisible when transitioning to auto-hide (not on every render)
215
+ const prevVariant = layoutService.appBarVariant.getValue()
216
+ layoutService.appBarVariant.setValue(props.appBar.variant)
217
+ if (props.appBar.variant === 'auto-hide' && prevVariant !== 'auto-hide') {
218
+ layoutService.appBarVisible.setValue(false)
219
+ }
220
+ } else {
221
+ layoutService.appBarHeight.setValue('0px')
222
+ }
223
+
224
+ // Initialize gaps
225
+ layoutService.setTopGap(props.topGap ?? '0px')
226
+ layoutService.setSideGap(props.sideGap ?? '0px')
227
+
228
+ // Initialize drawers
229
+ const initializeDrawer = (position: 'left' | 'right', config: DrawerConfig) => {
230
+ const width = config.width ?? DEFAULT_DRAWER_WIDTH
231
+ // Permanent drawers are always open
232
+ // Collapsible drawers default to open unless defaultOpen is false
233
+ // Temporary drawers default to closed unless defaultOpen is true
234
+ const isOpen =
235
+ config.variant === 'permanent' ||
236
+ (config.variant === 'collapsible' && (config.defaultOpen ?? true)) ||
237
+ (config.variant === 'temporary' && config.defaultOpen === true)
238
+ const currentState = layoutService.drawerState.getValue()[position]
239
+
240
+ // Only initialize if not already set (preserve user interactions)
241
+ if (!currentState) {
242
+ layoutService.initDrawer(position, { open: isOpen, width, variant: config.variant })
243
+ } else if (currentState.width !== width || currentState.variant !== config.variant) {
244
+ // Update if width or variant changed
245
+ layoutService.initDrawer(position, { ...currentState, width, variant: config.variant })
246
+ }
247
+ }
248
+
249
+ if (props.drawer?.left) {
250
+ initializeDrawer('left', props.drawer.left)
251
+ }
252
+ if (props.drawer?.right) {
253
+ initializeDrawer('right', props.drawer.right)
254
+ }
255
+
256
+ // Set up responsive breakpoint listeners for drawers
257
+ const setupBreakpointListener = (position: 'left' | 'right', config: DrawerConfig) => {
258
+ const { collapseOnBreakpoint, variant } = config
259
+
260
+ if (!collapseOnBreakpoint || variant === 'permanent') {
261
+ return { [Symbol.dispose]: () => {} }
262
+ }
263
+
264
+ const breakpointObservable = screenService.screenSize.atLeast[collapseOnBreakpoint]
265
+
266
+ const applyBreakpoint = (isAtLeast: boolean) => {
267
+ const currentState = layoutService.drawerState.getValue()[position]
268
+ const currentlyOpen = currentState?.open ?? false
269
+
270
+ // When screen becomes smaller than breakpoint, close the drawer
271
+ // When screen becomes larger than breakpoint, open the drawer (for collapsible)
272
+ if (variant === 'collapsible') {
273
+ // Only update if the state needs to change
274
+ if (isAtLeast !== currentlyOpen) {
275
+ layoutService.setDrawerOpen(position, isAtLeast)
276
+ }
277
+ } else if (variant === 'temporary' && isAtLeast && currentlyOpen) {
278
+ // For temporary drawers, close when screen is large enough
279
+ layoutService.setDrawerOpen(position, false)
280
+ }
281
+ }
282
+
283
+ const subscription: ValueObserver<boolean> = breakpointObservable.subscribe(applyBreakpoint)
284
+
285
+ // Apply the current breakpoint value immediately since subscribe only fires on changes
286
+ applyBreakpoint(breakpointObservable.getValue())
287
+
288
+ return subscription
289
+ }
290
+
291
+ // Set up breakpoint listeners for left and right drawers
292
+ useDisposable('breakpoint-listener-left', () => {
293
+ if (props.drawer?.left?.collapseOnBreakpoint) {
294
+ return setupBreakpointListener('left', props.drawer.left)
295
+ }
296
+ return { [Symbol.dispose]: () => {} }
297
+ })
298
+
299
+ useDisposable('breakpoint-listener-right', () => {
300
+ if (props.drawer?.right?.collapseOnBreakpoint) {
301
+ return setupBreakpointListener('right', props.drawer.right)
302
+ }
303
+ return { [Symbol.dispose]: () => {} }
304
+ })
305
+
306
+ // Subscribe to drawer state and appbar visibility - re-render to update host props
307
+ const [drawerState] = useObservable('drawerState', layoutService.drawerState)
308
+ const [isAppBarVisible] = useObservable('appBarVisible', layoutService.appBarVisible)
309
+
310
+ // Set host classes via useHostProps for CSS-based animations
311
+ const isLeftOpen = drawerState.left?.open ?? false
312
+ const isRightOpen = drawerState.right?.open ?? false
313
+ const isLeftTemporaryOpen = props.drawer?.left?.variant === 'temporary' && isLeftOpen
314
+ const isRightTemporaryOpen = props.drawer?.right?.variant === 'temporary' && isRightOpen
315
+
316
+ // Compute CSS variables from LayoutService state
317
+ const appBarHeightVal = layoutService.appBarHeight.getValue()
318
+ const appBarVariantVal = layoutService.appBarVariant.getValue()
319
+ const topGapVal = layoutService.topGap.getValue()
320
+ const sideGapVal = layoutService.sideGap.getValue()
321
+ const contentPaddingTop = appBarVariantVal === 'auto-hide' ? topGapVal : `calc(${appBarHeightVal} + ${topGapVal})`
322
+ const leftWidth = drawerState.left?.open ? (drawerState.left.width ?? '0px') : '0px'
323
+ const rightWidth = drawerState.right?.open ? (drawerState.right.width ?? '0px') : '0px'
324
+ const leftContentMargin = layoutService.getContentMarginForPosition('left')
325
+ const rightContentMargin = layoutService.getContentMarginForPosition('right')
326
+
327
+ useHostProps({
328
+ ...(!isLeftOpen ? { 'data-drawer-left-closed': '' } : {}),
329
+ ...(!isRightOpen ? { 'data-drawer-right-closed': '' } : {}),
330
+ ...(props.appBar?.variant === 'auto-hide' ? { 'data-appbar-auto-hide': '' } : {}),
331
+ ...(props.appBar?.variant === 'auto-hide' && isAppBarVisible ? { 'data-appbar-visible': '' } : {}),
332
+ ...(isLeftTemporaryOpen || isRightTemporaryOpen ? { 'data-backdrop-visible': '' } : {}),
333
+ style: {
334
+ '--layout-appbar-height': appBarHeightVal,
335
+ '--layout-top-gap': topGapVal,
336
+ '--layout-side-gap': sideGapVal,
337
+ '--layout-content-padding-top': contentPaddingTop,
338
+ '--layout-content-margin-top': appBarHeightVal,
339
+ '--layout-drawer-left-configured-width': drawerState.left?.width ?? '0px',
340
+ '--layout-drawer-left-width': leftWidth,
341
+ '--layout-content-margin-left': leftContentMargin,
342
+ '--layout-drawer-right-configured-width': drawerState.right?.width ?? '0px',
343
+ '--layout-drawer-right-width': rightWidth,
344
+ '--layout-content-margin-right': rightContentMargin,
345
+ },
346
+ })
347
+
348
+ // Handle temporary drawer backdrop click
349
+ const handleBackdropClick = () => {
350
+ const state = layoutService.drawerState.getValue()
351
+ if (props.drawer?.left?.variant === 'temporary' && state.left?.open) {
352
+ layoutService.setDrawerOpen('left', false)
353
+ }
354
+ if (props.drawer?.right?.variant === 'temporary' && state.right?.open) {
355
+ layoutService.setDrawerOpen('right', false)
356
+ }
357
+ }
358
+
359
+ return (
360
+ <div style={{ display: 'contents' }}>
361
+ {/* AppBar */}
362
+ {props.appBar && (
363
+ <div className="page-layout-appbar" data-testid="page-layout-appbar">
364
+ {props.appBar.component}
365
+ </div>
366
+ )}
367
+
368
+ {/* Backdrop for temporary drawers */}
369
+ <div className="page-layout-drawer-backdrop" onclick={handleBackdropClick} data-testid="page-layout-backdrop" />
370
+
371
+ {/* Left Drawer */}
372
+ {props.drawer?.left && (
373
+ <div className="page-layout-drawer page-layout-drawer-left" data-testid="page-layout-drawer-left">
374
+ {props.drawer.left.component}
375
+ </div>
376
+ )}
377
+
378
+ {/* Right Drawer */}
379
+ {props.drawer?.right && (
380
+ <div className="page-layout-drawer page-layout-drawer-right" data-testid="page-layout-drawer-right">
381
+ {props.drawer.right.component}
382
+ </div>
383
+ )}
384
+
385
+ {/* Main Content */}
386
+ <main className="page-layout-content" data-testid="page-layout-content">
387
+ {children}
388
+ </main>
389
+ </div>
390
+ )
391
+ },
392
+ })
@@ -0,0 +1,275 @@
1
+ import { createComponent, flushUpdates } from '@furystack/shades'
2
+ import { describe, expect, it, vi } from 'vitest'
3
+ import type { PaginationProps } from './pagination.js'
4
+ import { Pagination } from './pagination.js'
5
+
6
+ describe('Pagination', () => {
7
+ it('should be defined', () => {
8
+ expect(Pagination).toBeDefined()
9
+ expect(typeof Pagination).toBe('function')
10
+ })
11
+
12
+ it('should create a pagination element with required props', () => {
13
+ const onPageChange = vi.fn()
14
+ const el = (<Pagination count={10} page={1} onPageChange={onPageChange} />) as unknown as HTMLElement
15
+ expect(el).toBeDefined()
16
+ expect(el.tagName?.toLowerCase()).toBe('shade-pagination')
17
+ })
18
+
19
+ it('should set props correctly', () => {
20
+ const onPageChange = vi.fn()
21
+ const el = (
22
+ <Pagination
23
+ count={10}
24
+ page={3}
25
+ onPageChange={onPageChange}
26
+ siblingCount={2}
27
+ boundaryCount={1}
28
+ disabled
29
+ size="small"
30
+ color="primary"
31
+ />
32
+ ) as unknown as JSX.Element
33
+ const props = el.props as PaginationProps
34
+ expect(props.count).toBe(10)
35
+ expect(props.page).toBe(3)
36
+ expect(props.siblingCount).toBe(2)
37
+ expect(props.boundaryCount).toBe(1)
38
+ expect(props.disabled).toBe(true)
39
+ expect(props.size).toBe('small')
40
+ expect(props.color).toBe('primary')
41
+ })
42
+
43
+ it('should render page buttons for small page counts', async () => {
44
+ const onPageChange = vi.fn()
45
+ const el = (
46
+ <div>
47
+ <Pagination count={5} page={1} onPageChange={onPageChange} />
48
+ </div>
49
+ )
50
+ const pagination = el.firstElementChild as JSX.Element
51
+ pagination.updateComponent()
52
+ await flushUpdates()
53
+ // Should have prev + 5 page buttons + next = 7 buttons
54
+ const items = pagination.querySelectorAll('.pagination-item')
55
+ expect(items.length).toBe(7) // prev + 5 pages + next
56
+ })
57
+
58
+ it('should render ellipsis for large page counts', async () => {
59
+ const onPageChange = vi.fn()
60
+ const el = (
61
+ <div>
62
+ <Pagination count={20} page={10} onPageChange={onPageChange} />
63
+ </div>
64
+ )
65
+ const pagination = el.firstElementChild as JSX.Element
66
+ pagination.updateComponent()
67
+ await flushUpdates()
68
+ const ellipses = pagination.querySelectorAll('.pagination-ellipsis')
69
+ expect(ellipses.length).toBe(2)
70
+ })
71
+
72
+ it('should mark current page as selected', async () => {
73
+ const onPageChange = vi.fn()
74
+ const el = (
75
+ <div>
76
+ <Pagination count={5} page={3} onPageChange={onPageChange} />
77
+ </div>
78
+ )
79
+ const pagination = el.firstElementChild as JSX.Element
80
+ pagination.updateComponent()
81
+ await flushUpdates()
82
+ const selected = pagination.querySelector('[data-selected]') as HTMLElement
83
+ expect(selected).not.toBeNull()
84
+ expect(selected.textContent).toBe('3')
85
+ })
86
+
87
+ it('should set data-disabled on prev button when on first page', async () => {
88
+ const onPageChange = vi.fn()
89
+ const el = (
90
+ <div>
91
+ <Pagination count={5} page={1} onPageChange={onPageChange} />
92
+ </div>
93
+ )
94
+ const pagination = el.firstElementChild as JSX.Element
95
+ pagination.updateComponent()
96
+ await flushUpdates()
97
+ const prevButton = pagination.querySelector('.pagination-item') as HTMLElement
98
+ expect(prevButton.hasAttribute('data-disabled')).toBe(true)
99
+ })
100
+
101
+ it('should set data-disabled on next button when on last page', async () => {
102
+ const onPageChange = vi.fn()
103
+ const el = (
104
+ <div>
105
+ <Pagination count={5} page={5} onPageChange={onPageChange} />
106
+ </div>
107
+ )
108
+ const pagination = el.firstElementChild as JSX.Element
109
+ pagination.updateComponent()
110
+ await flushUpdates()
111
+ const items = pagination.querySelectorAll('.pagination-item')
112
+ const nextButton = items[items.length - 1] as HTMLElement
113
+ expect(nextButton.hasAttribute('data-disabled')).toBe(true)
114
+ })
115
+
116
+ it('should call onPageChange with the correct page when a page button is clicked', async () => {
117
+ const onPageChange = vi.fn()
118
+ const el = (
119
+ <div>
120
+ <Pagination count={5} page={1} onPageChange={onPageChange} />
121
+ </div>
122
+ )
123
+ const pagination = el.firstElementChild as JSX.Element
124
+ pagination.updateComponent()
125
+ await flushUpdates()
126
+ // Click page 3 (index: prev=0, page1=1, page2=2, page3=3)
127
+ const items = pagination.querySelectorAll('.pagination-item')
128
+ ;(items[3] as HTMLElement).click()
129
+ expect(onPageChange).toHaveBeenCalledWith(3)
130
+ })
131
+
132
+ it('should call onPageChange with page-1 when prev button is clicked', async () => {
133
+ const onPageChange = vi.fn()
134
+ const el = (
135
+ <div>
136
+ <Pagination count={5} page={3} onPageChange={onPageChange} />
137
+ </div>
138
+ )
139
+ const pagination = el.firstElementChild as JSX.Element
140
+ pagination.updateComponent()
141
+ await flushUpdates()
142
+ const prevButton = pagination.querySelector('.pagination-item') as HTMLElement
143
+ prevButton.click()
144
+ expect(onPageChange).toHaveBeenCalledWith(2)
145
+ })
146
+
147
+ it('should call onPageChange with page+1 when next button is clicked', async () => {
148
+ const onPageChange = vi.fn()
149
+ const el = (
150
+ <div>
151
+ <Pagination count={5} page={3} onPageChange={onPageChange} />
152
+ </div>
153
+ )
154
+ const pagination = el.firstElementChild as JSX.Element
155
+ pagination.updateComponent()
156
+ await flushUpdates()
157
+ const items = pagination.querySelectorAll('.pagination-item')
158
+ const nextButton = items[items.length - 1] as HTMLElement
159
+ nextButton.click()
160
+ expect(onPageChange).toHaveBeenCalledWith(4)
161
+ })
162
+
163
+ it('should not call onPageChange when clicking the currently selected page', async () => {
164
+ const onPageChange = vi.fn()
165
+ const el = (
166
+ <div>
167
+ <Pagination count={5} page={3} onPageChange={onPageChange} />
168
+ </div>
169
+ )
170
+ const pagination = el.firstElementChild as JSX.Element
171
+ pagination.updateComponent()
172
+ await flushUpdates()
173
+ const selected = pagination.querySelector('[data-selected]') as HTMLElement
174
+ selected.click()
175
+ expect(onPageChange).not.toHaveBeenCalled()
176
+ })
177
+
178
+ it('should set data-size attribute when size is provided', async () => {
179
+ const onPageChange = vi.fn()
180
+ const el = (
181
+ <div>
182
+ <Pagination count={5} page={1} onPageChange={onPageChange} size="small" />
183
+ </div>
184
+ )
185
+ const pagination = el.firstElementChild as JSX.Element
186
+ pagination.updateComponent()
187
+ await flushUpdates()
188
+ expect(pagination.getAttribute('data-size')).toBe('small')
189
+ })
190
+
191
+ it('should set data-disabled on host when disabled', async () => {
192
+ const onPageChange = vi.fn()
193
+ const el = (
194
+ <div>
195
+ <Pagination count={5} page={1} onPageChange={onPageChange} disabled />
196
+ </div>
197
+ )
198
+ const pagination = el.firstElementChild as JSX.Element
199
+ pagination.updateComponent()
200
+ await flushUpdates()
201
+ expect(pagination.hasAttribute('data-disabled')).toBe(true)
202
+ })
203
+
204
+ it('should set CSS custom properties for palette color', async () => {
205
+ const onPageChange = vi.fn()
206
+ const el = (
207
+ <div>
208
+ <Pagination count={5} page={1} onPageChange={onPageChange} color="primary" />
209
+ </div>
210
+ )
211
+ const pagination = el.firstElementChild as JSX.Element
212
+ pagination.updateComponent()
213
+ await flushUpdates()
214
+ expect(pagination.style.getPropertyValue('--pagination-color-main')).toBe(
215
+ 'var(--shades-theme-palette-primary-main)',
216
+ )
217
+ })
218
+
219
+ it('should set default CSS custom properties when no color prop', async () => {
220
+ const onPageChange = vi.fn()
221
+ const el = (
222
+ <div>
223
+ <Pagination count={5} page={1} onPageChange={onPageChange} />
224
+ </div>
225
+ )
226
+ const pagination = el.firstElementChild as JSX.Element
227
+ pagination.updateComponent()
228
+ await flushUpdates()
229
+ expect(pagination.style.getPropertyValue('--pagination-color-main')).toBe('var(--shades-theme-text-primary)')
230
+ })
231
+
232
+ it('should render only left ellipsis when near the end', async () => {
233
+ const onPageChange = vi.fn()
234
+ const el = (
235
+ <div>
236
+ <Pagination count={20} page={19} onPageChange={onPageChange} />
237
+ </div>
238
+ )
239
+ const pagination = el.firstElementChild as JSX.Element
240
+ pagination.updateComponent()
241
+ await flushUpdates()
242
+ const ellipses = pagination.querySelectorAll('.pagination-ellipsis')
243
+ expect(ellipses.length).toBe(1)
244
+ })
245
+
246
+ it('should render only right ellipsis when near the start', async () => {
247
+ const onPageChange = vi.fn()
248
+ const el = (
249
+ <div>
250
+ <Pagination count={20} page={2} onPageChange={onPageChange} />
251
+ </div>
252
+ )
253
+ const pagination = el.firstElementChild as JSX.Element
254
+ pagination.updateComponent()
255
+ await flushUpdates()
256
+ const ellipses = pagination.querySelectorAll('.pagination-ellipsis')
257
+ expect(ellipses.length).toBe(1)
258
+ })
259
+
260
+ it('should render all pages without ellipsis for count equal to total display slots', async () => {
261
+ const onPageChange = vi.fn()
262
+ const el = (
263
+ <div>
264
+ <Pagination count={7} page={4} onPageChange={onPageChange} />
265
+ </div>
266
+ )
267
+ const pagination = el.firstElementChild as JSX.Element
268
+ pagination.updateComponent()
269
+ await flushUpdates()
270
+ const ellipses = pagination.querySelectorAll('.pagination-ellipsis')
271
+ expect(ellipses.length).toBe(0)
272
+ const items = pagination.querySelectorAll('.pagination-item')
273
+ expect(items.length).toBe(9) // prev + 7 pages + next
274
+ })
275
+ })