Twig
A Sublime Text package that provides enhanced syntax highlighting, completions, snippets & more for PHP Twig templates.
Details
Installs
- Total 202K
- Win 86K
- Mac 67K
- Linux 49K
Jan 21 | Jan 20 | Jan 19 | Jan 18 | Jan 17 | Jan 16 | Jan 15 | Jan 14 | Jan 13 | Jan 12 | Jan 11 | Jan 10 | Jan 9 | Jan 8 | Jan 7 | Jan 6 | Jan 5 | Jan 4 | Jan 3 | Jan 2 | Jan 1 | Dec 31 | Dec 30 | Dec 29 | Dec 28 | Dec 27 | Dec 26 | Dec 25 | Dec 24 | Dec 23 | Dec 22 | Dec 21 | Dec 20 | Dec 19 | Dec 18 | Dec 17 | Dec 16 | Dec 15 | Dec 14 | Dec 13 | Dec 12 | Dec 11 | Dec 10 | Dec 9 | Dec 8 | Dec 7 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Windows | 0 | 5 | 1 | 0 | 4 | 6 | 2 | 2 | 1 | 2 | 2 | 5 | 5 | 6 | 4 | 1 | 0 | 0 | 3 | 5 | 0 | 1 | 2 | 0 | 3 | 3 | 4 | 3 | 3 | 2 | 2 | 0 | 2 | 4 | 1 | 3 | 7 | 2 | 1 | 1 | 2 | 5 | 4 | 4 | 2 | 1 |
Mac | 0 | 2 | 1 | 1 | 3 | 3 | 4 | 6 | 2 | 0 | 1 | 2 | 9 | 3 | 3 | 3 | 2 | 0 | 2 | 0 | 0 | 2 | 1 | 1 | 2 | 1 | 0 | 2 | 3 | 2 | 2 | 0 | 2 | 4 | 4 | 1 | 4 | 2 | 0 | 2 | 0 | 2 | 0 | 3 | 0 | 2 |
Linux | 0 | 1 | 1 | 0 | 1 | 3 | 2 | 1 | 1 | 0 | 1 | 0 | 6 | 2 | 3 | 0 | 0 | 0 | 0 | 1 | 0 | 2 | 2 | 2 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 4 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 2 | 3 | 2 | 2 | 3 |
Readme
- Source
- raw.githubusercontent.com
Twig
A Sublime Text package that offers enhanced syntax highlighting, snippets, completions and much more for PHP Twig templates. Read more for the full documentation.
Features
- Indentation for code blocks.
- Snippets for common code blocks.
- Key bindings to make your life easier.
- Enhanced syntax highlighting for Twig templates.
- Autocompletions for built in tags, filters, functions, tests & loop variables.
Installation
Package Control
Install Twig via Package Control. Once you have Package Control setup in Sublime Text, open the command palette and search for Package Control: Install Package
. Search for Twig
. There should be a package with the URL as https://github.com/Sublime-Instincts/BetterTwig. Install it.
Package Control will take care for of automatically updating the package for you if there are new releases.
Manual installation
In Sublime Text open the Preferences > Browse Packages menu item. In the Packages directory you should now see, clone this repository in a new directory called “Twig”.
Documentation
How to use this package ?
By default, this package supports the following Twig extensions,
.twig
.htm.twig
.html.twig
Since a user can have more than one templating language package installed, this package doesn't support .html
directly. To get highlighting for .html
files with Twig code and all the other features this package provides, you can follow any of the two approaches given below
Go to the bottom right status bar item that displays information on current syntax and click on that when the currently open file is any
.html
file. From there go toOpen all with current extensions as ...
and scroll to selectHTML (Twig)
. You should now be good to go.When the currently open file is a
.twig
file, from the main menu, go toPreferences -> Settings -- Syntax Specific
. This should open a 2 column new window, with the default settings on the right and a user settings on the left. In the user settings, add the following, save & close.
{
"extensions": [
".html"
]
}
Key bindings
- The key bindings are configured so that pressing shift + { twice will automatically add spaces on both sides for the inner brace expression block & place the cursor in the center, like so
{{ | }}
. - Similarly, pressing shift + % within
{}
will add spaces on both sides of the inner%
like so{% | %}
- Use ctrl + / or ctrl + shift + / for Twig comments (
{# This is a Twig comment #}
) - Use # within strings, to get the interpolation expression, like so
#{|}
.
Snippets
Basic snippets for each keyword are provided to create expressions without bothering with {% %}
.
Tab Trigger | Twig Tag |
---|---|
autoescape |
{% autoescape %} |
endautoescape |
{% endautoescape %} |
… | … |
Prefixed with b
basic snippets for most common control structures are provided.
Tab Trigger | Twig Code Block |
---|---|
bautoescape |
{% autoescape %}{% endautoescape %} |
bblock |
{% block %}{% endblock %} |
bembed |
{% embed %}{% endembed %} |
bextends |
{% extends %} |
bfor |
{% for %}{% endfor %} |
bif |
{% if %}{% endif %} |
bifelse |
{% if %}{% else %}{% endif %} |
bmacro |
{% macro %}{% endmacro %} |
bsandbox |
{% sandbox %}{% endsandbox %} |
bverbatim |
{% verbatim %}{% endverbatim %} |
bwith |
{% with %}{% endwith %} |
For more, please follow the official documentation on snippets to create your own.
Or use SnippetMaker for convenience.
If you want to ignore the snippets that are provided by default, you can use the ignored_snippets
setting.
ignored snippets | values |
---|---|
all | "Twig/Snippets/*" |
blocks | "Twig/Snippets/blocks" |
expressions | "Twig/Snippets/expressions" |
tags | "Twig/Snippets/tags" |
Example
To only keep tag snippets…
{
"ignored_snippets": [
"Twig/Snippets/blocks",
"Twig/Snippets/expressions",
],
}
Reporting issues.
There is always scope for improvements, so please do report any bug(s) that you encounter.
Please follow the issue template that has been setup while reporting any bug(s) (So as to stay as organised as possible).
Use the Twig playground if you want to share a particular snippet of template while creating a specific issue.