Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

⚛️ React.js components 💯% compatible with 🪐 Jupyter.

License

NotificationsYou must be signed in to change notification settings

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 Statusnpm versionLicenseTypeScriptReact

React.js components 💯% compatible with 🪐 Jupyter.

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

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

Jupyter UI is a set ofReact.js components that allow a frontend/webapp developer to build data products compatible with theJupyter 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

PackageVersionDescription
@datalayer/jupyter-reactnpmGeneric React components for Jupyter
@datalayer/jupyter-lexicalnpmRich text editor with Lexical framework
@datalayer/jupyter-docusaurus-pluginnpmDocusaurus plugin for Jupyter notebooks
datalayer-jupyter-vscodemarketplaceVS Code extension

🚀 Quick Start

Installation

npm install @datalayer/jupyter-react

Basic Usage

import{JupyterReactTheme,Notebook}from'@datalayer/jupyter-react';functionApp(){return(<JupyterReactTheme><Notebookpath="notebook.ipynb"id="notebook-id"startDefaultKernel/></JupyterReactTheme>);}

Collaborative Editing

Jupyter UI supports real-time collaboration through a pluggable provider system:

import{Notebook,JupyterCollaborationProvider,}from'@datalayer/jupyter-react';functionCollaborativeNotebook(){constcollaborationProvider=newJupyterCollaborationProvider();return(<Notebookpath="notebook.ipynb"collaborationProvider={collaborationProvider}/>);}

Creating Custom Collaboration Providers

You can create your own collaboration provider by extendingCollaborationProviderBase:

import{CollaborationProviderBase}from'@datalayer/jupyter-react';classMyCustomProviderextendsCollaborationProviderBase{constructor(config){super('my-provider-type');// Initialize your provider}asyncconnect(sharedModel,documentId,options){// Implement your connection logic// Set up WebSocket, authenticate, etc.}}// Use it with any Notebook componentconstprovider=newMyCustomProvider({/* config */});<NotebookcollaborationProvider={provider}path="notebook.ipynb"/>;

Development Setup

As a developer start with thesetup of your environment and tryone of the examples. We havedocumentation for more details.

# Clone the repositorygit clone https://github.com/datalayer/jupyter-ui.gitcd jupyter-ui# Install dependenciesnpm install# Build all packagesnpm run build# Start Jupyter server (required for development)npm run jupyter:server# Run an examplenpm 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 - Pluggable provider system supporting:
    • Jupyter collaboration (WebSocket-based with Y.js)
    • Custom providers viaICollaborationProvider interface
  • 🎨 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

Architecture Highlights

  • 🏗️ Clean Architecture - Modular, composable components with clear interfaces
  • 🔄 Composition Pattern - Components compose rather than inherit for maximum flexibility
  • 🔌 Provider System - Pluggable collaboration providers for different backends
  • 📦 One-way Dependencies - Core depends on jupyter-react, not vice versa
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 buildDatalayer, 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 andcan 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 favorcomposition 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 thisabstract of the talk given atFOSDEM 2022 (video recording).

🔗 Framework Integrations

Next.js

Full server-side rendering support with theNext.js example.

Jupyter UI Next.js

Docusaurus

We maintain a plugin forDocusaurus in thedocusaurus-plugin package (see theDocusaurus 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 >= 20.0.0
  • npm >= 8.0.0
  • Python >= 3.8 (for Jupyter server)
  • JupyterLab >= 4.0.0

🤝 Contributing

We welcome contributions! Please see ourContributing 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-checknpm 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 (seeLICENSE).

Sponsor this project

 

Contributors20


[8]ページ先頭

©2009-2025 Movatter.jp