Jadu Twig style is powered by Twig-CS-Fixer.
- Require the jadu/twig-style dev dependency:
composer require --dev jadu/twig-style
- Add the twig-cs-fixer config file
.twig-cs-fixer.php
:
<?php
use Jadu\Style\Twig\Standard\JaduStandard;
use TwigCsFixer\Config\Config;
use TwigCsFixer\File\Finder;
use TwigCsFixer\Ruleset\Ruleset;
$finder = Finder::create()
->in(__DIR__ . '/src')
->ignoreVCSIgnored(true);
$config = new Config();
$config->setFinder($finder);
$ruleset = new Ruleset();
$ruleset->addStandard(new JaduStandard());
$config->setRuleset($ruleset);
return $config;
- Add
.twig-cs-fixer.cache
to your project's.gitignore
file.
To lint your project's twig files, run the following dry run command:
vendor/bin/twig-cs-fixer lint
This command will return a list of twig-cs-fixer violations and is recommended for build tasks.
To fix any reported fixable violations, run the following fix command:
vendor/bin/twig-cs-fixer lint --fix
This standard is based on the official Twig coding standards, with the following additions and changes:
There must be one new line before block tags and one new line after endblock tags.
{% block aside %}
<div class="aside">
{% block aside_inner %}
{% block before_primary_supplements %}
{% endblock %}
{% block primary_supplements %}
{% endblock %}
{% block after_primary_supplements %}
{% endblock %}
{% endblock %}
</div>
{% endblock %}
The following exceptions apply:
-
Inline blocks are allowed.
<body class="{% block body_classes %}{{ bodyClasses }}{% endblock %}">
-
Comments on the line above block tags are allowed.
{# This block adds a container around the aside #} {% block aside_container %}
Any endblock
tags must be followed by the name of the block they are closing.
{% block aside_container %}
{% endblock aside_container %}
The spaceless
tag was deprecated in Twig 1.38 and 2.7.31 and an equivalent spaceless
filter was introduced. Usages of the spaceless
tag must be replaced with the equivalent apply spaceless
filter.
{% apply spaceless %}
{% endapply %}
The filter
tag was deprecated in Twig 1.402 and 2.93 in favour of the apply
tag, which behaves identically to filter
except that the wrapped template data is not scoped. Usages of the filter
tag must be replaced with the equivalent apply
tag.
{% apply lower|escape('html') %}
<strong>UPPERCASE TEXT</strong>
{% endapply %}
{# outputs "<strong>uppercase text</strong>" #}
A single space is required after the opening and before the closing of a hash.
{{ { 'foo': 'bar', 'baz': 'qux' } }}
The following exceptions apply:
- Empty hashes must not contain any whitespace.
{% set emptyHash = {} %}
Variable naming conventions are not enforced.
The rules in the Jadu\Style\Twig\Rule\Development
namespace are provided for development purposes to help with maintaining Jadu Twig style.
You will need to update your project's twig-cs-fixer config file .twig-cs-fixer.php
to enable these rules, as non-fixable rules are disabled by default.
<?php
use Jadu\Style\Twig\Rule\Development\TokenTypeRule;
use TwigCsFixer\Config\Config;
use TwigCsFixer\File\Finder;
use TwigCsFixer\Ruleset\Ruleset;
$finder = Finder::create()
->in(__DIR__ . '/src')
->ignoreVCSIgnored(true);
$config = new Config();
$config->setFinder($finder);
$ruleset = new Ruleset();
$ruleset->addRule(new TokenTypeRule());
$config->setRuleset($ruleset);
$config->allowNonFixableRules();
return $config;
TokenTypeRule
helps you see how a twig template is tokenized by Twig-CS-Fixer by mapping token types to values.