mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-20 07:58:51 +00:00
68e5972a03
* add route and nav tab for new module * add new module to tabs index * add signMessage to wallet interface * add signed message verification, normalize pkey sign * init Sign & Verify Message tab * reorder imports * mock out Trezor * cast to bool instead of length check * normalize ledger sign message * fix broken this context * add commented message signing to trezor wallet * correct var to start on sign tab * remove unused state var * clean up SignMessage classes * clean up VerifyMessage classes, remove unnecessary log * correct event variable types * remove unnecessary exports * remove empty classname * use implicit return * shorten signMessage method * remove unnecessary disable * tweak variable name * make better use of destructuring, remove console log * use destructured var * flatten if statement * add signMessage method to wallet reducer test
88 lines
2.7 KiB
TypeScript
88 lines
2.7 KiB
TypeScript
import React, { Component } from 'react';
|
|
import { Provider } from 'react-redux';
|
|
import { withRouter, Switch, Redirect, Router, Route } from 'react-router-dom';
|
|
// Components
|
|
import Contracts from 'containers/Tabs/Contracts';
|
|
import ENS from 'containers/Tabs/ENS';
|
|
import GenerateWallet from 'containers/Tabs/GenerateWallet';
|
|
import Help from 'containers/Tabs/Help';
|
|
import SendTransaction from 'containers/Tabs/SendTransaction';
|
|
import Swap from 'containers/Tabs/Swap';
|
|
import ViewWallet from 'containers/Tabs/ViewWallet';
|
|
import SignAndVerifyMessage from 'containers/Tabs/SignAndVerifyMessage';
|
|
import BroadcastTx from 'containers/Tabs/BroadcastTx';
|
|
|
|
// TODO: fix this
|
|
interface Props {
|
|
store: any;
|
|
history: any;
|
|
}
|
|
|
|
export default class Root extends Component<Props, {}> {
|
|
public render() {
|
|
const { store, history } = this.props;
|
|
// key={Math.random()} = hack for HMR from https://github.com/webpack/webpack-dev-server/issues/395
|
|
return (
|
|
<Provider store={store} key={Math.random()}>
|
|
<Router history={history} key={Math.random()}>
|
|
<div>
|
|
<Route exact={true} path="/" component={GenerateWallet} />
|
|
<Route path="/view-wallet" component={ViewWallet} />
|
|
<Route path="/help" component={Help} />
|
|
<Route path="/swap" component={Swap} />
|
|
<Route path="/send-transaction" component={SendTransaction} />
|
|
<Route path="/contracts" component={Contracts} />
|
|
<Route path="/ens" component={ENS} />
|
|
<Route
|
|
path="/sign-and-verify-message"
|
|
component={SignAndVerifyMessage}
|
|
/>
|
|
<Route path="/pushTx" component={BroadcastTx} />
|
|
|
|
<LegacyRoutes />
|
|
</div>
|
|
</Router>
|
|
</Provider>
|
|
);
|
|
}
|
|
}
|
|
|
|
const LegacyRoutes = withRouter(props => {
|
|
const { history } = props;
|
|
const { pathname, hash } = props.location;
|
|
|
|
if (pathname === '/') {
|
|
switch (hash) {
|
|
case '#send-transaction':
|
|
case '#offline-transaction':
|
|
history.push('/send-transaction');
|
|
break;
|
|
case '#generate-wallet':
|
|
history.push('/');
|
|
break;
|
|
case '#swap':
|
|
history.push('/swap');
|
|
break;
|
|
case '#contracts':
|
|
history.push('/contracts');
|
|
break;
|
|
case '#ens':
|
|
history.push('/ens');
|
|
break;
|
|
case '#view-wallet-info':
|
|
history.push('/view-wallet');
|
|
break;
|
|
case '#check-tx-status':
|
|
history.push('/check-tx-status');
|
|
break;
|
|
}
|
|
}
|
|
|
|
return (
|
|
<Switch>
|
|
<Redirect from="/signmsg.html" to="/sign-and-verify-message" />
|
|
<Redirect from="/helpers.html" to="/helpers" />
|
|
</Switch>
|
|
);
|
|
});
|