From 916b4cc4bff2f2d2a08f64068be5bd2612e737b4 Mon Sep 17 00:00:00 2001 From: Ivan Habunek Date: Tue, 29 Nov 2022 09:20:00 +0100 Subject: [PATCH] Extract code for printing a poll --- toot/output.py | 49 ++++++++++++++++++++++++++----------------------- 1 file changed, 26 insertions(+), 23 deletions(-) diff --git a/toot/output.py b/toot/output.py index daee4c6..a6ec64e 100644 --- a/toot/output.py +++ b/toot/output.py @@ -201,29 +201,7 @@ def print_status(status, width): print_out(line) if poll: - print_out("") - for idx, option in enumerate(poll["options"]): - perc = (round(100 * option["votes_count"] / poll["votes_count"]) - if poll["votes_count"] else 0) - - if poll["voted"] and poll["own_votes"] and idx in poll["own_votes"]: - voted_for = " " - else: - voted_for = "" - - print_out(option["title"] + " - {}%".format(perc) + voted_for) - - poll_footer = "Poll · {} votes".format(poll["votes_count"]) - - if poll["expired"]: - poll_footer += " · Closed" - - if poll["expires_at"]: - expires_at = parse_datetime(poll["expires_at"]).strftime("%Y-%m-%d %H:%M") - poll_footer += " · Closes on {}".format(expires_at) - - print_out("\n{}".format(poll_footer)) - + print_poll(poll) print_out("\n{}{}{}".format( "ID {} ".format(status['id']), @@ -232,6 +210,31 @@ def print_status(status, width): )) +def print_poll(poll): + print_out() + for idx, option in enumerate(poll["options"]): + perc = (round(100 * option["votes_count"] / poll["votes_count"]) + if poll["votes_count"] else 0) + + if poll["voted"] and poll["own_votes"] and idx in poll["own_votes"]: + voted_for = " " + else: + voted_for = "" + + print_out(f'{option["title"]} - {perc}% {voted_for}') + + poll_footer = f'Poll · {poll["votes_count"]} votes' + + if poll["expired"]: + poll_footer += " · Closed" + + if poll["expires_at"]: + expires_at = parse_datetime(poll["expires_at"]).strftime("%Y-%m-%d %H:%M") + poll_footer += f" · Closes on {expires_at}" + + print_out("\n{}".format(poll_footer)) + + def print_timeline(items, width=100): print_out("─" * width) for item in items: