UNPKG

@wordpress/components

Version:
49 lines (41 loc) 1.45 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = Slot; var _element = require("@wordpress/element"); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _slotFillContext = _interopRequireDefault(require("./slot-fill-context")); /** * WordPress dependencies */ /** * Internal dependencies */ function Slot({ name, fillProps = {}, as: Component = 'div', ...props }) { const registry = (0, _element.useContext)(_slotFillContext.default); const ref = (0, _element.useRef)(); (0, _element.useLayoutEffect)(() => { registry.registerSlot(name, ref, fillProps); return () => { registry.unregisterSlot(name, ref); }; // We are not including fillProps in the deps because we don't want to // unregister and register the slot whenever fillProps change, which would // cause the fill to be re-mounted. We are only considering the initial value // of fillProps. }, [registry.registerSlot, registry.unregisterSlot, name]); // fillProps may be an update that interacts with the layout, so we // useLayoutEffect (0, _element.useLayoutEffect)(() => { registry.updateSlot(name, fillProps); }); return (0, _element.createElement)(Component, (0, _extends2.default)({ ref: ref }, props)); } //# sourceMappingURL=slot.js.map