Skip to content

Latest commit

 

History

History
92 lines (65 loc) · 2.19 KB

README.md

File metadata and controls

92 lines (65 loc) · 2.19 KB

@lassehaslev/sass-asset-inliner

Helper functions for node-sass for inlining / base64 encoding assets

Install

npm install @lassehaslev/sass-asset-inliner --save

Usage

Setup

You need to add the sass-asset-inliner functions to node-sass function option.

var sass = require('node-sass');

// When not using es6 you must use the default property
var SassAssetInliner = require( '@lassehaslev/sass-asset-inliner' ).default;

sass.render({
    file: scss_filename,
    {
        functions: SassAssetInliner,
    }
}, function(err, result) { /*...*/ });

Sass

Inline assets by including absolute path, relative path or url to the assets you want to inline.

Inline images

body {
    // Inline image
    background-image: inline-image( 'path/to/your/image.png' );

    // Inline and resize image to width (Kepp aspect ratio)
    background-image: inline-image( 'path/to/your/image.png', "200" );

    // Resize image and ignoring aspect ratio
    background-image: inline-image( 'path/to/your/image.png', "200x400" );

    // Resize image to height and keep aspect ratio
    background-image: inline-image( 'path/to/your/image.png', "_x400" );

    // Underscore works also for height.
    // ("200x_" equals "200" as shown above)
}

Inline fonts

Note: at this point, there is not possible to subset a font from a url.

@font-face {
    src: inline-font( 'path/to/your/font.ttf' ); // Include full font

    // Subset font by adding regex as second parameter
    // of each character you want to include
    src: inline-font( 'path/to/your/font.ttf', '[0-9]' );
}

Api

As the SassFunctions you can use the functions of the Encoder.

import {Encoder} from '@lassehaslev/sass-asset-inliner';

// base64 encode file
Encoder.encode( '{path}' );

// base64 encode image
Encoder.encodeImage( '{path}', '100x100' );

// base64 encode font
Encoder.encodeFont( '{path}', '[0-9]' );

Development

// Test driven development
npm run tdd

// Build
npm run build