All files / cmd/compositing overlay-with.js

100% Statements 13/13
100% Branches 6/6
100% Functions 3/3
100% Lines 13/13

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109                                                          1x     1x 1x     1x                                                                       1x 18x 18x                   1x 18x 18x     18x 6x                       1x            
/*!
 * The MIT License (MIT)
 *
 * Copyright (c) 2019 Mark van Seventer
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy of
 * this software and associated documentation files (the "Software"), to deal in
 * the Software without restriction, including without limitation the rights to
 * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
 * the Software, and to permit persons to whom the Software is furnished to do so,
 * subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in all
 * copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
 * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
 * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
 * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 */
 
// @see http://sharp.pixelplumbing.com/en/v0.21.3/api-composite/#overlaywith
 
// Strict mode.
'use strict'
 
// Standard lib.
const path = require('path')
 
// Local modules.
const constants = require('../../lib/constants')
const queue = require('../../lib/queue')
 
// Configure.
const options = {
  create: {
    desc: 'Describes a blank overlay to be created',
    defaultDescription: 'width, height, channels, background',
    nargs: 4,
    type: 'array'
  },
  cutout: {
    desc: 'Apply only the alpha channel of the overlay image to the input image, giving the appearance of one image being cut out of another',
    type: 'boolean'
  },
  gravity: {
    choices: constants.GRAVITY,
    default: 'centre',
    desc: 'Gravity at which to place the overlay',
    nargs: 1,
    type: 'string'
  },
  offset: {
    desc: 'The pixel offset from the top and left edges',
    nargs: 2,
    type: 'array'
  },
  overlay: {
    coerce: path.normalize, // Positional arguments need manual normalization.
    desc: 'Path to an image file',
    normalize: true,
    type: 'string'
  },
  tile: {
    desc: 'Repeat the overlay image across the entire image with the given gravity',
    type: 'boolean'
  }
}
 
// Command builder.
const builder = (yargs) => {
  const optionNames = Object.keys(options)
  return yargs
    .strict()
    .example('$0 overlayWith ./input.png --gravity southeast', 'The output will be the input composited with ./input.png with SE gravity')
    .epilog('For more information on available options, please visit http://sharp.pixelplumbing.com/en/v0.21.3/api-composite/#overlaywith')
    .options(options)
    .global(optionNames, false)
    .group(optionNames, 'Command Options')
}
 
// Command handler.
const handler = (args) => {
  const [ top, left ] = args.offset || [ ]
  const [ width, height, channels, background ] = args.create || [ ]
 
  // @see http://sharp.pixelplumbing.com/en/v0.21.3/api-composite/#overlaywith
  return queue.push([ 'overlayWith', (sharp) => {
    return sharp.overlayWith(args.overlay, {
      create: args.create && { width, height, channels, background },
      gravity: args.gravity,
      top,
      left,
      tile: args.tile,
      cutout: args.cutout
    })
  }])
}
 
// Exports.
module.exports = {
  command: 'overlayWith <overlay>',
  describe: '[DEPRECATED] Overlay (composite) an image over the processed (resized, extracted etc.) image',
  builder,
  handler
}