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

57 lines
1.7 KiB
Dart
Raw Normal View History

import 'dart:convert';
2019-03-02 11:17:46 +01:00
import 'package:flutter/material.dart';
2019-09-08 15:20:12 +02:00
import 'package:git_touch/utils/utils.dart';
2019-09-11 13:59:47 +02:00
import 'package:git_touch/widgets/app_bar_title.dart';
import 'package:http/http.dart' as http;
2019-03-02 11:17:46 +01:00
import '../scaffolds/refresh.dart';
2019-09-23 12:28:33 +02:00
import 'package:git_touch/widgets/repository_item.dart';
2019-03-02 11:17:46 +01:00
class TrendingScreen extends StatefulWidget {
@override
_TrendingScreenState createState() => _TrendingScreenState();
}
class _TrendingScreenState extends State<TrendingScreen> {
@override
Widget build(BuildContext context) {
return RefreshScaffold(
2019-09-11 13:59:47 +02:00
title: AppBarTitle('Trending'),
onRefresh: (_) async {
var res = await http.get('https://github-trending-api.now.sh');
var items = json.decode(res.body);
return items.map((item) {
return {
'owner': {'login': item['author'], 'avatarUrl': item['avatar']},
'name': item['name'],
'description': item['description'],
'stargazers': {
'totalCount': item['stars'],
},
'forks': {
'totalCount': item['forks'],
},
'primaryLanguage': item['language'] == null
? null
: {
'name': item['language'],
'color': item['languageColor'],
},
'isPrivate': false,
'isFork': false // TODO:
};
}).toList();
},
2019-03-02 11:17:46 +01:00
bodyBuilder: (payload) {
return Column(
2019-09-08 15:20:12 +02:00
crossAxisAlignment: CrossAxisAlignment.stretch,
children: join(
2019-09-14 17:48:01 +02:00
borderView,
2019-09-23 12:28:33 +02:00
payload.map<Widget>((item) => RepositoryItem(item)).toList(),
2019-09-08 15:20:12 +02:00
),
2019-03-02 11:17:46 +01:00
);
},
);
}
}