1
0
mirror of https://github.com/git-touch/git-touch synced 2025-01-13 08:12:39 +01:00
git-touch-android-ios-app/lib/screens/gitlab_group.dart

68 lines
2.0 KiB
Dart
Raw Normal View History

2020-01-31 15:45:40 +01:00
import 'package:flutter/material.dart';
import 'package:flutter/widgets.dart';
import 'package:git_touch/models/auth.dart';
import 'package:git_touch/models/gitlab.dart';
import 'package:git_touch/scaffolds/refresh_stateful.dart';
import 'package:git_touch/widgets/entry_item.dart';
2020-01-31 15:45:40 +01:00
import 'package:git_touch/widgets/repository_item.dart';
import 'package:git_touch/widgets/user_header.dart';
import 'package:provider/provider.dart';
import 'package:tuple/tuple.dart';
import 'package:git_touch/utils/utils.dart';
import 'package:timeago/timeago.dart' as timeago;
class GitlabGroupScreen extends StatelessWidget {
final int id;
GitlabGroupScreen(this.id);
@override
Widget build(BuildContext context) {
return RefreshStatefulScaffold<Tuple2<GitlabGroup, int>>(
2020-01-31 15:45:40 +01:00
title: Text('Group'),
fetchData: () async {
final auth = Provider.of<AuthModel>(context);
final res = await Future.wait([
auth.fetchGitlab('/groups/$id'),
auth.fetchGitlabWithPage('/groups/$id/members?per_page=1')
]);
return Tuple2(
GitlabGroup.fromJson(res[0]),
(res[1] as DataWithPage).total,
);
2020-01-31 15:45:40 +01:00
},
bodyBuilder: (data, _) {
final p = data.item1;
return Column(
children: <Widget>[
UserHeader(
login: p.path,
avatarUrl: p.avatarUrl,
name: p.name,
createdAt: null,
bio: p.description,
),
CommonStyle.border,
Row(children: [
EntryItem(
count: data.item2,
text: 'Members',
2020-02-01 05:14:03 +01:00
url: '/gitlab/groups/$id/members',
),
]),
CommonStyle.border,
2020-01-31 15:45:40 +01:00
Column(
children: <Widget>[
for (var v in p.projects)
RepositoryItem.gl(
payload: v,
2020-02-01 03:35:55 +01:00
note: 'Updated ${timeago.format(v.lastActivityAt)}',
2020-01-31 15:45:40 +01:00
)
],
)
],
);
},
);
}
}