UNPKG

@wordpress/components

Version:
41 lines (40 loc) 1.26 kB
// packages/components/src/slot-fill/bubbles-virtually/slot.tsx import { useRef, useLayoutEffect, useContext, forwardRef } from "@wordpress/element"; import { useMergeRefs } from "@wordpress/compose"; import { View } from "../../view"; import SlotFillContext from "./slot-fill-context"; import { jsx as _jsx } from "react/jsx-runtime"; function Slot(props, forwardedRef) { const { name, fillProps = {}, as, // `children` is not allowed. However, if it is passed, // it will be displayed as is, so remove `children`. children, ...restProps } = props; const registry = useContext(SlotFillContext); const ref = useRef(null); const fillPropsRef = useRef(fillProps); useLayoutEffect(() => { fillPropsRef.current = fillProps; }, [fillProps]); useLayoutEffect(() => { registry.registerSlot(name, ref, fillPropsRef.current); return () => registry.unregisterSlot(name, ref); }, [registry, name]); useLayoutEffect(() => { registry.updateSlot(name, ref, fillPropsRef.current); }); return /* @__PURE__ */ _jsx(View, { as, ref: useMergeRefs([forwardedRef, ref]), ...restProps }); } var slot_default = forwardRef(Slot); export { slot_default as default }; //# sourceMappingURL=slot.js.map