From 2b194a3c090fd375321871c47a3de503a0758206 Mon Sep 17 00:00:00 2001 From: choldgraf Date: Tue, 21 May 2024 19:33:48 -0700 Subject: [PATCH 1/2] JEP: Add Jupyter Book as subproject --- .../jupyter-book-incorporation.md | 149 ++++++++++++++++++ .../repositoriestoinclude.csv | 89 +++++++++++ README.md | 2 +- 3 files changed, 239 insertions(+), 1 deletion(-) create mode 100644 122-jupyter-book-incorporation/jupyter-book-incorporation.md create mode 100644 122-jupyter-book-incorporation/repositoriestoinclude.csv diff --git a/122-jupyter-book-incorporation/jupyter-book-incorporation.md b/122-jupyter-book-incorporation/jupyter-book-incorporation.md new file mode 100644 index 00000000..a14a12a5 --- /dev/null +++ b/122-jupyter-book-incorporation/jupyter-book-incorporation.md @@ -0,0 +1,149 @@ +--- +title: Incorporate `jupyter-book` as a Jupyter sub-project +authors: choldgraf, gregcaporaso, jstac, rowanc1 +issue-number: 122 +pr-number: 123 +date-started: 2024-05-21 +--- + +# Incorporate Jupyter Book as a Jupyter Sub-project + +## Summary + +_One paragraph explanation of the proposal._ + +We propose the incorporation of a new Jupyter community sub-project: Jupyter Book (hereafter, `jupyter-book`). This sub-project is dedicated to building tools and standards that facilitate authoring, reading, and publishing workflows for computational narratives. The new sub-project would act as the steward of several successful technology and standards projects currently stewarded by the `executablebooks/` project, most notably `Jupyter Book` and the `MyST` documentation engine, document standard, and markdown syntax. This will allow these tools to further enhance interoperability with the broader Jupyter stack of tools and to enable extensions that improve the state of authoring, reading, and publishing across the Jupyter ecosystem. + +## Motivation + +_Why are we doing this? What use cases does it support? What is the expected outcome?_ + +The Jupyter Book project is a heavily-used user-facing tool for combining multiple computational narratives into an interactive book-like format. It was first created as a Jupyter repository (based on Jekyll), and was then moved into the [`executablebooks/` organization](https://github.com/executablebooks) when the Jupyter Book project received funding from the Sloan Foundation. The Jupyter Book stack was originally based on Sphinx, which was largely driven by development in the first half of the grant's timeline. It now seeks to [migrate to a JavaScript-based document engine with MyST](https://docs.google.com/document/d/1h4vsUD-vAjFrHVwD6ZMcXZRo2YJOQYbQQYX93i-RflY/edit). + +In the past two years, Jupyter Book has shifted its technical strategy to focus on a modern, future-proof foundation for authoring and reading computational narratives. It has invested project resources into developing a TypeScript-based documentation engine that can serve as the backbone of Jupyter Book. This documentation engine, called [MyST](https://mystmd.org) (for Markedly Structured Text, the same name as its flavor of markdown syntax), is designed to be web-native, and to more naturally interact with the web-based tools in the Jupyter ecosystem and beyond. + +The `executablebooks/` GitHub organization is an artifact of the Sloan Foundation grant that originally funded its operations. This grant is winding down, and we are seeking a longer-lasting and organizationally-neutral home for the vision, strategy, tools, and standards of this modern version of the Jupyter Book toolchain. + +The Jupyter project has a technical strategy that often discusses computational narratives. For example, many use Jupyter Notebooks to share data narratives and workflows around them (and in fact, this is one of the original driving use-cases for Jupyter Book). While Jupyter tends to focus on the computational and interactive aspects of the data science workflow first, we believe that `jupyter-book` would serve as a good “narrative-first” counterpart. By focusing on the content authoring, reading, and sharing aspects of the Jupyter ecosystem, `jupyter-book` could meet a unique set of use-cases that are relevant to the project. For example, improving Jupyter’s functionality for blogs, scholarship, data science education, software documentation, and community knowledge bases. + +For these reasons, we believe that the Jupyter Project would be a natural home for the parts of the `executablebooks/` ecosystem that intersect Jupyter's mission around technology and standards for interactive computing. Below we provide more context for what this could look like. + +## Guide-level explanation + +_Explain the proposal as if it was already implemented and you were explaining it to another community member._ + +At a strategic level: the `jupyter-book` sub-project focuses on **web-native workflows for authoring, reading, and publishing narratives with computation**, as well as integrating with existing Jupyter sub-projects. The sub-project assumes responsibility for defining the strategy that guides future development of `jupyter-book` and its related projects, getting the resources necessary to carry out this strategy, and stewarding an open community. + +At a team capacity level: the `jupyter-book` sub-project is currently maintained with the following team: A three-person Steering Council: Chris Holdgraf ([@choldgraf](https://github.com/choldgraf)), Greg Caporaso ([@gcaporaso](https://github.com/gregcaporaso)), Rowan Cockett ([@rowanc1](https://github.com/rowanc1)), as well as an additional three engineering team members: Angus Hollands ([@agoose77](https://github.com/agoose77)), Franklin Koch ([@fwkoch](https://github.com/fwkoch)), Steve Purves ([@stevejpurves](https://github.com/stevejpurves)). There have been over [30 additional contributors to the project](https://github.com/executablebooks/mystmd/graphs/contributors) as well, and we intend on growing the accessibility of the project to new contributors moving forward. + +At a functionality level: Jupyter Book allows users to build beautiful, publication-quality books and documents from computational content. The authoring experience works [directly in the JupyterLab interface](https://github.com/executablebooks/jupyterlab-myst) to enhance narrative content with cross-references and specialized markups (like exercises, proofs, theorems, etc.). A Jupyter Book can either be a static-renderer or integrate to computation from existing Jupyter projects that are local, collaborative (JupyterHub), ephemeral (Binder), or browser-based (JupyterLite). A Jupyter Book can be exported to many existing PDF templates used in scientific publishing. The underlying components work with existing Jupyter standards for notebooks and provide ways to write structured content in Markdown that can be accessed by scientific publishing workflows and documentation tool-chains. + +We’ve identified a subset of the `executablebooks/` repositories that fit within this strategic focus, and that we propose transferring to a newly-created Jupyter sub-project called `jupyter-book`. [See the appendix below for a list of projects and their proposed homes.](#appendix-repositories) + +We’ve selected repositories based on the likelihood that they integrate and interoperate cleanly with other major projects in the Jupyter ecosystem, and that they follow Jupyter's strategy for standards and protocols. For example, repositories that are largely based on web technologies (in order to integrate with tools like JupyterLab/Lite, Voila, etc), that integrate with Jupyter's underlying server and computation infrastructure (like Jupyter server and Binder), and that define and re-use standards for third-party communities to build on top of (like the MyST Markdown syntax or the notebook format). + +The remaining repositories that are _not_ transferred into the `jupyter-book` organization will remain under the governing structures of the `executablebooks/` project. The steering council of that project will continue to steward those repositories or identify alternative homes for them, but the Jupyter project will not have any responsibility or oversight over this process. + +## Reference-level explanation + +We wish to: + +- Create a GitHub organization called `jupyter-book`. +- Transfer over ownership of these repositories to this new organization (see [](#appendix-repositories)). +- List this organization as being the home of a "Jupyter sub-project" called `jupyter-book`. +- Define a steering council of the following people (in alphabetical order): + - Chris Holdgraf + - Greg Caporaso + - Rowan Cockett +- Define the necessary representatives for `jupyter-book` in the SSC. +- Define a team-compass for Jupyter Book at `jupyter-book/team-compass`. +- Begin operations as a Jupyter sub-project. + +This proposal does _not_ include any ideas around changes to technology or standards, both within `jupyter-book` and in its relation to the broader Jupyter community. + +## Rationale and alternatives + +### Why Jupyter? + +Jupyter is a natural home for the `jupyter-book` project for several key reasons described below: + +1. The strategy of `jupyter-book` aligns heavily with the broader goals of the Jupyter ecosystem. While Jupyter builds technology and standards for interactive computing workflows, Jupyter Book focuses on the "authoring, reading, and publishing" aspects of interactive computing, with an emphasis on traditional publishing workflows like "books", "articles", "knowledge bases", etc. +2. The technical direction for `jupyter-book` aligns heavily with Jupyter's broader technical direction and standards, and being a sub-project will create more opportunities for integrations, re-using components and standards, and generally connecting with the Jupyter stack in a way that is greater than the sum of its parts. +3. The proposed Steering Council of the `jupyter-book` project each have extensive experience in the open source ecosystem and understand how to build healthy open source communities aligned with Jupyter's principles. +4. Some members of the Steering Council (Chris Holdgraf) have extensive experience with other Jupyter sub-projects. For example, Chris was part of the inaugural Distinguished Contributor cohort and has served on the JupyterHub and Binder steering council for more than 5 years. +5. Jupyter Book (the technology project) began within the `jupyter/` organization, and was originally framed as "a way to publish collections of `.ipynb` files as a web-based book". +6. MyST Markdown (the markdown syntax) was initially brainstormed within the Jupyter community, with several then-Steering Council members serving as key catalysts in the creation of MyST. + +### Why split the `executablebooks/` repositories into two homes? + +We believe that the `executablebooks/` repositories naturally fall into two technical directions: one based on `docutils` and `sphinx` (with heavy overlap with the broader developer documentation community), and one based on Javascript (with heavy overlap with scientific computing and authoring workflows). + +The technical direction and user-focus of each is distinct enough that it is natural to split them into two projects. This will allow each organization to define their own set of target users and strategies to serve them. + +Note that, initially, the Steering Council of `executablebooks/` and that of the `jupyter-book` organization will be the same. This will allow us to coordinate the direction of projects in each organization for the immediate future, and minimize the friction associated with having two organizational homes. Over time, we intend for the strategy and governance of each organization to begin to evolve independent of one another. + +### What other options do we have? + +The most natural alternative is to define `executablebooks/` as its own standalone open source community, and request incorporation under a fiscal sponsor like NumFocus. We believe that this is a perfectly reasonable direction, but also believe that there is a unique opportunity to empower the workflows and users we care about by building a deeper relationship with the Jupyter community. + +Alternatively, we could decide to take no action, and retain `executablebooks/`'s current status as a project-focused GitHub organization with a governing body defined in its team compass, but with no formal organizational status. We believe that this would hinder the project's ability to grow its community, to define an organizationally-neutral place to host its tools and strategy, and to raise funds needed to sustain and grow the community's operations. + +## Prior art + +This proposal is similar to other JEP proposals to incorporate new Jupyter sub-projects from pre-existing technology. + +In each case, a team independently defined the strategy, direction, and early development to bring technology projects to a more "stable" state. They then proposed incorporation as a sub-project once the key ideas that drove these projects solidified, and when it became clear that there was a natural overlap at a technical and strategic level with the Jupyter ecosystem. In these cases, the leaders of the project were also leaders within the Jupyter project, which facilitated the flow of information and collaboration across Jupyter and the new sub-project. + +We believe that the `jupyter-book/` project follows the same pattern described here. For examples of previous JEPs similar to the one proposed here, see [Voila incorporation JEP](https://github.com/jupyter/enhancement-proposals/tree/master/42-voila-incorporation), and the [Xeus incorporation JEP](https://github.com/jupyter/enhancement-proposals/tree/master/44-xeus-incorporation). + +## Unresolved questions + +This JEP does not propose any new ideas for the technical future of the `jupyter-book` project or any other part of the Jupyter ecosystem. There may be many new directions to consider if `jupyter-book` is incorporated as a subproject, but this can be discussed and iterated on in the future. This proposal is only about defining the organizational structure of the `jupyter-book` subproject and its initial set of repositories. + +## Future possibilities + +There are many ways that the `jupyter-book` project could connect and integrate with the broader Jupyter community. For example: + +- By further-developing JupyterLab-MyST, which brings the functionality of MyST Markdown into the JupyterLab interface. For example, we could leverage JupyterLab's user interface to facilitate multi-document authoring and references, or to provide real-time previews of rendered MyST documents that leverage computation and notebooks. +- By integrating the interactive aspects of MyST and Jupyter Book with computational machinery provided by other Jupyter technology, such as JupyterHub and BinderHub (via a tool like `thebe/`). +- By integrating the MyST documentation engine into Jupyter services such as `nbviewer` or `Binder`. +- By improving the kernel execution frameworks within Jupyter that power Jupyter Book's functionality around executing content as part of the book building process. +- By better-integrating the interactive interfaces and outputs in the Jupyter ecosystem (ipywidgets, voila, RISE, etc) into Jupyter Book and MyST. +- By improving the `ipynb` specification and format in order to promote re-usability and composability in Jupyter Book and MyST. + +## Appendix: Frequently Asked Questions (FAQs) + +**Why is the Jupyter Book CLI being moved, given that it depends on the Sphinx stack?** + +Our intention is to gradually swap the back-end of Jupyter Book to use the mystmd backend instead of Sphinx. For this reason, it will be aligned at a technical strategy level with the rest of the web-native stack. This will likely take several months or more, as we slowly bring the MyST document engine up to feature parity with the Jupyter Book stack, and we plan on coordinating with the Executable Books community throughout this process (and note that initially the leadership of this sub-project, and Executable Books, will be the same in order to make this easier). + +**Does that mean the Sphinx stack is being abandoned?** + +No! The Sphinx-focused repositories will remain inside the `executablebooks/` organization and governance. Those projects will continue to be useful to the Sphinx community, as they’ve been designed to work independently of Jupyter Book and have a large user base without it (from the developer community in Sphinx). This will continue to grow/evolve as an independent GitHub organization with its own developer community. We think that it’s better to have a Sphinx-focused stack in its own space, so that the Jupyter project can reduce its extra maintenance burden, and focus on the web-native nature of its technology stack. + +**Does this involve other JS-based repositories like Papyri?** + +Not right now. We think Papyri is awesome and would love to find ways to integrate more with it and potentially include it in this organization. Right now we’d like to keep the decision relatively simple and tightly scoped to Executable Books repositories. + +**What about reading-focused Jupyter services like NBConvert?** + +Same idea as above. We’re open to talking about how Jupyter Book could support, integrate and/or help steward services like these, but want to focus this decision on bringing “Jupyter Book” into existence as a sub-project just with our current list of repositories. + +## Security considerations + +The main content for Jupyter Book is text-based and images, and can also include interactive Jupyter outputs that can potentially be untrusted vectors for abuse. Currently, the Jupyter Book and MyST Markdown tools are primarily intended and used for stand-alone sites that do not have authentication. There is the possibility to include user-generated content through Jupyter and other untrusted output that could provide a problem in an authenticated environment. The project uses React for rendering HTML, which provides some assurances around not rendering untrusted or arbitrary HTML, all content is stored as JSON data, and transformed on the fly to HTML. The Jupyter outputs are using the same components as the JupyterLab project. Currently deployed projects can be connected to a remote Jupyter kernel in a JupyterHub or BinderHub (using Thebe), these have the same security concerns as those tools, which is mitigated by having containerized environments. It is possible, when running locally, to connect to arbitrary user environments in Jupyter, this is always initiated through a user action through the terminal ([documentation](https://mystmd.org/guide/execute-notebooks)). + +## Accessibility considerations + +The Jupyter Book team is committed to making its interfaces accessible, and believes that building on modern web frameworks is a good foundation to begin with. It does not have accessibility expertise itself, although we have sponsored some of our team members to attend web-accessibility courses. The Jupyter Book team will need guidance and resourcing (at the least in a consulting/assessment capacity) from the Jupyter community in order to identify and implement accessibility improvements. + +From a technology standpoint, we are adopting tools that have a good accessibility track record (e.g. RadixUI, see [accessibility docs for Radix](https://www.radix-ui.com/primitives/docs/overview/accessibility)). This allows us to implement rather than reinvent accessibility best-practices. The interactive Jupyter components are inherited directly from the JupyterLab ecosystem, so improvements to accessibility there will directly improve MyST Markdown and Jupyter Book. We discuss some of the accessibility considerations in the [MyST Markdown project here](https://mystmd.org/guide/accessibility-and-performance). + +(appendix-repositories)= +## Appendix: List of `executablebooks/` repositories to incorporate under `jupyter-book` + +(note the "last updated" field is out of date, and reflects when this draft first started in early March 2024) + +```{csv-table} +:file: repositoriestoinclude.csv +``` \ No newline at end of file diff --git a/122-jupyter-book-incorporation/repositoriestoinclude.csv b/122-jupyter-book-incorporation/repositoriestoinclude.csv new file mode 100644 index 00000000..1aaa5386 --- /dev/null +++ b/122-jupyter-book-incorporation/repositoriestoinclude.csv @@ -0,0 +1,89 @@ +Repository,Description,Last Updated,New Home +myst-templates,A GitHub organization with templates for MyST renderers. Will remain a github org but move governance under the jupyter-book org.,2/28/2024,jupyter-book +mystmd,Command line tools for working with MyST Markdown.,2/9/2024,jupyter-book +myst-theme,Packages for creating MyST websites themes using React and Remix,2/8/2024,jupyter-book +jupyter-book,"Create beautiful, publication-quality books and documents from computational content.",2/8/2024,jupyter-book +jupyterlab-myst,Use MyST Markdown directly in Jupyter Lab,2/6/2024,jupyter-book +jupyter-cache,A defined interface for working with a cache of executed jupyter notebooks,1/29/2024,jupyter-book +jupyter-cache-upgrader,,1/25/2024,jupyter-book +myst-spec,"MyST is designed to create publication-quality, computational documents written entirely in Markdown.",1/24/2024,jupyter-book +thebe,Turn static HTML pages into live documents with Jupyter kernels.,1/20/2024,jupyter-book +cookiecutter-jupyter-book,Cookiecutter template for a simple jupyter book,11/29/2023,jupyter-book +github-activity,Simple markdown changelogs for GitHub repositories,11/22/2023,jupyter-book +myst-enhancement-proposals,MyST Enhancement Proposals (MEPs),10/9/2023,jupyter-book +mystmd.org,A splash page for the MyST Markdown ecosystem,8/2/2023,jupyter-book +jupyterlab-myst-quickstart,Quickstart examples for working with MyST in Jupyter,7/5/2023,jupyter-book +github-action-demo,A demonstration repository to build and host a book with GitHub Actions,6/21/2023,jupyter-book +myst-theme-patches,A minimal repository containing essential patches for myst-theme deveopment,6/14/2023,jupyter-book +thebe-binder-base,A minimal binder setup for thebe demos,4/27/2023,jupyter-book +myst-vs-code,A syntax highlighter for the MyST Markdown format,3/6/2023,jupyter-book +mystmd-quickstart,Repository to be used in the mystjs quickstart guide,1/25/2023,jupyter-book +thebe-core,Typescript based Jupyter connectivity and code execution layer for thebe,8/22/2022,jupyter-book +myst-demo,A web-component for interactive myst demos in documentation.,6/20/2022,jupyter-book +unified-myst,A repository of packages for working with MyST in the https://unifiedjs.com/ ecosystem,4/30/2022,jupyter-book +sphinx-book-theme,A clean book theme for scientific explanations and documentation with Sphinx,2/9/2024,executablebooks +meta,A community dedicated to supporting tools for technical and scientific communication and interactive computing,2/8/2024,executablebooks +sphinx-thebe,"A Sphinx extension to convert static code into interactive code cells with Jupyter, Thebe, and Binder.",2/7/2024,executablebooks +mdformat-tables,An mdformat plugin for rendering tables,2/7/2024,executablebooks +mdformat,CommonMark compliant Markdown formatter,2/6/2024,executablebooks +mdit-py-plugins,Collection of core plugins for markdown-it-py,2/5/2024,executablebooks +sphinx-external-toc,A sphinx extension that allows the site-map to be defined in a single YAML file,2/5/2024,executablebooks +markdown-it-py,"Markdown parser, done right. 100% CommonMark support, extensions, syntax plugins & high speed. Now in Python!",2/5/2024,executablebooks +MyST-NB,Parse and execute ipynb files in Sphinx,2/5/2024,executablebooks +MyST-Parser,"An extended commonmark compliant parser, with bridges to docutils/sphinx",2/5/2024,executablebooks +sphinx-design,"A sphinx extension for designing beautiful, screen-size responsive web components.",1/29/2024,executablebooks +sphinx-copybutton,"Add a ""copy"" button to code blocks in Sphinx",1/29/2024,executablebooks +rst-to-myst,Convert ReStructuredText to MyST Markdown,1/29/2024,executablebooks +sphinx-tabs,Tabbed views for Sphinx,1/29/2024,executablebooks +web-compile,"A CLI to compile/minify SCSS & JS, and associated pre-commit hook.",1/29/2024,executablebooks +mdurl,URL utilities for markdown-it (a Python port),1/29/2024,executablebooks +sphinx-togglebutton,Show and hide content with a button in Sphinx,12/22/2023,executablebooks +sphinx-panels,A sphinx extension for creating panels in a grid layout,12/18/2023,executablebooks +sphinx-jupyterbook-latex,Supporting LaTeX infrastructure for Jupyter Book,12/11/2023,executablebooks +grant-admin,,12/6/2023,executablebooks +.github,"Community health files: Contributing guidelines, Code of Conduct, ...",12/4/2023,executablebooks +team-compass,Organizational policy and internal documentation for the executablebooks community,11/28/2023,executablebooks +grant-application,Web publishing tool funding application,11/21/2023,executablebooks +mdformat-plugin,A template for creating an mdformat parser extension plugin,11/3/2023,executablebooks +sphinx-remove-toctrees,Speed up Sphinx builds by selectively removing toctrees from some pages,11/3/2023,executablebooks +markdown-it-myst-extras,Additional plugins required for the MyST specification,9/26/2023,executablebooks +markdown-it-dollarmath,A markdown-it plugin for $-delimited math,9/26/2023,executablebooks +markdown-it-amsmath,A markdown-it plugin for amsmath LaTeX environments.,9/26/2023,executablebooks +sphinx-proof,"A Sphinx extension for producing proof, theorem, lemma, definition, remark, conjecture, corollary and algorithm directives.",9/18/2023,executablebooks +mdformat-myst,Mdformat plugin for MyST compatibility,8/26/2023,executablebooks +mdformat-deflist,mdformat plugin for deflist,8/26/2023,executablebooks +staged-recipes,A place to submit conda recipes before they become fully fledged conda-forge feedstocks,8/1/2023,executablebooks +sphinx-comments,hypothes.is interaction layer with Sphinx,5/3/2023,executablebooks +myst-article-theme,A light-weight theme for rendering scientific articles and associated notebooks,4/26/2023,executablebooks +myst-book-theme,A lightweight MyST theme designed to mimic the look-and-feel of an interactive book.,4/26/2023,executablebooks +markdown-it-docutils,A markdown-it plugin for implementing docutils style roles/directives.,3/6/2023,executablebooks +jupyterlab-mystjs,TO ARCHIVE: Jupyterlab extension using the MySTjs parser,2/10/2023,executablebooks +sphinx-exercise,A Sphinx extension for producing exercise and solution directives.,1/23/2023,executablebooks +markdown-it-plugin-template,A template for creating a markdown-it plugin.,1/9/2023,executablebooks +sphinx-examples,A Sphinx extension to create examples of source markdown and the result of rendering it.,5/3/2022,executablebooks +mdformat-footnote,Footnote format addition for mdformat,2/16/2022,executablebooks +quantecon-mini-example,A short example showing how to write a lecture series using Jupyter Book 2.0.,11/13/2021,executablebooks +sphinx-multitoc-numbering,A Sphinx extension to support continuous numbering of sections across multiple tocs in HTML output.,7/6/2021,executablebooks +myst-react,TO ARCHIVE: A web-based UI for rendering MyST Markdown,5/28/2021,executablebooks +sphinx-tomyst,A sphinx translator for producing myst syntax files,5/26/2021,executablebooks +myst-standard,TO ARCHIVE: A meta-repository to discuss and plan for the MyST standard,5/20/2021,executablebooks +sphinx-yaml-config,,5/8/2021,executablebooks +jupytext,"Jupyter Notebooks as Markdown Documents, Julia, Python or R scripts",4/25/2021,executablebooks +quantecon-example,A demonstration of Jupyter Book functionality using QuantEcon Python programming source material.,10/30/2020,executablebooks +sphinx-conditional-asset,A small extension for developers of Sphinx to conditionally add assets to a page.,10/25/2020,executablebooks +mistletoe-ebp,"The EPB fork of mistletoe: A fast, extensible and spec-compliant Markdown parser in pure Python.",8/6/2020,executablebooks +mappings,Work on Mappings between IPYNB-RST and IPYNB-MD++,7/29/2020,executablebooks +rst2myst,Tools for converting RST files to MyST-NB files,6/23/2020,executablebooks +python-pkg-cookiecutter,"A cookiecutter for python packages, with docs and GitHub Actions CI",6/3/2020,executablebooks +sphinx-ext-autodoc,Auto-documentation for sphinx extension components,6/3/2020,executablebooks +myst-nb.example-project,An example project for working with myst-nb and developing myst syntax,6/3/2020,executablebooks +tcs_to_jb,For conversion of TCS to Jupyter Book format,5/26/2020,executablebooks +cli,"馃洃馃洃DEPRECATED, see https://github.com/ExecutableBookProject/jupyter-book馃洃馃洃",5/15/2020,executablebooks +multi-book-demo,,5/1/2020,executablebooks +myst-parser.example-project,An self contained example project for testing and development of myst syntax using myst-parser,4/11/2020,executablebooks +sphinx-jupyter-book-theme,An experimental Sphinx theme for Jupyter Book,3/5/2020,executablebooks +sphinx-globaltoc,,2/29/2020,executablebooks +write_ups,Write ups and publications that document the project,2/25/2020,executablebooks +markup_test_cases,Markup test cases for source files,2/14/2020,executablebooks +profile-sphinx-site,A tiny repository to profile a Sphinx site,1/23/2020,executablebooks +myst,TO ARCHIVE: Myst - Markedly Structured Text,11/17/2019,executablebooks \ No newline at end of file diff --git a/README.md b/README.md index bbb64459..112cb570 100644 --- a/README.md +++ b/README.md @@ -41,7 +41,7 @@ encouraged to commence on the topic. | 0072 | **Accepted** | [Language server protocol (LSP)](72-language-server-protocol/language-server-protocol.md) | [#72](https://github.com/jupyter/enhancement-proposals/pull/72) | | 0079 | **Accepted** | [Build Jupyter Notebook v7 off of JupyterLab components](79-notebook-v7/notebook-v7.md) | [#79](https://github.com/jupyter/enhancement-proposals/pull/79) | | 0108 | **Accepted** | [Subdomain and repository for publishing schemas under jupyter.org](108-jupyter-subdomain-for-schemas/jupyter-subdomain-for-schemas.md) | [#108](https://github.com/jupyter/enhancement-proposals/pull/108) | - +| 0122 | **Submitted** | [Incorporate Jupyter Book as a subproject](./122-jupyter-book-incorporation/jupyter-book-incorporation.md) | [#123](https://github.com/jupyter/enhancement-proposals/pull/123) | ## How do I submit a JEP? From feaf909c0cbc2cd9da16d814d31500c4b4453fb5 Mon Sep 17 00:00:00 2001 From: choldgraf Date: Tue, 21 May 2024 19:48:45 -0700 Subject: [PATCH 2/2] Blog post --- 122-jupyter-book-incorporation/jupyter-book-incorporation.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/122-jupyter-book-incorporation/jupyter-book-incorporation.md b/122-jupyter-book-incorporation/jupyter-book-incorporation.md index a14a12a5..41ef9f13 100644 --- a/122-jupyter-book-incorporation/jupyter-book-incorporation.md +++ b/122-jupyter-book-incorporation/jupyter-book-incorporation.md @@ -18,7 +18,7 @@ We propose the incorporation of a new Jupyter community sub-project: Jupyter Boo _Why are we doing this? What use cases does it support? What is the expected outcome?_ -The Jupyter Book project is a heavily-used user-facing tool for combining multiple computational narratives into an interactive book-like format. It was first created as a Jupyter repository (based on Jekyll), and was then moved into the [`executablebooks/` organization](https://github.com/executablebooks) when the Jupyter Book project received funding from the Sloan Foundation. The Jupyter Book stack was originally based on Sphinx, which was largely driven by development in the first half of the grant's timeline. It now seeks to [migrate to a JavaScript-based document engine with MyST](https://docs.google.com/document/d/1h4vsUD-vAjFrHVwD6ZMcXZRo2YJOQYbQQYX93i-RflY/edit). +The Jupyter Book project is a heavily-used user-facing tool for combining multiple computational narratives into an interactive book-like format. It was first created as a Jupyter repository (based on Jekyll), and was then moved into the [`executablebooks/` organization](https://github.com/executablebooks) when the Jupyter Book project received funding from the Sloan Foundation. The Jupyter Book stack was originally based on Sphinx, which was largely driven by development in the first half of the grant's timeline. It now seeks to [migrate to a JavaScript-based document engine with MyST](https://executablebooks.org/en/latest/blog/2024/2024-05-20-jupyter-book-myst/). In the past two years, Jupyter Book has shifted its technical strategy to focus on a modern, future-proof foundation for authoring and reading computational narratives. It has invested project resources into developing a TypeScript-based documentation engine that can serve as the backbone of Jupyter Book. This documentation engine, called [MyST](https://mystmd.org) (for Markedly Structured Text, the same name as its flavor of markdown syntax), is designed to be web-native, and to more naturally interact with the web-based tools in the Jupyter ecosystem and beyond.