From b3990ff04f2761aff65a879799ffd39b717a98f6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lorenzo=20Dellac=C3=A0?= Date: Mon, 19 Dec 2022 16:47:49 +0100 Subject: [PATCH] Make clear command also delete the sender's message --- .../beatrice/hidekobot/commands/base/ClearChat.java | 6 +++++- .../hidekobot/commands/message/ClearCommand.java | 11 ++++++++--- 2 files changed, 13 insertions(+), 4 deletions(-) diff --git a/src/main/java/wtf/beatrice/hidekobot/commands/base/ClearChat.java b/src/main/java/wtf/beatrice/hidekobot/commands/base/ClearChat.java index 1bfe884..b64546c 100644 --- a/src/main/java/wtf/beatrice/hidekobot/commands/base/ClearChat.java +++ b/src/main/java/wtf/beatrice/hidekobot/commands/base/ClearChat.java @@ -3,6 +3,7 @@ package wtf.beatrice.hidekobot.commands.base; import net.dv8tion.jda.api.Permission; import net.dv8tion.jda.api.entities.Message; import net.dv8tion.jda.api.entities.MessageHistory; +import net.dv8tion.jda.api.entities.User; import net.dv8tion.jda.api.entities.channel.Channel; import net.dv8tion.jda.api.entities.channel.concrete.TextChannel; import net.dv8tion.jda.api.entities.channel.middleman.MessageChannel; @@ -46,7 +47,9 @@ public class ClearChat return null; } - public static int delete(int toDeleteAmount, long startingMessageId, MessageChannel channel) + public static int delete(int toDeleteAmount, + long startingMessageId, + MessageChannel channel) { // int to keep track of how many messages we actually deleted. int deleted = 0; @@ -155,6 +158,7 @@ public class ClearChat public static String parseAmount(int deleted) { + if(deleted < 1) { return "\uD83D\uDE22 Couldn't clear any message!"; diff --git a/src/main/java/wtf/beatrice/hidekobot/commands/message/ClearCommand.java b/src/main/java/wtf/beatrice/hidekobot/commands/message/ClearCommand.java index aea9afb..2cb0fb5 100644 --- a/src/main/java/wtf/beatrice/hidekobot/commands/message/ClearCommand.java +++ b/src/main/java/wtf/beatrice/hidekobot/commands/message/ClearCommand.java @@ -75,11 +75,16 @@ public class ClearCommand implements MessageCommand // ^ todo: maybe the dismiss button should also delete the original message sent by the user? // todo: but then, we need to differentiate between command type in the database, and store // todo: that message's id too. - botMessage = botMessage.editMessage(content).setActionRow(dismiss).complete(); + Message finalMessage = event.getChannel().sendMessage(content).setActionRow(dismiss).complete(); // add the message to database. - Cache.getDatabaseSource().queueDisabling(botMessage); - Cache.getDatabaseSource().trackRanCommandReply(botMessage, event.getAuthor()); + Cache.getDatabaseSource().queueDisabling(finalMessage); + Cache.getDatabaseSource().trackRanCommandReply(finalMessage, event.getAuthor()); + + // delete the sender's message. + event.getMessage().delete().queue(); + // delete the "clearing" info message. + botMessage.delete().queue(); }