From cf639ec94bb79dffd096c027b6c4fc51befc98f6 Mon Sep 17 00:00:00 2001 From: Arvid Bjurklint Date: Wed, 7 Aug 2024 18:05:06 +0200 Subject: [PATCH] Filter the keys only when the prompt is updated --- main.go | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/main.go b/main.go index 4341d95..59f911b 100644 --- a/main.go +++ b/main.go @@ -102,11 +102,13 @@ func main() { defer quit() _, height := screen.Size() prompt := "" + nextPrompt := "" selectedIndex := 0 drawPrompt(screen, height, prompt) drawLoadingScreen(screen, height) screen.Show() keys := getKeys(vault, DirEnt{IsDir: true, Name: "/"}) + filteredKeys = keys for { ev := screen.PollEvent() switch ev := ev.(type) { @@ -129,24 +131,27 @@ func main() { return case tcell.KeyBackspace, tcell.KeyBackspace2: if len(prompt) > 0 { - prompt = prompt[:len(prompt)-1] + nextPrompt = prompt[:len(prompt)-1] } case tcell.KeyCtrlU: - prompt = "" + nextPrompt = "" case tcell.KeyCtrlK, tcell.KeyCtrlP: selectedIndex = min(len(filteredKeys)-1, selectedIndex+1) case tcell.KeyCtrlJ, tcell.KeyCtrlN: selectedIndex = max(0, selectedIndex-1) case tcell.KeyRune: - prompt += string(ev.Rune()) + nextPrompt += string(ev.Rune()) selectedIndex = 0 } } width, height := screen.Size() - filteredKeys = []string{} - for _, k := range keys { - if strings.Contains(k, prompt) { - filteredKeys = append(filteredKeys, k) + if nextPrompt != prompt { + prompt = nextPrompt + filteredKeys = []string{} + for _, k := range keys { + if strings.Contains(k, prompt) { + filteredKeys = append(filteredKeys, k) + } } } screen.Clear()