mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-05 10:29:23 +00:00
2bce18d240
* V4.8.1 v1.5.1 (#1038) * Revert "Cw 397 chatwoot live support (#1011)" This reverts commitaf9b5ff10c
. * Add Version 4.8.1 configs * Update macos build version [skip ci] * Re add chatwoot (#1044) * Revert "Revert "Cw 397 chatwoot live support (#1011)"" This reverts commitecdc7baa2e
. * Re-add chatwoot Change chatwoot base url * Cw 396 additional themes (#962) * 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> * Flutter update (#1048) * Update Flutter Update packages * Fix localization issues Fix UI issues Update old packages Update workflow Update how to build guide * Additional UI fixes for merged conflicts * Fix Ethereum network for anonpay invoice (#1051) * build: migrate from wakelock to wakelock_plus - plus is compatible with package_info_plus ^4.0.0 - plus has implemented Linux support * fix: theme & support view model merge fixes --------- Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
130 lines
No EOL
3.3 KiB
Dart
130 lines
No EOL
3.3 KiB
Dart
const textDirectionDeclaration = """
|
|
|
|
@override
|
|
TextDirection get textDirection => TextDirection.ltr;
|
|
|
|
""";
|
|
|
|
const classDeclaration = """
|
|
class GeneratedLocalizationsDelegate extends LocalizationsDelegate<S> {
|
|
const GeneratedLocalizationsDelegate();
|
|
|
|
List<Locale> get supportedLocales {
|
|
return const <Locale>[
|
|
""";
|
|
|
|
const part1 = """
|
|
import \'dart:async\';
|
|
import \'package:flutter/foundation.dart\';
|
|
import \'package:flutter/material.dart\';
|
|
|
|
class S implements WidgetsLocalizations {
|
|
const S();
|
|
|
|
static late S current;
|
|
|
|
static const GeneratedLocalizationsDelegate delegate =
|
|
GeneratedLocalizationsDelegate();
|
|
|
|
static S of(BuildContext context) => Localizations.of<S>(context, S)!;
|
|
|
|
@override
|
|
String get reorderItemToStart => "reorderItemToStart";
|
|
|
|
@override
|
|
String get reorderItemToEnd => "reorderItemToEnd";
|
|
|
|
@override
|
|
String get reorderItemUp => "reorderItemUp";
|
|
|
|
@override
|
|
String get reorderItemDown => "reorderItemDown";
|
|
|
|
@override
|
|
String get reorderItemLeft => "reorderItemLeft";
|
|
|
|
@override
|
|
String get reorderItemRight => "reorderItemRight";
|
|
""";
|
|
|
|
const part2 = """
|
|
];
|
|
}
|
|
|
|
LocaleListResolutionCallback listResolution({required Locale fallback, bool withCountry = true}) {
|
|
return (List<Locale>? locales, Iterable<Locale> supported) {
|
|
if (locales == null || locales.isEmpty) {
|
|
return fallback ?? supported.first;
|
|
} else {
|
|
return _resolve(locales.first, fallback, supported, withCountry);
|
|
}
|
|
};
|
|
}
|
|
|
|
LocaleResolutionCallback resolution({required Locale fallback, bool withCountry = true}) {
|
|
return (Locale? locale, Iterable<Locale> supported) {
|
|
return _resolve(locale, fallback, supported, withCountry);
|
|
};
|
|
}
|
|
|
|
@override
|
|
Future<S> load(Locale locale) {
|
|
final String lang = getLang(locale);
|
|
if (lang != null) {
|
|
switch (lang) {
|
|
""";
|
|
|
|
const part3 = """
|
|
default:
|
|
}
|
|
}
|
|
S.current = const S();
|
|
return SynchronousFuture<S>(S.current);
|
|
}
|
|
|
|
@override
|
|
bool isSupported(Locale locale) => _isSupported(locale, true);
|
|
|
|
@override
|
|
bool shouldReload(GeneratedLocalizationsDelegate old) => false;
|
|
|
|
Locale _resolve(Locale? locale, Locale fallback, Iterable<Locale> supported, bool withCountry) {
|
|
if (locale == null || !_isSupported(locale, withCountry)) {
|
|
return fallback ?? supported.first;
|
|
}
|
|
|
|
final Locale languageLocale = Locale(locale.languageCode, "");
|
|
if (supported.contains(locale)) {
|
|
return locale;
|
|
} else if (supported.contains(languageLocale)) {
|
|
return languageLocale;
|
|
} else {
|
|
final Locale fallbackLocale = fallback ?? supported.first;
|
|
return fallbackLocale;
|
|
}
|
|
}
|
|
|
|
bool _isSupported(Locale locale, bool withCountry) {
|
|
if (locale != null) {
|
|
for (Locale supportedLocale in supportedLocales) {
|
|
if (supportedLocale.languageCode != locale.languageCode) {
|
|
continue;
|
|
}
|
|
if (supportedLocale.countryCode == locale.countryCode) {
|
|
return true;
|
|
}
|
|
if (true != withCountry && (supportedLocale.countryCode == null || supportedLocale.countryCode!.isEmpty)) {
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
}
|
|
|
|
String getLang(Locale l) => l == null
|
|
? throw Exception('Incorrect local')
|
|
: l.countryCode != null && l.countryCode!.isEmpty
|
|
? l.languageCode
|
|
: l.toString();
|
|
"""; |