Compare commits

..

3 Commits

Author SHA1 Message Date
baz e9a6e40170 make linter happy 2024-03-18 20:39:36 +00:00
baz 61c677e2a1 Add user command 2024-03-18 20:39:26 +00:00
baz e98a572b4a Add getRecentEntry databaseHelperFunction 2024-03-18 20:39:17 +00:00
3 changed files with 66 additions and 1 deletions

View File

@ -0,0 +1,54 @@
const { SlashCommandBuilder, EmbedBuilder } = require('discord.js');
const { getUserRegistration, getBeatenGameCount, getPlanningGameCount, getPlayingGameCount, getRecentBeatenGameEntry, getBeatenGames, getRecentEntry } = require('../../databaseHelperFunctions');
module.exports = {
data: new SlashCommandBuilder()
.setName('user')
.setDescription('Get the users info for the 100 Game Challenge')
.addUserOption(option => option.setName('user').setDescription('The user to check')),
async execute(interaction) {
await interaction.reply({ content: 'Searching for user...', ephemeral: true });
let user = interaction.user;
const userOption = interaction.options.getUser('user');
if (userOption) {
user = userOption;
}
const userDatabaseEntry = await getUserRegistration(user);
if (!userDatabaseEntry) return interaction.followUp({ content: `Issue checking registration with "${user.username}".`, ephemeral: true });
const planNum = await getPlanningGameCount(userDatabaseEntry);
const playNum = await getPlayingGameCount(userDatabaseEntry);
const beatNum = await getBeatenGameCount(userDatabaseEntry);
const gameDatabaseEntry = await getRecentBeatenGameEntry(userDatabaseEntry.id);
const beatenGamesDatabaseEntries = await getBeatenGames(userDatabaseEntry.id);
const recentEntry = await getRecentEntry(userDatabaseEntry.id);
const embed = new EmbedBuilder();
embed.setColor(0x6441a5);
embed.setTitle(`User Info for ${user.displayName}`);
embed.setThumbnail(user.avatarURL());
if (planNum >= 0) embed.addFields({ name: 'Planned', value: `${planNum} games`, inline: true });
if (playNum >= 0) embed.addFields({ name: 'Now Playing', value: `${playNum} games`, inline: true });
if (beatNum >= 0) embed.addFields({ name: 'Beaten', value: `${beatNum}/100 (${100 - beatNum} games remaining)`, inline: true });
if (gameDatabaseEntry) embed.addFields({ name: 'Last Beat Game', value: `${gameDatabaseEntry.name}`, inline: true });
if (beatenGamesDatabaseEntries && beatenGamesDatabaseEntries.length > 0) {
const today = new Date();
const start = new Date(2024, 0, 1);
const days = (today - start) / (1000 * 60 * 60 * 24);
const timepergame = days / beatenGamesDatabaseEntries.length;
const finishdate = new Date();
finishdate.setDate(start.getDate() + (timepergame * 100));
const date = finishdate.toLocaleDateString('en-GB', { year: 'numeric', month: '2-digit', day: '2-digit' }).replace(/\//g, '/');
embed.addFields({ name: 'Estimated Finish Date', value: `${date}`, inline: true });
}
if (recentEntry) embed.addFields({ name: 'Last Updated', value: `${recentEntry.updatedAt.toLocaleDateString('en-GB', { year: 'numeric', month: '2-digit', day: '2-digit' }).replace(/\//g, '/')}`, inline: true });
return interaction.followUp({ embeds: [embed] });
},
};

View File

@ -43,7 +43,6 @@ module.exports = {
const currentDate = `${currentYear}/${currentMonth}/${currentDay} ${currentHour}:${currentMinute}:${currentSecond}`; const currentDate = `${currentYear}/${currentMonth}/${currentDay} ${currentHour}:${currentMinute}:${currentSecond}`;
const embed = new EmbedBuilder() const embed = new EmbedBuilder()
.setColor(0xD36918) .setColor(0xD36918)
.setTitle('Current Uptime') .setTitle('Current Uptime')
.setThumbnail(interaction.client.user.avatarURL()) .setThumbnail(interaction.client.user.avatarURL())

View File

@ -280,6 +280,17 @@ async function getRecentGameEntry(userId, status) {
return false; return false;
} }
async function getRecentEntry(userId) {
const beatenGameEntry = await LoggedGames.findOne({ where: { userId: userId }, order: [ [ 'updatedAt', 'DESC' ]] })
.catch((err) => {
console.log(err);
});
if (!beatenGameEntry) return false;
return beatenGameEntry;
}
async function getPlanningGames(id) { async function getPlanningGames(id) {
return await getGames(id, 'planning'); return await getGames(id, 'planning');
} }
@ -350,6 +361,7 @@ module.exports = {
getRecentPlayingGameEntry, getRecentPlayingGameEntry,
getRecentBeatenGameEntry, getRecentBeatenGameEntry,
getRecentGameEntry, getRecentGameEntry,
getRecentEntry,
getPlanningGames, getPlanningGames,
getPlayingGames, getPlayingGames,
getBeatenGames, getBeatenGames,