woocommerce/plugins/woocommerce-admin/client/customize-store/assembler-hub/sidebar/navigation-extra-screen/sidebar-navigation-extra-sc...

52 lines
1.2 KiB
TypeScript

/**
* External dependencies
*/
import { useQuery } from '@woocommerce/navigation';
import { useMemo } from '@wordpress/element';
/**
* Internal dependencies
*/
import { SidebarPatternScreen } from '../pattern-screen/sidebar-pattern-screen';
import './style.scss';
import { PATTERN_CATEGORIES } from '../pattern-screen/categories';
const getPatternCategoryByPath = ( path: string ) => {
// Define the regex pattern to match everything after "/homepage/"
const regex = /\/homepage\/(.*)/;
// Apply the regex pattern to the pathname part of the URL
const match = path.match( regex );
const patternCategory = match?.[ 1 ];
if (
patternCategory &&
Object.keys( PATTERN_CATEGORIES ).includes( patternCategory )
) {
return patternCategory;
}
return null;
};
export const SidebarNavigationExtraScreen = () => {
const { path } = useQuery();
const patternCategory = useMemo(
() => ( path ? getPatternCategoryByPath( path ) : null ),
[ path ]
);
if ( patternCategory ) {
return (
<div className="woocommerce-customize-store-edit-site-layout__sidebar-extra">
<SidebarPatternScreen category={ patternCategory } />;
</div>
);
}
return null;
};