wyw-in-js, short for "Whatever-you-want-in-JS," is the world's first toolkit for creating various zero-runtime CSS(and more)-in-JS libraries. In essence, it empowers developers to build their own solutions with arbitrary syntax and functionality, offering complete independence from specific implementations.
This library evolved from the CSS-in-JS library Linaria, with the aim of decoupling from a specific implementation and providing developers with a comprehensive toolkit for crafting their own solutions with custom syntax and features.
- Provides an API for creating custom processors (e.g.,
cssandstyledin Linaria ormakeStylesin Griffel). - Supports a wide range of syntaxes, including tagged templates, function calls, and object literals.
- Computes any unprepared JavaScript during the build phase, generating a set of artifacts that processors can transform into styles (or other outputs, depending on the processor).
- Allows for arbitrary JavaScript in style definitions, including imports, conditionals, and loops.
- Offers loaders and plugins for popular bundlers (including Webpack, Vite, esbuild) and frameworks (Next.js), ensuring compatibility with various build systems.
- Website: https://wyw-in-js.dev/
- Stability: https://wyw-in-js.dev/stability
- Configuration: https://wyw-in-js.dev/configuration
- How it works: https://wyw-in-js.dev/how-it-works
- Bundlers: https://wyw-in-js.dev/bundlers
- CLI: https://wyw-in-js.dev/cli
Install:
npm i -D @wyw-in-js/cli
yarn add -D @wyw-in-js/cli
pnpm add -D @wyw-in-js/cli
bun add -d @wyw-in-js/cliExtract CSS and inject imports into your compiled output:
wyw-in-js \
--config ./wyw-in-js.config.js \
--source-root ./src \
--out-dir ./dist/wyw-css \
--insert-css-requires ./dist \
--modules esnext \
--transform \
"src/**/*.{ts,tsx,js,jsx}"See https://wyw-in-js.dev/cli for all options, migration notes from @linaria/cli, and notes about dependencies (including happy-dom).