draft-components 4.10.2 → 4.11.0
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/css/draft-components.css +9 -0
- package/dist/components/menu/menu.d.ts +5 -3
- package/dist/components/menu/menu.js +2 -2
- package/dist/components/menu/menu.js.map +1 -1
- package/dist/components/popover/popover.css +9 -0
- package/dist/components/popover/popover.d.ts +7 -3
- package/dist/components/popover/popover.js +10 -3
- package/dist/components/popover/popover.js.map +1 -1
- package/package.json +1 -1
package/css/draft-components.css
CHANGED
|
@@ -2144,6 +2144,15 @@
|
|
|
2144
2144
|
backdrop-filter: var(--background-filter);
|
|
2145
2145
|
}
|
|
2146
2146
|
|
|
2147
|
+
.dc-popover__backdrop {
|
|
2148
|
+
position: fixed;
|
|
2149
|
+
top: 0;
|
|
2150
|
+
left: 0;
|
|
2151
|
+
z-index: var(--dc-overlay-z-index);
|
|
2152
|
+
width: 100%;
|
|
2153
|
+
height: 100%;
|
|
2154
|
+
}
|
|
2155
|
+
|
|
2147
2156
|
@keyframes dc-popover-enter {
|
|
2148
2157
|
from {
|
|
2149
2158
|
opacity: 0;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { type ComponentProps, type MouseEventHandler, type KeyboardEventHandler, type RefCallback, type JSX } from 'react';
|
|
2
|
-
import { type PopoverPlacement } from '../popover/index.js';
|
|
2
|
+
import { type GetPopoverBackdropProps, type PopoverPlacement } from '../popover/index.js';
|
|
3
3
|
import { MenuItem } from './menu-item.js';
|
|
4
4
|
import { MenuSeparator } from './menu-separator.js';
|
|
5
5
|
export type MenuOpenHandler = () => void;
|
|
@@ -21,13 +21,15 @@ export type MenuButtonRenderer = (props: {
|
|
|
21
21
|
type MenuHTMLProps = ComponentProps<'div'>;
|
|
22
22
|
type MenuBaseProps = {
|
|
23
23
|
defaultIsOpen?: boolean;
|
|
24
|
+
shouldRenderBackdrop?: boolean;
|
|
24
25
|
placement?: PopoverPlacement;
|
|
25
|
-
renderButton: MenuButtonRenderer;
|
|
26
26
|
onOpen?: MenuOpenHandler;
|
|
27
27
|
onClose?: MenuCloseHandler;
|
|
28
|
+
getBackdropProps?: GetPopoverBackdropProps;
|
|
29
|
+
renderButton: MenuButtonRenderer;
|
|
28
30
|
};
|
|
29
31
|
export type MenuProps = MenuBaseProps & Omit<MenuHTMLProps, keyof MenuBaseProps>;
|
|
30
|
-
export declare function Menu({ defaultIsOpen, placement, className, children,
|
|
32
|
+
export declare function Menu({ defaultIsOpen, shouldRenderBackdrop, placement, className, children, onClick, onKeyDown, onMouseOver, onOpen, onClose, getBackdropProps, renderButton, ...props }: MenuProps): import("react/jsx-runtime").JSX.Element;
|
|
31
33
|
export declare namespace Menu {
|
|
32
34
|
var Item: typeof MenuItem;
|
|
33
35
|
var Separator: typeof MenuSeparator;
|
|
@@ -6,7 +6,7 @@ import { useRefCallback } from '../../hooks/use-ref-callback.js';
|
|
|
6
6
|
import { Popover } from '../popover/index.js';
|
|
7
7
|
import { MenuItem } from './menu-item.js';
|
|
8
8
|
import { MenuSeparator } from './menu-separator.js';
|
|
9
|
-
export function Menu({ defaultIsOpen = false, placement = 'bottom-start', className, children,
|
|
9
|
+
export function Menu({ defaultIsOpen = false, shouldRenderBackdrop = false, placement = 'bottom-start', className, children, onClick, onKeyDown, onMouseOver, onOpen, onClose, getBackdropProps, renderButton, ...props }) {
|
|
10
10
|
const id = useId();
|
|
11
11
|
const menuId = props.id || id;
|
|
12
12
|
const buttonId = `menu-button-${menuId}`;
|
|
@@ -161,7 +161,7 @@ export function Menu({ defaultIsOpen = false, placement = 'bottom-start', classN
|
|
|
161
161
|
'onKeyDown': handleButtonKeyDown,
|
|
162
162
|
});
|
|
163
163
|
};
|
|
164
|
-
return (_jsx(Popover, { id: menuId, role: "menu", className: classNames(className, 'dc-menu'), "aria-labelledby": buttonId, tabIndex: 0, placement: placement, isOpen: isOpen, onClose: close,
|
|
164
|
+
return (_jsx(Popover, { id: menuId, role: "menu", className: classNames(className, 'dc-menu'), "aria-labelledby": buttonId, tabIndex: 0, shouldRenderBackdrop: shouldRenderBackdrop, placement: placement, isOpen: isOpen, onClose: close, onClick: handleMenuClick, onKeyDown: handleMenuKeyDown, onMouseOver: handleMenuMouseOver, getBackdropProps: getBackdropProps, renderAnchor: renderAnchor, children: children }));
|
|
165
165
|
}
|
|
166
166
|
Menu.Item = MenuItem;
|
|
167
167
|
Menu.Separator = MenuSeparator;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"menu.js","sourceRoot":"","sources":["../../../src/components/menu/menu.tsx"],"names":[],"mappings":";AAAA,OAAO,EAML,KAAK,EACL,QAAQ,GACT,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC3E,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,OAAO,
|
|
1
|
+
{"version":3,"file":"menu.js","sourceRoot":"","sources":["../../../src/components/menu/menu.tsx"],"names":[],"mappings":"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"}
|
|
@@ -27,6 +27,15 @@
|
|
|
27
27
|
backdrop-filter: var(--background-filter);
|
|
28
28
|
}
|
|
29
29
|
|
|
30
|
+
.dc-popover__backdrop {
|
|
31
|
+
position: fixed;
|
|
32
|
+
top: 0;
|
|
33
|
+
left: 0;
|
|
34
|
+
z-index: var(--dc-overlay-z-index);
|
|
35
|
+
width: 100%;
|
|
36
|
+
height: 100%;
|
|
37
|
+
}
|
|
38
|
+
|
|
30
39
|
@keyframes dc-popover-enter {
|
|
31
40
|
from {
|
|
32
41
|
opacity: 0;
|
|
@@ -1,13 +1,16 @@
|
|
|
1
1
|
import { type ElementPlacement } from '../../lib/calc-element-position.js';
|
|
2
2
|
import { type ComponentProps, type JSX, type RefCallback, type RefObject } from 'react';
|
|
3
|
+
type PopoverHTMLProps = ComponentProps<'div'>;
|
|
3
4
|
export { type ElementPlacement as PopoverPlacement };
|
|
4
5
|
export type PopoverCloseHandler = () => void;
|
|
5
6
|
export type PopoverUnmountHandler = () => void;
|
|
6
7
|
export type PopoverRenderAnchor = (props: {
|
|
7
8
|
ref: RefCallback<HTMLElement | null>;
|
|
8
9
|
}) => JSX.Element;
|
|
9
|
-
type
|
|
10
|
+
export type PopoverBackdropProps = ComponentProps<'div'>;
|
|
11
|
+
export type GetPopoverBackdropProps = () => PopoverBackdropProps;
|
|
10
12
|
type PopoverCommonProps = {
|
|
13
|
+
isOpen?: boolean;
|
|
11
14
|
placement?: ElementPlacement;
|
|
12
15
|
anchorPadding?: number;
|
|
13
16
|
viewportPadding?: number;
|
|
@@ -17,9 +20,10 @@ type PopoverCommonProps = {
|
|
|
17
20
|
shouldLockBodyScroll?: boolean;
|
|
18
21
|
shouldCloseOnEsc?: boolean;
|
|
19
22
|
shouldCloseOnClickOutside?: boolean;
|
|
20
|
-
|
|
23
|
+
shouldRenderBackdrop?: boolean;
|
|
21
24
|
onClose?: PopoverCloseHandler;
|
|
22
25
|
onUnmount?: PopoverUnmountHandler;
|
|
26
|
+
getBackdropProps?: GetPopoverBackdropProps;
|
|
23
27
|
};
|
|
24
28
|
type PopoverBaseProps = PopoverCommonProps & ({
|
|
25
29
|
anchorRef: RefObject<HTMLElement | null>;
|
|
@@ -27,4 +31,4 @@ type PopoverBaseProps = PopoverCommonProps & ({
|
|
|
27
31
|
renderAnchor: PopoverRenderAnchor;
|
|
28
32
|
});
|
|
29
33
|
export type PopoverProps = PopoverBaseProps & Omit<PopoverHTMLProps, keyof PopoverBaseProps>;
|
|
30
|
-
export declare function Popover({ className, role, 'aria-modal': ariaModal, placement, anchorPadding, viewportPadding, shouldTrapFocus, shouldLockBodyScroll, shouldCloseOnEsc, shouldCloseOnClickOutside,
|
|
34
|
+
export declare function Popover({ className, role, 'aria-modal': ariaModal, isOpen, placement, anchorPadding, viewportPadding, shouldTrapFocus, shouldLockBodyScroll, shouldCloseOnEsc, shouldCloseOnClickOutside, shouldRenderBackdrop, children, onClose, onUnmount, getBackdropProps, ...props }: PopoverProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { jsx as _jsx,
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
2
|
import { classNames, tryToFocusElement } from '../../lib/react-helpers.js';
|
|
3
3
|
import { observeElementMove } from '../../lib/observe-element-move.js';
|
|
4
4
|
import { observeElementChange } from '../../lib/observe-element-change.js';
|
|
@@ -12,7 +12,7 @@ import { useCloseOnClickOutside } from '../../hooks/use-close-on-click-outside.j
|
|
|
12
12
|
import { useEffect, useRef, useState } from 'react';
|
|
13
13
|
import { Portal } from '../portal/portal.js';
|
|
14
14
|
export {};
|
|
15
|
-
export function Popover({ className, role = 'dialog', 'aria-modal': ariaModal = true, placement = 'bottom-start', anchorPadding = 4, viewportPadding = 4, shouldTrapFocus = true, shouldLockBodyScroll = true, shouldCloseOnEsc = true, shouldCloseOnClickOutside = true,
|
|
15
|
+
export function Popover({ className, role = 'dialog', 'aria-modal': ariaModal = true, isOpen = false, placement = 'bottom-start', anchorPadding = 4, viewportPadding = 4, shouldTrapFocus = true, shouldLockBodyScroll = true, shouldCloseOnEsc = true, shouldCloseOnClickOutside = true, shouldRenderBackdrop = false, children = null, onClose, onUnmount, getBackdropProps, ...props }) {
|
|
16
16
|
const [isMounted, setIsMounted] = useState(isOpen);
|
|
17
17
|
const defaultAnchorRef = useRef(null);
|
|
18
18
|
const popoverRef = useRef(null);
|
|
@@ -107,10 +107,17 @@ export function Popover({ className, role = 'dialog', 'aria-modal': ariaModal =
|
|
|
107
107
|
};
|
|
108
108
|
}
|
|
109
109
|
}, [isOpen]);
|
|
110
|
+
let backdropElement = null;
|
|
111
|
+
if (shouldRenderBackdrop) {
|
|
112
|
+
const backdropProps = typeof getBackdropProps === 'function'
|
|
113
|
+
? getBackdropProps()
|
|
114
|
+
: {};
|
|
115
|
+
backdropElement = (_jsx("div", { ...backdropProps, className: classNames('dc-popover__backdrop', backdropProps.className) }));
|
|
116
|
+
}
|
|
110
117
|
return (_jsxs(_Fragment, { children: [!isAnchorRefProvided && props.renderAnchor({
|
|
111
118
|
ref: (el) => {
|
|
112
119
|
defaultAnchorRef.current = el;
|
|
113
120
|
},
|
|
114
|
-
}), (isOpen || isMounted) && (
|
|
121
|
+
}), (isOpen || isMounted) && (_jsxs(Portal, { children: [backdropElement, _jsx("div", { className: classNames('dc-popover', className), ref: popoverRef, role: role, "aria-modal": ariaModal, ...isAnchorRefProvided ? deleteKeys(props, 'anchorRef') : deleteKeys(props, 'renderAnchor'), children: children })] }))] }));
|
|
115
122
|
}
|
|
116
123
|
//# sourceMappingURL=popover.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"popover.js","sourceRoot":"","sources":["../../../src/components/popover/popover.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAC;AAC3E,OAAO,EAAE,mBAAmB,EAAyB,MAAM,oCAAoC,CAAC;AAChG,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAC7D,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,sBAAsB,EAAE,MAAM,2CAA2C,CAAC;AACnF,OAAO,EAAmE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACrH,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"popover.js","sourceRoot":"","sources":["../../../src/components/popover/popover.tsx"],"names":[],"mappings":"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"}
|