From ebb9e2a7153d46a0edb83759f158aa99db408385 Mon Sep 17 00:00:00 2001 From: Youhei Sakurai Date: Wed, 29 Nov 2023 23:22:14 +0900 Subject: [PATCH] [Console] Fix autocomplete on typing in every letter (#171952) Closes #171951 ## Summary This PR fixes autocomplete to show suggestions even if user types in every letter. ![autocomplete-typing-in](https://github.com/elastic/kibana/assets/721858/c2d2dfb9-bc81-4285-b5c1-444d634f9af2) ### Checklist - [x] [Unit or functional tests](https://www.elastic.co/guide/en/kibana/master/development-tests.html) were updated or added to match the most common scenarios ### 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 autocomplete to show suggestions even if user types in every letter (cherry picked from commit 1f5a3a08a53d3d60cae0eb2aa310ff90217436f7) --- .../autocomplete/looks_like_typing_in.test.ts | 4 ++++ .../lib/autocomplete/looks_like_typing_in.ts | 21 ++++++++++++------- 2 files changed, 18 insertions(+), 7 deletions(-) diff --git a/src/plugins/console/public/lib/autocomplete/looks_like_typing_in.test.ts b/src/plugins/console/public/lib/autocomplete/looks_like_typing_in.test.ts index 969f06f8d994f..cbcfb724798df 100644 --- a/src/plugins/console/public/lib/autocomplete/looks_like_typing_in.test.ts +++ b/src/plugins/console/public/lib/autocomplete/looks_like_typing_in.test.ts @@ -103,6 +103,10 @@ describe('looksLikeTypingIn', () => { { preamble: 'GET _cat/indices?s=index&exp', autocomplete: 'and_wildcards', input: '=' }, { preamble: 'GET _cat/indices?v&', autocomplete: 'expand_wildcards', input: '=' }, { preamble: 'GET _cat/indices?v&exp', autocomplete: 'and_wildcards', input: '=' }, + // autocomplete skips one iteration of token evaluation if user types in every letter + { preamble: 'GET .kibana', autocomplete: '/', input: '_' }, // token '/' may not be evaluated + { preamble: 'GET .kibana', autocomplete: ',', input: '.' }, // token ',' may not be evaluated + { preamble: 'GET .kibana', autocomplete: '?', input: 'k' }, // token '?' may not be evaluated ]; for (const c of cases) { const name = diff --git a/src/plugins/console/public/lib/autocomplete/looks_like_typing_in.ts b/src/plugins/console/public/lib/autocomplete/looks_like_typing_in.ts index a679aa2eda117..44dbb99025c73 100644 --- a/src/plugins/console/public/lib/autocomplete/looks_like_typing_in.ts +++ b/src/plugins/console/public/lib/autocomplete/looks_like_typing_in.ts @@ -11,6 +11,7 @@ import type { CoreEditor, Position, Token } from '../../types'; enum Move { ForwardOneCharacter = 1, ForwardOneToken, // the column position may jump to the next token by autocomplete + ForwardTwoTokens, // the column position could jump two tokens due to autocomplete } const knownTypingInTokenTypes = new Map>>([ @@ -43,6 +44,10 @@ const knownTypingInTokenTypes = new Map>>([ ['whitespace', new Set(['url.comma', 'url.questionmark', 'url.slash'])], ]), ], + [ + Move.ForwardTwoTokens, + new Map>([['url.part', new Set(['url.param', 'url.part'])]]), + ], ]); const getOneCharacterNextOnTheRight = (pos: Position, coreEditor: CoreEditor): string => { @@ -75,14 +80,16 @@ export const looksLikeTypingIn = ( currentToken.value.length === 1 && getOneCharacterNextOnTheRight(currentToken.position, coreEditor) === '' ) { - const move = + const moves = lastEvaluatedToken.position.column + 1 === currentToken.position.column - ? Move.ForwardOneCharacter - : Move.ForwardOneToken; - const tokenTypesPairs = knownTypingInTokenTypes.get(move) ?? new Map>(); - const currentTokenTypes = tokenTypesPairs.get(lastEvaluatedToken.type) ?? new Set(); - if (currentTokenTypes.has(currentToken.type)) { - return true; + ? [Move.ForwardOneCharacter] + : [Move.ForwardOneToken, Move.ForwardTwoTokens]; + for (const move of moves) { + const tokenTypesPairs = knownTypingInTokenTypes.get(move) ?? new Map>(); + const currentTokenTypes = tokenTypesPairs.get(lastEvaluatedToken.type) ?? new Set(); + if (currentTokenTypes.has(currentToken.type)) { + return true; + } } }