blurry

A node module to generate reliable image load effects.

Generate Base64 inline Images. Prepared for lazyloading. Based on configurable SVG Templates. Compatible with Internet Explorer 11 and up.

A Solution with a very small footprint to get your DOM interactive blurry and fast.

# install
npm install --save-dev js.node.blurry
// usage
const Blurry = require('blurry');
const blurry = new Blurry({'file': path.join(__dirname, 'static/img/teapott-preview.jpg'), 'width': 1140, 'height': 640});
<img alt="" src="' + blurry.getUrl() + '">

Base64 inline Image

base64 blured svg/jpeg preview image
Original Preview Image 114x64px resized to 1140x640px within the SVG. The SVG feGaussianBlur filter produce a blurry effect.
In this solution the SVG below is encoded into base64 and directly writen to img src with blurry.getUrl().
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="1140px" height="640px" viewBox="1 1 {{width}} {{height}}">
  <image filter="url(#blurWitchProject)" width="100%" height="100%" xlink:href=""
  />
  <filter id="blurWitchProject" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
    <feGaussianBlur stdDeviation="20" edgeMode="duplicate" />
    <feComponentTransfer>
      <feFuncA type="discrete" tableValues="1 1" />
    </feComponentTransfer>
  </filter>
</svg>

Picture Element with blurry and lazyload

webp/jpeg picture element with four breakpoints and base64 blured svg/jpeg preview image
Blured Preview Image 114x64px in lazyload picture container is displayed until source srcset image has been loaded by the browser.
<picture>
  <source data-srcset="static/img/teapott-ld.webp 1x, static/img/teapott-ld_x2.webp 2x" media="(min-width: 1200px)" type="image/webp">
  <source data-srcset="static/img/teapott-md.webp 1x, static/img/teapott-md_x2.webp 2x" media="(min-width: 992px) and (max-width: 1199px)" type="image/webp">
  <source data-srcset="static/img/teapott-t.webp 1x, static/img/teapott-t_x2.webp 2x" media="(min-width: 768px) and (max-width: 991px)" type="image/webp">
  <source data-srcset="static/img/teapott-m.webp 1x, static/img/teapott-m_x2.webp 2x" media="(max-width: 767px)" type="image/webp">
  <source data-srcset="static/img/teapott-ld.jpg 1x, static/img/teapott-ld_x2.jpg 2x" media="(min-width: 1200px)" type="image/jpeg">
  <source data-srcset="static/img/teapott-md.jpg 1x, static/img/teapott-md_x2.jpg 2x" media="(min-width: 992px) and (max-width: 1199px)" type="image/jpeg">
  <source data-srcset="static/img/teapott-t.jpg 1x, static/img/teapott-t_x2.jpg 2x" media="(min-width: 768px) and (max-width: 991px)" type="image/jpeg">
  <source data-srcset="static/img/teapott-m.jpg 1x, static/img/teapott-m_x2.jpg 2x" media="(max-width: 767px)" type="image/jpeg">
  <img class="lazyload" alt="webp/jpeg picture element with four breakpoints and base64 blured svg/jpeg preview image" src="">
</picture>

Picture Element with blurry and lazyload VS. without lazyload

Picture Element with blurry and lazyloadPicture Element with blurry and without lazyload

Usage

// Render Blurry as base64 image src
const Blurry = require('blurry')
const blurry = new Blurry({'file': path.join(__dirname, 'static/img/teapott-preview.jpg'), 'width': 1140, 'height': 640});
<img alt="" src="' + blurry.getUrl() + '">
// Construct Blurry with custom template
const blurry = new Blurry({'file': path.join(__dirname, 'static/img/teapott-preview.jpg'), 'width': 1140, 'height': 640, 'template': 'blurry.tmpl'});
<!-- Blurry default template -->
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="{{width}}px" height="{{height}}px" viewBox="1 1 {{width}} {{height}}">
  <image filter="url(#blurWitchProject)" width="100%" height="100%" xlink:href="{{base64FileUrl}}" />
  <filter id="blurWitchProject" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
    <feGaussianBlur stdDeviation="20" edgeMode="duplicate" />
    <feComponentTransfer>
      <feFuncA type="discrete" tableValues="1 1" />
    </feComponentTransfer>
  </filter>
</svg>
Lazysizes is needed to enable lazyloading. Lazysizes switch also the blurry base64 SVG image to a image defined in srcset within this solution.
IE 11 needs picturefill to enable picture element support.