Includes two different side panels:
| JupyterLab version | Extension version |
|---|---|
| v4 | >=v4.0.0 |
| v3 | v2.0.0-v3.0.0 |
| v2 | v1.0.0 |
There are two ways to install the extension:
The extension is now available as a Python package on PyPI. You can install it with:
pip install apache-beam-jupyterlab-sidepanel
After installation, rebuild JupyterLab to activate the extension:
jupyter lab clean
jupyter lab build
Then restart JupyterLab. The side panels will be available automatically.
jupyter labextension install apache-beam-jupyterlab-sidepanel
This installs the extension using JupyterLab's legacy extension system.
Note: When creating a Python package, the module name (i.e., the folder name and import path) must use underscores (
_) instead of dashes (-). Dashes are not allowed in Python identifiers. However, the distribution name (the name used inpip install ...) can include dashes, and this is a common convention in the Python ecosystem. For example:
pip install apache-beam-jupyterlab-sidepanel✅import apache_beam_jupyterlab_sidepanel✅import apache-beam-jupyterlab-sidepanel❌ (invalid syntax)
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 apache-beam-jupyterlab-sidepanel directory # 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
Now every change will be built locally and bundled into JupyterLab. Be sure to refresh your browser page after saving file changes to reload the extension (note: you'll need to wait for webpack to finish, which can take 10s+ at times).
To run all tests, under apache-beam-jupyterlab-sidepanel directory, simply do:
# Make sure all dependencies are installed. jlpm # Run all tests. jlpm jest
This project uses ts-jest to test all ts/tsx files under src/__tests__ directory.
To run a single test, find out the name of a test in the source code that looks like:
it('does ABC', () => {...})
Then run:
jlpm jest -t 'does ABC'
The project uses prettier for formatting and eslint for lint. Prettier is configured as a plugin used by eslint. There are pre-configured yarn scripts to execute them.
# Under apache-beam-jupyterlab-sidepanel directory. # Make sure dependencies are installed. # Prettier and eslint are both installed as dev dependencies. jlpm # Check format and lint issues. jlpm eslint:check # Check then fix in place format and lint issues. jlpm eslint
This JupyterLab extension is distributed as a prebuilt Python package, and includes all necessary frontend assets (TypeScript-compiled JavaScript, styles, and metadata).
To build the extension locally and package it into a wheel:
# Ensure build dependencies are available pip install build jupyterlab jupyter_packaging hatch # Build the wheel and source tarball hatch build
This will generate dist/*.whl and dist/*.tar.gz files.
pip install .
After installation, JupyterLab will automatically discover and enable the extension. You can verify it was installed via:
jupyter labextension list
If properly installed, your extension should appear under the prebuilt extensions section.
A typical prebuilt extension should include the following structure under your Python package:
apache_beam_jupyterlab_sidepanel/
├── __init__.py
├── _version.py
└── labextension/
├── package.json
├── install.json
└── static/
└── ...
These will be copied to:
$PREFIX/share/jupyter/labextensions/apache-beam-jupyterlab-sidepanel/
jupyter labextension uninstall apache-beam-jupyterlab-sidepanel
or
pip uninstall apache-beam-jupyterlab-sidepanel