Skip to content

Latest commit

 

History

History
33 lines (26 loc) · 1.97 KB

README.md

File metadata and controls

33 lines (26 loc) · 1.97 KB

HTML-to-Image

This is a simple node service that can be passed an HTML string via a post request, and return a link to an image hosted on this server.

Example set-up building Docker image from local:

  • docker build -t <yournamespace>/html-to-image .
  • docker images
  • docker run -p 8080:8080 -d jonforest/html-to-image Or, you can share a volume so that your original web-site can server the images directly
  • docker run -p 8080:8080 -d -v /var/www/html/assets/thumbnails:/usr/src/app/public jonforest/html-to-image

Trouble-shooting tips

Example for running locally

  • npm install
  • node app.js

Example usage

  • curl --data "html=<p>hello world</p>" http://localhost:8080/make-image
  • Browse to http://localhost:8080/4118204522.png to see the image

Important notes:

  • The html sent in the data must not be multi-part, so you will almost certainly need to urlencode the string before sending

  • The underlying library used for converting the html into an image does not support changing the size of the image, so you'll always get a 1280 x 800 image.

    • If you're using the output to populate an tag in your html, then I'd add a class with max-width/height and overflow: hidden to a surrounding div in order to make the page flow correctly. The extra image is all transparent pixels, so the larger dimensions have minimal impact on the file size.
    • It's hacky, I'm sorry, and if I have a need I'll try to find a replacement library, the first version of this is written in a rush.

    TODO:

    • Allow port number to be set as an environment variable
    • Change the underlying library to support modifying the image size