1
0
mirror of https://github.com/git-touch/git-touch synced 2024-12-24 06:42:07 +01:00
git-touch-android-ios-app/lib/screens/trending.dart
2020-01-02 13:56:50 +08:00

67 lines
2.3 KiB
Dart

import 'dart:convert';
import 'package:flutter/material.dart';
import 'package:git_touch/models/github.dart';
import 'package:git_touch/scaffolds/tab_stateful.dart';
import 'package:git_touch/utils/utils.dart';
import 'package:git_touch/widgets/app_bar_title.dart';
import 'package:git_touch/widgets/user_item.dart';
import 'package:http/http.dart' as http;
import 'package:git_touch/widgets/repository_item.dart';
class TrendingScreen extends StatelessWidget {
Widget build(BuildContext context) {
return TabStatefulScaffold<Iterable>(
title: AppBarTitle('Trending'),
tabs: ['Repositories', 'Developers'],
fetchData: (tabIndex) async {
final uri = Uri.parse('https://github-trending-api.now.sh')
.resolve(tabIndex == 1 ? '/developers' : '/');
final res = await http.get(uri);
return json.decode(res.body) as List;
},
bodyBuilder: (payload, activeTab) {
return Column(
crossAxisAlignment: CrossAxisAlignment.stretch,
children: join(
CommonStyle.border,
payload.map<Widget>((v) {
switch (activeTab) {
case 0:
final item = GithubTrendingItem.fromJson(v);
return RepositoryItem.raw(
item.author,
item.avatar,
item.name,
item.description,
Octicons.repo,
item.stars ?? 0,
item.forks ?? 0,
item.language,
item.languageColor,
[],
);
case 1:
final item = GithubTrendingUser.fromJson(v);
return UserItem(
login: item.username,
name: item.name,
avatarUrl: item.avatar,
bio: Row(
children: <Widget>[
Icon(Octicons.repo, size: 17),
SizedBox(width: 2),
Text(item.repo.name, style: TextStyle(fontSize: 17))
],
),
);
default:
throw '';
}
}).toList(),
),
);
},
);
}
}