-
Notifications
You must be signed in to change notification settings - Fork 72
/
Copy pathBasicExample.tsx
64 lines (58 loc) · 1.75 KB
/
BasicExample.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import * as React from 'react';
import styled from '@emotion/styled';
import { ReactMultiEmail } from '../react-multi-email';
import { Button } from 'antd';
interface Props {}
function BasicExample(props: Props) {
const [emails, setEmails] = React.useState<string[]>([]);
const [focused, setFocused] = React.useState(false);
return (
<Container>
<form>
<h3>Email</h3>
<ReactMultiEmail
label='Emails'
placeholder='Enter your email'
emails={emails}
onChange={(_emails: string[]) => {
setEmails(_emails);
}}
autoFocus={true}
onFocus={() => setFocused(true)}
onBlur={() => setFocused(false)}
onKeyDown={evt => {
console.log(evt);
}}
onKeyUp={evt => {
console.log(evt);
}}
getLabel={(email, index, removeEmail) => {
return (
<div data-tag key={index}>
<div data-tag-item>{email}</div>
<span data-tag-handle onClick={() => removeEmail(index)}>
×
</span>
</div>
);
}}
onChangeInput={value => {
console.log(value);
}}
/>
<br />
<h4>react-multi-email value</h4>
<h3>Focused: {focused ? 'true' : 'false'}</h3>
<p>{emails.join(', ') || 'empty'}</p>
<Button onClick={() => setEmails(['test', 'tt', '[email protected]'])}>
{`setEmails("['test', 'tt', '[email protected]']")`}
</Button>
<Button onClick={() => setEmails([])}>{`setEmails("[]")`}</Button>
</form>
</Container>
);
}
const Container = styled.div`
font-size: 13px;
`;
export default BasicExample;