MyCrypto/common/containers/Tabs/SendTransaction/index.tsx

102 lines
3.0 KiB
TypeScript

import React from 'react';
import { connect } from 'react-redux';
import translate from 'translations';
import TabSection from 'containers/TabSection';
import { UnlockHeader } from 'components/ui';
import { SideBar } from './components/index';
import { getWalletInst } from 'selectors/wallet';
import { AppState } from 'reducers';
import { RouteComponentProps, Route, Switch, Redirect } from 'react-router';
import {
WalletInfo,
RequestPayment,
Fields,
UnavailableWallets
} from 'containers/Tabs/SendTransaction/components';
import SubTabs, { Tab } from 'components/SubTabs';
import { getNetworkConfig } from 'selectors/config';
import { isNetworkUnit } from 'utils/network';
import { RouteNotFound } from 'components/RouteNotFound';
const Send = () => (
<React.Fragment>
<Fields />
<UnavailableWallets />
</React.Fragment>
);
interface StateProps {
wallet: AppState['wallet']['inst'];
network: AppState['config']['network'];
}
type Props = StateProps & RouteComponentProps<{}>;
class SendTransaction extends React.Component<Props> {
public render() {
const { wallet, match } = this.props;
const currentPath = match.url;
const tabs: Tab[] = [
{
path: 'send',
name: translate('NAV_SendEther'),
disabled: !!wallet && !!wallet.isReadOnly
},
{
path: 'request',
name: translate('Request Payment'),
disabled: !isNetworkUnit(this.props.network, 'ETH')
},
{
path: 'info',
name: translate('NAV_ViewWallet')
}
];
return (
<TabSection>
<section className="Tab-content">
<UnlockHeader title={translate('Account')} />
<div className="SubTabs row">
<div className="col-sm-8">{wallet && <SubTabs tabs={tabs} match={match} />}</div>
<div className="col-sm-8">
<Switch>
<Route
exact={true}
path={currentPath}
render={() => (
<Redirect
from={`${currentPath}`}
to={`${
wallet && wallet.isReadOnly ? currentPath + '/info' : currentPath + '/send'
}`}
/>
)}
/>
<Route exact={true} path={`${currentPath}/send`} component={Send} />
<Route
path={`${currentPath}/info`}
exact={true}
render={() => wallet && <WalletInfo wallet={wallet} />}
/>
<Route
path={`${currentPath}/request`}
exact={true}
render={() => <RequestPayment wallet={wallet} />}
/>
<RouteNotFound />
</Switch>
</div>
<SideBar />
</div>
</section>
</TabSection>
);
}
}
export default connect((state: AppState) => ({
wallet: getWalletInst(state),
network: getNetworkConfig(state)
}))(SendTransaction);