@mole-inc/sqip-loader
v1.0.1
Published
Loads images and exports tiny SQIP previews as image/svg+xml data
Downloads
4
Readme
SQIP Loader
Loads images and exports tiny SQIP previews as image/svg+xml data
This is a fork of EmilTholin/sqip-loader.@mole-inc/sqip-loader
is depends on the canary version of sqip.
If you use stable one, you are able to use original sqip-loader.
Requirements for non-64bit operating systems
Install
npm install --save-dev @mole-inc/sqip-loader
Usage
The @mole-inc/sqip-loader
loads your image and exports the url of the image as src
, the image/svg+xml URL-encoded data as preview
, and a sizes
object containing width, height and the type of the imported image.
import { src, preview, sizes } from './image.png'
webpack.config.js
module.exports = {
module: {
rules: [
{
test: /\.(gif|png|jpe?g)$/i,
use: [
{
loader: '@mole-inc/sqip-loader',
options: {
numberOfPrimitives: 20,
},
},
],
},
],
},
}
It can also be used in conjunction with url-loader or file-loader.
webpack.config.js
module.exports = {
module: {
rules: [
{
test: /\.(gif|png|jpe?g)$/i,
use: [
{
loader: '@mole-inc/sqip-loader',
options: {
numberOfPrimitives: 20,
},
},
{
loader: 'url-loader',
options: {
limit: 8192,
},
},
],
},
],
},
}
Options
| Name | Type | Default | Description |
| :-----------------------: | :---------: | :-----: | :--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| numberOfPrimitives
| {Number}
| 20
| SQIP works by first approximating the image with a certain number of shapes, specified by numberOfPrimitives
, and then adding a blur effect to it. Larger values will generate sharper previews, but will also increase the size |
| mode
| {Number}
| 0
| Specifies the type of primitive shapes that will be used to generate the image. 0=combo, 1=triangle, 2=rect, 3=ellipse, 4=circle, 5=rotatedrect, 6=beziers, 7=rotatedellipse, 8=polygon |
| blur
| {Number}
| 12
| Specifies the standard deviation of the Gaussian blur |
| skipPreviewIfBase64
| {Boolean}
| false
| If set to true
, will not generate a preview if the image already is base64 encoded. Useful when the inlined base64 representation is enough, and you don't want to bloat your files with unused previews |