codeberg_cli/actions/repo/
assignees.rs

1use forgejo_api::structs::User;
2
3use crate::actions::GlobalArgs;
4use crate::render::json::JsonToStdout;
5use crate::render::option::option_display;
6use crate::render::spinner::spin_until_ready;
7use crate::types::context::BergContext;
8use crate::types::git::OwnerRepo;
9use crate::types::output::OutputMode;
10
11use clap::Parser;
12
13/// List available assignee candidates
14#[derive(Parser, Debug)]
15pub struct RepoAssigneesArgs {}
16
17impl RepoAssigneesArgs {
18    pub async fn run(self, global_args: GlobalArgs) -> anyhow::Result<()> {
19        let ctx = BergContext::new(self, global_args).await?;
20
21        let OwnerRepo { repo, owner } = ctx.owner_repo()?;
22        let (_, repo_assignees) = spin_until_ready(
23            ctx.client
24                .repo_get_assignees(owner.as_str(), repo.as_str())
25                .send(),
26        )
27        .await?;
28
29        match ctx.global_args.output_mode {
30            OutputMode::Pretty => {
31                present_repo_assignees(&ctx, repo_assignees);
32            }
33            OutputMode::Json => repo_assignees.print_json()?,
34        }
35
36        Ok(())
37    }
38}
39
40fn present_repo_assignees(ctx: &BergContext<RepoAssigneesArgs>, repo_assignees: Vec<User>) {
41    let mut table = ctx.make_table();
42
43    table
44        .set_header(vec![format!(
45            "Repository Assignees{}",
46            if repo_assignees.is_empty() {
47                " (empty)"
48            } else {
49                Default::default()
50            }
51        )])
52        .add_rows(
53            repo_assignees
54                .into_iter()
55                .map(|assignee| vec![option_display(&assignee.login)]),
56        );
57
58    println!("{table}", table = table.show());
59}