@studiocubics/components 0.0.1 → 0.0.2

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 (433) hide show
  1. package/dist/Cards/Card/Card.d.ts +49 -0
  2. package/dist/Cards/Card/Card.js +45 -0
  3. package/dist/Cards/Card/Card.js.map +1 -0
  4. package/dist/Cards/Card/Card.module.css.js +4 -0
  5. package/dist/Cards/Card/Card.module.css.js.map +1 -0
  6. package/dist/Cards/CollectionItemCard/CollectionItemCard.d.ts +55 -0
  7. package/dist/Cards/CollectionItemCard/CollectionItemCard.js +48 -0
  8. package/dist/Cards/CollectionItemCard/CollectionItemCard.js.map +1 -0
  9. package/dist/Cards/CollectionItemCard/CollectionItemCard.module.css.js +4 -0
  10. package/dist/Cards/CollectionItemCard/CollectionItemCard.module.css.js.map +1 -0
  11. package/dist/Cards/CollectionItemCard/CollectionItemCardActions.d.ts +19 -0
  12. package/dist/Cards/CollectionItemCard/CollectionItemCardActions.js +34 -0
  13. package/dist/Cards/CollectionItemCard/CollectionItemCardActions.js.map +1 -0
  14. package/dist/Cards/GlassCard/GlassCard.d.ts +7 -0
  15. package/dist/Cards/GlassCard/GlassCard.js +52 -0
  16. package/dist/Cards/GlassCard/GlassCard.js.map +1 -0
  17. package/dist/Cards/GlassCard/GlassCard.module.css.js +4 -0
  18. package/dist/Cards/GlassCard/GlassCard.module.css.js.map +1 -0
  19. package/dist/Display/Accordion/Accordion.d.ts +14 -0
  20. package/dist/Display/Accordion/Accordion.js +28 -0
  21. package/dist/Display/Accordion/Accordion.js.map +1 -0
  22. package/dist/Display/Accordion/Accordion.module.css.js +4 -0
  23. package/dist/Display/Accordion/Accordion.module.css.js.map +1 -0
  24. package/dist/Display/Accordion/AccordionItem.d.ts +15 -0
  25. package/dist/Display/Accordion/AccordionItem.js +56 -0
  26. package/dist/Display/Accordion/AccordionItem.js.map +1 -0
  27. package/dist/Display/Chip/Chip.d.ts +46 -0
  28. package/dist/Display/Chip/Chip.js +43 -0
  29. package/dist/Display/Chip/Chip.js.map +1 -0
  30. package/dist/Display/Chip/Chip.module.css.js +4 -0
  31. package/dist/Display/Chip/Chip.module.css.js.map +1 -0
  32. package/dist/Display/IdentityDisplay/IdentityDisplay.d.ts +21 -0
  33. package/dist/Display/IdentityDisplay/IdentityDisplay.js +36 -0
  34. package/dist/Display/IdentityDisplay/IdentityDisplay.js.map +1 -0
  35. package/dist/Display/IdentityDisplay/IdentityDisplay.module.css.js +4 -0
  36. package/dist/Display/IdentityDisplay/IdentityDisplay.module.css.js.map +1 -0
  37. package/dist/Display/InputErrors/InputErrors.d.ts +11 -0
  38. package/dist/Display/InputErrors/InputErrors.js +25 -0
  39. package/dist/Display/InputErrors/InputErrors.js.map +1 -0
  40. package/dist/Display/InputErrors/InputErrors.module.css.js +4 -0
  41. package/dist/Display/InputErrors/InputErrors.module.css.js.map +1 -0
  42. package/dist/Display/Kbd/Kbd.d.ts +8 -0
  43. package/dist/Display/Kbd/Kbd.js +19 -0
  44. package/dist/Display/Kbd/Kbd.js.map +1 -0
  45. package/dist/Display/Kbd/Kbd.module.css.js +4 -0
  46. package/dist/Display/Kbd/Kbd.module.css.js.map +1 -0
  47. package/dist/Display/Kbd/buttonList.d.ts +324 -0
  48. package/dist/Display/Kbd/buttonList.js +198 -0
  49. package/dist/Display/Kbd/buttonList.js.map +1 -0
  50. package/dist/Display/LabeledValue/LabeledValue.d.ts +9 -0
  51. package/dist/Display/LabeledValue/LabeledValue.js +11 -0
  52. package/dist/Display/LabeledValue/LabeledValue.js.map +1 -0
  53. package/dist/Display/LabeledValue/LabeledValue.module.css.js +4 -0
  54. package/dist/Display/LabeledValue/LabeledValue.module.css.js.map +1 -0
  55. package/dist/Display/List/List.d.ts +50 -0
  56. package/dist/Display/List/List.js +96 -0
  57. package/dist/Display/List/List.js.map +1 -0
  58. package/dist/Display/List/List.module.css.js +4 -0
  59. package/dist/Display/List/List.module.css.js.map +1 -0
  60. package/dist/Display/PasswordStrength/PasswordStrength.d.ts +4 -0
  61. package/dist/Display/PasswordStrength/PasswordStrength.js +17 -0
  62. package/dist/Display/PasswordStrength/PasswordStrength.js.map +1 -0
  63. package/dist/Display/PasswordStrength/PasswordStrength.module.css.js +4 -0
  64. package/dist/Display/PasswordStrength/PasswordStrength.module.css.js.map +1 -0
  65. package/dist/Display/PasswordStrength/usePasswordStrength.d.ts +42 -0
  66. package/dist/Display/PasswordStrength/usePasswordStrength.js +49 -0
  67. package/dist/Display/PasswordStrength/usePasswordStrength.js.map +1 -0
  68. package/dist/Display/Skeleton/Skeleton.d.ts +8 -0
  69. package/dist/Display/Skeleton/Skeleton.js +11 -0
  70. package/dist/Display/Skeleton/Skeleton.js.map +1 -0
  71. package/dist/Display/Skeleton/Skeleton.module.css.js +4 -0
  72. package/dist/Display/Skeleton/Skeleton.module.css.js.map +1 -0
  73. package/dist/Display/Toast/Toaster.d.ts +1 -0
  74. package/dist/Display/Toast/Toaster.js +45 -0
  75. package/dist/Display/Toast/Toaster.js.map +1 -0
  76. package/dist/Display/Toast/toast.d.ts +12 -0
  77. package/dist/Display/Toast/toast.js +32 -0
  78. package/dist/Display/Toast/toast.js.map +1 -0
  79. package/dist/Display/Tooltip/Tooltip.d.ts +8 -0
  80. package/dist/Display/Tooltip/Tooltip.js +45 -0
  81. package/dist/Display/Tooltip/Tooltip.js.map +1 -0
  82. package/dist/Display/Tooltip/Tooltip.module.css.js +4 -0
  83. package/dist/Display/Tooltip/Tooltip.module.css.js.map +1 -0
  84. package/dist/Display/Tooltip/getArrowDirection.d.ts +1 -0
  85. package/dist/Display/Tooltip/getArrowDirection.js +48 -0
  86. package/dist/Display/Tooltip/getArrowDirection.js.map +1 -0
  87. package/dist/Display/Tooltip/useTooltip.d.ts +8 -0
  88. package/dist/Display/Tooltip/useTooltip.js +48 -0
  89. package/dist/Display/Tooltip/useTooltip.js.map +1 -0
  90. package/dist/Forms/ConfirmationForm/ConfirmationForm.d.ts +15 -0
  91. package/dist/Forms/ConfirmationForm/ConfirmationForm.js +12 -0
  92. package/dist/Forms/ConfirmationForm/ConfirmationForm.js.map +1 -0
  93. package/dist/Forms/ConfirmationForm/ConfirmationForm.module.css.js +4 -0
  94. package/dist/Forms/ConfirmationForm/ConfirmationForm.module.css.js.map +1 -0
  95. package/dist/Inputs/Button/Button.d.ts +83 -0
  96. package/dist/Inputs/Button/Button.js +56 -0
  97. package/dist/Inputs/Button/Button.js.map +1 -0
  98. package/dist/Inputs/Button/Button.module.css.js +4 -0
  99. package/dist/Inputs/Button/Button.module.css.js.map +1 -0
  100. package/dist/Inputs/Checkbox/Checkbox.d.ts +23 -0
  101. package/dist/Inputs/Checkbox/Checkbox.js +55 -0
  102. package/dist/Inputs/Checkbox/Checkbox.js.map +1 -0
  103. package/dist/Inputs/Checkbox/Checkbox.module.css.js +4 -0
  104. package/dist/Inputs/Checkbox/Checkbox.module.css.js.map +1 -0
  105. package/dist/Inputs/Checkbox/CheckboxGroup/CheckboxGroup.d.ts +15 -0
  106. package/dist/Inputs/Checkbox/CheckboxGroup/CheckboxGroup.js +35 -0
  107. package/dist/Inputs/Checkbox/CheckboxGroup/CheckboxGroup.js.map +1 -0
  108. package/dist/Inputs/Checkbox/CheckboxGroup/CheckboxGroup.module.css.js +4 -0
  109. package/dist/Inputs/Checkbox/CheckboxGroup/CheckboxGroup.module.css.js.map +1 -0
  110. package/dist/Inputs/Checkbox/CheckboxSelectAll.d.ts +5 -0
  111. package/dist/Inputs/Checkbox/CheckboxSelectAll.js +19 -0
  112. package/dist/Inputs/Checkbox/CheckboxSelectAll.js.map +1 -0
  113. package/dist/Inputs/PasswordInput/PasswordInput.d.ts +31 -0
  114. package/dist/Inputs/PasswordInput/PasswordInput.js +45 -0
  115. package/dist/Inputs/PasswordInput/PasswordInput.js.map +1 -0
  116. package/dist/Inputs/PasswordInput/PasswordInput.module.css.js +4 -0
  117. package/dist/Inputs/PasswordInput/PasswordInput.module.css.js.map +1 -0
  118. package/dist/Inputs/Select/Select.d.ts +22 -0
  119. package/dist/Inputs/Select/Select.js +26 -0
  120. package/dist/Inputs/Select/Select.js.map +1 -0
  121. package/dist/Inputs/Select/Select.module.css.js +4 -0
  122. package/dist/Inputs/Select/Select.module.css.js.map +1 -0
  123. package/dist/Inputs/Switch/Switch.d.ts +43 -0
  124. package/dist/Inputs/Switch/Switch.js +81 -0
  125. package/dist/Inputs/Switch/Switch.js.map +1 -0
  126. package/dist/Inputs/Switch/Switch.module.css.js +4 -0
  127. package/dist/Inputs/Switch/Switch.module.css.js.map +1 -0
  128. package/dist/Inputs/TextAreaInput/TextAreaInput.d.ts +17 -0
  129. package/dist/Inputs/TextAreaInput/TextAreaInput.js +30 -0
  130. package/dist/Inputs/TextAreaInput/TextAreaInput.js.map +1 -0
  131. package/dist/Inputs/TextAreaInput/TextAreaInput.module.css.js +4 -0
  132. package/dist/Inputs/TextAreaInput/TextAreaInput.module.css.js.map +1 -0
  133. package/dist/Inputs/TextInput/TextInput.d.ts +27 -0
  134. package/dist/Inputs/TextInput/TextInput.js +23 -0
  135. package/dist/Inputs/TextInput/TextInput.js.map +1 -0
  136. package/dist/Inputs/TextInput/TextInput.module.css.js +4 -0
  137. package/dist/Inputs/TextInput/TextInput.module.css.js.map +1 -0
  138. package/dist/Inputs/ThemeToggle/ThemeToggleListItem.d.ts +16 -0
  139. package/dist/Inputs/ThemeToggle/ThemeToggleListItem.js +31 -0
  140. package/dist/Inputs/ThemeToggle/ThemeToggleListItem.js.map +1 -0
  141. package/dist/Inputs/ThemeToggle/_index.d.ts +1 -0
  142. package/dist/Layout/Dialog/Dialog.d.ts +13 -0
  143. package/dist/Layout/Dialog/Dialog.js +74 -0
  144. package/dist/Layout/Dialog/Dialog.js.map +1 -0
  145. package/dist/Layout/Dialog/Dialog.module.css.js +4 -0
  146. package/dist/Layout/Dialog/Dialog.module.css.js.map +1 -0
  147. package/dist/Layout/PageLayout/PageLayout.d.ts +28 -0
  148. package/dist/Layout/PageLayout/PageLayout.js +25 -0
  149. package/dist/Layout/PageLayout/PageLayout.js.map +1 -0
  150. package/dist/Layout/PageLayout/PageLayout.module.css.js +4 -0
  151. package/dist/Layout/PageLayout/PageLayout.module.css.js.map +1 -0
  152. package/dist/Layout/PageLayoutPagination/PageLayoutPagination.d.ts +7 -0
  153. package/dist/Layout/PageLayoutPagination/PageLayoutPagination.js +13 -0
  154. package/dist/Layout/PageLayoutPagination/PageLayoutPagination.js.map +1 -0
  155. package/dist/Layout/PageLayoutPagination/PageLayoutPagination.module.css.js +4 -0
  156. package/dist/Layout/PageLayoutPagination/PageLayoutPagination.module.css.js.map +1 -0
  157. package/dist/Layout/PageLayoutTabs/PageLayoutTabs.d.ts +14 -0
  158. package/dist/Layout/PageLayoutTabs/PageLayoutTabs.js +22 -0
  159. package/dist/Layout/PageLayoutTabs/PageLayoutTabs.js.map +1 -0
  160. package/dist/Layout/PageLayoutTabs/PageLayoutTabs.module.css.js +4 -0
  161. package/dist/Layout/PageLayoutTabs/PageLayoutTabs.module.css.js.map +1 -0
  162. package/dist/Layout/Popover/Popover.d.ts +14 -0
  163. package/dist/Layout/Popover/Popover.js +103 -0
  164. package/dist/Layout/Popover/Popover.js.map +1 -0
  165. package/dist/Layout/Popover/Popover.module.css.js +4 -0
  166. package/dist/Layout/Popover/Popover.module.css.js.map +1 -0
  167. package/dist/Layout/SectionWrapper/SectionWrapper.d.ts +14 -0
  168. package/dist/Layout/SectionWrapper/SectionWrapper.js +11 -0
  169. package/dist/Layout/SectionWrapper/SectionWrapper.js.map +1 -0
  170. package/dist/Layout/SectionWrapper/SectionWrapper.module.css.js +4 -0
  171. package/dist/Layout/SectionWrapper/SectionWrapper.module.css.js.map +1 -0
  172. package/dist/Layout/Sidebar/Sidebar.d.ts +15 -0
  173. package/dist/Layout/Sidebar/Sidebar.js +25 -0
  174. package/dist/Layout/Sidebar/Sidebar.js.map +1 -0
  175. package/dist/Layout/Sidebar/Sidebar.module.css.js +4 -0
  176. package/dist/Layout/Sidebar/Sidebar.module.css.js.map +1 -0
  177. package/dist/Layout/Sidebar/SidebarBody/SidebarBody.d.ts +2 -0
  178. package/dist/Layout/Sidebar/SidebarBody/SidebarBody.js +14 -0
  179. package/dist/Layout/Sidebar/SidebarBody/SidebarBody.js.map +1 -0
  180. package/dist/Layout/Sidebar/SidebarBody/SidebarBody.module.css.js +4 -0
  181. package/dist/Layout/Sidebar/SidebarBody/SidebarBody.module.css.js.map +1 -0
  182. package/dist/Layout/Sidebar/SidebarDrawer/SidebarDrawer.d.ts +2 -0
  183. package/dist/Layout/Sidebar/SidebarDrawer/SidebarDrawer.js +14 -0
  184. package/dist/Layout/Sidebar/SidebarDrawer/SidebarDrawer.js.map +1 -0
  185. package/dist/Layout/Sidebar/SidebarDrawer/SidebarDrawer.module.css.js +4 -0
  186. package/dist/Layout/Sidebar/SidebarDrawer/SidebarDrawer.module.css.js.map +1 -0
  187. package/dist/Layout/Sidebar/SidebarFooter/SidebarFooter.d.ts +2 -0
  188. package/dist/Layout/Sidebar/SidebarFooter/SidebarFooter.js +14 -0
  189. package/dist/Layout/Sidebar/SidebarFooter/SidebarFooter.js.map +1 -0
  190. package/dist/Layout/Sidebar/SidebarFooter/SidebarFooter.module.css.js +4 -0
  191. package/dist/Layout/Sidebar/SidebarFooter/SidebarFooter.module.css.js.map +1 -0
  192. package/dist/Layout/Sidebar/SidebarHeader/SidebarHeader.d.ts +2 -0
  193. package/dist/Layout/Sidebar/SidebarHeader/SidebarHeader.js +12 -0
  194. package/dist/Layout/Sidebar/SidebarHeader/SidebarHeader.js.map +1 -0
  195. package/dist/Layout/Sidebar/SidebarViewport/SidebarViewport.d.ts +2 -0
  196. package/dist/Layout/Sidebar/SidebarViewport/SidebarViewport.js +11 -0
  197. package/dist/Layout/Sidebar/SidebarViewport/SidebarViewport.js.map +1 -0
  198. package/dist/Layout/Sidebar/SidebarViewport/SidebarViewport.module.css.js +4 -0
  199. package/dist/Layout/Sidebar/SidebarViewport/SidebarViewport.module.css.js.map +1 -0
  200. package/dist/Layout/Table/Table.d.ts +54 -0
  201. package/dist/Layout/Table/Table.js +131 -0
  202. package/dist/Layout/Table/Table.js.map +1 -0
  203. package/dist/Layout/Table/Table.module.css.js +4 -0
  204. package/dist/Layout/Table/Table.module.css.js.map +1 -0
  205. package/dist/Layout/Table/TableFooter.d.ts +1 -0
  206. package/dist/Layout/Table/TableFooter.js +9 -0
  207. package/dist/Layout/Table/TableFooter.js.map +1 -0
  208. package/dist/Layout/Table/TableHeader.d.ts +1 -0
  209. package/dist/Layout/Table/TableHeader.js +9 -0
  210. package/dist/Layout/Table/TableHeader.js.map +1 -0
  211. package/dist/Layout/Table/tableUtils.d.ts +52 -0
  212. package/dist/Layout/Table/tableUtils.js +124 -0
  213. package/dist/Layout/Table/tableUtils.js.map +1 -0
  214. package/dist/Layout/Table/types.d.ts +43 -0
  215. package/dist/Misc/Cursor/Cursor.d.ts +1 -0
  216. package/dist/Misc/Cursor/Cursor.js +59 -0
  217. package/dist/Misc/Cursor/Cursor.js.map +1 -0
  218. package/dist/Misc/Cursor/Cursor.module.css.js +4 -0
  219. package/dist/Misc/Cursor/Cursor.module.css.js.map +1 -0
  220. package/dist/Misc/Logos.d.ts +14 -0
  221. package/dist/Misc/Logos.js +29 -0
  222. package/dist/Misc/Logos.js.map +1 -0
  223. package/dist/Misc/PoweredByBanner/PoweredByBanner.d.ts +3 -0
  224. package/dist/Misc/PoweredByBanner/PoweredByBanner.js +11 -0
  225. package/dist/Misc/PoweredByBanner/PoweredByBanner.js.map +1 -0
  226. package/dist/Misc/PoweredByBanner/PoweredByBanner.module.css.js +4 -0
  227. package/dist/Misc/PoweredByBanner/PoweredByBanner.module.css.js.map +1 -0
  228. package/dist/Misc/Ripple/Ripple.d.ts +21 -0
  229. package/dist/Misc/Ripple/Ripple.js +62 -0
  230. package/dist/Misc/Ripple/Ripple.js.map +1 -0
  231. package/dist/Misc/Ripple/Ripple.module.css.js +4 -0
  232. package/dist/Misc/Ripple/Ripple.module.css.js.map +1 -0
  233. package/dist/Misc/Spinner/Spinner.d.ts +2 -0
  234. package/dist/Misc/Spinner/Spinner.js +12 -0
  235. package/dist/Misc/Spinner/Spinner.js.map +1 -0
  236. package/dist/Misc/Spinner/Spinner.module.css.js +4 -0
  237. package/dist/Misc/Spinner/Spinner.module.css.js.map +1 -0
  238. package/dist/Misc/TransitionAnimation/TransitionAnimation.d.ts +71 -0
  239. package/dist/Misc/TransitionAnimation/TransitionAnimation.js +87 -0
  240. package/dist/Misc/TransitionAnimation/TransitionAnimation.js.map +1 -0
  241. package/dist/Misc/TransitionAnimation/TransitionAnimation.module.css.js +4 -0
  242. package/dist/Misc/TransitionAnimation/TransitionAnimation.module.css.js.map +1 -0
  243. package/dist/Navigation/Breadcrumbs/Breadcrumbs.d.ts +39 -0
  244. package/dist/Navigation/Breadcrumbs/Breadcrumbs.js +36 -0
  245. package/dist/Navigation/Breadcrumbs/Breadcrumbs.js.map +1 -0
  246. package/dist/Navigation/Breadcrumbs/Breadcrumbs.module.css.js +4 -0
  247. package/dist/Navigation/Breadcrumbs/Breadcrumbs.module.css.js.map +1 -0
  248. package/dist/Navigation/Breadcrumbs/BreadcrumbsItem.d.ts +10 -0
  249. package/dist/Navigation/Breadcrumbs/BreadcrumbsItem.js +15 -0
  250. package/dist/Navigation/Breadcrumbs/BreadcrumbsItem.js.map +1 -0
  251. package/dist/Navigation/Breadcrumbs/useBreadcrumbs.d.ts +7 -0
  252. package/dist/Navigation/Breadcrumbs/useBreadcrumbs.js +44 -0
  253. package/dist/Navigation/Breadcrumbs/useBreadcrumbs.js.map +1 -0
  254. package/dist/Navigation/Pagination/Pagination.d.ts +52 -0
  255. package/dist/Navigation/Pagination/Pagination.js +61 -0
  256. package/dist/Navigation/Pagination/Pagination.js.map +1 -0
  257. package/dist/Navigation/Pagination/Pagination.module.css.js +4 -0
  258. package/dist/Navigation/Pagination/Pagination.module.css.js.map +1 -0
  259. package/dist/Navigation/Pagination/PaginationItem.d.ts +8 -0
  260. package/dist/Navigation/Pagination/PaginationItem.js +14 -0
  261. package/dist/Navigation/Pagination/PaginationItem.js.map +1 -0
  262. package/dist/Navigation/Pagination/usePagination.d.ts +6 -0
  263. package/dist/Navigation/Pagination/usePagination.js +38 -0
  264. package/dist/Navigation/Pagination/usePagination.js.map +1 -0
  265. package/dist/Navigation/Tabs/Tab/Tab.d.ts +46 -0
  266. package/dist/Navigation/Tabs/Tab/Tab.js +70 -0
  267. package/dist/Navigation/Tabs/Tab/Tab.js.map +1 -0
  268. package/dist/Navigation/Tabs/Tab/Tab.module.css.js +4 -0
  269. package/dist/Navigation/Tabs/Tab/Tab.module.css.js.map +1 -0
  270. package/dist/Navigation/Tabs/Tabs.d.ts +12 -0
  271. package/dist/Navigation/Tabs/Tabs.js +22 -0
  272. package/dist/Navigation/Tabs/Tabs.js.map +1 -0
  273. package/dist/Navigation/Tabs/TabsBar/TabsBar.d.ts +12 -0
  274. package/dist/Navigation/Tabs/TabsBar/TabsBar.js +44 -0
  275. package/dist/Navigation/Tabs/TabsBar/TabsBar.js.map +1 -0
  276. package/dist/Navigation/Tabs/TabsBar/TabsBar.module.css.js +4 -0
  277. package/dist/Navigation/Tabs/TabsBar/TabsBar.module.css.js.map +1 -0
  278. package/dist/Typography/ClampedText/ClampedText.d.ts +38 -0
  279. package/dist/Typography/ClampedText/ClampedText.js +44 -0
  280. package/dist/Typography/ClampedText/ClampedText.js.map +1 -0
  281. package/dist/Typography/ClampedText/ClampedText.module.css.js +4 -0
  282. package/dist/Typography/ClampedText/ClampedText.module.css.js.map +1 -0
  283. package/dist/Typography/CopyableText/CopyableText.d.ts +16 -0
  284. package/dist/Typography/CopyableText/CopyableText.js +39 -0
  285. package/dist/Typography/CopyableText/CopyableText.js.map +1 -0
  286. package/dist/Typography/CopyableText/CopyableText.module.css.js +4 -0
  287. package/dist/Typography/CopyableText/CopyableText.module.css.js.map +1 -0
  288. package/dist/Typography/PageTitle/PageTitle.d.ts +9 -0
  289. package/dist/Typography/PageTitle/PageTitle.js +10 -0
  290. package/dist/Typography/PageTitle/PageTitle.js.map +1 -0
  291. package/dist/Typography/PageTitle/PageTitle.module.css.js +4 -0
  292. package/dist/Typography/PageTitle/PageTitle.module.css.js.map +1 -0
  293. package/dist/index.css +2392 -0
  294. package/dist/index.js +64 -0
  295. package/dist/index.js.map +1 -0
  296. package/package.json +4 -4
  297. package/CHANGELOG.md +0 -11
  298. package/eslint.config.js +0 -21
  299. package/src/Cards/Card/Card.module.css +0 -27
  300. package/src/Cards/Card/Card.tsx +0 -105
  301. package/src/Cards/CollectionItemCard/CollectionItemCard.module.css +0 -84
  302. package/src/Cards/CollectionItemCard/CollectionItemCard.tsx +0 -170
  303. package/src/Cards/CollectionItemCard/CollectionItemCardActions.tsx +0 -85
  304. package/src/Cards/GlassCard/GlassCard.module.css +0 -71
  305. package/src/Cards/GlassCard/GlassCard.tsx +0 -80
  306. package/src/Display/Accordion/Accordion.module.css +0 -69
  307. package/src/Display/Accordion/Accordion.tsx +0 -61
  308. package/src/Display/Accordion/AccordionItem.tsx +0 -135
  309. package/src/Display/Chip/Chip.module.css +0 -64
  310. package/src/Display/Chip/Chip.tsx +0 -105
  311. package/src/Display/IdentityDisplay/IdentityDisplay.module.css +0 -95
  312. package/src/Display/IdentityDisplay/IdentityDisplay.tsx +0 -119
  313. package/src/Display/InputErrors/InputErrors.module.css +0 -6
  314. package/src/Display/InputErrors/InputErrors.tsx +0 -52
  315. package/src/Display/Kbd/Kbd.module.css +0 -29
  316. package/src/Display/Kbd/Kbd.tsx +0 -39
  317. package/src/Display/Kbd/buttonList.tsx +0 -246
  318. package/src/Display/LabeledValue/LabeledValue.module.css +0 -32
  319. package/src/Display/LabeledValue/LabeledValue.tsx +0 -20
  320. package/src/Display/List/List.module.css +0 -143
  321. package/src/Display/List/List.tsx +0 -298
  322. package/src/Display/PasswordStrength/PasswordStrength.module.css +0 -45
  323. package/src/Display/PasswordStrength/PasswordStrength.tsx +0 -41
  324. package/src/Display/PasswordStrength/usePasswordStrength.tsx +0 -77
  325. package/src/Display/Skeleton/Skeleton.module.css +0 -54
  326. package/src/Display/Skeleton/Skeleton.tsx +0 -28
  327. package/src/Display/Toast/Toaster.tsx +0 -58
  328. package/src/Display/Toast/toast.ts +0 -44
  329. package/src/Display/Tooltip/Tooltip.module.css +0 -128
  330. package/src/Display/Tooltip/Tooltip.tsx +0 -93
  331. package/src/Display/Tooltip/getArrowDirection.ts +0 -55
  332. package/src/Display/Tooltip/useTooltip.tsx +0 -63
  333. package/src/Forms/ConfirmationForm/ConfirmationForm.module.css +0 -23
  334. package/src/Forms/ConfirmationForm/ConfirmationForm.tsx +0 -60
  335. package/src/Inputs/Button/Button.module.css +0 -131
  336. package/src/Inputs/Button/Button.tsx +0 -178
  337. package/src/Inputs/Checkbox/Checkbox.module.css +0 -77
  338. package/src/Inputs/Checkbox/Checkbox.tsx +0 -191
  339. package/src/Inputs/Checkbox/CheckboxGroup/CheckboxGroup.module.css +0 -10
  340. package/src/Inputs/Checkbox/CheckboxGroup/CheckboxGroup.tsx +0 -83
  341. package/src/Inputs/Checkbox/CheckboxSelectAll.tsx +0 -34
  342. package/src/Inputs/PasswordInput/PasswordInput.module.css +0 -111
  343. package/src/Inputs/PasswordInput/PasswordInput.tsx +0 -229
  344. package/src/Inputs/Select/Select.module.css +0 -138
  345. package/src/Inputs/Select/Select.tsx +0 -136
  346. package/src/Inputs/Switch/Switch.module.css +0 -119
  347. package/src/Inputs/Switch/Switch.tsx +0 -195
  348. package/src/Inputs/TextAreaInput/TextAreaInput.module.css +0 -65
  349. package/src/Inputs/TextAreaInput/TextAreaInput.tsx +0 -97
  350. package/src/Inputs/TextInput/TextInput.module.css +0 -112
  351. package/src/Inputs/TextInput/TextInput.tsx +0 -142
  352. package/src/Inputs/ThemeToggle/ThemeToggleListItem.tsx +0 -80
  353. package/src/Inputs/ThemeToggle/_index.ts +0 -1
  354. package/src/Layout/Dialog/Dialog.module.css +0 -15
  355. package/src/Layout/Dialog/Dialog.tsx +0 -115
  356. package/src/Layout/PageLayout/PageLayout.module.css +0 -20
  357. package/src/Layout/PageLayout/PageLayout.tsx +0 -79
  358. package/src/Layout/PageLayoutPagination/PageLayoutPagination.module.css +0 -5
  359. package/src/Layout/PageLayoutPagination/PageLayoutPagination.tsx +0 -40
  360. package/src/Layout/PageLayoutTabs/PageLayoutTabs.module.css +0 -3
  361. package/src/Layout/PageLayoutTabs/PageLayoutTabs.tsx +0 -62
  362. package/src/Layout/Popover/Popover.module.css +0 -9
  363. package/src/Layout/Popover/Popover.tsx +0 -145
  364. package/src/Layout/SectionWrapper/SectionWrapper.module.css +0 -31
  365. package/src/Layout/SectionWrapper/SectionWrapper.tsx +0 -62
  366. package/src/Layout/Sidebar/Sidebar.module.css +0 -17
  367. package/src/Layout/Sidebar/Sidebar.tsx +0 -39
  368. package/src/Layout/Sidebar/SidebarBody/SidebarBody.module.css +0 -31
  369. package/src/Layout/Sidebar/SidebarBody/SidebarBody.tsx +0 -18
  370. package/src/Layout/Sidebar/SidebarDrawer/SidebarDrawer.module.css +0 -20
  371. package/src/Layout/Sidebar/SidebarDrawer/SidebarDrawer.tsx +0 -19
  372. package/src/Layout/Sidebar/SidebarFooter/SidebarFooter.module.css +0 -35
  373. package/src/Layout/Sidebar/SidebarFooter/SidebarFooter.tsx +0 -19
  374. package/src/Layout/Sidebar/SidebarHeader/SidebarHeader.tsx +0 -14
  375. package/src/Layout/Sidebar/SidebarViewport/SidebarViewport.module.css +0 -12
  376. package/src/Layout/Sidebar/SidebarViewport/SidebarViewport.tsx +0 -11
  377. package/src/Layout/Table/Table.module.css +0 -46
  378. package/src/Layout/Table/Table.tsx +0 -222
  379. package/src/Layout/Table/TableFooter.tsx +0 -4
  380. package/src/Layout/Table/TableHeader.tsx +0 -4
  381. package/src/Layout/Table/tableUtils.ts +0 -142
  382. package/src/Layout/Table/types.ts +0 -48
  383. package/src/Misc/Cursor/Cursor.module.css +0 -31
  384. package/src/Misc/Cursor/Cursor.tsx +0 -77
  385. package/src/Misc/Logos.tsx +0 -230
  386. package/src/Misc/PoweredByBanner/PoweredByBanner.module.css +0 -20
  387. package/src/Misc/PoweredByBanner/PoweredByBanner.tsx +0 -17
  388. package/src/Misc/Ripple/Ripple.module.css +0 -25
  389. package/src/Misc/Ripple/Ripple.tsx +0 -126
  390. package/src/Misc/Spinner/Spinner.module.css +0 -38
  391. package/src/Misc/Spinner/Spinner.tsx +0 -36
  392. package/src/Misc/TransitionAnimation/TransitionAnimation.module.css +0 -131
  393. package/src/Misc/TransitionAnimation/TransitionAnimation.tsx +0 -166
  394. package/src/Navigation/Breadcrumbs/Breadcrumbs.module.css +0 -22
  395. package/src/Navigation/Breadcrumbs/Breadcrumbs.tsx +0 -127
  396. package/src/Navigation/Breadcrumbs/BreadcrumbsItem.tsx +0 -31
  397. package/src/Navigation/Breadcrumbs/useBreadcrumbs.tsx +0 -74
  398. package/src/Navigation/Pagination/Pagination.module.css +0 -41
  399. package/src/Navigation/Pagination/Pagination.tsx +0 -187
  400. package/src/Navigation/Pagination/PaginationItem.tsx +0 -28
  401. package/src/Navigation/Pagination/usePagination.tsx +0 -65
  402. package/src/Navigation/Tabs/Tab/Tab.module.css +0 -43
  403. package/src/Navigation/Tabs/Tab/Tab.tsx +0 -155
  404. package/src/Navigation/Tabs/Tabs.tsx +0 -37
  405. package/src/Navigation/Tabs/TabsBar/TabsBar.module.css +0 -47
  406. package/src/Navigation/Tabs/TabsBar/TabsBar.tsx +0 -92
  407. package/src/Typography/ClampedText/ClampedText.module.css +0 -5
  408. package/src/Typography/ClampedText/ClampedText.tsx +0 -77
  409. package/src/Typography/CopyableText/CopyableText.module.css +0 -21
  410. package/src/Typography/CopyableText/CopyableText.tsx +0 -120
  411. package/src/Typography/PageTitle/PageTitle.module.css +0 -47
  412. package/src/Typography/PageTitle/PageTitle.tsx +0 -35
  413. package/src/declaration.d.ts +0 -4
  414. package/tsconfig.json +0 -32
  415. /package/{src/Cards/CollectionItemCard/_index.ts → dist/Cards/CollectionItemCard/_index.d.ts} +0 -0
  416. /package/{src/Cards/_index.ts → dist/Cards/_index.d.ts} +0 -0
  417. /package/{src/Display/Accordion/_index.ts → dist/Display/Accordion/_index.d.ts} +0 -0
  418. /package/{src/Display/Kbd/_index.ts → dist/Display/Kbd/_index.d.ts} +0 -0
  419. /package/{src/Display/Toast/_index.ts → dist/Display/Toast/_index.d.ts} +0 -0
  420. /package/{src/Display/_index.ts → dist/Display/_index.d.ts} +0 -0
  421. /package/{src/Forms/_index.ts → dist/Forms/_index.d.ts} +0 -0
  422. /package/{src/Inputs/Checkbox/_index.ts → dist/Inputs/Checkbox/_index.d.ts} +0 -0
  423. /package/{src/Inputs/_index.ts → dist/Inputs/_index.d.ts} +0 -0
  424. /package/{src/Layout/Sidebar/_index.ts → dist/Layout/Sidebar/_index.d.ts} +0 -0
  425. /package/{src/Layout/Table/_index.ts → dist/Layout/Table/_index.d.ts} +0 -0
  426. /package/{src/Layout/_index.ts → dist/Layout/_index.d.ts} +0 -0
  427. /package/{src/Misc/_index.ts → dist/Misc/_index.d.ts} +0 -0
  428. /package/{src/Navigation/Breadcrumbs/_index.ts → dist/Navigation/Breadcrumbs/_index.d.ts} +0 -0
  429. /package/{src/Navigation/Pagination/_index.ts → dist/Navigation/Pagination/_index.d.ts} +0 -0
  430. /package/{src/Navigation/Tabs/_index.ts → dist/Navigation/Tabs/_index.d.ts} +0 -0
  431. /package/{src/Navigation/_index.ts → dist/Navigation/_index.d.ts} +0 -0
  432. /package/{src/Typography/_index.ts → dist/Typography/_index.d.ts} +0 -0
  433. /package/{src/index.ts → dist/index.d.ts} +0 -0
@@ -1,195 +0,0 @@
1
- "use client";
2
-
3
- import {
4
- type ChangeEvent,
5
- type ComponentProps,
6
- type ReactNode,
7
- useEffect,
8
- useRef,
9
- useState,
10
- } from "react";
11
- import styles from "./Switch.module.css";
12
- import { cn, mergeRefs } from "@studiocubics/utils";
13
-
14
- /**
15
- * Props for the Switch component
16
- *
17
- * @group switch
18
- * @category inputs
19
- */
20
- export interface SwitchProps
21
- extends Omit<ComponentProps<"input">, "defaultValue" | "value" | "onChange"> {
22
- /**
23
- * Default value of the switch in boolean
24
- */
25
- defaultValue?: boolean;
26
- /**
27
- * Value of the switch in boolean
28
- */
29
- value?: boolean | null;
30
- /**
31
- * Event handler for when the value of the switch changes
32
- */
33
- onChange?: (e: ChangeEvent<HTMLInputElement>, checked: boolean) => void;
34
- /**
35
- * Label for the switch
36
- */
37
- label?: string;
38
- /**
39
- * Icon to render in the thumb of the switch
40
- */
41
- icon?: ReactNode;
42
- /**
43
- * Switch slots props
44
- */
45
- slotProps?: {
46
- inputWrapper?: ComponentProps<"div">;
47
- label?: ComponentProps<"label">;
48
- };
49
- // TODO add size
50
- // TODO add color
51
- }
52
-
53
- /**
54
- * A switch can be used to show on/off state for form inputs, theme toggles etc.
55
- *
56
- * @group switch
57
- * @category inputs
58
- */
59
- export function Switch(props: SwitchProps) {
60
- const {
61
- value,
62
- defaultValue,
63
- type = "checkbox",
64
- onChange,
65
- className,
66
- ref,
67
- label,
68
- "aria-label": ariaLabel,
69
- icon,
70
- disabled,
71
- slotProps = {},
72
- ...rest
73
- } = props;
74
-
75
- const inputRef = useRef<HTMLInputElement>(null);
76
- const thumbRef = useRef<HTMLSpanElement>(null);
77
- const [checked, setChecked] = useState(value);
78
- const [isDragging, setIsDragging] = useState(false);
79
- const dragStartX = useRef(0);
80
- const dragStartChecked = useRef(false);
81
-
82
- useEffect(() => {
83
- setChecked(value);
84
- }, [value]);
85
-
86
- const handleDragStart = (clientX: number) => {
87
- if (disabled) return;
88
- setIsDragging(true);
89
- dragStartX.current = clientX;
90
- dragStartChecked.current = checked ?? false;
91
- };
92
-
93
- const handleDragMove = (clientX: number) => {
94
- if (!isDragging || disabled) return;
95
-
96
- const delta = clientX - dragStartX.current;
97
- const threshold = 10; // Minimum drag distance to trigger change
98
-
99
- if (Math.abs(delta) > threshold) {
100
- const newChecked = delta > 0;
101
- if (newChecked !== checked) {
102
- setChecked(newChecked);
103
- if (inputRef.current && onChange) {
104
- inputRef.current.checked = newChecked;
105
- const event = new Event("change", { bubbles: true }) as any;
106
- Object.defineProperty(event, "currentTarget", {
107
- value: inputRef.current,
108
- });
109
- onChange(event, newChecked);
110
- }
111
- }
112
- }
113
- };
114
-
115
- const handleDragEnd = () => {
116
- setIsDragging(false);
117
- };
118
-
119
- useEffect(() => {
120
- const handleMouseMove = (e: MouseEvent) => handleDragMove(e.clientX);
121
- const handleTouchMove = (e: TouchEvent) =>
122
- handleDragMove(e.touches[0].clientX);
123
- const handleMouseUp = () => handleDragEnd();
124
- const handleTouchEnd = () => handleDragEnd();
125
-
126
- if (isDragging) {
127
- document.addEventListener("mousemove", handleMouseMove);
128
- document.addEventListener("mouseup", handleMouseUp);
129
- document.addEventListener("touchmove", handleTouchMove);
130
- document.addEventListener("touchend", handleTouchEnd);
131
- }
132
-
133
- return () => {
134
- document.removeEventListener("mousemove", handleMouseMove);
135
- document.removeEventListener("mouseup", handleMouseUp);
136
- document.removeEventListener("touchmove", handleTouchMove);
137
- document.removeEventListener("touchend", handleTouchEnd);
138
- };
139
- }, [isDragging, checked]);
140
-
141
- return (
142
- <div
143
- className={cn(className, styles.root, disabled ? styles.disabled : "")}
144
- >
145
- <div
146
- {...slotProps.inputWrapper}
147
- className={cn(styles.inputWrapper, slotProps.inputWrapper?.className)}
148
- >
149
- <input
150
- {...rest}
151
- id={label}
152
- type={type}
153
- ref={mergeRefs(ref, inputRef)}
154
- className={styles.input}
155
- role="switch"
156
- aria-checked={checked ?? false}
157
- aria-label={ariaLabel || label}
158
- disabled={disabled}
159
- onChange={(e) => {
160
- const c = e.currentTarget.checked;
161
- setChecked(c);
162
- if (onChange) onChange(e, c);
163
- }}
164
- />
165
- <span
166
- className={cn(
167
- styles.switch,
168
- checked ? styles.checked : "",
169
- isDragging ? styles.dragging : ""
170
- )}
171
- onClick={() => !isDragging && inputRef.current?.click()}
172
- aria-hidden="true"
173
- >
174
- <span
175
- ref={thumbRef}
176
- className={styles.thumb}
177
- onMouseDown={(e) => handleDragStart(e.clientX)}
178
- onTouchStart={(e) => handleDragStart(e.touches[0].clientX)}
179
- >
180
- {icon}
181
- </span>
182
- </span>
183
- </div>
184
- {label && (
185
- <label
186
- {...slotProps.label}
187
- htmlFor={props.id || label}
188
- className={cn(slotProps.label?.className, styles.label)}
189
- >
190
- {label}
191
- </label>
192
- )}
193
- </div>
194
- );
195
- }
@@ -1,65 +0,0 @@
1
- .root {
2
- --input-border: var(--color-outline);
3
- --input-color: var(--color-on-surface);
4
- --input-fs: var(--fs-body2);
5
- --input-background: var(--color-background-faint);
6
- --input-focus-background: var(--color-background);
7
-
8
- display: flex;
9
- flex-direction: column;
10
- gap: var(--spacing-gap);
11
- font-size: var(--input-fs);
12
- &.fullWidth {
13
- width: 100%;
14
- }
15
- &:has(.inputWrapper > .input:focus) {
16
- & > .inputWrapper {
17
- outline: none;
18
- background: var(--input-focus-background);
19
- }
20
- .label {
21
- color: var(--input-color);
22
- }
23
- }
24
- &:has(.inputWrapper > .input:disabled) {
25
- opacity: 0.5;
26
- }
27
- }
28
- .inputWrapper {
29
- position: relative;
30
- display: flex;
31
- border-radius: var(--shape-br-sm);
32
- outline: 1px solid var(--input-border);
33
- background: var(--input-background);
34
- }
35
- .label {
36
- font-size: 0.9em;
37
- color: var(--color-on-background-faint);
38
- margin-left: var(--spacing-gap);
39
- }
40
- .input {
41
- flex: 1 1 100%;
42
- font-family: var(--font-p);
43
- padding: calc(1.618 * var(--spacing-gap-2));
44
- font-size: inherit;
45
- border: none;
46
- background: none;
47
- color: var(--input-color);
48
- &:focus {
49
- outline: none;
50
- }
51
- &.disableResize {
52
- resize: none;
53
- }
54
- }
55
-
56
- .errored {
57
- --input-border: var(--color-error);
58
- --input-color: var(--color-error);
59
- & > .inputWrapper {
60
- outline: 1px solid var(--input-border);
61
- }
62
- & > .label {
63
- color: var(--input-color);
64
- }
65
- }
@@ -1,97 +0,0 @@
1
- "use client";
2
-
3
- import { cn } from "@studiocubics/utils";
4
- import { useEffect, useState, type ComponentProps } from "react";
5
- import {
6
- eventWithRipple,
7
- useRipple,
8
- type UseRippleProps,
9
- } from "../../Misc/Ripple/Ripple";
10
- import styles from "./TextAreaInput.module.css";
11
- import { InputErrors, type InputErrorsProps } from "../../Display/_index";
12
-
13
- export interface TextAreaInputProps extends ComponentProps<"textarea"> {
14
- label?: string;
15
- error?: string | string[];
16
- disableResize?: boolean;
17
- fullWidth?: boolean;
18
- slotProps?: {
19
- ripple?: UseRippleProps;
20
- root?: ComponentProps<"div">;
21
- inputWrapper?: ComponentProps<"div">;
22
- label?: ComponentProps<"label">;
23
- error?: InputErrorsProps;
24
- };
25
- }
26
-
27
- export function TextAreaInput(props: TextAreaInputProps) {
28
- const {
29
- label,
30
- error,
31
- fullWidth,
32
- disableResize = false,
33
- onTouchStart,
34
- onClick,
35
- onBlur,
36
- slotProps = {},
37
- className: inputClass,
38
- ...inputProps
39
- } = props;
40
-
41
- const { rippleElements, createRipple } = useRipple(slotProps.ripple);
42
- const [isErrored, setIsErrored] = useState(error && !!error.length);
43
-
44
- useEffect(() => {
45
- setIsErrored(error && !!error.length);
46
- }, [error]);
47
-
48
- return (
49
- <div
50
- {...slotProps.root}
51
- className={cn(
52
- slotProps.root?.className,
53
- styles.root,
54
- fullWidth ? styles.fullWidth : undefined,
55
- isErrored ? styles.errored : undefined
56
- )}
57
- >
58
- {label && (
59
- <label
60
- {...slotProps.label}
61
- htmlFor={props.id || label}
62
- className={cn(slotProps.label?.className, styles.label)}
63
- >
64
- {label}
65
- </label>
66
- )}
67
- <div
68
- {...slotProps.inputWrapper}
69
- className={cn(slotProps.inputWrapper?.className, styles.inputWrapper)}
70
- >
71
- <textarea
72
- className={cn(
73
- inputClass,
74
- styles.input,
75
- disableResize ? styles.disableResize : undefined
76
- )}
77
- onTouchStart={eventWithRipple(createRipple, onTouchStart)}
78
- onClick={eventWithRipple(createRipple, onClick)}
79
- onBlur={(e) => {
80
- setIsErrored(false);
81
- onBlur?.(e);
82
- }}
83
- id={label}
84
- {...inputProps}
85
- />
86
- {rippleElements}
87
- </div>
88
- {isErrored && (
89
- <InputErrors
90
- {...slotProps.error}
91
- className={cn(slotProps.error?.className, styles.errorText)}
92
- error={error}
93
- />
94
- )}
95
- </div>
96
- );
97
- }
@@ -1,112 +0,0 @@
1
- .root {
2
- --input-border: var(--color-outline);
3
- --input-color: var(--color-on-surface);
4
- --input-fs: var(--fs-body2);
5
- --input-background: var(--color-background-alpha);
6
- --input-focus-background: var(--color-background);
7
-
8
- display: flex;
9
- flex-direction: column;
10
- gap: var(--spacing-gap);
11
- font-size: var(--input-fs);
12
- &.fullWidth {
13
- width: 100%;
14
- }
15
- &:has(.inputWrapper > .input:focus) {
16
- & > .inputWrapper {
17
- outline: none;
18
- background: var(--input-focus-background);
19
- }
20
- .label {
21
- color: var(--input-color);
22
- }
23
- }
24
- &:has(.inputWrapper > .input:disabled) {
25
- opacity: 0.5;
26
- }
27
- }
28
-
29
- .inputWrapper {
30
- position: relative;
31
- display: flex;
32
- border-radius: var(--shape-br-sm);
33
- outline: 1px solid var(--input-border);
34
- background: var(--input-background);
35
- }
36
- .label {
37
- color: var(--color-on-background-faint);
38
- margin-left: var(--spacing-gap);
39
- width: max-content;
40
- cursor: pointer;
41
- }
42
- .input {
43
- flex: 1 1 100%;
44
- font-family: var(--font-p);
45
- font-size: inherit;
46
- border: none;
47
- background: none;
48
- color: var(--input-color);
49
- &:focus {
50
- outline: none;
51
- }
52
- }
53
- .iconContainer {
54
- display: flex;
55
- justify-content: center;
56
- font-size: inherit;
57
- align-items: center;
58
- color: var(--color-on-background-faint);
59
- /* Start Icon */
60
- &:nth-of-type(1) {
61
- margin-left: var(--spacing-gap-2);
62
- &.disableGutters {
63
- margin-left: 0;
64
- }
65
- }
66
- /* End Icon */
67
- &:nth-of-type(2) {
68
- margin-right: var(--spacing-gap-2);
69
- &.disableGutters {
70
- margin-right: 0;
71
- }
72
- }
73
- }
74
-
75
- .errored {
76
- --input-border: var(--color-error);
77
- --input-color: var(--color-error);
78
- & > .inputWrapper {
79
- outline: 1px solid var(--input-border);
80
- & > .iconContainer {
81
- color: var(--input-color);
82
- }
83
- }
84
- & > .label {
85
- color: var(--input-color);
86
- }
87
- }
88
-
89
- .size_sm {
90
- .label {
91
- font-size: 0.8em;
92
- }
93
- .input {
94
- padding: var(--spacing-gap) calc(1.618 * var(--spacing-gap));
95
- }
96
- }
97
- .size_md {
98
- .label {
99
- font-size: 0.9em;
100
- }
101
- .input {
102
- padding: var(--spacing-gap-2) calc(1.618 * var(--spacing-gap-2));
103
- }
104
- }
105
- .size_lg {
106
- .label {
107
- font-size: 1em;
108
- }
109
- .input {
110
- padding: var(--spacing-gap-3) calc(1.618 * var(--spacing-gap-3));
111
- }
112
- }
@@ -1,142 +0,0 @@
1
- "use client";
2
-
3
- import { cn } from "@studiocubics/utils";
4
- import {
5
- useEffect,
6
- useState,
7
- type ComponentProps,
8
- type ReactNode,
9
- } from "react";
10
- import {
11
- eventWithRipple,
12
- useRipple,
13
- type UseRippleProps,
14
- } from "../../Misc/Ripple/Ripple";
15
- import styles from "./TextInput.module.css";
16
- import {
17
- InputErrors,
18
- type InputErrorsProps,
19
- } from "../../Display/InputErrors/InputErrors";
20
-
21
- export interface TextInputProps extends Omit<ComponentProps<"input">, "size"> {
22
- startIcon?: ReactNode;
23
- endIcon?: ReactNode;
24
- label?: string;
25
- error?: string | string[];
26
- fullWidth?: boolean;
27
- /**
28
- * Use inputSize for <input size="10"/>
29
- */
30
- size?: "sm" | "md" | "lg";
31
- inputSize?: ComponentProps<"input">["size"];
32
- disableEndIconGutters?: boolean;
33
- disableStartIconGutters?: boolean;
34
- slotProps?: {
35
- ripple?: UseRippleProps;
36
- startIcon?: ComponentProps<"span">;
37
- endIcon?: ComponentProps<"span">;
38
- root?: ComponentProps<"div">;
39
- inputWrapper?: ComponentProps<"div">;
40
- label?: ComponentProps<"label">;
41
- error?: InputErrorsProps;
42
- };
43
- }
44
-
45
- export function TextInput(props: TextInputProps) {
46
- const {
47
- startIcon,
48
- endIcon,
49
- label,
50
- error,
51
- fullWidth,
52
- disableEndIconGutters = false,
53
- disableStartIconGutters = false,
54
- size = "md",
55
- inputSize,
56
- onTouchStart,
57
- onClick,
58
- onBlur,
59
- slotProps = {},
60
- className: inputClass,
61
- ...inputProps
62
- } = props;
63
- const { rippleElements, createRipple } = useRipple(slotProps.ripple);
64
- const [isErrored, setIsErrored] = useState(error && !!error.length);
65
-
66
- useEffect(() => {
67
- setIsErrored(error && !!error.length);
68
- }, [error]);
69
-
70
- return (
71
- <div
72
- {...slotProps.root}
73
- className={cn(
74
- slotProps.root?.className,
75
- styles.root,
76
- styles[`size_${size}`],
77
- fullWidth ? styles.fullWidth : undefined,
78
- isErrored ? styles.errored : undefined
79
- )}
80
- >
81
- {label && (
82
- <label
83
- {...slotProps.label}
84
- htmlFor={props.id || label}
85
- className={cn(slotProps.label?.className, styles.label)}
86
- >
87
- {label}
88
- </label>
89
- )}
90
- <div
91
- {...slotProps.inputWrapper}
92
- className={cn(slotProps.inputWrapper?.className, styles.inputWrapper)}
93
- >
94
- {startIcon && (
95
- <span
96
- {...slotProps.startIcon}
97
- className={cn(
98
- styles.iconContainer,
99
- slotProps.startIcon?.className,
100
- disableStartIconGutters ? styles.disableGutters : undefined
101
- )}
102
- >
103
- {startIcon}
104
- </span>
105
- )}
106
- <input
107
- type="text"
108
- className={cn(inputClass, styles.input)}
109
- onTouchStart={eventWithRipple(createRipple, onTouchStart)}
110
- onClick={eventWithRipple(createRipple, onClick)}
111
- onBlur={(e) => {
112
- setIsErrored(false);
113
- onBlur?.(e);
114
- }}
115
- size={inputSize}
116
- id={label}
117
- {...inputProps}
118
- />
119
- {endIcon && (
120
- <span
121
- {...slotProps.endIcon}
122
- className={cn(
123
- styles.iconContainer,
124
- slotProps.endIcon?.className,
125
- disableEndIconGutters ? styles.disableGutters : undefined
126
- )}
127
- >
128
- {endIcon}
129
- </span>
130
- )}
131
- {rippleElements}
132
- </div>
133
- {isErrored && (
134
- <InputErrors
135
- {...slotProps.error}
136
- className={cn(slotProps.error?.className, styles.errorText)}
137
- error={error}
138
- />
139
- )}
140
- </div>
141
- );
142
- }
@@ -1,80 +0,0 @@
1
- import { useAnchorElement } from "@studiocubics/hooks";
2
- import {
3
- List,
4
- type ListItemProps,
5
- ListItem,
6
- } from "../../Display/List/List";
7
- import { type PopoverProps, Popover } from "../../Layout/Popover/Popover";
8
- import type { MouseEvent, ReactNode } from "react";
9
-
10
- export type ThemeObject = Record<
11
- "dark" | "light" | "system",
12
- {
13
- text?: string;
14
- icon?: ReactNode;
15
- onClick?: (e: MouseEvent<HTMLElement>) => void;
16
- }
17
- >;
18
-
19
- export interface ThemeToggleListItemProps
20
- extends Omit<ListItemProps, "slotProps"> {
21
- themeObject?: Partial<ThemeObject>;
22
- currentTheme: keyof ThemeObject;
23
- slotProps?: ListItemProps["slotProps"] & {
24
- popover?: PopoverProps;
25
- };
26
- }
27
-
28
- export function ThemeToggleListItem(props: ThemeToggleListItemProps) {
29
- const { currentTheme, themeObject = {}, slotProps = {}, ...rest } = props;
30
- const { open, anchorEl, handleClick, handleClose } = useAnchorElement();
31
- const { popover = {}, ...listItemSlotProps } = slotProps;
32
- const sanitisedThemeObject: ThemeObject = {
33
- dark: {
34
- text: "Dark Mode",
35
- icon: <>🌚</>,
36
- onClick: (e) => {
37
- if (themeObject.dark?.onClick) themeObject.dark?.onClick(e);
38
- if (open) handleClose();
39
- else handleClick(e);
40
- },
41
- ...themeObject.dark,
42
- },
43
- light: { text: "Light Mode", icon: <>🌞</>, ...themeObject.light },
44
- system: { text: "System Color", icon: <>💻</>, ...themeObject.system },
45
- };
46
-
47
- return (
48
- <>
49
- <ListItem
50
- slotProps={listItemSlotProps}
51
- startIcon={sanitisedThemeObject[currentTheme].icon}
52
- onClick={open ? handleClose : handleClick}
53
- {...rest}
54
- >
55
- {sanitisedThemeObject[currentTheme].text}
56
- </ListItem>
57
- <Popover
58
- open={open}
59
- anchorEl={anchorEl}
60
- onClose={handleClose}
61
- anchorPosition={{ vertical: "top", horizontal: "right" }}
62
- transformOrigin={{ vertical: "bottom", horizontal: "left" }}
63
- {...slotProps.popover}
64
- >
65
- <List className={"surfaceContainer"}>
66
- {Object.entries(sanitisedThemeObject).map(([key, value]) => (
67
- <ListItem
68
- selected={currentTheme == key}
69
- startIcon={value.icon}
70
- key={key}
71
- onClick={value.onClick}
72
- >
73
- {value.text}
74
- </ListItem>
75
- ))}
76
- </List>
77
- </Popover>
78
- </>
79
- );
80
- }
@@ -1 +0,0 @@
1
- export * from "./ThemeToggleListItem"
@@ -1,15 +0,0 @@
1
- .root[open] {
2
- background-color: var(--color-surface);
3
- width: 50%;
4
- max-height: 80%;
5
- max-width: 45rem;
6
- min-width: 350px;
7
- backdrop-filter: var(--backdrop-blur);
8
- margin: auto;
9
- border-radius: var(--shape-br-lg);
10
- overflow: hidden;
11
- padding: var(--spacing-gap-6);
12
- }
13
- .root::backdrop {
14
- backdrop-filter: var(--backdrop-blur);
15
- }