@angular/language-service
Version:
Angular - language services
125 lines • 16.5 kB
JavaScript
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
(function (factory) {
if (typeof module === "object" && typeof module.exports === "object") {
var v = factory(require, exports);
if (v !== undefined) module.exports = v;
}
else if (typeof define === "function" && define.amd) {
define("@angular/language-service/src/hover", ["require", "exports", "tslib", "typescript", "@angular/language-service/src/locate_symbol", "@angular/language-service/src/utils"], factory);
}
})(function (require, exports) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.getTsHover = exports.getTemplateHover = void 0;
var tslib_1 = require("tslib");
var ts = require("typescript");
var locate_symbol_1 = require("@angular/language-service/src/locate_symbol");
var utils_1 = require("@angular/language-service/src/utils");
// Reverse mappings of enum would generate strings
var SYMBOL_SPACE = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.space];
var SYMBOL_PUNC = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.punctuation];
var SYMBOL_TEXT = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.text];
var SYMBOL_INTERFACE = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.interfaceName];
/**
* Traverse the template AST and look for the symbol located at `position`, then
* return the corresponding quick info.
* @param info template AST
* @param position location of the symbol
* @param analyzedModules all NgModules in the program.
*/
function getTemplateHover(info, position, analyzedModules) {
var _a, _b;
var symbolInfo = locate_symbol_1.locateSymbols(info, position)[0];
if (!symbolInfo) {
return;
}
var symbol = symbolInfo.symbol, span = symbolInfo.span, staticSymbol = symbolInfo.staticSymbol;
// The container is either the symbol's container (for example, 'AppComponent'
// is the container of the symbol 'title' in its template) or the NgModule
// that the directive belongs to (the container of AppComponent is AppModule).
var containerName = (_a = symbol.container) === null || _a === void 0 ? void 0 : _a.name;
if (!containerName && staticSymbol) {
// If there is a static symbol then the target is a directive.
var ngModule = analyzedModules.ngModuleByPipeOrDirective.get(staticSymbol);
containerName = ngModule === null || ngModule === void 0 ? void 0 : ngModule.type.reference.name;
}
return createQuickInfo(symbol.name, symbol.kind, span, containerName, (_b = symbol.type) === null || _b === void 0 ? void 0 : _b.name, symbol.documentation);
}
exports.getTemplateHover = getTemplateHover;
/**
* Get quick info for Angular semantic entities in TypeScript files, like Directives.
* @param position location of the symbol in the source file
* @param declarations All Directive-like declarations in the source file.
* @param analyzedModules all NgModules in the program.
*/
function getTsHover(position, declarations, analyzedModules) {
var e_1, _a;
try {
for (var declarations_1 = tslib_1.__values(declarations), declarations_1_1 = declarations_1.next(); !declarations_1_1.done; declarations_1_1 = declarations_1.next()) {
var _b = declarations_1_1.value, declarationSpan = _b.declarationSpan, metadata = _b.metadata;
if (utils_1.inSpan(position, declarationSpan)) {
var staticSymbol = metadata.type.reference;
var directiveName = staticSymbol.name;
var kind = metadata.isComponent ? 'component' : 'directive';
var textSpan = ts.createTextSpanFromBounds(declarationSpan.start, declarationSpan.end);
var ngModule = analyzedModules.ngModuleByPipeOrDirective.get(staticSymbol);
var moduleName = ngModule === null || ngModule === void 0 ? void 0 : ngModule.type.reference.name;
return createQuickInfo(directiveName, kind, textSpan, moduleName, ts.ScriptElementKind.classElement);
}
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (declarations_1_1 && !declarations_1_1.done && (_a = declarations_1.return)) _a.call(declarations_1);
}
finally { if (e_1) throw e_1.error; }
}
}
exports.getTsHover = getTsHover;
/**
* Construct a QuickInfo object taking into account its container and type.
* @param name Name of the QuickInfo target
* @param kind component, directive, pipe, etc.
* @param textSpan span of the target
* @param containerName either the Symbol's container or the NgModule that contains the directive
* @param type user-friendly name of the type
* @param documentation docstring or comment
*/
function createQuickInfo(name, kind, textSpan, containerName, type, documentation) {
var containerDisplayParts = containerName ?
[
{ text: containerName, kind: SYMBOL_INTERFACE },
{ text: '.', kind: SYMBOL_PUNC },
] :
[];
var typeDisplayParts = type ?
[
{ text: ':', kind: SYMBOL_PUNC },
{ text: ' ', kind: SYMBOL_SPACE },
{ text: type, kind: SYMBOL_INTERFACE },
] :
[];
return {
kind: kind,
kindModifiers: ts.ScriptElementKindModifier.none,
textSpan: textSpan,
displayParts: tslib_1.__spread([
{ text: '(', kind: SYMBOL_PUNC },
{ text: kind, kind: SYMBOL_TEXT },
{ text: ')', kind: SYMBOL_PUNC },
{ text: ' ', kind: SYMBOL_SPACE }
], containerDisplayParts, [
{ text: name, kind: SYMBOL_INTERFACE }
], typeDisplayParts),
documentation: documentation,
};
}
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hover.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/hover.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {NgAnalyzedModules} from '@angular/compiler';\nimport * as ts from 'typescript';\nimport {locateSymbols} from './locate_symbol';\nimport * as ng from './types';\nimport {inSpan} from './utils';\n\n// Reverse mappings of enum would generate strings\nconst SYMBOL_SPACE = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.space];\nconst SYMBOL_PUNC = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.punctuation];\nconst SYMBOL_TEXT = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.text];\nconst SYMBOL_INTERFACE = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.interfaceName];\n\n/**\n * Traverse the template AST and look for the symbol located at `position`, then\n * return the corresponding quick info.\n * @param info template AST\n * @param position location of the symbol\n * @param analyzedModules all NgModules in the program.\n */\nexport function getTemplateHover(\n    info: ng.AstResult, position: number, analyzedModules: NgAnalyzedModules): ts.QuickInfo|\n    undefined {\n  const symbolInfo = locateSymbols(info, position)[0];\n  if (!symbolInfo) {\n    return;\n  }\n  const {symbol, span, staticSymbol} = symbolInfo;\n\n  // The container is either the symbol's container (for example, 'AppComponent'\n  // is the container of the symbol 'title' in its template) or the NgModule\n  // that the directive belongs to (the container of AppComponent is AppModule).\n  let containerName: string|undefined = symbol.container?.name;\n  if (!containerName && staticSymbol) {\n    // If there is a static symbol then the target is a directive.\n    const ngModule = analyzedModules.ngModuleByPipeOrDirective.get(staticSymbol);\n    containerName = ngModule?.type.reference.name;\n  }\n\n  return createQuickInfo(\n      symbol.name, symbol.kind, span, containerName, symbol.type?.name, symbol.documentation);\n}\n\n/**\n * Get quick info for Angular semantic entities in TypeScript files, like Directives.\n * @param position location of the symbol in the source file\n * @param declarations All Directive-like declarations in the source file.\n * @param analyzedModules all NgModules in the program.\n */\nexport function getTsHover(\n    position: number, declarations: ng.Declaration[],\n    analyzedModules: NgAnalyzedModules): ts.QuickInfo|undefined {\n  for (const {declarationSpan, metadata} of declarations) {\n    if (inSpan(position, declarationSpan)) {\n      const staticSymbol: ng.StaticSymbol = metadata.type.reference;\n      const directiveName = staticSymbol.name;\n      const kind = metadata.isComponent ? 'component' : 'directive';\n      const textSpan = ts.createTextSpanFromBounds(declarationSpan.start, declarationSpan.end);\n      const ngModule = analyzedModules.ngModuleByPipeOrDirective.get(staticSymbol);\n      const moduleName = ngModule?.type.reference.name;\n      return createQuickInfo(\n          directiveName, kind, textSpan, moduleName, ts.ScriptElementKind.classElement);\n    }\n  }\n}\n\n/**\n * Construct a QuickInfo object taking into account its container and type.\n * @param name Name of the QuickInfo target\n * @param kind component, directive, pipe, etc.\n * @param textSpan span of the target\n * @param containerName either the Symbol's container or the NgModule that contains the directive\n * @param type user-friendly name of the type\n * @param documentation docstring or comment\n */\nfunction createQuickInfo(\n    name: string, kind: string, textSpan: ts.TextSpan, containerName?: string, type?: string,\n    documentation?: ts.SymbolDisplayPart[]): ts.QuickInfo {\n  const containerDisplayParts = containerName ?\n      [\n        {text: containerName, kind: SYMBOL_INTERFACE},\n        {text: '.', kind: SYMBOL_PUNC},\n      ] :\n      [];\n\n  const typeDisplayParts = type ?\n      [\n        {text: ':', kind: SYMBOL_PUNC},\n        {text: ' ', kind: SYMBOL_SPACE},\n        {text: type, kind: SYMBOL_INTERFACE},\n      ] :\n      [];\n\n  return {\n    kind: kind as ts.ScriptElementKind,\n    kindModifiers: ts.ScriptElementKindModifier.none,\n    textSpan: textSpan,\n    displayParts: [\n      {text: '(', kind: SYMBOL_PUNC},\n      {text: kind, kind: SYMBOL_TEXT},\n      {text: ')', kind: SYMBOL_PUNC},\n      {text: ' ', kind: SYMBOL_SPACE},\n      ...containerDisplayParts,\n      {text: name, kind: SYMBOL_INTERFACE},\n      ...typeDisplayParts,\n    ],\n    documentation,\n  };\n}\n"]}