Skip to content

datalayer/jupyter-ui

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

Datalayer

Become a Sponsor

๐Ÿช โš›๏ธ Jupyter UI

Build Status npm version License TypeScript React

React.js components ๐Ÿ’ฏ% compatible with ๐Ÿช Jupyter.

Documentation: https://jupyter-ui.datalayer.tech

Storybook: https://jupyter-ui-storybook.datalayer.tech

Jupyter UI is a set of React.js components that allow a frontend/webapp developer to build data products compatible with the Jupyter ecosystem. The user interface delivers executable notebooks, cells, terminals, file browsers and allows the developer to manage a full integrated React tree instead of relying on iframes to display the Jupyter notebooks.

๐Ÿ“ฆ Packages

Package Version Description
@datalayer/jupyter-react npm Core React components for Jupyter integration
@datalayer/jupyter-lexical npm Rich text editor with Lexical framework
@datalayer/jupyter-docusaurus-plugin npm Docusaurus plugin for Jupyter notebooks
datalayer-jupyter-vscode marketplace VS Code extension

๐Ÿš€ Quick Start

Installation

npm install @datalayer/jupyter-react

Basic Usage

import { Jupyter, Notebook } from '@datalayer/jupyter-react';

function App() {
  return (
    <Jupyter
      jupyterServerUrl="http://localhost:8686"
      jupyterServerToken="your-token"
      startDefaultKernel
    >
      <Notebook />
    </Jupyter>
  );
}

Development Setup

As a developer start with the setup of your environment and try one of the examples. We have documentation for more details.

# Clone the repository
git clone https://github.com/datalayer/jupyter-ui.git
cd jupyter-ui

# Install dependencies
npm install

# Build all packages
npm run build

# Start Jupyter server (required for development)
npm run jupyter:server

# Run an example
npm run jupyter:ui:vite

๐ŸŽฎ Try It Online

You can try the CodeSandbox examples:

We host a Storybook on โœจ https://jupyter-ui-storybook.datalayer.tech that showcases various low-level and high-level React.js components useful to build a Data Product.

โœจ Features

Core Components

  • ๐Ÿ““ Notebook - Full notebook interface with cells, outputs, and toolbar
  • ๐Ÿ“ Cell - Individual code/markdown cells with execution
  • ๐Ÿ’ป Console - Interactive Jupyter console
  • ๐Ÿ–ฅ๏ธ Terminal - Web-based terminal interface
  • ๐Ÿ“ FileBrowser - File system navigation and management
  • โš™๏ธ Kernel Management - Kernel lifecycle and execution control
  • ๐Ÿ“Š Output Rendering - Display of execution results, plots, and widgets

Advanced Features

  • ๐Ÿ”Œ IPyWidgets Support - Full support for interactive widgets
  • ๐Ÿ‘ฅ Collaborative Editing - Real-time collaboration using Y.js
  • ๐ŸŽจ Theming - JupyterLab theme support with dark/light modes
  • ๐Ÿ”ง Extensible - Plugin system for custom functionality
  • ๐Ÿš€ Performance - Virtual scrolling, lazy loading, and optimizations
  • ๐Ÿ”’ Security - Token authentication, CORS, XSS protection
Jupyter UI Gallery

The above image shows a gallery of the available React.js components ready to be used in you custom application. These open source components are used to build Datalayer, a collaborative platform for data analysis.

Why?

The Jupyter(Lab) notebook is a tool that allows data scientist to analyse dataset. However, it is not easy to create a custom user interface integrated in an existing application. Jupyter UI, an open-source library, fills that gap and provides components that a developer can easily integrate in any React.js application.

The Jupyter(Lab) user interface is built on top of Lumino widget toolkit, an imperative way to build user interface and can not be consumed by industry standard declarative frameworks like React.js. As a user interface developer, if you want to create a custom data product on top of Jupyter, you have to stick to Lumino and carry-on the full notebook interface not tailored to your specific needs. This is not what you want. You just want to expose what you need, you want to develop with your favorite toolkit (like React.js) and you also want to integrate on a per-component basis the Jupyter functionality in your application.

We also aim removing the rigidity of the extension system and favor composition over inheritance.

IPyWidgets are supported (the Comm feature needs to be fixed). JupyterLite and PyScript support is on the roadmap. Autocompletion is also available.

You can find more context reading this abstract of the talk given at FOSDEM 2022 (video recording).

๐Ÿ”— Framework Integrations

Next.js

Full server-side rendering support with the Next.js example.

Jupyter UI Next.js

Docusaurus

We maintain a plugin for Docusaurus in the docusaurus-plugin package (see the Docusaurus example).

Jupyter UI Docusaurus

Other Integrations

  • Vite - Modern build tool integration (example)
  • Create React App - Classic React app setup
  • Lexical - Rich text editing capabilities (example)
  • VS Code - Extension for notebook editing (package)

๐Ÿ“‹ Requirements

  • Node.js >= 18.0.0
  • npm >= 8.0.0
  • Python >= 3.8 (for Jupyter server)
  • JupyterLab >= 4.0.0

๐Ÿค Contributing

We welcome contributions! Please see our Contributing Guide for details.

Development Workflow

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Make your changes
  4. Run tests (npm test)
  5. Run code quality checks (npm run check)
  6. Commit your changes (git commit -m 'Add amazing feature')
  7. Push to your branch (git push origin feature/amazing-feature)
  8. Open a Pull Request

Code Quality

  • TypeScript - Strict type checking enabled
  • ESLint - Modern flat config with React and TypeScript rules
  • Prettier - Consistent code formatting
  • Husky - Pre-commit hooks for quality checks
  • Commitlint - Conventional commit messages

Run all checks with a single command:

npm run check        # Run format check, lint, and type-check
npm run check:fix    # Run format, lint fix, and type-check

๐Ÿ’ฌ Support

โš–๏ธ License

Copyright (c) 2022-2025 Datalayer, Inc.

Released under the terms of the MIT license (see LICENSE).

Sponsor this project

 

Contributors 18