Added ability to see others balance
This commit is contained in:
@@ -1,8 +1,12 @@
|
|||||||
#define CURRENCY_NAME "Night Coin"
|
#define CURRENCY_NAME "Night Coin"
|
||||||
|
|
||||||
#define COMMAND_BALANCE_DESCRIPTION "See your balance of " CURRENCY_NAME
|
#define COMMAND_BALANCE_DESCRIPTION "See someone's balance of " CURRENCY_NAME
|
||||||
#define COMMAND_BALANCE_RESPONSE(balance) \
|
#define COMMAND_BALANCE_USER_DESCRIPTION \
|
||||||
|
"Leave this blank if you want to see your own balance"
|
||||||
|
#define COMMAND_BALANCE_SELF_RESPONSE(balance) \
|
||||||
"You currently have " + balance + " " CURRENCY_NAME "(s)"
|
"You currently have " + balance + " " CURRENCY_NAME "(s)"
|
||||||
|
#define COMMAND_BALANCE_SOMEONE_ELSE_RESPONSE(person, balance) \
|
||||||
|
"<@!" + person + "> currently has " + balance + " " CURRENCY_NAME "(s)"
|
||||||
|
|
||||||
#define COMMAND_PAY_DESCRIPTION "Send someone some amount of " CURRENCY_NAME "s"
|
#define COMMAND_PAY_DESCRIPTION "Send someone some amount of " CURRENCY_NAME "s"
|
||||||
#define COMMAND_PAY_ARGS_USER_DESCRIPTION "Who do you want to pay"
|
#define COMMAND_PAY_ARGS_USER_DESCRIPTION "Who do you want to pay"
|
||||||
|
@@ -1,14 +1,30 @@
|
|||||||
#include "Base/SQL.hpp"
|
#include "Base/SQL.hpp"
|
||||||
#include "Commands.hpp"
|
#include "Commands.hpp"
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
|
#include <dpp/appcommand.h>
|
||||||
#include <dpp/dispatcher.h>
|
#include <dpp/dispatcher.h>
|
||||||
|
#include <dpp/exception.h>
|
||||||
#include <dpp/snowflake.h>
|
#include <dpp/snowflake.h>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
#include <variant>
|
||||||
|
|
||||||
void commandPing(const dpp::slashcommand_t &event) { event.reply("Pong"); }
|
void commandPing(const dpp::slashcommand_t &event) { event.reply("Pong"); }
|
||||||
void commandBalance(const dpp::slashcommand_t &event) {
|
void commandBalance(const dpp::slashcommand_t &event) {
|
||||||
std::string balance = getUserBalance(event.command.get_issuing_user().id);
|
std::string person, balance;
|
||||||
event.reply(COMMAND_BALANCE_RESPONSE(balance));
|
dpp::command_value id = event.get_parameter("user");
|
||||||
|
|
||||||
|
// Weirdest thing ever
|
||||||
|
if (std::holds_alternative<std::monostate>(id)) {
|
||||||
|
person = event.command.get_issuing_user().id;
|
||||||
|
balance = getUserBalance(person);
|
||||||
|
event.reply(COMMAND_BALANCE_SELF_RESPONSE(balance));
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
person = std::get<dpp::snowflake>(id).str();
|
||||||
|
balance = getUserBalance(person);
|
||||||
|
event.reply(COMMAND_BALANCE_SOMEONE_ELSE_RESPONSE(person, balance));
|
||||||
}
|
}
|
||||||
|
|
||||||
void commandPay(const dpp::slashcommand_t &event) {
|
void commandPay(const dpp::slashcommand_t &event) {
|
||||||
|
@@ -7,10 +7,18 @@ void createCommands(const dpp::ready_t &event, dpp::cluster &bot) {
|
|||||||
|
|
||||||
// Money related stuff
|
// Money related stuff
|
||||||
bot.guild_command_create(
|
bot.guild_command_create(
|
||||||
dpp::slashcommand("balance", COMMAND_BALANCE_DESCRIPTION, bot.me.id),
|
dpp::slashcommand("balance", COMMAND_BALANCE_DESCRIPTION, bot.me.id)
|
||||||
|
.add_option(dpp::command_option(dpp::command_option_type::co_user,
|
||||||
|
"user",
|
||||||
|
COMMAND_BALANCE_USER_DESCRIPTION)),
|
||||||
GUILD);
|
GUILD);
|
||||||
bot.guild_command_create(
|
bot.guild_command_create(
|
||||||
dpp::slashcommand("bal", COMMAND_BALANCE_DESCRIPTION, bot.me.id), GUILD);
|
dpp::slashcommand("bal", COMMAND_BALANCE_DESCRIPTION, bot.me.id)
|
||||||
|
.add_option(dpp::command_option(dpp::command_option_type::co_user,
|
||||||
|
"user",
|
||||||
|
COMMAND_BALANCE_USER_DESCRIPTION)),
|
||||||
|
GUILD);
|
||||||
|
|
||||||
bot.guild_command_create(
|
bot.guild_command_create(
|
||||||
dpp::slashcommand("pay", COMMAND_PAY_DESCRIPTION, bot.me.id)
|
dpp::slashcommand("pay", COMMAND_PAY_DESCRIPTION, bot.me.id)
|
||||||
.add_option(dpp::command_option(
|
.add_option(dpp::command_option(
|
||||||
|
Reference in New Issue
Block a user