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.
Reference the Simple Schema GitHub repository for more information.
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.
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?