Skip to main content

Streamlit component for PDF visualisation and manipulation

Project description

License PyPI version Downloads Build Coverage Status

streamlit-pdf-viewer

Streamlit component that allows the visualisation and enrichment of PDF documents. You can see an application in action here.

Features

  • Show PDF files in a Streamlit application with a simple command
  • Based on the pdf.js library
  • Visualize annotations on top of the PDF documents
  • Render text on top of the PDF document, allowing copy-paste
  • Allow rendering specific pages of the PDF document
  • Scroll to a specific page
  • Scroll to a specific annotation
  • Allow custom callbacks when an annotation is clicked
  • Interactive zoom controls with multiple zoom options
  • Configurable alignment of the PDF viewer within its container
  • Optional horizontal separators between PDF pages
  • Version 0.0.x provides an additional "legacy" viewer using the native pdf.js browser's, with limitations including no annotations, no scrolling - this is removed from version 0.1.x.

Limitations

  • Tested and developed to support Firefox and Chrome.
  • The legacy visualization works only on Firefox and does not support annotations
  • This is a side project, so all troubleshooting may take time
  • The component is still in development, so expect some bugs and limitations
  • The streamlit reload at each action may render slowly for complex PDF documents

Caveats

Here are some caveats to be aware of:

  • It is mandatory to specify a width to show PDF document on tabs and expanders, otherwise, the viewer will not be displayed on tabs not immediately visible.
  • From version 0.0.16, the behavior for managing width and height has changed:
    • If only the height is specified, the PDF document will be shown in proportion with the with proportional based on the PDF dimensions.
    • The possibility to show a large view of half the PDF is not available anymore (let's face it, it was not very useful).
    • If you need to use all the available space and limit the height, you can encapsulate the pdf_viewer() into a st.component(width:...) setting the width.
  • The legacy rendering has been removed from version 0.1.x+

Getting started

pip install streamlit-pdf-viewer

In your streamlit application, you can use it as:

import streamlit as st
from streamlit_pdf_viewer import pdf_viewer

pdf_viewer("str, path or bytes")

You can also customize the viewer with additional options:

import streamlit as st
from streamlit_pdf_viewer import pdf_viewer

# Display PDF with custom zoom, alignment, and separators
pdf_viewer(
    "path/to/your/document.pdf",
    width=700,
    height=1000,
    zoom_level=1.2,                    # 120% zoom
    viewer_align="center",             # Center alignment
    show_page_separator=True           # Show separators between pages
)

Params

In the following table the list of parameters that can be provided to the pdf_viewer function:

name description
input The source of the PDF file. Accepts a file path or binary data.
width Width of the PDF viewer in pixels. It defaults to 700 pixels. It supports both integer (pixel, e.g. 700) and string (percentages, e.g. 90% will make the pdf render to 90% of the container/window/screen width. If the pdf width is larger than the screen width, it will horizontally scroll).
height Height of the PDF viewer in pixels. If not provided, the viewer shows the whole content.
annotations A list of annotations to be overlaid on the PDF. Format is described here.
pages_vertical_spacing The vertical space (in pixels) between each page of the PDF. Defaults to 2 pixels.
annotation_outline_size Size of the outline around each annotation in pixels. Defaults to 1 pixel.
pages_to_render Filter the rendering to a specific set of pages. By default, all pages are rendered.
render_text Enable a layer of text on top of the PDF document. The text may be selected and copied. NOTE to avoid breaking existing deployments, we made this optional at first, also considering that having many annotations might interfere with the copy-paste.
zoom_level The zoom level of the PDF viewer. Can be a float (0.1-10.0), "auto" for fit-to-width, "auto-height" for fit-to-height, or None (defaults to auto-fit to width). When zoom controls are enabled, users can interactively adjust the zoom level.
viewer_align The alignment of the PDF viewer within its container. Can be "center" (default), "left", or "right".
show_page_separator Whether to show a horizontal separator line between PDF pages. Defaults to True.
scroll_to_page Scroll to a specific page when the component is rendered. The parameter is an integer, which represent the positional value of the page. E.g. 1, will be the first page. Default is None. Require ints and ignores the parameters below zero.
scroll_to_annotation Scroll to a specific annotation when the component is rendered. The parameter is an integer, which represent the positional value of the annotation. E.g. 1, will be the first annotation. Default is None (don't scroll). Mutually exclusive with scroll_to_page. Raise an exception if used with scroll_to_page
on_annotation_click Callback function that is called when an annotation is clicked. The function receives the annotation as a parameter.

Annotation format

The annotation format has been derived from the Grobid's coordinate formats, which are described as a list of "bounding boxes". The annotations are expressed as a dictionary of six elements; the page, x and y indicate the top left point. The color can be expressed following the HTML CSS convention. The border style also follow the HTML conventions limited to these values: solid, dashed, dotted, double, groove, ridge, inset, outset. Any other value will result in the default value: solid.

Annotation unique identifiers are expressed by the id field, if id is not specified, an identifier will be generated during rendering. Furthermore, the HTML identifier will be generated as #annotation-{annotation.id}.

Here is an example:

[
  {
    "page": 1,
    "x": 220,
    "y": 155,
    "height": 22,
    "width": 65,
    "color": "red",
    "border": "solid"
  },
[...]

The example shown in our screenshot can be found here.

Custom callback for clicking on annotations

from streamlit_pdf_viewer import pdf_viewer

annotations = [
    {
        "page": 1,
        "x": 220,
        "y": 155,
        "height": 22,
        "width": 65,
        "color": "red"
    },
    {
        "page": 1,
        "x": 220,
        "y": 155,
        "height": 22,
        "width": 65,
        "color": "red",
        "border": "dotted"
    }
]


def my_custom_annotation_handler(annotation):
    print(f"Annotation {annotation} clicked.")


pdf_viewer(
    "path/to/pdf",
    on_annotation_click=my_custom_annotation_handler,
    annotations=annotations
)

Developers notes

Environment

  • Python >= 3.8
  • Node.js >= 16
  • Streamlit >= 1.28.2

Configure environment for development

First, make sure that _RELEASE = False in streamlit_pdf_viewer/__init__.py. To run the component in development mode, use the following commands:

streamlit run streamlit_pdf_viewer/__init__.py

cd frontend
npm run serve

These commands will start the Streamlit application and serve the Node.js component. Please make sure you're in the correct directory before running these commands.

Integrate into a streamlit application

  1. Build the frontend part:

    cd frontend
    export NODE_OPTIONS=--openssl-legacy-provider
    npm run build 
    
  2. Make sure that _RELEASE = True in streamlit_pdf_viewer/__init__.py.

  3. move to the streamlit_application and run

    pip install -e {path of component}
    

Release

bump-my-version bump patch | minor | major
git push
git push --tags 

Acknowledgement

The project was initiated by Luca Foppiano at the National Institute for Materials Science (NIMS) in Japan. Currently, the development is possible thanks to ScienciLAB.

Main contacts: Luca Foppiano and Tomoya Mato.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

streamlit_pdf_viewer-0.0.27.tar.gz (2.3 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

streamlit_pdf_viewer-0.0.27-py3-none-any.whl (2.3 MB view details)

Uploaded Python 3

File details

Details for the file streamlit_pdf_viewer-0.0.27.tar.gz.

File metadata

  • Download URL: streamlit_pdf_viewer-0.0.27.tar.gz
  • Upload date:
  • Size: 2.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for streamlit_pdf_viewer-0.0.27.tar.gz
Algorithm Hash digest
SHA256 72985d30cac26650e126f31270ed3e8aa7ee87f277464271e0c323208c856a37
MD5 a601763cdf823f6d33b3cdeb52129d4a
BLAKE2b-256 e52259f714ab28357ce29eac8f61295d36f334e49849bd42db3c6faa55073087

See more details on using hashes here.

File details

Details for the file streamlit_pdf_viewer-0.0.27-py3-none-any.whl.

File metadata

File hashes

Hashes for streamlit_pdf_viewer-0.0.27-py3-none-any.whl
Algorithm Hash digest
SHA256 e10bb1cfe8e7e7fd6dd0b095e0422555d82537b7abe0cbcddf29533f3382933f
MD5 e767ba1f6538e222306a246d835b64dc
BLAKE2b-256 3ed7e89f9b86d1da41b9151d8b58761ef8c73994225fe091aa64b65056167d98

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page