Formatter plugin for go template files. The only peer dependency is prettier. Test you own code on the playground.
npm install --save-dev prettier prettier-plugin-go-template
The following file types are detected automatically:
.gohtml
, .gotmpl
, .go.tmpl
, .tmpl
, .tpl
, .html.tmpl
Input | Output |
---|---|
{{ if or .Prev .Next -}}
{{ $p := where site.Pages }}
<div class="my-navigation">
{{ with $p.Next . -}}
<a href="{{ .RelPermalink }}">
<div class="row">
<div class="cell py-2">
{{ .Title }}
</div> </div> </a>
{{ end -}}
</div>
{{ end -}} |
{{ if or .Prev .Next -}}
{{ $p := where site.Pages }}
<div class="my-navigation">
{{ with $p.Next . -}}
<a href="{{ .RelPermalink }}">
<div class="row">
<div class="cell py-2">{{ .Title }}</div>
</div>
</a>
{{ end -}}
</div>
{{ end -}} |
To use it with GoHugo and basic .html
files, you'll have to override the used parser inside your .prettierrc
file:
{
overrides: [
{
files: ["*.html"],
options: {
parser: "go-template",
},
},
],
}
Make sure to always have installed both dependencies:
prettier
prettier-plugin-go-template
Also make sure that they are installed inside the same scope.
Install both globally (npm i -g
) or locally – otherwise prettier may not pick up the plugin.
Note: The global setup additional requires setting your VSCode prettier path to your global prettier path. You can read in this issue how to set it up – should be doable in less than a minute if you have npm & VSCode already running.
// .prettierrc
{
/**
* Enables & disables spacing between go statements.
* E.g. {{ statement }} vs {{statement}}.
* Default: true
*/
"goTemplateBracketSpacing": true
}
<div>
<!-- prettier-ignore -->
{{if }}
{{end }}
</div>
<html>
{{/* prettier-ignore-start */}}
<script>
{{if }}
Whatever.
{{else }}
Psych.
{{end }}
</script>
{{/* prettier-ignore-end */}}
</html>
- Fix several formatting issues
- Improve unformattable script & style detection
- Huge thanks to @jasikpark for validating & cleaning up the issues 🎉
- AST rewrite
- Fix inline actions
- If / Else / Else-If support
- Ignore formatting for blocks with `{{/* prettier-ignore */}}
- Ignore large code sections with `{{/* prettier-ignore-start /}}...{{/ prettier-ignore-end */}}
- Tweak general formatting
- Support for multiline actions
- Resolve bug #19: Fix template comments.
- Resolve bug of single line if statements.
- Go block statements will now be indented accordingly. Except for
else
.- if, range, block, with, define, end
- Fix broken shortcodes. Thanks to @alqu for discovering & fixing the bug.
Thanks goes to these wonderful people (emoji key):
alqu 🐛 |
Gabriel Monteagudo 🐛 |
Bryan 🐛 |
Andreas Richter 🐛 |
Noah Brenner 💻 📖 |
silverwind 🤔 |
Charles Pence 🐛 |
Caleb Jasik 🐛 📖 💡 🤔 🚧 💬 |
Dan Gold 🐛 |
This project follows the all-contributors specification. Contributions of any kind welcome!