|
|
@ -11,6 +11,7 @@ |
|
|
|
|
|
|
|
|
|
|
|
import 'dart:async'; |
|
|
|
import 'dart:async'; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import 'package:flutter/foundation.dart'; |
|
|
|
import 'package:intl/intl.dart'; |
|
|
|
import 'package:intl/intl.dart'; |
|
|
|
import 'package:intl/message_lookup_by_library.dart'; |
|
|
|
import 'package:intl/message_lookup_by_library.dart'; |
|
|
|
import 'package:intl/src/intl_helpers.dart'; |
|
|
|
import 'package:intl/src/intl_helpers.dart'; |
|
|
@ -24,15 +25,15 @@ import 'messages_zh_TW.dart' as messages_zh_tw; |
|
|
|
|
|
|
|
|
|
|
|
typedef Future<dynamic> LibraryLoader(); |
|
|
|
typedef Future<dynamic> LibraryLoader(); |
|
|
|
Map<String, LibraryLoader> _deferredLibraries = { |
|
|
|
Map<String, LibraryLoader> _deferredLibraries = { |
|
|
|
'en': () => new Future.value(null), |
|
|
|
'en': () => new SynchronousFuture(null), |
|
|
|
'en_US': () => new Future.value(null), |
|
|
|
'en_US': () => new SynchronousFuture(null), |
|
|
|
'zh_CN': () => new Future.value(null), |
|
|
|
'zh_CN': () => new SynchronousFuture(null), |
|
|
|
'zh_Hans_CN': () => new Future.value(null), |
|
|
|
'zh_Hans_CN': () => new SynchronousFuture(null), |
|
|
|
'zh_Hant_CN': () => new Future.value(null), |
|
|
|
'zh_Hant_CN': () => new SynchronousFuture(null), |
|
|
|
'zh_TW': () => new Future.value(null), |
|
|
|
'zh_TW': () => new SynchronousFuture(null), |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
MessageLookupByLibrary _findExact(String localeName) { |
|
|
|
MessageLookupByLibrary? _findExact(String localeName) { |
|
|
|
switch (localeName) { |
|
|
|
switch (localeName) { |
|
|
|
case 'en': |
|
|
|
case 'en': |
|
|
|
return messages_en.messages; |
|
|
|
return messages_en.messages; |
|
|
@ -52,19 +53,18 @@ MessageLookupByLibrary _findExact(String localeName) { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/// User programs should call this before using [localeName] for messages. |
|
|
|
/// User programs should call this before using [localeName] for messages. |
|
|
|
Future<bool> initializeMessages(String localeName) async { |
|
|
|
Future<bool> initializeMessages(String localeName) { |
|
|
|
var availableLocale = Intl.verifiedLocale( |
|
|
|
var availableLocale = Intl.verifiedLocale( |
|
|
|
localeName, |
|
|
|
localeName, (locale) => _deferredLibraries[locale] != null, |
|
|
|
(locale) => _deferredLibraries[locale] != null, |
|
|
|
|
|
|
|
onFailure: (_) => null); |
|
|
|
onFailure: (_) => null); |
|
|
|
if (availableLocale == null) { |
|
|
|
if (availableLocale == null) { |
|
|
|
return new Future.value(false); |
|
|
|
return new SynchronousFuture(false); |
|
|
|
} |
|
|
|
} |
|
|
|
var lib = _deferredLibraries[availableLocale]; |
|
|
|
var lib = _deferredLibraries[availableLocale]; |
|
|
|
await (lib == null ? new Future.value(false) : lib()); |
|
|
|
lib == null ? new SynchronousFuture(false) : lib(); |
|
|
|
initializeInternalMessageLookup(() => new CompositeMessageLookup()); |
|
|
|
initializeInternalMessageLookup(() => new CompositeMessageLookup()); |
|
|
|
messageLookup.addLocale(availableLocale, _findGeneratedMessagesFor); |
|
|
|
messageLookup.addLocale(availableLocale, _findGeneratedMessagesFor); |
|
|
|
return new Future.value(true); |
|
|
|
return new SynchronousFuture(true); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
bool _messagesExistFor(String locale) { |
|
|
|
bool _messagesExistFor(String locale) { |
|
|
@ -75,9 +75,9 @@ bool _messagesExistFor(String locale) { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
MessageLookupByLibrary _findGeneratedMessagesFor(String locale) { |
|
|
|
MessageLookupByLibrary? _findGeneratedMessagesFor(String locale) { |
|
|
|
var actualLocale = Intl.verifiedLocale(locale, _messagesExistFor, |
|
|
|
var actualLocale = |
|
|
|
onFailure: (_) => null); |
|
|
|
Intl.verifiedLocale(locale, _messagesExistFor, onFailure: (_) => null); |
|
|
|
if (actualLocale == null) return null; |
|
|
|
if (actualLocale == null) return null; |
|
|
|
return _findExact(actualLocale); |
|
|
|
return _findExact(actualLocale); |
|
|
|
} |
|
|
|
} |
|
|
|