OpenContacts/lib/widgets/friends/friend_list_tile.dart

118 lines
4.1 KiB
Dart
Raw Normal View History

2023-10-10 03:53:34 -04:00
import 'package:flutter/material.dart';
import 'package:intl/intl.dart';
import 'package:provider/provider.dart';
import 'package:recon/auxiliary.dart';
import 'package:recon/clients/messaging_client.dart';
import 'package:recon/models/message.dart';
import 'package:recon/models/users/friend.dart';
import 'package:recon/models/users/online_status.dart';
import 'package:recon/widgets/formatted_text.dart';
import 'package:recon/widgets/friends/friend_online_status_indicator.dart';
import 'package:recon/widgets/generic_avatar.dart';
import 'package:recon/widgets/messages/messages_list.dart';
2023-04-30 09:43:59 -04:00
class FriendListTile extends StatelessWidget {
2023-11-11 07:00:01 -04:00
const FriendListTile({required this.friend, required this.unreads, this.onTap, super.key});
2023-04-30 09:43:59 -04:00
final Friend friend;
final int unreads;
2023-05-03 14:03:46 -04:00
final Function? onTap;
2023-04-30 09:43:59 -04:00
@override
Widget build(BuildContext context) {
2023-09-29 03:51:46 -04:00
final imageUri = Aux.resdbToHttp(friend.userProfile.iconUrl);
2023-05-03 14:03:46 -04:00
final theme = Theme.of(context);
final mClient = Provider.of<MessagingClient>(context, listen: false);
2023-10-03 12:20:02 -04:00
final currentSession = friend.userStatus.currentSessionIndex == -1
? null
2023-11-11 07:00:01 -04:00
: friend.userStatus.decodedSessions.elementAtOrNull(friend.userStatus.currentSessionIndex);
2023-04-30 09:43:59 -04:00
return ListTile(
leading: GenericAvatar(
imageUri: imageUri,
),
trailing: unreads != 0
? Text(
"+$unreads",
2023-11-11 07:00:01 -04:00
style: theme.textTheme.bodyMedium?.copyWith(color: theme.colorScheme.primary),
)
2023-05-03 14:03:46 -04:00
: null,
title: Row(
children: [
Text(friend.username),
if (friend.isHeadless)
Padding(
padding: const EdgeInsets.only(left: 8),
child: Icon(
Icons.dns,
size: 12,
color: theme.colorScheme.onSecondaryContainer.withAlpha(150),
),
),
],
),
subtitle: Row(
mainAxisSize: MainAxisSize.min,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
FriendOnlineStatusIndicator(userStatus: friend.userStatus),
const SizedBox(
width: 4,
),
2023-11-11 07:00:01 -04:00
Text(toBeginningOfSentenceCase(friend.userStatus.onlineStatus.name) ?? "Unknown"),
if (!(friend.userStatus.onlineStatus == OnlineStatus.offline ||
friend.userStatus.onlineStatus == OnlineStatus.invisible))
if (currentSession != null) ...[
const Text(" in "),
if (currentSession.name.isNotEmpty)
Expanded(
child: FormattedText(
currentSession.formattedName,
overflow: TextOverflow.ellipsis,
maxLines: 1,
),
)
else
Expanded(
child: Text(
"${currentSession.accessLevel.toReadableString()} World",
overflow: TextOverflow.ellipsis,
maxLines: 1,
),
)
] else if (friend.userStatus.appVersion.isNotEmpty)
2023-10-10 03:53:34 -04:00
Expanded(
child: Text(
" on version ${friend.userStatus.appVersion}",
2023-10-10 03:53:34 -04:00
overflow: TextOverflow.ellipsis,
maxLines: 1,
),
),
],
),
2023-05-03 14:03:46 -04:00
onTap: () async {
onTap?.call();
mClient.loadUserMessageCache(friend.id);
final unreads = mClient.getUnreadsForFriend(friend);
if (unreads.isNotEmpty) {
final readBatch = MarkReadBatch(
senderId: friend.id,
ids: unreads.map((e) => e.id).toList(),
readTime: DateTime.now(),
);
mClient.markMessagesRead(readBatch);
}
mClient.selectedFriend = friend;
await Navigator.of(context).push(
MaterialPageRoute(
builder: (context) => ChangeNotifierProvider<MessagingClient>.value(
value: mClient,
child: const MessagesList(),
),
),
);
mClient.selectedFriend = null;
2023-04-30 09:43:59 -04:00
},
);
}
}