Skip to content
This repository has been archived by the owner on Jan 24, 2025. It is now read-only.

Commit

Permalink
fix(docz-theme-default): link isActive logic
Browse files Browse the repository at this point in the history
  • Loading branch information
pedronauck committed Jul 5, 2018
1 parent 49c75bd commit 205ea8d
Showing 1 changed file with 82 additions and 35 deletions.
117 changes: 82 additions & 35 deletions packages/docz-theme-default/src/components/shared/Sidebar/Link.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,11 @@
import * as React from 'react'
import { SFC } from 'react'
import { Link as BaseLink, LinkProps as BaseLinkProps, Entry } from 'docz'
import { Component } from 'react'
import {
Link as BaseLink,
LinkProps as BaseLinkProps,
Entry,
ThemeConfig,
} from 'docz'

import styled, { css } from 'react-emotion'

Expand All @@ -25,10 +30,6 @@ export const linkStyle = (p: any) => css`
}
`

const LinkStyled = styled(BaseLink)`
${linkStyle};
`

interface LinkWrapperProps {
active: boolean
theme?: any
Expand Down Expand Up @@ -61,10 +62,6 @@ const LinkWrapper = styled('div')`
${(p: LinkWrapperProps) => p.active && activeWrapper(p)};
`

const isActive = (doc: Entry, location: any) => {
return doc.route === location.pathname
}

const SmallLink = styled(BaseLink)`
position: relative;
font-size: 14px;
Expand Down Expand Up @@ -114,30 +111,80 @@ interface LinkProps extends BaseLinkProps {
doc: Entry
}

export const Link: SFC<LinkProps> = ({ doc, onClick, ...props }) => {
const active = isActive(doc, location)

return (
<LinkWrapper active={active}>
<LinkStyled {...props} onClick={onClick} />
{active && (
<Submenu>
{doc.headings.map(
heading =>
heading.depth > 1 &&
heading.depth < 3 && (
<SmallLink
key={heading.slug}
onClick={onClick}
to={{ pathname: doc.route, hash: heading.slug }}
isActive={isSmallLinkActive(heading.slug)}
>
{heading.value}
</SmallLink>
)
interface LinkState {
active: boolean
}

export class Link extends Component<LinkProps, LinkState> {
public $el: HTMLElement | null
public state: LinkState = {
active: false,
}

constructor(props: LinkProps) {
super(props)
this.$el = null
}

public checkActive = (): boolean => {
if (this.$el) {
const classes = this.$el.classList
return classes.contains('active')
}

return false
}

public updateActive = (prevActive: boolean): void => {
const active = this.checkActive()
if (prevActive !== active) this.setState({ active })
}

public componentDidUpdate(prevProps: LinkProps, prevState: LinkState): void {
this.updateActive(prevState.active)
}

public componentDidMount(): void {
this.updateActive(this.state.active)
}

public render(): React.ReactNode {
const { doc, onClick, ...props } = this.props
const { active } = this.state

return (
<LinkWrapper active={active}>
<ThemeConfig>
{theme => (
<BaseLink
{...props}
className={linkStyle({ theme })}
onClick={onClick}
innerRef={(node: any) => {
this.$el = node
}}
/>
)}
</Submenu>
)}
</LinkWrapper>
)
</ThemeConfig>
{active && (
<Submenu>
{doc.headings.map(
heading =>
heading.depth > 1 &&
heading.depth < 3 && (
<SmallLink
key={heading.slug}
onClick={onClick}
to={{ pathname: doc.route, hash: heading.slug }}
isActive={isSmallLinkActive(heading.slug)}
>
{heading.value}
</SmallLink>
)
)}
</Submenu>
)}
</LinkWrapper>
)
}
}

0 comments on commit 205ea8d

Please sign in to comment.