@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,696 @@
1
+ import { Shade, createComponent } from '@furystack/shades'
2
+ import { buildTransition, cssVariableTheme } from '../../services/css-variable-theme.js'
3
+ import type { Palette } from '../../services/theme-provider-service.js'
4
+ import { ThemeProviderService } from '../../services/theme-provider-service.js'
5
+
6
+ /**
7
+ * Represents a mark on the slider track
8
+ */
9
+ export type SliderMark = {
10
+ /** The value at which to place the mark */
11
+ value: number
12
+ /** Optional label text displayed near the mark */
13
+ label?: string
14
+ }
15
+
16
+ /**
17
+ * Props for the Slider component
18
+ */
19
+ export type SliderProps = {
20
+ /**
21
+ * Current value. A single number for standard mode, or a [min, max] tuple for range mode.
22
+ */
23
+ value?: number | [number, number]
24
+ /**
25
+ * Minimum allowed value
26
+ * @default 0
27
+ */
28
+ min?: number
29
+ /**
30
+ * Maximum allowed value
31
+ * @default 100
32
+ */
33
+ max?: number
34
+ /**
35
+ * Step increment. Set to 0 for continuous (no snapping).
36
+ * @default 1
37
+ */
38
+ step?: number
39
+ /**
40
+ * Whether the slider is disabled
41
+ */
42
+ disabled?: boolean
43
+ /**
44
+ * The palette color for the slider
45
+ * @default 'primary'
46
+ */
47
+ color?: keyof Palette
48
+ /**
49
+ * Whether to render the slider vertically
50
+ */
51
+ vertical?: boolean
52
+ /**
53
+ * Display marks on the slider.
54
+ * `true` auto-generates a mark at each step; an array of SliderMark objects places custom marks.
55
+ */
56
+ marks?: boolean | SliderMark[]
57
+ /**
58
+ * Callback fired when the value changes during interaction
59
+ */
60
+ onValueChange?: (value: number | [number, number]) => void
61
+ /**
62
+ * The name attribute for a hidden input (form integration)
63
+ */
64
+ name?: string
65
+ }
66
+
67
+ const valueToPercent = (value: number, min: number, max: number): number => {
68
+ if (max === min) return 0
69
+ return ((value - min) / (max - min)) * 100
70
+ }
71
+
72
+ const percentToValue = (percent: number, min: number, max: number): number => {
73
+ return min + (percent / 100) * (max - min)
74
+ }
75
+
76
+ const clamp = (value: number, min: number, max: number): number => Math.max(min, Math.min(max, value))
77
+
78
+ const snapToStep = (value: number, step: number, min: number, max: number): number => {
79
+ if (step <= 0) return clamp(value, min, max)
80
+ const snapped = Math.round((value - min) / step) * step + min
81
+ const decimals = String(step).split('.')[1]?.length ?? 0
82
+ return clamp(Number(snapped.toFixed(decimals)), min, max)
83
+ }
84
+
85
+ const resolveMarks = (
86
+ marks: boolean | SliderMark[] | undefined,
87
+ min: number,
88
+ max: number,
89
+ step: number,
90
+ ): SliderMark[] => {
91
+ if (!marks) return []
92
+ if (Array.isArray(marks)) return marks
93
+ if (step <= 0) return []
94
+ const result: SliderMark[] = []
95
+ const decimals = String(step).split('.')[1]?.length ?? 0
96
+ for (let v = min; v <= max; v = Number((v + step).toFixed(decimals))) {
97
+ result.push({ value: v })
98
+ }
99
+ return result
100
+ }
101
+
102
+ const isRangeValue = (value: unknown): value is [number, number] =>
103
+ Array.isArray(value) && value.length === 2 && typeof value[0] === 'number' && typeof value[1] === 'number'
104
+
105
+ /** Stores props for each Slider ref so the constructed handler can access them without re-renders */
106
+ const sliderPropsMap = new WeakMap<object, SliderProps>()
107
+
108
+ /**
109
+ * Directly updates DOM positions and aria-valuenow on thumb/track elements.
110
+ * Used during drag for smooth updates without triggering a full re-render.
111
+ */
112
+ const syncVisuals = (
113
+ track: HTMLElement | null,
114
+ thumb0: HTMLElement | null,
115
+ thumb1: HTMLElement | null,
116
+ value: number | [number, number],
117
+ min: number,
118
+ max: number,
119
+ vertical: boolean,
120
+ ): void => {
121
+ const thumbs = [thumb0, thumb1].filter(Boolean) as HTMLElement[]
122
+
123
+ if (isRangeValue(value)) {
124
+ const startPct = valueToPercent(value[0], min, max)
125
+ const endPct = valueToPercent(value[1], min, max)
126
+
127
+ if (track) {
128
+ if (vertical) {
129
+ track.style.bottom = `${startPct}%`
130
+ track.style.height = `${endPct - startPct}%`
131
+ track.style.left = ''
132
+ track.style.width = ''
133
+ } else {
134
+ track.style.left = `${startPct}%`
135
+ track.style.width = `${endPct - startPct}%`
136
+ track.style.bottom = ''
137
+ track.style.height = ''
138
+ }
139
+ }
140
+
141
+ thumbs.forEach((thumb, i) => {
142
+ const pct = i === 0 ? startPct : endPct
143
+ if (vertical) {
144
+ thumb.style.bottom = `${pct}%`
145
+ thumb.style.left = ''
146
+ } else {
147
+ thumb.style.left = `${pct}%`
148
+ thumb.style.bottom = ''
149
+ }
150
+ thumb.setAttribute('aria-valuenow', String(value[i]))
151
+ })
152
+ } else {
153
+ const pct = valueToPercent(value, min, max)
154
+
155
+ if (track) {
156
+ if (vertical) {
157
+ track.style.bottom = '0%'
158
+ track.style.height = `${pct}%`
159
+ track.style.left = ''
160
+ track.style.width = ''
161
+ } else {
162
+ track.style.left = '0%'
163
+ track.style.width = `${pct}%`
164
+ track.style.bottom = ''
165
+ track.style.height = ''
166
+ }
167
+ }
168
+
169
+ if (thumbs[0]) {
170
+ if (vertical) {
171
+ thumbs[0].style.bottom = `${pct}%`
172
+ thumbs[0].style.left = ''
173
+ } else {
174
+ thumbs[0].style.left = `${pct}%`
175
+ thumbs[0].style.bottom = ''
176
+ }
177
+ thumbs[0].setAttribute('aria-valuenow', String(value))
178
+ }
179
+ }
180
+ }
181
+
182
+ /**
183
+ * Sets all ARIA attributes on thumb elements after render.
184
+ */
185
+ const syncAriaAttributes = (
186
+ thumb0: HTMLElement | null,
187
+ thumb1: HTMLElement | null,
188
+ value: number | [number, number],
189
+ min: number,
190
+ max: number,
191
+ vertical: boolean,
192
+ disabled: boolean,
193
+ ): void => {
194
+ const thumbs = [thumb0, thumb1].filter(Boolean) as HTMLElement[]
195
+ thumbs.forEach((thumb, i) => {
196
+ thumb.setAttribute('role', 'slider')
197
+ thumb.setAttribute('aria-valuemin', String(min))
198
+ thumb.setAttribute('aria-valuemax', String(max))
199
+ thumb.setAttribute('aria-orientation', vertical ? 'vertical' : 'horizontal')
200
+ if (disabled) {
201
+ thumb.setAttribute('aria-disabled', 'true')
202
+ } else {
203
+ thumb.removeAttribute('aria-disabled')
204
+ }
205
+ if (isRangeValue(value)) {
206
+ thumb.setAttribute('aria-valuenow', String(value[i]))
207
+ } else {
208
+ thumb.setAttribute('aria-valuenow', String(value))
209
+ }
210
+ })
211
+ }
212
+
213
+ export const Slider = Shade<SliderProps>({
214
+ shadowDomName: 'shade-slider',
215
+ css: {
216
+ display: 'block',
217
+ position: 'relative',
218
+ width: '100%',
219
+ padding: '10px',
220
+ cursor: 'pointer',
221
+ userSelect: 'none',
222
+ webkitUserSelect: 'none',
223
+ touchAction: 'none',
224
+
225
+ '&[data-vertical]': {
226
+ display: 'inline-flex',
227
+ width: 'auto',
228
+ height: '200px',
229
+ },
230
+
231
+ '&[data-disabled]': {
232
+ cursor: 'default',
233
+ opacity: cssVariableTheme.action.disabledOpacity,
234
+ pointerEvents: 'none',
235
+ },
236
+
237
+ '&[data-has-labels]': {
238
+ paddingBottom: '28px',
239
+ },
240
+
241
+ '&[data-vertical][data-has-labels]': {
242
+ paddingBottom: '10px',
243
+ paddingRight: '40px',
244
+ },
245
+
246
+ '& .slider-root': {
247
+ position: 'relative',
248
+ width: '100%',
249
+ height: '4px',
250
+ },
251
+
252
+ '&[data-vertical] .slider-root': {
253
+ width: '4px',
254
+ height: '100%',
255
+ },
256
+
257
+ '& .slider-rail': {
258
+ position: 'absolute',
259
+ inset: '0',
260
+ borderRadius: cssVariableTheme.shape.borderRadius.xs,
261
+ backgroundColor: 'color-mix(in srgb, var(--slider-color) 30%, transparent)',
262
+ },
263
+
264
+ '& .slider-track': {
265
+ position: 'absolute',
266
+ height: '100%',
267
+ borderRadius: cssVariableTheme.shape.borderRadius.xs,
268
+ backgroundColor: 'var(--slider-color)',
269
+ transition: buildTransition(
270
+ ['left', cssVariableTheme.transitions.duration.fast, cssVariableTheme.transitions.easing.default],
271
+ ['width', cssVariableTheme.transitions.duration.fast, cssVariableTheme.transitions.easing.default],
272
+ ),
273
+ },
274
+
275
+ '&[data-vertical] .slider-track': {
276
+ width: '100%',
277
+ height: 'auto',
278
+ transition: buildTransition(
279
+ ['bottom', cssVariableTheme.transitions.duration.fast, cssVariableTheme.transitions.easing.default],
280
+ ['height', cssVariableTheme.transitions.duration.fast, cssVariableTheme.transitions.easing.default],
281
+ ),
282
+ },
283
+
284
+ '&[data-dragging] .slider-track': {
285
+ transition: 'none',
286
+ },
287
+
288
+ '& .slider-thumb': {
289
+ position: 'absolute',
290
+ width: '20px',
291
+ height: '20px',
292
+ borderRadius: cssVariableTheme.shape.borderRadius.full,
293
+ backgroundColor: 'var(--slider-color)',
294
+ boxShadow: cssVariableTheme.shadows.sm,
295
+ top: '50%',
296
+ transform: 'translate(-50%, -50%)',
297
+ outline: 'none',
298
+ cursor: 'grab',
299
+ zIndex: '1',
300
+ transition: buildTransition(
301
+ ['left', cssVariableTheme.transitions.duration.fast, cssVariableTheme.transitions.easing.default],
302
+ ['box-shadow', cssVariableTheme.transitions.duration.fast, cssVariableTheme.transitions.easing.default],
303
+ ),
304
+ },
305
+
306
+ '&[data-vertical] .slider-thumb': {
307
+ top: 'auto',
308
+ left: '50%',
309
+ transform: 'translate(-50%, 50%)',
310
+ transition: buildTransition(
311
+ ['bottom', cssVariableTheme.transitions.duration.fast, cssVariableTheme.transitions.easing.default],
312
+ ['box-shadow', cssVariableTheme.transitions.duration.fast, cssVariableTheme.transitions.easing.default],
313
+ ),
314
+ },
315
+
316
+ '&[data-dragging] .slider-thumb': {
317
+ cursor: 'grabbing',
318
+ transition: 'none',
319
+ },
320
+
321
+ '& .slider-thumb:hover': {
322
+ boxShadow: '0 0 0 8px color-mix(in srgb, var(--slider-color) 16%, transparent)',
323
+ },
324
+
325
+ '& .slider-thumb:focus-visible': {
326
+ boxShadow: '0 0 0 4px color-mix(in srgb, var(--slider-color) 30%, transparent)',
327
+ },
328
+
329
+ '& .slider-mark-dot': {
330
+ position: 'absolute',
331
+ width: '4px',
332
+ height: '4px',
333
+ borderRadius: cssVariableTheme.shape.borderRadius.full,
334
+ top: '50%',
335
+ transform: 'translate(-50%, -50%)',
336
+ backgroundColor: 'color-mix(in srgb, var(--slider-color) 50%, white)',
337
+ },
338
+
339
+ '& .slider-mark-dot[data-active]': {
340
+ backgroundColor: 'var(--slider-color)',
341
+ },
342
+
343
+ '&[data-vertical] .slider-mark-dot': {
344
+ top: 'auto',
345
+ left: '50%',
346
+ transform: 'translate(-50%, 50%)',
347
+ },
348
+
349
+ '& .slider-mark-label': {
350
+ position: 'absolute',
351
+ top: '14px',
352
+ transform: 'translateX(-50%)',
353
+ fontSize: cssVariableTheme.typography.fontSize.xs,
354
+ color: cssVariableTheme.text.secondary,
355
+ whiteSpace: 'nowrap',
356
+ },
357
+
358
+ '&[data-vertical] .slider-mark-label': {
359
+ top: 'auto',
360
+ left: cssVariableTheme.spacing.md,
361
+ transform: 'translateY(50%)',
362
+ },
363
+ },
364
+
365
+ render: ({ props, injector, useDisposable, useHostProps, useRef }) => {
366
+ const sliderRootRef = useRef<HTMLDivElement>('sliderRoot')
367
+ const trackRef = useRef<HTMLElement>('sliderTrack')
368
+ const thumb0Ref = useRef<HTMLElement>('sliderThumb0')
369
+ const thumb1Ref = useRef<HTMLElement>('sliderThumb1')
370
+
371
+ useDisposable('interaction-handler', () => {
372
+ let isDragging = false
373
+ let activeThumbIdx = 0
374
+ let cleanupDrag: (() => void) | null = null
375
+ // Pending value tracked during drag to avoid triggering re-renders mid-interaction.
376
+ // Shades recreates custom elements on parent re-render, which would orphan our
377
+ // document-level drag listeners and cause stale getBoundingClientRect calculations.
378
+ let pendingValue: number | [number, number] | null = null
379
+
380
+ const getProps = (): SliderProps & { min: number; max: number; step: number } => {
381
+ const p = sliderPropsMap.get(sliderRootRef)
382
+ return {
383
+ ...p,
384
+ min: p?.min ?? 0,
385
+ max: p?.max ?? 100,
386
+ step: p?.step ?? 1,
387
+ }
388
+ }
389
+
390
+ const getValueFromPointer = (clientX: number, clientY: number): number | null => {
391
+ if (!sliderRootRef.current?.isConnected) return null
392
+ const root = sliderRootRef.current
393
+ if (!root) return null
394
+ const rect = root.getBoundingClientRect()
395
+ if (rect.width === 0 && rect.height === 0) return null
396
+ const { min, max, step, vertical } = getProps()
397
+ let pct: number
398
+ if (vertical) {
399
+ pct = rect.height > 0 ? ((rect.bottom - clientY) / rect.height) * 100 : 0
400
+ } else {
401
+ pct = rect.width > 0 ? ((clientX - rect.left) / rect.width) * 100 : 0
402
+ }
403
+ pct = clamp(pct, 0, 100)
404
+ return snapToStep(percentToValue(pct, min, max), step, min, max)
405
+ }
406
+
407
+ const applyVisual = (newValue: number | [number, number]): void => {
408
+ const { min, max, vertical } = getProps()
409
+ syncVisuals(trackRef.current, thumb0Ref.current, thumb1Ref.current, newValue, min, max, vertical ?? false)
410
+ }
411
+
412
+ const emitToParent = (newValue: number | [number, number]): void => {
413
+ getProps().onValueChange?.(newValue)
414
+ }
415
+
416
+ const getCurrentValue = (): number | [number, number] => {
417
+ if (pendingValue !== null) return pendingValue
418
+ const currentProps = getProps()
419
+ return currentProps.value ?? currentProps.min
420
+ }
421
+
422
+ const handlePointerDown = (e: MouseEvent | TouchEvent): void => {
423
+ const currentProps = getProps()
424
+ if (currentProps.disabled) return
425
+
426
+ const clientX = 'touches' in e ? e.touches[0].clientX : e.clientX
427
+ const clientY = 'touches' in e ? e.touches[0].clientY : e.clientY
428
+ const target = e.target as HTMLElement
429
+ const isThumb = target.classList.contains('slider-thumb')
430
+
431
+ if (isThumb) {
432
+ activeThumbIdx = Number(target.dataset.index ?? 0)
433
+ pendingValue = getCurrentValue()
434
+ } else {
435
+ const newVal = getValueFromPointer(clientX, clientY)
436
+ if (newVal === null) return
437
+ const currentValue = currentProps.value ?? currentProps.min
438
+
439
+ if (isRangeValue(currentValue)) {
440
+ const distStart = Math.abs(newVal - currentValue[0])
441
+ const distEnd = Math.abs(newVal - currentValue[1])
442
+ activeThumbIdx = distStart <= distEnd ? 0 : 1
443
+ const updated: [number, number] = [currentValue[0], currentValue[1]]
444
+ updated[activeThumbIdx] = newVal
445
+ if (updated[0] > updated[1]) {
446
+ activeThumbIdx = activeThumbIdx === 0 ? 1 : 0
447
+ ;[updated[0], updated[1]] = [updated[1], updated[0]]
448
+ }
449
+ pendingValue = updated
450
+ } else {
451
+ activeThumbIdx = 0
452
+ pendingValue = newVal
453
+ }
454
+ applyVisual(pendingValue)
455
+ }
456
+
457
+ isDragging = true
458
+ sliderRootRef.current?.setAttribute('data-dragging', '')
459
+
460
+ const handlePointerMove = (moveEvt: MouseEvent | TouchEvent): void => {
461
+ if (!isDragging || !sliderRootRef.current?.isConnected) {
462
+ endDrag()
463
+ return
464
+ }
465
+ moveEvt.preventDefault()
466
+
467
+ const mx = 'touches' in moveEvt ? moveEvt.touches[0].clientX : moveEvt.clientX
468
+ const my = 'touches' in moveEvt ? moveEvt.touches[0].clientY : moveEvt.clientY
469
+ const newVal = getValueFromPointer(mx, my)
470
+ if (newVal === null) return
471
+ const currentValue = getCurrentValue()
472
+
473
+ if (isRangeValue(currentValue)) {
474
+ const updated: [number, number] = [currentValue[0], currentValue[1]]
475
+ updated[activeThumbIdx] = newVal
476
+ if (updated[0] > updated[1]) {
477
+ activeThumbIdx = activeThumbIdx === 0 ? 1 : 0
478
+ ;[updated[0], updated[1]] = [updated[1], updated[0]]
479
+ }
480
+ pendingValue = updated
481
+ } else {
482
+ pendingValue = newVal
483
+ }
484
+ applyVisual(pendingValue)
485
+ }
486
+
487
+ const endDrag = (): void => {
488
+ isDragging = false
489
+ sliderRootRef.current?.removeAttribute('data-dragging')
490
+ document.removeEventListener('mousemove', handlePointerMove)
491
+ document.removeEventListener('mouseup', endDrag)
492
+ document.removeEventListener('touchmove', handlePointerMove)
493
+ document.removeEventListener('touchend', endDrag)
494
+ cleanupDrag = null
495
+ if (pendingValue !== null) {
496
+ const value = pendingValue
497
+ pendingValue = null
498
+ emitToParent(value)
499
+ }
500
+ }
501
+
502
+ document.addEventListener('mousemove', handlePointerMove)
503
+ document.addEventListener('mouseup', endDrag)
504
+ document.addEventListener('touchmove', handlePointerMove, { passive: false })
505
+ document.addEventListener('touchend', endDrag)
506
+ cleanupDrag = endDrag
507
+ e.preventDefault()
508
+ }
509
+
510
+ const handleKeyDown = (e: KeyboardEvent): void => {
511
+ const currentProps = getProps()
512
+ if (currentProps.disabled) return
513
+
514
+ const target = e.target as HTMLElement
515
+ if (!target.classList.contains('slider-thumb')) return
516
+
517
+ const thumbIdx = Number(target.dataset.index ?? 0)
518
+ const { step, min, max } = currentProps
519
+ const currentValue = getCurrentValue()
520
+
521
+ let val: number
522
+ if (isRangeValue(currentValue)) {
523
+ val = currentValue[thumbIdx]
524
+ } else {
525
+ val = currentValue
526
+ }
527
+
528
+ const effectiveStep = step <= 0 ? 1 : step
529
+ const bigStep = effectiveStep * 10
530
+ let newVal: number
531
+
532
+ switch (e.key) {
533
+ case 'ArrowRight':
534
+ case 'ArrowUp':
535
+ newVal = snapToStep(val + effectiveStep, step, min, max)
536
+ break
537
+ case 'ArrowLeft':
538
+ case 'ArrowDown':
539
+ newVal = snapToStep(val - effectiveStep, step, min, max)
540
+ break
541
+ case 'PageUp':
542
+ newVal = snapToStep(val + bigStep, step, min, max)
543
+ break
544
+ case 'PageDown':
545
+ newVal = snapToStep(val - bigStep, step, min, max)
546
+ break
547
+ case 'Home':
548
+ newVal = min
549
+ break
550
+ case 'End':
551
+ newVal = max
552
+ break
553
+ default:
554
+ return
555
+ }
556
+
557
+ e.preventDefault()
558
+
559
+ let updated: number | [number, number]
560
+ if (isRangeValue(currentValue)) {
561
+ const pair: [number, number] = [currentValue[0], currentValue[1]]
562
+ pair[thumbIdx] = newVal
563
+ if (thumbIdx === 0 && pair[0] > pair[1]) pair[0] = pair[1]
564
+ if (thumbIdx === 1 && pair[1] < pair[0]) pair[1] = pair[0]
565
+ updated = pair
566
+ } else {
567
+ updated = newVal
568
+ }
569
+ applyVisual(updated)
570
+ emitToParent(updated)
571
+ }
572
+
573
+ let root: HTMLElement | null = null
574
+ queueMicrotask(() => {
575
+ root = sliderRootRef.current
576
+ root?.addEventListener('mousedown', handlePointerDown)
577
+ root?.addEventListener('touchstart', handlePointerDown, { passive: false })
578
+ root?.addEventListener('keydown', handleKeyDown)
579
+ })
580
+
581
+ return {
582
+ [Symbol.dispose]: () => {
583
+ root?.removeEventListener('mousedown', handlePointerDown)
584
+ root?.removeEventListener('touchstart', handlePointerDown)
585
+ root?.removeEventListener('keydown', handleKeyDown)
586
+ cleanupDrag?.()
587
+ },
588
+ }
589
+ })
590
+
591
+ const themeProvider = injector.getInstance(ThemeProviderService)
592
+ const min = props.min ?? 0
593
+ const max = props.max ?? 100
594
+ const step = props.step ?? 1
595
+ const value = props.value ?? min
596
+ const vertical = props.vertical ?? false
597
+ const disabled = props.disabled ?? false
598
+ const rangeMode = isRangeValue(value)
599
+
600
+ // Store props for interaction event handlers
601
+ sliderPropsMap.set(sliderRootRef, props)
602
+
603
+ // Theme color
604
+ const color = themeProvider.theme.palette[props.color || 'primary'].main
605
+
606
+ // Resolve marks
607
+ const marks = resolveMarks(props.marks, min, max, step)
608
+ const hasLabels = marks.some((m) => m.label)
609
+
610
+ useHostProps({
611
+ style: { '--slider-color': color },
612
+ ...(vertical ? { 'data-vertical': '' } : {}),
613
+ ...(disabled ? { 'data-disabled': '' } : {}),
614
+ ...(hasLabels ? { 'data-has-labels': '' } : {}),
615
+ })
616
+
617
+ // Set ARIA attributes on thumbs after render
618
+ queueMicrotask(() => {
619
+ syncAriaAttributes(thumb0Ref.current, thumb1Ref.current, value, min, max, vertical, disabled)
620
+ })
621
+
622
+ // Calculate positions
623
+ const renderMarks = (activeCheck: (markValue: number) => boolean) =>
624
+ marks.map((mark) => {
625
+ const pct = valueToPercent(mark.value, min, max)
626
+ const isActive = activeCheck(mark.value)
627
+ const pos: Partial<CSSStyleDeclaration> = vertical ? { bottom: `${pct}%` } : { left: `${pct}%` }
628
+ return (
629
+ <>
630
+ <span className="slider-mark-dot" {...(isActive ? { 'data-active': '' } : {})} style={pos} />
631
+ {mark.label ? (
632
+ <span className="slider-mark-label" style={pos}>
633
+ {mark.label}
634
+ </span>
635
+ ) : null}
636
+ </>
637
+ )
638
+ })
639
+
640
+ if (rangeMode) {
641
+ const startPct = valueToPercent(value[0], min, max)
642
+ const endPct = valueToPercent(value[1], min, max)
643
+
644
+ const trackStyle: Partial<CSSStyleDeclaration> = vertical
645
+ ? { bottom: `${startPct}%`, height: `${endPct - startPct}%` }
646
+ : { left: `${startPct}%`, width: `${endPct - startPct}%` }
647
+
648
+ const thumbStartStyle: Partial<CSSStyleDeclaration> = vertical
649
+ ? { bottom: `${startPct}%` }
650
+ : { left: `${startPct}%` }
651
+
652
+ const thumbEndStyle: Partial<CSSStyleDeclaration> = vertical ? { bottom: `${endPct}%` } : { left: `${endPct}%` }
653
+
654
+ return (
655
+ <div ref={sliderRootRef} className="slider-root">
656
+ <div className="slider-rail" />
657
+ <div ref={trackRef} className="slider-track" style={trackStyle} />
658
+ <div
659
+ ref={thumb0Ref}
660
+ className="slider-thumb"
661
+ data-index="0"
662
+ tabIndex={disabled ? -1 : 0}
663
+ style={thumbStartStyle}
664
+ />
665
+ <div
666
+ ref={thumb1Ref}
667
+ className="slider-thumb"
668
+ data-index="1"
669
+ tabIndex={disabled ? -1 : 0}
670
+ style={thumbEndStyle}
671
+ />
672
+ {renderMarks((v) => v >= value[0] && v <= value[1])}
673
+ </div>
674
+ )
675
+ }
676
+
677
+ // Single slider
678
+ const pct = valueToPercent(value, min, max)
679
+
680
+ const trackStyle: Partial<CSSStyleDeclaration> = vertical
681
+ ? { bottom: '0%', height: `${pct}%` }
682
+ : { left: '0%', width: `${pct}%` }
683
+
684
+ const thumbStyle: Partial<CSSStyleDeclaration> = vertical ? { bottom: `${pct}%` } : { left: `${pct}%` }
685
+
686
+ return (
687
+ <div ref={sliderRootRef} className="slider-root">
688
+ <div className="slider-rail" />
689
+ <div ref={trackRef} className="slider-track" style={trackStyle} />
690
+ <div ref={thumb0Ref} className="slider-thumb" data-index="0" tabIndex={disabled ? -1 : 0} style={thumbStyle} />
691
+ {renderMarks((v) => v <= value)}
692
+ {props.name ? <input type="hidden" name={props.name} value={String(value)} /> : null}
693
+ </div>
694
+ )
695
+ },
696
+ })