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>

41 lines (34 loc) 1.54 kB
import { LiquidHtmlNode, SourceCodeType } from '@shopify/theme-check-common'; import { LinkedEditingRangeParams, LinkedEditingRanges } from 'vscode-languageserver'; import { DocumentManager } from '../documents'; import { findCurrentNode } from '../visitor'; import { BaseLinkedEditingRangesProvider } from './BaseLinkedEditingRangesProvider'; import { EmptyHtmlTagLinkedRangesProvider, HtmlTagNameLinkedRangesProvider } from './providers'; export class LinkedEditingRangesProvider { private providers: BaseLinkedEditingRangesProvider[]; constructor(public documentManager: DocumentManager) { this.providers = [ new HtmlTagNameLinkedRangesProvider(documentManager), new EmptyHtmlTagLinkedRangesProvider(documentManager), ]; } async linkedEditingRanges(params: LinkedEditingRangeParams): Promise<LinkedEditingRanges | null> { const document = this.documentManager.get(params.textDocument.uri); if (!document || document.type !== SourceCodeType.LiquidHtml) { return null; } let currentNode: LiquidHtmlNode | null = null; let ancestors: LiquidHtmlNode[] | null = null; if (!(document.ast instanceof Error)) { [currentNode, ancestors] = 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 results.find(Boolean) ?? null; } }