2022-11-29 15:33:16 +00:00
|
|
|
import 'package:flutter/material.dart';
|
2023-01-30 15:45:02 +00:00
|
|
|
import 'package:provider/provider.dart';
|
2022-11-29 15:33:16 +00:00
|
|
|
|
2023-01-30 15:45:02 +00:00
|
|
|
import '../controls/standard_appbar.dart';
|
2022-11-29 15:33:16 +00:00
|
|
|
import '../controls/timeline/timeline_panel.dart';
|
2023-01-30 15:45:02 +00:00
|
|
|
import '../globals.dart';
|
2022-11-29 15:33:16 +00:00
|
|
|
import '../models/TimelineIdentifiers.dart';
|
|
|
|
import '../routes.dart';
|
2023-01-30 15:45:02 +00:00
|
|
|
import '../services/network_status_service.dart';
|
|
|
|
import '../services/timeline_manager.dart';
|
2022-11-29 15:33:16 +00:00
|
|
|
|
|
|
|
class UserPostsScreen extends StatelessWidget {
|
|
|
|
final String userId;
|
|
|
|
|
|
|
|
const UserPostsScreen({super.key, required this.userId});
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
2023-01-30 15:45:02 +00:00
|
|
|
final nss = getIt<NetworkStatusService>();
|
|
|
|
final manager = context.watch<TimelineManager>();
|
|
|
|
final timeline = TimelineIdentifiers.profile(userId);
|
2022-11-29 15:33:16 +00:00
|
|
|
return Scaffold(
|
2023-01-30 15:45:02 +00:00
|
|
|
appBar: StandardAppBar.build(
|
|
|
|
context,
|
|
|
|
'User Posts',
|
2022-11-29 15:33:16 +00:00
|
|
|
actions: [
|
2023-01-30 15:45:02 +00:00
|
|
|
ValueListenableBuilder(
|
|
|
|
valueListenable: nss.timelineLoadingStatus,
|
|
|
|
builder: (context2, executing, _) {
|
|
|
|
if (executing) {
|
|
|
|
final theme = Theme.of(context);
|
|
|
|
final size = theme.appBarTheme.actionsIconTheme?.size ??
|
|
|
|
theme.iconTheme.size ??
|
|
|
|
24;
|
|
|
|
return Center(
|
|
|
|
child: SizedBox(
|
|
|
|
width: size,
|
|
|
|
height: size,
|
|
|
|
child: CircularProgressIndicator(
|
|
|
|
color: Theme.of(context).canvasColor,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
return IconButton(
|
|
|
|
onPressed: () async => await manager.updateTimeline(
|
|
|
|
timeline, TimelineRefreshType.refresh),
|
|
|
|
icon: Icon(
|
|
|
|
Icons.refresh,
|
|
|
|
));
|
|
|
|
}),
|
2022-11-29 15:33:16 +00:00
|
|
|
IconButton(
|
|
|
|
onPressed: () {
|
|
|
|
Navigator.of(context).popUntil((route) {
|
2022-12-08 19:23:11 +00:00
|
|
|
return route.settings.name == ScreenPaths.timelines;
|
2022-11-29 15:33:16 +00:00
|
|
|
});
|
|
|
|
},
|
|
|
|
icon: const Icon(Icons.home),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
body: Center(
|
|
|
|
child: TimelinePanel(
|
2023-01-30 15:45:02 +00:00
|
|
|
timeline: timeline,
|
2022-11-29 15:33:16 +00:00
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|