OLD | NEW |
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 /** | 5 /** |
6 * This file should be imported, along with date_format.dart in order to read | 6 * This file should be imported, along with date_format.dart in order to read |
7 * locale data via http requests to a web server.. | 7 * locale data via http requests to a web server.. |
8 */ | 8 */ |
9 library date_symbol_data_json; | 9 library date_symbol_data_json; |
10 | 10 |
11 import "date_symbols.dart"; | 11 import 'dart:async'; |
12 import "src/lazy_locale_data.dart"; | 12 import 'date_symbols.dart'; |
| 13 import 'src/lazy_locale_data.dart'; |
13 import 'src/date_format_internal.dart'; | 14 import 'src/date_format_internal.dart'; |
14 import 'src/http_request_data_reader.dart'; | 15 import 'src/http_request_data_reader.dart'; |
15 | 16 |
16 part "src/data/dates/localeList.dart"; | 17 part "src/data/dates/localeList.dart"; |
17 | 18 |
18 /** | 19 /** |
19 * This should be called for at least one [locale] before any date formatting | 20 * This should be called for at least one [locale] before any date formatting |
20 * methods are called. It sets up the lookup for date symbols using [url]. | 21 * methods are called. It sets up the lookup for date symbols using [url]. |
21 * The [url] parameter should end with a "/". For example, | 22 * The [url] parameter should end with a "/". For example, |
22 * "http://localhost:8000/dates/" | 23 * "http://localhost:8000/dates/" |
23 */ | 24 */ |
24 Future initializeDateFormatting(String locale, String url) { | 25 Future initializeDateFormatting(String locale, String url) { |
25 var reader = new HTTPRequestDataReader('${url}symbols/'); | 26 var reader = new HTTPRequestDataReader('${url}symbols/'); |
26 initializeDateSymbols(() => new LazyLocaleData( | 27 initializeDateSymbols(() => new LazyLocaleData( |
27 reader, _createDateSymbol, availableLocalesForDateFormatting)); | 28 reader, _createDateSymbol, availableLocalesForDateFormatting)); |
28 var reader2 = new HTTPRequestDataReader('${url}patterns/'); | 29 var reader2 = new HTTPRequestDataReader('${url}patterns/'); |
29 initializeDatePatterns(() => new LazyLocaleData( | 30 initializeDatePatterns(() => new LazyLocaleData( |
30 reader2, (x) => x, availableLocalesForDateFormatting)); | 31 reader2, (x) => x, availableLocalesForDateFormatting)); |
31 return initializeIndividualLocaleDateFormatting( | 32 return initializeIndividualLocaleDateFormatting( |
32 (symbols, patterns) { | 33 (symbols, patterns) { |
33 return Futures.wait([ | 34 return Futures.wait([ |
34 symbols.initLocale(locale), | 35 symbols.initLocale(locale), |
35 patterns.initLocale(locale)]); | 36 patterns.initLocale(locale)]); |
36 }); | 37 }); |
37 } | 38 } |
38 | 39 |
39 /** Defines how new date symbol entries are created. */ | 40 /** Defines how new date symbol entries are created. */ |
40 DateSymbols _createDateSymbol(Map map) { | 41 DateSymbols _createDateSymbol(Map map) { |
41 return new DateSymbols.deserializeFromMap(map); | 42 return new DateSymbols.deserializeFromMap(map); |
42 } | 43 } |
OLD | NEW |