CAKE-272 | resolved problems

This commit is contained in:
OleksandrSobol 2021-03-19 21:52:07 +02:00
parent 3bfeaeb46b
commit 319a7bfca6
5 changed files with 5710 additions and 5685 deletions

1
.gitignore vendored
View file

@ -93,3 +93,4 @@ vendor/
android/app/.cxx/** android/app/.cxx/**
ios/Flutter/.last_build_id ios/Flutter/.last_build_id
lib/generated/i18n.dart

File diff suppressed because it is too large Load diff

View file

@ -89,7 +89,7 @@
"trade_is_powered_by" : "Dieser Handel wird betrieben von ${provider}", "trade_is_powered_by" : "Dieser Handel wird betrieben von ${provider}",
"copy_address" : "Adresse kopieren", "copy_address" : "Adresse kopieren",
"exchange_result_confirm" : "Durch Drücken von Bestätigen wird gesendet ${fetchingLabel} ${from} von Ihrer Brieftasche aus angerufen ${walletName} an die unten angegebene Adresse. Oder Sie können von Ihrem externen Portemonnaie an die unten angegebene Adresse / QR-Code senden.\n\nBitte bestätigen Sie, um fortzufahren, oder gehen Sie zurück, um die Beträge zu änderns.", "exchange_result_confirm" : "Durch Drücken von Bestätigen wird gesendet ${fetchingLabel} ${from} von Ihrer Brieftasche aus angerufen ${walletName} an die unten angegebene Adresse. Oder Sie können von Ihrem externen Portemonnaie an die unten angegebene Adresse / QR-Code senden.\n\nBitte bestätigen Sie, um fortzufahren, oder gehen Sie zurück, um die Beträge zu änderns.",
"exchange_result_description" : "Bitte senden ${fetchingLabel} ${from} an die auf der nächsten Seite angegebene Adresse.", "exchange_result_description" : "Sie müssen mindestens ${fetchingLabel} ${from} an die auf der nächsten Seite angegebene Adresse senden. Wenn Sie einen Betrag unter ${fetchingLabel} ${from} senden, wird dieser möglicherweise nicht konvertiert und möglicherweise nicht erstattet.",
"exchange_result_write_down_ID" : "*Bitte kopieren oder notieren Sie Ihren oben gezeigten Ausweis.", "exchange_result_write_down_ID" : "*Bitte kopieren oder notieren Sie Ihren oben gezeigten Ausweis.",
"confirm" : "Bestätigen", "confirm" : "Bestätigen",
"confirm_sending" : "Bestätigen Sie das Senden", "confirm_sending" : "Bestätigen Sie das Senden",

View file

@ -89,7 +89,7 @@
"trade_is_powered_by" : "この取引は ${provider}", "trade_is_powered_by" : "この取引は ${provider}",
"copy_address" : "住所をコピー", "copy_address" : "住所をコピー",
"exchange_result_confirm" : "確認を押すと、送信されます ${fetchingLabel} ${from} と呼ばれるあなたの財布から ${walletName} 下記の住所へ。 または、外部ウォレットから以下のアドレスに送信することもできます/ QRコードに送信できます.\n\n確認を押して続行するか、戻って金額を変更してください.", "exchange_result_confirm" : "確認を押すと、送信されます ${fetchingLabel} ${from} と呼ばれるあなたの財布から ${walletName} 下記の住所へ。 または、外部ウォレットから以下のアドレスに送信することもできます/ QRコードに送信できます.\n\n確認を押して続行するか、戻って金額を変更してください.",
"exchange_result_description" : 次のページに示されているアドレスに最低 ${fetchingLabel} ${from} を送信する必要があります。 ${fetchingLabel} ${from} 未満の金額を送信すると、変換されず、返金されない場合があります。", "exchange_result_description" : "次のページに示されているアドレスに最低 ${fetchingLabel} ${from} を送信する必要があります。 ${fetchingLabel} ${from} 未満の金額を送信すると、変換されず、返金されない場合があります。",
"exchange_result_write_down_ID" : "*上記のIDをコピーまたは書き留めてください.", "exchange_result_write_down_ID" : "*上記のIDをコピーまたは書き留めてください.",
"confirm" : "確認する", "confirm" : "確認する",
"confirm_sending" : "送信を確認", "confirm_sending" : "送信を確認",

View file

@ -6,26 +6,127 @@ const outputPath = 'lib/generated/i18n.dart';
const locales = ['en', 'de', 'es', 'hi', const locales = ['en', 'de', 'es', 'hi',
'ja', 'ko', 'nl', 'pl', 'ja', 'ko', 'nl', 'pl',
'pt', 'ru', 'uk', 'zh']; 'pt', 'ru', 'uk', 'zh'];
const header = """
import \'dart:async\';
import \'package:flutter/foundation.dart\';
import \'package:flutter/material.dart\';
class S implements WidgetsLocalizations {
const S();
static S current;
static const GeneratedLocalizationsDelegate delegate =
GeneratedLocalizationsDelegate();
static S of(BuildContext context) => Localizations.of<S>(context, S);
""";
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 middle = """
];
}
LocaleListResolutionCallback listResolution({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({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 end = """
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
? null
: l.countryCode != null && l.countryCode.isEmpty
? l.languageCode
: l.toString();
""";
Future<void> main() async { Future<void> main() async {
var inputContent = File(inputPath + 'strings_en.arb').readAsStringSync(); var inputContent = File(inputPath + 'strings_en.arb').readAsStringSync();
var config = json.decode(inputContent) as Map<String, dynamic>; var config = json.decode(inputContent) as Map<String, dynamic>;
var output = ''; var output = '';
output += 'import \'dart:async\';' + '\n'; output += header;
output += 'import \'package:flutter/foundation.dart\';' + '\n'; output += textDirectionDeclaration;
output += 'import \'package:flutter/material.dart\';' + '\n\n';
output += 'class S implements WidgetsLocalizations {' + '\n';
output += ' const S();' + '\n\n';
output += ' static S current;' + '\n\n';
output += ' static const GeneratedLocalizationsDelegate delegate =' + '\n';
output += ' GeneratedLocalizationsDelegate();' + '\n\n';
output += ' static S of(BuildContext context) => Localizations.of<S>(context, S);' + '\n\n';
output += ' @override' + '\n';
output += ' TextDirection get textDirection => TextDirection.ltr;' + '\n\n';
output += localizedStrings(config: config, hasOverride: false); output += localizedStrings(config: config, hasOverride: false);
output += '}' + '\n\n'; output += '}' + '\n\n';
for (var locale in locales) { for (var locale in locales) {
@ -33,9 +134,7 @@ Future<void> main() async {
output += ' const \$$locale();' + '\n'; output += ' const \$$locale();' + '\n';
if (locale != locales.first) { if (locale != locales.first) {
output += '\n' + ' @override' + '\n'; output += textDirectionDeclaration;
output +=
' TextDirection get textDirection => TextDirection.ltr;' + '\n\n';
inputContent = File(inputPath + 'strings_$locale.arb').readAsStringSync(); inputContent = File(inputPath + 'strings_$locale.arb').readAsStringSync();
config = json.decode(inputContent) as Map<String, dynamic>; config = json.decode(inputContent) as Map<String, dynamic>;
@ -46,39 +145,13 @@ Future<void> main() async {
output += '}' + '\n\n'; output += '}' + '\n\n';
} }
output += 'class GeneratedLocalizationsDelegate extends LocalizationsDelegate<S> {' + '\n'; output += classDeclaration;
output += ' const GeneratedLocalizationsDelegate();' + '\n\n';
output += ' List<Locale> get supportedLocales {' + '\n';
output += ' return const <Locale>[' + '\n';
for (var locale in locales) { for (var locale in locales) {
output += ' Locale("$locale", ""),' + '\n'; output += ' Locale("$locale", ""),' + '\n';
} }
output += ' ];' + '\n'; output += middle;
output += ' }' + '\n\n';
output += ' LocaleListResolutionCallback listResolution({Locale fallback, bool withCountry = true}) {' + '\n';
output += ' return (List<Locale> locales, Iterable<Locale> supported) {' + '\n';
output += ' if (locales == null || locales.isEmpty) {' + '\n';
output += ' return fallback ?? supported.first;' + '\n';
output += ' } else {' + '\n';
output += ' return _resolve(locales.first, fallback, supported, withCountry);' + '\n';
output += ' }' + '\n';
output += ' };' + '\n';
output += ' }' + '\n\n';
output += ' LocaleResolutionCallback resolution({Locale fallback, bool withCountry = true}) {' + '\n';
output += ' return (Locale locale, Iterable<Locale> supported) {' + '\n';
output += ' return _resolve(locale, fallback, supported, withCountry);' + '\n';
output += ' };' + '\n';
output += ' }' + '\n\n';
output += ' @override' + '\n';
output += ' Future<S> load(Locale locale) {' + '\n';
output += ' final String lang = getLang(locale);' + '\n';
output += ' if (lang != null) {' + '\n';
output += ' switch (lang) {' + '\n';
for (var locale in locales) { for (var locale in locales) {
output += ' case "$locale":' + '\n'; output += ' case "$locale":' + '\n';
@ -86,57 +159,7 @@ Future<void> main() async {
output += ' return SynchronousFuture<S>(S.current);' + '\n'; output += ' return SynchronousFuture<S>(S.current);' + '\n';
} }
output += ' default:' + '\n'; output += end;
output += ' }' + '\n';
output += ' }' + '\n';
output += ' S.current = const S();' + '\n';
output += ' return SynchronousFuture<S>(S.current);' + '\n';
output += ' }' + '\n\n';
output += ' @override' + '\n';
output += ' bool isSupported(Locale locale) => _isSupported(locale, true);' + '\n\n';
output += ' @override' + '\n';
output += ' bool shouldReload(GeneratedLocalizationsDelegate old) => false;' + '\n\n';
output += ' Locale _resolve(Locale locale, Locale fallback, Iterable<Locale> supported, bool withCountry) {' + '\n';
output += ' if (locale == null || !_isSupported(locale, withCountry)) {' + '\n';
output += ' return fallback ?? supported.first;' + '\n';
output += ' }' + '\n\n';
output += ' final Locale languageLocale = Locale(locale.languageCode, "");' + '\n';
output += ' if (supported.contains(locale)) {' + '\n';
output += ' return locale;' + '\n';
output += ' } else if (supported.contains(languageLocale)) {' + '\n';
output += ' return languageLocale;' + '\n';
output += ' } else {' + '\n';
output += ' final Locale fallbackLocale = fallback ?? supported.first;' + '\n';
output += ' return fallbackLocale;' + '\n';
output += ' }' + '\n';
output += ' }' + '\n\n';
output += ' bool _isSupported(Locale locale, bool withCountry) {' + '\n';
output += ' if (locale != null) {' + '\n';
output += ' for (Locale supportedLocale in supportedLocales) {' + '\n';
output += ' if (supportedLocale.languageCode != locale.languageCode) {' + '\n';
output += ' continue;' + '\n';
output += ' }' + '\n';
output += ' if (supportedLocale.countryCode == locale.countryCode) {' + '\n';
output += ' return true;' + '\n';
output += ' }' + '\n';
output += ' if (true != withCountry && (supportedLocale.countryCode == null || supportedLocale.countryCode.isEmpty)) {' + '\n';
output += ' return true;' + '\n';
output += ' }' + '\n';
output += ' }' + '\n';
output += ' }' + '\n';
output += ' return false;' + '\n';
output += ' }' + '\n';
output += '}' + '\n\n';
output += 'String getLang(Locale l) => l == null' + '\n';
output += ' ? null' + '\n';
output += ' : l.countryCode != null && l.countryCode.isEmpty' + '\n';
output += ' ? l.languageCode' + '\n';
output += ' : l.toString();';
await File(outputPath).writeAsString(output); await File(outputPath).writeAsString(output);
} }
@ -146,29 +169,30 @@ String localizedStrings({Map<String, dynamic> config, bool hasOverride}) {
final pattern = RegExp('[\$]{(.*?)}'); final pattern = RegExp('[\$]{(.*?)}');
for (int i = 0; i < config.length; i++) { config.forEach((key, dynamic value) {
final key = config.keys.elementAt(i); final matches = pattern.allMatches(value as String);
final value = config.values.elementAt(i) as String;
final matches = pattern.allMatches(value);
if (hasOverride) { if (hasOverride) {
output += ' @override' + '\n'; output += ' @override' + '\n';
} }
if (matches.length == 0) { if (matches.isEmpty) {
output += ' String get ${key} => \'\'\'${value}\'\'\';' + '\n'; output += ' String get ${key} => \"\"\"${value}\"\"\";' + '\n';
} else { } else {
final set = matches.map((elem) => elem.group(1)).toSet().toList();
output += ' String ${key}('; output += ' String ${key}(';
for (var match in matches) {
if (match.group(1) == matches.last.group(1)) { for (var elem in set) {
output += 'String ${match.group(1)}'; if (elem == set.last) {
output += 'String ${elem}';
} else { } else {
output += 'String ${match.group(1)}, '; output += 'String ${elem}, ';
} }
} }
output += ') => \'\'\'${value}\'\'\';' + '\n'; output += ') => \"\"\"${value}\"\"\";' + '\n';
} }
} });
return output; return output;
} }