Skip to main content

An arctic, north-bluish clean and elegant JupyterLab theme based on the Nord color palette

Project description

JupyterLab Nord Theme

An arctic, north-bluish clean and elegant JupyterLab theme based on the Nord color palette.

JupyterLab version PyPI License

Features

  • Nord Color Palette: Authentic implementation of the 16-color Nord palette
  • Dark Theme: Designed for comfortable coding in low-light environments
  • Complete Coverage: Themes all JupyterLab components including notebooks, file browser, terminals, and settings
  • Syntax Highlighting: Beautiful Nord-based syntax highlighting for code cells
  • Perfect Compatibility: Built using JupyterLab 4.0+ CSS variable system for full compatibility
  • Font Scaling Support: Respects JupyterLab's font scaling settings
  • Layout Preservation: Uses exact default theme layout and sizing, only changes colors

Color Palette

This theme uses the official Nord color palette:

Polar Night (Dark Backgrounds)

  • nord0 - #2e3440 - Darkest background
  • nord1 - #3b4252 - Dark background
  • nord2 - #434c5e - Medium background
  • nord3 - #4c566a - Light background

Snow Storm (Light Text)

  • nord4 - #d8dee9 - Dark foreground
  • nord5 - #e5e9f0 - Medium foreground
  • nord6 - #eceff4 - Light foreground

Frost (Blue Accents)

  • nord7 - #8fbcbb - Calm accent
  • nord8 - #88c0d0 - Bright accent
  • nord9 - #81a1c1 - Medium accent
  • nord10 - #5e81ac - Dark accent

Aurora (Vibrant Colors)

  • nord11 - #bf616a - Red (errors)
  • nord12 - #d08770 - Orange
  • nord13 - #ebcb8b - Yellow (warnings)
  • nord14 - #a3be8c - Green (success)
  • nord15 - #b48ead - Purple

Installation

From PyPI (Recommended)

pip install jupyterlab-nord-theme

From Source

# Clone the repository
git clone https://github.com/carlyou/jupyter-nord-theme.git
cd jupyter-nord-theme

# Install in development mode
pip install -e .

Usage

  1. Install the extension using one of the methods above
  2. Launch JupyterLab: jupyter lab
  3. Go to SettingsThemeNord Theme
  4. The theme will be applied immediately

Development

Requirements

  • Python >= 3.8
  • Node.js >= 16
  • JupyterLab >= 4.0

Setup Development Environment

# Clone the repository
git clone https://github.com/carlyou/jupyter-nord-theme.git
cd jupyter-nord-theme

# Install Python dependencies
pip install -e .

# Install Node.js dependencies
npm install

# Build in development mode
npm run build

# Install for development
jupyter labextension develop . --overwrite

Making Changes

  1. Edit CSS variables in style/index.css
  2. Modify TypeScript registration in src/index.ts
  3. Rebuild: npm run build
  4. Refresh JupyterLab to see changes

Project Structure

jupyter-nord-theme/
├── src/                    # TypeScript source code
│   └── index.ts           # Extension registration
├── style/                 # CSS theme files
│   ├── index.css         # Main theme CSS with Nord variables
│   └── index.js          # Style module entry point
├── jupyterlab_nord_theme/ # Python package
│   ├── __init__.py       # Extension metadata
│   └── labextension/     # Built extension files
├── package.json          # Node.js configuration
├── pyproject.toml        # Python packaging configuration
├── tsconfig.json         # TypeScript configuration
└── README.md            # This file

Building for Production

# Clean previous builds
npm run clean:all

# Build production version
npm run build:prod

Publishing

PyPI

# Build package
pip install build
python -m build

# Upload to PyPI
pip install twine
twine upload dist/*

npm (for developers)

npm publish

Contributing

Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.

Guidelines

  • Follow the existing code style
  • Test your changes thoroughly
  • Update documentation as needed
  • Add appropriate commit messages

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgments

  • Nord Theme by Arctic Ice Studio for the beautiful color palette
  • JupyterLab team for the excellent extension system
  • The JupyterLab community for inspiration and best practices

Related Projects

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

jupyterlab_nord_theme-0.1.0.tar.gz (85.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

jupyterlab_nord_theme-0.1.0-py3-none-any.whl (25.5 kB view details)

Uploaded Python 3

File details

Details for the file jupyterlab_nord_theme-0.1.0.tar.gz.

File metadata

  • Download URL: jupyterlab_nord_theme-0.1.0.tar.gz
  • Upload date:
  • Size: 85.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for jupyterlab_nord_theme-0.1.0.tar.gz
Algorithm Hash digest
SHA256 4b8417a57754cd71b4ccc065f424ef15736ced4b5d6a27b1d7af01d4fe1f9814
MD5 78f5de9485a3d17c22847a923e211f20
BLAKE2b-256 421efc5ecbc41ef7883b30af59c7255b5482304b44b3be2e468f0acc31857844

See more details on using hashes here.

File details

Details for the file jupyterlab_nord_theme-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for jupyterlab_nord_theme-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 15be54e1af00b0560c79df0046f439dd55487549076c3714e3eab1b00f2efcc0
MD5 fad04bebed1a35f433b8a702336edeb1
BLAKE2b-256 4ce7301eb39f2dbb2ca9b583fd9caabd018746154de6b32ccbe6c556f77d58ca

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page