@angular/core 18.1.0-rc.0 → 18.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.
Files changed (46) hide show
  1. package/esm2022/primitives/event-dispatch/contract_binary.mjs +3 -3
  2. package/esm2022/primitives/event-dispatch/index.mjs +6 -7
  3. package/esm2022/primitives/event-dispatch/src/a11y_click.mjs +1 -1
  4. package/esm2022/primitives/event-dispatch/src/action_resolver.mjs +1 -1
  5. package/esm2022/primitives/event-dispatch/src/bootstrap_app_scoped.mjs +29 -0
  6. package/esm2022/primitives/event-dispatch/src/bootstrap_global.mjs +21 -0
  7. package/esm2022/primitives/event-dispatch/src/cache.mjs +10 -21
  8. package/esm2022/primitives/event-dispatch/src/earlyeventcontract.mjs +32 -21
  9. package/esm2022/primitives/event-dispatch/src/event.mjs +3 -3
  10. package/esm2022/primitives/event-dispatch/src/event_contract_defines.mjs +1 -6
  11. package/esm2022/primitives/event-dispatch/src/event_type.mjs +19 -21
  12. package/esm2022/primitives/event-dispatch/src/eventcontract.mjs +6 -8
  13. package/esm2022/primitives/event-dispatch/src/property.mjs +1 -1
  14. package/esm2022/rxjs-interop/src/to_signal.mjs +4 -4
  15. package/esm2022/src/defer/instructions.mjs +53 -35
  16. package/esm2022/src/event_delegation_utils.mjs +10 -10
  17. package/esm2022/src/hydration/event_replay.mjs +17 -22
  18. package/esm2022/src/render3/after_render_hooks.mjs +7 -2
  19. package/esm2022/src/render3/component_ref.mjs +1 -1
  20. package/esm2022/src/render3/debug/framework_injector_profiler.mjs +3 -2
  21. package/esm2022/src/version.mjs +1 -1
  22. package/esm2022/testing/src/logger.mjs +3 -3
  23. package/event-dispatch-contract.min.js +1 -1
  24. package/fesm2022/core.mjs +85 -66
  25. package/fesm2022/core.mjs.map +1 -1
  26. package/fesm2022/primitives/event-dispatch.mjs +452 -529
  27. package/fesm2022/primitives/event-dispatch.mjs.map +1 -1
  28. package/fesm2022/primitives/signals.mjs +1 -1
  29. package/fesm2022/rxjs-interop.mjs +4 -4
  30. package/fesm2022/rxjs-interop.mjs.map +1 -1
  31. package/fesm2022/testing.mjs +1 -1
  32. package/index.d.ts +4 -4
  33. package/package.json +1 -1
  34. package/primitives/event-dispatch/index.d.ts +23 -37
  35. package/primitives/signals/index.d.ts +1 -1
  36. package/rxjs-interop/index.d.ts +2 -2
  37. package/schematics/migrations/after-render-phase/bundle.js +12 -12
  38. package/schematics/migrations/http-providers/bundle.js +15 -15
  39. package/schematics/migrations/invalid-two-way-bindings/bundle.js +202 -193
  40. package/schematics/migrations/invalid-two-way-bindings/bundle.js.map +2 -2
  41. package/schematics/ng-generate/control-flow-migration/bundle.js +227 -202
  42. package/schematics/ng-generate/control-flow-migration/bundle.js.map +2 -2
  43. package/schematics/ng-generate/standalone-migration/bundle.js +533 -506
  44. package/schematics/ng-generate/standalone-migration/bundle.js.map +2 -2
  45. package/testing/index.d.ts +1 -1
  46. package/esm2022/primitives/event-dispatch/src/register_events.mjs +0 -31
@@ -168,7 +168,8 @@ function handleInstanceCreatedByInjectorEvent(context, data) {
168
168
  if (typeof value === 'object') {
169
169
  standaloneComponent = value?.constructor;
170
170
  }
171
- if (standaloneComponent === undefined || !isStandaloneComponent(standaloneComponent)) {
171
+ // We want to also cover if `standaloneComponent === null` in addition to `undefined`
172
+ if (standaloneComponent == undefined || !isStandaloneComponent(standaloneComponent)) {
172
173
  return;
173
174
  }
174
175
  const environmentInjector = context.injector.get(EnvironmentInjector, null, { optional: true });
@@ -246,4 +247,4 @@ function canBeHeldWeakly(value) {
246
247
  return (value !== null &&
247
248
  (typeof value === 'object' || typeof value === 'function' || typeof value === 'symbol'));
248
249
  }
249
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"framework_injector_profiler.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/debug/framework_injector_profiler.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 {Injector} from '../../di/injector';\nimport {EnvironmentInjector} from '../../di/r3_injector';\nimport {Type} from '../../interface/type';\nimport {assertDefined, throwError} from '../../util/assert';\nimport {assertTNode, assertTNodeForLView} from '../assert';\nimport {getComponentDef} from '../definition';\nimport {getNodeInjectorLView, getNodeInjectorTNode, NodeInjector} from '../di';\nimport {TNode} from '../interfaces/node';\nimport {LView} from '../interfaces/view';\n\nimport {\n  InjectedService,\n  InjectorCreatedInstance,\n  InjectorProfilerContext,\n  InjectorProfilerEvent,\n  InjectorProfilerEventType,\n  ProviderRecord,\n  setInjectorProfiler,\n} from './injector_profiler';\n\n/**\n * These are the data structures that our framework injector profiler will fill with data in order\n * to support DI debugging APIs.\n *\n * resolverToTokenToDependencies: Maps an injector to a Map of tokens to an Array of\n * dependencies. Injector -> Token -> Dependencies This is used to support the\n * getDependenciesFromInjectable API, which takes in an injector and a token and returns it's\n * dependencies.\n *\n * resolverToProviders: Maps a DI resolver (an Injector or a TNode) to the providers configured\n * within it This is used to support the getInjectorProviders API, which takes in an injector and\n * returns the providers that it was configured with. Note that for the element injector case we\n * use the TNode instead of the LView as the DI resolver. This is because the registration of\n * providers happens only once per type of TNode. If an injector is created with an identical TNode,\n * the providers for that injector will not be reconfigured.\n *\n * standaloneInjectorToComponent: Maps the injector of a standalone component to the standalone\n * component that it is associated with. Used in the getInjectorProviders API, specificially in the\n * discovery of import paths for each provider. This is necessary because the imports array of a\n * standalone component is processed and configured in its standalone injector, but exists within\n * the component's definition. Because getInjectorProviders takes in an injector, if that injector\n * is the injector of a standalone component, we need to be able to discover the place where the\n * imports array is located (the component) in order to flatten the imports array within it to\n * discover all of it's providers.\n *\n *\n * All of these data structures are instantiated with WeakMaps. This will ensure that the presence\n * of any object in the keys of these maps does not prevent the garbage collector from collecting\n * those objects. Because of this property of WeakMaps, these data structures will never be the\n * source of a memory leak.\n *\n * An example of this advantage: When components are destroyed, we don't need to do\n * any additional work to remove that component from our mappings.\n *\n */\nclass DIDebugData {\n  resolverToTokenToDependencies = new WeakMap<\n    Injector | LView,\n    WeakMap<Type<unknown>, InjectedService[]>\n  >();\n  resolverToProviders = new WeakMap<Injector | TNode, ProviderRecord[]>();\n  standaloneInjectorToComponent = new WeakMap<Injector, Type<unknown>>();\n\n  reset() {\n    this.resolverToTokenToDependencies = new WeakMap<\n      Injector | LView,\n      WeakMap<Type<unknown>, InjectedService[]>\n    >();\n    this.resolverToProviders = new WeakMap<Injector | TNode, ProviderRecord[]>();\n    this.standaloneInjectorToComponent = new WeakMap<Injector, Type<unknown>>();\n  }\n}\n\nlet frameworkDIDebugData = new DIDebugData();\n\nexport function getFrameworkDIDebugData(): DIDebugData {\n  return frameworkDIDebugData;\n}\n\n/**\n * Initalize default handling of injector events. This handling parses events\n * as they are emitted and constructs the data structures necessary to support\n * some of debug APIs.\n *\n * See handleInjectEvent, handleCreateEvent and handleProviderConfiguredEvent\n * for descriptions of each handler\n *\n * Supported APIs:\n *               - getDependenciesFromInjectable\n *               - getInjectorProviders\n */\nexport function setupFrameworkInjectorProfiler(): void {\n  frameworkDIDebugData.reset();\n  setInjectorProfiler((injectorProfilerEvent) =>\n    handleInjectorProfilerEvent(injectorProfilerEvent),\n  );\n}\n\nfunction handleInjectorProfilerEvent(injectorProfilerEvent: InjectorProfilerEvent): void {\n  const {context, type} = injectorProfilerEvent;\n\n  if (type === InjectorProfilerEventType.Inject) {\n    handleInjectEvent(context, injectorProfilerEvent.service);\n  } else if (type === InjectorProfilerEventType.InstanceCreatedByInjector) {\n    handleInstanceCreatedByInjectorEvent(context, injectorProfilerEvent.instance);\n  } else if (type === InjectorProfilerEventType.ProviderConfigured) {\n    handleProviderConfiguredEvent(context, injectorProfilerEvent.providerRecord);\n  }\n}\n\n/**\n *\n * Stores the injected service in frameworkDIDebugData.resolverToTokenToDependencies\n * based on it's injector and token.\n *\n * @param context InjectorProfilerContext the injection context that this event occurred in.\n * @param data InjectedService the service associated with this inject event.\n *\n */\nfunction handleInjectEvent(context: InjectorProfilerContext, data: InjectedService) {\n  const diResolver = getDIResolver(context.injector);\n  if (diResolver === null) {\n    throwError('An Inject event must be run within an injection context.');\n  }\n\n  const diResolverToInstantiatedToken = frameworkDIDebugData.resolverToTokenToDependencies;\n\n  if (!diResolverToInstantiatedToken.has(diResolver)) {\n    diResolverToInstantiatedToken.set(diResolver, new WeakMap<Type<unknown>, InjectedService[]>());\n  }\n\n  // if token is a primitive type, ignore this event. We do this because we cannot keep track of\n  // non-primitive tokens in WeakMaps since they are not garbage collectable.\n  if (!canBeHeldWeakly(context.token)) {\n    return;\n  }\n\n  const instantiatedTokenToDependencies = diResolverToInstantiatedToken.get(diResolver)!;\n  if (!instantiatedTokenToDependencies.has(context.token!)) {\n    instantiatedTokenToDependencies.set(context.token!, []);\n  }\n\n  const {token, value, flags} = data;\n\n  assertDefined(context.token, 'Injector profiler context token is undefined.');\n\n  const dependencies = instantiatedTokenToDependencies.get(context.token);\n  assertDefined(dependencies, 'Could not resolve dependencies for token.');\n\n  if (context.injector instanceof NodeInjector) {\n    dependencies.push({token, value, flags, injectedIn: getNodeInjectorContext(context.injector)});\n  } else {\n    dependencies.push({token, value, flags});\n  }\n}\n\n/**\n *\n * Returns the LView and TNode associated with a NodeInjector. Returns undefined if the injector\n * is not a NodeInjector.\n *\n * @param injector\n * @returns {lView: LView, tNode: TNode}|undefined\n */\nfunction getNodeInjectorContext(injector: Injector): {lView: LView; tNode: TNode} | undefined {\n  if (!(injector instanceof NodeInjector)) {\n    throwError('getNodeInjectorContext must be called with a NodeInjector');\n  }\n\n  const lView = getNodeInjectorLView(injector);\n  const tNode = getNodeInjectorTNode(injector);\n  if (tNode === null) {\n    return;\n  }\n\n  assertTNodeForLView(tNode, lView);\n\n  return {lView, tNode};\n}\n\n/**\n *\n * If the created instance is an instance of a standalone component, maps the injector to that\n * standalone component in frameworkDIDebugData.standaloneInjectorToComponent\n *\n * @param context InjectorProfilerContext the injection context that this event occurred in.\n * @param data InjectorCreatedInstance an object containing the instance that was just created\n *\n */\nfunction handleInstanceCreatedByInjectorEvent(\n  context: InjectorProfilerContext,\n  data: InjectorCreatedInstance,\n): void {\n  const {value} = data;\n\n  if (getDIResolver(context.injector) === null) {\n    throwError('An InjectorCreatedInstance event must be run within an injection context.');\n  }\n\n  // if our value is an instance of a standalone component, map the injector of that standalone\n  // component to the component class. Otherwise, this event is a noop.\n  let standaloneComponent: Type<unknown> | undefined = undefined;\n  if (typeof value === 'object') {\n    standaloneComponent = value?.constructor as Type<unknown>;\n  }\n  if (standaloneComponent === undefined || !isStandaloneComponent(standaloneComponent)) {\n    return;\n  }\n\n  const environmentInjector: EnvironmentInjector | null = context.injector.get(\n    EnvironmentInjector,\n    null,\n    {optional: true},\n  );\n  // Standalone components should have an environment injector. If one cannot be\n  // found we may be in a test case for low level functionality that did not explicitly\n  // setup this injector. In those cases, we simply ignore this event.\n  if (environmentInjector === null) {\n    return;\n  }\n\n  const {standaloneInjectorToComponent} = frameworkDIDebugData;\n\n  // If our injector has already been mapped, as is the case\n  // when a standalone component imports another standalone component,\n  // we consider the original component (the component doing the importing)\n  // as the component connected to our injector.\n  if (standaloneInjectorToComponent.has(environmentInjector)) {\n    return;\n  }\n  // If our injector hasn't been mapped, then we map it to the standalone component\n  standaloneInjectorToComponent.set(environmentInjector, standaloneComponent);\n}\n\nfunction isStandaloneComponent(value: Type<unknown>): boolean {\n  const def = getComponentDef(value);\n  return !!def?.standalone;\n}\n\n/**\n *\n * Stores the emitted ProviderRecords from the InjectorProfilerEventType.ProviderConfigured\n * event in frameworkDIDebugData.resolverToProviders\n *\n * @param context InjectorProfilerContext the injection context that this event occurred in.\n * @param data ProviderRecord an object containing the instance that was just created\n *\n */\nfunction handleProviderConfiguredEvent(\n  context: InjectorProfilerContext,\n  data: ProviderRecord,\n): void {\n  const {resolverToProviders} = frameworkDIDebugData;\n\n  let diResolver: Injector | TNode;\n  if (context?.injector instanceof NodeInjector) {\n    diResolver = getNodeInjectorTNode(context.injector) as TNode;\n  } else {\n    diResolver = context.injector;\n  }\n\n  if (diResolver === null) {\n    throwError('A ProviderConfigured event must be run within an injection context.');\n  }\n\n  if (!resolverToProviders.has(diResolver)) {\n    resolverToProviders.set(diResolver, []);\n  }\n\n  resolverToProviders.get(diResolver)!.push(data);\n}\n\nfunction getDIResolver(injector: Injector | undefined): Injector | LView | null {\n  let diResolver: Injector | LView | null = null;\n\n  if (injector === undefined) {\n    return diResolver;\n  }\n\n  // We use the LView as the diResolver for NodeInjectors because they\n  // do not persist anywhere in the framework. They are simply wrappers around an LView and a TNode\n  // that do persist. Because of this, we rely on the LView of the NodeInjector in order to use\n  // as a concrete key to represent this injector. If we get the same LView back later, we know\n  // we're looking at the same injector.\n  if (injector instanceof NodeInjector) {\n    diResolver = getNodeInjectorLView(injector);\n  }\n  // Other injectors can be used a keys for a map because their instances\n  // persist\n  else {\n    diResolver = injector;\n  }\n\n  return diResolver;\n}\n\n// inspired by\n// https://tc39.es/ecma262/multipage/executable-code-and-execution-contexts.html#sec-canbeheldweakly\nfunction canBeHeldWeakly(value: any): boolean {\n  // we check for value !== null here because typeof null === 'object\n  return (\n    value !== null &&\n    (typeof value === 'object' || typeof value === 'function' || typeof value === 'symbol')\n  );\n}\n"]}
250
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"framework_injector_profiler.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/debug/framework_injector_profiler.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 {Injector} from '../../di/injector';\nimport {EnvironmentInjector} from '../../di/r3_injector';\nimport {Type} from '../../interface/type';\nimport {assertDefined, throwError} from '../../util/assert';\nimport {assertTNode, assertTNodeForLView} from '../assert';\nimport {getComponentDef} from '../definition';\nimport {getNodeInjectorLView, getNodeInjectorTNode, NodeInjector} from '../di';\nimport {TNode} from '../interfaces/node';\nimport {LView} from '../interfaces/view';\n\nimport {\n  InjectedService,\n  InjectorCreatedInstance,\n  InjectorProfilerContext,\n  InjectorProfilerEvent,\n  InjectorProfilerEventType,\n  ProviderRecord,\n  setInjectorProfiler,\n} from './injector_profiler';\n\n/**\n * These are the data structures that our framework injector profiler will fill with data in order\n * to support DI debugging APIs.\n *\n * resolverToTokenToDependencies: Maps an injector to a Map of tokens to an Array of\n * dependencies. Injector -> Token -> Dependencies This is used to support the\n * getDependenciesFromInjectable API, which takes in an injector and a token and returns it's\n * dependencies.\n *\n * resolverToProviders: Maps a DI resolver (an Injector or a TNode) to the providers configured\n * within it This is used to support the getInjectorProviders API, which takes in an injector and\n * returns the providers that it was configured with. Note that for the element injector case we\n * use the TNode instead of the LView as the DI resolver. This is because the registration of\n * providers happens only once per type of TNode. If an injector is created with an identical TNode,\n * the providers for that injector will not be reconfigured.\n *\n * standaloneInjectorToComponent: Maps the injector of a standalone component to the standalone\n * component that it is associated with. Used in the getInjectorProviders API, specificially in the\n * discovery of import paths for each provider. This is necessary because the imports array of a\n * standalone component is processed and configured in its standalone injector, but exists within\n * the component's definition. Because getInjectorProviders takes in an injector, if that injector\n * is the injector of a standalone component, we need to be able to discover the place where the\n * imports array is located (the component) in order to flatten the imports array within it to\n * discover all of it's providers.\n *\n *\n * All of these data structures are instantiated with WeakMaps. This will ensure that the presence\n * of any object in the keys of these maps does not prevent the garbage collector from collecting\n * those objects. Because of this property of WeakMaps, these data structures will never be the\n * source of a memory leak.\n *\n * An example of this advantage: When components are destroyed, we don't need to do\n * any additional work to remove that component from our mappings.\n *\n */\nclass DIDebugData {\n  resolverToTokenToDependencies = new WeakMap<\n    Injector | LView,\n    WeakMap<Type<unknown>, InjectedService[]>\n  >();\n  resolverToProviders = new WeakMap<Injector | TNode, ProviderRecord[]>();\n  standaloneInjectorToComponent = new WeakMap<Injector, Type<unknown>>();\n\n  reset() {\n    this.resolverToTokenToDependencies = new WeakMap<\n      Injector | LView,\n      WeakMap<Type<unknown>, InjectedService[]>\n    >();\n    this.resolverToProviders = new WeakMap<Injector | TNode, ProviderRecord[]>();\n    this.standaloneInjectorToComponent = new WeakMap<Injector, Type<unknown>>();\n  }\n}\n\nlet frameworkDIDebugData = new DIDebugData();\n\nexport function getFrameworkDIDebugData(): DIDebugData {\n  return frameworkDIDebugData;\n}\n\n/**\n * Initalize default handling of injector events. This handling parses events\n * as they are emitted and constructs the data structures necessary to support\n * some of debug APIs.\n *\n * See handleInjectEvent, handleCreateEvent and handleProviderConfiguredEvent\n * for descriptions of each handler\n *\n * Supported APIs:\n *               - getDependenciesFromInjectable\n *               - getInjectorProviders\n */\nexport function setupFrameworkInjectorProfiler(): void {\n  frameworkDIDebugData.reset();\n  setInjectorProfiler((injectorProfilerEvent) =>\n    handleInjectorProfilerEvent(injectorProfilerEvent),\n  );\n}\n\nfunction handleInjectorProfilerEvent(injectorProfilerEvent: InjectorProfilerEvent): void {\n  const {context, type} = injectorProfilerEvent;\n\n  if (type === InjectorProfilerEventType.Inject) {\n    handleInjectEvent(context, injectorProfilerEvent.service);\n  } else if (type === InjectorProfilerEventType.InstanceCreatedByInjector) {\n    handleInstanceCreatedByInjectorEvent(context, injectorProfilerEvent.instance);\n  } else if (type === InjectorProfilerEventType.ProviderConfigured) {\n    handleProviderConfiguredEvent(context, injectorProfilerEvent.providerRecord);\n  }\n}\n\n/**\n *\n * Stores the injected service in frameworkDIDebugData.resolverToTokenToDependencies\n * based on it's injector and token.\n *\n * @param context InjectorProfilerContext the injection context that this event occurred in.\n * @param data InjectedService the service associated with this inject event.\n *\n */\nfunction handleInjectEvent(context: InjectorProfilerContext, data: InjectedService) {\n  const diResolver = getDIResolver(context.injector);\n  if (diResolver === null) {\n    throwError('An Inject event must be run within an injection context.');\n  }\n\n  const diResolverToInstantiatedToken = frameworkDIDebugData.resolverToTokenToDependencies;\n\n  if (!diResolverToInstantiatedToken.has(diResolver)) {\n    diResolverToInstantiatedToken.set(diResolver, new WeakMap<Type<unknown>, InjectedService[]>());\n  }\n\n  // if token is a primitive type, ignore this event. We do this because we cannot keep track of\n  // non-primitive tokens in WeakMaps since they are not garbage collectable.\n  if (!canBeHeldWeakly(context.token)) {\n    return;\n  }\n\n  const instantiatedTokenToDependencies = diResolverToInstantiatedToken.get(diResolver)!;\n  if (!instantiatedTokenToDependencies.has(context.token!)) {\n    instantiatedTokenToDependencies.set(context.token!, []);\n  }\n\n  const {token, value, flags} = data;\n\n  assertDefined(context.token, 'Injector profiler context token is undefined.');\n\n  const dependencies = instantiatedTokenToDependencies.get(context.token);\n  assertDefined(dependencies, 'Could not resolve dependencies for token.');\n\n  if (context.injector instanceof NodeInjector) {\n    dependencies.push({token, value, flags, injectedIn: getNodeInjectorContext(context.injector)});\n  } else {\n    dependencies.push({token, value, flags});\n  }\n}\n\n/**\n *\n * Returns the LView and TNode associated with a NodeInjector. Returns undefined if the injector\n * is not a NodeInjector.\n *\n * @param injector\n * @returns {lView: LView, tNode: TNode}|undefined\n */\nfunction getNodeInjectorContext(injector: Injector): {lView: LView; tNode: TNode} | undefined {\n  if (!(injector instanceof NodeInjector)) {\n    throwError('getNodeInjectorContext must be called with a NodeInjector');\n  }\n\n  const lView = getNodeInjectorLView(injector);\n  const tNode = getNodeInjectorTNode(injector);\n  if (tNode === null) {\n    return;\n  }\n\n  assertTNodeForLView(tNode, lView);\n\n  return {lView, tNode};\n}\n\n/**\n *\n * If the created instance is an instance of a standalone component, maps the injector to that\n * standalone component in frameworkDIDebugData.standaloneInjectorToComponent\n *\n * @param context InjectorProfilerContext the injection context that this event occurred in.\n * @param data InjectorCreatedInstance an object containing the instance that was just created\n *\n */\nfunction handleInstanceCreatedByInjectorEvent(\n  context: InjectorProfilerContext,\n  data: InjectorCreatedInstance,\n): void {\n  const {value} = data;\n\n  if (getDIResolver(context.injector) === null) {\n    throwError('An InjectorCreatedInstance event must be run within an injection context.');\n  }\n\n  // if our value is an instance of a standalone component, map the injector of that standalone\n  // component to the component class. Otherwise, this event is a noop.\n  let standaloneComponent: Type<unknown> | undefined | null = undefined;\n  if (typeof value === 'object') {\n    standaloneComponent = value?.constructor as Type<unknown> | undefined | null;\n  }\n\n  // We want to also cover if `standaloneComponent === null` in addition to `undefined`\n  if (standaloneComponent == undefined || !isStandaloneComponent(standaloneComponent)) {\n    return;\n  }\n\n  const environmentInjector: EnvironmentInjector | null = context.injector.get(\n    EnvironmentInjector,\n    null,\n    {optional: true},\n  );\n  // Standalone components should have an environment injector. If one cannot be\n  // found we may be in a test case for low level functionality that did not explicitly\n  // setup this injector. In those cases, we simply ignore this event.\n  if (environmentInjector === null) {\n    return;\n  }\n\n  const {standaloneInjectorToComponent} = frameworkDIDebugData;\n\n  // If our injector has already been mapped, as is the case\n  // when a standalone component imports another standalone component,\n  // we consider the original component (the component doing the importing)\n  // as the component connected to our injector.\n  if (standaloneInjectorToComponent.has(environmentInjector)) {\n    return;\n  }\n  // If our injector hasn't been mapped, then we map it to the standalone component\n  standaloneInjectorToComponent.set(environmentInjector, standaloneComponent);\n}\n\nfunction isStandaloneComponent(value: Type<unknown>): boolean {\n  const def = getComponentDef(value);\n  return !!def?.standalone;\n}\n\n/**\n *\n * Stores the emitted ProviderRecords from the InjectorProfilerEventType.ProviderConfigured\n * event in frameworkDIDebugData.resolverToProviders\n *\n * @param context InjectorProfilerContext the injection context that this event occurred in.\n * @param data ProviderRecord an object containing the instance that was just created\n *\n */\nfunction handleProviderConfiguredEvent(\n  context: InjectorProfilerContext,\n  data: ProviderRecord,\n): void {\n  const {resolverToProviders} = frameworkDIDebugData;\n\n  let diResolver: Injector | TNode;\n  if (context?.injector instanceof NodeInjector) {\n    diResolver = getNodeInjectorTNode(context.injector) as TNode;\n  } else {\n    diResolver = context.injector;\n  }\n\n  if (diResolver === null) {\n    throwError('A ProviderConfigured event must be run within an injection context.');\n  }\n\n  if (!resolverToProviders.has(diResolver)) {\n    resolverToProviders.set(diResolver, []);\n  }\n\n  resolverToProviders.get(diResolver)!.push(data);\n}\n\nfunction getDIResolver(injector: Injector | undefined): Injector | LView | null {\n  let diResolver: Injector | LView | null = null;\n\n  if (injector === undefined) {\n    return diResolver;\n  }\n\n  // We use the LView as the diResolver for NodeInjectors because they\n  // do not persist anywhere in the framework. They are simply wrappers around an LView and a TNode\n  // that do persist. Because of this, we rely on the LView of the NodeInjector in order to use\n  // as a concrete key to represent this injector. If we get the same LView back later, we know\n  // we're looking at the same injector.\n  if (injector instanceof NodeInjector) {\n    diResolver = getNodeInjectorLView(injector);\n  }\n  // Other injectors can be used a keys for a map because their instances\n  // persist\n  else {\n    diResolver = injector;\n  }\n\n  return diResolver;\n}\n\n// inspired by\n// https://tc39.es/ecma262/multipage/executable-code-and-execution-contexts.html#sec-canbeheldweakly\nfunction canBeHeldWeakly(value: any): boolean {\n  // we check for value !== null here because typeof null === 'object\n  return (\n    value !== null &&\n    (typeof value === 'object' || typeof value === 'function' || typeof value === 'symbol')\n  );\n}\n"]}
@@ -22,5 +22,5 @@ export class Version {
22
22
  /**
23
23
  * @publicApi
24
24
  */
25
- export const VERSION = new Version('18.1.0-rc.0');
25
+ export const VERSION = new Version('18.1.1');
26
26
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUg7Ozs7R0FJRztBQUNILE1BQU0sT0FBTyxPQUFPO0lBS2xCLFlBQW1CLElBQVk7UUFBWixTQUFJLEdBQUosSUFBSSxDQUFRO1FBQzdCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDOUIsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdEIsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdEIsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN4QyxDQUFDO0NBQ0Y7QUFFRDs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxJQUFJLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIFJlcHJlc2VudHMgdGhlIHZlcnNpb24gb2YgQW5ndWxhclxuICpcbiAqIEBwdWJsaWNBcGlcbiAqL1xuZXhwb3J0IGNsYXNzIFZlcnNpb24ge1xuICBwdWJsaWMgcmVhZG9ubHkgbWFqb3I6IHN0cmluZztcbiAgcHVibGljIHJlYWRvbmx5IG1pbm9yOiBzdHJpbmc7XG4gIHB1YmxpYyByZWFkb25seSBwYXRjaDogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBmdWxsOiBzdHJpbmcpIHtcbiAgICBjb25zdCBwYXJ0cyA9IGZ1bGwuc3BsaXQoJy4nKTtcbiAgICB0aGlzLm1ham9yID0gcGFydHNbMF07XG4gICAgdGhpcy5taW5vciA9IHBhcnRzWzFdO1xuICAgIHRoaXMucGF0Y2ggPSBwYXJ0cy5zbGljZSgyKS5qb2luKCcuJyk7XG4gIH1cbn1cblxuLyoqXG4gKiBAcHVibGljQXBpXG4gKi9cbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gbmV3IFZlcnNpb24oJzAuMC4wLVBMQUNFSE9MREVSJyk7XG4iXX0=
@@ -25,10 +25,10 @@ export class Log {
25
25
  result() {
26
26
  return this.logItems.join('; ');
27
27
  }
28
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0-rc.0", ngImport: i0, type: Log, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
29
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.0-rc.0", ngImport: i0, type: Log }); }
28
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: Log, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
29
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: Log }); }
30
30
  }
31
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0-rc.0", ngImport: i0, type: Log, decorators: [{
31
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: Log, decorators: [{
32
32
  type: Injectable
33
33
  }], ctorParameters: () => [] });
34
34
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS90ZXN0aW5nL3NyYy9sb2dnZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFHekMsTUFBTSxPQUFPLEdBQUc7SUFHZDtRQUNFLElBQUksQ0FBQyxRQUFRLEdBQUcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxHQUFHLENBQUMsS0FBUTtRQUNWLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzVCLENBQUM7SUFFRCxFQUFFLENBQUMsS0FBUTtRQUNULE9BQU8sR0FBRyxFQUFFO1lBQ1YsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDNUIsQ0FBQyxDQUFDO0lBQ0osQ0FBQztJQUVELEtBQUs7UUFDSCxJQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBRUQsTUFBTTtRQUNKLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbEMsQ0FBQzt5SEF2QlUsR0FBRzs2SEFBSCxHQUFHOztzR0FBSCxHQUFHO2tCQURmLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHtJbmplY3RhYmxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIExvZzxUID0gc3RyaW5nPiB7XG4gIGxvZ0l0ZW1zOiBUW107XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5sb2dJdGVtcyA9IFtdO1xuICB9XG5cbiAgYWRkKHZhbHVlOiBUKTogdm9pZCB7XG4gICAgdGhpcy5sb2dJdGVtcy5wdXNoKHZhbHVlKTtcbiAgfVxuXG4gIGZuKHZhbHVlOiBUKSB7XG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIHRoaXMubG9nSXRlbXMucHVzaCh2YWx1ZSk7XG4gICAgfTtcbiAgfVxuXG4gIGNsZWFyKCk6IHZvaWQge1xuICAgIHRoaXMubG9nSXRlbXMgPSBbXTtcbiAgfVxuXG4gIHJlc3VsdCgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmxvZ0l0ZW1zLmpvaW4oJzsgJyk7XG4gIH1cbn1cbiJdfQ==
@@ -1 +1 @@
1
- (()=>{function u(i,n,t,e,r,o,s,a){return{eventType:i,event:n,targetElement:t,eic:e,timeStamp:r,eia:o,eirp:s,eiack:a}}var c=class{constructor(n=window,t=window.document.documentElement){this.replaySink=n,this.container=t,n._ejsa={c:t,q:[],et:[],etc:[],h:e=>{let r=u(e.type,e,e.target,t,Date.now());n._ejsa.q.push(r)}}}addEvents(n,t){let e=this.replaySink._ejsa;for(let r=0;r<n.length;r++){let o=n[r];(t?e.etc:e.et).push(o),this.container.addEventListener(o,e.h,t)}}};function p(i,n,t,e,r,o=window){o[i]||(o[i]={}),o[i][t]={};let s=new c(o[i][t],n);e&&s.addEvents(e),r&&s.addEvents(r,!0)}window.__jsaction_bootstrap=p;})();
1
+ (()=>{function c(t,n,r,o,e,i,a,f){return{eventType:t,event:n,targetElement:r,eic:o,timeStamp:e,eia:i,eirp:a,eiack:f}}function p(t){let n=[],r=e=>{n.push(e)};return{c:t,q:n,et:[],etc:[],d:r,h:e=>{r(c(e.type,e,e.target,t,Date.now()))}}}function s(t,n,r){for(let o=0;o<n.length;o++){let e=n[o];(r?t.etc:t.et).push(e),t.c.addEventListener(e,t.h,r)}}function u(t,n,r,o,e=window){let i=p(t);e._ejsas||(e._ejsas={}),e._ejsas[n]=i,s(i,r),s(i,o,!0)}window.__jsaction_bootstrap=u;})();
package/fesm2022/core.mjs CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v18.1.0-rc.0
2
+ * @license Angular v18.1.1
3
3
  * (c) 2010-2024 Google LLC. https://angular.io/
4
4
  * License: MIT
5
5
  */
@@ -7,7 +7,7 @@
7
7
  import { SIGNAL_NODE as SIGNAL_NODE$1, signalSetFn as signalSetFn$1, producerAccessed as producerAccessed$1, SIGNAL as SIGNAL$1, getActiveConsumer as getActiveConsumer$1, setActiveConsumer as setActiveConsumer$1, consumerDestroy as consumerDestroy$1, REACTIVE_NODE as REACTIVE_NODE$1, consumerBeforeComputation as consumerBeforeComputation$1, consumerAfterComputation as consumerAfterComputation$1, consumerPollProducersForChange as consumerPollProducersForChange$1, createSignal as createSignal$1, signalUpdateFn as signalUpdateFn$1, createComputed as createComputed$1, setThrowInvalidWriteToSignalError as setThrowInvalidWriteToSignalError$1, createWatch as createWatch$1 } from '@angular/core/primitives/signals';
8
8
  import { BehaviorSubject, Subject, Subscription } from 'rxjs';
9
9
  import { map, first } from 'rxjs/operators';
10
- import { Attribute as Attribute$1, isSupportedEvent, registerEventType, unregisterEventType, EventContract, EventContractContainer, EventDispatcher, registerDispatcher, isCaptureEvent } from '@angular/core/primitives/event-dispatch';
10
+ import { Attribute as Attribute$1, isEarlyEventType, getActionCache, EventContract, EventContractContainer, EventDispatcher, registerDispatcher, isCaptureEventType } from '@angular/core/primitives/event-dispatch';
11
11
 
12
12
  /**
13
13
  * Base URL for the error details page.
@@ -16381,19 +16381,24 @@ function afterRenderImpl(callbackOrSpec, injector, once, phase) {
16381
16381
  unregisterFn();
16382
16382
  };
16383
16383
  const unregisterFn = injector.get(DestroyRef).onDestroy(destroy);
16384
+ let callbacksLeftToRun = 0;
16384
16385
  const registerCallback = (phase, phaseCallback) => {
16385
16386
  if (!phaseCallback) {
16386
16387
  return;
16387
16388
  }
16388
16389
  const callback = once
16389
16390
  ? (...args) => {
16390
- destroy();
16391
+ callbacksLeftToRun--;
16392
+ if (callbacksLeftToRun < 1) {
16393
+ destroy();
16394
+ }
16391
16395
  phaseCallback(...args);
16392
16396
  }
16393
16397
  : phaseCallback;
16394
16398
  const instance = runInInjectionContext(injector, () => new AfterRenderCallback(phase, pipelinedArgs, callback));
16395
16399
  callbackHandler.register(instance);
16396
16400
  instances.push(instance);
16401
+ callbacksLeftToRun++;
16397
16402
  };
16398
16403
  registerCallback(AfterRenderPhase.EarlyRead, spec.earlyRead);
16399
16404
  registerCallback(AfterRenderPhase.Write, spec.write);
@@ -17200,7 +17205,7 @@ function createRootComponent(componentView, rootComponentDef, rootDirectives, ho
17200
17205
  function setRootNodeAttributes(hostRenderer, componentDef, hostRNode, rootSelectorOrNode) {
17201
17206
  if (rootSelectorOrNode) {
17202
17207
  // The placeholder will be replaced with the actual version at build time.
17203
- setUpAttributes(hostRenderer, hostRNode, ['ng-version', '18.1.0-rc.0']);
17208
+ setUpAttributes(hostRenderer, hostRNode, ['ng-version', '18.1.1']);
17204
17209
  }
17205
17210
  else {
17206
17211
  // If host element is created as a part of this function call (i.e. `rootSelectorOrNode`
@@ -20775,17 +20780,55 @@ function renderDeferBlockState(newState, tNode, lContainer, skipTimerScheduling
20775
20780
  }
20776
20781
  }
20777
20782
  /**
20778
- * Creates an instance of the `OutletInjector` using a private factory
20779
- * function available on the `OutletInjector` class.
20780
- *
20781
- * @param parentOutletInjector Parent OutletInjector, which should be used
20782
- * to produce a new instance.
20783
- * @param parentInjector An Injector, which should be used as a parent one
20784
- * for a newly created `OutletInjector` instance.
20783
+ * Checks whether there is a cached injector associated with a given defer block
20784
+ * declaration and returns if it exists. If there is no cached injector present -
20785
+ * creates a new injector and stores in the cache.
20786
+ */
20787
+ function getOrCreateEnvironmentInjector(parentInjector, tDetails, providers) {
20788
+ return parentInjector
20789
+ .get(CachedInjectorService)
20790
+ .getOrCreateInjector(tDetails, parentInjector, providers, ngDevMode ? 'DeferBlock Injector' : '');
20791
+ }
20792
+ /**
20793
+ * Creates a new injector, which contains providers collected from dependencies (NgModules) of
20794
+ * defer-loaded components. This function detects different types of parent injectors and creates
20795
+ * a new injector based on that.
20785
20796
  */
20786
- function createRouterOutletInjector(parentOutletInjector, parentInjector) {
20787
- const outletInjector = parentOutletInjector.injector;
20788
- return outletInjector.__ngOutletInjector(parentInjector);
20797
+ function createDeferBlockInjector(parentInjector, tDetails, providers) {
20798
+ // Check if the parent injector is an instance of a `ChainedInjector`.
20799
+ //
20800
+ // In this case, we retain the shape of the injector and use a newly created
20801
+ // `EnvironmentInjector` as a parent in the `ChainedInjector`. That is needed to
20802
+ // make sure that the primary injector gets consulted first (since it's typically
20803
+ // a NodeInjector) and `EnvironmentInjector` tree is consulted after that.
20804
+ if (parentInjector instanceof ChainedInjector) {
20805
+ const origInjector = parentInjector.injector;
20806
+ // Guaranteed to be an environment injector
20807
+ const parentEnvInjector = parentInjector.parentInjector;
20808
+ const envInjector = getOrCreateEnvironmentInjector(parentEnvInjector, tDetails, providers);
20809
+ return new ChainedInjector(origInjector, envInjector);
20810
+ }
20811
+ const parentEnvInjector = parentInjector.get(EnvironmentInjector);
20812
+ // If the `parentInjector` is *not* an `EnvironmentInjector` - we need to create
20813
+ // a new `ChainedInjector` with the following setup:
20814
+ //
20815
+ // - the provided `parentInjector` becomes a primary injector
20816
+ // - an existing (real) `EnvironmentInjector` becomes a parent injector for
20817
+ // a newly-created one, which contains extra providers
20818
+ //
20819
+ // So the final order in which injectors would be consulted in this case would look like this:
20820
+ //
20821
+ // 1. Provided `parentInjector`
20822
+ // 2. Newly-created `EnvironmentInjector` with extra providers
20823
+ // 3. `EnvironmentInjector` from the `parentInjector`
20824
+ if (parentEnvInjector !== parentInjector) {
20825
+ const envInjector = getOrCreateEnvironmentInjector(parentEnvInjector, tDetails, providers);
20826
+ return new ChainedInjector(parentInjector, envInjector);
20827
+ }
20828
+ // The `parentInjector` is an instance of an `EnvironmentInjector`.
20829
+ // No need for special handling, we can use `parentInjector` as a
20830
+ // parent injector directly.
20831
+ return getOrCreateEnvironmentInjector(parentInjector, tDetails, providers);
20789
20832
  }
20790
20833
  /**
20791
20834
  * Applies changes to the DOM to reflect a given state.
@@ -20807,32 +20850,12 @@ function applyDeferBlockState(newState, lDetails, lContainer, tNode, hostLView)
20807
20850
  // newly loaded standalone components used within the block, which may
20808
20851
  // import NgModules with providers. In order to make those providers
20809
20852
  // available for components declared in that NgModule, we create an instance
20810
- // of environment injector to host those providers and pass this injector
20853
+ // of an environment injector to host those providers and pass this injector
20811
20854
  // to the logic that creates a view.
20812
20855
  const tDetails = getTDeferBlockDetails(hostTView, tNode);
20813
20856
  const providers = tDetails.providers;
20814
20857
  if (providers && providers.length > 0) {
20815
- const parentInjector = hostLView[INJECTOR];
20816
- // Note: we have a special case for Router's `OutletInjector`,
20817
- // since it's not an instance of the `EnvironmentInjector`, so
20818
- // we can't inject it. Once the `OutletInjector` is replaced
20819
- // with the `EnvironmentInjector` in Router's code, this special
20820
- // handling can be removed.
20821
- const isParentOutletInjector = isRouterOutletInjector(parentInjector);
20822
- const parentEnvInjector = isParentOutletInjector
20823
- ? parentInjector
20824
- : parentInjector.get(EnvironmentInjector);
20825
- injector = parentEnvInjector
20826
- .get(CachedInjectorService)
20827
- .getOrCreateInjector(tDetails, parentEnvInjector, providers, ngDevMode ? 'DeferBlock Injector' : '');
20828
- // Note: this is a continuation of the special case for Router's `OutletInjector`.
20829
- // Since the `OutletInjector` handles `ActivatedRoute` and `ChildrenOutletContexts`
20830
- // dynamically (i.e. their values are not really stored statically in an injector),
20831
- // we need to "wrap" a defer injector into another `OutletInjector`, so we retain
20832
- // the dynamic resolution of the mentioned tokens.
20833
- if (isParentOutletInjector) {
20834
- injector = createRouterOutletInjector(parentInjector, injector);
20835
- }
20858
+ injector = createDeferBlockInjector(hostLView[INJECTOR], tDetails, providers);
20836
20859
  }
20837
20860
  }
20838
20861
  const dehydratedView = findMatchingDehydratedView(lContainer, activeBlockTNode.tView.ssrId);
@@ -30980,7 +31003,7 @@ class Version {
30980
31003
  /**
30981
31004
  * @publicApi
30982
31005
  */
30983
- const VERSION = new Version('18.1.0-rc.0');
31006
+ const VERSION = new Version('18.1.1');
30984
31007
 
30985
31008
  /*
30986
31009
  * This file exists to support compilation of @angular/core in Ivy mode.
@@ -31177,7 +31200,8 @@ function handleInstanceCreatedByInjectorEvent(context, data) {
31177
31200
  if (typeof value === 'object') {
31178
31201
  standaloneComponent = value?.constructor;
31179
31202
  }
31180
- if (standaloneComponent === undefined || !isStandaloneComponent(standaloneComponent)) {
31203
+ // We want to also cover if `standaloneComponent === null` in addition to `undefined`
31204
+ if (standaloneComponent == undefined || !isStandaloneComponent(standaloneComponent)) {
31181
31205
  return;
31182
31206
  }
31183
31207
  const environmentInjector = context.injector.get(EnvironmentInjector, null, { optional: true });
@@ -36795,16 +36819,16 @@ class GlobalEventDelegation {
36795
36819
  ngOnDestroy() {
36796
36820
  this.eventContractDetails.instance?.cleanUp();
36797
36821
  }
36798
- supports(eventName) {
36799
- return isSupportedEvent(eventName);
36822
+ supports(eventType) {
36823
+ return isEarlyEventType(eventType);
36800
36824
  }
36801
- addEventListener(element, eventName, handler) {
36802
- this.eventContractDetails.instance.addEvent(eventName);
36803
- registerEventType(element, eventName, '');
36804
- return () => this.removeEventListener(element, eventName, handler);
36825
+ addEventListener(element, eventType, handler) {
36826
+ this.eventContractDetails.instance.addEvent(eventType);
36827
+ getActionCache(element)[eventType] = '';
36828
+ return () => this.removeEventListener(element, eventType, handler);
36805
36829
  }
36806
- removeEventListener(element, eventName, callback) {
36807
- unregisterEventType(element, eventName);
36830
+ removeEventListener(element, eventType, callback) {
36831
+ getActionCache(element)[eventType] = undefined;
36808
36832
  }
36809
36833
  static { this.ɵfac = function GlobalEventDelegation_Factory(t) { return new (t || GlobalEventDelegation)(); }; }
36810
36834
  static { this.ɵprov = /*@__PURE__*/ ɵɵdefineInjectable({ token: GlobalEventDelegation, factory: GlobalEventDelegation.ɵfac }); }
@@ -36822,7 +36846,6 @@ const initGlobalEventDelegation = (eventContractDetails, injector) => {
36822
36846
  registerDispatcher(eventContract, dispatcher);
36823
36847
  };
36824
36848
 
36825
- const CONTRACT_PROPERTY = 'ngContracts';
36826
36849
  /**
36827
36850
  * A set of DOM elements with `jsaction` attributes.
36828
36851
  */
@@ -36852,7 +36875,7 @@ function withEventReplay() {
36852
36875
  // is enabled, but there are no events configured in this application, in which case
36853
36876
  // we don't activate this feature, since there are no events to replay.
36854
36877
  const appId = inject(APP_ID);
36855
- isEnabled = !!globalThis[CONTRACT_PROPERTY]?.[appId];
36878
+ isEnabled = !!window._ejsas?.[appId];
36856
36879
  }
36857
36880
  if (isEnabled) {
36858
36881
  performanceMarkFeature('NgEventReplay');
@@ -36902,15 +36925,10 @@ function withEventReplay() {
36902
36925
  },
36903
36926
  ];
36904
36927
  }
36905
- // TODO: Upstream this back into event-dispatch.
36906
- function getJsactionData(container) {
36907
- return container._ejsa;
36908
- }
36909
36928
  const initEventReplay = (eventDelegation, injector) => {
36910
36929
  const appId = injector.get(APP_ID);
36911
36930
  // This is set in packages/platform-server/src/utils.ts
36912
- const container = globalThis[CONTRACT_PROPERTY]?.[appId];
36913
- const earlyJsactionData = getJsactionData(container);
36931
+ const earlyJsactionData = window._ejsas[appId];
36914
36932
  const eventContract = (eventDelegation.instance = new EventContract(new EventContractContainer(earlyJsactionData.c),
36915
36933
  /* useActionResolver= */ false));
36916
36934
  for (const et of earlyJsactionData.et) {
@@ -36919,7 +36937,8 @@ const initEventReplay = (eventDelegation, injector) => {
36919
36937
  for (const et of earlyJsactionData.etc) {
36920
36938
  eventContract.addEvent(et);
36921
36939
  }
36922
- eventContract.replayEarlyEvents(container);
36940
+ eventContract.replayEarlyEvents(earlyJsactionData);
36941
+ window._ejsas[appId] = undefined;
36923
36942
  const dispatcher = new EventDispatcher(invokeRegisteredListeners);
36924
36943
  registerDispatcher(eventContract, dispatcher);
36925
36944
  };
@@ -36928,11 +36947,11 @@ const initEventReplay = (eventDelegation, injector) => {
36928
36947
  * LView. Maps collected events to a corresponding DOM element (an element is used as a key).
36929
36948
  */
36930
36949
  function collectDomEventsInfo(tView, lView, eventTypesToReplay) {
36931
- const events = new Map();
36950
+ const domEventsInfo = new Map();
36932
36951
  const lCleanup = lView[CLEANUP];
36933
36952
  const tCleanup = tView.cleanup;
36934
36953
  if (!tCleanup || !lCleanup) {
36935
- return events;
36954
+ return domEventsInfo;
36936
36955
  }
36937
36956
  for (let i = 0; i < tCleanup.length;) {
36938
36957
  const firstParam = tCleanup[i++];
@@ -36940,15 +36959,15 @@ function collectDomEventsInfo(tView, lView, eventTypesToReplay) {
36940
36959
  if (typeof firstParam !== 'string') {
36941
36960
  continue;
36942
36961
  }
36943
- const name = firstParam;
36944
- if (!isSupportedEvent(name)) {
36962
+ const eventType = firstParam;
36963
+ if (!isEarlyEventType(eventType)) {
36945
36964
  continue;
36946
36965
  }
36947
- if (isCaptureEvent(name)) {
36948
- eventTypesToReplay.capture.add(name);
36966
+ if (isCaptureEventType(eventType)) {
36967
+ eventTypesToReplay.capture.add(eventType);
36949
36968
  }
36950
36969
  else {
36951
- eventTypesToReplay.regular.add(name);
36970
+ eventTypesToReplay.regular.add(eventType);
36952
36971
  }
36953
36972
  const listenerElement = unwrapRNode(lView[secondParam]);
36954
36973
  i++; // move the cursor to the next position (location of the listener idx)
@@ -36960,14 +36979,14 @@ function collectDomEventsInfo(tView, lView, eventTypesToReplay) {
36960
36979
  if (!isDomEvent) {
36961
36980
  continue;
36962
36981
  }
36963
- if (!events.has(listenerElement)) {
36964
- events.set(listenerElement, [name]);
36982
+ if (!domEventsInfo.has(listenerElement)) {
36983
+ domEventsInfo.set(listenerElement, [eventType]);
36965
36984
  }
36966
36985
  else {
36967
- events.get(listenerElement).push(name);
36986
+ domEventsInfo.get(listenerElement).push(eventType);
36968
36987
  }
36969
36988
  }
36970
- return events;
36989
+ return domEventsInfo;
36971
36990
  }
36972
36991
 
36973
36992
  /**