@wordpress/block-editor
Version:
57 lines (56 loc) • 2.16 kB
JavaScript
// packages/block-editor/src/components/link-control/settings-drawer.js
import {
Button,
__unstableMotion as motion,
__unstableAnimatePresence as AnimatePresence
} from "@wordpress/components";
import { chevronLeftSmall, chevronRightSmall } from "@wordpress/icons";
import { useReducedMotion, useInstanceId } from "@wordpress/compose";
import { _x, isRTL } from "@wordpress/i18n";
import { Fragment } from "@wordpress/element";
import { Fragment as Fragment2, jsx, jsxs } from "react/jsx-runtime";
function LinkSettingsDrawer({ children, settingsOpen, setSettingsOpen }) {
const prefersReducedMotion = useReducedMotion();
const MaybeAnimatePresence = prefersReducedMotion ? Fragment : AnimatePresence;
const MaybeMotionDiv = prefersReducedMotion ? "div" : motion.div;
const id = useInstanceId(LinkSettingsDrawer);
const settingsDrawerId = `link-control-settings-drawer-${id}`;
return /* @__PURE__ */ jsxs(Fragment2, { children: [
/* @__PURE__ */ jsx(
Button,
{
__next40pxDefaultSize: true,
className: "block-editor-link-control__drawer-toggle",
"aria-expanded": settingsOpen,
onClick: () => setSettingsOpen(!settingsOpen),
icon: isRTL() ? chevronLeftSmall : chevronRightSmall,
"aria-controls": settingsDrawerId,
children: _x("Advanced", "Additional link settings")
}
),
/* @__PURE__ */ jsx(MaybeAnimatePresence, { children: settingsOpen && /* @__PURE__ */ jsx(
MaybeMotionDiv,
{
className: "block-editor-link-control__drawer",
hidden: !settingsOpen,
id: settingsDrawerId,
initial: "collapsed",
animate: "open",
exit: "collapsed",
variants: {
open: { opacity: 1, height: "auto" },
collapsed: { opacity: 0, height: 0 }
},
transition: {
duration: 0.1
},
children: /* @__PURE__ */ jsx("div", { className: "block-editor-link-control__drawer-inner", children })
}
) })
] });
}
var settings_drawer_default = LinkSettingsDrawer;
export {
settings_drawer_default as default
};
//# sourceMappingURL=settings-drawer.js.map