diff --git a/packages/components/src/tab-panel/index.js b/packages/components/src/tab-panel/index.js index 8ca38e19927b0..fa867139c0339 100644 --- a/packages/components/src/tab-panel/index.js +++ b/packages/components/src/tab-panel/index.js @@ -7,7 +7,7 @@ import { partial, noop, find } from 'lodash'; /** * WordPress dependencies */ -import { useState } from '@wordpress/element'; +import { useState, useEffect } from '@wordpress/element'; import { useInstanceId } from '@wordpress/compose'; /** @@ -39,9 +39,7 @@ export default function TabPanel( { onSelect = noop, } ) { const instanceId = useInstanceId( TabPanel, 'tab-panel' ); - const [ selected, setSelected ] = useState( - initialTabName || ( tabs.length > 0 ? tabs[ 0 ].name : null ) - ); + const [ selected, setSelected ] = useState( null ); const handleClick = ( tabKey ) => { setSelected( tabKey ); @@ -51,9 +49,17 @@ export default function TabPanel( { const onNavigate = ( childIndex, child ) => { child.click(); }; - const selectedTab = find( tabs, { name: selected } ); - const selectedId = `${ instanceId }-${ selectedTab.name }`; + const selectedId = `${ instanceId }-${ selectedTab?.name ?? 'none' }`; + + useEffect( () => { + const newSelectedTab = find( tabs, { name: selected } ); + if ( ! newSelectedTab ) { + setSelected( + initialTabName || ( tabs.length > 0 ? tabs[ 0 ].name : null ) + ); + } + }, [ tabs ] ); return (