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.
Package | Version | Description |
---|---|---|
@datalayer/jupyter-react | Core React components for Jupyter integration | |
@datalayer/jupyter-lexical | Rich text editor with Lexical framework | |
@datalayer/jupyter-docusaurus-plugin | Docusaurus plugin for Jupyter notebooks | |
datalayer-jupyter-vscode | VS Code extension |
npm install @datalayer/jupyter-react
import { Jupyter, Notebook } from '@datalayer/jupyter-react';
function App() {
return (
<Jupyter
jupyterServerUrl="http://localhost:8686"
jupyterServerToken="your-token"
startDefaultKernel
>
<Notebook />
</Jupyter>
);
}
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
You can try the CodeSandbox examples:
- Notebook with Create React App
- Notebook with Next.js
- Simple Cell Component - You may need to refresh the sandbox navigator
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.
- ๐ 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
- ๐ 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
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.
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).
Full server-side rendering support with the Next.js example.
We maintain a plugin for Docusaurus in the docusaurus-plugin package (see the Docusaurus example).
- 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)
- Node.js >= 18.0.0
- npm >= 8.0.0
- Python >= 3.8 (for Jupyter server)
- JupyterLab >= 4.0.0
We welcome contributions! Please see our Contributing Guide for details.
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature
) - Make your changes
- Run tests (
npm test
) - Run code quality checks (
npm run check
) - Commit your changes (
git commit -m 'Add amazing feature'
) - Push to your branch (
git push origin feature/amazing-feature
) - Open a Pull Request
- 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
- ๐ Documentation
- ๐ Issues
- ๐ก Discussions
- ๐จ Storybook
Copyright (c) 2022-2025 Datalayer, Inc.
Released under the terms of the MIT license (see LICENSE).