fluffychat/lib/pages/chat_details/participant_list_item.dart

94 lines
3 KiB
Dart
Raw Normal View History

2020-01-01 18:10:13 +00:00
import 'package:flutter/material.dart';
2021-10-26 16:50:34 +00:00
import 'package:flutter_gen/gen_l10n/l10n.dart';
2021-10-26 16:50:34 +00:00
import 'package:matrix/matrix.dart';
2020-01-01 18:10:13 +00:00
2023-01-07 09:29:34 +00:00
import 'package:fluffychat/utils/adaptive_bottom_sheet.dart';
2021-11-09 20:32:16 +00:00
import '../../widgets/avatar.dart';
import '../user_bottom_sheet/user_bottom_sheet.dart';
2020-01-01 18:10:13 +00:00
class ParticipantListItem extends StatelessWidget {
final User user;
const ParticipantListItem(this.user, {super.key});
2020-01-01 18:10:13 +00:00
@override
Widget build(BuildContext context) {
2024-04-14 13:49:46 +00:00
final membershipBatch = switch (user.membership) {
Membership.ban => L10n.of(context)!.banned,
Membership.invite => L10n.of(context)!.invited,
Membership.join => null,
Membership.knock => L10n.of(context)!.knocking,
Membership.leave => L10n.of(context)!.leftTheChat,
2020-01-01 18:10:13 +00:00
};
2024-04-14 13:49:46 +00:00
2020-05-13 13:58:59 +00:00
final permissionBatch = user.powerLevel == 100
2022-01-29 11:35:03 +00:00
? L10n.of(context)!.admin
2020-10-02 06:56:28 +00:00
: user.powerLevel >= 50
2022-01-29 11:35:03 +00:00
? L10n.of(context)!.moderator
2020-10-02 06:56:28 +00:00
: '';
2020-02-16 10:41:08 +00:00
return Opacity(
opacity: user.membership == Membership.join ? 1 : 0.5,
child: ListTile(
2023-01-07 09:29:34 +00:00
onTap: () => showAdaptiveBottomSheet(
context: context,
builder: (c) => UserBottomSheet(
user: user,
outerContext: context,
),
2020-10-28 06:23:50 +00:00
),
title: Row(
children: <Widget>[
Expanded(
child: Text(
user.calcDisplayname(),
overflow: TextOverflow.ellipsis,
),
),
2023-02-04 18:10:27 +00:00
if (permissionBatch.isNotEmpty)
Container(
padding: const EdgeInsets.symmetric(
horizontal: 4,
vertical: 2,
),
margin: const EdgeInsets.symmetric(horizontal: 8),
decoration: BoxDecoration(
color: Theme.of(context).colorScheme.primaryContainer,
borderRadius: BorderRadius.circular(8),
border: Border.all(
color: Theme.of(context).colorScheme.primary,
),
),
2023-02-04 18:10:27 +00:00
child: Text(
permissionBatch,
style: TextStyle(
fontSize: 14,
color: Theme.of(context).colorScheme.primary,
2020-01-01 18:10:13 +00:00
),
2023-02-04 18:10:27 +00:00
),
),
2024-04-14 13:49:46 +00:00
membershipBatch == null
? const SizedBox.shrink()
: Container(
padding: const EdgeInsets.all(4),
margin: const EdgeInsets.symmetric(horizontal: 8),
decoration: BoxDecoration(
color: Theme.of(context).secondaryHeaderColor,
borderRadius: BorderRadius.circular(8),
),
2024-04-14 13:49:46 +00:00
child: Center(child: Text(membershipBatch)),
2020-01-01 18:10:13 +00:00
),
],
),
subtitle: Text(user.id),
2023-11-11 16:56:23 +00:00
leading: Avatar(
mxContent: user.avatarUrl,
name: user.calcDisplayname(),
presenceUserId: user.stateKey,
),
2020-01-01 18:10:13 +00:00
),
);
}
}