Shopware 6 Theme Twig

Folgende Doku beruht auf EA1 und EA2. In der aktuellen Version von Shopware 6 ist die Ordnerstruktur verändert.

Shopware Variablen ausgeben

Folgender Befehl kann an jeder Stelle im Template/Theme eingefügt werden. Darauf zu achten ist, dass diese Stelle auch gerendert wird und nicht mehrfach aufgerufen werden soll, z.b. nicht innerhalb eines wiederholenden Twig-Macros oder einer Twig-For-Schleife. Mit dem Befehl wird an dieser Steller im Theme eine pre-Element eingebracht welches die ganzen möglichen Variaben darstellt.

{{ dump() }}

Zur Zeit funktioniert der dump() Befehl innerhalb eines Twig-Blocks und wenn in der Datei ".env" der Eintrag "APP_ENV=prod" geändert wird in "APP_ENV=dev".

Block überschreiben

{% block block-name %}
  Ich bin der neue Inhalt
{% endblock %}

Eltern-Block

{{ parent() }}

Block erweitern davor (prepend)

{% block block-name %}
  Ich bin der neue Inhalt vor dem "alten" Inhalt
  {{ parent() }}  der vererbte Stamm-Inhalt
{% endblock %}

Block erweitern danach (append)

{% block block-name %}
  {{ parent() }}  der vererbte Stamm-Inhalt
  Ich bin der neue Inhalt nach dem "alten" Inhalt
{% endblock %}

Variable setzen/deklarieren

Name der Variabel ist variablenname und der Wert ist das Wort "Hallo".

{% set variablenname = "Hallo" %}

Variable ausgeben

Gibt "Hallo" aus wenn variablenname den Wert "Hallo" gesetzt bekommen hat, siehe ein Abschnitt oben.

{{ variablenname }}

Kommentar einfügen

Es ist manchmal hilfreich seinen Code für andere Programmierer zu kommentieren. Dieser erscheint nur in der Twig Datei für den Programmierer und nicht im Frontend.

{# Ich bin ein Kommentar #}

Template-Datei erweitern

Shopware Twig extends (vorerst empfohlen)

{% sw_extends "@Storefront/base.html.twig" %}

und das original Twig extends:

{% extends "@Storefront/base.html.twig" %}

Template-Datei überschreiben

Im Gegensatz zum erweitern einer Template-Datei, kann diese auch komplett überschrieben werden, so dass der Inhalt komplett neu oder leer ist. Beim überschreiben mit nichts, einfach eine leere Twig-Datei erstellen mit dem Namen der ursprünglichen Twig-Datei, z.B. "base.html.twig". Beim überschreiben mit eigenem Inhalt, einfach die Datei nicht extenden (kein "sw_extends" am Anfang). Auf die original Blöck kann trotzdem zugegriffen werden.

{# Hier kein sw_extends #}
Mein eigener Inhalt
{% block blockname%}
  weiterere Inhalt
{% endblock %}

Template-Datei in Template einfügen

{% sw_include "@Storefront/page/account/address.html.twig" %}

If Abfrage

{% if controllerName|lower == "index" %}
  Ausgabe wenn Kontroller-Name gleich index ist, z.b. Startseite
{% endif %}

If - Else Abfrage

{% if controllerName|lower == "index" %}
  Ausgabe wenn Kontroller-Name gleich "index" ist, z.b. Startseite
{% else %}
  Ausgabe wenn Kontroller-Name nicht "index" ist, z.B. alle anderen Seiten ausser Startseite
{% endif %}

If - Elseif Abfrage

{% if controllerName|lower == "index" %}
  Ausgabe wenn Kontroller-Name gleich "index" ist, z.b. Startseite
{% elseif controllerName|auth%}
  Ausgabe wenn Kontroller-Name nicht "index" ist sondern "auth", z.B. Anmeldeseite
{% endif %}

For Schleifen

{% for Item in Array %}
  {{ Item }}
{% endfor %}

Funktion

{% macro functionname() %}
   Hallo Welt.
{% endmacro %}

{{ _self.functionname() }}

Dateien einbinden

In der Konfiguration des Themes (Datei: theme.json) werden die Speicherorte der Datei angegeben. Dies könnte wie folgt aussehen:

{
  "name": "Meintheme",
  "author": "Max Mustermann",
  "style": [
    "@Storefront",
    "Resources/storefront/style/base.scss"
  ],
  "script": [
    "@Storefront",
    "Resources/storefront/dist/script/all.js"
  ],
  "asset": [
    "Resources/storefront/asset"
  ]
}

Der CSS-Dateien und die Javascripte werden in diesem Beispiel mit dem Grund-CSS und dem Grund-Javascript "verschmolzen". Unter "asset" können Dateien abgelegt werden, z.B. Icons oder Bilder.

Beim Kompilieren des Theme werden dann alle Daten in den public/ -Ordner kopiert und sind damit für den Besucher der Website aufrufbar.

{{ asset('pfad/zur/datei.xyz', '@Meintheme') }}

Bild einfügen

<img src="{{ asset('img/meinBild.jpg') }}">

Ergebnispfad: /kompletter/Pfad/public/img/meinBild.jpg 
<img src="{{ asset('img/meinBild.jpg', '@Storefront') }}">

Ergebnispfad: /bundles/storefront/img/meinBild.jpg 

Bild einfügen aus eigenem Theme

<img src="{{ asset('img/meinBild.jpg', '@Meintheme') }}"> 

Ergebnispfad: /bundles/meintheme/img/meinBild.jpg