@blockle/blocks 0.19.1 → 0.20.0-alpha1.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 (406) hide show
  1. package/dist/components/accessibility/VisuallyHidden/VisuallyHidden.cjs +20 -0
  2. package/dist/components/accessibility/VisuallyHidden/VisuallyHidden.d.ts +5 -0
  3. package/dist/components/accessibility/VisuallyHidden/VisuallyHidden.js +20 -0
  4. package/dist/components/accessibility/VisuallyHidden/VisuallyHidden.spec.d.ts +1 -0
  5. package/dist/components/accessibility/VisuallyHidden/VisuallyHidden.stories.d.ts +6 -0
  6. package/dist/components/accessibility/VisuallyHidden/index.d.ts +1 -0
  7. package/dist/{styles/components/Accessibility → components/accessibility}/VisuallyHidden/visually-hidden.css.cjs +3 -2
  8. package/dist/components/accessibility/VisuallyHidden/visually-hidden.css.d.ts +1 -0
  9. package/dist/{styles/components/Accessibility/VisuallyHidden/visually-hidden.css.mjs → components/accessibility/VisuallyHidden/visually-hidden.css.js} +2 -2
  10. package/dist/components/display/Divider/Divider.cjs +26 -0
  11. package/dist/components/display/Divider/Divider.d.ts +7 -0
  12. package/dist/components/display/Divider/Divider.js +26 -0
  13. package/dist/components/display/Divider/Divider.spec.d.ts +1 -0
  14. package/dist/components/display/Divider/Divider.stories.d.ts +6 -0
  15. package/dist/{styles/components → components}/display/Divider/divider.css.cjs +4 -3
  16. package/dist/components/display/Divider/divider.css.d.ts +1 -0
  17. package/dist/{styles/components/display/Divider/divider.css.mjs → components/display/Divider/divider.css.js} +2 -2
  18. package/dist/components/display/Divider/index.d.ts +1 -0
  19. package/dist/components/feedback/Progress/Progress.cjs +54 -0
  20. package/dist/components/feedback/Progress/Progress.d.ts +16 -0
  21. package/dist/components/feedback/Progress/Progress.js +54 -0
  22. package/dist/components/feedback/Progress/Progress.stories.d.ts +5 -0
  23. package/dist/components/feedback/Progress/index.d.ts +1 -0
  24. package/dist/components/feedback/Spinner/Spinner.cjs +26 -0
  25. package/dist/components/feedback/Spinner/Spinner.d.ts +9 -0
  26. package/dist/components/feedback/Spinner/Spinner.js +26 -0
  27. package/dist/components/feedback/Spinner/Spinner.stories.d.ts +5 -0
  28. package/dist/components/feedback/Spinner/index.d.ts +1 -0
  29. package/dist/components/form/Button/Button.cjs +59 -0
  30. package/dist/{styles/components → components}/form/Button/Button.css.cjs +4 -3
  31. package/dist/components/form/Button/Button.css.d.ts +1 -0
  32. package/dist/{styles/components/form/Button/Button.css.mjs → components/form/Button/Button.css.js} +2 -2
  33. package/dist/components/form/Button/Button.d.ts +21 -0
  34. package/dist/{styles/components/form/Button/Button.mjs → components/form/Button/Button.js} +16 -14
  35. package/dist/components/form/Button/Button.spec.d.ts +1 -0
  36. package/dist/components/form/Button/Button.stories.d.ts +7 -0
  37. package/dist/components/form/Button/index.d.ts +1 -0
  38. package/dist/components/form/Checkbox/Checkbox.cjs +79 -0
  39. package/dist/components/form/Checkbox/Checkbox.d.ts +9 -0
  40. package/dist/components/form/Checkbox/Checkbox.js +79 -0
  41. package/dist/components/form/Checkbox/Checkbox.spec.d.ts +1 -0
  42. package/dist/components/form/Checkbox/Checkbox.stories.d.ts +5 -0
  43. package/dist/{styles/components → components}/form/Checkbox/checkbox.css.cjs +7 -6
  44. package/dist/components/form/Checkbox/checkbox.css.d.ts +3 -0
  45. package/dist/{styles/components/form/Checkbox/checkbox.css.mjs → components/form/Checkbox/checkbox.css.js} +4 -4
  46. package/dist/components/form/Checkbox/index.d.ts +1 -0
  47. package/dist/components/form/Input/Input.cjs +51 -0
  48. package/dist/components/form/Input/Input.d.ts +11 -0
  49. package/dist/components/form/Input/Input.js +51 -0
  50. package/dist/components/form/Input/Input.spec.d.ts +1 -0
  51. package/dist/components/form/Input/Input.stories.d.ts +5 -0
  52. package/dist/components/form/Input/index.d.ts +1 -0
  53. package/dist/{styles/components → components}/form/Input/input.css.cjs +4 -3
  54. package/dist/components/form/Input/input.css.d.ts +1 -0
  55. package/dist/{styles/components/form/Input/input.css.mjs → components/form/Input/input.css.js} +2 -2
  56. package/dist/components/form/Label/Label.cjs +30 -0
  57. package/dist/components/form/Label/Label.d.ts +18 -0
  58. package/dist/components/form/Label/Label.js +30 -0
  59. package/dist/components/form/Label/Label.spec.d.ts +1 -0
  60. package/dist/components/form/Label/Label.stories.d.ts +6 -0
  61. package/dist/components/form/Label/index.d.ts +1 -0
  62. package/dist/components/form/Radio/Radio.cjs +48 -0
  63. package/dist/components/form/Radio/Radio.d.ts +8 -0
  64. package/dist/components/form/Radio/Radio.js +48 -0
  65. package/dist/components/form/Radio/Radio.spec.d.ts +1 -0
  66. package/dist/components/form/Radio/Radio.stories.d.ts +6 -0
  67. package/dist/components/form/Radio/RadioGroup.d.ts +8 -0
  68. package/dist/components/form/Radio/index.d.ts +2 -0
  69. package/dist/{styles/components → components}/form/Radio/radio.css.cjs +7 -6
  70. package/dist/components/form/Radio/radio.css.d.ts +3 -0
  71. package/dist/{styles/components/form/Radio/radio.css.mjs → components/form/Radio/radio.css.js} +4 -4
  72. package/dist/components/form/Select/Select.cjs +65 -0
  73. package/dist/components/form/Select/Select.d.ts +10 -0
  74. package/dist/{styles/components/form/Select/Select.mjs → components/form/Select/Select.js} +24 -7
  75. package/dist/components/form/Select/Select.stories.d.ts +5 -0
  76. package/dist/components/form/Select/index.d.ts +1 -0
  77. package/dist/{styles/components → components}/form/Select/select.css.cjs +8 -7
  78. package/dist/components/form/Select/select.css.d.ts +3 -0
  79. package/dist/{styles/components/form/Select/select.css.mjs → components/form/Select/select.css.js} +4 -4
  80. package/dist/components/form/Slider/Slider.cjs +141 -0
  81. package/dist/components/form/Slider/Slider.d.ts +20 -0
  82. package/dist/components/form/Slider/Slider.js +141 -0
  83. package/dist/components/form/Slider/Slider.spec.d.ts +1 -0
  84. package/dist/components/form/Slider/Slider.stories.d.ts +6 -0
  85. package/dist/components/form/Slider/index.d.ts +1 -0
  86. package/dist/{styles/components → components}/form/Slider/slider.css.cjs +12 -11
  87. package/dist/components/form/Slider/slider.css.d.ts +5 -0
  88. package/dist/{styles/components/form/Slider/slider.css.mjs → components/form/Slider/slider.css.js} +6 -6
  89. package/dist/components/form/Slider/usePointerProgress.cjs +47 -0
  90. package/dist/components/form/Slider/usePointerProgress.d.ts +11 -0
  91. package/dist/components/form/Slider/usePointerProgress.js +47 -0
  92. package/dist/{styles/components → components}/form/Switch/Switch.cjs +12 -8
  93. package/dist/components/form/Switch/Switch.d.ts +6 -0
  94. package/dist/{styles/components/form/Switch/Switch.mjs → components/form/Switch/Switch.js} +9 -6
  95. package/dist/components/form/Switch/Switch.stories.d.ts +5 -0
  96. package/dist/components/form/Switch/index.d.ts +1 -0
  97. package/dist/{styles/components → components}/form/Switch/switch.css.cjs +6 -5
  98. package/dist/components/form/Switch/switch.css.d.ts +2 -0
  99. package/dist/{styles/components/form/Switch/switch.css.mjs → components/form/Switch/switch.css.js} +3 -3
  100. package/dist/components/layout/Box/Box.cjs +28 -0
  101. package/dist/components/layout/Box/Box.d.ts +11 -0
  102. package/dist/components/layout/Box/Box.js +28 -0
  103. package/dist/components/layout/Box/Box.spec.d.ts +1 -0
  104. package/dist/components/layout/Box/Box.stories.d.ts +6 -0
  105. package/dist/components/layout/Box/index.d.ts +1 -0
  106. package/dist/components/layout/Inline/Inline.cjs +30 -0
  107. package/dist/components/layout/Inline/Inline.d.ts +13 -0
  108. package/dist/components/layout/Inline/Inline.js +30 -0
  109. package/dist/components/layout/Inline/Inline.stories.d.ts +6 -0
  110. package/dist/components/layout/Inline/index.d.ts +1 -0
  111. package/dist/components/layout/Stack/Stack.cjs +30 -0
  112. package/dist/components/layout/Stack/Stack.d.ts +17 -0
  113. package/dist/components/layout/Stack/Stack.js +30 -0
  114. package/dist/components/layout/Stack/Stack.stories.d.ts +6 -0
  115. package/dist/components/layout/Stack/index.d.ts +1 -0
  116. package/dist/components/navigation/Link/Link.cjs +32 -0
  117. package/dist/components/navigation/Link/Link.d.ts +11 -0
  118. package/dist/components/navigation/Link/Link.js +32 -0
  119. package/dist/components/navigation/Link/Link.stories.d.ts +6 -0
  120. package/dist/components/navigation/Link/index.d.ts +1 -0
  121. package/dist/components/other/BlocksProvider/BlocksProvider.cjs +38 -0
  122. package/dist/components/other/BlocksProvider/BlocksProvider.d.ts +8 -0
  123. package/dist/{styles/components/other/BlocksProvider/BlocksProvider.mjs → components/other/BlocksProvider/BlocksProvider.js} +12 -6
  124. package/dist/components/other/BlocksProvider/context.cjs +6 -0
  125. package/dist/components/other/BlocksProvider/context.d.ts +4 -0
  126. package/dist/components/other/BlocksProvider/context.js +6 -0
  127. package/dist/components/other/BlocksProvider/index.d.ts +2 -0
  128. package/dist/components/other/Portal/Portal.cjs +8 -0
  129. package/dist/components/other/Portal/Portal.d.ts +5 -0
  130. package/dist/components/other/Portal/Portal.js +8 -0
  131. package/dist/components/other/Portal/index.d.ts +1 -0
  132. package/dist/components/overlay/Dialog/Dialog.cjs +79 -0
  133. package/dist/components/overlay/Dialog/Dialog.d.ts +10 -0
  134. package/dist/components/overlay/Dialog/Dialog.js +79 -0
  135. package/dist/components/overlay/Dialog/Dialog.stories.d.ts +7 -0
  136. package/dist/{styles/components → components}/overlay/Dialog/dialog.css.cjs +4 -3
  137. package/dist/components/overlay/Dialog/dialog.css.d.ts +1 -0
  138. package/dist/{styles/components/overlay/Dialog/dialog.css.mjs → components/overlay/Dialog/dialog.css.js} +2 -2
  139. package/dist/components/overlay/Dialog/dialogHelper.cjs +22 -0
  140. package/dist/components/overlay/Dialog/dialogHelper.d.ts +6 -0
  141. package/dist/components/overlay/Dialog/dialogHelper.js +22 -0
  142. package/dist/components/overlay/Dialog/index.d.ts +1 -0
  143. package/dist/components/overlay/Popover/Popover.cjs +113 -0
  144. package/dist/components/overlay/Popover/Popover.d.ts +12 -0
  145. package/dist/components/overlay/Popover/Popover.js +113 -0
  146. package/dist/components/overlay/Popover/Popover.stories.d.ts +5 -0
  147. package/dist/components/overlay/Popover/popover-utils.cjs +62 -0
  148. package/dist/components/overlay/Popover/popover-utils.d.ts +2 -0
  149. package/dist/components/overlay/Popover/popover-utils.js +62 -0
  150. package/dist/components/overlay/Tooltip/Tooltip.cjs +73 -0
  151. package/dist/components/overlay/Tooltip/Tooltip.d.ts +11 -0
  152. package/dist/components/overlay/Tooltip/Tooltip.js +73 -0
  153. package/dist/components/overlay/Tooltip/Tooltip.stories.d.ts +5 -0
  154. package/dist/components/overlay/Tooltip/index.d.ts +1 -0
  155. package/dist/components/typography/Heading/Heading.cjs +24 -0
  156. package/dist/components/typography/Heading/Heading.d.ts +8 -0
  157. package/dist/components/typography/Heading/Heading.js +24 -0
  158. package/dist/{styles/components → components}/typography/Heading/heading.css.cjs +4 -3
  159. package/dist/components/typography/Heading/heading.css.d.ts +1 -0
  160. package/dist/{styles/components/typography/Heading/heading.css.mjs → components/typography/Heading/heading.css.js} +2 -2
  161. package/dist/components/typography/Heading/heading.stories.d.ts +12 -0
  162. package/dist/components/typography/Heading/index.d.ts +1 -0
  163. package/dist/components/typography/Text/Text.cjs +21 -0
  164. package/dist/components/typography/Text/Text.d.ts +12 -0
  165. package/dist/{styles/components/typography/Text/Text.mjs → components/typography/Text/Text.js} +3 -3
  166. package/dist/components/typography/Text/Text.stories.d.ts +5 -0
  167. package/dist/components/typography/Text/index.d.ts +1 -0
  168. package/dist/{styles/components → components}/typography/Text/text.css.cjs +4 -3
  169. package/dist/components/typography/Text/text.css.d.ts +1 -0
  170. package/dist/{styles/components/typography/Text/text.css.mjs → components/typography/Text/text.css.js} +2 -2
  171. package/dist/entries/reset.d.ts +0 -0
  172. package/dist/entries/themes/momotaro.d.ts +1 -0
  173. package/dist/hooks/useClickOutside/useClickOutside.cjs +24 -0
  174. package/dist/hooks/useClickOutside/useClickOutside.d.ts +6 -0
  175. package/dist/hooks/useClickOutside/useClickOutside.js +24 -0
  176. package/dist/hooks/useControlledValue/useControlledValue.cjs +33 -0
  177. package/dist/hooks/useControlledValue/useControlledValue.d.ts +8 -0
  178. package/dist/hooks/useControlledValue/useControlledValue.js +33 -0
  179. package/dist/hooks/useFocusLock/index.d.ts +1 -0
  180. package/dist/hooks/useFocusLock/useFocusLock.d.ts +6 -0
  181. package/dist/hooks/useIsomorphicLayoutEffect/index.d.ts +1 -0
  182. package/dist/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.cjs +6 -0
  183. package/dist/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.d.ts +5 -0
  184. package/dist/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.js +6 -0
  185. package/dist/hooks/useKeyboard/index.d.ts +1 -0
  186. package/dist/hooks/useKeyboard/useKeyboard.cjs +21 -0
  187. package/dist/hooks/useKeyboard/useKeyboard.d.ts +6 -0
  188. package/dist/hooks/useKeyboard/useKeyboard.js +21 -0
  189. package/dist/hooks/useLayer/index.d.ts +1 -0
  190. package/dist/hooks/useLayer/useLayer.cjs +27 -0
  191. package/dist/hooks/useLayer/useLayer.d.ts +1 -0
  192. package/dist/hooks/useLayer/useLayer.js +27 -0
  193. package/dist/hooks/usePreventBodyScroll/index.d.ts +1 -0
  194. package/dist/hooks/usePreventBodyScroll/usePreventBodyScroll.cjs +30 -0
  195. package/dist/hooks/usePreventBodyScroll/usePreventBodyScroll.d.ts +1 -0
  196. package/dist/hooks/usePreventBodyScroll/usePreventBodyScroll.js +30 -0
  197. package/dist/hooks/useRestoreFocus/index.d.ts +1 -0
  198. package/dist/hooks/useRestoreFocus/useRestoreFocus.cjs +19 -0
  199. package/dist/hooks/useRestoreFocus/useRestoreFocus.d.ts +4 -0
  200. package/dist/hooks/useRestoreFocus/useRestoreFocus.js +19 -0
  201. package/dist/hooks/useRootAriaHidden/index.d.ts +1 -0
  202. package/dist/hooks/useRootAriaHidden/useRootAriaHidden.cjs +12 -0
  203. package/dist/hooks/useRootAriaHidden/useRootAriaHidden.d.ts +7 -0
  204. package/dist/hooks/useRootAriaHidden/useRootAriaHidden.js +12 -0
  205. package/dist/hooks/useVisibilityState/index.d.ts +1 -0
  206. package/dist/hooks/useVisibilityState/useVisibilityState.cjs +17 -0
  207. package/dist/hooks/useVisibilityState/useVisibilityState.d.ts +3 -0
  208. package/dist/hooks/useVisibilityState/useVisibilityState.js +17 -0
  209. package/dist/index.cjs +71 -444
  210. package/dist/index.d.ts +36 -1
  211. package/dist/index.js +73 -0
  212. package/dist/lib/asChildRenderer/createAsChildTemplate.cjs +73 -0
  213. package/dist/lib/asChildRenderer/createAsChildTemplate.d.ts +34 -0
  214. package/dist/lib/asChildRenderer/createAsChildTemplate.js +73 -0
  215. package/dist/lib/asChildRenderer/createAsChildTemplate.spec.d.ts +1 -0
  216. package/dist/lib/css/atoms/atomTypes.d.ts +37 -0
  217. package/dist/{styles/lib → lib}/css/atoms/atomicProperties.cjs +29 -22
  218. package/dist/lib/css/atoms/atomicProperties.d.ts +286 -0
  219. package/dist/{styles/lib/css/atoms/atomicProperties.mjs → lib/css/atoms/atomicProperties.js} +8 -2
  220. package/dist/lib/css/atoms/atoms.d.ts +1 -0
  221. package/dist/{styles/lib → lib}/css/atoms/breakpoints.cjs +2 -0
  222. package/dist/lib/css/atoms/breakpoints.d.ts +9 -0
  223. package/dist/{styles/lib/css/atoms/breakpoints.mjs → lib/css/atoms/breakpoints.js} +1 -0
  224. package/dist/lib/css/atoms/index.d.ts +2 -0
  225. package/dist/lib/css/atoms/sprinkles.css.cjs +52 -0
  226. package/dist/lib/css/atoms/sprinkles.css.d.ts +233 -0
  227. package/dist/{styles/lib/css/atoms/sprinkles.css.mjs → lib/css/atoms/sprinkles.css.js} +18 -5
  228. package/dist/lib/css/flexbox/flexbox.cjs +17 -0
  229. package/dist/lib/css/flexbox/flexbox.d.ts +15 -0
  230. package/dist/lib/css/flexbox/flexbox.js +17 -0
  231. package/dist/{styles/lib → lib}/css/layers/layers.css.cjs +1 -0
  232. package/dist/lib/css/layers/layers.css.d.ts +1 -0
  233. package/dist/lib/css/reset/reset.css.d.ts +1 -0
  234. package/dist/{styles/lib → lib}/css/style/style.cjs +4 -3
  235. package/dist/lib/css/style/style.d.ts +12 -0
  236. package/dist/{styles/lib/css/style/style.mjs → lib/css/style/style.js} +1 -1
  237. package/dist/{styles/lib → lib}/css/utils/cssUtils.cjs +1 -0
  238. package/dist/lib/css/utils/cssUtils.d.ts +1 -0
  239. package/dist/lib/react/mergeProps.cjs +43 -0
  240. package/dist/lib/react/mergeProps.d.ts +4 -0
  241. package/dist/lib/react/mergeProps.js +43 -0
  242. package/dist/lib/react/refs.cjs +17 -0
  243. package/dist/lib/react/refs.d.ts +3 -0
  244. package/dist/lib/react/refs.js +17 -0
  245. package/dist/lib/theme/componentThemes.d.ts +134 -0
  246. package/dist/{styles/lib → lib}/theme/makeComponentTheme.cjs +1 -0
  247. package/dist/lib/theme/makeComponentTheme.d.ts +49 -0
  248. package/dist/lib/theme/makeTheme.cjs +13 -0
  249. package/dist/lib/theme/makeTheme.d.ts +14 -0
  250. package/dist/{styles/lib/theme/makeTheme.mjs → lib/theme/makeTheme.js} +2 -2
  251. package/dist/{styles/lib → lib}/theme/makeVanillaTheme.cjs +1 -0
  252. package/dist/lib/theme/makeVanillaTheme.d.ts +16 -0
  253. package/dist/lib/theme/store/theme.cjs +93 -0
  254. package/dist/lib/theme/store/theme.d.ts +13 -0
  255. package/dist/lib/theme/store/theme.js +93 -0
  256. package/dist/{styles/lib → lib}/theme/tokens.cjs +1 -0
  257. package/dist/lib/theme/tokens.d.ts +2 -0
  258. package/dist/lib/theme/tokensType.d.ts +33 -0
  259. package/dist/lib/theme/vars.css.cjs +10 -0
  260. package/dist/lib/theme/vars.css.d.ts +75 -0
  261. package/dist/{styles/lib/theme/vars.css.mjs → lib/theme/vars.css.js} +2 -2
  262. package/dist/{styles/lib → lib}/utils/atom-props.cjs +3 -2
  263. package/dist/lib/utils/atom-props.d.ts +4 -0
  264. package/dist/{styles/lib/utils/atom-props.mjs → lib/utils/atom-props.js} +1 -1
  265. package/dist/lib/utils/classnames.cjs +7 -0
  266. package/dist/lib/utils/classnames.d.ts +3 -0
  267. package/dist/lib/utils/classnames.js +7 -0
  268. package/dist/lib/utils/dom-focus.d.ts +2 -0
  269. package/dist/lib/utils/dom.cjs +13 -0
  270. package/dist/lib/utils/dom.d.ts +4 -0
  271. package/dist/lib/utils/dom.js +13 -0
  272. package/dist/lib/utils/helpers.d.ts +9 -0
  273. package/dist/lib/utils/math.cjs +13 -0
  274. package/dist/lib/utils/math.d.ts +2 -0
  275. package/dist/lib/utils/math.js +13 -0
  276. package/dist/lib/utils/utils.d.ts +3 -0
  277. package/dist/reset.cjs +2 -2
  278. package/dist/reset.js +2 -0
  279. package/dist/themes/momotaro/components/button.css.cjs +110 -0
  280. package/dist/themes/momotaro/components/button.css.d.ts +1 -0
  281. package/dist/{styles/themes/momotaro/components/button.css.mjs → themes/momotaro/components/button.css.js} +45 -39
  282. package/dist/themes/momotaro/components/checkbox.css.cjs +64 -0
  283. package/dist/themes/momotaro/components/checkbox.css.d.ts +1 -0
  284. package/dist/themes/momotaro/components/checkbox.css.js +64 -0
  285. package/dist/themes/momotaro/components/dialog.css.cjs +82 -0
  286. package/dist/themes/momotaro/components/dialog.css.d.ts +1 -0
  287. package/dist/themes/momotaro/components/dialog.css.js +82 -0
  288. package/dist/{styles/themes → themes}/momotaro/components/divider.css.cjs +4 -3
  289. package/dist/themes/momotaro/components/divider.css.d.ts +1 -0
  290. package/dist/{styles/themes/momotaro/components/divider.css.mjs → themes/momotaro/components/divider.css.js} +2 -2
  291. package/dist/{styles/themes → themes}/momotaro/components/helpers.css.cjs +13 -9
  292. package/dist/themes/momotaro/components/helpers.css.d.ts +8 -0
  293. package/dist/{styles/themes/momotaro/components/helpers.css.mjs → themes/momotaro/components/helpers.css.js} +10 -7
  294. package/dist/themes/momotaro/components/index.cjs +35 -0
  295. package/dist/themes/momotaro/components/index.d.ts +2 -0
  296. package/dist/themes/momotaro/components/index.js +35 -0
  297. package/dist/themes/momotaro/components/input.css.cjs +48 -0
  298. package/dist/themes/momotaro/components/input.css.d.ts +1 -0
  299. package/dist/themes/momotaro/components/input.css.js +48 -0
  300. package/dist/themes/momotaro/components/label.css.cjs +34 -0
  301. package/dist/themes/momotaro/components/label.css.d.ts +1 -0
  302. package/dist/{styles/themes/momotaro/components/label.css.mjs → themes/momotaro/components/label.css.js} +7 -7
  303. package/dist/themes/momotaro/components/link.css.cjs +57 -0
  304. package/dist/themes/momotaro/components/link.css.d.ts +1 -0
  305. package/dist/{styles/themes/momotaro/components/link.css.mjs → themes/momotaro/components/link.css.js} +27 -24
  306. package/dist/{styles/themes → themes}/momotaro/components/popover.css.cjs +5 -4
  307. package/dist/themes/momotaro/components/popover.css.d.ts +1 -0
  308. package/dist/{styles/themes/momotaro/components/popover.css.mjs → themes/momotaro/components/popover.css.js} +2 -2
  309. package/dist/{styles/themes → themes}/momotaro/components/progress.css.cjs +22 -18
  310. package/dist/themes/momotaro/components/progress.css.d.ts +1 -0
  311. package/dist/{styles/themes/momotaro/components/progress.css.mjs → themes/momotaro/components/progress.css.js} +18 -15
  312. package/dist/themes/momotaro/components/radio.css.cjs +65 -0
  313. package/dist/themes/momotaro/components/radio.css.d.ts +1 -0
  314. package/dist/{styles/themes/momotaro/components/radio.css.mjs → themes/momotaro/components/radio.css.js} +31 -27
  315. package/dist/themes/momotaro/components/select.css.cjs +48 -0
  316. package/dist/themes/momotaro/components/select.css.d.ts +1 -0
  317. package/dist/themes/momotaro/components/select.css.js +48 -0
  318. package/dist/themes/momotaro/components/slider.css.cjs +93 -0
  319. package/dist/themes/momotaro/components/slider.css.d.ts +1 -0
  320. package/dist/{styles/themes/momotaro/components/slider.css.mjs → themes/momotaro/components/slider.css.js} +31 -28
  321. package/dist/{styles/themes → themes}/momotaro/components/spinner.css.cjs +8 -7
  322. package/dist/themes/momotaro/components/spinner.css.d.ts +1 -0
  323. package/dist/{styles/themes/momotaro/components/spinner.css.mjs → themes/momotaro/components/spinner.css.js} +6 -6
  324. package/dist/themes/momotaro/components/switch.css.cjs +62 -0
  325. package/dist/themes/momotaro/components/switch.css.d.ts +1 -0
  326. package/dist/{styles/themes/momotaro/components/switch.css.mjs → themes/momotaro/components/switch.css.js} +31 -28
  327. package/dist/{styles/themes → themes}/momotaro/components/tooltip.css.cjs +7 -6
  328. package/dist/themes/momotaro/components/tooltip.css.d.ts +1 -0
  329. package/dist/{styles/themes/momotaro/components/tooltip.css.mjs → themes/momotaro/components/tooltip.css.js} +2 -2
  330. package/dist/{styles/themes → themes}/momotaro/components/transitions.cjs +1 -0
  331. package/dist/themes/momotaro/components/transitions.d.ts +1 -0
  332. package/dist/themes/momotaro/index.d.ts +1 -0
  333. package/dist/themes/momotaro/momotaro.css.cjs +14 -0
  334. package/dist/themes/momotaro/momotaro.css.d.ts +1 -0
  335. package/dist/{styles/themes/momotaro/momotaro.css.mjs → themes/momotaro/momotaro.css.js} +3 -3
  336. package/dist/{styles/themes → themes}/momotaro/tokens.css.cjs +12 -11
  337. package/dist/themes/momotaro/tokens.css.d.ts +2 -0
  338. package/dist/{styles/themes/momotaro/tokens.css.mjs → themes/momotaro/tokens.css.js} +1 -1
  339. package/dist/themes/momotaro.cjs +2 -2
  340. package/dist/themes/momotaro.js +4 -0
  341. package/package.json +17 -28
  342. package/dist/index.d.mts +0 -1
  343. package/dist/index.mjs +0 -451
  344. package/dist/momotaro.chunk.d.ts +0 -922
  345. package/dist/reset.d.mts +0 -2
  346. package/dist/reset.d.ts +0 -2
  347. package/dist/reset.mjs +0 -2
  348. package/dist/styles/components/Accessibility/VisuallyHidden/VisuallyHidden.cjs +0 -16
  349. package/dist/styles/components/Accessibility/VisuallyHidden/VisuallyHidden.mjs +0 -17
  350. package/dist/styles/components/display/Divider/Divider.cjs +0 -239
  351. package/dist/styles/components/display/Divider/Divider.mjs +0 -240
  352. package/dist/styles/components/form/Button/Button.cjs +0 -56
  353. package/dist/styles/components/form/Checkbox/Checkbox.cjs +0 -84
  354. package/dist/styles/components/form/Checkbox/Checkbox.mjs +0 -85
  355. package/dist/styles/components/form/Input/Input.cjs +0 -37
  356. package/dist/styles/components/form/Input/Input.mjs +0 -38
  357. package/dist/styles/components/form/Radio/Radio.cjs +0 -23
  358. package/dist/styles/components/form/Radio/Radio.mjs +0 -24
  359. package/dist/styles/components/form/Select/Select.cjs +0 -47
  360. package/dist/styles/components/form/Slider/Slider.cjs +0 -205
  361. package/dist/styles/components/form/Slider/Slider.mjs +0 -206
  362. package/dist/styles/components/other/BlocksProvider/BlocksProvider.cjs +0 -31
  363. package/dist/styles/components/overlay/Dialog/Dialog.cjs +0 -172
  364. package/dist/styles/components/overlay/Dialog/Dialog.mjs +0 -173
  365. package/dist/styles/components/typography/Heading/Heading.cjs +0 -15
  366. package/dist/styles/components/typography/Heading/Heading.mjs +0 -16
  367. package/dist/styles/components/typography/Text/Text.cjs +0 -20
  368. package/dist/styles/lib/css/atoms/atoms.cjs +0 -2
  369. package/dist/styles/lib/css/atoms/atoms.mjs +0 -1
  370. package/dist/styles/lib/css/atoms/index.cjs +0 -2
  371. package/dist/styles/lib/css/atoms/index.mjs +0 -1
  372. package/dist/styles/lib/css/atoms/sprinkles.css.cjs +0 -38
  373. package/dist/styles/lib/theme/makeTheme.cjs +0 -12
  374. package/dist/styles/lib/theme/vars.css.cjs +0 -9
  375. package/dist/styles/themes/momotaro/components/button.css.cjs +0 -103
  376. package/dist/styles/themes/momotaro/components/checkbox.css.cjs +0 -59
  377. package/dist/styles/themes/momotaro/components/checkbox.css.mjs +0 -60
  378. package/dist/styles/themes/momotaro/components/dialog.css.cjs +0 -78
  379. package/dist/styles/themes/momotaro/components/dialog.css.mjs +0 -79
  380. package/dist/styles/themes/momotaro/components/index.cjs +0 -34
  381. package/dist/styles/themes/momotaro/components/index.mjs +0 -35
  382. package/dist/styles/themes/momotaro/components/input.css.cjs +0 -41
  383. package/dist/styles/themes/momotaro/components/input.css.mjs +0 -42
  384. package/dist/styles/themes/momotaro/components/label.css.cjs +0 -33
  385. package/dist/styles/themes/momotaro/components/link.css.cjs +0 -53
  386. package/dist/styles/themes/momotaro/components/radio.css.cjs +0 -60
  387. package/dist/styles/themes/momotaro/components/select.css.cjs +0 -44
  388. package/dist/styles/themes/momotaro/components/select.css.mjs +0 -45
  389. package/dist/styles/themes/momotaro/components/slider.css.cjs +0 -89
  390. package/dist/styles/themes/momotaro/components/switch.css.cjs +0 -58
  391. package/dist/styles/themes/momotaro/index.cjs +0 -2
  392. package/dist/styles/themes/momotaro/index.mjs +0 -1
  393. package/dist/styles/themes/momotaro/momotaro.css.cjs +0 -13
  394. package/dist/themes/momotaro.d.mts +0 -1
  395. package/dist/themes/momotaro.d.ts +0 -1
  396. package/dist/themes/momotaro.mjs +0 -4
  397. package/reset/index.d.ts +0 -1
  398. package/reset/package.json +0 -5
  399. /package/dist/{styles/lib/css/layers/layers.css.mjs → lib/css/layers/layers.css.js} +0 -0
  400. /package/dist/{styles/lib → lib}/css/reset/reset.css.cjs +0 -0
  401. /package/dist/{styles/lib/css/reset/reset.css.mjs → lib/css/reset/reset.css.js} +0 -0
  402. /package/dist/{styles/lib/css/utils/cssUtils.mjs → lib/css/utils/cssUtils.js} +0 -0
  403. /package/dist/{styles/lib/theme/makeComponentTheme.mjs → lib/theme/makeComponentTheme.js} +0 -0
  404. /package/dist/{styles/lib/theme/makeVanillaTheme.mjs → lib/theme/makeVanillaTheme.js} +0 -0
  405. /package/dist/{styles/lib/theme/tokens.mjs → lib/theme/tokens.js} +0 -0
  406. /package/dist/{styles/themes/momotaro/components/transitions.mjs → themes/momotaro/components/transitions.js} +0 -0
@@ -1,30 +1,31 @@
1
1
  "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
3
  const fileScope = require("@vanilla-extract/css/fileScope");
3
4
  const css = require("@vanilla-extract/css");
4
- const styles_lib_css_layers_layers_css_cjs = require("../../../lib/css/layers/layers.css.cjs");
5
+ const layers_css = require("../../../lib/css/layers/layers.css.cjs");
5
6
  fileScope.setFileScope("src/components/form/Radio/radio.css.ts", "@blockle/blocks");
6
7
  const container = css.style({
7
8
  "@layer": {
8
- [styles_lib_css_layers_layers_css_cjs.blocksLayer]: {
9
+ [layers_css.blocksLayer]: {
9
10
  position: "relative",
10
11
  cursor: "pointer",
11
12
  overflow: "hidden"
12
13
  }
13
14
  }
14
- }, "container");
15
+ });
15
16
  const input = css.style({
16
17
  position: "absolute",
17
18
  inset: 0,
18
19
  opacity: 0,
19
20
  "@layer": {
20
- [styles_lib_css_layers_layers_css_cjs.blocksLayer]: {
21
+ [layers_css.blocksLayer]: {
21
22
  all: "unset"
22
23
  }
23
24
  }
24
- }, "input");
25
+ });
25
26
  const icon = css.style({
26
27
  pointerEvents: "none"
27
- }, "icon");
28
+ });
28
29
  fileScope.endFileScope();
29
30
  exports.container = container;
30
31
  exports.icon = icon;
@@ -0,0 +1,3 @@
1
+ export declare const container: string;
2
+ export declare const input: string;
3
+ export declare const icon: string;
@@ -1,6 +1,6 @@
1
1
  import { setFileScope, endFileScope } from "@vanilla-extract/css/fileScope";
2
2
  import { style } from "@vanilla-extract/css";
3
- import { blocksLayer } from "../../../lib/css/layers/layers.css.mjs";
3
+ import { blocksLayer } from "../../../lib/css/layers/layers.css.js";
4
4
  setFileScope("src/components/form/Radio/radio.css.ts", "@blockle/blocks");
5
5
  const container = style({
6
6
  "@layer": {
@@ -10,7 +10,7 @@ const container = style({
10
10
  overflow: "hidden"
11
11
  }
12
12
  }
13
- }, "container");
13
+ });
14
14
  const input = style({
15
15
  position: "absolute",
16
16
  inset: 0,
@@ -20,10 +20,10 @@ const input = style({
20
20
  all: "unset"
21
21
  }
22
22
  }
23
- }, "input");
23
+ });
24
24
  const icon = style({
25
25
  pointerEvents: "none"
26
- }, "icon");
26
+ });
27
27
  endFileScope();
28
28
  export {
29
29
  container,
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("react/jsx-runtime");
4
+ const theme = require("../../../lib/theme/store/theme.cjs");
5
+ const classnames = require("../../../lib/utils/classnames.cjs");
6
+ const select_css = require("./select.css.cjs");
7
+ const Box = require("../../layout/Box/Box.cjs");
8
+ const Select = ({
9
+ children,
10
+ placeholder,
11
+ className,
12
+ variant,
13
+ ref,
14
+ ...restProps
15
+ }) => {
16
+ const wrapperClassName = theme.getComponentStyles(
17
+ "select",
18
+ { wrapper: true },
19
+ false
20
+ );
21
+ const selectClassName = theme.getComponentStyles("select", {
22
+ select: true,
23
+ variants: { variant }
24
+ });
25
+ const iconClassName = theme.getComponentStyles("select", { icon: true }, false);
26
+ return /* @__PURE__ */ jsxRuntime.jsxs(Box.Box, { className: classnames.classnames(select_css.wrapper, wrapperClassName), children: [
27
+ /* @__PURE__ */ jsxRuntime.jsxs(
28
+ "select",
29
+ {
30
+ ref,
31
+ className: classnames.classnames(select_css.select, selectClassName, className),
32
+ ...restProps,
33
+ children: [
34
+ placeholder && /* @__PURE__ */ jsxRuntime.jsx("option", { value: "", children: placeholder }),
35
+ children
36
+ ]
37
+ }
38
+ ),
39
+ /* @__PURE__ */ jsxRuntime.jsx(
40
+ Box.Box,
41
+ {
42
+ className: classnames.classnames(select_css.icon, iconClassName),
43
+ role: "presentation",
44
+ "aria-hidden": true,
45
+ children: /* @__PURE__ */ jsxRuntime.jsx(DefaultIcon, {})
46
+ }
47
+ )
48
+ ] });
49
+ };
50
+ const DefaultIcon = () => {
51
+ return (
52
+ // TOOD - replace with actual icon component renderer
53
+ // biome-ignore lint/a11y/noSvgWithoutTitle: <explanation>
54
+ /* @__PURE__ */ jsxRuntime.jsx("svg", { viewBox: "0 0 24 24", style: { width: "1rem", height: "1rem" }, children: /* @__PURE__ */ jsxRuntime.jsx(
55
+ "path",
56
+ {
57
+ fill: "currentColor",
58
+ fillRule: "evenodd",
59
+ d: "m11.625 14.3666 7.9365-7.653c.5241-.5055 1.3133-.4372 1.7625.1525.4493.5897.3886 1.4774-.1355 1.9829l-8.75 8.4375c-.4681.4513-1.1589.4513-1.627 0l-8.75-8.4375c-.5241-.5055-.5848-1.3932-.1356-1.9829.4493-.5897 1.2385-.658 1.7626-.1525l7.9365 7.653Z",
60
+ clipRule: "evenodd"
61
+ }
62
+ ) })
63
+ );
64
+ };
65
+ exports.Select = Select;
@@ -0,0 +1,10 @@
1
+ import { default as React } from 'react';
2
+ import { SelectTheme } from '../../../lib/theme/componentThemes';
3
+ import { HTMLElementProps } from '../../../lib/utils/utils';
4
+ export type SelectProps = {
5
+ children: React.ReactNode;
6
+ placeholder?: string;
7
+ ref?: React.Ref<HTMLSelectElement>;
8
+ variant?: SelectTheme['variants']['variant'];
9
+ } & HTMLElementProps<HTMLSelectElement>;
10
+ export declare const Select: React.FC<SelectProps>;
@@ -1,7 +1,8 @@
1
1
  import { jsxs, jsx } from "react/jsx-runtime";
2
- import { classnames } from "../../Accessibility/VisuallyHidden/VisuallyHidden.mjs";
3
- import { select, icon, wrapper } from "./select.css.mjs";
4
- import { useComponentStyles, Box } from "../../display/Divider/Divider.mjs";
2
+ import { getComponentStyles } from "../../../lib/theme/store/theme.js";
3
+ import { classnames } from "../../../lib/utils/classnames.js";
4
+ import { select, icon, wrapper } from "./select.css.js";
5
+ import { Box } from "../../layout/Box/Box.js";
5
6
  const Select = ({
6
7
  children,
7
8
  placeholder,
@@ -10,9 +11,16 @@ const Select = ({
10
11
  ref,
11
12
  ...restProps
12
13
  }) => {
13
- const wrapperClassName = useComponentStyles("select", { wrapper: true }, false);
14
- const selectClassName = useComponentStyles("select", { select: true, variants: { variant } });
15
- const iconClassName = useComponentStyles("select", { icon: true }, false);
14
+ const wrapperClassName = getComponentStyles(
15
+ "select",
16
+ { wrapper: true },
17
+ false
18
+ );
19
+ const selectClassName = getComponentStyles("select", {
20
+ select: true,
21
+ variants: { variant }
22
+ });
23
+ const iconClassName = getComponentStyles("select", { icon: true }, false);
16
24
  return /* @__PURE__ */ jsxs(Box, { className: classnames(wrapper, wrapperClassName), children: [
17
25
  /* @__PURE__ */ jsxs(
18
26
  "select",
@@ -26,12 +34,21 @@ const Select = ({
26
34
  ]
27
35
  }
28
36
  ),
29
- /* @__PURE__ */ jsx(Box, { className: classnames(icon, iconClassName), role: "presentation", "aria-hidden": true, children: /* @__PURE__ */ jsx(DefaultIcon, {}) })
37
+ /* @__PURE__ */ jsx(
38
+ Box,
39
+ {
40
+ className: classnames(icon, iconClassName),
41
+ role: "presentation",
42
+ "aria-hidden": true,
43
+ children: /* @__PURE__ */ jsx(DefaultIcon, {})
44
+ }
45
+ )
30
46
  ] });
31
47
  };
32
48
  const DefaultIcon = () => {
33
49
  return (
34
50
  // TOOD - replace with actual icon component renderer
51
+ // biome-ignore lint/a11y/noSvgWithoutTitle: <explanation>
35
52
  /* @__PURE__ */ jsx("svg", { viewBox: "0 0 24 24", style: { width: "1rem", height: "1rem" }, children: /* @__PURE__ */ jsx(
36
53
  "path",
37
54
  {
@@ -0,0 +1,5 @@
1
+ import { Meta, StoryObj } from '@storybook/react';
2
+ import { Select, SelectProps } from './Select';
3
+ declare const _default: Meta<typeof Select>;
4
+ export default _default;
5
+ export declare const Default: StoryObj<SelectProps>;
@@ -0,0 +1 @@
1
+ export { Select, type SelectProps } from './Select';
@@ -1,26 +1,27 @@
1
1
  "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
3
  const fileScope = require("@vanilla-extract/css/fileScope");
3
4
  const css = require("@vanilla-extract/css");
4
- const styles_lib_css_layers_layers_css_cjs = require("../../../lib/css/layers/layers.css.cjs");
5
+ const layers_css = require("../../../lib/css/layers/layers.css.cjs");
5
6
  fileScope.setFileScope("src/components/form/Select/select.css.ts", "@blockle/blocks");
6
7
  const wrapper = css.style({
7
8
  "@layer": {
8
- [styles_lib_css_layers_layers_css_cjs.blocksLayer]: {
9
+ [layers_css.blocksLayer]: {
9
10
  position: "relative"
10
11
  }
11
12
  }
12
- }, "wrapper");
13
+ });
13
14
  const select = css.style({
14
15
  "@layer": {
15
- [styles_lib_css_layers_layers_css_cjs.blocksLayer]: {
16
+ [layers_css.blocksLayer]: {
16
17
  appearance: "none",
17
18
  inlineSize: "100%"
18
19
  }
19
20
  }
20
- }, "select");
21
+ });
21
22
  const icon = css.style({
22
23
  "@layer": {
23
- [styles_lib_css_layers_layers_css_cjs.blocksLayer]: {
24
+ [layers_css.blocksLayer]: {
24
25
  position: "absolute",
25
26
  right: 0,
26
27
  top: 0,
@@ -30,7 +31,7 @@ const icon = css.style({
30
31
  alignItems: "center"
31
32
  }
32
33
  }
33
- }, "icon");
34
+ });
34
35
  fileScope.endFileScope();
35
36
  exports.icon = icon;
36
37
  exports.select = select;
@@ -0,0 +1,3 @@
1
+ export declare const wrapper: string;
2
+ export declare const select: string;
3
+ export declare const icon: string;
@@ -1,6 +1,6 @@
1
1
  import { setFileScope, endFileScope } from "@vanilla-extract/css/fileScope";
2
2
  import { style } from "@vanilla-extract/css";
3
- import { blocksLayer } from "../../../lib/css/layers/layers.css.mjs";
3
+ import { blocksLayer } from "../../../lib/css/layers/layers.css.js";
4
4
  setFileScope("src/components/form/Select/select.css.ts", "@blockle/blocks");
5
5
  const wrapper = style({
6
6
  "@layer": {
@@ -8,7 +8,7 @@ const wrapper = style({
8
8
  position: "relative"
9
9
  }
10
10
  }
11
- }, "wrapper");
11
+ });
12
12
  const select = style({
13
13
  "@layer": {
14
14
  [blocksLayer]: {
@@ -16,7 +16,7 @@ const select = style({
16
16
  inlineSize: "100%"
17
17
  }
18
18
  }
19
- }, "select");
19
+ });
20
20
  const icon = style({
21
21
  "@layer": {
22
22
  [blocksLayer]: {
@@ -29,7 +29,7 @@ const icon = style({
29
29
  alignItems: "center"
30
30
  }
31
31
  }
32
- }, "icon");
32
+ });
33
33
  endFileScope();
34
34
  export {
35
35
  icon,
@@ -0,0 +1,141 @@
1
+ "use client";
2
+ "use strict";
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
+ const jsxRuntime = require("react/jsx-runtime");
5
+ const react = require("react");
6
+ const useControlledValue = require("../../../hooks/useControlledValue/useControlledValue.cjs");
7
+ const theme = require("../../../lib/theme/store/theme.cjs");
8
+ const classnames = require("../../../lib/utils/classnames.cjs");
9
+ const math = require("../../../lib/utils/math.cjs");
10
+ const slider_css = require("./slider.css.cjs");
11
+ const usePointerProgress = require("./usePointerProgress.cjs");
12
+ const usableKeys = /* @__PURE__ */ new Set([
13
+ "ArrowLeft",
14
+ "ArrowRight",
15
+ "ArrowUp",
16
+ "ArrowDown",
17
+ "Home",
18
+ "End",
19
+ "PageUp",
20
+ "PageDown",
21
+ "Home",
22
+ "End"
23
+ ]);
24
+ const Slider = ({
25
+ min = 0,
26
+ max = 100,
27
+ step = 1,
28
+ orientation = "horizontal",
29
+ defaultValue = 0,
30
+ onChange,
31
+ value,
32
+ name,
33
+ size,
34
+ colorScheme,
35
+ disabled,
36
+ precision = 2,
37
+ ...restProps
38
+ }) => {
39
+ const baseClass = theme.getComponentStyles("slider", {
40
+ base: true,
41
+ variants: { size, colorScheme, disabled }
42
+ });
43
+ const trackClass = theme.getComponentStyles("slider", { track: true }, false);
44
+ const filledTrackClass = theme.getComponentStyles(
45
+ "slider",
46
+ { filledTrack: true },
47
+ false
48
+ );
49
+ const thumbClass = theme.getComponentStyles("slider", { thumb: true }, false);
50
+ const containerRef = react.useRef(null);
51
+ const [currentValue, setValue] = useControlledValue.useControlledValue({
52
+ defaultValue,
53
+ value,
54
+ onChange,
55
+ transformValue: (value2) => math.roundToPrecision(math.getBoundValue(value2, min, max, step), precision)
56
+ });
57
+ usePointerProgress.usePointerProgress({
58
+ container: containerRef,
59
+ orientation,
60
+ onChange(progress) {
61
+ if (orientation === "vertical") {
62
+ setValue(max * (1 - progress));
63
+ } else {
64
+ setValue(max * progress);
65
+ }
66
+ }
67
+ });
68
+ const onKeyDown = react.useCallback(
69
+ (event) => {
70
+ if (!usableKeys.has(event.key)) {
71
+ return;
72
+ }
73
+ event.preventDefault();
74
+ event.stopPropagation();
75
+ const specialKey = ["PageUp", "PageDown"];
76
+ const stepModifier = event.shiftKey || specialKey.includes(event.key) ? (max - min) / 10 : step;
77
+ if (event.key === "ArrowLeft" || event.key === "ArrowDown" || event.key === "PageDown") {
78
+ return setValue(currentValue - stepModifier);
79
+ }
80
+ if (event.key === "ArrowRight" || event.key === "ArrowUp" || event.key === "PageUp") {
81
+ return setValue(currentValue + stepModifier);
82
+ }
83
+ if (event.key === "Home") {
84
+ return setValue(min);
85
+ }
86
+ if (event.key === "End") {
87
+ return setValue(max);
88
+ }
89
+ },
90
+ [max, min, step, setValue, currentValue]
91
+ );
92
+ return /* @__PURE__ */ jsxRuntime.jsxs(
93
+ "div",
94
+ {
95
+ ref: containerRef,
96
+ className: classnames.classnames(
97
+ slider_css.container,
98
+ orientation === "vertical" ? slider_css.containerVertical : "",
99
+ baseClass
100
+ ),
101
+ children: [
102
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: classnames.classnames(slider_css.track, trackClass), children: /* @__PURE__ */ jsxRuntime.jsx(
103
+ "div",
104
+ {
105
+ className: classnames.classnames(slider_css.filledTrack, filledTrackClass),
106
+ style: {
107
+ inlineSize: `${currentValue / max * 100}%`
108
+ }
109
+ }
110
+ ) }),
111
+ /* @__PURE__ */ jsxRuntime.jsx(
112
+ "button",
113
+ {
114
+ type: "button",
115
+ className: classnames.classnames(slider_css.thumb, thumbClass),
116
+ role: "slider",
117
+ "aria-valuemin": min,
118
+ "aria-valuemax": max,
119
+ "aria-valuenow": currentValue,
120
+ "aria-orientation": orientation,
121
+ style: {
122
+ [orientation === "horizontal" ? "insetInlineStart" : "insetInlineEnd"]: `${currentValue / max * 100}%`
123
+ },
124
+ onKeyDown,
125
+ ...restProps
126
+ }
127
+ ),
128
+ /* @__PURE__ */ jsxRuntime.jsx(
129
+ "input",
130
+ {
131
+ type: "hidden",
132
+ disabled,
133
+ name,
134
+ value: currentValue
135
+ }
136
+ )
137
+ ]
138
+ }
139
+ );
140
+ };
141
+ exports.Slider = Slider;
@@ -0,0 +1,20 @@
1
+ import { default as React } from 'react';
2
+ import { SliderTheme } from '../../../lib/theme/componentThemes';
3
+ export type SliderProps = {
4
+ name?: string;
5
+ min?: number;
6
+ max?: number;
7
+ step?: number;
8
+ value?: number;
9
+ defaultValue?: number;
10
+ onChange?: (value: number) => void;
11
+ orientation?: 'horizontal' | 'vertical';
12
+ 'aria-labelledby'?: string;
13
+ 'aria-valuetext'?: string;
14
+ 'aria-label'?: string;
15
+ size: SliderTheme['variants']['size'];
16
+ colorScheme: SliderTheme['variants']['colorScheme'];
17
+ disabled?: boolean;
18
+ precision?: number;
19
+ };
20
+ export declare const Slider: React.FC<SliderProps>;
@@ -0,0 +1,141 @@
1
+ "use client";
2
+ import { jsxs, jsx } from "react/jsx-runtime";
3
+ import { useRef, useCallback } from "react";
4
+ import { useControlledValue } from "../../../hooks/useControlledValue/useControlledValue.js";
5
+ import { getComponentStyles } from "../../../lib/theme/store/theme.js";
6
+ import { classnames } from "../../../lib/utils/classnames.js";
7
+ import { roundToPrecision, getBoundValue } from "../../../lib/utils/math.js";
8
+ import { filledTrack, track, thumb, containerVertical, container } from "./slider.css.js";
9
+ import { usePointerProgress } from "./usePointerProgress.js";
10
+ const usableKeys = /* @__PURE__ */ new Set([
11
+ "ArrowLeft",
12
+ "ArrowRight",
13
+ "ArrowUp",
14
+ "ArrowDown",
15
+ "Home",
16
+ "End",
17
+ "PageUp",
18
+ "PageDown",
19
+ "Home",
20
+ "End"
21
+ ]);
22
+ const Slider = ({
23
+ min = 0,
24
+ max = 100,
25
+ step = 1,
26
+ orientation = "horizontal",
27
+ defaultValue = 0,
28
+ onChange,
29
+ value,
30
+ name,
31
+ size,
32
+ colorScheme,
33
+ disabled,
34
+ precision = 2,
35
+ ...restProps
36
+ }) => {
37
+ const baseClass = getComponentStyles("slider", {
38
+ base: true,
39
+ variants: { size, colorScheme, disabled }
40
+ });
41
+ const trackClass = getComponentStyles("slider", { track: true }, false);
42
+ const filledTrackClass = getComponentStyles(
43
+ "slider",
44
+ { filledTrack: true },
45
+ false
46
+ );
47
+ const thumbClass = getComponentStyles("slider", { thumb: true }, false);
48
+ const containerRef = useRef(null);
49
+ const [currentValue, setValue] = useControlledValue({
50
+ defaultValue,
51
+ value,
52
+ onChange,
53
+ transformValue: (value2) => roundToPrecision(getBoundValue(value2, min, max, step), precision)
54
+ });
55
+ usePointerProgress({
56
+ container: containerRef,
57
+ orientation,
58
+ onChange(progress) {
59
+ if (orientation === "vertical") {
60
+ setValue(max * (1 - progress));
61
+ } else {
62
+ setValue(max * progress);
63
+ }
64
+ }
65
+ });
66
+ const onKeyDown = useCallback(
67
+ (event) => {
68
+ if (!usableKeys.has(event.key)) {
69
+ return;
70
+ }
71
+ event.preventDefault();
72
+ event.stopPropagation();
73
+ const specialKey = ["PageUp", "PageDown"];
74
+ const stepModifier = event.shiftKey || specialKey.includes(event.key) ? (max - min) / 10 : step;
75
+ if (event.key === "ArrowLeft" || event.key === "ArrowDown" || event.key === "PageDown") {
76
+ return setValue(currentValue - stepModifier);
77
+ }
78
+ if (event.key === "ArrowRight" || event.key === "ArrowUp" || event.key === "PageUp") {
79
+ return setValue(currentValue + stepModifier);
80
+ }
81
+ if (event.key === "Home") {
82
+ return setValue(min);
83
+ }
84
+ if (event.key === "End") {
85
+ return setValue(max);
86
+ }
87
+ },
88
+ [max, min, step, setValue, currentValue]
89
+ );
90
+ return /* @__PURE__ */ jsxs(
91
+ "div",
92
+ {
93
+ ref: containerRef,
94
+ className: classnames(
95
+ container,
96
+ orientation === "vertical" ? containerVertical : "",
97
+ baseClass
98
+ ),
99
+ children: [
100
+ /* @__PURE__ */ jsx("div", { className: classnames(track, trackClass), children: /* @__PURE__ */ jsx(
101
+ "div",
102
+ {
103
+ className: classnames(filledTrack, filledTrackClass),
104
+ style: {
105
+ inlineSize: `${currentValue / max * 100}%`
106
+ }
107
+ }
108
+ ) }),
109
+ /* @__PURE__ */ jsx(
110
+ "button",
111
+ {
112
+ type: "button",
113
+ className: classnames(thumb, thumbClass),
114
+ role: "slider",
115
+ "aria-valuemin": min,
116
+ "aria-valuemax": max,
117
+ "aria-valuenow": currentValue,
118
+ "aria-orientation": orientation,
119
+ style: {
120
+ [orientation === "horizontal" ? "insetInlineStart" : "insetInlineEnd"]: `${currentValue / max * 100}%`
121
+ },
122
+ onKeyDown,
123
+ ...restProps
124
+ }
125
+ ),
126
+ /* @__PURE__ */ jsx(
127
+ "input",
128
+ {
129
+ type: "hidden",
130
+ disabled,
131
+ name,
132
+ value: currentValue
133
+ }
134
+ )
135
+ ]
136
+ }
137
+ );
138
+ };
139
+ export {
140
+ Slider
141
+ };
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,6 @@
1
+ import { Meta, StoryObj } from '@storybook/react';
2
+ import { Slider, SliderProps } from './Slider';
3
+ declare const _default: Meta<typeof Slider>;
4
+ export default _default;
5
+ export declare const Default: StoryObj<SliderProps>;
6
+ export declare const WithState: StoryObj<SliderProps>;
@@ -0,0 +1 @@
1
+ export { Slider, type SliderProps } from './Slider';