@zackad/prettier-plugin-twig v0.16.0
Prettier Plugin for Twig
Forked from trivago/prettier-plugin-twig-melody with focus on twig template only.
This Plugin enables Prettier to format .twig files, as well as .html.twig.
Installation
yarn add --dev @zackad/prettier-plugin-twigConfiguration
Add the plugin explicitly into your Prettier configuration (e.g., .prettierrc.json) using the plugins key:
{
"plugins": ["@zackad/prettier-plugin-twig"]
}Usage
./node_modules/.bin/prettier --write "**/*.twig"Options
This Prettier plugin comes with some options that you can add to your Prettier configuration (e.g., prettierrc.json).
twigSingleQuote (default: true)
Values can be true or false. If true, single quotes will be used for string literals in Twig files.
twigAlwaysBreakObjects (default: true)
If set to true, objects will always be wrapped/broken, even if they would fit on one line:
<section
class="{{ {
base: css.prices
} | classes }}"
></section>If set to false, this would be printed as:
<section class="{{ { base: css.prices } | classes }}"></section>twigFollowOfficialCodingStandards (default: true)
Follow the standards described in https://twig.symfony.com/doc/2.x/coding_standards.html exactly. If set to false, some slight deviations might occur, such as spaces around the filter | operator (s | upper instead of s|upper).
twigOutputEndblockName (default: false)
Choose whether to output the block name in {% endblock %} tags (e.g., {% endblock content %}) or not. The default is not to output it.
twigMultiTags (default: [])
An array of coherent sequences of non-standard Twig tags that should be treated as belonging together. Example (inspired by Craft CMS):
{
"twigMultiTags": [
"nav,endnav",
"switch,case,default,endswitch",
"ifchildren,endifchildren",
"cache,endcache"
]
}Looking at the case of nav,endnav, this means that the Twig tags {% nav %} and {% endnav %} will be treated as a pair, and everything in between will be indented:
{% nav entry in entries %}
<li>
<a href="{{ entry.url }}">{{ entry.title }}</a>
</li>
{% endnav %}If we did not list the "nav,endnav" entry in twigMultiTags, this code example would be printed without indentation, because {% nav %} and {% endnav %} would be treated as unrelated, individual Twig tags:
{% nav entry in entries %}
<li>
<a href="{{ entry.url }}">{{ entry.title }}</a>
</li>
{% endnav %}Note that the order matters: It has to be "nav,endnav", and it must not be "endnav,nav". In general, the first and the last tag name matter. In the case of "switch,case,default,endswitch", the order of case and default does not matter. However, switch has to come first, and endswitch has to come last.
twigTestExpressions (default: [])
Make custom Twig tests known to the parser.
{
"twigTestExpressions": [
"snake_case_test",
"camelCaseTest"
]
}Example
{{ a is snake_case_test }}
{{ a is not snake_case_test }}
{{ a is camelCaseTest }}
{{ a is not camelCaseTest }}Features
prettier-ignore and prettier-ignore-start
When you are not happy with how Prettier formats a certain element or section in the code, you can tell it to leave it in peace:
{# prettier-ignore #}
<div class="weird-formatting" >This will not be re-formatted</div>
<div class="weird-formatting" >But this will be</div>You can also tell Prettier to leave entire regions as they are:
{# prettier-ignore-start #}
...
{# prettier-ignore-end #}Testing
- You can call
yarn testto test against all regular tests
Credit
- Author: Tom Bartel thomas.bartel@trivago.com
8 months ago
8 months ago
9 months ago
9 months ago
9 months ago
10 months ago
11 months ago
11 months ago
11 months ago
12 months ago
12 months ago
12 months ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago