Skip to content

Kaktushose/jda-commands

Repository files navigation

JDA-Version Generic badge Java CI Codacy Badge Codacy Badge license-shield

JDA-Commands

A lightweight, easy-to-use command framework for building Discord bots with JDA with full support for interactions. JDA-Commands goal is to remove any boilerplate code, so you can focus solely on the business logic of your bot - writing bots has never been easier!

Version Guide

jda-commands JDA Text Commands Interactions
4.0.0-beta.4 5
3.0.0 5
2.2.0 4

Features

  • Simple and intuitive syntax following an annotation-driven and declarative style

  • Built-in support for slash commands, components, context menus and modals

  • Automatic and customizable type adapting and constraint validation of parameters

  • Expandable executing chain (Middleware API)

  • Multithreaded event handling using VirtualThreads


The following example will demonstrate how easy it is not only to write commands, but also to integrate components with them:

@Interaction
public class CookieClicker {

    private int count;

    @SlashCommand(value = "cookie clicker", desc = "Play cookie clicker")
    public void onClicker(CommandEvent event) {
        event.with().components("onCookie", "onReset").reply("You've got %s cookie(s)!", count);
    }

    @Button(value = "Collect", emoji = "🍪", style = ButtonStyle.SUCCESS)
    public void onCookie(ComponentEvent event) {
        count++;
        event.reply("You've got %s cookie(s)!", count);
    }

    @Button(value = "Reset", emoji = "🔄", style = ButtonStyle.DANGER)
    public void onReset(ComponentEvent event) {
        count = 0;
        event.reply("You've got %s cookie(s)!", count);
    }
}

Finally, start the framework by calling:

JDACommands.start(jda, Main.class);

If you want to learn more, check out the Wiki or the Javadocs.

Download

You can download the latest version here.

Maven

<dependency>
   <groupId>io.github.kaktushose</groupId>
   <artifactId>jda-commands</artifactId>
   <version>v4.0.0-beta.4</version>
</dependency>

Gradle

repositories {
   mavenCentral()
}
dependencies {
   implementation("io.github.kaktushose:jda-commands:v4.0.0-beta.4")
}

Contributing

If you think that something is missing, and you want to add it yourself, feel free to open a pull request. Please try to keep your code quality as good as mine and stick to the core concepts of this framework. Also consider opening an issue first, so we can discuss if your changes fit to the framework.

Special thanks to all contributors, especially to @Goldmensch and @lus <3

Contributors Display