@angular/core 6.0.3 → 6.0.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/bundles/core-testing.umd.js +61 -237
- package/bundles/core-testing.umd.js.map +1 -1
- package/bundles/core-testing.umd.min.js +11 -4
- package/bundles/core-testing.umd.min.js.map +1 -1
- package/bundles/core.umd.js +591 -2007
- package/bundles/core.umd.js.map +1 -1
- package/bundles/core.umd.min.js +4 -32
- package/bundles/core.umd.min.js.map +1 -1
- package/core.metadata.json +1 -1
- package/esm2015/core.externs.js +3 -3
- package/esm2015/src/application_init.js +2 -9
- package/esm2015/src/application_module.js +1 -10
- package/esm2015/src/application_ref.js +15 -30
- package/esm2015/src/change_detection/change_detector_ref.js +7 -5
- package/esm2015/src/change_detection/differs/iterable_differs.js +4 -3
- package/esm2015/src/change_detection/differs/keyvalue_differs.js +4 -3
- package/esm2015/src/change_detection/pipe_transform.js +3 -6
- package/esm2015/src/console.js +0 -11
- package/esm2015/src/di/forward_ref.js +8 -6
- package/esm2015/src/di/injectable.js +1 -4
- package/esm2015/src/di/injection_token.js +6 -8
- package/esm2015/src/di/injector.js +5 -10
- package/esm2015/src/di/metadata.js +1 -16
- package/esm2015/src/di/provider.js +47 -138
- package/esm2015/src/di/reflective_errors.js +14 -7
- package/esm2015/src/di/reflective_injector.js +22 -24
- package/esm2015/src/di/reflective_provider.js +11 -12
- package/esm2015/src/error_handler.js +2 -5
- package/esm2015/src/event_emitter.js +6 -3
- package/esm2015/src/i18n/tokens.js +7 -4
- package/esm2015/src/linker/compiler.js +1 -12
- package/esm2015/src/linker/query_list.js +4 -4
- package/esm2015/src/linker/system_js_ng_module_factory_loader.js +3 -10
- package/esm2015/src/linker/view_ref.js +10 -7
- package/esm2015/src/metadata/di.js +10 -16
- package/esm2015/src/metadata/directives.js +111 -33
- package/esm2015/src/metadata/lifecycle_hooks.js +9 -9
- package/esm2015/src/metadata/ng_module.js +19 -11
- package/esm2015/src/render3/node_manipulation.js +2 -3
- package/esm2015/src/render3/view_ref.js +7 -3
- package/esm2015/src/testability/testability.js +2 -16
- package/esm2015/src/version.js +1 -1
- package/esm2015/src/view/ng_module.js +4 -1
- package/esm2015/src/zone/ng_zone.js +2 -1
- package/esm2015/testing/src/fake_async.js +5 -3
- package/esm2015/testing/src/fake_async_fallback.js +5 -3
- package/esm2015/testing/src/logger.js +0 -7
- package/esm2015/testing/src/metadata_override.js +1 -1
- package/esm2015/testing/src/ng_zone_mock.js +0 -7
- package/esm2015/testing/src/test_bed.js +1 -34
- package/esm2015/testing/src/test_compiler.js +1 -12
- package/esm5/index.js +5 -1
- package/esm5/public_api.js +6 -1
- package/esm5/src/application_init.js +3 -5
- package/esm5/src/application_module.js +2 -2
- package/esm5/src/application_ref.js +35 -211
- package/esm5/src/application_tokens.js +1 -1
- package/esm5/src/change_detection/change_detection.js +1 -1
- package/esm5/src/change_detection/change_detection_util.js +7 -72
- package/esm5/src/change_detection/change_detector_ref.js +1 -1
- package/esm5/src/change_detection/constants.js +1 -24
- package/esm5/src/change_detection/differs/default_iterable_differ.js +26 -209
- package/esm5/src/change_detection/differs/default_keyvalue_differ.js +7 -38
- package/esm5/src/change_detection/differs/iterable_differs.js +5 -42
- package/esm5/src/change_detection/differs/keyvalue_differs.js +6 -51
- package/esm5/src/change_detection/pipe_transform.js +1 -1
- package/esm5/src/change_detection.js +6 -1
- package/esm5/src/codegen_private_exports.js +1 -1
- package/esm5/src/console.js +2 -7
- package/esm5/src/core.js +6 -1
- package/esm5/src/core_private_export.js +1 -1
- package/esm5/src/core_render3_private_export.js +2 -1
- package/esm5/src/debug/debug_node.js +3 -15
- package/esm5/src/di/defs.js +1 -1
- package/esm5/src/di/forward_ref.js +7 -6
- package/esm5/src/di/injectable.js +2 -3
- package/esm5/src/di/injection_token.js +5 -83
- package/esm5/src/di/injector.js +13 -27
- package/esm5/src/di/metadata.js +1 -6
- package/esm5/src/di/provider.js +1 -1
- package/esm5/src/di/r3_injector.js +13 -39
- package/esm5/src/di/reflective_errors.js +14 -7
- package/esm5/src/di/reflective_injector.js +19 -265
- package/esm5/src/di/reflective_key.js +4 -45
- package/esm5/src/di/reflective_provider.js +17 -35
- package/esm5/src/di/scope.js +1 -1
- package/esm5/src/di.js +6 -1
- package/esm5/src/error_handler.js +7 -66
- package/esm5/src/errors.js +1 -1
- package/esm5/src/event_emitter.js +4 -95
- package/esm5/src/i18n/tokens.js +9 -49
- package/esm5/src/linker/compiler.js +9 -69
- package/esm5/src/linker/component_factory.js +2 -18
- package/esm5/src/linker/component_factory_resolver.js +1 -1
- package/esm5/src/linker/element_ref.js +2 -32
- package/esm5/src/linker/ng_module_factory.js +3 -25
- package/esm5/src/linker/ng_module_factory_loader.js +2 -10
- package/esm5/src/linker/query_list.js +12 -112
- package/esm5/src/linker/system_js_ng_module_factory_loader.js +4 -16
- package/esm5/src/linker/template_ref.js +2 -26
- package/esm5/src/linker/view_container_ref.js +2 -38
- package/esm5/src/linker/view_ref.js +10 -115
- package/esm5/src/linker.js +2 -1
- package/esm5/src/metadata/di.js +7 -25
- package/esm5/src/metadata/directives.js +111 -20
- package/esm5/src/metadata/lifecycle_hooks.js +1 -1
- package/esm5/src/metadata/ng_module.js +14 -9
- package/esm5/src/metadata/view.js +1 -20
- package/esm5/src/metadata.js +1 -1
- package/esm5/src/platform_core_providers.js +1 -1
- package/esm5/src/profile/profile.js +1 -1
- package/esm5/src/profile/wtf_impl.js +1 -1
- package/esm5/src/reflection/platform_reflection_capabilities.js +1 -1
- package/esm5/src/reflection/reflection.js +1 -1
- package/esm5/src/reflection/reflection_capabilities.js +3 -8
- package/esm5/src/reflection/reflector.js +2 -10
- package/esm5/src/reflection/types.js +1 -1
- package/esm5/src/render/api.js +7 -71
- package/esm5/src/render.js +2 -1
- package/esm5/src/render3/assert.js +1 -1
- package/esm5/src/render3/component.js +6 -5
- package/esm5/src/render3/definition.js +6 -8
- package/esm5/src/render3/di.js +9 -14
- package/esm5/src/render3/errors.js +1 -1
- package/esm5/src/render3/hooks.js +2 -2
- package/esm5/src/render3/index.js +11 -1
- package/esm5/src/render3/instructions.js +52 -38
- package/esm5/src/render3/interfaces/container.js +1 -1
- package/esm5/src/render3/interfaces/definition.js +1 -1
- package/esm5/src/render3/interfaces/injector.js +1 -1
- package/esm5/src/render3/interfaces/node.js +1 -1
- package/esm5/src/render3/interfaces/projection.js +1 -1
- package/esm5/src/render3/interfaces/query.js +1 -1
- package/esm5/src/render3/interfaces/renderer.js +1 -3
- package/esm5/src/render3/interfaces/view.js +1 -1
- package/esm5/src/render3/ng_dev_mode.js +1 -1
- package/esm5/src/render3/node_assert.js +1 -1
- package/esm5/src/render3/node_manipulation.js +12 -15
- package/esm5/src/render3/node_selector_matcher.js +2 -2
- package/esm5/src/render3/pipe.js +1 -1
- package/esm5/src/render3/pure_function.js +1 -1
- package/esm5/src/render3/query.js +11 -59
- package/esm5/src/render3/util.js +1 -1
- package/esm5/src/render3/view_ref.js +15 -345
- package/esm5/src/sanitization/html_sanitizer.js +8 -12
- package/esm5/src/sanitization/inert_body.js +8 -72
- package/esm5/src/sanitization/sanitization.js +1 -1
- package/esm5/src/sanitization/security.js +2 -37
- package/esm5/src/sanitization/style_sanitizer.js +1 -1
- package/esm5/src/sanitization/url_sanitizer.js +1 -1
- package/esm5/src/testability/testability.js +21 -143
- package/esm5/src/type.js +1 -1
- package/esm5/src/util/decorators.js +1 -1
- package/esm5/src/util/lang.js +1 -1
- package/esm5/src/util/property.js +1 -1
- package/esm5/src/util.js +6 -1
- package/esm5/src/version.js +3 -13
- package/esm5/src/view/element.js +7 -7
- package/esm5/src/view/entrypoint.js +1 -1
- package/esm5/src/view/errors.js +1 -1
- package/esm5/src/view/index.js +1 -1
- package/esm5/src/view/ng_content.js +1 -1
- package/esm5/src/view/ng_module.js +4 -1
- package/esm5/src/view/provider.js +12 -12
- package/esm5/src/view/pure_expression.js +1 -1
- package/esm5/src/view/query.js +6 -6
- package/esm5/src/view/refs.js +8 -14
- package/esm5/src/view/services.js +16 -20
- package/esm5/src/view/text.js +1 -1
- package/esm5/src/view/types.js +19 -41
- package/esm5/src/view/util.js +5 -5
- package/esm5/src/view/view.js +4 -6
- package/esm5/src/view/view_attach.js +5 -5
- package/esm5/src/zone/ng_zone.js +22 -257
- package/esm5/src/zone.js +2 -1
- package/esm5/testing/index.js +5 -1
- package/esm5/testing/public_api.js +6 -1
- package/esm5/testing/src/async.js +1 -1
- package/esm5/testing/src/async_fallback.js +1 -1
- package/esm5/testing/src/async_test_completer.js +2 -8
- package/esm5/testing/src/before_each.js +6 -1
- package/esm5/testing/src/component_fixture.js +9 -75
- package/esm5/testing/src/fake_async.js +12 -3
- package/esm5/testing/src/fake_async_fallback.js +5 -3
- package/esm5/testing/src/lang_utils.js +1 -1
- package/esm5/testing/src/logger.js +1 -1
- package/esm5/testing/src/metadata_override.js +1 -1
- package/esm5/testing/src/ng_zone_mock.js +1 -1
- package/esm5/testing/src/private_export_testing.js +1 -1
- package/esm5/testing/src/render3.js +1 -5
- package/esm5/testing/src/test_bed.js +20 -172
- package/esm5/testing/src/test_compiler.js +5 -43
- package/esm5/testing/src/testing.js +6 -1
- package/esm5/testing/src/testing_internal.js +3 -9
- package/fesm2015/core.js +248 -177
- package/fesm2015/core.js.map +1 -1
- package/fesm2015/testing.js +9 -13
- package/fesm2015/testing.js.map +1 -1
- package/fesm5/core.js +591 -2007
- package/fesm5/core.js.map +1 -1
- package/fesm5/testing.js +61 -237
- package/fesm5/testing.js.map +1 -1
- package/package.json +1 -1
- package/src/application_ref.d.ts +7 -8
- package/src/change_detection/change_detector_ref.d.ts +6 -4
- package/src/change_detection/differs/iterable_differs.d.ts +3 -2
- package/src/change_detection/differs/keyvalue_differs.d.ts +3 -2
- package/src/change_detection/pipe_transform.d.ts +2 -5
- package/src/di/forward_ref.d.ts +7 -5
- package/src/di/injectable.d.ts +4 -14
- package/src/di/injection_token.d.ts +5 -7
- package/src/di/injector.d.ts +7 -10
- package/src/di/metadata.d.ts +13 -86
- package/src/di/provider.d.ts +55 -150
- package/src/di/reflective_errors.d.ts +13 -6
- package/src/di/reflective_injector.d.ts +21 -23
- package/src/di/reflective_provider.d.ts +7 -8
- package/src/error_handler.d.ts +1 -4
- package/src/event_emitter.d.ts +3 -0
- package/src/i18n/tokens.d.ts +8 -4
- package/src/linker/query_list.d.ts +2 -2
- package/src/linker/view_ref.d.ts +9 -6
- package/src/metadata/di.d.ts +41 -59
- package/src/metadata/directives.d.ts +410 -460
- package/src/metadata/lifecycle_hooks.d.ts +8 -8
- package/src/metadata/ng_module.d.ts +49 -38
- package/src/render3/view_ref.d.ts +6 -2
- package/src/zone/ng_zone.d.ts +1 -0
- package/testing/src/fake_async.d.ts +4 -2
- package/testing/src/fake_async_fallback.d.ts +4 -2
- package/testing/src/metadata_override.d.ts +3 -3
- package/testing.d.ts +0 -5
- package/testing.metadata.json +1 -1
|
@@ -11,12 +11,10 @@ import { notImplemented } from './util';
|
|
|
11
11
|
var ViewRef = /** @class */ (function () {
|
|
12
12
|
function ViewRef(_view, context) {
|
|
13
13
|
this._view = _view;
|
|
14
|
-
this.context =
|
|
14
|
+
this.context = context;
|
|
15
15
|
}
|
|
16
16
|
/** @internal */
|
|
17
|
-
|
|
18
|
-
ViewRef.prototype._setComponentContext = /** @internal */
|
|
19
|
-
function (view, context) {
|
|
17
|
+
ViewRef.prototype._setComponentContext = function (view, context) {
|
|
20
18
|
this._view = view;
|
|
21
19
|
this.context = context;
|
|
22
20
|
};
|
|
@@ -34,7 +32,8 @@ var ViewRef = /** @class */ (function () {
|
|
|
34
32
|
*
|
|
35
33
|
* <!-- TODO: Add a link to a chapter on OnPush components -->
|
|
36
34
|
*
|
|
37
|
-
*
|
|
35
|
+
* @usageNotes
|
|
36
|
+
* ### Example
|
|
38
37
|
*
|
|
39
38
|
* ```typescript
|
|
40
39
|
* @Component({
|
|
@@ -55,73 +54,7 @@ var ViewRef = /** @class */ (function () {
|
|
|
55
54
|
* }
|
|
56
55
|
* ```
|
|
57
56
|
*/
|
|
58
|
-
|
|
59
|
-
* Marks a view and all of its ancestors dirty.
|
|
60
|
-
*
|
|
61
|
-
* It also triggers change detection by calling `scheduleTick` internally, which coalesces
|
|
62
|
-
* multiple `markForCheck` calls to into one change detection run.
|
|
63
|
-
*
|
|
64
|
-
* This can be used to ensure an {@link ChangeDetectionStrategy#OnPush OnPush} component is
|
|
65
|
-
* checked when it needs to be re-rendered but the two normal triggers haven't marked it
|
|
66
|
-
* dirty (i.e. inputs haven't changed and events haven't fired in the view).
|
|
67
|
-
*
|
|
68
|
-
* <!-- TODO: Add a link to a chapter on OnPush components -->
|
|
69
|
-
*
|
|
70
|
-
* ### Example ([live demo](https://stackblitz.com/edit/angular-kx7rrw))
|
|
71
|
-
*
|
|
72
|
-
* ```typescript
|
|
73
|
-
* @Component({
|
|
74
|
-
* selector: 'my-app',
|
|
75
|
-
* template: `Number of ticks: {{numberOfTicks}}`
|
|
76
|
-
* changeDetection: ChangeDetectionStrategy.OnPush,
|
|
77
|
-
* })
|
|
78
|
-
* class AppComponent {
|
|
79
|
-
* numberOfTicks = 0;
|
|
80
|
-
*
|
|
81
|
-
* constructor(private ref: ChangeDetectorRef) {
|
|
82
|
-
* setInterval(() => {
|
|
83
|
-
* this.numberOfTicks++;
|
|
84
|
-
* // the following is required, otherwise the view will not be updated
|
|
85
|
-
* this.ref.markForCheck();
|
|
86
|
-
* }, 1000);
|
|
87
|
-
* }
|
|
88
|
-
* }
|
|
89
|
-
* ```
|
|
90
|
-
*/
|
|
91
|
-
ViewRef.prototype.markForCheck = /**
|
|
92
|
-
* Marks a view and all of its ancestors dirty.
|
|
93
|
-
*
|
|
94
|
-
* It also triggers change detection by calling `scheduleTick` internally, which coalesces
|
|
95
|
-
* multiple `markForCheck` calls to into one change detection run.
|
|
96
|
-
*
|
|
97
|
-
* This can be used to ensure an {@link ChangeDetectionStrategy#OnPush OnPush} component is
|
|
98
|
-
* checked when it needs to be re-rendered but the two normal triggers haven't marked it
|
|
99
|
-
* dirty (i.e. inputs haven't changed and events haven't fired in the view).
|
|
100
|
-
*
|
|
101
|
-
* <!-- TODO: Add a link to a chapter on OnPush components -->
|
|
102
|
-
*
|
|
103
|
-
* ### Example ([live demo](https://stackblitz.com/edit/angular-kx7rrw))
|
|
104
|
-
*
|
|
105
|
-
* ```typescript
|
|
106
|
-
* @Component({
|
|
107
|
-
* selector: 'my-app',
|
|
108
|
-
* template: `Number of ticks: {{numberOfTicks}}`
|
|
109
|
-
* changeDetection: ChangeDetectionStrategy.OnPush,
|
|
110
|
-
* })
|
|
111
|
-
* class AppComponent {
|
|
112
|
-
* numberOfTicks = 0;
|
|
113
|
-
*
|
|
114
|
-
* constructor(private ref: ChangeDetectorRef) {
|
|
115
|
-
* setInterval(() => {
|
|
116
|
-
* this.numberOfTicks++;
|
|
117
|
-
* // the following is required, otherwise the view will not be updated
|
|
118
|
-
* this.ref.markForCheck();
|
|
119
|
-
* }, 1000);
|
|
120
|
-
* }
|
|
121
|
-
* }
|
|
122
|
-
* ```
|
|
123
|
-
*/
|
|
124
|
-
function () { markViewDirty(this._view); };
|
|
57
|
+
ViewRef.prototype.markForCheck = function () { markViewDirty(this._view); };
|
|
125
58
|
/**
|
|
126
59
|
* Detaches the view from the change detection tree.
|
|
127
60
|
*
|
|
@@ -133,6 +66,7 @@ var ViewRef = /** @class */ (function () {
|
|
|
133
66
|
* <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
|
|
134
67
|
* <!-- TODO: Add a live demo once ref.detectChanges is merged into master -->
|
|
135
68
|
*
|
|
69
|
+
* @usageNotes
|
|
136
70
|
* ### Example
|
|
137
71
|
*
|
|
138
72
|
* The following example defines a component with a large list of readonly data.
|
|
@@ -174,111 +108,7 @@ var ViewRef = /** @class */ (function () {
|
|
|
174
108
|
* }
|
|
175
109
|
* ```
|
|
176
110
|
*/
|
|
177
|
-
|
|
178
|
-
* Detaches the view from the change detection tree.
|
|
179
|
-
*
|
|
180
|
-
* Detached views will not be checked during change detection runs until they are
|
|
181
|
-
* re-attached, even if they are dirty. `detach` can be used in combination with
|
|
182
|
-
* {@link ChangeDetectorRef#detectChanges detectChanges} to implement local change
|
|
183
|
-
* detection checks.
|
|
184
|
-
*
|
|
185
|
-
* <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
|
|
186
|
-
* <!-- TODO: Add a live demo once ref.detectChanges is merged into master -->
|
|
187
|
-
*
|
|
188
|
-
* ### Example
|
|
189
|
-
*
|
|
190
|
-
* The following example defines a component with a large list of readonly data.
|
|
191
|
-
* Imagine the data changes constantly, many times per second. For performance reasons,
|
|
192
|
-
* we want to check and update the list every five seconds. We can do that by detaching
|
|
193
|
-
* the component's change detector and doing a local check every five seconds.
|
|
194
|
-
*
|
|
195
|
-
* ```typescript
|
|
196
|
-
* class DataProvider {
|
|
197
|
-
* // in a real application the returned data will be different every time
|
|
198
|
-
* get data() {
|
|
199
|
-
* return [1,2,3,4,5];
|
|
200
|
-
* }
|
|
201
|
-
* }
|
|
202
|
-
*
|
|
203
|
-
* @Component({
|
|
204
|
-
* selector: 'giant-list',
|
|
205
|
-
* template: `
|
|
206
|
-
* <li *ngFor="let d of dataProvider.data">Data {{d}}</li>
|
|
207
|
-
* `,
|
|
208
|
-
* })
|
|
209
|
-
* class GiantList {
|
|
210
|
-
* constructor(private ref: ChangeDetectorRef, private dataProvider: DataProvider) {
|
|
211
|
-
* ref.detach();
|
|
212
|
-
* setInterval(() => {
|
|
213
|
-
* this.ref.detectChanges();
|
|
214
|
-
* }, 5000);
|
|
215
|
-
* }
|
|
216
|
-
* }
|
|
217
|
-
*
|
|
218
|
-
* @Component({
|
|
219
|
-
* selector: 'app',
|
|
220
|
-
* providers: [DataProvider],
|
|
221
|
-
* template: `
|
|
222
|
-
* <giant-list><giant-list>
|
|
223
|
-
* `,
|
|
224
|
-
* })
|
|
225
|
-
* class App {
|
|
226
|
-
* }
|
|
227
|
-
* ```
|
|
228
|
-
*/
|
|
229
|
-
ViewRef.prototype.detach = /**
|
|
230
|
-
* Detaches the view from the change detection tree.
|
|
231
|
-
*
|
|
232
|
-
* Detached views will not be checked during change detection runs until they are
|
|
233
|
-
* re-attached, even if they are dirty. `detach` can be used in combination with
|
|
234
|
-
* {@link ChangeDetectorRef#detectChanges detectChanges} to implement local change
|
|
235
|
-
* detection checks.
|
|
236
|
-
*
|
|
237
|
-
* <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
|
|
238
|
-
* <!-- TODO: Add a live demo once ref.detectChanges is merged into master -->
|
|
239
|
-
*
|
|
240
|
-
* ### Example
|
|
241
|
-
*
|
|
242
|
-
* The following example defines a component with a large list of readonly data.
|
|
243
|
-
* Imagine the data changes constantly, many times per second. For performance reasons,
|
|
244
|
-
* we want to check and update the list every five seconds. We can do that by detaching
|
|
245
|
-
* the component's change detector and doing a local check every five seconds.
|
|
246
|
-
*
|
|
247
|
-
* ```typescript
|
|
248
|
-
* class DataProvider {
|
|
249
|
-
* // in a real application the returned data will be different every time
|
|
250
|
-
* get data() {
|
|
251
|
-
* return [1,2,3,4,5];
|
|
252
|
-
* }
|
|
253
|
-
* }
|
|
254
|
-
*
|
|
255
|
-
* @Component({
|
|
256
|
-
* selector: 'giant-list',
|
|
257
|
-
* template: `
|
|
258
|
-
* <li *ngFor="let d of dataProvider.data">Data {{d}}</li>
|
|
259
|
-
* `,
|
|
260
|
-
* })
|
|
261
|
-
* class GiantList {
|
|
262
|
-
* constructor(private ref: ChangeDetectorRef, private dataProvider: DataProvider) {
|
|
263
|
-
* ref.detach();
|
|
264
|
-
* setInterval(() => {
|
|
265
|
-
* this.ref.detectChanges();
|
|
266
|
-
* }, 5000);
|
|
267
|
-
* }
|
|
268
|
-
* }
|
|
269
|
-
*
|
|
270
|
-
* @Component({
|
|
271
|
-
* selector: 'app',
|
|
272
|
-
* providers: [DataProvider],
|
|
273
|
-
* template: `
|
|
274
|
-
* <giant-list><giant-list>
|
|
275
|
-
* `,
|
|
276
|
-
* })
|
|
277
|
-
* class App {
|
|
278
|
-
* }
|
|
279
|
-
* ```
|
|
280
|
-
*/
|
|
281
|
-
function () { this._view.flags &= ~8 /* Attached */; };
|
|
111
|
+
ViewRef.prototype.detach = function () { this._view.flags &= ~8 /* Attached */; };
|
|
282
112
|
/**
|
|
283
113
|
* Re-attaches a view to the change detection tree.
|
|
284
114
|
*
|
|
@@ -287,7 +117,8 @@ var ViewRef = /** @class */ (function () {
|
|
|
287
117
|
*
|
|
288
118
|
* <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
|
|
289
119
|
*
|
|
290
|
-
*
|
|
120
|
+
* @usageNotes
|
|
121
|
+
* ### Example
|
|
291
122
|
*
|
|
292
123
|
* The following example creates a component displaying `live` data. The component will detach
|
|
293
124
|
* its change detector from the main change detector tree when the component's live property
|
|
@@ -334,117 +165,7 @@ var ViewRef = /** @class */ (function () {
|
|
|
334
165
|
* }
|
|
335
166
|
* ```
|
|
336
167
|
*/
|
|
337
|
-
|
|
338
|
-
* Re-attaches a view to the change detection tree.
|
|
339
|
-
*
|
|
340
|
-
* This can be used to re-attach views that were previously detached from the tree
|
|
341
|
-
* using {@link ChangeDetectorRef#detach detach}. Views are attached to the tree by default.
|
|
342
|
-
*
|
|
343
|
-
* <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
|
|
344
|
-
*
|
|
345
|
-
* ### Example ([live demo](https://stackblitz.com/edit/angular-ymgsxw))
|
|
346
|
-
*
|
|
347
|
-
* The following example creates a component displaying `live` data. The component will detach
|
|
348
|
-
* its change detector from the main change detector tree when the component's live property
|
|
349
|
-
* is set to false.
|
|
350
|
-
*
|
|
351
|
-
* ```typescript
|
|
352
|
-
* class DataProvider {
|
|
353
|
-
* data = 1;
|
|
354
|
-
*
|
|
355
|
-
* constructor() {
|
|
356
|
-
* setInterval(() => {
|
|
357
|
-
* this.data = this.data * 2;
|
|
358
|
-
* }, 500);
|
|
359
|
-
* }
|
|
360
|
-
* }
|
|
361
|
-
*
|
|
362
|
-
* @Component({
|
|
363
|
-
* selector: 'live-data',
|
|
364
|
-
* inputs: ['live'],
|
|
365
|
-
* template: 'Data: {{dataProvider.data}}'
|
|
366
|
-
* })
|
|
367
|
-
* class LiveData {
|
|
368
|
-
* constructor(private ref: ChangeDetectorRef, private dataProvider: DataProvider) {}
|
|
369
|
-
*
|
|
370
|
-
* set live(value) {
|
|
371
|
-
* if (value) {
|
|
372
|
-
* this.ref.reattach();
|
|
373
|
-
* } else {
|
|
374
|
-
* this.ref.detach();
|
|
375
|
-
* }
|
|
376
|
-
* }
|
|
377
|
-
* }
|
|
378
|
-
*
|
|
379
|
-
* @Component({
|
|
380
|
-
* selector: 'my-app',
|
|
381
|
-
* providers: [DataProvider],
|
|
382
|
-
* template: `
|
|
383
|
-
* Live Update: <input type="checkbox" [(ngModel)]="live">
|
|
384
|
-
* <live-data [live]="live"><live-data>
|
|
385
|
-
* `,
|
|
386
|
-
* })
|
|
387
|
-
* class AppComponent {
|
|
388
|
-
* live = true;
|
|
389
|
-
* }
|
|
390
|
-
* ```
|
|
391
|
-
*/
|
|
392
|
-
ViewRef.prototype.reattach = /**
|
|
393
|
-
* Re-attaches a view to the change detection tree.
|
|
394
|
-
*
|
|
395
|
-
* This can be used to re-attach views that were previously detached from the tree
|
|
396
|
-
* using {@link ChangeDetectorRef#detach detach}. Views are attached to the tree by default.
|
|
397
|
-
*
|
|
398
|
-
* <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
|
|
399
|
-
*
|
|
400
|
-
* ### Example ([live demo](https://stackblitz.com/edit/angular-ymgsxw))
|
|
401
|
-
*
|
|
402
|
-
* The following example creates a component displaying `live` data. The component will detach
|
|
403
|
-
* its change detector from the main change detector tree when the component's live property
|
|
404
|
-
* is set to false.
|
|
405
|
-
*
|
|
406
|
-
* ```typescript
|
|
407
|
-
* class DataProvider {
|
|
408
|
-
* data = 1;
|
|
409
|
-
*
|
|
410
|
-
* constructor() {
|
|
411
|
-
* setInterval(() => {
|
|
412
|
-
* this.data = this.data * 2;
|
|
413
|
-
* }, 500);
|
|
414
|
-
* }
|
|
415
|
-
* }
|
|
416
|
-
*
|
|
417
|
-
* @Component({
|
|
418
|
-
* selector: 'live-data',
|
|
419
|
-
* inputs: ['live'],
|
|
420
|
-
* template: 'Data: {{dataProvider.data}}'
|
|
421
|
-
* })
|
|
422
|
-
* class LiveData {
|
|
423
|
-
* constructor(private ref: ChangeDetectorRef, private dataProvider: DataProvider) {}
|
|
424
|
-
*
|
|
425
|
-
* set live(value) {
|
|
426
|
-
* if (value) {
|
|
427
|
-
* this.ref.reattach();
|
|
428
|
-
* } else {
|
|
429
|
-
* this.ref.detach();
|
|
430
|
-
* }
|
|
431
|
-
* }
|
|
432
|
-
* }
|
|
433
|
-
*
|
|
434
|
-
* @Component({
|
|
435
|
-
* selector: 'my-app',
|
|
436
|
-
* providers: [DataProvider],
|
|
437
|
-
* template: `
|
|
438
|
-
* Live Update: <input type="checkbox" [(ngModel)]="live">
|
|
439
|
-
* <live-data [live]="live"><live-data>
|
|
440
|
-
* `,
|
|
441
|
-
* })
|
|
442
|
-
* class AppComponent {
|
|
443
|
-
* live = true;
|
|
444
|
-
* }
|
|
445
|
-
* ```
|
|
446
|
-
*/
|
|
447
|
-
function () { this._view.flags |= 8 /* Attached */; };
|
|
168
|
+
ViewRef.prototype.reattach = function () { this._view.flags |= 8 /* Attached */; };
|
|
448
169
|
/**
|
|
449
170
|
* Checks the view and its children.
|
|
450
171
|
*
|
|
@@ -454,6 +175,7 @@ var ViewRef = /** @class */ (function () {
|
|
|
454
175
|
* <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
|
|
455
176
|
* <!-- TODO: Add a live demo once ref.detectChanges is merged into master -->
|
|
456
177
|
*
|
|
178
|
+
* @usageNotes
|
|
457
179
|
* ### Example
|
|
458
180
|
*
|
|
459
181
|
* The following example defines a component with a large list of readonly data.
|
|
@@ -465,66 +187,14 @@ var ViewRef = /** @class */ (function () {
|
|
|
465
187
|
*
|
|
466
188
|
* See {@link ChangeDetectorRef#detach detach} for more information.
|
|
467
189
|
*/
|
|
468
|
-
|
|
469
|
-
* Checks the view and its children.
|
|
470
|
-
*
|
|
471
|
-
* This can also be used in combination with {@link ChangeDetectorRef#detach detach} to implement
|
|
472
|
-
* local change detection checks.
|
|
473
|
-
*
|
|
474
|
-
* <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
|
|
475
|
-
* <!-- TODO: Add a live demo once ref.detectChanges is merged into master -->
|
|
476
|
-
*
|
|
477
|
-
* ### Example
|
|
478
|
-
*
|
|
479
|
-
* The following example defines a component with a large list of readonly data.
|
|
480
|
-
* Imagine, the data changes constantly, many times per second. For performance reasons,
|
|
481
|
-
* we want to check and update the list every five seconds.
|
|
482
|
-
*
|
|
483
|
-
* We can do that by detaching the component's change detector and doing a local change detection
|
|
484
|
-
* check every five seconds.
|
|
485
|
-
*
|
|
486
|
-
* See {@link ChangeDetectorRef#detach detach} for more information.
|
|
487
|
-
*/
|
|
488
|
-
ViewRef.prototype.detectChanges = /**
|
|
489
|
-
* Checks the view and its children.
|
|
490
|
-
*
|
|
491
|
-
* This can also be used in combination with {@link ChangeDetectorRef#detach detach} to implement
|
|
492
|
-
* local change detection checks.
|
|
493
|
-
*
|
|
494
|
-
* <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->
|
|
495
|
-
* <!-- TODO: Add a live demo once ref.detectChanges is merged into master -->
|
|
496
|
-
*
|
|
497
|
-
* ### Example
|
|
498
|
-
*
|
|
499
|
-
* The following example defines a component with a large list of readonly data.
|
|
500
|
-
* Imagine, the data changes constantly, many times per second. For performance reasons,
|
|
501
|
-
* we want to check and update the list every five seconds.
|
|
502
|
-
*
|
|
503
|
-
* We can do that by detaching the component's change detector and doing a local change detection
|
|
504
|
-
* check every five seconds.
|
|
505
|
-
*
|
|
506
|
-
* See {@link ChangeDetectorRef#detach detach} for more information.
|
|
507
|
-
*/
|
|
508
|
-
function () { detectChanges(this.context); };
|
|
190
|
+
ViewRef.prototype.detectChanges = function () { detectChanges(this.context); };
|
|
509
191
|
/**
|
|
510
192
|
* Checks the change detector and its children, and throws if any changes are detected.
|
|
511
193
|
*
|
|
512
194
|
* This is used in development mode to verify that running change detection doesn't
|
|
513
195
|
* introduce other changes.
|
|
514
196
|
*/
|
|
515
|
-
|
|
516
|
-
* Checks the change detector and its children, and throws if any changes are detected.
|
|
517
|
-
*
|
|
518
|
-
* This is used in development mode to verify that running change detection doesn't
|
|
519
|
-
* introduce other changes.
|
|
520
|
-
*/
|
|
521
|
-
ViewRef.prototype.checkNoChanges = /**
|
|
522
|
-
* Checks the change detector and its children, and throws if any changes are detected.
|
|
523
|
-
*
|
|
524
|
-
* This is used in development mode to verify that running change detection doesn't
|
|
525
|
-
* introduce other changes.
|
|
526
|
-
*/
|
|
527
|
-
function () { checkNoChanges(this.context); };
|
|
197
|
+
ViewRef.prototype.checkNoChanges = function () { checkNoChanges(this.context); };
|
|
528
198
|
return ViewRef;
|
|
529
199
|
}());
|
|
530
200
|
export { ViewRef };
|
|
@@ -546,7 +216,7 @@ export { EmbeddedViewRef };
|
|
|
546
216
|
*/
|
|
547
217
|
export function createViewRef(view, context) {
|
|
548
218
|
// TODO: add detectChanges back in when implementing ChangeDetectorRef.detectChanges
|
|
549
|
-
return addDestroyable(new ViewRef(
|
|
219
|
+
return addDestroyable(new ViewRef(view, context));
|
|
550
220
|
}
|
|
551
221
|
/**
|
|
552
222
|
* Decorates an object with destroy logic (implementing the DestroyRef interface)
|
|
@@ -566,4 +236,4 @@ export function addDestroyable(obj) {
|
|
|
566
236
|
return obj;
|
|
567
237
|
}
|
|
568
238
|
|
|
569
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view_ref.js","sourceRoot":"","sources":["../../../../../../../../../../packages/core/src/render3/view_ref.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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\nimport {EmbeddedViewRef as viewEngine_EmbeddedViewRef} from '../linker/view_ref';\n\nimport {checkNoChanges, detectChanges, markViewDirty} from './instructions';\nimport {ComponentTemplate} from './interfaces/definition';\nimport {LViewNode} from './interfaces/node';\nimport {LView, LViewFlags} from './interfaces/view';\nimport {notImplemented} from './util';\n\nexport class ViewRef<T> implements viewEngine_EmbeddedViewRef<T> {\n  context: T;\n  rootNodes: any[];\n\n  constructor(private _view: LView, context: T|null, ) { this.context = context !; }\n\n  /** @internal */\n  _setComponentContext(view: LView, context: T) {\n    this._view = view;\n    this.context = context;\n  }\n\n  destroy(): void { notImplemented(); }\n  destroyed: boolean;\n  onDestroy(callback: Function) { notImplemented(); }\n\n  /**\n   * Marks a view and all of its ancestors dirty.\n   *\n   * It also triggers change detection by calling `scheduleTick` internally, which coalesces\n   * multiple `markForCheck` calls to into one change detection run.\n   *\n   * This can be used to ensure an {@link ChangeDetectionStrategy#OnPush OnPush} component is\n   * checked when it needs to be re-rendered but the two normal triggers haven't marked it\n   * dirty (i.e. inputs haven't changed and events haven't fired in the view).\n   *\n   * <!-- TODO: Add a link to a chapter on OnPush components -->\n   *\n   * ### Example ([live demo](https://stackblitz.com/edit/angular-kx7rrw))\n   *\n   * ```typescript\n   * @Component({\n   *   selector: 'my-app',\n   *   template: `Number of ticks: {{numberOfTicks}}`\n   *   changeDetection: ChangeDetectionStrategy.OnPush,\n   * })\n   * class AppComponent {\n   *   numberOfTicks = 0;\n   *\n   *   constructor(private ref: ChangeDetectorRef) {\n   *     setInterval(() => {\n   *       this.numberOfTicks++;\n   *       // the following is required, otherwise the view will not be updated\n   *       this.ref.markForCheck();\n   *     }, 1000);\n   *   }\n   * }\n   * ```\n   */\n  markForCheck(): void { markViewDirty(this._view); }\n\n  /**\n   * Detaches the view from the change detection tree.\n   *\n   * Detached views will not be checked during change detection runs until they are\n   * re-attached, even if they are dirty. `detach` can be used in combination with\n   * {@link ChangeDetectorRef#detectChanges detectChanges} to implement local change\n   * detection checks.\n   *\n   * <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->\n   * <!-- TODO: Add a live demo once ref.detectChanges is merged into master -->\n   *\n   * ### Example\n   *\n   * The following example defines a component with a large list of readonly data.\n   * Imagine the data changes constantly, many times per second. For performance reasons,\n   * we want to check and update the list every five seconds. We can do that by detaching\n   * the component's change detector and doing a local check every five seconds.\n   *\n   * ```typescript\n   * class DataProvider {\n   *   // in a real application the returned data will be different every time\n   *   get data() {\n   *     return [1,2,3,4,5];\n   *   }\n   * }\n   *\n   * @Component({\n   *   selector: 'giant-list',\n   *   template: `\n   *     <li *ngFor=\"let d of dataProvider.data\">Data {{d}}</li>\n   *   `,\n   * })\n   * class GiantList {\n   *   constructor(private ref: ChangeDetectorRef, private dataProvider: DataProvider) {\n   *     ref.detach();\n   *     setInterval(() => {\n   *       this.ref.detectChanges();\n   *     }, 5000);\n   *   }\n   * }\n   *\n   * @Component({\n   *   selector: 'app',\n   *   providers: [DataProvider],\n   *   template: `\n   *     <giant-list><giant-list>\n   *   `,\n   * })\n   * class App {\n   * }\n   * ```\n   */\n  detach(): void { this._view.flags &= ~LViewFlags.Attached; }\n\n  /**\n   * Re-attaches a view to the change detection tree.\n   *\n   * This can be used to re-attach views that were previously detached from the tree\n   * using {@link ChangeDetectorRef#detach detach}. Views are attached to the tree by default.\n   *\n   * <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->\n   *\n   * ### Example ([live demo](https://stackblitz.com/edit/angular-ymgsxw))\n   *\n   * The following example creates a component displaying `live` data. The component will detach\n   * its change detector from the main change detector tree when the component's live property\n   * is set to false.\n   *\n   * ```typescript\n   * class DataProvider {\n   *   data = 1;\n   *\n   *   constructor() {\n   *     setInterval(() => {\n   *       this.data = this.data * 2;\n   *     }, 500);\n   *   }\n   * }\n   *\n   * @Component({\n   *   selector: 'live-data',\n   *   inputs: ['live'],\n   *   template: 'Data: {{dataProvider.data}}'\n   * })\n   * class LiveData {\n   *   constructor(private ref: ChangeDetectorRef, private dataProvider: DataProvider) {}\n   *\n   *   set live(value) {\n   *     if (value) {\n   *       this.ref.reattach();\n   *     } else {\n   *       this.ref.detach();\n   *     }\n   *   }\n   * }\n   *\n   * @Component({\n   *   selector: 'my-app',\n   *   providers: [DataProvider],\n   *   template: `\n   *     Live Update: <input type=\"checkbox\" [(ngModel)]=\"live\">\n   *     <live-data [live]=\"live\"><live-data>\n   *   `,\n   * })\n   * class AppComponent {\n   *   live = true;\n   * }\n   * ```\n   */\n  reattach(): void { this._view.flags |= LViewFlags.Attached; }\n\n  /**\n   * Checks the view and its children.\n   *\n   * This can also be used in combination with {@link ChangeDetectorRef#detach detach} to implement\n   * local change detection checks.\n   *\n   * <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->\n   * <!-- TODO: Add a live demo once ref.detectChanges is merged into master -->\n   *\n   * ### Example\n   *\n   * The following example defines a component with a large list of readonly data.\n   * Imagine, the data changes constantly, many times per second. For performance reasons,\n   * we want to check and update the list every five seconds.\n   *\n   * We can do that by detaching the component's change detector and doing a local change detection\n   * check every five seconds.\n   *\n   * See {@link ChangeDetectorRef#detach detach} for more information.\n   */\n  detectChanges(): void { detectChanges(this.context); }\n\n  /**\n   * Checks the change detector and its children, and throws if any changes are detected.\n   *\n   * This is used in development mode to verify that running change detection doesn't\n   * introduce other changes.\n   */\n  checkNoChanges(): void { checkNoChanges(this.context); }\n}\n\n\nexport class EmbeddedViewRef<T> extends ViewRef<T> {\n  /**\n   * @internal\n   */\n  _lViewNode: LViewNode;\n\n  constructor(viewNode: LViewNode, template: ComponentTemplate<T>, context: T) {\n    super(viewNode.data, context);\n    this._lViewNode = viewNode;\n  }\n}\n\n/**\n * Creates a ViewRef bundled with destroy functionality.\n *\n * @param context The context for this view\n * @returns The ViewRef\n */\nexport function createViewRef<T>(view: LView | null, context: T): ViewRef<T> {\n  // TODO: add detectChanges back in when implementing ChangeDetectorRef.detectChanges\n  return addDestroyable(new ViewRef(view !, context));\n}\n\n/** Interface for destroy logic. Implemented by addDestroyable. */\nexport interface DestroyRef<T> {\n  /** Whether or not this object has been destroyed */\n  destroyed: boolean;\n  /** Destroy the instance and call all onDestroy callbacks. */\n  destroy(): void;\n  /** Register callbacks that should be called onDestroy */\n  onDestroy(cb: Function): void;\n}\n\n/**\n * Decorates an object with destroy logic (implementing the DestroyRef interface)\n * and returns the enhanced object.\n *\n * @param obj The object to decorate\n * @returns The object with destroy logic\n */\nexport function addDestroyable<T, C>(obj: any): T&DestroyRef<C> {\n  let destroyFn: Function[]|null = null;\n  obj.destroyed = false;\n  obj.destroy = function() {\n    destroyFn && destroyFn.forEach((fn) => fn());\n    this.destroyed = true;\n  };\n  obj.onDestroy = (fn: Function) => (destroyFn || (destroyFn = [])).push(fn);\n  return obj;\n}\n"]}
|
|
239
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view_ref.js","sourceRoot":"","sources":["../../../../../../../../../../packages/core/src/render3/view_ref.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;AAIH,OAAO,EAAC,cAAc,EAAE,aAAa,EAAE,aAAa,EAAC,MAAM,gBAAgB,CAAC;AAI5E,OAAO,EAAC,cAAc,EAAC,MAAM,QAAQ,CAAC;AAEtC;IAIE,iBAAoB,KAAY,EAAE,OAAe;QAA7B,UAAK,GAAL,KAAK,CAAO;QAAuB,IAAI,CAAC,OAAO,GAAG,OAAS,CAAC;IAAC,CAAC;IAElF,gBAAgB;IAChB,sCAAoB,GAApB,UAAqB,IAAW,EAAE,OAAU;QAC1C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAED,yBAAO,GAAP,cAAkB,cAAc,EAAE,CAAC,CAAC,CAAC;IAErC,2BAAS,GAAT,UAAU,QAAkB,IAAI,cAAc,EAAE,CAAC,CAAC,CAAC;IAEnD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAiCG;IACH,8BAAY,GAAZ,cAAuB,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAEnD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAoDG;IACH,wBAAM,GAAN,cAAiB,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,iBAAoB,CAAC,CAAC,CAAC;IAE5D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAuDG;IACH,0BAAQ,GAAR,cAAmB,IAAI,CAAC,KAAK,CAAC,KAAK,oBAAuB,CAAC,CAAC,CAAC;IAE7D;;;;;;;;;;;;;;;;;;;;OAoBG;IACH,+BAAa,GAAb,cAAwB,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAEtD;;;;;OAKG;IACH,gCAAc,GAAd,cAAyB,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC1D,cAAC;AAAD,CAAC,AAnMD,IAmMC;;AAGD;IAAwC,2CAAU;IAMhD,yBAAY,QAAmB,EAAE,QAA8B,EAAE,OAAU;QAA3E,YACE,kBAAM,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,SAE9B;QADC,KAAI,CAAC,UAAU,GAAG,QAAQ,CAAC;;IAC7B,CAAC;IACH,sBAAC;AAAD,CAAC,AAVD,CAAwC,OAAO,GAU9C;;AAED;;;;;GAKG;AACH,MAAM,wBAA2B,IAAkB,EAAE,OAAU;IAC7D,oFAAoF;IACpF,MAAM,CAAC,cAAc,CAAC,IAAI,OAAO,CAAC,IAAM,EAAE,OAAO,CAAC,CAAC,CAAC;AACtD,CAAC;AAYD;;;;;;GAMG;AACH,MAAM,yBAA+B,GAAQ;IAC3C,IAAI,SAAS,GAAoB,IAAI,CAAC;IACtC,GAAG,CAAC,SAAS,GAAG,KAAK,CAAC;IACtB,GAAG,CAAC,OAAO,GAAG;QACZ,SAAS,IAAI,SAAS,CAAC,OAAO,CAAC,UAAC,EAAE,IAAK,OAAA,EAAE,EAAE,EAAJ,CAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;IACxB,CAAC,CAAC;IACF,GAAG,CAAC,SAAS,GAAG,UAAC,EAAY,IAAK,OAAA,CAAC,SAAS,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAxC,CAAwC,CAAC;IAC3E,MAAM,CAAC,GAAG,CAAC;AACb,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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\nimport {EmbeddedViewRef as viewEngine_EmbeddedViewRef} from '../linker/view_ref';\n\nimport {checkNoChanges, detectChanges, markViewDirty} from './instructions';\nimport {ComponentTemplate} from './interfaces/definition';\nimport {LViewNode} from './interfaces/node';\nimport {LView, LViewFlags} from './interfaces/view';\nimport {notImplemented} from './util';\n\nexport class ViewRef<T> implements viewEngine_EmbeddedViewRef<T> {\n  context: T;\n  rootNodes: any[];\n\n  constructor(private _view: LView, context: T|null, ) { this.context = context !; }\n\n  /** @internal */\n  _setComponentContext(view: LView, context: T) {\n    this._view = view;\n    this.context = context;\n  }\n\n  destroy(): void { notImplemented(); }\n  destroyed: boolean;\n  onDestroy(callback: Function) { notImplemented(); }\n\n  /**\n   * Marks a view and all of its ancestors dirty.\n   *\n   * It also triggers change detection by calling `scheduleTick` internally, which coalesces\n   * multiple `markForCheck` calls to into one change detection run.\n   *\n   * This can be used to ensure an {@link ChangeDetectionStrategy#OnPush OnPush} component is\n   * checked when it needs to be re-rendered but the two normal triggers haven't marked it\n   * dirty (i.e. inputs haven't changed and events haven't fired in the view).\n   *\n   * <!-- TODO: Add a link to a chapter on OnPush components -->\n   *\n   * @usageNotes\n   * ### Example\n   *\n   * ```typescript\n   * @Component({\n   *   selector: 'my-app',\n   *   template: `Number of ticks: {{numberOfTicks}}`\n   *   changeDetection: ChangeDetectionStrategy.OnPush,\n   * })\n   * class AppComponent {\n   *   numberOfTicks = 0;\n   *\n   *   constructor(private ref: ChangeDetectorRef) {\n   *     setInterval(() => {\n   *       this.numberOfTicks++;\n   *       // the following is required, otherwise the view will not be updated\n   *       this.ref.markForCheck();\n   *     }, 1000);\n   *   }\n   * }\n   * ```\n   */\n  markForCheck(): void { markViewDirty(this._view); }\n\n  /**\n   * Detaches the view from the change detection tree.\n   *\n   * Detached views will not be checked during change detection runs until they are\n   * re-attached, even if they are dirty. `detach` can be used in combination with\n   * {@link ChangeDetectorRef#detectChanges detectChanges} to implement local change\n   * detection checks.\n   *\n   * <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->\n   * <!-- TODO: Add a live demo once ref.detectChanges is merged into master -->\n   *\n   * @usageNotes\n   * ### Example\n   *\n   * The following example defines a component with a large list of readonly data.\n   * Imagine the data changes constantly, many times per second. For performance reasons,\n   * we want to check and update the list every five seconds. We can do that by detaching\n   * the component's change detector and doing a local check every five seconds.\n   *\n   * ```typescript\n   * class DataProvider {\n   *   // in a real application the returned data will be different every time\n   *   get data() {\n   *     return [1,2,3,4,5];\n   *   }\n   * }\n   *\n   * @Component({\n   *   selector: 'giant-list',\n   *   template: `\n   *     <li *ngFor=\"let d of dataProvider.data\">Data {{d}}</li>\n   *   `,\n   * })\n   * class GiantList {\n   *   constructor(private ref: ChangeDetectorRef, private dataProvider: DataProvider) {\n   *     ref.detach();\n   *     setInterval(() => {\n   *       this.ref.detectChanges();\n   *     }, 5000);\n   *   }\n   * }\n   *\n   * @Component({\n   *   selector: 'app',\n   *   providers: [DataProvider],\n   *   template: `\n   *     <giant-list><giant-list>\n   *   `,\n   * })\n   * class App {\n   * }\n   * ```\n   */\n  detach(): void { this._view.flags &= ~LViewFlags.Attached; }\n\n  /**\n   * Re-attaches a view to the change detection tree.\n   *\n   * This can be used to re-attach views that were previously detached from the tree\n   * using {@link ChangeDetectorRef#detach detach}. Views are attached to the tree by default.\n   *\n   * <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->\n   *\n   * @usageNotes\n   * ### Example\n   *\n   * The following example creates a component displaying `live` data. The component will detach\n   * its change detector from the main change detector tree when the component's live property\n   * is set to false.\n   *\n   * ```typescript\n   * class DataProvider {\n   *   data = 1;\n   *\n   *   constructor() {\n   *     setInterval(() => {\n   *       this.data = this.data * 2;\n   *     }, 500);\n   *   }\n   * }\n   *\n   * @Component({\n   *   selector: 'live-data',\n   *   inputs: ['live'],\n   *   template: 'Data: {{dataProvider.data}}'\n   * })\n   * class LiveData {\n   *   constructor(private ref: ChangeDetectorRef, private dataProvider: DataProvider) {}\n   *\n   *   set live(value) {\n   *     if (value) {\n   *       this.ref.reattach();\n   *     } else {\n   *       this.ref.detach();\n   *     }\n   *   }\n   * }\n   *\n   * @Component({\n   *   selector: 'my-app',\n   *   providers: [DataProvider],\n   *   template: `\n   *     Live Update: <input type=\"checkbox\" [(ngModel)]=\"live\">\n   *     <live-data [live]=\"live\"><live-data>\n   *   `,\n   * })\n   * class AppComponent {\n   *   live = true;\n   * }\n   * ```\n   */\n  reattach(): void { this._view.flags |= LViewFlags.Attached; }\n\n  /**\n   * Checks the view and its children.\n   *\n   * This can also be used in combination with {@link ChangeDetectorRef#detach detach} to implement\n   * local change detection checks.\n   *\n   * <!-- TODO: Add a link to a chapter on detach/reattach/local digest -->\n   * <!-- TODO: Add a live demo once ref.detectChanges is merged into master -->\n   *\n   * @usageNotes\n   * ### Example\n   *\n   * The following example defines a component with a large list of readonly data.\n   * Imagine, the data changes constantly, many times per second. For performance reasons,\n   * we want to check and update the list every five seconds.\n   *\n   * We can do that by detaching the component's change detector and doing a local change detection\n   * check every five seconds.\n   *\n   * See {@link ChangeDetectorRef#detach detach} for more information.\n   */\n  detectChanges(): void { detectChanges(this.context); }\n\n  /**\n   * Checks the change detector and its children, and throws if any changes are detected.\n   *\n   * This is used in development mode to verify that running change detection doesn't\n   * introduce other changes.\n   */\n  checkNoChanges(): void { checkNoChanges(this.context); }\n}\n\n\nexport class EmbeddedViewRef<T> extends ViewRef<T> {\n  /**\n   * @internal\n   */\n  _lViewNode: LViewNode;\n\n  constructor(viewNode: LViewNode, template: ComponentTemplate<T>, context: T) {\n    super(viewNode.data, context);\n    this._lViewNode = viewNode;\n  }\n}\n\n/**\n * Creates a ViewRef bundled with destroy functionality.\n *\n * @param context The context for this view\n * @returns The ViewRef\n */\nexport function createViewRef<T>(view: LView | null, context: T): ViewRef<T> {\n  // TODO: add detectChanges back in when implementing ChangeDetectorRef.detectChanges\n  return addDestroyable(new ViewRef(view !, context));\n}\n\n/** Interface for destroy logic. Implemented by addDestroyable. */\nexport interface DestroyRef<T> {\n  /** Whether or not this object has been destroyed */\n  destroyed: boolean;\n  /** Destroy the instance and call all onDestroy callbacks. */\n  destroy(): void;\n  /** Register callbacks that should be called onDestroy */\n  onDestroy(cb: Function): void;\n}\n\n/**\n * Decorates an object with destroy logic (implementing the DestroyRef interface)\n * and returns the enhanced object.\n *\n * @param obj The object to decorate\n * @returns The object with destroy logic\n */\nexport function addDestroyable<T, C>(obj: any): T&DestroyRef<C> {\n  let destroyFn: Function[]|null = null;\n  obj.destroyed = false;\n  obj.destroy = function() {\n    destroyFn && destroyFn.forEach((fn) => fn());\n    this.destroyed = true;\n  };\n  obj.onDestroy = (fn: Function) => (destroyFn || (destroyFn = [])).push(fn);\n  return obj;\n}\n"]}
|