mirror of
https://gitlab.com/mysocialportal/relatica
synced 2024-10-19 05:53:31 +00:00
126 lines
4.1 KiB
Dart
126 lines
4.1 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter_widget_from_html_core/flutter_widget_from_html_core.dart';
|
|
import 'package:go_router/go_router.dart';
|
|
import 'package:provider/provider.dart';
|
|
|
|
import '../globals.dart';
|
|
import '../models/user_notification.dart';
|
|
import '../routes.dart';
|
|
import '../services/connections_manager.dart';
|
|
import '../services/notifications_manager.dart';
|
|
import '../services/timeline_manager.dart';
|
|
import '../utils/dateutils.dart';
|
|
import '../utils/snackbar_builder.dart';
|
|
import 'image_control.dart';
|
|
|
|
class NotificationControl extends StatelessWidget {
|
|
final UserNotification notification;
|
|
|
|
const NotificationControl({
|
|
super.key,
|
|
required this.notification,
|
|
});
|
|
|
|
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}/${notification.iid}');
|
|
return;
|
|
}
|
|
final loadedPost = await manager.refreshStatusChain(notification.iid);
|
|
if (loadedPost.isSuccess) {
|
|
context.push('/post/view/${loadedPost.value.id}/${notification.iid}');
|
|
return;
|
|
}
|
|
buildSnackbar(
|
|
context, 'Error getting data for notification: ${loadedPost.error}');
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
const iconSize = 50.0;
|
|
final manager = context.watch<NotificationsManager>();
|
|
final fromIcon =
|
|
getIt<ConnectionsManager>().getById(notification.fromId).fold(
|
|
onSuccess: (connection) => ImageControl(
|
|
imageUrl: connection.avatarUrl.toString(),
|
|
iconOverride: const Icon(Icons.person),
|
|
width: iconSize,
|
|
height: iconSize,
|
|
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),
|
|
),
|
|
),
|
|
);
|
|
|
|
Function()? onTap;
|
|
switch (notification.type) {
|
|
case NotificationType.follow:
|
|
onTap = () {
|
|
context.pushNamed(ScreenPaths.userProfile,
|
|
params: {'id': notification.fromId});
|
|
};
|
|
break;
|
|
case NotificationType.follow_request:
|
|
onTap = () {
|
|
context.push('/connect/${notification.fromId}');
|
|
};
|
|
break;
|
|
case NotificationType.unknown:
|
|
buildSnackbar(context, 'Unknown message type, nothing to do');
|
|
break;
|
|
case NotificationType.favourite:
|
|
case NotificationType.mention:
|
|
case NotificationType.reshare:
|
|
case NotificationType.reblog:
|
|
case NotificationType.status:
|
|
onTap = () {
|
|
_goToStatus(context);
|
|
};
|
|
break;
|
|
}
|
|
|
|
return ListTile(
|
|
tileColor: notification.dismissed ? null : Colors.black12,
|
|
leading: fromIcon,
|
|
title: GestureDetector(
|
|
onTap: onTap == null ? null : () async => onTap!(),
|
|
child: HtmlWidget(
|
|
notification.content,
|
|
onTapUrl: onTap == null ? null : (_) async => onTap!(),
|
|
),
|
|
),
|
|
subtitle: GestureDetector(
|
|
onTap: onTap == null ? null : () async => onTap!(),
|
|
child: Text(
|
|
ElapsedDateUtils.epochSecondsToString(notification.timestamp),
|
|
),
|
|
),
|
|
trailing: notification.dismissed
|
|
? null
|
|
: IconButton(
|
|
onPressed: () async {
|
|
final result = await manager.markSeen(notification);
|
|
if (result.isFailure) {
|
|
buildSnackbar(
|
|
context, 'Error marking notification: ${result.error}');
|
|
}
|
|
},
|
|
icon: Icon(Icons.close_rounded)),
|
|
);
|
|
}
|
|
}
|