Browse Source

fixes sent modal for ethereum/litecoin when no balance was set

master
Valentin D. Pinkman 7 years ago
parent
commit
dd590854f3
No known key found for this signature in database GPG Key ID: E7D110669FFB8D3E
  1. 5
      src/bridge/EthereumJSBridge.js
  2. 2
      src/bridge/LibcoreBridge.js
  3. 9
      src/components/FeesField/BitcoinKind.js
  4. 6
      src/components/base/InputCurrency/index.js
  5. 2
      src/components/modals/Send/steps/01-step-amount.js

5
src/bridge/EthereumJSBridge.js

@ -403,7 +403,10 @@ const EthereumBridge: WalletBridge<Transaction> = {
? Promise.resolve() ? Promise.resolve()
: Promise.reject(new NotEnoughBalance()), : Promise.reject(new NotEnoughBalance()),
getTotalSpent: (a, t) => Promise.resolve(t.amount.plus(t.gasPrice.times(t.gasLimit))), getTotalSpent: (a, t) =>
t.amount.isGreaterThan(0) && t.gasPrice.isGreaterThan(0) && t.gasLimit.isGreaterThan(0)
? Promise.resolve(t.amount.plus(t.gasPrice.times(t.gasLimit)))
: Promise.resolve(BigNumber(0)),
getMaxAmount: (a, t) => Promise.resolve(a.balance.minus(t.gasPrice.times(t.gasLimit))), getMaxAmount: (a, t) => Promise.resolve(a.balance.minus(t.gasPrice.times(t.gasLimit))),

2
src/bridge/LibcoreBridge.js

@ -197,7 +197,7 @@ const LibcoreBridge: WalletBridge<Transaction> = {
checkCanBeSpent, checkCanBeSpent,
getTotalSpent: (a, t) => getTotalSpent: (a, t) =>
!t.amount t.amount.isZero()
? Promise.resolve(BigNumber(0)) ? Promise.resolve(BigNumber(0))
: getFees(a, t) : getFees(a, t)
.then(totalFees => t.amount.plus(totalFees || 0)) .then(totalFees => t.amount.plus(totalFees || 0))

9
src/components/FeesField/BitcoinKind.js

@ -53,7 +53,9 @@ const customItem = {
type State = { isFocused: boolean, items: FeeItem[], selectedItem: FeeItem } type State = { isFocused: boolean, items: FeeItem[], selectedItem: FeeItem }
class FeesField extends Component<Props & { fees?: Fees, error?: Error }, State> { type OwnProps = Props & { fees?: Fees, error?: Error }
class FeesField extends Component<OwnProps, State> {
state = { state = {
items: [customItem], items: [customItem],
selectedItem: customItem, selectedItem: customItem,
@ -85,10 +87,10 @@ class FeesField extends Component<Props & { fees?: Fees, error?: Error }, State>
return { items, selectedItem } return { items, selectedItem }
} }
componentDidUpdate() { componentDidUpdate({ fees: prevFees }: OwnProps) {
const { feePerByte, fees, onChange } = this.props const { feePerByte, fees, onChange } = this.props
const { items, isFocused } = this.state const { items, isFocused } = this.state
if (fees && feePerByte.isZero() && !isFocused) { if (fees && fees !== prevFees && feePerByte.isZero() && !isFocused) {
// initialize with the median // initialize with the median
const feePerByte = (items.find(item => item.blockCount === defaultBlockCount) || items[0]) const feePerByte = (items.find(item => item.blockCount === defaultBlockCount) || items[0])
.feePerByte .feePerByte
@ -140,6 +142,7 @@ class FeesField extends Component<Props & { fees?: Fees, error?: Error }, State>
{t('app:send.steps.amount.unitPerByte', { unit: satoshi.code })} {t('app:send.steps.amount.unitPerByte', { unit: satoshi.code })}
</InputRight> </InputRight>
} }
allowZero
/> />
</GenericContainer> </GenericContainer>
) )

6
src/components/base/InputCurrency/index.js

@ -84,6 +84,7 @@ type Props = {
value: BigNumber, value: BigNumber,
showAllDigits?: boolean, showAllDigits?: boolean,
subMagnitude: number, subMagnitude: number,
allowZero: boolean,
} }
type State = { type State = {
@ -100,6 +101,7 @@ class InputCurrency extends PureComponent<Props, State> {
value: BigNumber(0), value: BigNumber(0),
showAllDigits: false, showAllDigits: false,
subMagnitude: 0, subMagnitude: 0,
allowZero: false,
} }
state = { state = {
@ -153,11 +155,11 @@ class InputCurrency extends PureComponent<Props, State> {
} }
syncInput = ({ isFocused }: { isFocused: boolean }) => { syncInput = ({ isFocused }: { isFocused: boolean }) => {
const { value, showAllDigits, subMagnitude, unit } = this.props const { value, showAllDigits, subMagnitude, unit, allowZero } = this.props
this.setState({ this.setState({
isFocused, isFocused,
displayValue: displayValue:
!value || value.isZero() (!value || value.isZero()) && !allowZero
? '' ? ''
: format(unit, value, { isFocused, showAllDigits, subMagnitude }), : format(unit, value, { isFocused, showAllDigits, subMagnitude }),
}) })

2
src/components/modals/Send/steps/01-step-amount.js

@ -138,7 +138,7 @@ export class StepAmountFooter extends PureComponent<
.checkCanBeSpent(account, transaction) .checkCanBeSpent(account, transaction)
.then(() => true, () => false) .then(() => true, () => false)
if (syncId !== this.syncId) return if (syncId !== this.syncId) return
const canNext = isRecipientValid && canBeSpent const canNext = isRecipientValid && canBeSpent && totalSpent.gt(0)
this.setState({ totalSpent, canNext, isSyncing: false }) this.setState({ totalSpent, canNext, isSyncing: false })
} catch (err) { } catch (err) {
logger.critical(err) logger.critical(err)

Loading…
Cancel
Save