Solian/lib/screens/feed/draft_box.dart

115 lines
3.6 KiB
Dart
Raw Normal View History

2024-07-09 21:23:38 +08:00
import 'package:flutter/material.dart';
import 'package:get/get.dart';
2024-07-09 22:39:44 +08:00
import 'package:infinite_scroll_pagination/infinite_scroll_pagination.dart';
import 'package:solian/models/pagination.dart';
import 'package:solian/models/post.dart';
import 'package:solian/providers/content/posts.dart';
2024-07-09 21:23:38 +08:00
import 'package:solian/theme.dart';
import 'package:solian/widgets/app_bar_leading.dart';
2024-07-09 21:23:38 +08:00
import 'package:solian/widgets/app_bar_title.dart';
2024-07-09 22:39:44 +08:00
import 'package:solian/widgets/posts/post_action.dart';
import 'package:solian/widgets/posts/post_owned_list.dart';
2024-10-06 17:37:07 +08:00
import 'package:solian/widgets/root_container.dart';
2024-07-09 21:23:38 +08:00
2024-07-09 22:39:44 +08:00
class DraftBoxScreen extends StatefulWidget {
2024-07-09 21:23:38 +08:00
const DraftBoxScreen({super.key});
2024-07-09 22:39:44 +08:00
@override
State<DraftBoxScreen> createState() => _DraftBoxScreenState();
}
class _DraftBoxScreenState extends State<DraftBoxScreen> {
final PagingController<int, Post> _pagingController =
2024-07-09 22:39:44 +08:00
PagingController(firstPageKey: 0);
2024-08-04 20:43:25 +08:00
_getPosts(int pageKey) async {
final PostProvider provider = Get.find();
2024-07-09 22:39:44 +08:00
Response resp;
try {
resp = await provider.listDraft(pageKey);
} catch (e) {
_pagingController.error = e;
return;
}
final PaginationResult result = PaginationResult.fromJson(resp.body);
if (result.count == 0) {
_pagingController.appendLastPage([]);
return;
}
final parsed = result.data?.map((e) => Post.fromJson(e)).toList();
2024-07-09 22:39:44 +08:00
if (parsed != null && parsed.length >= 10) {
_pagingController.appendPage(parsed, pageKey + parsed.length);
} else if (parsed != null) {
_pagingController.appendLastPage(parsed);
}
}
@override
void initState() {
super.initState();
2024-08-04 20:43:25 +08:00
_pagingController.addPageRequestListener(_getPosts);
2024-07-09 22:39:44 +08:00
}
2024-07-09 21:23:38 +08:00
@override
Widget build(BuildContext context) {
2024-10-06 17:37:07 +08:00
return RootContainer(
2024-07-09 21:23:38 +08:00
child: Scaffold(
appBar: AppBar(
2024-07-12 22:37:58 +08:00
leading: AppBarLeadingButton.adaptive(context),
2024-07-09 21:23:38 +08:00
title: AppBarTitle('draftBox'.tr),
centerTitle: false,
toolbarHeight: AppTheme.toolbarHeight(context),
2024-07-09 21:23:38 +08:00
actions: [
SizedBox(
width: AppTheme.isLargeScreen(context) ? 8 : 16,
2024-07-09 21:23:38 +08:00
),
],
),
2024-07-09 22:39:44 +08:00
body: RefreshIndicator(
onRefresh: () => Future.sync(() => _pagingController.refresh()),
child: PagedListView<int, Post>(
2024-07-09 22:39:44 +08:00
pagingController: _pagingController,
builderDelegate: PagedChildBuilderDelegate(
itemBuilder: (context, item, index) {
return PostOwnedListEntry(
item: item,
2024-08-04 20:43:25 +08:00
isFullContent: true,
2024-08-04 17:15:56 +08:00
backgroundColor:
Theme.of(context).colorScheme.surfaceContainerLow,
onTap: () async {
showModalBottomSheet(
useRootNavigator: true,
context: context,
builder: (context) => PostAction(
item: item,
noReact: true,
),
).then((value) {
2024-08-04 18:13:59 +08:00
if (value is Future) {
value.then((_) {
_pagingController.refresh();
});
} else if (value != null) {
_pagingController.refresh();
}
});
},
).paddingOnly(left: 12, right: 12, bottom: 4);
2024-07-09 22:39:44 +08:00
},
),
),
),
2024-07-09 21:23:38 +08:00
),
);
}
2024-07-09 22:39:44 +08:00
@override
void dispose() {
_pagingController.dispose();
super.dispose();
}
2024-07-09 21:23:38 +08:00
}