mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-02-21 15:28:32 +00:00
* Refactor babel/types * Refactor entry point * Refactor actions * Refactor api * Full project refactor -- Broad type fixing sweep * - completely fix merge conflicts - handle various type errors * Add tslint to package.json * Dependency cleanup * Fix module resolution * Work on type definitions for untyped libs * progress commit * Add more definition typing * various type additions * Add unit types * Fix sagaiterator + unit types * various types added * additional type additions * Fix typing on Sagas * remove flowfixmes; swap translate for translateRaw * Get rid of contracts - awaiting Henry's contract PR * Remove contracts from routing * Fix most of actions/reducers * refactor actions directory structure * fix reducer action type imports * Fix most of type errors pre-actions refactor * fix action creator imports in containers * Refactor more * Refactor index of actions * fix action imports; use module level index export * package-lock.json updated * Use action types in props * Type up action creators * Fix most of connect errors * Typefixing progress * More types * Fix run-time errors * Caching improvements for webpack * Remove path resolve from webpack * Update non-breaking packages to latest version * Fix token typing * Remove unused color code * Fix wallet decrypt dispatch * Set redux-form related props/functions to ANY, since we're stripping it out later on * Revert BigNumber.js package changes * Extend window to custom object for Perf * Format Navigation * Typecase keystore errors as any (since we shouldnt touch this) * Push wallet context fix * - find/replace value->payload in swap - properly type swap state properties - extract inline reducer into reducer function * - type local storage retrieved items as generic * - bind all RPCClient methods with fat arrow * - reformat * Change to enums for constants * Change state into any * Fix swap errors * ensure that seconds are passed into state as integers * Fix rest of errors * use parseInt explicitly instead of type coercion * Fix derivation-checker, remove flow command, add tslint command, add tslint-react, tell travis to use tslint instead of flow. * Whoops, remove those tests. * Remove unsupported (yet) config option. * Fix precommit to target ts and tsx files. * Fix some errors, ignore some silly rules. * Revert jest to v19, use ts-jest and make all tests typescript. Fixes all but one. * Get rid of saga tests * Fix tslint errors
132 lines
4.0 KiB
TypeScript
132 lines
4.0 KiB
TypeScript
import { TChangeGasPrice, TChangeLanguage, TChangeNode } from 'actions/config';
|
|
import logo from 'assets/images/logo-myetherwallet.svg';
|
|
import { Dropdown } from 'components/ui';
|
|
import React, { Component } from 'react';
|
|
import { Link } from 'react-router';
|
|
import {
|
|
ANNOUNCEMENT_MESSAGE,
|
|
ANNOUNCEMENT_TYPE,
|
|
languages,
|
|
NETWORKS,
|
|
NODES,
|
|
VERSION
|
|
} from '../../config/data';
|
|
import GasPriceDropdown from './components/GasPriceDropdown';
|
|
import Navigation from './components/Navigation';
|
|
|
|
import './index.scss';
|
|
|
|
interface Props {
|
|
location: {};
|
|
languageSelection: string;
|
|
nodeSelection: string;
|
|
gasPriceGwei: number;
|
|
|
|
changeLanguage: TChangeLanguage;
|
|
changeNode: TChangeNode;
|
|
changeGasPrice: TChangeGasPrice;
|
|
}
|
|
|
|
export default class Header extends Component<Props, {}> {
|
|
public render() {
|
|
const { languageSelection, changeNode, nodeSelection } = this.props;
|
|
const selectedLanguage =
|
|
languages.find(l => l.sign === languageSelection) || languages[0];
|
|
const selectedNode = NODES[nodeSelection];
|
|
const selectedNetwork = NETWORKS[selectedNode.network];
|
|
const LanguageDropDown = Dropdown as new () => Dropdown<
|
|
typeof selectedLanguage
|
|
>;
|
|
const NodeDropDown = Dropdown as new () => Dropdown<keyof typeof NODES>;
|
|
return (
|
|
<div className="Header">
|
|
{ANNOUNCEMENT_MESSAGE && (
|
|
<div
|
|
className={`Header-announcement is-${ANNOUNCEMENT_TYPE}`}
|
|
dangerouslySetInnerHTML={{
|
|
__html: ANNOUNCEMENT_MESSAGE
|
|
}}
|
|
/>
|
|
)}
|
|
|
|
<section className="Header-branding">
|
|
<section className="Header-branding-inner container">
|
|
<Link
|
|
to={'/'}
|
|
className="Header-branding-title"
|
|
aria-label="Go to homepage"
|
|
>
|
|
{/* TODO - don't hardcode image path*/}
|
|
<img
|
|
className="Header-branding-title-logo"
|
|
src={logo}
|
|
height="64px"
|
|
width="245px"
|
|
alt="MyEtherWallet"
|
|
/>
|
|
</Link>
|
|
<div className="Header-branding-title-tagline">
|
|
<span className="Header-branding-title-tagline-version">
|
|
v{VERSION}
|
|
</span>
|
|
|
|
<GasPriceDropdown
|
|
value={this.props.gasPriceGwei}
|
|
onChange={this.props.changeGasPrice}
|
|
/>
|
|
|
|
<LanguageDropDown
|
|
ariaLabel={`change language. current language ${selectedLanguage.name}`}
|
|
options={languages}
|
|
formatTitle={this.extractName}
|
|
value={selectedLanguage}
|
|
extra={[
|
|
<li key={'separator'} role="separator" className="divider" />,
|
|
<li key={'disclaimer'}>
|
|
<a data-toggle="modal" data-target="#disclaimerModal">
|
|
Disclaimer
|
|
</a>
|
|
</li>
|
|
]}
|
|
onChange={this.changeLanguage}
|
|
/>
|
|
|
|
<NodeDropDown
|
|
ariaLabel={`change node. current node ${selectedNode.network} node by ${selectedNode.service}`}
|
|
options={Object.keys(NODES)}
|
|
formatTitle={this.nodeNetworkAndService}
|
|
value={nodeSelection}
|
|
extra={
|
|
<li>
|
|
<a>Add Custom Node</a>
|
|
</li>
|
|
}
|
|
onChange={changeNode}
|
|
/>
|
|
</div>
|
|
</section>
|
|
</section>
|
|
|
|
<Navigation
|
|
location={this.props.location}
|
|
// color={selectedNetwork.color}
|
|
/>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
public changeLanguage = (value: { sign: string }) => {
|
|
this.props.changeLanguage(value.sign);
|
|
};
|
|
|
|
private extractName(): (option: { sign: string; name: string }) => string {
|
|
return name;
|
|
}
|
|
|
|
private nodeNetworkAndService = (option: string) => [
|
|
NODES[option].network,
|
|
' ',
|
|
<small key="service">({NODES[option].service}) </small>
|
|
];
|
|
}
|