mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2024-11-01 09:57:46 +00:00
09c942564e
* fix: SectionStandardList using BuildContext as param * refactor: deprecated backgroundColor -> colorScheme.background * refactor: themeBase and current themes * refactor: accentTextTheme.titleLarge.color -> dialogTheme.backgroundColor * refactor: gradient background * refactor: text themes using the same color as primaryColor * refactor: accentTextTheme.bodySmall.color -> cardColor * refactor: text themes using same dialogBackgroundColor * refactor: scrollbarTheme * refactor: create SyncIndicatorTheme * refactor: SectionDivider * refactor: base_page improvements and simplify * refactor: collapsible_standart_list improvements * refactor: accentTextTheme.bodyLarge.backgroundColor -> KeyboardTheme.keyboardBarColor * refactor: create PinCodeTheme for accentTextTheme.bodyMedium * refactor: create SupportPageTheme for accentTextTheme.displayLarge.backgroundColor and fix cases that use it * refactor: accentTextTheme.displayLarge.color -> disabledColor * refactor: create ExchangePageTheme * refactor: create DashboardPageTheme and use textColor * refactor: create NewWalletTheme for accentTextTheme.displayMedium * refactor: create BalancePageTheme for accentTextTheme.displaySmall.backgroundColor * refactor: create AddressTheme for accentTextTheme.displaySmall.color * refactor: create IndicatorDotTheme * refactor: create CakeMenuTheme * refactor: create FilterTheme * refactor: create WalletListTheme * refactor: accentTextTheme.bodySmall.decorationColor -> InfoTheme.textColor * refactor: accentTextTheme.titleLarge.backgroundColor -> PickerTheme.dividerColor * refactor: primaryTextTheme.bodyLarge.backgroundColor -> AlertTheme.leftButtonTextColor * refactor: primaryTextTheme.displayLarge.backgroundColor -> OrderTheme.iconColor * refactor: create SendPageTheme * fix: missing migrated styles * refactor: primaryTextTheme.labelSmall.decorationColor -> PlaceholderTheme.color * refactor: create TransactionTradeTheme * refactor: create CakeTextTheme * refactor: create AccountListTheme * refactor: create ReceivePageTheme * refactor: create QRCodeTheme * refactor: move remaining items to CakeTextTheme and some missing fixes * feat(display_settings): add new theme selector * feat: additional themes * fix: conflict error * fix(lag): move colorScheme initialization to constructor * feat: add backdropColor to alert and picker backdrop filters * fix: merge fixes * fix: send template page missing new colors * fix: anonpay pages title and icon colors * fix: merge fixes * fix: unspent coins page * fix: also fix exchange template * fix: missing checkbox * fix: fixes for high contrast theme * Merge branch 'main' into CW-396-additional-themes * fix: merge fixes * fix: .gitignore and rm added files * Fix review comments --------- Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
94 lines
3.3 KiB
Dart
94 lines
3.3 KiB
Dart
import 'package:cake_wallet/src/widgets/standard_list.dart';
|
|
import 'package:cake_wallet/src/widgets/standard_list_card.dart';
|
|
import 'package:cake_wallet/src/widgets/standard_list_status_row.dart';
|
|
import 'package:cake_wallet/utils/show_bar.dart';
|
|
import 'package:cake_wallet/view_model/trade_details_view_model.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/screens/base_page.dart';
|
|
import 'package:cake_wallet/src/widgets/list_row.dart';
|
|
import 'package:cake_wallet/src/screens/trade_details/track_trade_list_item.dart';
|
|
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';
|
|
|
|
class TradeDetailsPage extends BasePage {
|
|
TradeDetailsPage(this.tradeDetailsViewModel);
|
|
|
|
@override
|
|
String get title => S.current.trade_details_title;
|
|
|
|
final TradeDetailsViewModel tradeDetailsViewModel;
|
|
|
|
@override
|
|
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) {
|
|
return Observer(builder: (_) {
|
|
// FIX-ME: Added `context` it was not used here before, maby bug ?
|
|
return SectionStandardList(
|
|
sectionCount: 1,
|
|
itemCounter: (int _) => tradeDetailsViewModel.items.length,
|
|
itemBuilder: (__, index) {
|
|
final item = tradeDetailsViewModel.items[index];
|
|
|
|
if (item is TrackTradeListItem) {
|
|
return GestureDetector(
|
|
onTap: item.onTap,
|
|
child: ListRow(
|
|
title: '${item.title}', value: '${item.value}'));
|
|
}
|
|
|
|
if (item is DetailsListStatusItem) {
|
|
return StandardListStatusRow(
|
|
title: item.title,
|
|
value: item.value);
|
|
}
|
|
|
|
if (item is TradeDetailsListCardItem) {
|
|
return TradeDetailsStandardListCard(
|
|
id: item.id,
|
|
create: item.createdAt,
|
|
pair: item.pair,
|
|
currentTheme: tradeDetailsViewModel.settingsStore.currentTheme.type,
|
|
onTap: item.onTap,);
|
|
}
|
|
|
|
return GestureDetector(
|
|
onTap: () {
|
|
Clipboard.setData(ClipboardData(text: '${item.value}'));
|
|
showBar<void>(context, S.of(context).copied_to_clipboard);
|
|
},
|
|
child: ListRow(
|
|
title: '${item.title}', value: '${item.value}'));
|
|
});
|
|
});
|
|
}
|
|
|
|
}
|