postcss-rem-multiplier-test

1.0.3 • Public • Published

postcss-rem-to-pixel NPM version

A plugin for PostCSS that multiplies rem units by a certain factor.

Install

$ npm install postcss-rem-multiplier --save-dev

Usage

There are cases that you need to embed your own widget with your own css into an application. However, all of your css which contains rem value which is based on a base-font-size that is different from the one given in the application’s css.

With this plugin, it will multiply your rem by a certain factor so as to match the resultant font size correctly.

The default multiplier is 1, which basically doesn't multiply anything

Input/Output

With the default settings, only font related properties are targeted.

// input
h1 {
    margin: 0 0 20px;
    font-size: 2rem;
    line-height: 1.2;
    letter-spacing: 0.0625rem;
}

// output
h1 {
    margin: 0 0 20px;
    font-size: 32px;
    line-height: 1.2;
    letter-spacing: 1px;
}

Example

var fs = require("fs");
var postcss = require("postcss");
var remToPx = require("postcss-rem-to-pixel");
var css = fs.readFileSync("main.css", "utf8");
var options = {
    replace: false,
};
var processedCss = postcss(remToPx(options)).process(css).css;

fs.writeFile("main-px.css", processedCss, function (err) {
    if (err) {
        throw err;
    }
    console.log("Rem file written.");
});

options

Type: Object | Null
Default:

{
    unitPrecision: 5,
    propList: ['font', 'font-size', 'line-height', 'letter-spacing'],
    selectorBlackList: [],
    mediaQuery: false,
}
  • unitPrecision (Number) The decimal precision px units are allowed to use, floored (rounding down on half).
  • propList (Array) The properties that can change from rem to px.
    • Values need to be exact matches.
    • Use wildcard * to enable all properties. Example: ['*']
    • Use * at the start or end of a word. (['*position*'] will match background-position-y)
    • Use ! to not match a property. Example: ['*', '!letter-spacing']
    • Combine the "not" prefix with the other prefixes. Example: ['*', '!font*']
  • selectorBlackList (Array) The selectors to ignore and leave as rem.
    • If value is string, it checks to see if selector contains the string.
      • ['body'] will match .body-class
    • If value is regexp, it checks to see if the selector matches the regexp.
      • [/^body$/] will match body but not .body
  • mediaQuery (Boolean) Allow rem to be converted in media queries.

Package Sidebar

Install

npm i postcss-rem-multiplier-test

Weekly Downloads

0

Version

1.0.3

License

MIT

Unpacked Size

5.18 kB

Total Files

3

Last publish

Collaborators

  • finalight