Skip to content

builat/printscreen

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

printScreen

Motivation

  • create zero dep util to make printscreen of DOM elements.

Signature

async function printScreen(
  src: string | HTMLElement,
  params: PrintScreenParamsT
): Promise<string>;
type PrintScreenParamsT = {
  scale?: number;
  fonts?: FontCfg[];
  underlayStyle?: string;
  fontFaceTemplate: FontFaceTemplate;
};
  • scale is multiplyer for original image width and height
  • fonts is config for fonts added by <link />
export type FontCfg<T = unknown> = {
  uri: string;
  format: string;
  name: string;
  options?: T;
};
  • underlayStyle is raw string for css. like background-color: black; This needed when you printscreen the element whithout background. So with this prop you can provide style for parent div.
  • fontFaceTemplate is template function for attaching fonts listed in fonts by default it looks like:
function createFontFace(fontCfg: FontCfg) {
  const { name, format, uri } = fontCfg;
  return `
        @font-face {
          font-family: "${name}";
          src: url(${uri}) format("${format}");
          font-weight: normal;
          font-style: normal;
        }
      `;
}

Usage

  • npm install @builat/printscreen
import logo from "./logo.svg";
import "./App.css";
import { printScreen } from "@builat/printscreen";

function appendImg(src) {
  const img = document.createElement("img");
  img.src = src;
  document.getElementById("root").appendChild(img);
}

function App() {
  return (
    <div className="App">
      <header className="App-header">
        <img src={logo} className="App-logo" alt="logo" />
        <p>
          Edit <code>src/App.js</code> and save to reload.
        </p>
        <a
          className="App-link"
          href="https://reactjs.org"
          target="_blank"
          rel="noopener noreferrer"
        >
          Learn React
        </a>
        <button onClick={() => printScreen("#root").then(appendImg)}>
          print screen
        </button>
      </header>
    </div>
  );
}

export default App;

Ok I want to convert function output to binary image. How?

const imageWithPrefix = await printScreen("#root");
const [prefix, base64Image] = imageWithPrefix.split(",");
const binaryImage = Buffer.from(base64Image, "base64");

About

SImple web printscreen util

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •