From 2265cb59384199868b5cfe5550be30382d5522ee Mon Sep 17 00:00:00 2001 From: crisbeto Date: Mon, 7 Oct 2019 22:53:02 +0200 Subject: [PATCH] refactor(core): remove deprecated Renderer (#33019) Removes the `Renderer` and related symbols which have been deprecated since version 4. BREAKING CHANGES: * `Renderer` has been removed. Use `Renderer2` instead. * `RenderComponentType` has been removed. Use `RendererType2` instead. * `RootRenderer` has been removed. Use `RendererFactory2` instead. PR Close #33019 --- aio/content/guide/deprecations.md | 8 +- integration/_payload-limits.json | 2 +- modules/benchmarks/src/tree/ng2_next/tree.ts | 3 +- packages/core/src/core_private_export.ts | 1 - packages/core/src/render.ts | 2 +- packages/core/src/render/api.ts | 106 ---------------- packages/core/src/view/provider.ts | 9 +- packages/core/src/view/refs.ts | 117 ------------------ .../change_detection_integration_spec.ts | 2 +- packages/core/test/view/provider_spec.ts | 13 +- packages/docs/web_workers/web_workers.md | 16 +-- .../src/compiler_reflector.ts | 3 +- .../src/web_workers/shared/serializer.ts | 24 +--- tools/public_api_guard/core/core.d.ts | 39 ------ 14 files changed, 20 insertions(+), 325 deletions(-) diff --git a/aio/content/guide/deprecations.md b/aio/content/guide/deprecations.md index 703aee99ce..d6d1432e4e 100644 --- a/aio/content/guide/deprecations.md +++ b/aio/content/guide/deprecations.md @@ -40,8 +40,6 @@ v8 - v11 | `@angular/core` | [`DefaultIterableDiffer`](#core) | v9 | | `@angular/core` | [`ReflectiveKey`](#core) | v9 | | `@angular/core` | [`RenderComponentType`](#core) | v9 | -| `@angular/core` | [`Renderer`](#core) | v9 | -| `@angular/core` | [`RootRenderer`](#core) | v9 | | `@angular/core` | [`ViewEncapsulation.Native`](#core) | v9 | | `@angular/forms` | [`ngForm` element selector](#ngform) | v9 | | `@angular/forms` | [`NgFormSelectorWarning`](#forms) | v9 | @@ -96,9 +94,6 @@ Tip: In the [API reference section](api) of this doc site, deprecated APIs are i | [`defineInjectable`](api/core/defineInjectable) | `ɵɵdefineInjectable` | v8 | Used only in generated code. No source code should depend on this API. | | [`ReflectiveInjector`](api/core/ReflectiveInjector) | [`Injector.create`](api/core/Injector#create) | v5 | See [`ReflectiveInjector`](#reflectiveinjector) | | [`ReflectiveKey`](api/core/ReflectiveKey) | none | v5 | none | -| [`RenderComponentType`](api/core/RenderComponentType) | [`RendererType2`](api/core/RendererType2) and [`Renderer2`](api/core/Renderer2) | v4 | none | -| [`Renderer`](api/core/Renderer) | [`Renderer2`](api/core/Renderer2) | v4 | none | -| [`RootRenderer`](api/core/RootRenderer) | [`RendererFactory2`](api/core/RendererFactory2) | v4 | none | | [`ViewEncapsulation.Native`](api/core/ViewEncapsulation#Native) | [`ViewEncapsulation.ShadowDom`](api/core/ViewEncapsulation#ShadowDom) | v6 | Use the native encapsulation mechanism of the renderer. See [view.ts](https://github.com/angular/angular/blob/3e992e18ebf51d6036818f26c3d77b52d3ec48eb/packages/core/src/metadata/view.ts#L32). | [`WtfScopeFn`](api/core/WtfScopeFn) | none | v8 | See [Web Tracing Framework](#wtf) | | [`wtfCreateScope`](api/core/wtfCreateScope) | none | v8 | See [Web Tracing Framework](#wtf) | @@ -410,6 +405,9 @@ The following APIs have been removed starting with version 8.0.0: | `@angular/core/testing` | [`TestBed.deprecatedOverrideProvider()`](https://v7.angular.io/api/core/testing/TestBed#deprecatedoverrideprovider) | [`TestBed.overrideProvider()`](api/core/testing/TestBed#overrideprovider) | none | | `@angular/core/testing` | [`TestBedStatic.deprecatedOverrideProvider()`](https://v7.angular.io/api/core/testing/TestBedStatic#deprecatedoverrideprovider) | [`TestBedStatic.overrideProvider()`](api/core/testing/TestBedStatic#overrideprovider) | none | | `@angular/service-worker` | `versionedFiles` | `files` | In the service worker configuration file `ngsw-config.json`, replace `versionedFiles` with `files`. See [Service Worker Configuration](guide/service-worker-config#assetgroups). | +| `@angular/core` | [`Renderer`](https://v8.angular.io/api/core/Renderer) | [`Renderer2`](https://angular.io/api/core/Renderer2) | [Migration guide.](guide/migration-renderer) +| `@angular/core` | [`RootRenderer`](https://v8.angular.io/api/core/RootRenderer) | [`RendererFactory2`](https://angular.io/api/core/RendererFactory2) | none +| `@angular/core` | [`RenderComponentType`](https://v8.angular.io/api/core/RenderComponentType) | [`RendererType2`](https://angular.io/api/core/RendererType2) | none diff --git a/integration/_payload-limits.json b/integration/_payload-limits.json index 9945a54f07..614fd48e36 100644 --- a/integration/_payload-limits.json +++ b/integration/_payload-limits.json @@ -3,7 +3,7 @@ "master": { "uncompressed": { "runtime": 1497, - "main": 157021, + "main": 154699, "polyfills": 45399 } } diff --git a/modules/benchmarks/src/tree/ng2_next/tree.ts b/modules/benchmarks/src/tree/ng2_next/tree.ts index 44eb24b87a..6ded8e33d6 100644 --- a/modules/benchmarks/src/tree/ng2_next/tree.ts +++ b/modules/benchmarks/src/tree/ng2_next/tree.ts @@ -7,7 +7,7 @@ */ import {NgIf} from '@angular/common'; -import {ComponentFactory, ComponentFactoryResolver, ComponentRef, ErrorHandler, Injector, NgModuleRef, RendererFactory2, RootRenderer, Sanitizer, TemplateRef, ViewContainerRef, ɵArgumentType as ArgumentType, ɵBindingFlags as BindingFlags, ɵNodeFlags as NodeFlags, ɵViewDefinition as ViewDefinition, ɵViewFlags as ViewFlags, ɵand as anchorDef, ɵccf as createComponentFactory, ɵdid as directiveDef, ɵeld as elementDef, ɵinitServicesIfNeeded as initServicesIfNeeded, ɵted as textDef, ɵvid as viewDef} from '@angular/core'; +import {ComponentFactory, ComponentFactoryResolver, ComponentRef, ErrorHandler, Injector, NgModuleRef, RendererFactory2, Sanitizer, TemplateRef, ViewContainerRef, ɵArgumentType as ArgumentType, ɵBindingFlags as BindingFlags, ɵNodeFlags as NodeFlags, ɵViewDefinition as ViewDefinition, ɵViewFlags as ViewFlags, ɵand as anchorDef, ɵccf as createComponentFactory, ɵdid as directiveDef, ɵeld as elementDef, ɵinitServicesIfNeeded as initServicesIfNeeded, ɵted as textDef, ɵvid as viewDef} from '@angular/core'; import {SafeStyle, ɵDomRendererFactory2 as DomRendererFactory2, ɵDomSanitizerImpl as DomSanitizerImpl} from '@angular/platform-browser'; import {TreeNode, emptyTree} from '../util'; @@ -107,7 +107,6 @@ export class AppModule implements Injector, NgModuleRef { return this.renderer2; case Sanitizer: return this.sanitizer; - case RootRenderer: case ErrorHandler: return null; case NgModuleRef: diff --git a/packages/core/src/core_private_export.ts b/packages/core/src/core_private_export.ts index 0498b825cc..07f37b8684 100644 --- a/packages/core/src/core_private_export.ts +++ b/packages/core/src/core_private_export.ts @@ -23,7 +23,6 @@ export {CodegenComponentFactoryResolver as ɵCodegenComponentFactoryResolver} fr export {clearResolutionOfComponentResourcesQueue as ɵclearResolutionOfComponentResourcesQueue, resolveComponentResources as ɵresolveComponentResources} from './metadata/resource_loading'; export {ReflectionCapabilities as ɵReflectionCapabilities} from './reflection/reflection_capabilities'; export {GetterFn as ɵGetterFn, MethodFn as ɵMethodFn, SetterFn as ɵSetterFn} from './reflection/types'; -export {DirectRenderer as ɵDirectRenderer, RenderDebugInfo as ɵRenderDebugInfo} from './render/api'; export {_sanitizeHtml as ɵ_sanitizeHtml} from './sanitization/html_sanitizer'; export {_sanitizeStyle as ɵ_sanitizeStyle} from './sanitization/style_sanitizer'; export {_sanitizeUrl as ɵ_sanitizeUrl} from './sanitization/url_sanitizer'; diff --git a/packages/core/src/render.ts b/packages/core/src/render.ts index 9db56a4848..3f9b74ccc6 100644 --- a/packages/core/src/render.ts +++ b/packages/core/src/render.ts @@ -7,4 +7,4 @@ */ // Public API for render -export {RenderComponentType, Renderer, Renderer2, RendererFactory2, RendererStyleFlags2, RendererType2, RootRenderer} from './render/api'; +export {Renderer2, RendererFactory2, RendererStyleFlags2, RendererType2} from './render/api'; diff --git a/packages/core/src/render/api.ts b/packages/core/src/render/api.ts index 0eb61f7d9b..cbd9343128 100644 --- a/packages/core/src/render/api.ts +++ b/packages/core/src/render/api.ts @@ -7,119 +7,13 @@ */ import {InjectionToken} from '../di/injection_token'; -import {Injector} from '../di/injector'; import {ViewEncapsulation} from '../metadata/view'; import {injectRenderer2 as render3InjectRenderer2} from '../render3/view_engine_compatibility'; import {noop} from '../util/noop'; - -/** - * @deprecated Use `RendererType2` (and `Renderer2`) instead. - * @publicApi - */ -export class RenderComponentType { - constructor( - public id: string, public templateUrl: string, public slotCount: number, - public encapsulation: ViewEncapsulation, public styles: Array, - public animations: any) {} -} - -/** - * @deprecated Debug info is handled internally in the view engine now. - */ -export abstract class RenderDebugInfo { - abstract get injector(): Injector; - abstract get component(): any; - abstract get providerTokens(): any[]; - abstract get references(): {[key: string]: any}; - abstract get context(): any; - abstract get source(): string; -} - -/** - * @deprecated Use the `Renderer2` instead. - */ -export interface DirectRenderer { - remove(node: any): void; - appendChild(node: any, parent: any): void; - insertBefore(node: any, refNode: any): void; - nextSibling(node: any): any; - parentElement(node: any): any; -} - -/** - * @deprecated Use the `Renderer2` instead. - * @publicApi - */ -export abstract class Renderer { - abstract selectRootElement(selectorOrNode: string|any, debugInfo?: RenderDebugInfo): any; - - abstract createElement(parentElement: any, name: string, debugInfo?: RenderDebugInfo): any; - - abstract createViewRoot(hostElement: any): any; - - abstract createTemplateAnchor(parentElement: any, debugInfo?: RenderDebugInfo): any; - - abstract createText(parentElement: any, value: string, debugInfo?: RenderDebugInfo): any; - - abstract projectNodes(parentElement: any, nodes: any[]): void; - - abstract attachViewAfter(node: any, viewRootNodes: any[]): void; - - abstract detachView(viewRootNodes: any[]): void; - - abstract destroyView(hostElement: any, viewAllNodes: any[]): void; - - abstract listen(renderElement: any, name: string, callback: Function): Function; - - abstract listenGlobal(target: string, name: string, callback: Function): Function; - - abstract setElementProperty(renderElement: any, propertyName: string, propertyValue: any): void; - - abstract setElementAttribute(renderElement: any, attributeName: string, attributeValue?: string): - void; - - /** - * Used only in debug mode to serialize property changes to dom nodes as attributes. - */ - abstract setBindingDebugInfo(renderElement: any, propertyName: string, propertyValue: string): - void; - - abstract setElementClass(renderElement: any, className: string, isAdd: boolean): void; - - abstract setElementStyle(renderElement: any, styleName: string, styleValue?: string): void; - - abstract invokeElementMethod(renderElement: any, methodName: string, args?: any[]): void; - - abstract setText(renderNode: any, text: string): void; - - abstract animate( - element: any, startingStyles: any, keyframes: any[], duration: number, delay: number, - easing: string, previousPlayers?: any[]): any; -} - export const Renderer2Interceptor = new InjectionToken('Renderer2Interceptor'); -/** - * Injectable service that provides a low-level interface for modifying the UI. - * - * Use this service to bypass Angular's templating and make custom UI changes that can't be - * expressed declaratively. For example if you need to set a property or an attribute whose name is - * not statically known, use {@link Renderer#setElementProperty setElementProperty} or - * {@link Renderer#setElementAttribute setElementAttribute} respectively. - * - * If you are implementing a custom renderer, you must implement this interface. - * - * The default Renderer implementation is `DomRenderer`. Also available is `WebWorkerRenderer`. - * - * @deprecated Use `RendererFactory2` instead. - * @publicApi - */ -export abstract class RootRenderer { - abstract renderComponent(componentType: RenderComponentType): Renderer; -} - /** * Used by `RendererFactory2` to associate custom rendering data and styles * with a rendering implementation. diff --git a/packages/core/src/view/provider.ts b/packages/core/src/view/provider.ts index 13cf82633c..f8421a03bc 100644 --- a/packages/core/src/view/provider.ts +++ b/packages/core/src/view/provider.ts @@ -11,15 +11,14 @@ import {INJECTOR, Injector, resolveForwardRef} from '../di'; import {ElementRef} from '../linker/element_ref'; import {TemplateRef} from '../linker/template_ref'; import {ViewContainerRef} from '../linker/view_container_ref'; -import {Renderer as RendererV1, Renderer2} from '../render/api'; +import {Renderer2} from '../render/api'; import {isObservable} from '../util/lang'; import {stringify} from '../util/stringify'; -import {createChangeDetectorRef, createInjector, createRendererV1} from './refs'; +import {createChangeDetectorRef, createInjector} from './refs'; import {BindingDef, BindingFlags, DepDef, DepFlags, NodeDef, NodeFlags, OutputDef, OutputType, ProviderData, QueryValueType, Services, ViewData, ViewFlags, ViewState, asElementData, asProviderData, shouldCallLifecycleInitHook} from './types'; import {calcBindingFlags, checkBinding, dispatchEvent, isComponentView, splitDepsDsl, splitMatchedQueriesDsl, tokenKey, viewParentEl} from './util'; -const RendererV1TokenKey = tokenKey(RendererV1); const Renderer2TokenKey = tokenKey(Renderer2); const ElementRefTokenKey = tokenKey(ElementRef); const ViewContainerRefTokenKey = tokenKey(ViewContainerRef); @@ -359,10 +358,6 @@ export function resolveDep( while (searchView) { if (elDef) { switch (tokenKey) { - case RendererV1TokenKey: { - const compView = findCompView(searchView, elDef, allowPrivateServices); - return createRendererV1(compView); - } case Renderer2TokenKey: { const compView = findCompView(searchView, elDef, allowPrivateServices); return compView.renderer; diff --git a/packages/core/src/view/refs.ts b/packages/core/src/view/refs.ts index 6253f93f52..198f56df50 100644 --- a/packages/core/src/view/refs.ts +++ b/packages/core/src/view/refs.ts @@ -18,7 +18,6 @@ import {InternalNgModuleRef, NgModuleRef} from '../linker/ng_module_factory'; import {TemplateRef} from '../linker/template_ref'; import {ViewContainerRef} from '../linker/view_container_ref'; import {EmbeddedViewRef, InternalViewRef, ViewRef} from '../linker/view_ref'; -import {Renderer as RendererV1, Renderer2} from '../render/api'; import {stringify} from '../util/stringify'; import {VERSION} from '../version'; @@ -356,122 +355,6 @@ export function nodeValue(view: ViewData, index: number): any { throw new Error(`Illegal state: read nodeValue for node index ${index}`); } -export function createRendererV1(view: ViewData): RendererV1 { - return new RendererAdapter(view.renderer); -} - -class RendererAdapter implements RendererV1 { - constructor(private delegate: Renderer2) {} - selectRootElement(selectorOrNode: string|Element): Element { - return this.delegate.selectRootElement(selectorOrNode); - } - - createElement(parent: Element|DocumentFragment, namespaceAndName: string): Element { - const [ns, name] = splitNamespace(namespaceAndName); - const el = this.delegate.createElement(name, ns); - if (parent) { - this.delegate.appendChild(parent, el); - } - return el; - } - - createViewRoot(hostElement: Element): Element|DocumentFragment { return hostElement; } - - createTemplateAnchor(parentElement: Element|DocumentFragment): Comment { - const comment = this.delegate.createComment(''); - if (parentElement) { - this.delegate.appendChild(parentElement, comment); - } - return comment; - } - - createText(parentElement: Element|DocumentFragment, value: string): any { - const node = this.delegate.createText(value); - if (parentElement) { - this.delegate.appendChild(parentElement, node); - } - return node; - } - - projectNodes(parentElement: Element|DocumentFragment, nodes: Node[]) { - for (let i = 0; i < nodes.length; i++) { - this.delegate.appendChild(parentElement, nodes[i]); - } - } - - attachViewAfter(node: Node, viewRootNodes: Node[]) { - const parentElement = this.delegate.parentNode(node); - const nextSibling = this.delegate.nextSibling(node); - for (let i = 0; i < viewRootNodes.length; i++) { - this.delegate.insertBefore(parentElement, viewRootNodes[i], nextSibling); - } - } - - detachView(viewRootNodes: (Element|Text|Comment)[]) { - for (let i = 0; i < viewRootNodes.length; i++) { - const node = viewRootNodes[i]; - const parentElement = this.delegate.parentNode(node); - this.delegate.removeChild(parentElement, node); - } - } - - destroyView(hostElement: Element|DocumentFragment, viewAllNodes: Node[]) { - for (let i = 0; i < viewAllNodes.length; i++) { - this.delegate.destroyNode !(viewAllNodes[i]); - } - } - - listen(renderElement: any, name: string, callback: Function): Function { - return this.delegate.listen(renderElement, name, callback); - } - - listenGlobal(target: string, name: string, callback: Function): Function { - return this.delegate.listen(target, name, callback); - } - - setElementProperty( - renderElement: Element|DocumentFragment, propertyName: string, propertyValue: any): void { - this.delegate.setProperty(renderElement, propertyName, propertyValue); - } - - setElementAttribute(renderElement: Element, namespaceAndName: string, attributeValue?: string): - void { - const [ns, name] = splitNamespace(namespaceAndName); - if (attributeValue != null) { - this.delegate.setAttribute(renderElement, name, attributeValue, ns); - } else { - this.delegate.removeAttribute(renderElement, name, ns); - } - } - - setBindingDebugInfo(renderElement: Element, propertyName: string, propertyValue: string): void {} - - setElementClass(renderElement: Element, className: string, isAdd: boolean): void { - if (isAdd) { - this.delegate.addClass(renderElement, className); - } else { - this.delegate.removeClass(renderElement, className); - } - } - - setElementStyle(renderElement: HTMLElement, styleName: string, styleValue?: string): void { - if (styleValue != null) { - this.delegate.setStyle(renderElement, styleName, styleValue); - } else { - this.delegate.removeStyle(renderElement, styleName); - } - } - - invokeElementMethod(renderElement: Element, methodName: string, args: any[]): void { - (renderElement as any)[methodName].apply(renderElement, args); - } - - setText(renderNode: Text, text: string): void { this.delegate.setValue(renderNode, text); } - - animate(): any { throw new Error('Renderer.animate is no longer supported!'); } -} - - export function createNgModuleRef( moduleType: Type, parent: Injector, bootstrapComponents: Type[], def: NgModuleDefinition): NgModuleRef { diff --git a/packages/core/test/linker/change_detection_integration_spec.ts b/packages/core/test/linker/change_detection_integration_spec.ts index 1ba892ef82..a0af686da2 100644 --- a/packages/core/test/linker/change_detection_integration_spec.ts +++ b/packages/core/test/linker/change_detection_integration_spec.ts @@ -8,7 +8,7 @@ import {ResourceLoader, UrlResolver} from '@angular/compiler'; import {MockResourceLoader} from '@angular/compiler/testing'; -import {AfterContentChecked, AfterContentInit, AfterViewChecked, AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, DebugElement, Directive, DoCheck, EventEmitter, HostBinding, Inject, Injectable, Input, OnChanges, OnDestroy, OnInit, Output, Pipe, PipeTransform, Provider, RenderComponentType, Renderer, RendererFactory2, RendererType2, RootRenderer, SimpleChange, SimpleChanges, TemplateRef, Type, ViewChild, ViewContainerRef, WrappedValue} from '@angular/core'; +import {AfterContentChecked, AfterContentInit, AfterViewChecked, AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, DebugElement, Directive, DoCheck, EventEmitter, HostBinding, Inject, Injectable, Input, OnChanges, OnDestroy, OnInit, Output, Pipe, PipeTransform, Provider, RendererFactory2, RendererType2, SimpleChange, SimpleChanges, TemplateRef, Type, ViewChild, ViewContainerRef, WrappedValue} from '@angular/core'; import {ComponentFixture, TestBed, fakeAsync} from '@angular/core/testing'; import {By} from '@angular/platform-browser/src/dom/debug/by'; import {isTextNode} from '@angular/platform-browser/testing/src/browser_util'; diff --git a/packages/core/test/view/provider_spec.ts b/packages/core/test/view/provider_spec.ts index 54a290cac3..cab5b26bc8 100644 --- a/packages/core/test/view/provider_spec.ts +++ b/packages/core/test/view/provider_spec.ts @@ -6,7 +6,7 @@ * found in the LICENSE file at https://angular.io/license */ -import {AfterContentChecked, AfterContentInit, AfterViewChecked, AfterViewInit, ChangeDetectorRef, DoCheck, ElementRef, ErrorHandler, EventEmitter, Injector, OnChanges, OnDestroy, OnInit, Renderer, Renderer2, SimpleChange, TemplateRef, ViewContainerRef,} from '@angular/core'; +import {AfterContentChecked, AfterContentInit, AfterViewChecked, AfterViewInit, ChangeDetectorRef, DoCheck, ElementRef, ErrorHandler, EventEmitter, Injector, OnChanges, OnDestroy, OnInit, Renderer2, SimpleChange, TemplateRef, ViewContainerRef,} from '@angular/core'; import {getDebugContext} from '@angular/core/src/errors'; import {ArgumentType, DepFlags, NodeFlags, Services, anchorDef, asElementData, directiveDef, elementDef, providerDef, textDef} from '@angular/core/src/view/index'; import {TestBed, withModule} from '@angular/core/testing'; @@ -285,17 +285,6 @@ import {ARG_TYPE_VALUES, checkNodeInlineOrDynamic, createRootView, createAndGetR expect(instance.dep._view).toBe(compView); }); - it('should inject RendererV1', () => { - createAndGetRootNodes(compViewDef([ - elementDef( - 0, NodeFlags.None, null, null, 1, 'span', null, null, null, null, - () => compViewDef([anchorDef(NodeFlags.None, null, null, 0)])), - directiveDef(1, NodeFlags.Component, null, 0, SomeService, [Renderer]) - ])); - - expect(instance.dep.createElement).toBeTruthy(); - }); - it('should inject Renderer2', () => { createAndGetRootNodes(compViewDef([ elementDef( diff --git a/packages/docs/web_workers/web_workers.md b/packages/docs/web_workers/web_workers.md index e4f7c26bd5..086dee9de9 100644 --- a/packages/docs/web_workers/web_workers.md +++ b/packages/docs/web_workers/web_workers.md @@ -136,7 +136,7 @@ This code is nearly the same as the TypeScript version with just a couple key di * We provide a `SendPort` through DI using the token `RENDER_SEND_PORT`. Dart applications use the Isolate API, which communicates via Dart's Port abstraction. When you call `setupIsolate` from the UI thread, angular starts a new Isolate to run your application logic. When Dart starts a new Isolate it passes a `SendPort` to that Isolate so that it -can communicate with the Isolate that spawned it. You need to provide this `SendPort` through DI +can communicate with the Isolate that spawned it. You need to provide this `SendPort` through DI so that Angular can communicate with the UI. * You need to set up `ReflectionCapabilities` on both the UI and Worker. Just like writing non-concurrent Angular2 Dart applications you need to set up the reflector. You should not use Reflection in production, @@ -149,15 +149,15 @@ to the transformer until that bug is fixed. You can do almost everything in a WebWorker component that you can do in a typical Angular Component. The main exception is that there is **no** DOM access from a WebWorker component. In Dart this means you can't import anything from `dart:html` and in JavaScript it means you can't use `document` or `window`. Instead you -should use data bindings and if needed you can inject the `Renderer` along with your component's `ElementRef` -directly into your component and use methods such as `setElementProperty`, `setElementAttribute`, -`setElementClass`, `setElementStyle`, `invokeElementMethod`, and `setText`. Note that you **cannot** call +should use data bindings and if needed you can inject `Renderer2` along with your component's `ElementRef` +directly into your component and use methods such as `setProperty`, `setAttribute`, +`addClass`, `setStyle`, and `setValue`. Note that you **cannot** call `getNativeElementSync`. Doing so will always return `null` when running in a WebWorker. If you need DOM access see [Running Code on the UI](#running-code-on-the-ui). ## WebWorker Design Overview When running your application in a WebWorker, the majority of the angular core along with your application logic -runs on the worker. The two main components that run on the UI are the `Renderer` and the `RenderCompiler`. When +runs on the worker. The two main components that run on the UI are the `Renderer2` and the `RenderCompiler`. When running angular in a WebWorker the bindings for these two components are replaced by the `WebWorkerRenderer` and the `WebWorkerRenderCompiler`. When these components are used at runtime, they pass messages through the [MessageBroker](#messagebroker) instructing the UI to run the actual method and return the result. The @@ -329,7 +329,7 @@ if you do this, you don't need to implement zone or channel support yourself. Yo `GenericMessageBusSource`. The `MessageBusSink` must override the `sendMessages` method. This method is given a list of serialized messages that it is required to send through the sink. -Once you've implemented your custom MessageBus in either TypeScript, you must provide it through DI +Once you've implemented your custom MessageBus in either TypeScript, you must provide it through DI during bootstrap like so: In TypeScript: @@ -346,7 +346,7 @@ import { var bus = new MyAwesomeMessageBus(); platform([WORKER_RENDER_PLATFORM]) .application([WORKER_RENDER_APPLICATION_COMMON, {provide: MessageBus, useValue: bus}, - { provide: APP_INITIALIZER, + { provide: APP_INITIALIZER, useFactory: (injector) => () => initializeGenericWorkerRenderer(injector), deps: [Injector], multi: true @@ -473,7 +473,7 @@ The service then calls `registerMethod` to register the method that it wants to four arguments. The first is the name of the method, the second is the Types of that method's parameters, the third is the method itself, and the fourth (which is optional) is the return Type of that method. The MessageBroker handles serializing / deserializing your parameters and return types using angular's serializer. -However, at the moment the serializer only knows how to serialize angular classes like those used by the Renderer. +However, at the moment the serializer only knows how to serialize angular classes like those used by `Renderer2`. If you're passing anything other than those types around in your application you can handle serialization yourself and then use the `PRIMITIVE` type to tell the MessageBroker to avoid serializing your data. diff --git a/packages/platform-browser-dynamic/src/compiler_reflector.ts b/packages/platform-browser-dynamic/src/compiler_reflector.ts index da2ec859d2..25904ae730 100644 --- a/packages/platform-browser-dynamic/src/compiler_reflector.ts +++ b/packages/platform-browser-dynamic/src/compiler_reflector.ts @@ -7,7 +7,7 @@ */ import {CompileReflector, ExternalReference, Identifiers, getUrlScheme, syntaxError} from '@angular/compiler'; -import {ANALYZE_FOR_ENTRY_COMPONENTS, ChangeDetectionStrategy, ChangeDetectorRef, Component, ComponentFactory, ComponentFactoryResolver, ComponentRef, ElementRef, Injector, LOCALE_ID, NgModuleFactory, NgModuleRef, QueryList, Renderer, Renderer2, SecurityContext, TRANSLATIONS_FORMAT, TemplateRef, ViewContainerRef, ViewEncapsulation, ɵCodegenComponentFactoryResolver, ɵEMPTY_ARRAY, ɵEMPTY_MAP, ɵReflectionCapabilities as ReflectionCapabilities, ɵand, ɵccf, ɵcmf, ɵcrt, ɵdid, ɵeld, ɵinlineInterpolate, ɵinterpolate, ɵmod, ɵmpd, ɵncd, ɵnov, ɵpad, ɵpid, ɵpod, ɵppd, ɵprd, ɵqud, ɵregisterModuleFactory, ɵstringify as stringify, ɵted, ɵunv, ɵvid} from '@angular/core'; +import {ANALYZE_FOR_ENTRY_COMPONENTS, ChangeDetectionStrategy, ChangeDetectorRef, Component, ComponentFactory, ComponentFactoryResolver, ComponentRef, ElementRef, Injector, LOCALE_ID, NgModuleFactory, NgModuleRef, QueryList, Renderer2, SecurityContext, TRANSLATIONS_FORMAT, TemplateRef, ViewContainerRef, ViewEncapsulation, ɵCodegenComponentFactoryResolver, ɵEMPTY_ARRAY, ɵEMPTY_MAP, ɵReflectionCapabilities as ReflectionCapabilities, ɵand, ɵccf, ɵcmf, ɵcrt, ɵdid, ɵeld, ɵinlineInterpolate, ɵinterpolate, ɵmod, ɵmpd, ɵncd, ɵnov, ɵpad, ɵpid, ɵpod, ɵppd, ɵprd, ɵqud, ɵregisterModuleFactory, ɵstringify as stringify, ɵted, ɵunv, ɵvid} from '@angular/core'; export const MODULE_SUFFIX = ''; const builtinExternalReferences = createBuiltinExternalReferencesMap(); @@ -81,7 +81,6 @@ function createBuiltinExternalReferencesMap() { map.set(Identifiers.interpolate, ɵinterpolate); map.set(Identifiers.EMPTY_ARRAY, ɵEMPTY_ARRAY); map.set(Identifiers.EMPTY_MAP, ɵEMPTY_MAP); - map.set(Identifiers.Renderer, Renderer); map.set(Identifiers.viewDef, ɵvid); map.set(Identifiers.elementDef, ɵeld); map.set(Identifiers.anchorDef, ɵand); diff --git a/packages/platform-webworker/src/web_workers/shared/serializer.ts b/packages/platform-webworker/src/web_workers/shared/serializer.ts index 7b2d16631f..dfb1c1c6e2 100644 --- a/packages/platform-webworker/src/web_workers/shared/serializer.ts +++ b/packages/platform-webworker/src/web_workers/shared/serializer.ts @@ -6,7 +6,7 @@ * found in the LICENSE file at https://angular.io/license */ -import {Injectable, RenderComponentType, RendererType2, Type, ɵstringify as stringify} from '@angular/core'; +import {Injectable, RendererType2, Type, ɵstringify as stringify} from '@angular/core'; import {RenderStore} from './render_store'; @@ -44,9 +44,6 @@ export class Serializer { if (type === SerializerTypes.RENDER_STORE_OBJECT) { return this._renderStore.serialize(obj) !; } - if (type === RenderComponentType) { - return this._serializeRenderComponentType(obj); - } if (type === SerializerTypes.RENDERER_TYPE_2) { return this._serializeRendererType2(obj); } @@ -67,9 +64,6 @@ export class Serializer { if (type === SerializerTypes.RENDER_STORE_OBJECT) { return this._renderStore.deserialize(map); } - if (type === RenderComponentType) { - return this._deserializeRenderComponentType(map); - } if (type === SerializerTypes.RENDERER_TYPE_2) { return this._deserializeRendererType2(map); } @@ -99,22 +93,6 @@ export class Serializer { loc['search'], loc['hash'], loc['origin']); } - private _serializeRenderComponentType(type: RenderComponentType): Object { - return { - 'id': type.id, - 'templateUrl': type.templateUrl, - 'slotCount': type.slotCount, - 'encapsulation': this.serialize(type.encapsulation), - 'styles': this.serialize(type.styles), - }; - } - - private _deserializeRenderComponentType(props: {[key: string]: any}): RenderComponentType { - return new RenderComponentType( - props['id'], props['templateUrl'], props['slotCount'], - this.deserialize(props['encapsulation']), this.deserialize(props['styles']), {}); - } - private _serializeRendererType2(type: RendererType2): {[key: string]: any} { return { 'id': type.id, diff --git a/tools/public_api_guard/core/core.d.ts b/tools/public_api_guard/core/core.d.ts index bf81f43698..fb2064600b 100644 --- a/tools/public_api_guard/core/core.d.ts +++ b/tools/public_api_guard/core/core.d.ts @@ -1200,40 +1200,6 @@ export declare class ReflectiveKey { static get(token: Object): ReflectiveKey; } -/** @deprecated */ -export declare class RenderComponentType { - animations: any; - encapsulation: ViewEncapsulation; - id: string; - slotCount: number; - styles: Array; - templateUrl: string; - constructor(id: string, templateUrl: string, slotCount: number, encapsulation: ViewEncapsulation, styles: Array, animations: any); -} - -/** @deprecated */ -export declare abstract class Renderer { - abstract animate(element: any, startingStyles: any, keyframes: any[], duration: number, delay: number, easing: string, previousPlayers?: any[]): any; - abstract attachViewAfter(node: any, viewRootNodes: any[]): void; - abstract createElement(parentElement: any, name: string, debugInfo?: RenderDebugInfo): any; - abstract createTemplateAnchor(parentElement: any, debugInfo?: RenderDebugInfo): any; - abstract createText(parentElement: any, value: string, debugInfo?: RenderDebugInfo): any; - abstract createViewRoot(hostElement: any): any; - abstract destroyView(hostElement: any, viewAllNodes: any[]): void; - abstract detachView(viewRootNodes: any[]): void; - abstract invokeElementMethod(renderElement: any, methodName: string, args?: any[]): void; - abstract listen(renderElement: any, name: string, callback: Function): Function; - abstract listenGlobal(target: string, name: string, callback: Function): Function; - abstract projectNodes(parentElement: any, nodes: any[]): void; - abstract selectRootElement(selectorOrNode: string | any, debugInfo?: RenderDebugInfo): any; - abstract setBindingDebugInfo(renderElement: any, propertyName: string, propertyValue: string): void; - abstract setElementAttribute(renderElement: any, attributeName: string, attributeValue?: string): void; - abstract setElementClass(renderElement: any, className: string, isAdd: boolean): void; - abstract setElementProperty(renderElement: any, propertyName: string, propertyValue: any): void; - abstract setElementStyle(renderElement: any, styleName: string, styleValue?: string): void; - abstract setText(renderNode: any, text: string): void; -} - export declare abstract class Renderer2 { abstract readonly data: { [key: string]: any; @@ -1297,11 +1263,6 @@ export interface ResolvedReflectiveProvider { export declare function resolveForwardRef(type: T): T; -/** @deprecated */ -export declare abstract class RootRenderer { - abstract renderComponent(componentType: RenderComponentType): Renderer; -} - export declare abstract class Sanitizer { abstract sanitize(context: SecurityContext, value: {} | string | null): string | null; static ngInjectableDef: never;