diff --git a/commands/100-games/globalchangelog.js b/commands/100-games/globalchangelog.js new file mode 100644 index 0000000..ccb79c4 --- /dev/null +++ b/commands/100-games/globalchangelog.js @@ -0,0 +1,38 @@ +const { SlashCommandBuilder, EmbedBuilder } = require('discord.js'); +const { getAllChangelog, checkGameStorageId, getUserFromId } = require('../../databaseHelperFunctions.js'); + +module.exports = { + data: new SlashCommandBuilder() + .setName('globalchangelog') + .setDescription('Show all recent activity'), + async execute(interaction) { + await interaction.deferReply(); + const changelogEntries = await getAllChangelog(); + let desc = ''; + + for (const entry of changelogEntries) { + const game = await checkGameStorageId(entry.gameId); + const user = await getUserFromId(entry.userId); + + if (entry.newStatus == 'planning') { + desc = desc.concat(`:pencil: *${user.username}* planned **${game.name}** *(${entry.createdAt.toLocaleDateString('en-GB', { year: 'numeric', month: '2-digit', day: '2-digit' }).replace(/\//g, '/')})*\n`); + } else if (entry.newStatus == 'playing') { + desc = desc.concat(`:video_game: *${user.username}* started playing **${game.name}** *(${entry.createdAt.toLocaleDateString('en-GB', { year: 'numeric', month: '2-digit', day: '2-digit' }).replace(/\//g, '/')})*\n`); + } else if (entry.newStatus == 'beat') { + desc = desc.concat(`:white_check_mark: *${user.username}* beat **${game.name}** *(${entry.createdAt.toLocaleDateString('en-GB', { year: 'numeric', month: '2-digit', day: '2-digit' }).replace(/\//g, '/')})*\n`); + } else if (!entry.newStatus) { + desc = desc.concat(`:x: *${user.username}* deleted **${game.name}** from **${entry.oldStatus}** *(${entry.createdAt.toLocaleDateString('en-GB', { year: 'numeric', month: '2-digit', day: '2-digit' }).replace(/\//g, '/')})*\n`); + } + } + + const embed = new EmbedBuilder() + .setColor(0x6441a5) + .setThumbnail(interaction.client.user.avatarURL()) + .setTitle('Global Changelog') + .setDescription(desc) + .setFooter({ text: 'The Ochulus • 100 Games Challenge', iconURL: interaction.client.user.avatarURL() }) + .setTimestamp(); + + return interaction.editReply({ embeds: [embed] }); + }, +}; \ No newline at end of file diff --git a/databaseHelperFunctions.js b/databaseHelperFunctions.js index 97435ce..ac9ed87 100644 --- a/databaseHelperFunctions.js +++ b/databaseHelperFunctions.js @@ -402,6 +402,17 @@ async function getChangelog(id) { return false; } +async function getAllChangelog() { + const changelogEntries = await Changelog.findAll({ order: [ [ 'updatedAt', 'DESC' ]] }) + .catch((err) => { + console.log(err); + }); + + if (changelogEntries) return changelogEntries; + + return false; +} + module.exports = { checkUserRegistration, getUserRegistration, @@ -435,4 +446,5 @@ module.exports = { getAllBeatenGames, backupDatabase, getChangelog, + getAllChangelog, }; \ No newline at end of file