TheOchulus/commands/100-games/beatGame.js

99 lines
4.8 KiB
JavaScript
Raw Normal View History

2023-11-27 00:02:34 +01:00
const { SlashCommandBuilder, EmbedBuilder } = require('discord.js');
const { getCoverURL, getGameJson } = require('../../igdbHelperFunctions.js');
2024-02-11 21:23:08 +01:00
const { checkGameStorage, getUserRegistration, createBeatenGameEntry, getBeatenGameCount, getPlanningGameCount, getPlayingGameCount } = require('../../databaseHelperFunctions.js');
2023-11-18 01:35:28 +01:00
2023-11-27 00:02:34 +01:00
module.exports = {
data: new SlashCommandBuilder()
.setName('beatgame')
.setDescription('Log a game that you have beat towards the 100 game challenge!')
2023-12-31 02:12:24 +01:00
.addStringOption(option => option.setName('gamename').setDescription('The name of the game.').setRequired(true))
.addStringOption(option => option.setName('date').setDescription('The date to be logged. (YYYY/MM/DD)'))
2023-12-27 22:34:10 +01:00
.addNumberOption(option => option.setName('gameid').setDescription('The IGDB game id.').setMinValue(0)),
2023-11-27 00:02:34 +01:00
async execute(interaction) {
2023-12-19 00:53:52 +01:00
await interaction.deferReply();
2023-12-31 02:12:24 +01:00
2023-12-19 00:53:52 +01:00
const userDatabaseEntry = await getUserRegistration(interaction.user);
if (!userDatabaseEntry) return interaction.editReply({ content: `Issue checking registration with "${interaction.user.username}".`, ephemeral: true });
2023-12-19 00:53:52 +01:00
const oldnum = await getBeatenGameCount(userDatabaseEntry);
if (oldnum >= 100) return interaction.editReply({ content: 'You have already completed the 100 Games Challenge.', ephemeral: true });
2023-11-27 00:02:34 +01:00
const gamename = interaction.options.getString('gamename');
const gameid = interaction.options.getNumber('gameid');
const date = interaction.options.getString('date');
2023-11-28 23:04:08 +01:00
if (!gamename && !gameid) return interaction.editReply({ content: 'No gamename or gameid supplied, please supply an option to register a game!', ephemeral: true });
2023-11-28 23:04:08 +01:00
let body = '';
2023-11-27 00:02:34 +01:00
if (gameid) {
2023-11-28 23:04:08 +01:00
body = body.concat('where id = ', gameid, '; ');
2023-11-27 00:02:34 +01:00
} else if (gamename) {
2023-11-28 23:04:08 +01:00
body = body.concat('search "', gamename, '"; ');
body = body.concat('limit 25; where (category = 0 | category = 4 | category = 8 | category = 9) & version_parent = null;');
2023-11-27 00:02:34 +01:00
}
2023-11-28 23:04:08 +01:00
2023-11-27 00:02:34 +01:00
body = body.concat('fields *;');
2023-11-28 23:04:08 +01:00
2024-02-14 20:48:39 +01:00
let res = await getGameJson(body);
res = res.filter(entry => entry.status !== 6);
res.sort((a, b) => parseInt(b.total_rating_count) - parseInt(a.total_rating_count));
2023-11-28 23:04:08 +01:00
if (!res[0]) return interaction.editReply({ content: 'No game found for the options supplied.', ephemeral: true });
2023-11-28 23:04:08 +01:00
2023-12-19 20:47:26 +01:00
const game = res[0];
const release_date = game.first_release_date;
if (!release_date || (release_date * 1000) > Date.now()) return interaction.editReply({ content: `${game.name} is not yet released.`, ephemeral: true });
2023-12-19 20:47:26 +01:00
const gameDatabaseEntry = await checkGameStorage(game);
let gameDate = new Date();
if (date) {
const parsedDate = new Date(date);
if (!isNaN(parsedDate.getTime())) {
gameDate = parsedDate;
}
else {
gameDate = new Date();
}
}
await createBeatenGameEntry(userDatabaseEntry, gameDatabaseEntry, gameDate);
2023-12-19 00:53:52 +01:00
2024-02-11 21:23:08 +01:00
const beatNum = await getBeatenGameCount(userDatabaseEntry);
const planNum = await getPlanningGameCount(userDatabaseEntry);
const playNum = await getPlayingGameCount(userDatabaseEntry);
2023-11-28 23:04:08 +01:00
2023-11-27 00:02:34 +01:00
const embed = new EmbedBuilder()
.setColor(0xFFD700)
.setAuthor({ name: `${interaction.user.displayName} beat a new game!`, iconURL: interaction.user.avatarURL() })
2023-12-19 20:47:26 +01:00
.setTitle(`${game.name} beaten!`)
2023-11-27 00:02:34 +01:00
.setFooter({ text: 'The Ochulus • 100 Games Challenge', iconURL: interaction.client.user.avatarURL() })
.setTimestamp();
2023-11-28 23:04:08 +01:00
if (game.cover) {
const coverUrl = await getCoverURL(game.cover);
embed.setThumbnail(`${coverUrl}`);
}
2024-03-18 21:47:32 +01:00
embed.addFields({ name: 'Planned', value: `${planNum} game(s)`, inline: true });
embed.addFields({ name: 'Now Playing', value: `${playNum} game(s)`, inline: true });
embed.addFields({ name: 'Beaten', value: `${beatNum}/100 (${100 - beatNum} game(s) remaining)`, inline: true });
await interaction.editReply({ embeds: [embed] });
2024-02-11 21:23:08 +01:00
if (beatNum == 100) {
const challengeCompletedEmbed = new EmbedBuilder()
.setColor(0xFFD700)
.setAuthor({ name: `${interaction.user.displayName} has completed the 100 Game Challenge!`, iconURL: interaction.user.avatarURL() })
.setTitle(`Congratulations ${interaction.user.displayName}, you have completed the 100 Game Challenge!`)
.setFooter({ text: 'The Ochulus • 100 Games Challenge', iconURL: interaction.client.user.avatarURL() })
.setTimestamp()
.setImage('https://c.tenor.com/82zAqfFm7OMAAAAC/tenor.gif');
await interaction.editReply({ embeds: [challengeCompletedEmbed] });
}
2023-11-27 00:02:34 +01:00
},
};