codeberg_cli/actions/repo/
assignees.rs1use forgejo_api::structs::User;
2
3use crate::actions::GeneralArgs;
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#[derive(Parser, Debug)]
15pub struct RepoAssigneesArgs {}
16
17impl RepoAssigneesArgs {
18 pub async fn run(self, general_args: GeneralArgs) -> anyhow::Result<()> {
19 let ctx = BergContext::new(self, general_args).await?;
20
21 let OwnerRepo { repo, owner } = ctx.owner_repo()?;
22 let (_, repo_assignees) =
23 spin_until_ready(ctx.client.repo_get_assignees(owner.as_str(), repo.as_str())).await?;
24
25 match general_args.output_mode {
26 OutputMode::Pretty => {
27 present_repo_assignees(&ctx, repo_assignees);
28 }
29 OutputMode::Json => repo_assignees.print_json()?,
30 }
31
32 Ok(())
33 }
34}
35
36fn present_repo_assignees(ctx: &BergContext<RepoAssigneesArgs>, repo_assignees: Vec<User>) {
37 let mut table = ctx.make_table();
38
39 table
40 .set_header(vec![format!(
41 "Repository Assignees{}",
42 if repo_assignees.is_empty() {
43 " (empty)"
44 } else {
45 Default::default()
46 }
47 )])
48 .add_rows(
49 repo_assignees
50 .into_iter()
51 .map(|assignee| vec![option_display(&assignee.login)]),
52 );
53
54 println!("{table}", table = table.show());
55}