1.1.1 • Published 6 years ago
stylus-vrhr v1.1.1
stylus-vrhr
Minimalist vertical rhythm and horizontal rhythm plugin for stylus.
I've been using these helpers on all my stylus projects for years. It makes your pages look harmonious and consistent. Stop picking random pixel numbers, and use some basic geometry.
Looks like this:
$vertical-rhythm = 20px;
$horizontal-rhythm = 80px;
button
  height: vr(2) // 40px
  min-width: hr(9/12) // 60px
p
  font-size: 33px
  line-height: vr(@font-size) // 40px
  margin-bottom: vr(2/12) // 3.5pxThe vr() and hr() helpers take a plain number and multiply it by the rhythm value. That's it. As you can see from the example, you can easily use ratios instead. Divisions of 12 are nice.
However, if you pass the helpers a px unit value, the output will be that value rounded up to the nearest rhythm.
Also, all output will be rounded to the nearest half pixel.
Installation
npm install stylus-vrhrJS API Example:
const stylus = require('stylus');
const vrhr = require('stylus-vrhr');
const rendered = stylus('...')
  .use(vrhr())
  .render();Webpack Example:
const vrhr = require('stylus-vrhr');
const webpackConfig = {
  module: {
    rules: [
      {
        test: /\.styl$/,
        loader: 'stylus-loader',
        options: {
          use: [
            vrhr() // <--- HERE
          ]
        }
      }
    ]
  }
};Gulp Example:
const vrhr = require('stylus-vrhr');
gulp.task('styles', function () {
  gulp.src('./index.styl')
    .pipe(stylus({
      use: [
        vrhr() // <--- HERE
      ]
    }))
   .pipe(gulp.dest('./index.css'));
});