@transferwise/components 46.103.0 → 46.104.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 (212) hide show
  1. package/build/index.js +2 -0
  2. package/build/index.js.map +1 -1
  3. package/build/index.mjs +1 -0
  4. package/build/index.mjs.map +1 -1
  5. package/build/listItem/AdditionalInfo/ListItemAdditionalInfo.js +56 -0
  6. package/build/listItem/AdditionalInfo/ListItemAdditionalInfo.js.map +1 -0
  7. package/build/listItem/AdditionalInfo/ListItemAdditionalInfo.mjs +54 -0
  8. package/build/listItem/AdditionalInfo/ListItemAdditionalInfo.mjs.map +1 -0
  9. package/build/listItem/AvatarLayout/ListItemAvatarLayout.js +23 -0
  10. package/build/listItem/AvatarLayout/ListItemAvatarLayout.js.map +1 -0
  11. package/build/listItem/AvatarLayout/ListItemAvatarLayout.mjs +21 -0
  12. package/build/listItem/AvatarLayout/ListItemAvatarLayout.mjs.map +1 -0
  13. package/build/listItem/AvatarView/ListItemAvatarView.js +23 -0
  14. package/build/listItem/AvatarView/ListItemAvatarView.js.map +1 -0
  15. package/build/listItem/AvatarView/ListItemAvatarView.mjs +21 -0
  16. package/build/listItem/AvatarView/ListItemAvatarView.mjs.map +1 -0
  17. package/build/listItem/Button/ListItemButton.js +43 -0
  18. package/build/listItem/Button/ListItemButton.js.map +1 -0
  19. package/build/listItem/Button/ListItemButton.mjs +41 -0
  20. package/build/listItem/Button/ListItemButton.mjs.map +1 -0
  21. package/build/listItem/Checkbox/ListItemCheckbox.js +30 -0
  22. package/build/listItem/Checkbox/ListItemCheckbox.js.map +1 -0
  23. package/build/listItem/Checkbox/ListItemCheckbox.mjs +28 -0
  24. package/build/listItem/Checkbox/ListItemCheckbox.mjs.map +1 -0
  25. package/build/listItem/IconButton/ListItemIconButton.js +56 -0
  26. package/build/listItem/IconButton/ListItemIconButton.js.map +1 -0
  27. package/build/listItem/IconButton/ListItemIconButton.mjs +54 -0
  28. package/build/listItem/IconButton/ListItemIconButton.mjs.map +1 -0
  29. package/build/listItem/Image/ListItemImage.js +31 -0
  30. package/build/listItem/Image/ListItemImage.js.map +1 -0
  31. package/build/listItem/Image/ListItemImage.mjs +29 -0
  32. package/build/listItem/Image/ListItemImage.mjs.map +1 -0
  33. package/build/listItem/ListItem.js +309 -0
  34. package/build/listItem/ListItem.js.map +1 -0
  35. package/build/listItem/ListItem.mjs +304 -0
  36. package/build/listItem/ListItem.mjs.map +1 -0
  37. package/build/listItem/ListItemContext.js +8 -0
  38. package/build/listItem/ListItemContext.js.map +1 -0
  39. package/build/listItem/ListItemContext.mjs +6 -0
  40. package/build/listItem/ListItemContext.mjs.map +1 -0
  41. package/build/listItem/Navigation/ListItemNavigation.js +44 -0
  42. package/build/listItem/Navigation/ListItemNavigation.js.map +1 -0
  43. package/build/listItem/Navigation/ListItemNavigation.mjs +42 -0
  44. package/build/listItem/Navigation/ListItemNavigation.mjs.map +1 -0
  45. package/build/listItem/Prompt/ListItemPrompt.js +59 -0
  46. package/build/listItem/Prompt/ListItemPrompt.js.map +1 -0
  47. package/build/listItem/Prompt/ListItemPrompt.mjs +54 -0
  48. package/build/listItem/Prompt/ListItemPrompt.mjs.map +1 -0
  49. package/build/listItem/Radio/ListItemRadio.js +30 -0
  50. package/build/listItem/Radio/ListItemRadio.js.map +1 -0
  51. package/build/listItem/Radio/ListItemRadio.mjs +28 -0
  52. package/build/listItem/Radio/ListItemRadio.mjs.map +1 -0
  53. package/build/listItem/Switch/ListItemSwitch.js +30 -0
  54. package/build/listItem/Switch/ListItemSwitch.js.map +1 -0
  55. package/build/listItem/Switch/ListItemSwitch.mjs +28 -0
  56. package/build/listItem/Switch/ListItemSwitch.mjs.map +1 -0
  57. package/build/listItem/useListItemControl.js +22 -0
  58. package/build/listItem/useListItemControl.js.map +1 -0
  59. package/build/listItem/useListItemControl.mjs +20 -0
  60. package/build/listItem/useListItemControl.mjs.map +1 -0
  61. package/build/listItem/useListItemMedia.js +21 -0
  62. package/build/listItem/useListItemMedia.js.map +1 -0
  63. package/build/listItem/useListItemMedia.mjs +19 -0
  64. package/build/listItem/useListItemMedia.mjs.map +1 -0
  65. package/build/main.css +771 -1
  66. package/build/styles/button/Button.css +1 -1
  67. package/build/styles/listItem/ListItem.css +770 -0
  68. package/build/styles/listItem/ListItem.grid.css +370 -0
  69. package/build/styles/listItem/Prompt/ListItemPrompt.css +157 -0
  70. package/build/styles/main.css +771 -1
  71. package/build/types/index.d.ts +2 -0
  72. package/build/types/index.d.ts.map +1 -1
  73. package/build/types/listItem/AdditionalInfo/ListItemAdditionalInfo.d.ts +15 -0
  74. package/build/types/listItem/AdditionalInfo/ListItemAdditionalInfo.d.ts.map +1 -0
  75. package/build/types/listItem/AdditionalInfo/index.d.ts +3 -0
  76. package/build/types/listItem/AdditionalInfo/index.d.ts.map +1 -0
  77. package/build/types/listItem/AvatarLayout/ListItemAvatarLayout.d.ts +18 -0
  78. package/build/types/listItem/AvatarLayout/ListItemAvatarLayout.d.ts.map +1 -0
  79. package/build/types/listItem/AvatarLayout/index.d.ts +3 -0
  80. package/build/types/listItem/AvatarLayout/index.d.ts.map +1 -0
  81. package/build/types/listItem/AvatarView/ListItemAvatarView.d.ts +16 -0
  82. package/build/types/listItem/AvatarView/ListItemAvatarView.d.ts.map +1 -0
  83. package/build/types/listItem/AvatarView/index.d.ts +3 -0
  84. package/build/types/listItem/AvatarView/index.d.ts.map +1 -0
  85. package/build/types/listItem/Button/ListItemButton.d.ts +20 -0
  86. package/build/types/listItem/Button/ListItemButton.d.ts.map +1 -0
  87. package/build/types/listItem/Button/index.d.ts +3 -0
  88. package/build/types/listItem/Button/index.d.ts.map +1 -0
  89. package/build/types/listItem/Checkbox/ListItemCheckbox.d.ts +14 -0
  90. package/build/types/listItem/Checkbox/ListItemCheckbox.d.ts.map +1 -0
  91. package/build/types/listItem/Checkbox/index.d.ts +3 -0
  92. package/build/types/listItem/Checkbox/index.d.ts.map +1 -0
  93. package/build/types/listItem/IconButton/ListItemIconButton.d.ts +18 -0
  94. package/build/types/listItem/IconButton/ListItemIconButton.d.ts.map +1 -0
  95. package/build/types/listItem/IconButton/index.d.ts +3 -0
  96. package/build/types/listItem/IconButton/index.d.ts.map +1 -0
  97. package/build/types/listItem/Image/ListItemImage.d.ts +25 -0
  98. package/build/types/listItem/Image/ListItemImage.d.ts.map +1 -0
  99. package/build/types/listItem/Image/index.d.ts +3 -0
  100. package/build/types/listItem/Image/index.d.ts.map +1 -0
  101. package/build/types/listItem/ListItem.d.ts +111 -0
  102. package/build/types/listItem/ListItem.d.ts.map +1 -0
  103. package/build/types/listItem/ListItemContext.d.ts +21 -0
  104. package/build/types/listItem/ListItemContext.d.ts.map +1 -0
  105. package/build/types/listItem/Navigation/ListItemNavigation.d.ts +15 -0
  106. package/build/types/listItem/Navigation/ListItemNavigation.d.ts.map +1 -0
  107. package/build/types/listItem/Navigation/index.d.ts +3 -0
  108. package/build/types/listItem/Navigation/index.d.ts.map +1 -0
  109. package/build/types/listItem/Prompt/ListItemPrompt.d.ts +16 -0
  110. package/build/types/listItem/Prompt/ListItemPrompt.d.ts.map +1 -0
  111. package/build/types/listItem/Prompt/index.d.ts +3 -0
  112. package/build/types/listItem/Prompt/index.d.ts.map +1 -0
  113. package/build/types/listItem/Radio/ListItemRadio.d.ts +14 -0
  114. package/build/types/listItem/Radio/ListItemRadio.d.ts.map +1 -0
  115. package/build/types/listItem/Radio/index.d.ts +3 -0
  116. package/build/types/listItem/Radio/index.d.ts.map +1 -0
  117. package/build/types/listItem/Switch/ListItemSwitch.d.ts +14 -0
  118. package/build/types/listItem/Switch/ListItemSwitch.d.ts.map +1 -0
  119. package/build/types/listItem/Switch/index.d.ts +3 -0
  120. package/build/types/listItem/Switch/index.d.ts.map +1 -0
  121. package/build/types/listItem/_stories/helpers.d.ts +27 -0
  122. package/build/types/listItem/_stories/helpers.d.ts.map +1 -0
  123. package/build/types/listItem/_stories/subcomponents.d.ts +18 -0
  124. package/build/types/listItem/_stories/subcomponents.d.ts.map +1 -0
  125. package/build/types/listItem/index.d.ts +14 -0
  126. package/build/types/listItem/index.d.ts.map +1 -0
  127. package/build/types/listItem/test-utils.d.ts +7 -0
  128. package/build/types/listItem/test-utils.d.ts.map +1 -0
  129. package/build/types/listItem/useListItemControl.d.ts +5 -0
  130. package/build/types/listItem/useListItemControl.d.ts.map +1 -0
  131. package/build/types/listItem/useListItemMedia.d.ts +6 -0
  132. package/build/types/listItem/useListItemMedia.d.ts.map +1 -0
  133. package/package.json +1 -1
  134. package/src/actionButton/ActionButton.story.tsx +1 -1
  135. package/src/avatar/Avatar.story.tsx +1 -1
  136. package/src/avatarWrapper/AvatarWrapper.story.tsx +1 -1
  137. package/src/badge/Badge.story.tsx +1 -1
  138. package/src/button/Button.css +1 -1
  139. package/src/button/Button.less +1 -1
  140. package/src/button/Button.story.tsx +95 -9
  141. package/src/button/LegacyButton.story.tsx +1 -1
  142. package/src/index.ts +15 -0
  143. package/src/legacylistItem/LegacyListItem.story.tsx +1 -1
  144. package/src/legacylistItem/LegacyListItem.tests.story.tsx +2 -1
  145. package/src/list/List.story.tsx +13 -3
  146. package/src/listItem/AdditionalInfo/ListItemAdditionalInfo.spec.tsx +56 -0
  147. package/src/listItem/AdditionalInfo/ListItemAdditionalInfo.story.tsx +198 -0
  148. package/src/listItem/AdditionalInfo/ListItemAdditionalInfo.tsx +36 -0
  149. package/src/listItem/AdditionalInfo/index.ts +2 -0
  150. package/src/listItem/AvatarLayout/ListItemAvatarLayout.spec.tsx +59 -0
  151. package/src/listItem/AvatarLayout/ListItemAvatarLayout.story.tsx +124 -0
  152. package/src/listItem/AvatarLayout/ListItemAvatarLayout.tsx +27 -0
  153. package/src/listItem/AvatarLayout/index.ts +2 -0
  154. package/src/listItem/AvatarView/ListItemAvatarView.spec.tsx +75 -0
  155. package/src/listItem/AvatarView/ListItemAvatarView.story.tsx +339 -0
  156. package/src/listItem/AvatarView/ListItemAvatarView.tsx +27 -0
  157. package/src/listItem/AvatarView/index.ts +2 -0
  158. package/src/listItem/Button/ListItemButton.spec.tsx +68 -0
  159. package/src/listItem/Button/ListItemButton.story.tsx +473 -0
  160. package/src/listItem/Button/ListItemButton.tsx +56 -0
  161. package/src/listItem/Button/index.ts +2 -0
  162. package/src/listItem/Checkbox/ListItemCheckbox.spec.tsx +82 -0
  163. package/src/listItem/Checkbox/ListItemCheckbox.story.tsx +128 -0
  164. package/src/listItem/Checkbox/ListItemCheckbox.tsx +33 -0
  165. package/src/listItem/Checkbox/index.ts +2 -0
  166. package/src/listItem/IconButton/ListItemIconButton.spec.tsx +119 -0
  167. package/src/listItem/IconButton/ListItemIconButton.story.tsx +284 -0
  168. package/src/listItem/IconButton/ListItemIconButton.tsx +73 -0
  169. package/src/listItem/IconButton/index.ts +2 -0
  170. package/src/listItem/Image/ListItemImage.spec.tsx +30 -0
  171. package/src/listItem/Image/ListItemImage.story.tsx +80 -0
  172. package/src/listItem/Image/ListItemImage.tsx +46 -0
  173. package/src/listItem/Image/index.ts +2 -0
  174. package/src/listItem/ListItem.css +770 -0
  175. package/src/listItem/ListItem.grid.css +370 -0
  176. package/src/listItem/ListItem.grid.less +622 -0
  177. package/src/listItem/ListItem.less +287 -0
  178. package/src/listItem/ListItem.spec.tsx +1511 -0
  179. package/src/listItem/ListItem.tsx +438 -0
  180. package/src/listItem/ListItemContext.tsx +26 -0
  181. package/src/listItem/Navigation/ListItemNavigation.spec.tsx +59 -0
  182. package/src/listItem/Navigation/ListItemNavigation.story.tsx +112 -0
  183. package/src/listItem/Navigation/ListItemNavigation.tsx +39 -0
  184. package/src/listItem/Navigation/index.ts +2 -0
  185. package/src/listItem/Prompt/ListItemPrompt.css +157 -0
  186. package/src/listItem/Prompt/ListItemPrompt.less +134 -0
  187. package/src/listItem/Prompt/ListItemPrompt.spec.tsx +36 -0
  188. package/src/listItem/Prompt/ListItemPrompt.story.tsx +204 -0
  189. package/src/listItem/Prompt/ListItemPrompt.tsx +32 -0
  190. package/src/listItem/Prompt/index.ts +2 -0
  191. package/src/listItem/Radio/ListItemRadio.spec.tsx +66 -0
  192. package/src/listItem/Radio/ListItemRadio.story.tsx +111 -0
  193. package/src/listItem/Radio/ListItemRadio.tsx +33 -0
  194. package/src/listItem/Radio/index.ts +2 -0
  195. package/src/listItem/Switch/ListItemSwitch.spec.tsx +47 -0
  196. package/src/listItem/Switch/ListItemSwitch.story.tsx +79 -0
  197. package/src/listItem/Switch/ListItemSwitch.tsx +33 -0
  198. package/src/listItem/Switch/index.ts +2 -0
  199. package/src/listItem/_stories/ListItem.focus.test.story.tsx +265 -0
  200. package/src/listItem/_stories/ListItem.layout.test.story.tsx +354 -0
  201. package/src/listItem/_stories/ListItem.scenarios.story.tsx +228 -0
  202. package/src/listItem/_stories/ListItem.story.tsx +774 -0
  203. package/src/listItem/_stories/ListItem.variants.test.story.tsx +271 -0
  204. package/src/listItem/_stories/helpers.tsx +53 -0
  205. package/src/listItem/_stories/subcomponents.tsx +139 -0
  206. package/src/listItem/index.ts +14 -0
  207. package/src/listItem/test-utils.tsx +33 -0
  208. package/src/listItem/useListItemControl.tsx +18 -0
  209. package/src/listItem/useListItemMedia.tsx +16 -0
  210. package/src/main.css +771 -1
  211. package/src/main.less +1 -0
  212. package/src/select/Select.story.tsx +1 -1
@@ -0,0 +1,80 @@
1
+ import { Meta, StoryObj } from '@storybook/react-webpack5';
2
+ import List from '../../list';
3
+ import { ListItem } from '../ListItem';
4
+ import {
5
+ SB_LIST_ITEM_ADDITIONAL_INFO as INFO,
6
+ SB_LIST_ITEM_CONTROLS as CONTROLS,
7
+ } from '../_stories/subcomponents';
8
+ import landscapeImage from '../../test-utils/assets/placeholder-landscape.svg';
9
+ import portraitImage from '../../test-utils/assets/placeholder-portrait.svg';
10
+ import type { ListItemImageProps } from './ListItemImage';
11
+
12
+ export default {
13
+ component: ListItem.Image,
14
+ title: 'Content/ListItem/ListItem.Image',
15
+ parameters: {
16
+ docs: {
17
+ toc: true,
18
+ },
19
+ },
20
+ args: {
21
+ size: 48,
22
+ loading: undefined,
23
+ alt: undefined,
24
+ },
25
+ } satisfies Meta<ListItemImageProps>;
26
+
27
+ /**
28
+ * Convenience controls for previewing rich markup,
29
+ * not otherwise possible via Storybook
30
+ */
31
+ type PreviewStoryArgs = ListItemImageProps & {
32
+ previewOrientation?: ListItemImageProps['src'];
33
+ };
34
+
35
+ const previewArgGroup = {
36
+ category: 'Preview options',
37
+ type: {
38
+ summary: undefined,
39
+ },
40
+ };
41
+
42
+ const previewArgTypes = {
43
+ previewOrientation: {
44
+ name: 'Preview image with orientation',
45
+ control: 'radio',
46
+ options: ['unset (use `src` prop)', 'landscape', 'portrait'],
47
+ mapping: {
48
+ 'unset (use `src` prop)': undefined,
49
+ landscape: landscapeImage,
50
+ portrait: portraitImage,
51
+ },
52
+ table: previewArgGroup,
53
+ },
54
+ } as const;
55
+
56
+ export const Playground: StoryObj<PreviewStoryArgs> = {
57
+ argTypes: previewArgTypes,
58
+ args: {
59
+ src: 'https://wise.com/public-resources/assets/spend/card-asset/medium/v2/personal_green_wise_2023_active.svg',
60
+ },
61
+ render: (args: PreviewStoryArgs) => {
62
+ const { previewOrientation, src, ...imageProps } = args as {
63
+ previewOrientation: string;
64
+ src: PreviewStoryArgs['src'];
65
+ props: PreviewStoryArgs;
66
+ };
67
+
68
+ return (
69
+ <List>
70
+ <ListItem
71
+ title="List item title"
72
+ subtitle="Subtitle goes here"
73
+ media={<ListItem.Image {...imageProps} src={previewOrientation || src} />}
74
+ control={CONTROLS.partialButton}
75
+ additionalInfo={INFO.nonInteractive}
76
+ />
77
+ </List>
78
+ );
79
+ },
80
+ };
@@ -0,0 +1,46 @@
1
+ import ImageComp, { type ImageProps } from '../../image';
2
+ import { clsx } from 'clsx';
3
+ import { useListItemMedia } from '../useListItemMedia';
4
+
5
+ export type ListItemImageProps = Omit<ImageProps, 'stretch' | 'shrink' | 'id' | 'alt' | 'role'> & {
6
+ /**
7
+ * The size of square container for the image, matching available avatar sizes.
8
+ */
9
+ size?: 32 | 40 | 48 | 56 | 72;
10
+ /**
11
+ * When unset, it will force `role="presentation"` on the image. Otherwise, the image will use its implicit img role.
12
+ */
13
+ alt?: string;
14
+ };
15
+
16
+ /**
17
+ * This component should be used as a last resort, for rare cases when `<ListItem.AvatarView />`
18
+ * or `<ListItem.AvatarLayout />` are insufficient.
19
+ * It's a wrapper around the
20
+ * [Image component](https://storybook.wise.design/?path=/docs/content-image--docs), but offers only
21
+ * a subset of its props, in line with the ListItem's constraints.
22
+ *
23
+ * > **NB**: This component is [not intended for use with illustrations](https://wise.design/foundations/illustration#scale).
24
+ */
25
+ export const Image = ({ alt = '', size = 48, className, ...props }: ListItemImageProps) => {
26
+ useListItemMedia(size);
27
+
28
+ return (
29
+ <div
30
+ className={clsx('wds-list-item-media-image-wrapper')}
31
+ style={
32
+ {
33
+ '--wds-list-item-media-size': `${size}px`,
34
+ } as React.CSSProperties
35
+ }
36
+ >
37
+ <ImageComp
38
+ {...props}
39
+ className={clsx(className, 'wds-list-item-media-image')}
40
+ alt={alt}
41
+ role={alt ? undefined : 'presentation'}
42
+ />
43
+ </div>
44
+ );
45
+ };
46
+ Image.displayName = 'ListItem.Image';
@@ -0,0 +1,2 @@
1
+ export type { ListItemImageProps } from './ListItemImage';
2
+ export { Image } from './ListItemImage';