schelmo / windicss-webpack-plugin

πŸƒ Windi CSS for webpack ⚑

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

windicss-webpack-plugin

Windi CSS for webpack, it's fast! ⚑️
a.k.a On-demand Tailwind CSS

⚑️ See speed comparison with Tailwind

Features

  • ⚑️ It's FAST - 20~100x times faster than Tailwind on webpack apps
  • 🧩 On-demand CSS utilities (Compatible with Tailwind CSS v2)
  • πŸ“¦ On-demand native elements style reseting
  • πŸ”₯ Hot module replacement (HMR)
  • πŸƒ Load configurations from tailwind.config.js
  • 🀝 Framework-agnostic - Vue, React, Svelte and vanilla!
  • πŸ“„ CSS @apply / @screen directives transforms (also works for Vue SFC's <style>)
  • 🎳 Support Utility Groups - e.g. bg-gray-200 hover:(bg-gray-100 text-red-300)

Install

yarn add windicss-webpack-plugin -D 
# npm i windicss-webpack-plugin -D

webpack.config.js

If you have access to modify the webpack.config.js directly, then you can do the following.

// webpack.config.js
import WebpackWindiCSSPlugin from 'windicss-webpack-plugin'

export default {
  // ...
  plugins: [
    new WindiCSSWebpackPlugin()
  ],
};
// main.js
import 'windi.css'

Other examples

See ./example

That's all. Build your app just like what you would do with Tailwind CSS, but much faster! ⚑️

Migration

If you are already using Tailwind CSS for your app, please consult the documentation on migrating.

All set.

That's all, fire up your app and enjoy the speed!

TypeScript

You can use TypeScript for your config file if you're using esbuild.

Simply rename your config it to tailwind.config.ts.

// tailwind.config.ts
import { defineConfig } from 'windicss-webpack-plugin'

export default defineConfig({
  darkMode: 'class',
  theme: {
    extend: {
      colors: {
        teal: {
          100: '#096',
        },
      },
    },
  },
})

Configuration

See options.ts for configuration reference.

Caveats

Scoped Style

You will need to set transformCSS: 'pre' to get it work.

@media directive with scoped style can only works with css postcss scss but not sass, less nor stylus

Credits

  • Windy team
  • @antfu Based on his Rollup / Vite implementation & his util package

License

MIT License Β© 2021 Harlan Wilton

About

πŸƒ Windi CSS for webpack ⚑

License:MIT License


Languages

Language:JavaScript 39.2%Language:TypeScript 32.9%Language:Vue 13.2%Language:CSS 6.8%Language:HTML 4.6%Language:Svelte 3.2%Language:Shell 0.1%