2021-01-06 13:34:04 +00:00
|
|
|
import 'package:cake_wallet/src/widgets/standard_list.dart';
|
2022-12-12 12:28:53 +00:00
|
|
|
import 'package:cake_wallet/src/widgets/standard_list_card.dart';
|
|
|
|
import 'package:cake_wallet/src/widgets/standard_list_status_row.dart';
|
2020-09-30 18:23:15 +00:00
|
|
|
import 'package:cake_wallet/utils/show_bar.dart';
|
2020-12-18 12:42:53 +00:00
|
|
|
import 'package:cake_wallet/view_model/trade_details_view_model.dart';
|
2020-01-04 19:31:52 +00:00
|
|
|
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/screens/base_page.dart';
|
2022-12-12 12:28:53 +00:00
|
|
|
import 'package:cake_wallet/src/widgets/standard_list_row.dart';
|
2021-02-02 01:36:36 +00:00
|
|
|
import 'package:cake_wallet/src/screens/trade_details/track_trade_list_item.dart';
|
2022-09-02 13:10:54 +00:00
|
|
|
import 'package:cake_wallet/src/screens/trade_details/trade_details_list_card.dart';
|
|
|
|
import 'package:cake_wallet/src/screens/trade_details/trade_details_status_item.dart';
|
2020-01-04 19:31:52 +00:00
|
|
|
|
|
|
|
class TradeDetailsPage extends BasePage {
|
2020-12-18 12:42:53 +00:00
|
|
|
TradeDetailsPage(this.tradeDetailsViewModel);
|
2020-01-04 19:31:52 +00:00
|
|
|
|
2020-09-21 11:50:26 +00:00
|
|
|
@override
|
|
|
|
String get title => S.current.trade_details_title;
|
2020-01-04 19:31:52 +00:00
|
|
|
|
2020-12-18 12:42:53 +00:00
|
|
|
final TradeDetailsViewModel tradeDetailsViewModel;
|
2020-01-04 19:31:52 +00:00
|
|
|
|
2020-09-21 11:50:26 +00:00
|
|
|
@override
|
2021-04-15 17:10:23 +00:00
|
|
|
Widget body(BuildContext context) =>
|
|
|
|
TradeDetailsPageBody(tradeDetailsViewModel);
|
|
|
|
}
|
|
|
|
|
|
|
|
class TradeDetailsPageBody extends StatefulWidget {
|
|
|
|
TradeDetailsPageBody(this.tradeDetailsViewModel);
|
|
|
|
|
|
|
|
final TradeDetailsViewModel tradeDetailsViewModel;
|
|
|
|
|
|
|
|
@override
|
|
|
|
TradeDetailsPageBodyState createState() =>
|
|
|
|
TradeDetailsPageBodyState(tradeDetailsViewModel);
|
|
|
|
}
|
|
|
|
|
|
|
|
class TradeDetailsPageBodyState extends State<TradeDetailsPageBody> {
|
|
|
|
TradeDetailsPageBodyState(this.tradeDetailsViewModel);
|
|
|
|
|
|
|
|
final TradeDetailsViewModel tradeDetailsViewModel;
|
|
|
|
|
|
|
|
@override
|
|
|
|
void dispose() {
|
|
|
|
super.dispose();
|
|
|
|
tradeDetailsViewModel.timer?.cancel();
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
2021-01-06 13:34:04 +00:00
|
|
|
return Observer(builder: (_) {
|
2022-10-12 17:09:57 +00:00
|
|
|
// FIX-ME: Added `context` it was not used here before, maby bug ?
|
2021-01-06 13:34:04 +00:00
|
|
|
return SectionStandardList(
|
2022-10-12 17:09:57 +00:00
|
|
|
context: context,
|
2021-01-06 13:34:04 +00:00
|
|
|
sectionCount: 1,
|
|
|
|
itemCounter: (int _) => tradeDetailsViewModel.items.length,
|
|
|
|
itemBuilder: (_, __, index) {
|
2020-12-18 12:42:53 +00:00
|
|
|
final item = tradeDetailsViewModel.items[index];
|
2020-04-27 10:23:55 +00:00
|
|
|
|
2021-02-03 02:23:02 +00:00
|
|
|
if (item is TrackTradeListItem) {
|
|
|
|
return GestureDetector(
|
|
|
|
onTap: item.onTap,
|
2022-12-12 12:28:53 +00:00
|
|
|
child: AnotherStandardListRow(
|
2021-02-03 02:23:02 +00:00
|
|
|
title: '${item.title}', value: '${item.value}'));
|
2022-09-02 13:10:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (item is DetailsListStatusItem) {
|
2022-12-12 12:28:53 +00:00
|
|
|
return StandardListStatusRow(
|
2022-09-02 13:10:54 +00:00
|
|
|
title: item.title,
|
|
|
|
value: item.value);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (item is TradeDetailsListCardItem) {
|
2022-12-12 12:28:53 +00:00
|
|
|
return TradeDetailsStandardListCard(
|
2022-09-02 13:10:54 +00:00
|
|
|
id: item.id,
|
|
|
|
create: item.createdAt,
|
|
|
|
pair: item.pair,
|
|
|
|
currentTheme: tradeDetailsViewModel.settingsStore.currentTheme.type,
|
|
|
|
onTap: item.onTap,);
|
|
|
|
}
|
|
|
|
|
2021-02-03 02:23:02 +00:00
|
|
|
return GestureDetector(
|
|
|
|
onTap: () {
|
|
|
|
Clipboard.setData(ClipboardData(text: '${item.value}'));
|
|
|
|
showBar<void>(context, S.of(context).copied_to_clipboard);
|
|
|
|
},
|
2022-12-12 12:28:53 +00:00
|
|
|
child: AnotherStandardListRow(
|
2021-02-03 02:23:02 +00:00
|
|
|
title: '${item.title}', value: '${item.value}'));
|
|
|
|
});
|
2021-01-06 13:34:04 +00:00
|
|
|
});
|
2020-01-04 19:31:52 +00:00
|
|
|
}
|
2021-04-15 17:10:23 +00:00
|
|
|
|
2021-02-03 02:23:02 +00:00
|
|
|
}
|