Merge soundboard and airhorn, aliases, improve command formats

This commit is contained in:
Daniel Odendahl Jr
2018-07-02 00:46:07 +00:00
parent a96b8f1667
commit 0d453ff5e1
23 changed files with 11 additions and 52 deletions
+1 -2
View File
@@ -33,8 +33,7 @@ module.exports = class NekoAtsumePasswordCommand extends Command {
The current Neko Atsume password is **${data.password}**.
It will expire in **${duration(data.expires - data.date)}**.
${data.gold} ${this.goldFish}
${data.silver} ${this.silverFish}
${data.gold} ${this.goldFish} ${data.silver} ${this.silverFish}
`);
} catch (err) {
return msg.reply(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
+1 -1
View File
@@ -6,7 +6,7 @@ module.exports = class RedditCommand extends Command {
constructor(client) {
super(client, {
name: 'reddit',
aliases: ['subreddit'],
aliases: ['subreddit', 'r/'],
group: 'random',
memberName: 'reddit',
description: 'Responds with a random post from a subreddit.',
+1
View File
@@ -10,6 +10,7 @@ module.exports = class FlickrCommand extends Command {
group: 'search',
memberName: 'flickr',
description: 'Searches Flickr for your query.',
nsfw: true,
args: [
{
key: 'query',
+1 -1
View File
@@ -5,7 +5,7 @@ module.exports = class Rule34Command extends Command {
constructor(client) {
super(client, {
name: 'rule34',
aliases: ['rule34-image'],
aliases: ['rule34-image', 'r34'],
group: 'search',
memberName: 'rule34',
description: 'Responds with an image from Rule34, with optional query.',
+2 -2
View File
@@ -6,7 +6,7 @@ module.exports = class WikihowCommand extends Command {
constructor(client) {
super(client, {
name: 'wikihow',
aliases: ['wikihow-article', 'how-to'],
aliases: ['wikihow-article', 'how-to', 'how'],
group: 'search',
memberName: 'wikihow',
description: 'Searches Wikihow for your query.',
@@ -15,7 +15,7 @@ module.exports = class WikihowCommand extends Command {
key: 'query',
prompt: 'What article would you like to search for?',
type: 'string',
parse: query => query.replace(/^(how to)/i, '')
parse: query => query.replace(/^((how )?to)/i, '')
}
]
});
-41
View File
@@ -1,41 +0,0 @@
const Command = require('../../structures/Command');
const fs = require('fs');
const path = require('path');
const sounds = fs.readdirSync(path.join(__dirname, '..', '..', 'assets', 'sounds', 'airhorn'));
module.exports = class AirhornCommand extends Command {
constructor(client) {
super(client, {
name: 'airhorn',
group: 'voice',
memberName: 'airhorn',
description: 'Plays an airhorn sound in your voice channel.',
guildOnly: true,
throttling: {
usages: 1,
duration: 10
}
});
}
async run(msg) {
const channel = msg.member.voiceChannel;
if (!channel) return msg.reply('Please enter a voice channel first.');
if (!channel.permissionsFor(this.client.user).has(['CONNECT', 'SPEAK'])) {
return msg.reply('Missing the "Connect" or "Speak" permission for the voice channel.');
}
if (!channel.joinable) return msg.reply('Your voice channel is not joinable.');
if (this.client.voiceConnections.has(channel.guild.id)) return msg.reply('I am already playing a sound.');
try {
const connection = await channel.join();
const airhorn = sounds[Math.floor(Math.random() * sounds.length)];
const dispatcher = connection.play(path.join(__dirname, '..', '..', 'assets', 'sounds', 'airhorn', airhorn));
dispatcher.once('finish', () => channel.leave());
dispatcher.once('error', () => channel.leave());
return null;
} catch (err) {
channel.leave();
throw err;
}
}
};