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

127 lines
3.4 KiB
Dart
Raw Normal View History

2019-02-04 14:38:29 +01:00
import 'package:flutter/material.dart';
2019-09-11 13:59:47 +02:00
import 'package:git_touch/widgets/app_bar_title.dart';
import 'package:primer/primer.dart';
2019-09-13 10:55:27 +02:00
import 'package:tuple/tuple.dart';
import '../scaffolds/list.dart';
2019-09-08 14:07:35 +02:00
import 'package:git_touch/models/settings.dart';
import 'package:provider/provider.dart';
import '../utils/utils.dart';
import '../widgets/link.dart';
import '../screens/user.dart';
import '../widgets/avatar.dart';
2019-02-04 14:38:29 +01:00
2019-09-13 10:55:27 +02:00
enum UsersScreenType {
userFollowing,
userFollowers,
repoStars,
repoWatchers,
orgs,
}
class UsersScreen extends StatelessWidget {
final UsersScreenType type;
final String login;
2019-09-13 10:55:27 +02:00
final String name;
2019-03-10 16:34:34 +01:00
UsersScreen({
2019-09-13 10:55:27 +02:00
@required this.type,
2019-03-10 16:34:34 +01:00
@required this.login,
2019-09-13 10:55:27 +02:00
this.name,
2019-03-10 16:34:34 +01:00
});
2019-09-13 10:55:27 +02:00
Tuple3<String, String, String> get queryKeys {
switch (type) {
case UsersScreenType.userFollowing:
return Tuple3('user', 'login: "$login"', 'following');
case UsersScreenType.userFollowers:
return Tuple3('user', 'login: "$login"', 'followers');
case UsersScreenType.repoStars:
return Tuple3(
'repository', 'owner: "$login", name: "$name"', 'stargazers');
case UsersScreenType.repoWatchers:
return Tuple3(
'repository', 'owner: "$login", name: "$name"', 'watchers');
case UsersScreenType.orgs:
return Tuple3('', '', ''); // FIXME:
default:
throw 'Should not be here';
2019-03-10 16:34:34 +01:00
}
}
2019-09-13 10:55:27 +02:00
Future<ListPayload> _queryUsers(BuildContext context, [String cursor]) async {
var cursorChunk = cursor == null ? '' : ', after: "$cursor"';
2019-09-13 10:55:27 +02:00
var scope = queryKeys.item1;
var params = queryKeys.item2;
var resource = queryKeys.item3;
2019-09-08 14:07:35 +02:00
var data = await Provider.of<SettingsModel>(context).query('''
{
2019-09-13 10:55:27 +02:00
$scope($params) {
$resource(first: $pageSize$cursorChunk) {
pageInfo {
hasNextPage
endCursor
}
nodes {
name
login
avatarUrl
2019-09-09 16:50:22 +02:00
url
}
}
}
}
''');
2019-03-10 16:34:34 +01:00
var repo = data[scope][resource];
return ListPayload(
cursor: repo["pageInfo"]["endCursor"],
2019-02-09 07:20:21 +01:00
hasMore: repo['pageInfo']['hasNextPage'],
items: repo["nodes"],
);
}
Widget _buildItem(payload) {
return Link(
screenBuilder: (_) => UserScreen(payload['login']),
child: Container(
padding: EdgeInsets.all(10),
child: Row(
children: <Widget>[
2019-09-13 09:55:58 +02:00
Avatar(url: payload['avatarUrl'], size: 24),
SizedBox(width: 10),
2019-09-13 09:55:58 +02:00
Expanded(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: join(SizedBox(height: 6), [
Text(
payload['name'] ?? payload['login'],
style: TextStyle(
fontSize: 16,
color: PrimerColors.blue500,
fontWeight: FontWeight.w500,
),
2019-09-13 09:55:58 +02:00
),
Text(
payload['login'],
style: TextStyle(fontSize: 14, color: PrimerColors.gray700),
)
]),
),
)
],
),
),
);
}
2019-02-04 14:38:29 +01:00
@override
Widget build(BuildContext context) {
return ListScaffold(
2019-09-13 10:55:27 +02:00
title: AppBarTitle('Users'),
onRefresh: () => _queryUsers(context),
onLoadMore: (cursor) => _queryUsers(context, cursor),
itemBuilder: _buildItem,
);
2019-02-04 14:38:29 +01:00
}
}