@angular/animations 17.0.0-next.5 → 17.0.0-next.7
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/browser/index.d.ts +112 -13
- package/browser/testing/index.d.ts +1 -1
- package/esm2022/browser/src/browser.mjs +2 -2
- package/esm2022/browser/src/create_engine.mjs +20 -0
- package/esm2022/browser/src/private_export.mjs +4 -2
- package/esm2022/browser/src/render/animation_driver.mjs +35 -4
- package/esm2022/browser/src/render/animation_renderer.mjs +107 -0
- package/esm2022/browser/src/render/renderer.mjs +157 -0
- package/esm2022/browser/src/render/transition_animation_engine.mjs +1 -1
- package/esm2022/src/version.mjs +1 -1
- package/fesm2022/animations.mjs +1 -1
- package/fesm2022/browser/testing.mjs +1 -1
- package/fesm2022/browser.mjs +393 -98
- package/fesm2022/browser.mjs.map +1 -1
- package/index.d.ts +1 -1
- package/package.json +2 -2
@@ -0,0 +1,157 @@
|
|
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
|
+
this.isAnimationRenderer = true;
|
17
|
+
}
|
18
|
+
get data() {
|
19
|
+
return this.delegate.data;
|
20
|
+
}
|
21
|
+
destroyNode(node) {
|
22
|
+
this.delegate.destroyNode?.(node);
|
23
|
+
}
|
24
|
+
destroy() {
|
25
|
+
this.engine.destroy(this.namespaceId, this.delegate);
|
26
|
+
this.engine.afterFlushAnimationsDone(() => {
|
27
|
+
// Call the renderer destroy method after the animations has finished as otherwise
|
28
|
+
// styles will be removed too early which will cause an unstyled animation.
|
29
|
+
queueMicrotask(() => {
|
30
|
+
this.delegate.destroy();
|
31
|
+
});
|
32
|
+
});
|
33
|
+
this._onDestroy?.();
|
34
|
+
}
|
35
|
+
createElement(name, namespace) {
|
36
|
+
return this.delegate.createElement(name, namespace);
|
37
|
+
}
|
38
|
+
createComment(value) {
|
39
|
+
return this.delegate.createComment(value);
|
40
|
+
}
|
41
|
+
createText(value) {
|
42
|
+
return this.delegate.createText(value);
|
43
|
+
}
|
44
|
+
appendChild(parent, newChild) {
|
45
|
+
this.delegate.appendChild(parent, newChild);
|
46
|
+
this.engine.onInsert(this.namespaceId, newChild, parent, false);
|
47
|
+
}
|
48
|
+
insertBefore(parent, newChild, refChild, isMove = true) {
|
49
|
+
this.delegate.insertBefore(parent, newChild, refChild);
|
50
|
+
// If `isMove` true than we should animate this insert.
|
51
|
+
this.engine.onInsert(this.namespaceId, newChild, parent, isMove);
|
52
|
+
}
|
53
|
+
removeChild(parent, oldChild, isHostElement) {
|
54
|
+
this.engine.onRemove(this.namespaceId, oldChild, this.delegate);
|
55
|
+
}
|
56
|
+
selectRootElement(selectorOrNode, preserveContent) {
|
57
|
+
return this.delegate.selectRootElement(selectorOrNode, preserveContent);
|
58
|
+
}
|
59
|
+
parentNode(node) {
|
60
|
+
return this.delegate.parentNode(node);
|
61
|
+
}
|
62
|
+
nextSibling(node) {
|
63
|
+
return this.delegate.nextSibling(node);
|
64
|
+
}
|
65
|
+
setAttribute(el, name, value, namespace) {
|
66
|
+
this.delegate.setAttribute(el, name, value, namespace);
|
67
|
+
}
|
68
|
+
removeAttribute(el, name, namespace) {
|
69
|
+
this.delegate.removeAttribute(el, name, namespace);
|
70
|
+
}
|
71
|
+
addClass(el, name) {
|
72
|
+
this.delegate.addClass(el, name);
|
73
|
+
}
|
74
|
+
removeClass(el, name) {
|
75
|
+
this.delegate.removeClass(el, name);
|
76
|
+
}
|
77
|
+
setStyle(el, style, value, flags) {
|
78
|
+
this.delegate.setStyle(el, style, value, flags);
|
79
|
+
}
|
80
|
+
removeStyle(el, style, flags) {
|
81
|
+
this.delegate.removeStyle(el, style, flags);
|
82
|
+
}
|
83
|
+
setProperty(el, name, value) {
|
84
|
+
if (name.charAt(0) == ANIMATION_PREFIX && name == DISABLE_ANIMATIONS_FLAG) {
|
85
|
+
this.disableAnimations(el, !!value);
|
86
|
+
}
|
87
|
+
else {
|
88
|
+
this.delegate.setProperty(el, name, value);
|
89
|
+
}
|
90
|
+
}
|
91
|
+
setValue(node, value) {
|
92
|
+
this.delegate.setValue(node, value);
|
93
|
+
}
|
94
|
+
listen(target, eventName, callback) {
|
95
|
+
return this.delegate.listen(target, eventName, callback);
|
96
|
+
}
|
97
|
+
disableAnimations(element, value) {
|
98
|
+
this.engine.disableAnimations(element, value);
|
99
|
+
}
|
100
|
+
}
|
101
|
+
export class AnimationRenderer extends BaseAnimationRenderer {
|
102
|
+
constructor(factory, namespaceId, delegate, engine, onDestroy) {
|
103
|
+
super(namespaceId, delegate, engine, onDestroy);
|
104
|
+
this.factory = factory;
|
105
|
+
this.namespaceId = namespaceId;
|
106
|
+
}
|
107
|
+
setProperty(el, name, value) {
|
108
|
+
if (name.charAt(0) == ANIMATION_PREFIX) {
|
109
|
+
if (name.charAt(1) == '.' && name == DISABLE_ANIMATIONS_FLAG) {
|
110
|
+
value = value === undefined ? true : !!value;
|
111
|
+
this.disableAnimations(el, value);
|
112
|
+
}
|
113
|
+
else {
|
114
|
+
this.engine.process(this.namespaceId, el, name.slice(1), value);
|
115
|
+
}
|
116
|
+
}
|
117
|
+
else {
|
118
|
+
this.delegate.setProperty(el, name, value);
|
119
|
+
}
|
120
|
+
}
|
121
|
+
listen(target, eventName, callback) {
|
122
|
+
if (eventName.charAt(0) == ANIMATION_PREFIX) {
|
123
|
+
const element = resolveElementFromTarget(target);
|
124
|
+
let name = eventName.slice(1);
|
125
|
+
let phase = '';
|
126
|
+
// @listener.phase is for trigger animation callbacks
|
127
|
+
// @@listener is for animation builder callbacks
|
128
|
+
if (name.charAt(0) != ANIMATION_PREFIX) {
|
129
|
+
[name, phase] = parseTriggerCallbackName(name);
|
130
|
+
}
|
131
|
+
return this.engine.listen(this.namespaceId, element, name, phase, event => {
|
132
|
+
const countId = event['_data'] || -1;
|
133
|
+
this.factory.scheduleListenerCallback(countId, callback, event);
|
134
|
+
});
|
135
|
+
}
|
136
|
+
return this.delegate.listen(target, eventName, callback);
|
137
|
+
}
|
138
|
+
}
|
139
|
+
function resolveElementFromTarget(target) {
|
140
|
+
switch (target) {
|
141
|
+
case 'body':
|
142
|
+
return document.body;
|
143
|
+
case 'document':
|
144
|
+
return document;
|
145
|
+
case 'window':
|
146
|
+
return window;
|
147
|
+
default:
|
148
|
+
return target;
|
149
|
+
}
|
150
|
+
}
|
151
|
+
function parseTriggerCallbackName(triggerName) {
|
152
|
+
const dotIndex = triggerName.indexOf('.');
|
153
|
+
const trigger = triggerName.substring(0, dotIndex);
|
154
|
+
const phase = triggerName.slice(dotIndex + 1);
|
155
|
+
return [trigger, phase];
|
156
|
+
}
|
157
|
+
//# 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 type {Renderer2, RendererFactory2, RendererStyleFlags2} 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\nexport class BaseAnimationRenderer implements Renderer2 {\n  public readonly isAnimationRenderer = true;\n\n  constructor(\n      protected namespaceId: string, public delegate: Renderer2, public engine: AnimationEngine,\n      private _onDestroy?: () => void) {}\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    this.engine.onRemove(this.namespaceId, oldChild, this.delegate);\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, namespaceId: string,\n      delegate: Renderer2, engine: AnimationEngine, onDestroy?: () => void) {\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, eventName: string,\n      callback: (event: any) => any): () => 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"]}
|