mirror of
https://github.com/apache/superset.git
synced 2026-04-24 18:44:53 +00:00
fix(sqllab): Add docText for long keyword (#24847)
This commit is contained in:
@@ -267,3 +267,49 @@ test('returns column keywords among selected tables', async () => {
|
||||
),
|
||||
);
|
||||
});
|
||||
|
||||
test('returns long keywords with docText', async () => {
|
||||
const expectLongKeywordDbId = 2;
|
||||
const longKeyword = 'veryveryveryveryverylongtablename';
|
||||
const dbFunctionNamesApiRoute = `glob:*/api/v1/database/${expectLongKeywordDbId}/function_names/`;
|
||||
fetchMock.get(dbFunctionNamesApiRoute, { function_names: [] });
|
||||
|
||||
act(() => {
|
||||
store.dispatch(
|
||||
schemaApiUtil.upsertQueryData(
|
||||
'schemas',
|
||||
{
|
||||
dbId: expectLongKeywordDbId,
|
||||
forceRefresh: false,
|
||||
},
|
||||
['short', longKeyword].map(value => ({
|
||||
value,
|
||||
label: value,
|
||||
title: value,
|
||||
})),
|
||||
),
|
||||
);
|
||||
});
|
||||
const { result, waitFor } = renderHook(
|
||||
() =>
|
||||
useKeywords({
|
||||
queryEditorId: 'testqueryid',
|
||||
dbId: expectLongKeywordDbId,
|
||||
}),
|
||||
{
|
||||
wrapper: createWrapper({
|
||||
useRedux: true,
|
||||
store,
|
||||
}),
|
||||
},
|
||||
);
|
||||
await waitFor(() =>
|
||||
expect(result.current).toContainEqual(
|
||||
expect.objectContaining({
|
||||
name: longKeyword,
|
||||
value: longKeyword,
|
||||
docText: longKeyword,
|
||||
}),
|
||||
),
|
||||
);
|
||||
});
|
||||
|
||||
@@ -50,6 +50,11 @@ const EMPTY_LIST = [] as typeof sqlKeywords;
|
||||
const { useQueryState: useSchemasQueryState } = schemaEndpoints.schemas;
|
||||
const { useQueryState: useTablesQueryState } = tableEndpoints.tables;
|
||||
|
||||
const getHelperText = (value: string) =>
|
||||
value.length > 30 && {
|
||||
docText: value,
|
||||
};
|
||||
|
||||
export function useKeywords(
|
||||
{ queryEditorId, dbId, schema }: Params,
|
||||
skip = false,
|
||||
@@ -149,6 +154,7 @@ export function useKeywords(
|
||||
completer: {
|
||||
insertMatch,
|
||||
},
|
||||
...getHelperText(s.value),
|
||||
})),
|
||||
[schemaOptions, insertMatch],
|
||||
);
|
||||
@@ -163,6 +169,7 @@ export function useKeywords(
|
||||
completer: {
|
||||
insertMatch,
|
||||
},
|
||||
...getHelperText(value),
|
||||
})),
|
||||
[tableData?.options, insertMatch],
|
||||
);
|
||||
@@ -174,6 +181,7 @@ export function useKeywords(
|
||||
value: col,
|
||||
score: COLUMN_AUTOCOMPLETE_SCORE,
|
||||
meta: 'column',
|
||||
...getHelperText(col),
|
||||
})),
|
||||
[allColumns],
|
||||
);
|
||||
@@ -188,6 +196,7 @@ export function useKeywords(
|
||||
completer: {
|
||||
insertMatch,
|
||||
},
|
||||
...getHelperText(func),
|
||||
})),
|
||||
[functionNames, insertMatch],
|
||||
);
|
||||
|
||||
Reference in New Issue
Block a user