kopia lustrzana https://gitlab.com/mysocialportal/relatica
Update how timeline panel renders when loading content and having none.
rodzic
df4a875ebd
commit
0adbeb8f82
|
@ -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,
|
||||
),
|
||||
);
|
||||
},
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
Ładowanie…
Reference in New Issue