Skip to main content
Our new developer certification is live!

IconCard

Card component optimized for displaying icons with optional title and description.

Props

PropTypeRequiredDefaultDescription
cardCardDataYes-Card data object (same as DefaultCard)
variant'default' | 'centered'No'default'Layout variant
size'default' | 'small'No'default'Size variant (only applies to centered)
prioritybooleanNofalseLoads the icon image eagerly with fetchPriority="high" (for above-the-fold cards)
cslpCSLPFieldMappingNo-CSLP mapping for editable fields

Variants

Default

  • Horizontal layout with icon and title side-by-side
  • Gradient background
  • Taxonomy tags (TechnologyTags with icons for kickstart)

Centered

  • Vertical centered layout
  • Square aspect ratio (or 100x100px for small)
  • Icon centered above title
  • No description

Usage

import { IconCard } from '@/components/organisms/IconCard';

// Default variant
<IconCard 
  card={{
    image: { url: "/icon.svg", alt: "Icon" },
    title: "Feature",
    description: "Description",
    url: "/feature"
  }}
/>

// Centered variant
<IconCard 
  card={{
    image: { url: "/icon.svg", alt: "Icon" },
    title: "Feature",
    url: "/feature"
  }}
  variant="centered"
  size="small"
/>

Features

  • Icon-focused: Optimized for icon display
  • Two variants: Default (horizontal) and centered (vertical)
  • Size options: Small (100x100px) or default for centered variant
  • Gradient background: Default variant uses curated-product-card-gradient
  • Hover effects: Scale transform on hover
  • Priority loading: Supports priority prop for above-the-fold images (passed through to MediaItem/Next.js Image)

Size Details (Centered Variant)

  • Default: Aspect square, p-8, icon 64x64px, cs-h5 title
  • Small: 100x100px fixed, p-4, icon 40x40px, cs-h6 title

Notes

  • Centered variant: icon + title only, no taxonomies or date
  • Default variant: uses CardTaxonomies for taxonomy display
  • Uses MediaItem component for icons
  • Links to card URL using Next.js Link
  • Supports CSLP for live preview editing