The layout is the html structure of your view, it is composed of areas
The layout is composed of :
See https://github.com/opera-project/opera-cms/blob/master/src/DataFixtures/LayoutFixtures.php
$layout = new Layout();
$layout->setName('default');
$layout->setConfiguration([
'areas' => [
'H' => 'header',
'B' => 'body'
],
'layout' => [
'H H H H',
'B B B B',
'B B B B',
]
]);
$manager->persist($layout);
$manager->flush();
templates/layouts/NAME.html.twig
The configuration declare some areas that will be used inside of the template. And associate them to one letter. After you have to configure the layout representation using this letters. The syntax is based on css grid-template.
{# in file templates/layouts/NAME.html.twig #}
{% extends 'base.html.twig' %}
{% block body %}
{{ cms_area('header', _opera_page) }}
{{ cms_area('header') }}
<hr />
{{ cms_area('body', _opera_page) }}
{% endblock %}
The twig function cms_area(area_name, ?page)
will show the list of blocks attached to the given area name. If page is not given it will call the area for _global
page usefull for common elements like menu for example.
the _global page
You must have a global
page. The _global
page doesn’t have a layout and will never be rendered.
The global page have all the commons block that are used on all the page (menu, footer…) so you don’t have to configure them on all the pages.
{# in file templates/base.html.twig #}
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>{% block title %}{{ cms_render(_opera_page.title) }}{% endblock %}</title>
<meta name="description" content="{{ _opera_page.metaDescription }}" />
<meta name="keywords" content="{{ _opera_page.metaKeyword }}" />
{% block stylesheets %}{% endblock %}
</head>
<body>
{% block body %}{% endblock %}
{% block javascripts %}{% endblock %}
</body>
</html>
You can also directly show all elements of page object. But for title, or other if you want, we recommand you to use the cms_render
function: this call will enable your user to save twig template inside of the page to render elements that depends of PageController context. Eg the title of the current article we will save in database $page->setTitle('{{ article.title }}');
and this will render the article title.