mirror of
https://gitea.com/gitea/tea.git
synced 2024-11-03 04:27:21 -05: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>
76 lines
2.3 KiB
Go
76 lines
2.3 KiB
Go
// Copyright 2020 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 interact
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
|
|
"code.gitea.io/sdk/gitea"
|
|
"code.gitea.io/tea/modules/context"
|
|
"code.gitea.io/tea/modules/print"
|
|
"github.com/AlecAivazis/survey/v2"
|
|
"golang.org/x/crypto/ssh/terminal"
|
|
)
|
|
|
|
// ShowCommentsMaybeInteractive fetches & prints comments, depending on the --comments flag.
|
|
// If that flag is unset, and output is not piped, prompts the user first.
|
|
func ShowCommentsMaybeInteractive(ctx *context.TeaContext, idx int64, totalComments int) error {
|
|
if ctx.Bool("comments") {
|
|
opts := gitea.ListIssueCommentOptions{ListOptions: ctx.GetListOptions()}
|
|
c := ctx.Login.Client()
|
|
comments, _, err := c.ListIssueComments(ctx.Owner, ctx.Repo, idx, opts)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
print.Comments(comments)
|
|
} else if isInteractive() && !ctx.IsSet("comments") {
|
|
// if we're interactive, but --comments hasn't been explicitly set to false
|
|
if err := ShowCommentsPaginated(ctx, idx, totalComments); err != nil {
|
|
fmt.Printf("error while loading comments: %v\n", err)
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// ShowCommentsPaginated prompts if issue/pr comments should be shown and continues to do so.
|
|
func ShowCommentsPaginated(ctx *context.TeaContext, idx int64, totalComments int) error {
|
|
c := ctx.Login.Client()
|
|
opts := gitea.ListIssueCommentOptions{ListOptions: ctx.GetListOptions()}
|
|
prompt := "show comments?"
|
|
commentsLoaded := 0
|
|
|
|
// paginated fetch
|
|
// NOTE: as of gitea 1.13, pagination is not provided by this endpoint, but handles
|
|
// this function gracefully anyways.
|
|
for {
|
|
loadComments := false
|
|
confirm := survey.Confirm{Message: prompt, Default: true}
|
|
if err := survey.AskOne(&confirm, &loadComments); err != nil {
|
|
return err
|
|
} else if !loadComments {
|
|
break
|
|
} else {
|
|
if comments, _, err := c.ListIssueComments(ctx.Owner, ctx.Repo, idx, opts); err != nil {
|
|
return err
|
|
} else if len(comments) != 0 {
|
|
print.Comments(comments)
|
|
commentsLoaded += len(comments)
|
|
}
|
|
if commentsLoaded >= totalComments {
|
|
break
|
|
}
|
|
opts.ListOptions.Page++
|
|
prompt = "load more?"
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// IsInteractive checks if the output is piped, but NOT if the session is run interactively..
|
|
func isInteractive() bool {
|
|
return terminal.IsTerminal(int(os.Stdout.Fd()))
|
|
}
|