A fluent builder of Schema.org types and ld+json generator based on Spatie's schema-org package which makes for a fast and easy way to add structured data to your templates.
This plugin is licensed under a MIT license, which means that it's completely free open source software, and you can use it for whatever and however you wish. If you're using it and want to support the development, buy me a beer over at Beerpay!
This plugin requires Craft CMS 3.0.0-RC1 or later and PHP 7.
To install the plugin, install it from the plugin store or follow these instructions.
-
Open your terminal and go to your Craft project:
cd /path/to/project
-
Then tell Composer to load the plugin:
composer require rias/craft-schema
-
In the Control Panel, go to Settings → Plugins and click the “Install” button for schema.
Schema provides a fluent builder for all Schema.org types and their properties. For more information and the available methods, check out spatie/schema-org.
Once Schema is installed, it's accessible through the craft
variable in your templates.
For the best experience, set the schema to a variable and typehint it to Spatie's model. In combination with the Symfony plugin for PHPStorm, you get autocompletion for all the Schema's and their properties.
For example:
{# @var schema \Spatie\SchemaOrg\Schema #}
{% set schema = craft.schema %}
{{ schema
.person
.name("Rias Van der Veken")
.email("hello@rias.be")
.company(
schema.localBusiness
.name("Marbles")
.address(schema.postalAddress
.addressCountry("Belgium")
.addressLocality("Antwerp")
.addressRegion("Antwerp")
.postalCode(2000)
.streetAddress("IJzerenpoortkaai 3")
)
) | raw
}}
Generates the following output:
<script type="application/ld+json">
{
"@context":"http:\/\/schema.org",
"@type":"Person",
"name":"Rias Van der Veken",
"email":"hello@rias.be",
"company":{
"@type":"LocalBusiness",
"name":"Marbles",
"address":{
"@type":"PostalAddress",
"addressCountry":"Belgium",
"addressLocality":"Antwerp",
"addressRegion":"Antwerp",
"postalCode":2000,
"streetAddress":"IJzerenpoortkaai 3"
}
}
}
</script>
Brought to you by Rias