From fb6849ca163779e5fa33786568b78592f433470a Mon Sep 17 00:00:00 2001 From: Kenny Parnell Date: Tue, 28 Nov 2023 12:34:50 -0500 Subject: [PATCH] Add `--select-if-one` flag to `choose`/`filter`. (#398) * Add `--select-if-one` flag to `choose`/`filter`. * Remove accidental commit of other changes. * fix: use o.Options --------- Co-authored-by: Maas Lalani --- choose/command.go | 5 +++++ choose/options.go | 1 + filter/command.go | 9 +++++++++ filter/options.go | 1 + format/formats.go | 2 +- main.go | 2 +- 6 files changed, 18 insertions(+), 2 deletions(-) diff --git a/choose/command.go b/choose/command.go index bd7db4129..1b99d11b4 100644 --- a/choose/command.go +++ b/choose/command.go @@ -35,6 +35,11 @@ func (o Options) Run() error { o.Options = strings.Split(strings.TrimSuffix(input, "\n"), "\n") } + if o.SelectIfOne && len(o.Options) == 1 { + print(o.Options[0]) + return nil + } + // We don't need to display prefixes if we are only picking one option. // Simply displaying the cursor is enough. if o.Limit == 1 && !o.NoLimit { diff --git a/choose/options.go b/choose/options.go index 52e3a50d9..cab9e801d 100644 --- a/choose/options.go +++ b/choose/options.go @@ -19,6 +19,7 @@ type Options struct { SelectedPrefix string `help:"Prefix to show on selected items (hidden if limit is 1)" default:"◉ " env:"GUM_CHOOSE_SELECTED_PREFIX"` UnselectedPrefix string `help:"Prefix to show on unselected items (hidden if limit is 1)" default:"○ " env:"GUM_CHOOSE_UNSELECTED_PREFIX"` Selected []string `help:"Options that should start as selected" default:"" env:"GUM_CHOOSE_SELECTED"` + SelectIfOne bool `help:"Select the given option if there is only one" group:"Selection"` CursorStyle style.Styles `embed:"" prefix:"cursor." set:"defaultForeground=212" envprefix:"GUM_CHOOSE_CURSOR_"` HeaderStyle style.Styles `embed:"" prefix:"header." set:"defaultForeground=240" envprefix:"GUM_CHOOSE_HEADER_"` ItemStyle style.Styles `embed:"" prefix:"item." hidden:"" envprefix:"GUM_CHOOSE_ITEM_"` diff --git a/filter/command.go b/filter/command.go index 4fa6e0ece..86b4e6044 100644 --- a/filter/command.go +++ b/filter/command.go @@ -45,6 +45,15 @@ func (o Options) Run() error { return errors.New("no options provided, see `gum filter --help`") } + if o.SelectIfOne && len(o.Options) == 1 { + if isatty.IsTerminal(os.Stdout.Fd()) { + fmt.Print(o.Options[0]) + } else { + fmt.Print(ansi.Strip(o.Options[0])) + } + return nil + } + options := []tea.ProgramOption{tea.WithOutput(os.Stderr)} if o.Height == 0 { options = append(options, tea.WithAltScreen()) diff --git a/filter/options.go b/filter/options.go index c2957022c..70cbe6dfa 100644 --- a/filter/options.go +++ b/filter/options.go @@ -14,6 +14,7 @@ type Options struct { IndicatorStyle style.Styles `embed:"" prefix:"indicator." set:"defaultForeground=212" envprefix:"GUM_FILTER_INDICATOR_"` Limit int `help:"Maximum number of options to pick" default:"1" group:"Selection"` NoLimit bool `help:"Pick unlimited number of options (ignores limit)" group:"Selection"` + SelectIfOne bool `help:"Select the given option if there is only one" group:"Selection"` Strict bool `help:"Only returns if anything matched. Otherwise return Filter" negatable:"true" default:"true" group:"Selection"` SelectedPrefix string `help:"Character to indicate selected items (hidden if limit is 1)" default:" ◉ " env:"GUM_FILTER_SELECTED_PREFIX"` SelectedPrefixStyle style.Styles `embed:"" prefix:"selected-indicator." set:"defaultForeground=212" envprefix:"GUM_FILTER_SELECTED_PREFIX_"` diff --git a/format/formats.go b/format/formats.go index 412c50998..d12313544 100644 --- a/format/formats.go +++ b/format/formats.go @@ -54,7 +54,7 @@ func markdown(input string, theme string) (string, error) { } func template(input string) (string, error) { - f := termenv.TemplateFuncs(termenv.EnvColorProfile()) + f := termenv.TemplateFuncs(termenv.ColorProfile()) t, err := tpl.New("tpl").Funcs(f).Parse(input) if err != nil { return "", fmt.Errorf("unable to parse template: %w", err) diff --git a/main.go b/main.go index e014adc4b..5d2c50d91 100644 --- a/main.go +++ b/main.go @@ -28,7 +28,7 @@ var ( var bubbleGumPink = lipgloss.NewStyle().Foreground(lipgloss.Color("212")) func main() { - lipgloss.SetColorProfile(termenv.NewOutput(os.Stderr).EnvColorProfile()) + lipgloss.SetColorProfile(termenv.NewOutput(os.Stderr).Profile) if Version == "" { if info, ok := debug.ReadBuildInfo(); ok && info.Main.Sum != "" {