@wordpress/block-editor
Version:
68 lines (59 loc) • 1.46 kB
JavaScript
/**
* WordPress dependencies
*/
import { __experimentalUseSlotFills as useSlotFills } from '@wordpress/components';
import { forwardRef } from '@wordpress/element';
import warning from '@wordpress/warning';
import deprecated from '@wordpress/deprecated';
/**
* Internal dependencies
*/
import BlockSupportToolsPanel from './block-support-tools-panel';
import BlockSupportSlotContainer from './block-support-slot-container';
import groups from './groups';
function InspectorControlsSlot(
{ __experimentalGroup, group = 'default', label, fillProps, ...props },
ref
) {
if ( __experimentalGroup ) {
deprecated(
'`__experimentalGroup` property in `InspectorControlsSlot`',
{
since: '6.2',
version: '6.4',
alternative: '`group`',
}
);
group = __experimentalGroup;
}
const slotFill = groups[ group ];
const fills = useSlotFills( slotFill?.name );
if ( ! slotFill ) {
warning( `Unknown InspectorControls group "${ group }" provided.` );
return null;
}
if ( ! fills?.length ) {
return null;
}
const { Slot } = slotFill;
if ( label ) {
return (
<BlockSupportToolsPanel group={ group } label={ label }>
<BlockSupportSlotContainer
{ ...props }
fillProps={ fillProps }
Slot={ Slot }
/>
</BlockSupportToolsPanel>
);
}
return (
<Slot
{ ...props }
ref={ ref }
fillProps={ fillProps }
bubblesVirtually
/>
);
}
export default forwardRef( InspectorControlsSlot );