@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.
- package/build/avatarLayout/AvatarLayout.js +4 -10
- package/build/avatarLayout/AvatarLayout.js.map +1 -1
- package/build/avatarLayout/AvatarLayout.mjs +4 -10
- package/build/avatarLayout/AvatarLayout.mjs.map +1 -1
- package/build/button/Button.js +79 -81
- package/build/button/Button.js.map +1 -1
- package/build/button/Button.mjs +80 -82
- package/build/button/Button.mjs.map +1 -1
- package/build/criticalBanner/CriticalCommsBanner.js +2 -2
- package/build/criticalBanner/CriticalCommsBanner.js.map +1 -1
- package/build/criticalBanner/CriticalCommsBanner.mjs +1 -1
- package/build/header/Header.js +2 -2
- package/build/header/Header.js.map +1 -1
- package/build/header/Header.mjs +1 -1
- package/build/index.js +4 -2
- package/build/index.js.map +1 -1
- package/build/index.mjs +2 -1
- package/build/index.mjs.map +1 -1
- package/build/link/Link.js +3 -8
- package/build/link/Link.js.map +1 -1
- package/build/link/Link.mjs +3 -8
- package/build/link/Link.mjs.map +1 -1
- package/build/main.css +13 -224
- package/build/nudge/Nudge.js.map +1 -1
- package/build/nudge/Nudge.mjs.map +1 -1
- package/build/primitives/PrimitiveAnchor/src/PrimitiveAnchor.js +3 -1
- package/build/primitives/PrimitiveAnchor/src/PrimitiveAnchor.js.map +1 -1
- package/build/primitives/PrimitiveAnchor/src/PrimitiveAnchor.mjs +3 -1
- package/build/primitives/PrimitiveAnchor/src/PrimitiveAnchor.mjs.map +1 -1
- package/build/primitives/PrimitiveButton/src/PrimitiveButton.js +4 -1
- package/build/primitives/PrimitiveButton/src/PrimitiveButton.js.map +1 -1
- package/build/primitives/PrimitiveButton/src/PrimitiveButton.mjs +4 -1
- package/build/primitives/PrimitiveButton/src/PrimitiveButton.mjs.map +1 -1
- package/build/select/Select.js +2 -2
- package/build/select/Select.js.map +1 -1
- package/build/select/Select.mjs +1 -1
- package/build/styles/avatarLayout/AvatarLayout.css +2 -12
- package/build/styles/button/Button.css +15 -204
- package/build/styles/main.css +13 -224
- package/build/styles/nudge/Nudge.css +11 -0
- package/build/table/Table.js +166 -0
- package/build/table/Table.js.map +1 -0
- package/build/table/Table.messages.js +24 -0
- package/build/table/Table.messages.js.map +1 -0
- package/build/table/Table.messages.mjs +22 -0
- package/build/table/Table.messages.mjs.map +1 -0
- package/build/table/Table.mjs +164 -0
- package/build/table/Table.mjs.map +1 -0
- package/build/table/TableCell.js +86 -0
- package/build/table/TableCell.js.map +1 -0
- package/build/table/TableCell.mjs +84 -0
- package/build/table/TableCell.mjs.map +1 -0
- package/build/table/TableHeader.js +57 -0
- package/build/table/TableHeader.js.map +1 -0
- package/build/table/TableHeader.mjs +55 -0
- package/build/table/TableHeader.mjs.map +1 -0
- package/build/table/TableRow.js +85 -0
- package/build/table/TableRow.js.map +1 -0
- package/build/table/TableRow.mjs +83 -0
- package/build/table/TableRow.mjs.map +1 -0
- package/build/table/TableStatusText.js +54 -0
- package/build/table/TableStatusText.js.map +1 -0
- package/build/table/TableStatusText.mjs +52 -0
- package/build/table/TableStatusText.mjs.map +1 -0
- package/build/types/avatarLayout/AvatarLayout.d.ts.map +1 -1
- package/build/types/button/Button.d.ts +23 -2
- package/build/types/button/Button.d.ts.map +1 -1
- package/build/types/button/index.d.ts +2 -2
- package/build/types/button/index.d.ts.map +1 -1
- package/build/types/index.d.ts +2 -0
- package/build/types/index.d.ts.map +1 -1
- package/build/types/link/Link.d.ts +2 -2
- package/build/types/link/Link.d.ts.map +1 -1
- package/build/types/nudge/Nudge.d.ts +1 -1
- package/build/types/nudge/Nudge.d.ts.map +1 -1
- package/build/types/primitives/PrimitiveAnchor/src/PrimitiveAnchor.d.ts.map +1 -1
- package/build/types/primitives/PrimitiveAnchor/src/PrimitiveAnchor.types.d.ts +2 -6
- package/build/types/primitives/PrimitiveAnchor/src/PrimitiveAnchor.types.d.ts.map +1 -1
- package/build/types/primitives/PrimitiveButton/src/PrimitiveButton.d.ts.map +1 -1
- package/build/types/test-utils/story-config.d.ts +1 -1
- package/build/types/test-utils/story-config.d.ts.map +1 -1
- package/build/types/uploadInput/uploadButton/getAllowedFileTypes.d.ts.map +1 -1
- package/build/upload/steps/completeStep/completeStep.js +2 -2
- package/build/upload/steps/completeStep/completeStep.js.map +1 -1
- package/build/upload/steps/completeStep/completeStep.mjs +1 -1
- package/build/upload/steps/processingStep/processingStep.js +2 -2
- package/build/upload/steps/processingStep/processingStep.js.map +1 -1
- package/build/upload/steps/processingStep/processingStep.mjs +1 -1
- package/build/uploadInput/UploadInput.js +3 -3
- package/build/uploadInput/UploadInput.js.map +1 -1
- package/build/uploadInput/UploadInput.mjs +1 -1
- package/build/uploadInput/uploadButton/getAllowedFileTypes.js +23 -3
- package/build/uploadInput/uploadButton/getAllowedFileTypes.js.map +1 -1
- package/build/uploadInput/uploadButton/getAllowedFileTypes.mjs +23 -3
- package/build/uploadInput/uploadButton/getAllowedFileTypes.mjs.map +1 -1
- package/package.json +3 -3
- package/src/alert/Alert.tests.story.tsx +1 -1
- package/src/avatarLayout/AvatarLayout.css +2 -12
- package/src/avatarLayout/AvatarLayout.less +2 -19
- package/src/avatarLayout/AvatarLayout.tsx +3 -10
- package/src/button/Button.css +15 -204
- package/src/button/Button.less +14 -211
- package/src/button/Button.spec.tsx +227 -75
- package/src/button/Button.story.tsx +135 -728
- package/src/button/Button.tsx +131 -94
- package/src/button/__snapshots__/Button.spec.tsx.snap +309 -0
- package/src/button/index.ts +3 -2
- package/src/drawer/Drawer.spec.tsx +93 -0
- package/src/field/Field.story.tsx +1 -1
- package/src/flowNavigation/__snapshots__/FlowNavigation.spec.js.snap +1 -1
- package/src/index.ts +12 -0
- package/src/inputs/SelectInput.story.tsx +1 -1
- package/src/label/Label.story.tsx +1 -1
- package/src/link/Link.tsx +6 -15
- package/src/main.css +13 -224
- package/src/main.less +0 -1
- package/src/nudge/Nudge.css +11 -0
- package/src/nudge/Nudge.less +3 -0
- package/src/nudge/Nudge.story.tsx +10 -0
- package/src/nudge/Nudge.tsx +2 -1
- package/src/primitives/PrimitiveAnchor/src/PrimitiveAnchor.tsx +7 -1
- package/src/primitives/PrimitiveAnchor/src/PrimitiveAnchor.types.ts +2 -7
- package/src/primitives/PrimitiveAnchor/test/PrimitiveAnchor.spec.tsx +3 -1
- package/src/primitives/PrimitiveButton/src/PrimitiveButton.tsx +8 -1
- package/src/primitives/PrimitiveButton/test/PrimitiveButton.spec.tsx +5 -2
- package/src/test-utils/Parameters.d.ts +1 -9
- package/src/test-utils/story-config.ts +1 -10
- package/src/uploadInput/UploadInput.tests.story.tsx +5 -5
- package/src/uploadInput/uploadButton/getAllowedFileTypes.spec.ts +12 -0
- package/src/uploadInput/uploadButton/getAllowedFileTypes.ts +33 -7
- package/build/button/Button.resolver.js +0 -74
- package/build/button/Button.resolver.js.map +0 -1
- package/build/button/Button.resolver.mjs +0 -72
- package/build/button/Button.resolver.mjs.map +0 -1
- package/build/button/LegacyButton.js +0 -114
- package/build/button/LegacyButton.js.map +0 -1
- package/build/button/LegacyButton.mjs +0 -112
- package/build/button/LegacyButton.mjs.map +0 -1
- package/build/styles/button/Button.vars.css +0 -39
- package/build/styles/button/LegacyButton.css +0 -23
- package/build/types/button/Button.resolver.d.ts +0 -33
- package/build/types/button/Button.resolver.d.ts.map +0 -1
- package/build/types/button/Button.types.d.ts +0 -58
- package/build/types/button/Button.types.d.ts.map +0 -1
- package/build/types/button/LegacyButton.d.ts +0 -30
- package/build/types/button/LegacyButton.d.ts.map +0 -1
- package/src/button/Button.resolver.tsx +0 -73
- package/src/button/Button.tests.story.tsx +0 -27
- package/src/button/Button.types.ts +0 -74
- package/src/button/Button.vars.css +0 -39
- package/src/button/Button.vars.less +0 -50
- package/src/button/LegacyButton.css +0 -23
- package/src/button/LegacyButton.less +0 -24
- package/src/button/LegacyButton.spec.tsx +0 -147
- package/src/button/LegacyButton.story.tsx +0 -225
- package/src/button/LegacyButton.tsx +0 -160
- package/src/drawer/Drawer.rtl.spec.tsx +0 -59
- package/src/drawer/Drawer.spec.js +0 -101
- package/src/drawer/__snapshots__/Drawer.rtl.spec.tsx.snap +0 -55
package/src/button/Button.tsx
CHANGED
|
@@ -1,117 +1,154 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import {
|
|
1
|
+
import { clsx } from 'clsx';
|
|
2
|
+
import { ElementType, forwardRef, MouseEvent } from 'react';
|
|
3
|
+
import { useIntl } from 'react-intl';
|
|
4
|
+
|
|
4
5
|
import {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
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
|
-
|
|
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
|
|
59
|
+
as: component,
|
|
60
|
+
block = false,
|
|
20
61
|
children,
|
|
21
62
|
className,
|
|
22
|
-
|
|
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
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
65
|
+
priority = Priority.PRIMARY,
|
|
66
|
+
size = Size.MEDIUM,
|
|
67
|
+
type = ControlType.ACCENT,
|
|
68
|
+
onClick,
|
|
69
|
+
...rest
|
|
70
|
+
}: Props,
|
|
71
|
+
reference,
|
|
38
72
|
) => {
|
|
39
|
-
const
|
|
40
|
-
|
|
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
|
-
|
|
43
|
-
|
|
44
|
-
|
|
84
|
+
'btn-loading': loading,
|
|
85
|
+
'btn-block np-btn-block': block,
|
|
86
|
+
disabled,
|
|
45
87
|
},
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
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
|
-
|
|
53
|
-
[
|
|
54
|
-
}
|
|
97
|
+
function processIndicatorSize() {
|
|
98
|
+
return ['sm', 'xs'].includes(size) ? 'xxs' : 'xs';
|
|
99
|
+
}
|
|
55
100
|
|
|
56
|
-
const
|
|
57
|
-
|
|
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 (
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
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
|
-
<
|
|
106
|
-
ref={
|
|
107
|
-
{
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
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
|
-
{
|
|
114
|
-
|
|
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
|
+
`;
|
package/src/button/index.ts
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
|
-
export { default } from './Button
|
|
2
|
-
|
|
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 @@ 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
|
>
|