2024-02-11 21:33:08 +01:00
const { SlashCommandBuilder , EmbedBuilder } = require ( 'discord.js' ) ;
const { getCoverURL , getGameJson } = require ( '../../igdbHelperFunctions.js' ) ;
const { checkGameStorage , getUserRegistration , createPlayingGameEntry , getBeatenGameCount , getPlanningGameCount , getPlayingGameCount } = require ( '../../databaseHelperFunctions.js' ) ;
module . exports = {
data : new SlashCommandBuilder ( )
2024-02-11 21:35:33 +01:00
. setName ( 'startplaying' )
. setDescription ( 'Log a game that you have started playing towards the 100 game challenge!' )
2024-02-11 21:33:08 +01:00
. addStringOption ( option => option . setName ( 'gamename' ) . setDescription ( 'The name of the game.' ) . setRequired ( true ) )
. addNumberOption ( option => option . setName ( 'gameid' ) . setDescription ( 'The IGDB game id.' ) . setMinValue ( 0 ) ) ,
async execute ( interaction ) {
await interaction . reply ( { content : 'Attempting to log game.' , ephemeral : true } ) ;
const userDatabaseEntry = await getUserRegistration ( interaction . user ) ;
if ( ! userDatabaseEntry ) return interaction . followUp ( { content : ` Issue checking registration with " ${ interaction . user . username } ". ` , ephemeral : true } ) ;
const gamename = interaction . options . getString ( 'gamename' ) ;
const gameid = interaction . options . getNumber ( 'gameid' ) ;
if ( ! gamename && ! gameid ) return interaction . followUp ( { content : 'No gamename or gameid supplied, please supply an option to register a game!' , ephemeral : true } ) ;
let body = '' ;
if ( gameid ) {
body = body . concat ( 'where id = ' , gameid , '; ' ) ;
} else if ( gamename ) {
body = body . concat ( 'search "' , gamename , '"; ' ) ;
body = body . concat ( 'limit 25; where (category = 0 | category = 4 | category = 8 | category = 9) & version_parent = null;' ) ;
}
body = body . concat ( 'fields *;' ) ;
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 ) ) ;
2024-02-11 21:33:08 +01:00
if ( ! res [ 0 ] ) return interaction . followUp ( { content : 'No game found for the options supplied.' , ephemeral : true } ) ;
const game = res [ 0 ] ;
const release _date = game . first _release _date ;
if ( ! release _date || ( release _date * 1000 ) > Date . now ( ) ) return interaction . followUp ( { content : ` ${ game . name } is not yet released. ` , ephemeral : true } ) ;
const gameDatabaseEntry = await checkGameStorage ( game ) ;
if ( ! ( await createPlayingGameEntry ( userDatabaseEntry , gameDatabaseEntry ) ) ) return interaction . followUp ( { content : ` ${ game . name } already currently being played. ` , ephemeral : true } ) ;
const beatNum = await getBeatenGameCount ( userDatabaseEntry ) ;
const planNum = await getPlanningGameCount ( userDatabaseEntry ) ;
const playNum = await getPlayingGameCount ( userDatabaseEntry ) ;
const embed = new EmbedBuilder ( )
2024-02-11 22:06:43 +01:00
. setColor ( 0x00C921 )
2024-02-11 21:33:08 +01:00
. setAuthor ( { name : ` ${ interaction . user . displayName } has started playing a new game! ` , iconURL : interaction . user . avatarURL ( ) } )
. setTitle ( ` ${ game . name } ! ` )
. setDescription ( ` ${ interaction . user . displayName } has ${ planNum } games planned, they are playing ${ playNum } games, they have beaten ${ beatNum } games, they have ${ 100 - beatNum } games remaining. ` )
. setFooter ( { text : 'The Ochulus • 100 Games Challenge' , iconURL : interaction . client . user . avatarURL ( ) } )
. setTimestamp ( ) ;
2024-02-14 20:11:28 +01:00
if ( game . cover ) {
const coverUrl = await getCoverURL ( game . cover ) ;
embed . setThumbnail ( ` ${ coverUrl } ` ) ;
}
2024-02-11 21:33:08 +01:00
await interaction . followUp ( { embeds : [ embed ] } ) ;
} ,
} ;