Eine häufige Anforderung besteht darin, die Startseite eines Projektes individuell anzupassen. Zikula bietet zwar die Möglichkeit, eine Controller-Aktion sowie die zu übergebenden Argumente in der Grundkonfiguration einer Seite einzustellen, allerdings ist diese Funktionalität bislang doch eher eingeschränkt. Mit einigen Modulen, wie etwa Content, sind zwar unterschiedliche Inhalte je Sprache auf ein und derselben Seite möglich, aber auch das kann nicht alle Varianten abdecken. Also was für Möglichkeiten gibt es? 😕
Zum Glück kann man in Symfony ganz einfach beliebige Controller-Aktionen von einem Template aus aufrufen und diese somit einbinden 👷 Der folgende Code zeigt exemplarisch, wie sich abhängig von beliebigen Bedingungen oder auch für verschiedene Domains unterschiedliche Module beziehungsweise Content-Seiten einstellen lassen. Es wird immer eine von drei verschiedenen Inhaltsseiten gezeigt; außer am Wochenende: denn samstags sollen die Newsartikel aufgelistet werden und am Sonntag wird die Sitemap von Content aufgerufen.
{% set weekDay = 'now'|date('N') %}
{% set startModule = weekDay == '6' ? 'MUNewsModule' : 'ZikulaContentModule' %}
{{ app.request.attributes.set('_zkBundle', startModule) }}
{{ app.request.attributes.set('_zkModule', startModule) }}
{% if weekDay == '6' %}
{% render(controller(
'MU\\NewsModule\\Controller\\MessageController::viewAction',
{sort: '', sortdir: 'asc', pos: 1, num: 10}
)) %}
{% elseif weekDay == '7' %}
{{ render(controller(
'Zikula\\ContentModule\\Controller\\PageController::sitemapAction'
)) }}
{% else %}
{% set startPage = 'meine-seite' %}
{% if app.request.schemeAndHttpHost == 'https://seite1.de' %}
{% set startPage = 'andere-seite' %}
{% elseif app.request.schemeAndHttpHost == 'https://seite2.de' %}
{% set startPage = 'dritte-seite' %}
{% endif %}
{{ render(controller(
'Zikula\\ContentModule\\Controller\\PageController::displayAction',
{slug: startPage}
)) }}
{% endif %}
Wie man sieht, sind der Phantasie hier kaum Grenzen gesetzt. Wer sich für die Details interessiert, kann im entsprechenden Abschnitt der Symfony-Dokumentation weiterlesen.