(core) Fix searching in filter for coltype not a text-or-number (ie: Date)

Summary:
 - Simply apply search against word label instead of the key
 - Fix a tricky bug of observable dependencies that appeared while working on this diff.

Test Plan: Added a browser test for searching date in the filter menu.

Reviewers: paulfitz

Reviewed By: paulfitz

Subscribers: paulfitz

Differential Revision: https://phab.getgrist.com/D2762
This commit is contained in:
Cyprien P 2021-03-18 14:16:05 +01:00
parent afb83a4ff1
commit 34f8078ead

View File

@ -58,7 +58,7 @@ export function columnFilterMenu(owner: IDisposableOwner,
// computes a set of all keys that matches the search text. // computes a set of all keys that matches the search text.
const filterSet = Computed.create(owner, searchValueObs, (_use, searchValue) => { const filterSet = Computed.create(owner, searchValueObs, (_use, searchValue) => {
const searchRegex = new RegExp(escapeRegExp(searchValue), 'i'); const searchRegex = new RegExp(escapeRegExp(searchValue), 'i');
return new Set(valueCountArr.filter(([key]) => searchRegex.test(key as string)).map(([key]) => key)); return new Set(valueCountArr.filter(([_, {label}]) => searchRegex.test(label)).map(([key]) => key));
}); });
// computes the sorted array of all values (ie: pair of key and IFilterCount) that matches the search text. // computes the sorted array of all values (ie: pair of key and IFilterCount) that matches the search text.
@ -129,6 +129,9 @@ export function columnFilterMenu(owner: IDisposableOwner,
cssMenuItem( cssMenuItem(
dom.domComputed((use) => { dom.domComputed((use) => {
const searchValue = use(searchValueObs); const searchValue = use(searchValueObs);
// This is necessary to avoid a known bug in grainjs where filteredKeys does not get
// recalculated.
use(filteredKeys);
const allSpec = searchValue ? {included: use(filteredKeys)} : {excluded: []}; const allSpec = searchValue ? {included: use(filteredKeys)} : {excluded: []};
const noneSpec = searchValue ? {excluded: use(filteredKeys)} : {included: []}; const noneSpec = searchValue ? {excluded: use(filteredKeys)} : {included: []};
const state = use(columnFilter.state); const state = use(columnFilter.state);