Skip to content

A lightweight helper for generating CSS property/value prefixes

License

Notifications You must be signed in to change notification settings

jsau-/lw-css-prefixer

Repository files navigation

lw-css-prefixer

npm version minzipped size build status npm downloads

NOTE: This project is under active development and is not considered stable for production use. Exposed APIs are liable to change in major ways before a 1.0.0 release. Expect issues if you use this in production.

A lightweight auto-prefixer for CSS properties and values. Intended for runtime use, e.g. in CSS-in-JS libraries where inclusion of a fully-fledged solution like Autoprefixer is too big an impact on your overall bundle size.

npm i lw-css-prefixer

Code Samples

Converting a property/value pair to a CSS string

import { prefixer } from 'lw-css-prefixer';

/*
 * To ensure the impact on your bundle size is as small as possible
 * plugins and propertyPrefixes must be loaded separately.
 *
 * If you're particularly conscious of your own bundle size it may
 * be sensible to define your own property prefix and plugins list in
 * line with your own needs, only supporting the minimum required set
 * of features.
 */
import { plugins } from 'lw-css-prefixer/dist/plugins';
import { propertyPrefixes } from 'lw-css-prefixer/dist/propertyPrefixes';

const pfx = prefixer(plugins, propertyPrefixes);

// [['-webkit-align-content', 'inherit'], ['align-content', 'inherit']]
const styles = pfx('align-content', 'inherit');

// '-webkit-align-content:inherit;align-content:inherit;'
const style = styles.map(([prop, val]) => `${prop}:${val};`).join('');

With Goober

import { setup } from 'goober';
import { prefixer } from 'lw-css-prefixer';

/*
 * To ensure the impact on your bundle size is as small as possible
 * plugins and propertyPrefixes must be loaded separately.
 *
 * If you're particularly conscious of your own bundle size it may
 * be sensible to define your own property prefix and plugins list in
 * line with your own needs, only supporting the minimum required set
 * of features.
 */
import { plugins } from 'lw-css-prefixer/dist/plugins';
import { propertyPrefixes } from 'lw-css-prefixer/dist/propertyPrefixes';

setup(React.createElement, prefixer(plugins, propertyPrefixes));

Links

Intended Browser Support

  • IE10+
  • Edge 12+
  • Chrome 17+
  • Firefox 17+
  • Safari 7+

Big missing features

  • transition
  • grid
  • Short-hand properties (likely missing a ton of shorthand behaviors)

Contributing

While contributions are appreciated, they may be rejected if not in line with the intended project direction. It's recommended to check before undertaking a major piece of work and/or refactoring.

Contributions should be based off the develop branch, and any pull requests made into develop.

Useful Snippets

# Install dependencies
npm ci

# Run tests
npm run lint
npm run test

# Build the library
npm run build

Feedback and Support

For suggestions, issues, and/or support raise a GitHub issue!

Special Thanks

About

A lightweight helper for generating CSS property/value prefixes

Resources

License

Stars

Watchers

Forks