UNPKG

@wordpress/block-editor

Version:
57 lines (56 loc) 2.16 kB
// 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