mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2024-11-01 01:47:41 +00:00
cdf081edfd
* thorChain btc to eth swap
* eth to btc swap
* update the UI
* update localization
* Update thorchain_exchange.provider.dart
* minor fixes
* minor fix
* fix min amount bug
* revert amount_converter changes
* fetching thorChain traid info
* resolve evm related merge conflicts
* minor fix
* Fix eth transaction hash for Thorchain Integration
* add new status endpoint and refund address for eth
* Adjust affiliate fee
* Fix conflicts with main
* review comments + transaction filter item
* taproot addresses check
* added 10 outputs check
* Update thorchain_exchange.provider.dart
* minor fixes
* update thorchain title
* fix fetching rate for thorchain
* Revert "fix fetching rate for thorchain"
This reverts commit 3aa1386ecf
.
* fix thorchain exchange rate
---------
Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
154 lines
3.6 KiB
Dart
154 lines
3.6 KiB
Dart
import 'package:cake_wallet/exchange/exchange_provider_description.dart';
|
|
import 'package:cake_wallet/exchange/trade_state.dart';
|
|
import 'package:cw_core/crypto_currency.dart';
|
|
import 'package:cw_core/format_amount.dart';
|
|
import 'package:cw_core/hive_type_ids.dart';
|
|
import 'package:hive/hive.dart';
|
|
|
|
part 'trade.g.dart';
|
|
|
|
@HiveType(typeId: Trade.typeId)
|
|
class Trade extends HiveObject {
|
|
Trade({
|
|
required this.id,
|
|
required this.amount,
|
|
ExchangeProviderDescription? provider,
|
|
CryptoCurrency? from,
|
|
CryptoCurrency? to,
|
|
TradeState? state,
|
|
this.createdAt,
|
|
this.expiredAt,
|
|
this.inputAddress,
|
|
this.extraId,
|
|
this.outputTransaction,
|
|
this.refundAddress,
|
|
this.walletId,
|
|
this.payoutAddress,
|
|
this.password,
|
|
this.providerId,
|
|
this.providerName,
|
|
this.fromWalletAddress,
|
|
this.memo,
|
|
this.txId,
|
|
this.isRefund,
|
|
}) {
|
|
if (provider != null) providerRaw = provider.raw;
|
|
|
|
if (from != null) fromRaw = from.raw;
|
|
|
|
if (to != null) toRaw = to.raw;
|
|
|
|
if (state != null) stateRaw = state.raw;
|
|
}
|
|
|
|
static const typeId = TRADE_TYPE_ID;
|
|
static const boxName = 'Trades';
|
|
static const boxKey = 'tradesBoxKey';
|
|
|
|
@HiveField(0, defaultValue: '')
|
|
String id;
|
|
|
|
@HiveField(1, defaultValue: 0)
|
|
late int providerRaw;
|
|
|
|
ExchangeProviderDescription get provider =>
|
|
ExchangeProviderDescription.deserialize(raw: providerRaw);
|
|
|
|
@HiveField(2, defaultValue: 0)
|
|
late int fromRaw;
|
|
|
|
CryptoCurrency get from => CryptoCurrency.deserialize(raw: fromRaw);
|
|
|
|
@HiveField(3, defaultValue: 0)
|
|
late int toRaw;
|
|
|
|
CryptoCurrency get to => CryptoCurrency.deserialize(raw: toRaw);
|
|
|
|
@HiveField(4, defaultValue: '')
|
|
late String stateRaw;
|
|
|
|
TradeState get state => TradeState.deserialize(raw: stateRaw);
|
|
|
|
@HiveField(5)
|
|
DateTime? createdAt;
|
|
|
|
@HiveField(6)
|
|
DateTime? expiredAt;
|
|
|
|
@HiveField(7, defaultValue: '')
|
|
String amount;
|
|
|
|
@HiveField(8)
|
|
String? inputAddress;
|
|
|
|
@HiveField(9)
|
|
String? extraId;
|
|
|
|
@HiveField(10)
|
|
String? outputTransaction;
|
|
|
|
@HiveField(11)
|
|
String? refundAddress;
|
|
|
|
@HiveField(12)
|
|
String? walletId;
|
|
|
|
@HiveField(13)
|
|
String? payoutAddress;
|
|
|
|
@HiveField(14)
|
|
String? password;
|
|
|
|
@HiveField(15)
|
|
String? providerId;
|
|
|
|
@HiveField(16)
|
|
String? providerName;
|
|
|
|
@HiveField(17)
|
|
String? fromWalletAddress;
|
|
|
|
@HiveField(18)
|
|
String? memo;
|
|
|
|
@HiveField(19)
|
|
String? txId;
|
|
|
|
@HiveField(20)
|
|
bool? isRefund;
|
|
|
|
static Trade fromMap(Map<String, Object?> map) {
|
|
return Trade(
|
|
id: map['id'] as String,
|
|
provider: ExchangeProviderDescription.deserialize(raw: map['provider'] as int),
|
|
from: CryptoCurrency.deserialize(raw: map['input'] as int),
|
|
to: CryptoCurrency.deserialize(raw: map['output'] as int),
|
|
createdAt:
|
|
map['date'] != null ? DateTime.fromMillisecondsSinceEpoch(map['date'] as int) : null,
|
|
amount: map['amount'] as String,
|
|
walletId: map['wallet_id'] as String,
|
|
fromWalletAddress: map['from_wallet_address'] as String?,
|
|
memo: map['memo'] as String?,
|
|
txId: map['tx_id'] as String?,
|
|
isRefund: map['isRefund'] as bool?
|
|
);
|
|
}
|
|
|
|
Map<String, dynamic> toMap() {
|
|
return <String, dynamic>{
|
|
'id': id,
|
|
'provider': provider.serialize(),
|
|
'input': from.serialize(),
|
|
'output': to.serialize(),
|
|
'date': createdAt != null ? createdAt!.millisecondsSinceEpoch : null,
|
|
'amount': amount,
|
|
'wallet_id': walletId,
|
|
'from_wallet_address': fromWalletAddress,
|
|
'memo': memo,
|
|
'tx_id': txId,
|
|
'isRefund': isRefund
|
|
};
|
|
}
|
|
|
|
String amountFormatted() => formatAmount(amount);
|
|
}
|