codeberg_cli/actions/milestone/
list.rs1use crate::render::json::JsonToStdout;
2use crate::render::option::option_display;
3use crate::render::spinner::spin_until_ready;
4use crate::types::context::BergContext;
5use crate::types::git::OwnerRepo;
6use crate::{actions::GlobalArgs, types::output::OutputMode};
7use clap::Parser;
8use forgejo_api::structs::{IssueGetMilestonesListQuery, Milestone};
9use miette::IntoDiagnostic;
10
11#[derive(Parser, Debug)]
13pub struct ListMilestonesArgs {
14 #[arg(short, long, value_name = "N", default_value_t = 5)]
16 pub count: usize,
17}
18
19impl ListMilestonesArgs {
20 pub async fn run(self, global_args: GlobalArgs) -> miette::Result<()> {
21 let ctx = BergContext::new(self, global_args).await?;
22
23 let OwnerRepo { repo, owner } = ctx.owner_repo()?;
24 let (_, milestones_list) = spin_until_ready(
25 ctx.client
26 .issue_get_milestones_list(
27 owner.as_str(),
28 repo.as_str(),
29 IssueGetMilestonesListQuery::default(),
30 )
31 .send(),
32 )
33 .await
34 .into_diagnostic()?;
35
36 match ctx.global_args.output_mode {
37 OutputMode::Pretty => {
38 present_milestones_list(&ctx, milestones_list);
39 }
40 OutputMode::Json => milestones_list.print_json()?,
41 }
42
43 Ok(())
44 }
45}
46
47fn present_milestones_list(ctx: &BergContext<ListMilestonesArgs>, milestones: Vec<Milestone>) {
48 let milestones_empty = milestones.is_empty();
49
50 let table = ctx
51 .make_table()
52 .set_header(vec![format!(
53 "Milestones{}",
54 if milestones_empty {
55 " (empty)"
56 } else {
57 Default::default()
58 }
59 )])
60 .add_rows(
61 milestones
62 .into_iter()
63 .map(|milestone| vec![option_display(&milestone.title)]),
64 );
65
66 println!("{table}", table = table.show());
67}