# tiled-images

> Merge multiple images into a single image

`tiled-images` is modified version of [`merge-img`][merge-img] to make it work with [`sharp`][sharp] library.

`tiled-images` merges given images into a single image in right order. This will be helpful in a situation when you have to generate a preview of multiple images into a single image. This module is based on [`sharp`][sharp] for image processing.

## Install

```bash
$ npm install sharp tiled-images
```

## Usage

```javascript
import TiledImages from 'tiled-images'

TiledImages(['image-1.png', 'image-2.jpg']).then((img) => {
    // Save image as file
    img.toFile('out.png')
})
```

## API

### joinImages(images[, options])

-   `images` Array of (String | Object | Buffer) - List of images to concat. If `String` is passed, it will be considered to the file path. An `Object` entry can have following options:
    -   `src` _`String`_ or `Buffer` - A single image source to concat.
    -   `offsetX` Number (optional) - `x` offset to affect this image. Default is `0`.
    -   `offsetY` Number (optional) - `y` offset to affect this image. Default is `0`.
-   `options` Object (optional)
    -   `direction` String (`vertical|horizontal`) - Direction of the merged image.`.
    -   `color` (String | Object) - Default background color represented by RGBA hex value. Default is `{ alpha: 0.5, b: 0, g: 0, r: 0 }`.
    -   `align` String - Aligning of given images. If the images are not all the same size, images will be sorted to largest image. Possible values are `start`, `center` and `end`. Default is `start`.
    -   `offset` Number - Offset in pixels between each image. Default is `0`.
    -   `margin` (Number | String | Object) - Margin of the result image. If `Number` or `String` is passed, it will be considered as [standard css shorthand properties](https://developer.mozilla.org/en-US/docs/Web/CSS/Shorthand_properties) (e.g. '40 40 0 10'). An `Object` entry can have following options:
        -   `top` Number (optional) - Margin on top side of result image. Default is `0`.
        -   `right` Number (optional) - Margin on right side of result image. Default is `0`.
        -   `bottom` Number (optional) - Margin on bottom side of result image. Default is `0`.
        -   `left` Number (optional) - Margin on left side of result image. Default is `0`.

Returns a `Promise` that contains `sharp` object.

[sharp]: https://github.com/lovell/sharp
[merge-img]: https://github.com/preco21/merge-img
