/
Button.ts
53 lines (43 loc) · 1.3 KB
/
Button.ts
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
import * as React from "react";
import { createComponent } from "reakit-system/createComponent";
import { createHook } from "reakit-system/createHook";
import { mergeRefs } from "reakit-utils/mergeRefs";
import { isButton } from "reakit-utils/isButton";
import {
TabbableOptions,
TabbableHTMLProps,
useTabbable
} from "../Tabbable/Tabbable";
export type ButtonOptions = TabbableOptions;
export type ButtonHTMLProps = TabbableHTMLProps &
React.ButtonHTMLAttributes<any>;
export type ButtonProps = ButtonOptions & ButtonHTMLProps;
export const useButton = createHook<ButtonOptions, ButtonHTMLProps>({
name: "Button",
compose: useTabbable,
useProps(_, { ref: htmlRef, ...htmlProps }) {
const ref = React.useRef<HTMLElement>(null);
const [role, setRole] = React.useState<"button" | undefined>(undefined);
const [type, setType] = React.useState<"button" | undefined>("button");
React.useEffect(() => {
const self = ref.current;
if (!self) return;
if (!isButton(self)) {
if (self.tagName !== "A") {
setRole("button");
}
setType(undefined);
}
}, []);
return {
ref: mergeRefs(ref, htmlRef),
role,
type,
...htmlProps
};
}
});
export const Button = createComponent({
as: "button",
useHook: useButton
});