From ebc87100332744bab5891fb83624380bf1d051c3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=B1=B1=E5=90=B9=E8=89=B2=E5=BE=A1=E5=AE=88?= <85992002+KazariEX@users.noreply.github.com> Date: Mon, 26 Aug 2024 07:19:45 +0800 Subject: [PATCH] fix(language-core): generate `ref` as identifier instead of interpolation (#4688) --- .../lib/codegen/template/element.ts | 40 ++++++++++++------- 1 file changed, 25 insertions(+), 15 deletions(-) diff --git a/packages/language-core/lib/codegen/template/element.ts b/packages/language-core/lib/codegen/template/element.ts index f0c98d6e7a..f9ce74932e 100644 --- a/packages/language-core/lib/codegen/template/element.ts +++ b/packages/language-core/lib/codegen/template/element.ts @@ -583,19 +583,24 @@ function* generateReferencesForElements( && prop.name === 'ref' && prop.value ) { + const [content, startOffset] = normalizeAttributeValue(prop.value); + yield `// @ts-ignore${newLine}`; - yield* generateInterpolation( + yield `__VLS_ctx`; + yield* generatePropertyAccess( options, ctx, - prop.value.content, - prop.value.loc, - prop.value.loc.start.offset + 1, + content, + startOffset, ctx.codeFeatures.navigation, - '(', - ')' + prop.value.loc ); yield endOfLine; + if (variableNameRegex.test(content)) { + ctx.accessExternalVariable(content, startOffset); + } + const refName = CompilerDOM.toValidAssetId(prop.value.content, '_VLS_refs' as any); options.templateRefNames.set(prop.value.content, refName); return refName; @@ -631,16 +636,8 @@ function* generateReferencesForScopedCssClasses( } } else { - let startOffset = prop.value.loc.start.offset; - let content = prop.value.loc.source; let isWrapped = false; - if ( - (content.startsWith(`'`) && content.endsWith(`'`)) - || (content.startsWith(`"`) && content.endsWith(`"`)) - ) { - content = content.slice(1, -1); - isWrapped = true; - } + const [content, startOffset] = normalizeAttributeValue(prop.value); if (content) { const classes = collectClasses(content, startOffset + (isWrapped ? 1 : 0)); ctx.scopedClasses.push(...classes); @@ -746,6 +743,19 @@ function getTagRenameApply(oldName: string) { return oldName === hyphenateTag(oldName) ? hyphenateTag : undefined; } +function normalizeAttributeValue(node: CompilerDOM.TextNode): [string, number] { + let offset = node.loc.start.offset; + let content = node.loc.source; + if ( + (content.startsWith(`'`) && content.endsWith(`'`)) + || (content.startsWith(`"`) && content.endsWith(`"`)) + ) { + offset++; + content = content.slice(1, -1); + } + return [content, offset]; +} + function collectClasses(content: string, startOffset = 0) { const classes: { source: string;