mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-14 08:08:34 +02:00
Revert some stuff
This commit is contained in:
@@ -55,6 +55,7 @@ module.exports = class AkinatorCommand extends Command {
|
||||
await msg.embed(embed);
|
||||
const verification = await verify(msg.channel, msg.author);
|
||||
this.sessions.delete(msg.channel.id);
|
||||
if (verification === 0) return msg.reply('I guess your silence means I have won.');
|
||||
if (!verification) return msg.say('Bravo, you have defeated me.');
|
||||
return msg.say('Guessed right one more time! I love playing with you!');
|
||||
} catch (err) {
|
||||
|
||||
@@ -52,6 +52,7 @@ module.exports = class HangmanCommand extends Command {
|
||||
if (choice.length > 1) {
|
||||
if (word === choice) break;
|
||||
else await msg.say('Nope, that\'s not the word, try again!');
|
||||
points++;
|
||||
} else if (confirmation.includes(choice) || incorrect.includes(choice)) {
|
||||
await msg.say('You have already picked that letter!');
|
||||
} else if (word.includes(choice)) {
|
||||
|
||||
@@ -0,0 +1,176 @@
|
||||
const { Command } = require('discord.js-commando');
|
||||
const { Collection } = require('discord.js');
|
||||
const { stripIndents } = require('common-tags');
|
||||
const { shuffle, list, wait } = require('../../util/Util');
|
||||
const { questions, stories } = require('../../assets/json/wizard-convention');
|
||||
|
||||
module.exports = class WizardConventionCommand extends Command {
|
||||
constructor(client) {
|
||||
super(client, {
|
||||
name: 'wizard-convention',
|
||||
group: 'games',
|
||||
memberName: 'wizard-convention',
|
||||
description: 'Who is the Dragon? Who is the healer? Who is the mind reader? Will the Dragon eat them all?',
|
||||
guildOnly: true
|
||||
});
|
||||
|
||||
this.playing = new Set();
|
||||
}
|
||||
|
||||
async run(msg) { // eslint-disable-line complexity
|
||||
if (this.playing.has(msg.channel.id)) return msg.say('Only one game may be occurring per channel.');
|
||||
try {
|
||||
await msg.say('You will need at least 2 more players, type `join game` to join the game.');
|
||||
const joined = [];
|
||||
const filter = res => {
|
||||
if (res.author.id === msg.author.id) return false;
|
||||
if (joined.includes(res.author.id)) return false;
|
||||
if (['join game', 'join convention'].includes(res.content.toLowerCase())) {
|
||||
joined.push(res.author.id);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
};
|
||||
const verify = await msg.channel.awaitMessages(filter, { time: 30000 });
|
||||
if (verify.size < 2) {
|
||||
this.playing.delete(msg.channel.id);
|
||||
return msg.say('Game could not be started...');
|
||||
}
|
||||
let roles = ['dragon', 'healer', 'mind reader'];
|
||||
for (let i = 0; i < (verify.size - 2); i++) roles.push(`pleb ${i + 1}`);
|
||||
roles = shuffle(roles);
|
||||
const players = new Collection();
|
||||
players.set(msg.author.id, {
|
||||
user: msg.author,
|
||||
role: roles[0]
|
||||
});
|
||||
await msg.author.send(`You are ${roles[0].includes('pleb') ? 'a pleb.' : `the ${roles[0]}!`}`);
|
||||
let i = 1;
|
||||
for (const message of verify.values()) {
|
||||
players.set(message.author.id, {
|
||||
user: message.author,
|
||||
role: roles[i]
|
||||
});
|
||||
await message.author.send(`You are ${roles[i].includes('pleb') ? 'a pleb.' : `the ${roles[i]}!`}`);
|
||||
i++;
|
||||
}
|
||||
let night = 1;
|
||||
let win = false;
|
||||
let skips = 0;
|
||||
while (players.size > 2) {
|
||||
if (skips > 3) return msg.say('Game ended after too many skips.');
|
||||
let eaten = null;
|
||||
let healed = null;
|
||||
await msg.say(`Night ${night++}... Sending DMs...`);
|
||||
for (const player of players.values()) {
|
||||
if (player.role.includes('pleb')) continue;
|
||||
const playerList = players.filter(p => p.role !== player.role).map(p => p.user.tag);
|
||||
await player.user.send(`${questions[player.role]} ${list(playerList, 'or')}?`);
|
||||
const decision = await player.user.dmChannel.awaitMessages(res => playerList.includes(res.content), {
|
||||
max: 1,
|
||||
time: 30000
|
||||
});
|
||||
if (!decision.size) {
|
||||
await player.user.send('Skipping your turn...');
|
||||
++skips;
|
||||
continue;
|
||||
}
|
||||
const choice = decision.first().content;
|
||||
if (player.role === 'dragon') {
|
||||
const found = players.find(p => p.user.tag === choice);
|
||||
eaten = found.user.id;
|
||||
await player.user.send(`${choice} will be eaten...`);
|
||||
} else if (player.role === 'healer') {
|
||||
const found = players.find(p => p.user.tag === choice);
|
||||
healed = found.user.id;
|
||||
await player.user.send(`${choice} will be healed...`);
|
||||
} else if (player.role === 'mind reader') {
|
||||
const dragon = players.find('role', 'dragon');
|
||||
const found = players.find(p => p.user.tag === choice);
|
||||
await player.user.send(dragon.user.id === found.user.id ? 'Yes.' : 'No.');
|
||||
}
|
||||
}
|
||||
const display = eaten ? players.get(eaten).user : null;
|
||||
if (eaten && eaten !== healed) {
|
||||
const found = players.find(p => p.user.id === eaten);
|
||||
players.delete(found.user.id);
|
||||
}
|
||||
const story = stories[Math.floor(Math.random() * stories.length)];
|
||||
if (eaten && eaten === healed) {
|
||||
await msg.say(stripIndents`
|
||||
Late last night, a dragon emerged and tried to eat ${display}${story}
|
||||
Thankfully, a healer stepped in just in time to save the day.
|
||||
Who is this mysterious dragon? You have one minute to argue your case.
|
||||
`);
|
||||
} else if (eaten && players.size < 3) {
|
||||
await msg.say(stripIndents`
|
||||
Late last night, a dragon emerged and devoured poor ${display}${story}
|
||||
Sadly, after the event, the final wizard ran in fear, leaving the dragon to rule forever.
|
||||
`);
|
||||
break;
|
||||
} else if (eaten && eaten !== healed) {
|
||||
await msg.say(stripIndents`
|
||||
Late last night, a dragon emerged and devoured poor ${display}${story}
|
||||
Who is this mysterious dragon? You have one minute to argue your case.
|
||||
`);
|
||||
} else {
|
||||
await msg.say(stripIndents`
|
||||
Late last night, a dragon emerged. Thankfully, however, it didn't try to eat anyone.
|
||||
Who is this mysterious dragon? You have one minute to argue your case.
|
||||
`);
|
||||
}
|
||||
await wait(60000);
|
||||
await msg.say('Time is up!');
|
||||
const voteCounts = new Collection();
|
||||
const voted = [];
|
||||
const playerList = players.map(p => p.user.tag);
|
||||
const filter2 = res => {
|
||||
if (!players.has(res.author.id)) return false;
|
||||
if (voted.includes(res.author.id)) return false;
|
||||
if (playerList.includes(res.content)) {
|
||||
voted.push(res.author.id);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
};
|
||||
await msg.say(`Who is the dragon? ${list(playerList, 'or')}?`);
|
||||
const votes = await msg.channel.awaitMessages(filter2, { time: 30000 });
|
||||
for (const vote of votes.values()) {
|
||||
for (const player of players.values()) {
|
||||
if (!player.user.tag.includes(vote.content)) continue;
|
||||
const existing = voteCounts.get(player.user.id);
|
||||
if (existing) {
|
||||
++existing.votes;
|
||||
} else {
|
||||
voteCounts.set(player.user.id, {
|
||||
votes: 1,
|
||||
user: player.user
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
if (!voteCounts.size) {
|
||||
await msg.say('No one will be expelled.');
|
||||
++skips;
|
||||
continue;
|
||||
}
|
||||
const expelled = voteCounts.sort((a, b) => b.votes - a.votes).first();
|
||||
await msg.say(`${expelled.user} will be expelled.`);
|
||||
if (players.find('role', 'dragon').user.id === expelled.user.id) {
|
||||
win = true;
|
||||
break;
|
||||
} else {
|
||||
const found = players.find(player => player.user.id === expelled.id);
|
||||
players.delete(found.user.id);
|
||||
}
|
||||
}
|
||||
this.playing.delete(msg.channel.id);
|
||||
if (win) return msg.say('The dragon is dead! Thanks for playing!');
|
||||
const dragon = players.find('role', 'dragon');
|
||||
return msg.say(`Oh no... The dragon wasn't caught in time... Nice job, ${dragon.user}!`);
|
||||
} catch (err) {
|
||||
this.playing.delete(msg.channel.id);
|
||||
return msg.say(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
||||
}
|
||||
}
|
||||
};
|
||||
@@ -24,22 +24,22 @@ module.exports = class ServerInfoCommand extends Command {
|
||||
msg.guild.name, true)
|
||||
.addField('❯ ID',
|
||||
msg.guild.id, true)
|
||||
.addField('❯ Shard',
|
||||
this.client.shard.id, true)
|
||||
.addField('❯ Region',
|
||||
msg.guild.region.toUpperCase(), true)
|
||||
.addField('❯ Creation Date',
|
||||
msg.guild.createdAt.toDateString(), true)
|
||||
.addField('❯ Explicit Filter',
|
||||
filterLevels[msg.guild.explicitContentFilter], true)
|
||||
.addField('❯ Verification Level',
|
||||
verificationLevels[msg.guild.verificationLevel], true)
|
||||
.addField('❯ Region',
|
||||
msg.guild.region.toUpperCase(), true)
|
||||
.addField('❯ Owner',
|
||||
msg.guild.owner ? msg.guild.owner.user.tag : 'None', true)
|
||||
.addField('❯ Channels',
|
||||
msg.guild.channels.size, true)
|
||||
.addField('❯ Members',
|
||||
msg.guild.memberCount, true);
|
||||
msg.guild.memberCount, true)
|
||||
.addField('❯ Roles',
|
||||
msg.guild.roles.size, true)
|
||||
.addField('❯ Channels',
|
||||
msg.guild.channels.size, true);
|
||||
return msg.embed(embed);
|
||||
}
|
||||
};
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
const { Command } = require('discord.js-commando');
|
||||
const snekfetch = require('snekfetch');
|
||||
const { stripIndents } = require('common-tags');
|
||||
|
||||
module.exports = class DanbooruCommand extends Command {
|
||||
constructor(client) {
|
||||
@@ -34,10 +33,7 @@ module.exports = class DanbooruCommand extends Command {
|
||||
limit: 1
|
||||
});
|
||||
if (!body.length || !body[0].file_url) return msg.say('Could not find any results.');
|
||||
return msg.say(stripIndents`
|
||||
Result for ${query}:
|
||||
https://danbooru.donmai.us${body[0].file_url}
|
||||
`);
|
||||
return msg.say(`https://danbooru.donmai.us${body[0].file_url}`);
|
||||
} catch (err) {
|
||||
return msg.say(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
||||
}
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
const { Command } = require('discord.js-commando');
|
||||
const snekfetch = require('snekfetch');
|
||||
const { stripIndents } = require('common-tags');
|
||||
|
||||
module.exports = class DerpibooruCommand extends Command {
|
||||
constructor(client) {
|
||||
@@ -30,10 +29,7 @@ module.exports = class DerpibooruCommand extends Command {
|
||||
});
|
||||
if (!search.body) return msg.say('Could not find any results.');
|
||||
const { body } = await snekfetch.get(`https://derpibooru.org/images/${search.body.id}.json`);
|
||||
return msg.say(stripIndents`
|
||||
Result for ${query}:
|
||||
https:${body.representations.medium}
|
||||
`);
|
||||
return msg.say(`https:${body.representations.medium}`);
|
||||
} catch (err) {
|
||||
return msg.say(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
||||
}
|
||||
|
||||
@@ -1,7 +1,6 @@
|
||||
const { Command } = require('discord.js-commando');
|
||||
const snekfetch = require('snekfetch');
|
||||
const { xml2js } = require('xml-js');
|
||||
const { stripIndents } = require('common-tags');
|
||||
|
||||
module.exports = class GelbooruCommand extends Command {
|
||||
constructor(client) {
|
||||
@@ -34,10 +33,7 @@ module.exports = class GelbooruCommand extends Command {
|
||||
});
|
||||
const parsed = xml2js(text, { compact: true }).posts;
|
||||
if (!parsed.post || !parsed.post.length) return msg.say('Could not find any results.');
|
||||
return msg.say(stripIndents`
|
||||
Result for ${query}:
|
||||
${parsed.post[Math.floor(Math.random() * parsed.post.length)]._attributes.file_url}
|
||||
`);
|
||||
return msg.say(`${parsed.post[Math.floor(Math.random() * parsed.post.length)]._attributes.file_url}`);
|
||||
} catch (err) {
|
||||
return msg.say(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
||||
}
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
const { Command } = require('discord.js-commando');
|
||||
const snekfetch = require('snekfetch');
|
||||
const { stripIndents } = require('common-tags');
|
||||
|
||||
module.exports = class KonachanCommand extends Command {
|
||||
constructor(client) {
|
||||
@@ -30,10 +29,7 @@ module.exports = class KonachanCommand extends Command {
|
||||
limit: 1
|
||||
});
|
||||
if (!body.length || !body[0].file_url) return msg.say('Could not find any results.');
|
||||
return msg.say(stripIndents`
|
||||
Result for ${query}:
|
||||
https:${body[0].file_url}
|
||||
`);
|
||||
return msg.say(`https:${body[0].file_url}`);
|
||||
} catch (err) {
|
||||
return msg.say(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
||||
}
|
||||
|
||||
@@ -1,7 +1,6 @@
|
||||
const { Command } = require('discord.js-commando');
|
||||
const snekfetch = require('snekfetch');
|
||||
const { xml2js } = require('xml-js');
|
||||
const { stripIndents } = require('common-tags');
|
||||
|
||||
module.exports = class SafebooruCommand extends Command {
|
||||
constructor(client) {
|
||||
@@ -33,10 +32,7 @@ module.exports = class SafebooruCommand extends Command {
|
||||
});
|
||||
const parsed = xml2js(text, { compact: true }).posts;
|
||||
if (!parsed.post || !parsed.post.length) return msg.say('Could not find any results.');
|
||||
return msg.say(stripIndents`
|
||||
Result for ${query}:
|
||||
https:${parsed.post[Math.floor(Math.random() * parsed.post.length)]._attributes.file_url}
|
||||
`);
|
||||
return msg.say(`https:${parsed.post[Math.floor(Math.random() * parsed.post.length)]._attributes.file_url}`);
|
||||
} catch (err) {
|
||||
return msg.say(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
||||
}
|
||||
|
||||
@@ -27,7 +27,7 @@ module.exports = class PortalSendCommand extends Command {
|
||||
async run(msg, { text }) {
|
||||
const valid = this.client.channels.filter(channel => channel.type === 'text' && channel.guild.id !== msg.guild.id);
|
||||
const channels = valid.filter(channel => channel.topic && channel.topic.toLowerCase().includes('<portal>'));
|
||||
if (!channels.size) return msg.say('No channels on this shard have an open portal.');
|
||||
if (!channels.size) return msg.say('No channels have an open portal.');
|
||||
const channel = channels.random();
|
||||
try {
|
||||
await channel.send(`**${msg.author.tag} (${msg.guild.name})**: ${text}`);
|
||||
|
||||
@@ -16,13 +16,12 @@ module.exports = class InfoCommand extends Command {
|
||||
});
|
||||
}
|
||||
|
||||
async run(msg) {
|
||||
const guilds = await this.client.shard.fetchClientValues('guilds.size');
|
||||
run(msg) {
|
||||
const embed = new MessageEmbed()
|
||||
.setColor(0x00AE86)
|
||||
.setFooter('©2017 dragonfire535#8081')
|
||||
.addField('❯ Servers',
|
||||
guilds.reduce((prev, val) => prev + val, 0), true)
|
||||
this.client.guilds.size, true)
|
||||
.addField('❯ Home Server',
|
||||
`[Here](https://${this.client.options.invite})`, true)
|
||||
.addField('❯ Invite',
|
||||
|
||||
@@ -7,7 +7,7 @@ module.exports = class UptimeCommand extends Command {
|
||||
name: 'uptime',
|
||||
group: 'util',
|
||||
memberName: 'uptime',
|
||||
description: 'Responds with how long the bot has been active on this Shard.',
|
||||
description: 'Responds with how long the bot has been active.',
|
||||
guarded: true
|
||||
});
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user