2022-11-29 15:33:16 +00:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:logging/logging.dart';
|
|
|
|
import 'package:provider/provider.dart';
|
2023-04-07 12:55:37 +00:00
|
|
|
import 'package:scrollable_positioned_list/scrollable_positioned_list.dart';
|
2022-11-29 15:33:16 +00:00
|
|
|
|
|
|
|
import '../../models/TimelineIdentifiers.dart';
|
|
|
|
import '../../services/timeline_manager.dart';
|
2023-03-14 03:47:40 +00:00
|
|
|
import '../../utils/active_profile_selector.dart';
|
2023-01-07 16:30:16 +00:00
|
|
|
import 'post_control.dart';
|
2022-11-29 15:33:16 +00:00
|
|
|
|
|
|
|
class TimelinePanel extends StatelessWidget {
|
|
|
|
static final _logger = Logger('$TimelinePanel');
|
|
|
|
final TimelineIdentifiers timeline;
|
2023-04-07 12:55:37 +00:00
|
|
|
final controller = ItemScrollController();
|
2022-11-29 15:33:16 +00:00
|
|
|
|
2023-04-07 12:55:37 +00:00
|
|
|
TimelinePanel({super.key, required this.timeline});
|
2022-11-29 15:33:16 +00:00
|
|
|
|
2023-03-20 01:38:05 +00:00
|
|
|
Future<void> update(TimelineManager manager) async {
|
|
|
|
await manager.updateTimeline(
|
|
|
|
timeline,
|
|
|
|
TimelineRefreshType.refresh,
|
|
|
|
);
|
|
|
|
|
|
|
|
await manager.updateTimeline(
|
|
|
|
timeline,
|
|
|
|
TimelineRefreshType.loadNewer,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2023-04-07 12:55:37 +00:00
|
|
|
void scrollToTop() {
|
|
|
|
controller.jumpTo(index: 0);
|
|
|
|
}
|
|
|
|
|
2022-11-29 15:33:16 +00:00
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
2023-03-22 04:35:38 +00:00
|
|
|
_logger.finer('Build');
|
2023-03-14 03:47:40 +00:00
|
|
|
final manager = context
|
|
|
|
.watch<ActiveProfileSelector<TimelineManager>>()
|
|
|
|
.activeEntry
|
|
|
|
.value;
|
2023-03-20 00:54:28 +00:00
|
|
|
final items = manager.getTimeline(timeline);
|
2023-03-15 01:58:49 +00:00
|
|
|
return RefreshIndicator(
|
|
|
|
onRefresh: () async {
|
2023-03-20 01:38:05 +00:00
|
|
|
update(manager);
|
2023-03-15 01:58:49 +00:00
|
|
|
return;
|
2023-01-29 15:14:34 +00:00
|
|
|
},
|
2023-03-20 00:54:28 +00:00
|
|
|
child: items.isEmpty
|
|
|
|
? Center(
|
|
|
|
child: Column(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
children: [
|
|
|
|
ElevatedButton(
|
|
|
|
onPressed: () => manager.updateTimeline(
|
|
|
|
timeline, TimelineRefreshType.refresh),
|
|
|
|
child: const Text('Load Posts'))
|
|
|
|
],
|
|
|
|
),
|
|
|
|
)
|
2023-04-07 12:55:37 +00:00
|
|
|
: ScrollablePositionedList.builder(
|
|
|
|
itemScrollController: controller,
|
2023-03-20 00:54:28 +00:00
|
|
|
physics: const AlwaysScrollableScrollPhysics(),
|
|
|
|
itemBuilder: (context, index) {
|
|
|
|
if (index == 0) {
|
|
|
|
return TextButton(
|
|
|
|
onPressed: () async => await manager.updateTimeline(
|
|
|
|
timeline, TimelineRefreshType.loadNewer),
|
|
|
|
child: const Text('Load newer posts'));
|
|
|
|
}
|
2023-03-15 01:58:49 +00:00
|
|
|
|
2023-03-20 00:54:28 +00:00
|
|
|
if (index == items.length + 1) {
|
|
|
|
return TextButton(
|
|
|
|
onPressed: () async => await manager.updateTimeline(
|
|
|
|
timeline, TimelineRefreshType.loadOlder),
|
|
|
|
child: const Text('Load older posts'));
|
|
|
|
}
|
|
|
|
final itemIndex = index - 1;
|
|
|
|
final item = items[itemIndex];
|
|
|
|
TimelinePanel._logger.finest(
|
|
|
|
'Building item: $itemIndex: ${item.entry.toShortString()}');
|
|
|
|
return PostControl(
|
|
|
|
originalItem: item,
|
|
|
|
scrollToId: item.id,
|
|
|
|
openRemote: false,
|
|
|
|
showStatusOpenButton: true,
|
|
|
|
isRoot: false,
|
|
|
|
);
|
|
|
|
},
|
|
|
|
itemCount: items.length + 2,
|
|
|
|
),
|
2022-11-29 15:33:16 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|