1
0
mirror of https://github.com/trezor/trezor-wallet synced 2024-11-28 03:08:30 +00:00

restructuring "./src/js/components/wallet' directory

This commit is contained in:
Szymon Lesisz 2018-05-18 18:26:45 +02:00
parent e3243ffa7e
commit 8f5c87a02e
23 changed files with 130 additions and 104 deletions

View File

@ -12,6 +12,9 @@ import { JSONRequest, httpRequest } from '../utils/networkUtils';
import type { ThunkAction, AsyncAction, GetState, Dispatch, TrezorDevice } from '../flowtype';
import type { Config, Coin, TokensCollection } from '../reducers/LocalStorageReducer';
import AppConfigJSON from '~/data/appConfig.json';
import Erc20AbiJSON from '~/data/ERC20Abi.json';
export type StorageAction = {
type: typeof STORAGE.READY,
config: Config,
@ -85,8 +88,8 @@ export function loadTokensFromJSON(): AsyncAction {
if (typeof window.localStorage === 'undefined') return;
try {
const config: Config = await httpRequest('data/appConfig.json', 'json');
const ERC20Abi = await httpRequest('data/ERC20Abi.json', 'json');
const config: Config = await httpRequest(AppConfigJSON, 'json');
const ERC20Abi = await httpRequest(Erc20AbiJSON, 'json');
window.addEventListener('storage', event => {
dispatch( update(event) );

View File

@ -2,37 +2,17 @@
'use strict';
import React, { Component } from 'react';
import { bindActionCreators } from 'redux';
import { connect } from 'react-redux';
import Tooltip from 'rc-tooltip';
import { QRCode } from 'react-qr-svg';
import AbstractAccount from './account/AbstractAccount';
import { Notification } from '../common/Notification';
import { default as ReceiveActions } from '../../actions/ReceiveActions';
import { default as AbstractAccountActions } from '../../actions/AbstractAccountActions';
import AbstractAccount from '../AbstractAccount';
import { Notification } from '../../../common/Notification';
import type { MapStateToProps, MapDispatchToProps } from 'react-redux';
import type { State, Dispatch } from '../../flowtype';
import type { StateProps as BaseStateProps, DispatchProps as BaseDispatchProps } from './account/AbstractAccount';
import type { AccountState } from '../AbstractAccount';
import type { Props } from './index';
import type { AccountState } from './account/AbstractAccount';
type OwnProps = { }
type StateProps = BaseStateProps & {
receive: $ElementType<State, 'receive'>,
}
type DispatchProps = BaseDispatchProps & {
showAddress: typeof ReceiveActions.showAddress
}
type Props = StateProps & DispatchProps;
class Receive extends AbstractAccount<Props> {
export default class Receive extends AbstractAccount<Props> {
render() {
return super.render() || _render(this.props, this.state);
}
@ -58,7 +38,7 @@ const _render = (props: Props, state: AccountState): React$Element<string> => {
let address = `${account.address.substring(0, 20)}...`;
let className = 'address hidden';
let button = (
<button disabled={ device.connected && !discovery.completed } onClick={ event => props.showAddress(account.addressPath) }>
<button disabled={ device.connected && !discovery.completed }>
<span>Show full address</span>
</button>
);
@ -87,7 +67,7 @@ const _render = (props: Props, state: AccountState): React$Element<string> => {
arrowContent={<div className="rc-tooltip-arrow-inner"></div>}
overlay={ tooltip }
placement="bottomRight">
<button className="white" onClick={ event => props.showAddress(account.addressPath) }>
<button className="white">
<span></span>
</button>
</Tooltip>
@ -108,27 +88,4 @@ const _render = (props: Props, state: AccountState): React$Element<string> => {
{ qrCode }
</section>
);
}
const mapStateToProps: MapStateToProps<State, OwnProps, StateProps> = (state: State, own: OwnProps): StateProps => {
return {
abstractAccount: state.abstractAccount,
devices: state.connect.devices,
accounts: state.accounts,
discovery: state.discovery,
receive: state.receive
};
}
const mapDispatchToProps: MapDispatchToProps<Dispatch, OwnProps, DispatchProps> = (dispatch: Dispatch): DispatchProps => {
return {
abstractAccountActions: bindActionCreators(AbstractAccountActions, dispatch),
initAccount: bindActionCreators(ReceiveActions.init, dispatch),
disposeAccount: bindActionCreators(ReceiveActions.dispose, dispatch),
showAddress: bindActionCreators(ReceiveActions.showAddress, dispatch),
};
}
export default connect(mapStateToProps, mapDispatchToProps)(Receive);

View File

@ -0,0 +1,54 @@
/* @flow */
'use strict';
import React, { Component, PropTypes } from 'react';
import { bindActionCreators } from 'redux';
import { connect } from 'react-redux';
import { default as ReceiveActions } from '../../../../actions/ReceiveActions';
import { default as AbstractAccountActions } from '../../../../actions/AbstractAccountActions';
import * as TokenActions from '../../../../actions/TokenActions';
import Receive from './Receive';
import type { MapStateToProps, MapDispatchToProps } from 'react-redux';
import type { State, Dispatch } from '../../../../flowtype';
import type {
StateProps as BaseStateProps,
DispatchProps as BaseDispatchProps
} from '../AbstractAccount';
import type { AccountState } from '../AbstractAccount';
type OwnProps = { }
type StateProps = BaseStateProps & {
receive: $ElementType<State, 'receive'>,
}
type DispatchProps = BaseDispatchProps & {
showAddress: typeof ReceiveActions.showAddress
};
export type Props = StateProps & DispatchProps;
const mapStateToProps: MapStateToProps<State, OwnProps, StateProps> = (state: State, own: OwnProps): StateProps => {
return {
abstractAccount: state.abstractAccount,
devices: state.connect.devices,
accounts: state.accounts,
discovery: state.discovery,
receive: state.receive
};
}
const mapDispatchToProps: MapDispatchToProps<Dispatch, OwnProps, DispatchProps> = (dispatch: Dispatch): DispatchProps => {
return {
abstractAccountActions: bindActionCreators(AbstractAccountActions, dispatch),
initAccount: bindActionCreators(ReceiveActions.init, dispatch),
disposeAccount: bindActionCreators(ReceiveActions.dispose, dispatch),
showAddress: bindActionCreators(ReceiveActions.showAddress, dispatch),
};
}
export default connect(mapStateToProps, mapDispatchToProps)(Receive);

View File

@ -3,7 +3,14 @@
import React from 'react';
import Tooltip from 'rc-tooltip';
import type { Props } from './index';
import type { Props as BaseProps } from './index';
type Props = {
abstractAccount: $ElementType<BaseProps, 'abstractAccount'>,
sendForm: $ElementType<BaseProps, 'sendForm'>,
sendFormActions: $ElementType<BaseProps, 'sendFormActions'>,
children?: $ElementType<BaseProps, 'children'>,
};
const AdvancedForm = (props: Props) => {

View File

@ -5,14 +5,16 @@ import React from 'react';
import ColorHash from 'color-hash';
import ScaleText from 'react-scale-text';
import { findAccountTokens } from '../../../reducers/TokensReducer';
import { findAccountTokens } from '../../../../reducers/TokensReducer';
import type { Props as ParentProps } from './index';
import type { Coin } from '../../../reducers/LocalStorageReducer';
import type { Account } from '../../../reducers/AccountsReducer';
import type { Token } from '../../../reducers/TokensReducer';
import type { Coin } from '../../../../reducers/LocalStorageReducer';
import type { Account } from '../../../../reducers/AccountsReducer';
import type { Token } from '../../../../reducers/TokensReducer';
import type { Props as BaseProps } from './index';
type Props = ParentProps & {
type Props = {
pending: $ElementType<BaseProps, 'pending'>,
tokens: $ElementType<BaseProps, 'tokens'>,
account: Account,
selectedCoin: Coin
}

View File

@ -6,12 +6,12 @@ import Select from 'react-select';
import AdvancedForm from './AdvancedForm';
import PendingTransactions from './PendingTransactions';
import { FeeSelectValue, FeeSelectOption } from './FeeSelect';
import { Notification } from '../../common/Notification';
import AbstractAccount from '../account/AbstractAccount';
import { findAccountTokens } from '../../../reducers/TokensReducer';
import { Notification } from '../../../common/Notification';
import AbstractAccount from '../AbstractAccount';
import { findAccountTokens } from '../../../../reducers/TokensReducer';
import type { Props } from './index';
import type { AccountState } from '../account/AbstractAccount';
import type { AccountState } from '../AbstractAccount';
export default class Send extends AbstractAccount<Props> {
render() {
@ -19,7 +19,6 @@ export default class Send extends AbstractAccount<Props> {
}
}
const _render = (props: Props, state: AccountState): React$Element<string> => {
const {
@ -177,12 +176,16 @@ const _render = (props: Props, state: AccountState): React$Element<string> => {
options={ feeLevels } />
</div>
<AdvancedForm { ...props}>
<AdvancedForm
abstractAccount={ props.abstractAccount }
sendForm={ props.sendForm }
sendFormActions={ props.sendFormActions }>
<button disabled={ buttonDisabled } onClick={ event => onSend() }>{ buttonLabel }</button>
</AdvancedForm>
<PendingTransactions
{ ...props }
pending={ props.pending }
tokens={ props.tokens }
account={ account }
selectedCoin={ selectedCoin } />

View File

@ -5,17 +5,17 @@ import * as React from 'react';
import { bindActionCreators } from 'redux';
import { connect } from 'react-redux';
import { default as SendFormActions } from '../../../actions/SendFormActions';
import { default as AbstractAccountActions } from '../../../actions/AbstractAccountActions';
import { default as SendFormActions } from '../../../../actions/SendFormActions';
import { default as AbstractAccountActions } from '../../../../actions/AbstractAccountActions';
import SendForm from './SendForm';
import type { MapStateToProps, MapDispatchToProps } from 'react-redux';
import type { State, Dispatch } from '../../../flowtype';
import type { StateProps as BaseStateProps, DispatchProps as BaseDispatchProps } from '../account/AbstractAccount';
import type { State, Dispatch } from '../../../../flowtype';
import type { StateProps as BaseStateProps, DispatchProps as BaseDispatchProps } from '../AbstractAccount';
type OwnProps = { }
type StateProps = BaseStateProps & {
export type StateProps = BaseStateProps & {
tokens: $ElementType<State, 'tokens'>,
pending: $ElementType<State, 'pending'>,
sendForm: $ElementType<State, 'sendForm'>,
@ -24,7 +24,7 @@ type StateProps = BaseStateProps & {
children?: React.Node;
}
type DispatchProps = BaseDispatchProps & {
export type DispatchProps = BaseDispatchProps & {
sendFormActions: typeof SendFormActions
}

View File

@ -6,20 +6,20 @@ import BigNumber from 'bignumber.js';
import { Async } from 'react-select';
import Tooltip from 'rc-tooltip';
import { resolveAfter } from '../../../utils/promiseUtils';
import AbstractAccount from '../account/AbstractAccount';
import { Notification } from '../../common/Notification';
import { resolveAfter } from '../../../../utils/promiseUtils';
import AbstractAccount from '../AbstractAccount';
import { Notification } from '../../../common/Notification';
import SummaryDetails from './SummaryDetails.js';
import SummaryTokens from './SummaryTokens.js';
import type { Props } from './index';
import type { AccountState } from '../account/AbstractAccount';
import type { AccountState } from '../AbstractAccount';
import type { TrezorDevice } from '../../../flowtype';
import type { NetworkToken } from '../../../reducers/LocalStorageReducer';
import type { Account } from '../../../reducers/AccountsReducer';
import type { Discovery } from '../../../reducers/DiscoveryReducer';
import { findAccountTokens } from '../../../reducers/TokensReducer';
import type { TrezorDevice } from '../../../../flowtype';
import type { NetworkToken } from '../../../../reducers/LocalStorageReducer';
import type { Account } from '../../../../reducers/AccountsReducer';
import type { Discovery } from '../../../../reducers/DiscoveryReducer';
import { findAccountTokens } from '../../../../reducers/TokensReducer';
export default class Summary extends AbstractAccount<Props> {
render() {

View File

@ -5,7 +5,7 @@ import React from 'react';
import BigNumber from 'bignumber.js';
import type { Props as BaseProps } from './index';
import type { Coin } from '../../../reducers/LocalStorageReducer';
import type { Coin } from '../../../../reducers/LocalStorageReducer';
type Props = {
// coin: $PropertyType<$ElementType<BaseProps, 'abstractAccount'>, 'coin'>,

View File

@ -6,14 +6,13 @@ import { bindActionCreators } from 'redux';
import { connect } from 'react-redux';
import Summary from './Summary';
import { default as AbstractAccountActions } from '../../../actions/AbstractAccountActions';
import * as SummaryActions from '../../../actions/SummaryActions';
import * as TokenActions from '../../../actions/TokenActions';
import { default as AbstractAccountActions } from '../../../../actions/AbstractAccountActions';
import * as SummaryActions from '../../../../actions/SummaryActions';
import * as TokenActions from '../../../../actions/TokenActions';
import type { ActionCreators } from 'redux';
import type { MapStateToProps, MapDispatchToProps } from 'react-redux';
import type { State, Dispatch } from '../../../flowtype';
import type { StateProps as BaseStateProps, DispatchProps as BaseDispatchProps } from '../account/AbstractAccount';
import type { State, Dispatch } from '../../../../flowtype';
import type { StateProps as BaseStateProps, DispatchProps as BaseDispatchProps } from '../AbstractAccount';
type OwnProps = { }

View File

@ -9,7 +9,7 @@ import { Route, withRouter } from 'react-router-dom';
import Header from '../common/Header';
import Footer from '../common/Footer';
import AccountTabs from './account/AccountTabs';
import DeviceSettingsTabs from './account/DeviceSettingsTabs';
import DeviceSettingsTabs from './pages/DeviceSettingsTabs';
import AsideContainer from './aside';
import ModalContainer from '../modal';
import Notifications from '../common/Notification';

View File

@ -4,10 +4,10 @@
import React from 'react';
import { bindActionCreators } from 'redux';
import { connect } from 'react-redux';
import { Notification } from '../common/Notification';
import * as TrezorConnectActions from '../../actions/TrezorConnectActions';
import { Notification } from '../../common/Notification';
import * as TrezorConnectActions from '../../../actions/TrezorConnectActions';
import type { State, Dispatch } from '../../flowtype';
import type { State, Dispatch } from '../../../flowtype';
type Props = {
connect: $ElementType<State, 'connect'>,
acquireDevice: typeof TrezorConnectActions.acquire

View File

@ -4,6 +4,7 @@
import React from 'react';
import { bindActionCreators } from 'redux';
import { connect } from 'react-redux';
import DashboardImg from '~/images/dashboard.png';
const Dashboard = () => {
return (
@ -12,7 +13,7 @@ const Dashboard = () => {
<div className="row">
<h2>Please select your coin</h2>
<p>You will gain access to recieving &amp; sending selected coin</p>
<img src="./images/dashboard.png" height="34" width="auto" alt="Dashboard" />
<img src={ DashboardImg } height="34" width="auto" alt="Dashboard" />
</div>
</section>
);

View File

@ -6,7 +6,7 @@ import { render } from 'react-dom';
import store from './store';
import router from './router';
import { onBeforeUnload } from './actions/WalletActions';
import styles from '../styles/index.less';
import styles from '~/styles/index.less';
const root: ?HTMLElement = document.getElementById('root');
if (root) {

View File

@ -9,16 +9,16 @@ import store, { history } from '../store';
import LandingPageContainer from '../components/landing';
import WalletContainer from '../components/wallet';
import BootloaderContainer from '../components/wallet/Bootloader';
import AcquireContainer from '../components/wallet/Acquire';
import BootloaderContainer from '../components/wallet/pages/Bootloader';
import AcquireContainer from '../components/wallet/pages/Acquire';
import DashboardContainer from '../components/wallet/Dashboard';
import SummaryContainer from '../components/wallet/summary';
import SendFormContainer from '../components/wallet/send';
import ReceiveContainer from '../components/wallet/Receive';
import SignVerifyContainer from '../components/wallet/SignVerify';
import DeviceSettingsContainer from '../components/wallet/DeviceSettings';
import WalletSettingsContainer from '../components/wallet/WalletSettings';
import DashboardContainer from '../components/wallet/pages/Dashboard';
import SummaryContainer from '../components/wallet/account/summary';
import SendFormContainer from '../components/wallet/account/send';
import ReceiveContainer from '../components/wallet/account/receive';
import SignVerifyContainer from '../components/wallet/account/sign/SignVerify';
import DeviceSettingsContainer from '../components/wallet/pages/DeviceSettings';
import WalletSettingsContainer from '../components/wallet/pages/WalletSettings';
export default (
<Provider store={ store }>