mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-18 08:45:05 +00:00
CAKE-20 | applied light theme to dashboard, receive, monero_account_list, monero_account_edit_or_create, address_edit_or_create, trade_details, transaction_details and base pages
This commit is contained in:
parent
1ba86506f0
commit
27dce3118d
30 changed files with 399 additions and 227 deletions
BIN
assets/images/2.0x/bitcoin_menu.png
Normal file
BIN
assets/images/2.0x/bitcoin_menu.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.3 KiB |
BIN
assets/images/3.0x/bitcoin_menu.png
Normal file
BIN
assets/images/3.0x/bitcoin_menu.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.4 KiB |
BIN
assets/images/bitcoin_menu.png
Normal file
BIN
assets/images/bitcoin_menu.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.2 KiB |
|
@ -13,6 +13,23 @@ class Palette {
|
||||||
static const Color blue = Color.fromRGBO(88, 143, 252, 1.0);
|
static const Color blue = Color.fromRGBO(88, 143, 252, 1.0);
|
||||||
static const Color darkLavender = Color.fromRGBO(225, 238, 250, 1.0);
|
static const Color darkLavender = Color.fromRGBO(225, 238, 250, 1.0);
|
||||||
static const Color nightBlue = Color.fromRGBO(46, 57, 96, 1.0);
|
static const Color nightBlue = Color.fromRGBO(46, 57, 96, 1.0);
|
||||||
|
|
||||||
|
// NEW DESIGN
|
||||||
|
static const Color blueCraiola = Color.fromRGBO(69, 110, 255, 1.0);
|
||||||
|
static const Color darkBlueCraiola = Color.fromRGBO(53, 86, 136, 1.0);
|
||||||
|
static const Color pinkFlamingo = Color.fromRGBO(240, 60, 243, 1.0);
|
||||||
|
static const Color redHat = Color.fromRGBO(209, 68, 37, 1.0);
|
||||||
|
static const Color shineOrange = Color.fromRGBO(255, 184, 78, 1.0);
|
||||||
|
static const Color paleBlue = Color.fromRGBO(225, 228, 233, 1.0);
|
||||||
|
static const Color violetBlue = Color.fromRGBO(56, 69, 103, 1.0);
|
||||||
|
static const Color periwinkleCraiola = Color.fromRGBO(229, 232, 242, 1.0);
|
||||||
|
static const Color moderatePurpleBlue = Color.fromRGBO(57, 74, 95, 1.0);
|
||||||
|
static const Color moderateLavender = Color.fromRGBO(233, 242, 252, 1.0);
|
||||||
|
static const Color wildLavender = Color.fromRGBO(224, 230, 246, 1.0);
|
||||||
|
static const Color gray = Color.fromRGBO(112, 147, 186, 1.0);
|
||||||
|
static const Color wildPeriwinkle = Color.fromRGBO(219, 227, 243, 1.0);
|
||||||
|
static const Color darkGray = Color.fromRGBO(122, 147, 186, 1.0);
|
||||||
|
|
||||||
// FIXME: Rename.
|
// FIXME: Rename.
|
||||||
static const Color eee = Color.fromRGBO(236, 239, 245, 1.0);
|
static const Color eee = Color.fromRGBO(236, 239, 245, 1.0);
|
||||||
static const Color xxx = Color.fromRGBO(72, 89, 109, 1);
|
static const Color xxx = Color.fromRGBO(72, 89, 109, 1);
|
||||||
|
|
|
@ -15,7 +15,9 @@ abstract class BasePage extends StatelessWidget {
|
||||||
|
|
||||||
Color get backgroundLightColor => Colors.white;
|
Color get backgroundLightColor => Colors.white;
|
||||||
|
|
||||||
Color get backgroundDarkColor => PaletteDark.darkNightBlue;
|
Color get backgroundDarkColor => PaletteDark.backgroundColor;
|
||||||
|
|
||||||
|
Color get titleColor => null;
|
||||||
|
|
||||||
bool get resizeToAvoidBottomPadding => true;
|
bool get resizeToAvoidBottomPadding => true;
|
||||||
|
|
||||||
|
@ -27,11 +29,6 @@ abstract class BasePage extends StatelessWidget {
|
||||||
|
|
||||||
final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();
|
final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();
|
||||||
|
|
||||||
final _backArrowImage = Image.asset('assets/images/back_arrow.png',
|
|
||||||
color: Colors.white);
|
|
||||||
final _backArrowImageDarkTheme =
|
|
||||||
Image.asset('assets/images/back_arrow_dark_theme.png',
|
|
||||||
color: Colors.white);
|
|
||||||
final _closeButtonImage = Image.asset('assets/images/close_button.png');
|
final _closeButtonImage = Image.asset('assets/images/close_button.png');
|
||||||
final _closeButtonImageDarkTheme =
|
final _closeButtonImageDarkTheme =
|
||||||
Image.asset('assets/images/close_button_dark_theme.png');
|
Image.asset('assets/images/close_button_dark_theme.png');
|
||||||
|
@ -45,16 +42,13 @@ abstract class BasePage extends StatelessWidget {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
final _themeChanger = Provider.of<ThemeChanger>(context);
|
final _backButton = Image.asset('assets/images/back_arrow.png',
|
||||||
Image _closeButton, _backButton;
|
color: titleColor ?? Theme.of(context).primaryTextTheme.title.color);
|
||||||
|
|
||||||
if (_themeChanger.getTheme() == Themes.darkTheme) {
|
final _themeChanger = Provider.of<ThemeChanger>(context);
|
||||||
_backButton = _backArrowImageDarkTheme;
|
final _closeButton = _themeChanger.getTheme() == Themes.darkTheme
|
||||||
_closeButton = _closeButtonImageDarkTheme;
|
? _closeButtonImageDarkTheme
|
||||||
} else {
|
: _closeButtonImage;
|
||||||
_backButton = _backArrowImage;
|
|
||||||
_closeButton = _closeButtonImage;
|
|
||||||
}
|
|
||||||
|
|
||||||
return SizedBox(
|
return SizedBox(
|
||||||
height: 37,
|
height: 37,
|
||||||
|
@ -79,7 +73,8 @@ abstract class BasePage extends StatelessWidget {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 18.0,
|
fontSize: 18.0,
|
||||||
fontWeight: FontWeight.bold,
|
fontWeight: FontWeight.bold,
|
||||||
color: Colors.white),
|
color: titleColor ??
|
||||||
|
Theme.of(context).primaryTextTheme.title.color),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,6 @@ import 'package:flutter/cupertino.dart';
|
||||||
import 'package:cake_wallet/view_model/dashboard/dashboard_view_model.dart';
|
import 'package:cake_wallet/view_model/dashboard/dashboard_view_model.dart';
|
||||||
import 'package:cake_wallet/src/screens/base_page.dart';
|
import 'package:cake_wallet/src/screens/base_page.dart';
|
||||||
import 'package:cake_wallet/src/screens/dashboard/widgets/menu_widget.dart';
|
import 'package:cake_wallet/src/screens/dashboard/widgets/menu_widget.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
import 'package:cake_wallet/src/screens/dashboard/widgets/action_button.dart';
|
import 'package:cake_wallet/src/screens/dashboard/widgets/action_button.dart';
|
||||||
import 'package:cake_wallet/src/screens/dashboard/widgets/balance_page.dart';
|
import 'package:cake_wallet/src/screens/dashboard/widgets/balance_page.dart';
|
||||||
import 'package:cake_wallet/src/screens/dashboard/widgets/address_page.dart';
|
import 'package:cake_wallet/src/screens/dashboard/widgets/address_page.dart';
|
||||||
|
@ -21,10 +20,23 @@ class DashboardPage extends BasePage {
|
||||||
});
|
});
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Color get backgroundLightColor => PaletteDark.backgroundColor;
|
Color get backgroundLightColor => Colors.transparent;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Color get backgroundDarkColor => PaletteDark.backgroundColor;
|
Color get backgroundDarkColor => Colors.transparent;
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget Function(BuildContext, Widget) get rootWrapper =>
|
||||||
|
(BuildContext context, Widget scaffold) => Container(
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
gradient: LinearGradient(colors: [
|
||||||
|
Theme.of(context).accentColor,
|
||||||
|
Theme.of(context).scaffoldBackgroundColor,
|
||||||
|
Theme.of(context).primaryColor,
|
||||||
|
],
|
||||||
|
begin: Alignment.topRight,
|
||||||
|
end: Alignment.bottomLeft)),
|
||||||
|
child: scaffold);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
bool get resizeToAvoidBottomPadding => false;
|
bool get resizeToAvoidBottomPadding => false;
|
||||||
|
@ -101,7 +113,7 @@ class DashboardPage extends BasePage {
|
||||||
radius: 6.0,
|
radius: 6.0,
|
||||||
dotWidth: 6.0,
|
dotWidth: 6.0,
|
||||||
dotHeight: 6.0,
|
dotHeight: 6.0,
|
||||||
dotColor: PaletteDark.cyanBlue,
|
dotColor: Theme.of(context).indicatorColor,
|
||||||
activeDotColor: Colors.white
|
activeDotColor: Colors.white
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
|
|
||||||
class ActionButton extends StatelessWidget{
|
class ActionButton extends StatelessWidget{
|
||||||
ActionButton({
|
ActionButton({
|
||||||
|
@ -36,7 +35,7 @@ class ActionButton extends StatelessWidget{
|
||||||
width: 60,
|
width: 60,
|
||||||
alignment: Alignment.center,
|
alignment: Alignment.center,
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
color: PaletteDark.nightBlue,
|
color: Theme.of(context).buttonColor,
|
||||||
shape: BoxShape.circle),
|
shape: BoxShape.circle),
|
||||||
child: image,
|
child: image,
|
||||||
),
|
),
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:cake_wallet/view_model/wallet_address_list/wallet_address_list_view_model.dart';
|
import 'package:cake_wallet/view_model/wallet_address_list/wallet_address_list_view_model.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
import 'package:cake_wallet/src/screens/receive/widgets/qr_widget.dart';
|
import 'package:cake_wallet/src/screens/receive/widgets/qr_widget.dart';
|
||||||
import 'package:cake_wallet/routes.dart';
|
import 'package:cake_wallet/routes.dart';
|
||||||
import 'package:cake_wallet/generated/i18n.dart';
|
import 'package:cake_wallet/generated/i18n.dart';
|
||||||
|
@ -29,7 +28,11 @@ class AddressPage extends StatelessWidget {
|
||||||
alignment: Alignment.center,
|
alignment: Alignment.center,
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
borderRadius: BorderRadius.all(Radius.circular(25)),
|
borderRadius: BorderRadius.all(Radius.circular(25)),
|
||||||
color: PaletteDark.nightBlue
|
border: Border.all(
|
||||||
|
color: Theme.of(context).textTheme.subhead.color,
|
||||||
|
width: 1
|
||||||
|
),
|
||||||
|
color: Theme.of(context).buttonColor
|
||||||
),
|
),
|
||||||
child: Row(
|
child: Row(
|
||||||
mainAxisSize: MainAxisSize.max,
|
mainAxisSize: MainAxisSize.max,
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:cake_wallet/view_model/dashboard/dashboard_view_model.dart';
|
import 'package:cake_wallet/view_model/dashboard/dashboard_view_model.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
import 'package:flutter_mobx/flutter_mobx.dart';
|
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||||
|
|
||||||
class BalancePage extends StatelessWidget {
|
class BalancePage extends StatelessWidget {
|
||||||
|
@ -26,7 +25,7 @@ class BalancePage extends StatelessWidget {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 40,
|
fontSize: 40,
|
||||||
fontWeight: FontWeight.bold,
|
fontWeight: FontWeight.bold,
|
||||||
color: PaletteDark.cyanBlue,
|
color: Theme.of(context).indicatorColor,
|
||||||
height: 1
|
height: 1
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
@ -52,7 +51,7 @@ class BalancePage extends StatelessWidget {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 18,
|
fontSize: 18,
|
||||||
fontWeight: FontWeight.w500,
|
fontWeight: FontWeight.w500,
|
||||||
color: PaletteDark.cyanBlue,
|
color: Theme.of(context).indicatorColor,
|
||||||
height: 1
|
height: 1
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
|
@ -3,7 +3,6 @@ import 'package:intl/intl.dart';
|
||||||
import 'package:cake_wallet/generated/i18n.dart';
|
import 'package:cake_wallet/generated/i18n.dart';
|
||||||
import 'package:provider/provider.dart';
|
import 'package:provider/provider.dart';
|
||||||
import 'package:cake_wallet/src/stores/settings/settings_store.dart';
|
import 'package:cake_wallet/src/stores/settings/settings_store.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
|
|
||||||
class DateSectionRaw extends StatelessWidget {
|
class DateSectionRaw extends StatelessWidget {
|
||||||
DateSectionRaw({this.date});
|
DateSectionRaw({this.date});
|
||||||
|
@ -42,7 +41,7 @@ class DateSectionRaw extends StatelessWidget {
|
||||||
child: Text(title,
|
child: Text(title,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 12,
|
fontSize: 12,
|
||||||
color: PaletteDark.darkCyanBlue
|
color: Theme.of(context).textTheme.overline.backgroundColor
|
||||||
))
|
))
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
import 'package:cake_wallet/generated/i18n.dart';
|
import 'package:cake_wallet/generated/i18n.dart';
|
||||||
import 'package:cake_wallet/view_model/dashboard/dashboard_view_model.dart';
|
import 'package:cake_wallet/view_model/dashboard/dashboard_view_model.dart';
|
||||||
import 'package:cake_wallet/src/domain/exchange/exchange_provider_description.dart';
|
import 'package:cake_wallet/src/domain/exchange/exchange_provider_description.dart';
|
||||||
|
@ -11,11 +10,11 @@ class HeaderRow extends StatelessWidget {
|
||||||
|
|
||||||
final DashboardViewModel dashboardViewModel;
|
final DashboardViewModel dashboardViewModel;
|
||||||
|
|
||||||
final filterIcon = Image.asset('assets/images/filter_icon.png',
|
|
||||||
color: PaletteDark.wildBlue);
|
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
|
final filterIcon = Image.asset('assets/images/filter_icon.png',
|
||||||
|
color: Theme.of(context).textTheme.caption.decorationColor);
|
||||||
|
|
||||||
return Container(
|
return Container(
|
||||||
height: 52,
|
height: 52,
|
||||||
color: Colors.transparent,
|
color: Colors.transparent,
|
||||||
|
@ -40,7 +39,7 @@ class HeaderRow extends StatelessWidget {
|
||||||
child: Text(S.of(context).transactions,
|
child: Text(S.of(context).transactions,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontWeight: FontWeight.bold,
|
fontWeight: FontWeight.bold,
|
||||||
color: Theme.of(context).primaryTextTheme.caption.color))),
|
color: Theme.of(context).primaryTextTheme.title.color))),
|
||||||
PopupMenuItem(
|
PopupMenuItem(
|
||||||
value: 0,
|
value: 0,
|
||||||
child: Observer(
|
child: Observer(
|
||||||
|
@ -49,7 +48,11 @@ class HeaderRow extends StatelessWidget {
|
||||||
MainAxisAlignment
|
MainAxisAlignment
|
||||||
.spaceBetween,
|
.spaceBetween,
|
||||||
children: [
|
children: [
|
||||||
Text(S.of(context).incoming),
|
Text(S.of(context).incoming,
|
||||||
|
style: TextStyle(
|
||||||
|
color: Theme.of(context).primaryTextTheme.title.color
|
||||||
|
),
|
||||||
|
),
|
||||||
Checkbox(
|
Checkbox(
|
||||||
value: dashboardViewModel
|
value: dashboardViewModel
|
||||||
.transactionFilterStore
|
.transactionFilterStore
|
||||||
|
@ -67,7 +70,11 @@ class HeaderRow extends StatelessWidget {
|
||||||
MainAxisAlignment
|
MainAxisAlignment
|
||||||
.spaceBetween,
|
.spaceBetween,
|
||||||
children: [
|
children: [
|
||||||
Text(S.of(context).outgoing),
|
Text(S.of(context).outgoing,
|
||||||
|
style: TextStyle(
|
||||||
|
color: Theme.of(context).primaryTextTheme.title.color
|
||||||
|
)
|
||||||
|
),
|
||||||
Checkbox(
|
Checkbox(
|
||||||
value: dashboardViewModel
|
value: dashboardViewModel
|
||||||
.transactionFilterStore
|
.transactionFilterStore
|
||||||
|
@ -80,7 +87,11 @@ class HeaderRow extends StatelessWidget {
|
||||||
PopupMenuItem(
|
PopupMenuItem(
|
||||||
value: 2,
|
value: 2,
|
||||||
child:
|
child:
|
||||||
Text(S.of(context).transactions_by_date)),
|
Text(S.of(context).transactions_by_date,
|
||||||
|
style: TextStyle(
|
||||||
|
color: Theme.of(context).primaryTextTheme.title.color
|
||||||
|
)
|
||||||
|
)),
|
||||||
PopupMenuDivider(),
|
PopupMenuDivider(),
|
||||||
PopupMenuItem(
|
PopupMenuItem(
|
||||||
enabled: false,
|
enabled: false,
|
||||||
|
@ -88,7 +99,7 @@ class HeaderRow extends StatelessWidget {
|
||||||
child: Text(S.of(context).trades,
|
child: Text(S.of(context).trades,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontWeight: FontWeight.bold,
|
fontWeight: FontWeight.bold,
|
||||||
color: Theme.of(context).primaryTextTheme.caption.color))),
|
color: Theme.of(context).primaryTextTheme.title.color))),
|
||||||
PopupMenuItem(
|
PopupMenuItem(
|
||||||
value: 3,
|
value: 3,
|
||||||
child: Observer(
|
child: Observer(
|
||||||
|
@ -97,7 +108,11 @@ class HeaderRow extends StatelessWidget {
|
||||||
MainAxisAlignment
|
MainAxisAlignment
|
||||||
.spaceBetween,
|
.spaceBetween,
|
||||||
children: [
|
children: [
|
||||||
Text('XMR.TO'),
|
Text('XMR.TO',
|
||||||
|
style: TextStyle(
|
||||||
|
color: Theme.of(context).primaryTextTheme.title.color
|
||||||
|
)
|
||||||
|
),
|
||||||
Checkbox(
|
Checkbox(
|
||||||
value: dashboardViewModel
|
value: dashboardViewModel
|
||||||
.tradeFilterStore
|
.tradeFilterStore
|
||||||
|
@ -117,7 +132,11 @@ class HeaderRow extends StatelessWidget {
|
||||||
MainAxisAlignment
|
MainAxisAlignment
|
||||||
.spaceBetween,
|
.spaceBetween,
|
||||||
children: [
|
children: [
|
||||||
Text('Change.NOW'),
|
Text('Change.NOW',
|
||||||
|
style: TextStyle(
|
||||||
|
color: Theme.of(context).primaryTextTheme.title.color
|
||||||
|
)
|
||||||
|
),
|
||||||
Checkbox(
|
Checkbox(
|
||||||
value: dashboardViewModel
|
value: dashboardViewModel
|
||||||
.tradeFilterStore
|
.tradeFilterStore
|
||||||
|
@ -137,7 +156,11 @@ class HeaderRow extends StatelessWidget {
|
||||||
MainAxisAlignment
|
MainAxisAlignment
|
||||||
.spaceBetween,
|
.spaceBetween,
|
||||||
children: [
|
children: [
|
||||||
Text('MorphToken'),
|
Text('MorphToken',
|
||||||
|
style: TextStyle(
|
||||||
|
color: Theme.of(context).primaryTextTheme.title.color
|
||||||
|
)
|
||||||
|
),
|
||||||
Checkbox(
|
Checkbox(
|
||||||
value: dashboardViewModel
|
value: dashboardViewModel
|
||||||
.tradeFilterStore
|
.tradeFilterStore
|
||||||
|
@ -155,7 +178,7 @@ class HeaderRow extends StatelessWidget {
|
||||||
width: 36,
|
width: 36,
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
shape: BoxShape.circle,
|
shape: BoxShape.circle,
|
||||||
color: PaletteDark.oceanBlue
|
color: Theme.of(context).textTheme.overline.color
|
||||||
),
|
),
|
||||||
child: filterIcon,
|
child: filterIcon,
|
||||||
),
|
),
|
||||||
|
|
|
@ -17,7 +17,7 @@ class MenuWidget extends StatefulWidget {
|
||||||
|
|
||||||
class MenuWidgetState extends State<MenuWidget> {
|
class MenuWidgetState extends State<MenuWidget> {
|
||||||
final moneroIcon = Image.asset('assets/images/monero_menu.png');
|
final moneroIcon = Image.asset('assets/images/monero_menu.png');
|
||||||
final bitcoinIcon = Image.asset('assets/images/bitcoin.png');
|
final bitcoinIcon = Image.asset('assets/images/bitcoin_menu.png');
|
||||||
final largeScreen = 731;
|
final largeScreen = 731;
|
||||||
|
|
||||||
double menuWidth;
|
double menuWidth;
|
||||||
|
@ -81,7 +81,7 @@ class MenuWidgetState extends State<MenuWidget> {
|
||||||
width: 4,
|
width: 4,
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
borderRadius: BorderRadius.all(Radius.circular(2)),
|
borderRadius: BorderRadius.all(Radius.circular(2)),
|
||||||
color: Theme.of(context).hintColor),
|
color: PaletteDark.gray),
|
||||||
)),
|
)),
|
||||||
SizedBox(width: 12),
|
SizedBox(width: 12),
|
||||||
Expanded(
|
Expanded(
|
||||||
|
@ -92,12 +92,13 @@ class MenuWidgetState extends State<MenuWidget> {
|
||||||
child: Container(
|
child: Container(
|
||||||
width: menuWidth,
|
width: menuWidth,
|
||||||
height: double.infinity,
|
height: double.infinity,
|
||||||
color: PaletteDark.deepPurpleBlue,
|
color: Theme.of(context).textTheme.body2.decorationColor,
|
||||||
child: SingleChildScrollView(
|
child: SingleChildScrollView(
|
||||||
child: Column(
|
child: Column(
|
||||||
children: <Widget>[
|
children: <Widget>[
|
||||||
Container(
|
Container(
|
||||||
height: headerHeight,
|
height: headerHeight,
|
||||||
|
color: Theme.of(context).textTheme.body2.color,
|
||||||
padding: EdgeInsets.only(
|
padding: EdgeInsets.only(
|
||||||
left: 24,
|
left: 24,
|
||||||
top: fromTopEdge,
|
top: fromTopEdge,
|
||||||
|
@ -120,7 +121,8 @@ class MenuWidgetState extends State<MenuWidget> {
|
||||||
Text(
|
Text(
|
||||||
widget.name,
|
widget.name,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
color: Colors.white,
|
color: Theme.of(context).textTheme
|
||||||
|
.display2.color,
|
||||||
fontSize: 16,
|
fontSize: 16,
|
||||||
fontWeight: FontWeight.bold),
|
fontWeight: FontWeight.bold),
|
||||||
),
|
),
|
||||||
|
@ -128,7 +130,9 @@ class MenuWidgetState extends State<MenuWidget> {
|
||||||
Text(
|
Text(
|
||||||
widget.subname,
|
widget.subname,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
color: PaletteDark.darkCyanBlue,
|
color: Theme.of(context)
|
||||||
|
.primaryTextTheme
|
||||||
|
.caption.color,
|
||||||
fontWeight: FontWeight.w500,
|
fontWeight: FontWeight.w500,
|
||||||
fontSize: 12),
|
fontSize: 12),
|
||||||
)
|
)
|
||||||
|
@ -140,7 +144,7 @@ class MenuWidgetState extends State<MenuWidget> {
|
||||||
),
|
),
|
||||||
Container(
|
Container(
|
||||||
height: 1,
|
height: 1,
|
||||||
color: PaletteDark.darkOceanBlue,
|
color: Theme.of(context).primaryTextTheme.caption.decorationColor,
|
||||||
),
|
),
|
||||||
ListView.separated(
|
ListView.separated(
|
||||||
shrinkWrap: true,
|
shrinkWrap: true,
|
||||||
|
@ -178,7 +182,8 @@ class MenuWidgetState extends State<MenuWidget> {
|
||||||
child: Text(
|
child: Text(
|
||||||
item,
|
item,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
color: Colors.white,
|
color: Theme.of(context).textTheme
|
||||||
|
.display2.color,
|
||||||
fontSize: 16,
|
fontSize: 16,
|
||||||
fontWeight: FontWeight.bold),
|
fontWeight: FontWeight.bold),
|
||||||
))
|
))
|
||||||
|
@ -189,7 +194,7 @@ class MenuWidgetState extends State<MenuWidget> {
|
||||||
},
|
},
|
||||||
separatorBuilder: (_, index) => Container(
|
separatorBuilder: (_, index) => Container(
|
||||||
height: 1,
|
height: 1,
|
||||||
color: PaletteDark.darkOceanBlue,
|
color: Theme.of(context).primaryTextTheme.caption.decorationColor,
|
||||||
),
|
),
|
||||||
itemCount: itemCount)
|
itemCount: itemCount)
|
||||||
],
|
],
|
||||||
|
|
|
@ -13,35 +13,36 @@ class SyncIndicator extends StatelessWidget {
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return Observer(
|
return Observer(
|
||||||
builder: (_) {
|
builder: (_) {
|
||||||
final syncIndicatorWidth = 250.0;
|
final syncIndicatorWidth = 237.0;
|
||||||
final status = dashboardViewModel.status;
|
final status = dashboardViewModel.status;
|
||||||
final statusText = status.title();
|
final statusText = status != null ? status.title() : '';
|
||||||
final progress = status.progress();
|
final progress = status != null ? status.progress() : 0.0;
|
||||||
final indicatorOffset = progress * syncIndicatorWidth;
|
final indicatorOffset = progress * syncIndicatorWidth;
|
||||||
final indicatorWidth =
|
final indicatorWidth = progress < 1
|
||||||
progress <= 1 ? syncIndicatorWidth - indicatorOffset : 0.0;
|
? indicatorOffset > 0 ? indicatorOffset : 0.0
|
||||||
|
: syncIndicatorWidth;
|
||||||
final indicatorColor = status is SyncedSyncStatus
|
final indicatorColor = status is SyncedSyncStatus
|
||||||
? PaletteDark.brightGreen
|
? PaletteDark.brightGreen
|
||||||
: PaletteDark.orangeYellow;
|
: Theme.of(context).textTheme.caption.color;
|
||||||
|
|
||||||
return ClipRRect(
|
return ClipRRect(
|
||||||
borderRadius: BorderRadius.all(Radius.circular(15)),
|
borderRadius: BorderRadius.all(Radius.circular(15)),
|
||||||
child: Container(
|
child: Container(
|
||||||
height: 30,
|
height: 30,
|
||||||
width: syncIndicatorWidth,
|
width: syncIndicatorWidth,
|
||||||
color: PaletteDark.lightNightBlue,
|
color: Theme.of(context).textTheme.title.decorationColor,
|
||||||
child: Stack(
|
child: Stack(
|
||||||
alignment: Alignment.center,
|
alignment: Alignment.center,
|
||||||
children: <Widget>[
|
children: <Widget>[
|
||||||
progress <= 1
|
progress <= 1
|
||||||
? Positioned(
|
? Positioned(
|
||||||
left: indicatorOffset,
|
left: 0,
|
||||||
top: 0,
|
top: 0,
|
||||||
bottom: 0,
|
bottom: 0,
|
||||||
child: Container(
|
child: Container(
|
||||||
width: indicatorWidth,
|
width: indicatorWidth,
|
||||||
height: 30,
|
height: 30,
|
||||||
color: PaletteDark.oceanBlue,
|
color: Theme.of(context).textTheme.title.backgroundColor,
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
: Offstage(),
|
: Offstage(),
|
||||||
|
@ -70,7 +71,7 @@ class SyncIndicator extends StatelessWidget {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 12,
|
fontSize: 12,
|
||||||
fontWeight: FontWeight.w500,
|
fontWeight: FontWeight.w500,
|
||||||
color: PaletteDark.wildBlue
|
color: Theme.of(context).textTheme.title.color
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:cake_wallet/src/domain/common/crypto_currency.dart';
|
import 'package:cake_wallet/src/domain/common/crypto_currency.dart';
|
||||||
import 'package:cake_wallet/src/domain/exchange/exchange_provider_description.dart';
|
import 'package:cake_wallet/src/domain/exchange/exchange_provider_description.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
|
|
||||||
class TradeRow extends StatelessWidget {
|
class TradeRow extends StatelessWidget {
|
||||||
TradeRow({
|
TradeRow({
|
||||||
|
@ -66,7 +65,8 @@ class TradeRow extends StatelessWidget {
|
||||||
Text(createdAtFormattedDate,
|
Text(createdAtFormattedDate,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 14,
|
fontSize: 14,
|
||||||
color: PaletteDark.darkCyanBlue))
|
color: Theme.of(context).textTheme
|
||||||
|
.overline.backgroundColor))
|
||||||
]),
|
]),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
import 'package:cake_wallet/src/domain/common/transaction_direction.dart';
|
import 'package:cake_wallet/src/domain/common/transaction_direction.dart';
|
||||||
import 'package:cake_wallet/generated/i18n.dart';
|
import 'package:cake_wallet/generated/i18n.dart';
|
||||||
|
|
||||||
|
@ -35,7 +34,7 @@ class TransactionRow extends StatelessWidget {
|
||||||
width: 36,
|
width: 36,
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
shape: BoxShape.circle,
|
shape: BoxShape.circle,
|
||||||
color: PaletteDark.wildNightBlue
|
color: Theme.of(context).textTheme.overline.decorationColor
|
||||||
),
|
),
|
||||||
child: Image.asset(
|
child: Image.asset(
|
||||||
direction == TransactionDirection.incoming
|
direction == TransactionDirection.incoming
|
||||||
|
@ -79,13 +78,15 @@ class TransactionRow extends StatelessWidget {
|
||||||
Text(formattedDate,
|
Text(formattedDate,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 14,
|
fontSize: 14,
|
||||||
color: PaletteDark.darkCyanBlue)),
|
color: Theme.of(context).textTheme
|
||||||
|
.overline.backgroundColor)),
|
||||||
Text(direction == TransactionDirection.incoming
|
Text(direction == TransactionDirection.incoming
|
||||||
? formattedFiatAmount
|
? formattedFiatAmount
|
||||||
: '- ' + formattedFiatAmount,
|
: '- ' + formattedFiatAmount,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 14,
|
fontSize: 14,
|
||||||
color: PaletteDark.darkCyanBlue))
|
color: Theme.of(context).textTheme
|
||||||
|
.overline.backgroundColor))
|
||||||
]),
|
]),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
|
|
|
@ -75,7 +75,7 @@ class TransactionsPage extends StatelessWidget {
|
||||||
}
|
}
|
||||||
|
|
||||||
return Container(
|
return Container(
|
||||||
color: Theme.of(context).backgroundColor,
|
color: Colors.transparent,
|
||||||
height: 1);
|
height: 1);
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
@ -84,7 +84,8 @@ class TransactionsPage extends StatelessWidget {
|
||||||
S.of(context).placeholder_transactions,
|
S.of(context).placeholder_transactions,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 14,
|
fontSize: 14,
|
||||||
color: Colors.grey
|
color: Theme.of(context).primaryTextTheme
|
||||||
|
.overline.decorationColor
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
|
@ -8,7 +8,6 @@ import 'package:cake_wallet/view_model/monero_account_list/monero_account_edit_o
|
||||||
import 'package:cake_wallet/src/widgets/primary_button.dart';
|
import 'package:cake_wallet/src/widgets/primary_button.dart';
|
||||||
import 'package:cake_wallet/src/screens/base_page.dart';
|
import 'package:cake_wallet/src/screens/base_page.dart';
|
||||||
import 'package:cake_wallet/src/widgets/base_text_form_field.dart';
|
import 'package:cake_wallet/src/widgets/base_text_form_field.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
|
|
||||||
class MoneroAccountEditOrCreatePage extends BasePage {
|
class MoneroAccountEditOrCreatePage extends BasePage {
|
||||||
MoneroAccountEditOrCreatePage({@required this.moneroAccountCreationViewModel})
|
MoneroAccountEditOrCreatePage({@required this.moneroAccountCreationViewModel})
|
||||||
|
@ -24,12 +23,6 @@ class MoneroAccountEditOrCreatePage extends BasePage {
|
||||||
@override
|
@override
|
||||||
String get title => S.current.account;
|
String get title => S.current.account;
|
||||||
|
|
||||||
@override
|
|
||||||
Color get backgroundLightColor => PaletteDark.backgroundColor;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Color get backgroundDarkColor => PaletteDark.backgroundColor;
|
|
||||||
|
|
||||||
final GlobalKey<FormState> _formKey;
|
final GlobalKey<FormState> _formKey;
|
||||||
final TextEditingController _textController;
|
final TextEditingController _textController;
|
||||||
|
|
||||||
|
@ -45,7 +38,6 @@ class MoneroAccountEditOrCreatePage extends BasePage {
|
||||||
child: Center(
|
child: Center(
|
||||||
child: BaseTextFormField(
|
child: BaseTextFormField(
|
||||||
controller: _textController,
|
controller: _textController,
|
||||||
textColor: Colors.white,
|
|
||||||
hintText: S.of(context).account,
|
hintText: S.of(context).account,
|
||||||
validator: MoneroLabelValidator(),
|
validator: MoneroLabelValidator(),
|
||||||
))),
|
))),
|
||||||
|
|
|
@ -64,7 +64,7 @@ class MoneroAccountListPage extends StatelessWidget {
|
||||||
borderRadius: BorderRadius.all(Radius.circular(14)),
|
borderRadius: BorderRadius.all(Radius.circular(14)),
|
||||||
child: Container(
|
child: Container(
|
||||||
height: 296,
|
height: 296,
|
||||||
color: PaletteDark.deepPurpleBlue,
|
color: Theme.of(context).textTheme.display4.decorationColor,
|
||||||
child: Column(
|
child: Column(
|
||||||
children: <Widget>[
|
children: <Widget>[
|
||||||
Expanded(
|
Expanded(
|
||||||
|
@ -83,7 +83,7 @@ class MoneroAccountListPage extends StatelessWidget {
|
||||||
separatorBuilder: (context, index) =>
|
separatorBuilder: (context, index) =>
|
||||||
Container(
|
Container(
|
||||||
height: 1,
|
height: 1,
|
||||||
color: PaletteDark.dividerColor,
|
color: Theme.of(context).dividerColor,
|
||||||
),
|
),
|
||||||
itemCount: accounts.length ?? 0,
|
itemCount: accounts.length ?? 0,
|
||||||
itemBuilder: (context, index) {
|
itemBuilder: (context, index) {
|
||||||
|
@ -121,7 +121,7 @@ class MoneroAccountListPage extends StatelessWidget {
|
||||||
.pushNamed(Routes.accountCreation),
|
.pushNamed(Routes.accountCreation),
|
||||||
child: Container(
|
child: Container(
|
||||||
height: 62,
|
height: 62,
|
||||||
color: Colors.white,
|
color: Theme.of(context).textTheme.subtitle.decorationColor,
|
||||||
padding: EdgeInsets.only(left: 24, right: 24),
|
padding: EdgeInsets.only(left: 24, right: 24),
|
||||||
child: Center(
|
child: Center(
|
||||||
child: Row(
|
child: Row(
|
||||||
|
@ -129,7 +129,7 @@ class MoneroAccountListPage extends StatelessWidget {
|
||||||
children: <Widget>[
|
children: <Widget>[
|
||||||
Icon(
|
Icon(
|
||||||
Icons.add,
|
Icons.add,
|
||||||
color: PaletteDark.darkNightBlue,
|
color: Colors.white,
|
||||||
),
|
),
|
||||||
Padding(
|
Padding(
|
||||||
padding: EdgeInsets.only(left: 5),
|
padding: EdgeInsets.only(left: 5),
|
||||||
|
@ -138,7 +138,7 @@ class MoneroAccountListPage extends StatelessWidget {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 15,
|
fontSize: 15,
|
||||||
fontWeight: FontWeight.w600,
|
fontWeight: FontWeight.w600,
|
||||||
color: PaletteDark.darkNightBlue,
|
color: Colors.white,
|
||||||
decoration: TextDecoration.none,
|
decoration: TextDecoration.none,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
|
|
||||||
class AccountTile extends StatelessWidget {
|
class AccountTile extends StatelessWidget {
|
||||||
AccountTile({
|
AccountTile({
|
||||||
|
@ -14,8 +13,12 @@ class AccountTile extends StatelessWidget {
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final color = isCurrent ? PaletteDark.lightOceanBlue : Colors.transparent;
|
final color = isCurrent
|
||||||
final textColor = isCurrent ? Colors.blue : Colors.white;
|
? Theme.of(context).textTheme.subtitle.decorationColor
|
||||||
|
: Theme.of(context).textTheme.display4.decorationColor;
|
||||||
|
final textColor = isCurrent
|
||||||
|
? Theme.of(context).textTheme.subtitle.color
|
||||||
|
: Theme.of(context).textTheme.display4.color;
|
||||||
|
|
||||||
return GestureDetector(
|
return GestureDetector(
|
||||||
onTap: onTap,
|
onTap: onTap,
|
||||||
|
|
|
@ -14,7 +14,6 @@ import 'package:cake_wallet/view_model/wallet_address_list/wallet_address_list_h
|
||||||
import 'package:cake_wallet/view_model/wallet_address_list/wallet_address_list_item.dart';
|
import 'package:cake_wallet/view_model/wallet_address_list/wallet_address_list_item.dart';
|
||||||
import 'package:cake_wallet/view_model/wallet_address_list/wallet_address_list_view_model.dart';
|
import 'package:cake_wallet/view_model/wallet_address_list/wallet_address_list_view_model.dart';
|
||||||
import 'package:cake_wallet/src/screens/receive/widgets/qr_widget.dart';
|
import 'package:cake_wallet/src/screens/receive/widgets/qr_widget.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
|
|
||||||
class ReceivePage extends BasePage {
|
class ReceivePage extends BasePage {
|
||||||
ReceivePage({this.addressListViewModel});
|
ReceivePage({this.addressListViewModel});
|
||||||
|
@ -25,10 +24,26 @@ class ReceivePage extends BasePage {
|
||||||
String get title => S.current.receive;
|
String get title => S.current.receive;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Color get backgroundLightColor => PaletteDark.backgroundColor;
|
Color get backgroundLightColor => Colors.transparent;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Color get backgroundDarkColor => PaletteDark.backgroundColor;
|
Color get backgroundDarkColor => Colors.transparent;
|
||||||
|
|
||||||
|
@override
|
||||||
|
Color get titleColor => Colors.white;
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget Function(BuildContext, Widget) get rootWrapper =>
|
||||||
|
(BuildContext context, Widget scaffold) => Container(
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
gradient: LinearGradient(colors: [
|
||||||
|
Theme.of(context).accentColor,
|
||||||
|
Theme.of(context).scaffoldBackgroundColor,
|
||||||
|
Theme.of(context).primaryColor,
|
||||||
|
],
|
||||||
|
begin: Alignment.topRight,
|
||||||
|
end: Alignment.bottomLeft)),
|
||||||
|
child: scaffold);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget trailing(BuildContext context) {
|
Widget trailing(BuildContext context) {
|
||||||
|
@ -66,7 +81,9 @@ class ReceivePage extends BasePage {
|
||||||
Observer(
|
Observer(
|
||||||
builder: (_) => ListView.separated(
|
builder: (_) => ListView.separated(
|
||||||
separatorBuilder: (context, _) =>
|
separatorBuilder: (context, _) =>
|
||||||
Container(height: 1, color: PaletteDark.dividerColor),
|
Container(
|
||||||
|
height: 1,
|
||||||
|
color: Theme.of(context).dividerColor),
|
||||||
shrinkWrap: true,
|
shrinkWrap: true,
|
||||||
physics: NeverScrollableScrollPhysics(),
|
physics: NeverScrollableScrollPhysics(),
|
||||||
itemCount: addressListViewModel.items.length,
|
itemCount: addressListViewModel.items.length,
|
||||||
|
@ -83,7 +100,7 @@ class ReceivePage extends BasePage {
|
||||||
icon: Icon(
|
icon: Icon(
|
||||||
Icons.arrow_forward_ios,
|
Icons.arrow_forward_ios,
|
||||||
size: 14,
|
size: 14,
|
||||||
color: Colors.white,
|
color: Theme.of(context).textTheme.display1.color,
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -95,7 +112,7 @@ class ReceivePage extends BasePage {
|
||||||
icon: Icon(
|
icon: Icon(
|
||||||
Icons.add,
|
Icons.add,
|
||||||
size: 20,
|
size: 20,
|
||||||
color: Colors.white,
|
color: Theme.of(context).textTheme.display1.color,
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -105,11 +122,11 @@ class ReceivePage extends BasePage {
|
||||||
final isCurrent = item.address ==
|
final isCurrent = item.address ==
|
||||||
addressListViewModel.address.address;
|
addressListViewModel.address.address;
|
||||||
final backgroundColor = isCurrent
|
final backgroundColor = isCurrent
|
||||||
? PaletteDark.lightOceanBlue
|
? Theme.of(context).textTheme.display3.decorationColor
|
||||||
: PaletteDark.nightBlue;
|
: Theme.of(context).textTheme.display2.decorationColor;
|
||||||
final textColor = isCurrent
|
final textColor = isCurrent
|
||||||
? Colors.blue
|
? Theme.of(context).textTheme.display3.color
|
||||||
: Colors.white;
|
: Theme.of(context).textTheme.display2.color;
|
||||||
|
|
||||||
return AddressCell.fromItem(item,
|
return AddressCell.fromItem(item,
|
||||||
isCurrent: isCurrent,
|
isCurrent: isCurrent,
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
|
|
||||||
class HeaderTile extends StatelessWidget {
|
class HeaderTile extends StatelessWidget {
|
||||||
HeaderTile({
|
HeaderTile({
|
||||||
|
@ -23,7 +22,7 @@ class HeaderTile extends StatelessWidget {
|
||||||
top: 24,
|
top: 24,
|
||||||
bottom: 24
|
bottom: 24
|
||||||
),
|
),
|
||||||
color: PaletteDark.nightBlue,
|
color: Theme.of(context).textTheme.display2.decorationColor,
|
||||||
child: Row(
|
child: Row(
|
||||||
mainAxisSize: MainAxisSize.max,
|
mainAxisSize: MainAxisSize.max,
|
||||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
@ -32,8 +31,8 @@ class HeaderTile extends StatelessWidget {
|
||||||
title,
|
title,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 18,
|
fontSize: 18,
|
||||||
fontWeight: FontWeight.w500,
|
fontWeight: FontWeight.w600,
|
||||||
color: Colors.white
|
color: Theme.of(context).textTheme.display2.color
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
Container(
|
Container(
|
||||||
|
@ -41,7 +40,7 @@ class HeaderTile extends StatelessWidget {
|
||||||
width: 32,
|
width: 32,
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
shape: BoxShape.circle,
|
shape: BoxShape.circle,
|
||||||
color: PaletteDark.distantNightBlue
|
color: Theme.of(context).textTheme.display1.decorationColor
|
||||||
),
|
),
|
||||||
child: icon,
|
child: icon,
|
||||||
)
|
)
|
||||||
|
|
|
@ -7,7 +7,6 @@ import 'package:cake_wallet/src/screens/receive/widgets/qr_image.dart';
|
||||||
import 'package:cake_wallet/src/widgets/base_text_form_field.dart';
|
import 'package:cake_wallet/src/widgets/base_text_form_field.dart';
|
||||||
import 'package:cake_wallet/core/amount_validator.dart';
|
import 'package:cake_wallet/core/amount_validator.dart';
|
||||||
import 'package:cake_wallet/view_model/wallet_address_list/wallet_address_list_view_model.dart';
|
import 'package:cake_wallet/view_model/wallet_address_list/wallet_address_list_view_model.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
|
|
||||||
class QRWidget extends StatelessWidget {
|
class QRWidget extends StatelessWidget {
|
||||||
QRWidget({
|
QRWidget({
|
||||||
|
@ -27,7 +26,7 @@ class QRWidget extends StatelessWidget {
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final copyImage = Image.asset('assets/images/copy_address.png',
|
final copyImage = Image.asset('assets/images/copy_address.png',
|
||||||
color: PaletteDark.lightBlueGrey);
|
color: Theme.of(context).textTheme.subhead.decorationColor);
|
||||||
final addressTopOffset = isAmountFieldShow ? 60.0 : 40.0;
|
final addressTopOffset = isAmountFieldShow ? 60.0 : 40.0;
|
||||||
|
|
||||||
return Column(
|
return Column(
|
||||||
|
@ -45,7 +44,7 @@ class QRWidget extends StatelessWidget {
|
||||||
child: QrImage(
|
child: QrImage(
|
||||||
data: addressListViewModel.uri.toString(),
|
data: addressListViewModel.uri.toString(),
|
||||||
backgroundColor: Colors.transparent,
|
backgroundColor: Colors.transparent,
|
||||||
foregroundColor: PaletteDark.lightBlueGrey,
|
foregroundColor: Theme.of(context).textTheme.headline.color,
|
||||||
))))),
|
))))),
|
||||||
Spacer(flex: 3)
|
Spacer(flex: 3)
|
||||||
]),
|
]),
|
||||||
|
@ -56,7 +55,7 @@ class QRWidget extends StatelessWidget {
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 12,
|
fontSize: 12,
|
||||||
fontWeight: FontWeight.w500,
|
fontWeight: FontWeight.w500,
|
||||||
color: PaletteDark.cyanBlue
|
color: Theme.of(context).indicatorColor
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
@ -79,14 +78,14 @@ class QRWidget extends StatelessWidget {
|
||||||
textAlign: TextAlign.center,
|
textAlign: TextAlign.center,
|
||||||
hintText: S.of(context).receive_amount,
|
hintText: S.of(context).receive_amount,
|
||||||
textColor: Colors.white,
|
textColor: Colors.white,
|
||||||
borderColor: PaletteDark.darkGrey,
|
borderColor: Theme.of(context).textTheme.headline.decorationColor,
|
||||||
validator: AmountValidator(
|
validator: AmountValidator(
|
||||||
type: addressListViewModel.type,
|
type: addressListViewModel.type,
|
||||||
isAutovalidate: true
|
isAutovalidate: true
|
||||||
),
|
),
|
||||||
autovalidate: true,
|
autovalidate: true,
|
||||||
placeholderTextStyle: TextStyle(
|
placeholderTextStyle: TextStyle(
|
||||||
color: PaletteDark.cyanBlue,
|
color: Theme.of(context).hoverColor,
|
||||||
fontSize: 18,
|
fontSize: 18,
|
||||||
fontWeight: FontWeight.w500))))
|
fontWeight: FontWeight.w500))))
|
||||||
],
|
],
|
||||||
|
|
|
@ -8,7 +8,6 @@ import 'package:cake_wallet/core/address_label_validator.dart';
|
||||||
import 'package:cake_wallet/src/widgets/primary_button.dart';
|
import 'package:cake_wallet/src/widgets/primary_button.dart';
|
||||||
import 'package:cake_wallet/src/widgets/base_text_form_field.dart';
|
import 'package:cake_wallet/src/widgets/base_text_form_field.dart';
|
||||||
import 'package:cake_wallet/src/screens/base_page.dart';
|
import 'package:cake_wallet/src/screens/base_page.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
|
|
||||||
class AddressEditOrCreatePage extends BasePage {
|
class AddressEditOrCreatePage extends BasePage {
|
||||||
AddressEditOrCreatePage({@required this.addressEditOrCreateViewModel})
|
AddressEditOrCreatePage({@required this.addressEditOrCreateViewModel})
|
||||||
|
@ -29,12 +28,6 @@ class AddressEditOrCreatePage extends BasePage {
|
||||||
@override
|
@override
|
||||||
String get title => S.current.new_subaddress_title;
|
String get title => S.current.new_subaddress_title;
|
||||||
|
|
||||||
@override
|
|
||||||
Color get backgroundLightColor => PaletteDark.backgroundColor;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Color get backgroundDarkColor => PaletteDark.backgroundColor;
|
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget body(BuildContext context) {
|
Widget body(BuildContext context) {
|
||||||
reaction((_) => addressEditOrCreateViewModel.state,
|
reaction((_) => addressEditOrCreateViewModel.state,
|
||||||
|
@ -55,7 +48,6 @@ class AddressEditOrCreatePage extends BasePage {
|
||||||
child: Center(
|
child: Center(
|
||||||
child: BaseTextFormField(
|
child: BaseTextFormField(
|
||||||
controller: _labelController,
|
controller: _labelController,
|
||||||
textColor: Colors.white,
|
|
||||||
hintText: S.of(context).new_subaddress_label_name,
|
hintText: S.of(context).new_subaddress_label_name,
|
||||||
validator: AddressLabelValidator()))),
|
validator: AddressLabelValidator()))),
|
||||||
Observer(
|
Observer(
|
||||||
|
|
|
@ -24,7 +24,6 @@ class TradeDetailsPage extends BasePage {
|
||||||
formatDefault: "dd.MM.yyyy, HH:mm");
|
formatDefault: "dd.MM.yyyy, HH:mm");
|
||||||
|
|
||||||
return Container(
|
return Container(
|
||||||
padding: EdgeInsets.only(top: 20, bottom: 20),
|
|
||||||
child: Observer(builder: (_) {
|
child: Observer(builder: (_) {
|
||||||
final trade = exchangeStore.trade;
|
final trade = exchangeStore.trade;
|
||||||
final items = [
|
final items = [
|
||||||
|
@ -59,17 +58,15 @@ class TradeDetailsPage extends BasePage {
|
||||||
separatorBuilder: (_, __) => Container(
|
separatorBuilder: (_, __) => Container(
|
||||||
height: 1,
|
height: 1,
|
||||||
padding: EdgeInsets.only(left: 24),
|
padding: EdgeInsets.only(left: 24),
|
||||||
color: Theme.of(context).accentTextTheme.title.backgroundColor,
|
color: Theme.of(context).backgroundColor,
|
||||||
child: Container(
|
child: Container(
|
||||||
height: 1,
|
height: 1,
|
||||||
color: Theme.of(context).dividerColor,
|
color: Theme.of(context).primaryTextTheme.title.backgroundColor,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
itemCount: items.length,
|
itemCount: items.length,
|
||||||
itemBuilder: (BuildContext context, int index) {
|
itemBuilder: (BuildContext context, int index) {
|
||||||
final item = items[index];
|
final item = items[index];
|
||||||
|
|
||||||
final isDrawTop = index == 0 ? true : false;
|
|
||||||
final isDrawBottom = index == items.length - 1 ? true : false;
|
final isDrawBottom = index == items.length - 1 ? true : false;
|
||||||
|
|
||||||
return GestureDetector(
|
return GestureDetector(
|
||||||
|
@ -87,7 +84,6 @@ class TradeDetailsPage extends BasePage {
|
||||||
child: StandartListRow(
|
child: StandartListRow(
|
||||||
title: '${item.title}',
|
title: '${item.title}',
|
||||||
value: '${item.value}',
|
value: '${item.value}',
|
||||||
isDrawTop: isDrawTop,
|
|
||||||
isDrawBottom: isDrawBottom,
|
isDrawBottom: isDrawBottom,
|
||||||
));
|
));
|
||||||
});
|
});
|
||||||
|
|
|
@ -69,22 +69,19 @@ class TransactionDetailsPage extends BasePage {
|
||||||
@override
|
@override
|
||||||
Widget body(BuildContext context) {
|
Widget body(BuildContext context) {
|
||||||
return Container(
|
return Container(
|
||||||
padding: EdgeInsets.only(top: 20, bottom: 20),
|
|
||||||
child: ListView.separated(
|
child: ListView.separated(
|
||||||
separatorBuilder: (context, index) => Container(
|
separatorBuilder: (context, index) => Container(
|
||||||
height: 1,
|
height: 1,
|
||||||
padding: EdgeInsets.only(left: 24),
|
padding: EdgeInsets.only(left: 24),
|
||||||
color: Theme.of(context).accentTextTheme.title.backgroundColor,
|
color: Theme.of(context).backgroundColor,
|
||||||
child: Container(
|
child: Container(
|
||||||
height: 1,
|
height: 1,
|
||||||
color: Theme.of(context).dividerColor,
|
color: Theme.of(context).primaryTextTheme.title.backgroundColor,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
itemCount: _items.length,
|
itemCount: _items.length,
|
||||||
itemBuilder: (context, index) {
|
itemBuilder: (context, index) {
|
||||||
final item = _items[index];
|
final item = _items[index];
|
||||||
|
|
||||||
final isDrawTop = index == 0 ? true : false;
|
|
||||||
final isDrawBottom = index == _items.length - 1 ? true : false;
|
final isDrawBottom = index == _items.length - 1 ? true : false;
|
||||||
|
|
||||||
return GestureDetector(
|
return GestureDetector(
|
||||||
|
@ -102,7 +99,6 @@ class TransactionDetailsPage extends BasePage {
|
||||||
child: StandartListRow(
|
child: StandartListRow(
|
||||||
title: '${item.title}:',
|
title: '${item.title}:',
|
||||||
value: item.value,
|
value: item.value,
|
||||||
isDrawTop: isDrawTop,
|
|
||||||
isDrawBottom: isDrawBottom),
|
isDrawBottom: isDrawBottom),
|
||||||
);
|
);
|
||||||
}),
|
}),
|
||||||
|
|
|
@ -64,21 +64,20 @@ class BaseTextFormField extends StatelessWidget {
|
||||||
suffixIcon: suffixIcon,
|
suffixIcon: suffixIcon,
|
||||||
hintStyle: placeholderTextStyle ??
|
hintStyle: placeholderTextStyle ??
|
||||||
TextStyle(
|
TextStyle(
|
||||||
color: hintColor ??
|
color: hintColor ?? Theme.of(context).hintColor,
|
||||||
Theme.of(context).primaryTextTheme.caption.color,
|
|
||||||
fontSize: 16),
|
fontSize: 16),
|
||||||
hintText: hintText,
|
hintText: hintText,
|
||||||
focusedBorder: UnderlineInputBorder(
|
focusedBorder: UnderlineInputBorder(
|
||||||
borderSide: BorderSide(
|
borderSide: BorderSide(
|
||||||
color: borderColor ?? Theme.of(context).dividerColor,
|
color: borderColor ?? Theme.of(context).primaryTextTheme.title.backgroundColor,
|
||||||
width: 1.0)),
|
width: 1.0)),
|
||||||
disabledBorder: UnderlineInputBorder(
|
disabledBorder: UnderlineInputBorder(
|
||||||
borderSide: BorderSide(
|
borderSide: BorderSide(
|
||||||
color: borderColor ?? Theme.of(context).dividerColor,
|
color: borderColor ?? Theme.of(context).primaryTextTheme.title.backgroundColor,
|
||||||
width: 1.0)),
|
width: 1.0)),
|
||||||
enabledBorder: UnderlineInputBorder(
|
enabledBorder: UnderlineInputBorder(
|
||||||
borderSide: BorderSide(
|
borderSide: BorderSide(
|
||||||
color: borderColor ?? Theme.of(context).dividerColor,
|
color: borderColor ?? Theme.of(context).primaryTextTheme.title.backgroundColor,
|
||||||
width: 1.0))),
|
width: 1.0))),
|
||||||
validator: validator,
|
validator: validator,
|
||||||
);
|
);
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
|
|
||||||
class CakeScrollbar extends StatelessWidget {
|
class CakeScrollbar extends StatelessWidget {
|
||||||
CakeScrollbar({
|
CakeScrollbar({
|
||||||
|
@ -20,7 +19,7 @@ class CakeScrollbar extends StatelessWidget {
|
||||||
height: backgroundHeight,
|
height: backgroundHeight,
|
||||||
width: 6,
|
width: 6,
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
color: PaletteDark.violetBlue,
|
color: Theme.of(context).textTheme.body1.decorationColor,
|
||||||
borderRadius: BorderRadius.all(Radius.circular(3))
|
borderRadius: BorderRadius.all(Radius.circular(3))
|
||||||
),
|
),
|
||||||
child: Stack(
|
child: Stack(
|
||||||
|
@ -32,7 +31,7 @@ class CakeScrollbar extends StatelessWidget {
|
||||||
height: thumbHeight,
|
height: thumbHeight,
|
||||||
width: 6.0,
|
width: 6.0,
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
color: PaletteDark.wildBlueGrey,
|
color: Theme.of(context).textTheme.body1.color,
|
||||||
borderRadius: BorderRadius.all(Radius.circular(3))
|
borderRadius: BorderRadius.all(Radius.circular(3))
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
import 'package:flutter/cupertino.dart';
|
import 'package:flutter/cupertino.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:cake_wallet/palette.dart';
|
|
||||||
|
|
||||||
class PrimaryButton extends StatelessWidget {
|
class PrimaryButton extends StatelessWidget {
|
||||||
const PrimaryButton(
|
const PrimaryButton(
|
||||||
|
@ -38,7 +37,7 @@ class PrimaryButton extends StatelessWidget {
|
||||||
fontSize: 15.0,
|
fontSize: 15.0,
|
||||||
fontWeight: FontWeight.w600,
|
fontWeight: FontWeight.w600,
|
||||||
color: isDisabled
|
color: isDisabled
|
||||||
? Colors.grey.withOpacity(0.5)
|
? textColor.withOpacity(0.5)
|
||||||
: textColor)),
|
: textColor)),
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
@ -78,7 +77,7 @@ class LoadingPrimaryButton extends StatelessWidget {
|
||||||
fontSize: 15.0,
|
fontSize: 15.0,
|
||||||
fontWeight: FontWeight.w600,
|
fontWeight: FontWeight.w600,
|
||||||
color: isDisabled
|
color: isDisabled
|
||||||
? Colors.grey.withOpacity(0.5)
|
? textColor.withOpacity(0.5)
|
||||||
: textColor
|
: textColor
|
||||||
)),
|
)),
|
||||||
));
|
));
|
||||||
|
|
|
@ -4,28 +4,19 @@ class StandartListRow extends StatelessWidget {
|
||||||
StandartListRow(
|
StandartListRow(
|
||||||
{this.title,
|
{this.title,
|
||||||
this.value,
|
this.value,
|
||||||
this.isDrawTop = false,
|
|
||||||
this.isDrawBottom = false});
|
this.isDrawBottom = false});
|
||||||
|
|
||||||
final String title;
|
final String title;
|
||||||
final String value;
|
final String value;
|
||||||
final bool isDrawTop;
|
|
||||||
final bool isDrawBottom;
|
final bool isDrawBottom;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return Column(
|
return Column(
|
||||||
children: <Widget>[
|
children: <Widget>[
|
||||||
isDrawTop
|
|
||||||
? Container(
|
|
||||||
width: double.infinity,
|
|
||||||
height: 1,
|
|
||||||
color: Theme.of(context).dividerColor,
|
|
||||||
)
|
|
||||||
: Offstage(),
|
|
||||||
Container(
|
Container(
|
||||||
width: double.infinity,
|
width: double.infinity,
|
||||||
color: Theme.of(context).accentTextTheme.title.backgroundColor,
|
color: Theme.of(context).backgroundColor,
|
||||||
child: Padding(
|
child: Padding(
|
||||||
padding:
|
padding:
|
||||||
const EdgeInsets.only(left: 24, top: 16, bottom: 16, right: 24),
|
const EdgeInsets.only(left: 24, top: 16, bottom: 16, right: 24),
|
||||||
|
@ -35,9 +26,9 @@ class StandartListRow extends StatelessWidget {
|
||||||
Text(title,
|
Text(title,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 14,
|
fontSize: 14,
|
||||||
fontWeight: FontWeight.w600,
|
fontWeight: FontWeight.w500,
|
||||||
color:
|
color:
|
||||||
Theme.of(context).primaryTextTheme.caption.color),
|
Theme.of(context).primaryTextTheme.overline.color),
|
||||||
textAlign: TextAlign.left),
|
textAlign: TextAlign.left),
|
||||||
Padding(
|
Padding(
|
||||||
padding: const EdgeInsets.only(top: 12),
|
padding: const EdgeInsets.only(top: 12),
|
||||||
|
@ -55,9 +46,13 @@ class StandartListRow extends StatelessWidget {
|
||||||
),
|
),
|
||||||
isDrawBottom
|
isDrawBottom
|
||||||
? Container(
|
? Container(
|
||||||
width: double.infinity,
|
|
||||||
height: 1,
|
height: 1,
|
||||||
color: Theme.of(context).dividerColor,
|
padding: EdgeInsets.only(left: 24),
|
||||||
|
color: Theme.of(context).backgroundColor,
|
||||||
|
child: Container(
|
||||||
|
height: 1,
|
||||||
|
color: Theme.of(context).primaryTextTheme.title.backgroundColor,
|
||||||
|
),
|
||||||
)
|
)
|
||||||
: Offstage(),
|
: Offstage(),
|
||||||
],
|
],
|
||||||
|
|
197
lib/themes.dart
197
lib/themes.dart
|
@ -7,26 +7,83 @@ class Themes {
|
||||||
fontFamily: 'Poppins',
|
fontFamily: 'Poppins',
|
||||||
brightness: Brightness.light,
|
brightness: Brightness.light,
|
||||||
backgroundColor: Colors.white,
|
backgroundColor: Colors.white,
|
||||||
focusColor: Colors.white, // wallet card border
|
accentColor: Palette.blueCraiola, // first gradient color
|
||||||
hintColor: Colors.white, // menu
|
scaffoldBackgroundColor: Palette.pinkFlamingo, // second gradient color
|
||||||
scaffoldBackgroundColor: Palette.blueAlice, // gradient background start
|
primaryColor: Palette.redHat, // third gradient color
|
||||||
primaryColor: Palette.lightBlue, // gradient background end
|
buttonColor: Colors.white.withOpacity(0.2), // action buttons on dashboard page
|
||||||
cardColor: Palette.blueAlice,
|
indicatorColor: Colors.white.withOpacity(0.5), // page indicator
|
||||||
cardTheme: CardTheme(
|
hoverColor: Colors.white, // amount hint text (receive page)
|
||||||
color: Colors.white, // synced card start
|
dividerColor: Palette.paleBlue,
|
||||||
),
|
hintColor: Palette.gray,
|
||||||
hoverColor: Colors.white, // synced card end
|
textTheme: TextTheme(
|
||||||
primaryTextTheme: TextTheme(
|
|
||||||
title: TextStyle(
|
title: TextStyle(
|
||||||
color: Palette.oceanBlue, // primary text
|
color: Colors.white, // sync_indicator text
|
||||||
backgroundColor: Colors.white // selectButton text
|
backgroundColor: Colors.white.withOpacity(0.2), // synced sync_indicator
|
||||||
|
decorationColor: Colors.white.withOpacity(0.15), // not synced sync_indicator
|
||||||
),
|
),
|
||||||
caption: TextStyle(
|
caption: TextStyle(
|
||||||
color: Palette.lightBlueGrey, // secondary text
|
color: Palette.shineOrange, // not synced light
|
||||||
|
decorationColor: Colors.white, // filter icon
|
||||||
),
|
),
|
||||||
overline: TextStyle(
|
overline: TextStyle(
|
||||||
color: Palette.lavender // address field in the wallet card
|
color: Colors.white.withOpacity(0.2), // filter button
|
||||||
|
backgroundColor: Colors.white.withOpacity(0.5), // date section row
|
||||||
|
decorationColor: Colors.white.withOpacity(0.2) // icons (transaction and trade rows)
|
||||||
),
|
),
|
||||||
|
subhead: TextStyle(
|
||||||
|
color: Colors.white.withOpacity(0.2), // address button border
|
||||||
|
decorationColor: Colors.white.withOpacity(0.4), // copy button (qr widget)
|
||||||
|
),
|
||||||
|
headline: TextStyle(
|
||||||
|
color: Colors.white, // qr code
|
||||||
|
decorationColor: Colors.white.withOpacity(0.5), // bottom border of amount (receive page)
|
||||||
|
),
|
||||||
|
display1: TextStyle(
|
||||||
|
color: PaletteDark.lightBlueGrey, // icons color (receive page)
|
||||||
|
decorationColor: Palette.lavender, // icons background (receive page)
|
||||||
|
),
|
||||||
|
display2: TextStyle(
|
||||||
|
color: Palette.darkBlueCraiola, // text color of tiles (receive page)
|
||||||
|
decorationColor: Colors.white // background of tiles (receive page)
|
||||||
|
),
|
||||||
|
display3: TextStyle(
|
||||||
|
color: Colors.white, // text color of current tile (receive page),
|
||||||
|
decorationColor: Palette.blueCraiola // background of current tile (receive page)
|
||||||
|
),
|
||||||
|
display4: TextStyle(
|
||||||
|
color: Palette.violetBlue, // text color of tiles (account list)
|
||||||
|
decorationColor: Colors.white // background of tiles (account list)
|
||||||
|
),
|
||||||
|
subtitle: TextStyle(
|
||||||
|
color: Colors.white, // text color of current tile (account list)
|
||||||
|
decorationColor: Palette.blueCraiola // background of current tile (account list)
|
||||||
|
),
|
||||||
|
body1: TextStyle(
|
||||||
|
color: Palette.moderatePurpleBlue, // scrollbar thumb
|
||||||
|
decorationColor: Palette.periwinkleCraiola // scrollbar background
|
||||||
|
),
|
||||||
|
body2: TextStyle(
|
||||||
|
color: Palette.moderateLavender, // menu header
|
||||||
|
decorationColor: Colors.white, // menu background
|
||||||
|
)
|
||||||
|
),
|
||||||
|
primaryTextTheme: TextTheme(
|
||||||
|
title: TextStyle(
|
||||||
|
color: Palette.darkBlueCraiola, // title color
|
||||||
|
backgroundColor: Palette.wildPeriwinkle // textfield underline
|
||||||
|
),
|
||||||
|
caption: TextStyle(
|
||||||
|
color: PaletteDark.pigeonBlue, // secondary text
|
||||||
|
decorationColor: Palette.wildLavender // menu divider
|
||||||
|
),
|
||||||
|
overline: TextStyle(
|
||||||
|
color: Palette.darkGray, // transaction/trade details titles
|
||||||
|
decorationColor: Colors.white.withOpacity(0.5), // placeholder
|
||||||
|
),
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
subhead: TextStyle(
|
subhead: TextStyle(
|
||||||
color: Colors.white.withOpacity(0.5) // send, exchange, buy buttons on dashboard page
|
color: Colors.white.withOpacity(0.5) // send, exchange, buy buttons on dashboard page
|
||||||
),
|
),
|
||||||
|
@ -45,9 +102,18 @@ class Themes {
|
||||||
display4: TextStyle(
|
display4: TextStyle(
|
||||||
color: Palette.oceanBlue // QR code
|
color: Palette.oceanBlue // QR code
|
||||||
),
|
),
|
||||||
// headline1: TextStyle(color: Palette.nightBlue)
|
|
||||||
),
|
),
|
||||||
dividerColor: Palette.eee,
|
|
||||||
|
|
||||||
|
|
||||||
|
focusColor: Colors.white, // wallet card border
|
||||||
|
|
||||||
|
cardColor: Palette.blueAlice,
|
||||||
|
cardTheme: CardTheme(
|
||||||
|
color: Colors.white, // synced card start
|
||||||
|
),
|
||||||
|
|
||||||
|
|
||||||
accentTextTheme: TextTheme(
|
accentTextTheme: TextTheme(
|
||||||
title: TextStyle(
|
title: TextStyle(
|
||||||
color: Palette.darkLavender, // top panel
|
color: Palette.darkLavender, // top panel
|
||||||
|
@ -75,27 +141,83 @@ class Themes {
|
||||||
static final ThemeData darkTheme = ThemeData(
|
static final ThemeData darkTheme = ThemeData(
|
||||||
fontFamily: 'Poppins',
|
fontFamily: 'Poppins',
|
||||||
brightness: Brightness.dark,
|
brightness: Brightness.dark,
|
||||||
backgroundColor: PaletteDark.darkNightBlue,
|
backgroundColor: PaletteDark.backgroundColor,
|
||||||
focusColor: PaletteDark.lightDistantBlue, // wallet card border
|
accentColor: PaletteDark.backgroundColor, // first gradient color
|
||||||
hintColor: PaletteDark.gray, // menu
|
scaffoldBackgroundColor: PaletteDark.backgroundColor, // second gradient color
|
||||||
scaffoldBackgroundColor: PaletteDark.distantBlue, // gradient background start
|
primaryColor: PaletteDark.backgroundColor, // third gradient color
|
||||||
primaryColor: PaletteDark.distantBlue, // gradient background end
|
buttonColor: PaletteDark.nightBlue, // action buttons on dashboard page
|
||||||
cardColor: PaletteDark.darkNightBlue,
|
indicatorColor: PaletteDark.cyanBlue, // page indicator
|
||||||
cardTheme: CardTheme(
|
hoverColor: PaletteDark.cyanBlue, // amount hint text (receive page)
|
||||||
color: PaletteDark.moderateBlue, // synced card start
|
dividerColor: PaletteDark.dividerColor,
|
||||||
),
|
hintColor: PaletteDark.pigeonBlue, // menu
|
||||||
hoverColor: PaletteDark.nightBlue, // synced card end
|
textTheme: TextTheme(
|
||||||
primaryTextTheme: TextTheme(
|
|
||||||
title: TextStyle(
|
title: TextStyle(
|
||||||
color: Colors.white,
|
color: PaletteDark.wildBlue, // sync_indicator text
|
||||||
backgroundColor: PaletteDark.moderatePurpleBlue // selectButton text
|
backgroundColor: PaletteDark.lightNightBlue, // synced sync_indicator
|
||||||
|
decorationColor: PaletteDark.oceanBlue // not synced sync_indicator
|
||||||
),
|
),
|
||||||
caption: TextStyle(
|
caption: TextStyle(
|
||||||
color: PaletteDark.gray,
|
color: PaletteDark.orangeYellow, // not synced light
|
||||||
|
decorationColor: PaletteDark.wildBlue, // filter icon
|
||||||
),
|
),
|
||||||
overline: TextStyle(
|
overline: TextStyle(
|
||||||
color: PaletteDark.lightDistantBlue // address field in the wallet card
|
color: PaletteDark.oceanBlue, // filter button
|
||||||
|
backgroundColor: PaletteDark.darkCyanBlue, // date section row
|
||||||
|
decorationColor: PaletteDark.wildNightBlue // icons (transaction and trade rows)
|
||||||
),
|
),
|
||||||
|
subhead: TextStyle(
|
||||||
|
color: PaletteDark.nightBlue, // address button border
|
||||||
|
decorationColor: PaletteDark.lightBlueGrey, // copy button (qr widget)
|
||||||
|
),
|
||||||
|
headline: TextStyle(
|
||||||
|
color: PaletteDark.lightBlueGrey, // qr code
|
||||||
|
decorationColor: PaletteDark.darkGrey, // bottom border of amount (receive page)
|
||||||
|
),
|
||||||
|
display1: TextStyle(
|
||||||
|
color: Colors.white, // icons color (receive page)
|
||||||
|
decorationColor: PaletteDark.distantNightBlue, // icons background (receive page)
|
||||||
|
),
|
||||||
|
display2: TextStyle(
|
||||||
|
color: Colors.white, // text color of tiles (receive page)
|
||||||
|
decorationColor: PaletteDark.nightBlue // background of tiles (receive page)
|
||||||
|
),
|
||||||
|
display3: TextStyle(
|
||||||
|
color: Colors.blue, // text color of current tile (receive page)
|
||||||
|
decorationColor: PaletteDark.lightOceanBlue // background of current tile (receive page)
|
||||||
|
),
|
||||||
|
display4: TextStyle(
|
||||||
|
color: Colors.white, // text color of tiles (account list)
|
||||||
|
decorationColor: PaletteDark.darkOceanBlue // background of tiles (account list)
|
||||||
|
),
|
||||||
|
subtitle: TextStyle(
|
||||||
|
color: Palette.blueCraiola, // text color of current tile (account list)
|
||||||
|
decorationColor: PaletteDark.darkNightBlue // background of current tile (account list)
|
||||||
|
),
|
||||||
|
body1: TextStyle(
|
||||||
|
color: PaletteDark.wildBlueGrey, // scrollbar thumb
|
||||||
|
decorationColor: PaletteDark.violetBlue // scrollbar background
|
||||||
|
),
|
||||||
|
body2: TextStyle(
|
||||||
|
color: PaletteDark.deepPurpleBlue, // menu header
|
||||||
|
decorationColor: PaletteDark.deepPurpleBlue, // menu background
|
||||||
|
)
|
||||||
|
),
|
||||||
|
primaryTextTheme: TextTheme(
|
||||||
|
title: TextStyle(
|
||||||
|
color: Colors.white, // title color
|
||||||
|
backgroundColor: PaletteDark.darkOceanBlue // textfield underline
|
||||||
|
),
|
||||||
|
caption: TextStyle(
|
||||||
|
color: PaletteDark.darkCyanBlue, // secondary text
|
||||||
|
decorationColor: PaletteDark.darkOceanBlue // menu divider
|
||||||
|
),
|
||||||
|
overline: TextStyle(
|
||||||
|
color: PaletteDark.lightBlueGrey, // transaction/trade details titles
|
||||||
|
decorationColor: Colors.grey, // placeholder
|
||||||
|
),
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
subhead: TextStyle(
|
subhead: TextStyle(
|
||||||
color: PaletteDark.lightDistantBlue // send, exchange, buy buttons on dashboard page
|
color: PaletteDark.lightDistantBlue // send, exchange, buy buttons on dashboard page
|
||||||
),
|
),
|
||||||
|
@ -114,9 +236,18 @@ class Themes {
|
||||||
display4: TextStyle(
|
display4: TextStyle(
|
||||||
color: PaletteDark.gray // QR code
|
color: PaletteDark.gray // QR code
|
||||||
),
|
),
|
||||||
// headline5: TextStyle(color: PaletteDark.gray)
|
|
||||||
),
|
),
|
||||||
dividerColor: PaletteDark.distantBlue,
|
|
||||||
|
|
||||||
|
|
||||||
|
focusColor: PaletteDark.lightDistantBlue, // wallet card border
|
||||||
|
cardColor: PaletteDark.darkNightBlue,
|
||||||
|
cardTheme: CardTheme(
|
||||||
|
color: PaletteDark.moderateBlue, // synced card start
|
||||||
|
),
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
accentTextTheme: TextTheme(
|
accentTextTheme: TextTheme(
|
||||||
title: TextStyle(
|
title: TextStyle(
|
||||||
color: PaletteDark.moderateBlue, // top panel
|
color: PaletteDark.moderateBlue, // top panel
|
||||||
|
|
Loading…
Reference in a new issue