The extension allows you to utilize specially formatted Antlers comments to improve code completion, suggestions, provide inline documentation, and other advanced features. The extension is capable of determining which blueprint fields to show in suggestions based on common collection configurations, but there are some scenarios where explicitly specifying them can improve your development experience.
To provide a name, or description, for your partial, you must include an Antlers comment as the first item in your Antlers template. Within this comment you can prefix a line with @name
to specify the partial name, and another line with @desc
to provide a description:
1{{#2 @name The template name.3 @desc A human-friendly description for your awesome template.4#}}5 6The rest of your awesome Antlers template.
When the a user is using the {{ partial }}
tag, they will see the human-friendly names and descriptions as part of the suggestions:
Specifying Collections or Blueprints
You can explicitly set the collection or blueprint names that apply to any template file within your Statamic project. These must appear within an Antlers comment as the first item in your Antlers template. When the extension sees these hints, it will pull in the relevant blueprint fields to improve suggestions and syntax highlighting.
We can use the @param
directive to define which additional parameters our partial accepts. When we do this, Antlers Toolbox will add these extra parameters to the auto-complete suggestions list.
The format for adding parameter names is:
1@param <PARAM_NAME> <PARAM_DESCRIPTION>
The following would add the_param_name
and param_two
to the partial's suggestion list:
1{{#2 @name The template name.3 @desc A human-friendly description for your awesome template.4 @param the_param_name A description for the parameter.5 @param param_two A description for a second additional parameter.6#}}7 8The rest of your awesome Antlers template.
You may specify the collection name by using either the @entry
or @collection
directive (use whichever feels best for you as they are equivalent):
1{{#2 @name The template name.3 @desc A human-friendly description for your awesome template.4 @entry collectionName5 @collection collectionName6#}}7 8The rest of your awesome Antlers template.
You can specify multiple collections by separating each name with a comma:
1{{#2 @name The template name.3 @desc A human-friendly description for your awesome template.4 @entry collectionOne, collectionTwo5#}}6 7The rest of your awesome Antlers template.
You may specify which blueprint(s) apply to any template file by using the @blueprint
directive:
1{{#2 @name The template name.3 @desc A human-friendly description for your awesome template.4 @blueprint blueprintName5#}}6 7The rest of your awesome Antlers template.
You may specify multiple blueprints by separating each name with a comma:
1{{#2 @name The template name.3 @desc A human-friendly description for your awesome template.4 @blueprint blueprintOne, blueprintTwo5#}}6 7The rest of your awesome Antlers template.
If you are dynamically loading a partial based on a set type (such as when creating templates for a Bard or Replicator field), you can specify which set within the corresponding blueprint applies to a file by using the special @set
directive:
1{{#2 @name The template name.3 @desc A human-friendly description for your awesome template.4 @set collectionName.fieldName.setName5#}}6 7The rest of your awesome Antlers template.
When the extension sees the special @set
directive, it will load all the relevant blueprint fields only from that set to improve your suggestions and syntax highlighting.