@angular/animations 17.0.4 → 17.1.0-next.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 (38) hide show
  1. package/browser/index.d.ts +1 -1
  2. package/browser/testing/index.d.ts +1 -1
  3. package/esm2022/browser/src/create_engine.mjs +1 -1
  4. package/esm2022/browser/src/dsl/animation.mjs +1 -1
  5. package/esm2022/browser/src/dsl/animation_ast_builder.mjs +18 -18
  6. package/esm2022/browser/src/dsl/animation_timeline_builder.mjs +5 -5
  7. package/esm2022/browser/src/dsl/animation_transition_expr.mjs +1 -1
  8. package/esm2022/browser/src/dsl/animation_transition_factory.mjs +1 -1
  9. package/esm2022/browser/src/dsl/animation_trigger.mjs +11 -3
  10. package/esm2022/browser/src/dsl/element_instruction_map.mjs +1 -1
  11. package/esm2022/browser/src/dsl/style_normalization/web_animations_style_normalizer.mjs +1 -1
  12. package/esm2022/browser/src/render/animation_driver.mjs +3 -3
  13. package/esm2022/browser/src/render/animation_engine_next.mjs +1 -1
  14. package/esm2022/browser/src/render/animation_renderer.mjs +1 -1
  15. package/esm2022/browser/src/render/renderer.mjs +1 -1
  16. package/esm2022/browser/src/render/shared.mjs +1 -1
  17. package/esm2022/browser/src/render/special_cased_styles.mjs +1 -1
  18. package/esm2022/browser/src/render/timeline_animation_engine.mjs +1 -1
  19. package/esm2022/browser/src/render/transition_animation_engine.mjs +1 -1
  20. package/esm2022/browser/src/render/web_animations/web_animations_driver.mjs +1 -1
  21. package/esm2022/browser/src/render/web_animations/web_animations_player.mjs +1 -1
  22. package/esm2022/browser/src/util.mjs +15 -15
  23. package/esm2022/browser/src/warning_helpers.mjs +1 -1
  24. package/esm2022/browser/testing/src/mock_animation_driver.mjs +1 -1
  25. package/esm2022/src/animation_builder.mjs +7 -7
  26. package/esm2022/src/animation_metadata.mjs +90 -14
  27. package/esm2022/src/animations.mjs +2 -2
  28. package/esm2022/src/players/animation_group_player.mjs +1 -1
  29. package/esm2022/src/players/animation_player.mjs +1 -1
  30. package/esm2022/src/version.mjs +1 -1
  31. package/fesm2022/animations.mjs +97 -21
  32. package/fesm2022/animations.mjs.map +1 -1
  33. package/fesm2022/browser/testing.mjs +1 -1
  34. package/fesm2022/browser/testing.mjs.map +1 -1
  35. package/fesm2022/browser.mjs +39 -39
  36. package/fesm2022/browser.mjs.map +1 -1
  37. package/index.d.ts +2 -2
  38. package/package.json +2 -2
@@ -102,4 +102,4 @@ export class NoopAnimationPlayer {
102
102
  methods.length = 0;
103
103
  }
104
104
  }
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animation_player.js","sourceRoot":"","sources":["../../../../../../../packages/animations/src/players/animation_player.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\n/**\n * Provides programmatic control of a reusable animation sequence,\n * built using the <code>[AnimationBuilder.build](api/animations/AnimationBuilder#build)()</code>\n * method which returns an `AnimationFactory`, whose\n * <code>[create](api/animations/AnimationFactory#create)()</code> method instantiates and\n * initializes this interface.\n *\n * @see {@link AnimationBuilder}\n * @see {@link AnimationFactory}\n * @see {@link animate}\n *\n * @publicApi\n */\nexport interface AnimationPlayer {\n  /**\n   * Provides a callback to invoke when the animation finishes.\n   * @param fn The callback function.\n   * @see {@link #finish}\n   */\n  onDone(fn: () => void): void;\n  /**\n   * Provides a callback to invoke when the animation starts.\n   * @param fn The callback function.\n   * @see {@link #play}\n   */\n  onStart(fn: () => void): void;\n  /**\n   * Provides a callback to invoke after the animation is destroyed.\n   * @param fn The callback function.\n   * @see {@link #destroy}\n   * @see {@link #beforeDestroy}\n   */\n  onDestroy(fn: () => void): void;\n  /**\n   * Initializes the animation.\n   */\n  init(): void;\n  /**\n   * Reports whether the animation has started.\n   * @returns True if the animation has started, false otherwise.\n   */\n  hasStarted(): boolean;\n  /**\n   * Runs the animation, invoking the `onStart()` callback.\n   */\n  play(): void;\n  /**\n   * Pauses the animation.\n   */\n  pause(): void;\n  /**\n   * Restarts the paused animation.\n   */\n  restart(): void;\n  /**\n   * Ends the animation, invoking the `onDone()` callback.\n   */\n  finish(): void;\n  /**\n   * Destroys the animation, after invoking the `beforeDestroy()` callback.\n   * Calls the `onDestroy()` callback when destruction is completed.\n   */\n  destroy(): void;\n  /**\n   * Resets the animation to its initial state.\n   */\n  reset(): void;\n  /**\n   * Sets the position of the animation.\n   * @param position A 0-based offset into the duration, in milliseconds.\n   */\n  setPosition(position: number): void;\n  /**\n   * Reports the current position of the animation.\n   * @returns A 0-based offset into the duration, in milliseconds.\n   */\n  getPosition(): number;\n  /**\n   * The parent of this player, if any.\n   */\n  parentPlayer: AnimationPlayer|null;\n  /**\n   * The total run time of the animation, in milliseconds.\n   */\n  readonly totalTime: number;\n  /**\n   * Provides a callback to invoke before the animation is destroyed.\n   */\n  beforeDestroy?: () => any;\n  /**\n   * @internal\n   * Internal\n   */\n  triggerCallback?: (phaseName: string) => void;\n  /**\n   * @internal\n   * Internal\n   */\n  disabled?: boolean;\n}\n\n/**\n * An empty programmatic controller for reusable animations.\n * Used internally when animations are disabled, to avoid\n * checking for the null case when an animation player is expected.\n *\n * @see {@link animate}\n * @see {@link AnimationPlayer}\n * @see {@link ɵAnimationGroupPlayer AnimationGroupPlayer}\n *\n * @publicApi\n */\nexport class NoopAnimationPlayer implements AnimationPlayer {\n  private _onDoneFns: Function[] = [];\n  private _onStartFns: Function[] = [];\n  private _onDestroyFns: Function[] = [];\n  private _originalOnDoneFns: Function[] = [];\n  private _originalOnStartFns: Function[] = [];\n  private _started = false;\n  private _destroyed = false;\n  private _finished = false;\n  private _position = 0;\n  public parentPlayer: AnimationPlayer|null = null;\n  public readonly totalTime: number;\n  constructor(duration: number = 0, delay: number = 0) {\n    this.totalTime = duration + delay;\n  }\n  private _onFinish() {\n    if (!this._finished) {\n      this._finished = true;\n      this._onDoneFns.forEach(fn => fn());\n      this._onDoneFns = [];\n    }\n  }\n  onStart(fn: () => void): void {\n    this._originalOnStartFns.push(fn);\n    this._onStartFns.push(fn);\n  }\n  onDone(fn: () => void): void {\n    this._originalOnDoneFns.push(fn);\n    this._onDoneFns.push(fn);\n  }\n  onDestroy(fn: () => void): void {\n    this._onDestroyFns.push(fn);\n  }\n  hasStarted(): boolean {\n    return this._started;\n  }\n  init(): void {}\n  play(): void {\n    if (!this.hasStarted()) {\n      this._onStart();\n      this.triggerMicrotask();\n    }\n    this._started = true;\n  }\n\n  /** @internal */\n  triggerMicrotask() {\n    queueMicrotask(() => this._onFinish());\n  }\n\n  private _onStart() {\n    this._onStartFns.forEach(fn => fn());\n    this._onStartFns = [];\n  }\n\n  pause(): void {}\n  restart(): void {}\n  finish(): void {\n    this._onFinish();\n  }\n  destroy(): void {\n    if (!this._destroyed) {\n      this._destroyed = true;\n      if (!this.hasStarted()) {\n        this._onStart();\n      }\n      this.finish();\n      this._onDestroyFns.forEach(fn => fn());\n      this._onDestroyFns = [];\n    }\n  }\n  reset(): void {\n    this._started = false;\n    this._finished = false;\n    this._onStartFns = this._originalOnStartFns;\n    this._onDoneFns = this._originalOnDoneFns;\n  }\n  setPosition(position: number): void {\n    this._position = this.totalTime ? position * this.totalTime : 1;\n  }\n  getPosition(): number {\n    return this.totalTime ? this._position / this.totalTime : 1;\n  }\n\n  /** @internal */\n  triggerCallback(phaseName: string): void {\n    const methods = phaseName == 'start' ? this._onStartFns : this._onDoneFns;\n    methods.forEach(fn => fn());\n    methods.length = 0;\n  }\n}\n"]}
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animation_player.js","sourceRoot":"","sources":["../../../../../../../packages/animations/src/players/animation_player.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\n/**\n * Provides programmatic control of a reusable animation sequence,\n * built using the <code>[AnimationBuilder.build](api/animations/AnimationBuilder#build)()</code>\n * method which returns an `AnimationFactory`, whose\n * <code>[create](api/animations/AnimationFactory#create)()</code> method instantiates and\n * initializes this interface.\n *\n * @see {@link AnimationBuilder}\n * @see {@link AnimationFactory}\n * @see {@link animate}\n *\n * @publicApi\n */\nexport interface AnimationPlayer {\n  /**\n   * Provides a callback to invoke when the animation finishes.\n   * @param fn The callback function.\n   * @see {@link #finish}\n   */\n  onDone(fn: () => void): void;\n  /**\n   * Provides a callback to invoke when the animation starts.\n   * @param fn The callback function.\n   * @see {@link #play}\n   */\n  onStart(fn: () => void): void;\n  /**\n   * Provides a callback to invoke after the animation is destroyed.\n   * @param fn The callback function.\n   * @see {@link #destroy}\n   * @see {@link #beforeDestroy}\n   */\n  onDestroy(fn: () => void): void;\n  /**\n   * Initializes the animation.\n   */\n  init(): void;\n  /**\n   * Reports whether the animation has started.\n   * @returns True if the animation has started, false otherwise.\n   */\n  hasStarted(): boolean;\n  /**\n   * Runs the animation, invoking the `onStart()` callback.\n   */\n  play(): void;\n  /**\n   * Pauses the animation.\n   */\n  pause(): void;\n  /**\n   * Restarts the paused animation.\n   */\n  restart(): void;\n  /**\n   * Ends the animation, invoking the `onDone()` callback.\n   */\n  finish(): void;\n  /**\n   * Destroys the animation, after invoking the `beforeDestroy()` callback.\n   * Calls the `onDestroy()` callback when destruction is completed.\n   */\n  destroy(): void;\n  /**\n   * Resets the animation to its initial state.\n   */\n  reset(): void;\n  /**\n   * Sets the position of the animation.\n   * @param position A 0-based offset into the duration, in milliseconds.\n   */\n  setPosition(position: number): void;\n  /**\n   * Reports the current position of the animation.\n   * @returns A 0-based offset into the duration, in milliseconds.\n   */\n  getPosition(): number;\n  /**\n   * The parent of this player, if any.\n   */\n  parentPlayer: AnimationPlayer|null;\n  /**\n   * The total run time of the animation, in milliseconds.\n   */\n  readonly totalTime: number;\n  /**\n   * Provides a callback to invoke before the animation is destroyed.\n   */\n  beforeDestroy?: () => any;\n  /**\n   * @internal\n   * Internal\n   */\n  triggerCallback?: (phaseName: string) => void;\n  /**\n   * @internal\n   * Internal\n   */\n  disabled?: boolean;\n}\n\n/**\n * An empty programmatic controller for reusable animations.\n * Used internally when animations are disabled, to avoid\n * checking for the null case when an animation player is expected.\n *\n * @see {@link animate}\n * @see {@link AnimationPlayer}\n * @see {@link ɵAnimationGroupPlayer AnimationGroupPlayer}\n *\n * @publicApi\n */\nexport class NoopAnimationPlayer implements AnimationPlayer {\n  private _onDoneFns: Function[] = [];\n  private _onStartFns: Function[] = [];\n  private _onDestroyFns: Function[] = [];\n  private _originalOnDoneFns: Function[] = [];\n  private _originalOnStartFns: Function[] = [];\n  private _started = false;\n  private _destroyed = false;\n  private _finished = false;\n  private _position = 0;\n  public parentPlayer: AnimationPlayer|null = null;\n  public readonly totalTime: number;\n  constructor(duration: number = 0, delay: number = 0) {\n    this.totalTime = duration + delay;\n  }\n  private _onFinish() {\n    if (!this._finished) {\n      this._finished = true;\n      this._onDoneFns.forEach(fn => fn());\n      this._onDoneFns = [];\n    }\n  }\n  onStart(fn: () => void): void {\n    this._originalOnStartFns.push(fn);\n    this._onStartFns.push(fn);\n  }\n  onDone(fn: () => void): void {\n    this._originalOnDoneFns.push(fn);\n    this._onDoneFns.push(fn);\n  }\n  onDestroy(fn: () => void): void {\n    this._onDestroyFns.push(fn);\n  }\n  hasStarted(): boolean {\n    return this._started;\n  }\n  init(): void {}\n  play(): void {\n    if (!this.hasStarted()) {\n      this._onStart();\n      this.triggerMicrotask();\n    }\n    this._started = true;\n  }\n\n  /** @internal */\n  triggerMicrotask() {\n    queueMicrotask(() => this._onFinish());\n  }\n\n  private _onStart() {\n    this._onStartFns.forEach(fn => fn());\n    this._onStartFns = [];\n  }\n\n  pause(): void {}\n  restart(): void {}\n  finish(): void {\n    this._onFinish();\n  }\n  destroy(): void {\n    if (!this._destroyed) {\n      this._destroyed = true;\n      if (!this.hasStarted()) {\n        this._onStart();\n      }\n      this.finish();\n      this._onDestroyFns.forEach(fn => fn());\n      this._onDestroyFns = [];\n    }\n  }\n  reset(): void {\n    this._started = false;\n    this._finished = false;\n    this._onStartFns = this._originalOnStartFns;\n    this._onDoneFns = this._originalOnDoneFns;\n  }\n  setPosition(position: number): void {\n    this._position = this.totalTime ? position * this.totalTime : 1;\n  }\n  getPosition(): number {\n    return this.totalTime ? this._position / this.totalTime : 1;\n  }\n\n  /** @internal */\n  triggerCallback(phaseName: string): void {\n    const methods = phaseName == 'start' ? this._onStartFns : this._onDoneFns;\n    methods.forEach(fn => fn());\n    methods.length = 0;\n  }\n}\n"]}
@@ -11,5 +11,5 @@
11
11
  * Entry point for all public APIs of the animation package.
12
12
  */
13
13
  import { Version } from '@angular/core';
14
- export const VERSION = new Version('17.0.4');
14
+ export const VERSION = new Version('17.1.0-next.1');
15
15
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuaW1hdGlvbnMvc3JjL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUg7Ozs7R0FJRztBQUNILE9BQU8sRUFBQyxPQUFPLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFdEMsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLElBQUksT0FBTyxDQUFDLG1CQUFtQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuLyoqXG4gKiBAbW9kdWxlXG4gKiBAZGVzY3JpcHRpb25cbiAqIEVudHJ5IHBvaW50IGZvciBhbGwgcHVibGljIEFQSXMgb2YgdGhlIGFuaW1hdGlvbiBwYWNrYWdlLlxuICovXG5pbXBvcnQge1ZlcnNpb259IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IG5ldyBWZXJzaW9uKCcwLjAuMC1QTEFDRUhPTERFUicpO1xuIl19
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v17.0.4
2
+ * @license Angular v17.1.0-next.1
3
3
  * (c) 2010-2022 Google LLC. https://angular.io/
4
4
  * License: MIT
5
5
  */
@@ -8,6 +8,82 @@ import { DOCUMENT } from '@angular/common';
8
8
  import * as i0 from '@angular/core';
9
9
  import { inject, Injectable, ANIMATION_MODULE_TYPE, ViewEncapsulation, ɵRuntimeError, Inject } from '@angular/core';
10
10
 
11
+ /**
12
+ * @description Constants for the categories of parameters that can be defined for animations.
13
+ *
14
+ * A corresponding function defines a set of parameters for each category, and
15
+ * collects them into a corresponding `AnimationMetadata` object.
16
+ *
17
+ * @publicApi
18
+ */
19
+ var AnimationMetadataType;
20
+ (function (AnimationMetadataType) {
21
+ /**
22
+ * Associates a named animation state with a set of CSS styles.
23
+ * See [`state()`](api/animations/state)
24
+ */
25
+ AnimationMetadataType[AnimationMetadataType["State"] = 0] = "State";
26
+ /**
27
+ * Data for a transition from one animation state to another.
28
+ * See `transition()`
29
+ */
30
+ AnimationMetadataType[AnimationMetadataType["Transition"] = 1] = "Transition";
31
+ /**
32
+ * Contains a set of animation steps.
33
+ * See `sequence()`
34
+ */
35
+ AnimationMetadataType[AnimationMetadataType["Sequence"] = 2] = "Sequence";
36
+ /**
37
+ * Contains a set of animation steps.
38
+ * See `{@link animations/group group()}`
39
+ */
40
+ AnimationMetadataType[AnimationMetadataType["Group"] = 3] = "Group";
41
+ /**
42
+ * Contains an animation step.
43
+ * See `animate()`
44
+ */
45
+ AnimationMetadataType[AnimationMetadataType["Animate"] = 4] = "Animate";
46
+ /**
47
+ * Contains a set of animation steps.
48
+ * See `keyframes()`
49
+ */
50
+ AnimationMetadataType[AnimationMetadataType["Keyframes"] = 5] = "Keyframes";
51
+ /**
52
+ * Contains a set of CSS property-value pairs into a named style.
53
+ * See `style()`
54
+ */
55
+ AnimationMetadataType[AnimationMetadataType["Style"] = 6] = "Style";
56
+ /**
57
+ * Associates an animation with an entry trigger that can be attached to an element.
58
+ * See `trigger()`
59
+ */
60
+ AnimationMetadataType[AnimationMetadataType["Trigger"] = 7] = "Trigger";
61
+ /**
62
+ * Contains a re-usable animation.
63
+ * See `animation()`
64
+ */
65
+ AnimationMetadataType[AnimationMetadataType["Reference"] = 8] = "Reference";
66
+ /**
67
+ * Contains data to use in executing child animations returned by a query.
68
+ * See `animateChild()`
69
+ */
70
+ AnimationMetadataType[AnimationMetadataType["AnimateChild"] = 9] = "AnimateChild";
71
+ /**
72
+ * Contains animation parameters for a re-usable animation.
73
+ * See `useAnimation()`
74
+ */
75
+ AnimationMetadataType[AnimationMetadataType["AnimateRef"] = 10] = "AnimateRef";
76
+ /**
77
+ * Contains child-animation query data.
78
+ * See `query()`
79
+ */
80
+ AnimationMetadataType[AnimationMetadataType["Query"] = 11] = "Query";
81
+ /**
82
+ * Contains data for staggering an animation sequence.
83
+ * See `stagger()`
84
+ */
85
+ AnimationMetadataType[AnimationMetadataType["Stagger"] = 12] = "Stagger";
86
+ })(AnimationMetadataType || (AnimationMetadataType = {}));
11
87
  /**
12
88
  * Specifies automatic styling.
13
89
  *
@@ -163,7 +239,7 @@ const AUTO_STYLE = '*';
163
239
  * @publicApi
164
240
  */
165
241
  function trigger(name, definitions) {
166
- return { type: 7 /* AnimationMetadataType.Trigger */, name, definitions, options: {} };
242
+ return { type: AnimationMetadataType.Trigger, name, definitions, options: {} };
167
243
  }
168
244
  /**
169
245
  * Defines an animation step that combines styling information with timing information.
@@ -224,7 +300,7 @@ function trigger(name, definitions) {
224
300
  * @publicApi
225
301
  */
226
302
  function animate(timings, styles = null) {
227
- return { type: 4 /* AnimationMetadataType.Animate */, styles, timings };
303
+ return { type: AnimationMetadataType.Animate, styles, timings };
228
304
  }
229
305
  /**
230
306
  * @description Defines a list of animation steps to be run in parallel.
@@ -260,7 +336,7 @@ function animate(timings, styles = null) {
260
336
  * @publicApi
261
337
  */
262
338
  function group(steps, options = null) {
263
- return { type: 3 /* AnimationMetadataType.Group */, steps, options };
339
+ return { type: AnimationMetadataType.Group, steps, options };
264
340
  }
265
341
  /**
266
342
  * Defines a list of animation steps to be run sequentially, one by one.
@@ -296,7 +372,7 @@ function group(steps, options = null) {
296
372
  * @publicApi
297
373
  **/
298
374
  function sequence(steps, options = null) {
299
- return { type: 2 /* AnimationMetadataType.Sequence */, steps, options };
375
+ return { type: AnimationMetadataType.Sequence, steps, options };
300
376
  }
301
377
  /**
302
378
  * Declares a key/value object containing CSS properties/styles that
@@ -338,7 +414,7 @@ function sequence(steps, options = null) {
338
414
  * @publicApi
339
415
  **/
340
416
  function style(tokens) {
341
- return { type: 6 /* AnimationMetadataType.Style */, styles: tokens, offset: null };
417
+ return { type: AnimationMetadataType.Style, styles: tokens, offset: null };
342
418
  }
343
419
  /**
344
420
  * Declares an animation state within a trigger attached to an element.
@@ -370,7 +446,7 @@ function style(tokens) {
370
446
  * @publicApi
371
447
  **/
372
448
  function state(name, styles, options) {
373
- return { type: 0 /* AnimationMetadataType.State */, name, styles, options };
449
+ return { type: AnimationMetadataType.State, name, styles, options };
374
450
  }
375
451
  /**
376
452
  * Defines a set of animation styles, associating each style with an optional `offset` value.
@@ -418,7 +494,7 @@ function state(name, styles, options) {
418
494
  * @publicApi
419
495
  */
420
496
  function keyframes(steps) {
421
- return { type: 5 /* AnimationMetadataType.Keyframes */, steps };
497
+ return { type: AnimationMetadataType.Keyframes, steps };
422
498
  }
423
499
  /**
424
500
  * Declares an animation transition which is played when a certain specified condition is met.
@@ -567,7 +643,7 @@ function keyframes(steps) {
567
643
  * @publicApi
568
644
  **/
569
645
  function transition(stateChangeExpr, steps, options = null) {
570
- return { type: 1 /* AnimationMetadataType.Transition */, expr: stateChangeExpr, animation: steps, options };
646
+ return { type: AnimationMetadataType.Transition, expr: stateChangeExpr, animation: steps, options };
571
647
  }
572
648
  /**
573
649
  * Produces a reusable animation that can be invoked in another animation or sequence,
@@ -615,7 +691,7 @@ function transition(stateChangeExpr, steps, options = null) {
615
691
  * @publicApi
616
692
  */
617
693
  function animation(steps, options = null) {
618
- return { type: 8 /* AnimationMetadataType.Reference */, animation: steps, options };
694
+ return { type: AnimationMetadataType.Reference, animation: steps, options };
619
695
  }
620
696
  /**
621
697
  * Executes a queried inner animation element within an animation sequence.
@@ -637,7 +713,7 @@ function animation(steps, options = null) {
637
713
  * @publicApi
638
714
  */
639
715
  function animateChild(options = null) {
640
- return { type: 9 /* AnimationMetadataType.AnimateChild */, options };
716
+ return { type: AnimationMetadataType.AnimateChild, options };
641
717
  }
642
718
  /**
643
719
  * Starts a reusable animation that is created using the `animation()` function.
@@ -650,7 +726,7 @@ function animateChild(options = null) {
650
726
  * @publicApi
651
727
  */
652
728
  function useAnimation(animation, options = null) {
653
- return { type: 10 /* AnimationMetadataType.AnimateRef */, animation, options };
729
+ return { type: AnimationMetadataType.AnimateRef, animation, options };
654
730
  }
655
731
  /**
656
732
  * Finds one or more inner elements within the current element that is
@@ -773,7 +849,7 @@ function useAnimation(animation, options = null) {
773
849
  * @publicApi
774
850
  */
775
851
  function query(selector, animation, options = null) {
776
- return { type: 11 /* AnimationMetadataType.Query */, selector, animation, options };
852
+ return { type: AnimationMetadataType.Query, selector, animation, options };
777
853
  }
778
854
  /**
779
855
  * Use within an animation `query()` call to issue a timing gap after
@@ -856,7 +932,7 @@ function query(selector, animation, options = null) {
856
932
  * @publicApi
857
933
  */
858
934
  function stagger(timings, animation) {
859
- return { type: 12 /* AnimationMetadataType.Stagger */, timings, animation };
935
+ return { type: AnimationMetadataType.Stagger, timings, animation };
860
936
  }
861
937
 
862
938
  /**
@@ -906,10 +982,10 @@ function stagger(timings, animation) {
906
982
  * @publicApi
907
983
  */
908
984
  class AnimationBuilder {
909
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.4", ngImport: i0, type: AnimationBuilder, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
910
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.0.4", ngImport: i0, type: AnimationBuilder, providedIn: 'root', useFactory: () => inject(BrowserAnimationBuilder) }); }
985
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0-next.1", ngImport: i0, type: AnimationBuilder, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
986
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.0-next.1", ngImport: i0, type: AnimationBuilder, providedIn: 'root', useFactory: () => inject(BrowserAnimationBuilder) }); }
911
987
  }
912
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.4", ngImport: i0, type: AnimationBuilder, decorators: [{
988
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0-next.1", ngImport: i0, type: AnimationBuilder, decorators: [{
913
989
  type: Injectable,
914
990
  args: [{ providedIn: 'root', useFactory: () => inject(BrowserAnimationBuilder) }]
915
991
  }] });
@@ -948,10 +1024,10 @@ class BrowserAnimationBuilder extends AnimationBuilder {
948
1024
  issueAnimationCommand(this._renderer, null, id, 'register', [entry]);
949
1025
  return new BrowserAnimationFactory(id, this._renderer);
950
1026
  }
951
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.4", ngImport: i0, type: BrowserAnimationBuilder, deps: [{ token: i0.RendererFactory2 }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
952
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.0.4", ngImport: i0, type: BrowserAnimationBuilder, providedIn: 'root' }); }
1027
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0-next.1", ngImport: i0, type: BrowserAnimationBuilder, deps: [{ token: i0.RendererFactory2 }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
1028
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.0-next.1", ngImport: i0, type: BrowserAnimationBuilder, providedIn: 'root' }); }
953
1029
  }
954
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.4", ngImport: i0, type: BrowserAnimationBuilder, decorators: [{
1030
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0-next.1", ngImport: i0, type: BrowserAnimationBuilder, decorators: [{
955
1031
  type: Injectable,
956
1032
  args: [{ providedIn: 'root' }]
957
1033
  }], ctorParameters: () => [{ type: i0.RendererFactory2 }, { type: Document, decorators: [{
@@ -1306,5 +1382,5 @@ const ɵPRE_STYLE = '!';
1306
1382
  * Generated bundle index. Do not edit.
1307
1383
  */
1308
1384
 
1309
- export { AUTO_STYLE, AnimationBuilder, AnimationFactory, NoopAnimationPlayer, animate, animateChild, animation, group, keyframes, query, sequence, stagger, state, style, transition, trigger, useAnimation, AnimationGroupPlayer as ɵAnimationGroupPlayer, BrowserAnimationBuilder as ɵBrowserAnimationBuilder, ɵPRE_STYLE };
1385
+ export { AUTO_STYLE, AnimationBuilder, AnimationFactory, AnimationMetadataType, NoopAnimationPlayer, animate, animateChild, animation, group, keyframes, query, sequence, stagger, state, style, transition, trigger, useAnimation, AnimationGroupPlayer as ɵAnimationGroupPlayer, BrowserAnimationBuilder as ɵBrowserAnimationBuilder, ɵPRE_STYLE };
1310
1386
  //# sourceMappingURL=animations.mjs.map