1.1.1 • Published 5 years ago
react-nbviewer v1.1.1
react-nbviewer
Render Jupyter Notebooks as React components.
Install
npm install --save react-nbviewerUsage
import React from 'react'
import NbViewer from 'react-nbviewer'
import 'react-nbviewer/dist/index.css'
import Markdown from 'react-markdown'
import SyntaxHighlighter from 'react-syntax-highlighter'
<Nbviewer
  source="{.ipynb file content}"
  markdown={Markdown}
  code={SyntaxHighlighter} />Importing react-nbviewer/dist/index.css is not required. You can style the component on your own. See src/index.css for details.
Options
| Name | Type | Description | 
|---|---|---|
| source | stringorobject | The Jupyter Notebook source to parse. | 
| markdown | ReactNode<{source: string}> | (Optional) The React component to render Markdown. react-markdownis recommended. | 
| code | ReactNode<{language: string, children: string}> | (Optional) The React component to highlight code blocks. | 
Complete example
Here's a more complete example which also renders math in Markdown cells:
import React from 'react'
import ReactDOM from 'react-dom'
import NbViewer from 'react-nbviewer'
import Markdown from 'react-markdown'
import MathPlugin from 'remark-math'
import TeX from '@matejmazur/react-katex'
import Highlighter from 'react-syntax-highlighter'
import 'react-nbviewer/dist/index.css'
import 'katex/dist/katex.min.css'
const MathMarkdown = (props) => {
  const renderers = {
    math: ({ value }) => <TeX block math={value} />,
    inlineMath: ({ value }) => <TeX math={value} />,
    code: props => <Highlighter language={props.language}>{props.value}</Highlighter>
  }
  return <Markdown renderers={renderers} plugins={[MathPlugin]} source={props.source} />
}
ReactDOM.render(
  <NbViewer source="{.ipynb file content}" markdown={MathMarkdown} code={Highlighter} />,
  document.getElementById('root')
)License
MIT © chuangzhu