@wordpress/components
Version:
UI components for WordPress.
41 lines (40 loc) • 1.26 kB
JavaScript
// 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