Enhance UI

This commit is contained in:
Kiana Sheibani 2023-11-26 16:15:52 -05:00
parent 72884497c1
commit 43921bd8fa
Signed by: toki
GPG key ID: 6CB106C25E86A9F7

View file

@ -144,8 +144,8 @@ fn dataset_list() {
for (name, metadata) in datasets { for (name, metadata) in datasets {
print!( print!(
"\n\x1b[1m\x1b[4m{}\x1b[0m - \ "\n· \x1b[1m\x1b[34m{}\x1b[0m
\x1b]8;;https://www.start.gg/{}\x1b\\{}\x1b]8;;\x1b\\ ", \x1b[4m\x1b]8;;https://www.start.gg/{}\x1b\\{}\x1b]8;;\x1b\\\x1b[0m ",
name, metadata.game_slug, metadata.game_name name, metadata.game_slug, metadata.game_name
); );
@ -168,7 +168,7 @@ fn dataset_list() {
} else { } else {
print!( print!(
"\x1b[1mLast synced:\x1b[0m {}", "\x1b[1mLast synced:\x1b[0m {}",
strftime_utc("%x %X", metadata.last_sync.0 as i64).unwrap() strftime_utc("%b %e, %Y %I:%M %p", metadata.last_sync.0 as i64).unwrap()
); );
} }
if current_time - metadata.last_sync.0 > SECS_IN_WEEK { if current_time - metadata.last_sync.0 > SECS_IN_WEEK {
@ -252,10 +252,9 @@ fn dataset_new(name: Option<String>, auth_token: Option<String>) {
print!( print!(
" "
\x1b[4mCountry\x1b[0m \x1b[1mCountry\x1b[0m
Enter the two-letter code for the country you want to track ratings in, e.g. Enter the two-letter code for the country you want to track ratings in, e.g.
\"US\" for the United States. See \x1b[1m\x1b]8;;https://www.ups.com/worldshiphelp/\ \"US\" for the United States. See \x1b[4m\x1b]8;;https://www.ups.com/worldshiphelp/\
WSA/ENU/AppHelp/mergedProjects/CORE/Codes/Country_Territory_and_Currency_Codes.htm\ WSA/ENU/AppHelp/mergedProjects/CORE/Codes/Country_Territory_and_Currency_Codes.htm\
\x1b\\this site\x1b]8;;\x1b\\\x1b[0m for a list of these codes. \x1b\\this site\x1b]8;;\x1b\\\x1b[0m for a list of these codes.
If no code is entered, then the dataset will track all players globally. If no code is entered, then the dataset will track all players globally.
@ -277,10 +276,9 @@ Country to track ratings for (leave empty for none): "
let state = if country.as_ref().is_some_and(|s| s == "US" || s == "CA") { let state = if country.as_ref().is_some_and(|s| s == "US" || s == "CA") {
print!( print!(
" "
\x1b[4mState/Province\x1b[0m \x1b[1mState/Province\x1b[0m
Enter the two-letter code for the US state or Canadian province you want to track Enter the two-letter code for the US state or Canadian province you want to track
ratings in, e.g. \"CA\" for California. See \x1b[1m\x1b]8;;https://www.ups.com/worldshiphelp/\ ratings in, e.g. \"CA\" for California. See \x1b[4m\x1b]8;;https://www.ups.com/worldshiphelp/\
WSA/ENU/AppHelp/mergedProjects/CORE/Codes/State_Province_Codes.htm\x1b\\this site\ WSA/ENU/AppHelp/mergedProjects/CORE/Codes/State_Province_Codes.htm\x1b\\this site\
\x1b]8;;\x1b\\\x1b[0m for a list of these codes. \x1b]8;;\x1b\\\x1b[0m for a list of these codes.
If no code is entered, then the dataset will track all players within the country. If no code is entered, then the dataset will track all players within the country.
@ -305,9 +303,11 @@ State/province to track ratings for (leave empty for none): "
let mut set_limit = 0; let mut set_limit = 0;
print!( print!(
" "
\x1b[4mSet Limit\x1b[0m \x1b[1mSet Limit\x1b[0m
The set limit is an optional feature of the rating system that defines how many
TODO sets must be played between two players for their rating data to be considered
trustworthy.
This value should be set low, i.e. not more than 5 or 6.
Set limit (default 0): " Set limit (default 0): "
); );
@ -332,8 +332,7 @@ Set limit (default 0): "
print!( print!(
" "
\x1b[4mNetwork Decay Rate\x1b[0m \x1b[1mNetwork Decay Rate\x1b[0m
The network decay rate is a number between 0 and 1 that controls how the The network decay rate is a number between 0 and 1 that controls how the
advantage network reacts to player wins and losses. If the decay rate is 1, advantage network reacts to player wins and losses. If the decay rate is 1,
then it is assumed that a player's skill against one opponent always carries then it is assumed that a player's skill against one opponent always carries
@ -352,15 +351,15 @@ Network decay rate (default 0.8): "
} }
} }
// Decay Rate // Adjusted Decay Rate
if set_limit != 0 {
print!( print!(
" "
\x1b[4mAdjusted Network Decay Rate\x1b[0m \x1b[1mAdjusted Network Decay Rate\x1b[0m
If the number of sets played between two players is less than the set limit,
TODO then this value is used instead of the regular network decay rate.
This value should be \x1b[1mlower\x1b[0m than the network decay rate.
This should be lower than the regular network decay rate.
Adjusted network decay rate (default 0.5): " Adjusted network decay rate (default 0.5): "
); );
@ -373,13 +372,13 @@ Adjusted network decay rate (default 0.5): "
error("Input is not between 0 and 1", 1); error("Input is not between 0 and 1", 1);
} }
} }
}
// Rating Period // Rating Period
print!( print!(
" "
\x1b[4mRating Period\x1b[0m \x1b[1mRating Period\x1b[0m
The rating period is an interval of time that dictates how player ratings change The rating period is an interval of time that dictates how player ratings change
during inactivity. Ideally the rating period should be somewhat long, long during inactivity. Ideally the rating period should be somewhat long, long
enough to expect almost every player in the dataset to have played at least a enough to expect almost every player in the dataset to have played at least a
@ -398,8 +397,7 @@ Rating period (in days, default 40): "
print!( print!(
" "
\x1b[4mTau Constant\x1b[0m \x1b[1mTau Constant\x1b[0m
The tau constant is an internal system constant that roughly represents how The tau constant is an internal system constant that roughly represents how
much random chance and luck play a role in game outcomes. In games where match much random chance and luck play a role in game outcomes. In games where match
results are highly predictable, and a player's skill is the sole factor for results are highly predictable, and a player's skill is the sole factor for
@ -479,11 +477,19 @@ fn player_info(dataset: Option<String>, player: String) {
let (deviation, volatility, last_played) = let (deviation, volatility, last_played) =
get_player_rating_data(&connection, &dataset, player_id).unwrap(); get_player_rating_data(&connection, &dataset, player_id).unwrap();
print!("\n\x1b]8;;https://www.start.gg/user/{}\x1b\\", discrim); println!();
if let Some(pre) = prefix { if let Some(pre) = prefix {
print!("\x1b[2m{}\x1b[0m ", pre); print!("\x1b[2m{}\x1b[22m ", pre);
} }
println!("\x1b[1m{}\x1b[0m\x1b]8;;\x1b\\ ({})", name, discrim); println!(
"\x1b[4m\x1b]8;;https://www.start.gg/user/{1}\x1b\\\
\x1b[1m{0}\x1b[22m\x1b]8;;\x1b\\\x1b[0m ({1})",
name, discrim
);
println!("\n\x1b[1mID:\x1b[0m {}", player_id.0);
println!("\x1b[1mDeviation:\x1b[0m {}", deviation);
println!("\x1b[1mVolatility:\x1b[0m {}", volatility);
} }
// Sync // Sync