From 0e43ce6e07ebf1a4ed21f346f4e5f980b5e3a23b Mon Sep 17 00:00:00 2001 From: maciejhirsz Date: Mon, 25 Sep 2017 17:08:09 +0200 Subject: [PATCH] Disable time conditions in Tx UI #6445 --- js/src/api/local/localAccountsMiddleware.js | 4 ++ .../modals/DeployContract/deployContract.js | 6 ++- .../AdvancedStep/advancedStep.js | 8 +++- .../modals/ExecuteContract/executeContract.js | 13 ++++-- js/src/modals/Transfer/Extras/extras.js | 4 +- js/src/modals/Transfer/transfer.js | 7 ++- js/src/ui/GasPriceEditor/gasPriceEditor.js | 45 ++++++++++++------- .../TransactionPending/transactionPending.js | 8 +++- 8 files changed, 68 insertions(+), 27 deletions(-) diff --git a/js/src/api/local/localAccountsMiddleware.js b/js/src/api/local/localAccountsMiddleware.js index c32ac0ddd60..adfe8f50d36 100644 --- a/js/src/api/local/localAccountsMiddleware.js +++ b/js/src/api/local/localAccountsMiddleware.js @@ -188,6 +188,10 @@ export default class LocalAccountsMiddleware extends Middleware { return []; }); + register('parity_lockedHardwareAccountsInfo', () => { + return []; + }); + register('parity_hashContent', () => { throw new Error('Functionality unavailable on a public wallet.'); }); diff --git a/js/src/modals/DeployContract/deployContract.js b/js/src/modals/DeployContract/deployContract.js index a5d6c6b3426..345aeafa9d4 100644 --- a/js/src/modals/DeployContract/deployContract.js +++ b/js/src/modals/DeployContract/deployContract.js @@ -66,6 +66,7 @@ class DeployContract extends Component { }; static propTypes = { + availability: PropTypes.string.isRequired, accounts: PropTypes.object.isRequired, abi: PropTypes.string, code: PropTypes.string, @@ -331,6 +332,7 @@ class DeployContract extends Component { return ( - + ); } diff --git a/js/src/modals/ExecuteContract/executeContract.js b/js/src/modals/ExecuteContract/executeContract.js index 0f648dece5c..0dfa7c92ef4 100644 --- a/js/src/modals/ExecuteContract/executeContract.js +++ b/js/src/modals/ExecuteContract/executeContract.js @@ -57,6 +57,7 @@ class ExecuteContract extends Component { }; static propTypes = { + availability: PropTypes.string.isRequired, accounts: PropTypes.object, contract: PropTypes.object.isRequired, fromAddress: PropTypes.string, @@ -198,7 +199,7 @@ class ExecuteContract extends Component { } renderStep () { - const { accounts, contract, fromAddress, onFromAddressChange } = this.props; + const { availability, accounts, contract, fromAddress, onFromAddressChange } = this.props; const { step } = this.state; if (step === STEP_DETAILS) { @@ -218,7 +219,10 @@ class ExecuteContract extends Component { } return ( - + ); } @@ -337,9 +341,10 @@ class ExecuteContract extends Component { } function mapStateToProps (state) { - const { gasLimit } = state.nodeStatus; + const { gasLimit, nodeKind = {} } = state.nodeStatus; + const { availability = 'unknown' } = nodeKind; - return { gasLimit }; + return { availability, gasLimit }; } export default connect( diff --git a/js/src/modals/Transfer/Extras/extras.js b/js/src/modals/Transfer/Extras/extras.js index c3e2d1a8e68..5cbccc36943 100644 --- a/js/src/modals/Transfer/Extras/extras.js +++ b/js/src/modals/Transfer/Extras/extras.js @@ -23,6 +23,7 @@ import styles from '../transfer.css'; export default class Extras extends Component { static propTypes = { + availability: PropTypes.string.isRequired, data: PropTypes.string, dataError: PropTypes.string, hideData: PropTypes.bool, @@ -38,13 +39,14 @@ export default class Extras extends Component { }; render () { - const { gasStore, onChange } = this.props; + const { availability, gasStore, onChange } = this.props; return (
{ this.renderData() }
diff --git a/js/src/modals/Transfer/transfer.js b/js/src/modals/Transfer/transfer.js index fd2625ee75f..25e5d4f8f47 100644 --- a/js/src/modals/Transfer/transfer.js +++ b/js/src/modals/Transfer/transfer.js @@ -42,6 +42,7 @@ class Transfer extends Component { } static propTypes = { + availability: PropTypes.string.isRequired, newError: PropTypes.func.isRequired, gasLimit: PropTypes.object.isRequired, @@ -186,6 +187,7 @@ class Transfer extends Component { onChange={ this.store.onUpdateDetails } total={ total } totalError={ totalError } + availability={ this.props.availability } /> ); } @@ -291,13 +293,14 @@ function mapStateToProps (initState, initProps) { : null; return (state) => { - const { gasLimit } = state.nodeStatus; + const { gasLimit, nodeKind = {} } = state.nodeStatus; const { balances } = state; + const { availability = 'unknown' } = nodeKind; const balance = balances[address]; const sendersBalances = senders ? pick(balances, Object.keys(senders)) : null; - return { balance, gasLimit, senders, sendersBalances, tokens, wallet }; + return { availability, balance, gasLimit, senders, sendersBalances, tokens, wallet }; }; } diff --git a/js/src/ui/GasPriceEditor/gasPriceEditor.js b/js/src/ui/GasPriceEditor/gasPriceEditor.js index db9e02396e0..7d70d35210f 100644 --- a/js/src/ui/GasPriceEditor/gasPriceEditor.js +++ b/js/src/ui/GasPriceEditor/gasPriceEditor.js @@ -64,7 +64,8 @@ export default class GasPriceEditor extends Component { static propTypes = { children: PropTypes.node, onChange: PropTypes.func, - store: PropTypes.object.isRequired + store: PropTypes.object.isRequired, + availability: PropTypes.string.isRequired } static Store = Store; @@ -72,7 +73,7 @@ export default class GasPriceEditor extends Component { render () { const { api } = this.context; const { children, store } = this.props; - const { conditionType, errorGas, errorPrice, errorTotal, estimated, gas, histogram, price, priceDefault, totalValue } = store; + const { errorGas, errorPrice, errorTotal, estimated, gas, histogram, price, priceDefault, totalValue } = store; const eth = api.util.fromWei(totalValue).toFormat(); const gasLabel = `gas (estimated: ${new BigNumber(estimated).toFormat()})`; @@ -80,18 +81,7 @@ export default class GasPriceEditor extends Component { return (
- - } - onChange={ this.onChangeConditionType } - value={ conditionType } - values={ CONDITION_VALUES } - /> + { this.renderConditionRadioButtons() } { this.renderConditions() }
@@ -148,10 +138,35 @@ export default class GasPriceEditor extends Component { ); } + renderConditionRadioButtons () { + const { availability } = this.props; + const { conditionType } = this.props.store; + + if (availability !== 'personal') { + return null; + } + + return ( + + } + onChange={ this.onChangeConditionType } + value={ conditionType } + values={ CONDITION_VALUES } + /> + ); + } + renderConditions () { + const { availability } = this.props; const { conditionType, condition, conditionBlockError } = this.props.store; - if (conditionType === CONDITIONS.NONE) { + if (conditionType === CONDITIONS.NONE || availability !== 'personal') { return null; } diff --git a/js/src/views/Signer/components/TransactionPending/transactionPending.js b/js/src/views/Signer/components/TransactionPending/transactionPending.js index b9cc8f684ba..2d6797b69e5 100644 --- a/js/src/views/Signer/components/TransactionPending/transactionPending.js +++ b/js/src/views/Signer/components/TransactionPending/transactionPending.js @@ -36,6 +36,7 @@ class TransactionPending extends Component { }; static propTypes = { + availability: PropTypes.string.isRequired, accounts: PropTypes.object.isRequired, className: PropTypes.string, date: PropTypes.instanceOf(Date).isRequired, @@ -140,11 +141,11 @@ class TransactionPending extends Component { } renderTxEditor () { - const { className } = this.props; + const { availability, className } = this.props; return (
- +