mirror of
https://github.com/jxnblk/mdx-deck.git
synced 2024-11-29 13:58:02 +03:00
Clean up gatsby-theme package
This commit is contained in:
parent
4980bb0e88
commit
73432a7ea1
@ -7,7 +7,7 @@ import mdxComponents from './mdx-components'
|
|||||||
const DefaultProvider = props => <>{props.children}</>
|
const DefaultProvider = props => <>{props.children}</>
|
||||||
|
|
||||||
export const Provider = props => {
|
export const Provider = props => {
|
||||||
const { headTags, theme, mdx } = props
|
const { headTags, theme = {}, mdx } = props
|
||||||
const {
|
const {
|
||||||
Provider: UserProvider = DefaultProvider,
|
Provider: UserProvider = DefaultProvider,
|
||||||
components: themeComponents = {},
|
components: themeComponents = {},
|
||||||
|
@ -11,7 +11,7 @@ _Note:_ This theme **requires MDX v1** and will not work with previous versions
|
|||||||
```js
|
```js
|
||||||
// gatsby-config.js
|
// gatsby-config.js
|
||||||
module.exports = {
|
module.exports = {
|
||||||
__experimentalThemes: ['@mdx-deck/gatsby-theme'],
|
plugins: ['@mdx-deck/gatsby-theme'],
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -50,7 +50,7 @@ The following options can be passed to the gatsby theme.
|
|||||||
```js
|
```js
|
||||||
// gatsby-config.js
|
// gatsby-config.js
|
||||||
module.exports = {
|
module.exports = {
|
||||||
__experimentalThemes: [
|
plugins: [
|
||||||
{
|
{
|
||||||
resolve: '@mdx-deck/gatsby-theme',
|
resolve: '@mdx-deck/gatsby-theme',
|
||||||
options: {
|
options: {
|
||||||
|
@ -22,7 +22,7 @@ This is the MDX Deck Gatsby theme
|
|||||||
```js
|
```js
|
||||||
// gatsby-config.js
|
// gatsby-config.js
|
||||||
module.exports = {
|
module.exports = {
|
||||||
__experimentalThemes: [
|
plugins: [
|
||||||
'@mdx-deck/gatsby-theme',
|
'@mdx-deck/gatsby-theme',
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
@ -1 +0,0 @@
|
|||||||
export default () => false
|
|
@ -1 +0,0 @@
|
|||||||
export default () => false
|
|
@ -2,8 +2,6 @@ import React from 'react'
|
|||||||
import { navigate } from 'gatsby'
|
import { navigate } from 'gatsby'
|
||||||
import { Embed } from '@mdx-deck/components'
|
import { Embed } from '@mdx-deck/components'
|
||||||
import Root from './root'
|
import Root from './root'
|
||||||
import Header from './header'
|
|
||||||
import Footer from './footer'
|
|
||||||
|
|
||||||
const Thumb = props => (
|
const Thumb = props => (
|
||||||
<div
|
<div
|
||||||
@ -30,7 +28,6 @@ const Thumb = props => (
|
|||||||
|
|
||||||
export default props => (
|
export default props => (
|
||||||
<Root>
|
<Root>
|
||||||
<Header {...props} />
|
|
||||||
<ul
|
<ul
|
||||||
css={{
|
css={{
|
||||||
listStyle: 'none',
|
listStyle: 'none',
|
||||||
@ -57,6 +54,5 @@ export default props => (
|
|||||||
</li>
|
</li>
|
||||||
))}
|
))}
|
||||||
</ul>
|
</ul>
|
||||||
<Footer {...props} />
|
|
||||||
</Root>
|
</Root>
|
||||||
)
|
)
|
||||||
|
@ -1,29 +0,0 @@
|
|||||||
import React from 'react'
|
|
||||||
|
|
||||||
export default props => {
|
|
||||||
const { basepath } = props.pageContext || {}
|
|
||||||
const { theme, themes } = props
|
|
||||||
const arr = React.Children.toArray(props.children)
|
|
||||||
const splits = []
|
|
||||||
const slides = []
|
|
||||||
|
|
||||||
arr.forEach((child, i) => {
|
|
||||||
if (child.props.mdxType === 'hr') splits.push(i)
|
|
||||||
})
|
|
||||||
|
|
||||||
let previousSplit = 0
|
|
||||||
splits.forEach(i => {
|
|
||||||
const children = [...arr.slice(previousSplit, i)]
|
|
||||||
slides.push(() => children)
|
|
||||||
previousSplit = i + 1
|
|
||||||
})
|
|
||||||
slides.push(() => [...arr.slice(previousSplit)])
|
|
||||||
|
|
||||||
return {
|
|
||||||
...props,
|
|
||||||
theme,
|
|
||||||
themes,
|
|
||||||
slides,
|
|
||||||
basepath,
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,11 +1,11 @@
|
|||||||
import React from 'react'
|
import React from 'react'
|
||||||
import MDXRenderer from 'gatsby-mdx/mdx-renderer'
|
import { MDXRenderer } from 'gatsby-plugin-mdx'
|
||||||
import { graphql } from 'gatsby'
|
import { graphql } from 'gatsby'
|
||||||
import Layout from '../layouts/deck'
|
import Layout from '../layouts/deck'
|
||||||
|
|
||||||
export default props => {
|
export default props => {
|
||||||
const { mdx } = props.data
|
const { mdx } = props.data
|
||||||
const Component = props => <MDXRenderer {...props} children={mdx.code.body} />
|
const Component = props => <MDXRenderer {...props} children={mdx.body} />
|
||||||
|
|
||||||
return <Layout Component={Component} basepath={props.pageContext.basepath} />
|
return <Layout Component={Component} basepath={props.pageContext.basepath} />
|
||||||
}
|
}
|
||||||
@ -14,9 +14,7 @@ export const query = graphql`
|
|||||||
query($id: String!) {
|
query($id: String!) {
|
||||||
mdx(id: { eq: $id }) {
|
mdx(id: { eq: $id }) {
|
||||||
id
|
id
|
||||||
code {
|
|
||||||
body
|
body
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
`
|
`
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import React from 'react'
|
import React from 'react'
|
||||||
import { graphql } from 'gatsby'
|
import { graphql } from 'gatsby'
|
||||||
import MDXRenderer from 'gatsby-mdx/mdx-renderer'
|
import { MDXRenderer } from 'gatsby-plugin-mdx'
|
||||||
import get from 'lodash.get'
|
import get from 'lodash.get'
|
||||||
import Layout from '../layouts/index'
|
import Layout from '../layouts/index'
|
||||||
|
|
||||||
@ -15,8 +15,8 @@ export default props => {
|
|||||||
...node,
|
...node,
|
||||||
slug: node.fields.deck,
|
slug: node.fields.deck,
|
||||||
title: getTitle(node),
|
title: getTitle(node),
|
||||||
children: <MDXRenderer children={node.code.body} />,
|
children: <MDXRenderer children={node.body} />,
|
||||||
Component: props => <MDXRenderer {...props} children={node.code.body} />,
|
Component: props => <MDXRenderer {...props} children={node.body} />,
|
||||||
}))
|
}))
|
||||||
.filter(node => node.parent.sourceInstanceName === 'decks')
|
.filter(node => node.parent.sourceInstanceName === 'decks')
|
||||||
return <Layout {...props} decks={decks} />
|
return <Layout {...props} decks={decks} />
|
||||||
@ -31,9 +31,7 @@ export const query = graphql`
|
|||||||
fields {
|
fields {
|
||||||
deck
|
deck
|
||||||
}
|
}
|
||||||
code {
|
|
||||||
body
|
body
|
||||||
}
|
|
||||||
headings {
|
headings {
|
||||||
depth
|
depth
|
||||||
value
|
value
|
||||||
|
Loading…
Reference in New Issue
Block a user