2020-01-04 19:31:52 +00:00
|
|
|
import 'package:provider/provider.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter/cupertino.dart';
|
|
|
|
import 'package:flutter/services.dart';
|
|
|
|
import 'package:flutter_mobx/flutter_mobx.dart';
|
|
|
|
import 'package:cake_wallet/generated/i18n.dart';
|
|
|
|
import 'package:cake_wallet/src/stores/exchange_trade/exchange_trade_store.dart';
|
2020-03-06 18:38:13 +00:00
|
|
|
import 'package:cake_wallet/src/stores/settings/settings_store.dart';
|
2020-01-04 19:31:52 +00:00
|
|
|
import 'package:cake_wallet/src/screens/base_page.dart';
|
|
|
|
import 'package:cake_wallet/src/screens/transaction_details/standart_list_item.dart';
|
|
|
|
import 'package:cake_wallet/src/screens/transaction_details/standart_list_row.dart';
|
2020-04-27 10:23:55 +00:00
|
|
|
import 'package:cake_wallet/palette.dart';
|
2020-01-04 19:31:52 +00:00
|
|
|
|
|
|
|
class TradeDetailsPage extends BasePage {
|
2020-04-27 10:23:55 +00:00
|
|
|
|
2020-01-08 12:26:34 +00:00
|
|
|
@override
|
2020-04-27 10:23:55 +00:00
|
|
|
Color get backgroundColor => PaletteDark.historyPanel;
|
2020-01-08 12:26:34 +00:00
|
|
|
|
|
|
|
@override
|
2020-04-27 10:23:55 +00:00
|
|
|
String get title => S.current.trade_details_title;
|
2020-01-04 19:31:52 +00:00
|
|
|
|
|
|
|
@override
|
|
|
|
Widget body(BuildContext context) {
|
|
|
|
final exchangeStore = Provider.of<ExchangeTradeStore>(context);
|
2020-03-06 18:38:13 +00:00
|
|
|
final settingsStore = Provider.of<SettingsStore>(context);
|
2020-03-09 16:51:54 +00:00
|
|
|
final createdAtFormat = settingsStore.getCurrentDateFormat(
|
|
|
|
formatUSA: "yyyy.MM.dd, HH:mm",
|
|
|
|
formatDefault: "dd.MM.yyyy, HH:mm");
|
2020-01-04 19:31:52 +00:00
|
|
|
|
|
|
|
return Container(
|
2020-04-27 10:23:55 +00:00
|
|
|
color: PaletteDark.historyPanel,
|
|
|
|
padding: EdgeInsets.only(top: 20, bottom: 20),
|
2020-01-04 19:31:52 +00:00
|
|
|
child: Observer(builder: (_) {
|
|
|
|
final trade = exchangeStore.trade;
|
|
|
|
final items = [
|
|
|
|
StandartListItem(
|
|
|
|
title: S.of(context).trade_details_id, value: trade.id),
|
|
|
|
StandartListItem(
|
|
|
|
title: S.of(context).trade_details_state,
|
|
|
|
value: trade.state != null
|
|
|
|
? trade.state.toString()
|
|
|
|
: S.of(context).trade_details_fetching)
|
|
|
|
];
|
|
|
|
|
|
|
|
if (trade.provider != null) {
|
|
|
|
items.add(StandartListItem(
|
|
|
|
title: S.of(context).trade_details_provider,
|
|
|
|
value: trade.provider.toString()));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (trade.createdAt != null) {
|
|
|
|
items.add(StandartListItem(
|
|
|
|
title: S.of(context).trade_details_created_at,
|
2020-02-12 12:31:26 +00:00
|
|
|
value: createdAtFormat.format(trade.createdAt).toString()));
|
2020-01-04 19:31:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (trade.from != null && trade.to != null) {
|
|
|
|
items.add(StandartListItem(
|
|
|
|
title: S.of(context).trade_details_pair,
|
|
|
|
value: '${trade.from.toString()} → ${trade.to.toString()}'));
|
|
|
|
}
|
|
|
|
|
|
|
|
return ListView.separated(
|
2020-04-27 10:23:55 +00:00
|
|
|
separatorBuilder: (_, __) => Container(
|
|
|
|
height: 1,
|
|
|
|
padding: EdgeInsets.only(left: 24),
|
|
|
|
color: PaletteDark.menuList,
|
|
|
|
child: Container(
|
|
|
|
height: 1,
|
|
|
|
color: PaletteDark.walletCardTopEndSync,
|
|
|
|
),
|
|
|
|
),
|
2020-01-04 19:31:52 +00:00
|
|
|
itemCount: items.length,
|
|
|
|
itemBuilder: (BuildContext context, int index) {
|
|
|
|
final item = items[index];
|
2020-04-27 10:23:55 +00:00
|
|
|
|
|
|
|
final isDrawTop = index == 0 ? true : false;
|
|
|
|
final isDrawBottom = index == items.length - 1 ? true : false;
|
|
|
|
|
2020-01-04 19:31:52 +00:00
|
|
|
return GestureDetector(
|
|
|
|
onTap: () {
|
|
|
|
Clipboard.setData(ClipboardData(text: '${item.value}'));
|
|
|
|
Scaffold.of(context).showSnackBar(
|
|
|
|
SnackBar(
|
|
|
|
content: Text(
|
|
|
|
S.of(context).trade_details_copied(item.title)),
|
|
|
|
backgroundColor: Colors.green,
|
|
|
|
duration: Duration(milliseconds: 1500),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
},
|
|
|
|
child: StandartListRow(
|
2020-04-27 10:23:55 +00:00
|
|
|
title: '${item.title}',
|
|
|
|
value: '${item.value}',
|
|
|
|
isDrawTop: isDrawTop,
|
|
|
|
isDrawBottom: isDrawBottom,
|
|
|
|
));
|
2020-01-04 19:31:52 +00:00
|
|
|
});
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
}
|