|
@ -20,13 +20,13 @@ import { |
|
|
import FeesRippleKind from 'components/FeesField/RippleKind' |
|
|
import FeesRippleKind from 'components/FeesField/RippleKind' |
|
|
import AdvancedOptionsRippleKind from 'components/AdvancedOptions/RippleKind' |
|
|
import AdvancedOptionsRippleKind from 'components/AdvancedOptions/RippleKind' |
|
|
import { getAccountPlaceholderName, getNewAccountPlaceholderName } from 'helpers/accountName' |
|
|
import { getAccountPlaceholderName, getNewAccountPlaceholderName } from 'helpers/accountName' |
|
|
import { NotEnoughBalance } from 'config/errors' |
|
|
import { NotEnoughBalance, FeeNotLoaded } from 'config/errors' |
|
|
import type { WalletBridge, EditProps } from './types' |
|
|
import type { WalletBridge, EditProps } from './types' |
|
|
|
|
|
|
|
|
type Transaction = { |
|
|
type Transaction = { |
|
|
amount: BigNumber, |
|
|
amount: BigNumber, |
|
|
recipient: string, |
|
|
recipient: string, |
|
|
fee: BigNumber, |
|
|
fee: ?BigNumber, |
|
|
tag: ?number, |
|
|
tag: ?number, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -51,6 +51,8 @@ const EditAdvancedOptions = ({ onChange, value }: EditProps<Transaction>) => ( |
|
|
|
|
|
|
|
|
async function signAndBroadcast({ a, t, deviceId, isCancelled, onSigned, onOperationBroadcasted }) { |
|
|
async function signAndBroadcast({ a, t, deviceId, isCancelled, onSigned, onOperationBroadcasted }) { |
|
|
const api = apiForEndpointConfig(a.endpointConfig) |
|
|
const api = apiForEndpointConfig(a.endpointConfig) |
|
|
|
|
|
const { fee } = t |
|
|
|
|
|
if (!fee) throw new FeeNotLoaded() |
|
|
try { |
|
|
try { |
|
|
await api.connect() |
|
|
await api.connect() |
|
|
const amount = formatAPICurrencyXRP(t.amount) |
|
|
const amount = formatAPICurrencyXRP(t.amount) |
|
@ -66,7 +68,7 @@ async function signAndBroadcast({ a, t, deviceId, isCancelled, onSigned, onOpera |
|
|
}, |
|
|
}, |
|
|
} |
|
|
} |
|
|
const instruction = { |
|
|
const instruction = { |
|
|
fee: formatAPICurrencyXRP(t.fee).value, |
|
|
fee: formatAPICurrencyXRP(fee).value, |
|
|
maxLedgerVersionOffset: 12, |
|
|
maxLedgerVersionOffset: 12, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -97,7 +99,7 @@ async function signAndBroadcast({ a, t, deviceId, isCancelled, onSigned, onOpera |
|
|
accountId: a.id, |
|
|
accountId: a.id, |
|
|
type: 'OUT', |
|
|
type: 'OUT', |
|
|
value: t.amount, |
|
|
value: t.amount, |
|
|
fee: t.fee, |
|
|
fee, |
|
|
blockHash: null, |
|
|
blockHash: null, |
|
|
blockHeight: null, |
|
|
blockHeight: null, |
|
|
senders: [a.freshAddress], |
|
|
senders: [a.freshAddress], |
|
@ -452,7 +454,7 @@ const RippleJSBridge: WalletBridge<Transaction> = { |
|
|
createTransaction: () => ({ |
|
|
createTransaction: () => ({ |
|
|
amount: BigNumber(0), |
|
|
amount: BigNumber(0), |
|
|
recipient: '', |
|
|
recipient: '', |
|
|
fee: BigNumber(0), |
|
|
fee: null, |
|
|
tag: undefined, |
|
|
tag: undefined, |
|
|
}), |
|
|
}), |
|
|
|
|
|
|
|
@ -495,10 +497,11 @@ const RippleJSBridge: WalletBridge<Transaction> = { |
|
|
getTransactionRecipient: (a, t) => t.recipient, |
|
|
getTransactionRecipient: (a, t) => t.recipient, |
|
|
|
|
|
|
|
|
checkValidTransaction: async (a, t) => { |
|
|
checkValidTransaction: async (a, t) => { |
|
|
|
|
|
if (!t.fee) throw new FeeNotLoaded() |
|
|
const r = await getServerInfo(a.endpointConfig) |
|
|
const r = await getServerInfo(a.endpointConfig) |
|
|
if ( |
|
|
if ( |
|
|
t.amount |
|
|
t.amount |
|
|
.plus(t.fee) |
|
|
.plus(t.fee || 0) |
|
|
.plus(parseAPIValue(r.validatedLedger.reserveBaseXRP)) |
|
|
.plus(parseAPIValue(r.validatedLedger.reserveBaseXRP)) |
|
|
.isLessThanOrEqualTo(a.balance) |
|
|
.isLessThanOrEqualTo(a.balance) |
|
|
) { |
|
|
) { |
|
@ -507,9 +510,9 @@ const RippleJSBridge: WalletBridge<Transaction> = { |
|
|
throw new NotEnoughBalance() |
|
|
throw new NotEnoughBalance() |
|
|
}, |
|
|
}, |
|
|
|
|
|
|
|
|
getTotalSpent: (a, t) => Promise.resolve(t.amount.plus(t.fee)), |
|
|
getTotalSpent: (a, t) => Promise.resolve(t.amount.plus(t.fee || 0)), |
|
|
|
|
|
|
|
|
getMaxAmount: (a, t) => Promise.resolve(a.balance.minus(t.fee)), |
|
|
getMaxAmount: (a, t) => Promise.resolve(a.balance.minus(t.fee || 0)), |
|
|
|
|
|
|
|
|
signAndBroadcast: (a, t, deviceId) => |
|
|
signAndBroadcast: (a, t, deviceId) => |
|
|
Observable.create(o => { |
|
|
Observable.create(o => { |
|
|