2021-05-26 16:37:10 +08:00
< h1 align = "center" >
< img
alt="RetroLab"
src="./logo.png"
width="256"
/>
< / h1 >
2020-12-04 21:15:41 +08:00
2021-05-27 03:35:22 +08:00
![Github Actions Status ](https://github.com/jupyterlab/retrolab/workflows/Build/badge.svg )
2021-05-19 22:51:48 +08:00
[![Binder ](https://mybinder.org/badge_logo.svg )](https://mybinder.org/v2/gist/jtpio/77c82c512f6779a1a05ab59d915dfc36/master?urlpath=/retro/notebooks/tour.ipynb)
2021-05-27 03:35:22 +08:00
[![Binder main ](https://img.shields.io/badge/launch-main-E66581.svg?logo= )](https://mybinder.org/v2/gh/jupyterlab/retrolab/main?urlpath=retro/tree)
2021-05-19 21:13:00 +08:00
[![PyPI ](https://img.shields.io/pypi/v/retrolab.svg )](https://pypi.org/project/retrolab)
[![conda-forge ](https://img.shields.io/conda/vn/conda-forge/retrolab.svg )](https://anaconda.org/conda-forge/retrolab)
2020-12-08 00:51:17 +08:00
2021-05-19 22:51:48 +08:00
`RetroLab` (also known as _JupyterLab Retro_ , previously called _JupyterLab Classic_ ) is a [JupyterLab ](https://github.com/jupyterlab/jupyterlab ) distribution with a retro look and feel.
2020-12-04 21:15:41 +08:00
2021-05-19 21:13:00 +08:00
![image ](https://user-images.githubusercontent.com/591645/118792690-2f1e8080-b898-11eb-98fb-1b8a22b8a07d.png )
2020-12-08 00:45:58 +08:00
2020-12-04 21:15:41 +08:00
## Install
2021-05-19 21:13:00 +08:00
`retrolab` can be installed with `pip` :
2020-12-04 21:15:41 +08:00
```bash
2021-05-19 21:13:00 +08:00
pip install retrolab
2020-12-04 21:15:41 +08:00
```
2021-01-07 17:39:36 +08:00
With `mamba` :
```bash
2021-05-19 21:13:00 +08:00
mamba install -c conda-forge retrolab
2021-01-07 17:39:36 +08:00
```
With `conda` :
2020-12-04 21:15:41 +08:00
```bash
2021-05-19 21:13:00 +08:00
conda install -c conda-forge retrolab
2020-12-04 21:15:41 +08:00
```
## Usage
2021-05-19 21:13:00 +08:00
`retrolab` can be started as a standalone app with:
2020-12-04 21:15:41 +08:00
```bash
2021-05-19 21:13:00 +08:00
jupyter retro
2020-12-04 21:15:41 +08:00
```
Existing federated JupyterLab extensions listed via:
```bash
jupyter labextension list
```
2021-05-19 21:13:00 +08:00
Should also be available when starting `retrolab` .
2020-12-04 21:15:41 +08:00
2020-12-12 05:11:47 +08:00
### Files 📂 and Running Sessions 🏃♀️
2020-12-09 03:50:57 +08:00
2020-12-12 05:11:47 +08:00
![tree ](https://user-images.githubusercontent.com/591645/101952684-54c4a100-3bf9-11eb-8031-6900f6d3a445.gif )
### Notebook 📒
![notebook ](https://user-images.githubusercontent.com/591645/101953039-efbd7b00-3bf9-11eb-9d34-3cb663a5ac43.gif )
### Open in a new Browser Tab by default
2021-05-19 21:13:00 +08:00
![new-browser-tab ](https://user-images.githubusercontent.com/591645/118811914-d9ed6980-b8ad-11eb-8362-f38627199f71.gif )
2020-12-12 05:11:47 +08:00
### Command Palette 🎨
![command-palette ](https://user-images.githubusercontent.com/591645/101953322-72ded100-3bfa-11eb-9b13-3a912e4f6844.gif )
### Themes 🌈
Support for existing JupyterLab themes!
![themes ](https://user-images.githubusercontent.com/591645/101953333-75d9c180-3bfa-11eb-868f-af54d1ea7091.gif )
2021-05-26 17:15:14 +08:00
For an even more retro look, you might want to start `retrolab` with the `--retro-logo` CLI flag:
```bash
jupyter retro --retro-logo
# or
# jupyter retro --RetroApp.retro_logo=True
```
Example with the [JupyterLab Miami Nights Theme ](https://github.com/timkpaine/jupyterlab_miami_nights ) installed as a prebuilt extension:
![image ](https://user-images.githubusercontent.com/591645/119634905-77e3b580-be13-11eb-9c4c-d187ebea9df8.png )
2020-12-12 05:11:47 +08:00
### Zen Mode 😌
![compact-zen-mode ](https://user-images.githubusercontent.com/591645/101923740-149cf880-3bd0-11eb-9617-e3349a76d034.gif )
### Terminals 🖥️
2021-05-19 21:13:00 +08:00
![terminals ](https://user-images.githubusercontent.com/591645/118793525-fc28bc80-b898-11eb-9e02-d5a80ad8ddb8.gif )
2020-12-12 05:11:47 +08:00
### File Editor 🖊️
![image ](https://user-images.githubusercontent.com/591645/101953590-e2ed5700-3bfa-11eb-9fee-0b6d964f0949.png )
### Compact View on Mobile Devices 📱
2020-12-13 05:33:31 +08:00
![mobile ](https://user-images.githubusercontent.com/591645/101995448-2793f380-3cca-11eb-8971-067dd068ccbe.gif )
2020-12-12 05:11:47 +08:00
2020-12-24 16:44:24 +08:00
### Support for prebuilt extensions 🧩
2020-12-12 05:11:47 +08:00
Install new extensions easily!
2021-05-19 21:13:00 +08:00
![federated-extensions ](https://user-images.githubusercontent.com/591645/118813222-38671780-b8af-11eb-835b-f2865bab5c62.gif )
2020-12-12 05:11:47 +08:00
2021-05-19 21:13:00 +08:00
### Switch between JupyterLab and RetroLab easily ↔️
2020-12-12 05:11:47 +08:00
2021-05-19 21:13:00 +08:00
![jupyterlab-switch ](https://user-images.githubusercontent.com/591645/118816963-05bf1e00-b8b3-11eb-92a2-899288471011.gif )
2020-12-09 03:50:57 +08:00
2020-12-17 03:12:40 +08:00
## Contributing
If you would like to contribute to the project and set up a development environment, check out [CONTRIBUTING.md ](./CONTRIBUTING.md ).
2020-12-04 21:15:41 +08:00
## Motivation
2020-12-24 16:44:24 +08:00
JupyterLab is the next-gen UI for Project Jupyter. Currently at version 3.0, it is becoming more mature and provides an advanced computational environment, that can sometimes be compared to what traditional IDEs offer.
2020-12-04 21:15:41 +08:00
However in some cases, having a leaner, simpler, and more focused interface to work on a notebook is really useful.
2020-12-08 00:45:58 +08:00
The single document mode as currently implemented in JupyterLab helps address this issue, but still displays a couple of visual cues that can be distracting to some users.
2020-12-04 21:15:41 +08:00
2021-05-19 21:13:00 +08:00
The goal of the `retrolab` project is to provide an alternative JupyterLab distribution with the look and feed of the classic notebook UI, while leveraging the efforts put in the development of JupyterLab itself and its extension system.
2020-12-04 21:15:41 +08:00
2021-05-19 21:13:00 +08:00
Technically speaking, `retrolab` reuses **many** of the existing plugins for JupyterLab (notebook, toolbar), and also supports prebuilt (federated) third-party extensions using the new distribution system added in 3.0. That way, extensions built for JupyterLab should also be compatible with `retrolab` , as long as they can be added to the application shell provided by RetroLab.
2020-12-04 21:15:41 +08:00
2020-12-22 19:48:10 +08:00
## Relation to other Jupyter frontends
2020-12-21 16:05:36 +08:00
2021-05-19 21:13:00 +08:00
RetroLab is an alternative frontend built using the latest JupyterLab components, with the look and feel of the Classic Jupyter Notebook UI. Below is a short comparison to know where it stands when compared to other Jupyter UI projects:
2020-12-21 16:05:36 +08:00
2020-12-22 19:48:10 +08:00
- Classic Jupyter Notebook - Classic frontend, classic notebook server.
- NBClassic - Classic frontend, new Jupyter Server.
- JupyterLab - Jupyterlab frontend, new Jupyter Server (or Classic Notebook Server). Extensions are not compatible with the Classic Jupyter Notebook since it is built with different components. With version 3.0 onwards, it uses the new Jupyter Server and supports federated extensions that don't need to be rebuilt on the end-user machine.
2021-05-19 21:13:00 +08:00
- RetroLab - JupyterLab frontend built with JupyterLab components, with the look and feel of the Classic Notebook. Consistent with the latest version of Jupyterlab. Extensions built for Jupyterlab should work as long as the components they depend on are part of this classic interface (for install RetroLab doesn't have the `left` , `right` and `bottom` areas).
2020-12-21 16:05:36 +08:00
2020-12-04 21:15:41 +08:00
## Prior art
This project is mostly a reboot of the two previous attempts at making something similar:
- [simplest-notebook ](https://github.com/yuvipanda/simplest-notebook )
- [jupyterlab-clarity-mode ](https://github.com/jupytercalpoly/jupyterlab-clarity-mode )
2020-12-08 00:45:58 +08:00
These projects really expressed the need for a stripped down, minimal version of the Jupyter Notebook UI.
2020-12-04 21:15:41 +08:00
2021-05-19 21:13:00 +08:00
`retrolab` contributes to that space with the added features:
2020-12-04 21:15:41 +08:00
- Support for existing federated (prebuilt) JupyterLab extensions
2020-12-08 00:45:58 +08:00
- Zen Mode
2020-12-04 21:15:41 +08:00
- Repo structure, similar to JupyterLab
- Reusing as much as possible from upstream JupyterLab
2021-05-19 21:13:00 +08:00
- Serve as a template and reference implementation for other alternative JupyterLab distributions
2021-05-27 03:35:22 +08:00
## Community Guidelines and Code of Conduct
This repository is a Jupyter project and follows the Jupyter
[Community Guides and Code of Conduct ](https://jupyter.readthedocs.io/en/latest/community/content-community.html ).