Title Schema

Introduction

Schemas are structured definitions that describe the format, rules, and relationships of data within a system. They ensure consistency and validate inputs. In Beefree SDK, the Simple Title Schema defines how titles (headings) are represented within builders for emails, pages, and popups. It manages styling, typography, alignment, and responsive behavior. This documentation breaks down the schema's properties, requirements, and usage examples to help you implement and extend title blocks effectively.

Schema Overview

This section summarizes the purpose and key characteristics of the Simple Title Schema.

  • Schema Name: Simple Title

  • Purpose: Defines title elements (e.g., headings) with formatting options like bold, underline, alignment, and spacing.

  • Related Schemas:

    • definitions.schema.json (for padding definitions)

Structure Definition

Below is the JSON Schema definition and a detailed breakdown of each property.

JSON Schema

{
  "$schema": "http://json-schema.org/draft-07/schema",
  "$id": "simple_title.schema.json",
  "title": "Simple Title",
  "type": "object",
  "additionalProperties": false,
  "properties": {
    "type": {
      "enum": [
        "title",
        "heading"
      ]
    },
    "underline": {
      "type": "boolean"
    },
    "italic": {
      "type": "boolean"
    },
    "bold": {
      "type": "boolean"
    },
    "html": {
      "type": "string"
    },
    "text": {
      "type": "string"
    },
    "align": {
      "enum": [
        "left",
        "center",
        "right",
        "justify"
      ]
    },
    "title": {
      "enum": [
        "h1",
        "h2",
        "h3"
      ]
    },
    "size": {
      "type": "integer",
      "minimum": 1
    },
    "color": {
      "type": "string"
    },
    "linkColor": {
      "type": "string"
    },
    "letter-spacing": {
      "type": "integer",
      "minimum": -99,
      "maximum": 99
    },
    "line-height": {
      "type": "number",
      "minimum": 0.5,
      "maximum": 3,
      "multipleOf": 0.00001
    },
    "direction": {
      "enum": [
        "ltr",
        "rtl"
      ]
    },
    "padding-top": {
      "$ref": "definitions.schema.json#/definitions/padding"
    },
    "padding-right": {
      "$ref": "definitions.schema.json#/definitions/padding"
    },
    "padding-bottom": {
      "$ref": "definitions.schema.json#/definitions/padding"
    },
    "padding-left": {
      "$ref": "definitions.schema.json#/definitions/padding"
    },
    "locked": {
      "type": "boolean"
    },
    "customFields": {
      "type": "object"
    }
  }
}

Field Descriptions

The following table lists the field descriptions along with their corresponding data type, whether or not they are mandatory, and their description.

Property
Type
Mandatory
Description

text

string

No

The text content of the title

html deprecated (use text)

string

No

The text content of the title

underline

boolean

No

Whether the text is underlined

italic

boolean

No

Whether the text is italicized

bold

boolean

No

Whether the text is bold

align

enum

No

The alignment of the text

title

enum

No

The title level (h1, h2, h3)

size

integer

No

The size of the text (minimum 1)

color

string

No

The color of the text

linkColor

string

No

The color of the links

letter-spacing

integer

No

The letter spacing (-99 to 99)

line-height

number

No

The line height (0.5 to 3)

direction

enum

No

The text direction (ltr, rtl)

padding-top

integer

No

The top padding (0-60)

padding-right

integer

No

The right padding (0-60)

padding-bottom

integer

No

The bottom padding (0-60)

padding-left

integer

No

The left padding (0-60)

customFields

object

No

Custom fields

locked

boolean

No

Whether the module is locked. Note: This is not available for Single Content AddOn.

Usage Examples

Reference an example of the schema in the following code snippet.

Example Title

{
  "underline": true,
  "italic": false,
  "bold": true,
  "text": "Welcome",
  "align": "center",
  "title": "h1",
  "size": 24,
  "color": "#000000",
  "linkColor": "#FF0000",
  "letter-spacing": 1,
  "line-height": 1.5,
  "direction": "ltr",
  "padding-top": 10,
  "padding-right": 10,
  "padding-bottom": 10,
  "padding-left": 10,
  "customFields": {
    "custom1": "value1",
    "custom2": "value2"
  }
}

Additional Considerations

Consider the following when working with the Simple Title Schema in Beefree SDK:

  • Extensibility: Use customFields for non-standard properties.

  • Responsiveness: Text alignment and direction settings help support responsive, multilingual layouts.

Last updated

Was this helpful?