Replace developers, genres and franchise ID with text
This commit is contained in:
parent
2a09c7a0f7
commit
ec25605a8a
|
@ -1,5 +1,5 @@
|
||||||
const { SlashCommandBuilder, EmbedBuilder } = require('discord.js');
|
const { SlashCommandBuilder, EmbedBuilder } = require('discord.js');
|
||||||
const { getCoverURL, getGameJson } = require('../../igdbHelperFunctions.js');
|
const { getCoverURL, getGameJson, getCompanyInfo, getGenres, getFranchise } = require('../../igdbHelperFunctions.js');
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
data: new SlashCommandBuilder()
|
data: new SlashCommandBuilder()
|
||||||
|
@ -7,6 +7,7 @@ module.exports = {
|
||||||
.setDescription('Get the details of a given game.')
|
.setDescription('Get the details of a given game.')
|
||||||
.addStringOption(option => option.setName('gamename').setDescription('The name of the game.'))
|
.addStringOption(option => option.setName('gamename').setDescription('The name of the game.'))
|
||||||
.addNumberOption(option => option.setName('gameid').setDescription('The IGDB game id.').setMinValue(0)),
|
.addNumberOption(option => option.setName('gameid').setDescription('The IGDB game id.').setMinValue(0)),
|
||||||
|
|
||||||
async execute(interaction) {
|
async execute(interaction) {
|
||||||
const gamename = interaction.options.getString('gamename');
|
const gamename = interaction.options.getString('gamename');
|
||||||
const gameid = interaction.options.getNumber('gameid');
|
const gameid = interaction.options.getNumber('gameid');
|
||||||
|
@ -18,12 +19,12 @@ module.exports = {
|
||||||
if (gameid) {
|
if (gameid) {
|
||||||
await interaction.reply(`Searching for ${gameid}...`);
|
await interaction.reply(`Searching for ${gameid}...`);
|
||||||
body = body.concat('where id = ', gameid, '; ');
|
body = body.concat('where id = ', gameid, '; ');
|
||||||
|
body = body.concat('fields *;');
|
||||||
} else if (gamename) {
|
} else if (gamename) {
|
||||||
await interaction.reply(`Searching for ${gamename}...`);
|
await interaction.reply(`Searching for ${gamename}...`);
|
||||||
body = body.concat('search "', gamename, '"; ');
|
body = body.concat('search "', gamename, '"; ');
|
||||||
}
|
|
||||||
|
|
||||||
body = body.concat('fields *; limit 25; where (category = 0 | category = 4) & version_parent = null;');
|
body = body.concat('fields *; limit 25; where (category = 0 | category = 4) & version_parent = null;');
|
||||||
|
}
|
||||||
|
|
||||||
const games = await getGameJson(body);
|
const games = await getGameJson(body);
|
||||||
|
|
||||||
|
@ -37,21 +38,37 @@ module.exports = {
|
||||||
|
|
||||||
const release_date = new Intl.DateTimeFormat('en-GB', { dateStyle: 'full' }).format(game.first_release_date * 1000);
|
const release_date = new Intl.DateTimeFormat('en-GB', { dateStyle: 'full' }).format(game.first_release_date * 1000);
|
||||||
|
|
||||||
|
const companies = [];
|
||||||
|
for (const company of game.involved_companies) {
|
||||||
|
const info = await getCompanyInfo(company);
|
||||||
|
companies.push(info.name);
|
||||||
|
}
|
||||||
|
|
||||||
|
const genres = [];
|
||||||
|
for (const genreId of game.genres) {
|
||||||
|
const genre = await getGenres(genreId);
|
||||||
|
genres.push(genre);
|
||||||
|
}
|
||||||
|
|
||||||
const embed = new EmbedBuilder()
|
const embed = new EmbedBuilder()
|
||||||
.setColor(0x6441a5)
|
.setColor(0x6441a5)
|
||||||
.setTitle(`${game.name}`)
|
.setTitle(`${game.name}`)
|
||||||
.setURL(`${game.url}`)
|
.setURL(`${game.url}`)
|
||||||
.setThumbnail(`${coverUrl}`)
|
.setThumbnail(`${coverUrl}`)
|
||||||
.addFields({ name: 'Description', value: `${game.summary}` })
|
.addFields({ name: 'Description', value: `${game.summary}` })
|
||||||
.addFields({ name: 'Developers', value: `${game.involved_companies.join(', ')}`, inline: true })
|
.addFields({ name: 'Developers', value: `${companies.join(', ')}`, inline: true })
|
||||||
.addFields({ name: 'Release Date', value: `${release_date}`, inline: true })
|
.addFields({ name: 'Release Date', value: `${release_date}`, inline: true })
|
||||||
.addFields({ name: 'Genres', value: `${game.genres.join(', ')}`, inline: true })
|
.addFields({ name: 'Genres', value: `${genres.join(', ')}`, inline: true })
|
||||||
.addFields({ name: 'Rating', value: `${game.total_rating.toFixed(0)} / 100, ${game.total_rating_count } ratings`, inline: true })
|
.addFields({ name: 'Rating', value: `${game.total_rating.toFixed(0)} / 100, ${game.total_rating_count } ratings`, inline: true })
|
||||||
.addFields({ name: 'Franchise', value: `${game.franchises}`, inline: true })
|
|
||||||
.addFields({ name: 'ID', value: `${game.id}`, inline: true })
|
.addFields({ name: 'ID', value: `${game.id}`, inline: true })
|
||||||
.setFooter({ text: 'The Ochulus • 100 Games Challenge', iconURL: interaction.client.user.avatarURL() })
|
.setFooter({ text: 'The Ochulus • 100 Games Challenge', iconURL: interaction.client.user.avatarURL() })
|
||||||
.setTimestamp();
|
.setTimestamp();
|
||||||
|
|
||||||
|
if (game.franchises) {
|
||||||
|
const franchise = await getFranchise(game.franchises);
|
||||||
|
embed.addFields({ name: 'Franchise', value: `${franchise}`, inline: true });
|
||||||
|
}
|
||||||
|
|
||||||
return interaction.followUp({ embeds: [embed] });
|
return interaction.followUp({ embeds: [embed] });
|
||||||
},
|
},
|
||||||
};
|
};
|
Loading…
Reference in New Issue