Skip to content
This repository has been archived by the owner on Jan 14, 2022. It is now read-only.
/ use-screenshot Public archive
forked from fayeed/use-screenshot

React hook to take screenshot for React components.

Notifications You must be signed in to change notification settings

zipmex/use-screenshot

 
 

Repository files navigation

use-screenshot-hook

React hook to take screenshot for React components.

NPM JavaScript Style Guide

Install

Using npm:

npm install --save use-screenshot-hook

Using yarn:

yarn add use-screenshot-hook

Usage

import * as React from "react";

import { useScreenshot } from "use-screenshot-hook";

const Example = () => {
  const { image, takeScreenshot } = useScreenshot();
  return (
    <div>
      <h1>Hello World!</h1>
      <button onClick={() => takeScreenshot()}>screenshot</button>
      {image && <img src={img} />}
    </div>
  );
};

API

UseScreenshot(options: UseScreenshotProps): UseScreenshotReturnType

UseScreenshotProps

  • ref - Ref to the component for which the screenshot should be taken. If no ref is taken it will take the screenshot for the topmost div or body.

UseScreenshotReturnType

  • isLoading - Indicates if the screenshot is loading this is useful for some webpages that are big and have lots of content to render.
  • takeScreenshot: (types: ImgType, options: OptionsType): string | undefined - A function to take screenshot.
  • image - Contains the dataUrl for the image.
  • clear() - Clear the image from the memory.

Found this project useful? ❤️

If you found this project useful, then please consider giving it a ⭐️ on Github and sharing it with your friends via social media.

Issues and feedback 💭

If you have any suggestion for including a feature or if something doesn't work, feel free to open a Github issue for us to have a discussion on it.

License

MIT © fayeed


This hook is created using create-react-hook.

About

React hook to take screenshot for React components.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 46.0%
  • CSS 45.1%
  • JavaScript 5.4%
  • HTML 3.5%