From bd63b81d4b309a89dfae9c9600578bd8e234fe88 Mon Sep 17 00:00:00 2001 From: Sigve Kvalsvik Date: Fri, 15 Sep 2017 08:47:01 +0200 Subject: [PATCH] Fix transfer fee not getting set properly fix #409 --- app/components/Transfer/Transfer.jsx | 22 ++++++++++++++-------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/app/components/Transfer/Transfer.jsx b/app/components/Transfer/Transfer.jsx index 40a640872e..e3c790ea80 100644 --- a/app/components/Transfer/Transfer.jsx +++ b/app/components/Transfer/Transfer.jsx @@ -71,6 +71,7 @@ class Transfer extends React.Component { componentWillMount() { this.nestedRef = null; this._updateFee(); + this._checkFeeStatus(); } shouldComponentUpdate(np, ns) { @@ -117,7 +118,7 @@ class Transfer extends React.Component { let balanceObject = ChainStore.getObject(balanceID); let feeBalanceObject = feeBalanceID ? ChainStore.getObject(feeBalanceID) : null; if (!feeBalanceObject || feeBalanceObject.get("balance") === 0) { - this._updateFee("1.3.0"); + this.setState({fee_asset_id: "1.3.0"}, this._updateFee); } const hasBalance = checkBalance(amount, asset, feeAmount, balanceObject); if (hasBalance === null) return; @@ -127,7 +128,7 @@ class Transfer extends React.Component { _checkFeeStatus(account = this.state.from_account) { if (!account) return; - const assets = Object.keys(this.state.from_account.get("balances").toJS()).sort(utils.sortID); + const assets = Object.keys(account.get("balances").toJS()).sort(utils.sortID); let feeStatus = {}; let p = []; assets.forEach(a => { @@ -156,15 +157,20 @@ class Transfer extends React.Component { }); } - _updateFee(fee_asset_id = this.state.fee_asset_id) { - if (!this.state.from_account) return null; + _updateFee(state = this.state) { + let { fee_asset_id, from_account } = state; + const { fee_asset_types } = this._getAvailableAssets(state); + if ( fee_asset_types.length === 1 && fee_asset_types[0] !== fee_asset_id) { + fee_asset_id = fee_asset_types[0]; + } + if (!from_account) return null; checkFeeStatusAsync({ - accountID: this.state.from_account.get("id"), + accountID: from_account.get("id"), feeID: fee_asset_id, options: ["price_per_kbyte"], data: { type: "memo", - content: this.state.memo + content: state.memo } }) .then(({fee, hasBalance, hasPoolBalance}) => { @@ -174,7 +180,7 @@ class Transfer extends React.Component { hasBalance, hasPoolBalance, error: (!hasBalance || !hasPoolBalance) - }, this._checkFeeStatus); + }); }); } @@ -188,7 +194,7 @@ class Transfer extends React.Component { } onFromAccountChanged(from_account) { - this.setState({from_account, error: null}, this._updateFee); + this.setState({from_account, error: null}, () => {this._updateFee(); this._checkFeeStatus();}); } onToAccountChanged(to_account) {