xtoncore v1.2.2
XtonCore is an easy-to-use JavaScript library. This makes creating your own Handler in Discord.js easier.
This library only supports discord.js v14
Credit
Thank you for the source code for this project. UnderCtrl
Installation
To install XtonCore, simply run the following command:
For npm:
npm install xtoncoreFor yarn:
yarn add xtoncoreUsage
Insert this code into your index.js.
// index.js
const { ClientHandler } = require('xtoncore');
const path = require('path');
new ClientHandler({
  client, // Discord.js client 
  commandsPath: path.join(__dirname, 'commands'),
  //Enter the name of your command folder.
  eventsPath: path.join(__dirname, 'events'),
  //Enter the name of your events folder.
  validationsPath: path.join(__dirname, 'validations'),
  //Only works if commandsPath is provided
  guild: 'SERVER_ID',
  //To register guild-based commands (if not provided commands will be registered globally)
});File Structure
Commands
XtonCore allows a very flexible file structure for your commands directory. Here's an example of what your file structure could look like:
commands/
├── ping.js
├── botinfo.js
└── mod/
	├── ban.js
	└── kick.jsAny file inside the commands directory will be considered a command file, so make sure it properly exports an object. Like this:
// commands/ping.js
const { SlashCommandBuilder } = require('discord.js');
module.exports = {
  data: new SlashCommandBuilder()
  .setName('ping')
  .setDescription('Pong!'),
  run: ({ interaction, client, handler }) => {
    interaction.reply(`Pong! ${client.ws.ping}ms`);
  },
  // deleted: true, // Deletes the command from Discord (if you passed in a "testServer" property it'll delete from the guild and not globally)
};- interaction
- clientis the discord.js Client instance.
- handleris the ClientHandler instance. You can use this to get access to properties such as- commands.
Events
XtonCore assumes a specific file structure for your events. Here's an example of what your file structure could look like:
events/
├── ready/
|	├── console-log.js
|	└── webhook.js
|
└── messageCreate/
	├── auto-mod/
	|	├── delete-swear-words.js
	|	└── anti-raid.js
	|
	└── chat-bot.jsMake sure each file exports a default function. Like this:
// events/ready/console-log.js
module.exports = (argument, client, handler) => {
  console.log(`${client.user.tag} is online.`);
};- argumentis the argument you receive from the event being triggered (you can name this whatever you want). For example, the- messageCreateevent will give you an argument of the message object.
- clientis the discord.js Client instance.
- handleris the CommandHandler instance. You can use this to get access to properties such as- commands.
Validations
XtonCore allows you to organize your validation files however you want to. Functions inside these files are executed in ascending order so you can prioritize your validations however you see fit. Here’s an example of what your file structure could look like:
validations/
└── dev-only.jsMake sure each file exports a default function. Like this:
// validations/dev-only.js
module.exports = (interaction, commandObj, handler, client) => {
  if (commandObj.devOnly) {
    if (interaction.member.id !== 'DEVELOPER_ID') {
      interaction.reply('This command is for the developer only');
      return true; // This must be added to stop the command from being executed.
    }
  }
};- interactionis the interaction object.
- commandObjis the command object exported from the command file itself. Properties such as- name,- descriptionand- optionsare all available within.
- handleris the CommandHandler instance. You can use this to get access to properties such as- commands.
- clientis the Client instance. (defined in your main entry point)
It's important to return true (or any truthy value) if you don't want the command to be executed (this also ensures the next validation that was queued up is not executed).