Jupyter Notebooks with ES6 and TypeScript
matsko@google.com
April 28th 2020
data:image/s3,"s3://crabby-images/71c5b/71c5b9b77515a65eaf20cf48d8ab0b496eff2ad7" alt=""
data:image/s3,"s3://crabby-images/52e6b/52e6ba95457defdad3d2e2f33d26592e18d6d725" alt=""
How do we test out ES6/TS Code?
data:image/s3,"s3://crabby-images/4597a/4597a99dc0c86358e494f719bebdd939d15de142" alt=""
data:image/s3,"s3://crabby-images/1f6ba/1f6ba3d0356b698f17c1c3d76b6299074f67c4aa" alt=""
data:image/s3,"s3://crabby-images/4597a/4597a99dc0c86358e494f719bebdd939d15de142" alt=""
data:image/s3,"s3://crabby-images/2e214/2e2149d0e13bfcfba6a8bc53b3d8373cd74064b5" alt=""
const r = foo('...');
console.log(r);
tsc index.ts
node index.js
- Output is not saved
- Boilerplate
- Online Services
- Sharing
- Manual loading
- Manual versioning
- Slow
there are issues with doing this...
What about design docs and content?
data:image/s3,"s3://crabby-images/2fa38/2fa38a25c98c7f0f72d6898aad21eefddb993c3f" alt=""
data:image/s3,"s3://crabby-images/5980f/5980f25b097709e726e7d1c14f9894adceb71a70" alt=""
data:image/s3,"s3://crabby-images/5980f/5980f25b097709e726e7d1c14f9894adceb71a70" alt=""
data:image/s3,"s3://crabby-images/2fa38/2fa38a25c98c7f0f72d6898aad21eefddb993c3f" alt=""
Google Docs
- Code Highlighting
- Sharing
HackMD
- Outside Google
- Tied to accounts
- Markdown only
- Collaboration...
there are issues with this as well...
data:image/s3,"s3://crabby-images/cc667/cc6672e9a71e5247228101c5bc4994f9a5a82a8f" alt=""
What about docs and stuff in Github?
- Markdown is still limit
- Code and preview are separate
- Files get mixed in with source code
- Rendering images, rich media is tricky
data:image/s3,"s3://crabby-images/71c5b/71c5b9b77515a65eaf20cf48d8ab0b496eff2ad7" alt=""
Docs
+
REPL
data:image/s3,"s3://crabby-images/71c5b/71c5b9b77515a65eaf20cf48d8ab0b496eff2ad7" alt=""
Notebook
- REPL
- Multiple Languages
- Input + Output mixed together
- Workspace of notebooks
- Multiple sources
- Debugging, previews, etc...
Lab
Markdown + REPLs
+ Output
===
Notebook
- Markdown describes content
- Code examples are live and can generate output
- All output is saved
# install python 3.8.x before
# (use pyenv to install python)
pip install jupyterlab
# install TS & ES6 support
npm install -g tslab
tslab install
# serve @ localhost:8888
jupyter notebook
Native ES6 / TS
Support with `tslab`
- Understands TypeScript & Classes
- Supports async await
- Great for querying APIs
What this means for Angular?
- Custom dashboards for CircleCI, Travis, etc...
- Interactive apps for debugging, profiling, etc...
Github
- All output is saved
- Notebook contents can be rendered on Github
Jupiter Lab
data:image/s3,"s3://crabby-images/71c5b/71c5b9b77515a65eaf20cf48d8ab0b496eff2ad7" alt=""
Notebooks +
IDE
===
Lab
- An integrated environment for running notebooks
- Supports plugins and tools
What about multi-user collaboration?
- Various options
- Both local and online
- Needs investigation
Jupyter
Hub
- Run JupyterLab on a server for everyone to access
- Github authentication
Google CoLab
- colab.research
.google.com - Google supports notebooks
- Files saved in Drive
- Commenting
- Python only
- Research Project?
Binder
- mybinder.org
- Turn Github-level notebooks into interactive docs
- Works off of any GH project
Some final ideas...
- Lots we can do with Jupyter
- Teaching, learning, documenting, prototyping
- It will require exploration and experimentation
Thank you!
data:image/s3,"s3://crabby-images/a7c14/a7c1422952b92d1f694885135b5a047112e821e2" alt=""
Jupyter Notebooks with ES6 and TypeScript
By Matias Niemelä
Jupyter Notebooks with ES6 and TypeScript
- 2,769