From d1690ad706df71ca35b9212424bc112b4ba400f6 Mon Sep 17 00:00:00 2001 From: Pine Wu Date: Tue, 22 Jan 2019 11:25:41 -0800 Subject: [PATCH] Improve granularity --- .../server/src/modes/htmlMode.ts | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/extensions/html-language-features/server/src/modes/htmlMode.ts b/extensions/html-language-features/server/src/modes/htmlMode.ts index e5b582663fb2b..00dc9313a37aa 100644 --- a/extensions/html-language-features/server/src/modes/htmlMode.ts +++ b/extensions/html-language-features/server/src/modes/htmlMode.ts @@ -18,14 +18,21 @@ export function getHTMLMode(htmlLanguageService: HTMLLanguageService, workspace: doSelection(document: TextDocument, position: Position): Range[] { const htmlDocument = htmlDocuments.get(document); let currNode = htmlDocument.findNodeAt(document.offsetAt(position)); - let getNodeRange = (n: Node) => { - return Range.create(document.positionAt(n.start), document.positionAt(n.end)); + let getNodeRanges = (n: Node) => { + if (n.startTagEnd && n.endTagStart && n.startTagEnd < n.endTagStart) { + return [ + Range.create(document.positionAt(n.startTagEnd), document.positionAt(n.endTagStart)), + Range.create(document.positionAt(n.start), document.positionAt(n.end)), + ]; + } + + return [Range.create(document.positionAt(n.start), document.positionAt(n.end))]; }; - const result = [getNodeRange(currNode)]; + const result = [...getNodeRanges(currNode)]; while (currNode.parent) { currNode = currNode.parent; - result.push(getNodeRange(currNode)); + getNodeRanges(currNode).forEach(r => result.push(r)); } return result;