import { PortableText, stegaClean } from 'next-sanity'
import CTAsSubModule, { type CTAsSubModuleType } from './CTAsSubModule'
import CustomHTMLSubmodule, {
type CustomHTMLSubmoduleType,
} from './CustomHTMLSubmodule'
import IconSubModule, { type IconSubModuleType } from './IconSubModule'
import ImageSubModule, { type ImageSubModuleType } from './ImageSubModule'
import RichtextSubModule, {
type RichtextSubModuleType,
} from './RichtextSubModule'
import { cn } from '@/lib/utils'
import moduleProps from '@/lib/moduleProps'
export default function CreativeModule({
intro,
modules,
columns,
visualSeparation,
textAlign,
alignItems,
...props
}: Partial<{
intro: any
modules: Partial<{
subModules: Array<
| CTAsSubModuleType
| CustomHTMLSubmoduleType
| IconSubModuleType
| ImageSubModuleType
| RichtextSubModuleType
>
colSpan: number
}>[]
columns: number
visualSeparation: boolean
textAlign: React.CSSProperties['textAlign']
alignItems: React.CSSProperties['alignItems']
}>) {
const imageWidth = Math.round((1200 / (modules?.length || 1)) * 1.5)
return (
<section {...moduleProps(props)}>
<div className="section space-y-8">
{intro && (
<header className="richtext mx-auto max-w-xl text-balance text-center">
<PortableText value={intro} />
</header>
)}
<div
className={cn(
'grid items-center md:grid-cols-[repeat(var(--col,1),minmax(0px,1fr))]',
visualSeparation ? 'gap-4' : 'gap-x-12 gap-y-8',
)}
style={
{
'--col': columns || modules?.length,
textAlign: stegaClean(textAlign),
alignItems: visualSeparation ? 'stretch' : stegaClean(alignItems),
} as React.CSSProperties
}
>
{modules?.map(({ subModules, colSpan = 1 }, i) => (
<article
className={cn(
'space-y-4',
colSpan > 1 && 'md:col-[var(--col-span,1)]',
visualSeparation && 'rounded bg-neutral-50 p-6',
)}
style={
{
'--col-span': colSpan > 1 && `span ${colSpan}`,
} as React.CSSProperties
}
key={i}
>
{subModules?.map((subModule, ii) => {
switch (subModule._type) {
case 'ctas':
return (
<CTAsSubModule
module={subModule}
className={cn(
stegaClean(textAlign) === 'center' &&
'justify-center',
)}
key={ii}
/>
)
case 'custom-html':
return <CustomHTMLSubmodule module={subModule} />
case 'icon':
return (
<IconSubModule
module={subModule}
className={cn(
stegaClean(textAlign) === 'center' &&
'[&_img]:mx-auto',
)}
key={ii}
/>
)
case 'image':
return (
<ImageSubModule
module={subModule}
imageWidth={imageWidth * colSpan}
key={ii}
/>
)
case 'richtext':
return <RichtextSubModule module={subModule} key={ii} />
}
})}
</article>
))}
</div>
</div>
</section>
)
}