Skip to main content

Jupyter extensions to add nbgallery integration

Project description

Project Status: Active – The project has reached a stable, usable state and is being actively developed.

Overview

This package provides several Jupyter extensions to enable integration with nbgallery. More information is available here in the nbgallery github project.

Installation

This package contains UI extensions (nbextensions) for NBClassic only. The server extension was migrated to jupyterlab_nbgallery To install with pip:

pip install jupyter_nbgallery

As of version 2.0, the minimal set of extensions required for nbgallery integration will be automatically installed and enabled. This includes the post_hack server extension, the nbgallery environment registration UI extension, and the Gallery menu UI extension.

To enable the optional extensions:

# Enable all extensions
jupyter nbclassic-extension enable --sys-prefix --py jupyter_nbgallery

# Enable individual extensions
jupyter nbclassic-extension enable --sys-prefix --section tree jupyter_nbgallery/autodownload/autodownload
jupyter nbclassic-extension enable --sys-prefix --section notebook jupyter_nbgallery/easy_buttons/easy_buttons
jupyter nbclassic-extension enable --sys-prefix --section notebook jupyter_nbgallery/instrumentation/instrumentation

Jupyter configuration

Once the extension is installed, you will also need to modify your Jupyter configuration to interact with your nbgallery server.

First, your Jupyter instance needs to know about your nbgallery server in order to save notebooks, download preferences, etc. This is configured in nbconfig/common.json underneath one of Jupyter's configuration directories. You can use the included jupyter nbgallery script to set the location of your nbgallery, as well as the Jupyter client name that will appear in nbgallery's "Run in Jupyter" Environments page.

# Set nbgallery server location:
# jupyter nbgallery [--user|--system|--sys-prefix] configure url <nbgallery server address>
# Example:
jupyter nbgallery --sys-prefix configure url http://localhost:3000

# Set nbgallery environment client name
# Example:
jupyter nbgallery --sys-prefix configure client.name my-jupyter-instance

After configuration, nbconfig/common.json should look something like this (potentially with other unrelated sections):

{
  "nbgallery": {
    "url": "http://localhost:3000",
    "client": {
      "name": "my-jupyter-instance"
    }
  }
}

Second, in order for nbgallery's "Run in Jupyter" button to work, Jupyter must be configured to allow cross-site AJAX. Note these are security-relevant configuration settings. These can be set in jupyter_notebook_config.py:

c.NotebookApp.allow_origin = <URL of your nbgallery instance>`
c.NotebookApp.allow_credentials = True
c.NotebookApp.disable_check_xsrf = True

These can also be set on the command line when launching Jupyter; for example:

jupyter notebook --NotebookApp.allow_origin='http://localhost:3000' --NotebookApp.allow_credentials=True --NotebookApp.disable_check_xsrf=True

If you are launching jupyter lab instead of jupyter notebook, be aware that as of Lab 3.0, these are now ServerApp settings that can be set in jupyter_server_config.py (see the migration guide).

List of Extensions

UI Extensions (nbextensions)

Minimal Set

  • environment registers this Jupyter instance with nbgallery so notebooks can be launched with the "Run in Jupyter" button. It also downloads preferences stored in nbgallery.
  • gallery_menu adds the Gallery and Preferences menus to the Notebook interface. These are necessary for saving notebooks and preferences back to nbgallery.

Optional

Project details


Download files

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

Source Distribution

jupyter-nbgallery-3.0.0.tar.gz (79.5 kB view details)

Uploaded Source

Built Distribution

jupyter_nbgallery-3.0.0-py3-none-any.whl (158.3 kB view details)

Uploaded Python 3

File details

Details for the file jupyter-nbgallery-3.0.0.tar.gz.

File metadata

  • Download URL: jupyter-nbgallery-3.0.0.tar.gz
  • Upload date:
  • Size: 79.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for jupyter-nbgallery-3.0.0.tar.gz
Algorithm Hash digest
SHA256 00d4cda513611af9600d84b150dc91994d6a2fc05358888c7902d61c5dc9cd00
MD5 9d9c9a2667b1c958e0cc17850f084680
BLAKE2b-256 fc4f6e55adf00ef2abb75659172e3d610cc488ae51b7708463991a6ede3a8af7

See more details on using hashes here.

File details

Details for the file jupyter_nbgallery-3.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for jupyter_nbgallery-3.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b30fa3122d028f4d0446f0d3256b92b8b5bb2e36aab12c4e591b8179020fd197
MD5 93745a625385207632a95f89aee508bf
BLAKE2b-256 644ead8c0127ae617fa041b754c27aa74316091b9c439605344b913bc2ad7993

See more details on using hashes here.

Supported by

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