@xsu1010/babel-plugin-transform-scss-import-to-string
v1.1.0
Published
Babel plugin for transforming SCSS imports to static variable declarations with transpiled CSS string. Modernized.
Downloads
4
Maintainers
Readme
babel-plugin-transform-scss-import-to-string
Babel transform plugin for replacing *.scss imports with static variable declaration as css string.
This fork uses sass
and is overall a more modern version of the original plugin.
Example
import sideEffectStyles from "./styles.sass";
// vvv
const sideEffectStyles = ".foo { color: red; }";
Quick start
Install the plugin first:
# pnpm
pnpm add -D @xsu1010/babel-plugin-transform-scss-import-to-string
# yarn
yarn add --dev @xsu1010/babel-plugin-transform-scss-import-to-string
# npm
npm install --save-dev @xsu1010/babel-plugin-transform-scss-import-to-string
Add it to your babel configuration:
{
"plugins": ["@xsu1010/babel-plugin-transform-scss-import-to-string"]
}
Or with custom sass
options:
{
"plugins": [
[
"@xsu1010/babel-plugin-transform-scss-import-to-string",
{ "precision": 3, "style": "compressed" }
]
]
}
Import *.scss files:
// foo.scss
$bar: 42px;
.foo {
font-size: $bar;
}
// foo.js
import foo from "./foo.scss";
console.log(foo); // -> .foo { font-size: 42px; }
Requirements
sass
, which you should install explicitly@babel/core
, which you should already have with babel configured
Caveats
- This module shouldn't be used with webpack and sass-loader since babel transform would take first place in build process.
- Every import transpiled with sass as an independent file, so you have to explicitly import dependencies if you used to have common context before.