Solian/lib/screens/posts/post_detail.dart

111 lines
3.0 KiB
Dart
Raw Normal View History

2024-05-25 05:19:16 +00:00
import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:solian/exts.dart';
import 'package:solian/models/post.dart';
import 'package:solian/providers/content/posts.dart';
2024-09-16 17:23:49 +00:00
import 'package:solian/providers/last_read.dart';
2024-10-12 17:31:59 +00:00
import 'package:solian/theme.dart';
2024-05-25 05:19:16 +00:00
import 'package:solian/widgets/posts/post_item.dart';
2024-05-25 09:21:27 +00:00
import 'package:solian/widgets/posts/post_replies.dart';
2024-05-25 05:19:16 +00:00
class PostDetailScreen extends StatefulWidget {
final String id;
2024-08-01 20:42:38 +00:00
final Post? post;
2024-05-25 05:19:16 +00:00
2024-08-01 20:42:38 +00:00
const PostDetailScreen({
super.key,
required this.id,
this.post,
});
2024-05-25 05:19:16 +00:00
@override
State<PostDetailScreen> createState() => _PostDetailScreenState();
}
class _PostDetailScreenState extends State<PostDetailScreen> {
Post? item;
2024-10-11 16:41:03 +00:00
Future<Post?> _getDetail() async {
2024-08-01 20:42:38 +00:00
if (widget.post != null) {
2024-10-11 16:41:03 +00:00
setState(() {
item = widget.post;
});
2024-08-01 20:42:38 +00:00
}
final PostProvider provider = Get.find();
2024-05-25 05:19:16 +00:00
try {
final resp = await provider.getPost(widget.id);
2024-05-25 05:19:16 +00:00
item = Post.fromJson(resp.body);
} catch (e) {
context.showErrorDialog(e).then((_) => Navigator.pop(context));
}
2024-09-16 17:23:49 +00:00
Get.find<LastReadProvider>().feedLastReadAt = item?.id;
2024-05-25 05:19:16 +00:00
return item;
}
@override
Widget build(BuildContext context) {
2024-10-06 15:23:11 +00:00
return FutureBuilder(
2024-10-11 16:41:03 +00:00
future: _getDetail(),
2024-10-06 15:23:11 +00:00
builder: (context, snapshot) {
if (!snapshot.hasData || snapshot.data == null) {
return const Center(
child: CircularProgressIndicator(),
);
}
2024-05-25 05:19:16 +00:00
2024-10-06 15:23:11 +00:00
return CustomScrollView(
slivers: [
SliverToBoxAdapter(
child: PostItem(
item: item!,
isClickable: false,
isOverrideEmbedClickable: true,
isFullDate: true,
isFullContent: true,
isShowReply: false,
isContentSelectable: true,
2024-10-12 17:31:59 +00:00
padding: AppTheme.isLargeScreen(context)
? EdgeInsets.symmetric(
horizontal: 4,
vertical: 8,
)
: EdgeInsets.zero,
2024-05-25 09:21:27 +00:00
),
2024-10-06 15:23:11 +00:00
),
SliverToBoxAdapter(
2024-10-12 17:31:59 +00:00
child: const Divider(thickness: 0.3, height: 1).paddingOnly(
top: 8,
),
2024-10-06 15:23:11 +00:00
),
SliverToBoxAdapter(
child: Align(
alignment: Alignment.centerLeft,
child: Text(
'postReplies'.tr,
style: Theme.of(context).textTheme.headlineSmall,
).paddingOnly(left: 24, right: 24, top: 16),
2024-05-29 12:13:53 +00:00
),
2024-10-06 15:23:11 +00:00
),
2024-10-12 17:31:59 +00:00
PostReplyList(
item: item!,
padding: AppTheme.isLargeScreen(context)
? EdgeInsets.symmetric(
horizontal: 4,
vertical: 8,
)
: EdgeInsets.zero,
),
2024-10-06 15:23:11 +00:00
SliverToBoxAdapter(
child: SizedBox(height: MediaQuery.of(context).padding.bottom),
),
],
);
},
2024-05-25 05:19:16 +00:00
);
}
}