reshaped 3.3.11 → 3.3.13

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 (253) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/dist/bundle.css +1 -1
  3. package/dist/bundle.d.ts +1 -1
  4. package/dist/bundle.js +16 -17
  5. package/dist/cjs/themes/_generator/utilities/generateColors.d.ts +1 -1
  6. package/dist/cjs/themes/_generator/utilities/generateColors.js +3 -2
  7. package/dist/cjs/themes/_generator/utilities/tests/color.test.js +32 -31
  8. package/dist/cjs/themes/slate/theme.css +1 -1
  9. package/dist/components/Accordion/tests/Accordion.stories.d.ts +30 -8
  10. package/dist/components/Accordion/tests/Accordion.stories.js +172 -119
  11. package/dist/components/ActionBar/tests/ActionBar.stories.d.ts +12 -3
  12. package/dist/components/ActionBar/tests/ActionBar.stories.js +51 -36
  13. package/dist/components/ActionBar/tests/ActionBar.test.stories.d.ts +15 -0
  14. package/dist/components/ActionBar/tests/ActionBar.test.stories.js +26 -0
  15. package/dist/components/Actionable/Actionable.js +1 -1
  16. package/dist/components/Actionable/tests/Actionable.stories.d.ts +19 -5
  17. package/dist/components/Actionable/tests/Actionable.stories.js +88 -63
  18. package/dist/components/Actionable/tests/Actionable.test.stories.d.ts +32 -0
  19. package/dist/components/Actionable/tests/Actionable.test.stories.js +130 -0
  20. package/dist/components/Alert/Alert.js +1 -1
  21. package/dist/components/Alert/tests/Alert.stories.d.ts +12 -3
  22. package/dist/components/Alert/tests/Alert.stories.js +51 -86
  23. package/dist/components/Alert/tests/Alert.test.stories.d.ts +15 -0
  24. package/dist/components/Alert/tests/Alert.test.stories.js +26 -0
  25. package/dist/components/Autocomplete/Autocomplete.js +9 -2
  26. package/dist/components/Autocomplete/tests/Autocomplete.stories.d.ts +6 -2
  27. package/dist/components/Autocomplete/tests/Autocomplete.stories.js +94 -111
  28. package/dist/components/Autocomplete/tests/Autocomplete.test.stories.d.ts +23 -0
  29. package/dist/components/Autocomplete/tests/Autocomplete.test.stories.js +86 -0
  30. package/dist/components/Avatar/Avatar.js +1 -1
  31. package/dist/components/Avatar/tests/Avatar.stories.d.ts +14 -4
  32. package/dist/components/Avatar/tests/Avatar.stories.js +94 -80
  33. package/dist/components/Avatar/tests/Avatar.test.stories.d.ts +17 -0
  34. package/dist/components/Avatar/tests/Avatar.test.stories.js +39 -0
  35. package/dist/components/Badge/tests/Badge.stories.d.ts +33 -8
  36. package/dist/components/Badge/tests/Badge.stories.js +238 -212
  37. package/dist/components/Badge/tests/Badge.test.stories.d.ts +20 -0
  38. package/dist/components/Badge/tests/Badge.test.stories.js +44 -0
  39. package/dist/components/Breadcrumbs/Breadcrumbs.js +2 -2
  40. package/dist/components/Breadcrumbs/Breadcrumbs.types.d.ts +1 -0
  41. package/dist/components/Breadcrumbs/tests/Breadcrumbs.stories.d.ts +24 -5
  42. package/dist/components/Breadcrumbs/tests/Breadcrumbs.stories.js +114 -95
  43. package/dist/components/Breadcrumbs/tests/Breadcrumbs.test.stories.d.ts +23 -0
  44. package/dist/components/Breadcrumbs/tests/Breadcrumbs.test.stories.js +76 -0
  45. package/dist/components/Button/Button.js +5 -2
  46. package/dist/components/Button/Button.module.css +1 -1
  47. package/dist/components/Button/Button.types.d.ts +1 -0
  48. package/dist/components/Button/tests/Button.stories.d.ts +2 -2
  49. package/dist/components/Button/tests/Button.stories.js +77 -74
  50. package/dist/components/Button/tests/Button.test.stories.d.ts +27 -0
  51. package/dist/components/Button/tests/Button.test.stories.js +112 -0
  52. package/dist/components/Calendar/tests/Calendar.test.stories.d.ts +26 -0
  53. package/dist/components/Calendar/tests/Calendar.test.stories.js +161 -0
  54. package/dist/components/Card/tests/Card.stories.d.ts +0 -1
  55. package/dist/components/Card/tests/Card.stories.js +0 -11
  56. package/dist/components/Card/tests/Card.test.stories.d.ts +35 -0
  57. package/dist/components/Card/tests/Card.test.stories.js +54 -0
  58. package/dist/components/Carousel/Carousel.js +52 -4
  59. package/dist/components/Carousel/Carousel.types.d.ts +4 -0
  60. package/dist/components/Carousel/CarouselControl.js +1 -1
  61. package/dist/components/Carousel/tests/Carousel.stories.d.ts +23 -4
  62. package/dist/components/Carousel/tests/Carousel.stories.js +199 -102
  63. package/dist/components/Checkbox/tests/Checkbox.test.stories.d.ts +25 -0
  64. package/dist/components/Checkbox/tests/Checkbox.test.stories.js +104 -0
  65. package/dist/components/CheckboxGroup/tests/CheckboxGroup.test.stories.d.ts +22 -0
  66. package/dist/components/CheckboxGroup/tests/CheckboxGroup.test.stories.js +78 -0
  67. package/dist/components/Container/tests/Container.stories.d.ts +12 -3
  68. package/dist/components/Container/tests/Container.stories.js +50 -31
  69. package/dist/components/Container/tests/Container.test.stories.d.ts +15 -0
  70. package/dist/components/Container/tests/Container.test.stories.js +26 -0
  71. package/dist/components/ContextMenu/ContextMenu.js +13 -9
  72. package/dist/components/ContextMenu/tests/ContextMenu.stories.js +2 -3
  73. package/dist/components/ContextMenu/tests/ContextMenu.test.stories.d.ts +26 -0
  74. package/dist/components/ContextMenu/tests/ContextMenu.test.stories.js +53 -0
  75. package/dist/components/Dismissible/Dismissible.js +1 -1
  76. package/dist/components/Dismissible/tests/Dismissible.stories.d.ts +10 -3
  77. package/dist/components/Dismissible/tests/Dismissible.stories.js +51 -34
  78. package/dist/components/Dismissible/tests/Dismissible.test.stories.d.ts +19 -0
  79. package/dist/components/Dismissible/tests/Dismissible.test.stories.js +42 -0
  80. package/dist/components/Divider/tests/Divider.test.stories.d.ts +18 -0
  81. package/dist/components/Divider/tests/Divider.test.stories.js +47 -0
  82. package/dist/components/DropdownMenu/tests/DropdownMenu.test.stories.d.ts +37 -0
  83. package/dist/components/DropdownMenu/tests/DropdownMenu.test.stories.js +117 -0
  84. package/dist/components/FileUpload/tests/FileUpload.test.stories.d.ts +22 -0
  85. package/dist/components/FileUpload/tests/FileUpload.test.stories.js +52 -0
  86. package/dist/components/FormControl/FormControlCaption.js +1 -1
  87. package/dist/components/FormControl/FormControlLabel.js +1 -1
  88. package/dist/components/FormControl/tests/FormControl.stories.d.ts +11 -5
  89. package/dist/components/FormControl/tests/FormControl.stories.js +78 -73
  90. package/dist/components/FormControl/tests/FormControl.test.stories.d.ts +20 -0
  91. package/dist/components/FormControl/tests/FormControl.test.stories.js +49 -0
  92. package/dist/components/Grid/tests/Grid.stories.d.ts +20 -5
  93. package/dist/components/Grid/tests/Grid.stories.js +164 -149
  94. package/dist/components/Grid/tests/Grid.test.stories.d.ts +19 -0
  95. package/dist/components/Grid/tests/Grid.test.stories.js +42 -0
  96. package/dist/components/Hidden/tests/Hidden.stories.d.ts +4 -1
  97. package/dist/components/Hidden/tests/Hidden.stories.js +28 -25
  98. package/dist/components/Hidden/tests/Hidden.test.stories.d.ts +15 -0
  99. package/dist/components/Hidden/tests/Hidden.test.stories.js +20 -0
  100. package/dist/components/HiddenVisually/tests/HiddenVisually.stories.d.ts +4 -1
  101. package/dist/components/HiddenVisually/tests/HiddenVisually.stories.js +8 -5
  102. package/dist/components/HiddenVisually/tests/HiddenVisually.test.stories.d.ts +15 -0
  103. package/dist/components/HiddenVisually/tests/HiddenVisually.test.stories.js +20 -0
  104. package/dist/components/Hotkey/tests/Hotkey.test.stories.d.ts +15 -0
  105. package/dist/components/Hotkey/tests/Hotkey.test.stories.js +26 -0
  106. package/dist/components/Icon/tests/Icon.stories.d.ts +12 -3
  107. package/dist/components/Icon/tests/Icon.stories.js +69 -60
  108. package/dist/components/Icon/tests/Icon.test.stories.d.ts +16 -0
  109. package/dist/components/Icon/tests/Icon.test.stories.js +35 -0
  110. package/dist/components/Image/tests/Image.stories.d.ts +24 -5
  111. package/dist/components/Image/tests/Image.stories.js +95 -75
  112. package/dist/components/Image/tests/Image.test.stories.d.ts +25 -0
  113. package/dist/components/Image/tests/Image.test.stories.js +80 -0
  114. package/dist/components/Link/tests/Link.test.stories.d.ts +29 -0
  115. package/dist/components/Link/tests/Link.test.stories.js +87 -0
  116. package/dist/components/Loader/Loader.js +1 -1
  117. package/dist/components/Loader/Loader.types.d.ts +1 -0
  118. package/dist/components/Loader/tests/Loader.stories.js +8 -8
  119. package/dist/components/Loader/tests/Loader.test.stories.d.ts +16 -0
  120. package/dist/components/Loader/tests/Loader.test.stories.js +32 -0
  121. package/dist/components/MenuItem/tests/MenuItem.test.stories.d.ts +26 -0
  122. package/dist/components/MenuItem/tests/MenuItem.test.stories.js +100 -0
  123. package/dist/components/Modal/tests/Modal.test.stories.d.ts +32 -0
  124. package/dist/components/Modal/tests/Modal.test.stories.js +149 -0
  125. package/dist/components/Overlay/tests/Overlay.stories.d.ts +4 -2
  126. package/dist/components/Overlay/tests/Overlay.stories.js +53 -53
  127. package/dist/components/Overlay/tests/Overlay.test.stories.d.ts +28 -0
  128. package/dist/components/Overlay/tests/Overlay.test.stories.js +146 -0
  129. package/dist/components/Pagination/tests/Pagination.test.stories.d.ts +23 -0
  130. package/dist/components/Pagination/tests/Pagination.test.stories.js +86 -0
  131. package/dist/components/PinField/tests/PinField.stories.d.ts +0 -1
  132. package/dist/components/PinField/tests/PinField.stories.js +10 -19
  133. package/dist/components/PinField/tests/PinField.test.stories.d.ts +29 -0
  134. package/dist/components/PinField/tests/PinField.test.stories.js +177 -0
  135. package/dist/components/Popover/tests/Popover.test.stories.d.ts +40 -0
  136. package/dist/components/Popover/tests/Popover.test.stories.js +167 -0
  137. package/dist/components/Progress/Progress.js +2 -2
  138. package/dist/components/Progress/Progress.types.d.ts +1 -0
  139. package/dist/components/Progress/tests/Progress.stories.js +10 -10
  140. package/dist/components/Progress/tests/Progress.test.stories.d.ts +16 -0
  141. package/dist/components/Progress/tests/Progress.test.stories.js +35 -0
  142. package/dist/components/Radio/tests/Radio.test.stories.d.ts +30 -0
  143. package/dist/components/Radio/tests/Radio.test.stories.js +118 -0
  144. package/dist/components/RadioGroup/tests/RadioGroup.test.stories.d.ts +22 -0
  145. package/dist/components/RadioGroup/tests/RadioGroup.test.stories.js +78 -0
  146. package/dist/components/Reshaped/tests/Reshaped.stories.d.ts +33 -0
  147. package/dist/components/Reshaped/tests/Reshaped.stories.js +88 -0
  148. package/dist/components/Resizable/Resizable.js +1 -0
  149. package/dist/components/Resizable/tests/Resizable.stories.d.ts +3 -0
  150. package/dist/components/Resizable/tests/Resizable.stories.js +4 -0
  151. package/dist/components/Resizable/tests/Resizable.test.stories.d.ts +19 -0
  152. package/dist/components/Resizable/tests/Resizable.test.stories.js +25 -0
  153. package/dist/components/Scrim/tests/Scrim.test.stories.d.ts +15 -0
  154. package/dist/components/Scrim/tests/Scrim.test.stories.js +25 -0
  155. package/dist/components/ScrollArea/ScrollArea.js +1 -1
  156. package/dist/components/ScrollArea/ScrollArea.module.css +1 -1
  157. package/dist/components/ScrollArea/tests/ScrollArea.stories.d.ts +17 -4
  158. package/dist/components/ScrollArea/tests/ScrollArea.stories.js +114 -139
  159. package/dist/components/ScrollArea/tests/ScrollArea.test.stories.d.ts +23 -0
  160. package/dist/components/ScrollArea/tests/ScrollArea.test.stories.js +66 -0
  161. package/dist/components/Select/tests/Select.stories.d.ts +1 -1
  162. package/dist/components/Select/tests/Select.stories.js +5 -12
  163. package/dist/components/Select/tests/Select.test.stories.d.ts +27 -0
  164. package/dist/components/Select/tests/Select.test.stories.js +132 -0
  165. package/dist/components/Skeleton/tests/Skeleton.test.stories.d.ts +15 -0
  166. package/dist/components/Skeleton/tests/Skeleton.test.stories.js +23 -0
  167. package/dist/components/Slider/tests/Slider.stories.d.ts +0 -1
  168. package/dist/components/Slider/tests/Slider.stories.js +8 -9
  169. package/dist/components/Slider/tests/Slider.test.stories.d.ts +38 -0
  170. package/dist/components/Slider/tests/Slider.test.stories.js +150 -0
  171. package/dist/components/Stepper/Stepper.js +1 -1
  172. package/dist/components/Stepper/tests/Stepper.stories.js +0 -3
  173. package/dist/components/Stepper/tests/Stepper.test.stories.d.ts +18 -0
  174. package/dist/components/Stepper/tests/Stepper.test.stories.js +28 -0
  175. package/dist/components/Switch/tests/Switch.test.stories.d.ts +23 -0
  176. package/dist/components/Switch/tests/Switch.test.stories.js +79 -0
  177. package/dist/components/Table/index.d.ts +1 -1
  178. package/dist/components/Table/tests/Table.stories.d.ts +5 -5
  179. package/dist/components/Table/tests/Table.test.stories.d.ts +25 -0
  180. package/dist/components/Table/tests/Table.test.stories.js +93 -0
  181. package/dist/components/Tabs/tests/Tabs.stories.js +4 -4
  182. package/dist/components/Tabs/tests/Tabs.test.stories.d.ts +28 -0
  183. package/dist/components/Tabs/tests/Tabs.test.stories.js +128 -0
  184. package/dist/components/Text/tests/Text.stories.d.ts +28 -7
  185. package/dist/components/Text/tests/Text.stories.js +148 -125
  186. package/dist/components/Text/tests/Text.test.stories.d.ts +18 -0
  187. package/dist/components/Text/tests/Text.test.stories.js +49 -0
  188. package/dist/components/TextArea/TextArea.module.css +1 -1
  189. package/dist/components/TextArea/tests/TextArea.stories.js +1 -1
  190. package/dist/components/TextArea/tests/TextArea.test.stories.d.ts +29 -0
  191. package/dist/components/TextArea/tests/TextArea.test.stories.js +99 -0
  192. package/dist/components/TextField/tests/TextField.stories.js +1 -1
  193. package/dist/components/TextField/tests/TextField.test.stories.d.ts +29 -0
  194. package/dist/components/TextField/tests/TextField.test.stories.js +99 -0
  195. package/dist/components/Theme/tests/Theme.test.stories.d.ts +24 -0
  196. package/dist/components/Theme/tests/Theme.test.stories.js +133 -0
  197. package/dist/components/Timeline/tests/Timeline.test.stories.d.ts +18 -0
  198. package/dist/components/Timeline/tests/Timeline.test.stories.js +32 -0
  199. package/dist/components/Toast/tests/Toast.test.stories.d.ts +16 -0
  200. package/dist/components/Toast/tests/Toast.test.stories.js +101 -0
  201. package/dist/components/Tooltip/tests/Tooltip.stories.js +0 -14
  202. package/dist/components/Tooltip/tests/Tooltip.test.stories.d.ts +19 -0
  203. package/dist/components/Tooltip/tests/Tooltip.test.stories.js +40 -0
  204. package/dist/components/View/View.js +1 -2
  205. package/dist/components/View/tests/View.stories.d.ts +112 -28
  206. package/dist/components/View/tests/View.stories.js +1092 -1012
  207. package/dist/components/View/tests/View.test.stories.d.ts +20 -0
  208. package/dist/components/View/tests/View.test.stories.js +50 -0
  209. package/dist/components/_private/Flyout/FlyoutContent.js +1 -1
  210. package/dist/components/_private/Flyout/tests/Flyout.stories.js +4 -4
  211. package/dist/components/_private/Flyout/tests/Flyout.test.stories.d.ts +28 -0
  212. package/dist/components/_private/Flyout/tests/Flyout.test.stories.js +205 -0
  213. package/dist/components/_private/Portal/tests/Portal.stories.js +1 -1
  214. package/dist/hooks/_private/useSingletonHotkeys.d.ts +3 -3
  215. package/dist/hooks/_private/useSingletonHotkeys.js +1 -1
  216. package/dist/hooks/tests/useDrag.stories.js +1 -0
  217. package/dist/hooks/tests/useDrag.test.stories.d.ts +26 -0
  218. package/dist/hooks/tests/useDrag.test.stories.js +120 -0
  219. package/dist/hooks/tests/useElementId.stories.d.ts +6 -0
  220. package/dist/hooks/tests/useElementId.stories.js +19 -0
  221. package/dist/hooks/tests/useHotkeys.test.stories.d.ts +39 -0
  222. package/dist/hooks/tests/useHotkeys.test.stories.js +119 -0
  223. package/dist/hooks/tests/useRTL.stories.d.ts +6 -0
  224. package/dist/hooks/tests/useRTL.stories.js +25 -0
  225. package/dist/hooks/tests/useResponsiveClientValue.stories.d.ts +9 -1
  226. package/dist/hooks/tests/useResponsiveClientValue.stories.js +22 -9
  227. package/dist/hooks/tests/useScrollLock.stories.d.ts +6 -0
  228. package/dist/hooks/tests/useScrollLock.stories.js +22 -0
  229. package/dist/hooks/tests/useToggle.stories.d.ts +8 -0
  230. package/dist/hooks/tests/useToggle.stories.js +54 -0
  231. package/dist/hooks/useHotkeys.js +0 -2
  232. package/dist/hooks/useScrollLock.d.ts +1 -0
  233. package/dist/hooks/useScrollLock.js +7 -3
  234. package/dist/index.d.ts +1 -1
  235. package/dist/tests/ShadowDOM.stories.js +1 -1
  236. package/dist/themes/_generator/tests/themes.stories.d.ts +3 -0
  237. package/dist/themes/_generator/tests/themes.stories.js +7 -11
  238. package/dist/themes/_generator/utilities/generateColors.d.ts +1 -1
  239. package/dist/themes/_generator/utilities/generateColors.js +3 -2
  240. package/dist/themes/slate/theme.css +1 -1
  241. package/dist/utilities/helpers.d.ts +1 -0
  242. package/dist/utilities/helpers.js +3 -0
  243. package/dist/utilities/scroll/lock.d.ts +1 -0
  244. package/dist/utilities/scroll/lock.js +3 -3
  245. package/dist/utilities/scroll/lockSafari.d.ts +1 -1
  246. package/dist/utilities/scroll/lockSafari.js +4 -5
  247. package/dist/utilities/scroll/lockStandard.d.ts +4 -1
  248. package/dist/utilities/scroll/lockStandard.js +7 -2
  249. package/dist/utilities/storybook/Example.js +1 -2
  250. package/package.json +42 -41
  251. package/dist/components/Theme/tests/Theme.stories.d.ts +0 -13
  252. package/dist/components/Theme/tests/Theme.stories.js +0 -80
  253. package/dist/utilities/storybook/Example.module.css +0 -1
@@ -9,42 +9,57 @@ export default {
9
9
  },
10
10
  },
11
11
  };
12
- export const position = () => (<Example>
13
- <Example.Item title="position: top">
14
- <ActionBar position="top">
15
- <Placeholder />
16
- </ActionBar>
17
- </Example.Item>
12
+ export const position = {
13
+ name: "position",
14
+ render: () => (<Example>
15
+ <Example.Item title="position: top">
16
+ <ActionBar position="top">
17
+ <Placeholder />
18
+ </ActionBar>
19
+ </Example.Item>
18
20
 
19
- <Example.Item title="position: bottom">
20
- <ActionBar>
21
- <Placeholder />
22
- </ActionBar>
23
- </Example.Item>
24
- </Example>);
25
- export const elevated = () => (<Example>
26
- <Example.Item title="elevated, position: top">
27
- <ActionBar position="top" elevated>
28
- <Placeholder />
29
- </ActionBar>
30
- </Example.Item>
21
+ <Example.Item title="position: bottom">
22
+ <ActionBar>
23
+ <Placeholder />
24
+ </ActionBar>
25
+ </Example.Item>
26
+ </Example>),
27
+ };
28
+ export const elevated = {
29
+ name: "elevated",
30
+ render: () => (<Example>
31
+ <Example.Item title="elevated, position: top">
32
+ <ActionBar position="top" elevated>
33
+ <Placeholder />
34
+ </ActionBar>
35
+ </Example.Item>
36
+
37
+ <Example.Item title="elevated, position: bottom">
38
+ <ActionBar elevated>
39
+ <Placeholder />
40
+ </ActionBar>
41
+ </Example.Item>
42
+ </Example>),
43
+ };
44
+ export const padding = {
45
+ name: "padding, paddingBlock, paddingInline",
46
+ render: () => (<Example>
47
+ <Example.Item title="padding: 6">
48
+ <ActionBar padding={6}>
49
+ <Placeholder />
50
+ </ActionBar>
51
+ </Example.Item>
31
52
 
32
- <Example.Item title="elevated, position: bottom">
33
- <ActionBar elevated>
34
- <Placeholder h={16}/>
35
- </ActionBar>
36
- </Example.Item>
37
- </Example>);
38
- export const padding = () => (<Example>
39
- <Example.Item title="padding: 6">
40
- <ActionBar padding={6}>
41
- <Placeholder />
42
- </ActionBar>
43
- </Example.Item>
53
+ <Example.Item title="paddingBlock: 2, paddingInline: 4">
54
+ <ActionBar paddingBlock={2} paddingInline={4}>
55
+ <Placeholder />
56
+ </ActionBar>
57
+ </Example.Item>
44
58
 
45
- <Example.Item title={["padding: responsive", "[s] 4", "[m+] 6"]}>
46
- <ActionBar padding={{ s: 4, m: 6 }}>
47
- <Placeholder />
48
- </ActionBar>
49
- </Example.Item>
50
- </Example>);
59
+ <Example.Item title="padding: [s] 4, [m+] 6">
60
+ <ActionBar padding={{ s: 4, m: 6 }}>
61
+ <Placeholder />
62
+ </ActionBar>
63
+ </Example.Item>
64
+ </Example>),
65
+ };
@@ -0,0 +1,15 @@
1
+ import { StoryObj } from "@storybook/react";
2
+ declare const _default: {
3
+ title: string;
4
+ component: (props: import("./..").ActionBarProps) => import("react").JSX.Element;
5
+ parameters: {
6
+ iframe: {
7
+ url: string;
8
+ };
9
+ chromatic: {
10
+ disableSnapshot: boolean;
11
+ };
12
+ };
13
+ };
14
+ export default _default;
15
+ export declare const className: StoryObj;
@@ -0,0 +1,26 @@
1
+ import { expect } from "@storybook/test";
2
+ import ActionBar from "../index.js";
3
+ import { Placeholder } from "../../../utilities/storybook/index.js";
4
+ export default {
5
+ title: "Components/ActionBar/tests",
6
+ component: ActionBar,
7
+ parameters: {
8
+ iframe: {
9
+ url: "https://reshaped.so/docs/components/action-bar",
10
+ },
11
+ chromatic: { disableSnapshot: true },
12
+ },
13
+ };
14
+ export const className = {
15
+ name: "className, attributes",
16
+ render: () => (<div data-testid="root">
17
+ <ActionBar className="test-classname" attributes={{ id: "test-id" }}>
18
+ <Placeholder />
19
+ </ActionBar>
20
+ </div>),
21
+ play: async ({ canvas }) => {
22
+ const root = canvas.getByTestId("root").firstChild;
23
+ expect(root).toHaveClass("test-classname");
24
+ expect(root).toHaveAttribute("id", "test-id");
25
+ },
26
+ };
@@ -55,6 +55,6 @@ const Actionable = forwardRef((props, ref) => {
55
55
  event.preventDefault();
56
56
  handlePress(event);
57
57
  };
58
- return (_jsx(TagName, { ref: ref, ...rootAttributes, className: rootClassNames, onClick: handlePress, onKeyDown: handleKeyDown, children: children }));
58
+ return (_jsx(TagName, { ref: ref, ...rootAttributes, "aria-disabled": disabled ? true : undefined, className: rootClassNames, onClick: handlePress, onKeyDown: handleKeyDown, children: children }));
59
59
  });
60
60
  export default Actionable;
@@ -1,3 +1,4 @@
1
+ import { StoryObj } from "@storybook/react";
1
2
  declare const _default: {
2
3
  title: string;
3
4
  component: import("react").ForwardRefExoticComponent<import("./..").ActionableProps & import("react").RefAttributes<HTMLAnchorElement | HTMLButtonElement>>;
@@ -8,8 +9,21 @@ declare const _default: {
8
9
  };
9
10
  };
10
11
  export default _default;
11
- export declare const role: () => import("react").JSX.Element;
12
- export declare const disabled: () => import("react").JSX.Element;
13
- export declare const fullWidth: () => import("react").JSX.Element;
14
- export declare const focusRing: () => import("react").JSX.Element;
15
- export declare const edgeCases: () => import("react").JSX.Element;
12
+ export declare const base: StoryObj;
13
+ export declare const disabled: StoryObj;
14
+ export declare const fullWidth: StoryObj;
15
+ export declare const insetFocus: {
16
+ name: string;
17
+ render: () => import("react").JSX.Element;
18
+ play: () => Promise<void>;
19
+ };
20
+ export declare const disableFocusRing: {
21
+ name: string;
22
+ render: () => import("react").JSX.Element;
23
+ play: () => Promise<void>;
24
+ };
25
+ export declare const borderRadius: {
26
+ name: string;
27
+ render: () => import("react").JSX.Element;
28
+ play: () => Promise<void>;
29
+ };
@@ -1,5 +1,6 @@
1
- import Actionable from "../index.js";
1
+ import { userEvent, expect } from "@storybook/test";
2
2
  import { Example } from "../../../utilities/storybook/index.js";
3
+ import Actionable from "../index.js";
3
4
  import View from "../../View/index.js";
4
5
  export default {
5
6
  title: "Utilities/Actionable",
@@ -10,66 +11,90 @@ export default {
10
11
  },
11
12
  },
12
13
  };
13
- export const role = () => (<Example>
14
- <Example.Item title="rendered as link">
15
- <Actionable href="https://reshaped.so" attributes={{ target: "_blank" }}>
16
- Actionable
17
- </Actionable>
18
- </Example.Item>
19
- <Example.Item title="rendered as button">
20
- <Actionable onClick={() => console.log("Clicked")}>Actionable</Actionable>
21
- </Example.Item>
22
- <Example.Item title="rendered as div with button role">
23
- <Actionable as="div" onClick={() => console.log("Clicked")}>
24
- Actionable
25
- </Actionable>
26
- </Example.Item>
27
- <Example.Item title="rendered as link with onClick">
28
- <Actionable onClick={() => console.log("Clicked")} href="https://reshaped.so">
29
- Actionable
30
- </Actionable>
31
- </Example.Item>
32
- </Example>);
33
- export const disabled = () => (<Example>
34
- <Example.Item title="disabled, button">
35
- <Actionable disabled onClick={() => { }}>
36
- Actionable
37
- </Actionable>
38
- </Example.Item>
39
- <Example.Item title="disabled, link">
40
- <Actionable disabled href="https://reshaped.so">
41
- Actionable
42
- </Actionable>
43
- </Example.Item>
44
- </Example>);
45
- export const fullWidth = () => (<Example>
46
- <Example.Item title="fullWidth">
47
- <Actionable fullWidth href="https://reshaped.so">
48
- Actionable
49
- </Actionable>
50
- </Example.Item>
51
- </Example>);
52
- export const focusRing = () => (<Example>
53
- <Example.Item title="insetFocus">
54
- <Actionable insetFocus onClick={() => { }}>
55
- Actionable
56
- </Actionable>
57
- </Example.Item>
58
- <Example.Item title="radius: inherit">
59
- <Actionable borderRadius="inherit" onClick={() => { }}>
60
- <View borderRadius="large">Actionable</View>
61
- </Actionable>
62
- </Example.Item>
63
- </Example>);
64
- export const edgeCases = () => (<Example>
65
- <Example.Item title="form submit">
66
- <form onSubmit={(e) => {
67
- e.preventDefault();
68
- alert("Submitted");
69
- }}>
70
- <Actionable type="submit" onClick={() => console.log("Clicked")}>
71
- Submit
14
+ export const base = {
15
+ name: "base",
16
+ render: () => (<Example>
17
+ <Example.Item title="link">
18
+ <Actionable href="https://reshaped.so" attributes={{ target: "_blank" }}>
19
+ Link
20
+ </Actionable>
21
+ </Example.Item>
22
+ <Example.Item title="button">
23
+ <Actionable onClick={() => { }}>Button</Actionable>
24
+ </Example.Item>
25
+ </Example>),
26
+ };
27
+ export const disabled = {
28
+ name: "disabled",
29
+ render: () => (<Example>
30
+ <Example.Item title="disabled, button">
31
+ <Actionable disabled onClick={() => { }}>
32
+ Button
33
+ </Actionable>
34
+ </Example.Item>
35
+ <Example.Item title="disabled, link">
36
+ <Actionable disabled href="https://reshaped.so">
37
+ Link
38
+ </Actionable>
39
+ </Example.Item>
40
+ </Example>),
41
+ play: ({ canvas }) => {
42
+ const button = canvas.getAllByRole("button")[0];
43
+ const link = canvas.getByText("Link");
44
+ expect(button).toBeDisabled();
45
+ expect(link).not.toHaveAttribute("href");
46
+ expect(link).not.toHaveRole("link");
47
+ },
48
+ };
49
+ export const fullWidth = {
50
+ name: "fullWidth",
51
+ render: () => (<Example>
52
+ <Example.Item title="fullWidth">
53
+ <Actionable fullWidth href="https://reshaped.so">
54
+ Actionable
72
55
  </Actionable>
73
- </form>
74
- </Example.Item>
75
- </Example>);
56
+ </Example.Item>
57
+ </Example>),
58
+ play: async () => {
59
+ await userEvent.keyboard("{Tab/}");
60
+ },
61
+ };
62
+ export const insetFocus = {
63
+ name: "insetFocus",
64
+ render: () => (<Example>
65
+ <Example.Item title="insetFocus">
66
+ <Actionable insetFocus onClick={() => { }}>
67
+ Actionable
68
+ </Actionable>
69
+ </Example.Item>
70
+ </Example>),
71
+ play: async () => {
72
+ await userEvent.keyboard("{Tab/}");
73
+ },
74
+ };
75
+ export const disableFocusRing = {
76
+ name: "disableFocusRing",
77
+ render: () => (<Example>
78
+ <Example.Item title="disableFocusRing">
79
+ <Actionable disableFocusRing onClick={() => { }}>
80
+ Actionable
81
+ </Actionable>
82
+ </Example.Item>
83
+ </Example>),
84
+ play: async () => {
85
+ await userEvent.keyboard("{Tab/}");
86
+ },
87
+ };
88
+ export const borderRadius = {
89
+ name: "borderRadius",
90
+ render: () => (<Example>
91
+ <Example.Item title="radius: inherit">
92
+ <Actionable borderRadius="inherit" onClick={() => { }}>
93
+ <View borderRadius="large">Actionable</View>
94
+ </Actionable>
95
+ </Example.Item>
96
+ </Example>),
97
+ play: async () => {
98
+ await userEvent.keyboard("{Tab/}");
99
+ },
100
+ };
@@ -0,0 +1,32 @@
1
+ import { StoryObj } from "@storybook/react";
2
+ import { fn } from "@storybook/test";
3
+ declare const _default: {
4
+ title: string;
5
+ component: import("react").ForwardRefExoticComponent<import("./..").ActionableProps & import("react").RefAttributes<HTMLAnchorElement | HTMLButtonElement>>;
6
+ parameters: {
7
+ iframe: {
8
+ url: string;
9
+ };
10
+ chromatic: {
11
+ disableSnapshot: boolean;
12
+ };
13
+ };
14
+ };
15
+ export default _default;
16
+ export declare const children: StoryObj;
17
+ export declare const href: StoryObj;
18
+ export declare const attributesHref: StoryObj;
19
+ export declare const onClick: StoryObj<{
20
+ handleClick: ReturnType<typeof fn>;
21
+ }>;
22
+ export declare const hrefOnClick: StoryObj<{
23
+ handleClick: ReturnType<typeof fn>;
24
+ }>;
25
+ export declare const as: StoryObj;
26
+ export declare const type: StoryObj<{
27
+ handleSubmit: ReturnType<typeof fn>;
28
+ }>;
29
+ export declare const stopPropagation: StoryObj<{
30
+ handleParentClick: ReturnType<typeof fn>;
31
+ }>;
32
+ export declare const className: StoryObj;
@@ -0,0 +1,130 @@
1
+ import { userEvent, expect, fn } from "@storybook/test";
2
+ import Actionable from "../index.js";
3
+ export default {
4
+ title: "Utilities/Actionable/tests",
5
+ component: Actionable,
6
+ parameters: {
7
+ iframe: {
8
+ url: "https://reshaped.so/docs/utilities/actionable",
9
+ },
10
+ chromatic: { disableSnapshot: true },
11
+ },
12
+ };
13
+ export const children = {
14
+ name: "children",
15
+ render: () => <Actionable>Trigger</Actionable>,
16
+ play: async ({ canvas }) => {
17
+ const el = canvas.getByText("Trigger");
18
+ expect(el).toBeInTheDocument();
19
+ expect(el.tagName).toBe("SPAN");
20
+ },
21
+ };
22
+ export const href = {
23
+ name: "href",
24
+ render: () => <Actionable href="https://reshaped.so">Trigger</Actionable>,
25
+ play: async ({ canvas }) => {
26
+ const el = canvas.getByRole("link");
27
+ expect(el).toHaveAttribute("href", "https://reshaped.so");
28
+ },
29
+ };
30
+ export const attributesHref = {
31
+ name: "attributes.href",
32
+ render: () => <Actionable attributes={{ href: "https://reshaped.so" }}>Trigger</Actionable>,
33
+ play: async ({ canvas }) => {
34
+ const el = canvas.getByRole("link");
35
+ expect(el).toHaveAttribute("href", "https://reshaped.so");
36
+ },
37
+ };
38
+ export const onClick = {
39
+ name: "onClick",
40
+ args: {
41
+ handleClick: fn(),
42
+ },
43
+ render: (args) => <Actionable onClick={args.handleClick}>Trigger</Actionable>,
44
+ play: async ({ canvas, args }) => {
45
+ const { handleClick } = args;
46
+ const el = canvas.getAllByRole("button")[0];
47
+ await userEvent.click(el);
48
+ expect(el).toHaveAttribute("type", "button");
49
+ expect(handleClick).toHaveBeenCalledTimes(1);
50
+ expect(handleClick).toHaveBeenCalledWith(expect.objectContaining({ target: el }));
51
+ },
52
+ };
53
+ export const hrefOnClick = {
54
+ name: "href + onClick",
55
+ args: {
56
+ handleClick: fn(),
57
+ },
58
+ render: (args) => (<Actionable onClick={(e) => {
59
+ e.preventDefault();
60
+ args.handleClick(e);
61
+ }} href="https://reshaped.so">
62
+ Trigger
63
+ </Actionable>),
64
+ play: async ({ canvas, args }) => {
65
+ const { handleClick } = args;
66
+ const el = canvas.getByRole("link");
67
+ await userEvent.click(el);
68
+ expect(el).toHaveAttribute("href", "https://reshaped.so");
69
+ expect(handleClick).toHaveBeenCalledTimes(1);
70
+ expect(handleClick).toHaveBeenCalledWith(expect.objectContaining({ target: el }));
71
+ },
72
+ };
73
+ export const as = {
74
+ name: "as",
75
+ render: () => (<Actionable onClick={() => { }} as="span">
76
+ Trigger
77
+ </Actionable>),
78
+ play: ({ canvas }) => {
79
+ const el = canvas.getAllByRole("button")[0];
80
+ expect(el.tagName).toBe("SPAN");
81
+ },
82
+ };
83
+ export const type = {
84
+ name: "type",
85
+ args: {
86
+ handleSubmit: fn(),
87
+ },
88
+ render: (args) => (<form onSubmit={(e) => {
89
+ e.preventDefault();
90
+ args.handleSubmit();
91
+ }}>
92
+ <Actionable onClick={() => { }} type="submit">
93
+ Trigger
94
+ </Actionable>
95
+ </form>),
96
+ play: async ({ canvas, args }) => {
97
+ const button = canvas.getAllByRole("button")[0];
98
+ await userEvent.click(button);
99
+ expect(args.handleSubmit).toHaveBeenCalledTimes(1);
100
+ },
101
+ };
102
+ export const stopPropagation = {
103
+ name: "stopPropagation",
104
+ args: {
105
+ handleParentClick: fn(),
106
+ },
107
+ render: (args) => (<div onClick={args.handleParentClick}>
108
+ <Actionable stopPropagation onClick={() => { }}>
109
+ Trigger
110
+ </Actionable>
111
+ </div>),
112
+ play: async ({ canvas, args }) => {
113
+ const button = canvas.getAllByRole("button")[0];
114
+ await userEvent.click(button);
115
+ expect(args.handleParentClick).not.toHaveBeenCalled();
116
+ },
117
+ };
118
+ export const className = {
119
+ name: "className, attributes",
120
+ render: () => (<div data-testid="root">
121
+ <Actionable className="test-classname" attributes={{ id: "test-id" }}>
122
+ Trigger
123
+ </Actionable>
124
+ </div>),
125
+ play: async ({ canvas }) => {
126
+ const root = canvas.getByTestId("root").firstChild;
127
+ expect(root).toHaveClass("test-classname");
128
+ expect(root).toHaveAttribute("id", "test-id");
129
+ },
130
+ };
@@ -10,7 +10,7 @@ const Alert = (props) => {
10
10
  if (inline) {
11
11
  return (_jsxs(_Fragment, { children: [title && (_jsx(Text, { variant: "body-3", weight: "medium", as: "span", children: title })), title && children && " ", children && (_jsx(Text, { variant: "body-3", as: "span", children: children }))] }));
12
12
  }
13
- return (_jsxs(View, { gap: 1, children: [title && (_jsx(Text, { variant: "body-3", weight: "medium", children: title })), children && _jsx(Text, { variant: "body-3", children: children })] }));
13
+ return (_jsxs(View, { gap: 1, grow: true, children: [title && (_jsx(Text, { variant: "body-3", weight: "medium", children: title })), children && _jsx(Text, { variant: "body-3", children: children })] }));
14
14
  };
15
15
  const applyActions = (content) => {
16
16
  if (!actionsSlot)
@@ -9,6 +9,15 @@ declare const _default: {
9
9
  };
10
10
  };
11
11
  export default _default;
12
- export declare const color: () => React.JSX.Element;
13
- export declare const inline: () => React.JSX.Element;
14
- export declare const bleed: () => React.JSX.Element;
12
+ export declare const color: {
13
+ name: string;
14
+ render: () => React.JSX.Element;
15
+ };
16
+ export declare const inline: {
17
+ name: string;
18
+ render: () => React.JSX.Element;
19
+ };
20
+ export declare const bleed: {
21
+ name: string;
22
+ render: () => React.JSX.Element;
23
+ };