mirror of
https://gitea.com/gitea/tea
synced 2024-10-31 21:20:23 +00:00
32b7b771cc
show comments of PR TODO: there needs to be a way to force running non-interactively add `tea comment` to post a comment add --comments flag, prompt only if necessary don't prompt if --comments is provided, or output is piped show comments for issues, add --comments flag tea comment: print resulting comment Merge branch 'master' into issue-172-comments remove debug print statement unrelated, but better than opening another PR for this ;) Merge remote-tracking branch 'upstream/master' into issue-172-comments ret err fix lint Co-authored-by: Norwin Roosen <git@nroo.de> Co-authored-by: 6543 <6543@obermui.de> Reviewed-on: https://gitea.com/gitea/tea/pulls/313 Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com> Reviewed-by: 6543 <6543@obermui.de> Co-Authored-By: Norwin <noerw@noreply.gitea.io> Co-Committed-By: Norwin <noerw@noreply.gitea.io>
72 lines
1.8 KiB
Go
72 lines
1.8 KiB
Go
// Copyright 2018 The Gitea Authors. All rights reserved.
|
|
// Use of this source code is governed by a MIT-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package cmd
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"code.gitea.io/tea/cmd/issues"
|
|
"code.gitea.io/tea/modules/context"
|
|
"code.gitea.io/tea/modules/interact"
|
|
"code.gitea.io/tea/modules/print"
|
|
"code.gitea.io/tea/modules/utils"
|
|
|
|
"github.com/urfave/cli/v2"
|
|
)
|
|
|
|
// CmdIssues represents to login a gitea server.
|
|
var CmdIssues = cli.Command{
|
|
Name: "issues",
|
|
Aliases: []string{"issue", "i"},
|
|
Category: catEntities,
|
|
Usage: "List, create and update issues",
|
|
Description: `Lists issues when called without argument. If issue index is provided, will show it in detail.`,
|
|
ArgsUsage: "[<issue index>]",
|
|
Action: runIssues,
|
|
Subcommands: []*cli.Command{
|
|
&issues.CmdIssuesList,
|
|
&issues.CmdIssuesCreate,
|
|
&issues.CmdIssuesReopen,
|
|
&issues.CmdIssuesClose,
|
|
},
|
|
Flags: append([]cli.Flag{
|
|
&cli.BoolFlag{
|
|
Name: "comments",
|
|
Usage: "Wether to display comments (will prompt if not provided & run interactively)",
|
|
},
|
|
}, issues.CmdIssuesList.Flags...),
|
|
}
|
|
|
|
func runIssues(ctx *cli.Context) error {
|
|
if ctx.Args().Len() == 1 {
|
|
return runIssueDetail(ctx, ctx.Args().First())
|
|
}
|
|
return issues.RunIssuesList(ctx)
|
|
}
|
|
|
|
func runIssueDetail(cmd *cli.Context, index string) error {
|
|
ctx := context.InitCommand(cmd)
|
|
ctx.Ensure(context.CtxRequirement{RemoteRepo: true})
|
|
|
|
idx, err := utils.ArgToIndex(index)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
issue, _, err := ctx.Login.Client().GetIssue(ctx.Owner, ctx.Repo, idx)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
print.IssueDetails(issue)
|
|
|
|
if issue.Comments > 0 {
|
|
err = interact.ShowCommentsMaybeInteractive(ctx, idx, issue.Comments)
|
|
if err != nil {
|
|
return fmt.Errorf("error loading comments: %v", err)
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|