Update 1/4/2021
New embed color option for giveaways.
discord-giveaway
A package for giveaways and drops.
Drops
Go here to see how to use the drops.
Examples
Start
Start by creating a new GiveawayCreator.
const { Client } = require('discord.js');
const client = new Client();
const { GiveawayCreator } = require('discord-giveaway');
const Creator = new GiveawayCreator(client, 'mongodb://...');
client.giveaways = Creator; // Access the Creator from anywhere.
All Methods
startGiveaway(options)
Creates a giveaway. Example:
client.on('message', async message => {
if (message.content.startsWith('!create')) {
const channel = message.mentions.channels.first();
await client.giveaways.startGiveaway({
prize: 'Discord Nitro Classic',
channelId: channel.id,
guildId: message.guild.id,
duration: 30000, // 30 Seconds
winners: 1, // 1 winner
hostedBy: message.author.id
});
}
});
endGiveaway(messageId)
Ends a giveaway. Example:
client.on('message', async message => {
if (message.content.startsWith('!end')) {
const args = message.content.split(' ').slice(1);
const ended = await client.giveaways.endGiveaway(args.join(' '));
if (!ended) {
return message.channel.send('This giveaway has already ended');
}
else {
message.channel.send('Ended the giveaway');
}
}
});
rerollGiveaway(messageId)
Rerolls a giveaway. Example:
client.on('message', async message => {
if (message.content.startsWith('!end')) {
const args = message.content.split(' ').slice(1);
const rerolled = await client.giveaways.rerollGiveaway(args.join(' '));
if (!rerolled) {
return message.channel.send('This giveaway hasn\'t ended');
}
else {
message.channel.send('Rerolled the giveaway');
}
}
});
listGiveaways(guildId)
const prettyMilliseconds = require('pretty-ms'); // npm i pretty-ms
client.on('message', async message => {
if (message.content.startsWith('!list')) {
const list = await client.giveaways.listGiveaways(message.guild.id);
if (!list) {
return message.channel.send('No active giveaways.');
} else {
message.channel.send(`${list.map(i => `\`${i.messageId}\` - **${i.prize}** | ${prettyMilliseconds(i.timeRemaining)} | Host: **${i.hostedBy}**`).join('\n')}`)
}
}
});
How to Use Drops
First, you need to create a new DropCreator.
const Discord = require('discord.js');
const client = new Discord.Client();
const Giveaway = require('discord-giveaway');
const DropCreator = new Giveaway.DropCreator(client, 'mongodb://...');
Drop Methods
createDrop(options)
Creates a drop. Example:
const channel = message.mentions.channels.first();
const newDrop = await DropCreator.createDrop({
prize: 'Discord Nitro',
guildId: message.guild.id,
channelId: channel.id,
createdBy: message.author.id
});
message.channel.send(`Created a drop in ${channel}. The prize is **${newDrop.prize}**`);
deleteDrop(guildId, position)
Deletes a drop. Find the position by using the listDrops() method.
const args = message.content.split(' ').slice(1);
const deleted = await DropCreator.deleteDrop(message.guild.id, parseInt(args[0]));
if (!deleted) {
return message.channel.send('Doesn\'t exist :/');
}
message.channel.send('Deleted the Drop');
listDrops(guildId)
Lists all the drops in a guild.
const { MessageEmbed } = require('discord.js');
const list = await DropCreator.listDrops(message.guild.id);
if (!list) {
return message.channel.send('No Drops :/');
}
const mapped = list.map(i => `**${i.position}.** Channel: ${i.channel} | Prize: ${i.prize}`);
const embed = new MessageEmbed()
.setTitle('List of Drops')
.setDescription(`${mapped.join('\n')}`)
.setColor(message.guild.me.roles.highest.hexColor)
.setFooter(client.user.tag, client.user.displayAvatarURL({ format: 'png', size: 512 }));
message.channel.send(embed);
Events
Here are some events you can use for the drops and giveaways.
const { Client } = require('discord.js');
const client = new Client();
const { GiveawayCreator, DropCreator } = require('discord-giveaway');
const giveaways = new GiveawayCreator(client, 'mongodb://...');
const drops = new DropCreator(client, 'mongodb://...');
client.login('some-token');
DropCreator.on('dropCreate', drop => console.log(`New drop created with the prize of ${drop.prize}`));
DropCreator.on('dropDelete', drop => console.log(`Deleted the ${drop.prize} drop.`));
DropCreator.on('wonDrop', drop => console.log(`Someone won the ${drop.prize} drop.`));
GiveawayCreator.on('giveawayEnd', giveaway => {
console.log(`The ${giveaway.prize} giveaway has ended at ${giveaway.endsOn}.`);
});
GiveawayCreator.on('giveawayStart', giveaway => {
console.log(`${giveaway.prize} giveaway has been scheduled for ${giveaway.endsOn}.`);
});
GiveawayCreator.on('giveawayReroll', giveaway => {
console.log(`Rerolled the ${giveaway.prize} giveaway.`);
});
Properties
Giveaway Properties
guildId
The guild ID of the giveaway.
channelId
The channel ID of the giveaway.
hostedBy
The ID of the person who hosted the giveaway.
messageId
The message ID of the giveaway.
startsOn
A date of when the giveaway started.
endsOn
A date of when the giveaway will end.
winners
The amount of winners the giveaway can have.
hasEnded
Whether the giveaway has ended.
duration
The duration of the giveaway in milliseconds.
prize
The prize of the giveaway.
Drop Properties
guildId
The guild ID of the drop.
channelId
The channel ID of the drop.
prize
The prize of the drop.
createdBy
The ID of the person who created the drop.
timeCreated
The date when the drop was created.
position
The position of the drop.