diff --git a/js_modules/dagster-ui/packages/ui-core/src/search/SearchDialog.tsx b/js_modules/dagster-ui/packages/ui-core/src/search/SearchDialog.tsx index e9855337ff37c..e8605d16b4161 100644 --- a/js_modules/dagster-ui/packages/ui-core/src/search/SearchDialog.tsx +++ b/js_modules/dagster-ui/packages/ui-core/src/search/SearchDialog.tsx @@ -72,6 +72,14 @@ const initialState: State = { const DEBOUNCE_MSEC = 100; +// sort by Fuse score ascending, lower is better +const sortResultsByFuseScore = ( + a: Fuse.FuseResult, + b: Fuse.FuseResult, +) => { + return (a.score ?? 0) - (b.score ?? 0); +}; + export const SearchDialog = () => { const history = useHistory(); const {initialize, loading, searchPrimary, searchSecondary} = useGlobalSearch({ @@ -82,9 +90,11 @@ export const SearchDialog = () => { const [state, dispatch] = React.useReducer(reducer, initialState); const {shown, queryString, primaryResults, secondaryResults, highlight} = state; - const results = [...primaryResults, ...secondaryResults]; - const renderedResults = results.slice(0, MAX_DISPLAYED_RESULTS); - const numRenderedResults = renderedResults.length; + const {renderedResults, numRenderedResults} = React.useMemo(() => { + const results = [...primaryResults, ...secondaryResults].sort(sortResultsByFuseScore); + const renderedResults = results.slice(0, MAX_DISPLAYED_RESULTS); + return {renderedResults, numRenderedResults: renderedResults.length}; + }, [primaryResults, secondaryResults]); const openSearch = React.useCallback(() => { trackEvent('open-global-search'); diff --git a/js_modules/dagster-ui/packages/ui-core/src/search/useGlobalSearch.tsx b/js_modules/dagster-ui/packages/ui-core/src/search/useGlobalSearch.tsx index c17bb0674470e..013e1435c8093 100644 --- a/js_modules/dagster-ui/packages/ui-core/src/search/useGlobalSearch.tsx +++ b/js_modules/dagster-ui/packages/ui-core/src/search/useGlobalSearch.tsx @@ -307,6 +307,7 @@ const fuseOptions = { threshold: 0.3, useExtendedSearch: true, includeMatches: true, + includeScore: true, // Allow searching to continue to the end of the string. ignoreLocation: true,