1
0
mirror of https://github.com/oceanprotocol/docs.git synced 2024-11-26 19:49:26 +01:00

add TOC functionality

This commit is contained in:
Matthias Kretschmann 2019-03-26 23:30:03 +01:00
parent f28289c301
commit 2fd5410a0e
Signed by: m
GPG Key ID: 606EEEF3C479A91F
3 changed files with 72 additions and 4 deletions

View File

@ -0,0 +1,59 @@
import React, { PureComponent } from 'react'
import PropTypes from 'prop-types'
import slugify from 'slugify'
// import Scrollspy from 'react-scrollspy'
import Scroll from '../../components/Scroll'
import { cleanPaths } from './utils'
// import stylesSidebar from '../../components/Sidebar.module.scss'
export default class Toc extends PureComponent {
static propTypes = {
data: PropTypes.object.isRequired
}
state = {
subIds: []
}
componentWillMount() {
this.getSubIds()
}
getSubIds = () =>
Object.keys(this.props.data).map(path => {
const cleanedPath = cleanPaths(path)
const slug = slugify(cleanedPath, {
remove: /[*+~.()'"/!:@]/g
})
this.setState(prevState => ({
subIds: [...prevState.subIds, slug]
}))
})
items = Object.keys(this.props.data).map(path => {
const cleanedPath = cleanPaths(path)
const slug = slugify(cleanedPath, {
remove: /[*+~.()'"/!:@]/g
})
return (
<li key={path}>
<Scroll type="id" element={slug} offset={-20}>
<code>{cleanedPath}</code>
</Scroll>
{/* <Scrollspy
items={this.state.subIds}
currentClassName={stylesSidebar.scrollspyActive}
offset={-30}
>
{cleanedPath}
</Scrollspy> */}
</li>
)
})
render() {
return <ul>{this.items}</ul>
}
}

View File

@ -2,6 +2,7 @@ import React, { Component } from 'react'
import PropTypes from 'prop-types' import PropTypes from 'prop-types'
import { graphql } from 'gatsby' import { graphql } from 'gatsby'
import Helmet from 'react-helmet' import Helmet from 'react-helmet'
import slugify from 'slugify'
import Layout from '../../components/Layout' import Layout from '../../components/Layout'
import Content from '../../components/Content' import Content from '../../components/Content'
import HeaderSection from '../../components/HeaderSection' import HeaderSection from '../../components/HeaderSection'
@ -10,16 +11,21 @@ import DocHeader from '../../components/DocHeader'
import SEO from '../../components/Seo' import SEO from '../../components/Seo'
import stylesDoc from '../Doc.module.scss' import stylesDoc from '../Doc.module.scss'
import Toc from './Toc'
import { cleanPaths } from './utils'
const title = 'squid-java' const title = 'squid-java'
const description = 'Java client library for Ocean Protocol' const description = 'Java client library for Ocean Protocol'
const version = '0.2.0' const version = '0.2.0'
const cleanPaths = path =>
path.replace('src/main/java/com/oceanprotocol/squid/', '')
const Paths = ({ javadoc }) => { const Paths = ({ javadoc }) => {
return Object.keys(javadoc).map(path => ( return Object.keys(javadoc).map(path => (
<div key={path}> <div
key={path}
id={slugify(cleanPaths(path), {
remove: /[*+~.()'"/!:@]/g
})}
>
<h2 className={stylesDoc.pathName}> <h2 className={stylesDoc.pathName}>
<code>{cleanPaths(path)}</code> <code>{cleanPaths(path)}</code>
</h2> </h2>
@ -70,6 +76,7 @@ export default class JavadocTemplate extends Component {
sidebar={'references'} sidebar={'references'}
collapsed collapsed
toc toc
tocComponent={<Toc data={javadoc} />}
/> />
</aside> </aside>
<article className={stylesDoc.main}> <article className={stylesDoc.main}>

View File

@ -0,0 +1,2 @@
export const cleanPaths = path =>
path.replace('src/main/java/com/oceanprotocol/squid/', '')