/babel-plugin-transform-scss

Babel plugin for transpile scss or sass imports to css and embedding them in the head of the html document

Primary LanguageJavaScript

babel-plugin-transform-scss

Babel plugin for converting scss or sass imports to css and embedding them in the head of the document

This plugin completely replaces the standard webpack sass-loader. This part of code can be removed:

module: {
  rules: [
    //rules
    {
      test: /\.s[ac]ss$/i,
      use: ['style-loader', 'css-loader', 'sass-loader']
    }
  ]
}

Installation

npm install --save-dev babel-plugin-transform-scss or yarn add -D babel-plugin-transform-scss

Use it in your config file:

{
  "presets": [],
  "plugins": [
    ["babel-plugin-transform-scss", {"include": ["node_modules"] }]
  ]
}

options optional :)

How it works

This plugin looks for import of sass or scss files, when imports are found - imported files replaces with function which renders pure css to the head of the document.

import React from 'react'
import 'style.scss'

const Button = () => {
  return (
    <div className="button">
      Custom button
    </div>
  )
}

export default Button

import "style.scss" will be transpiled to css and will be rendered to the head of the document:

<style data-scss-component="Button_style_123e4567-e89b-12d3-a456-426614174000">
    .button {
      display: flex;
      justify-content: space-around;
    }
</style>

if import contains more than one styles:

Input
import React from 'react'
import 'style.scss'
import 'style2.scss'

const Button = () => {
  return (
    <div className="button">
      <div className="nested-from-style2">Nested</div>
    </div>
  )
}

export default Button
Output
<style data-scss-component="Button_style_2cb3b893-c04b-4d58-98ac-1262408e7557">
    .button {
      display: flex;
      justify-content: space-around;
    }
</style>
<style data-scss-component="Button_style2_c7eacc89-f7cb-4ee8-8b73-a585a11fa527">
    .nested-from-style2 {
      display: grid;
    }
</style>