feat: Send reactions to multiple events

This commit is contained in:
Krille Fear 2021-11-19 10:23:24 +01:00
parent 068e312726
commit f4425771f8
3 changed files with 56 additions and 50 deletions

View File

@ -631,14 +631,14 @@ class ChatController extends State<Chat> {
} }
void sendEmojiAction(String emoji) async { void sendEmojiAction(String emoji) async {
await showFutureLoadingDialog( final events = List<Event>.from(selectedEvents);
context: context,
future: () => room.sendReaction(
selectedEvents.single.eventId,
emoji,
),
);
setState(() => selectedEvents.clear()); setState(() => selectedEvents.clear());
for (final event in events) {
await room.sendReaction(
event.eventId,
emoji,
);
}
} }
void clearSelectedEvents() => setState(() { void clearSelectedEvents() => setState(() {

View File

@ -41,12 +41,20 @@ class MessageReactions extends StatelessWidget {
reactionMap[key].reacted |= e.senderId == e.room.client.userID; reactionMap[key].reacted |= e.senderId == e.room.client.userID;
} }
} }
final reactionList = reactionMap.values.toList(); final reactionList = reactionMap.values.toList();
reactionList.sort((a, b) => b.count - a.count > 0 ? 1 : -1); reactionList.sort((a, b) => b.count - a.count > 0 ? 1 : -1);
return Wrap( return Wrap(spacing: 4.0, runSpacing: 4.0, children: [
spacing: 4.0, if (allReactionEvents.any((e) => e.status.isSending))
runSpacing: 4.0, const SizedBox(
children: reactionList width: 28,
height: 28,
child: Padding(
padding: EdgeInsets.all(4.0),
child: CircularProgressIndicator.adaptive(strokeWidth: 1),
),
),
...reactionList
.map( .map(
(r) => _Reaction( (r) => _Reaction(
reactionKey: r.key, reactionKey: r.key,
@ -78,7 +86,8 @@ class MessageReactions extends StatelessWidget {
).show(context), ).show(context),
), ),
) )
.toList()); .toList(),
]);
} }
} }

View File

@ -12,20 +12,17 @@ class ReactionsPicker extends StatelessWidget {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
if (controller.showEmojiPicker) return Container(); if (controller.showEmojiPicker) return Container();
return AnimatedContainer( final display = controller.editEvent == null &&
duration: const Duration(milliseconds: 300),
height: (controller.editEvent == null &&
controller.replyEvent == null && controller.replyEvent == null &&
controller.room.canSendDefaultMessages && controller.room.canSendDefaultMessages &&
controller.selectedEvents.length == 1) controller.selectedEvents.isNotEmpty;
? 56 return AnimatedContainer(
: 0, duration: const Duration(milliseconds: 300),
height: (display) ? 56 : 0,
child: Material( child: Material(
color: Theme.of(context).secondaryHeaderColor, color: Theme.of(context).secondaryHeaderColor,
child: Builder(builder: (context) { child: Builder(builder: (context) {
if (!(controller.editEvent == null && if (!display) {
controller.replyEvent == null &&
controller.selectedEvents.length == 1)) {
return Container(); return Container();
} }
final emojis = List<String>.from(AppEmojis.emojis); final emojis = List<String>.from(AppEmojis.emojis);