diff --git a/packages/block-library/src/template-part/edit/import-controls.js b/packages/block-library/src/template-part/edit/import-controls.js index 1512cd936f02cb..48178451e33dec 100644 --- a/packages/block-library/src/template-part/edit/import-controls.js +++ b/packages/block-library/src/template-part/edit/import-controls.js @@ -25,16 +25,25 @@ import { store as noticesStore } from '@wordpress/notices'; import { useCreateTemplatePartFromBlocks } from './utils/hooks'; import { transformWidgetToBlock } from './utils/transformers'; +const SIDEBARS_QUERY = { + per_page: -1, + _fields: 'id,name,description,status,widgets', +}; + export function TemplatePartImportControls( { area, setAttributes } ) { const [ selectedSidebar, setSelectedSidebar ] = useState( '' ); const [ isBusy, setIsBusy ] = useState( false ); const registry = useRegistry(); - const sidebars = useSelect( ( select ) => { - return select( coreStore ).getSidebars( { - per_page: -1, - _fields: 'id,name,description,status,widgets', - } ); + const { sidebars, hasResolved } = useSelect( ( select ) => { + const { getSidebars, hasFinishedResolution } = select( coreStore ); + + return { + sidebars: getSidebars( SIDEBARS_QUERY ), + hasResolved: hasFinishedResolution( 'getSidebars', [ + SIDEBARS_QUERY, + ] ), + }; }, [] ); const { createErrorNotice } = useDispatch( noticesStore ); @@ -67,6 +76,16 @@ export function TemplatePartImportControls( { area, setAttributes } ) { ]; }, [ sidebars ] ); + // Render an empty node while data is loading to avoid SlotFill re-positioning bug. + // See: https://github.com/WordPress/gutenberg/issues/15641. + if ( ! hasResolved ) { + return ; + } + + if ( hasResolved && ! options.length ) { + return null; + } + async function createFromWidgets( event ) { event.preventDefault();