@transferwise/components 0.0.0-experimental-696128b → 0.0.0-experimental-328f2cc

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 (159) hide show
  1. package/build/avatarLayout/AvatarLayout.js +4 -10
  2. package/build/avatarLayout/AvatarLayout.js.map +1 -1
  3. package/build/avatarLayout/AvatarLayout.mjs +4 -10
  4. package/build/avatarLayout/AvatarLayout.mjs.map +1 -1
  5. package/build/button/Button.js +79 -81
  6. package/build/button/Button.js.map +1 -1
  7. package/build/button/Button.mjs +80 -82
  8. package/build/button/Button.mjs.map +1 -1
  9. package/build/criticalBanner/CriticalCommsBanner.js +2 -2
  10. package/build/criticalBanner/CriticalCommsBanner.js.map +1 -1
  11. package/build/criticalBanner/CriticalCommsBanner.mjs +1 -1
  12. package/build/header/Header.js +2 -2
  13. package/build/header/Header.js.map +1 -1
  14. package/build/header/Header.mjs +1 -1
  15. package/build/index.js +4 -2
  16. package/build/index.js.map +1 -1
  17. package/build/index.mjs +2 -1
  18. package/build/index.mjs.map +1 -1
  19. package/build/link/Link.js +3 -8
  20. package/build/link/Link.js.map +1 -1
  21. package/build/link/Link.mjs +3 -8
  22. package/build/link/Link.mjs.map +1 -1
  23. package/build/main.css +13 -224
  24. package/build/nudge/Nudge.js.map +1 -1
  25. package/build/nudge/Nudge.mjs.map +1 -1
  26. package/build/primitives/PrimitiveAnchor/src/PrimitiveAnchor.js +3 -1
  27. package/build/primitives/PrimitiveAnchor/src/PrimitiveAnchor.js.map +1 -1
  28. package/build/primitives/PrimitiveAnchor/src/PrimitiveAnchor.mjs +3 -1
  29. package/build/primitives/PrimitiveAnchor/src/PrimitiveAnchor.mjs.map +1 -1
  30. package/build/primitives/PrimitiveButton/src/PrimitiveButton.js +4 -1
  31. package/build/primitives/PrimitiveButton/src/PrimitiveButton.js.map +1 -1
  32. package/build/primitives/PrimitiveButton/src/PrimitiveButton.mjs +4 -1
  33. package/build/primitives/PrimitiveButton/src/PrimitiveButton.mjs.map +1 -1
  34. package/build/select/Select.js +2 -2
  35. package/build/select/Select.js.map +1 -1
  36. package/build/select/Select.mjs +1 -1
  37. package/build/styles/avatarLayout/AvatarLayout.css +2 -12
  38. package/build/styles/button/Button.css +15 -204
  39. package/build/styles/main.css +13 -224
  40. package/build/styles/nudge/Nudge.css +11 -0
  41. package/build/table/Table.js +166 -0
  42. package/build/table/Table.js.map +1 -0
  43. package/build/table/Table.messages.js +24 -0
  44. package/build/table/Table.messages.js.map +1 -0
  45. package/build/table/Table.messages.mjs +22 -0
  46. package/build/table/Table.messages.mjs.map +1 -0
  47. package/build/table/Table.mjs +164 -0
  48. package/build/table/Table.mjs.map +1 -0
  49. package/build/table/TableCell.js +86 -0
  50. package/build/table/TableCell.js.map +1 -0
  51. package/build/table/TableCell.mjs +84 -0
  52. package/build/table/TableCell.mjs.map +1 -0
  53. package/build/table/TableHeader.js +57 -0
  54. package/build/table/TableHeader.js.map +1 -0
  55. package/build/table/TableHeader.mjs +55 -0
  56. package/build/table/TableHeader.mjs.map +1 -0
  57. package/build/table/TableRow.js +85 -0
  58. package/build/table/TableRow.js.map +1 -0
  59. package/build/table/TableRow.mjs +83 -0
  60. package/build/table/TableRow.mjs.map +1 -0
  61. package/build/table/TableStatusText.js +54 -0
  62. package/build/table/TableStatusText.js.map +1 -0
  63. package/build/table/TableStatusText.mjs +52 -0
  64. package/build/table/TableStatusText.mjs.map +1 -0
  65. package/build/types/avatarLayout/AvatarLayout.d.ts.map +1 -1
  66. package/build/types/button/Button.d.ts +23 -2
  67. package/build/types/button/Button.d.ts.map +1 -1
  68. package/build/types/button/index.d.ts +2 -2
  69. package/build/types/button/index.d.ts.map +1 -1
  70. package/build/types/index.d.ts +2 -0
  71. package/build/types/index.d.ts.map +1 -1
  72. package/build/types/link/Link.d.ts +2 -2
  73. package/build/types/link/Link.d.ts.map +1 -1
  74. package/build/types/nudge/Nudge.d.ts +1 -1
  75. package/build/types/nudge/Nudge.d.ts.map +1 -1
  76. package/build/types/primitives/PrimitiveAnchor/src/PrimitiveAnchor.d.ts.map +1 -1
  77. package/build/types/primitives/PrimitiveAnchor/src/PrimitiveAnchor.types.d.ts +2 -6
  78. package/build/types/primitives/PrimitiveAnchor/src/PrimitiveAnchor.types.d.ts.map +1 -1
  79. package/build/types/primitives/PrimitiveButton/src/PrimitiveButton.d.ts.map +1 -1
  80. package/build/types/test-utils/story-config.d.ts +1 -1
  81. package/build/types/test-utils/story-config.d.ts.map +1 -1
  82. package/build/types/uploadInput/uploadButton/getAllowedFileTypes.d.ts.map +1 -1
  83. package/build/upload/steps/completeStep/completeStep.js +2 -2
  84. package/build/upload/steps/completeStep/completeStep.js.map +1 -1
  85. package/build/upload/steps/completeStep/completeStep.mjs +1 -1
  86. package/build/upload/steps/processingStep/processingStep.js +2 -2
  87. package/build/upload/steps/processingStep/processingStep.js.map +1 -1
  88. package/build/upload/steps/processingStep/processingStep.mjs +1 -1
  89. package/build/uploadInput/UploadInput.js +3 -3
  90. package/build/uploadInput/UploadInput.js.map +1 -1
  91. package/build/uploadInput/UploadInput.mjs +1 -1
  92. package/build/uploadInput/uploadButton/getAllowedFileTypes.js +23 -3
  93. package/build/uploadInput/uploadButton/getAllowedFileTypes.js.map +1 -1
  94. package/build/uploadInput/uploadButton/getAllowedFileTypes.mjs +23 -3
  95. package/build/uploadInput/uploadButton/getAllowedFileTypes.mjs.map +1 -1
  96. package/package.json +3 -3
  97. package/src/alert/Alert.tests.story.tsx +1 -1
  98. package/src/avatarLayout/AvatarLayout.css +2 -12
  99. package/src/avatarLayout/AvatarLayout.less +2 -19
  100. package/src/avatarLayout/AvatarLayout.tsx +3 -10
  101. package/src/button/Button.css +15 -204
  102. package/src/button/Button.less +14 -211
  103. package/src/button/Button.spec.tsx +227 -75
  104. package/src/button/Button.story.tsx +135 -728
  105. package/src/button/Button.tsx +131 -94
  106. package/src/button/__snapshots__/Button.spec.tsx.snap +309 -0
  107. package/src/button/index.ts +3 -2
  108. package/src/drawer/Drawer.spec.tsx +93 -0
  109. package/src/field/Field.story.tsx +1 -1
  110. package/src/flowNavigation/__snapshots__/FlowNavigation.spec.js.snap +1 -1
  111. package/src/index.ts +12 -0
  112. package/src/inputs/SelectInput.story.tsx +1 -1
  113. package/src/label/Label.story.tsx +1 -1
  114. package/src/link/Link.tsx +6 -15
  115. package/src/main.css +13 -224
  116. package/src/main.less +0 -1
  117. package/src/nudge/Nudge.css +11 -0
  118. package/src/nudge/Nudge.less +3 -0
  119. package/src/nudge/Nudge.story.tsx +10 -0
  120. package/src/nudge/Nudge.tsx +2 -1
  121. package/src/primitives/PrimitiveAnchor/src/PrimitiveAnchor.tsx +7 -1
  122. package/src/primitives/PrimitiveAnchor/src/PrimitiveAnchor.types.ts +2 -7
  123. package/src/primitives/PrimitiveAnchor/test/PrimitiveAnchor.spec.tsx +3 -1
  124. package/src/primitives/PrimitiveButton/src/PrimitiveButton.tsx +8 -1
  125. package/src/primitives/PrimitiveButton/test/PrimitiveButton.spec.tsx +5 -2
  126. package/src/test-utils/Parameters.d.ts +1 -9
  127. package/src/test-utils/story-config.ts +1 -10
  128. package/src/uploadInput/UploadInput.tests.story.tsx +5 -5
  129. package/src/uploadInput/uploadButton/getAllowedFileTypes.spec.ts +12 -0
  130. package/src/uploadInput/uploadButton/getAllowedFileTypes.ts +33 -7
  131. package/build/button/Button.resolver.js +0 -74
  132. package/build/button/Button.resolver.js.map +0 -1
  133. package/build/button/Button.resolver.mjs +0 -72
  134. package/build/button/Button.resolver.mjs.map +0 -1
  135. package/build/button/LegacyButton.js +0 -114
  136. package/build/button/LegacyButton.js.map +0 -1
  137. package/build/button/LegacyButton.mjs +0 -112
  138. package/build/button/LegacyButton.mjs.map +0 -1
  139. package/build/styles/button/Button.vars.css +0 -39
  140. package/build/styles/button/LegacyButton.css +0 -23
  141. package/build/types/button/Button.resolver.d.ts +0 -33
  142. package/build/types/button/Button.resolver.d.ts.map +0 -1
  143. package/build/types/button/Button.types.d.ts +0 -58
  144. package/build/types/button/Button.types.d.ts.map +0 -1
  145. package/build/types/button/LegacyButton.d.ts +0 -30
  146. package/build/types/button/LegacyButton.d.ts.map +0 -1
  147. package/src/button/Button.resolver.tsx +0 -73
  148. package/src/button/Button.tests.story.tsx +0 -27
  149. package/src/button/Button.types.ts +0 -74
  150. package/src/button/Button.vars.css +0 -39
  151. package/src/button/Button.vars.less +0 -50
  152. package/src/button/LegacyButton.css +0 -23
  153. package/src/button/LegacyButton.less +0 -24
  154. package/src/button/LegacyButton.spec.tsx +0 -147
  155. package/src/button/LegacyButton.story.tsx +0 -225
  156. package/src/button/LegacyButton.tsx +0 -160
  157. package/src/drawer/Drawer.rtl.spec.tsx +0 -59
  158. package/src/drawer/Drawer.spec.js +0 -101
  159. package/src/drawer/__snapshots__/Drawer.rtl.spec.tsx.snap +0 -55
@@ -1,117 +1,154 @@
1
- /* eslint-disable react/display-name */
2
- /* eslint-disable @typescript-eslint/no-unsafe-assignment */
3
- import { forwardRef } from 'react';
1
+ import { clsx } from 'clsx';
2
+ import { ElementType, forwardRef, MouseEvent } from 'react';
3
+ import { useIntl } from 'react-intl';
4
+
4
5
  import {
5
- AnchorElementProps,
6
- ButtonReferenceType,
7
- ButtonProps as NewButtonProps,
8
- } from './Button.types';
9
- import { PrimitiveAnchor, PrimitiveButton } from '../primitives';
10
- import AvatarLayout from '../avatarLayout';
6
+ Size,
7
+ ControlType,
8
+ Priority,
9
+ ControlTypeAccent,
10
+ ControlTypeNegative,
11
+ ControlTypePositive,
12
+ PriorityPrimary,
13
+ PrioritySecondary,
14
+ PriorityTertiary,
15
+ SizeExtraSmall,
16
+ SizeSmall,
17
+ SizeMedium,
18
+ SizeLarge,
19
+ } from '../common';
11
20
  import ProcessIndicator from '../processIndicator';
12
- import { clsx } from 'clsx';
13
- import { Typography } from '../common';
14
- import Body from '../body';
15
21
 
16
- const Button = forwardRef<ButtonReferenceType, NewButtonProps>(
22
+ import messages from '../i18n/commonMessages/Button.messages';
23
+ import { typeClassMap, priorityClassMap } from './classMap';
24
+ import { establishNewPriority, establishNewType, logDeprecationNotices } from './legacyUtils';
25
+
26
+ /** @deprecated */
27
+ type DeprecatedTypes = 'primary' | 'pay' | 'secondary' | 'danger' | 'link';
28
+
29
+ /** @deprecated */
30
+ type DeprecatedSizes = SizeExtraSmall;
31
+
32
+ type CommonProps = {
33
+ block?: boolean;
34
+ disabled?: boolean;
35
+ loading?: boolean;
36
+ type?: ControlTypeAccent | ControlTypeNegative | ControlTypePositive | DeprecatedTypes | null;
37
+ priority?: PriorityPrimary | PrioritySecondary | PriorityTertiary | null;
38
+ size?: SizeSmall | SizeMedium | SizeLarge | DeprecatedSizes;
39
+ };
40
+
41
+ type ButtonProps = CommonProps &
42
+ Omit<React.ComponentPropsWithRef<'button'>, 'type'> & {
43
+ as?: 'button';
44
+ htmlType?: 'submit' | 'reset' | 'button';
45
+ };
46
+
47
+ type AnchorProps = CommonProps &
48
+ Omit<React.ComponentPropsWithRef<'a'>, 'type'> & {
49
+ as?: 'a';
50
+ };
51
+
52
+ export type Props = ButtonProps | AnchorProps;
53
+
54
+ export type ButtonReferenceType = HTMLButtonElement | HTMLAnchorElement;
55
+
56
+ const Button = forwardRef<ButtonReferenceType, Props>(
17
57
  (
18
58
  {
19
- as = 'button',
59
+ as: component,
60
+ block = false,
20
61
  children,
21
62
  className,
22
- size = 'lg',
23
- href,
24
- disabled = false,
25
- priority = 'primary',
26
- sentiment = 'default',
27
- iconStart: IconStart,
28
- iconEnd: IconEnd,
29
- avatars,
30
- // @ts-expect-error NewButtonProps has `type` prop
31
- type = 'button',
63
+ disabled,
32
64
  loading = false,
33
- block = false,
34
- v2,
35
- ...props
36
- },
37
- ref,
65
+ priority = Priority.PRIMARY,
66
+ size = Size.MEDIUM,
67
+ type = ControlType.ACCENT,
68
+ onClick,
69
+ ...rest
70
+ }: Props,
71
+ reference,
38
72
  ) => {
39
- const classNames = clsx(
40
- 'wds-Button',
73
+ const intl = useIntl();
74
+
75
+ logDeprecationNotices({ size, type });
76
+
77
+ const newType = establishNewType(type);
78
+ const newPriority = establishNewPriority(priority, type);
79
+
80
+ const classes = clsx(
81
+ `btn btn-${size}`,
82
+ `np-btn np-btn-${size}`,
41
83
  {
42
- [`wds-Button--block`]: block,
43
- [`wds-Button--disabled`]: disabled,
44
- [`wds-Button--loading`]: loading,
84
+ 'btn-loading': loading,
85
+ 'btn-block np-btn-block': block,
86
+ disabled,
45
87
  },
46
- `wds-Button--${{ sm: 'small', md: 'medium', lg: 'large' }[size]}`,
47
- `wds-Button--${priority}`,
48
- `wds-Button--${sentiment}`,
88
+ // @ts-expect-error fix when refactor `typeClassMap` to TypeScript
89
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
90
+ typeClassMap[newType],
91
+ // @ts-expect-error fix when refactor `typeClassMap` to TypeScript
92
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
93
+ priorityClassMap[newPriority],
49
94
  className,
50
95
  );
51
96
 
52
- const contentClassNames = clsx('wds-Button-content', {
53
- [`wds-Button-content--loading`]: loading,
54
- });
97
+ function processIndicatorSize() {
98
+ return ['sm', 'xs'].includes(size) ? 'xxs' : 'xs';
99
+ }
55
100
 
56
- const content = (
57
- <Body
58
- as="span"
59
- type={size === 'sm' ? Typography.BODY_DEFAULT_BOLD : Typography.BODY_LARGE_BOLD}
60
- className={contentClassNames}
61
- >
62
- {loading && (
63
- <ProcessIndicator
64
- size={size === 'sm' ? 'xxs' : 'xs'}
65
- className="wds-Button-loader"
66
- data-testid="button-loader-indicator"
67
- />
68
- )}
69
- <span className="wds-Button-label" aria-hidden={loading}>
70
- {size === 'lg' ? (
71
- children
72
- ) : (
73
- <>
74
- {size === 'md' && avatars && (
75
- <span className="wds-Button-avatars">
76
- <AvatarLayout orientation="horizontal" avatars={avatars} size={24} />
77
- </span>
78
- )}
79
- {!avatars && IconStart && (
80
- <IconStart className="wds-Button-icon wds-Button-icon--start" />
81
- )}
82
- {children}
83
- {IconEnd && <IconEnd className="wds-Button-icon wds-Button-icon--end" />}
84
- </>
85
- )}
86
- </span>
87
- </Body>
88
- );
101
+ const Element = (component as ElementType) ?? 'button';
102
+ let props;
89
103
 
90
- if (href || as === 'a') {
91
- return (
92
- <PrimitiveAnchor
93
- ref={ref as React.Ref<HTMLAnchorElement>}
94
- {...(props as any)}
95
- href={href}
96
- className={classNames}
97
- disabled={disabled}
98
- >
99
- {content}
100
- </PrimitiveAnchor>
101
- );
104
+ if (Element === 'button') {
105
+ const { htmlType = 'button', ...restProps } = rest as ButtonProps;
106
+ props = {
107
+ ...restProps,
108
+ disabled,
109
+ 'aria-disabled': loading,
110
+ type: htmlType,
111
+ };
112
+ } else {
113
+ props = {
114
+ ...rest,
115
+ 'aria-disabled': loading,
116
+ } as AnchorProps;
102
117
  }
103
118
 
119
+ /**
120
+ * Ensures that the button cannot be activated in loading or disabled mode,
121
+ * when `aria-disabled` might be used over the `disabled` HTML attribute
122
+ */
123
+ const handleClick =
124
+ (handler: Props['onClick']) =>
125
+ (event: MouseEvent<HTMLButtonElement> & MouseEvent<HTMLAnchorElement>) => {
126
+ if (disabled || loading) {
127
+ event.preventDefault();
128
+ } else if (typeof handler === 'function') {
129
+ handler(event);
130
+ }
131
+ };
132
+
104
133
  return (
105
- <PrimitiveButton
106
- ref={ref as React.Ref<HTMLButtonElement>}
107
- {...(props as any)}
108
- className={classNames}
109
- disabled={disabled}
110
- loading={loading}
111
- type={type}
134
+ <Element
135
+ ref={reference}
136
+ className={classes}
137
+ onClick={handleClick(onClick)}
138
+ {...props}
139
+ aria-live={loading ? 'polite' : 'off'}
140
+ aria-busy={loading}
141
+ aria-label={loading ? intl.formatMessage(messages.loadingAriaLabel) : rest['aria-label']}
112
142
  >
113
- {content}
114
- </PrimitiveButton>
143
+ {children}
144
+ {loading && (
145
+ <ProcessIndicator
146
+ size={processIndicatorSize()}
147
+ className="btn-loader"
148
+ data-testid="ButtonProgressIndicator"
149
+ />
150
+ )}
151
+ </Element>
115
152
  );
116
153
  },
117
154
  );
@@ -0,0 +1,309 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`Button by default renders a medium button of type accent and priority primary 1`] = `
4
+ <div>
5
+ <button
6
+ aria-busy="false"
7
+ aria-disabled="false"
8
+ aria-live="off"
9
+ class="btn btn-md np-btn np-btn-md btn-accent btn-priority-1"
10
+ type="button"
11
+ >
12
+ Send money
13
+ </button>
14
+ </div>
15
+ `;
16
+
17
+ exports[`Button by default renders an anchor tag with button styles of type accent and priority primary 1`] = `
18
+ <div>
19
+ <a
20
+ aria-busy="false"
21
+ aria-disabled="false"
22
+ aria-live="off"
23
+ class="btn btn-md np-btn np-btn-md btn-accent btn-priority-1"
24
+ href="#"
25
+ >
26
+ Send money
27
+ </a>
28
+ </div>
29
+ `;
30
+
31
+ exports[`Button deprecated types renders danger as negative buttons with priority secondary and logs a warning 1`] = `
32
+ <div>
33
+ <button
34
+ aria-busy="false"
35
+ aria-disabled="false"
36
+ aria-live="off"
37
+ class="btn btn-md np-btn np-btn-md btn-negative btn-priority-2"
38
+ type="button"
39
+ >
40
+ Send money
41
+ </button>
42
+ </div>
43
+ `;
44
+
45
+ exports[`Button deprecated types renders link as accent buttons with priority tertiary and logs a warning 1`] = `
46
+ <div>
47
+ <button
48
+ aria-busy="false"
49
+ aria-disabled="false"
50
+ aria-live="off"
51
+ class="btn btn-md np-btn np-btn-md btn-accent btn-priority-3"
52
+ type="button"
53
+ >
54
+ Send money
55
+ </button>
56
+ </div>
57
+ `;
58
+
59
+ exports[`Button deprecated types renders pay as positive buttons and logs a warning 1`] = `
60
+ <div>
61
+ <button
62
+ aria-busy="false"
63
+ aria-disabled="false"
64
+ aria-live="off"
65
+ class="btn btn-md np-btn np-btn-md btn-positive btn-priority-1"
66
+ type="button"
67
+ >
68
+ Send money
69
+ </button>
70
+ </div>
71
+ `;
72
+
73
+ exports[`Button deprecated types renders primary as accent buttons and logs a warning 1`] = `
74
+ <div>
75
+ <button
76
+ aria-busy="false"
77
+ aria-disabled="false"
78
+ aria-live="off"
79
+ class="btn btn-md np-btn np-btn-md btn-accent btn-priority-1"
80
+ type="button"
81
+ >
82
+ Send money
83
+ </button>
84
+ </div>
85
+ `;
86
+
87
+ exports[`Button other states renders as block if block is true 1`] = `
88
+ <div>
89
+ <button
90
+ aria-busy="false"
91
+ aria-disabled="false"
92
+ aria-live="off"
93
+ class="btn btn-md np-btn np-btn-md btn-block np-btn-block btn-accent btn-priority-1"
94
+ type="button"
95
+ >
96
+ Send money
97
+ </button>
98
+ </div>
99
+ `;
100
+
101
+ exports[`Button priorities defaults tertiary buttons to secondary for positive buttons 1`] = `
102
+ <div>
103
+ <button
104
+ aria-busy="false"
105
+ aria-disabled="false"
106
+ aria-live="off"
107
+ class="btn btn-md np-btn np-btn-md btn-positive btn-priority-2"
108
+ type="button"
109
+ >
110
+ Send money
111
+ </button>
112
+ </div>
113
+ `;
114
+
115
+ exports[`Button priorities defaults tertiary buttons to secondary for positive buttons 2`] = `
116
+ <div>
117
+ <button
118
+ aria-busy="false"
119
+ aria-disabled="false"
120
+ aria-live="off"
121
+ class="btn btn-md np-btn np-btn-md btn-negative btn-priority-2"
122
+ type="button"
123
+ >
124
+ Send money
125
+ </button>
126
+ </div>
127
+ `;
128
+
129
+ exports[`Button priorities renders primary buttons 1`] = `
130
+ <div>
131
+ <button
132
+ aria-busy="false"
133
+ aria-disabled="false"
134
+ aria-live="off"
135
+ class="btn btn-md np-btn np-btn-md btn-accent btn-priority-1"
136
+ type="button"
137
+ >
138
+ Send money
139
+ </button>
140
+ </div>
141
+ `;
142
+
143
+ exports[`Button priorities renders primary buttons 2`] = `
144
+ <div>
145
+ <button
146
+ aria-busy="false"
147
+ aria-disabled="false"
148
+ aria-live="off"
149
+ class="btn btn-md np-btn np-btn-md btn-positive btn-priority-1"
150
+ type="button"
151
+ >
152
+ Send money
153
+ </button>
154
+ </div>
155
+ `;
156
+
157
+ exports[`Button priorities renders primary buttons 3`] = `
158
+ <div>
159
+ <button
160
+ aria-busy="false"
161
+ aria-disabled="false"
162
+ aria-live="off"
163
+ class="btn btn-md np-btn np-btn-md btn-negative btn-priority-1"
164
+ type="button"
165
+ >
166
+ Send money
167
+ </button>
168
+ </div>
169
+ `;
170
+
171
+ exports[`Button priorities renders secondary buttons 1`] = `
172
+ <div>
173
+ <button
174
+ aria-busy="false"
175
+ aria-disabled="false"
176
+ aria-live="off"
177
+ class="btn btn-md np-btn np-btn-md btn-accent btn-priority-2"
178
+ type="button"
179
+ >
180
+ Send money
181
+ </button>
182
+ </div>
183
+ `;
184
+
185
+ exports[`Button priorities renders secondary buttons 2`] = `
186
+ <div>
187
+ <button
188
+ aria-busy="false"
189
+ aria-disabled="false"
190
+ aria-live="off"
191
+ class="btn btn-md np-btn np-btn-md btn-positive btn-priority-2"
192
+ type="button"
193
+ >
194
+ Send money
195
+ </button>
196
+ </div>
197
+ `;
198
+
199
+ exports[`Button priorities renders secondary buttons 3`] = `
200
+ <div>
201
+ <button
202
+ aria-busy="false"
203
+ aria-disabled="false"
204
+ aria-live="off"
205
+ class="btn btn-md np-btn np-btn-md btn-negative btn-priority-2"
206
+ type="button"
207
+ >
208
+ Send money
209
+ </button>
210
+ </div>
211
+ `;
212
+
213
+ exports[`Button priorities renders tertiary buttons 1`] = `
214
+ <div>
215
+ <button
216
+ aria-busy="false"
217
+ aria-disabled="false"
218
+ aria-live="off"
219
+ class="btn btn-md np-btn np-btn-md btn-accent btn-priority-3"
220
+ type="button"
221
+ >
222
+ Send money
223
+ </button>
224
+ </div>
225
+ `;
226
+
227
+ exports[`Button sizes renders large buttons 1`] = `
228
+ <div>
229
+ <button
230
+ aria-busy="false"
231
+ aria-disabled="false"
232
+ aria-live="off"
233
+ class="btn btn-lg np-btn np-btn-lg btn-accent btn-priority-1"
234
+ type="button"
235
+ >
236
+ Send money
237
+ </button>
238
+ </div>
239
+ `;
240
+
241
+ exports[`Button sizes renders medium buttons 1`] = `
242
+ <div>
243
+ <button
244
+ aria-busy="false"
245
+ aria-disabled="false"
246
+ aria-live="off"
247
+ class="btn btn-md np-btn np-btn-md btn-accent btn-priority-1"
248
+ type="button"
249
+ >
250
+ Send money
251
+ </button>
252
+ </div>
253
+ `;
254
+
255
+ exports[`Button sizes renders small buttons 1`] = `
256
+ <div>
257
+ <button
258
+ aria-busy="false"
259
+ aria-disabled="false"
260
+ aria-live="off"
261
+ class="btn btn-sm np-btn np-btn-sm btn-accent btn-priority-1"
262
+ type="button"
263
+ >
264
+ Send money
265
+ </button>
266
+ </div>
267
+ `;
268
+
269
+ exports[`Button types renders accent buttons 1`] = `
270
+ <div>
271
+ <button
272
+ aria-busy="false"
273
+ aria-disabled="false"
274
+ aria-live="off"
275
+ class="btn btn-md np-btn np-btn-md btn-accent btn-priority-1"
276
+ type="button"
277
+ >
278
+ Send money
279
+ </button>
280
+ </div>
281
+ `;
282
+
283
+ exports[`Button types renders negative buttons 1`] = `
284
+ <div>
285
+ <button
286
+ aria-busy="false"
287
+ aria-disabled="false"
288
+ aria-live="off"
289
+ class="btn btn-md np-btn np-btn-md btn-negative btn-priority-1"
290
+ type="button"
291
+ >
292
+ Send money
293
+ </button>
294
+ </div>
295
+ `;
296
+
297
+ exports[`Button types renders positive buttons 1`] = `
298
+ <div>
299
+ <button
300
+ aria-busy="false"
301
+ aria-disabled="false"
302
+ aria-live="off"
303
+ class="btn btn-md np-btn np-btn-md btn-positive btn-priority-1"
304
+ type="button"
305
+ >
306
+ Send money
307
+ </button>
308
+ </div>
309
+ `;
@@ -1,2 +1,3 @@
1
- export { default } from './Button.resolver';
2
- export type { ButtonProps } from './Button.resolver';
1
+ export { default } from './Button';
2
+
3
+ export type { Props as ButtonProps } from './Button';
@@ -0,0 +1,93 @@
1
+ import { render, screen, userEvent, mockMatchMedia } from '../test-utils';
2
+ import { Position } from '../common';
3
+
4
+ import Drawer from './Drawer';
5
+
6
+ jest.mock('../common/DOMOperations');
7
+ mockMatchMedia();
8
+
9
+ describe('Drawer', () => {
10
+ const renderedComponent = (props: React.ComponentProps<typeof Drawer>) =>
11
+ render(<Drawer {...props} />);
12
+
13
+ const props = {
14
+ open: true,
15
+ onClose: jest.fn(),
16
+ headerTitle: 'Drawer Title',
17
+ footerContent: <div>Footer Content</div>,
18
+ children: <p>Drawer Content</p>,
19
+ className: 'drawer-class',
20
+ };
21
+
22
+ beforeEach(() => {
23
+ jest.clearAllMocks();
24
+ });
25
+
26
+ it('renders the Drawer component', () => {
27
+ renderedComponent(props);
28
+ expect(screen.getByRole('dialog')).toBeInTheDocument();
29
+ });
30
+
31
+ it('renders the header title', () => {
32
+ renderedComponent(props);
33
+ expect(screen.getByText('Drawer Title')).toBeInTheDocument();
34
+ });
35
+
36
+ it('renders the footer content', () => {
37
+ renderedComponent(props);
38
+ expect(screen.getByText('Footer Content')).toBeInTheDocument();
39
+ });
40
+
41
+ it('renders the children content', () => {
42
+ renderedComponent(props);
43
+ expect(screen.getByText('Drawer Content')).toBeInTheDocument();
44
+ });
45
+
46
+ it('passes through the className prop', () => {
47
+ renderedComponent({ ...props, className: 'drawer-class' });
48
+ expect(screen.getByRole('dialog')).toHaveClass('drawer-class');
49
+ });
50
+
51
+ it('calls onClose when the close button is clicked', async () => {
52
+ renderedComponent(props);
53
+ await userEvent.click(screen.getByLabelText('Close'));
54
+ expect(props.onClose).toHaveBeenCalled();
55
+ });
56
+
57
+ it('calls onClose if the dimmer is clicked', async () => {
58
+ render(<Drawer {...props} />);
59
+ await userEvent.click(screen.getByRole('button'));
60
+ expect(props.onClose).toHaveBeenCalledTimes(1);
61
+ });
62
+
63
+ it('does not call onClose if the drawer content is clicked', async () => {
64
+ render(<Drawer {...props}>Drawer Content</Drawer>);
65
+ await userEvent.click(screen.getByText('Drawer Content'));
66
+ expect(props.onClose).not.toHaveBeenCalled();
67
+ });
68
+
69
+ it('does not render the Drawer when open is false', () => {
70
+ renderedComponent({ ...props, open: false });
71
+ expect(screen.queryByRole('dialog')).not.toBeInTheDocument();
72
+ });
73
+
74
+ it('renders the Drawer with the correct aria-labelledby attribute', () => {
75
+ renderedComponent(props);
76
+ expect(screen.getByRole('dialog')).toHaveAttribute('aria-labelledby');
77
+ });
78
+
79
+ it('renders the Drawer with the correct position', () => {
80
+ renderedComponent({ ...props, position: Position.LEFT });
81
+ expect(screen.getByRole('dialog').parentElement).toHaveClass('sliding-panel--open-left');
82
+ });
83
+
84
+ it('renders the Drawer with the correct role attribute', () => {
85
+ renderedComponent(props);
86
+ expect(screen.getByRole('dialog')).toHaveAttribute('role', 'dialog');
87
+ });
88
+
89
+ it('renders the Drawer with the correct aria-modal attribute', () => {
90
+ renderedComponent(props);
91
+ expect(screen.getByRole('dialog')).toHaveAttribute('aria-modal', 'true');
92
+ });
93
+ });
@@ -12,7 +12,7 @@ import Info from '../info';
12
12
 
13
13
  export default {
14
14
  component: Field,
15
- title: 'Forms/Field',
15
+ title: 'Field',
16
16
  tags: ['autodocs'],
17
17
  argTypes: {
18
18
  messageIconLabel: {
@@ -12,7 +12,7 @@ exports[`FlowNavigation on mobile renders as expected 1`] = `
12
12
  aria-disabled="false"
13
13
  aria-label="back to previous step"
14
14
  aria-live="off"
15
- class="np-circle d-flex align-items-center justify-content-center np-icon-button np-icon-button-tertiary-default"
15
+ class="wds-Button np-circle d-flex align-items-center justify-content-center np-icon-button np-icon-button-tertiary-default"
16
16
  style="--circle-size: 40px; --circle-icon-size: 20px; --circle-font-size: 18px;"
17
17
  type="button"
18
18
  >