A Jupyter extensions that turns notebooks into web applications, with modifications for AiiDA lab.
Project description
Appmode
A Jupyter extensions that turns notebooks into web applications.
Try it live
Click the binder badge to try it live without installing anything. This will take you directly to the "app" version of the notebook.
Installation
If you use conda
, you can install it as:
conda install --channel conda-forge appmode
If you use pip
, you can install it as:
pip install appmode
jupyter nbextension enable --py --sys-prefix appmode
jupyter serverextension enable --py --sys-prefix appmode
If you want to use mybinder add the following environment.yml
file to your repository:
channels:
- conda-forge
dependencies:
- appmode
Description
Appmode consist of a server-side and a notebook extension for Jupyter. Together these two extensions provide the following features:
-
One can view any notebook in appmode by clicking on the Appmode button in the toolbar. Alternatively one can change the url from
baseurl/notebooks/foo.ipynb
tobaseurl/apps/foo.ipynb
. This also allows for direct links into appmode. -
When a notebook is opened in appmode, all code cells are automatically executed. In order to present a clean UI, all code cells are hidden and the markdown cells are read-only.
-
A notebook can be opened multiple times in appmode without interference. This is achieved by creating temporary copies of the notebook for each active appmode view. Each appmode view has its dedicated ipython kernel. When an appmode page is closed the kernel is shutdown and the temporary copy gets removed.
-
To allow for passing information between notebooks via url parameters, the current url is injected into the variable
jupyter_notebook_url
.
Server Side Configuration
Appmode adds the following configuration options:
Appmode.trusted_path
Run only notebooks below this path in Appmode. Default: No restrictions.Appmode.show_edit_button
Show Edit App button during Appmode. Default: True.Appmode.show_other_buttons
Show other buttons, e.g. Logout, during Appmode. Default: True.
Client Side Customization
The UI elements of Appmode can be customized via the custom.js file. Some examples are:
$('#appmode-leave').hide(); // Hides the edit app button.
$('#appmode-busy').hide(); // Hides the kernel busy indicator.
$('#appmode-loader').append('<h2>Loading...</h2>'); // Adds a loading message.
Beware that hiding the edit button does not prevent users from leaving Appmode by changing the URL manually.
Development
With the included Dockerfile a development environment can be quickly created:
- Install Docker.
- git clone this repository
docker build --tag appmode_dev ./
docker run --init -ti -p8888:8888 appmode_dev
- Browse to
http://localhost:8888/apps/example_app.ipynb
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
Built Distribution
File details
Details for the file appmode-aiidalab-0.5.0.1.tar.gz
.
File metadata
- Download URL: appmode-aiidalab-0.5.0.1.tar.gz
- Upload date:
- Size: 13.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/2.7.15rc1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 74a9fd486acfe9729a39d0c5172f8e8deb0082ff9199321db1d737a96ea6e9fc |
|
MD5 | e6f0e30e7bbbd375588bff99fd3aaa57 |
|
BLAKE2b-256 | 11ce93352bb90889a4fdc65e19886367ad1665f757c8ff6695e18a275038b76f |
File details
Details for the file appmode_aiidalab-0.5.0.1-py2-none-any.whl
.
File metadata
- Download URL: appmode_aiidalab-0.5.0.1-py2-none-any.whl
- Upload date:
- Size: 22.1 kB
- Tags: Python 2
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/2.7.15rc1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f8668e2f639560a4bc023a742a7fae78a7b297eac3c1e3dbe0cabe9299288ad7 |
|
MD5 | c6c30f526d79ea9df8bda32ed66768e5 |
|
BLAKE2b-256 | 590634c7e9fc86f9917bdc392f0831b7fda85d25360afe3281deb4db89dd6f85 |