diff --git a/packages/@ourworldindata/grapher/src/core/Grapher.tsx b/packages/@ourworldindata/grapher/src/core/Grapher.tsx index e985c3df065..5e7374dc6a3 100644 --- a/packages/@ourworldindata/grapher/src/core/Grapher.tsx +++ b/packages/@ourworldindata/grapher/src/core/Grapher.tsx @@ -205,7 +205,7 @@ import { type EntitySelectorState, } from "../entitySelector/EntitySelector" import { SlideInDrawer } from "../slideInDrawer/SlideInDrawer" - +declare const StarboardEmbed: any // Inform TypeScript about StarboardEmbed declare global { interface Window { details?: DetailDictionary @@ -2268,6 +2268,49 @@ export class Grapher void this.timelineController.togglePlay() } + @action.bound private async addNotebook() { + const notebookNode = document.createElement("div") + notebookNode.id = "notebook" + document.body.appendChild(notebookNode) + const packageUrl = "https://unpkg.com/starboard-wrap/dist/index.js" + + const module = await import(packageUrl) + + // Ensure the module is available and extract the necessary export + const { StarboardEmbed } = module + + // Create a script tag to load the necessary library + const notebookContent = `# %% [markdown] +# Setup code +The code in the cell below provides the infrastructure to access our data. It is automatically run when the page is loaded. +# %%--- [python] +# properties: +# run_on_load: true +# ---%% +from pyodide.http import open_url +import pandas as pd +csv = open_url("${this.baseUrl}.csv") + +df = pd.read_csv(csv) + +# %% [markdown] +Add your code below - the example shows the first few rows of the data. Refer to the pandas documentation of ask ChatGPT for help on how to manipulate pandas dataframes. +# %%--- [python] +# properties: +# run_on_load: true +# ---%% +df.head() +` + + const mount = document.querySelector("#notebook") + const el = new StarboardEmbed({ + notebookContent: notebookContent, + src: "https://unpkg.com/starboard-notebook/dist/index.html", + }) + + mount!.appendChild(el) + } + selection = this.manager?.selection ?? new SelectionArray( @@ -2369,6 +2412,14 @@ export class Grapher title: "Reset to original", category: "Navigation", }, + { + combo: "ctrl+n", + fn: (): void => { + void this.addNotebook() + }, + title: "Open a notebook", + category: "Notebook", + }, ] if (this.slideShow) { diff --git a/packages/@ourworldindata/grapher/src/core/grapher.scss b/packages/@ourworldindata/grapher/src/core/grapher.scss index 92793a6c6e9..edf2793c625 100644 --- a/packages/@ourworldindata/grapher/src/core/grapher.scss +++ b/packages/@ourworldindata/grapher/src/core/grapher.scss @@ -247,3 +247,14 @@ $zindex-controls-drawer: 150; @include dod-span; } } + +#notebook { + position: absolute; + top: 70px; + left: 50px; + right: 50px; + bottom: 50px; + background: white; + z-index: 100; + overflow-y: scroll; +}