@ -12,19 +12,25 @@ use std::fs::File;
use std ::io ::Write ;
use std ::io ::Write ;
use std ::path ::Path ;
use std ::path ::Path ;
#[ command(prefix_command, slash_command, description_localized( " en-US " , " View the latest handwriting challenge info. " )) ]
#[ command(
prefix_command ,
slash_command ,
description_localized ( "en-US" , "View the latest handwriting challenge info." )
) ]
pub async fn challenge ( ctx : Context < ' _ > ) -> Result < ( ) , Error > {
pub async fn challenge ( ctx : Context < ' _ > ) -> Result < ( ) , Error > {
ctx . say (
ctx . say ( format! (
format! (
"Tegaki Tuesday #{n}: <https://tegakituesday.com/{n}>" ,
"Tegaki Tuesday #{n}: <https://tegakituesday.com/{n}>" ,
n = get_challenge_number ( )
n = get_challenge_number ( )
) )
) ,
)
. await ? ;
. await ? ;
Ok ( ( ) )
Ok ( ( ) )
}
}
#[ command(prefix_command, broadcast_typing, description_localized( " en-US " , " Submit to the latest handwriting challenge. " )) ]
#[ command(
prefix_command ,
broadcast_typing ,
description_localized ( "en-US" , "Submit to the latest handwriting challenge." )
) ]
pub async fn submit ( ctx : PrefixContext < ' _ > ) -> Result < ( ) , Error > {
pub async fn submit ( ctx : PrefixContext < ' _ > ) -> Result < ( ) , Error > {
// TODO: The code for this command needs to be refactored,
// TODO: The code for this command needs to be refactored,
// there are large duplicated sections that need to be merged somehow.
// there are large duplicated sections that need to be merged somehow.
@ -36,24 +42,32 @@ pub async fn submit(ctx: PrefixContext<'_>) -> Result<(), Error> {
. unwrap ( )
. unwrap ( )
. contains_key ( "submissionChannel" )
. contains_key ( "submissionChannel" )
{
{
ctx . msg . reply ( & ctx . discord . http , "Submissions aren't enabled for this server yet." ) . await ? ;
ctx . msg
. reply (
& ctx . discord . http ,
"Submissions aren't enabled for this server yet." ,
)
. await ? ;
return Ok ( ( ) ) ;
return Ok ( ( ) ) ;
}
}
let current_guild_data = & guild_data [ & guild ] . as_object ( ) . unwrap ( ) ;
let current_guild_data = & guild_data [ & guild ] . as_object ( ) . unwrap ( ) ;
let submission_channel = current_guild_data [ "submissionChannel" ] . as_str ( ) . unwrap ( ) ;
let submission_channel = current_guild_data [ "submissionChannel" ] . as_str ( ) . unwrap ( ) ;
if submission_channel ! = ctx . msg . channel_id . as_u64 ( ) . to_string ( ) {
if submission_channel ! = ctx . msg . channel_id . as_u64 ( ) . to_string ( ) {
ctx . msg . reply (
ctx . msg
& ctx . discord . http ,
. reply (
format! (
& ctx . discord . http ,
"Sorry, submissions aren't permitted here. Please go to <#{}>. Thanks!" ,
format! (
guild
"Sorry, submissions aren't permitted here. Please go to <#{}>. Thanks!" ,
) ,
guild
)
) ,
. await ? ;
)
. await ? ;
return Ok ( ( ) ) ;
return Ok ( ( ) ) ;
}
}
if ctx . msg . attachments . len ( ) = = 0 {
if ctx . msg . attachments . len ( ) = = 0 {
ctx . msg . reply ( & ctx . discord . http , "Please attach at least one image." ) . await ? ;
ctx . msg
. reply ( & ctx . discord . http , "Please attach at least one image." )
. await ? ;
return Ok ( ( ) ) ;
return Ok ( ( ) ) ;
}
}
let challenge_number = get_challenge_number ( ) ;
let challenge_number = get_challenge_number ( ) ;
@ -170,7 +184,11 @@ pub async fn submit(ctx: PrefixContext<'_>) -> Result<(), Error> {
Ok ( ( ) )
Ok ( ( ) )
}
}
#[ command(prefix_command, slash_command, description_localized( " en-US " , " List images in your current submission, if available. " )) ]
#[ command(
prefix_command ,
slash_command ,
description_localized ( "en-US" , "List images in your current submission, if available." )
) ]
pub async fn images ( ctx : Context < ' _ > ) -> Result < ( ) , Error > {
pub async fn images ( ctx : Context < ' _ > ) -> Result < ( ) , Error > {
let submission_data = get_current_submission_data ( ) ;
let submission_data = get_current_submission_data ( ) ;
let images : Vec < String > = {
let images : Vec < String > = {
@ -187,12 +205,10 @@ pub async fn images(ctx: Context<'_>) -> Result<(), Error> {
} ;
} ;
let challenge_number = get_challenge_number ( ) ;
let challenge_number = get_challenge_number ( ) ;
if images . len ( ) = = 0 {
if images . len ( ) = = 0 {
ctx . say (
ctx . say ( format! (
format! (
"You haven't submitted anything for Tegaki Tuesday #{}." ,
"You haven't submitted anything for Tegaki Tuesday #{}." ,
challenge_number
challenge_number
) )
) ,
)
. await ? ;
. await ? ;
return Ok ( ( ) ) ;
return Ok ( ( ) ) ;
}
}
@ -212,13 +228,18 @@ pub async fn images(ctx: Context<'_>) -> Result<(), Error> {
Ok ( ( ) )
Ok ( ( ) )
}
}
#[ command(prefix_command, slash_command, description_localized( " en-US " , " Delete images from your current submission using image numbers from the images command. " )) ]
#[ command(
pub async fn imagedelete (
prefix_command ,
ctx : Context < ' _ > ,
slash_command ,
number : i32 ,
description_localized (
) -> Result < ( ) , Error > {
"en-US" ,
"Delete images from your current submission using image numbers from the images command."
)
) ]
pub async fn imagedelete ( ctx : Context < ' _ > , number : i32 ) -> Result < ( ) , Error > {
if number < 1 {
if number < 1 {
ctx . say ( "That isn't a valid image number. Image numbers start at 1." ) . await ? ;
ctx . say ( "That isn't a valid image number. Image numbers start at 1." )
. await ? ;
return Ok ( ( ) ) ;
return Ok ( ( ) ) ;
}
}
let challenge_number = get_challenge_number ( ) ;
let challenge_number = get_challenge_number ( ) ;
@ -230,23 +251,21 @@ pub async fn imagedelete(
let mut images = submission [ "images" ] . as_array ( ) . unwrap ( ) . clone ( ) ;
let mut images = submission [ "images" ] . as_array ( ) . unwrap ( ) . clone ( ) ;
let image_count = images . len ( ) ;
let image_count = images . len ( ) ;
if image_count < number . try_into ( ) . unwrap ( ) {
if image_count < number . try_into ( ) . unwrap ( ) {
ctx . say (
ctx . say ( if image_count = = 0 {
if image_count = = 0 {
// This is an edge case that should never happen.
// This is an edge case that should never happen.
// In this scenario, there is submission data with an empty image list.
// In this scenario, there is submission data with an empty image list.
// Submission data should be deleted uppon imageDelete if there are no images remaining.
// Submission data should be deleted uppon imageDelete if there are no images remaining.
format! (
format! (
"You haven't submitted anything for Tegaki Tuesday #{}." ,
"You haven't submitted anything for Tegaki Tuesday #{}." ,
challenge_number
challenge_number
)
)
} else {
} else {
format! (
format! (
"That image number doesn't exist, you only have {} image{}." ,
"That image number doesn't exist, you only have {} image{}." ,
image_count ,
image_count ,
if image_count = = 1 { "" } else { "s" }
if image_count = = 1 { "" } else { "s" }
)
)
} )
} ,
)
. await ? ;
. await ? ;
return Ok ( ( ) ) ;
return Ok ( ( ) ) ;
}
}
@ -304,22 +323,22 @@ pub async fn imagedelete(
ctx . say ( message ) . await ? ;
ctx . say ( message ) . await ? ;
return Ok ( ( ) ) ;
return Ok ( ( ) ) ;
}
}
ctx . say (
ctx . say ( format! (
format! (
"You haven't submitted anything for Tegaki Tuesday #{}." ,
"You haven't submitted anything for Tegaki Tuesday #{}." ,
challenge_number
challenge_number
) )
) ,
)
. await ? ;
. await ? ;
Ok ( ( ) )
Ok ( ( ) )
}
}
// TODO: make also slash command
// TODO: make also slash command
#[ command(prefix_command, description_localized( " en-US " , " Make a suggestion for future challenge prompts! " )) ]
#[ command(
prefix_command ,
description_localized ( "en-US" , "Make a suggestion for future challenge prompts!" )
) ]
pub async fn suggest (
pub async fn suggest (
ctx : PrefixContext < ' _ > ,
ctx : PrefixContext < ' _ > ,
#[ description = " Suggestion text. Please include passage and source. " ]
#[ description = " Suggestion text. Please include passage and source. " ] suggestion : String ,
suggestion : String ,
) -> Result < ( ) , Error > {
) -> Result < ( ) , Error > {
let guild_data = get_guild_data ( ) ;
let guild_data = get_guild_data ( ) ;
let channel = serenity ::ChannelId (
let channel = serenity ::ChannelId (
@ -332,7 +351,9 @@ pub async fn suggest(
// User::accent_colour is only available via the REST API
// User::accent_colour is only available via the REST API
// If we just do msg.author.accent_colour here, we will get None
// If we just do msg.author.accent_colour here, we will get None
let author = & ctx . msg . author ;
let author = & ctx . msg . author ;
let accent_color = ctx . discord . http
let accent_color = ctx
. discord
. http
. get_user ( * author . id . as_u64 ( ) )
. get_user ( * author . id . as_u64 ( ) )
. await
. await
. unwrap ( )
. unwrap ( )