@angular/platform-browser 12.2.8 → 13.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/animations/animations.d.ts +47 -56
- package/animations/package.json +5 -5
- package/esm2020/animations/animations.mjs +5 -0
- package/{esm2015/animations/index.js → esm2020/animations/index.mjs} +0 -0
- package/{esm2015/animations/public_api.js → esm2020/animations/public_api.mjs} +0 -0
- package/esm2020/animations/src/animation_builder.mjs +106 -0
- package/esm2020/animations/src/animation_renderer.mjs +248 -0
- package/{esm2015/animations/src/animations.js → esm2020/animations/src/animations.mjs} +0 -0
- package/esm2020/animations/src/module.mjs +68 -0
- package/{esm2015/animations/src/private_export.js → esm2020/animations/src/private_export.mjs} +0 -0
- package/esm2020/animations/src/providers.mjs +71 -0
- package/{esm2015/index.js → esm2020/index.mjs} +0 -0
- package/esm2020/platform-browser.mjs +5 -0
- package/{esm2015/public_api.js → esm2020/public_api.mjs} +0 -0
- package/{esm2015/src/browser/browser_adapter.js → esm2020/src/browser/browser_adapter.mjs} +0 -0
- package/{esm2015/src/browser/generic_browser_adapter.js → esm2020/src/browser/generic_browser_adapter.mjs} +0 -0
- package/esm2020/src/browser/meta.mjs +182 -0
- package/{esm2015/src/browser/server-transition.js → esm2020/src/browser/server-transition.mjs} +0 -0
- package/{esm2015/src/browser/testability.js → esm2020/src/browser/testability.mjs} +0 -0
- package/esm2020/src/browser/title.mjs +54 -0
- package/{esm2015/src/browser/tools/browser.js → esm2020/src/browser/tools/browser.mjs} +0 -0
- package/{esm2015/src/browser/tools/common_tools.js → esm2020/src/browser/tools/common_tools.mjs} +0 -0
- package/{esm2015/src/browser/tools/tools.js → esm2020/src/browser/tools/tools.mjs} +0 -0
- package/esm2020/src/browser/transfer_state.mjs +158 -0
- package/esm2020/src/browser/xhr.mjs +16 -0
- package/esm2020/src/browser.mjs +132 -0
- package/{esm2015/src/dom/debug/by.js → esm2020/src/dom/debug/by.mjs} +0 -0
- package/esm2020/src/dom/debug/ng_probe.mjs +54 -0
- package/esm2020/src/dom/dom_renderer.mjs +310 -0
- package/esm2020/src/dom/events/dom_events.mjs +37 -0
- package/esm2020/src/dom/events/event_manager.mjs +103 -0
- package/esm2020/src/dom/events/hammer_gestures.mjs +266 -0
- package/esm2020/src/dom/events/key_events.mjs +204 -0
- package/esm2020/src/dom/shared_styles_host.mjs +83 -0
- package/{esm2015/src/dom/util.js → esm2020/src/dom/util.mjs} +0 -0
- package/{esm2015/src/platform-browser.js → esm2020/src/platform-browser.mjs} +0 -0
- package/{esm2015/src/private_export.js → esm2020/src/private_export.mjs} +0 -0
- package/{esm2015/src/security/dom_sanitization_service.js → esm2020/src/security/dom_sanitization_service.mjs} +16 -12
- package/{esm2015/src/version.js → esm2020/src/version.mjs} +1 -1
- package/{esm2015/testing/index.js → esm2020/testing/index.mjs} +0 -0
- package/{esm2015/testing/public_api.js → esm2020/testing/public_api.mjs} +0 -0
- package/esm2020/testing/src/browser.mjs +48 -0
- package/{esm2015/testing/src/browser_util.js → esm2020/testing/src/browser_util.mjs} +0 -0
- package/{esm2015/testing/src/matchers.js → esm2020/testing/src/matchers.mjs} +0 -0
- package/{esm2015/testing/src/testing.js → esm2020/testing/src/testing.mjs} +0 -0
- package/esm2020/testing/testing.mjs +5 -0
- package/fesm2015/{animations.js → animations.mjs} +52 -40
- package/fesm2015/animations.mjs.map +1 -0
- package/fesm2015/platform-browser.mjs +2152 -0
- package/fesm2015/platform-browser.mjs.map +1 -0
- package/fesm2015/{testing.js → testing.mjs} +23 -15
- package/fesm2015/testing.mjs.map +1 -0
- package/fesm2020/animations.mjs +524 -0
- package/fesm2020/animations.mjs.map +1 -0
- package/{fesm2015/platform-browser.js → fesm2020/platform-browser.mjs} +158 -121
- package/fesm2020/platform-browser.mjs.map +1 -0
- package/fesm2020/testing.mjs +285 -0
- package/fesm2020/testing.mjs.map +1 -0
- package/package.json +34 -10
- package/platform-browser.d.ts +63 -78
- package/testing/package.json +5 -5
- package/testing/testing.d.ts +6 -4
- package/animations/animations.metadata.json +0 -1
- package/animations.d.ts +0 -7
- package/animations.metadata.json +0 -1
- package/bundles/platform-browser-animations.umd.js +0 -873
- package/bundles/platform-browser-animations.umd.js.map +0 -1
- package/bundles/platform-browser-testing.umd.js +0 -684
- package/bundles/platform-browser-testing.umd.js.map +0 -1
- package/bundles/platform-browser.umd.js +0 -2505
- package/bundles/platform-browser.umd.js.map +0 -1
- package/esm2015/animations/animations.externs.js +0 -6
- package/esm2015/animations/animations.js +0 -7
- package/esm2015/animations/src/animation_builder.js +0 -105
- package/esm2015/animations/src/animation_renderer.js +0 -249
- package/esm2015/animations/src/module.js +0 -59
- package/esm2015/animations/src/providers.js +0 -69
- package/esm2015/platform-browser.externs.js +0 -6
- package/esm2015/platform-browser.js +0 -16
- package/esm2015/src/browser/meta.js +0 -180
- package/esm2015/src/browser/title.js +0 -52
- package/esm2015/src/browser/transfer_state.js +0 -151
- package/esm2015/src/browser/xhr.js +0 -20
- package/esm2015/src/browser.js +0 -125
- package/esm2015/src/dom/debug/ng_probe.js +0 -56
- package/esm2015/src/dom/dom_renderer.js +0 -308
- package/esm2015/src/dom/events/dom_events.js +0 -34
- package/esm2015/src/dom/events/event_manager.js +0 -101
- package/esm2015/src/dom/events/hammer_gestures.js +0 -252
- package/esm2015/src/dom/events/key_events.js +0 -203
- package/esm2015/src/dom/shared_styles_host.js +0 -78
- package/esm2015/testing/src/browser.js +0 -41
- package/esm2015/testing/testing.externs.js +0 -6
- package/esm2015/testing/testing.js +0 -6
- package/fesm2015/animations.js.map +0 -1
- package/fesm2015/platform-browser.js.map +0 -1
- package/fesm2015/testing.js.map +0 -1
- package/platform-browser.metadata.json +0 -1
- package/testing/testing.metadata.json +0 -1
- package/testing.d.ts +0 -7
- package/testing.metadata.json +0 -1
@@ -1,5 +1,5 @@
|
|
1
1
|
/**
|
2
|
-
* @license Angular
|
2
|
+
* @license Angular v13.0.0-next.11
|
3
3
|
* (c) 2010-2021 Google LLC. https://angular.io/
|
4
4
|
* License: MIT
|
5
5
|
*/
|
@@ -10,27 +10,55 @@ import { AnimationFactory } from '@angular/animations';
|
|
10
10
|
import { AnimationMetadata } from '@angular/animations';
|
11
11
|
import { AnimationOptions } from '@angular/animations';
|
12
12
|
import { AnimationPlayer } from '@angular/animations';
|
13
|
+
import * as i0 from '@angular/core';
|
14
|
+
import * as i1 from '@angular/platform-browser';
|
13
15
|
import { InjectionToken } from '@angular/core';
|
14
16
|
import { ModuleWithProviders } from '@angular/core';
|
15
17
|
import { NgZone } from '@angular/core';
|
16
18
|
import { OnDestroy } from '@angular/core';
|
17
|
-
import { Provider } from '@angular/core';
|
18
19
|
import { Renderer2 } from '@angular/core';
|
19
20
|
import { RendererFactory2 } from '@angular/core';
|
20
21
|
import { RendererStyleFlags2 } from '@angular/core';
|
21
22
|
import { RendererType2 } from '@angular/core';
|
22
23
|
import { ɵAnimationEngine } from '@angular/animations/browser';
|
23
24
|
import { ɵAnimationStyleNormalizer } from '@angular/animations/browser';
|
24
|
-
import { ɵCssKeyframesDriver } from '@angular/animations/browser';
|
25
|
-
import { ɵDomRendererFactory2 } from '@angular/platform-browser';
|
26
|
-
import { ɵWebAnimationsDriver } from '@angular/animations/browser';
|
27
|
-
import { ɵWebAnimationsStyleNormalizer } from '@angular/animations/browser';
|
28
25
|
|
29
26
|
/**
|
30
27
|
* @publicApi
|
31
28
|
*/
|
32
29
|
export declare const ANIMATION_MODULE_TYPE: InjectionToken<"NoopAnimations" | "BrowserAnimations">;
|
33
30
|
|
31
|
+
declare class BaseAnimationRenderer implements Renderer2 {
|
32
|
+
protected namespaceId: string;
|
33
|
+
delegate: Renderer2;
|
34
|
+
engine: ɵAnimationEngine;
|
35
|
+
constructor(namespaceId: string, delegate: Renderer2, engine: ɵAnimationEngine);
|
36
|
+
get data(): {
|
37
|
+
[key: string]: any;
|
38
|
+
};
|
39
|
+
destroyNode: ((n: any) => void) | null;
|
40
|
+
destroy(): void;
|
41
|
+
createElement(name: string, namespace?: string | null | undefined): any;
|
42
|
+
createComment(value: string): any;
|
43
|
+
createText(value: string): any;
|
44
|
+
appendChild(parent: any, newChild: any): void;
|
45
|
+
insertBefore(parent: any, newChild: any, refChild: any, isMove?: boolean): void;
|
46
|
+
removeChild(parent: any, oldChild: any, isHostElement: boolean): void;
|
47
|
+
selectRootElement(selectorOrNode: any, preserveContent?: boolean): any;
|
48
|
+
parentNode(node: any): any;
|
49
|
+
nextSibling(node: any): any;
|
50
|
+
setAttribute(el: any, name: string, value: string, namespace?: string | null | undefined): void;
|
51
|
+
removeAttribute(el: any, name: string, namespace?: string | null | undefined): void;
|
52
|
+
addClass(el: any, name: string): void;
|
53
|
+
removeClass(el: any, name: string): void;
|
54
|
+
setStyle(el: any, style: string, value: any, flags?: RendererStyleFlags2 | undefined): void;
|
55
|
+
removeStyle(el: any, style: string, flags?: RendererStyleFlags2 | undefined): void;
|
56
|
+
setProperty(el: any, name: string, value: any): void;
|
57
|
+
setValue(node: any, value: string): void;
|
58
|
+
listen(target: any, eventName: string, callback: (event: any) => boolean | void): () => void;
|
59
|
+
protected disableAnimations(element: any, value: boolean): void;
|
60
|
+
}
|
61
|
+
|
34
62
|
/**
|
35
63
|
* Exports `BrowserModule` with additional [dependency-injection providers](guide/glossary#provider)
|
36
64
|
* for use with animations. See [Animations](guide/animations).
|
@@ -54,6 +82,9 @@ export declare class BrowserAnimationsModule {
|
|
54
82
|
* ```
|
55
83
|
*/
|
56
84
|
static withConfig(config: BrowserAnimationsModuleConfig): ModuleWithProviders<BrowserAnimationsModule>;
|
85
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<BrowserAnimationsModule, never>;
|
86
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<BrowserAnimationsModule, never, never, [typeof i1.BrowserModule]>;
|
87
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<BrowserAnimationsModule>;
|
57
88
|
}
|
58
89
|
|
59
90
|
/**
|
@@ -73,58 +104,12 @@ export declare interface BrowserAnimationsModuleConfig {
|
|
73
104
|
* @publicApi
|
74
105
|
*/
|
75
106
|
export declare class NoopAnimationsModule {
|
107
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NoopAnimationsModule, never>;
|
108
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<NoopAnimationsModule, never, never, [typeof i1.BrowserModule]>;
|
109
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<NoopAnimationsModule>;
|
76
110
|
}
|
77
111
|
|
78
|
-
export declare
|
79
|
-
|
80
|
-
export declare function ɵangular_packages_platform_browser_animations_animations_b(): ɵWebAnimationsStyleNormalizer;
|
81
|
-
|
82
|
-
export declare function ɵangular_packages_platform_browser_animations_animations_c(renderer: ɵDomRendererFactory2, engine: ɵAnimationEngine, zone: NgZone): ɵAnimationRendererFactory;
|
83
|
-
|
84
|
-
/**
|
85
|
-
* Separate providers from the actual module so that we can do a local modification in Google3 to
|
86
|
-
* include them in the BrowserModule.
|
87
|
-
*/
|
88
|
-
export declare const ɵangular_packages_platform_browser_animations_animations_d: Provider[];
|
89
|
-
|
90
|
-
/**
|
91
|
-
* Separate providers from the actual module so that we can do a local modification in Google3 to
|
92
|
-
* include them in the BrowserTestingModule.
|
93
|
-
*/
|
94
|
-
export declare const ɵangular_packages_platform_browser_animations_animations_e: Provider[];
|
95
|
-
|
96
|
-
export declare class ɵangular_packages_platform_browser_animations_animations_f implements Renderer2 {
|
97
|
-
protected namespaceId: string;
|
98
|
-
delegate: Renderer2;
|
99
|
-
engine: ɵAnimationEngine;
|
100
|
-
constructor(namespaceId: string, delegate: Renderer2, engine: ɵAnimationEngine);
|
101
|
-
get data(): {
|
102
|
-
[key: string]: any;
|
103
|
-
};
|
104
|
-
destroyNode: ((n: any) => void) | null;
|
105
|
-
destroy(): void;
|
106
|
-
createElement(name: string, namespace?: string | null | undefined): any;
|
107
|
-
createComment(value: string): any;
|
108
|
-
createText(value: string): any;
|
109
|
-
appendChild(parent: any, newChild: any): void;
|
110
|
-
insertBefore(parent: any, newChild: any, refChild: any, isMove?: boolean): void;
|
111
|
-
removeChild(parent: any, oldChild: any, isHostElement: boolean): void;
|
112
|
-
selectRootElement(selectorOrNode: any, preserveContent?: boolean): any;
|
113
|
-
parentNode(node: any): any;
|
114
|
-
nextSibling(node: any): any;
|
115
|
-
setAttribute(el: any, name: string, value: string, namespace?: string | null | undefined): void;
|
116
|
-
removeAttribute(el: any, name: string, namespace?: string | null | undefined): void;
|
117
|
-
addClass(el: any, name: string): void;
|
118
|
-
removeClass(el: any, name: string): void;
|
119
|
-
setStyle(el: any, style: string, value: any, flags?: RendererStyleFlags2 | undefined): void;
|
120
|
-
removeStyle(el: any, style: string, flags?: RendererStyleFlags2 | undefined): void;
|
121
|
-
setProperty(el: any, name: string, value: any): void;
|
122
|
-
setValue(node: any, value: string): void;
|
123
|
-
listen(target: any, eventName: string, callback: (event: any) => boolean | void): () => void;
|
124
|
-
protected disableAnimations(element: any, value: boolean): void;
|
125
|
-
}
|
126
|
-
|
127
|
-
export declare class ɵAnimationRenderer extends ɵangular_packages_platform_browser_animations_animations_f implements Renderer2 {
|
112
|
+
export declare class ɵAnimationRenderer extends BaseAnimationRenderer implements Renderer2 {
|
128
113
|
factory: ɵAnimationRendererFactory;
|
129
114
|
constructor(factory: ɵAnimationRendererFactory, namespaceId: string, delegate: Renderer2, engine: ɵAnimationEngine);
|
130
115
|
setProperty(el: any, name: string, value: any): void;
|
@@ -147,6 +132,8 @@ export declare class ɵAnimationRendererFactory implements RendererFactory2 {
|
|
147
132
|
private _scheduleCountTask;
|
148
133
|
end(): void;
|
149
134
|
whenRenderingDone(): Promise<any>;
|
135
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ɵAnimationRendererFactory, never>;
|
136
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<ɵAnimationRendererFactory>;
|
150
137
|
}
|
151
138
|
|
152
139
|
export declare class ɵBrowserAnimationBuilder extends AnimationBuilder {
|
@@ -154,6 +141,8 @@ export declare class ɵBrowserAnimationBuilder extends AnimationBuilder {
|
|
154
141
|
private _renderer;
|
155
142
|
constructor(rootRenderer: RendererFactory2, doc: any);
|
156
143
|
build(animation: AnimationMetadata | AnimationMetadata[]): AnimationFactory;
|
144
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ɵBrowserAnimationBuilder, never>;
|
145
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<ɵBrowserAnimationBuilder>;
|
157
146
|
}
|
158
147
|
|
159
148
|
export declare class ɵBrowserAnimationFactory extends AnimationFactory {
|
@@ -166,6 +155,8 @@ export declare class ɵBrowserAnimationFactory extends AnimationFactory {
|
|
166
155
|
export declare class ɵInjectableAnimationEngine extends ɵAnimationEngine implements OnDestroy {
|
167
156
|
constructor(doc: any, driver: AnimationDriver, normalizer: ɵAnimationStyleNormalizer);
|
168
157
|
ngOnDestroy(): void;
|
158
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ɵInjectableAnimationEngine, never>;
|
159
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<ɵInjectableAnimationEngine>;
|
169
160
|
}
|
170
161
|
|
171
162
|
export { }
|
package/animations/package.json
CHANGED
@@ -1,10 +1,10 @@
|
|
1
1
|
{
|
2
2
|
"name": "@angular/platform-browser/animations",
|
3
3
|
"sideEffects": false,
|
4
|
-
"
|
5
|
-
"fesm2015": "../fesm2015/animations.
|
6
|
-
"
|
4
|
+
"fesm2020": "../fesm2020/animations.mjs",
|
5
|
+
"fesm2015": "../fesm2015/animations.mjs",
|
6
|
+
"esm2020": "../esm2020/animations/animations.mjs",
|
7
7
|
"typings": "./animations.d.ts",
|
8
|
-
"module": "../fesm2015/animations.
|
9
|
-
"
|
8
|
+
"module": "../fesm2015/animations.mjs",
|
9
|
+
"es2020": "../fesm2020/animations.mjs"
|
10
10
|
}
|
@@ -0,0 +1,5 @@
|
|
1
|
+
/**
|
2
|
+
* Generated bundle index. Do not edit.
|
3
|
+
*/
|
4
|
+
export * from './index';
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5pbWF0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYXRmb3JtLWJyb3dzZXIvYW5pbWF0aW9ucy9hbmltYXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
|
File without changes
|
File without changes
|
@@ -0,0 +1,106 @@
|
|
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 { AnimationBuilder, AnimationFactory, sequence } from '@angular/animations';
|
9
|
+
import { DOCUMENT } from '@angular/common';
|
10
|
+
import { Inject, Injectable, RendererFactory2, ViewEncapsulation } from '@angular/core';
|
11
|
+
import * as i0 from "@angular/core";
|
12
|
+
export class BrowserAnimationBuilder extends AnimationBuilder {
|
13
|
+
constructor(rootRenderer, doc) {
|
14
|
+
super();
|
15
|
+
this._nextAnimationId = 0;
|
16
|
+
const typeData = { id: '0', encapsulation: ViewEncapsulation.None, styles: [], data: { animation: [] } };
|
17
|
+
this._renderer = rootRenderer.createRenderer(doc.body, typeData);
|
18
|
+
}
|
19
|
+
build(animation) {
|
20
|
+
const id = this._nextAnimationId.toString();
|
21
|
+
this._nextAnimationId++;
|
22
|
+
const entry = Array.isArray(animation) ? sequence(animation) : animation;
|
23
|
+
issueAnimationCommand(this._renderer, null, id, 'register', [entry]);
|
24
|
+
return new BrowserAnimationFactory(id, this._renderer);
|
25
|
+
}
|
26
|
+
}
|
27
|
+
BrowserAnimationBuilder.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0-next.11", ngImport: i0, type: BrowserAnimationBuilder, deps: [{ token: i0.RendererFactory2 }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable });
|
28
|
+
BrowserAnimationBuilder.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.0.0-next.11", ngImport: i0, type: BrowserAnimationBuilder });
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0-next.11", ngImport: i0, type: BrowserAnimationBuilder, decorators: [{
|
30
|
+
type: Injectable
|
31
|
+
}], ctorParameters: function () { return [{ type: i0.RendererFactory2 }, { type: undefined, decorators: [{
|
32
|
+
type: Inject,
|
33
|
+
args: [DOCUMENT]
|
34
|
+
}] }]; } });
|
35
|
+
export class BrowserAnimationFactory extends AnimationFactory {
|
36
|
+
constructor(_id, _renderer) {
|
37
|
+
super();
|
38
|
+
this._id = _id;
|
39
|
+
this._renderer = _renderer;
|
40
|
+
}
|
41
|
+
create(element, options) {
|
42
|
+
return new RendererAnimationPlayer(this._id, element, options || {}, this._renderer);
|
43
|
+
}
|
44
|
+
}
|
45
|
+
export class RendererAnimationPlayer {
|
46
|
+
constructor(id, element, options, _renderer) {
|
47
|
+
this.id = id;
|
48
|
+
this.element = element;
|
49
|
+
this._renderer = _renderer;
|
50
|
+
this.parentPlayer = null;
|
51
|
+
this._started = false;
|
52
|
+
this.totalTime = 0;
|
53
|
+
this._command('create', options);
|
54
|
+
}
|
55
|
+
_listen(eventName, callback) {
|
56
|
+
return this._renderer.listen(this.element, `@@${this.id}:${eventName}`, callback);
|
57
|
+
}
|
58
|
+
_command(command, ...args) {
|
59
|
+
return issueAnimationCommand(this._renderer, this.element, this.id, command, args);
|
60
|
+
}
|
61
|
+
onDone(fn) {
|
62
|
+
this._listen('done', fn);
|
63
|
+
}
|
64
|
+
onStart(fn) {
|
65
|
+
this._listen('start', fn);
|
66
|
+
}
|
67
|
+
onDestroy(fn) {
|
68
|
+
this._listen('destroy', fn);
|
69
|
+
}
|
70
|
+
init() {
|
71
|
+
this._command('init');
|
72
|
+
}
|
73
|
+
hasStarted() {
|
74
|
+
return this._started;
|
75
|
+
}
|
76
|
+
play() {
|
77
|
+
this._command('play');
|
78
|
+
this._started = true;
|
79
|
+
}
|
80
|
+
pause() {
|
81
|
+
this._command('pause');
|
82
|
+
}
|
83
|
+
restart() {
|
84
|
+
this._command('restart');
|
85
|
+
}
|
86
|
+
finish() {
|
87
|
+
this._command('finish');
|
88
|
+
}
|
89
|
+
destroy() {
|
90
|
+
this._command('destroy');
|
91
|
+
}
|
92
|
+
reset() {
|
93
|
+
this._command('reset');
|
94
|
+
this._started = false;
|
95
|
+
}
|
96
|
+
setPosition(p) {
|
97
|
+
this._command('setPosition', p);
|
98
|
+
}
|
99
|
+
getPosition() {
|
100
|
+
return this._renderer.engine.players[+this.id]?.getPosition() ?? 0;
|
101
|
+
}
|
102
|
+
}
|
103
|
+
function issueAnimationCommand(renderer, element, id, command, args) {
|
104
|
+
return renderer.setProperty(element, `@@${id}:${command}`, args);
|
105
|
+
}
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animation_builder.js","sourceRoot":"","sources":["../../../../../../../packages/platform-browser/animations/src/animation_builder.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 {AnimationBuilder, AnimationFactory, AnimationMetadata, AnimationOptions, AnimationPlayer, sequence} from '@angular/animations';\nimport {DOCUMENT} from '@angular/common';\nimport {Inject, Injectable, RendererFactory2, RendererType2, ViewEncapsulation} from '@angular/core';\n\nimport {AnimationRenderer} from './animation_renderer';\n\n@Injectable()\nexport class BrowserAnimationBuilder extends AnimationBuilder {\n  private _nextAnimationId = 0;\n  private _renderer: AnimationRenderer;\n\n  constructor(rootRenderer: RendererFactory2, @Inject(DOCUMENT) doc: any) {\n    super();\n    const typeData =\n        {id: '0', encapsulation: ViewEncapsulation.None, styles: [], data: {animation: []}} as\n        RendererType2;\n    this._renderer = rootRenderer.createRenderer(doc.body, typeData) as AnimationRenderer;\n  }\n\n  build(animation: AnimationMetadata|AnimationMetadata[]): AnimationFactory {\n    const id = this._nextAnimationId.toString();\n    this._nextAnimationId++;\n    const entry = Array.isArray(animation) ? sequence(animation) : animation;\n    issueAnimationCommand(this._renderer, null, id, 'register', [entry]);\n    return new BrowserAnimationFactory(id, this._renderer);\n  }\n}\n\nexport class BrowserAnimationFactory extends AnimationFactory {\n  constructor(private _id: string, private _renderer: AnimationRenderer) {\n    super();\n  }\n\n  create(element: any, options?: AnimationOptions): AnimationPlayer {\n    return new RendererAnimationPlayer(this._id, element, options || {}, this._renderer);\n  }\n}\n\nexport class RendererAnimationPlayer implements AnimationPlayer {\n  public parentPlayer: AnimationPlayer|null = null;\n  private _started = false;\n\n  constructor(\n      public id: string, public element: any, options: AnimationOptions,\n      private _renderer: AnimationRenderer) {\n    this._command('create', options);\n  }\n\n  private _listen(eventName: string, callback: (event: any) => any): () => void {\n    return this._renderer.listen(this.element, `@@${this.id}:${eventName}`, callback);\n  }\n\n  private _command(command: string, ...args: any[]) {\n    return issueAnimationCommand(this._renderer, this.element, this.id, command, args);\n  }\n\n  onDone(fn: () => void): void {\n    this._listen('done', fn);\n  }\n\n  onStart(fn: () => void): void {\n    this._listen('start', fn);\n  }\n\n  onDestroy(fn: () => void): void {\n    this._listen('destroy', fn);\n  }\n\n  init(): void {\n    this._command('init');\n  }\n\n  hasStarted(): boolean {\n    return this._started;\n  }\n\n  play(): void {\n    this._command('play');\n    this._started = true;\n  }\n\n  pause(): void {\n    this._command('pause');\n  }\n\n  restart(): void {\n    this._command('restart');\n  }\n\n  finish(): void {\n    this._command('finish');\n  }\n\n  destroy(): void {\n    this._command('destroy');\n  }\n\n  reset(): void {\n    this._command('reset');\n    this._started = false;\n  }\n\n  setPosition(p: number): void {\n    this._command('setPosition', p);\n  }\n\n  getPosition(): number {\n    return this._renderer.engine.players[+this.id]?.getPosition() ?? 0;\n  }\n\n  public totalTime = 0;\n}\n\nfunction issueAnimationCommand(\n    renderer: AnimationRenderer, element: any, id: string, command: string, args: any[]): any {\n  return renderer.setProperty(element, `@@${id}:${command}`, args);\n}\n"]}
|
@@ -0,0 +1,248 @@
|
|
1
|
+
import { ɵAnimationEngine as AnimationEngine } from '@angular/animations/browser';
|
2
|
+
import { Injectable, NgZone, RendererFactory2 } from '@angular/core';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
import * as i1 from "@angular/animations/browser";
|
5
|
+
const ANIMATION_PREFIX = '@';
|
6
|
+
const DISABLE_ANIMATIONS_FLAG = '@.disabled';
|
7
|
+
export class AnimationRendererFactory {
|
8
|
+
constructor(delegate, engine, _zone) {
|
9
|
+
this.delegate = delegate;
|
10
|
+
this.engine = engine;
|
11
|
+
this._zone = _zone;
|
12
|
+
this._currentId = 0;
|
13
|
+
this._microtaskId = 1;
|
14
|
+
this._animationCallbacksBuffer = [];
|
15
|
+
this._rendererCache = new Map();
|
16
|
+
this._cdRecurDepth = 0;
|
17
|
+
this.promise = Promise.resolve(0);
|
18
|
+
engine.onRemovalComplete = (element, delegate) => {
|
19
|
+
// Note: if an component element has a leave animation, and the component
|
20
|
+
// a host leave animation, the view engine will call `removeChild` for the parent
|
21
|
+
// component renderer as well as for the child component renderer.
|
22
|
+
// Therefore, we need to check if we already removed the element.
|
23
|
+
if (delegate && delegate.parentNode(element)) {
|
24
|
+
delegate.removeChild(element.parentNode, element);
|
25
|
+
}
|
26
|
+
};
|
27
|
+
}
|
28
|
+
createRenderer(hostElement, type) {
|
29
|
+
const EMPTY_NAMESPACE_ID = '';
|
30
|
+
// cache the delegates to find out which cached delegate can
|
31
|
+
// be used by which cached renderer
|
32
|
+
const delegate = this.delegate.createRenderer(hostElement, type);
|
33
|
+
if (!hostElement || !type || !type.data || !type.data['animation']) {
|
34
|
+
let renderer = this._rendererCache.get(delegate);
|
35
|
+
if (!renderer) {
|
36
|
+
renderer = new BaseAnimationRenderer(EMPTY_NAMESPACE_ID, delegate, this.engine);
|
37
|
+
// only cache this result when the base renderer is used
|
38
|
+
this._rendererCache.set(delegate, renderer);
|
39
|
+
}
|
40
|
+
return renderer;
|
41
|
+
}
|
42
|
+
const componentId = type.id;
|
43
|
+
const namespaceId = type.id + '-' + this._currentId;
|
44
|
+
this._currentId++;
|
45
|
+
this.engine.register(namespaceId, hostElement);
|
46
|
+
const registerTrigger = (trigger) => {
|
47
|
+
if (Array.isArray(trigger)) {
|
48
|
+
trigger.forEach(registerTrigger);
|
49
|
+
}
|
50
|
+
else {
|
51
|
+
this.engine.registerTrigger(componentId, namespaceId, hostElement, trigger.name, trigger);
|
52
|
+
}
|
53
|
+
};
|
54
|
+
const animationTriggers = type.data['animation'];
|
55
|
+
animationTriggers.forEach(registerTrigger);
|
56
|
+
return new AnimationRenderer(this, namespaceId, delegate, this.engine);
|
57
|
+
}
|
58
|
+
begin() {
|
59
|
+
this._cdRecurDepth++;
|
60
|
+
if (this.delegate.begin) {
|
61
|
+
this.delegate.begin();
|
62
|
+
}
|
63
|
+
}
|
64
|
+
_scheduleCountTask() {
|
65
|
+
// always use promise to schedule microtask instead of use Zone
|
66
|
+
this.promise.then(() => {
|
67
|
+
this._microtaskId++;
|
68
|
+
});
|
69
|
+
}
|
70
|
+
/** @internal */
|
71
|
+
scheduleListenerCallback(count, fn, data) {
|
72
|
+
if (count >= 0 && count < this._microtaskId) {
|
73
|
+
this._zone.run(() => fn(data));
|
74
|
+
return;
|
75
|
+
}
|
76
|
+
if (this._animationCallbacksBuffer.length == 0) {
|
77
|
+
Promise.resolve(null).then(() => {
|
78
|
+
this._zone.run(() => {
|
79
|
+
this._animationCallbacksBuffer.forEach(tuple => {
|
80
|
+
const [fn, data] = tuple;
|
81
|
+
fn(data);
|
82
|
+
});
|
83
|
+
this._animationCallbacksBuffer = [];
|
84
|
+
});
|
85
|
+
});
|
86
|
+
}
|
87
|
+
this._animationCallbacksBuffer.push([fn, data]);
|
88
|
+
}
|
89
|
+
end() {
|
90
|
+
this._cdRecurDepth--;
|
91
|
+
// this is to prevent animations from running twice when an inner
|
92
|
+
// component does CD when a parent component instead has inserted it
|
93
|
+
if (this._cdRecurDepth == 0) {
|
94
|
+
this._zone.runOutsideAngular(() => {
|
95
|
+
this._scheduleCountTask();
|
96
|
+
this.engine.flush(this._microtaskId);
|
97
|
+
});
|
98
|
+
}
|
99
|
+
if (this.delegate.end) {
|
100
|
+
this.delegate.end();
|
101
|
+
}
|
102
|
+
}
|
103
|
+
whenRenderingDone() {
|
104
|
+
return this.engine.whenRenderingDone();
|
105
|
+
}
|
106
|
+
}
|
107
|
+
AnimationRendererFactory.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0-next.11", ngImport: i0, type: AnimationRendererFactory, deps: [{ token: i0.RendererFactory2 }, { token: i1.ɵAnimationEngine }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Injectable });
|
108
|
+
AnimationRendererFactory.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.0.0-next.11", ngImport: i0, type: AnimationRendererFactory });
|
109
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0-next.11", ngImport: i0, type: AnimationRendererFactory, decorators: [{
|
110
|
+
type: Injectable
|
111
|
+
}], ctorParameters: function () { return [{ type: i0.RendererFactory2 }, { type: i1.ɵAnimationEngine }, { type: i0.NgZone }]; } });
|
112
|
+
export class BaseAnimationRenderer {
|
113
|
+
constructor(namespaceId, delegate, engine) {
|
114
|
+
this.namespaceId = namespaceId;
|
115
|
+
this.delegate = delegate;
|
116
|
+
this.engine = engine;
|
117
|
+
this.destroyNode = this.delegate.destroyNode ? (n) => delegate.destroyNode(n) : null;
|
118
|
+
}
|
119
|
+
get data() {
|
120
|
+
return this.delegate.data;
|
121
|
+
}
|
122
|
+
destroy() {
|
123
|
+
this.engine.destroy(this.namespaceId, this.delegate);
|
124
|
+
this.delegate.destroy();
|
125
|
+
}
|
126
|
+
createElement(name, namespace) {
|
127
|
+
return this.delegate.createElement(name, namespace);
|
128
|
+
}
|
129
|
+
createComment(value) {
|
130
|
+
return this.delegate.createComment(value);
|
131
|
+
}
|
132
|
+
createText(value) {
|
133
|
+
return this.delegate.createText(value);
|
134
|
+
}
|
135
|
+
appendChild(parent, newChild) {
|
136
|
+
this.delegate.appendChild(parent, newChild);
|
137
|
+
this.engine.onInsert(this.namespaceId, newChild, parent, false);
|
138
|
+
}
|
139
|
+
insertBefore(parent, newChild, refChild, isMove = true) {
|
140
|
+
this.delegate.insertBefore(parent, newChild, refChild);
|
141
|
+
// If `isMove` true than we should animate this insert.
|
142
|
+
this.engine.onInsert(this.namespaceId, newChild, parent, isMove);
|
143
|
+
}
|
144
|
+
removeChild(parent, oldChild, isHostElement) {
|
145
|
+
this.engine.onRemove(this.namespaceId, oldChild, this.delegate, isHostElement);
|
146
|
+
}
|
147
|
+
selectRootElement(selectorOrNode, preserveContent) {
|
148
|
+
return this.delegate.selectRootElement(selectorOrNode, preserveContent);
|
149
|
+
}
|
150
|
+
parentNode(node) {
|
151
|
+
return this.delegate.parentNode(node);
|
152
|
+
}
|
153
|
+
nextSibling(node) {
|
154
|
+
return this.delegate.nextSibling(node);
|
155
|
+
}
|
156
|
+
setAttribute(el, name, value, namespace) {
|
157
|
+
this.delegate.setAttribute(el, name, value, namespace);
|
158
|
+
}
|
159
|
+
removeAttribute(el, name, namespace) {
|
160
|
+
this.delegate.removeAttribute(el, name, namespace);
|
161
|
+
}
|
162
|
+
addClass(el, name) {
|
163
|
+
this.delegate.addClass(el, name);
|
164
|
+
}
|
165
|
+
removeClass(el, name) {
|
166
|
+
this.delegate.removeClass(el, name);
|
167
|
+
}
|
168
|
+
setStyle(el, style, value, flags) {
|
169
|
+
this.delegate.setStyle(el, style, value, flags);
|
170
|
+
}
|
171
|
+
removeStyle(el, style, flags) {
|
172
|
+
this.delegate.removeStyle(el, style, flags);
|
173
|
+
}
|
174
|
+
setProperty(el, name, value) {
|
175
|
+
if (name.charAt(0) == ANIMATION_PREFIX && name == DISABLE_ANIMATIONS_FLAG) {
|
176
|
+
this.disableAnimations(el, !!value);
|
177
|
+
}
|
178
|
+
else {
|
179
|
+
this.delegate.setProperty(el, name, value);
|
180
|
+
}
|
181
|
+
}
|
182
|
+
setValue(node, value) {
|
183
|
+
this.delegate.setValue(node, value);
|
184
|
+
}
|
185
|
+
listen(target, eventName, callback) {
|
186
|
+
return this.delegate.listen(target, eventName, callback);
|
187
|
+
}
|
188
|
+
disableAnimations(element, value) {
|
189
|
+
this.engine.disableAnimations(element, value);
|
190
|
+
}
|
191
|
+
}
|
192
|
+
export class AnimationRenderer extends BaseAnimationRenderer {
|
193
|
+
constructor(factory, namespaceId, delegate, engine) {
|
194
|
+
super(namespaceId, delegate, engine);
|
195
|
+
this.factory = factory;
|
196
|
+
this.namespaceId = namespaceId;
|
197
|
+
}
|
198
|
+
setProperty(el, name, value) {
|
199
|
+
if (name.charAt(0) == ANIMATION_PREFIX) {
|
200
|
+
if (name.charAt(1) == '.' && name == DISABLE_ANIMATIONS_FLAG) {
|
201
|
+
value = value === undefined ? true : !!value;
|
202
|
+
this.disableAnimations(el, value);
|
203
|
+
}
|
204
|
+
else {
|
205
|
+
this.engine.process(this.namespaceId, el, name.substr(1), value);
|
206
|
+
}
|
207
|
+
}
|
208
|
+
else {
|
209
|
+
this.delegate.setProperty(el, name, value);
|
210
|
+
}
|
211
|
+
}
|
212
|
+
listen(target, eventName, callback) {
|
213
|
+
if (eventName.charAt(0) == ANIMATION_PREFIX) {
|
214
|
+
const element = resolveElementFromTarget(target);
|
215
|
+
let name = eventName.substr(1);
|
216
|
+
let phase = '';
|
217
|
+
// @listener.phase is for trigger animation callbacks
|
218
|
+
// @@listener is for animation builder callbacks
|
219
|
+
if (name.charAt(0) != ANIMATION_PREFIX) {
|
220
|
+
[name, phase] = parseTriggerCallbackName(name);
|
221
|
+
}
|
222
|
+
return this.engine.listen(this.namespaceId, element, name, phase, event => {
|
223
|
+
const countId = event['_data'] || -1;
|
224
|
+
this.factory.scheduleListenerCallback(countId, callback, event);
|
225
|
+
});
|
226
|
+
}
|
227
|
+
return this.delegate.listen(target, eventName, callback);
|
228
|
+
}
|
229
|
+
}
|
230
|
+
function resolveElementFromTarget(target) {
|
231
|
+
switch (target) {
|
232
|
+
case 'body':
|
233
|
+
return document.body;
|
234
|
+
case 'document':
|
235
|
+
return document;
|
236
|
+
case 'window':
|
237
|
+
return window;
|
238
|
+
default:
|
239
|
+
return target;
|
240
|
+
}
|
241
|
+
}
|
242
|
+
function parseTriggerCallbackName(triggerName) {
|
243
|
+
const dotIndex = triggerName.indexOf('.');
|
244
|
+
const trigger = triggerName.substring(0, dotIndex);
|
245
|
+
const phase = triggerName.substr(dotIndex + 1);
|
246
|
+
return [trigger, phase];
|
247
|
+
}
|
248
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animation_renderer.js","sourceRoot":"","sources":["../../../../../../../packages/platform-browser/animations/src/animation_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 */\nimport {AnimationTriggerMetadata} from '@angular/animations';\nimport {ɵAnimationEngine as AnimationEngine} from '@angular/animations/browser';\nimport {Injectable, NgZone, Renderer2, RendererFactory2, RendererStyleFlags2, RendererType2} from '@angular/core';\n\nconst ANIMATION_PREFIX = '@';\nconst DISABLE_ANIMATIONS_FLAG = '@.disabled';\n\n// Define a recursive type to allow for nested arrays of `AnimationTriggerMetadata`. Note that an\n// interface declaration is used as TypeScript prior to 3.7 does not support recursive type\n// references, see https://github.com/microsoft/TypeScript/pull/33050 for details.\ntype NestedAnimationTriggerMetadata = AnimationTriggerMetadata|RecursiveAnimationTriggerMetadata;\ninterface RecursiveAnimationTriggerMetadata extends Array<NestedAnimationTriggerMetadata> {}\n\n@Injectable()\nexport class AnimationRendererFactory implements RendererFactory2 {\n  private _currentId: number = 0;\n  private _microtaskId: number = 1;\n  private _animationCallbacksBuffer: [(e: any) => any, any][] = [];\n  private _rendererCache = new Map<Renderer2, BaseAnimationRenderer>();\n  private _cdRecurDepth = 0;\n  private promise: Promise<any> = Promise.resolve(0);\n\n  constructor(\n      private delegate: RendererFactory2, private engine: AnimationEngine, private _zone: NgZone) {\n    engine.onRemovalComplete = (element: any, delegate: Renderer2) => {\n      // Note: if an component element has a leave animation, and the component\n      // a host leave animation, the view engine will call `removeChild` for the parent\n      // component renderer as well as for the child component renderer.\n      // Therefore, we need to check if we already removed the element.\n      if (delegate && delegate.parentNode(element)) {\n        delegate.removeChild(element.parentNode, element);\n      }\n    };\n  }\n\n  createRenderer(hostElement: any, type: RendererType2): Renderer2 {\n    const EMPTY_NAMESPACE_ID = '';\n\n    // cache the delegates to find out which cached delegate can\n    // be used by which cached renderer\n    const delegate = this.delegate.createRenderer(hostElement, type);\n    if (!hostElement || !type || !type.data || !type.data['animation']) {\n      let renderer: BaseAnimationRenderer|undefined = this._rendererCache.get(delegate);\n      if (!renderer) {\n        renderer = new BaseAnimationRenderer(EMPTY_NAMESPACE_ID, delegate, this.engine);\n        // only cache this result when the base renderer is used\n        this._rendererCache.set(delegate, renderer);\n      }\n      return renderer;\n    }\n\n    const componentId = type.id;\n    const namespaceId = type.id + '-' + this._currentId;\n    this._currentId++;\n\n    this.engine.register(namespaceId, hostElement);\n\n    const registerTrigger = (trigger: NestedAnimationTriggerMetadata) => {\n      if (Array.isArray(trigger)) {\n        trigger.forEach(registerTrigger);\n      } else {\n        this.engine.registerTrigger(componentId, namespaceId, hostElement, trigger.name, trigger);\n      }\n    };\n    const animationTriggers = type.data['animation'] as NestedAnimationTriggerMetadata[];\n    animationTriggers.forEach(registerTrigger);\n\n    return new AnimationRenderer(this, namespaceId, delegate, this.engine);\n  }\n\n  begin() {\n    this._cdRecurDepth++;\n    if (this.delegate.begin) {\n      this.delegate.begin();\n    }\n  }\n\n  private _scheduleCountTask() {\n    // always use promise to schedule microtask instead of use Zone\n    this.promise.then(() => {\n      this._microtaskId++;\n    });\n  }\n\n  /** @internal */\n  scheduleListenerCallback(count: number, fn: (e: any) => any, data: any) {\n    if (count >= 0 && count < this._microtaskId) {\n      this._zone.run(() => fn(data));\n      return;\n    }\n\n    if (this._animationCallbacksBuffer.length == 0) {\n      Promise.resolve(null).then(() => {\n        this._zone.run(() => {\n          this._animationCallbacksBuffer.forEach(tuple => {\n            const [fn, data] = tuple;\n            fn(data);\n          });\n          this._animationCallbacksBuffer = [];\n        });\n      });\n    }\n\n    this._animationCallbacksBuffer.push([fn, data]);\n  }\n\n  end() {\n    this._cdRecurDepth--;\n\n    // this is to prevent animations from running twice when an inner\n    // component does CD when a parent component instead has inserted it\n    if (this._cdRecurDepth == 0) {\n      this._zone.runOutsideAngular(() => {\n        this._scheduleCountTask();\n        this.engine.flush(this._microtaskId);\n      });\n    }\n    if (this.delegate.end) {\n      this.delegate.end();\n    }\n  }\n\n  whenRenderingDone(): Promise<any> {\n    return this.engine.whenRenderingDone();\n  }\n}\n\nexport class BaseAnimationRenderer implements Renderer2 {\n  constructor(\n      protected namespaceId: string, public delegate: Renderer2, public engine: AnimationEngine) {\n    this.destroyNode = this.delegate.destroyNode ? (n) => delegate.destroyNode!(n) : null;\n  }\n\n  get data() {\n    return this.delegate.data;\n  }\n\n  destroyNode: ((n: any) => void)|null;\n\n  destroy(): void {\n    this.engine.destroy(this.namespaceId, this.delegate);\n    this.delegate.destroy();\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, isHostElement);\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: AnimationRendererFactory, namespaceId: string, delegate: Renderer2,\n      engine: AnimationEngine) {\n    super(namespaceId, delegate, engine);\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.substr(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.substr(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.substr(dotIndex + 1);\n  return [trigger, phase];\n}\n"]}
|
File without changes
|