feat: add users' repo screen
This commit is contained in:
parent
8d50862b52
commit
ab755005b7
|
@ -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();
|
||||||
|
|
|
@ -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> {
|
||||||
@override
|
get login => widget.login;
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return Container();
|
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
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return ListScaffold(
|
||||||
|
title: Text('$login\'s repositories'),
|
||||||
|
onRefresh: () => _queryRepos(),
|
||||||
|
onLoadMore: (cursor) => _queryRepos(cursor),
|
||||||
|
itemBuilder: (payload) => RepoItem(payload),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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'],
|
||||||
|
|
|
@ -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
|
||||||
|
}
|
||||||
|
''';
|
||||||
|
|
Loading…
Reference in New Issue