Note
This does not work if you have installed the SEO Bundle! Read more about it here!
The Schema Bundles allows you to build schema blocks in two sections:
- based on request: add ld+json data to head based on request
- based on element: add ld+json data to your markup by using the
json_ld
twig helper based on given element
App\Schema\Generator\KnowledgeGraphGenerator:
autowire: true
tags:
- { name: schema.generator, alias: knowledge_graph }
<?php
namespace App\Schema\Generator;
use Spatie\SchemaOrg\Graph;
use Spatie\SchemaOrg\BaseType;
use Symfony\Component\HttpFoundation\Request;
use SchemaBundle\Generator\GeneratorInterface;
class KnowledgeGraphGenerator implements GeneratorInterface
{
public function supportsRequest(Request $request, string $route): bool
{
return true;
}
public function supportsElement($element): bool
{
return false;
}
public function generateForRequest(Graph $graph, Request $request, array &$schemaBlocks): void
{
// just a dummy here
// you could use the pimcore website settings for example
$myBusiness = [
'name' => 'My Business Name',
'email' => '[email protected]'
];
$graph
->organization()
->name($myBusiness['name']);
}
public function generateForElement($element): ?BaseType
{
return null;
}
}
Use the Graph
Element to join multiple services.
App\Schema\Generator\OrganizationGenerator:
autowire: true
tags:
- { name: schema.generator, alias: organization }
App\Schema\Generator\ProductGenerator:
autowire: true
tags:
- { name: schema.generator, alias: product }
<?php
namespace App\Schema\Generator;
use SchemaBundle\Generator\GeneratorInterface;
use Spatie\SchemaOrg\BaseType;
use Spatie\SchemaOrg\Graph;
use Symfony\Component\HttpFoundation\Request;
class OrganizationGenerator implements GeneratorInterface
{
public function supportsRequest(Request $request, string $route): bool
{
return true;
}
public function supportsElement($element): bool
{
return false;
}
public function generateForRequest(Graph $graph, Request $request, array &$schemaBlocks): void
{
$graph
->organization()
->name('My awesome Company');
}
public function generateForElement($element): ?BaseType
{
// return null since we do not support requests
return null;
}
}
<?php
namespace App\Schema\Generator;
use SchemaBundle\Generator\GeneratorInterface;
use Spatie\SchemaOrg\BaseType;
use Spatie\SchemaOrg\Graph;
use Symfony\Component\HttpFoundation\Request;
class ProductGenerator implements GeneratorInterface
{
public function supportsRequest(Request $request, string $route): bool
{
return $request->attributes->has('product-id');
}
public function supportsElement($element): bool
{
return false;
}
public function generateForRequest(Graph $graph, Request $request, array &$schemaBlocks): void
{
$graph
->product()
->name('My cool Product')
->brand($graph->organization());
}
public function generateForElement($element): ?BaseType
{
// return null since we do not support requests
return null;
}
}
You're able to render json-ld data in your markup. For this you need to make use of the json_ld
twig extension.
App\Schema\Generator\ProductGenerator:
autowire: true
tags:
- { name: schema.generator, alias: product }
<?php
namespace App\Schema\Generator;
use Pimcore\Model\DataObject\TestClass;
use SchemaBundle\Generator\GeneratorInterface;
use Spatie\SchemaOrg\BaseType;
use Spatie\SchemaOrg\Graph;
use Spatie\SchemaOrg\Schema;
use Symfony\Component\HttpFoundation\Request;
class ProductGenerator implements GeneratorInterface
{
public function supportsRequest(Request $request, string $route): bool
{
return false;
}
public function supportsElement($element): bool
{
return $element instanceof TestClass;
}
public function generateForRequest(Graph $graph, Request $request, array &$schemaBlocks): void
{
// nothing to do since we do not support requests
}
public function generateForElement($element): ?BaseType
{
/** @var TestClass $product */
$product = $element;
return Schema::product()
->name($product->getName())
->sku($product->getSku());
}
}
<div class="container">
<h3>json ld for object</h3>
{% set object = pimcore_object(41) %}
{{ object|json_ld }}
</div>