hbs-dedent-helper
v0.3.0
Published
A set of simple handlebars helpers to help with indentation
Downloads
19,569
Readme
Handlebars dedent helper
A set of simple handlebars helpers to help with indentation
Very often, when using block helpers our code would end up nested more than it should be. Which can be problematic for code-generators:
if (foo) {
{{#each items}}
console.log('{{.}}')
{{/each}}
}
generates something like:
if (foo) {
console.log('a');
console.log('b');
}
This is visually unappealing. In addition, for indentation sensitve languages this can break the code.
To solve this we provide following helpers:
dedent
helper:
(Dedents a block of code by one level)
if (foo) {
{{#each items}}
{{#dedent}}
console.log('{{.}}')
{{/dedent}}
{{/each}}
}
One level defaults to 4 spaces. But this is configurable through setLevelSize & setLevelChar:
import {setLevelSize} from "hbs-dedent-helper";
// Configure dedent helper to use 1 tab
setLevelSize(1);
setLevelChar('\\t');
dedent-by
helper provides more control:
if (foo) {
{{#dedent-by 2 "level"}}
{{#each items}}
console.log('{{.}}')
{{/each}}
{{/dedent-by}}
}
We can also explicitly use tabs or spaces:
if (foo) {
{{#dedent-by 8 "spaces"}}
{{#each items}}
console.log('{{.}}')
{{/each}}
{{/dedent-by}}
}
if (foo) {
{{#dedent-by 2 "tabs"}}
{{#each items}}
console.log('{{.}}')
{{/each}}
{{/dedent-by}}
}
base-indent
helper:
(Changes the minimum indentation of all lines in the contained block, while retaining relative indentation)
if (foo) {
{{#base-indent 1 "level"}}
{{#each items}}
console.log('{{.}}')
{{/each}}
{{/base-indent}}
}
if (foo) {
console.log(1)
}
This is particularly useful when including other templates in a base template.
trim-trailing-whitespace
helper:
(Removes all trailing whitespace in generated output)
Installation
npm install --save handlebars hbs-dedent-helper
Registration
import {register} from "hbs-dedent-helper";
register();