UNPKG

16.8 kBJavaScriptView Raw
1/**
2 * @license
3 * Copyright Google LLC All Rights Reserved.
4 *
5 * Use of this source code is governed by an MIT-style license that can be
6 * found in the LICENSE file at https://angular.io/license
7 */
8(function (factory) {
9 if (typeof module === "object" && typeof module.exports === "object") {
10 var v = factory(require, exports);
11 if (v !== undefined) module.exports = v;
12 }
13 else if (typeof define === "function" && define.amd) {
14 define("@angular/language-service/src/hover", ["require", "exports", "tslib", "typescript", "@angular/language-service/src/locate_symbol", "@angular/language-service/src/utils"], factory);
15 }
16})(function (require, exports) {
17 "use strict";
18 Object.defineProperty(exports, "__esModule", { value: true });
19 exports.getTsHover = exports.getTemplateHover = void 0;
20 var tslib_1 = require("tslib");
21 var ts = require("typescript");
22 var locate_symbol_1 = require("@angular/language-service/src/locate_symbol");
23 var utils_1 = require("@angular/language-service/src/utils");
24 /**
25 * Traverse the template AST and look for the symbol located at `position`, then
26 * return the corresponding quick info.
27 * @param info template AST
28 * @param position location of the symbol
29 * @param analyzedModules all NgModules in the program.
30 */
31 function getTemplateHover(info, position, analyzedModules) {
32 var _a, _b;
33 var symbolInfo = locate_symbol_1.locateSymbols(info, position)[0];
34 if (!symbolInfo) {
35 return;
36 }
37 var symbol = symbolInfo.symbol, span = symbolInfo.span, staticSymbol = symbolInfo.staticSymbol;
38 // The container is either the symbol's container (for example, 'AppComponent'
39 // is the container of the symbol 'title' in its template) or the NgModule
40 // that the directive belongs to (the container of AppComponent is AppModule).
41 var containerName = (_a = symbol.container) === null || _a === void 0 ? void 0 : _a.name;
42 if (!containerName && staticSymbol) {
43 // If there is a static symbol then the target is a directive.
44 var ngModule = analyzedModules.ngModuleByPipeOrDirective.get(staticSymbol);
45 containerName = ngModule === null || ngModule === void 0 ? void 0 : ngModule.type.reference.name;
46 }
47 return createQuickInfo(symbol.name, symbol.kind, span, containerName, (_b = symbol.type) === null || _b === void 0 ? void 0 : _b.name, symbol.documentation);
48 }
49 exports.getTemplateHover = getTemplateHover;
50 /**
51 * Get quick info for Angular semantic entities in TypeScript files, like Directives.
52 * @param position location of the symbol in the source file
53 * @param declarations All Directive-like declarations in the source file.
54 * @param analyzedModules all NgModules in the program.
55 */
56 function getTsHover(position, declarations, analyzedModules) {
57 var e_1, _a;
58 try {
59 for (var declarations_1 = tslib_1.__values(declarations), declarations_1_1 = declarations_1.next(); !declarations_1_1.done; declarations_1_1 = declarations_1.next()) {
60 var _b = declarations_1_1.value, declarationSpan = _b.declarationSpan, metadata = _b.metadata;
61 if (utils_1.inSpan(position, declarationSpan)) {
62 var staticSymbol = metadata.type.reference;
63 var directiveName = staticSymbol.name;
64 var kind = metadata.isComponent ? 'component' : 'directive';
65 var textSpan = ts.createTextSpanFromBounds(declarationSpan.start, declarationSpan.end);
66 var ngModule = analyzedModules.ngModuleByPipeOrDirective.get(staticSymbol);
67 var moduleName = ngModule === null || ngModule === void 0 ? void 0 : ngModule.type.reference.name;
68 return createQuickInfo(directiveName, kind, textSpan, moduleName, ts.ScriptElementKind.classElement);
69 }
70 }
71 }
72 catch (e_1_1) { e_1 = { error: e_1_1 }; }
73 finally {
74 try {
75 if (declarations_1_1 && !declarations_1_1.done && (_a = declarations_1.return)) _a.call(declarations_1);
76 }
77 finally { if (e_1) throw e_1.error; }
78 }
79 }
80 exports.getTsHover = getTsHover;
81 // Reverse mappings of enum would generate strings
82 var ALIAS_NAME = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.aliasName];
83 var SYMBOL_INTERFACE = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.interfaceName];
84 var SYMBOL_PUNC = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.punctuation];
85 var SYMBOL_SPACE = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.space];
86 var SYMBOL_TEXT = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.text];
87 /**
88 * Construct a QuickInfo object taking into account its container and type.
89 * @param name Name of the QuickInfo target
90 * @param kind component, directive, pipe, etc.
91 * @param textSpan span of the target
92 * @param containerName either the Symbol's container or the NgModule that contains the directive
93 * @param type user-friendly name of the type
94 * @param documentation docstring or comment
95 */
96 function createQuickInfo(name, kind, textSpan, containerName, type, documentation) {
97 var containerDisplayParts = containerName ?
98 [
99 { text: containerName, kind: SYMBOL_INTERFACE },
100 { text: '.', kind: SYMBOL_PUNC },
101 ] :
102 [];
103 var typeDisplayParts = type ?
104 [
105 { text: ':', kind: SYMBOL_PUNC },
106 { text: ' ', kind: SYMBOL_SPACE },
107 { text: type, kind: SYMBOL_INTERFACE },
108 ] :
109 [];
110 return {
111 kind: kind,
112 kindModifiers: ts.ScriptElementKindModifier.none,
113 textSpan: textSpan,
114 displayParts: tslib_1.__spread([
115 { text: '(', kind: SYMBOL_PUNC },
116 { text: kind, kind: SYMBOL_TEXT },
117 { text: ')', kind: SYMBOL_PUNC },
118 { text: ' ', kind: SYMBOL_SPACE }
119 ], containerDisplayParts, [
120 { text: name, kind: SYMBOL_INTERFACE }
121 ], typeDisplayParts),
122 documentation: documentation,
123 };
124 }
125});
126//# 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';\n\nimport {locateSymbols} from './locate_symbol';\nimport * as ng from './types';\nimport {inSpan} from './utils';\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\n// Reverse mappings of enum would generate strings\nconst ALIAS_NAME = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.aliasName];\nconst SYMBOL_INTERFACE = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.interfaceName];\nconst SYMBOL_PUNC = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.punctuation];\nconst SYMBOL_SPACE = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.space];\nconst SYMBOL_TEXT = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.text];\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"]}
\No newline at end of file