@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,964 @@
1
+ import { Injector } from '@furystack/inject'
2
+ import { createComponent, initializeShadeRoot } from '@furystack/shades'
3
+ import { ObservableValue, sleepAsync, usingAsync } from '@furystack/utils'
4
+ import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest'
5
+ import { CollectionService } from '../../services/collection-service.js'
6
+ import { DataGrid } from './data-grid.js'
7
+
8
+ type TestEntry = { id: number; name: string }
9
+
10
+ describe('DataGrid', () => {
11
+ beforeEach(() => {
12
+ document.body.innerHTML = '<div id="root"></div>'
13
+ })
14
+
15
+ afterEach(() => {
16
+ document.body.innerHTML = ''
17
+ })
18
+
19
+ const createTestService = () => {
20
+ const service = new CollectionService<TestEntry>()
21
+ service.data.setValue({
22
+ count: 3,
23
+ entries: [
24
+ { id: 1, name: 'First' },
25
+ { id: 2, name: 'Second' },
26
+ { id: 3, name: 'Third' },
27
+ ],
28
+ })
29
+ return service
30
+ }
31
+
32
+ describe('rendering', () => {
33
+ it('should render with columns', async () => {
34
+ await usingAsync(new Injector(), async (injector) => {
35
+ const rootElement = document.getElementById('root') as HTMLDivElement
36
+ const service = createTestService()
37
+ const findOptions = new ObservableValue<any>({})
38
+
39
+ initializeShadeRoot({
40
+ injector,
41
+ rootElement,
42
+ jsxElement: (
43
+ <DataGrid<TestEntry, 'id' | 'name'>
44
+ columns={['id', 'name']}
45
+ collectionService={service}
46
+ findOptions={findOptions}
47
+ styles={{}}
48
+ headerComponents={{}}
49
+ rowComponents={{}}
50
+ />
51
+ ),
52
+ })
53
+
54
+ await sleepAsync(50)
55
+
56
+ const grid = document.querySelector('shade-data-grid')
57
+ expect(grid).not.toBeNull()
58
+
59
+ const headers = grid?.querySelectorAll('th')
60
+ expect(headers?.length).toBe(2)
61
+
62
+ service[Symbol.dispose]()
63
+ findOptions[Symbol.dispose]()
64
+ })
65
+ })
66
+
67
+ it('should render table structure', async () => {
68
+ await usingAsync(new Injector(), async (injector) => {
69
+ const rootElement = document.getElementById('root') as HTMLDivElement
70
+ const service = createTestService()
71
+ const findOptions = new ObservableValue<any>({})
72
+
73
+ initializeShadeRoot({
74
+ injector,
75
+ rootElement,
76
+ jsxElement: (
77
+ <DataGrid<TestEntry, 'id' | 'name'>
78
+ columns={['id', 'name']}
79
+ collectionService={service}
80
+ findOptions={findOptions}
81
+ styles={{}}
82
+ headerComponents={{}}
83
+ rowComponents={{}}
84
+ />
85
+ ),
86
+ })
87
+
88
+ await sleepAsync(50)
89
+
90
+ const grid = document.querySelector('shade-data-grid')
91
+ const table = grid?.querySelector('table')
92
+ const thead = grid?.querySelector('thead')
93
+ const tbody = grid?.querySelector('tbody')
94
+
95
+ expect(table).not.toBeNull()
96
+ expect(thead).not.toBeNull()
97
+ expect(tbody).not.toBeNull()
98
+
99
+ service[Symbol.dispose]()
100
+ findOptions[Symbol.dispose]()
101
+ })
102
+ })
103
+
104
+ it('should render custom header components when provided', async () => {
105
+ await usingAsync(new Injector(), async (injector) => {
106
+ const rootElement = document.getElementById('root') as HTMLDivElement
107
+ const service = createTestService()
108
+ const findOptions = new ObservableValue<any>({})
109
+
110
+ initializeShadeRoot({
111
+ injector,
112
+ rootElement,
113
+ jsxElement: (
114
+ <DataGrid<TestEntry, 'id' | 'name'>
115
+ columns={['id', 'name']}
116
+ collectionService={service}
117
+ findOptions={findOptions}
118
+ styles={{}}
119
+ headerComponents={{
120
+ id: () => <span data-testid="custom-header-id">Custom ID Header</span>,
121
+ }}
122
+ rowComponents={{}}
123
+ />
124
+ ),
125
+ })
126
+
127
+ await sleepAsync(50)
128
+
129
+ const grid = document.querySelector('shade-data-grid')
130
+ const customHeader = grid?.querySelector('[data-testid="custom-header-id"]')
131
+ expect(customHeader).not.toBeNull()
132
+ expect(customHeader?.textContent).toBe('Custom ID Header')
133
+
134
+ service[Symbol.dispose]()
135
+ findOptions[Symbol.dispose]()
136
+ })
137
+ })
138
+
139
+ it('should render default header components from headerComponents.default', async () => {
140
+ await usingAsync(new Injector(), async (injector) => {
141
+ const rootElement = document.getElementById('root') as HTMLDivElement
142
+ const service = createTestService()
143
+ const findOptions = new ObservableValue<any>({})
144
+
145
+ initializeShadeRoot({
146
+ injector,
147
+ rootElement,
148
+ jsxElement: (
149
+ <DataGrid<TestEntry, 'id' | 'name'>
150
+ columns={['id', 'name']}
151
+ collectionService={service}
152
+ findOptions={findOptions}
153
+ styles={{}}
154
+ headerComponents={{
155
+ default: (name) => <span data-testid={`default-header-${name}`}>Default: {name}</span>,
156
+ }}
157
+ rowComponents={{}}
158
+ />
159
+ ),
160
+ })
161
+
162
+ await sleepAsync(50)
163
+
164
+ const grid = document.querySelector('shade-data-grid')
165
+ const defaultHeaderId = grid?.querySelector('[data-testid="default-header-id"]')
166
+ const defaultHeaderName = grid?.querySelector('[data-testid="default-header-name"]')
167
+
168
+ expect(defaultHeaderId?.textContent).toBe('Default: id')
169
+ expect(defaultHeaderName?.textContent).toBe('Default: name')
170
+
171
+ service[Symbol.dispose]()
172
+ findOptions[Symbol.dispose]()
173
+ })
174
+ })
175
+
176
+ it('should render DataGridHeader when no custom header is provided', async () => {
177
+ await usingAsync(new Injector(), async (injector) => {
178
+ const rootElement = document.getElementById('root') as HTMLDivElement
179
+ const service = createTestService()
180
+ const findOptions = new ObservableValue<any>({})
181
+
182
+ initializeShadeRoot({
183
+ injector,
184
+ rootElement,
185
+ jsxElement: (
186
+ <DataGrid<TestEntry, 'id' | 'name'>
187
+ columns={['id', 'name']}
188
+ collectionService={service}
189
+ findOptions={findOptions}
190
+ styles={{}}
191
+ headerComponents={{}}
192
+ rowComponents={{}}
193
+ />
194
+ ),
195
+ })
196
+
197
+ await sleepAsync(50)
198
+
199
+ const grid = document.querySelector('shade-data-grid')
200
+ const defaultHeaders = grid?.querySelectorAll('data-grid-header')
201
+ expect(defaultHeaders?.length).toBe(2)
202
+
203
+ service[Symbol.dispose]()
204
+ findOptions[Symbol.dispose]()
205
+ })
206
+ })
207
+ })
208
+
209
+ describe('focus management', () => {
210
+ it('should set focus on click', async () => {
211
+ await usingAsync(new Injector(), async (injector) => {
212
+ const rootElement = document.getElementById('root') as HTMLDivElement
213
+ const service = createTestService()
214
+ const findOptions = new ObservableValue<any>({})
215
+
216
+ expect(service.hasFocus.getValue()).toBe(false)
217
+
218
+ initializeShadeRoot({
219
+ injector,
220
+ rootElement,
221
+ jsxElement: (
222
+ <DataGrid<TestEntry, 'id' | 'name'>
223
+ columns={['id', 'name']}
224
+ collectionService={service}
225
+ findOptions={findOptions}
226
+ styles={{}}
227
+ headerComponents={{}}
228
+ rowComponents={{}}
229
+ />
230
+ ),
231
+ })
232
+
233
+ await sleepAsync(50)
234
+
235
+ const grid = document.querySelector('shade-data-grid')
236
+ const wrapper = grid?.querySelector('.shade-grid-wrapper') as HTMLElement
237
+
238
+ wrapper?.click()
239
+
240
+ expect(service.hasFocus.getValue()).toBe(true)
241
+
242
+ service[Symbol.dispose]()
243
+ findOptions[Symbol.dispose]()
244
+ })
245
+ })
246
+
247
+ it('should lose focus on click outside', async () => {
248
+ await usingAsync(new Injector(), async (injector) => {
249
+ const rootElement = document.getElementById('root') as HTMLDivElement
250
+ const service = createTestService()
251
+ const findOptions = new ObservableValue<any>({})
252
+
253
+ initializeShadeRoot({
254
+ injector,
255
+ rootElement,
256
+ jsxElement: (
257
+ <>
258
+ <div data-testid="outside">Outside</div>
259
+ <DataGrid<TestEntry, 'id' | 'name'>
260
+ columns={['id', 'name']}
261
+ collectionService={service}
262
+ findOptions={findOptions}
263
+ styles={{}}
264
+ headerComponents={{}}
265
+ rowComponents={{}}
266
+ />
267
+ </>
268
+ ),
269
+ })
270
+
271
+ await sleepAsync(50)
272
+
273
+ const grid = document.querySelector('shade-data-grid')
274
+ const wrapper = grid?.querySelector('.shade-grid-wrapper') as HTMLElement
275
+ wrapper?.click()
276
+
277
+ expect(service.hasFocus.getValue()).toBe(true)
278
+
279
+ const outside = document.querySelector('[data-testid="outside"]') as HTMLElement
280
+ outside?.dispatchEvent(new MouseEvent('click', { bubbles: true }))
281
+
282
+ expect(service.hasFocus.getValue()).toBe(false)
283
+
284
+ service[Symbol.dispose]()
285
+ findOptions[Symbol.dispose]()
286
+ })
287
+ })
288
+ })
289
+
290
+ describe('keyboard navigation', () => {
291
+ it('should handle ArrowDown to move focus to next entry', async () => {
292
+ await usingAsync(new Injector(), async (injector) => {
293
+ const rootElement = document.getElementById('root') as HTMLDivElement
294
+ const service = createTestService()
295
+ const findOptions = new ObservableValue<any>({})
296
+
297
+ service.hasFocus.setValue(true)
298
+ service.focusedEntry.setValue(service.data.getValue().entries[0])
299
+
300
+ initializeShadeRoot({
301
+ injector,
302
+ rootElement,
303
+ jsxElement: (
304
+ <DataGrid<TestEntry, 'id' | 'name'>
305
+ columns={['id', 'name']}
306
+ collectionService={service}
307
+ findOptions={findOptions}
308
+ styles={{}}
309
+ headerComponents={{}}
310
+ rowComponents={{}}
311
+ />
312
+ ),
313
+ })
314
+
315
+ await sleepAsync(50)
316
+
317
+ const keydownEvent = new KeyboardEvent('keydown', { key: 'ArrowDown', bubbles: true })
318
+ window.dispatchEvent(keydownEvent)
319
+
320
+ expect(service.focusedEntry.getValue()).toEqual({ id: 2, name: 'Second' })
321
+
322
+ service[Symbol.dispose]()
323
+ findOptions[Symbol.dispose]()
324
+ })
325
+ })
326
+
327
+ it('should handle ArrowUp to move focus to previous entry', async () => {
328
+ await usingAsync(new Injector(), async (injector) => {
329
+ const rootElement = document.getElementById('root') as HTMLDivElement
330
+ const service = createTestService()
331
+ const findOptions = new ObservableValue<any>({})
332
+
333
+ service.hasFocus.setValue(true)
334
+ service.focusedEntry.setValue(service.data.getValue().entries[1])
335
+
336
+ initializeShadeRoot({
337
+ injector,
338
+ rootElement,
339
+ jsxElement: (
340
+ <DataGrid<TestEntry, 'id' | 'name'>
341
+ columns={['id', 'name']}
342
+ collectionService={service}
343
+ findOptions={findOptions}
344
+ styles={{}}
345
+ headerComponents={{}}
346
+ rowComponents={{}}
347
+ />
348
+ ),
349
+ })
350
+
351
+ await sleepAsync(50)
352
+
353
+ const keydownEvent = new KeyboardEvent('keydown', { key: 'ArrowUp', bubbles: true })
354
+ window.dispatchEvent(keydownEvent)
355
+
356
+ expect(service.focusedEntry.getValue()).toEqual({ id: 1, name: 'First' })
357
+
358
+ service[Symbol.dispose]()
359
+ findOptions[Symbol.dispose]()
360
+ })
361
+ })
362
+
363
+ it('should handle Home to move focus to first entry', async () => {
364
+ await usingAsync(new Injector(), async (injector) => {
365
+ const rootElement = document.getElementById('root') as HTMLDivElement
366
+ const service = createTestService()
367
+ const findOptions = new ObservableValue<any>({})
368
+
369
+ service.hasFocus.setValue(true)
370
+ service.focusedEntry.setValue(service.data.getValue().entries[2])
371
+
372
+ initializeShadeRoot({
373
+ injector,
374
+ rootElement,
375
+ jsxElement: (
376
+ <DataGrid<TestEntry, 'id' | 'name'>
377
+ columns={['id', 'name']}
378
+ collectionService={service}
379
+ findOptions={findOptions}
380
+ styles={{}}
381
+ headerComponents={{}}
382
+ rowComponents={{}}
383
+ />
384
+ ),
385
+ })
386
+
387
+ await sleepAsync(50)
388
+
389
+ const keydownEvent = new KeyboardEvent('keydown', { key: 'Home', bubbles: true })
390
+ window.dispatchEvent(keydownEvent)
391
+
392
+ expect(service.focusedEntry.getValue()).toEqual({ id: 1, name: 'First' })
393
+
394
+ service[Symbol.dispose]()
395
+ findOptions[Symbol.dispose]()
396
+ })
397
+ })
398
+
399
+ it('should handle End to move focus to last entry', async () => {
400
+ await usingAsync(new Injector(), async (injector) => {
401
+ const rootElement = document.getElementById('root') as HTMLDivElement
402
+ const service = createTestService()
403
+ const findOptions = new ObservableValue<any>({})
404
+
405
+ service.hasFocus.setValue(true)
406
+ service.focusedEntry.setValue(service.data.getValue().entries[0])
407
+
408
+ initializeShadeRoot({
409
+ injector,
410
+ rootElement,
411
+ jsxElement: (
412
+ <DataGrid<TestEntry, 'id' | 'name'>
413
+ columns={['id', 'name']}
414
+ collectionService={service}
415
+ findOptions={findOptions}
416
+ styles={{}}
417
+ headerComponents={{}}
418
+ rowComponents={{}}
419
+ />
420
+ ),
421
+ })
422
+
423
+ await sleepAsync(50)
424
+
425
+ const keydownEvent = new KeyboardEvent('keydown', { key: 'End', bubbles: true })
426
+ window.dispatchEvent(keydownEvent)
427
+
428
+ expect(service.focusedEntry.getValue()).toEqual({ id: 3, name: 'Third' })
429
+
430
+ service[Symbol.dispose]()
431
+ findOptions[Symbol.dispose]()
432
+ })
433
+ })
434
+
435
+ it('should handle Tab to toggle focus', async () => {
436
+ await usingAsync(new Injector(), async (injector) => {
437
+ const rootElement = document.getElementById('root') as HTMLDivElement
438
+ const service = createTestService()
439
+ const findOptions = new ObservableValue<any>({})
440
+
441
+ service.hasFocus.setValue(true)
442
+
443
+ initializeShadeRoot({
444
+ injector,
445
+ rootElement,
446
+ jsxElement: (
447
+ <DataGrid<TestEntry, 'id' | 'name'>
448
+ columns={['id', 'name']}
449
+ collectionService={service}
450
+ findOptions={findOptions}
451
+ styles={{}}
452
+ headerComponents={{}}
453
+ rowComponents={{}}
454
+ />
455
+ ),
456
+ })
457
+
458
+ await sleepAsync(50)
459
+
460
+ const keydownEvent = new KeyboardEvent('keydown', { key: 'Tab', bubbles: true })
461
+ window.dispatchEvent(keydownEvent)
462
+
463
+ expect(service.hasFocus.getValue()).toBe(false)
464
+
465
+ service[Symbol.dispose]()
466
+ findOptions[Symbol.dispose]()
467
+ })
468
+ })
469
+
470
+ it('should handle Escape to clear selection and search', async () => {
471
+ await usingAsync(new Injector(), async (injector) => {
472
+ const rootElement = document.getElementById('root') as HTMLDivElement
473
+ const service = createTestService()
474
+ const findOptions = new ObservableValue<any>({})
475
+
476
+ const { entries } = service.data.getValue()
477
+ service.hasFocus.setValue(true)
478
+ service.selection.setValue([entries[0], entries[1]])
479
+ service.searchTerm.setValue('test')
480
+
481
+ initializeShadeRoot({
482
+ injector,
483
+ rootElement,
484
+ jsxElement: (
485
+ <DataGrid<TestEntry, 'id' | 'name'>
486
+ columns={['id', 'name']}
487
+ collectionService={service}
488
+ findOptions={findOptions}
489
+ styles={{}}
490
+ headerComponents={{}}
491
+ rowComponents={{}}
492
+ />
493
+ ),
494
+ })
495
+
496
+ await sleepAsync(50)
497
+
498
+ const keydownEvent = new KeyboardEvent('keydown', { key: 'Escape', bubbles: true })
499
+ window.dispatchEvent(keydownEvent)
500
+
501
+ expect(service.selection.getValue()).toEqual([])
502
+ expect(service.searchTerm.getValue()).toBe('')
503
+
504
+ service[Symbol.dispose]()
505
+ findOptions[Symbol.dispose]()
506
+ })
507
+ })
508
+
509
+ it('should handle Space to toggle selection of focused entry', async () => {
510
+ await usingAsync(new Injector(), async (injector) => {
511
+ const rootElement = document.getElementById('root') as HTMLDivElement
512
+ const service = createTestService()
513
+ const findOptions = new ObservableValue<any>({})
514
+
515
+ const { entries } = service.data.getValue()
516
+ service.hasFocus.setValue(true)
517
+ service.focusedEntry.setValue(entries[0])
518
+
519
+ initializeShadeRoot({
520
+ injector,
521
+ rootElement,
522
+ jsxElement: (
523
+ <DataGrid<TestEntry, 'id' | 'name'>
524
+ columns={['id', 'name']}
525
+ collectionService={service}
526
+ findOptions={findOptions}
527
+ styles={{}}
528
+ headerComponents={{}}
529
+ rowComponents={{}}
530
+ />
531
+ ),
532
+ })
533
+
534
+ await sleepAsync(50)
535
+
536
+ const keydownEvent = new KeyboardEvent('keydown', { key: ' ', bubbles: true })
537
+ window.dispatchEvent(keydownEvent)
538
+
539
+ expect(service.selection.getValue()).toContain(entries[0])
540
+
541
+ window.dispatchEvent(new KeyboardEvent('keydown', { key: ' ', bubbles: true }))
542
+ expect(service.selection.getValue()).not.toContain(entries[0])
543
+
544
+ service[Symbol.dispose]()
545
+ findOptions[Symbol.dispose]()
546
+ })
547
+ })
548
+
549
+ it('should handle + to select all entries', async () => {
550
+ await usingAsync(new Injector(), async (injector) => {
551
+ const rootElement = document.getElementById('root') as HTMLDivElement
552
+ const service = createTestService()
553
+ const findOptions = new ObservableValue<any>({})
554
+
555
+ service.hasFocus.setValue(true)
556
+
557
+ initializeShadeRoot({
558
+ injector,
559
+ rootElement,
560
+ jsxElement: (
561
+ <DataGrid<TestEntry, 'id' | 'name'>
562
+ columns={['id', 'name']}
563
+ collectionService={service}
564
+ findOptions={findOptions}
565
+ styles={{}}
566
+ headerComponents={{}}
567
+ rowComponents={{}}
568
+ />
569
+ ),
570
+ })
571
+
572
+ await sleepAsync(50)
573
+
574
+ const keydownEvent = new KeyboardEvent('keydown', { key: '+', bubbles: true })
575
+ window.dispatchEvent(keydownEvent)
576
+
577
+ expect(service.selection.getValue().length).toBe(3)
578
+
579
+ service[Symbol.dispose]()
580
+ findOptions[Symbol.dispose]()
581
+ })
582
+ })
583
+
584
+ it('should handle - to deselect all entries', async () => {
585
+ await usingAsync(new Injector(), async (injector) => {
586
+ const rootElement = document.getElementById('root') as HTMLDivElement
587
+ const service = createTestService()
588
+ const findOptions = new ObservableValue<any>({})
589
+
590
+ const { entries } = service.data.getValue()
591
+ service.hasFocus.setValue(true)
592
+ service.selection.setValue([...entries])
593
+
594
+ initializeShadeRoot({
595
+ injector,
596
+ rootElement,
597
+ jsxElement: (
598
+ <DataGrid<TestEntry, 'id' | 'name'>
599
+ columns={['id', 'name']}
600
+ collectionService={service}
601
+ findOptions={findOptions}
602
+ styles={{}}
603
+ headerComponents={{}}
604
+ rowComponents={{}}
605
+ />
606
+ ),
607
+ })
608
+
609
+ await sleepAsync(50)
610
+
611
+ const keydownEvent = new KeyboardEvent('keydown', { key: '-', bubbles: true })
612
+ window.dispatchEvent(keydownEvent)
613
+
614
+ expect(service.selection.getValue().length).toBe(0)
615
+
616
+ service[Symbol.dispose]()
617
+ findOptions[Symbol.dispose]()
618
+ })
619
+ })
620
+
621
+ it('should handle * to invert selection', async () => {
622
+ await usingAsync(new Injector(), async (injector) => {
623
+ const rootElement = document.getElementById('root') as HTMLDivElement
624
+ const service = createTestService()
625
+ const findOptions = new ObservableValue<any>({})
626
+
627
+ const { entries } = service.data.getValue()
628
+ service.hasFocus.setValue(true)
629
+ service.selection.setValue([entries[0]])
630
+
631
+ initializeShadeRoot({
632
+ injector,
633
+ rootElement,
634
+ jsxElement: (
635
+ <DataGrid<TestEntry, 'id' | 'name'>
636
+ columns={['id', 'name']}
637
+ collectionService={service}
638
+ findOptions={findOptions}
639
+ styles={{}}
640
+ headerComponents={{}}
641
+ rowComponents={{}}
642
+ />
643
+ ),
644
+ })
645
+
646
+ await sleepAsync(50)
647
+
648
+ const keydownEvent = new KeyboardEvent('keydown', { key: '*', bubbles: true })
649
+ window.dispatchEvent(keydownEvent)
650
+
651
+ const selection = service.selection.getValue()
652
+ expect(selection).not.toContain(entries[0])
653
+ expect(selection).toContain(entries[1])
654
+ expect(selection).toContain(entries[2])
655
+
656
+ service[Symbol.dispose]()
657
+ findOptions[Symbol.dispose]()
658
+ })
659
+ })
660
+
661
+ it('should not handle keyboard when not focused', async () => {
662
+ await usingAsync(new Injector(), async (injector) => {
663
+ const rootElement = document.getElementById('root') as HTMLDivElement
664
+ const service = createTestService()
665
+ const findOptions = new ObservableValue<any>({})
666
+
667
+ service.hasFocus.setValue(false)
668
+ service.focusedEntry.setValue(service.data.getValue().entries[0])
669
+
670
+ initializeShadeRoot({
671
+ injector,
672
+ rootElement,
673
+ jsxElement: (
674
+ <DataGrid<TestEntry, 'id' | 'name'>
675
+ columns={['id', 'name']}
676
+ collectionService={service}
677
+ findOptions={findOptions}
678
+ styles={{}}
679
+ headerComponents={{}}
680
+ rowComponents={{}}
681
+ />
682
+ ),
683
+ })
684
+
685
+ await sleepAsync(50)
686
+
687
+ const keydownEvent = new KeyboardEvent('keydown', { key: 'ArrowDown', bubbles: true })
688
+ window.dispatchEvent(keydownEvent)
689
+
690
+ expect(service.focusedEntry.getValue()).toEqual({ id: 1, name: 'First' })
691
+
692
+ service[Symbol.dispose]()
693
+ findOptions[Symbol.dispose]()
694
+ })
695
+ })
696
+
697
+ it('should handle Insert to toggle selection and move to next', async () => {
698
+ await usingAsync(new Injector(), async (injector) => {
699
+ const rootElement = document.getElementById('root') as HTMLDivElement
700
+ const service = createTestService()
701
+ const findOptions = new ObservableValue<any>({})
702
+
703
+ const { entries } = service.data.getValue()
704
+ service.hasFocus.setValue(true)
705
+ service.focusedEntry.setValue(entries[0])
706
+
707
+ initializeShadeRoot({
708
+ injector,
709
+ rootElement,
710
+ jsxElement: (
711
+ <DataGrid<TestEntry, 'id' | 'name'>
712
+ columns={['id', 'name']}
713
+ collectionService={service}
714
+ findOptions={findOptions}
715
+ styles={{}}
716
+ headerComponents={{}}
717
+ rowComponents={{}}
718
+ />
719
+ ),
720
+ })
721
+
722
+ await sleepAsync(50)
723
+
724
+ const keydownEvent = new KeyboardEvent('keydown', { key: 'Insert', bubbles: true })
725
+ window.dispatchEvent(keydownEvent)
726
+
727
+ expect(service.selection.getValue()).toContain(entries[0])
728
+ expect(service.focusedEntry.getValue()).toEqual(entries[1])
729
+
730
+ service[Symbol.dispose]()
731
+ findOptions[Symbol.dispose]()
732
+ })
733
+ })
734
+ })
735
+
736
+ describe('styles', () => {
737
+ it('should apply wrapper styles when provided', async () => {
738
+ await usingAsync(new Injector(), async (injector) => {
739
+ const rootElement = document.getElementById('root') as HTMLDivElement
740
+ const service = createTestService()
741
+ const findOptions = new ObservableValue<any>({})
742
+
743
+ initializeShadeRoot({
744
+ injector,
745
+ rootElement,
746
+ jsxElement: (
747
+ <DataGrid<TestEntry, 'id' | 'name'>
748
+ columns={['id', 'name']}
749
+ collectionService={service}
750
+ findOptions={findOptions}
751
+ styles={{
752
+ wrapper: { backgroundColor: 'red' },
753
+ }}
754
+ headerComponents={{}}
755
+ rowComponents={{}}
756
+ />
757
+ ),
758
+ })
759
+
760
+ await sleepAsync(50)
761
+
762
+ const grid = document.querySelector('shade-data-grid') as HTMLElement
763
+ expect(grid?.style.backgroundColor).toBe('red')
764
+
765
+ service[Symbol.dispose]()
766
+ findOptions[Symbol.dispose]()
767
+ })
768
+ })
769
+
770
+ it('should apply header styles when provided', async () => {
771
+ await usingAsync(new Injector(), async (injector) => {
772
+ const rootElement = document.getElementById('root') as HTMLDivElement
773
+ const service = createTestService()
774
+ const findOptions = new ObservableValue<any>({})
775
+
776
+ initializeShadeRoot({
777
+ injector,
778
+ rootElement,
779
+ jsxElement: (
780
+ <DataGrid<TestEntry, 'id' | 'name'>
781
+ columns={['id', 'name']}
782
+ collectionService={service}
783
+ findOptions={findOptions}
784
+ styles={{
785
+ header: { color: 'blue' },
786
+ }}
787
+ headerComponents={{}}
788
+ rowComponents={{}}
789
+ />
790
+ ),
791
+ })
792
+
793
+ await sleepAsync(50)
794
+
795
+ const grid = document.querySelector('shade-data-grid')
796
+ const headers = grid?.querySelectorAll('th') as NodeListOf<HTMLElement>
797
+ expect(headers?.[0]?.style.color).toBe('blue')
798
+
799
+ service[Symbol.dispose]()
800
+ findOptions[Symbol.dispose]()
801
+ })
802
+ })
803
+ })
804
+
805
+ describe('empty and loading states', () => {
806
+ it('should show empty component when no data', async () => {
807
+ await usingAsync(new Injector(), async (injector) => {
808
+ const rootElement = document.getElementById('root') as HTMLDivElement
809
+ const service = new CollectionService<TestEntry>()
810
+ const findOptions = new ObservableValue<any>({})
811
+
812
+ initializeShadeRoot({
813
+ injector,
814
+ rootElement,
815
+ jsxElement: (
816
+ <DataGrid<TestEntry, 'id' | 'name'>
817
+ columns={['id', 'name']}
818
+ collectionService={service}
819
+ findOptions={findOptions}
820
+ styles={{}}
821
+ headerComponents={{}}
822
+ rowComponents={{}}
823
+ emptyComponent={<div data-testid="empty-state">No data available</div>}
824
+ />
825
+ ),
826
+ })
827
+
828
+ await sleepAsync(50)
829
+
830
+ const grid = document.querySelector('shade-data-grid')
831
+ const emptyState = grid?.querySelector('[data-testid="empty-state"]')
832
+ expect(emptyState).not.toBeNull()
833
+ expect(emptyState?.textContent).toBe('No data available')
834
+
835
+ service[Symbol.dispose]()
836
+ findOptions[Symbol.dispose]()
837
+ })
838
+ })
839
+ })
840
+
841
+ describe('row interactions', () => {
842
+ it('should pass row click to collectionService', async () => {
843
+ await usingAsync(new Injector(), async (injector) => {
844
+ const rootElement = document.getElementById('root') as HTMLDivElement
845
+ const onRowClick = vi.fn()
846
+ const service = new CollectionService<TestEntry>({ onRowClick })
847
+ const findOptions = new ObservableValue<any>({})
848
+
849
+ service.data.setValue({
850
+ count: 1,
851
+ entries: [{ id: 1, name: 'Test' }],
852
+ })
853
+
854
+ initializeShadeRoot({
855
+ injector,
856
+ rootElement,
857
+ jsxElement: (
858
+ <DataGrid<TestEntry, 'id' | 'name'>
859
+ columns={['id', 'name']}
860
+ collectionService={service}
861
+ findOptions={findOptions}
862
+ styles={{}}
863
+ headerComponents={{}}
864
+ rowComponents={{}}
865
+ />
866
+ ),
867
+ })
868
+
869
+ await sleepAsync(50)
870
+
871
+ const grid = document.querySelector('shade-data-grid')
872
+ const cell = grid?.querySelector('td') as HTMLTableCellElement
873
+ cell?.click()
874
+
875
+ expect(onRowClick).toHaveBeenCalledWith({ id: 1, name: 'Test' })
876
+
877
+ service[Symbol.dispose]()
878
+ findOptions[Symbol.dispose]()
879
+ })
880
+ })
881
+
882
+ it('should pass row double click to collectionService', async () => {
883
+ await usingAsync(new Injector(), async (injector) => {
884
+ const rootElement = document.getElementById('root') as HTMLDivElement
885
+ const onRowDoubleClick = vi.fn()
886
+ const service = new CollectionService<TestEntry>({ onRowDoubleClick })
887
+ const findOptions = new ObservableValue<any>({})
888
+
889
+ service.data.setValue({
890
+ count: 1,
891
+ entries: [{ id: 1, name: 'Test' }],
892
+ })
893
+
894
+ initializeShadeRoot({
895
+ injector,
896
+ rootElement,
897
+ jsxElement: (
898
+ <DataGrid<TestEntry, 'id' | 'name'>
899
+ columns={['id', 'name']}
900
+ collectionService={service}
901
+ findOptions={findOptions}
902
+ styles={{}}
903
+ headerComponents={{}}
904
+ rowComponents={{}}
905
+ />
906
+ ),
907
+ })
908
+
909
+ await sleepAsync(50)
910
+
911
+ const grid = document.querySelector('shade-data-grid')
912
+ const cell = grid?.querySelector('td') as HTMLTableCellElement
913
+ const dblClickEvent = new MouseEvent('dblclick', { bubbles: true })
914
+ cell?.dispatchEvent(dblClickEvent)
915
+
916
+ expect(onRowDoubleClick).toHaveBeenCalledWith({ id: 1, name: 'Test' })
917
+
918
+ service[Symbol.dispose]()
919
+ findOptions[Symbol.dispose]()
920
+ })
921
+ })
922
+ })
923
+
924
+ describe('keyboard listener cleanup', () => {
925
+ it('should remove keyboard listener when component is disconnected', async () => {
926
+ await usingAsync(new Injector(), async (injector) => {
927
+ const rootElement = document.getElementById('root') as HTMLDivElement
928
+ const service = createTestService()
929
+ const findOptions = new ObservableValue<any>({})
930
+
931
+ service.hasFocus.setValue(true)
932
+ service.focusedEntry.setValue(service.data.getValue().entries[0])
933
+
934
+ initializeShadeRoot({
935
+ injector,
936
+ rootElement,
937
+ jsxElement: (
938
+ <DataGrid<TestEntry, 'id' | 'name'>
939
+ columns={['id', 'name']}
940
+ collectionService={service}
941
+ findOptions={findOptions}
942
+ styles={{}}
943
+ headerComponents={{}}
944
+ rowComponents={{}}
945
+ />
946
+ ),
947
+ })
948
+
949
+ await sleepAsync(50)
950
+
951
+ const grid = document.querySelector('shade-data-grid') as HTMLElement
952
+ grid.remove()
953
+
954
+ await sleepAsync(10)
955
+
956
+ window.dispatchEvent(new KeyboardEvent('keydown', { key: 'ArrowDown', bubbles: true }))
957
+ expect(service.focusedEntry.getValue()).toEqual({ id: 1, name: 'First' })
958
+
959
+ service[Symbol.dispose]()
960
+ findOptions[Symbol.dispose]()
961
+ })
962
+ })
963
+ })
964
+ })