From b4dc9e13cb56331364200a7bc427a10fd771edc9 Mon Sep 17 00:00:00 2001 From: 2 * r + 2 * t <61896496+soramanew@users.noreply.github.com> Date: Sat, 19 Jul 2025 16:21:53 +1000 Subject: launcher: better scheme search --- utils/Searcher.qml | 28 +++++++++++++++++++++------- 1 file changed, 21 insertions(+), 7 deletions(-) (limited to 'utils') diff --git a/utils/Searcher.qml b/utils/Searcher.qml index 8fe8dee..053b73b 100644 --- a/utils/Searcher.qml +++ b/utils/Searcher.qml @@ -10,18 +10,31 @@ Singleton { property bool useFuzzy: false property var extraOpts: ({}) + // Extra stuff for fuzzy + property list keys: [key] + property list weights: [1] + readonly property var fzf: useFuzzy ? [] : new Fzf.Finder(list, Object.assign({ - selector: e => e[key] + selector }, extraOpts)) - readonly property list fuzzyPrepped: useFuzzy ? list.map(e => ({ - [key]: e[key], - _item: e - })) : [] + readonly property list fuzzyPrepped: useFuzzy ? list.map(e => { + const obj = { + _item: e + }; + for (const k of keys) + obj[k] = Fuzzy.prepare(e[k]); + return obj; + }) : [] function transformSearch(search: string): string { return search; } + function selector(item: var): string { + // Only for fzf + return item[key]; + } + function query(search: string): list { search = transformSearch(search); if (!search) @@ -30,12 +43,13 @@ Singleton { if (useFuzzy) return Fuzzy.go(search, fuzzyPrepped, Object.assign({ all: true, - key + keys, + scoreFn: r => weights.reduce((a, w, i) => a + r[i].score * w, 0) }, extraOpts)).map(r => r.obj._item); return fzf.find(search).sort((a, b) => { if (a.score === b.score) - return a.item[key].trim().length - b.item[key].trim().length; + return selector(a.item).trim().length - selector(b.item).trim().length; return b.score - a.score; }).map(r => r.item); } -- cgit v1.2.3-freya