From bf15bcb27791d81e5d7095fd88096a40f28c65d6 Mon Sep 17 00:00:00 2001 From: Szymon Uglis Date: Sat, 8 Jan 2022 22:51:21 +0100 Subject: [PATCH 1/3] bug: fix add embed behavior (#284) * bug: fix add embed behavior * Fixup unit tests * Code review * Code review --- lib/src/utils/builders/message_builder.dart | 8 +++++--- test/unit/builders_test.dart | 4 ++-- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/lib/src/utils/builders/message_builder.dart b/lib/src/utils/builders/message_builder.dart index 416d7f1b2..32f10cd7d 100644 --- a/lib/src/utils/builders/message_builder.dart +++ b/lib/src/utils/builders/message_builder.dart @@ -1,3 +1,4 @@ +import 'dart:async'; import 'dart:io'; import 'package:http/http.dart' as http; @@ -73,10 +74,11 @@ class MessageBuilder { ..embeds = message.embeds.map((e) => e.toBuilder()).toList() ..replyBuilder = message.referencedMessage?.toBuilder(); - /// Allows to add embed to message - void addEmbed(void Function(EmbedBuilder embed) builder) { + /// Allows to add embed to message. + /// Warning: Completes future synchronously! + FutureOr addEmbed(FutureOr Function(EmbedBuilder embed) builder) async { final e = EmbedBuilder(); - builder(e); + await builder(e); embeds.add(e); } diff --git a/test/unit/builders_test.dart b/test/unit/builders_test.dart index a0e71ea92..f08b73d0c 100644 --- a/test/unit/builders_test.dart +++ b/test/unit/builders_test.dart @@ -140,9 +140,9 @@ main() { expect(builder.content, equals(MessageBuilder.clearCharacter)); }); - test('embeds', () { + test('embeds', () async { final builder = MessageBuilder.embed(EmbedBuilder()..description = 'test1'); - builder.addEmbed((embed) => embed.description = 'test2'); + await builder.addEmbed((embed) => embed.description = 'test2'); final result = builder.build(); From ded14701ce219efbacfbf50488a1e4e60ac9df55 Mon Sep 17 00:00:00 2001 From: Szymon Uglis Date: Sat, 8 Jan 2022 22:57:13 +0100 Subject: [PATCH 2/3] bug: fix message edit behavior (#283) --- lib/src/utils/builders/message_builder.dart | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/lib/src/utils/builders/message_builder.dart b/lib/src/utils/builders/message_builder.dart index 32f10cd7d..95b7ef859 100644 --- a/lib/src/utils/builders/message_builder.dart +++ b/lib/src/utils/builders/message_builder.dart @@ -29,7 +29,7 @@ class MessageBuilder { ReplyBuilder? replyBuilder; /// Embed to include in message - List embeds = []; + List? embeds; /// [AllowedMentions] object to control mentions in message AllowedMentions? allowedMentions; @@ -77,9 +77,11 @@ class MessageBuilder { /// Allows to add embed to message. /// Warning: Completes future synchronously! FutureOr addEmbed(FutureOr Function(EmbedBuilder embed) builder) async { + embeds ??= []; + final e = EmbedBuilder(); await builder(e); - embeds.add(e); + embeds!.add(e); } /// Appends clear character. Can be used to skip first line in message body. @@ -150,14 +152,14 @@ class MessageBuilder { Future send(ISend entity) => entity.sendMessage(this); /// Returns if this instance of message builder can be used when editing message - bool canBeUsedAsNewMessage() => content.isNotEmpty || embeds.isNotEmpty || (files != null && files!.isNotEmpty); + bool canBeUsedAsNewMessage() => content.isNotEmpty || embeds != null || (files != null && files!.isNotEmpty); RawApiMap build([AllowedMentions? defaultAllowedMentions]) { allowedMentions ??= defaultAllowedMentions; return { if (content.isNotEmpty) "content": content.toString(), - if (embeds.isNotEmpty) "embeds": [for (final e in embeds) e.build()], + if (embeds != null) "embeds": [for (final e in embeds!) e.build()], if (allowedMentions != null) "allowed_mentions": allowedMentions!.build(), if (replyBuilder != null) "message_reference": replyBuilder!.build(), if (tts != null) "tts": tts, From 1d4d1bdb326b37f3f2f0aa9a3038cbae364b0a10 Mon Sep 17 00:00:00 2001 From: Szymon Uglis Date: Sat, 8 Jan 2022 23:06:53 +0100 Subject: [PATCH 3/3] Release 3.2.2 --- CHANGELOG.md | 6 ++++++ lib/src/internal/constants.dart | 2 +- pubspec.yaml | 2 +- 3 files changed, 8 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 9c745c639..4882de487 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,9 @@ +## 3.2.2 +__08.01.2022__ + +- Fix message edit behavior (#283) +- Fix `addEmbed` behavior on message builder (#284) + ## 3.2.1 __01.01.2022__ diff --git a/lib/src/internal/constants.dart b/lib/src/internal/constants.dart index f62d53127..474132cf6 100644 --- a/lib/src/internal/constants.dart +++ b/lib/src/internal/constants.dart @@ -33,7 +33,7 @@ class Constants { static const int apiVersion = 9; /// Version of Nyxx - static const String version = "3.2.1"; + static const String version = "3.2.2"; /// Url to Nyxx repo static const String repoUrl = "https://github.com/nyxx-discord/nyxx"; diff --git a/pubspec.yaml b/pubspec.yaml index 22455e18f..b1175c75c 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -1,5 +1,5 @@ name: nyxx -version: 3.2.1 +version: 3.2.2 description: A Discord library for Dart. Simple, robust framework for creating discord bots for Dart language. homepage: https://github.com/nyxx-discord/nyxx repository: https://github.com/nyxx-discord/nyxx