Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/robinloeffel/gulp-rezzy

The incredibly fast image resizer utility for gulp. ⚡️
https://github.com/robinloeffel/gulp-rezzy

gulp gulp-plugin image image-processing javascript nodejs resizer sharp

Last synced: 3 months ago
JSON representation

The incredibly fast image resizer utility for gulp. ⚡️

Awesome Lists containing this project

README

        

# gulp-rezzy

[![latest version on npm](https://img.shields.io/npm/v/gulp-rezzy)](https://www.npmjs.com/package/gulp-rezzy)
[![npm downloads a month](https://img.shields.io/npm/dm/gulp-rezzy)](https://www.npmjs.com/package/gulp-rezzy)
[![required node version](https://img.shields.io/node/v/gulp-rezzy)](https://github.com/nodejs/Release)
[![package license](https://img.shields.io/npm/l/gulp-rezzy)](license)

> The incredibly fast image resize utility for [`gulp`](https://github.com/gulpjs/gulp). ⚡️

`gulp-rezzy` enables you to resize your images and then pipe each and every newly created version version of it into your stream. This allows you to only have one big background image asset in your source directory and then generate several smaller versions of it for all your responsiveness needs automatically. No more Photoshop for you, my friend!

## Setup

```sh
npm i gulp-rezzy -D
```

```js
import gulp from 'gulp';
import rezzy from 'gulp-rezzy';

export const images = () => src('source/img/*')
.pipe(rezzy([{
width: 640,
suffix: '-sm'
}, {
width: 1280,
suffix: '-md'
}, {
width: 1920,
suffix: '-lg'
}]))
.pipe(dest('public/img'));
```

This plugin works perfectly in tandem with [`gulp-imagemin`](https://github.com/sindresorhus/gulp-imagemin) and [`gulp-webp`](https://github.com/sindresorhus/gulp-webp).

## Config

You can configure `gulp-rezzy` by passing in an array of objects containing the details of the versions to be generated.

[`width`](#width) and [`height`](#height) are optional. If none of them are supplied, there'll be no resizing. If one of them is present, the image will be transformed accordingly, preserving the aspect ratio. If both are present, the image will be resized and cropped to those exact dimensions. [`suffix`](#suffix) is always required. If no configuration gets passed, no transformations will be made.

You can see all available options for [`fit`](#fit) and [`position`](#position) in the [`sharp` documentation](https://sharp.pixelplumbing.com/api-resize#resize). They get passed right to [`sharp`](https://github.com/lovell/sharp).

### `width`

Type: `number`

Default: `undefined`

Desired width of the image in pixels. Either [`width`](#width) or [`height`](#height) has to be set.

### `height`

Type: `number`

Default: `undefined`

Desired height of the image in pixels. Either [`height`](#height) or [`width`](#width) has to be set.

### `fit`

Type: `string`

Default: `'cover'`

How the image should fit inside the specified dimensions.

### `position`

Type: `string`

Default: `'center'`

What or where to focus on when cropping is necessary.

### `suffix`

Type: `string`

Default: `undefined`

String to prepend the file extension.

## License

MIT