@angular/animations 13.2.0-next.0 → 13.2.0-rc.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.
- package/animations.d.ts +144 -161
- package/browser/browser.d.ts +4 -4
- package/browser/testing/testing.d.ts +2 -2
- package/esm2020/browser/src/dsl/animation.mjs +1 -1
- package/esm2020/browser/src/dsl/animation_ast_builder.mjs +1 -1
- package/esm2020/browser/src/dsl/animation_timeline_builder.mjs +18 -7
- package/esm2020/browser/src/dsl/animation_transition_factory.mjs +1 -1
- package/esm2020/browser/src/dsl/animation_transition_instruction.mjs +1 -1
- package/esm2020/browser/src/dsl/animation_trigger.mjs +1 -1
- package/esm2020/browser/src/dsl/element_instruction_map.mjs +3 -10
- package/esm2020/browser/src/render/animation_driver.mjs +3 -3
- package/esm2020/browser/src/render/animation_engine_next.mjs +1 -1
- package/esm2020/browser/src/render/shared.mjs +4 -20
- package/esm2020/browser/src/render/timeline_animation_engine.mjs +1 -1
- package/esm2020/browser/src/render/transition_animation_engine.mjs +32 -7
- package/esm2020/browser/src/render/web_animations/web_animations_player.mjs +7 -4
- package/esm2020/browser/src/util.mjs +1 -3
- package/esm2020/src/animation_builder.mjs +6 -4
- package/esm2020/src/animation_metadata.mjs +128 -150
- package/esm2020/src/players/animation_player.mjs +1 -1
- package/esm2020/src/version.mjs +1 -1
- package/fesm2015/animations.mjs +134 -154
- package/fesm2015/animations.mjs.map +1 -1
- package/fesm2015/browser/testing.mjs +2 -2
- package/fesm2015/browser.mjs +64 -50
- package/fesm2015/browser.mjs.map +1 -1
- package/fesm2020/animations.mjs +134 -154
- package/fesm2020/animations.mjs.map +1 -1
- package/fesm2020/browser/testing.mjs +2 -2
- package/fesm2020/browser.mjs +64 -50
- package/fesm2020/browser.mjs.map +1 -1
- package/package.json +2 -2
|
@@ -96,4 +96,4 @@ export class NoopAnimationPlayer {
|
|
|
96
96
|
methods.length = 0;
|
|
97
97
|
}
|
|
98
98
|
}
|
|
99
|
-
//# 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 */\nimport {scheduleMicroTask} from '../util';\n\n/**\n * Provides programmatic control of a reusable animation sequence,\n * built using the `build()` method of `AnimationBuilder`. The `build()` method\n * returns a factory, whose `create()` method instantiates and initializes this interface.\n *\n * @see `AnimationBuilder`\n * @see `AnimationFactory`\n * @see `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 `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 `run()`\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 `destroy()`\n   * @see `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: any /** TODO #9100 */): 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 `animate()`\n * @see `AnimationPlayer`\n * @see `GroupPlayer`\n *\n * @publicApi\n */\nexport class NoopAnimationPlayer implements AnimationPlayer {\n  private _onDoneFns: Function[] = [];\n  private _onStartFns: Function[] = [];\n  private _onDestroyFns: 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._onStartFns.push(fn);\n  }\n  onDone(fn: () => void): void {\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    scheduleMicroTask(() => 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  }\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"]}
|
|
99
|
+
//# 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 */\nimport {scheduleMicroTask} from '../util';\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 `AnimationBuilder`\n * @see `AnimationFactory`\n * @see `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 `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 `run()`\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 `destroy()`\n   * @see `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: any /** TODO #9100 */): 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 `animate()`\n * @see `AnimationPlayer`\n * @see `GroupPlayer`\n *\n * @publicApi\n */\nexport class NoopAnimationPlayer implements AnimationPlayer {\n  private _onDoneFns: Function[] = [];\n  private _onStartFns: Function[] = [];\n  private _onDestroyFns: 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._onStartFns.push(fn);\n  }\n  onDone(fn: () => void): void {\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    scheduleMicroTask(() => 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  }\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"]}
|
package/esm2020/src/version.mjs
CHANGED
|
@@ -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('13.2.0-
|
|
14
|
+
export const VERSION = new Version('13.2.0-rc.1');
|
|
15
15
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuaW1hdGlvbnMvc3JjL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUg7Ozs7R0FJRztBQUNILE9BQU8sRUFBQyxPQUFPLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFdEMsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLElBQUksT0FBTyxDQUFDLG1CQUFtQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuLyoqXG4gKiBAbW9kdWxlXG4gKiBAZGVzY3JpcHRpb25cbiAqIEVudHJ5IHBvaW50IGZvciBhbGwgcHVibGljIEFQSXMgb2YgdGhlIGFuaW1hdGlvbiBwYWNrYWdlLlxuICovXG5pbXBvcnQge1ZlcnNpb259IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IG5ldyBWZXJzaW9uKCcwLjAuMC1QTEFDRUhPTERFUicpO1xuIl19
|
package/fesm2015/animations.mjs
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @license Angular v13.2.0-
|
|
3
|
-
* (c) 2010-
|
|
2
|
+
* @license Angular v13.2.0-rc.1
|
|
3
|
+
* (c) 2010-2022 Google LLC. https://angular.io/
|
|
4
4
|
* License: MIT
|
|
5
5
|
*/
|
|
6
6
|
|
|
@@ -17,8 +17,8 @@
|
|
|
17
17
|
* Apps do not typically need to create their own animation players, but if you
|
|
18
18
|
* do need to, follow these steps:
|
|
19
19
|
*
|
|
20
|
-
* 1. Use the
|
|
21
|
-
*
|
|
20
|
+
* 1. Use the <code>[AnimationBuilder.build](api/animations/AnimationBuilder#build)()</code> method
|
|
21
|
+
* to create a programmatic animation. The method returns an `AnimationFactory` instance.
|
|
22
22
|
*
|
|
23
23
|
* 2. Use the factory object to create an `AnimationPlayer` and attach it to a DOM element.
|
|
24
24
|
*
|
|
@@ -53,7 +53,9 @@
|
|
|
53
53
|
class AnimationBuilder {
|
|
54
54
|
}
|
|
55
55
|
/**
|
|
56
|
-
* A factory object returned from the
|
|
56
|
+
* A factory object returned from the
|
|
57
|
+
* <code>[AnimationBuilder.build](api/animations/AnimationBuilder#build)()</code>
|
|
58
|
+
* method.
|
|
57
59
|
*
|
|
58
60
|
* @publicApi
|
|
59
61
|
*/
|
|
@@ -74,13 +76,13 @@ class AnimationFactory {
|
|
|
74
76
|
*/
|
|
75
77
|
const AUTO_STYLE = '*';
|
|
76
78
|
/**
|
|
77
|
-
* Creates a named animation trigger, containing a list of `state()`
|
|
79
|
+
* Creates a named animation trigger, containing a list of [`state()`](api/animations/state)
|
|
78
80
|
* and `transition()` entries to be evaluated when the expression
|
|
79
81
|
* bound to the trigger changes.
|
|
80
82
|
*
|
|
81
83
|
* @param name An identifying string.
|
|
82
|
-
* @param definitions An animation definition object, containing an array of
|
|
83
|
-
* and `transition()` declarations.
|
|
84
|
+
* @param definitions An animation definition object, containing an array of
|
|
85
|
+
* [`state()`](api/animations/state) and `transition()` declarations.
|
|
84
86
|
*
|
|
85
87
|
* @return An object that encapsulates the trigger data.
|
|
86
88
|
*
|
|
@@ -359,8 +361,8 @@ function sequence(steps, options = null) {
|
|
|
359
361
|
}
|
|
360
362
|
/**
|
|
361
363
|
* Declares a key/value object containing CSS properties/styles that
|
|
362
|
-
* can then be used for an animation `state
|
|
363
|
-
|
|
364
|
+
* can then be used for an animation [`state`](api/animations/state), within an animation
|
|
365
|
+
*`sequence`, or as styling data for calls to `animate()` and `keyframes()`.
|
|
364
366
|
*
|
|
365
367
|
* @param tokens A set of CSS styles or HTML styles associated with an animation state.
|
|
366
368
|
* The value can be any of the following:
|
|
@@ -480,170 +482,148 @@ function keyframes(steps) {
|
|
|
480
482
|
return { type: 5 /* Keyframes */, steps };
|
|
481
483
|
}
|
|
482
484
|
/**
|
|
483
|
-
* Declares an animation transition
|
|
484
|
-
* condition is satisfied. The condition is a Boolean expression or function that compares
|
|
485
|
-
* the previous and current animation states, and returns true if this transition should occur.
|
|
486
|
-
* When the state criteria of a defined transition are met, the associated animation is
|
|
487
|
-
* triggered.
|
|
488
|
-
*
|
|
489
|
-
* @param stateChangeExpr A Boolean expression or function that compares the previous and current
|
|
490
|
-
* animation states, and returns true if this transition should occur. Note that "true" and "false"
|
|
491
|
-
* match 1 and 0, respectively. An expression is evaluated each time a state change occurs in the
|
|
492
|
-
* animation trigger element.
|
|
493
|
-
* The animation steps run when the expression evaluates to true.
|
|
494
|
-
*
|
|
495
|
-
* - A state-change string takes the form "state1 => state2", where each side is a defined animation
|
|
496
|
-
* state, or an asterisk (*) to refer to a dynamic start or end state.
|
|
497
|
-
* - The expression string can contain multiple comma-separated statements;
|
|
498
|
-
* for example "state1 => state2, state3 => state4".
|
|
499
|
-
* - Special values `:enter` and `:leave` initiate a transition on the entry and exit states,
|
|
500
|
-
* equivalent to "void => *" and "* => void".
|
|
501
|
-
* - Special values `:increment` and `:decrement` initiate a transition when a numeric value has
|
|
502
|
-
* increased or decreased in value.
|
|
503
|
-
* - A function is executed each time a state change occurs in the animation trigger element.
|
|
504
|
-
* The animation steps run when the function returns true.
|
|
505
|
-
*
|
|
506
|
-
* @param steps One or more animation objects, as returned by the `animate()` or
|
|
507
|
-
* `sequence()` function, that form a transformation from one state to another.
|
|
508
|
-
* A sequence is used by default when you pass an array.
|
|
509
|
-
* @param options An options object that can contain a delay value for the start of the animation,
|
|
510
|
-
* and additional developer-defined parameters. Provided values for additional parameters are used
|
|
511
|
-
* as defaults, and override values can be passed to the caller on invocation.
|
|
512
|
-
* @returns An object that encapsulates the transition data.
|
|
485
|
+
* Declares an animation transition which is played when a certain specified condition is met.
|
|
513
486
|
*
|
|
514
|
-
* @
|
|
515
|
-
*
|
|
487
|
+
* @param stateChangeExpr A string with a specific format or a function that specifies when the
|
|
488
|
+
* animation transition should occur (see [State Change Expression](#state-change-expression)).
|
|
516
489
|
*
|
|
517
|
-
*
|
|
518
|
-
* <!-- somewhere inside of my-component-tpl.html -->
|
|
519
|
-
* <div [@myAnimationTrigger]="myStatusExp">...</div>
|
|
520
|
-
* ```
|
|
490
|
+
* @param steps One or more animation objects that represent the animation's instructions.
|
|
521
491
|
*
|
|
522
|
-
*
|
|
523
|
-
*
|
|
492
|
+
* @param options An options object that can be used to specify a delay for the animation or provide
|
|
493
|
+
* custom parameters for it.
|
|
524
494
|
*
|
|
525
|
-
*
|
|
526
|
-
* trigger("myAnimationTrigger", [
|
|
527
|
-
* // define states
|
|
528
|
-
* state("on", style({ background: "green" })),
|
|
529
|
-
* state("off", style({ background: "grey" })),
|
|
530
|
-
* ...]
|
|
531
|
-
* ```
|
|
532
|
-
*
|
|
533
|
-
* Note that when you call the `sequence()` function within a `{@link animations/group group()}`
|
|
534
|
-
* or a `transition()` call, execution does not continue to the next instruction
|
|
535
|
-
* until each of the inner animation steps have completed.
|
|
536
|
-
*
|
|
537
|
-
* ### Syntax examples
|
|
538
|
-
*
|
|
539
|
-
* The following examples define transitions between the two defined states (and default states),
|
|
540
|
-
* using various options:
|
|
541
|
-
*
|
|
542
|
-
* ```typescript
|
|
543
|
-
* // Transition occurs when the state value
|
|
544
|
-
* // bound to "myAnimationTrigger" changes from "on" to "off"
|
|
545
|
-
* transition("on => off", animate(500))
|
|
546
|
-
* // Run the same animation for both directions
|
|
547
|
-
* transition("on <=> off", animate(500))
|
|
548
|
-
* // Define multiple state-change pairs separated by commas
|
|
549
|
-
* transition("on => off, off => void", animate(500))
|
|
550
|
-
* ```
|
|
551
|
-
*
|
|
552
|
-
* ### Special values for state-change expressions
|
|
553
|
-
*
|
|
554
|
-
* - Catch-all state change for when an element is inserted into the page and the
|
|
555
|
-
* destination state is unknown:
|
|
495
|
+
* @returns An object that encapsulates the transition data.
|
|
556
496
|
*
|
|
557
|
-
*
|
|
558
|
-
* transition("void => *", [
|
|
559
|
-
* style({ opacity: 0 }),
|
|
560
|
-
* animate(500)
|
|
561
|
-
* ])
|
|
562
|
-
* ```
|
|
497
|
+
* @usageNotes
|
|
563
498
|
*
|
|
564
|
-
*
|
|
499
|
+
* ### State Change Expression
|
|
500
|
+
*
|
|
501
|
+
* The State Change Expression instructs Angular when to run the transition's animations, it can
|
|
502
|
+
*either be
|
|
503
|
+
* - a string with a specific syntax
|
|
504
|
+
* - or a function that compares the previous and current state (value of the expression bound to
|
|
505
|
+
* the element's trigger) and returns `true` if the transition should occur or `false` otherwise
|
|
506
|
+
*
|
|
507
|
+
* The string format can be:
|
|
508
|
+
* - `fromState => toState`, which indicates that the transition's animations should occur then the
|
|
509
|
+
* expression bound to the trigger's element goes from `fromState` to `toState`
|
|
510
|
+
*
|
|
511
|
+
* _Example:_
|
|
512
|
+
* ```typescript
|
|
513
|
+
* transition('open => closed', animate('.5s ease-out', style({ height: 0 }) ))
|
|
514
|
+
* ```
|
|
515
|
+
*
|
|
516
|
+
* - `fromState <=> toState`, which indicates that the transition's animations should occur then
|
|
517
|
+
* the expression bound to the trigger's element goes from `fromState` to `toState` or vice versa
|
|
518
|
+
*
|
|
519
|
+
* _Example:_
|
|
520
|
+
* ```typescript
|
|
521
|
+
* transition('enabled <=> disabled', animate('1s cubic-bezier(0.8,0.3,0,1)'))
|
|
522
|
+
* ```
|
|
523
|
+
*
|
|
524
|
+
* - `:enter`/`:leave`, which indicates that the transition's animations should occur when the
|
|
525
|
+
* element enters or exists the DOM
|
|
526
|
+
*
|
|
527
|
+
* _Example:_
|
|
528
|
+
* ```typescript
|
|
529
|
+
* transition(':enter', [
|
|
530
|
+
* style({ opacity: 0 }),
|
|
531
|
+
* animate('500ms', style({ opacity: 1 }))
|
|
532
|
+
* ])
|
|
533
|
+
* ```
|
|
534
|
+
*
|
|
535
|
+
* - `:increment`/`:decrement`, which indicates that the transition's animations should occur when
|
|
536
|
+
* the numerical expression bound to the trigger's element has increased in value or decreased
|
|
537
|
+
*
|
|
538
|
+
* _Example:_
|
|
539
|
+
* ```typescript
|
|
540
|
+
* transition(':increment', query('@counter', animateChild()))
|
|
541
|
+
* ```
|
|
542
|
+
*
|
|
543
|
+
* - a sequence of any of the above divided by commas, which indicates that transition's animations
|
|
544
|
+
* should occur whenever one of the state change expressions matches
|
|
545
|
+
*
|
|
546
|
+
* _Example:_
|
|
547
|
+
* ```typescript
|
|
548
|
+
* transition(':increment, * => enabled, :enter', animate('1s ease', keyframes([
|
|
549
|
+
* style({ transform: 'scale(1)', offset: 0}),
|
|
550
|
+
* style({ transform: 'scale(1.1)', offset: 0.7}),
|
|
551
|
+
* style({ transform: 'scale(1)', offset: 1})
|
|
552
|
+
* ]))),
|
|
553
|
+
* ```
|
|
554
|
+
*
|
|
555
|
+
* Also note that in such context:
|
|
556
|
+
* - `void` can be used to indicate the absence of the element
|
|
557
|
+
* - asterisks can be used as wildcards that match any state
|
|
558
|
+
* - (as a consequence of the above, `void => *` is equivalent to `:enter` and `* => void` is
|
|
559
|
+
* equivalent to `:leave`)
|
|
560
|
+
* - `true` and `false` also match expression values of `1` and `0` respectively (but do not match
|
|
561
|
+
* _truthy_ and _falsy_ values)
|
|
565
562
|
*
|
|
566
|
-
*
|
|
563
|
+
* <div class="alert is-helpful">
|
|
567
564
|
*
|
|
568
|
-
*
|
|
565
|
+
* Be careful about entering end leaving elements as their transitions present a common
|
|
566
|
+
* pitfall for developers.
|
|
569
567
|
*
|
|
570
|
-
*
|
|
571
|
-
*
|
|
572
|
-
*
|
|
573
|
-
*
|
|
574
|
-
*
|
|
575
|
-
* transition(":leave", [
|
|
576
|
-
* animate(500, style({ opacity: 0 }))
|
|
577
|
-
* ])
|
|
578
|
-
* ```
|
|
568
|
+
* Note that when an element with a trigger enters the DOM its `:enter` transition always
|
|
569
|
+
* gets executed, but its `:leave` transition will not be executed if the element is removed
|
|
570
|
+
* alongside its parent (as it will be removed "without warning" before its transition has
|
|
571
|
+
* a chance to be executed, the only way that such transition can occur is if the element
|
|
572
|
+
* is exiting the DOM on its own).
|
|
579
573
|
*
|
|
580
|
-
* - Use `:increment` and `:decrement` to initiate transitions:
|
|
581
574
|
*
|
|
582
|
-
*
|
|
583
|
-
* transition(":increment", group([
|
|
584
|
-
* query(':enter', [
|
|
585
|
-
* style({ left: '100%' }),
|
|
586
|
-
* animate('0.5s ease-out', style('*'))
|
|
587
|
-
* ]),
|
|
588
|
-
* query(':leave', [
|
|
589
|
-
* animate('0.5s ease-out', style({ left: '-100%' }))
|
|
590
|
-
* ])
|
|
591
|
-
* ]))
|
|
575
|
+
* </div>
|
|
592
576
|
*
|
|
593
|
-
*
|
|
594
|
-
* query(':enter', [
|
|
595
|
-
* style({ left: '100%' }),
|
|
596
|
-
* animate('0.5s ease-out', style('*'))
|
|
597
|
-
* ]),
|
|
598
|
-
* query(':leave', [
|
|
599
|
-
* animate('0.5s ease-out', style({ left: '-100%' }))
|
|
600
|
-
* ])
|
|
601
|
-
* ]))
|
|
602
|
-
* ```
|
|
577
|
+
* ### Animating to a Final State
|
|
603
578
|
*
|
|
604
|
-
*
|
|
579
|
+
* If the final step in a transition is a call to `animate()` that uses a timing value
|
|
580
|
+
* with no `style` data, that step is automatically considered the final animation arc,
|
|
581
|
+
* for the element to reach the final state, in such case Angular automatically adds or removes
|
|
582
|
+
* CSS styles to ensure that the element is in the correct final state.
|
|
605
583
|
*
|
|
606
|
-
* Here is an example of a `fromState` specified as a state-change function that invokes an
|
|
607
|
-
* animation when true:
|
|
608
584
|
*
|
|
609
|
-
*
|
|
610
|
-
* transition((fromState, toState) =>
|
|
611
|
-
* {
|
|
612
|
-
* return fromState == "off" && toState == "on";
|
|
613
|
-
* },
|
|
614
|
-
* animate("1s 0s"))
|
|
615
|
-
* ```
|
|
585
|
+
* ### Usage Examples
|
|
616
586
|
*
|
|
617
|
-
*
|
|
587
|
+
* - Transition animations applied based on
|
|
588
|
+
* the trigger's expression value
|
|
618
589
|
*
|
|
619
|
-
*
|
|
620
|
-
*
|
|
621
|
-
*
|
|
622
|
-
*
|
|
590
|
+
* ```HTML
|
|
591
|
+
* <div [@myAnimationTrigger]="myStatusExp">
|
|
592
|
+
* ...
|
|
593
|
+
* </div>
|
|
594
|
+
* ```
|
|
623
595
|
*
|
|
624
|
-
*
|
|
625
|
-
*
|
|
596
|
+
* ```typescript
|
|
597
|
+
* trigger("myAnimationTrigger", [
|
|
598
|
+
* ..., // states
|
|
599
|
+
* transition("on => off, open => closed", animate(500)),
|
|
600
|
+
* transition("* <=> error", query('.indicator', animateChild()))
|
|
601
|
+
* ])
|
|
602
|
+
* ```
|
|
626
603
|
*
|
|
627
|
-
*
|
|
628
|
-
*
|
|
629
|
-
* style({ opacity: 0 }),
|
|
630
|
-
* animate(500)
|
|
631
|
-
* ])
|
|
632
|
-
* ```
|
|
633
|
-
* ### Boolean value matching
|
|
634
|
-
* If a trigger binding value is a Boolean, it can be matched using a transition expression
|
|
635
|
-
* that compares true and false or 1 and 0. For example:
|
|
604
|
+
* - Transition animations applied based on custom logic dependent
|
|
605
|
+
* on the trigger's expression value and provided parameters
|
|
636
606
|
*
|
|
637
|
-
*
|
|
638
|
-
*
|
|
639
|
-
*
|
|
640
|
-
*
|
|
641
|
-
*
|
|
642
|
-
*
|
|
643
|
-
*
|
|
644
|
-
*
|
|
645
|
-
*
|
|
646
|
-
*
|
|
607
|
+
* ```HTML
|
|
608
|
+
* <div [@myAnimationTrigger]="{
|
|
609
|
+
* value: stepName,
|
|
610
|
+
* params: { target: currentTarget }
|
|
611
|
+
* }">
|
|
612
|
+
* ...
|
|
613
|
+
* </div>
|
|
614
|
+
* ```
|
|
615
|
+
*
|
|
616
|
+
* ```typescript
|
|
617
|
+
* trigger("myAnimationTrigger", [
|
|
618
|
+
* ..., // states
|
|
619
|
+
* transition(
|
|
620
|
+
* (fromState, toState, _element, params) =>
|
|
621
|
+
* ['firststep', 'laststep'].includes(fromState.toLowerCase())
|
|
622
|
+
* && toState === params?.['target'],
|
|
623
|
+
* animate('1s')
|
|
624
|
+
* )
|
|
625
|
+
* ])
|
|
626
|
+
* ```
|
|
647
627
|
*
|
|
648
628
|
* @publicApi
|
|
649
629
|
**/
|