UNPKG

@shopify/theme-language-server-common

Version:

<h1 align="center" style="position: relative;" > <br> <img src="https://github.com/Shopify/theme-check-vscode/blob/main/images/shopify_glyph.png?raw=true" alt="logo" width="141" height="160"> <br> Theme Language Server </h1>

32 lines 1.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.LinkedEditingRangesProvider = void 0; const theme_check_common_1 = require("@shopify/theme-check-common"); const visitor_1 = require("../visitor"); const providers_1 = require("./providers"); class LinkedEditingRangesProvider { constructor(documentManager) { this.documentManager = documentManager; this.providers = [ new providers_1.HtmlTagNameLinkedRangesProvider(documentManager), new providers_1.EmptyHtmlTagLinkedRangesProvider(documentManager), ]; } async linkedEditingRanges(params) { var _a; const document = this.documentManager.get(params.textDocument.uri); if (!document || document.type !== theme_check_common_1.SourceCodeType.LiquidHtml) { return null; } let currentNode = null; let ancestors = null; if (!(document.ast instanceof Error)) { [currentNode, ancestors] = (0, visitor_1.findCurrentNode)(document.ast, document.textDocument.offsetAt(params.position)); } const promises = this.providers.map((p) => p.linkedEditingRanges(currentNode, ancestors, params).catch(() => null)); const results = await Promise.all(promises); return (_a = results.find(Boolean)) !== null && _a !== void 0 ? _a : null; } } exports.LinkedEditingRangesProvider = LinkedEditingRangesProvider; //# sourceMappingURL=LinkedEditingRangesProvider.js.map