1
0
mirror of https://gitlab.com/comunic/comunicmobile synced 2024-11-22 21:09:21 +00:00
comunicmobile/lib/ui/tiles/pending_friend_tile.dart

82 lines
2.4 KiB
Dart
Raw Normal View History

2022-03-18 16:54:19 +00:00
import 'package:comunic/helpers/server_config_helper.dart';
import 'package:comunic/models/friend.dart';
import 'package:comunic/models/user.dart';
2022-03-18 16:54:19 +00:00
import 'package:comunic/ui/tiles/accepted_friend_tile.dart';
import 'package:comunic/ui/widgets/account_image_widget.dart';
import 'package:comunic/utils/intl_utils.dart';
import 'package:flutter/material.dart';
/// Pending friend tile
///
/// @author Pierre HUBERT
typedef RespondFriendshipRequestCallback = void Function(Friend, bool);
class PendingFriendTile extends StatelessWidget {
final Friend friend;
final User user;
final RespondFriendshipRequestCallback onRespond;
2022-03-18 16:54:19 +00:00
final OnReportFriend onReport;
2022-03-18 16:54:19 +00:00
const PendingFriendTile({
Key? key,
required this.friend,
required this.user,
required this.onRespond,
required this.onReport,
}) : super(key: key);
@override
Widget build(BuildContext context) {
return ListTile(
leading: AccountImageWidget(
user: user,
),
isThreeLine: true,
title: Text(user.fullName),
subtitle: Container(
height: 30.0,
margin: EdgeInsets.only(top: 8.0),
child: Row(
mainAxisAlignment: MainAxisAlignment.end,
children: <Widget>[
2021-03-13 14:28:34 +00:00
ElevatedButton(
child: Text(
tr("Accept")!.toUpperCase(),
style: TextStyle(color: Colors.white),
),
2021-03-13 14:28:34 +00:00
style: ButtonStyle(
backgroundColor: MaterialStateProperty.all(Colors.green)),
onPressed: () => onRespond(friend, true),
),
2021-03-13 14:28:34 +00:00
Container(
width: 8.0,
),
ElevatedButton(
child: Text(
tr("Reject")!.toUpperCase(),
style: TextStyle(color: Colors.white),
),
2021-03-13 14:28:34 +00:00
style: ButtonStyle(
backgroundColor: MaterialStateProperty.all(Colors.red)),
onPressed: () => onRespond(friend, false),
2022-03-18 16:54:19 +00:00
),
// Report button
srvConfig!.isReportingEnabled
? IconButton(
visualDensity: VisualDensity.compact,
onPressed: () => onReport(friend),
icon: Icon(
Icons.flag,
size: 15.0,
),
)
: Container()
],
),
),
);
}
}