@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.
- package/LICENSE +21 -0
- package/browser/index.d.ts +1 -1
- package/browser/testing/index.d.ts +1 -1
- package/fesm2022/animations.mjs +7 -7
- package/fesm2022/animations.mjs.map +1 -1
- package/fesm2022/browser/testing.mjs +1 -1
- package/fesm2022/browser/testing.mjs.map +1 -1
- package/fesm2022/browser.mjs +4 -4
- package/fesm2022/browser.mjs.map +1 -1
- package/index.d.ts +1 -1
- package/package.json +2 -8
- package/esm2022/animations.mjs +0 -5
- package/esm2022/browser/browser.mjs +0 -5
- package/esm2022/browser/index.mjs +0 -13
- package/esm2022/browser/public_api.mjs +0 -14
- package/esm2022/browser/src/browser.mjs +0 -15
- package/esm2022/browser/src/create_engine.mjs +0 -20
- package/esm2022/browser/src/dsl/animation.mjs +0 -37
- package/esm2022/browser/src/dsl/animation_ast.mjs +0 -3
- package/esm2022/browser/src/dsl/animation_ast_builder.mjs +0 -514
- package/esm2022/browser/src/dsl/animation_dsl_visitor.mjs +0 -2
- package/esm2022/browser/src/dsl/animation_timeline_builder.mjs +0 -780
- package/esm2022/browser/src/dsl/animation_timeline_instruction.mjs +0 -15
- package/esm2022/browser/src/dsl/animation_transition_expr.mjs +0 -82
- package/esm2022/browser/src/dsl/animation_transition_factory.mjs +0 -152
- package/esm2022/browser/src/dsl/animation_transition_instruction.mjs +0 -26
- package/esm2022/browser/src/dsl/animation_trigger.mjs +0 -65
- package/esm2022/browser/src/dsl/element_instruction_map.mjs +0 -22
- package/esm2022/browser/src/dsl/style_normalization/animation_style_normalizer.mjs +0 -18
- package/esm2022/browser/src/dsl/style_normalization/web_animations_style_normalizer.mjs +0 -63
- package/esm2022/browser/src/error_helpers.mjs +0 -145
- package/esm2022/browser/src/private_export.mjs +0 -19
- package/esm2022/browser/src/render/animation_driver.mjs +0 -71
- package/esm2022/browser/src/render/animation_engine_instruction.mjs +0 -2
- package/esm2022/browser/src/render/animation_engine_next.mjs +0 -83
- package/esm2022/browser/src/render/animation_renderer.mjs +0 -99
- package/esm2022/browser/src/render/renderer.mjs +0 -165
- package/esm2022/browser/src/render/shared.mjs +0 -162
- package/esm2022/browser/src/render/special_cased_styles.mjs +0 -97
- package/esm2022/browser/src/render/timeline_animation_engine.mjs +0 -140
- package/esm2022/browser/src/render/transition_animation_engine.mjs +0 -1516
- package/esm2022/browser/src/render/web_animations/animatable_props_set.mjs +0 -214
- package/esm2022/browser/src/render/web_animations/web_animations_driver.mjs +0 -54
- package/esm2022/browser/src/render/web_animations/web_animations_player.mjs +0 -177
- package/esm2022/browser/src/util.mjs +0 -217
- package/esm2022/browser/src/warning_helpers.mjs +0 -36
- package/esm2022/browser/testing/index.mjs +0 -13
- package/esm2022/browser/testing/public_api.mjs +0 -14
- package/esm2022/browser/testing/src/mock_animation_driver.mjs +0 -117
- package/esm2022/browser/testing/src/testing.mjs +0 -9
- package/esm2022/browser/testing/testing.mjs +0 -5
- package/esm2022/index.mjs +0 -13
- package/esm2022/public_api.mjs +0 -14
- package/esm2022/src/animation_builder.mjs +0 -200
- package/esm2022/src/animation_event.mjs +0 -9
- package/esm2022/src/animation_metadata.mjs +0 -934
- package/esm2022/src/animations.mjs +0 -17
- package/esm2022/src/errors.mjs +0 -9
- package/esm2022/src/players/animation_group_player.mjs +0 -147
- package/esm2022/src/players/animation_player.mjs +0 -104
- package/esm2022/src/private_export.mjs +0 -11
- package/esm2022/src/version.mjs +0 -15
@@ -1,165 +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 ANIMATION_PREFIX = '@';
|
9
|
-
const DISABLE_ANIMATIONS_FLAG = '@.disabled';
|
10
|
-
export class BaseAnimationRenderer {
|
11
|
-
constructor(namespaceId, delegate, engine, _onDestroy) {
|
12
|
-
this.namespaceId = namespaceId;
|
13
|
-
this.delegate = delegate;
|
14
|
-
this.engine = engine;
|
15
|
-
this._onDestroy = _onDestroy;
|
16
|
-
// We need to explicitly type this property because of an api-extractor bug
|
17
|
-
// See https://github.com/microsoft/rushstack/issues/4390
|
18
|
-
this.ɵtype = 0 /* AnimationRendererType.Regular */;
|
19
|
-
}
|
20
|
-
get data() {
|
21
|
-
return this.delegate.data;
|
22
|
-
}
|
23
|
-
destroyNode(node) {
|
24
|
-
this.delegate.destroyNode?.(node);
|
25
|
-
}
|
26
|
-
destroy() {
|
27
|
-
this.engine.destroy(this.namespaceId, this.delegate);
|
28
|
-
this.engine.afterFlushAnimationsDone(() => {
|
29
|
-
// Call the renderer destroy method after the animations has finished as otherwise
|
30
|
-
// styles will be removed too early which will cause an unstyled animation.
|
31
|
-
queueMicrotask(() => {
|
32
|
-
this.delegate.destroy();
|
33
|
-
});
|
34
|
-
});
|
35
|
-
this._onDestroy?.();
|
36
|
-
}
|
37
|
-
createElement(name, namespace) {
|
38
|
-
return this.delegate.createElement(name, namespace);
|
39
|
-
}
|
40
|
-
createComment(value) {
|
41
|
-
return this.delegate.createComment(value);
|
42
|
-
}
|
43
|
-
createText(value) {
|
44
|
-
return this.delegate.createText(value);
|
45
|
-
}
|
46
|
-
appendChild(parent, newChild) {
|
47
|
-
this.delegate.appendChild(parent, newChild);
|
48
|
-
this.engine.onInsert(this.namespaceId, newChild, parent, false);
|
49
|
-
}
|
50
|
-
insertBefore(parent, newChild, refChild, isMove = true) {
|
51
|
-
this.delegate.insertBefore(parent, newChild, refChild);
|
52
|
-
// If `isMove` true than we should animate this insert.
|
53
|
-
this.engine.onInsert(this.namespaceId, newChild, parent, isMove);
|
54
|
-
}
|
55
|
-
removeChild(parent, oldChild, isHostElement) {
|
56
|
-
// Prior to the changes in #57203, this method wasn't being called at all by `core` if the child
|
57
|
-
// doesn't have a parent. There appears to be some animation-specific downstream logic that
|
58
|
-
// depends on the null check happening before the animation engine. This check keeps the old
|
59
|
-
// behavior while allowing `core` to not have to check for the parent element anymore.
|
60
|
-
if (this.parentNode(oldChild)) {
|
61
|
-
this.engine.onRemove(this.namespaceId, oldChild, this.delegate);
|
62
|
-
}
|
63
|
-
}
|
64
|
-
selectRootElement(selectorOrNode, preserveContent) {
|
65
|
-
return this.delegate.selectRootElement(selectorOrNode, preserveContent);
|
66
|
-
}
|
67
|
-
parentNode(node) {
|
68
|
-
return this.delegate.parentNode(node);
|
69
|
-
}
|
70
|
-
nextSibling(node) {
|
71
|
-
return this.delegate.nextSibling(node);
|
72
|
-
}
|
73
|
-
setAttribute(el, name, value, namespace) {
|
74
|
-
this.delegate.setAttribute(el, name, value, namespace);
|
75
|
-
}
|
76
|
-
removeAttribute(el, name, namespace) {
|
77
|
-
this.delegate.removeAttribute(el, name, namespace);
|
78
|
-
}
|
79
|
-
addClass(el, name) {
|
80
|
-
this.delegate.addClass(el, name);
|
81
|
-
}
|
82
|
-
removeClass(el, name) {
|
83
|
-
this.delegate.removeClass(el, name);
|
84
|
-
}
|
85
|
-
setStyle(el, style, value, flags) {
|
86
|
-
this.delegate.setStyle(el, style, value, flags);
|
87
|
-
}
|
88
|
-
removeStyle(el, style, flags) {
|
89
|
-
this.delegate.removeStyle(el, style, flags);
|
90
|
-
}
|
91
|
-
setProperty(el, name, value) {
|
92
|
-
if (name.charAt(0) == ANIMATION_PREFIX && name == DISABLE_ANIMATIONS_FLAG) {
|
93
|
-
this.disableAnimations(el, !!value);
|
94
|
-
}
|
95
|
-
else {
|
96
|
-
this.delegate.setProperty(el, name, value);
|
97
|
-
}
|
98
|
-
}
|
99
|
-
setValue(node, value) {
|
100
|
-
this.delegate.setValue(node, value);
|
101
|
-
}
|
102
|
-
listen(target, eventName, callback) {
|
103
|
-
return this.delegate.listen(target, eventName, callback);
|
104
|
-
}
|
105
|
-
disableAnimations(element, value) {
|
106
|
-
this.engine.disableAnimations(element, value);
|
107
|
-
}
|
108
|
-
}
|
109
|
-
export class AnimationRenderer extends BaseAnimationRenderer {
|
110
|
-
constructor(factory, namespaceId, delegate, engine, onDestroy) {
|
111
|
-
super(namespaceId, delegate, engine, onDestroy);
|
112
|
-
this.factory = factory;
|
113
|
-
this.namespaceId = namespaceId;
|
114
|
-
}
|
115
|
-
setProperty(el, name, value) {
|
116
|
-
if (name.charAt(0) == ANIMATION_PREFIX) {
|
117
|
-
if (name.charAt(1) == '.' && name == DISABLE_ANIMATIONS_FLAG) {
|
118
|
-
value = value === undefined ? true : !!value;
|
119
|
-
this.disableAnimations(el, value);
|
120
|
-
}
|
121
|
-
else {
|
122
|
-
this.engine.process(this.namespaceId, el, name.slice(1), value);
|
123
|
-
}
|
124
|
-
}
|
125
|
-
else {
|
126
|
-
this.delegate.setProperty(el, name, value);
|
127
|
-
}
|
128
|
-
}
|
129
|
-
listen(target, eventName, callback) {
|
130
|
-
if (eventName.charAt(0) == ANIMATION_PREFIX) {
|
131
|
-
const element = resolveElementFromTarget(target);
|
132
|
-
let name = eventName.slice(1);
|
133
|
-
let phase = '';
|
134
|
-
// @listener.phase is for trigger animation callbacks
|
135
|
-
// @@listener is for animation builder callbacks
|
136
|
-
if (name.charAt(0) != ANIMATION_PREFIX) {
|
137
|
-
[name, phase] = parseTriggerCallbackName(name);
|
138
|
-
}
|
139
|
-
return this.engine.listen(this.namespaceId, element, name, phase, (event) => {
|
140
|
-
const countId = event['_data'] || -1;
|
141
|
-
this.factory.scheduleListenerCallback(countId, callback, event);
|
142
|
-
});
|
143
|
-
}
|
144
|
-
return this.delegate.listen(target, eventName, callback);
|
145
|
-
}
|
146
|
-
}
|
147
|
-
function resolveElementFromTarget(target) {
|
148
|
-
switch (target) {
|
149
|
-
case 'body':
|
150
|
-
return document.body;
|
151
|
-
case 'document':
|
152
|
-
return document;
|
153
|
-
case 'window':
|
154
|
-
return window;
|
155
|
-
default:
|
156
|
-
return target;
|
157
|
-
}
|
158
|
-
}
|
159
|
-
function parseTriggerCallbackName(triggerName) {
|
160
|
-
const dotIndex = triggerName.indexOf('.');
|
161
|
-
const trigger = triggerName.substring(0, dotIndex);
|
162
|
-
const phase = triggerName.slice(dotIndex + 1);
|
163
|
-
return [trigger, phase];
|
164
|
-
}
|
165
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../../../../../../../packages/animations/browser/src/render/renderer.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\nconst ANIMATION_PREFIX = '@';\nconst DISABLE_ANIMATIONS_FLAG = '@.disabled';\n\nimport {\n  Renderer2,\n  RendererFactory2,\n  RendererStyleFlags2,\n  ɵAnimationRendererType as AnimationRendererType,\n} from '@angular/core';\nimport type {AnimationEngine} from './animation_engine_next';\n\ntype AnimationFactoryWithListenerCallback = RendererFactory2 & {\n  scheduleListenerCallback: (count: number, fn: (e: any) => any, data: any) => void;\n};\n\nexport class BaseAnimationRenderer implements Renderer2 {\n  // We need to explicitly type this property because of an api-extractor bug\n  // See https://github.com/microsoft/rushstack/issues/4390\n  readonly ɵtype: AnimationRendererType.Regular = AnimationRendererType.Regular;\n\n  constructor(\n    protected namespaceId: string,\n    public delegate: Renderer2,\n    public engine: AnimationEngine,\n    private _onDestroy?: () => void,\n  ) {}\n\n  get data() {\n    return this.delegate.data;\n  }\n\n  destroyNode(node: any): void {\n    this.delegate.destroyNode?.(node);\n  }\n\n  destroy(): void {\n    this.engine.destroy(this.namespaceId, this.delegate);\n    this.engine.afterFlushAnimationsDone(() => {\n      // Call the renderer destroy method after the animations has finished as otherwise\n      // styles will be removed too early which will cause an unstyled animation.\n      queueMicrotask(() => {\n        this.delegate.destroy();\n      });\n    });\n\n    this._onDestroy?.();\n  }\n\n  createElement(name: string, namespace?: string | null | undefined) {\n    return this.delegate.createElement(name, namespace);\n  }\n\n  createComment(value: string) {\n    return this.delegate.createComment(value);\n  }\n\n  createText(value: string) {\n    return this.delegate.createText(value);\n  }\n\n  appendChild(parent: any, newChild: any): void {\n    this.delegate.appendChild(parent, newChild);\n    this.engine.onInsert(this.namespaceId, newChild, parent, false);\n  }\n\n  insertBefore(parent: any, newChild: any, refChild: any, isMove: boolean = true): void {\n    this.delegate.insertBefore(parent, newChild, refChild);\n    // If `isMove` true than we should animate this insert.\n    this.engine.onInsert(this.namespaceId, newChild, parent, isMove);\n  }\n\n  removeChild(parent: any, oldChild: any, isHostElement?: boolean): void {\n    // Prior to the changes in #57203, this method wasn't being called at all by `core` if the child\n    // doesn't have a parent. There appears to be some animation-specific downstream logic that\n    // depends on the null check happening before the animation engine. This check keeps the old\n    // behavior while allowing `core` to not have to check for the parent element anymore.\n    if (this.parentNode(oldChild)) {\n      this.engine.onRemove(this.namespaceId, oldChild, this.delegate);\n    }\n  }\n\n  selectRootElement(selectorOrNode: any, preserveContent?: boolean) {\n    return this.delegate.selectRootElement(selectorOrNode, preserveContent);\n  }\n\n  parentNode(node: any) {\n    return this.delegate.parentNode(node);\n  }\n\n  nextSibling(node: any) {\n    return this.delegate.nextSibling(node);\n  }\n\n  setAttribute(el: any, name: string, value: string, namespace?: string | null | undefined): void {\n    this.delegate.setAttribute(el, name, value, namespace);\n  }\n\n  removeAttribute(el: any, name: string, namespace?: string | null | undefined): void {\n    this.delegate.removeAttribute(el, name, namespace);\n  }\n\n  addClass(el: any, name: string): void {\n    this.delegate.addClass(el, name);\n  }\n\n  removeClass(el: any, name: string): void {\n    this.delegate.removeClass(el, name);\n  }\n\n  setStyle(el: any, style: string, value: any, flags?: RendererStyleFlags2 | undefined): void {\n    this.delegate.setStyle(el, style, value, flags);\n  }\n\n  removeStyle(el: any, style: string, flags?: RendererStyleFlags2 | undefined): void {\n    this.delegate.removeStyle(el, style, flags);\n  }\n\n  setProperty(el: any, name: string, value: any): void {\n    if (name.charAt(0) == ANIMATION_PREFIX && name == DISABLE_ANIMATIONS_FLAG) {\n      this.disableAnimations(el, !!value);\n    } else {\n      this.delegate.setProperty(el, name, value);\n    }\n  }\n\n  setValue(node: any, value: string): void {\n    this.delegate.setValue(node, value);\n  }\n\n  listen(target: any, eventName: string, callback: (event: any) => boolean | void): () => void {\n    return this.delegate.listen(target, eventName, callback);\n  }\n\n  protected disableAnimations(element: any, value: boolean) {\n    this.engine.disableAnimations(element, value);\n  }\n}\n\nexport class AnimationRenderer extends BaseAnimationRenderer implements Renderer2 {\n  constructor(\n    public factory: AnimationFactoryWithListenerCallback,\n    namespaceId: string,\n    delegate: Renderer2,\n    engine: AnimationEngine,\n    onDestroy?: () => void,\n  ) {\n    super(namespaceId, delegate, engine, onDestroy);\n    this.namespaceId = namespaceId;\n  }\n\n  override setProperty(el: any, name: string, value: any): void {\n    if (name.charAt(0) == ANIMATION_PREFIX) {\n      if (name.charAt(1) == '.' && name == DISABLE_ANIMATIONS_FLAG) {\n        value = value === undefined ? true : !!value;\n        this.disableAnimations(el, value as boolean);\n      } else {\n        this.engine.process(this.namespaceId, el, name.slice(1), value);\n      }\n    } else {\n      this.delegate.setProperty(el, name, value);\n    }\n  }\n\n  override listen(\n    target: 'window' | 'document' | 'body' | any,\n    eventName: string,\n    callback: (event: any) => any,\n  ): () => void {\n    if (eventName.charAt(0) == ANIMATION_PREFIX) {\n      const element = resolveElementFromTarget(target);\n      let name = eventName.slice(1);\n      let phase = '';\n      // @listener.phase is for trigger animation callbacks\n      // @@listener is for animation builder callbacks\n      if (name.charAt(0) != ANIMATION_PREFIX) {\n        [name, phase] = parseTriggerCallbackName(name);\n      }\n      return this.engine.listen(this.namespaceId, element, name, phase, (event) => {\n        const countId = (event as any)['_data'] || -1;\n        this.factory.scheduleListenerCallback(countId, callback, event);\n      });\n    }\n    return this.delegate.listen(target, eventName, callback);\n  }\n}\n\nfunction resolveElementFromTarget(target: 'window' | 'document' | 'body' | any): any {\n  switch (target) {\n    case 'body':\n      return document.body;\n    case 'document':\n      return document;\n    case 'window':\n      return window;\n    default:\n      return target;\n  }\n}\n\nfunction parseTriggerCallbackName(triggerName: string) {\n  const dotIndex = triggerName.indexOf('.');\n  const trigger = triggerName.substring(0, dotIndex);\n  const phase = triggerName.slice(dotIndex + 1);\n  return [trigger, phase];\n}\n"]}
|
@@ -1,162 +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 { AUTO_STYLE, NoopAnimationPlayer, ɵAnimationGroupPlayer, ɵPRE_STYLE as PRE_STYLE, } from '@angular/animations';
|
9
|
-
import { animationFailed } from '../error_helpers';
|
10
|
-
import { ANIMATABLE_PROP_SET } from './web_animations/animatable_props_set';
|
11
|
-
export function optimizeGroupPlayer(players) {
|
12
|
-
switch (players.length) {
|
13
|
-
case 0:
|
14
|
-
return new NoopAnimationPlayer();
|
15
|
-
case 1:
|
16
|
-
return players[0];
|
17
|
-
default:
|
18
|
-
return new ɵAnimationGroupPlayer(players);
|
19
|
-
}
|
20
|
-
}
|
21
|
-
export function normalizeKeyframes(normalizer, keyframes, preStyles = new Map(), postStyles = new Map()) {
|
22
|
-
const errors = [];
|
23
|
-
const normalizedKeyframes = [];
|
24
|
-
let previousOffset = -1;
|
25
|
-
let previousKeyframe = null;
|
26
|
-
keyframes.forEach((kf) => {
|
27
|
-
const offset = kf.get('offset');
|
28
|
-
const isSameOffset = offset == previousOffset;
|
29
|
-
const normalizedKeyframe = (isSameOffset && previousKeyframe) || new Map();
|
30
|
-
kf.forEach((val, prop) => {
|
31
|
-
let normalizedProp = prop;
|
32
|
-
let normalizedValue = val;
|
33
|
-
if (prop !== 'offset') {
|
34
|
-
normalizedProp = normalizer.normalizePropertyName(normalizedProp, errors);
|
35
|
-
switch (normalizedValue) {
|
36
|
-
case PRE_STYLE:
|
37
|
-
normalizedValue = preStyles.get(prop);
|
38
|
-
break;
|
39
|
-
case AUTO_STYLE:
|
40
|
-
normalizedValue = postStyles.get(prop);
|
41
|
-
break;
|
42
|
-
default:
|
43
|
-
normalizedValue = normalizer.normalizeStyleValue(prop, normalizedProp, normalizedValue, errors);
|
44
|
-
break;
|
45
|
-
}
|
46
|
-
}
|
47
|
-
normalizedKeyframe.set(normalizedProp, normalizedValue);
|
48
|
-
});
|
49
|
-
if (!isSameOffset) {
|
50
|
-
normalizedKeyframes.push(normalizedKeyframe);
|
51
|
-
}
|
52
|
-
previousKeyframe = normalizedKeyframe;
|
53
|
-
previousOffset = offset;
|
54
|
-
});
|
55
|
-
if (errors.length) {
|
56
|
-
throw animationFailed(errors);
|
57
|
-
}
|
58
|
-
return normalizedKeyframes;
|
59
|
-
}
|
60
|
-
export function listenOnPlayer(player, eventName, event, callback) {
|
61
|
-
switch (eventName) {
|
62
|
-
case 'start':
|
63
|
-
player.onStart(() => callback(event && copyAnimationEvent(event, 'start', player)));
|
64
|
-
break;
|
65
|
-
case 'done':
|
66
|
-
player.onDone(() => callback(event && copyAnimationEvent(event, 'done', player)));
|
67
|
-
break;
|
68
|
-
case 'destroy':
|
69
|
-
player.onDestroy(() => callback(event && copyAnimationEvent(event, 'destroy', player)));
|
70
|
-
break;
|
71
|
-
}
|
72
|
-
}
|
73
|
-
export function copyAnimationEvent(e, phaseName, player) {
|
74
|
-
const totalTime = player.totalTime;
|
75
|
-
const disabled = player.disabled ? true : false;
|
76
|
-
const event = makeAnimationEvent(e.element, e.triggerName, e.fromState, e.toState, phaseName || e.phaseName, totalTime == undefined ? e.totalTime : totalTime, disabled);
|
77
|
-
const data = e['_data'];
|
78
|
-
if (data != null) {
|
79
|
-
event['_data'] = data;
|
80
|
-
}
|
81
|
-
return event;
|
82
|
-
}
|
83
|
-
export function makeAnimationEvent(element, triggerName, fromState, toState, phaseName = '', totalTime = 0, disabled) {
|
84
|
-
return { element, triggerName, fromState, toState, phaseName, totalTime, disabled: !!disabled };
|
85
|
-
}
|
86
|
-
export function getOrSetDefaultValue(map, key, defaultValue) {
|
87
|
-
let value = map.get(key);
|
88
|
-
if (!value) {
|
89
|
-
map.set(key, (value = defaultValue));
|
90
|
-
}
|
91
|
-
return value;
|
92
|
-
}
|
93
|
-
export function parseTimelineCommand(command) {
|
94
|
-
const separatorPos = command.indexOf(':');
|
95
|
-
const id = command.substring(1, separatorPos);
|
96
|
-
const action = command.slice(separatorPos + 1);
|
97
|
-
return [id, action];
|
98
|
-
}
|
99
|
-
const documentElement = /* @__PURE__ */ (() => typeof document === 'undefined' ? null : document.documentElement)();
|
100
|
-
export function getParentElement(element) {
|
101
|
-
const parent = element.parentNode || element.host || null; // consider host to support shadow DOM
|
102
|
-
if (parent === documentElement) {
|
103
|
-
return null;
|
104
|
-
}
|
105
|
-
return parent;
|
106
|
-
}
|
107
|
-
function containsVendorPrefix(prop) {
|
108
|
-
// Webkit is the only real popular vendor prefix nowadays
|
109
|
-
// cc: http://shouldiprefix.com/
|
110
|
-
return prop.substring(1, 6) == 'ebkit'; // webkit or Webkit
|
111
|
-
}
|
112
|
-
let _CACHED_BODY = null;
|
113
|
-
let _IS_WEBKIT = false;
|
114
|
-
export function validateStyleProperty(prop) {
|
115
|
-
if (!_CACHED_BODY) {
|
116
|
-
_CACHED_BODY = getBodyNode() || {};
|
117
|
-
_IS_WEBKIT = _CACHED_BODY.style ? 'WebkitAppearance' in _CACHED_BODY.style : false;
|
118
|
-
}
|
119
|
-
let result = true;
|
120
|
-
if (_CACHED_BODY.style && !containsVendorPrefix(prop)) {
|
121
|
-
result = prop in _CACHED_BODY.style;
|
122
|
-
if (!result && _IS_WEBKIT) {
|
123
|
-
const camelProp = 'Webkit' + prop.charAt(0).toUpperCase() + prop.slice(1);
|
124
|
-
result = camelProp in _CACHED_BODY.style;
|
125
|
-
}
|
126
|
-
}
|
127
|
-
return result;
|
128
|
-
}
|
129
|
-
export function validateWebAnimatableStyleProperty(prop) {
|
130
|
-
return ANIMATABLE_PROP_SET.has(prop);
|
131
|
-
}
|
132
|
-
export function getBodyNode() {
|
133
|
-
if (typeof document != 'undefined') {
|
134
|
-
return document.body;
|
135
|
-
}
|
136
|
-
return null;
|
137
|
-
}
|
138
|
-
export function containsElement(elm1, elm2) {
|
139
|
-
while (elm2) {
|
140
|
-
if (elm2 === elm1) {
|
141
|
-
return true;
|
142
|
-
}
|
143
|
-
elm2 = getParentElement(elm2);
|
144
|
-
}
|
145
|
-
return false;
|
146
|
-
}
|
147
|
-
export function invokeQuery(element, selector, multi) {
|
148
|
-
if (multi) {
|
149
|
-
return Array.from(element.querySelectorAll(selector));
|
150
|
-
}
|
151
|
-
const elem = element.querySelector(selector);
|
152
|
-
return elem ? [elem] : [];
|
153
|
-
}
|
154
|
-
export function hypenatePropsKeys(original) {
|
155
|
-
const newMap = new Map();
|
156
|
-
original.forEach((val, prop) => {
|
157
|
-
const newProp = prop.replace(/([a-z])([A-Z])/g, '$1-$2');
|
158
|
-
newMap.set(newProp, val);
|
159
|
-
});
|
160
|
-
return newMap;
|
161
|
-
}
|
162
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shared.js","sourceRoot":"","sources":["../../../../../../../../packages/animations/browser/src/render/shared.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 {\n  AnimationEvent,\n  AnimationPlayer,\n  AUTO_STYLE,\n  NoopAnimationPlayer,\n  ɵAnimationGroupPlayer,\n  ɵPRE_STYLE as PRE_STYLE,\n  ɵStyleDataMap,\n} from '@angular/animations';\n\nimport {AnimationStyleNormalizer} from '../../src/dsl/style_normalization/animation_style_normalizer';\nimport {animationFailed} from '../error_helpers';\n\nimport {ANIMATABLE_PROP_SET} from './web_animations/animatable_props_set';\n\nexport function optimizeGroupPlayer(players: AnimationPlayer[]): AnimationPlayer {\n  switch (players.length) {\n    case 0:\n      return new NoopAnimationPlayer();\n    case 1:\n      return players[0];\n    default:\n      return new ɵAnimationGroupPlayer(players);\n  }\n}\n\nexport function normalizeKeyframes(\n  normalizer: AnimationStyleNormalizer,\n  keyframes: Array<ɵStyleDataMap>,\n  preStyles: ɵStyleDataMap = new Map(),\n  postStyles: ɵStyleDataMap = new Map(),\n): Array<ɵStyleDataMap> {\n  const errors: Error[] = [];\n  const normalizedKeyframes: Array<ɵStyleDataMap> = [];\n  let previousOffset = -1;\n  let previousKeyframe: ɵStyleDataMap | null = null;\n  keyframes.forEach((kf) => {\n    const offset = kf.get('offset') as number;\n    const isSameOffset = offset == previousOffset;\n    const normalizedKeyframe: ɵStyleDataMap = (isSameOffset && previousKeyframe) || new Map();\n    kf.forEach((val, prop) => {\n      let normalizedProp = prop;\n      let normalizedValue = val;\n      if (prop !== 'offset') {\n        normalizedProp = normalizer.normalizePropertyName(normalizedProp, errors);\n        switch (normalizedValue) {\n          case PRE_STYLE:\n            normalizedValue = preStyles.get(prop)!;\n            break;\n\n          case AUTO_STYLE:\n            normalizedValue = postStyles.get(prop)!;\n            break;\n\n          default:\n            normalizedValue = normalizer.normalizeStyleValue(\n              prop,\n              normalizedProp,\n              normalizedValue,\n              errors,\n            );\n            break;\n        }\n      }\n      normalizedKeyframe.set(normalizedProp, normalizedValue);\n    });\n    if (!isSameOffset) {\n      normalizedKeyframes.push(normalizedKeyframe);\n    }\n    previousKeyframe = normalizedKeyframe;\n    previousOffset = offset;\n  });\n  if (errors.length) {\n    throw animationFailed(errors);\n  }\n\n  return normalizedKeyframes;\n}\n\nexport function listenOnPlayer(\n  player: AnimationPlayer,\n  eventName: string,\n  event: AnimationEvent | undefined,\n  callback: (event: any) => any,\n) {\n  switch (eventName) {\n    case 'start':\n      player.onStart(() => callback(event && copyAnimationEvent(event, 'start', player)));\n      break;\n    case 'done':\n      player.onDone(() => callback(event && copyAnimationEvent(event, 'done', player)));\n      break;\n    case 'destroy':\n      player.onDestroy(() => callback(event && copyAnimationEvent(event, 'destroy', player)));\n      break;\n  }\n}\n\nexport function copyAnimationEvent(\n  e: AnimationEvent,\n  phaseName: string,\n  player: AnimationPlayer,\n): AnimationEvent {\n  const totalTime = player.totalTime;\n  const disabled = (player as any).disabled ? true : false;\n  const event = makeAnimationEvent(\n    e.element,\n    e.triggerName,\n    e.fromState,\n    e.toState,\n    phaseName || e.phaseName,\n    totalTime == undefined ? e.totalTime : totalTime,\n    disabled,\n  );\n  const data = (e as any)['_data'];\n  if (data != null) {\n    (event as any)['_data'] = data;\n  }\n  return event;\n}\n\nexport function makeAnimationEvent(\n  element: any,\n  triggerName: string,\n  fromState: string,\n  toState: string,\n  phaseName: string = '',\n  totalTime: number = 0,\n  disabled?: boolean,\n): AnimationEvent {\n  return {element, triggerName, fromState, toState, phaseName, totalTime, disabled: !!disabled};\n}\n\nexport function getOrSetDefaultValue<T, V>(map: Map<T, V>, key: T, defaultValue: V) {\n  let value = map.get(key);\n  if (!value) {\n    map.set(key, (value = defaultValue));\n  }\n  return value;\n}\n\nexport function parseTimelineCommand(command: string): [string, string] {\n  const separatorPos = command.indexOf(':');\n  const id = command.substring(1, separatorPos);\n  const action = command.slice(separatorPos + 1);\n  return [id, action];\n}\n\nconst documentElement: HTMLElement | null = /* @__PURE__ */ (() =>\n  typeof document === 'undefined' ? null : document.documentElement)();\n\nexport function getParentElement(element: any): unknown | null {\n  const parent = element.parentNode || element.host || null; // consider host to support shadow DOM\n  if (parent === documentElement) {\n    return null;\n  }\n  return parent;\n}\n\nfunction containsVendorPrefix(prop: string): boolean {\n  // Webkit is the only real popular vendor prefix nowadays\n  // cc: http://shouldiprefix.com/\n  return prop.substring(1, 6) == 'ebkit'; // webkit or Webkit\n}\n\nlet _CACHED_BODY: {style: any} | null = null;\nlet _IS_WEBKIT = false;\nexport function validateStyleProperty(prop: string): boolean {\n  if (!_CACHED_BODY) {\n    _CACHED_BODY = getBodyNode() || {};\n    _IS_WEBKIT = _CACHED_BODY!.style ? 'WebkitAppearance' in _CACHED_BODY!.style : false;\n  }\n\n  let result = true;\n  if (_CACHED_BODY!.style && !containsVendorPrefix(prop)) {\n    result = prop in _CACHED_BODY!.style;\n    if (!result && _IS_WEBKIT) {\n      const camelProp = 'Webkit' + prop.charAt(0).toUpperCase() + prop.slice(1);\n      result = camelProp in _CACHED_BODY!.style;\n    }\n  }\n\n  return result;\n}\n\nexport function validateWebAnimatableStyleProperty(prop: string): boolean {\n  return ANIMATABLE_PROP_SET.has(prop);\n}\n\nexport function getBodyNode(): any | null {\n  if (typeof document != 'undefined') {\n    return document.body;\n  }\n  return null;\n}\n\nexport function containsElement(elm1: any, elm2: any): boolean {\n  while (elm2) {\n    if (elm2 === elm1) {\n      return true;\n    }\n    elm2 = getParentElement(elm2);\n  }\n  return false;\n}\n\nexport function invokeQuery(element: any, selector: string, multi: boolean): any[] {\n  if (multi) {\n    return Array.from(element.querySelectorAll(selector));\n  }\n  const elem = element.querySelector(selector);\n  return elem ? [elem] : [];\n}\n\nexport function hypenatePropsKeys(original: ɵStyleDataMap): ɵStyleDataMap {\n  const newMap: ɵStyleDataMap = new Map();\n  original.forEach((val, prop) => {\n    const newProp = prop.replace(/([a-z])([A-Z])/g, '$1-$2');\n    newMap.set(newProp, val);\n  });\n  return newMap;\n}\n"]}
|
@@ -1,97 +0,0 @@
|
|
1
|
-
import { eraseStyles, setStyles } from '../util';
|
2
|
-
/**
|
3
|
-
* Returns an instance of `SpecialCasedStyles` if and when any special (non animateable) styles are
|
4
|
-
* detected.
|
5
|
-
*
|
6
|
-
* In CSS there exist properties that cannot be animated within a keyframe animation
|
7
|
-
* (whether it be via CSS keyframes or web-animations) and the animation implementation
|
8
|
-
* will ignore them. This function is designed to detect those special cased styles and
|
9
|
-
* return a container that will be executed at the start and end of the animation.
|
10
|
-
*
|
11
|
-
* @returns an instance of `SpecialCasedStyles` if any special styles are detected otherwise `null`
|
12
|
-
*/
|
13
|
-
export function packageNonAnimatableStyles(element, styles) {
|
14
|
-
let startStyles = null;
|
15
|
-
let endStyles = null;
|
16
|
-
if (Array.isArray(styles) && styles.length) {
|
17
|
-
startStyles = filterNonAnimatableStyles(styles[0]);
|
18
|
-
if (styles.length > 1) {
|
19
|
-
endStyles = filterNonAnimatableStyles(styles[styles.length - 1]);
|
20
|
-
}
|
21
|
-
}
|
22
|
-
else if (styles instanceof Map) {
|
23
|
-
startStyles = filterNonAnimatableStyles(styles);
|
24
|
-
}
|
25
|
-
return startStyles || endStyles ? new SpecialCasedStyles(element, startStyles, endStyles) : null;
|
26
|
-
}
|
27
|
-
/**
|
28
|
-
* Designed to be executed during a keyframe-based animation to apply any special-cased styles.
|
29
|
-
*
|
30
|
-
* When started (when the `start()` method is run) then the provided `startStyles`
|
31
|
-
* will be applied. When finished (when the `finish()` method is called) the
|
32
|
-
* `endStyles` will be applied as well any any starting styles. Finally when
|
33
|
-
* `destroy()` is called then all styles will be removed.
|
34
|
-
*/
|
35
|
-
export class SpecialCasedStyles {
|
36
|
-
static { this.initialStylesByElement = new WeakMap(); }
|
37
|
-
constructor(_element, _startStyles, _endStyles) {
|
38
|
-
this._element = _element;
|
39
|
-
this._startStyles = _startStyles;
|
40
|
-
this._endStyles = _endStyles;
|
41
|
-
this._state = 0 /* SpecialCasedStylesState.Pending */;
|
42
|
-
let initialStyles = SpecialCasedStyles.initialStylesByElement.get(_element);
|
43
|
-
if (!initialStyles) {
|
44
|
-
SpecialCasedStyles.initialStylesByElement.set(_element, (initialStyles = new Map()));
|
45
|
-
}
|
46
|
-
this._initialStyles = initialStyles;
|
47
|
-
}
|
48
|
-
start() {
|
49
|
-
if (this._state < 1 /* SpecialCasedStylesState.Started */) {
|
50
|
-
if (this._startStyles) {
|
51
|
-
setStyles(this._element, this._startStyles, this._initialStyles);
|
52
|
-
}
|
53
|
-
this._state = 1 /* SpecialCasedStylesState.Started */;
|
54
|
-
}
|
55
|
-
}
|
56
|
-
finish() {
|
57
|
-
this.start();
|
58
|
-
if (this._state < 2 /* SpecialCasedStylesState.Finished */) {
|
59
|
-
setStyles(this._element, this._initialStyles);
|
60
|
-
if (this._endStyles) {
|
61
|
-
setStyles(this._element, this._endStyles);
|
62
|
-
this._endStyles = null;
|
63
|
-
}
|
64
|
-
this._state = 1 /* SpecialCasedStylesState.Started */;
|
65
|
-
}
|
66
|
-
}
|
67
|
-
destroy() {
|
68
|
-
this.finish();
|
69
|
-
if (this._state < 3 /* SpecialCasedStylesState.Destroyed */) {
|
70
|
-
SpecialCasedStyles.initialStylesByElement.delete(this._element);
|
71
|
-
if (this._startStyles) {
|
72
|
-
eraseStyles(this._element, this._startStyles);
|
73
|
-
this._endStyles = null;
|
74
|
-
}
|
75
|
-
if (this._endStyles) {
|
76
|
-
eraseStyles(this._element, this._endStyles);
|
77
|
-
this._endStyles = null;
|
78
|
-
}
|
79
|
-
setStyles(this._element, this._initialStyles);
|
80
|
-
this._state = 3 /* SpecialCasedStylesState.Destroyed */;
|
81
|
-
}
|
82
|
-
}
|
83
|
-
}
|
84
|
-
function filterNonAnimatableStyles(styles) {
|
85
|
-
let result = null;
|
86
|
-
styles.forEach((val, prop) => {
|
87
|
-
if (isNonAnimatableStyle(prop)) {
|
88
|
-
result = result || new Map();
|
89
|
-
result.set(prop, val);
|
90
|
-
}
|
91
|
-
});
|
92
|
-
return result;
|
93
|
-
}
|
94
|
-
function isNonAnimatableStyle(prop) {
|
95
|
-
return prop === 'display' || prop === 'position';
|
96
|
-
}
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"special_cased_styles.js","sourceRoot":"","sources":["../../../../../../../../packages/animations/browser/src/render/special_cased_styles.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 {ɵStyleDataMap} from '@angular/animations';\n\nimport {eraseStyles, setStyles} from '../util';\n\n/**\n * Returns an instance of `SpecialCasedStyles` if and when any special (non animateable) styles are\n * detected.\n *\n * In CSS there exist properties that cannot be animated within a keyframe animation\n * (whether it be via CSS keyframes or web-animations) and the animation implementation\n * will ignore them. This function is designed to detect those special cased styles and\n * return a container that will be executed at the start and end of the animation.\n *\n * @returns an instance of `SpecialCasedStyles` if any special styles are detected otherwise `null`\n */\nexport function packageNonAnimatableStyles(\n  element: any,\n  styles: ɵStyleDataMap | Array<ɵStyleDataMap>,\n): SpecialCasedStyles | null {\n  let startStyles: ɵStyleDataMap | null = null;\n  let endStyles: ɵStyleDataMap | null = null;\n  if (Array.isArray(styles) && styles.length) {\n    startStyles = filterNonAnimatableStyles(styles[0]);\n    if (styles.length > 1) {\n      endStyles = filterNonAnimatableStyles(styles[styles.length - 1]);\n    }\n  } else if (styles instanceof Map) {\n    startStyles = filterNonAnimatableStyles(styles);\n  }\n\n  return startStyles || endStyles ? new SpecialCasedStyles(element, startStyles, endStyles) : null;\n}\n\n/**\n * Designed to be executed during a keyframe-based animation to apply any special-cased styles.\n *\n * When started (when the `start()` method is run) then the provided `startStyles`\n * will be applied. When finished (when the `finish()` method is called) the\n * `endStyles` will be applied as well any any starting styles. Finally when\n * `destroy()` is called then all styles will be removed.\n */\nexport class SpecialCasedStyles {\n  static initialStylesByElement = /* @__PURE__ */ new WeakMap<any, ɵStyleDataMap>();\n\n  private _state = SpecialCasedStylesState.Pending;\n  private _initialStyles!: ɵStyleDataMap;\n\n  constructor(\n    private _element: any,\n    private _startStyles: ɵStyleDataMap | null,\n    private _endStyles: ɵStyleDataMap | null,\n  ) {\n    let initialStyles = SpecialCasedStyles.initialStylesByElement.get(_element);\n    if (!initialStyles) {\n      SpecialCasedStyles.initialStylesByElement.set(_element, (initialStyles = new Map()));\n    }\n    this._initialStyles = initialStyles;\n  }\n\n  start() {\n    if (this._state < SpecialCasedStylesState.Started) {\n      if (this._startStyles) {\n        setStyles(this._element, this._startStyles, this._initialStyles);\n      }\n      this._state = SpecialCasedStylesState.Started;\n    }\n  }\n\n  finish() {\n    this.start();\n    if (this._state < SpecialCasedStylesState.Finished) {\n      setStyles(this._element, this._initialStyles);\n      if (this._endStyles) {\n        setStyles(this._element, this._endStyles);\n        this._endStyles = null;\n      }\n      this._state = SpecialCasedStylesState.Started;\n    }\n  }\n\n  destroy() {\n    this.finish();\n    if (this._state < SpecialCasedStylesState.Destroyed) {\n      SpecialCasedStyles.initialStylesByElement.delete(this._element);\n      if (this._startStyles) {\n        eraseStyles(this._element, this._startStyles);\n        this._endStyles = null;\n      }\n      if (this._endStyles) {\n        eraseStyles(this._element, this._endStyles);\n        this._endStyles = null;\n      }\n      setStyles(this._element, this._initialStyles);\n      this._state = SpecialCasedStylesState.Destroyed;\n    }\n  }\n}\n\n/**\n * An enum of states reflective of what the status of `SpecialCasedStyles` is.\n *\n * Depending on how `SpecialCasedStyles` is interacted with, the start and end\n * styles may not be applied in the same way. This enum ensures that if and when\n * the ending styles are applied then the starting styles are applied. It is\n * also used to reflect what the current status of the special cased styles are\n * which helps prevent the starting/ending styles not be applied twice. It is\n * also used to cleanup the styles once `SpecialCasedStyles` is destroyed.\n */\nconst enum SpecialCasedStylesState {\n  Pending = 0,\n  Started = 1,\n  Finished = 2,\n  Destroyed = 3,\n}\n\nfunction filterNonAnimatableStyles(styles: ɵStyleDataMap): ɵStyleDataMap | null {\n  let result: ɵStyleDataMap | null = null;\n  styles.forEach((val, prop) => {\n    if (isNonAnimatableStyle(prop)) {\n      result = result || new Map();\n      result.set(prop, val);\n    }\n  });\n  return result;\n}\n\nfunction isNonAnimatableStyle(prop: string) {\n  return prop === 'display' || prop === 'position';\n}\n"]}
|