@angular/animations 13.2.0 → 14.0.0-next.2
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 +7 -2
- package/browser/browser.d.ts +14 -89
- package/browser/testing/testing.d.ts +8 -15
- package/esm2020/browser/src/dsl/animation.mjs +1 -1
- package/esm2020/browser/src/dsl/animation_ast.mjs +1 -1
- package/esm2020/browser/src/dsl/animation_ast_builder.mjs +40 -49
- package/esm2020/browser/src/dsl/animation_dsl_visitor.mjs +1 -1
- package/esm2020/browser/src/dsl/animation_timeline_builder.mjs +77 -87
- package/esm2020/browser/src/dsl/animation_timeline_instruction.mjs +1 -1
- package/esm2020/browser/src/dsl/animation_transition_factory.mjs +20 -18
- package/esm2020/browser/src/dsl/animation_transition_instruction.mjs +8 -1
- package/esm2020/browser/src/dsl/animation_trigger.mjs +9 -9
- package/esm2020/browser/src/dsl/style_normalization/web_animations_style_normalizer.mjs +33 -9
- package/esm2020/browser/src/private_export.mjs +3 -5
- package/esm2020/browser/src/render/animation_driver.mjs +4 -4
- package/esm2020/browser/src/render/shared.mjs +18 -27
- package/esm2020/browser/src/render/special_cased_styles.mjs +7 -16
- package/esm2020/browser/src/render/timeline_animation_engine.mjs +15 -15
- package/esm2020/browser/src/render/transition_animation_engine.mjs +55 -73
- package/esm2020/browser/src/render/web_animations/web_animations_driver.mjs +10 -29
- package/esm2020/browser/src/render/web_animations/web_animations_player.mjs +16 -9
- package/esm2020/browser/src/util.mjs +38 -28
- package/esm2020/browser/testing/src/mock_animation_driver.mjs +14 -14
- package/esm2020/src/animation_metadata.mjs +1 -1
- package/esm2020/src/animations.mjs +1 -1
- package/esm2020/src/version.mjs +1 -1
- package/fesm2015/animations.mjs +1 -1
- package/fesm2015/animations.mjs.map +1 -1
- package/fesm2015/browser/testing.mjs +14 -14
- package/fesm2015/browser/testing.mjs.map +1 -1
- package/fesm2015/browser.mjs +336 -791
- package/fesm2015/browser.mjs.map +1 -1
- package/fesm2020/animations.mjs +1 -1
- package/fesm2020/animations.mjs.map +1 -1
- package/fesm2020/browser/testing.mjs +14 -14
- package/fesm2020/browser/testing.mjs.map +1 -1
- package/fesm2020/browser.mjs +334 -790
- package/fesm2020/browser.mjs.map +1 -1
- package/package.json +2 -2
- package/esm2020/browser/src/render/css_keyframes/css_keyframes_driver.mjs +0 -121
- package/esm2020/browser/src/render/css_keyframes/css_keyframes_player.mjs +0 -133
- package/esm2020/browser/src/render/css_keyframes/direct_style_player.mjs +0 -51
- package/esm2020/browser/src/render/css_keyframes/element_animation_style_handler.mjs +0 -137
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@angular/animations",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "14.0.0-next.2",
|
|
4
4
|
"description": "Angular - animations integration with web-animations",
|
|
5
5
|
"author": "angular",
|
|
6
6
|
"license": "MIT",
|
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
"tslib": "^2.3.0"
|
|
12
12
|
},
|
|
13
13
|
"peerDependencies": {
|
|
14
|
-
"@angular/core": "
|
|
14
|
+
"@angular/core": "14.0.0-next.2"
|
|
15
15
|
},
|
|
16
16
|
"repository": {
|
|
17
17
|
"type": "git",
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
import { allowPreviousPlayerStylesMerge, balancePreviousStylesIntoKeyframes } from '../../util';
|
|
2
|
-
import { containsElement, hypenatePropsObject, invokeQuery, validateStyleProperty } from '../shared';
|
|
3
|
-
import { packageNonAnimatableStyles } from '../special_cased_styles';
|
|
4
|
-
import { CssKeyframesPlayer } from './css_keyframes_player';
|
|
5
|
-
import { DirectStylePlayer } from './direct_style_player';
|
|
6
|
-
const KEYFRAMES_NAME_PREFIX = 'gen_css_kf_';
|
|
7
|
-
const TAB_SPACE = ' ';
|
|
8
|
-
export class CssKeyframesDriver {
|
|
9
|
-
constructor() {
|
|
10
|
-
this._count = 0;
|
|
11
|
-
}
|
|
12
|
-
validateStyleProperty(prop) {
|
|
13
|
-
return validateStyleProperty(prop);
|
|
14
|
-
}
|
|
15
|
-
matchesElement(_element, _selector) {
|
|
16
|
-
// This method is deprecated and no longer in use so we return false.
|
|
17
|
-
return false;
|
|
18
|
-
}
|
|
19
|
-
containsElement(elm1, elm2) {
|
|
20
|
-
return containsElement(elm1, elm2);
|
|
21
|
-
}
|
|
22
|
-
query(element, selector, multi) {
|
|
23
|
-
return invokeQuery(element, selector, multi);
|
|
24
|
-
}
|
|
25
|
-
computeStyle(element, prop, defaultValue) {
|
|
26
|
-
return window.getComputedStyle(element)[prop];
|
|
27
|
-
}
|
|
28
|
-
buildKeyframeElement(element, name, keyframes) {
|
|
29
|
-
keyframes = keyframes.map(kf => hypenatePropsObject(kf));
|
|
30
|
-
let keyframeStr = `@keyframes ${name} {\n`;
|
|
31
|
-
let tab = '';
|
|
32
|
-
keyframes.forEach(kf => {
|
|
33
|
-
tab = TAB_SPACE;
|
|
34
|
-
const offset = parseFloat(kf['offset']);
|
|
35
|
-
keyframeStr += `${tab}${offset * 100}% {\n`;
|
|
36
|
-
tab += TAB_SPACE;
|
|
37
|
-
Object.keys(kf).forEach(prop => {
|
|
38
|
-
const value = kf[prop];
|
|
39
|
-
switch (prop) {
|
|
40
|
-
case 'offset':
|
|
41
|
-
return;
|
|
42
|
-
case 'easing':
|
|
43
|
-
if (value) {
|
|
44
|
-
keyframeStr += `${tab}animation-timing-function: ${value};\n`;
|
|
45
|
-
}
|
|
46
|
-
return;
|
|
47
|
-
default:
|
|
48
|
-
keyframeStr += `${tab}${prop}: ${value};\n`;
|
|
49
|
-
return;
|
|
50
|
-
}
|
|
51
|
-
});
|
|
52
|
-
keyframeStr += `${tab}}\n`;
|
|
53
|
-
});
|
|
54
|
-
keyframeStr += `}\n`;
|
|
55
|
-
const kfElm = document.createElement('style');
|
|
56
|
-
kfElm.textContent = keyframeStr;
|
|
57
|
-
return kfElm;
|
|
58
|
-
}
|
|
59
|
-
animate(element, keyframes, duration, delay, easing, previousPlayers = [], scrubberAccessRequested) {
|
|
60
|
-
if ((typeof ngDevMode === 'undefined' || ngDevMode) && scrubberAccessRequested) {
|
|
61
|
-
notifyFaultyScrubber();
|
|
62
|
-
}
|
|
63
|
-
const previousCssKeyframePlayers = previousPlayers.filter(player => player instanceof CssKeyframesPlayer);
|
|
64
|
-
const previousStyles = {};
|
|
65
|
-
if (allowPreviousPlayerStylesMerge(duration, delay)) {
|
|
66
|
-
previousCssKeyframePlayers.forEach(player => {
|
|
67
|
-
let styles = player.currentSnapshot;
|
|
68
|
-
Object.keys(styles).forEach(prop => previousStyles[prop] = styles[prop]);
|
|
69
|
-
});
|
|
70
|
-
}
|
|
71
|
-
keyframes = balancePreviousStylesIntoKeyframes(element, keyframes, previousStyles);
|
|
72
|
-
const finalStyles = flattenKeyframesIntoStyles(keyframes);
|
|
73
|
-
// if there is no animation then there is no point in applying
|
|
74
|
-
// styles and waiting for an event to get fired. This causes lag.
|
|
75
|
-
// It's better to just directly apply the styles to the element
|
|
76
|
-
// via the direct styling animation player.
|
|
77
|
-
if (duration == 0) {
|
|
78
|
-
return new DirectStylePlayer(element, finalStyles);
|
|
79
|
-
}
|
|
80
|
-
const animationName = `${KEYFRAMES_NAME_PREFIX}${this._count++}`;
|
|
81
|
-
const kfElm = this.buildKeyframeElement(element, animationName, keyframes);
|
|
82
|
-
const nodeToAppendKfElm = findNodeToAppendKeyframeElement(element);
|
|
83
|
-
nodeToAppendKfElm.appendChild(kfElm);
|
|
84
|
-
const specialStyles = packageNonAnimatableStyles(element, keyframes);
|
|
85
|
-
const player = new CssKeyframesPlayer(element, keyframes, animationName, duration, delay, easing, finalStyles, specialStyles);
|
|
86
|
-
player.onDestroy(() => removeElement(kfElm));
|
|
87
|
-
return player;
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
function findNodeToAppendKeyframeElement(element) {
|
|
91
|
-
const rootNode = element.getRootNode?.();
|
|
92
|
-
if (typeof ShadowRoot !== 'undefined' && rootNode instanceof ShadowRoot) {
|
|
93
|
-
return rootNode;
|
|
94
|
-
}
|
|
95
|
-
return document.head;
|
|
96
|
-
}
|
|
97
|
-
function flattenKeyframesIntoStyles(keyframes) {
|
|
98
|
-
let flatKeyframes = {};
|
|
99
|
-
if (keyframes) {
|
|
100
|
-
const kfs = Array.isArray(keyframes) ? keyframes : [keyframes];
|
|
101
|
-
kfs.forEach(kf => {
|
|
102
|
-
Object.keys(kf).forEach(prop => {
|
|
103
|
-
if (prop == 'offset' || prop == 'easing')
|
|
104
|
-
return;
|
|
105
|
-
flatKeyframes[prop] = kf[prop];
|
|
106
|
-
});
|
|
107
|
-
});
|
|
108
|
-
}
|
|
109
|
-
return flatKeyframes;
|
|
110
|
-
}
|
|
111
|
-
function removeElement(node) {
|
|
112
|
-
node.parentNode.removeChild(node);
|
|
113
|
-
}
|
|
114
|
-
let warningIssued = false;
|
|
115
|
-
function notifyFaultyScrubber() {
|
|
116
|
-
if (warningIssued)
|
|
117
|
-
return;
|
|
118
|
-
console.warn('@angular/animations: please load the web-animations.js polyfill to allow programmatic access...\n', ' visit https://bit.ly/IWukam to learn more about using the web-animation-js polyfill.');
|
|
119
|
-
warningIssued = true;
|
|
120
|
-
}
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"css_keyframes_driver.js","sourceRoot":"","sources":["../../../../../../../../../packages/animations/browser/src/render/css_keyframes/css_keyframes_driver.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, ɵStyleData} from '@angular/animations';\n\nimport {allowPreviousPlayerStylesMerge, balancePreviousStylesIntoKeyframes, computeStyle} from '../../util';\nimport {AnimationDriver} from '../animation_driver';\nimport {containsElement, hypenatePropsObject, invokeQuery, validateStyleProperty} from '../shared';\nimport {packageNonAnimatableStyles} from '../special_cased_styles';\n\nimport {CssKeyframesPlayer} from './css_keyframes_player';\nimport {DirectStylePlayer} from './direct_style_player';\n\nconst KEYFRAMES_NAME_PREFIX = 'gen_css_kf_';\nconst TAB_SPACE = ' ';\n\nexport class CssKeyframesDriver implements AnimationDriver {\n  private _count = 0;\n\n  validateStyleProperty(prop: string): boolean {\n    return validateStyleProperty(prop);\n  }\n\n  matchesElement(_element: any, _selector: string): boolean {\n    // This method is deprecated and no longer in use so we return false.\n    return false;\n  }\n\n  containsElement(elm1: any, elm2: any): boolean {\n    return containsElement(elm1, elm2);\n  }\n\n  query(element: any, selector: string, multi: boolean): any[] {\n    return invokeQuery(element, selector, multi);\n  }\n\n  computeStyle(element: any, prop: string, defaultValue?: string): string {\n    return (window.getComputedStyle(element) as any)[prop] as string;\n  }\n\n  buildKeyframeElement(element: any, name: string, keyframes: {[key: string]: any}[]): any {\n    keyframes = keyframes.map(kf => hypenatePropsObject(kf));\n    let keyframeStr = `@keyframes ${name} {\\n`;\n    let tab = '';\n    keyframes.forEach(kf => {\n      tab = TAB_SPACE;\n      const offset = parseFloat(kf['offset']);\n      keyframeStr += `${tab}${offset * 100}% {\\n`;\n      tab += TAB_SPACE;\n      Object.keys(kf).forEach(prop => {\n        const value = kf[prop];\n        switch (prop) {\n          case 'offset':\n            return;\n          case 'easing':\n            if (value) {\n              keyframeStr += `${tab}animation-timing-function: ${value};\\n`;\n            }\n            return;\n          default:\n            keyframeStr += `${tab}${prop}: ${value};\\n`;\n            return;\n        }\n      });\n      keyframeStr += `${tab}}\\n`;\n    });\n    keyframeStr += `}\\n`;\n\n    const kfElm = document.createElement('style');\n    kfElm.textContent = keyframeStr;\n    return kfElm;\n  }\n\n  animate(\n      element: any, keyframes: ɵStyleData[], duration: number, delay: number, easing: string,\n      previousPlayers: AnimationPlayer[] = [], scrubberAccessRequested?: boolean): AnimationPlayer {\n    if ((typeof ngDevMode === 'undefined' || ngDevMode) && scrubberAccessRequested) {\n      notifyFaultyScrubber();\n    }\n\n    const previousCssKeyframePlayers = <CssKeyframesPlayer[]>previousPlayers.filter(\n        player => player instanceof CssKeyframesPlayer);\n\n    const previousStyles: {[key: string]: any} = {};\n\n    if (allowPreviousPlayerStylesMerge(duration, delay)) {\n      previousCssKeyframePlayers.forEach(player => {\n        let styles = player.currentSnapshot;\n        Object.keys(styles).forEach(prop => previousStyles[prop] = styles[prop]);\n      });\n    }\n\n    keyframes = balancePreviousStylesIntoKeyframes(element, keyframes, previousStyles);\n    const finalStyles = flattenKeyframesIntoStyles(keyframes);\n\n    // if there is no animation then there is no point in applying\n    // styles and waiting for an event to get fired. This causes lag.\n    // It's better to just directly apply the styles to the element\n    // via the direct styling animation player.\n    if (duration == 0) {\n      return new DirectStylePlayer(element, finalStyles);\n    }\n\n    const animationName = `${KEYFRAMES_NAME_PREFIX}${this._count++}`;\n    const kfElm = this.buildKeyframeElement(element, animationName, keyframes);\n    const nodeToAppendKfElm = findNodeToAppendKeyframeElement(element);\n    nodeToAppendKfElm.appendChild(kfElm);\n\n    const specialStyles = packageNonAnimatableStyles(element, keyframes);\n    const player = new CssKeyframesPlayer(\n        element, keyframes, animationName, duration, delay, easing, finalStyles, specialStyles);\n\n    player.onDestroy(() => removeElement(kfElm));\n    return player;\n  }\n}\n\nfunction findNodeToAppendKeyframeElement(element: any): Node {\n  const rootNode = element.getRootNode?.();\n  if (typeof ShadowRoot !== 'undefined' && rootNode instanceof ShadowRoot) {\n    return rootNode;\n  }\n  return document.head;\n}\n\nfunction flattenKeyframesIntoStyles(keyframes: null|{[key: string]: any}|\n                                    {[key: string]: any}[]): {[key: string]: any} {\n  let flatKeyframes: {[key: string]: any} = {};\n  if (keyframes) {\n    const kfs = Array.isArray(keyframes) ? keyframes : [keyframes];\n    kfs.forEach(kf => {\n      Object.keys(kf).forEach(prop => {\n        if (prop == 'offset' || prop == 'easing') return;\n        flatKeyframes[prop] = kf[prop];\n      });\n    });\n  }\n  return flatKeyframes;\n}\n\nfunction removeElement(node: any) {\n  node.parentNode.removeChild(node);\n}\n\nlet warningIssued = false;\nfunction notifyFaultyScrubber(): void {\n  if (warningIssued) return;\n  console.warn(\n      '@angular/animations: please load the web-animations.js polyfill to allow programmatic access...\\n',\n      '  visit https://bit.ly/IWukam to learn more about using the web-animation-js polyfill.');\n  warningIssued = true;\n}\n"]}
|
|
@@ -1,133 +0,0 @@
|
|
|
1
|
-
import { computeStyle } from '../../util';
|
|
2
|
-
import { ElementAnimationStyleHandler } from './element_animation_style_handler';
|
|
3
|
-
const DEFAULT_FILL_MODE = 'forwards';
|
|
4
|
-
const DEFAULT_EASING = 'linear';
|
|
5
|
-
export class CssKeyframesPlayer {
|
|
6
|
-
constructor(element, keyframes, animationName, _duration, _delay, easing, _finalStyles, _specialStyles) {
|
|
7
|
-
this.element = element;
|
|
8
|
-
this.keyframes = keyframes;
|
|
9
|
-
this.animationName = animationName;
|
|
10
|
-
this._duration = _duration;
|
|
11
|
-
this._delay = _delay;
|
|
12
|
-
this._finalStyles = _finalStyles;
|
|
13
|
-
this._specialStyles = _specialStyles;
|
|
14
|
-
this._onDoneFns = [];
|
|
15
|
-
this._onStartFns = [];
|
|
16
|
-
this._onDestroyFns = [];
|
|
17
|
-
this.currentSnapshot = {};
|
|
18
|
-
this._state = 0;
|
|
19
|
-
this.easing = easing || DEFAULT_EASING;
|
|
20
|
-
this.totalTime = _duration + _delay;
|
|
21
|
-
this._buildStyler();
|
|
22
|
-
}
|
|
23
|
-
onStart(fn) {
|
|
24
|
-
this._onStartFns.push(fn);
|
|
25
|
-
}
|
|
26
|
-
onDone(fn) {
|
|
27
|
-
this._onDoneFns.push(fn);
|
|
28
|
-
}
|
|
29
|
-
onDestroy(fn) {
|
|
30
|
-
this._onDestroyFns.push(fn);
|
|
31
|
-
}
|
|
32
|
-
destroy() {
|
|
33
|
-
this.init();
|
|
34
|
-
if (this._state >= 4 /* DESTROYED */)
|
|
35
|
-
return;
|
|
36
|
-
this._state = 4 /* DESTROYED */;
|
|
37
|
-
this._styler.destroy();
|
|
38
|
-
this._flushStartFns();
|
|
39
|
-
this._flushDoneFns();
|
|
40
|
-
if (this._specialStyles) {
|
|
41
|
-
this._specialStyles.destroy();
|
|
42
|
-
}
|
|
43
|
-
this._onDestroyFns.forEach(fn => fn());
|
|
44
|
-
this._onDestroyFns = [];
|
|
45
|
-
}
|
|
46
|
-
_flushDoneFns() {
|
|
47
|
-
this._onDoneFns.forEach(fn => fn());
|
|
48
|
-
this._onDoneFns = [];
|
|
49
|
-
}
|
|
50
|
-
_flushStartFns() {
|
|
51
|
-
this._onStartFns.forEach(fn => fn());
|
|
52
|
-
this._onStartFns = [];
|
|
53
|
-
}
|
|
54
|
-
finish() {
|
|
55
|
-
this.init();
|
|
56
|
-
if (this._state >= 3 /* FINISHED */)
|
|
57
|
-
return;
|
|
58
|
-
this._state = 3 /* FINISHED */;
|
|
59
|
-
this._styler.finish();
|
|
60
|
-
this._flushStartFns();
|
|
61
|
-
if (this._specialStyles) {
|
|
62
|
-
this._specialStyles.finish();
|
|
63
|
-
}
|
|
64
|
-
this._flushDoneFns();
|
|
65
|
-
}
|
|
66
|
-
setPosition(value) {
|
|
67
|
-
this._styler.setPosition(value);
|
|
68
|
-
}
|
|
69
|
-
getPosition() {
|
|
70
|
-
return this._styler.getPosition();
|
|
71
|
-
}
|
|
72
|
-
hasStarted() {
|
|
73
|
-
return this._state >= 2 /* STARTED */;
|
|
74
|
-
}
|
|
75
|
-
init() {
|
|
76
|
-
if (this._state >= 1 /* INITIALIZED */)
|
|
77
|
-
return;
|
|
78
|
-
this._state = 1 /* INITIALIZED */;
|
|
79
|
-
const elm = this.element;
|
|
80
|
-
this._styler.apply();
|
|
81
|
-
if (this._delay) {
|
|
82
|
-
this._styler.pause();
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
play() {
|
|
86
|
-
this.init();
|
|
87
|
-
if (!this.hasStarted()) {
|
|
88
|
-
this._flushStartFns();
|
|
89
|
-
this._state = 2 /* STARTED */;
|
|
90
|
-
if (this._specialStyles) {
|
|
91
|
-
this._specialStyles.start();
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
this._styler.resume();
|
|
95
|
-
}
|
|
96
|
-
pause() {
|
|
97
|
-
this.init();
|
|
98
|
-
this._styler.pause();
|
|
99
|
-
}
|
|
100
|
-
restart() {
|
|
101
|
-
this.reset();
|
|
102
|
-
this.play();
|
|
103
|
-
}
|
|
104
|
-
reset() {
|
|
105
|
-
this._state = 0 /* RESET */;
|
|
106
|
-
this._styler.destroy();
|
|
107
|
-
this._buildStyler();
|
|
108
|
-
this._styler.apply();
|
|
109
|
-
}
|
|
110
|
-
_buildStyler() {
|
|
111
|
-
this._styler = new ElementAnimationStyleHandler(this.element, this.animationName, this._duration, this._delay, this.easing, DEFAULT_FILL_MODE, () => this.finish());
|
|
112
|
-
}
|
|
113
|
-
/** @internal */
|
|
114
|
-
triggerCallback(phaseName) {
|
|
115
|
-
const methods = phaseName == 'start' ? this._onStartFns : this._onDoneFns;
|
|
116
|
-
methods.forEach(fn => fn());
|
|
117
|
-
methods.length = 0;
|
|
118
|
-
}
|
|
119
|
-
beforeDestroy() {
|
|
120
|
-
this.init();
|
|
121
|
-
const styles = {};
|
|
122
|
-
if (this.hasStarted()) {
|
|
123
|
-
const finished = this._state >= 3 /* FINISHED */;
|
|
124
|
-
Object.keys(this._finalStyles).forEach(prop => {
|
|
125
|
-
if (prop != 'offset') {
|
|
126
|
-
styles[prop] = finished ? this._finalStyles[prop] : computeStyle(this.element, prop);
|
|
127
|
-
}
|
|
128
|
-
});
|
|
129
|
-
}
|
|
130
|
-
this.currentSnapshot = styles;
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"css_keyframes_player.js","sourceRoot":"","sources":["../../../../../../../../../packages/animations/browser/src/render/css_keyframes/css_keyframes_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} from '@angular/animations';\n\nimport {computeStyle} from '../../util';\nimport {SpecialCasedStyles} from '../special_cased_styles';\nimport {ElementAnimationStyleHandler} from './element_animation_style_handler';\n\nconst DEFAULT_FILL_MODE = 'forwards';\nconst DEFAULT_EASING = 'linear';\n\nexport const enum AnimatorControlState {\n  RESET = 0,\n  INITIALIZED = 1,\n  STARTED = 2,\n  FINISHED = 3,\n  DESTROYED = 4\n}\n\nexport class CssKeyframesPlayer implements AnimationPlayer {\n  private _onDoneFns: Function[] = [];\n  private _onStartFns: Function[] = [];\n  private _onDestroyFns: Function[] = [];\n\n  // TODO(issue/24571): remove '!'.\n  private _styler!: ElementAnimationStyleHandler;\n\n  // TODO(issue/24571): remove '!'.\n  public parentPlayer!: AnimationPlayer;\n  public readonly totalTime: number;\n  public readonly easing: string;\n  public currentSnapshot: {[key: string]: string} = {};\n\n  private _state: AnimatorControlState = 0;\n\n  constructor(\n      public readonly element: any, public readonly keyframes: {[key: string]: string|number}[],\n      public readonly animationName: string, private readonly _duration: number,\n      private readonly _delay: number, easing: string,\n      private readonly _finalStyles: {[key: string]: any},\n      private readonly _specialStyles?: SpecialCasedStyles|null) {\n    this.easing = easing || DEFAULT_EASING;\n    this.totalTime = _duration + _delay;\n    this._buildStyler();\n  }\n\n  onStart(fn: () => void): void {\n    this._onStartFns.push(fn);\n  }\n\n  onDone(fn: () => void): void {\n    this._onDoneFns.push(fn);\n  }\n\n  onDestroy(fn: () => void): void {\n    this._onDestroyFns.push(fn);\n  }\n\n  destroy() {\n    this.init();\n    if (this._state >= AnimatorControlState.DESTROYED) return;\n    this._state = AnimatorControlState.DESTROYED;\n    this._styler.destroy();\n    this._flushStartFns();\n    this._flushDoneFns();\n    if (this._specialStyles) {\n      this._specialStyles.destroy();\n    }\n    this._onDestroyFns.forEach(fn => fn());\n    this._onDestroyFns = [];\n  }\n\n  private _flushDoneFns() {\n    this._onDoneFns.forEach(fn => fn());\n    this._onDoneFns = [];\n  }\n\n  private _flushStartFns() {\n    this._onStartFns.forEach(fn => fn());\n    this._onStartFns = [];\n  }\n\n  finish() {\n    this.init();\n    if (this._state >= AnimatorControlState.FINISHED) return;\n    this._state = AnimatorControlState.FINISHED;\n    this._styler.finish();\n    this._flushStartFns();\n    if (this._specialStyles) {\n      this._specialStyles.finish();\n    }\n    this._flushDoneFns();\n  }\n\n  setPosition(value: number) {\n    this._styler.setPosition(value);\n  }\n\n  getPosition(): number {\n    return this._styler.getPosition();\n  }\n\n  hasStarted(): boolean {\n    return this._state >= AnimatorControlState.STARTED;\n  }\n  init(): void {\n    if (this._state >= AnimatorControlState.INITIALIZED) return;\n    this._state = AnimatorControlState.INITIALIZED;\n    const elm = this.element;\n    this._styler.apply();\n    if (this._delay) {\n      this._styler.pause();\n    }\n  }\n\n  play(): void {\n    this.init();\n    if (!this.hasStarted()) {\n      this._flushStartFns();\n      this._state = AnimatorControlState.STARTED;\n      if (this._specialStyles) {\n        this._specialStyles.start();\n      }\n    }\n    this._styler.resume();\n  }\n\n  pause(): void {\n    this.init();\n    this._styler.pause();\n  }\n  restart(): void {\n    this.reset();\n    this.play();\n  }\n  reset(): void {\n    this._state = AnimatorControlState.RESET;\n    this._styler.destroy();\n    this._buildStyler();\n    this._styler.apply();\n  }\n\n  private _buildStyler() {\n    this._styler = new ElementAnimationStyleHandler(\n        this.element, this.animationName, this._duration, this._delay, this.easing,\n        DEFAULT_FILL_MODE, () => this.finish());\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  beforeDestroy() {\n    this.init();\n    const styles: {[key: string]: string} = {};\n    if (this.hasStarted()) {\n      const finished = this._state >= AnimatorControlState.FINISHED;\n      Object.keys(this._finalStyles).forEach(prop => {\n        if (prop != 'offset') {\n          styles[prop] = finished ? this._finalStyles[prop] : computeStyle(this.element, prop);\n        }\n      });\n    }\n    this.currentSnapshot = styles;\n  }\n}\n"]}
|
|
@@ -1,51 +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
|
-
import { NoopAnimationPlayer } from '@angular/animations';
|
|
9
|
-
import { hypenatePropsObject } from '../shared';
|
|
10
|
-
export class DirectStylePlayer extends NoopAnimationPlayer {
|
|
11
|
-
constructor(element, styles) {
|
|
12
|
-
super();
|
|
13
|
-
this.element = element;
|
|
14
|
-
this._startingStyles = {};
|
|
15
|
-
this.__initialized = false;
|
|
16
|
-
this._styles = hypenatePropsObject(styles);
|
|
17
|
-
}
|
|
18
|
-
init() {
|
|
19
|
-
if (this.__initialized || !this._startingStyles)
|
|
20
|
-
return;
|
|
21
|
-
this.__initialized = true;
|
|
22
|
-
Object.keys(this._styles).forEach(prop => {
|
|
23
|
-
this._startingStyles[prop] = this.element.style[prop];
|
|
24
|
-
});
|
|
25
|
-
super.init();
|
|
26
|
-
}
|
|
27
|
-
play() {
|
|
28
|
-
if (!this._startingStyles)
|
|
29
|
-
return;
|
|
30
|
-
this.init();
|
|
31
|
-
Object.keys(this._styles)
|
|
32
|
-
.forEach(prop => this.element.style.setProperty(prop, this._styles[prop]));
|
|
33
|
-
super.play();
|
|
34
|
-
}
|
|
35
|
-
destroy() {
|
|
36
|
-
if (!this._startingStyles)
|
|
37
|
-
return;
|
|
38
|
-
Object.keys(this._startingStyles).forEach(prop => {
|
|
39
|
-
const value = this._startingStyles[prop];
|
|
40
|
-
if (value) {
|
|
41
|
-
this.element.style.setProperty(prop, value);
|
|
42
|
-
}
|
|
43
|
-
else {
|
|
44
|
-
this.element.style.removeProperty(prop);
|
|
45
|
-
}
|
|
46
|
-
});
|
|
47
|
-
this._startingStyles = null;
|
|
48
|
-
super.destroy();
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0X3N0eWxlX3BsYXllci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuaW1hdGlvbnMvYnJvd3Nlci9zcmMvcmVuZGVyL2Nzc19rZXlmcmFtZXMvZGlyZWN0X3N0eWxlX3BsYXllci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFDSCxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUN4RCxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSxXQUFXLENBQUM7QUFFOUMsTUFBTSxPQUFPLGlCQUFrQixTQUFRLG1CQUFtQjtJQUt4RCxZQUFtQixPQUFZLEVBQUUsTUFBNEI7UUFDM0QsS0FBSyxFQUFFLENBQUM7UUFEUyxZQUFPLEdBQVAsT0FBTyxDQUFLO1FBSnZCLG9CQUFlLEdBQThCLEVBQUUsQ0FBQztRQUNoRCxrQkFBYSxHQUFHLEtBQUssQ0FBQztRQUs1QixJQUFJLENBQUMsT0FBTyxHQUFHLG1CQUFtQixDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFFUSxJQUFJO1FBQ1gsSUFBSSxJQUFJLENBQUMsYUFBYSxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWU7WUFBRSxPQUFPO1FBQ3hELElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDO1FBQzFCLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUN2QyxJQUFJLENBQUMsZUFBZ0IsQ0FBQyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6RCxDQUFDLENBQUMsQ0FBQztRQUNILEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNmLENBQUM7SUFFUSxJQUFJO1FBQ1gsSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlO1lBQUUsT0FBTztRQUNsQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDWixNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7YUFDcEIsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMvRSxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDZixDQUFDO0lBRVEsT0FBTztRQUNkLElBQUksQ0FBQyxJQUFJLENBQUMsZUFBZTtZQUFFLE9BQU87UUFDbEMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQy9DLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxlQUFnQixDQUFDLElBQUksQ0FBQyxDQUFDO1lBQzFDLElBQUksS0FBSyxFQUFFO2dCQUNULElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUM7YUFDN0M7aUJBQU07Z0JBQ0wsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxDQUFDO2FBQ3pDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQztRQUM1QixLQUFLLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDbEIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge05vb3BBbmltYXRpb25QbGF5ZXJ9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHtoeXBlbmF0ZVByb3BzT2JqZWN0fSBmcm9tICcuLi9zaGFyZWQnO1xuXG5leHBvcnQgY2xhc3MgRGlyZWN0U3R5bGVQbGF5ZXIgZXh0ZW5kcyBOb29wQW5pbWF0aW9uUGxheWVyIHtcbiAgcHJpdmF0ZSBfc3RhcnRpbmdTdHlsZXM6IHtba2V5OiBzdHJpbmddOiBhbnl9fG51bGwgPSB7fTtcbiAgcHJpdmF0ZSBfX2luaXRpYWxpemVkID0gZmFsc2U7XG4gIHByaXZhdGUgX3N0eWxlczoge1trZXk6IHN0cmluZ106IGFueX07XG5cbiAgY29uc3RydWN0b3IocHVibGljIGVsZW1lbnQ6IGFueSwgc3R5bGVzOiB7W2tleTogc3RyaW5nXTogYW55fSkge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5fc3R5bGVzID0gaHlwZW5hdGVQcm9wc09iamVjdChzdHlsZXMpO1xuICB9XG5cbiAgb3ZlcnJpZGUgaW5pdCgpIHtcbiAgICBpZiAodGhpcy5fX2luaXRpYWxpemVkIHx8ICF0aGlzLl9zdGFydGluZ1N0eWxlcykgcmV0dXJuO1xuICAgIHRoaXMuX19pbml0aWFsaXplZCA9IHRydWU7XG4gICAgT2JqZWN0LmtleXModGhpcy5fc3R5bGVzKS5mb3JFYWNoKHByb3AgPT4ge1xuICAgICAgdGhpcy5fc3RhcnRpbmdTdHlsZXMhW3Byb3BdID0gdGhpcy5lbGVtZW50LnN0eWxlW3Byb3BdO1xuICAgIH0pO1xuICAgIHN1cGVyLmluaXQoKTtcbiAgfVxuXG4gIG92ZXJyaWRlIHBsYXkoKSB7XG4gICAgaWYgKCF0aGlzLl9zdGFydGluZ1N0eWxlcykgcmV0dXJuO1xuICAgIHRoaXMuaW5pdCgpO1xuICAgIE9iamVjdC5rZXlzKHRoaXMuX3N0eWxlcylcbiAgICAgICAgLmZvckVhY2gocHJvcCA9PiB0aGlzLmVsZW1lbnQuc3R5bGUuc2V0UHJvcGVydHkocHJvcCwgdGhpcy5fc3R5bGVzW3Byb3BdKSk7XG4gICAgc3VwZXIucGxheSgpO1xuICB9XG5cbiAgb3ZlcnJpZGUgZGVzdHJveSgpIHtcbiAgICBpZiAoIXRoaXMuX3N0YXJ0aW5nU3R5bGVzKSByZXR1cm47XG4gICAgT2JqZWN0LmtleXModGhpcy5fc3RhcnRpbmdTdHlsZXMpLmZvckVhY2gocHJvcCA9PiB7XG4gICAgICBjb25zdCB2YWx1ZSA9IHRoaXMuX3N0YXJ0aW5nU3R5bGVzIVtwcm9wXTtcbiAgICAgIGlmICh2YWx1ZSkge1xuICAgICAgICB0aGlzLmVsZW1lbnQuc3R5bGUuc2V0UHJvcGVydHkocHJvcCwgdmFsdWUpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdGhpcy5lbGVtZW50LnN0eWxlLnJlbW92ZVByb3BlcnR5KHByb3ApO1xuICAgICAgfVxuICAgIH0pO1xuICAgIHRoaXMuX3N0YXJ0aW5nU3R5bGVzID0gbnVsbDtcbiAgICBzdXBlci5kZXN0cm95KCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,137 +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
|
-
const ELAPSED_TIME_MAX_DECIMAL_PLACES = 3;
|
|
9
|
-
const ANIMATION_PROP = 'animation';
|
|
10
|
-
const ANIMATIONEND_EVENT = 'animationend';
|
|
11
|
-
const ONE_SECOND = 1000;
|
|
12
|
-
export class ElementAnimationStyleHandler {
|
|
13
|
-
constructor(_element, _name, _duration, _delay, _easing, _fillMode, _onDoneFn) {
|
|
14
|
-
this._element = _element;
|
|
15
|
-
this._name = _name;
|
|
16
|
-
this._duration = _duration;
|
|
17
|
-
this._delay = _delay;
|
|
18
|
-
this._easing = _easing;
|
|
19
|
-
this._fillMode = _fillMode;
|
|
20
|
-
this._onDoneFn = _onDoneFn;
|
|
21
|
-
this._finished = false;
|
|
22
|
-
this._destroyed = false;
|
|
23
|
-
this._startTime = 0;
|
|
24
|
-
this._position = 0;
|
|
25
|
-
this._eventFn = (e) => this._handleCallback(e);
|
|
26
|
-
}
|
|
27
|
-
apply() {
|
|
28
|
-
applyKeyframeAnimation(this._element, `${this._duration}ms ${this._easing} ${this._delay}ms 1 normal ${this._fillMode} ${this._name}`);
|
|
29
|
-
addRemoveAnimationEvent(this._element, this._eventFn, false);
|
|
30
|
-
this._startTime = Date.now();
|
|
31
|
-
}
|
|
32
|
-
pause() {
|
|
33
|
-
playPauseAnimation(this._element, this._name, 'paused');
|
|
34
|
-
}
|
|
35
|
-
resume() {
|
|
36
|
-
playPauseAnimation(this._element, this._name, 'running');
|
|
37
|
-
}
|
|
38
|
-
setPosition(position) {
|
|
39
|
-
const index = findIndexForAnimation(this._element, this._name);
|
|
40
|
-
this._position = position * this._duration;
|
|
41
|
-
setAnimationStyle(this._element, 'Delay', `-${this._position}ms`, index);
|
|
42
|
-
}
|
|
43
|
-
getPosition() {
|
|
44
|
-
return this._position;
|
|
45
|
-
}
|
|
46
|
-
_handleCallback(event) {
|
|
47
|
-
const timestamp = event._ngTestManualTimestamp || Date.now();
|
|
48
|
-
const elapsedTime = parseFloat(event.elapsedTime.toFixed(ELAPSED_TIME_MAX_DECIMAL_PLACES)) * ONE_SECOND;
|
|
49
|
-
if (event.animationName == this._name &&
|
|
50
|
-
Math.max(timestamp - this._startTime, 0) >= this._delay && elapsedTime >= this._duration) {
|
|
51
|
-
this.finish();
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
finish() {
|
|
55
|
-
if (this._finished)
|
|
56
|
-
return;
|
|
57
|
-
this._finished = true;
|
|
58
|
-
this._onDoneFn();
|
|
59
|
-
addRemoveAnimationEvent(this._element, this._eventFn, true);
|
|
60
|
-
}
|
|
61
|
-
destroy() {
|
|
62
|
-
if (this._destroyed)
|
|
63
|
-
return;
|
|
64
|
-
this._destroyed = true;
|
|
65
|
-
this.finish();
|
|
66
|
-
removeKeyframeAnimation(this._element, this._name);
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
function playPauseAnimation(element, name, status) {
|
|
70
|
-
const index = findIndexForAnimation(element, name);
|
|
71
|
-
setAnimationStyle(element, 'PlayState', status, index);
|
|
72
|
-
}
|
|
73
|
-
function applyKeyframeAnimation(element, value) {
|
|
74
|
-
const anim = getAnimationStyle(element, '').trim();
|
|
75
|
-
let index = 0;
|
|
76
|
-
if (anim.length) {
|
|
77
|
-
index = countChars(anim, ',') + 1;
|
|
78
|
-
value = `${anim}, ${value}`;
|
|
79
|
-
}
|
|
80
|
-
setAnimationStyle(element, '', value);
|
|
81
|
-
return index;
|
|
82
|
-
}
|
|
83
|
-
function removeKeyframeAnimation(element, name) {
|
|
84
|
-
const anim = getAnimationStyle(element, '');
|
|
85
|
-
const tokens = anim.split(',');
|
|
86
|
-
const index = findMatchingTokenIndex(tokens, name);
|
|
87
|
-
if (index >= 0) {
|
|
88
|
-
tokens.splice(index, 1);
|
|
89
|
-
const newValue = tokens.join(',');
|
|
90
|
-
setAnimationStyle(element, '', newValue);
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
function findIndexForAnimation(element, value) {
|
|
94
|
-
const anim = getAnimationStyle(element, '');
|
|
95
|
-
if (anim.indexOf(',') > 0) {
|
|
96
|
-
const tokens = anim.split(',');
|
|
97
|
-
return findMatchingTokenIndex(tokens, value);
|
|
98
|
-
}
|
|
99
|
-
return findMatchingTokenIndex([anim], value);
|
|
100
|
-
}
|
|
101
|
-
function findMatchingTokenIndex(tokens, searchToken) {
|
|
102
|
-
for (let i = 0; i < tokens.length; i++) {
|
|
103
|
-
if (tokens[i].indexOf(searchToken) >= 0) {
|
|
104
|
-
return i;
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
return -1;
|
|
108
|
-
}
|
|
109
|
-
function addRemoveAnimationEvent(element, fn, doRemove) {
|
|
110
|
-
doRemove ? element.removeEventListener(ANIMATIONEND_EVENT, fn) :
|
|
111
|
-
element.addEventListener(ANIMATIONEND_EVENT, fn);
|
|
112
|
-
}
|
|
113
|
-
function setAnimationStyle(element, name, value, index) {
|
|
114
|
-
const prop = ANIMATION_PROP + name;
|
|
115
|
-
if (index != null) {
|
|
116
|
-
const oldValue = element.style[prop];
|
|
117
|
-
if (oldValue.length) {
|
|
118
|
-
const tokens = oldValue.split(',');
|
|
119
|
-
tokens[index] = value;
|
|
120
|
-
value = tokens.join(',');
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
element.style[prop] = value;
|
|
124
|
-
}
|
|
125
|
-
export function getAnimationStyle(element, name) {
|
|
126
|
-
return element.style[ANIMATION_PROP + name] || '';
|
|
127
|
-
}
|
|
128
|
-
function countChars(value, char) {
|
|
129
|
-
let count = 0;
|
|
130
|
-
for (let i = 0; i < value.length; i++) {
|
|
131
|
-
const c = value.charAt(i);
|
|
132
|
-
if (c === char)
|
|
133
|
-
count++;
|
|
134
|
-
}
|
|
135
|
-
return count;
|
|
136
|
-
}
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element_animation_style_handler.js","sourceRoot":"","sources":["../../../../../../../../../packages/animations/browser/src/render/css_keyframes/element_animation_style_handler.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 */\nconst ELAPSED_TIME_MAX_DECIMAL_PLACES = 3;\nconst ANIMATION_PROP = 'animation';\nconst ANIMATIONEND_EVENT = 'animationend';\nconst ONE_SECOND = 1000;\n\nexport class ElementAnimationStyleHandler {\n  private readonly _eventFn: (e: any) => any;\n  private _finished = false;\n  private _destroyed = false;\n  private _startTime = 0;\n  private _position = 0;\n\n  constructor(\n      private readonly _element: any, private readonly _name: string,\n      private readonly _duration: number, private readonly _delay: number,\n      private readonly _easing: string, private readonly _fillMode: ''|'both'|'forwards',\n      private readonly _onDoneFn: () => any) {\n    this._eventFn = (e) => this._handleCallback(e);\n  }\n\n  apply() {\n    applyKeyframeAnimation(\n        this._element,\n        `${this._duration}ms ${this._easing} ${this._delay}ms 1 normal ${this._fillMode} ${\n            this._name}`);\n    addRemoveAnimationEvent(this._element, this._eventFn, false);\n    this._startTime = Date.now();\n  }\n\n  pause() {\n    playPauseAnimation(this._element, this._name, 'paused');\n  }\n\n  resume() {\n    playPauseAnimation(this._element, this._name, 'running');\n  }\n\n  setPosition(position: number) {\n    const index = findIndexForAnimation(this._element, this._name);\n    this._position = position * this._duration;\n    setAnimationStyle(this._element, 'Delay', `-${this._position}ms`, index);\n  }\n\n  getPosition() {\n    return this._position;\n  }\n\n  private _handleCallback(event: any) {\n    const timestamp = event._ngTestManualTimestamp || Date.now();\n    const elapsedTime =\n        parseFloat(event.elapsedTime.toFixed(ELAPSED_TIME_MAX_DECIMAL_PLACES)) * ONE_SECOND;\n    if (event.animationName == this._name &&\n        Math.max(timestamp - this._startTime, 0) >= this._delay && elapsedTime >= this._duration) {\n      this.finish();\n    }\n  }\n\n  finish() {\n    if (this._finished) return;\n    this._finished = true;\n    this._onDoneFn();\n    addRemoveAnimationEvent(this._element, this._eventFn, true);\n  }\n\n  destroy() {\n    if (this._destroyed) return;\n    this._destroyed = true;\n    this.finish();\n    removeKeyframeAnimation(this._element, this._name);\n  }\n}\n\nfunction playPauseAnimation(element: any, name: string, status: 'running'|'paused') {\n  const index = findIndexForAnimation(element, name);\n  setAnimationStyle(element, 'PlayState', status, index);\n}\n\nfunction applyKeyframeAnimation(element: any, value: string): number {\n  const anim = getAnimationStyle(element, '').trim();\n  let index = 0;\n  if (anim.length) {\n    index = countChars(anim, ',') + 1;\n    value = `${anim}, ${value}`;\n  }\n  setAnimationStyle(element, '', value);\n  return index;\n}\n\nfunction removeKeyframeAnimation(element: any, name: string) {\n  const anim = getAnimationStyle(element, '');\n  const tokens = anim.split(',');\n  const index = findMatchingTokenIndex(tokens, name);\n  if (index >= 0) {\n    tokens.splice(index, 1);\n    const newValue = tokens.join(',');\n    setAnimationStyle(element, '', newValue);\n  }\n}\n\nfunction findIndexForAnimation(element: any, value: string) {\n  const anim = getAnimationStyle(element, '');\n  if (anim.indexOf(',') > 0) {\n    const tokens = anim.split(',');\n    return findMatchingTokenIndex(tokens, value);\n  }\n  return findMatchingTokenIndex([anim], value);\n}\n\nfunction findMatchingTokenIndex(tokens: string[], searchToken: string): number {\n  for (let i = 0; i < tokens.length; i++) {\n    if (tokens[i].indexOf(searchToken) >= 0) {\n      return i;\n    }\n  }\n  return -1;\n}\n\nfunction addRemoveAnimationEvent(element: any, fn: (e: any) => any, doRemove: boolean) {\n  doRemove ? element.removeEventListener(ANIMATIONEND_EVENT, fn) :\n             element.addEventListener(ANIMATIONEND_EVENT, fn);\n}\n\nfunction setAnimationStyle(element: any, name: string, value: string, index?: number) {\n  const prop = ANIMATION_PROP + name;\n  if (index != null) {\n    const oldValue = element.style[prop];\n    if (oldValue.length) {\n      const tokens = oldValue.split(',');\n      tokens[index] = value;\n      value = tokens.join(',');\n    }\n  }\n  element.style[prop] = value;\n}\n\nexport function getAnimationStyle(element: any, name: string) {\n  return element.style[ANIMATION_PROP + name] || '';\n}\n\nfunction countChars(value: string, char: string): number {\n  let count = 0;\n  for (let i = 0; i < value.length; i++) {\n    const c = value.charAt(i);\n    if (c === char) count++;\n  }\n  return count;\n}\n"]}
|