From 51f59905591fa492017fc3ced46601eeca5fb057 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Iv=C3=A1n=20Ovejero?= Date: Tue, 2 May 2023 09:36:42 +0200 Subject: [PATCH] fix(editor): Fix quote handling on dollar-sign variable completions (#6128) :bug: Fix quote handling on dollar-sign variable completions --- .../codemirror/completions/__tests__/completions.test.ts | 8 ++++++++ .../codemirror/completions/datatype.completions.ts | 5 +++-- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/packages/editor-ui/src/plugins/codemirror/completions/__tests__/completions.test.ts b/packages/editor-ui/src/plugins/codemirror/completions/__tests__/completions.test.ts index d99e41eea0..ba72cb4e4d 100644 --- a/packages/editor-ui/src/plugins/codemirror/completions/__tests__/completions.test.ts +++ b/packages/editor-ui/src/plugins/codemirror/completions/__tests__/completions.test.ts @@ -276,6 +276,14 @@ describe('Resolution-based completions', () => { ); }); + test('should return completions for: {{ "hello"+input.| }}', () => { + resolveParameterSpy.mockReturnValue($input); + + expect(completions('{{ "hello"+$input.| }}')).toHaveLength( + Reflect.ownKeys($input).length + natives('object').length, + ); + }); + test("should return completions for: {{ $('nodeName').| }}", () => { resolveParameterSpy.mockReturnValue($('Rename')); diff --git a/packages/editor-ui/src/plugins/codemirror/completions/datatype.completions.ts b/packages/editor-ui/src/plugins/codemirror/completions/datatype.completions.ts index b2ad69094a..1e7b12914f 100644 --- a/packages/editor-ui/src/plugins/codemirror/completions/datatype.completions.ts +++ b/packages/editor-ui/src/plugins/codemirror/completions/datatype.completions.ts @@ -440,11 +440,12 @@ export const objectGlobalOptions = () => { }; const regexes = { - generalRef: /\$[^$]+\.([^{\s])*/, // $input. or $json. or similar ones + generalRef: /\$[^$'"]+\.([^{\s])*/, // $input. or $json. or similar ones selectorRef: /\$\(['"][\S\s]+['"]\)\.([^{\s])*/, // $('nodeName'). numberLiteral: /\((\d+)\.?(\d*)\)\.([^{\s])*/, // (123). or (123.4). - stringLiteral: /(".+"|('.+'))\.([^{\s])*/, // 'abc'. or "abc". + singleQuoteStringLiteral: /('.+')\.([^'{\s])*/, // 'abc'. + doubleQuoteStringLiteral: /(".+")\.([^"{\s])*/, // "abc". dateLiteral: /\(?new Date\(\(?.*?\)\)?\.([^{\s])*/, // new Date(). or (new Date()). arrayLiteral: /(\[.+\])\.([^{\s])*/, // [1, 2, 3]. objectLiteral: /\(\{.*\}\)\.([^{\s])*/, // ({}).