2022-11-19 05:00:17 +00:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_widget_from_html_core/flutter_widget_from_html_core.dart';
|
2022-11-30 00:56:14 +00:00
|
|
|
import 'package:go_router/go_router.dart';
|
2022-11-22 04:46:34 +00:00
|
|
|
import 'package:provider/provider.dart';
|
2022-11-19 05:00:17 +00:00
|
|
|
|
2022-11-30 00:56:14 +00:00
|
|
|
import '../globals.dart';
|
2022-11-19 05:00:17 +00:00
|
|
|
import '../models/user_notification.dart';
|
2022-11-30 00:56:14 +00:00
|
|
|
import '../routes.dart';
|
2022-12-27 16:08:16 +00:00
|
|
|
import '../services/connections_manager.dart';
|
2022-11-22 04:46:34 +00:00
|
|
|
import '../services/notifications_manager.dart';
|
2022-11-30 00:56:14 +00:00
|
|
|
import '../services/timeline_manager.dart';
|
2022-11-19 05:00:17 +00:00
|
|
|
import '../utils/dateutils.dart';
|
2022-11-22 04:46:34 +00:00
|
|
|
import '../utils/snackbar_builder.dart';
|
2022-12-30 15:55:05 +00:00
|
|
|
import 'image_control.dart';
|
2022-11-19 05:00:17 +00:00
|
|
|
|
|
|
|
class NotificationControl extends StatelessWidget {
|
|
|
|
final UserNotification notification;
|
|
|
|
|
|
|
|
const NotificationControl({
|
|
|
|
super.key,
|
|
|
|
required this.notification,
|
|
|
|
});
|
|
|
|
|
2022-11-30 19:32:40 +00:00
|
|
|
Future<void> _goToStatus(BuildContext context) async {
|
|
|
|
final manager = getIt<TimelineManager>();
|
|
|
|
final existingPostData = manager.getPostTreeEntryBy(notification.iid);
|
|
|
|
if (existingPostData.isSuccess) {
|
|
|
|
context.push('/post/view/${existingPostData.value.id}');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
final loadedPost = await manager.refreshStatusChain(notification.iid);
|
|
|
|
if (loadedPost.isSuccess) {
|
|
|
|
context.push('/post/view/${loadedPost.value.id}');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
buildSnackbar(
|
|
|
|
context, 'Error getting data for notification: ${loadedPost.error}');
|
|
|
|
}
|
|
|
|
|
2022-11-19 05:00:17 +00:00
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
2022-12-27 16:08:16 +00:00
|
|
|
const iconSize = 50.0;
|
2022-11-22 04:46:34 +00:00
|
|
|
final manager = context.watch<NotificationsManager>();
|
2022-12-27 16:08:16 +00:00
|
|
|
final fromIcon =
|
|
|
|
getIt<ConnectionsManager>().getById(notification.fromId).fold(
|
2022-12-30 15:55:05 +00:00
|
|
|
onSuccess: (connection) => ImageControl(
|
|
|
|
imageUrl: connection.avatarUrl.toString(),
|
|
|
|
iconOverride: const Icon(Icons.person),
|
2022-12-27 16:08:16 +00:00
|
|
|
width: iconSize,
|
|
|
|
height: iconSize,
|
2022-12-30 15:55:05 +00:00
|
|
|
onTap: () async {
|
|
|
|
context.pushNamed(ScreenPaths.userProfile,
|
|
|
|
params: {'id': notification.fromId});
|
|
|
|
},
|
|
|
|
),
|
|
|
|
onError: (error) => GestureDetector(
|
|
|
|
onTap: () async {
|
|
|
|
context.pushNamed(ScreenPaths.userProfile,
|
|
|
|
params: {'id': notification.fromId});
|
|
|
|
},
|
|
|
|
child: const SizedBox(
|
|
|
|
width: iconSize,
|
|
|
|
height: iconSize,
|
|
|
|
child: Icon(Icons.person),
|
|
|
|
),
|
2022-12-27 16:08:16 +00:00
|
|
|
),
|
|
|
|
);
|
2022-12-29 14:33:22 +00:00
|
|
|
|
2022-11-19 05:00:17 +00:00
|
|
|
return ListTile(
|
2022-11-30 00:56:14 +00:00
|
|
|
tileColor: notification.dismissed ? null : Colors.black12,
|
2022-12-30 15:55:05 +00:00
|
|
|
leading: fromIcon,
|
2022-11-30 00:56:14 +00:00
|
|
|
title: GestureDetector(
|
|
|
|
onTap: () async {
|
2022-11-30 19:32:40 +00:00
|
|
|
switch (notification.type) {
|
|
|
|
case NotificationType.follow:
|
2022-12-19 18:59:33 +00:00
|
|
|
context.push('/connect/${notification.fromId}');
|
2022-11-30 19:32:40 +00:00
|
|
|
break;
|
|
|
|
case NotificationType.follow_request:
|
2022-12-19 18:59:33 +00:00
|
|
|
context.push('/connect/${notification.fromId}');
|
2022-11-30 19:32:40 +00:00
|
|
|
break;
|
|
|
|
case NotificationType.unknown:
|
|
|
|
buildSnackbar(context, 'Unknown message type, nothing to do');
|
|
|
|
break;
|
2022-12-10 16:44:13 +00:00
|
|
|
case NotificationType.favourite:
|
2022-11-30 19:32:40 +00:00
|
|
|
case NotificationType.mention:
|
|
|
|
case NotificationType.reshare:
|
2022-12-13 13:29:16 +00:00
|
|
|
case NotificationType.reblog:
|
2022-11-30 19:32:40 +00:00
|
|
|
case NotificationType.status:
|
|
|
|
_goToStatus(context);
|
|
|
|
break;
|
2022-11-30 00:56:14 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
child: HtmlWidget(notification.content),
|
|
|
|
),
|
2022-11-19 05:00:17 +00:00
|
|
|
subtitle:
|
|
|
|
Text(ElapsedDateUtils.epochSecondsToString(notification.timestamp)),
|
2022-11-30 19:32:40 +00:00
|
|
|
trailing: notification.dismissed ||
|
|
|
|
(notification.type == NotificationType.follow ||
|
|
|
|
notification.type == NotificationType.follow_request)
|
2022-11-19 05:00:17 +00:00
|
|
|
? null
|
2022-11-22 04:46:34 +00:00
|
|
|
: IconButton(
|
|
|
|
onPressed: () async {
|
|
|
|
final result = await manager.markSeen(notification);
|
|
|
|
if (result.isFailure) {
|
|
|
|
buildSnackbar(
|
|
|
|
context, 'Error marking notification: ${result.error}');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
icon: Icon(Icons.close_rounded)),
|
2022-11-19 05:00:17 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|