mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-25 02:20:24 +00:00
aa0f9cd455
* Frameless Electron. Separate electron template. Generecize navigation link. Move nav info to config. * Add controls for language and node, network status to sidebar. * Sticky headers * Move custom node modal into standalone component. Render modals via portal. Add custom node modal opening to electron node list. * Conditional styling based on environment. * Fix active node highlight * Add frame back in, draggable only on OSX, fix sidebar scroll. * Remove panel content after delay. * Adjust window sizes * Style desktop help nav icon * Remove unused var * Move style to param * Remove unused * Update snapshot * Fix oversized stretching, zindex fighting * Make electron work better with various screen sizes * Remove not-working https option for electron * Add beta banner * Fix web footer * Address changes
63 lines
1.9 KiB
TypeScript
63 lines
1.9 KiB
TypeScript
import classnames from 'classnames';
|
|
import React from 'react';
|
|
import { Link, withRouter, RouteComponentProps } from 'react-router-dom';
|
|
import translate, { translateRaw } from 'translations';
|
|
import { NavigationLink } from 'config';
|
|
|
|
interface Props extends RouteComponentProps<{}> {
|
|
link: NavigationLink;
|
|
isHomepage: boolean;
|
|
className: string;
|
|
}
|
|
|
|
class NavigationLinkClass extends React.PureComponent<Props, {}> {
|
|
public render() {
|
|
const { link, location, isHomepage, className } = this.props;
|
|
let isActive = false;
|
|
|
|
if (!link.external) {
|
|
// isActive if
|
|
// 1) Current path is the same as link
|
|
// 2) the first path is the same for both links (/account and /account/send)
|
|
// 3) we're at the root path and this is the "homepage" nav item
|
|
const isSubRoute = location.pathname.split('/')[1] === link.to.split('/')[1];
|
|
isActive =
|
|
location.pathname === link.to || isSubRoute || (isHomepage && location.pathname === '/');
|
|
}
|
|
|
|
const linkClasses = classnames({
|
|
[`${className}-link`]: true,
|
|
'is-disabled': !link.to,
|
|
'is-active': isActive
|
|
});
|
|
const linkLabel = `nav item: ${translateRaw(link.name)}`;
|
|
|
|
const linkEl =
|
|
link.external || !link.to ? (
|
|
<a
|
|
className={linkClasses}
|
|
href={link.to}
|
|
aria-label={linkLabel}
|
|
target="_blank"
|
|
rel="noopener noreferrer"
|
|
>
|
|
{translate(link.name)}
|
|
<i className={`${className}-link-icon fa fa-external-link`} />
|
|
</a>
|
|
) : (
|
|
<Link className={linkClasses} to={(link as any).to} aria-label={linkLabel}>
|
|
{translate(link.name)}
|
|
</Link>
|
|
);
|
|
|
|
return (
|
|
<li id={link.name} className={className}>
|
|
{linkEl}
|
|
</li>
|
|
);
|
|
}
|
|
}
|
|
|
|
// withRouter is a HOC which provides NavigationLink with a react-router location prop
|
|
export default withRouter<Props>(NavigationLinkClass);
|