Make help command use descriptions and usages

This commit is contained in:
Bea 2022-12-20 17:51:28 +01:00
parent e08fefbda3
commit 496304c2c3
15 changed files with 258 additions and 13 deletions

View File

@ -0,0 +1,23 @@
package wtf.beatrice.hidekobot.commands.base;
import wtf.beatrice.hidekobot.objects.commands.MessageCommand;
import java.util.LinkedList;
public class Alias
{
public static String generateNiceAliases(MessageCommand command)
{
LinkedList<String> aliases = command.getCommandLabels();
StringBuilder aliasesStringBuilder = new StringBuilder();
for(int i = 0; i < aliases.size(); i++)
{
aliasesStringBuilder.append("`").append(aliases.get(i)).append("`");
if(i + 1 != aliases.size())
aliasesStringBuilder.append(", "); // separate with comma except on last iteration
}
return aliasesStringBuilder.toString();
}
}

View File

@ -5,6 +5,7 @@ import net.dv8tion.jda.api.events.message.MessageReceivedEvent;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
import wtf.beatrice.hidekobot.Cache; import wtf.beatrice.hidekobot.Cache;
import wtf.beatrice.hidekobot.commands.base.Alias;
import wtf.beatrice.hidekobot.objects.commands.CommandCategory; import wtf.beatrice.hidekobot.objects.commands.CommandCategory;
import wtf.beatrice.hidekobot.objects.commands.MessageCommand; import wtf.beatrice.hidekobot.objects.commands.MessageCommand;
@ -37,6 +38,18 @@ public class AliasCommand implements MessageCommand
return CommandCategory.TOOLS; return CommandCategory.TOOLS;
} }
@NotNull
@Override
public String getDescription() {
return "See other command aliases.";
}
@Nullable
@Override
public String getUsage() {
return "<command>";
}
@Override @Override
public void runCommand(MessageReceivedEvent event, String label, String[] args) public void runCommand(MessageReceivedEvent event, String label, String[] args)
{ {
@ -54,19 +67,11 @@ public class AliasCommand implements MessageCommand
return; return;
} }
LinkedList<String> aliases = command.getCommandLabels(); String aliases = Alias.generateNiceAliases(command);
StringBuilder aliasesStringBuilder = new StringBuilder(); aliases = "Aliases for **" + command.getCommandLabels().get(0) + "**: " + aliases;
aliasesStringBuilder.append("Aliases for **").append(aliases.get(0)).append("**: ");
for(int i = 0; i < aliases.size(); i++)
{
aliasesStringBuilder.append("`").append(aliases.get(i)).append("`");
if(i + 1 != aliases.size())
aliasesStringBuilder.append(", "); // separate with comma except on last iteration
}
event.getMessage() event.getMessage()
.reply(aliasesStringBuilder.toString()) .reply(aliases)
.queue(); .queue();
} }

View File

@ -36,6 +36,18 @@ public class AvatarCommand implements MessageCommand
return false; return false;
} }
@NotNull
@Override
public String getDescription() {
return "Get someone's avatar, or your own. You can additionally specify a resolution.";
}
@Nullable
@Override
public String getUsage() {
return "[mentioned user] [resolution]";
}
@NotNull @NotNull
@Override @Override
public CommandCategory getCategory() { public CommandCategory getCategory() {
@ -47,7 +59,7 @@ public class AvatarCommand implements MessageCommand
{ {
int[] acceptedSizes = Cache.getSupportedAvatarResolutions(); int[] acceptedSizes = Cache.getSupportedAvatarResolutions();
User user = null; User user;
int resolution = -1; int resolution = -1;
// we have no specific order for user and resolution, so let's try parsing any arg as resolution // we have no specific order for user and resolution, so let's try parsing any arg as resolution

View File

@ -33,6 +33,18 @@ public class BotInfoCommand implements MessageCommand
return false; return false;
} }
@NotNull
@Override
public String getDescription() {
return "Get general info about the bot.";
}
@Nullable
@Override
public String getUsage() {
return null;
}
@NotNull @NotNull
@Override @Override
public CommandCategory getCategory() { public CommandCategory getCategory() {

View File

@ -5,6 +5,7 @@ import net.dv8tion.jda.api.entities.Message;
import net.dv8tion.jda.api.events.message.MessageReceivedEvent; import net.dv8tion.jda.api.events.message.MessageReceivedEvent;
import net.dv8tion.jda.api.interactions.components.buttons.Button; import net.dv8tion.jda.api.interactions.components.buttons.Button;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import wtf.beatrice.hidekobot.Cache; import wtf.beatrice.hidekobot.Cache;
import wtf.beatrice.hidekobot.commands.base.ClearChat; import wtf.beatrice.hidekobot.commands.base.ClearChat;
import wtf.beatrice.hidekobot.objects.commands.CommandCategory; import wtf.beatrice.hidekobot.objects.commands.CommandCategory;
@ -29,12 +30,25 @@ public class ClearCommand implements MessageCommand
public boolean passRawArgs() { public boolean passRawArgs() {
return false; return false;
} }
@NotNull @NotNull
@Override @Override
public CommandCategory getCategory() { public CommandCategory getCategory() {
return CommandCategory.MODERATION; return CommandCategory.MODERATION;
} }
@NotNull
@Override
public String getDescription() {
return "Clear the current channel's chat history.";
}
@Nullable
@Override
public String getUsage() {
return "[amount]";
}
@Override @Override
public void runCommand(MessageReceivedEvent event, String label, String[] args) public void runCommand(MessageReceivedEvent event, String label, String[] args)
{ {

View File

@ -31,6 +31,18 @@ public class CoinFlipCommand implements MessageCommand
return false; return false;
} }
@NotNull
@Override
public String getDescription() {
return "Flip a coin.";
}
@Nullable
@Override
public String getUsage() {
return null;
}
@NotNull @NotNull
@Override @Override
public CommandCategory getCategory() { public CommandCategory getCategory() {

View File

@ -30,6 +30,23 @@ public class DiceRollCommand implements MessageCommand
return false; return false;
} }
@NotNull
@Override
public String getDescription() {
return "Roll dice. You can roll multiple dice at the same time." +
"\nExamples:" +
"\n - `d8 10` to roll an 8-sided die 10 times." +
"\n - `d12 3 d5 10` to roll a 12-sided die 3 times, and then a 5-sided die 10 times." +
"\n - `30` to roll a standard 6-sided die 30 times." +
"\n - `d10` to roll a 10-sided die once.";
}
@Nullable
@Override
public String getUsage() {
return "[dice size] [rolls]";
}
@NotNull @NotNull
@Override @Override
public CommandCategory getCategory() { public CommandCategory getCategory() {

View File

@ -3,6 +3,7 @@ package wtf.beatrice.hidekobot.commands.message;
import net.dv8tion.jda.api.Permission; import net.dv8tion.jda.api.Permission;
import net.dv8tion.jda.api.events.message.MessageReceivedEvent; import net.dv8tion.jda.api.events.message.MessageReceivedEvent;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import wtf.beatrice.hidekobot.objects.commands.CommandCategory; import wtf.beatrice.hidekobot.objects.commands.CommandCategory;
import wtf.beatrice.hidekobot.objects.commands.MessageCommand; import wtf.beatrice.hidekobot.objects.commands.MessageCommand;
@ -26,6 +27,18 @@ public class HelloCommand implements MessageCommand
return false; return false;
} }
@NotNull
@Override
public String getDescription() {
return "Get pinged by the bot.";
}
@Nullable
@Override
public String getUsage() {
return null;
}
@NotNull @NotNull
@Override @Override
public CommandCategory getCategory() { public CommandCategory getCategory() {

View File

@ -7,6 +7,7 @@ import org.apache.commons.text.WordUtils;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
import wtf.beatrice.hidekobot.Cache; import wtf.beatrice.hidekobot.Cache;
import wtf.beatrice.hidekobot.commands.base.Alias;
import wtf.beatrice.hidekobot.commands.base.Say; import wtf.beatrice.hidekobot.commands.base.Say;
import wtf.beatrice.hidekobot.objects.commands.CommandCategory; import wtf.beatrice.hidekobot.objects.commands.CommandCategory;
import wtf.beatrice.hidekobot.objects.commands.MessageCommand; import wtf.beatrice.hidekobot.objects.commands.MessageCommand;
@ -34,6 +35,18 @@ public class HelpCommand implements MessageCommand
return false; return false;
} }
@NotNull
@Override
public String getDescription() {
return "Get general help on the bot. Specify a command if you want specific help about that command.";
}
@Nullable
@Override
public String getUsage() {
return "[command]";
}
@NotNull @NotNull
@Override @Override
public CommandCategory getCategory() { public CommandCategory getCategory() {
@ -91,6 +104,51 @@ public class HelpCommand implements MessageCommand
embedBuilder.addField(niceCategoryName, commandsList.toString(), false); embedBuilder.addField(niceCategoryName, commandsList.toString(), false);
} }
event.getMessage().replyEmbeds(embedBuilder.build()).queue();
} else {
String commandLabel = args[0].toLowerCase();
MessageCommand command = Cache.getMessageCommandListener().getRegisteredCommand(commandLabel);
if(command == null)
{
event.getMessage().reply("Unrecognized command: `" + commandLabel + "`!").queue(); // todo prettier
return;
}
commandLabel = command.getCommandLabels().get(0);
String usage = "`" + Cache.getBotPrefix() + " " + commandLabel;
String internalUsage = command.getUsage();
if(internalUsage != null) usage += " " + internalUsage;
usage += "`";
String aliases = Alias.generateNiceAliases(command);
List<Permission> permissions = command.getPermissions();
StringBuilder permissionsStringBuilder = new StringBuilder();
if(permissions == null)
{
permissionsStringBuilder = new StringBuilder("Available to everyone");
} else {
for(int i = 0; i < permissions.size(); i++)
{
Permission permission = permissions.get(i);
permissionsStringBuilder.append("`").append(permission.getName()).append("`");
if(i + 1 != permissions.size())
permissionsStringBuilder.append(", "); // separate with comma expect on last iteration
}
}
EmbedBuilder embedBuilder = new EmbedBuilder();
embedBuilder.setColor(Cache.getBotColor());
embedBuilder.setTitle(WordUtils.capitalizeFully(commandLabel + " help"));
embedBuilder.addField("Description", command.getDescription(), false);
embedBuilder.addField("Usage", usage, false);
embedBuilder.addField("Aliases", aliases, false);
embedBuilder.addField("Permissions", permissionsStringBuilder.toString(), false);
event.getMessage().replyEmbeds(embedBuilder.build()).queue(); event.getMessage().replyEmbeds(embedBuilder.build()).queue();
} }
} }

View File

@ -34,6 +34,18 @@ public class InviteCommand implements MessageCommand
return false; return false;
} }
@NotNull
@Override
public String getDescription() {
return "Get the bot's invite link.";
}
@Nullable
@Override
public String getUsage() {
return null;
}
@NotNull @NotNull
@Override @Override
public CommandCategory getCategory() { public CommandCategory getCategory() {

View File

@ -39,6 +39,18 @@ public class LoveCalculatorCommand implements MessageCommand
return false; return false;
} }
@NotNull
@Override
public String getDescription() {
return "Calculate how much two people love each other. You can mention two people or just one.";
}
@Nullable
@Override
public String getUsage() {
return "<person 1> [person 2]";
}
@NotNull @NotNull
@Override @Override
public CommandCategory getCategory() { public CommandCategory getCategory() {
@ -55,7 +67,9 @@ public class LoveCalculatorCommand implements MessageCommand
if(args.length == 0 || mentions.isEmpty()) if(args.length == 0 || mentions.isEmpty())
{ {
event.getMessage().reply("\uD83D\uDE22 I need to know who to check!").queue(); event.getMessage()
.reply("\uD83D\uDE22 I need to know who to check! Please mention them.")
.queue();
return; return;
} }

View File

@ -30,6 +30,18 @@ public class MagicBallCommand implements MessageCommand
return false; return false;
} }
@NotNull
@Override
public String getDescription() {
return "Ask a question to the Magic Ball.";
}
@Nullable
@Override
public String getUsage() {
return "<question>";
}
@NotNull @NotNull
@Override @Override
public CommandCategory getCategory() { public CommandCategory getCategory() {

View File

@ -30,6 +30,18 @@ public class SayCommand implements MessageCommand
return true; return true;
} }
@NotNull
@Override
public String getDescription() {
return "Make the bot say something for you.";
}
@Nullable
@Override
public String getUsage() {
return "<text>";
}
@NotNull @NotNull
@Override @Override
public CommandCategory getCategory() { public CommandCategory getCategory() {

View File

@ -36,6 +36,18 @@ public class UrbanDictionaryCommand implements MessageCommand
return false; return false;
} }
@NotNull
@Override
public String getDescription() {
return "Look something up in the Urban Dictionary.";
}
@Nullable
@Override
public String getUsage() {
return "<query>";
}
@NotNull @NotNull
@Override @Override
public CommandCategory getCategory() { public CommandCategory getCategory() {

View File

@ -48,6 +48,23 @@ public interface MessageCommand
@NotNull @NotNull
CommandCategory getCategory(); CommandCategory getCategory();
/**
* Say what this command does.
*
* @return a String explaining what this command does.
*/
@NotNull
String getDescription();
/**
* Say how people should use this command.
*
* @return a String explaining how to use the command, excluding the bot prefix and command name. Null if no parameter is needed
*/
@Nullable
String getUsage();
/** /**
* Run the command logic by parsing the event and replying accordingly. * Run the command logic by parsing the event and replying accordingly.
* *