Skip to main content

Submit ballet modules from within JupyterLab

Project description

Github Actions Status PyPI Shield npm version

Assemblé

A development environment for Ballet collaborations on top of Jupyter Lab

Using Assemblé, you can develop patches for Ballet projects within Jupyter Lab and then easily submit them as GitHub Pull Requests (PRs) in one click without leaving your notebook.

Assemblé (pronounced "assam blay") is a ballet move that involves lifting off the floor on one leg and landing on two.

Assemblé is composed of (1) a Python package named ballet_assemble for the server extension (2) a NPM package also named ballet-assemble for the frontend extension and (3) tight integration with Binder for each Ballet project.

Requirements

  • JupyterLab >= 2.0

Install

Installation can be done completely using pip, which installs both the server and the frontend extensions. The frontend extension only can be installed using jupyter labextension install but will not function properly without the corresponding server extension.

pip install ballet_assemble
jupyter lab build

Note: You will need NodeJS to install the extension; the installation process will complain if it is not found.

Authenticate with GitHub

The extension provides an in-Lab experience for authenticating with GitHub. When you open a notebook, you should see the GitHub icon to the right on the Notebook toolbar. The icon should be grey at first, indicating you are not authenticated. Click the icon to open a login window, in which you can enter your GitHub username and password. These will be exchanged by the extension for an OAuth token and will be used to propose changes to the upstream Ballet project on your behalf (if you attempt to submit features).

Authenticate with GitHub

Alternately, you can provide a personal access token directly using the configuration approaches below.

Configure

The extension ties into the same configuration system as Jupyter [Lab] itself. You can configure the extension with command line arguments or via the config file, just like you configure Jupyter Notebook or Jupyter Lab.

All configuration options

The following configuration options are available:

$ python -c 'from ballet_assemble.app import print_help;print_help()'

AssembleApp options
-----------------
--AssembleApp.access_token_timeout=<Int>
    Default: 60
    timeout to receive access token from server via polling
--AssembleApp.ballet_yml_path=<Unicode>
    Default: ''
    path to ballet.yml file of Ballet project (if Lab is not run from project
    directory)
--AssembleApp.debug=<Bool>
    Default: False
    enable debug mode (no changes made on GitHub), will read from
    $ASSEMBLE_DEBUG if present
--AssembleApp.github_token=<Unicode>
    Default: ''
    github access token, will read from $GITHUB_TOKEN if present
--AssembleApp.oauth_gateway_url=<Unicode>
    Default: 'https://github-oauth-gateway.herokuapp.com/'
    url to github-oauth-gateway server

Command line arguments

Invoke Jupyter Lab with command line arguments providing config to the ballet extension, for example:

jupyter lab --AssembleApp.debug=True

Config file

  1. Determine the path to your jupyter config file (you may have to create it if it does not exist):

    touch "$(jupyter --config-dir)/jupyter_notebook_config.py"
    
  2. Append desired config to the end of the file, for example:

    c.AssembleApp.debug = True
    

Troubleshoot

If you are see the frontend extension but it is not working, check that the server extension is enabled:

jupyter serverextension list

If the server extension is installed and enabled but your not seeing the frontend, check the frontend is installed:

jupyter labextension list

If it is installed, try:

jupyter lab clean
jupyter lab build

Contributing

Development Install

The jlpm command is JupyterLab's pinned version of yarn that is installed with JupyterLab. You may use yarn or npm in lieu of jlpm below.

# Clone the repo to your local environment
# Move to ballet-assemble directory
# Install server extension
pip install -e .
# Register server extension
jupyter serverextension enable --py ballet_assemble
# Install dependencies
jlpm
# Build Typescript source
jlpm build
# Link your development version of the extension with JupyterLab
jupyter labextension link .

# Rebuild Typescript source after making changes
jlpm build
# Rebuild JupyterLab after making any changes
jupyter lab build

You can watch the source directory and run JupyterLab in watch mode to watch for changes in the extension's source and automatically rebuild the extension and application.

# Watch the source directory in another terminal tab
jlpm watch
# Run jupyterlab in watch mode in one terminal tab
jupyter lab --watch

Uninstall

pip uninstall ballet_assemble
jupyter labextension uninstall ballet-assemble

Release process

bumpversion <part>
make release

Credits

Contributors

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

ballet-assemble-0.8.8.tar.gz (25.6 kB view details)

Uploaded Source

Built Distribution

ballet_assemble-0.8.8-py3-none-any.whl (19.2 kB view details)

Uploaded Python 3

File details

Details for the file ballet-assemble-0.8.8.tar.gz.

File metadata

  • Download URL: ballet-assemble-0.8.8.tar.gz
  • Upload date:
  • Size: 25.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/52.0.0 requests-toolbelt/0.9.1 tqdm/4.57.0 CPython/3.8.3

File hashes

Hashes for ballet-assemble-0.8.8.tar.gz
Algorithm Hash digest
SHA256 3c26ca2110032a69c9a5c4a3c73d2f59e8d3e3fd2cb3e3bdfe4f8e6118137976
MD5 33258a815d4b48b2fd875a20f343a687
BLAKE2b-256 b3ff5322aba431f7b2ff7399391c1a876ef3ca3cb2f92d6577195f4f2ce108c9

See more details on using hashes here.

File details

Details for the file ballet_assemble-0.8.8-py3-none-any.whl.

File metadata

  • Download URL: ballet_assemble-0.8.8-py3-none-any.whl
  • Upload date:
  • Size: 19.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/52.0.0 requests-toolbelt/0.9.1 tqdm/4.57.0 CPython/3.8.3

File hashes

Hashes for ballet_assemble-0.8.8-py3-none-any.whl
Algorithm Hash digest
SHA256 3ca6e9dedc6c5566f2c3d2e8180d81036b0ade7f883ed27f521c5d285f277270
MD5 ed292b110163533397805f7b5387219d
BLAKE2b-256 4bebe966a44445710622624d88aa789bd9c65f95d83f0f13588f2666cd3d0e52

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