Customized Layouts

Layouts are written in YAML syntax. Before starting to create a custom layout, it is a good idea to study the pre-designed layouts, to get a better understanding of how they work. Then, create a new layout and reference it in the social_cards conf.py option (or within the social-card directive’s argument).

layouts/custom.yml is located adjacent to conf.py file
size: { width: 1200, height: 630 }
layers: []
social_cards = { # (1)!
    "cards_layout_dir": "layouts",
    "cards_layout": "custom"
}
  1. The required site_url is elided here for brevity.

.. social-card:: {
        "cards_layout_dir" = "layouts",
        "cards_layout" = "custom",
    }

Card Layout Options

class Cards_Layout_Options

There are some options that are used as default values for the layout’s subsequent layers. These values are set with cards_layout_options and are added to the layout.* jinja context (for customizable re-use in layer attributes).

Seealso

This section heavily relies on knowledge about Using Jinja Syntax within the Layout

background_image : Annotated[str | Path, AfterValidator(func=_validate_path)] | None

The fallback value used for a layer’s background.image attribute. Default is None. This image will not be shown if the background_color has no alpha channel (transparency) value.

conf.py
social_cards = {
    "description": "Generate social media cards for documentation pages with Sphinx",
    "site_url": "https://2bndy5.github.io/sphinx-social-cards/",
    "cards_layout_options": {
        "background_image": "images/rainbow.png"
    }
}
my-layout.yml
layers:
  - background:
      image: '{{ layout.background_image }}'

A image generated by sphinx-social-cards

background_color : Color | Linear_Gradient | Radial_Gradient | Conical_Gradient | None

The fallback value used for a layer’s background.color attribute in most pre-designed layouts. By default, this value is set to the palette[primary] color or "#4051B2" for themes other than sphinx-immaterial.

conf.py
social_cards = {
    "description": "Generate social media cards for documentation pages with Sphinx",
    "site_url": "https://2bndy5.github.io/sphinx-social-cards/",
    "cards_layout_options": {
        "background_color": "rgb(90, 32, 166)"
    }
}
my-layout.yml
layers:
  - background:
      color: '{{ layout.background_color | yaml }}'

A image generated by sphinx-social-cards

color : Color | Linear_Gradient | Radial_Gradient | Conical_Gradient | None

The color used for the foreground text in most pre-designed layouts. By default, this will be computed as "white" or "black" based on the background_color.

conf.py
social_cards = {
    "description": "Generate social media cards for documentation pages with Sphinx",
    "site_url": "https://2bndy5.github.io/sphinx-social-cards/",
    "cards_layout_options": {
        "color": "#0FF1CE"
    }
}
my-layout.yml
size: { width: 600, height: 125 }
layers:
  - background: { color: black }
  - typography:
      content: "'{{ layout.color }}'"
      color: '{{ layout.color | yaml }}'
      align: center
      line: { amount: 2 }

A image generated by sphinx-social-cards

accent : Color | Linear_Gradient | Radial_Gradient | Conical_Gradient | None

The color used as a foreground accentuating color. By default, this value is set to the palette[accent] color or "#4051B2" for themes other than sphinx-immaterial.

conf.py
social_cards = {
    "description": "Generate social media cards for documentation pages with Sphinx",
    "site_url": "https://2bndy5.github.io/sphinx-social-cards/",
    "cards_layout_options": {
        "accent": "hsl(35.7, 100%, 65.1%)"
    }
}
my-layout.yml
layers:
  - background:
      color: '{{ layout.accent| yaml }}'

A image generated by sphinx-social-cards

font : Font | None

The font specification to be used.

Seealso

Please review Choosing the font section.

conf.py
social_cards = {
    "description": "Generate social media cards for documentation pages with Sphinx",
    "site_url": "https://2bndy5.github.io/sphinx-social-cards/",
    "cards_layout_options": {
        "font": {
            "family": "Roboto",
            "style": "italic"
        }
    }
}
my-layout.yml
size: { width: 600, height: 125 }
layers:
  - background: { color: black }
  - typography:
      content: '{{ layout.font.family }}' '{{ layout.font.style }}'
      line: { amount: 2 }
      align: center

A image generated by sphinx-social-cards

The icon used for branding of the site. By default, this will be the html_logo (or the sphinx-immaterial theme’s icon[logo]).

In most pre-designed layouts, the image’s color is used as is. This behavior can be changed by setting this option.

Most pre-designed layouts use the icon metadata field to overridden the image value per page.

conf.py
social_cards = {
    "description": "Generate social media cards for documentation pages with Sphinx",
    "site_url": "https://2bndy5.github.io/sphinx-social-cards/",
    "cards_layout_options": {
        "logo": {
            "image": "images/message.png",
            "color": "#4051B2"
        }
    }
}
my-layout.yml
size: { width: 250, height: 250 }
layers:
  - background: { color: black }
  - icon:
      image: '{{ layout.logo.image }}'
      color: '{{ layout.logo.color | yaml }}'

A image generated by sphinx-social-cards

Layout Attributes

class Layout

The size attribute is not required (see width and height for default values), but the layers attribute is required.

Each layout supports these options:

size : Size

The card’s absolute maximum size. Any layers with no size specified will fallback to this layout.size. If this is not specified, then the layout uses the default width and height values.

layers : List[Layer]

A YAML list of layers in the layout that define the entire content of the layout.

Positioning Attributes

The layout’s and individual layer’s size and the individual layer’s offset are defined in pixels. The size is defined by a width and height property, and the offset is defined by x and y properties:

my-layout.yml
size: { width: 300, height: 300 } # the layout maximum size
layers:  # each layer in this list is denoted with a dash ('-')
  - {}
  - size: { width: 240, height: 240 }
    offset: { x: 30, y: 30 }

A image generated by sphinx-social-cards

The layer outline and grid are visible because we enabled debug in the social_cards configuration. The rest of the image is transparent because there are no layers with any actual content specified (like background, icon or typography).

Upon closer inspection you’ll notice that

class Size

An attribute to describe a layer’s or layout’s size.

width : Annotated[int, FieldInfo(annotation=NoneType, required=True, metadata=[Gt(gt=0)])]

The width of the layer (relative to the offset). Defaults to 1200 pixels width.

height : Annotated[int, FieldInfo(annotation=NoneType, required=True, metadata=[Gt(gt=0)])]

The height of the layer (relative to the offset). Defaults to 630 pixels height.

class Offset

An attribute to describe a layer’s positional offset.

x : int

The offset on the X axis (relative to the top-left corner of the card). Defaults to 0.

y : int

The offset on the Y axis (relative to the top-left corner of the card). Defaults to 0.