parent
8a6f82374f
commit
88d9c7d43b
@ -0,0 +1,83 @@ |
|||||||
|
const Discord = require('discord.js'); |
||||||
|
|
||||||
|
const AniData = require("../../models/anime"); |
||||||
|
const UserData = require('../../models/user'); |
||||||
|
const CharData = require('../../models/char'); |
||||||
|
|
||||||
|
const {Pagination} = require('../../util/pagination'); |
||||||
|
const {Tag} = require('../../util/tag'); |
||||||
|
const {TagFilter} = require('../../util/tagfilter'); |
||||||
|
|
||||||
|
module.exports = { |
||||||
|
name: "anipulse", |
||||||
|
aliases: ['ap'], |
||||||
|
meta: { |
||||||
|
category: 'Developer', |
||||||
|
description: "Get a pulse check of anime", |
||||||
|
syntax: '`anipulse`', |
||||||
|
extra: null |
||||||
|
}, |
||||||
|
help: "Not much to see here!", |
||||||
|
async execute(message, msg, args, cmd, prefix, mention, client) { |
||||||
|
let tu = await UserData.findOne({uid: message.author.id}); |
||||||
|
if (!tu || !tu.staff) {return message.channel.send("You must be Natsuki staff in order to use this command.");} |
||||||
|
|
||||||
|
let sm = await message.channel.send("One moment while I gather that information for you..."); |
||||||
|
|
||||||
|
let options = new TagFilter([ |
||||||
|
new Tag(['c', 'ch', 'char', 'chars', 'character', 'characters'], 'chars', 'append'), |
||||||
|
new Tag(['a', 'ani', 'anime'], 'anime', 'append') |
||||||
|
]).test(args.join(" ")); |
||||||
|
Object.keys(options).forEach(o => {if (isNaN(Number(options[o]))) {delete options[o];}}); |
||||||
|
|
||||||
|
let ani = client.misc.cache.animeID.size; |
||||||
|
let char = client.misc.cache.charsID.size; |
||||||
|
let nick = Array.from(client.misc.cache.chars.keys()).filter(x => !Array.from(client.misc.cache.charsID.values()).includes(x)).length; |
||||||
|
|
||||||
|
let charThresh = (options.chars !== undefined ? Number(options.chars) : 2); |
||||||
|
let aniThresh = (options.anime !== undefined ? Number(options.anime) : 15); |
||||||
|
|
||||||
|
let lowChars = []; |
||||||
|
for await (const ani of AniData.find()) { |
||||||
|
if (ani.characters.length < aniThresh) {lowChars.push(ani);} |
||||||
|
} |
||||||
|
|
||||||
|
let lowIms = []; |
||||||
|
for await (const char of CharData.find()) { |
||||||
|
if (char.images.length < charThresh) {lowIms.push(char);} |
||||||
|
} |
||||||
|
|
||||||
|
let pages = [new Discord.MessageEmbed() |
||||||
|
.setTitle("Anime Database Pulse Check") |
||||||
|
.setDescription(`**${ani}** Anime\n**${char}** Characters\n**${nick}** Nicknames`) |
||||||
|
.addField(`Anime with < ${aniThresh} character${client.utils.s(aniThresh)}`, `${lowChars.length}`) |
||||||
|
.addField(`Characters with < ${charThresh} extra image${client.utils.s(charThresh)}`, `${lowIms.length}`) |
||||||
|
.setColor('c375f0') |
||||||
|
]; |
||||||
|
|
||||||
|
let ma = Math.floor(lowIms.length / 10); |
||||||
|
for (let i = 0; i < ma; i++) { |
||||||
|
if (!lowChars.slice(10 * i, Math.min((10 * i) + 10, lowChars.length)).length) {break;} |
||||||
|
pages.push(new Discord.MessageEmbed() |
||||||
|
.setTitle("Anime Database Pulse Check") |
||||||
|
.setDescription(`**${ani}** Anime\n**${char}** Characters\n**${nick}** Nicknames`) |
||||||
|
.addField(`Anime with < ${aniThresh} character${client.utils.s(aniThresh)}`, lowChars.slice(10 * i, Math.min((10 * i) + 10, lowChars.length)).filter(x=>![null,undefined].includes(x)).map((ani, y) => `${(10*i)+y+1}. ${ani.name} -> **${ani.characters.length}** Char${client.utils.s(ani.characters.length)}.`).join('\n')) |
||||||
|
.setColor('c375f0') |
||||||
|
);} |
||||||
|
|
||||||
|
let mc = Math.floor(lowIms.length / 10); |
||||||
|
for (let i = 0; i < mc; i++) { |
||||||
|
if (!lowIms.slice(10 * i, Math.min((10 * i) + 10, lowIms.length)).length) {break;} |
||||||
|
pages.push(new Discord.MessageEmbed() |
||||||
|
.setTitle("Anime Database Pulse Check") |
||||||
|
.setDescription(`**${ani}** Anime\n**${char}** Characters\n**${nick}** Nicknames`) |
||||||
|
.addField(`Characters with < ${charThresh} extra image${client.utils.s(charThresh)}`, lowIms.slice(10 * i, Math.min((10 * i) + 10, lowIms.length)).filter(x=>![null,undefined].includes(x)).map((ch, y) => `${(10*i)+y+1}. ${ch.name} -> **${ch.images.length}** Image${client.utils.s(ch.images.length)}.`).join('\n')) |
||||||
|
.setColor('c375f0') |
||||||
|
);} |
||||||
|
|
||||||
|
const pag = new Pagination(message.channel, pages, message, client, true); |
||||||
|
sm.delete().catch(() => {}); |
||||||
|
|
||||||
|
return await pag.start({user: message.author.id, time: 60000}); |
||||||
|
} |
||||||
|
}; |
Loading…
Reference in new issue