mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-12 15:57:43 +02:00
One function to rule them all
This commit is contained in:
@@ -23,9 +23,8 @@ module.exports = class NeopetItemCommand extends Command {
|
|||||||
|
|
||||||
async run(msg, { item }) {
|
async run(msg, { item }) {
|
||||||
try {
|
try {
|
||||||
const search = await this.fetchItem(item);
|
const data = await this.fetchItem(item);
|
||||||
if (!search) return msg.say('Could not find any results');
|
if (!data) return msg.say('Could not find any results');
|
||||||
const data = await this.fetchItemDetails(search);
|
|
||||||
const embed = new MessageEmbed()
|
const embed = new MessageEmbed()
|
||||||
.setColor(0xFFCE31)
|
.setColor(0xFFCE31)
|
||||||
.setAuthor('Neopets', 'https://i.imgur.com/BP8qxJH.png', 'http://www.neopets.com/')
|
.setAuthor('Neopets', 'https://i.imgur.com/BP8qxJH.png', 'http://www.neopets.com/')
|
||||||
@@ -51,21 +50,16 @@ module.exports = class NeopetItemCommand extends Command {
|
|||||||
const id = text.match(/\/item\/([0-9]+)/);
|
const id = text.match(/\/item\/([0-9]+)/);
|
||||||
if (!id) return null;
|
if (!id) return null;
|
||||||
const price = text.match(/([0-9,]+) (NP|NC)/);
|
const price = text.match(/([0-9,]+) (NP|NC)/);
|
||||||
|
const url = `https://items.jellyneo.net/item/${id[1]}/`;
|
||||||
|
const details = await snekfetch.get(url);
|
||||||
return {
|
return {
|
||||||
id: id[1],
|
id: id[1],
|
||||||
url: `https://items.jellyneo.net/item/${id[1]}/`,
|
url,
|
||||||
|
name: details.text.match(/<h1>(.+)<\/h1>/)[1],
|
||||||
|
details: details.text.match(/<em>(.+)<\/em>/)[1],
|
||||||
image: `https://items.jellyneo.net/assets/imgs/items/${id[1]}.gif`,
|
image: `https://items.jellyneo.net/assets/imgs/items/${id[1]}.gif`,
|
||||||
price: price ? Number.parseInt(price[1].replace(/,/g, ''), 10) : null,
|
price: price ? Number.parseInt(price[1].replace(/,/g, ''), 10) : null,
|
||||||
currency: price ? price[2] : null
|
currency: price ? price[2] : null
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
async fetchItemDetails(item) {
|
|
||||||
const { text } = await snekfetch.get(item.url);
|
|
||||||
return {
|
|
||||||
...item,
|
|
||||||
name: text.match(/<h1>(.+)<\/h1>/)[1],
|
|
||||||
details: text.match(/<em>(.+)<\/em>/)[1]
|
|
||||||
};
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user