Skip to content

Commit

Permalink
[Auto Suggest] Look and Feel changes (#7991) (#8063)
Browse files Browse the repository at this point in the history
* put in trigger suggest on focus and on type space



* modify dql suggestions to keep suggestion chaining fluid



* Changeset file for PR #7991 created/updated

* user hints



* specify dql operators in details and icon



* Changeset file for PR #7991 created/updated

* Changeset file for PR #7991 created/updated

* update testing constants



* modify scss



* Changeset file for PR #7991 created/updated

---------



(cherry picked from commit 4776fcd)

Signed-off-by: Paul Sebastian <[email protected]>
Signed-off-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
Co-authored-by: opensearch-changeset-bot[bot] <154024398+opensearch-changeset-bot[bot]@users.noreply.github.com>
  • Loading branch information
3 people authored Sep 9, 2024
1 parent 9a9c4b5 commit a83f4e3
Show file tree
Hide file tree
Showing 9 changed files with 65 additions and 11 deletions.
2 changes: 2 additions & 0 deletions changelogs/fragments/7991.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
feat:
- Keep Autocomplete suggestion window open and put user hints below the suggestion window ([#7991](https://github.com/opensearch-project/OpenSearch-Dashboards/pull/7991))
20 changes: 12 additions & 8 deletions src/plugins/data/public/antlr/dql/code_completion.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -174,11 +174,11 @@ const testingIndex = ({
} as unknown) as IndexPattern;

const booleanOperatorSuggestions = [
{ text: 'or', type: 17, detail: 'Keyword' },
{ text: 'and', type: 17, detail: 'Keyword' },
{ text: 'or', type: 11, detail: 'Operator', insertText: 'or ' },
{ text: 'and', type: 11, detail: 'Operator', insertText: 'and ' },
];

const notOperatorSuggestion = { text: 'not', type: 17, detail: 'Keyword' };
const notOperatorSuggestion = { text: 'not', type: 11, detail: 'Operator', insertText: 'not ' };

const fieldNameSuggestions: Array<{
text: string;
Expand Down Expand Up @@ -211,27 +211,31 @@ const carrierValues = [
];

const allCarrierValueSuggestions = [
{ text: 'Logstash Airways', type: 13, detail: 'Value' },
{ text: 'BeatsWest', type: 13, detail: 'Value' },
{ text: 'Logstash Airways', type: 13, detail: 'Value', insertText: 'Logstash Airways ' },
{ text: 'BeatsWest', type: 13, detail: 'Value', insertText: 'BeatsWest ' },
{
text: 'OpenSearch Dashboards Airlines',
type: 13,
detail: 'Value',
insertText: 'OpenSearch Dashboards Airlines ',
},
{ text: 'OpenSearch-Air', type: 13, detail: 'Value' },
{ text: 'OpenSearch-Air', type: 13, detail: 'Value', insertText: 'OpenSearch-Air ' },
];

const carrierWithNotSuggestions = allCarrierValueSuggestions.concat(notOperatorSuggestion);

const logCarrierValueSuggestion = [{ text: 'Logstash Airways', type: 13, detail: 'Value' }];
const logCarrierValueSuggestion = [
{ text: 'Logstash Airways', type: 13, detail: 'Value', insertText: 'Logstash Airways ' },
];

const openCarrierValueSuggestion = [
{
text: 'OpenSearch Dashboards Airlines',
type: 13,
detail: 'Value',
insertText: 'OpenSearch Dashboards Airlines ',
},
{ text: 'OpenSearch-Air', type: 13, detail: 'Value' },
{ text: 'OpenSearch-Air', type: 13, detail: 'Value', insertText: 'OpenSearch-Air ' },
];

const addPositionToValue = (vals: any, start: number, end: number) =>
Expand Down
17 changes: 14 additions & 3 deletions src/plugins/data/public/antlr/dql/code_completion.ts
Original file line number Diff line number Diff line change
Expand Up @@ -135,7 +135,7 @@ export const getSuggestions = async ({

// check to see if field rule is a candidate. if so, suggest field names
if (candidates.rules.has(DQLParser.RULE_field)) {
completions.push(...fetchFieldSuggestions(indexPattern, (f) => `${f}: `));
completions.push(...fetchFieldSuggestions(indexPattern, (f: any) => `${f}: `));
}

interface FoundLastValue {
Expand Down Expand Up @@ -247,12 +247,15 @@ export const getSuggestions = async ({
cursorLine,
cursorColumn + 1
),
insertText: `${val} `,
};
})
);
}
}

const dqlOperators = new Set([DQLParser.AND, DQLParser.OR, DQLParser.NOT]);

// suggest other candidates, mainly keywords
[...candidates.tokens.keys()].forEach((token: number) => {
// ignore identifier, already handled with field rule
Expand All @@ -261,11 +264,19 @@ export const getSuggestions = async ({
}

const tokenSymbolName = parser.vocabulary.getSymbolicName(token)?.toLowerCase();

if (tokenSymbolName) {
let type = monaco.languages.CompletionItemKind.Keyword;
let detail = SuggestionItemDetailsTags.Keyword;
if (dqlOperators.has(token)) {
type = monaco.languages.CompletionItemKind.Operator;
detail = SuggestionItemDetailsTags.Operator;
}
completions.push({
text: tokenSymbolName,
type: monaco.languages.CompletionItemKind.Keyword,
detail: SuggestionItemDetailsTags.Keyword,
type,
detail,
insertText: `${tokenSymbolName} `,
});
}
});
Expand Down
1 change: 1 addition & 0 deletions src/plugins/data/public/antlr/shared/constants.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,5 +8,6 @@ export const enum SuggestionItemDetailsTags {
Keyword = 'Keyword',
AggregateFunction = 'Aggregate Function',
Value = 'Value',
Operator = 'Operator',
}
export const quotesRegex = /^'(.*)'$/;
20 changes: 20 additions & 0 deletions src/plugins/data/public/ui/query_editor/_query_editor.scss
Original file line number Diff line number Diff line change
Expand Up @@ -199,3 +199,23 @@
border: none;
}
}

.suggest-widget {
position: relative;

&.visible::after {
position: absolute;
height: auto;
bottom: auto;
left: 0;
width: 100%;
background-color: $euiColorLightestShade;
border: $euiBorderThin;
padding: $euiSizeXS;
text-align: left;
color: $euiColorDarkShade;
font-size: $euiFontSizeXS;
content: "Tab to insert, ESC to close window";
display: block;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ export const DefaultInput: React.FC<DefaultInputProps> = ({
}}
suggestionProvider={{
provideCompletionItems,
triggerCharacters: [' '],
}}
languageConfiguration={{
autoClosingPairs: [
Expand All @@ -65,6 +66,7 @@ export const DefaultInput: React.FC<DefaultInputProps> = ({
{ open: "'", close: "'" },
],
}}
triggerSuggestOnFocus={true}
/>
<div className="defaultEditor__footer">
{footerItems && (
Expand Down
2 changes: 2 additions & 0 deletions src/plugins/data/public/ui/query_editor/editors/shared.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,7 @@ export const SingleLineInput: React.FC<SingleLineInputProps> = ({
}}
suggestionProvider={{
provideCompletionItems,
triggerCharacters: [' '],
}}
languageConfiguration={{
autoClosingPairs: [
Expand All @@ -108,6 +109,7 @@ export const SingleLineInput: React.FC<SingleLineInputProps> = ({
},
],
}}
triggerSuggestOnFocus={true}
/>
</div>
</div>
Expand Down
1 change: 1 addition & 0 deletions src/plugins/data/public/ui/query_editor/query_editor.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -309,6 +309,7 @@ export default class QueryEditorUI extends Component<Props, State> {
insertText: s.insertText ?? s.text,
range: s.replacePosition ?? defaultRange,
detail: s.detail,
command: { id: 'editor.action.triggerSuggest', title: 'Trigger Next Suggestion' },
};
})
: [],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,11 @@ export interface Props {
* Should the editor use the dark theme
*/
useDarkTheme?: boolean;

/**
* Whether the suggestion widget/window will be triggered upon clicking into the editor
*/
triggerSuggestOnFocus?: boolean;
}

export class CodeEditor extends React.Component<Props, {}> {
Expand Down Expand Up @@ -141,6 +146,12 @@ export class CodeEditor extends React.Component<Props, {}> {
if (this.props.editorDidMount) {
this.props.editorDidMount(editor);
}

if (this.props.triggerSuggestOnFocus) {
editor.onDidFocusEditorWidget(() => {
editor.trigger('keyboard', 'editor.action.triggerSuggest', {});
});
}
};

render() {
Expand Down

0 comments on commit a83f4e3

Please sign in to comment.