Skip to content

Commit

Permalink
fix(editor): Fix completion on $input.item. in Code node (n8n-io#10800)
Browse files Browse the repository at this point in the history
  • Loading branch information
elsmr authored Sep 13, 2024
1 parent b2b1abc commit 45dccf3
Show file tree
Hide file tree
Showing 3 changed files with 80 additions and 9 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
import { CompletionContext } from '@codemirror/autocomplete';
import { EditorSelection, EditorState } from '@codemirror/state';
import { useItemFieldCompletions } from '../itemField.completions';

describe('inputMethodCompletions', () => {
test('should return completions for $input.item.|', () => {
const { inputMethodCompletions } = useItemFieldCompletions('javaScript');
expect(inputMethodCompletions(createContext('$input.item.|'))).toEqual({
from: 0,
options: [
{
info: expect.any(Function),
label: '$input.item.json',
type: 'variable',
},

{
info: expect.any(Function),
label: '$input.item.binary',
type: 'variable',
},
],
});
});

test('should return completions for $input.first().|', () => {
const { inputMethodCompletions } = useItemFieldCompletions('javaScript');
expect(inputMethodCompletions(createContext('$input.first().|'))).toEqual({
from: 0,
options: [
{
info: expect.any(Function),
label: '$input.first().json',
type: 'variable',
},

{
info: expect.any(Function),
label: '$input.first().binary',
type: 'variable',
},
],
});
});

test('should return completions for $input.all()[1].|', () => {
const { inputMethodCompletions } = useItemFieldCompletions('javaScript');
expect(inputMethodCompletions(createContext('$input.all()[1].|'))).toEqual({
from: 0,
options: [
{
info: expect.any(Function),
label: '$input.all()[1].json',
type: 'variable',
},

{
info: expect.any(Function),
label: '$input.all()[1].binary',
type: 'variable',
},
],
});
});
});

export function createContext(docWithCursor: string) {
const cursorPosition = docWithCursor.indexOf('|');

const doc = docWithCursor.slice(0, cursorPosition) + docWithCursor.slice(cursorPosition + 1);

return new CompletionContext(
EditorState.create({ doc, selection: EditorSelection.single(cursorPosition) }),
cursorPosition,
false,
);
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { addVarType, escape } from '../utils';
import { addInfoRenderer, addVarType, escape } from '../utils';
import type { Completion, CompletionContext, CompletionResult } from '@codemirror/autocomplete';
import { useI18n } from '@/composables/useI18n';

Expand Down Expand Up @@ -54,7 +54,7 @@ export function useItemFieldCompletions(language: 'python' | 'javaScript') {
const patterns = {
first: new RegExp(`\\${prefix}input\\.first\\(\\)\\..*`),
last: new RegExp(`\\${prefix}input\\.last\\(\\)\\..*`),
item: new RegExp(`\\${prefix}item\\.first\\(\\)\\..*`),
item: new RegExp(`\\${prefix}input\\.item\\..*`),
all: /\$input\.all\(\)\[(?<index>\w+)\]\..*/,
};

Expand Down Expand Up @@ -94,7 +94,7 @@ export function useItemFieldCompletions(language: 'python' | 'javaScript') {

return {
from: preCursor.from,
options: options.map(addVarType),
options: options.map(addVarType).map(addInfoRenderer),
};
}

Expand Down

This file was deleted.

0 comments on commit 45dccf3

Please sign in to comment.