2021-03-17 18:21:26 +00:00
|
|
|
import 'package:cake_wallet/entities/find_order_by_id.dart';
|
2021-03-03 18:54:23 +00:00
|
|
|
import 'package:cake_wallet/entities/wallet_type.dart';
|
2020-07-06 20:09:03 +00:00
|
|
|
import 'package:cake_wallet/generated/i18n.dart';
|
|
|
|
import 'package:cake_wallet/routes.dart';
|
2020-12-16 20:45:45 +00:00
|
|
|
import 'package:cake_wallet/themes/theme_base.dart';
|
2020-01-04 19:31:52 +00:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter/cupertino.dart';
|
2020-07-23 12:20:52 +00:00
|
|
|
import 'package:cake_wallet/view_model/dashboard/dashboard_view_model.dart';
|
2020-07-06 20:09:03 +00:00
|
|
|
import 'package:cake_wallet/src/screens/base_page.dart';
|
2020-05-29 15:10:11 +00:00
|
|
|
import 'package:cake_wallet/src/screens/dashboard/widgets/menu_widget.dart';
|
2020-07-21 17:22:41 +00:00
|
|
|
import 'package:cake_wallet/src/screens/dashboard/widgets/action_button.dart';
|
|
|
|
import 'package:cake_wallet/src/screens/dashboard/widgets/balance_page.dart';
|
2020-07-27 17:07:37 +00:00
|
|
|
import 'package:cake_wallet/src/screens/dashboard/widgets/address_page.dart';
|
2020-07-23 12:20:52 +00:00
|
|
|
import 'package:cake_wallet/src/screens/dashboard/widgets/transactions_page.dart';
|
2020-07-22 10:04:11 +00:00
|
|
|
import 'package:cake_wallet/src/screens/dashboard/widgets/sync_indicator.dart';
|
2020-07-27 17:07:37 +00:00
|
|
|
import 'package:cake_wallet/view_model/wallet_address_list/wallet_address_list_view_model.dart';
|
2021-03-03 18:54:23 +00:00
|
|
|
import 'package:flutter_mobx/flutter_mobx.dart';
|
2020-07-31 19:55:26 +00:00
|
|
|
import 'package:smooth_page_indicator/smooth_page_indicator.dart';
|
2020-01-04 19:31:52 +00:00
|
|
|
|
2020-07-06 20:09:03 +00:00
|
|
|
class DashboardPage extends BasePage {
|
2020-07-27 17:07:37 +00:00
|
|
|
DashboardPage({
|
|
|
|
@required this.walletViewModel,
|
|
|
|
@required this.addressListViewModel,
|
|
|
|
});
|
2020-06-20 07:10:00 +00:00
|
|
|
|
2020-04-14 18:15:47 +00:00
|
|
|
@override
|
2020-12-16 20:45:45 +00:00
|
|
|
Color get backgroundLightColor => currentTheme.type == ThemeType.bright
|
|
|
|
? Colors.transparent : Colors.white;
|
2020-01-04 19:31:52 +00:00
|
|
|
|
|
|
|
@override
|
2020-08-19 17:57:06 +00:00
|
|
|
Color get backgroundDarkColor => Colors.transparent;
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget Function(BuildContext, Widget) get rootWrapper =>
|
2020-09-01 11:18:07 +00:00
|
|
|
(BuildContext context, Widget scaffold) => Container(
|
2020-08-19 17:57:06 +00:00
|
|
|
decoration: BoxDecoration(
|
|
|
|
gradient: LinearGradient(colors: [
|
2020-09-01 11:18:07 +00:00
|
|
|
Theme.of(context).accentColor,
|
|
|
|
Theme.of(context).scaffoldBackgroundColor,
|
|
|
|
Theme.of(context).primaryColor,
|
|
|
|
], begin: Alignment.topRight, end: Alignment.bottomLeft)),
|
2020-08-19 17:57:06 +00:00
|
|
|
child: scaffold);
|
2020-01-04 19:31:52 +00:00
|
|
|
|
2020-07-28 16:03:34 +00:00
|
|
|
@override
|
|
|
|
bool get resizeToAvoidBottomPadding => false;
|
|
|
|
|
2020-07-31 15:29:21 +00:00
|
|
|
@override
|
2020-09-01 11:18:07 +00:00
|
|
|
Widget get endDrawer => MenuWidget(walletViewModel);
|
2020-07-31 15:29:21 +00:00
|
|
|
|
2020-07-22 10:04:11 +00:00
|
|
|
@override
|
|
|
|
Widget middle(BuildContext context) {
|
|
|
|
return SyncIndicator(dashboardViewModel: walletViewModel);
|
|
|
|
}
|
|
|
|
|
2020-01-04 19:31:52 +00:00
|
|
|
@override
|
2020-07-06 20:09:03 +00:00
|
|
|
Widget trailing(BuildContext context) {
|
2020-09-01 11:18:07 +00:00
|
|
|
final menuButton =
|
2020-12-11 18:46:20 +00:00
|
|
|
Image.asset('assets/images/menu.png',
|
|
|
|
color: Theme.of(context).accentTextTheme.display3.backgroundColor);
|
2020-07-06 20:09:03 +00:00
|
|
|
|
|
|
|
return Container(
|
2020-09-01 11:18:07 +00:00
|
|
|
alignment: Alignment.centerRight,
|
|
|
|
width: 40,
|
|
|
|
child: FlatButton(
|
|
|
|
highlightColor: Colors.transparent,
|
|
|
|
splashColor: Colors.transparent,
|
|
|
|
padding: EdgeInsets.all(0),
|
|
|
|
onPressed: () => onOpenEndDrawer(),
|
|
|
|
child: menuButton));
|
2020-07-06 20:09:03 +00:00
|
|
|
}
|
2020-04-14 18:15:47 +00:00
|
|
|
|
2020-07-06 20:09:03 +00:00
|
|
|
final DashboardViewModel walletViewModel;
|
2020-07-27 17:07:37 +00:00
|
|
|
final WalletAddressListViewModel addressListViewModel;
|
|
|
|
final controller = PageController(initialPage: 1);
|
2020-07-21 17:22:41 +00:00
|
|
|
|
|
|
|
var pages = <Widget>[];
|
|
|
|
bool _isEffectsInstalled = false;
|
2020-07-06 20:09:03 +00:00
|
|
|
|
|
|
|
@override
|
|
|
|
Widget body(BuildContext context) {
|
2020-12-11 18:46:20 +00:00
|
|
|
final sendImage = Image.asset('assets/images/upload.png',
|
|
|
|
height: 22.24, width: 24,
|
|
|
|
color: Theme.of(context).accentTextTheme.display3.backgroundColor);
|
|
|
|
final exchangeImage = Image.asset('assets/images/transfer.png',
|
|
|
|
height: 24.27, width: 22.25,
|
|
|
|
color: Theme.of(context).accentTextTheme.display3.backgroundColor);
|
2021-03-03 18:54:23 +00:00
|
|
|
final buyImage = Image.asset('assets/images/coins.png',
|
2020-12-11 18:46:20 +00:00
|
|
|
height: 22.24, width: 24,
|
|
|
|
color: Theme.of(context).accentTextTheme.display3.backgroundColor);
|
2020-07-21 17:22:41 +00:00
|
|
|
_setEffects();
|
|
|
|
|
|
|
|
return SafeArea(
|
2020-09-01 11:18:07 +00:00
|
|
|
child: Column(
|
|
|
|
mainAxisSize: MainAxisSize.max,
|
|
|
|
children: <Widget>[
|
|
|
|
Expanded(
|
2020-07-22 10:04:11 +00:00
|
|
|
child: PageView.builder(
|
2020-09-01 11:18:07 +00:00
|
|
|
controller: controller,
|
|
|
|
itemCount: pages.length,
|
2020-09-09 14:13:44 +00:00
|
|
|
itemBuilder: (context, index) => pages[index])),
|
2020-09-01 11:18:07 +00:00
|
|
|
Padding(
|
|
|
|
padding: EdgeInsets.only(bottom: 24),
|
2020-07-31 19:55:26 +00:00
|
|
|
child: SmoothPageIndicator(
|
2020-07-22 10:04:11 +00:00
|
|
|
controller: controller,
|
2020-09-01 11:18:07 +00:00
|
|
|
count: pages.length,
|
2020-07-31 19:55:26 +00:00
|
|
|
effect: ColorTransitionEffect(
|
2020-09-01 11:18:07 +00:00
|
|
|
spacing: 6.0,
|
|
|
|
radius: 6.0,
|
|
|
|
dotWidth: 6.0,
|
|
|
|
dotHeight: 6.0,
|
|
|
|
dotColor: Theme.of(context).indicatorColor,
|
2020-12-11 18:46:20 +00:00
|
|
|
activeDotColor: Theme.of(context).accentTextTheme.display1
|
|
|
|
.backgroundColor),
|
2020-09-01 11:18:07 +00:00
|
|
|
)),
|
|
|
|
Container(
|
2020-09-25 11:25:08 +00:00
|
|
|
padding: EdgeInsets.only(left: 45, right: 45, bottom: 24),
|
2021-03-03 18:54:23 +00:00
|
|
|
child: Observer(builder: (_) => Row(
|
2020-09-28 15:47:43 +00:00
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceAround,
|
2020-09-01 11:18:07 +00:00
|
|
|
children: <Widget>[
|
2020-09-25 11:25:08 +00:00
|
|
|
ActionButton(
|
2020-09-26 12:19:33 +00:00
|
|
|
image: sendImage,
|
|
|
|
title: S.of(context).send,
|
|
|
|
route: Routes.send),
|
2020-09-25 11:25:08 +00:00
|
|
|
ActionButton(
|
2020-09-26 12:19:33 +00:00
|
|
|
image: exchangeImage,
|
|
|
|
title: S.of(context).exchange,
|
|
|
|
route: Routes.exchange),
|
2021-03-17 19:32:13 +00:00
|
|
|
if (walletViewModel.type == WalletType.bitcoin) Observer(
|
|
|
|
builder: (_) => ActionButton(
|
|
|
|
image: buyImage,
|
|
|
|
title: S.of(context).buy,
|
|
|
|
onClick: walletViewModel.isRunningWebView
|
|
|
|
? null
|
|
|
|
: () async {
|
|
|
|
walletViewModel.isRunningWebView = true;
|
|
|
|
final url = await walletViewModel.getWyreUrl();
|
|
|
|
if (url.isNotEmpty) {
|
|
|
|
await Navigator.of(context)
|
|
|
|
.pushNamed(Routes.webView, arguments: url);
|
|
|
|
|
|
|
|
final orderId = walletViewModel.ordersStore.orderId;
|
|
|
|
|
|
|
|
if (orderId.isNotEmpty) {
|
|
|
|
await walletViewModel.saveOrder(orderId);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
walletViewModel.isRunningWebView = false;
|
|
|
|
})),
|
2020-09-01 11:18:07 +00:00
|
|
|
],
|
2021-03-03 18:54:23 +00:00
|
|
|
)),
|
2020-09-01 11:18:07 +00:00
|
|
|
)
|
|
|
|
],
|
|
|
|
));
|
2020-07-06 20:09:03 +00:00
|
|
|
}
|
|
|
|
|
2020-07-21 17:22:41 +00:00
|
|
|
void _setEffects() {
|
|
|
|
if (_isEffectsInstalled) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-07-27 17:07:37 +00:00
|
|
|
pages.add(AddressPage(addressListViewModel: addressListViewModel));
|
2020-07-21 17:22:41 +00:00
|
|
|
pages.add(BalancePage(dashboardViewModel: walletViewModel));
|
2020-07-23 12:20:52 +00:00
|
|
|
pages.add(TransactionsPage(dashboardViewModel: walletViewModel));
|
2020-07-21 17:22:41 +00:00
|
|
|
|
|
|
|
_isEffectsInstalled = true;
|
|
|
|
}
|
2020-01-04 19:31:52 +00:00
|
|
|
}
|