feat: add users' repo screen

This commit is contained in:
Rongjian Zhang 2019-02-09 13:36:15 +08:00
parent 8d50862b52
commit ab755005b7
4 changed files with 67 additions and 24 deletions

View File

@ -9,6 +9,7 @@ import 'screens/me.dart';
import 'screens/login.dart'; import 'screens/login.dart';
import 'screens/pull_request.dart'; import 'screens/pull_request.dart';
import 'screens/issue.dart'; import 'screens/issue.dart';
import 'screens/repos.dart';
class Home extends StatefulWidget { class Home extends StatefulWidget {
@override @override
@ -62,6 +63,7 @@ class _HomeState extends State<Home> {
_buildScreen(int index) { _buildScreen(int index) {
// return IssueScreen(number: 29, owner: 'reactjs', name: 'rfcs'); // return IssueScreen(number: 29, owner: 'reactjs', name: 'rfcs');
// return ReposScreen('pd4d10');
switch (index) { switch (index) {
case 0: case 0:
return NewsScreen(); return NewsScreen();

View File

@ -1,14 +1,55 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import '../scaffolds/list.dart';
import '../providers/settings.dart';
import '../utils/utils.dart';
import '../widgets/repo_item.dart';
/// Repos of user /// Repos of user
class ReposScreen extends StatefulWidget { class ReposScreen extends StatefulWidget {
final String login;
ReposScreen(this.login);
@override @override
_ReposScreenState createState() => _ReposScreenState(); _ReposScreenState createState() => _ReposScreenState();
} }
class _ReposScreenState extends State<ReposScreen> { class _ReposScreenState extends State<ReposScreen> {
get login => widget.login;
Future<ListPayload> _queryRepos([String cursor]) async {
var cursorChunk = cursor == null ? '' : ', after: "$cursor"';
var data = await SettingsProvider.of(context).query('''
{
user(login: "$login") {
repositories(first: $pageSize$cursorChunk, orderBy: {field: UPDATED_AT, direction: DESC}) {
pageInfo {
hasNextPage
endCursor
}
nodes {
$repoChunk
}
}
}
}
''');
var repo = data["user"]["repositories"];
return ListPayload(
cursor: repo["pageInfo"]["endCursor"],
items: repo["nodes"],
end: repo['pageInfo']['hasNextPage'],
);
}
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Container(); return ListScaffold(
title: Text('$login\'s repositories'),
onRefresh: () => _queryRepos(),
onLoadMore: (cursor) => _queryRepos(cursor),
itemBuilder: (payload) => RepoItem(payload),
);
} }
} }

View File

@ -13,26 +13,6 @@ import '../screens/users.dart';
import '../screens/settings.dart'; import '../screens/settings.dart';
import '../utils/utils.dart'; import '../utils/utils.dart';
var repoChunk = '''
owner {
login
}
name
description
isPrivate
isFork
stargazers {
totalCount
}
forks {
totalCount
}
primaryLanguage {
color
name
}
''';
class UserScreen extends StatefulWidget { class UserScreen extends StatefulWidget {
final String login; final String login;
final bool showSettings; final bool showSettings;
@ -205,12 +185,12 @@ class _UserScreenState extends State<UserScreen> {
EntryItem( EntryItem(
count: payload['repositories']['totalCount'], count: payload['repositories']['totalCount'],
text: 'Repositories', text: 'Repositories',
screenBuilder: (context) => ReposScreen(), screenBuilder: (context) => ReposScreen(widget.login),
), ),
EntryItem( EntryItem(
count: payload['starredRepositories']['totalCount'], count: payload['starredRepositories']['totalCount'],
text: 'Stars', text: 'Stars',
screenBuilder: (context) => ReposScreen(), screenBuilder: (context) => ReposScreen(widget.login),
), ),
EntryItem( EntryItem(
count: payload['followers']['totalCount'], count: payload['followers']['totalCount'],

View File

@ -155,7 +155,7 @@ class Palette {
static const gray = Color(0xff959da5); static const gray = Color(0xff959da5);
} }
final pageSize = 5; final pageSize = 20;
final graphqlChunk1 = ''' final graphqlChunk1 = '''
title title
@ -316,3 +316,23 @@ var createWarning =
(String text) => Text(text, style: TextStyle(color: Colors.redAccent)); (String text) => Text(text, style: TextStyle(color: Colors.redAccent));
var warningSpan = var warningSpan =
TextSpan(text: 'xxx', style: TextStyle(color: Colors.redAccent)); TextSpan(text: 'xxx', style: TextStyle(color: Colors.redAccent));
var repoChunk = '''
owner {
login
}
name
description
isPrivate
isFork
stargazers {
totalCount
}
forks {
totalCount
}
primaryLanguage {
color
name
}
''';