import Grid from 'components/grid';
import DynamicHeroIcon from 'components/hero-icon';
import { getMetaobjects, getMetaobjectsByIds } from 'lib/shopify';
import { PageContent, ScreenSize } from 'lib/shopify/types';
export const IconBlockPlaceholder = () => {
return (
);
};
const IconWithTextBlock = async ({ content }: { content: PageContent }) => {
// for icon with text content, we only need the first metaobject as the array always contains only one element due to the metafield definition set up on Shopify
const metaobject = content.metaobjects[0];
if (!metaobject) return null;
const [contentBlocks, layouts, screenSizes] = await Promise.all([
getMetaobjectsByIds(metaobject.content ? JSON.parse(metaobject.content) : []),
getMetaobjectsByIds(metaobject.layouts ? JSON.parse(metaobject.layouts) : []),
getMetaobjects('screen_sizes')
]);
const availableLayouts = layouts.reduce(
(acc, layout) => {
const screenSize = screenSizes.find((screen) => screen.id === layout.screen_size);
if (screenSize?.size) {
acc[screenSize.size.toLowerCase() as ScreenSize] = Number(layout.number_of_columns);
}
return acc;
},
{} as Record
);
let classnames = {} as { [key: string]: boolean };
if (availableLayouts.small) {
classnames = {
...classnames,
'sm:grid-cols-1': availableLayouts.small === 1,
'sm:grid-cols-2': availableLayouts.small === 2,
'sm:grid-cols-3': availableLayouts.small === 3,
'sm:grid-cols-4': availableLayouts.small === 4
};
}
if (availableLayouts.medium) {
classnames = {
...classnames,
'md:grid-cols-1': availableLayouts.medium === 1,
'md:grid-cols-2': availableLayouts.medium === 2,
'md:grid-cols-3': availableLayouts.medium === 3,
'md:grid-cols-4': availableLayouts.medium === 4
};
}
if (availableLayouts.large) {
classnames = {
...classnames,
'lg:grid-cols-1': availableLayouts.large === 1,
'lg:grid-cols-2': availableLayouts.large === 2,
'lg:grid-cols-3': availableLayouts.large === 3,
'lg:grid-cols-4': availableLayouts.large === 4
};
}
const validClassnames = Object.keys(classnames)
.filter((key) => classnames[key])
.join(' ');
return (
{metaobject.title}
{contentBlocks.map((block) => (
{block.icon_name && (
)}
{block.title}
{block.content}
))}
);
};
export default IconWithTextBlock;