New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

jsxstyle-webpack-plugin

Package Overview
Dependencies
Maintainers
2
Versions
108
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

jsxstyle-webpack-plugin

A webpack plugin that extracts out static styles defined on jsxstyle components

  • 0.0.0-canary-20220604021531
  • npm
  • Socket score

Version published
Weekly downloads
18
decreased by-5.26%
Maintainers
2
Weekly downloads
 
Created
Source

jsxstyle-webpack-plugin

jsxstyle-webpack-plugin is a webpack plugin that extracts static style props from jsxstyle components into a separate CSS file.

Don’t know what jsxstyle is? Check out the jsxstyle README for more information.

Getting Started

  1. Import jsxstyle-webpack-plugin and add it to the plugins section of your webpack config.

  2. Add a new rule object with jsxstyle-webpack-plugin’s companion loader to your webpack config, below any other JS loaders.

    jsxstyle-webpack-plugin relies on untranspiled JSX to be present in order to extract styles. Since webpack loaders run from right to left and bottom to top, jsxstyle-webpack-plugin should be placed at the end of your list of JS loaders.

  3. Ensure your webpack config contains a loader that handles .css files.

When you’re done, the relevant parts of your webpack config should look like this:

const JsxstylePlugin = require('jsxstyle-webpack-plugin');

module.exports = {
  // ...
  plugins: [new JsxstylePlugin()],
  // ...
  module: {
    rules: [
      // ...
      {
        test: /\.js$/,
        use: [
          // loaders that transpile JSX should go before jsxstyle-webpack-plugin’s companion loader
          {
            loader: 'your-cool-js-loader',
          },

          // companion loader goes at the end
          JsxstylePlugin.loader,
        ],
      },
      {
        test: /\.css$/,
        use: 'your-cool-css-loader',
      },
      // ...
    ],
  },
};

Plugin options

Plugin options are passed in object format to JsxstylePlugin.

staticModules

An array of absolute paths to modules that should be treated as static. All modules in this list will be evaluated. Exports from these modules that are referenced in jsxstyle components will be inlined.

For example, with the following plugin config, any prop on a jsxstyle component that references a value from ./LayoutConstants.js will be extracted:

new JsxstylePlugin({
  staticModules: [require.resolve('./LayoutConstants')],
}),

Loader options

parserPlugins

jsxstyle-webpack-plugin uses babylon to parse javascript into an AST. By default, jsxstyle-webpack-plugin is preconfigured with most of babylon’s plugins enabled, but if you need to enable additional plugins, you can specify an array of plugins with the parserPlugins option.

You can see a list of all available plugins in the @babel/parser documentation.

classNameFormat

Out of the box, jsxstyle-webpack-plugin will use a non-deterministic class naming scheme. Because webpack’s module iteration order is not guaranteed, class names will differ slightly between builds of the same code. If you need class names to remain the same each time the same code is bundled, set the classNameFormat option to hash in your loader config. Class names will be generated using a content-based hash.

FAQs

Can I use jsxstyle-webpack-plugin with Flow?

Yes! Flow parsing is automatically enabled for any non-Typescript files.

Can I use jsxstyle-webpack-plugin with Typescript?

Yes! Take a look at the TypeScript example and issue #82 for some context. You’ll need to make a few configuration changes:

  1. Set jsx to preserve in the compilerOptions section of your tsconfig.json file.
  2. Ensure jsxstyle-webpack-plugin’s companion loader runs after ts-loader. Webpack loaders run from bottom to top, to jsxstyle-webpack-plugin needs to be placed before ts-loader in your webpack config.
  3. Add a loader that transpiles JSX, since ts-loader is now set to preserve JSX.

It’s not working 😩

  1. Make sure the loader object test regex matches JS files that use jsxstyle.

  2. jsxstyle-webpack-plugin relies on JSX still being around, so make sure the companion loader runs before babel-loader does its thing.

  3. jsxstyle-webpack-plugin only supports destructured require/import syntax:

    // Cool!
    import { Block } from 'jsxstyle';
    <Block />;
    
    // Neat!
    const { Block } = require('jsxstyle');
    <Block />;
    
    // Nope :(
    const Block = require('jsxstyle').Block;
    <Block />;
    

What are “static style props”?

Simply put, static style props are props whose values can be evaluated at build time. By default, this consists of any literal type (string, number, null) as well as any variables provided to the evaluation context. The evaluation context is derived from the prop’s current scope.

For example, the fontSize prop in the following component will be marked as evaluatable and will be extracted as 42:

import { Block } from 'jsxstyle';

const bestNumber = 42;
<Block fontSize={bestNumber}>hello</Block>;

Any modules marked as static with the staticModules plugin config option will also be added to the evaluation context.

If the value of a style prop is a ternary and both sides can be evaluated, the prop will be extracted and the ternary condition will be moved to the className.

If the value of a prop is a simple logical expression with the && operator, it will be converted to a ternary with a null alternate.

Inline styles… are bad.

See the jsxstyle FAQs.

Does it work with hot reloading?

It sure does, but using it in development will only cause confusion, since what you will see in the developer tools is the transformed JS. jsxstyle-webpack-plugin is a production optimisation.

Any caveats?

CSS class names are reused across components but they are not de-duplicated. Any CSS minifier that combines identical class names will handle deduplication.

Contributing

Got an idea for jsxstyle-webpack-plugin? Did you encounter a bug? Open an issue and let’s talk it through. PRs welcome too!

FAQs

Package last updated on 04 Jun 2022

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc