feat: Send reactions to multiple events

onboarding
Krille Fear 4 years ago
parent 9e641c8ee4
commit cbf8e0799e

@ -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, setState(() => selectedEvents.clear());
future: () => room.sendReaction( for (final event in events) {
selectedEvents.single.eventId, await room.sendReaction(
event.eventId,
emoji, emoji,
),
); );
setState(() => selectedEvents.clear()); }
} }
void clearSelectedEvents() => setState(() { void clearSelectedEvents() => setState(() {

@ -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(),
]);
} }
} }

@ -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);

Loading…
Cancel
Save