import 'package:antd_mobile/antd_mobile.dart'; import 'package:flutter/widgets.dart'; import 'package:flutter_vector_icons/flutter_vector_icons.dart'; import 'package:git_touch/models/auth.dart'; import 'package:git_touch/models/gitee.dart'; import 'package:git_touch/scaffolds/refresh_stateful.dart'; import 'package:git_touch/utils/utils.dart'; import 'package:git_touch/widgets/action_button.dart'; import 'package:git_touch/widgets/action_entry.dart'; import 'package:git_touch/widgets/avatar.dart'; import 'package:git_touch/widgets/comment_item.dart'; import 'package:git_touch/widgets/link.dart'; import 'package:primer/primer.dart'; import 'package:provider/provider.dart'; import 'package:tuple/tuple.dart'; class GeIssueScreen extends StatelessWidget { const GeIssueScreen(this.owner, this.name, this.number, {this.isPr = false}); final String owner; final String name; final String number; final bool isPr; List _buildCommentActionItem( BuildContext context, GiteeComment comment) { final auth = context.read(); return [ ActionItem( text: 'Edit', onTap: (_) { final uri = Uri( path: '/gitee/$owner/$name/issues/$number/comment', queryParameters: { 'body': comment.body, 'id': comment.id.toString(), }, ).toString(); context.pushUrl(uri); }, ), ActionItem( text: 'Delete', onTap: (_) async { await auth.fetchGitee( '/repos/$owner/$name/issues/comments/${comment.id}', requestType: 'DELETE'); await context.pushUrl('/gitee/$owner/$name/issues/$number', replace: true); }, ), ]; } @override Widget build(BuildContext context) { return RefreshStatefulScaffold>>( title: Text('Issue: #$number'), fetch: () async { final auth = context.read(); final items = await Future.wait([ auth.fetchGitee('/repos/$owner/$name/issues/$number'), auth.fetchGitee('/repos/$owner/$name/issues/$number/comments') ]); return Tuple2(GiteeIssue.fromJson(items[0]), [for (var v in items[1]) GiteeComment.fromJson(v)]); }, actionBuilder: (data, _) => ActionEntry( iconData: Octicons.plus, url: '/gitee/$owner/$name/issues/$number/comment', ), bodyBuilder: (data, _) { final issue = data.item1; final comments = data.item2; return Column(children: [ Container( padding: CommonStyle.padding, child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ LinkWidget( url: '/gitee/$owner/$name', child: Row( children: [ Avatar( url: issue.user!.avatarUrl, size: AvatarSize.extraSmall, ), const SizedBox(width: 4), Text( '$owner / $name', style: TextStyle( fontSize: 17, color: AntTheme.of(context).colorTextSecondary, ), ), const SizedBox(width: 4), Text( '#$number', style: TextStyle( fontSize: 17, color: AntTheme.of(context).colorWeak, ), ), ], ), ), const SizedBox(height: 8), Text( issue.title!, style: const TextStyle( fontSize: 20, fontWeight: FontWeight.w600, ), ), const SizedBox(height: 8), StateLabel( issue.state == 'open' ? StateLabelStatus.issueOpened : StateLabelStatus.issueClosed, small: true), const SizedBox(height: 16), CommonStyle.border, ], )), Column(children: [ for (var comment in comments) ...[ Padding( padding: const EdgeInsets.only(left: 10), child: CommentItem( avatar: Avatar( url: comment.user!.avatarUrl, linkUrl: '/gitee/${comment.user!.login}', ), createdAt: DateTime.parse(comment.createdAt!), body: comment.body, login: comment.user!.login, prefix: 'gitee', commentActionItemList: _buildCommentActionItem(context, comment), )), CommonStyle.border, const SizedBox(height: 16), ], ]), ]); }, ); } }