From cbbeb5041db3f764939f32f989664942f9e9ef52 Mon Sep 17 00:00:00 2001 From: JG Date: Sun, 31 Dec 2023 17:39:47 +0000 Subject: [PATCH] fix: VsCode error textDocument/codeAction failed --- .../src/language-server/zmodel-code-action.ts | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/packages/schema/src/language-server/zmodel-code-action.ts b/packages/schema/src/language-server/zmodel-code-action.ts index e9e7862ec..aace4d0fe 100644 --- a/packages/schema/src/language-server/zmodel-code-action.ts +++ b/packages/schema/src/language-server/zmodel-code-action.ts @@ -75,8 +75,6 @@ export class ZModelCodeActionProvider implements CodeActionProvider { // eslint-disable-next-line @typescript-eslint/no-non-null-assertion const oppositeModel = fieldAstNode.type.reference!.ref! as DataModel; - const lastField = oppositeModel.fields[oppositeModel.fields.length - 1]; - const currentModel = document.parseResult.value as Model; const container = currentModel.declarations.find( @@ -121,17 +119,22 @@ export class ZModelCodeActionProvider implements CodeActionProvider { '\n' + indent + `${fieldName} ${typeName} @relation(fields: [${referenceIdFieldName}], references: [${idFieldName}])` + - referenceField; + referenceField + + '\n'; } else { // user User @relation(fields: [userAbc], references: [id]) const typeName = container.name; const fieldName = this.lowerCaseFirstLetter(typeName); - newText = '\n' + indent + `${fieldName} ${typeName}[]`; + newText = '\n' + indent + `${fieldName} ${typeName}[]` + '\n'; } // the opposite model might be in the imported file const targetDocument = getDocument(oppositeModel); + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion + const endOffset = oppositeModel.$cstNode!.end - 1; + const position = document.textDocument.positionAt(endOffset); + return { title: `Add opposite relation fields on ${oppositeModel.name}`, kind: CodeActionKind.QuickFix, @@ -142,10 +145,8 @@ export class ZModelCodeActionProvider implements CodeActionProvider { [targetDocument.textDocument.uri]: [ { range: { - // eslint-disable-next-line @typescript-eslint/no-non-null-assertion - start: lastField.$cstNode!.range.end, - // eslint-disable-next-line @typescript-eslint/no-non-null-assertion - end: lastField.$cstNode!.range.end, + start: position, + end: position, }, newText, },