1
0
mirror of https://gitlab.com/comunic/comunicmobile synced 2025-01-21 17:31:00 +00:00
comunicmobile/lib/ui/tiles/conversation_tile.dart

127 lines
3.6 KiB
Dart
Raw Normal View History

import 'package:comunic/helpers/conversations_helper.dart';
import 'package:comunic/lists/users_list.dart';
2019-04-23 12:35:41 +00:00
import 'package:comunic/models/conversation.dart';
2019-04-23 14:38:41 +00:00
import 'package:comunic/utils/date_utils.dart';
2019-04-23 12:35:41 +00:00
import 'package:comunic/utils/intl_utils.dart';
2019-11-01 13:17:46 +00:00
import 'package:comunic/utils/ui_utils.dart';
2019-04-23 12:35:41 +00:00
import 'package:flutter/material.dart';
/// Single conversation tile
///
/// @author Pierre HUBERT
2019-04-24 15:46:25 +00:00
typedef OpenConversationCallback = void Function(Conversation);
typedef RequestDeleteConversationCallback = void Function(Conversation);
typedef RequestUpdateConversationCallback = void Function(Conversation);
enum _PopupMenuChoices { UPDATE, DELETE }
2019-04-24 15:46:25 +00:00
2019-04-23 12:35:41 +00:00
class ConversationTile extends StatelessWidget {
final Conversation conversation;
final UsersList usersList;
2019-04-24 15:46:25 +00:00
final OpenConversationCallback onOpen;
final RequestUpdateConversationCallback onRequestUpdate;
final RequestDeleteConversationCallback onRequestDelete;
2019-04-23 12:35:41 +00:00
const ConversationTile({
Key key,
@required this.conversation,
@required this.usersList,
@required this.onOpen,
@required this.onRequestUpdate,
@required this.onRequestDelete,
}) : assert(conversation != null),
assert(usersList != null),
2019-04-24 15:46:25 +00:00
assert(onOpen != null),
assert(onRequestUpdate != null),
assert(onRequestDelete != null),
super(key: key);
2019-04-23 12:35:41 +00:00
_buildSubInformation(IconData icon, String content) {
return Row(
children: <Widget>[
Icon(
icon,
size: 15.0,
color: Colors.grey,
),
Text(" " + content),
],
);
}
@override
Widget build(BuildContext context) {
return ListTile(
2019-04-24 15:46:25 +00:00
onTap: () => onOpen(conversation),
2019-04-23 16:23:34 +00:00
// Conversation name
title: Text(
ConversationsHelper.getConversationName(
conversation,
usersList,
),
style: TextStyle(
fontWeight: conversation.sawLastMessage ? null : FontWeight.bold,
),
),
// Leading icon
2019-04-23 12:35:41 +00:00
leading: Icon(
conversation.sawLastMessage ? Icons.check_circle : Icons.lens,
2019-11-01 13:17:46 +00:00
color: conversation.sawLastMessage
? (darkTheme() ? darkAccentColor : null)
: Colors.blue,
2019-04-23 12:35:41 +00:00
),
2019-04-23 16:23:34 +00:00
// Conversation information
2019-04-23 12:35:41 +00:00
isThreeLine: true,
subtitle: Column(
crossAxisAlignment: CrossAxisAlignment.stretch,
children: <Widget>[
2019-04-23 14:38:41 +00:00
_buildSubInformation(
Icons.access_time, diffTimeFromNowToStr(conversation.lastActive)),
2019-04-23 12:35:41 +00:00
_buildSubInformation(
Icons.group,
conversation.members.length == 1
? tr("1 member")
: tr(
"%num% members",
args: {
"num": conversation.members.length.toString(),
},
),
),
],
),
// Trailing information
trailing: PopupMenuButton<_PopupMenuChoices>(
itemBuilder: (b) => <PopupMenuEntry<_PopupMenuChoices>>[
2019-11-01 13:17:46 +00:00
PopupMenuItem(
child: Text(tr("Update")),
value: _PopupMenuChoices.UPDATE,
),
PopupMenuItem(
child: Text(tr("Delete")),
value: _PopupMenuChoices.DELETE,
)
],
onSelected: _conversationMenuCallback,
),
2019-04-23 12:35:41 +00:00
);
}
/// Method called each time an option of the menu is selected
void _conversationMenuCallback(_PopupMenuChoices c) {
switch (c) {
case _PopupMenuChoices.UPDATE:
onRequestUpdate(conversation);
break;
case _PopupMenuChoices.DELETE:
onRequestDelete(conversation);
break;
}
}
2019-04-23 12:35:41 +00:00
}