mon-entreprise/source/components/RuleLink.js

42 lines
935 B
JavaScript
Raw Normal View History

/* @flow */
2018-07-12 08:09:41 +00:00
import withColours from 'Components/utils/withColours'
import withSitePaths from 'Components/utils/withSitePaths'
import { encodeRuleName, nameLeaf } from 'Engine/rules'
import { compose } from 'ramda'
import React from 'react'
import { Link } from 'react-router-dom'
import './RuleLink.css'
import type { Règle } from 'Types/RegleTypes'
import type { ThemeColours } from 'Components/utils/withColours'
type Props = Règle & {
sitePaths: Object,
style: CSSStyleDeclaration,
colours: ThemeColours
}
const RuleLink = ({
dottedName,
2019-07-01 15:59:57 +00:00
title,
colours: { colour },
style,
sitePaths,
children
}: Props) => {
const newPath =
sitePaths.documentation.index + '/' + encodeRuleName(dottedName)
2019-07-01 15:59:57 +00:00
return (
<Link
to={newPath}
className="rule-link"
style={{ color: colour, ...style }}>
{children || title || nameLeaf(dottedName)}
</Link>
)
}
export default compose(
withSitePaths,
withColours
)(RuleLink)