Commit d8d5156a authored by Eric Seidel's avatar Eric Seidel

Move data out of Github and into Firebase

@abarth @collinjackson
parent 769f9cb2
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
...@@ -53,12 +53,20 @@ class StockData { ...@@ -53,12 +53,20 @@ class StockData {
} }
typedef void StockDataCallback(StockData data); typedef void StockDataCallback(StockData data);
const _kChunkCount = 30; const _kChunkSize = 100;
String _urlToFetch(int chunk) { String _urlToFetch(int chunk) {
if (rootBundle == null) Map<String, String> queryParameters = {
return '../data/stock_data_$chunk.json'; 'limitToFirst': _kChunkSize.toString(),
return 'https://domokit.github.io/examples/stocks/data/stock_data_$chunk.json'; 'startAt': '\"${chunk * _kChunkSize}\"',
'orderBy': '"\$key"',
};
// Just a demo firebase app owned by eseidel.
return new Uri.https(
'sizzling-torch-6112.firebaseio.com',
'.json',
queryParameters=queryParameters
).toString();
} }
class StockDataFetcher { class StockDataFetcher {
...@@ -74,6 +82,7 @@ class StockDataFetcher { ...@@ -74,6 +82,7 @@ class StockDataFetcher {
void _fetchNextChunk() { void _fetchNextChunk() {
if (!actuallyFetchData) if (!actuallyFetchData)
return; return;
fetchBody(_urlToFetch(_nextChunk++)).then((Response response) { fetchBody(_urlToFetch(_nextChunk++)).then((Response response) {
String json = response.bodyAsString(); String json = response.bodyAsString();
if (json == null) { if (json == null) {
...@@ -81,8 +90,9 @@ class StockDataFetcher { ...@@ -81,8 +90,9 @@ class StockDataFetcher {
return; return;
} }
JsonDecoder decoder = new JsonDecoder(); JsonDecoder decoder = new JsonDecoder();
callback(new StockData(decoder.convert(json))); Map responseJson = decoder.convert(json);
if (_nextChunk < _kChunkCount) callback(new StockData(responseJson.values.toList()));
if (responseJson.isNotEmpty)
_fetchNextChunk(); _fetchNextChunk();
}); });
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment