1 | import { createComponent } from "reakit-system/createComponent";
|
2 | import { createHook } from "reakit-system/createHook";
|
3 | import { useForkRef } from "reakit-utils/useForkRef";
|
4 | import {
|
5 | DialogDisclosureOptions,
|
6 | DialogDisclosureHTMLProps,
|
7 | useDialogDisclosure,
|
8 | } from "../Dialog/DialogDisclosure";
|
9 | import { PopoverStateReturn } from "./PopoverState";
|
10 | import { POPOVER_DISCLOSURE_KEYS } from "./__keys";
|
11 |
|
12 | export type PopoverDisclosureOptions = DialogDisclosureOptions &
|
13 | Pick<Partial<PopoverStateReturn>, "unstable_referenceRef">;
|
14 |
|
15 | export type PopoverDisclosureHTMLProps = DialogDisclosureHTMLProps;
|
16 |
|
17 | export type PopoverDisclosureProps = PopoverDisclosureOptions &
|
18 | PopoverDisclosureHTMLProps;
|
19 |
|
20 | export const usePopoverDisclosure = createHook<
|
21 | PopoverDisclosureOptions,
|
22 | PopoverDisclosureHTMLProps
|
23 | >({
|
24 | name: "PopoverDisclosure",
|
25 | compose: useDialogDisclosure,
|
26 | keys: POPOVER_DISCLOSURE_KEYS,
|
27 |
|
28 | useProps(options, { ref: htmlRef, ...htmlProps }) {
|
29 | return {
|
30 | ref: useForkRef(options.unstable_referenceRef, htmlRef),
|
31 | ...htmlProps,
|
32 | };
|
33 | },
|
34 | });
|
35 |
|
36 | export const PopoverDisclosure = createComponent({
|
37 | as: "button",
|
38 | memo: true,
|
39 | useHook: usePopoverDisclosure,
|
40 | });
|