git-touch-android-ios-app/lib/screens/trending.dart

59 lines
1.5 KiB
Dart
Raw Normal View History

2019-03-02 11:17:46 +01:00
import 'package:flutter/material.dart';
import 'package:github_trending/github_trending.dart';
2019-03-02 11:17:46 +01:00
import '../scaffolds/refresh.dart';
import '../widgets/repo_item.dart';
class TrendingScreen extends StatefulWidget {
@override
_TrendingScreenState createState() => _TrendingScreenState();
}
class _TrendingScreenState extends State<TrendingScreen> {
Future<List<dynamic>> _fetchTrendingRepos() async {
var items = await getTrendingRepositories();
2019-03-02 11:17:46 +01:00
return items.map((item) {
return {
2019-03-02 11:17:46 +01:00
'owner': {
'login': item.owner,
2019-03-02 11:17:46 +01:00
},
'name': item.name,
'description': item.description,
2019-03-02 11:17:46 +01:00
'stargazers': {
'totalCount': item.starCount,
2019-03-02 11:17:46 +01:00
},
'forks': {
'totalCount': item.forkCount,
2019-03-02 11:17:46 +01:00
},
'primaryLanguage': item.primaryLanguage == null
? null
: {
'name': item.primaryLanguage.name,
'color': item.primaryLanguage.color,
},
2019-03-02 11:17:46 +01:00
'isPrivate': false,
'isFork': false // TODO:
};
}).toList();
}
@override
Widget build(BuildContext context) {
return RefreshScaffold(
title: Text('Trending'),
onRefresh: _fetchTrendingRepos,
bodyBuilder: (payload) {
return Column(
children: payload.map<Widget>((repo) {
return Container(
decoration: BoxDecoration(
border: Border(bottom: BorderSide(color: Colors.black12))),
child: RepoItem(repo),
);
}).toList(),
);
},
);
}
}