OpenContacts/lib/widgets/friends/friend_list_tile.dart

145 lines
4.9 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';
2024-07-15 00:23:04 -04:00
import 'package:OpenContacts/auxiliary.dart';
import 'package:OpenContacts/clients/messaging_client.dart';
import 'package:OpenContacts/models/message.dart';
import 'package:OpenContacts/models/users/friend.dart';
import 'package:OpenContacts/models/users/online_status.dart';
import 'package:OpenContacts/widgets/formatted_text.dart';
import 'package:OpenContacts/widgets/friends/friend_online_status_indicator.dart';
import 'package:OpenContacts/widgets/generic_avatar.dart';
import 'package:OpenContacts/widgets/messages/messages_list.dart';
2024-07-25 17:02:29 -04:00
import 'package:OpenContacts/widgets/my_profile_dialog.dart';
2023-04-30 09:43:59 -04:00
class FriendListTile extends StatelessWidget {
2024-07-25 17:02:29 -04:00
const FriendListTile({required this.friend, required this.unreads, this.onTap, super.key, this.onLongPress});
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;
2024-07-25 17:02:29 -04:00
final Function? onLongPress;
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(friend: friend),
const SizedBox(
width: 4,
),
if (!(friend.isOffline || friend.isHeadless)) ...[
Text(toBeginningOfSentenceCase(friend.userStatus.onlineStatus.name) ?? "Unknown"),
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,
),
),
] else if (friend.isOffline)
Text(
"Offline",
overflow: TextOverflow.ellipsis,
maxLines: 1,
style: theme.textTheme.bodyMedium?.copyWith(
color: OnlineStatus.offline.color(context),
),
)
else
Text(
"Headless Host",
overflow: TextOverflow.ellipsis,
maxLines: 1,
style: theme.textTheme.bodyMedium?.copyWith(
color: const Color.fromARGB(255, 41, 77, 92),
),
)
],
),
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
},
2024-07-25 17:02:29 -04:00
onLongPress: () async {
await showDialog(
context: context,
builder: (context) {
return const MyProfileDialog();
},
);
}
2023-04-30 09:43:59 -04:00
);
}
}