import BlurbSection from '@/components/modules/blurb-section/blurb-section'; import FilteredProductList from '@/components/modules/filtered-product-list/filtered-product-list'; import Hero from '@/components/modules/hero'; import ReusableSection from '@/components/modules/reusable-section/reusable-section'; import Slider from '@/components/modules/slider/slider'; import USPSection from '@/components/modules/usp-section/usp-section'; import { InformationCircleIcon } from '@heroicons/react/24/outline'; interface getContentComponentProps { _type: string; _key: number; disabled: boolean; } const getContentComponent = ({ _type, _key, disabled, ...rest }: getContentComponentProps) => { let Component: any; switch (_type) { case 'hero': if (disabled !== true) { Component = Hero; } else { return; } break; case 'slider': if (disabled !== true) { Component = Slider; } else { return; } break; case 'filteredProductList': if (disabled !== true) { Component = FilteredProductList; } else { return; } break; case 'blurbSection': if (disabled !== true) { Component = BlurbSection; } else { return; } break; case 'uspSection': if (disabled !== true) { Component = USPSection; } else { return; } break; case 'reusableSection': if (disabled !== true) { Component = ReusableSection; } else { return; } break; default: return (
{`No matching component (Type: ${_type})`}
); } return Component ? ( ) : (
Something else
); }; interface dynamicContentManagerProps { content: [] | any; } const DynamicContentManager = ({ content }: dynamicContentManagerProps) => { return (
{content?.map(getContentComponent)}
); }; export default DynamicContentManager;