mirror of
https://github.com/gristlabs/grist-core.git
synced 2024-10-27 20:44:07 +00:00
(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:
parent
afb83a4ff1
commit
34f8078ead
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user