@angular/compiler 17.1.0-rc.0 → 17.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -87,7 +87,7 @@ export function createI18nContexts(job) {
87
87
  if (op.message.id !== currentI18nOp.message.id) {
88
88
  // This ICU is a sub-message inside its parent i18n block message. We need to give it
89
89
  // its own context.
90
- const contextOp = ir.createI18nContextOp(ir.I18nContextKind.Icu, job.allocateXrefId(), currentI18nOp.xref, op.message, null);
90
+ const contextOp = ir.createI18nContextOp(ir.I18nContextKind.Icu, job.allocateXrefId(), currentI18nOp.root, op.message, null);
91
91
  unit.create.push(contextOp);
92
92
  op.context = contextOp.xref;
93
93
  }
@@ -102,4 +102,4 @@ export function createI18nContexts(job) {
102
102
  }
103
103
  }
104
104
  }
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create_i18n_contexts.js","sourceRoot":"","sources":["../../../../../../../../../../packages/compiler/src/template/pipeline/src/phases/create_i18n_contexts.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 * as i18n from '../../../../i18n/i18n_ast';\nimport * as ir from '../../ir';\nimport {CompilationJob} from '../compilation';\n\n/**\n * Create one helper context op per i18n block (including generate descending blocks).\n *\n * Also, if an ICU exists inside an i18n block that also contains other localizable content (such as\n * string), create an additional helper context op for the ICU.\n *\n * These context ops are later used for generating i18n messages. (Although we generate at least one\n * context op per nested view, we will collect them up the tree later, to generate a top-level\n * message.)\n */\nexport function createI18nContexts(job: CompilationJob) {\n  // Create i18n context ops for i18n attrs.\n  const attrContextByMessage = new Map<i18n.Message, ir.XrefId>();\n  for (const unit of job.units) {\n    for (const op of unit.ops()) {\n      switch (op.kind) {\n        case ir.OpKind.Binding:\n        case ir.OpKind.Property:\n        case ir.OpKind.Attribute:\n        case ir.OpKind.ExtractedAttribute:\n          if (op.i18nMessage === null) {\n            continue;\n          }\n          if (!attrContextByMessage.has(op.i18nMessage)) {\n            const i18nContext = ir.createI18nContextOp(\n                ir.I18nContextKind.Attr, job.allocateXrefId(), null, op.i18nMessage, null!);\n            unit.create.push(i18nContext);\n            attrContextByMessage.set(op.i18nMessage, i18nContext.xref);\n          }\n          op.i18nContext = attrContextByMessage.get(op.i18nMessage)!;\n          break;\n      }\n    }\n  }\n\n  // Create i18n context ops for root i18n blocks.\n  const blockContextByI18nBlock = new Map<ir.XrefId, ir.I18nContextOp>();\n  for (const unit of job.units) {\n    for (const op of unit.create) {\n      switch (op.kind) {\n        case ir.OpKind.I18nStart:\n          if (op.xref === op.root) {\n            const contextOp = ir.createI18nContextOp(\n                ir.I18nContextKind.RootI18n, job.allocateXrefId(), op.xref, op.message, null!);\n            unit.create.push(contextOp);\n            op.context = contextOp.xref;\n            blockContextByI18nBlock.set(op.xref, contextOp);\n          }\n          break;\n      }\n    }\n  }\n\n  // Assign i18n contexts for child i18n blocks. These don't need their own conext, instead they\n  // should inherit from their root i18n block.\n  for (const unit of job.units) {\n    for (const op of unit.create) {\n      if (op.kind === ir.OpKind.I18nStart && op.xref !== op.root) {\n        const rootContext = blockContextByI18nBlock.get(op.root);\n        if (rootContext === undefined) {\n          throw Error('AssertionError: Root i18n block i18n context should have been created.');\n        }\n        op.context = rootContext.xref;\n        blockContextByI18nBlock.set(op.xref, rootContext);\n      }\n    }\n  }\n\n  // Create or assign i18n contexts for ICUs.\n  let currentI18nOp: ir.I18nStartOp|null = null;\n  for (const unit of job.units) {\n    for (const op of unit.create) {\n      switch (op.kind) {\n        case ir.OpKind.I18nStart:\n          currentI18nOp = op;\n          break;\n        case ir.OpKind.I18nEnd:\n          currentI18nOp = null;\n          break;\n        case ir.OpKind.IcuStart:\n          if (currentI18nOp === null) {\n            throw Error('AssertionError: Unexpected ICU outside of an i18n block.');\n          }\n          if (op.message.id !== currentI18nOp.message.id) {\n            // This ICU is a sub-message inside its parent i18n block message. We need to give it\n            // its own context.\n            const contextOp = ir.createI18nContextOp(\n                ir.I18nContextKind.Icu, job.allocateXrefId(), currentI18nOp.xref, op.message, null!\n            );\n            unit.create.push(contextOp);\n            op.context = contextOp.xref;\n          } else {\n            // This ICU is the only translatable content in its parent i18n block. We need to\n            // convert the parent's context into an ICU context.\n            op.context = currentI18nOp.context;\n            blockContextByI18nBlock.get(currentI18nOp.xref)!.contextKind = ir.I18nContextKind.Icu;\n          }\n          break;\n      }\n    }\n  }\n}\n"]}
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create_i18n_contexts.js","sourceRoot":"","sources":["../../../../../../../../../../packages/compiler/src/template/pipeline/src/phases/create_i18n_contexts.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAGH,OAAO,KAAK,EAAE,MAAM,UAAU,CAAC;AAG/B;;;;;;;;;GASG;AACH,MAAM,UAAU,kBAAkB,CAAC,GAAmB;IACpD,0CAA0C;IAC1C,MAAM,oBAAoB,GAAG,IAAI,GAAG,EAA2B,CAAC;IAChE,KAAK,MAAM,IAAI,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC7B,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;YAC5B,QAAQ,EAAE,CAAC,IAAI,EAAE,CAAC;gBAChB,KAAK,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC;gBACvB,KAAK,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC;gBACxB,KAAK,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC;gBACzB,KAAK,EAAE,CAAC,MAAM,CAAC,kBAAkB;oBAC/B,IAAI,EAAE,CAAC,WAAW,KAAK,IAAI,EAAE,CAAC;wBAC5B,SAAS;oBACX,CAAC;oBACD,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC;wBAC9C,MAAM,WAAW,GAAG,EAAE,CAAC,mBAAmB,CACtC,EAAE,CAAC,eAAe,CAAC,IAAI,EAAE,GAAG,CAAC,cAAc,EAAE,EAAE,IAAI,EAAE,EAAE,CAAC,WAAW,EAAE,IAAK,CAAC,CAAC;wBAChF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;wBAC9B,oBAAoB,CAAC,GAAG,CAAC,EAAE,CAAC,WAAW,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;oBAC7D,CAAC;oBACD,EAAE,CAAC,WAAW,GAAG,oBAAoB,CAAC,GAAG,CAAC,EAAE,CAAC,WAAW,CAAE,CAAC;oBAC3D,MAAM;YACV,CAAC;QACH,CAAC;IACH,CAAC;IAED,gDAAgD;IAChD,MAAM,uBAAuB,GAAG,IAAI,GAAG,EAA+B,CAAC;IACvE,KAAK,MAAM,IAAI,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC7B,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAC7B,QAAQ,EAAE,CAAC,IAAI,EAAE,CAAC;gBAChB,KAAK,EAAE,CAAC,MAAM,CAAC,SAAS;oBACtB,IAAI,EAAE,CAAC,IAAI,KAAK,EAAE,CAAC,IAAI,EAAE,CAAC;wBACxB,MAAM,SAAS,GAAG,EAAE,CAAC,mBAAmB,CACpC,EAAE,CAAC,eAAe,CAAC,QAAQ,EAAE,GAAG,CAAC,cAAc,EAAE,EAAE,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,EAAE,IAAK,CAAC,CAAC;wBACnF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;wBAC5B,EAAE,CAAC,OAAO,GAAG,SAAS,CAAC,IAAI,CAAC;wBAC5B,uBAAuB,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;oBAClD,CAAC;oBACD,MAAM;YACV,CAAC;QACH,CAAC;IACH,CAAC;IAED,8FAA8F;IAC9F,6CAA6C;IAC7C,KAAK,MAAM,IAAI,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC7B,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAC7B,IAAI,EAAE,CAAC,IAAI,KAAK,EAAE,CAAC,MAAM,CAAC,SAAS,IAAI,EAAE,CAAC,IAAI,KAAK,EAAE,CAAC,IAAI,EAAE,CAAC;gBAC3D,MAAM,WAAW,GAAG,uBAAuB,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;gBACzD,IAAI,WAAW,KAAK,SAAS,EAAE,CAAC;oBAC9B,MAAM,KAAK,CAAC,wEAAwE,CAAC,CAAC;gBACxF,CAAC;gBACD,EAAE,CAAC,OAAO,GAAG,WAAW,CAAC,IAAI,CAAC;gBAC9B,uBAAuB,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;YACpD,CAAC;QACH,CAAC;IACH,CAAC;IAED,2CAA2C;IAC3C,IAAI,aAAa,GAAwB,IAAI,CAAC;IAC9C,KAAK,MAAM,IAAI,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC7B,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAC7B,QAAQ,EAAE,CAAC,IAAI,EAAE,CAAC;gBAChB,KAAK,EAAE,CAAC,MAAM,CAAC,SAAS;oBACtB,aAAa,GAAG,EAAE,CAAC;oBACnB,MAAM;gBACR,KAAK,EAAE,CAAC,MAAM,CAAC,OAAO;oBACpB,aAAa,GAAG,IAAI,CAAC;oBACrB,MAAM;gBACR,KAAK,EAAE,CAAC,MAAM,CAAC,QAAQ;oBACrB,IAAI,aAAa,KAAK,IAAI,EAAE,CAAC;wBAC3B,MAAM,KAAK,CAAC,0DAA0D,CAAC,CAAC;oBAC1E,CAAC;oBACD,IAAI,EAAE,CAAC,OAAO,CAAC,EAAE,KAAK,aAAa,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC;wBAC/C,qFAAqF;wBACrF,mBAAmB;wBACnB,MAAM,SAAS,GAAG,EAAE,CAAC,mBAAmB,CACpC,EAAE,CAAC,eAAe,CAAC,GAAG,EAAE,GAAG,CAAC,cAAc,EAAE,EAAE,aAAa,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,EAAE,IAAK,CACtF,CAAC;wBACF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;wBAC5B,EAAE,CAAC,OAAO,GAAG,SAAS,CAAC,IAAI,CAAC;oBAC9B,CAAC;yBAAM,CAAC;wBACN,iFAAiF;wBACjF,oDAAoD;wBACpD,EAAE,CAAC,OAAO,GAAG,aAAa,CAAC,OAAO,CAAC;wBACnC,uBAAuB,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,CAAE,CAAC,WAAW,GAAG,EAAE,CAAC,eAAe,CAAC,GAAG,CAAC;oBACxF,CAAC;oBACD,MAAM;YACV,CAAC;QACH,CAAC;IACH,CAAC;AACH,CAAC","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 * as i18n from '../../../../i18n/i18n_ast';\nimport * as ir from '../../ir';\nimport {CompilationJob} from '../compilation';\n\n/**\n * Create one helper context op per i18n block (including generate descending blocks).\n *\n * Also, if an ICU exists inside an i18n block that also contains other localizable content (such as\n * string), create an additional helper context op for the ICU.\n *\n * These context ops are later used for generating i18n messages. (Although we generate at least one\n * context op per nested view, we will collect them up the tree later, to generate a top-level\n * message.)\n */\nexport function createI18nContexts(job: CompilationJob) {\n  // Create i18n context ops for i18n attrs.\n  const attrContextByMessage = new Map<i18n.Message, ir.XrefId>();\n  for (const unit of job.units) {\n    for (const op of unit.ops()) {\n      switch (op.kind) {\n        case ir.OpKind.Binding:\n        case ir.OpKind.Property:\n        case ir.OpKind.Attribute:\n        case ir.OpKind.ExtractedAttribute:\n          if (op.i18nMessage === null) {\n            continue;\n          }\n          if (!attrContextByMessage.has(op.i18nMessage)) {\n            const i18nContext = ir.createI18nContextOp(\n                ir.I18nContextKind.Attr, job.allocateXrefId(), null, op.i18nMessage, null!);\n            unit.create.push(i18nContext);\n            attrContextByMessage.set(op.i18nMessage, i18nContext.xref);\n          }\n          op.i18nContext = attrContextByMessage.get(op.i18nMessage)!;\n          break;\n      }\n    }\n  }\n\n  // Create i18n context ops for root i18n blocks.\n  const blockContextByI18nBlock = new Map<ir.XrefId, ir.I18nContextOp>();\n  for (const unit of job.units) {\n    for (const op of unit.create) {\n      switch (op.kind) {\n        case ir.OpKind.I18nStart:\n          if (op.xref === op.root) {\n            const contextOp = ir.createI18nContextOp(\n                ir.I18nContextKind.RootI18n, job.allocateXrefId(), op.xref, op.message, null!);\n            unit.create.push(contextOp);\n            op.context = contextOp.xref;\n            blockContextByI18nBlock.set(op.xref, contextOp);\n          }\n          break;\n      }\n    }\n  }\n\n  // Assign i18n contexts for child i18n blocks. These don't need their own conext, instead they\n  // should inherit from their root i18n block.\n  for (const unit of job.units) {\n    for (const op of unit.create) {\n      if (op.kind === ir.OpKind.I18nStart && op.xref !== op.root) {\n        const rootContext = blockContextByI18nBlock.get(op.root);\n        if (rootContext === undefined) {\n          throw Error('AssertionError: Root i18n block i18n context should have been created.');\n        }\n        op.context = rootContext.xref;\n        blockContextByI18nBlock.set(op.xref, rootContext);\n      }\n    }\n  }\n\n  // Create or assign i18n contexts for ICUs.\n  let currentI18nOp: ir.I18nStartOp|null = null;\n  for (const unit of job.units) {\n    for (const op of unit.create) {\n      switch (op.kind) {\n        case ir.OpKind.I18nStart:\n          currentI18nOp = op;\n          break;\n        case ir.OpKind.I18nEnd:\n          currentI18nOp = null;\n          break;\n        case ir.OpKind.IcuStart:\n          if (currentI18nOp === null) {\n            throw Error('AssertionError: Unexpected ICU outside of an i18n block.');\n          }\n          if (op.message.id !== currentI18nOp.message.id) {\n            // This ICU is a sub-message inside its parent i18n block message. We need to give it\n            // its own context.\n            const contextOp = ir.createI18nContextOp(\n                ir.I18nContextKind.Icu, job.allocateXrefId(), currentI18nOp.root, op.message, null!\n            );\n            unit.create.push(contextOp);\n            op.context = contextOp.xref;\n          } else {\n            // This ICU is the only translatable content in its parent i18n block. We need to\n            // convert the parent's context into an ICU context.\n            op.context = currentI18nOp.context;\n            blockContextByI18nBlock.get(currentI18nOp.xref)!.contextKind = ir.I18nContextKind.Icu;\n          }\n          break;\n      }\n    }\n  }\n}\n"]}
@@ -11,5 +11,5 @@
11
11
  * Entry point for all public APIs of the compiler package.
12
12
  */
13
13
  import { Version } from './util';
14
- export const VERSION = new Version('17.1.0-rc.0');
14
+ export const VERSION = new Version('17.1.1');
15
15
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBpbGVyL3NyYy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVIOzs7O0dBSUc7QUFFSCxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sUUFBUSxDQUFDO0FBRS9CLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxJQUFJLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbi8qKlxuICogQG1vZHVsZVxuICogQGRlc2NyaXB0aW9uXG4gKiBFbnRyeSBwb2ludCBmb3IgYWxsIHB1YmxpYyBBUElzIG9mIHRoZSBjb21waWxlciBwYWNrYWdlLlxuICovXG5cbmltcG9ydCB7VmVyc2lvbn0gZnJvbSAnLi91dGlsJztcblxuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBuZXcgVmVyc2lvbignMC4wLjAtUExBQ0VIT0xERVInKTtcbiJdfQ==
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v17.1.0-rc.0
2
+ * @license Angular v17.1.1
3
3
  * (c) 2010-2022 Google LLC. https://angular.io/
4
4
  * License: MIT
5
5
  */
@@ -12282,7 +12282,7 @@ function createI18nContexts(job) {
12282
12282
  if (op.message.id !== currentI18nOp.message.id) {
12283
12283
  // This ICU is a sub-message inside its parent i18n block message. We need to give it
12284
12284
  // its own context.
12285
- const contextOp = createI18nContextOp(I18nContextKind.Icu, job.allocateXrefId(), currentI18nOp.xref, op.message, null);
12285
+ const contextOp = createI18nContextOp(I18nContextKind.Icu, job.allocateXrefId(), currentI18nOp.root, op.message, null);
12286
12286
  unit.create.push(contextOp);
12287
12287
  op.context = contextOp.xref;
12288
12288
  }
@@ -27819,7 +27819,7 @@ class TemplateData {
27819
27819
  }
27820
27820
  }
27821
27821
  class TemplateDefinitionBuilder {
27822
- constructor(constantPool, parentBindingScope, level = 0, contextName, i18nContext, templateIndex, templateName, _namespace, relativeContextFilePath, i18nUseExternalIds, deferBlocks, elementLocations, _constants = createComponentDefConsts()) {
27822
+ constructor(constantPool, parentBindingScope, level = 0, contextName, i18nContext, templateIndex, templateName, _namespace, relativeContextFilePath, i18nUseExternalIds, deferBlocks, elementLocations, allDeferrableDepsFn, _constants = createComponentDefConsts()) {
27823
27823
  this.constantPool = constantPool;
27824
27824
  this.level = level;
27825
27825
  this.contextName = contextName;
@@ -27830,6 +27830,7 @@ class TemplateDefinitionBuilder {
27830
27830
  this.i18nUseExternalIds = i18nUseExternalIds;
27831
27831
  this.deferBlocks = deferBlocks;
27832
27832
  this.elementLocations = elementLocations;
27833
+ this.allDeferrableDepsFn = allDeferrableDepsFn;
27833
27834
  this._constants = _constants;
27834
27835
  this._dataIndex = 0;
27835
27836
  this._bindingContext = 0;
@@ -28484,7 +28485,7 @@ class TemplateDefinitionBuilder {
28484
28485
  const contextName = `${this.contextName}${contextNameSuffix}_${index}`;
28485
28486
  const name = `${contextName}_Template`;
28486
28487
  // Create the template function
28487
- const visitor = new TemplateDefinitionBuilder(this.constantPool, this._bindingScope, this.level + 1, contextName, this.i18n, index, name, this._namespace, this.fileBasedI18nSuffix, this.i18nUseExternalIds, this.deferBlocks, this.elementLocations, this._constants);
28488
+ const visitor = new TemplateDefinitionBuilder(this.constantPool, this._bindingScope, this.level + 1, contextName, this.i18n, index, name, this._namespace, this.fileBasedI18nSuffix, this.i18nUseExternalIds, this.deferBlocks, this.elementLocations, this.allDeferrableDepsFn, this._constants);
28488
28489
  // Nested templates must not be visited until after their parent templates have completed
28489
28490
  // processing, so they are queued here until after the initial pass. Otherwise, we wouldn't
28490
28491
  // be able to support bindings in nested templates to local refs that occur after the
@@ -28772,7 +28773,7 @@ class TemplateDefinitionBuilder {
28772
28773
  this.creationInstruction(deferred.sourceSpan, Identifiers.defer, trimTrailingNulls([
28773
28774
  literal(deferredIndex),
28774
28775
  literal(primaryTemplateIndex),
28775
- this.createDeferredDepsFunction(depsFnName, metadata),
28776
+ this.allDeferrableDepsFn ?? this.createDeferredDepsFunction(depsFnName, metadata),
28776
28777
  literal(loadingIndex),
28777
28778
  literal(placeholderIndex),
28778
28779
  literal(errorIndex),
@@ -30134,6 +30135,24 @@ function compileDirectiveFromMetadata(meta, constantPool, bindingParser) {
30134
30135
  const type = createDirectiveType(meta);
30135
30136
  return { expression, type, statements: [] };
30136
30137
  }
30138
+ /**
30139
+ * Creates an AST for a function that contains dynamic imports representing
30140
+ * deferrable dependencies.
30141
+ */
30142
+ function createDeferredDepsFunction(constantPool, name, deps) {
30143
+ // This defer block has deps for which we need to generate dynamic imports.
30144
+ const dependencyExp = [];
30145
+ for (const [symbolName, importPath] of deps) {
30146
+ // Callback function, e.g. `m () => m.MyCmp;`.
30147
+ const innerFn = arrowFn([new FnParam('m', DYNAMIC_TYPE)], variable('m').prop(symbolName));
30148
+ // Dynamic import, e.g. `import('./a').then(...)`.
30149
+ const importExpr = (new DynamicImportExpr(importPath)).prop('then').callFn([innerFn]);
30150
+ dependencyExp.push(importExpr);
30151
+ }
30152
+ const depsFnExpr = arrowFn([], literalArr(dependencyExp));
30153
+ constantPool.statements.push(depsFnExpr.toDeclStmt(name, StmtModifier.Final));
30154
+ return variable(name);
30155
+ }
30137
30156
  /**
30138
30157
  * Compile a component for the render3 runtime as defined by the `R3ComponentMetadata`.
30139
30158
  */
@@ -30158,8 +30177,14 @@ function compileComponentFromMetadata(meta, constantPool, bindingParser) {
30158
30177
  if (!USE_TEMPLATE_PIPELINE) {
30159
30178
  // This is the main path currently used in compilation, which compiles the template with the
30160
30179
  // legacy `TemplateDefinitionBuilder`.
30180
+ let allDeferrableDepsFn = null;
30181
+ if (meta.deferBlocks.size > 0 && meta.deferrableTypes.size > 0 &&
30182
+ meta.deferBlockDepsEmitMode === 1 /* DeferBlockDepsEmitMode.PerComponent */) {
30183
+ const fnName = `${templateTypeName}_DeferFn`;
30184
+ allDeferrableDepsFn = createDeferredDepsFunction(constantPool, fnName, meta.deferrableTypes);
30185
+ }
30161
30186
  const template = meta.template;
30162
- const templateBuilder = new TemplateDefinitionBuilder(constantPool, BindingScope.createRootScope(), 0, templateTypeName, null, null, templateName, Identifiers.namespaceHTML, meta.relativeContextFilePath, meta.i18nUseExternalIds, meta.deferBlocks, new Map());
30187
+ const templateBuilder = new TemplateDefinitionBuilder(constantPool, BindingScope.createRootScope(), 0, templateTypeName, null, null, templateName, Identifiers.namespaceHTML, meta.relativeContextFilePath, meta.i18nUseExternalIds, meta.deferBlocks, new Map(), allDeferrableDepsFn);
30163
30188
  const templateFunctionExpression = templateBuilder.buildTemplateFunction(template.nodes, []);
30164
30189
  // We need to provide this so that dynamically generated components know what
30165
30190
  // projected content blocks to pass through to the component when it is
@@ -30890,7 +30915,7 @@ class R3TargetBinder {
30890
30915
  // Finally, run the TemplateBinder to bind references, variables, and other entities within the
30891
30916
  // template. This extracts all the metadata that doesn't depend on directive matching.
30892
30917
  const { expressions, symbols, nestingLevel, usedPipes, eagerPipes, deferBlocks } = TemplateBinder.applyWithScope(target.template, scope);
30893
- return new R3BoundTarget(target, directives, eagerDirectives, bindings, references, expressions, symbols, nestingLevel, scopedNodeEntities, usedPipes, eagerPipes, deferBlocks);
30918
+ return new R3BoundTarget(target, directives, eagerDirectives, bindings, references, expressions, symbols, nestingLevel, scopedNodeEntities, usedPipes, eagerPipes, deferBlocks, scope);
30894
30919
  }
30895
30920
  }
30896
30921
  /**
@@ -30908,6 +30933,10 @@ class Scope {
30908
30933
  * Named members of the `Scope`, such as `Reference`s or `Variable`s.
30909
30934
  */
30910
30935
  this.namedEntities = new Map();
30936
+ /**
30937
+ * Set of elements that belong to this scope.
30938
+ */
30939
+ this.elementsInScope = new Set();
30911
30940
  /**
30912
30941
  * Child `Scope`s for immediately nested `ScopedNode`s.
30913
30942
  */
@@ -30964,6 +30993,7 @@ class Scope {
30964
30993
  element.references.forEach(node => this.visitReference(node));
30965
30994
  // Recurse into the `Element`'s children.
30966
30995
  element.children.forEach(node => node.visit(this));
30996
+ this.elementsInScope.add(element);
30967
30997
  }
30968
30998
  visitTemplate(template) {
30969
30999
  // References on a <ng-template> are defined in the outer scope, so capture them before
@@ -31457,7 +31487,7 @@ class TemplateBinder extends RecursiveAstVisitor {
31457
31487
  * See `BoundTarget` for documentation on the individual methods.
31458
31488
  */
31459
31489
  class R3BoundTarget {
31460
- constructor(target, directives, eagerDirectives, bindings, references, exprTargets, symbols, nestingLevel, scopedNodeEntities, usedPipes, eagerPipes, deferredBlocks) {
31490
+ constructor(target, directives, eagerDirectives, bindings, references, exprTargets, symbols, nestingLevel, scopedNodeEntities, usedPipes, eagerPipes, deferredBlocks, rootScope) {
31461
31491
  this.target = target;
31462
31492
  this.directives = directives;
31463
31493
  this.eagerDirectives = eagerDirectives;
@@ -31470,6 +31500,7 @@ class R3BoundTarget {
31470
31500
  this.usedPipes = usedPipes;
31471
31501
  this.eagerPipes = eagerPipes;
31472
31502
  this.deferredBlocks = deferredBlocks;
31503
+ this.rootScope = rootScope;
31473
31504
  }
31474
31505
  getEntitiesInScope(node) {
31475
31506
  return this.scopedNodeEntities.get(node) ?? new Set();
@@ -31559,6 +31590,15 @@ class R3BoundTarget {
31559
31590
  }
31560
31591
  return null;
31561
31592
  }
31593
+ isDeferred(element) {
31594
+ for (const deferBlock of this.deferredBlocks) {
31595
+ const scope = this.rootScope.childScopes.get(deferBlock);
31596
+ if (scope && scope.elementsInScope.has(element)) {
31597
+ return true;
31598
+ }
31599
+ }
31600
+ return false;
31601
+ }
31562
31602
  /**
31563
31603
  * Finds an entity with a specific name in a scope.
31564
31604
  * @param rootNode Root node of the scope.
@@ -31747,9 +31787,9 @@ class CompilerFacadeImpl {
31747
31787
  declarations: facade.declarations.map(convertDeclarationFacadeToMetadata),
31748
31788
  declarationListEmitMode: 0 /* DeclarationListEmitMode.Direct */,
31749
31789
  deferBlocks,
31750
- // TODO: leaving empty in JIT mode for now,
31751
- // to be implemented as one of the next steps.
31790
+ deferrableTypes: new Map(),
31752
31791
  deferrableDeclToImportDecl: new Map(),
31792
+ deferBlockDepsEmitMode: 0 /* DeferBlockDepsEmitMode.PerBlock */,
31753
31793
  styles: [...facade.styles, ...template.styles],
31754
31794
  encapsulation: facade.encapsulation,
31755
31795
  interpolation,
@@ -31985,9 +32025,9 @@ function convertDeclareComponentFacadeToMetadata(decl, typeSourceSpan, sourceMap
31985
32025
  null,
31986
32026
  animations: decl.animations !== undefined ? new WrappedNodeExpr(decl.animations) : null,
31987
32027
  deferBlocks,
31988
- // TODO: leaving empty in JIT mode for now,
31989
- // to be implemented as one of the next steps.
32028
+ deferrableTypes: new Map(),
31990
32029
  deferrableDeclToImportDecl: new Map(),
32030
+ deferBlockDepsEmitMode: 0 /* DeferBlockDepsEmitMode.PerBlock */,
31991
32031
  changeDetection: decl.changeDetection ?? ChangeDetectionStrategy.Default,
31992
32032
  encapsulation: decl.encapsulation ?? ViewEncapsulation.Emulated,
31993
32033
  interpolation,
@@ -32275,7 +32315,7 @@ function publishFacade(global) {
32275
32315
  * @description
32276
32316
  * Entry point for all public APIs of the compiler package.
32277
32317
  */
32278
- const VERSION = new Version('17.1.0-rc.0');
32318
+ const VERSION = new Version('17.1.1');
32279
32319
 
32280
32320
  class CompilerConfig {
32281
32321
  constructor({ defaultEncapsulation = ViewEncapsulation.Emulated, preserveWhitespaces, strictInjectionParameters } = {}) {
@@ -33770,7 +33810,7 @@ function compileClassMetadata(metadata) {
33770
33810
  * check to tree-shake away this code in production mode.
33771
33811
  */
33772
33812
  function compileComponentClassMetadata(metadata, deferrableTypes) {
33773
- if (deferrableTypes.size === 0) {
33813
+ if (deferrableTypes === null || deferrableTypes.size === 0) {
33774
33814
  // If there are no deferrable symbols - just generate a regular `setClassMetadata` call.
33775
33815
  return compileClassMetadata(metadata);
33776
33816
  }
@@ -33841,7 +33881,7 @@ const MINIMUM_PARTIAL_LINKER_VERSION$5 = '12.0.0';
33841
33881
  function compileDeclareClassMetadata(metadata) {
33842
33882
  const definitionMap = new DefinitionMap();
33843
33883
  definitionMap.set('minVersion', literal(MINIMUM_PARTIAL_LINKER_VERSION$5));
33844
- definitionMap.set('version', literal('17.1.0-rc.0'));
33884
+ definitionMap.set('version', literal('17.1.1'));
33845
33885
  definitionMap.set('ngImport', importExpr(Identifiers.core));
33846
33886
  definitionMap.set('type', metadata.type);
33847
33887
  definitionMap.set('decorators', metadata.decorators);
@@ -33937,7 +33977,7 @@ function createDirectiveDefinitionMap(meta) {
33937
33977
  const definitionMap = new DefinitionMap();
33938
33978
  const minVersion = getMinimumVersionForPartialOutput(meta);
33939
33979
  definitionMap.set('minVersion', literal(minVersion));
33940
- definitionMap.set('version', literal('17.1.0-rc.0'));
33980
+ definitionMap.set('version', literal('17.1.1'));
33941
33981
  // e.g. `type: MyDirective`
33942
33982
  definitionMap.set('type', meta.type.value);
33943
33983
  if (meta.isStandalone) {
@@ -34321,7 +34361,7 @@ const MINIMUM_PARTIAL_LINKER_VERSION$4 = '12.0.0';
34321
34361
  function compileDeclareFactoryFunction(meta) {
34322
34362
  const definitionMap = new DefinitionMap();
34323
34363
  definitionMap.set('minVersion', literal(MINIMUM_PARTIAL_LINKER_VERSION$4));
34324
- definitionMap.set('version', literal('17.1.0-rc.0'));
34364
+ definitionMap.set('version', literal('17.1.1'));
34325
34365
  definitionMap.set('ngImport', importExpr(Identifiers.core));
34326
34366
  definitionMap.set('type', meta.type.value);
34327
34367
  definitionMap.set('deps', compileDependencies(meta.deps));
@@ -34356,7 +34396,7 @@ function compileDeclareInjectableFromMetadata(meta) {
34356
34396
  function createInjectableDefinitionMap(meta) {
34357
34397
  const definitionMap = new DefinitionMap();
34358
34398
  definitionMap.set('minVersion', literal(MINIMUM_PARTIAL_LINKER_VERSION$3));
34359
- definitionMap.set('version', literal('17.1.0-rc.0'));
34399
+ definitionMap.set('version', literal('17.1.1'));
34360
34400
  definitionMap.set('ngImport', importExpr(Identifiers.core));
34361
34401
  definitionMap.set('type', meta.type.value);
34362
34402
  // Only generate providedIn property if it has a non-null value
@@ -34407,7 +34447,7 @@ function compileDeclareInjectorFromMetadata(meta) {
34407
34447
  function createInjectorDefinitionMap(meta) {
34408
34448
  const definitionMap = new DefinitionMap();
34409
34449
  definitionMap.set('minVersion', literal(MINIMUM_PARTIAL_LINKER_VERSION$2));
34410
- definitionMap.set('version', literal('17.1.0-rc.0'));
34450
+ definitionMap.set('version', literal('17.1.1'));
34411
34451
  definitionMap.set('ngImport', importExpr(Identifiers.core));
34412
34452
  definitionMap.set('type', meta.type.value);
34413
34453
  definitionMap.set('providers', meta.providers);
@@ -34440,7 +34480,7 @@ function createNgModuleDefinitionMap(meta) {
34440
34480
  throw new Error('Invalid path! Local compilation mode should not get into the partial compilation path');
34441
34481
  }
34442
34482
  definitionMap.set('minVersion', literal(MINIMUM_PARTIAL_LINKER_VERSION$1));
34443
- definitionMap.set('version', literal('17.1.0-rc.0'));
34483
+ definitionMap.set('version', literal('17.1.1'));
34444
34484
  definitionMap.set('ngImport', importExpr(Identifiers.core));
34445
34485
  definitionMap.set('type', meta.type.value);
34446
34486
  // We only generate the keys in the metadata if the arrays contain values.
@@ -34491,7 +34531,7 @@ function compileDeclarePipeFromMetadata(meta) {
34491
34531
  function createPipeDefinitionMap(meta) {
34492
34532
  const definitionMap = new DefinitionMap();
34493
34533
  definitionMap.set('minVersion', literal(MINIMUM_PARTIAL_LINKER_VERSION));
34494
- definitionMap.set('version', literal('17.1.0-rc.0'));
34534
+ definitionMap.set('version', literal('17.1.1'));
34495
34535
  definitionMap.set('ngImport', importExpr(Identifiers.core));
34496
34536
  // e.g. `type: MyPipe`
34497
34537
  definitionMap.set('type', meta.type.value);