cake_wallet/lib/themes/theme_base.dart

107 lines
3.3 KiB
Dart
Raw Normal View History

import 'package:cake_wallet/themes/extensions/address_theme.dart';
import 'package:cake_wallet/themes/extensions/balance_page_theme.dart';
2023-07-03 12:43:33 +00:00
import 'package:cake_wallet/themes/extensions/cake_scrollbar_theme.dart';
import 'package:cake_wallet/themes/extensions/dashboard_page_theme.dart';
2023-07-03 17:56:29 +00:00
import 'package:cake_wallet/themes/extensions/exchange_page_theme.dart';
2023-07-03 20:37:38 +00:00
import 'package:cake_wallet/themes/extensions/filter_theme.dart';
import 'package:cake_wallet/themes/extensions/info_theme.dart';
import 'package:cake_wallet/themes/extensions/keyboard_theme.dart';
2023-07-03 19:39:48 +00:00
import 'package:cake_wallet/themes/extensions/menu_theme.dart';
import 'package:cake_wallet/themes/extensions/new_wallet_theme.dart';
import 'package:cake_wallet/themes/extensions/pin_code_theme.dart';
import 'package:cake_wallet/themes/extensions/support_page_theme.dart';
2023-07-03 12:48:09 +00:00
import 'package:cake_wallet/themes/extensions/sync_indicator_theme.dart';
2023-07-03 20:40:58 +00:00
import 'package:cake_wallet/themes/extensions/wallet_list_theme.dart';
import 'package:flutter/material.dart';
2023-06-30 16:55:22 +00:00
enum ThemeType { light, bright, dark }
abstract class ThemeBase {
2022-10-12 17:09:57 +00:00
ThemeBase({required this.raw});
final int raw;
String get title;
ThemeType get type;
@override
String toString() {
return title;
}
2023-06-30 16:55:22 +00:00
Brightness get brightness;
Color get backgroundColor;
Color get primaryColor;
Color get primaryTextColor;
Color get containerColor;
Color get dialogBackgroundColor;
2023-06-30 16:55:22 +00:00
ColorScheme get colorScheme => ColorScheme.fromSeed(
brightness: brightness,
seedColor: primaryColor,
background: backgroundColor);
2023-07-03 12:43:33 +00:00
ThemeData get generatedThemeData => ThemeData.from(
colorScheme: colorScheme,
textTheme: TextTheme().apply(fontFamily: 'Lato'));
2023-07-03 19:21:11 +00:00
DashboardPageTheme get dashboardPageTheme => DashboardPageTheme(
firstGradientBackgroundColor: backgroundColor,
secondGradientBackgroundColor: backgroundColor,
thirdGradientBackgroundColor: backgroundColor,
textColor: primaryTextColor);
2023-07-03 12:26:43 +00:00
2023-07-03 12:43:33 +00:00
CakeScrollbarTheme get scrollbarTheme;
2023-07-03 12:48:09 +00:00
SyncIndicatorTheme get syncIndicatorStyle;
KeyboardTheme get keyboardTheme;
PinCodeTheme get pinCodeTheme;
SupportPageTheme get supportPageTheme;
2023-07-03 17:56:29 +00:00
ExchangePageTheme get exchangePageTheme;
NewWalletTheme get newWalletTheme;
BalancePageTheme get balancePageTheme;
AddressTheme get addressTheme;
2023-07-03 19:39:48 +00:00
CakeMenuTheme get menuTheme;
2023-07-03 20:37:38 +00:00
FilterTheme get filterTheme;
2023-07-03 20:40:58 +00:00
WalletListTheme get walletListTheme;
InfoTheme get infoTheme;
2023-07-03 12:43:33 +00:00
ThemeData get themeData => generatedThemeData.copyWith(
primaryColor: primaryColor,
cardColor: containerColor,
dialogBackgroundColor: dialogBackgroundColor,
2023-07-03 12:48:09 +00:00
extensions: [
2023-07-03 19:21:11 +00:00
dashboardPageTheme,
2023-07-03 12:48:09 +00:00
scrollbarTheme,
syncIndicatorStyle,
keyboardTheme,
pinCodeTheme,
supportPageTheme,
2023-07-03 17:56:29 +00:00
exchangePageTheme,
newWalletTheme,
balancePageTheme,
addressTheme,
2023-07-03 19:39:48 +00:00
menuTheme,
2023-07-03 20:37:38 +00:00
filterTheme,
2023-07-03 20:40:58 +00:00
walletListTheme,
infoTheme,
2023-07-03 12:48:09 +00:00
],
2023-07-03 12:43:33 +00:00
scrollbarTheme: ScrollbarThemeData(
thumbColor: MaterialStateProperty.all(scrollbarTheme.thumbColor),
trackColor: MaterialStateProperty.all(scrollbarTheme.trackColor),
radius: Radius.circular(3),
thickness: MaterialStateProperty.all(6),
thumbVisibility: MaterialStateProperty.all(true),
crossAxisMargin: 6));
}