[Console] Fix wrong autocomplete suggestions on typing in slash (#171948)

Closes #171947

## Summary

This PR fixes wrong autocomplete suggestions on typing in slash in some
specific cases.

![fix-suggestion-on-slash](f3cab482-63ca-4ee7-99b7-0e3fc37e8940)

### For maintainers

- [x] This was checked for breaking API changes and was [labeled
appropriately](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)

## Release note

Fixes wrong autocomplete suggestions on typing in slash
This commit is contained in:
Youhei Sakurai 2023-11-29 23:22:40 +09:00 committed by GitHub
parent 1f5a3a08a5
commit 11136b6880
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -983,32 +983,33 @@ export default function ({
context.urlTokenPath = ret.urlTokenPath;
const components = getTopLevelUrlCompleteComponents(context.method);
const { tokenPath, predicate } = (() => {
const lastUrlTokenPath =
Array.isArray(context.urlTokenPath) && context.urlTokenPath.length !== 0
? context.urlTokenPath[context.urlTokenPath.length - 1]
: null;
// Checking the last chunk of path like 'c,d,' of 'GET /a/b/c,d,'
if (
Array.isArray(lastUrlTokenPath) &&
// true if neither c nor d equals to every ConstantComponent's name (such as _search)
!_.find(
components,
(c) => c instanceof ConstantComponent && _.find(lastUrlTokenPath, (p) => c.name === p)
)
) {
// will simulate autocomplete on 'GET /a/b/' with a filter by index
return {
tokenPath: context.urlTokenPath?.slice(0, -1),
predicate: (term: ReturnType<typeof addMetaToTermsList>[0]) => term.meta === 'index',
};
} else {
// will do nothing special
return { tokenPath: context.urlTokenPath, predicate: () => true };
}
})();
let urlTokenPath = context.urlTokenPath;
let predicate: (term: ReturnType<typeof addMetaToTermsList>[0]) => boolean = () => true;
populateContext(tokenPath, context, editor, true, components);
const tokenIter = createTokenIterator({ editor, position: pos });
const currentTokenType = tokenIter.getCurrentToken()?.type;
const previousTokenType = tokenIter.stepBackward()?.type;
if (!Array.isArray(urlTokenPath)) {
// skip checks for url.comma
} else if (previousTokenType === 'url.comma' && currentTokenType === 'url.comma') {
predicate = () => false; // two consecutive commas empty the autocomplete
} else if (
(previousTokenType === 'url.part' && currentTokenType === 'url.comma') ||
(previousTokenType === 'url.slash' && currentTokenType === 'url.comma') ||
(previousTokenType === 'url.comma' && currentTokenType === 'url.part')
) {
const lastUrlTokenPath = _.last(urlTokenPath) || []; // ['c', 'd'] from 'GET /a/b/c,d,'
const constantComponents = _.filter(components, (c) => c instanceof ConstantComponent);
const constantComponentNames = _.map(constantComponents, 'name');
// check if neither 'c' nor 'd' is a constant component name such as '_search'
if (_.every(lastUrlTokenPath, (token) => !_.includes(constantComponentNames, token))) {
urlTokenPath = urlTokenPath.slice(0, -1); // drop the last 'c,d,' part from the url path
predicate = (term) => term.meta === 'index'; // limit the autocomplete to indices only
}
}
populateContext(urlTokenPath, context, editor, true, components);
context.autoCompleteSet = _.filter(
addMetaToTermsList(context.autoCompleteSet!, 'endpoint'),
predicate