use reflow to migrate from flow to typescript

This commit is contained in:
Sebastian Sdorra
2019-10-19 16:38:07 +02:00
parent f7b8050dfa
commit 6e7a08a3bb
495 changed files with 14239 additions and 13766 deletions

View File

@@ -0,0 +1,56 @@
import * as React from 'react';
import classNames from 'classnames';
import { Link, Route } from 'react-router-dom';
// TODO mostly copy of PrimaryNavigationLink
type Props = {
to: string;
icon?: string;
label: string;
activeOnlyWhenExact?: boolean;
activeWhenMatch?: (route: any) => boolean;
};
class NavLink extends React.Component<Props> {
static defaultProps = {
activeOnlyWhenExact: true,
};
isActive(route: any) {
const { activeWhenMatch } = this.props;
return route.match || (activeWhenMatch && activeWhenMatch(route));
}
renderLink = (route: any) => {
const { to, icon, label } = this.props;
let showIcon = null;
if (icon) {
showIcon = (
<>
<i className={classNames(icon, 'fa-fw')} />{' '}
</>
);
}
return (
<li>
<Link className={this.isActive(route) ? 'is-active' : ''} to={to}>
{showIcon}
{label}
</Link>
</li>
);
};
render() {
const { to, activeOnlyWhenExact } = this.props;
return (
<Route path={to} exact={activeOnlyWhenExact} children={this.renderLink} />
);
}
}
export default NavLink;