2019-04-23 15:29:58 +00:00
|
|
|
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';
|
2021-03-13 11:02:24 +00:00
|
|
|
import 'package:comunic/ui/routes/main_route/main_route.dart';
|
2021-03-11 17:00:06 +00:00
|
|
|
import 'package:comunic/ui/widgets/conversation_image_widget.dart';
|
2020-05-09 05:14:38 +00:00
|
|
|
import 'package:comunic/ui/widgets/custom_list_tile.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';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
|
|
|
/// Single conversation tile
|
|
|
|
///
|
|
|
|
/// @author Pierre HUBERT
|
|
|
|
|
2019-04-24 15:46:25 +00:00
|
|
|
typedef OpenConversationCallback = void Function(Conversation);
|
2021-03-13 11:07:16 +00:00
|
|
|
typedef RequestLeaveConversationCallback = void Function(Conversation);
|
2019-05-01 08:58:45 +00:00
|
|
|
typedef RequestUpdateConversationCallback = void Function(Conversation);
|
2019-05-01 08:52:10 +00:00
|
|
|
|
2021-03-13 11:07:16 +00:00
|
|
|
enum _PopupMenuChoices { UPDATE, LEAVE }
|
2019-04-24 15:46:25 +00:00
|
|
|
|
2019-04-23 12:35:41 +00:00
|
|
|
class ConversationTile extends StatelessWidget {
|
|
|
|
final Conversation conversation;
|
2019-04-23 15:29:58 +00:00
|
|
|
final UsersList usersList;
|
2019-04-24 15:46:25 +00:00
|
|
|
final OpenConversationCallback onOpen;
|
2019-05-01 08:58:45 +00:00
|
|
|
final RequestUpdateConversationCallback onRequestUpdate;
|
2021-03-13 11:07:16 +00:00
|
|
|
final RequestLeaveConversationCallback onRequestLeave;
|
2019-04-23 12:35:41 +00:00
|
|
|
|
2019-05-01 08:58:45 +00:00
|
|
|
const ConversationTile({
|
|
|
|
Key key,
|
|
|
|
@required this.conversation,
|
|
|
|
@required this.usersList,
|
|
|
|
@required this.onOpen,
|
|
|
|
@required this.onRequestUpdate,
|
2021-03-13 11:07:16 +00:00
|
|
|
@required this.onRequestLeave,
|
2019-05-01 08:58:45 +00:00
|
|
|
}) : assert(conversation != null),
|
2019-04-23 15:29:58 +00:00
|
|
|
assert(usersList != null),
|
2019-04-24 15:46:25 +00:00
|
|
|
assert(onOpen != null),
|
2019-05-01 08:58:45 +00:00
|
|
|
assert(onRequestUpdate != null),
|
2021-03-13 11:07:16 +00:00
|
|
|
assert(onRequestLeave != null),
|
2019-04-23 15:29:58 +00:00
|
|
|
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
|
2021-03-13 11:02:24 +00:00
|
|
|
Widget build(BuildContext context) => Column(
|
|
|
|
children: [_buildMainTile(context), _buildCallTile(context)],
|
|
|
|
);
|
|
|
|
|
|
|
|
Widget _buildMainTile(BuildContext context) => CustomListTile(
|
|
|
|
onTap: () => onOpen(conversation),
|
|
|
|
// Conversation name
|
|
|
|
title: Text(
|
|
|
|
ConversationsHelper.getConversationName(
|
|
|
|
conversation,
|
|
|
|
usersList,
|
|
|
|
),
|
|
|
|
style: TextStyle(
|
|
|
|
fontWeight: conversation.sawLastMessage ? null : FontWeight.bold,
|
|
|
|
),
|
2019-04-23 16:23:34 +00:00
|
|
|
),
|
2021-03-13 11:02:24 +00:00
|
|
|
|
|
|
|
// Tile color
|
|
|
|
tileColor: conversation.sawLastMessage
|
|
|
|
? null
|
|
|
|
: (conversation.color ?? Colors.blue).withOpacity(0.2),
|
|
|
|
|
|
|
|
// Leading icon
|
|
|
|
leading: ConversationImageWidget(
|
|
|
|
conversation: conversation, users: usersList),
|
|
|
|
|
|
|
|
// Conversation information
|
|
|
|
isThreeLine: true,
|
|
|
|
subtitle: Column(
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.stretch,
|
|
|
|
children: <Widget>[
|
|
|
|
_buildSubInformation(Icons.access_time,
|
|
|
|
diffTimeFromNowToStr(conversation.lastActivity)),
|
|
|
|
_buildSubInformation(
|
|
|
|
Icons.group,
|
|
|
|
conversation.members.length == 1
|
|
|
|
? tr("1 member")
|
|
|
|
: tr(
|
|
|
|
"%num% members",
|
|
|
|
args: {
|
|
|
|
"num": conversation.members.length.toString(),
|
|
|
|
},
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
2019-04-23 16:23:34 +00:00
|
|
|
),
|
|
|
|
|
2021-03-13 11:02:24 +00:00
|
|
|
onLongPressOpenMenu: (position) {
|
|
|
|
showMenu<_PopupMenuChoices>(
|
|
|
|
context: context,
|
|
|
|
position: position,
|
|
|
|
items: [
|
|
|
|
PopupMenuItem(
|
|
|
|
child: Text(tr("Update")),
|
|
|
|
value: _PopupMenuChoices.UPDATE,
|
|
|
|
),
|
|
|
|
PopupMenuItem(
|
2021-03-13 11:07:16 +00:00
|
|
|
child: Text(tr("Leave")),
|
|
|
|
value: _PopupMenuChoices.LEAVE,
|
2021-03-13 11:02:24 +00:00
|
|
|
)
|
|
|
|
]).then(_conversationMenuCallback);
|
|
|
|
},
|
|
|
|
);
|
2019-05-01 08:52:10 +00:00
|
|
|
|
2021-03-13 11:02:24 +00:00
|
|
|
/// Build call tile, in case of ongoing call
|
|
|
|
Widget _buildCallTile(BuildContext context) {
|
|
|
|
if (!conversation.isHavingCall) return Container();
|
|
|
|
|
|
|
|
return Padding(
|
|
|
|
padding: EdgeInsets.only(bottom: 20),
|
|
|
|
child: ListTile(
|
|
|
|
onTap: () => MainController.of(context).startCall(conversation.id),
|
|
|
|
dense: true,
|
|
|
|
title: Text(tr("Ongoing call")),
|
|
|
|
leading: Icon(Icons.call),
|
|
|
|
tileColor: Colors.yellow.withOpacity(0.2),
|
|
|
|
),
|
2019-04-23 12:35:41 +00:00
|
|
|
);
|
|
|
|
}
|
2019-05-01 08:52:10 +00:00
|
|
|
|
|
|
|
/// Method called each time an option of the menu is selected
|
|
|
|
void _conversationMenuCallback(_PopupMenuChoices c) {
|
|
|
|
switch (c) {
|
2019-05-01 08:58:45 +00:00
|
|
|
case _PopupMenuChoices.UPDATE:
|
|
|
|
onRequestUpdate(conversation);
|
|
|
|
break;
|
|
|
|
|
2021-03-13 11:07:16 +00:00
|
|
|
case _PopupMenuChoices.LEAVE:
|
|
|
|
onRequestLeave(conversation);
|
2019-05-01 08:52:10 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2019-04-23 12:35:41 +00:00
|
|
|
}
|