From 5fcb054956efe102f0f37ee6e5d7d84947f30e6d Mon Sep 17 00:00:00 2001 From: Taveesh Anand Date: Mon, 21 Sep 2020 22:57:55 +0530 Subject: [PATCH] :sparkles: Add beforeScreenshot parameter (#65) --- README.md | 1 + src/screenshot.js | 6 ++- src/screenshot.spec.js | 31 +++++++++++++-- types/options.d.ts | 90 ++++++++++++++++++++++-------------------- types/screenshot.d.ts | 2 +- 5 files changed, 81 insertions(+), 49 deletions(-) diff --git a/README.md b/README.md index 0cc3d1c..c38391d 100644 --- a/README.md +++ b/README.md @@ -73,6 +73,7 @@ List of all available options: | content | If provided html property is considered an handlebars template and use content value to fill it | object or Array | optional | | waitUntil | Define when to consider markup succeded. [Learn more](https://github.com/puppeteer/puppeteer/blob/8370ec88ae94fa59d9e9dc0c154e48527d48c9fe/docs/api.md#pagesetcontenthtml-options). | string or Array (default: networkidle0) | optional | | puppeteerArgs | The puppeteerArgs property let you pass down custom configuration to puppeteer. [Learn more](https://github.com/puppeteer/puppeteer/blob/8370ec88ae94fa59d9e9dc0c154e48527d48c9fe/docs/api.md#puppeteerlaunchoptions). | object | optional | +| beforeScreenshot | An async function that will execute just before screenshot is taken. Gives access to puppeteer page element. | Function | optional | | transparent | The transparent property lets you generate images with transparent background (for png type). | boolean | optional | | encoding | The encoding property of the image. Options are `binary` (default) or `base64`. | string | optional | diff --git a/src/screenshot.js b/src/screenshot.js index ad6467b..2f4e0d2 100644 --- a/src/screenshot.js +++ b/src/screenshot.js @@ -1,13 +1,14 @@ const handlebars = require('handlebars') module.exports = { - makeScreenshot: async function(page, { + makeScreenshot: async function (page, { output, type, quality, encoding, content, html, + beforeScreenshot, transparent = false, waitUntil = 'networkidle0', }) { @@ -22,6 +23,9 @@ module.exports = { } await page.setContent(html, { waitUntil }) const element = await page.$('body') + if (beforeScreenshot && typeof beforeScreenshot === "function") { + await beforeScreenshot(page); + } const buffer = await element.screenshot({ path: output, type, omitBackground: transparent, encoding, ...screeshotArgs }) return buffer diff --git a/src/screenshot.spec.js b/src/screenshot.spec.js index a184806..99f99e8 100644 --- a/src/screenshot.spec.js +++ b/src/screenshot.spec.js @@ -1,3 +1,4 @@ +const { describe } = require('jest-circus') const puppeteer = require('puppeteer') const { makeScreenshot } = require('./screenshot') @@ -18,8 +19,8 @@ describe('quality', () => { quality: 300, html: 'Hello world!', }) - - expect(screenshot).toHaveBeenCalledWith(expect.objectContaining({'encoding': undefined, 'omitBackground': false, 'path': undefined, 'type': 'png'})) + + expect(screenshot).toHaveBeenCalledWith(expect.objectContaining({ 'encoding': undefined, 'omitBackground': false, 'path': undefined, 'type': 'png' })) }) it('should set quality option for jpg images', async () => { @@ -28,7 +29,7 @@ describe('quality', () => { quality: 30, html: 'Hello world!', }) - + expect(screenshot).toHaveBeenCalledWith(expect.objectContaining({ quality: 30 })) }) @@ -37,11 +38,33 @@ describe('quality', () => { type: 'jpeg', html: 'Hello world!', }) - + expect(screenshot).toHaveBeenCalledWith(expect.objectContaining({ quality: 80 })) }) }) +describe('beforeScreenshot', () => { + let screenshot + let puppeteer + let page + + beforeEach(() => { + puppeteer = require('puppeteer') + page = puppeteer.launch().newPage() + screenshot = page.$().screenshot + }) + + it('beforeScreenshot is called with page', async () => { + const beforeScreenshot = jest.fn(); + await makeScreenshot(page, { + beforeScreenshot, + html: 'Hello world!', + }) + + expect(beforeScreenshot).toHaveBeenCalledWith(page); + }) +}) + jest.mock('puppeteer', () => { const screenshot = jest.fn() return { diff --git a/types/options.d.ts b/types/options.d.ts index 266b1f5..6617040 100644 --- a/types/options.d.ts +++ b/types/options.d.ts @@ -4,46 +4,50 @@ import type { LaunchOptions, LoadEvent } from 'puppeteer'; * Available options to pass to the library */ export interface NodeHtmlToImageOptions { - /** - * The html used to generate image content - */ - html: string; - /** - * The ouput path for generated image - * If none is specified - */ - output?: string; - /** - * The type of the generated image - * @default png - */ - type?: 'jpeg' | 'png'; - /** - * The quality of the generated image (only applicable to jpg) - * @default 80 - */ - quality?: number; - /** - * If provided html property is considered an handlebars template and use content value to fill it - */ - content?: Array | Record; - /** - * Define when to consider markup succeded. - * {@link https://github.com/puppeteer/puppeteer/blob/8370ec88ae94fa59d9e9dc0c154e48527d48c9fe/docs/api.md#pagesetcontenthtml-options Learn more} - */ - waitUntil?: LoadEvent; - /** - * The puppeteerArgs property let you pass down custom configuration to puppeteer. - * {@link https://github.com/puppeteer/puppeteer/blob/8370ec88ae94fa59d9e9dc0c154e48527d48c9fe/docs/api.md#puppeteerlaunchoptions Learn more} - */ - puppeteerArgs?: LaunchOptions; - /** - * The transparent property lets you generate images with transparent background (for png type). - */ - transparent?: boolean; - /** - * The encoding property of the image. Options are `binary` (default) or `base64`. - * @default binary - */ - encoding?: 'binary' | 'base64'; -} \ No newline at end of file + /** + * The html used to generate image content + */ + html: string; + /** + * The ouput path for generated image + * If none is specified + */ + output?: string; + /** + * The type of the generated image + * @default png + */ + type?: 'jpeg' | 'png'; + /** + * The quality of the generated image (only applicable to jpg) + * @default 80 + */ + quality?: number; + /** + * If provided html property is considered an handlebars template and use content value to fill it + */ + content?: Array | Record; + /** + * Define when to consider markup succeded. + * {@link https://github.com/puppeteer/puppeteer/blob/8370ec88ae94fa59d9e9dc0c154e48527d48c9fe/docs/api.md#pagesetcontenthtml-options Learn more} + */ + waitUntil?: LoadEvent; + /** + * The puppeteerArgs property let you pass down custom configuration to puppeteer. + * {@link https://github.com/puppeteer/puppeteer/blob/8370ec88ae94fa59d9e9dc0c154e48527d48c9fe/docs/api.md#puppeteerlaunchoptions Learn more} + */ + puppeteerArgs?: LaunchOptions; + /** + * Function executes before screenshot is taken and provides access to puppeteer page element + */ + beforeScreenshot?: Function; + /** + * The transparent property lets you generate images with transparent background (for png type). + */ + transparent?: boolean; + /** + * The encoding property of the image. Options are `binary` (default) or `base64`. + * @default binary + */ + encoding?: 'binary' | 'base64'; +} diff --git a/types/screenshot.d.ts b/types/screenshot.d.ts index 668d20c..75f75b3 100644 --- a/types/screenshot.d.ts +++ b/types/screenshot.d.ts @@ -2,5 +2,5 @@ import type { Page } from 'puppeteer'; import type { NodeHtmlToImageOptions } from './options'; -declare function makeScreenshot(page: Page, { output, type, quality, encoding, content, html, transparent, waitUntil }: NodeHtmlToImageOptions): Promise; +declare function makeScreenshot(page: Page, { output, type, quality, encoding, content, html, beforeScreenshot, transparent, waitUntil }: NodeHtmlToImageOptions): Promise; export default makeScreenshot; \ No newline at end of file