From 412040f77ecd24926f8b0ecbc12ec1b7d3be6b6d Mon Sep 17 00:00:00 2001 From: Junegunn Choi Date: Sun, 31 Dec 2023 20:55:24 +0900 Subject: [PATCH] Enable preview if 'transform' action is bound to a key --- src/terminal.go | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/src/terminal.go b/src/terminal.go index 0e378584..152475f8 100644 --- a/src/terminal.go +++ b/src/terminal.go @@ -587,10 +587,14 @@ func trimQuery(query string) []rune { return []rune(strings.Replace(query, "\t", " ", -1)) } -func hasPreviewAction(opts *Options) bool { +func mayTriggerPreview(opts *Options) bool { + if opts.ListenAddr != nil { + return true + } for _, actions := range opts.Keymap { for _, action := range actions { - if action.t == actPreview || action.t == actChangePreview { + switch action.t { + case actPreview, actChangePreview, actTransform: return true } } @@ -629,8 +633,11 @@ func NewTerminal(opts *Options, eventBox *util.EventBox) *Terminal { delay = initialDelay } var previewBox *util.EventBox - // We need to start previewer if HTTP server is enabled even when --preview option is not specified - if len(opts.Preview.command) > 0 || hasPreviewAction(opts) || opts.ListenAddr != nil { + // We need to start the previewer even when --preview option is not specified + // * if HTTP server is enabled + // * if 'preview' or 'change-preview' action is bound to a key + // * if 'transform' action is bound to a key + if len(opts.Preview.command) > 0 || mayTriggerPreview(opts) { previewBox = util.NewEventBox() } var renderer tui.Renderer