react-miui 0.35.0 → 0.36.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 (290) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/dist/components/layout/header/HeaderIconAction.d.ts.map +1 -1
  3. package/dist/components/layout/header/HeaderIconAction.js +13 -3
  4. package/dist/components/layout/header/HeaderIconAction.js.map +1 -1
  5. package/dist/components/layout/header/HeaderIconAction.styled.d.ts.map +1 -1
  6. package/dist/components/layout/header/HeaderIconAction.styled.js +11 -17
  7. package/dist/components/layout/header/HeaderIconAction.styled.js.map +1 -1
  8. package/dist/components/layout/list/Item.d.ts.map +1 -1
  9. package/dist/components/layout/list/Item.js +17 -7
  10. package/dist/components/layout/list/Item.js.map +1 -1
  11. package/dist/components/layout/list/Item.styled.d.ts.map +1 -1
  12. package/dist/components/layout/list/Item.styled.js +2 -1
  13. package/dist/components/layout/list/Item.styled.js.map +1 -1
  14. package/dist/components/ui/button/Button.d.ts +94 -1
  15. package/dist/components/ui/button/Button.d.ts.map +1 -1
  16. package/dist/components/ui/button/Button.js +59 -2
  17. package/dist/components/ui/button/Button.js.map +1 -1
  18. package/dist/components/ui/button/Button.styled.d.ts +2 -2
  19. package/dist/components/ui/button/Button.styled.d.ts.map +1 -1
  20. package/dist/components/ui/button/Button.styled.js +4 -3
  21. package/dist/components/ui/button/Button.styled.js.map +1 -1
  22. package/dist/components/ui/directionPad/Button.d.ts.map +1 -1
  23. package/dist/components/ui/directionPad/Button.js +7 -2
  24. package/dist/components/ui/directionPad/Button.js.map +1 -1
  25. package/dist/components/ui/directionPad/Button.styled.d.ts.map +1 -1
  26. package/dist/components/ui/directionPad/Button.styled.js +2 -1
  27. package/dist/components/ui/directionPad/Button.styled.js.map +1 -1
  28. package/dist/components/ui/directionPad/Middle.d.ts.map +1 -1
  29. package/dist/components/ui/directionPad/Middle.js +7 -1
  30. package/dist/components/ui/directionPad/Middle.js.map +1 -1
  31. package/dist/components/ui/directionPad/Middle.styled.d.ts.map +1 -1
  32. package/dist/components/ui/directionPad/Middle.styled.js +2 -1
  33. package/dist/components/ui/directionPad/Middle.styled.js.map +1 -1
  34. package/dist/components/ui/modal/ModalButtons.d.ts +179 -1
  35. package/dist/components/ui/modal/ModalButtons.d.ts.map +1 -1
  36. package/dist/components/ui/modal/ModalButtons.js +63 -2
  37. package/dist/components/ui/modal/ModalButtons.js.map +1 -1
  38. package/dist/components/ui/modal/ModalButtons.styled.d.ts +90 -91
  39. package/dist/components/ui/modal/ModalButtons.styled.d.ts.map +1 -1
  40. package/dist/components/ui/modal/ModalButtons.styled.js +5 -7
  41. package/dist/components/ui/modal/ModalButtons.styled.js.map +1 -1
  42. package/dist/components/ui/pop/Pop.styled.d.ts.map +1 -1
  43. package/dist/components/ui/pop/Pop.styled.js +15 -17
  44. package/dist/components/ui/pop/Pop.styled.js.map +1 -1
  45. package/dist/components/ui/pop/PopOption.d.ts.map +1 -1
  46. package/dist/components/ui/pop/PopOption.js +7 -2
  47. package/dist/components/ui/pop/PopOption.js.map +1 -1
  48. package/dist/components/ui/toolButton/ToolButton.d.ts +94 -1
  49. package/dist/components/ui/toolButton/ToolButton.d.ts.map +1 -1
  50. package/dist/components/ui/toolButton/ToolButton.js +59 -2
  51. package/dist/components/ui/toolButton/ToolButton.js.map +1 -1
  52. package/dist/components/ui/toolButton/ToolButton.styled.d.ts +2 -2
  53. package/dist/components/ui/toolButton/ToolButton.styled.d.ts.map +1 -1
  54. package/dist/components/ui/toolButton/ToolButton.styled.js +20 -25
  55. package/dist/components/ui/toolButton/ToolButton.styled.js.map +1 -1
  56. package/dist/utils/useRipple.d.ts +15 -0
  57. package/dist/utils/useRipple.d.ts.map +1 -0
  58. package/dist/utils/useRipple.js +120 -0
  59. package/dist/utils/useRipple.js.map +1 -0
  60. package/dist/utils/useRipple.styled.d.ts +28 -0
  61. package/dist/utils/useRipple.styled.d.ts.map +1 -0
  62. package/dist/utils/useRipple.styled.js +36 -0
  63. package/dist/utils/useRipple.styled.js.map +1 -0
  64. package/docs/classes/index.Pop.html +7 -7
  65. package/docs/documents/Test.html +2 -2
  66. package/docs/enums/index.ICON.html +2 -2
  67. package/docs/functions/index.Action.html +3 -3
  68. package/docs/functions/index.Button.html +3 -9
  69. package/docs/functions/index.Card.html +2 -2
  70. package/docs/functions/index.Checkbox.html +3 -3
  71. package/docs/functions/index.Choice.html +2 -2
  72. package/docs/functions/index.ColorPicker.html +3 -3
  73. package/docs/functions/index.CoveringLoader.html +3 -3
  74. package/docs/functions/index.DirectionPad.html +2 -2
  75. package/docs/functions/index.Drawer.html +2 -2
  76. package/docs/functions/index.EqualActions.html +2 -2
  77. package/docs/functions/index.FullLoader.html +3 -3
  78. package/docs/functions/index.Gap.html +2 -2
  79. package/docs/functions/index.HandleEsc.html +3 -3
  80. package/docs/functions/index.Header.html +3 -3
  81. package/docs/functions/index.HeaderIconAction.html +3 -3
  82. package/docs/functions/index.Icon-1.html +2 -2
  83. package/docs/functions/index.If.html +3 -3
  84. package/docs/functions/index.Input.html +1 -1
  85. package/docs/functions/index.KeyValue.html +2 -2
  86. package/docs/functions/index.Label.html +2 -2
  87. package/docs/functions/index.Line.html +3 -3
  88. package/docs/functions/index.List.html +2 -2
  89. package/docs/functions/index.Loader.html +3 -3
  90. package/docs/functions/index.Loading.html +3 -3
  91. package/docs/functions/index.Message.html +3 -3
  92. package/docs/functions/index.Modal.html +2 -2
  93. package/docs/functions/index.ModalButtons.html +3 -3
  94. package/docs/functions/index.PopLoader.html +3 -3
  95. package/docs/functions/index.PopOption.html +2 -2
  96. package/docs/functions/index.Progress.html +2 -2
  97. package/docs/functions/index.SearchContainer.html +2 -2
  98. package/docs/functions/index.Section.html +4 -4
  99. package/docs/functions/index.Select.html +2 -2
  100. package/docs/functions/index.Selector.html +2 -2
  101. package/docs/functions/index.Spacer.html +2 -2
  102. package/docs/functions/index.Stats.html +2 -2
  103. package/docs/functions/index.StickyHeader.html +4 -4
  104. package/docs/functions/index.Table.html +2 -2
  105. package/docs/functions/index.TextArea.html +2 -2
  106. package/docs/functions/index.TimePicker.html +2 -2
  107. package/docs/functions/index.ToasterProvider.html +3 -3
  108. package/docs/functions/index.Toggle.html +3 -3
  109. package/docs/functions/index.ToolButton.html +3 -9
  110. package/docs/functions/index.Tooltip.html +3 -3
  111. package/docs/functions/index.TooltipProvider.html +2 -2
  112. package/docs/functions/index.borderPxToRem.html +1 -1
  113. package/docs/functions/index.createTheme.html +1 -1
  114. package/docs/functions/index.css.html +1 -1
  115. package/docs/functions/index.dimensionsPxToRem.html +1 -1
  116. package/docs/functions/index.fontPxToRem.html +1 -1
  117. package/docs/functions/index.getCssText.html +1 -1
  118. package/docs/functions/index.globalCss.html +2 -2
  119. package/docs/functions/index.injectGlobalStyles.html +1 -1
  120. package/docs/functions/index.keyframes.html +1 -1
  121. package/docs/functions/index.pxToRem.html +1 -1
  122. package/docs/functions/index.styled.html +1 -1
  123. package/docs/functions/index.toast.html +2 -2
  124. package/docs/functions/index.useToaster.html +1 -1
  125. package/docs/index.html +2 -2
  126. package/docs/interfaces/index.IconProps.html +2 -2
  127. package/docs/interfaces/index.InputCustomProps.html +3 -3
  128. package/docs/interfaces/index.LoaderProps.html +6 -6
  129. package/docs/interfaces/index.StickyHeaderProps.html +4 -4
  130. package/docs/interfaces/index.ToasterProviderProps.html +3 -3
  131. package/docs/interfaces/index.TooltipProps.html +14 -14
  132. package/docs/interfaces/index.TooltipProviderProps.html +5 -5
  133. package/docs/modules/index.html +1 -1
  134. package/docs/modules.html +1 -1
  135. package/docs/types/index.ActionProps.html +1 -1
  136. package/docs/types/index.CardProps.html +1 -1
  137. package/docs/types/index.CheckboxProps.html +2 -2
  138. package/docs/types/index.ChoiceProps.html +1 -1
  139. package/docs/types/index.ColorPickerProps.html +1 -1
  140. package/docs/types/index.DirectionPadProps.html +1 -1
  141. package/docs/types/index.DrawerFrom.html +1 -1
  142. package/docs/types/index.DrawerProps.html +2 -2
  143. package/docs/types/index.EqualActionsProps.html +1 -1
  144. package/docs/types/index.HeaderProps.html +1 -1
  145. package/docs/types/index.InputProps.html +1 -1
  146. package/docs/types/index.KeyValueProps.html +1 -1
  147. package/docs/types/index.LabelProps.html +1 -1
  148. package/docs/types/index.OverwriteProps.html +1 -1
  149. package/docs/types/index.ProgressProps.html +2 -2
  150. package/docs/types/index.SelectProps.html +1 -1
  151. package/docs/types/index.SelectorProps.html +1 -1
  152. package/docs/types/index.Stat.html +1 -1
  153. package/docs/types/index.StatsProps.html +1 -1
  154. package/docs/types/index.TextAreaProps.html +1 -1
  155. package/docs/types/index.ThemeCSS.html +1 -1
  156. package/docs/types/index.TimePickerProps.html +1 -1
  157. package/docs/types/index.ToggleProps.html +2 -2
  158. package/docs/variables/index.ActionBadgeSelector.html +1 -1
  159. package/docs/variables/index.ActionCircleSelector.html +1 -1
  160. package/docs/variables/index.CheckboxCheckmarkWrapperSelector.html +1 -1
  161. package/docs/variables/index.CheckboxTextLabelSelector.html +1 -1
  162. package/docs/variables/index.ChoiceItemSelector.html +1 -1
  163. package/docs/variables/index.ColorPickerColorDisplaySelector.html +1 -1
  164. package/docs/variables/index.DirectionPadButtonDotSelector.html +1 -1
  165. package/docs/variables/index.DirectionPadButtonSelector.html +1 -1
  166. package/docs/variables/index.DirectionPadLineSelector.html +1 -1
  167. package/docs/variables/index.DirectionPadMiddleSelector.html +1 -1
  168. package/docs/variables/index.DrawerContentSelector.html +1 -1
  169. package/docs/variables/index.HeaderAfterSelector.html +1 -1
  170. package/docs/variables/index.HeaderBeforeSelector.html +1 -1
  171. package/docs/variables/index.HeaderContentsSelector.html +1 -1
  172. package/docs/variables/index.HeaderIconActionIconSelector.html +1 -1
  173. package/docs/variables/index.InputContainerSelector.html +1 -1
  174. package/docs/variables/index.InputInputSelector.html +1 -1
  175. package/docs/variables/index.InputLabelSelector.html +1 -1
  176. package/docs/variables/index.InputPrefixSelector.html +1 -1
  177. package/docs/variables/index.InputSuffixSelector.html +1 -1
  178. package/docs/variables/index.KeyValueIconSelector.html +1 -1
  179. package/docs/variables/index.KeyValueItemSelector.html +1 -1
  180. package/docs/variables/index.KeyValueKeySelector.html +1 -1
  181. package/docs/variables/index.KeyValuePairSelector.html +1 -1
  182. package/docs/variables/index.KeyValueValueSelector.html +1 -1
  183. package/docs/variables/index.LabelTextSelector.html +1 -1
  184. package/docs/variables/index.ListItemInnerContainerClassNameSelector.html +1 -1
  185. package/docs/variables/index.ModalContainerSelector.html +1 -1
  186. package/docs/variables/index.ModalRemovePaddingSelector.html +1 -1
  187. package/docs/variables/index.ModalTitleSelector.html +1 -1
  188. package/docs/variables/index.PopListSelector.html +1 -1
  189. package/docs/variables/index.PopOptionButtonSelector.html +1 -1
  190. package/docs/variables/index.PopOptionIconSelector.html +1 -1
  191. package/docs/variables/index.PopOverlaySelector.html +1 -1
  192. package/docs/variables/index.ProgressBackgroundSelector.html +1 -1
  193. package/docs/variables/index.ProgressValueSelector.html +1 -1
  194. package/docs/variables/index.SelectorItemSelector.html +1 -1
  195. package/docs/variables/index.StatsItemSelector.html +1 -1
  196. package/docs/variables/index.StatsLabelSelector.html +1 -1
  197. package/docs/variables/index.StatsSeparatorSelector.html +1 -1
  198. package/docs/variables/index.StatsValueSelector.html +1 -1
  199. package/docs/variables/index.TextAreaLabelSelector.html +1 -1
  200. package/docs/variables/index.TextAreaTextAreaSelector.html +1 -1
  201. package/docs/variables/index.TextAreaWrapperSelector.html +1 -1
  202. package/docs/variables/index.ToggleStyledToggleSelector.html +1 -1
  203. package/docs/variables/index.TooltipContentSelector.html +1 -1
  204. package/docs/variables/index.config.html +1 -1
  205. package/docs/variables/index.cssReset.html +2 -2
  206. package/docs/variables/index.darkTheme.html +1 -1
  207. package/docs/variables/index.miuiScrollbars.html +1 -1
  208. package/docs/variables/index.theme.html +1 -1
  209. package/esm/components/layout/header/HeaderIconAction.d.ts.map +1 -1
  210. package/esm/components/layout/header/HeaderIconAction.js +13 -3
  211. package/esm/components/layout/header/HeaderIconAction.js.map +1 -1
  212. package/esm/components/layout/header/HeaderIconAction.styled.d.ts.map +1 -1
  213. package/esm/components/layout/header/HeaderIconAction.styled.js +11 -17
  214. package/esm/components/layout/header/HeaderIconAction.styled.js.map +1 -1
  215. package/esm/components/layout/list/Item.d.ts.map +1 -1
  216. package/esm/components/layout/list/Item.js +18 -8
  217. package/esm/components/layout/list/Item.js.map +1 -1
  218. package/esm/components/layout/list/Item.styled.d.ts.map +1 -1
  219. package/esm/components/layout/list/Item.styled.js +2 -1
  220. package/esm/components/layout/list/Item.styled.js.map +1 -1
  221. package/esm/components/ui/button/Button.d.ts +94 -1
  222. package/esm/components/ui/button/Button.d.ts.map +1 -1
  223. package/esm/components/ui/button/Button.js +15 -1
  224. package/esm/components/ui/button/Button.js.map +1 -1
  225. package/esm/components/ui/button/Button.styled.d.ts +2 -2
  226. package/esm/components/ui/button/Button.styled.d.ts.map +1 -1
  227. package/esm/components/ui/button/Button.styled.js +3 -2
  228. package/esm/components/ui/button/Button.styled.js.map +1 -1
  229. package/esm/components/ui/directionPad/Button.d.ts.map +1 -1
  230. package/esm/components/ui/directionPad/Button.js +7 -2
  231. package/esm/components/ui/directionPad/Button.js.map +1 -1
  232. package/esm/components/ui/directionPad/Button.styled.d.ts.map +1 -1
  233. package/esm/components/ui/directionPad/Button.styled.js +2 -1
  234. package/esm/components/ui/directionPad/Button.styled.js.map +1 -1
  235. package/esm/components/ui/directionPad/Middle.d.ts.map +1 -1
  236. package/esm/components/ui/directionPad/Middle.js +7 -1
  237. package/esm/components/ui/directionPad/Middle.js.map +1 -1
  238. package/esm/components/ui/directionPad/Middle.styled.d.ts.map +1 -1
  239. package/esm/components/ui/directionPad/Middle.styled.js +2 -1
  240. package/esm/components/ui/directionPad/Middle.styled.js.map +1 -1
  241. package/esm/components/ui/modal/ModalButtons.d.ts +179 -1
  242. package/esm/components/ui/modal/ModalButtons.d.ts.map +1 -1
  243. package/esm/components/ui/modal/ModalButtons.js +19 -1
  244. package/esm/components/ui/modal/ModalButtons.js.map +1 -1
  245. package/esm/components/ui/modal/ModalButtons.styled.d.ts +90 -91
  246. package/esm/components/ui/modal/ModalButtons.styled.d.ts.map +1 -1
  247. package/esm/components/ui/modal/ModalButtons.styled.js +3 -6
  248. package/esm/components/ui/modal/ModalButtons.styled.js.map +1 -1
  249. package/esm/components/ui/pop/Pop.styled.d.ts.map +1 -1
  250. package/esm/components/ui/pop/Pop.styled.js +15 -17
  251. package/esm/components/ui/pop/Pop.styled.js.map +1 -1
  252. package/esm/components/ui/pop/PopOption.d.ts.map +1 -1
  253. package/esm/components/ui/pop/PopOption.js +7 -2
  254. package/esm/components/ui/pop/PopOption.js.map +1 -1
  255. package/esm/components/ui/toolButton/ToolButton.d.ts +94 -1
  256. package/esm/components/ui/toolButton/ToolButton.d.ts.map +1 -1
  257. package/esm/components/ui/toolButton/ToolButton.js +15 -1
  258. package/esm/components/ui/toolButton/ToolButton.js.map +1 -1
  259. package/esm/components/ui/toolButton/ToolButton.styled.d.ts +2 -2
  260. package/esm/components/ui/toolButton/ToolButton.styled.d.ts.map +1 -1
  261. package/esm/components/ui/toolButton/ToolButton.styled.js +19 -24
  262. package/esm/components/ui/toolButton/ToolButton.styled.js.map +1 -1
  263. package/esm/utils/useRipple.d.ts +15 -0
  264. package/esm/utils/useRipple.d.ts.map +1 -0
  265. package/esm/utils/useRipple.js +84 -0
  266. package/esm/utils/useRipple.js.map +1 -0
  267. package/esm/utils/useRipple.styled.d.ts +28 -0
  268. package/esm/utils/useRipple.styled.d.ts.map +1 -0
  269. package/esm/utils/useRipple.styled.js +33 -0
  270. package/esm/utils/useRipple.styled.js.map +1 -0
  271. package/package.json +1 -1
  272. package/src/components/layout/header/HeaderIconAction.styled.ts +11 -18
  273. package/src/components/layout/header/HeaderIconAction.tsx +32 -5
  274. package/src/components/layout/list/Item.styled.ts +2 -1
  275. package/src/components/layout/list/Item.tsx +38 -5
  276. package/src/components/ui/button/Button.styled.ts +3 -2
  277. package/src/components/ui/button/Button.tsx +33 -1
  278. package/src/components/ui/directionPad/Button.styled.ts +2 -1
  279. package/src/components/ui/directionPad/Button.tsx +13 -1
  280. package/src/components/ui/directionPad/Middle.styled.ts +2 -1
  281. package/src/components/ui/directionPad/Middle.tsx +13 -1
  282. package/src/components/ui/modal/ModalButtons.styled.ts +4 -7
  283. package/src/components/ui/modal/ModalButtons.tsx +38 -1
  284. package/src/components/ui/pop/Pop.styled.ts +15 -18
  285. package/src/components/ui/pop/PopOption.tsx +15 -1
  286. package/src/components/ui/toolButton/ToolButton.styled.ts +20 -26
  287. package/src/components/ui/toolButton/ToolButton.tsx +33 -0
  288. package/src/utils/useRipple.styled.ts +56 -0
  289. package/src/utils/useRipple.tsx +139 -0
  290. package/src/components/ui/toolButton/ToolButton.ts +0 -1
@@ -1,27 +1,24 @@
1
1
  import { dimensionsPxToRem, fontPxToRem, styled } from "../../../theme";
2
+ import { rippleHostStyles } from "../../../utils/useRipple.styled";
2
3
 
3
4
  /**
4
5
  * Small buttons for toolbars
5
6
  */
6
- const ToolButton = styled("button", {
7
- "height": dimensionsPxToRem(79),
8
- "borderRadius": dimensionsPxToRem(10),
9
- "fontWeight": "bold",
10
- "fontSize": fontPxToRem(23),
11
- "display": "flex",
12
- "alignItems": "center",
13
- "justifyContent": "center",
14
- "paddingInline": dimensionsPxToRem(16),
15
- "background": "white",
16
- "boxSizing": "border-box",
17
- "border": `${dimensionsPxToRem(6)} solid transparent`,
7
+ const StyledToolButton = styled("button", rippleHostStyles, {
8
+ height: dimensionsPxToRem(79),
9
+ borderRadius: dimensionsPxToRem(10),
10
+ fontWeight: "bold",
11
+ fontSize: fontPxToRem(23),
12
+ display: "flex",
13
+ alignItems: "center",
14
+ justifyContent: "center",
15
+ paddingInline: dimensionsPxToRem(16),
16
+ background: "white",
17
+ boxSizing: "border-box",
18
+ border: `${dimensionsPxToRem(6)} solid transparent`,
19
+ color: "$toolButtonText",
18
20
 
19
- "color": "$toolButtonText",
20
- "&:hover": {
21
- background: "#ffffffcc",
22
- },
23
-
24
- "variants": {
21
+ variants: {
25
22
  inline: {
26
23
  true: {
27
24
  width: "auto",
@@ -30,19 +27,16 @@ const ToolButton = styled("button", {
30
27
  },
31
28
  variant: {
32
29
  secondary: {
33
- "border": `${dimensionsPxToRem(6)} solid #ffffff42`,
34
- "background": "none",
35
-
36
- "&:hover": {
37
- background: "#ffffff22",
38
- },
39
- "color": "white",
30
+ border: `${dimensionsPxToRem(6)} solid #ffffff42`,
31
+ background: "none",
32
+ color: "white",
40
33
  },
41
34
  secondaryOnLight: {
42
35
  "border": `${dimensionsPxToRem(6)} solid $border`,
43
36
  "background": "none",
44
37
  "color": "$text",
45
38
 
39
+ // emphasize border on hover (more than just the universal tint overlay)
46
40
  "&:hover": {
47
41
  borderColor: "$buttonBorder",
48
42
  },
@@ -52,5 +46,5 @@ const ToolButton = styled("button", {
52
46
  });
53
47
 
54
48
  export {
55
- ToolButton,
49
+ StyledToolButton,
56
50
  };
@@ -0,0 +1,33 @@
1
+ import React, { forwardRef } from "react";
2
+
3
+ import { useForwardedRef } from "@bedrock-layout/use-forwarded-ref";
4
+
5
+ import { useRipple } from "../../../utils/useRipple";
6
+ import { StyledToolButton } from "./ToolButton.styled";
7
+
8
+ type Props = React.ComponentProps<typeof StyledToolButton>;
9
+
10
+ const ToolButton = forwardRef<HTMLButtonElement, Props>((props, ref) => {
11
+ const { children, onPointerDown, onKeyDown, ...rest } = props;
12
+ const innerRef = useForwardedRef(ref);
13
+ const ripple = useRipple({ ref: innerRef, onPointerDown, onKeyDown });
14
+
15
+ return (
16
+ <StyledToolButton
17
+ ref={innerRef}
18
+ onPointerDown={ripple.onPointerDown}
19
+ onKeyDown={ripple.onKeyDown}
20
+ {...rest}
21
+ >
22
+ {children}
23
+ {ripple.ripples}
24
+ </StyledToolButton>
25
+ );
26
+ });
27
+
28
+ ToolButton.displayName = "ToolButton";
29
+ ToolButton.toString = () => StyledToolButton.toString();
30
+
31
+ export {
32
+ ToolButton,
33
+ };
@@ -0,0 +1,56 @@
1
+ import { keyframes } from "../theme";
2
+
3
+ const rippleKeyframes = keyframes({
4
+ "0%": { transform: "scale(0)", opacity: 0.35 },
5
+ "100%": { transform: "scale(1)", opacity: 0 },
6
+ });
7
+
8
+ /**
9
+ * Use with Stitches `styled(...)` definition to make the element a ripple host.
10
+ * Pair with `useRipple()` which provides handlers and rendered ripple spans.
11
+ *
12
+ * Sets `position: relative` and `overflow: hidden` on the host.
13
+ *
14
+ * To disable the effect for an element or whole subtree, set the CSS variable
15
+ * `--miui-ripple: 0` on the element or any ancestor. The hover/active overlay
16
+ * opacity is multiplied by this var and the JS hook skips ripple creation when
17
+ * it reads `0`.
18
+ */
19
+ const rippleHostStyles = {
20
+ "position": "relative",
21
+ "overflow": "hidden",
22
+ "WebkitTapHighlightColor": "transparent",
23
+ "transition": "box-shadow 150ms ease-out",
24
+
25
+ // Subtle hover/active overlay so interactive elements look clickable.
26
+ // Scoped to `a`/`button` so non-interactive hosts (e.g. List.Item rendered
27
+ // as <div>) don't get false affordances. `:active` also serves as the
28
+ // minimal feedback for users with `prefers-reduced-motion: reduce`,
29
+ // who don't see the ripple.
30
+ "&:where(a, button):hover:not(:disabled):not([aria-disabled='true'])": {
31
+ boxShadow: "inset 0 0 0 9999px color-mix(in srgb, currentColor calc(6% * var(--miui-ripple, 1)), transparent)",
32
+ },
33
+ "&:where(a, button):active:not(:disabled):not([aria-disabled='true'])": {
34
+ boxShadow: "inset 0 0 0 9999px color-mix(in srgb, currentColor calc(12% * var(--miui-ripple, 1)), transparent)",
35
+ },
36
+
37
+ "@media (prefers-reduced-motion: reduce)": {
38
+ transition: "none",
39
+ },
40
+
41
+ "& > span[data-miui-ripple]": {
42
+ position: "absolute",
43
+ pointerEvents: "none",
44
+ borderRadius: "50%",
45
+ backgroundColor: "currentColor",
46
+ transform: "scale(0)",
47
+ opacity: 0,
48
+ animationName: String(rippleKeyframes),
49
+ animationTimingFunction: "ease-out",
50
+ animationFillMode: "forwards",
51
+ },
52
+ };
53
+
54
+ export {
55
+ rippleHostStyles,
56
+ };
@@ -0,0 +1,139 @@
1
+ import React, { useCallback, useRef, useState } from "react";
2
+
3
+ type Ripple = {
4
+ id: number;
5
+ x: number;
6
+ y: number;
7
+ size: number;
8
+ duration: number;
9
+ };
10
+
11
+ const HALF = 2;
12
+ const RIPPLE_SPEED_PX_PER_MS = 1.5;
13
+ const RIPPLE_MIN_DURATION_MS = 250;
14
+
15
+ const prefersReducedMotion = (): boolean => {
16
+ if (typeof window === "undefined") {
17
+ return false;
18
+ }
19
+ return window.matchMedia("(prefers-reduced-motion: reduce)").matches;
20
+ };
21
+
22
+ const isDisabled = (el: HTMLElement): boolean => {
23
+ if ("disabled" in el && (el as HTMLButtonElement).disabled) {
24
+ return true;
25
+ }
26
+ return el.getAttribute("aria-disabled") === "true";
27
+ };
28
+
29
+ const isRippleDisabledByCssVar = (el: HTMLElement): boolean => {
30
+ if (typeof window === "undefined") {
31
+ return false;
32
+ }
33
+ return window.getComputedStyle(el).getPropertyValue("--miui-ripple").trim() === "0";
34
+ };
35
+
36
+ type UseRippleArgs<T extends HTMLElement> = {
37
+ ref: React.RefObject<T | null>;
38
+ onPointerDown?: React.PointerEventHandler<T> | undefined;
39
+ onKeyDown?: React.KeyboardEventHandler<T> | undefined;
40
+ /**
41
+ * If true, the ripple always emanates from the element's center,
42
+ * regardless of pointer position.
43
+ */
44
+ fromCenter?: boolean | undefined;
45
+ };
46
+
47
+ type UseRippleResult<T extends HTMLElement> = {
48
+ onPointerDown: React.PointerEventHandler<T>;
49
+ onKeyDown: React.KeyboardEventHandler<T>;
50
+ ripples: React.ReactNode;
51
+ };
52
+
53
+ /**
54
+ * Adds an Android-style ripple effect to an element.
55
+ *
56
+ * Pair with `rippleHostStyles` spread into the host's styled definition.
57
+ *
58
+ * - Triggered by pointer (mouse/touch/pen) and keyboard (Enter/Space — emanates from center).
59
+ * - Skipped when the host is `disabled` / `aria-disabled` or when `prefers-reduced-motion: reduce`.
60
+ * - Ripple duration scales with size (constant px/ms) so big and small elements feel the same.
61
+ */
62
+ // eslint-disable-next-line max-lines-per-function
63
+ const useRipple = <T extends HTMLElement>(args: UseRippleArgs<T>): UseRippleResult<T> => {
64
+ const { ref, onPointerDown, onKeyDown, fromCenter = false } = args;
65
+ const [ripples, setRipples] = useState<Ripple[]>([]);
66
+ const idCounter = useRef(0);
67
+
68
+ const addRippleAt = useCallback((clientX: number, clientY: number) => {
69
+ const el = ref.current;
70
+ if (!el || isDisabled(el) || prefersReducedMotion() || isRippleDisabledByCssVar(el)) {
71
+ return;
72
+ }
73
+ const rect = el.getBoundingClientRect();
74
+ const x = clientX - rect.left;
75
+ const y = clientY - rect.top;
76
+ const maxX = Math.max(x, rect.width - x);
77
+ const maxY = Math.max(y, rect.height - y);
78
+ const size = Math.hypot(maxX, maxY) * HALF;
79
+ const duration = Math.max(RIPPLE_MIN_DURATION_MS, size / RIPPLE_SPEED_PX_PER_MS);
80
+ idCounter.current += 1;
81
+ const id = idCounter.current;
82
+ setRipples((arr) => [...arr, { id, x, y, size, duration }]);
83
+ }, [ref]);
84
+
85
+ const handlePointerDown = useCallback<React.PointerEventHandler<T>>((evt) => {
86
+ if (fromCenter) {
87
+ const el = ref.current;
88
+ if (el) {
89
+ const rect = el.getBoundingClientRect();
90
+ addRippleAt(rect.left + (rect.width / HALF), rect.top + (rect.height / HALF));
91
+ }
92
+ }
93
+ else {
94
+ addRippleAt(evt.clientX, evt.clientY);
95
+ }
96
+ onPointerDown?.(evt);
97
+ }, [addRippleAt, onPointerDown, fromCenter, ref]);
98
+
99
+ const handleKeyDown = useCallback<React.KeyboardEventHandler<T>>((evt) => {
100
+ if (!evt.repeat && (evt.key === "Enter" || evt.key === " ")) {
101
+ const el = ref.current;
102
+ if (el) {
103
+ const rect = el.getBoundingClientRect();
104
+ addRippleAt(rect.left + (rect.width / HALF), rect.top + (rect.height / HALF));
105
+ }
106
+ }
107
+ onKeyDown?.(evt);
108
+ }, [addRippleAt, ref, onKeyDown]);
109
+
110
+ const handleAnimationEnd = useCallback<React.AnimationEventHandler<HTMLSpanElement>>((evt) => {
111
+ const id = Number(evt.currentTarget.dataset.rippleId);
112
+ setRipples((arr) => arr.filter((r) => r.id !== id));
113
+ }, []);
114
+
115
+ const elements = ripples.map((r) => (
116
+ <span
117
+ key={r.id}
118
+ data-miui-ripple={true}
119
+ data-ripple-id={r.id}
120
+ aria-hidden={true}
121
+ style={{
122
+ left: `${String(r.x - (r.size / HALF))}px`,
123
+ top: `${String(r.y - (r.size / HALF))}px`,
124
+ width: `${String(r.size)}px`,
125
+ height: `${String(r.size)}px`,
126
+ animationDuration: `${String(r.duration)}ms`,
127
+ }}
128
+ onAnimationEnd={handleAnimationEnd}
129
+ />
130
+ ));
131
+
132
+ return {
133
+ onPointerDown: handlePointerDown,
134
+ onKeyDown: handleKeyDown,
135
+ ripples: elements,
136
+ };
137
+ };
138
+
139
+ export { useRipple };
@@ -1 +0,0 @@
1
- export { ToolButton } from "./ToolButton.styled";