mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-04 15:56:52 +02:00
Add MissingNo.
This commit is contained in:
@@ -0,0 +1,26 @@
|
||||
{
|
||||
"names": [
|
||||
{
|
||||
"language": "en",
|
||||
"name": "MissingNo."
|
||||
},
|
||||
{
|
||||
"language": "ja",
|
||||
"name": "けつばん"
|
||||
}
|
||||
],
|
||||
"flavor_text_entries": [
|
||||
{
|
||||
"language": "en",
|
||||
"flavor_text": "Comment to be written."
|
||||
}
|
||||
],
|
||||
"id": 0,
|
||||
"genera": [
|
||||
{
|
||||
"language": "en",
|
||||
"genus": "???"
|
||||
}
|
||||
],
|
||||
"missingno": true
|
||||
}
|
||||
@@ -49,7 +49,7 @@ module.exports = class WhosThatPokemonCommand extends Command {
|
||||
}
|
||||
|
||||
async run(msg, { difficulty }) {
|
||||
const pokemon = Math.floor(Math.random() * 807) + 1;
|
||||
const pokemon = Math.floor(Math.random() * 808);
|
||||
try {
|
||||
const data = await this.client.pokemon.fetch(pokemon.toString());
|
||||
const names = data.names.map(name => name.name.toLowerCase());
|
||||
|
||||
+1
-1
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "xiao",
|
||||
"version": "112.14.1",
|
||||
"version": "112.14.2",
|
||||
"description": "Your personal server companion.",
|
||||
"main": "Xiao.js",
|
||||
"scripts": {
|
||||
|
||||
@@ -9,6 +9,7 @@ module.exports = class Pokemon {
|
||||
.map(entry => entry.flavor_text.replace(/\n|\f|\r/g, ' ')));
|
||||
this.names = data.names.map(entry => ({ name: entry.name, language: entry.language.name }));
|
||||
this.genus = `The ${data.genera.filter(entry => entry.language.name === 'en')[0].genus}`;
|
||||
this.missingno = data.missingno || false;
|
||||
}
|
||||
|
||||
get displayID() {
|
||||
@@ -20,14 +21,17 @@ module.exports = class Pokemon {
|
||||
}
|
||||
|
||||
get spriteImageURL() {
|
||||
if (this.missingno) return 'https://cdn.bulbagarden.net/upload/9/98/Missingno_RB.png';
|
||||
return `https://www.serebii.net/sunmoon/pokemon/${this.displayID}.png`;
|
||||
}
|
||||
|
||||
get boxImageURL() {
|
||||
if (this.missingno) return 'https://cdn.bulbagarden.net/upload/1/1f/AniMS_Missingno_I.png';
|
||||
return `https://www.serebii.net/pokedex-sm/icon/${this.displayID}.png`;
|
||||
}
|
||||
|
||||
get serebiiURL() {
|
||||
if (this.missingno) return 'https://bulbapedia.bulbagarden.net/wiki/MissingNo.';
|
||||
return `https://www.serebii.net/pokedex-sm/${this.displayID}.shtml`;
|
||||
}
|
||||
};
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
const Collection = require('@discordjs/collection');
|
||||
const request = require('node-superfetch');
|
||||
const Pokemon = require('./Pokemon');
|
||||
const missingno = require('../../assets/json/missingno');
|
||||
|
||||
module.exports = class PokemonStore extends Collection {
|
||||
async fetch(query) {
|
||||
@@ -9,6 +10,11 @@ module.exports = class PokemonStore extends Collection {
|
||||
if (this.has(num)) return this.get(num);
|
||||
const found = this.find(pokemon => pokemon.slug === query);
|
||||
if (found) return found;
|
||||
if (query === 'missingno' || num === 0) {
|
||||
const pokemon = new Pokemon(missingno);
|
||||
this.set(pokemon.id, pokemon);
|
||||
return pokemon;
|
||||
}
|
||||
const { body } = await request.get(`https://pokeapi.co/api/v2/pokemon-species/${query}/`);
|
||||
const pokemon = new Pokemon(body);
|
||||
this.set(pokemon.id, pokemon);
|
||||
|
||||
Reference in New Issue
Block a user