@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>
51 lines (45 loc) • 1.62 kB
text/typescript
import { NodeTypes } from '@shopify/liquid-html-parser';
import { LiquidHtmlNode } from '@shopify/theme-check-common';
import { Hover, HoverParams } from 'vscode-languageserver';
import { DocumentManager } from '../../documents';
import { GetTranslationsForURI, renderTranslation, translationValue } from '../../translations';
import { BaseHoverProvider } from '../BaseHoverProvider';
export class TranslationHoverProvider implements BaseHoverProvider {
constructor(
public getTranslationsForUri: GetTranslationsForURI,
public documentManager: DocumentManager,
) {}
async hover(
currentNode: LiquidHtmlNode,
ancestors: LiquidHtmlNode[],
params: HoverParams,
): Promise<Hover | null> {
const parentNode = ancestors.at(-1);
if (
currentNode.type !== NodeTypes.String ||
!parentNode ||
parentNode.type !== NodeTypes.LiquidVariable
) {
return null;
}
if (!parentNode.filters[0] || !['t', 'translate'].includes(parentNode.filters[0].name)) {
return null;
}
const translations = await this.getTranslationsForUri(params.textDocument.uri);
const translation = translationValue(currentNode.value, translations);
const document = this.documentManager.get(params.textDocument.uri)?.textDocument;
if (!translation || !document) {
return null;
}
return {
contents: {
kind: 'markdown',
value: renderTranslation(translation),
},
range: {
start: document.positionAt(currentNode.position.start),
end: document.positionAt(currentNode.position.end),
},
};
}
}