Update how timeline panel renders when loading content and having none.

main
Hank Grabowski 2023-11-30 11:16:17 -05:00
rodzic df4a875ebd
commit 0adbeb8f82
1 zmienionych plików z 70 dodań i 46 usunięć

Wyświetl plik

@ -1,10 +1,12 @@
import 'package:flutter/material.dart';
import 'package:logging/logging.dart';
import 'package:provider/provider.dart';
import 'package:relatica/controls/padding.dart';
import 'package:relatica/globals.dart';
import 'package:scrollable_positioned_list/scrollable_positioned_list.dart';
import '../../models/TimelineIdentifiers.dart';
import '../../services/network_status_service.dart';
import '../../services/timeline_manager.dart';
import '../../utils/active_profile_selector.dart';
import 'post_control.dart';
@ -34,29 +36,49 @@ class TimelinePanel extends StatelessWidget {
@override
Widget build(BuildContext context) {
_logger.finer('Build');
final nss = getIt<NetworkStatusService>();
final manager = context
.watch<ActiveProfileSelector<TimelineManager>>()
.activeEntry
.value;
final items = manager.getTimeline(timeline);
return RefreshIndicator(
onRefresh: () async {
update(context, manager);
return;
},
child: items.isEmpty
? Center(
return ValueListenableBuilder(
valueListenable: nss.timelineLoadingStatus,
builder: (BuildContext context, bool loading, Widget? _) {
if (items.isEmpty && loading) {
return const Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Text('Loading Posts'),
],
),
);
}
if (items.isEmpty) {
return Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
const Text('No posts loaded'),
const VerticalPadding(),
ElevatedButton(
onPressed: () => manager.updateTimeline(
timeline, TimelineRefreshType.refresh),
child: const Text('Load Posts'))
],
),
)
: ScrollablePositionedList.builder(
);
}
return RefreshIndicator(
onRefresh: () async {
update(context, manager);
return;
},
child: ScrollablePositionedList.builder(
itemScrollController: controller,
physics: const AlwaysScrollableScrollPhysics(),
itemBuilder: (context, index) {
@ -88,5 +110,7 @@ class TimelinePanel extends StatelessWidget {
itemCount: items.length + 2,
),
);
},
);
}
}