Rendering of live Jupyter notebooks with interactive widgets.
Run Fork on MyBinder
https://mybinder.org/v2/gh/ismms-himc/voila/stable?urlpath=voila%2Ftree%2Fnotebooks
Introduction
Voila serves live Jupyter notebook including Jupyter interactive widgets.
Unlike the usual HTML-converted notebooks, each user connecting to the Voila tornado application gets a dedicated Jupyter kernel which can execute the callbacks to changes in Jupyter interactive widgets.
- By default, voila disallows execute requests from the front-end, preventing execution of arbitrary code.
- By defaults, voila runs with the
strip_source
option, which strips out the input cells from the rendered notebook.
Installation
Voila can be installed with the conda package manager
conda install -c conda-forge voila
or from pypi
pip install voila
JupyterLab preview extension
Voila provides a JupyterLab extension that displays a Voila preview of your Notebook in a side-pane:
jupyter labextension install @jupyter-voila/jupyterlab-preview
Usage
As a standalone tornado application
To render the bqplot
example notebook as a standalone app, run
voila bqplot.ipynb
.
To serve a directory of jupyter notebooks, run voila
with no argument.
For example, to render the example notebook bqplot.ipynb
from this repository with voila, you can first update your current environment with the requirements of this notebook (in this case in a conda environment and render the notebook with
conda env update -f environment.yml
cd notebooks/
voila bqplot.ipynb
For more command line options (e.g., to specify an alternate port number),
run voila --help
.
notebook
or jupyter_server
As a server extension to Voila can also be used as a notebook server extension, both with the notebook server or with jupyter_server.
To install the notebook server extension, run
jupyter serverextension enable voila --sys-prefix
When running the notebook server, the voila app is accessible from the base url
suffixed with voila
.
Examples
The following two examples show how a standalone Jupyter notebook can be turned into a separate app, from the command-line integration.
Rendering a notebook including interactive widgets and rich mime-type rendering
Rendering a notebook making use of a custom widget library (bqplot)
Showing the source code for a voila notebook
The sources of the Jupyter notebook can be displayed in a voila app if option strip_sources
is set to False
.
Voila dashboards with other language kernels
Voila is built upon Jupyter standard formats and protocols, and is agnostic to the programming language of the notebook. In this example, we present an example of a voila application powered by the C++ Jupyter kernel xeus-cling, and the xleaflet project.
Development
See CONTRIBUTING.md to know how to contribute and setup a development environment.
Related projects
Voila depends on nbconvert and jupyter_server.
License
We use a shared copyright model that enables all contributors to maintain the copyright on their contributions.
This software is licensed under the BSD-3-Clause license. See the LICENSE file for details.