@angular/animations 19.0.0-next.1 → 19.0.0-next.11

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 (62) hide show
  1. package/LICENSE +21 -0
  2. package/browser/index.d.ts +1 -1
  3. package/browser/testing/index.d.ts +1 -1
  4. package/fesm2022/animations.mjs +7 -7
  5. package/fesm2022/animations.mjs.map +1 -1
  6. package/fesm2022/browser/testing.mjs +1 -1
  7. package/fesm2022/browser/testing.mjs.map +1 -1
  8. package/fesm2022/browser.mjs +4 -4
  9. package/fesm2022/browser.mjs.map +1 -1
  10. package/index.d.ts +1 -1
  11. package/package.json +2 -8
  12. package/esm2022/animations.mjs +0 -5
  13. package/esm2022/browser/browser.mjs +0 -5
  14. package/esm2022/browser/index.mjs +0 -13
  15. package/esm2022/browser/public_api.mjs +0 -14
  16. package/esm2022/browser/src/browser.mjs +0 -15
  17. package/esm2022/browser/src/create_engine.mjs +0 -20
  18. package/esm2022/browser/src/dsl/animation.mjs +0 -37
  19. package/esm2022/browser/src/dsl/animation_ast.mjs +0 -3
  20. package/esm2022/browser/src/dsl/animation_ast_builder.mjs +0 -514
  21. package/esm2022/browser/src/dsl/animation_dsl_visitor.mjs +0 -2
  22. package/esm2022/browser/src/dsl/animation_timeline_builder.mjs +0 -780
  23. package/esm2022/browser/src/dsl/animation_timeline_instruction.mjs +0 -15
  24. package/esm2022/browser/src/dsl/animation_transition_expr.mjs +0 -82
  25. package/esm2022/browser/src/dsl/animation_transition_factory.mjs +0 -152
  26. package/esm2022/browser/src/dsl/animation_transition_instruction.mjs +0 -26
  27. package/esm2022/browser/src/dsl/animation_trigger.mjs +0 -65
  28. package/esm2022/browser/src/dsl/element_instruction_map.mjs +0 -22
  29. package/esm2022/browser/src/dsl/style_normalization/animation_style_normalizer.mjs +0 -18
  30. package/esm2022/browser/src/dsl/style_normalization/web_animations_style_normalizer.mjs +0 -63
  31. package/esm2022/browser/src/error_helpers.mjs +0 -145
  32. package/esm2022/browser/src/private_export.mjs +0 -19
  33. package/esm2022/browser/src/render/animation_driver.mjs +0 -71
  34. package/esm2022/browser/src/render/animation_engine_instruction.mjs +0 -2
  35. package/esm2022/browser/src/render/animation_engine_next.mjs +0 -83
  36. package/esm2022/browser/src/render/animation_renderer.mjs +0 -99
  37. package/esm2022/browser/src/render/renderer.mjs +0 -165
  38. package/esm2022/browser/src/render/shared.mjs +0 -162
  39. package/esm2022/browser/src/render/special_cased_styles.mjs +0 -97
  40. package/esm2022/browser/src/render/timeline_animation_engine.mjs +0 -140
  41. package/esm2022/browser/src/render/transition_animation_engine.mjs +0 -1516
  42. package/esm2022/browser/src/render/web_animations/animatable_props_set.mjs +0 -214
  43. package/esm2022/browser/src/render/web_animations/web_animations_driver.mjs +0 -54
  44. package/esm2022/browser/src/render/web_animations/web_animations_player.mjs +0 -177
  45. package/esm2022/browser/src/util.mjs +0 -217
  46. package/esm2022/browser/src/warning_helpers.mjs +0 -36
  47. package/esm2022/browser/testing/index.mjs +0 -13
  48. package/esm2022/browser/testing/public_api.mjs +0 -14
  49. package/esm2022/browser/testing/src/mock_animation_driver.mjs +0 -117
  50. package/esm2022/browser/testing/src/testing.mjs +0 -9
  51. package/esm2022/browser/testing/testing.mjs +0 -5
  52. package/esm2022/index.mjs +0 -13
  53. package/esm2022/public_api.mjs +0 -14
  54. package/esm2022/src/animation_builder.mjs +0 -200
  55. package/esm2022/src/animation_event.mjs +0 -9
  56. package/esm2022/src/animation_metadata.mjs +0 -934
  57. package/esm2022/src/animations.mjs +0 -17
  58. package/esm2022/src/errors.mjs +0 -9
  59. package/esm2022/src/players/animation_group_player.mjs +0 -147
  60. package/esm2022/src/players/animation_player.mjs +0 -104
  61. package/esm2022/src/private_export.mjs +0 -11
  62. package/esm2022/src/version.mjs +0 -15
@@ -1,214 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright Google LLC All Rights Reserved.
4
- *
5
- * Use of this source code is governed by an MIT-style license that can be
6
- * found in the LICENSE file at https://angular.io/license
7
- */
8
- /**
9
- * Set of all animatable CSS properties
10
- *
11
- * @see https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_animated_properties
12
- */
13
- export const ANIMATABLE_PROP_SET = new Set([
14
- '-moz-outline-radius',
15
- '-moz-outline-radius-bottomleft',
16
- '-moz-outline-radius-bottomright',
17
- '-moz-outline-radius-topleft',
18
- '-moz-outline-radius-topright',
19
- '-ms-grid-columns',
20
- '-ms-grid-rows',
21
- '-webkit-line-clamp',
22
- '-webkit-text-fill-color',
23
- '-webkit-text-stroke',
24
- '-webkit-text-stroke-color',
25
- 'accent-color',
26
- 'all',
27
- 'backdrop-filter',
28
- 'background',
29
- 'background-color',
30
- 'background-position',
31
- 'background-size',
32
- 'block-size',
33
- 'border',
34
- 'border-block-end',
35
- 'border-block-end-color',
36
- 'border-block-end-width',
37
- 'border-block-start',
38
- 'border-block-start-color',
39
- 'border-block-start-width',
40
- 'border-bottom',
41
- 'border-bottom-color',
42
- 'border-bottom-left-radius',
43
- 'border-bottom-right-radius',
44
- 'border-bottom-width',
45
- 'border-color',
46
- 'border-end-end-radius',
47
- 'border-end-start-radius',
48
- 'border-image-outset',
49
- 'border-image-slice',
50
- 'border-image-width',
51
- 'border-inline-end',
52
- 'border-inline-end-color',
53
- 'border-inline-end-width',
54
- 'border-inline-start',
55
- 'border-inline-start-color',
56
- 'border-inline-start-width',
57
- 'border-left',
58
- 'border-left-color',
59
- 'border-left-width',
60
- 'border-radius',
61
- 'border-right',
62
- 'border-right-color',
63
- 'border-right-width',
64
- 'border-start-end-radius',
65
- 'border-start-start-radius',
66
- 'border-top',
67
- 'border-top-color',
68
- 'border-top-left-radius',
69
- 'border-top-right-radius',
70
- 'border-top-width',
71
- 'border-width',
72
- 'bottom',
73
- 'box-shadow',
74
- 'caret-color',
75
- 'clip',
76
- 'clip-path',
77
- 'color',
78
- 'column-count',
79
- 'column-gap',
80
- 'column-rule',
81
- 'column-rule-color',
82
- 'column-rule-width',
83
- 'column-width',
84
- 'columns',
85
- 'filter',
86
- 'flex',
87
- 'flex-basis',
88
- 'flex-grow',
89
- 'flex-shrink',
90
- 'font',
91
- 'font-size',
92
- 'font-size-adjust',
93
- 'font-stretch',
94
- 'font-variation-settings',
95
- 'font-weight',
96
- 'gap',
97
- 'grid-column-gap',
98
- 'grid-gap',
99
- 'grid-row-gap',
100
- 'grid-template-columns',
101
- 'grid-template-rows',
102
- 'height',
103
- 'inline-size',
104
- 'input-security',
105
- 'inset',
106
- 'inset-block',
107
- 'inset-block-end',
108
- 'inset-block-start',
109
- 'inset-inline',
110
- 'inset-inline-end',
111
- 'inset-inline-start',
112
- 'left',
113
- 'letter-spacing',
114
- 'line-clamp',
115
- 'line-height',
116
- 'margin',
117
- 'margin-block-end',
118
- 'margin-block-start',
119
- 'margin-bottom',
120
- 'margin-inline-end',
121
- 'margin-inline-start',
122
- 'margin-left',
123
- 'margin-right',
124
- 'margin-top',
125
- 'mask',
126
- 'mask-border',
127
- 'mask-position',
128
- 'mask-size',
129
- 'max-block-size',
130
- 'max-height',
131
- 'max-inline-size',
132
- 'max-lines',
133
- 'max-width',
134
- 'min-block-size',
135
- 'min-height',
136
- 'min-inline-size',
137
- 'min-width',
138
- 'object-position',
139
- 'offset',
140
- 'offset-anchor',
141
- 'offset-distance',
142
- 'offset-path',
143
- 'offset-position',
144
- 'offset-rotate',
145
- 'opacity',
146
- 'order',
147
- 'outline',
148
- 'outline-color',
149
- 'outline-offset',
150
- 'outline-width',
151
- 'padding',
152
- 'padding-block-end',
153
- 'padding-block-start',
154
- 'padding-bottom',
155
- 'padding-inline-end',
156
- 'padding-inline-start',
157
- 'padding-left',
158
- 'padding-right',
159
- 'padding-top',
160
- 'perspective',
161
- 'perspective-origin',
162
- 'right',
163
- 'rotate',
164
- 'row-gap',
165
- 'scale',
166
- 'scroll-margin',
167
- 'scroll-margin-block',
168
- 'scroll-margin-block-end',
169
- 'scroll-margin-block-start',
170
- 'scroll-margin-bottom',
171
- 'scroll-margin-inline',
172
- 'scroll-margin-inline-end',
173
- 'scroll-margin-inline-start',
174
- 'scroll-margin-left',
175
- 'scroll-margin-right',
176
- 'scroll-margin-top',
177
- 'scroll-padding',
178
- 'scroll-padding-block',
179
- 'scroll-padding-block-end',
180
- 'scroll-padding-block-start',
181
- 'scroll-padding-bottom',
182
- 'scroll-padding-inline',
183
- 'scroll-padding-inline-end',
184
- 'scroll-padding-inline-start',
185
- 'scroll-padding-left',
186
- 'scroll-padding-right',
187
- 'scroll-padding-top',
188
- 'scroll-snap-coordinate',
189
- 'scroll-snap-destination',
190
- 'scrollbar-color',
191
- 'shape-image-threshold',
192
- 'shape-margin',
193
- 'shape-outside',
194
- 'tab-size',
195
- 'text-decoration',
196
- 'text-decoration-color',
197
- 'text-decoration-thickness',
198
- 'text-emphasis',
199
- 'text-emphasis-color',
200
- 'text-indent',
201
- 'text-shadow',
202
- 'text-underline-offset',
203
- 'top',
204
- 'transform',
205
- 'transform-origin',
206
- 'translate',
207
- 'vertical-align',
208
- 'visibility',
209
- 'width',
210
- 'word-spacing',
211
- 'z-index',
212
- 'zoom',
213
- ]);
214
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animatable_props_set.js","sourceRoot":"","sources":["../../../../../../../../../packages/animations/browser/src/render/web_animations/animatable_props_set.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 * Set of all animatable CSS properties\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_animated_properties\n */\nexport const ANIMATABLE_PROP_SET = new Set([\n  '-moz-outline-radius',\n  '-moz-outline-radius-bottomleft',\n  '-moz-outline-radius-bottomright',\n  '-moz-outline-radius-topleft',\n  '-moz-outline-radius-topright',\n  '-ms-grid-columns',\n  '-ms-grid-rows',\n  '-webkit-line-clamp',\n  '-webkit-text-fill-color',\n  '-webkit-text-stroke',\n  '-webkit-text-stroke-color',\n  'accent-color',\n  'all',\n  'backdrop-filter',\n  'background',\n  'background-color',\n  'background-position',\n  'background-size',\n  'block-size',\n  'border',\n  'border-block-end',\n  'border-block-end-color',\n  'border-block-end-width',\n  'border-block-start',\n  'border-block-start-color',\n  'border-block-start-width',\n  'border-bottom',\n  'border-bottom-color',\n  'border-bottom-left-radius',\n  'border-bottom-right-radius',\n  'border-bottom-width',\n  'border-color',\n  'border-end-end-radius',\n  'border-end-start-radius',\n  'border-image-outset',\n  'border-image-slice',\n  'border-image-width',\n  'border-inline-end',\n  'border-inline-end-color',\n  'border-inline-end-width',\n  'border-inline-start',\n  'border-inline-start-color',\n  'border-inline-start-width',\n  'border-left',\n  'border-left-color',\n  'border-left-width',\n  'border-radius',\n  'border-right',\n  'border-right-color',\n  'border-right-width',\n  'border-start-end-radius',\n  'border-start-start-radius',\n  'border-top',\n  'border-top-color',\n  'border-top-left-radius',\n  'border-top-right-radius',\n  'border-top-width',\n  'border-width',\n  'bottom',\n  'box-shadow',\n  'caret-color',\n  'clip',\n  'clip-path',\n  'color',\n  'column-count',\n  'column-gap',\n  'column-rule',\n  'column-rule-color',\n  'column-rule-width',\n  'column-width',\n  'columns',\n  'filter',\n  'flex',\n  'flex-basis',\n  'flex-grow',\n  'flex-shrink',\n  'font',\n  'font-size',\n  'font-size-adjust',\n  'font-stretch',\n  'font-variation-settings',\n  'font-weight',\n  'gap',\n  'grid-column-gap',\n  'grid-gap',\n  'grid-row-gap',\n  'grid-template-columns',\n  'grid-template-rows',\n  'height',\n  'inline-size',\n  'input-security',\n  'inset',\n  'inset-block',\n  'inset-block-end',\n  'inset-block-start',\n  'inset-inline',\n  'inset-inline-end',\n  'inset-inline-start',\n  'left',\n  'letter-spacing',\n  'line-clamp',\n  'line-height',\n  'margin',\n  'margin-block-end',\n  'margin-block-start',\n  'margin-bottom',\n  'margin-inline-end',\n  'margin-inline-start',\n  'margin-left',\n  'margin-right',\n  'margin-top',\n  'mask',\n  'mask-border',\n  'mask-position',\n  'mask-size',\n  'max-block-size',\n  'max-height',\n  'max-inline-size',\n  'max-lines',\n  'max-width',\n  'min-block-size',\n  'min-height',\n  'min-inline-size',\n  'min-width',\n  'object-position',\n  'offset',\n  'offset-anchor',\n  'offset-distance',\n  'offset-path',\n  'offset-position',\n  'offset-rotate',\n  'opacity',\n  'order',\n  'outline',\n  'outline-color',\n  'outline-offset',\n  'outline-width',\n  'padding',\n  'padding-block-end',\n  'padding-block-start',\n  'padding-bottom',\n  'padding-inline-end',\n  'padding-inline-start',\n  'padding-left',\n  'padding-right',\n  'padding-top',\n  'perspective',\n  'perspective-origin',\n  'right',\n  'rotate',\n  'row-gap',\n  'scale',\n  'scroll-margin',\n  'scroll-margin-block',\n  'scroll-margin-block-end',\n  'scroll-margin-block-start',\n  'scroll-margin-bottom',\n  'scroll-margin-inline',\n  'scroll-margin-inline-end',\n  'scroll-margin-inline-start',\n  'scroll-margin-left',\n  'scroll-margin-right',\n  'scroll-margin-top',\n  'scroll-padding',\n  'scroll-padding-block',\n  'scroll-padding-block-end',\n  'scroll-padding-block-start',\n  'scroll-padding-bottom',\n  'scroll-padding-inline',\n  'scroll-padding-inline-end',\n  'scroll-padding-inline-start',\n  'scroll-padding-left',\n  'scroll-padding-right',\n  'scroll-padding-top',\n  'scroll-snap-coordinate',\n  'scroll-snap-destination',\n  'scrollbar-color',\n  'shape-image-threshold',\n  'shape-margin',\n  'shape-outside',\n  'tab-size',\n  'text-decoration',\n  'text-decoration-color',\n  'text-decoration-thickness',\n  'text-emphasis',\n  'text-emphasis-color',\n  'text-indent',\n  'text-shadow',\n  'text-underline-offset',\n  'top',\n  'transform',\n  'transform-origin',\n  'translate',\n  'vertical-align',\n  'visibility',\n  'width',\n  'word-spacing',\n  'z-index',\n  'zoom',\n]);\n"]}
@@ -1,54 +0,0 @@
1
- import { allowPreviousPlayerStylesMerge, balancePreviousStylesIntoKeyframes, camelCaseToDashCase, computeStyle, normalizeKeyframes, } from '../../util';
2
- import { containsElement, getParentElement, invokeQuery, validateStyleProperty, validateWebAnimatableStyleProperty, } from '../shared';
3
- import { packageNonAnimatableStyles } from '../special_cased_styles';
4
- import { WebAnimationsPlayer } from './web_animations_player';
5
- export class WebAnimationsDriver {
6
- validateStyleProperty(prop) {
7
- // Perform actual validation in dev mode only, in prod mode this check is a noop.
8
- if (typeof ngDevMode === 'undefined' || ngDevMode) {
9
- return validateStyleProperty(prop);
10
- }
11
- return true;
12
- }
13
- validateAnimatableStyleProperty(prop) {
14
- // Perform actual validation in dev mode only, in prod mode this check is a noop.
15
- if (typeof ngDevMode === 'undefined' || ngDevMode) {
16
- const cssProp = camelCaseToDashCase(prop);
17
- return validateWebAnimatableStyleProperty(cssProp);
18
- }
19
- return true;
20
- }
21
- containsElement(elm1, elm2) {
22
- return containsElement(elm1, elm2);
23
- }
24
- getParentElement(element) {
25
- return getParentElement(element);
26
- }
27
- query(element, selector, multi) {
28
- return invokeQuery(element, selector, multi);
29
- }
30
- computeStyle(element, prop, defaultValue) {
31
- return computeStyle(element, prop);
32
- }
33
- animate(element, keyframes, duration, delay, easing, previousPlayers = []) {
34
- const fill = delay == 0 ? 'both' : 'forwards';
35
- const playerOptions = { duration, delay, fill };
36
- // we check for this to avoid having a null|undefined value be present
37
- // for the easing (which results in an error for certain browsers #9752)
38
- if (easing) {
39
- playerOptions['easing'] = easing;
40
- }
41
- const previousStyles = new Map();
42
- const previousWebAnimationPlayers = (previousPlayers.filter((player) => player instanceof WebAnimationsPlayer));
43
- if (allowPreviousPlayerStylesMerge(duration, delay)) {
44
- previousWebAnimationPlayers.forEach((player) => {
45
- player.currentSnapshot.forEach((val, prop) => previousStyles.set(prop, val));
46
- });
47
- }
48
- let _keyframes = normalizeKeyframes(keyframes).map((styles) => new Map(styles));
49
- _keyframes = balancePreviousStylesIntoKeyframes(element, _keyframes, previousStyles);
50
- const specialStyles = packageNonAnimatableStyles(element, _keyframes);
51
- return new WebAnimationsPlayer(element, _keyframes, playerOptions, specialStyles);
52
- }
53
- }
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2ViX2FuaW1hdGlvbnNfZHJpdmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5pbWF0aW9ucy9icm93c2VyL3NyYy9yZW5kZXIvd2ViX2FuaW1hdGlvbnMvd2ViX2FuaW1hdGlvbnNfZHJpdmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVNBLE9BQU8sRUFDTCw4QkFBOEIsRUFDOUIsa0NBQWtDLEVBQ2xDLG1CQUFtQixFQUNuQixZQUFZLEVBQ1osa0JBQWtCLEdBQ25CLE1BQU0sWUFBWSxDQUFDO0FBRXBCLE9BQU8sRUFDTCxlQUFlLEVBQ2YsZ0JBQWdCLEVBQ2hCLFdBQVcsRUFDWCxxQkFBcUIsRUFDckIsa0NBQWtDLEdBQ25DLE1BQU0sV0FBVyxDQUFDO0FBQ25CLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBRW5FLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBRTVELE1BQU0sT0FBTyxtQkFBbUI7SUFDOUIscUJBQXFCLENBQUMsSUFBWTtRQUNoQyxpRkFBaUY7UUFDakYsSUFBSSxPQUFPLFNBQVMsS0FBSyxXQUFXLElBQUksU0FBUyxFQUFFLENBQUM7WUFDbEQsT0FBTyxxQkFBcUIsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNyQyxDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsK0JBQStCLENBQUMsSUFBWTtRQUMxQyxpRkFBaUY7UUFDakYsSUFBSSxPQUFPLFNBQVMsS0FBSyxXQUFXLElBQUksU0FBUyxFQUFFLENBQUM7WUFDbEQsTUFBTSxPQUFPLEdBQUcsbUJBQW1CLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDMUMsT0FBTyxrQ0FBa0MsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNyRCxDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsZUFBZSxDQUFDLElBQVMsRUFBRSxJQUFTO1FBQ2xDLE9BQU8sZUFBZSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQsZ0JBQWdCLENBQUMsT0FBZ0I7UUFDL0IsT0FBTyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRUQsS0FBSyxDQUFDLE9BQVksRUFBRSxRQUFnQixFQUFFLEtBQWM7UUFDbEQsT0FBTyxXQUFXLENBQUMsT0FBTyxFQUFFLFFBQVEsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBRUQsWUFBWSxDQUFDLE9BQVksRUFBRSxJQUFZLEVBQUUsWUFBcUI7UUFDNUQsT0FBTyxZQUFZLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFFRCxPQUFPLENBQ0wsT0FBWSxFQUNaLFNBQThDLEVBQzlDLFFBQWdCLEVBQ2hCLEtBQWEsRUFDYixNQUFjLEVBQ2Qsa0JBQXFDLEVBQUU7UUFFdkMsTUFBTSxJQUFJLEdBQUcsS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUM7UUFDOUMsTUFBTSxhQUFhLEdBQXFDLEVBQUMsUUFBUSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUMsQ0FBQztRQUNoRixzRUFBc0U7UUFDdEUsd0VBQXdFO1FBQ3hFLElBQUksTUFBTSxFQUFFLENBQUM7WUFDWCxhQUFhLENBQUMsUUFBUSxDQUFDLEdBQUcsTUFBTSxDQUFDO1FBQ25DLENBQUM7UUFFRCxNQUFNLGNBQWMsR0FBa0IsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUNoRCxNQUFNLDJCQUEyQixHQUEwQixDQUN6RCxlQUFlLENBQUMsTUFBTSxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxNQUFNLFlBQVksbUJBQW1CLENBQUMsQ0FDMUUsQ0FBQztRQUNGLElBQUksOEJBQThCLENBQUMsUUFBUSxFQUFFLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDcEQsMkJBQTJCLENBQUMsT0FBTyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUU7Z0JBQzdDLE1BQU0sQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUMsR0FBRyxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQztZQUMvRSxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7UUFFRCxJQUFJLFVBQVUsR0FBRyxrQkFBa0IsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLElBQUksR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7UUFDaEYsVUFBVSxHQUFHLGtDQUFrQyxDQUFDLE9BQU8sRUFBRSxVQUFVLEVBQUUsY0FBYyxDQUFDLENBQUM7UUFDckYsTUFBTSxhQUFhLEdBQUcsMEJBQTBCLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQ3RFLE9BQU8sSUFBSSxtQkFBbUIsQ0FBQyxPQUFPLEVBQUUsVUFBVSxFQUFFLGFBQWEsRUFBRSxhQUFhLENBQUMsQ0FBQztJQUNwRixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7QW5pbWF0aW9uUGxheWVyLCDJtVN0eWxlRGF0YU1hcH0gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XG5cbmltcG9ydCB7XG4gIGFsbG93UHJldmlvdXNQbGF5ZXJTdHlsZXNNZXJnZSxcbiAgYmFsYW5jZVByZXZpb3VzU3R5bGVzSW50b0tleWZyYW1lcyxcbiAgY2FtZWxDYXNlVG9EYXNoQ2FzZSxcbiAgY29tcHV0ZVN0eWxlLFxuICBub3JtYWxpemVLZXlmcmFtZXMsXG59IGZyb20gJy4uLy4uL3V0aWwnO1xuaW1wb3J0IHtBbmltYXRpb25Ecml2ZXJ9IGZyb20gJy4uL2FuaW1hdGlvbl9kcml2ZXInO1xuaW1wb3J0IHtcbiAgY29udGFpbnNFbGVtZW50LFxuICBnZXRQYXJlbnRFbGVtZW50LFxuICBpbnZva2VRdWVyeSxcbiAgdmFsaWRhdGVTdHlsZVByb3BlcnR5LFxuICB2YWxpZGF0ZVdlYkFuaW1hdGFibGVTdHlsZVByb3BlcnR5LFxufSBmcm9tICcuLi9zaGFyZWQnO1xuaW1wb3J0IHtwYWNrYWdlTm9uQW5pbWF0YWJsZVN0eWxlc30gZnJvbSAnLi4vc3BlY2lhbF9jYXNlZF9zdHlsZXMnO1xuXG5pbXBvcnQge1dlYkFuaW1hdGlvbnNQbGF5ZXJ9IGZyb20gJy4vd2ViX2FuaW1hdGlvbnNfcGxheWVyJztcblxuZXhwb3J0IGNsYXNzIFdlYkFuaW1hdGlvbnNEcml2ZXIgaW1wbGVtZW50cyBBbmltYXRpb25Ecml2ZXIge1xuICB2YWxpZGF0ZVN0eWxlUHJvcGVydHkocHJvcDogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgLy8gUGVyZm9ybSBhY3R1YWwgdmFsaWRhdGlvbiBpbiBkZXYgbW9kZSBvbmx5LCBpbiBwcm9kIG1vZGUgdGhpcyBjaGVjayBpcyBhIG5vb3AuXG4gICAgaWYgKHR5cGVvZiBuZ0Rldk1vZGUgPT09ICd1bmRlZmluZWQnIHx8IG5nRGV2TW9kZSkge1xuICAgICAgcmV0dXJuIHZhbGlkYXRlU3R5bGVQcm9wZXJ0eShwcm9wKTtcbiAgICB9XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICB2YWxpZGF0ZUFuaW1hdGFibGVTdHlsZVByb3BlcnR5KHByb3A6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIC8vIFBlcmZvcm0gYWN0dWFsIHZhbGlkYXRpb24gaW4gZGV2IG1vZGUgb25seSwgaW4gcHJvZCBtb2RlIHRoaXMgY2hlY2sgaXMgYSBub29wLlxuICAgIGlmICh0eXBlb2YgbmdEZXZNb2RlID09PSAndW5kZWZpbmVkJyB8fCBuZ0Rldk1vZGUpIHtcbiAgICAgIGNvbnN0IGNzc1Byb3AgPSBjYW1lbENhc2VUb0Rhc2hDYXNlKHByb3ApO1xuICAgICAgcmV0dXJuIHZhbGlkYXRlV2ViQW5pbWF0YWJsZVN0eWxlUHJvcGVydHkoY3NzUHJvcCk7XG4gICAgfVxuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgY29udGFpbnNFbGVtZW50KGVsbTE6IGFueSwgZWxtMjogYW55KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIGNvbnRhaW5zRWxlbWVudChlbG0xLCBlbG0yKTtcbiAgfVxuXG4gIGdldFBhcmVudEVsZW1lbnQoZWxlbWVudDogdW5rbm93bik6IHVua25vd24ge1xuICAgIHJldHVybiBnZXRQYXJlbnRFbGVtZW50KGVsZW1lbnQpO1xuICB9XG5cbiAgcXVlcnkoZWxlbWVudDogYW55LCBzZWxlY3Rvcjogc3RyaW5nLCBtdWx0aTogYm9vbGVhbik6IGFueVtdIHtcbiAgICByZXR1cm4gaW52b2tlUXVlcnkoZWxlbWVudCwgc2VsZWN0b3IsIG11bHRpKTtcbiAgfVxuXG4gIGNvbXB1dGVTdHlsZShlbGVtZW50OiBhbnksIHByb3A6IHN0cmluZywgZGVmYXVsdFZhbHVlPzogc3RyaW5nKTogc3RyaW5nIHtcbiAgICByZXR1cm4gY29tcHV0ZVN0eWxlKGVsZW1lbnQsIHByb3ApO1xuICB9XG5cbiAgYW5pbWF0ZShcbiAgICBlbGVtZW50OiBhbnksXG4gICAga2V5ZnJhbWVzOiBBcnJheTxNYXA8c3RyaW5nLCBzdHJpbmcgfCBudW1iZXI+PixcbiAgICBkdXJhdGlvbjogbnVtYmVyLFxuICAgIGRlbGF5OiBudW1iZXIsXG4gICAgZWFzaW5nOiBzdHJpbmcsXG4gICAgcHJldmlvdXNQbGF5ZXJzOiBBbmltYXRpb25QbGF5ZXJbXSA9IFtdLFxuICApOiBBbmltYXRpb25QbGF5ZXIge1xuICAgIGNvbnN0IGZpbGwgPSBkZWxheSA9PSAwID8gJ2JvdGgnIDogJ2ZvcndhcmRzJztcbiAgICBjb25zdCBwbGF5ZXJPcHRpb25zOiB7W2tleTogc3RyaW5nXTogc3RyaW5nIHwgbnVtYmVyfSA9IHtkdXJhdGlvbiwgZGVsYXksIGZpbGx9O1xuICAgIC8vIHdlIGNoZWNrIGZvciB0aGlzIHRvIGF2b2lkIGhhdmluZyBhIG51bGx8dW5kZWZpbmVkIHZhbHVlIGJlIHByZXNlbnRcbiAgICAvLyBmb3IgdGhlIGVhc2luZyAod2hpY2ggcmVzdWx0cyBpbiBhbiBlcnJvciBmb3IgY2VydGFpbiBicm93c2VycyAjOTc1MilcbiAgICBpZiAoZWFzaW5nKSB7XG4gICAgICBwbGF5ZXJPcHRpb25zWydlYXNpbmcnXSA9IGVhc2luZztcbiAgICB9XG5cbiAgICBjb25zdCBwcmV2aW91c1N0eWxlczogybVTdHlsZURhdGFNYXAgPSBuZXcgTWFwKCk7XG4gICAgY29uc3QgcHJldmlvdXNXZWJBbmltYXRpb25QbGF5ZXJzID0gPFdlYkFuaW1hdGlvbnNQbGF5ZXJbXT4oXG4gICAgICBwcmV2aW91c1BsYXllcnMuZmlsdGVyKChwbGF5ZXIpID0+IHBsYXllciBpbnN0YW5jZW9mIFdlYkFuaW1hdGlvbnNQbGF5ZXIpXG4gICAgKTtcbiAgICBpZiAoYWxsb3dQcmV2aW91c1BsYXllclN0eWxlc01lcmdlKGR1cmF0aW9uLCBkZWxheSkpIHtcbiAgICAgIHByZXZpb3VzV2ViQW5pbWF0aW9uUGxheWVycy5mb3JFYWNoKChwbGF5ZXIpID0+IHtcbiAgICAgICAgcGxheWVyLmN1cnJlbnRTbmFwc2hvdC5mb3JFYWNoKCh2YWwsIHByb3ApID0+IHByZXZpb3VzU3R5bGVzLnNldChwcm9wLCB2YWwpKTtcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIGxldCBfa2V5ZnJhbWVzID0gbm9ybWFsaXplS2V5ZnJhbWVzKGtleWZyYW1lcykubWFwKChzdHlsZXMpID0+IG5ldyBNYXAoc3R5bGVzKSk7XG4gICAgX2tleWZyYW1lcyA9IGJhbGFuY2VQcmV2aW91c1N0eWxlc0ludG9LZXlmcmFtZXMoZWxlbWVudCwgX2tleWZyYW1lcywgcHJldmlvdXNTdHlsZXMpO1xuICAgIGNvbnN0IHNwZWNpYWxTdHlsZXMgPSBwYWNrYWdlTm9uQW5pbWF0YWJsZVN0eWxlcyhlbGVtZW50LCBfa2V5ZnJhbWVzKTtcbiAgICByZXR1cm4gbmV3IFdlYkFuaW1hdGlvbnNQbGF5ZXIoZWxlbWVudCwgX2tleWZyYW1lcywgcGxheWVyT3B0aW9ucywgc3BlY2lhbFN0eWxlcyk7XG4gIH1cbn1cbiJdfQ==
@@ -1,177 +0,0 @@
1
- import { computeStyle } from '../../util';
2
- export class WebAnimationsPlayer {
3
- constructor(element, keyframes, options, _specialStyles) {
4
- this.element = element;
5
- this.keyframes = keyframes;
6
- this.options = options;
7
- this._specialStyles = _specialStyles;
8
- this._onDoneFns = [];
9
- this._onStartFns = [];
10
- this._onDestroyFns = [];
11
- this._initialized = false;
12
- this._finished = false;
13
- this._started = false;
14
- this._destroyed = false;
15
- // the following original fns are persistent copies of the _onStartFns and _onDoneFns
16
- // and are used to reset the fns to their original values upon reset()
17
- // (since the _onStartFns and _onDoneFns get deleted after they are called)
18
- this._originalOnDoneFns = [];
19
- this._originalOnStartFns = [];
20
- this.time = 0;
21
- this.parentPlayer = null;
22
- this.currentSnapshot = new Map();
23
- this._duration = options['duration'];
24
- this._delay = options['delay'] || 0;
25
- this.time = this._duration + this._delay;
26
- }
27
- _onFinish() {
28
- if (!this._finished) {
29
- this._finished = true;
30
- this._onDoneFns.forEach((fn) => fn());
31
- this._onDoneFns = [];
32
- }
33
- }
34
- init() {
35
- this._buildPlayer();
36
- this._preparePlayerBeforeStart();
37
- }
38
- _buildPlayer() {
39
- if (this._initialized)
40
- return;
41
- this._initialized = true;
42
- const keyframes = this.keyframes;
43
- // @ts-expect-error overwriting a readonly property
44
- this.domPlayer = this._triggerWebAnimation(this.element, keyframes, this.options);
45
- this._finalKeyframe = keyframes.length ? keyframes[keyframes.length - 1] : new Map();
46
- const onFinish = () => this._onFinish();
47
- this.domPlayer.addEventListener('finish', onFinish);
48
- this.onDestroy(() => {
49
- // We must remove the `finish` event listener once an animation has completed all its
50
- // iterations. This action is necessary to prevent a memory leak since the listener captures
51
- // `this`, creating a closure that prevents `this` from being garbage collected.
52
- this.domPlayer.removeEventListener('finish', onFinish);
53
- });
54
- }
55
- _preparePlayerBeforeStart() {
56
- // this is required so that the player doesn't start to animate right away
57
- if (this._delay) {
58
- this._resetDomPlayerState();
59
- }
60
- else {
61
- this.domPlayer.pause();
62
- }
63
- }
64
- _convertKeyframesToObject(keyframes) {
65
- const kfs = [];
66
- keyframes.forEach((frame) => {
67
- kfs.push(Object.fromEntries(frame));
68
- });
69
- return kfs;
70
- }
71
- /** @internal */
72
- _triggerWebAnimation(element, keyframes, options) {
73
- return element.animate(this._convertKeyframesToObject(keyframes), options);
74
- }
75
- onStart(fn) {
76
- this._originalOnStartFns.push(fn);
77
- this._onStartFns.push(fn);
78
- }
79
- onDone(fn) {
80
- this._originalOnDoneFns.push(fn);
81
- this._onDoneFns.push(fn);
82
- }
83
- onDestroy(fn) {
84
- this._onDestroyFns.push(fn);
85
- }
86
- play() {
87
- this._buildPlayer();
88
- if (!this.hasStarted()) {
89
- this._onStartFns.forEach((fn) => fn());
90
- this._onStartFns = [];
91
- this._started = true;
92
- if (this._specialStyles) {
93
- this._specialStyles.start();
94
- }
95
- }
96
- this.domPlayer.play();
97
- }
98
- pause() {
99
- this.init();
100
- this.domPlayer.pause();
101
- }
102
- finish() {
103
- this.init();
104
- if (this._specialStyles) {
105
- this._specialStyles.finish();
106
- }
107
- this._onFinish();
108
- this.domPlayer.finish();
109
- }
110
- reset() {
111
- this._resetDomPlayerState();
112
- this._destroyed = false;
113
- this._finished = false;
114
- this._started = false;
115
- this._onStartFns = this._originalOnStartFns;
116
- this._onDoneFns = this._originalOnDoneFns;
117
- }
118
- _resetDomPlayerState() {
119
- if (this.domPlayer) {
120
- this.domPlayer.cancel();
121
- }
122
- }
123
- restart() {
124
- this.reset();
125
- this.play();
126
- }
127
- hasStarted() {
128
- return this._started;
129
- }
130
- destroy() {
131
- if (!this._destroyed) {
132
- this._destroyed = true;
133
- this._resetDomPlayerState();
134
- this._onFinish();
135
- if (this._specialStyles) {
136
- this._specialStyles.destroy();
137
- }
138
- this._onDestroyFns.forEach((fn) => fn());
139
- this._onDestroyFns = [];
140
- }
141
- }
142
- setPosition(p) {
143
- if (this.domPlayer === undefined) {
144
- this.init();
145
- }
146
- this.domPlayer.currentTime = p * this.time;
147
- }
148
- getPosition() {
149
- // tsc is complaining with TS2362 without the conversion to number
150
- return +(this.domPlayer.currentTime ?? 0) / this.time;
151
- }
152
- get totalTime() {
153
- return this._delay + this._duration;
154
- }
155
- beforeDestroy() {
156
- const styles = new Map();
157
- if (this.hasStarted()) {
158
- // note: this code is invoked only when the `play` function was called prior to this
159
- // (thus `hasStarted` returns true), this implies that the code that initializes
160
- // `_finalKeyframe` has also been executed and the non-null assertion can be safely used here
161
- const finalKeyframe = this._finalKeyframe;
162
- finalKeyframe.forEach((val, prop) => {
163
- if (prop !== 'offset') {
164
- styles.set(prop, this._finished ? val : computeStyle(this.element, prop));
165
- }
166
- });
167
- }
168
- this.currentSnapshot = styles;
169
- }
170
- /** @internal */
171
- triggerCallback(phaseName) {
172
- const methods = phaseName === 'start' ? this._onStartFns : this._onDoneFns;
173
- methods.forEach((fn) => fn());
174
- methods.length = 0;
175
- }
176
- }
177
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"web_animations_player.js","sourceRoot":"","sources":["../../../../../../../../../packages/animations/browser/src/render/web_animations/web_animations_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 {AnimationPlayer, ɵStyleDataMap} from '@angular/animations';\n\nimport {computeStyle} from '../../util';\nimport {SpecialCasedStyles} from '../special_cased_styles';\n\nexport class WebAnimationsPlayer implements AnimationPlayer {\n  private _onDoneFns: Function[] = [];\n  private _onStartFns: Function[] = [];\n  private _onDestroyFns: Function[] = [];\n  private _duration: number;\n  private _delay: number;\n  private _initialized = false;\n  private _finished = false;\n  private _started = false;\n  private _destroyed = false;\n  private _finalKeyframe?: ɵStyleDataMap;\n\n  // the following original fns are persistent copies of the _onStartFns and _onDoneFns\n  // and are used to reset the fns to their original values upon reset()\n  // (since the _onStartFns and _onDoneFns get deleted after they are called)\n  private _originalOnDoneFns: Function[] = [];\n  private _originalOnStartFns: Function[] = [];\n\n  // using non-null assertion because it's re(set) by init();\n  public readonly domPlayer!: Animation;\n  public time = 0;\n\n  public parentPlayer: AnimationPlayer | null = null;\n  public currentSnapshot: ɵStyleDataMap = new Map();\n\n  constructor(\n    public element: any,\n    public keyframes: Array<ɵStyleDataMap>,\n    public options: {[key: string]: string | number},\n    private _specialStyles?: SpecialCasedStyles | null,\n  ) {\n    this._duration = <number>options['duration'];\n    this._delay = <number>options['delay'] || 0;\n    this.time = this._duration + this._delay;\n  }\n\n  private _onFinish() {\n    if (!this._finished) {\n      this._finished = true;\n      this._onDoneFns.forEach((fn) => fn());\n      this._onDoneFns = [];\n    }\n  }\n\n  init(): void {\n    this._buildPlayer();\n    this._preparePlayerBeforeStart();\n  }\n\n  private _buildPlayer(): void {\n    if (this._initialized) return;\n    this._initialized = true;\n\n    const keyframes = this.keyframes;\n    // @ts-expect-error overwriting a readonly property\n    this.domPlayer = this._triggerWebAnimation(this.element, keyframes, this.options);\n    this._finalKeyframe = keyframes.length ? keyframes[keyframes.length - 1] : new Map();\n    const onFinish = () => this._onFinish();\n    this.domPlayer.addEventListener('finish', onFinish);\n    this.onDestroy(() => {\n      // We must remove the `finish` event listener once an animation has completed all its\n      // iterations. This action is necessary to prevent a memory leak since the listener captures\n      // `this`, creating a closure that prevents `this` from being garbage collected.\n      this.domPlayer.removeEventListener('finish', onFinish);\n    });\n  }\n\n  private _preparePlayerBeforeStart() {\n    // this is required so that the player doesn't start to animate right away\n    if (this._delay) {\n      this._resetDomPlayerState();\n    } else {\n      this.domPlayer.pause();\n    }\n  }\n\n  private _convertKeyframesToObject(keyframes: Array<ɵStyleDataMap>): any[] {\n    const kfs: any[] = [];\n    keyframes.forEach((frame) => {\n      kfs.push(Object.fromEntries(frame));\n    });\n    return kfs;\n  }\n\n  /** @internal */\n  _triggerWebAnimation(\n    element: HTMLElement,\n    keyframes: Array<ɵStyleDataMap>,\n    options: any,\n  ): Animation {\n    return element.animate(this._convertKeyframesToObject(keyframes), options);\n  }\n\n  onStart(fn: () => void): void {\n    this._originalOnStartFns.push(fn);\n    this._onStartFns.push(fn);\n  }\n\n  onDone(fn: () => void): void {\n    this._originalOnDoneFns.push(fn);\n    this._onDoneFns.push(fn);\n  }\n\n  onDestroy(fn: () => void): void {\n    this._onDestroyFns.push(fn);\n  }\n\n  play(): void {\n    this._buildPlayer();\n    if (!this.hasStarted()) {\n      this._onStartFns.forEach((fn) => fn());\n      this._onStartFns = [];\n      this._started = true;\n      if (this._specialStyles) {\n        this._specialStyles.start();\n      }\n    }\n    this.domPlayer.play();\n  }\n\n  pause(): void {\n    this.init();\n    this.domPlayer.pause();\n  }\n\n  finish(): void {\n    this.init();\n    if (this._specialStyles) {\n      this._specialStyles.finish();\n    }\n    this._onFinish();\n    this.domPlayer.finish();\n  }\n\n  reset(): void {\n    this._resetDomPlayerState();\n    this._destroyed = false;\n    this._finished = false;\n    this._started = false;\n    this._onStartFns = this._originalOnStartFns;\n    this._onDoneFns = this._originalOnDoneFns;\n  }\n\n  private _resetDomPlayerState() {\n    if (this.domPlayer) {\n      this.domPlayer.cancel();\n    }\n  }\n\n  restart(): void {\n    this.reset();\n    this.play();\n  }\n\n  hasStarted(): boolean {\n    return this._started;\n  }\n\n  destroy(): void {\n    if (!this._destroyed) {\n      this._destroyed = true;\n      this._resetDomPlayerState();\n      this._onFinish();\n      if (this._specialStyles) {\n        this._specialStyles.destroy();\n      }\n      this._onDestroyFns.forEach((fn) => fn());\n      this._onDestroyFns = [];\n    }\n  }\n\n  setPosition(p: number): void {\n    if (this.domPlayer === undefined) {\n      this.init();\n    }\n    this.domPlayer.currentTime = p * this.time;\n  }\n\n  getPosition(): number {\n    // tsc is complaining with TS2362 without the conversion to number\n    return +(this.domPlayer.currentTime ?? 0) / this.time;\n  }\n\n  get totalTime(): number {\n    return this._delay + this._duration;\n  }\n\n  beforeDestroy() {\n    const styles: ɵStyleDataMap = new Map();\n    if (this.hasStarted()) {\n      // note: this code is invoked only when the `play` function was called prior to this\n      // (thus `hasStarted` returns true), this implies that the code that initializes\n      // `_finalKeyframe` has also been executed and the non-null assertion can be safely used here\n      const finalKeyframe = this._finalKeyframe!;\n      finalKeyframe.forEach((val, prop) => {\n        if (prop !== 'offset') {\n          styles.set(prop, this._finished ? val : computeStyle(this.element, prop));\n        }\n      });\n    }\n\n    this.currentSnapshot = styles;\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"]}