-
-
Notifications
You must be signed in to change notification settings - Fork 303
/
ExpandableChips.tsx
94 lines (87 loc) · 2.7 KB
/
ExpandableChips.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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
import React, { FC } from "react";
import { Avatar } from "@react-md/avatar";
import { Chip } from "@react-md/chip";
import { Divider } from "@react-md/divider";
import { Label } from "@react-md/form";
import { AddCircleSVGIcon } from "@react-md/material-icons";
import { Menu, MenuItem } from "@react-md/menu";
import { bem } from "@react-md/theme";
import { useToggle } from "@react-md/utils";
import Phone from "components/Phone";
import "./ExpandableChips.scss";
const PERSONAL_EMAIL = "jjeckhart@email.com";
const WORK_EMAIL = "jjeckhart@workemail.com";
const getSrc = (isWork: boolean): string =>
`https://i.pravatar.cc/40?img=${isWork ? 4 : 3}`;
const block = bem("expandable-chip-example");
const ExpandableChips: FC = () => {
const [visible, showMenu, hideMenu] = useToggle(false);
const [isWork, , , toggleWork] = useToggle(false);
return (
<Phone id="expandable-chip-phone" contentClassName={block()}>
<div className={block("header")}>
<Label htmlFor="to-email" className={block("label")}>
To
</Label>
<Chip
id="expandable-chip"
onClick={showMenu}
className={block("chip")}
leftIcon={<Avatar src={getSrc(isWork)} />}
>
Jonas Eckhart
</Chip>
<Menu
id="expandable-chip-menu"
aria-labelledby="expandable-chip"
controlId="expandable-chip"
visible={visible}
onRequestClose={hideMenu}
anchor={{
x: "inner-left",
y: "top",
}}
>
<MenuItem
id="selected-email-item"
className={block("selection")}
leftAvatar={<Avatar src={getSrc(isWork)} />}
secondaryText={isWork ? WORK_EMAIL : PERSONAL_EMAIL}
rightIcon={<AddCircleSVGIcon className={block("remove")} />}
>
Jonas Eckhart
</MenuItem>
<MenuItem
id="other-email-item"
leftAvatar={<Avatar src={getSrc(!isWork)} />}
onClick={toggleWork}
>
{isWork ? PERSONAL_EMAIL : WORK_EMAIL}
</MenuItem>
</Menu>
<input
id="email-to"
type="email"
name="email"
placeholder="someone@email.com"
className={block("field", { email: true })}
/>
</div>
<Divider />
<input
id="email-title"
name="title"
type="text"
defaultValue="Re: Vacation Request"
className={block("field")}
/>
<Divider />
<textarea
id="email-message"
placeholder="Message"
className={block("field", { area: true })}
/>
</Phone>
);
};
export default ExpandableChips;