(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/compiler/src/render3/partial/component", ["require", "exports", "tslib", "@angular/compiler/src/core", "@angular/compiler/src/ml_parser/interpolation_config", "@angular/compiler/src/output/output_ast", "@angular/compiler/src/parse_util", "@angular/compiler/src/render3/r3_identifiers", "@angular/compiler/src/render3/view/compiler", "@angular/compiler/src/render3/view/util", "@angular/compiler/src/render3/partial/directive", "@angular/compiler/src/render3/partial/util"], factory); } })(function (require, exports) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.createComponentDefinitionMap = exports.compileDeclareComponentFromMetadata = void 0; var tslib_1 = require("tslib"); /** * @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 */ var core = require("@angular/compiler/src/core"); var interpolation_config_1 = require("@angular/compiler/src/ml_parser/interpolation_config"); var o = require("@angular/compiler/src/output/output_ast"); var parse_util_1 = require("@angular/compiler/src/parse_util"); var r3_identifiers_1 = require("@angular/compiler/src/render3/r3_identifiers"); var compiler_1 = require("@angular/compiler/src/render3/view/compiler"); var util_1 = require("@angular/compiler/src/render3/view/util"); var directive_1 = require("@angular/compiler/src/render3/partial/directive"); var util_2 = require("@angular/compiler/src/render3/partial/util"); /** * Compile a component declaration defined by the `R3ComponentMetadata`. */ function compileDeclareComponentFromMetadata(meta, template, additionalTemplateInfo) { var definitionMap = createComponentDefinitionMap(meta, template, additionalTemplateInfo); var expression = o.importExpr(r3_identifiers_1.Identifiers.declareComponent).callFn([definitionMap.toLiteralMap()]); var type = compiler_1.createComponentType(meta); return { expression: expression, type: type, statements: [] }; } exports.compileDeclareComponentFromMetadata = compileDeclareComponentFromMetadata; /** * Gathers the declaration fields for a component into a `DefinitionMap`. */ function createComponentDefinitionMap(meta, template, templateInfo) { var definitionMap = directive_1.createDirectiveDefinitionMap(meta); definitionMap.set('template', getTemplateExpression(template, templateInfo)); if (templateInfo.isInline) { definitionMap.set('isInline', o.literal(true)); } definitionMap.set('styles', util_2.toOptionalLiteralArray(meta.styles, o.literal)); definitionMap.set('components', compileUsedDirectiveMetadata(meta, function (directive) { return directive.isComponent === true; })); definitionMap.set('directives', compileUsedDirectiveMetadata(meta, function (directive) { return directive.isComponent !== true; })); definitionMap.set('pipes', compileUsedPipeMetadata(meta)); definitionMap.set('viewProviders', meta.viewProviders); definitionMap.set('animations', meta.animations); if (meta.changeDetection !== undefined) { definitionMap.set('changeDetection', o.importExpr(r3_identifiers_1.Identifiers.ChangeDetectionStrategy) .prop(core.ChangeDetectionStrategy[meta.changeDetection])); } if (meta.encapsulation !== core.ViewEncapsulation.Emulated) { definitionMap.set('encapsulation', o.importExpr(r3_identifiers_1.Identifiers.ViewEncapsulation).prop(core.ViewEncapsulation[meta.encapsulation])); } if (meta.interpolation !== interpolation_config_1.DEFAULT_INTERPOLATION_CONFIG) { definitionMap.set('interpolation', o.literalArr([o.literal(meta.interpolation.start), o.literal(meta.interpolation.end)])); } if (template.preserveWhitespaces === true) { definitionMap.set('preserveWhitespaces', o.literal(true)); } return definitionMap; } exports.createComponentDefinitionMap = createComponentDefinitionMap; function getTemplateExpression(template, templateInfo) { // If the template has been defined using a direct literal, we use that expression directly // without any modifications. This is ensures proper source mapping from the partially // compiled code to the source file declaring the template. Note that this does not capture // template literals referenced indirectly through an identifier. if (templateInfo.inlineTemplateLiteralExpression !== null) { return templateInfo.inlineTemplateLiteralExpression; } // If the template is defined inline but not through a literal, the template has been resolved // through static interpretation. We create a literal but cannot provide any source span. Note // that we cannot use the expression defining the template because the linker expects the template // to be defined as a literal in the declaration. if (templateInfo.isInline) { return o.literal(templateInfo.content, null, null); } // The template is external so we must synthesize an expression node with // the appropriate source-span. var contents = templateInfo.content; var file = new parse_util_1.ParseSourceFile(contents, templateInfo.sourceUrl); var start = new parse_util_1.ParseLocation(file, 0, 0, 0); var end = computeEndLocation(file, contents); var span = new parse_util_1.ParseSourceSpan(start, end); return o.literal(contents, null, span); } function computeEndLocation(file, contents) { var length = contents.length; var lineStart = 0; var lastLineStart = 0; var line = 0; do { lineStart = contents.indexOf('\n', lastLineStart); if (lineStart !== -1) { lastLineStart = lineStart + 1; line++; } } while (lineStart !== -1); return new parse_util_1.ParseLocation(file, length, line, length - lastLineStart); } /** * Compiles the directives as registered in the component metadata into an array literal of the * individual directives. If the component does not use any directives, then null is returned. */ function compileUsedDirectiveMetadata(meta, predicate) { var wrapType = meta.declarationListEmitMode !== 0 /* Direct */ ? util_2.generateForwardRef : function (expr) { return expr; }; var directives = meta.directives.filter(predicate); return util_2.toOptionalLiteralArray(directives, function (directive) { var dirMeta = new util_1.DefinitionMap(); dirMeta.set('type', wrapType(directive.type)); dirMeta.set('selector', o.literal(directive.selector)); dirMeta.set('inputs', util_2.toOptionalLiteralArray(directive.inputs, o.literal)); dirMeta.set('outputs', util_2.toOptionalLiteralArray(directive.outputs, o.literal)); dirMeta.set('exportAs', util_2.toOptionalLiteralArray(directive.exportAs, o.literal)); return dirMeta.toLiteralMap(); }); } /** * Compiles the pipes as registered in the component metadata into an object literal, where the * pipe's name is used as key and a reference to its type as value. If the component does not use * any pipes, then null is returned. */ function compileUsedPipeMetadata(meta) { var e_1, _a; if (meta.pipes.size === 0) { return null; } var wrapType = meta.declarationListEmitMode !== 0 /* Direct */ ? util_2.generateForwardRef : function (expr) { return expr; }; var entries = []; try { for (var _b = tslib_1.__values(meta.pipes), _c = _b.next(); !_c.done; _c = _b.next()) { var _d = tslib_1.__read(_c.value, 2), name_1 = _d[0], pipe = _d[1]; entries.push({ key: name_1, value: wrapType(pipe), quoted: true }); } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_1) throw e_1.error; } } return o.literalMap(entries); } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler/src/render3/partial/component.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 */\nimport * as core from '../../core';\nimport {DEFAULT_INTERPOLATION_CONFIG} from '../../ml_parser/interpolation_config';\nimport * as o from '../../output/output_ast';\nimport {ParseLocation, ParseSourceFile, ParseSourceSpan} from '../../parse_util';\nimport {Identifiers as R3} from '../r3_identifiers';\nimport {R3CompiledExpression} from '../util';\nimport {DeclarationListEmitMode, R3ComponentMetadata, R3UsedDirectiveMetadata} from '../view/api';\nimport {createComponentType} from '../view/compiler';\nimport {ParsedTemplate} from '../view/template';\nimport {DefinitionMap} from '../view/util';\n\nimport {R3DeclareComponentMetadata, R3DeclareUsedDirectiveMetadata} from './api';\nimport {createDirectiveDefinitionMap} from './directive';\nimport {generateForwardRef, toOptionalLiteralArray} from './util';\n\nexport interface DeclareComponentTemplateInfo {\n  /**\n   * The string contents of the template.\n   *\n   * This is the \"logical\" template string, after expansion of any escaped characters (for inline\n   * templates). This may differ from the actual template bytes as they appear in the .ts file.\n   */\n  content: string;\n\n  /**\n   * A full path to the file which contains the template.\n   *\n   * This can be either the original .ts file if the template is inline, or the .html file if an\n   * external file was used.\n   */\n  sourceUrl: string;\n\n  /**\n   * Whether the template was inline (using `template`) or external (using `templateUrl`).\n   */\n  isInline: boolean;\n\n  /**\n   * If the template was defined inline by a direct string literal, then this is that literal\n   * expression. Otherwise `null`, if the template was not defined inline or was not a literal.\n   */\n  inlineTemplateLiteralExpression: o.Expression|null;\n}\n\n/**\n * Compile a component declaration defined by the `R3ComponentMetadata`.\n */\nexport function compileDeclareComponentFromMetadata(\n    meta: R3ComponentMetadata, template: ParsedTemplate,\n    additionalTemplateInfo: DeclareComponentTemplateInfo): R3CompiledExpression {\n  const definitionMap = createComponentDefinitionMap(meta, template, additionalTemplateInfo);\n\n  const expression = o.importExpr(R3.declareComponent).callFn([definitionMap.toLiteralMap()]);\n  const type = createComponentType(meta);\n\n  return {expression, type, statements: []};\n}\n\n/**\n * Gathers the declaration fields for a component into a `DefinitionMap`.\n */\nexport function createComponentDefinitionMap(\n    meta: R3ComponentMetadata, template: ParsedTemplate,\n    templateInfo: DeclareComponentTemplateInfo): DefinitionMap<R3DeclareComponentMetadata> {\n  const definitionMap: DefinitionMap<R3DeclareComponentMetadata> =\n      createDirectiveDefinitionMap(meta);\n\n  definitionMap.set('template', getTemplateExpression(template, templateInfo));\n  if (templateInfo.isInline) {\n    definitionMap.set('isInline', o.literal(true));\n  }\n\n  definitionMap.set('styles', toOptionalLiteralArray(meta.styles, o.literal));\n  definitionMap.set(\n      'components',\n      compileUsedDirectiveMetadata(meta, directive => directive.isComponent === true));\n  definitionMap.set(\n      'directives',\n      compileUsedDirectiveMetadata(meta, directive => directive.isComponent !== true));\n  definitionMap.set('pipes', compileUsedPipeMetadata(meta));\n  definitionMap.set('viewProviders', meta.viewProviders);\n  definitionMap.set('animations', meta.animations);\n\n  if (meta.changeDetection !== undefined) {\n    definitionMap.set(\n        'changeDetection',\n        o.importExpr(R3.ChangeDetectionStrategy)\n            .prop(core.ChangeDetectionStrategy[meta.changeDetection]));\n  }\n  if (meta.encapsulation !== core.ViewEncapsulation.Emulated) {\n    definitionMap.set(\n        'encapsulation',\n        o.importExpr(R3.ViewEncapsulation).prop(core.ViewEncapsulation[meta.encapsulation]));\n  }\n  if (meta.interpolation !== DEFAULT_INTERPOLATION_CONFIG) {\n    definitionMap.set(\n        'interpolation',\n        o.literalArr([o.literal(meta.interpolation.start), o.literal(meta.interpolation.end)]));\n  }\n\n  if (template.preserveWhitespaces === true) {\n    definitionMap.set('preserveWhitespaces', o.literal(true));\n  }\n\n  return definitionMap;\n}\n\nfunction getTemplateExpression(\n    template: ParsedTemplate, templateInfo: DeclareComponentTemplateInfo): o.Expression {\n  // If the template has been defined using a direct literal, we use that expression directly\n  // without any modifications. This is ensures proper source mapping from the partially\n  // compiled code to the source file declaring the template. Note that this does not capture\n  // template literals referenced indirectly through an identifier.\n  if (templateInfo.inlineTemplateLiteralExpression !== null) {\n    return templateInfo.inlineTemplateLiteralExpression;\n  }\n\n  // If the template is defined inline but not through a literal, the template has been resolved\n  // through static interpretation. We create a literal but cannot provide any source span. Note\n  // that we cannot use the expression defining the template because the linker expects the template\n  // to be defined as a literal in the declaration.\n  if (templateInfo.isInline) {\n    return o.literal(templateInfo.content, null, null);\n  }\n\n  // The template is external so we must synthesize an expression node with\n  // the appropriate source-span.\n  const contents = templateInfo.content;\n  const file = new ParseSourceFile(contents, templateInfo.sourceUrl);\n  const start = new ParseLocation(file, 0, 0, 0);\n  const end = computeEndLocation(file, contents);\n  const span = new ParseSourceSpan(start, end);\n  return o.literal(contents, null, span);\n}\n\nfunction computeEndLocation(file: ParseSourceFile, contents: string): ParseLocation {\n  const length = contents.length;\n  let lineStart = 0;\n  let lastLineStart = 0;\n  let line = 0;\n  do {\n    lineStart = contents.indexOf('\\n', lastLineStart);\n    if (lineStart !== -1) {\n      lastLineStart = lineStart + 1;\n      line++;\n    }\n  } while (lineStart !== -1);\n\n  return new ParseLocation(file, length, line, length - lastLineStart);\n}\n\n/**\n * Compiles the directives as registered in the component metadata into an array literal of the\n * individual directives. If the component does not use any directives, then null is returned.\n */\nfunction compileUsedDirectiveMetadata(\n    meta: R3ComponentMetadata,\n    predicate: (directive: R3UsedDirectiveMetadata) => boolean): o.LiteralArrayExpr|null {\n  const wrapType = meta.declarationListEmitMode !== DeclarationListEmitMode.Direct ?\n      generateForwardRef :\n      (expr: o.Expression) => expr;\n\n  const directives = meta.directives.filter(predicate);\n  return toOptionalLiteralArray(directives, directive => {\n    const dirMeta = new DefinitionMap<R3DeclareUsedDirectiveMetadata>();\n    dirMeta.set('type', wrapType(directive.type));\n    dirMeta.set('selector', o.literal(directive.selector));\n    dirMeta.set('inputs', toOptionalLiteralArray(directive.inputs, o.literal));\n    dirMeta.set('outputs', toOptionalLiteralArray(directive.outputs, o.literal));\n    dirMeta.set('exportAs', toOptionalLiteralArray(directive.exportAs, o.literal));\n    return dirMeta.toLiteralMap();\n  });\n}\n\n/**\n * Compiles the pipes as registered in the component metadata into an object literal, where the\n * pipe's name is used as key and a reference to its type as value. If the component does not use\n * any pipes, then null is returned.\n */\nfunction compileUsedPipeMetadata(meta: R3ComponentMetadata): o.LiteralMapExpr|null {\n  if (meta.pipes.size === 0) {\n    return null;\n  }\n\n  const wrapType = meta.declarationListEmitMode !== DeclarationListEmitMode.Direct ?\n      generateForwardRef :\n      (expr: o.Expression) => expr;\n\n  const entries = [];\n  for (const [name, pipe] of meta.pipes) {\n    entries.push({key: name, value: wrapType(pipe), quoted: true});\n  }\n  return o.literalMap(entries);\n}\n"]}