swc-plugin-de-indent-template-literal
v1.5.0
Published
SWC plugin for removing indentation of template literals
Downloads
3,176
Readme
swc-plugin-de-indent-template-literal
Usage
This plugin is used to de-indent template literal, very useful for logging errors and warns.
// BEFORE
function someFunction() {
console.log(/** #__DE-INDENT__ */ `
<div>
<p>hello</p>
</div>
`);
}
someFunction();
// <div>
// <p>hello</p>
// </div>
// AFTER
function someFunction() {
console.log(`<div>
<p>hello</p>
</div>`);
}
someFunction();
// <div>
// <p>hello</p>
// </div>Setup
npm install --save-dev swc-plugin-de-indent-template-literal @swc/coreThen update your .swcrc file like below:
{
"jsc": {
"experimental": {
"plugins": [["swc-plugin-de-indent-template-literal", {}]]
}
}
}Options
indentStyle
If your project uses tab instead of space, you can set indentStyle to tab.
- Type:
string - Default:
space - Valid values:
space,tab
example:
{
"jsc": {
"experimental": {
"plugins": [
[
"swc-plugin-de-indent-template-literal",
{
"indentStyle": "tab"
}
]
]
}
}
}tag
If you want to use a custom tag instead of #__DE-INDENT__, you can set tag to your custom tag.
- Type:
string - Default:
#__DE-INDENT__ - Valid values: any string
example:
{
"jsc": {
"experimental": {
"plugins": [
[
"swc-plugin-de-indent-template-literal",
{
"tag": "de-indent"
}
]
]
}
}
}// BEFORE
function someFunction() {
console.log(/** de-indent */ `
<div>
<p>hello</p>
</div>
`);
}
someFunction();
// <div>
// <p>hello</p>
// </div>
// AFTER
function someFunction() {
console.log(`<div>
<p>hello</p>
</div>`);
}
someFunction();
// <div>
// <p>hello</p>
// </div>