@angular/language-service 9.0.6 → 9.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.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v9.0.6
2
+ * @license Angular v9.0.7
3
3
  * Copyright Google Inc. All Rights Reserved.
4
4
  * License: MIT
5
5
  */
@@ -16770,12 +16770,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
16770
16770
  stylingBuilder.registerClassAttr(value);
16771
16771
  }
16772
16772
  else {
16773
- if (attr.i18n) {
16774
- i18nAttrs.push(attr);
16775
- }
16776
- else {
16777
- outputAttrs.push(attr);
16778
- }
16773
+ (attr.i18n ? i18nAttrs : outputAttrs).push(attr);
16779
16774
  }
16780
16775
  }
16781
16776
  }
@@ -17035,16 +17030,20 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
17035
17030
  this.templatePropertyBindings(templateIndex, template.templateAttrs);
17036
17031
  // Only add normal input/output binding instructions on explicit <ng-template> elements.
17037
17032
  if (template.tagName === NG_TEMPLATE_TAG_NAME) {
17033
+ var inputs_1 = [];
17034
+ var i18nAttrs_1 = template.attributes.filter(function (attr) { return !!attr.i18n; });
17035
+ template.inputs.forEach(function (input) { return (input.i18n ? i18nAttrs_1 : inputs_1).push(input); });
17038
17036
  // Add i18n attributes that may act as inputs to directives. If such attributes are present,
17039
17037
  // generate `i18nAttributes` instruction. Note: we generate it only for explicit <ng-template>
17040
17038
  // elements, in case of inline templates, corresponding instructions will be generated in the
17041
17039
  // nested template function.
17042
- var i18nAttrs = template.attributes.filter(function (attr) { return !!attr.i18n; });
17043
- if (i18nAttrs.length > 0) {
17044
- this.i18nAttributesInstruction(templateIndex, i18nAttrs, template.sourceSpan);
17040
+ if (i18nAttrs_1.length > 0) {
17041
+ this.i18nAttributesInstruction(templateIndex, i18nAttrs_1, template.sourceSpan);
17045
17042
  }
17046
17043
  // Add the input bindings
17047
- this.templatePropertyBindings(templateIndex, template.inputs);
17044
+ if (inputs_1.length > 0) {
17045
+ this.templatePropertyBindings(templateIndex, inputs_1);
17046
+ }
17048
17047
  // Generate listeners for directive output
17049
17048
  if (template.outputs.length > 0) {
17050
17049
  var listeners = template.outputs.map(function (outputAst) { return ({
@@ -17145,11 +17144,22 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
17145
17144
  var value_4 = input.value.visit(_this._valueConverter);
17146
17145
  if (value_4 !== undefined) {
17147
17146
  _this.allocateBindingSlots(value_4);
17148
- propertyBindings.push({
17149
- name: input.name,
17150
- sourceSpan: input.sourceSpan,
17151
- value: function () { return _this.convertPropertyBinding(value_4); }
17152
- });
17147
+ if (value_4 instanceof Interpolation) {
17148
+ // Params typically contain attribute namespace and value sanitizer, which is applicable
17149
+ // for regular HTML elements, but not applicable for <ng-template> (since props act as
17150
+ // inputs to directives), so keep params array empty.
17151
+ var params = [];
17152
+ // prop="{{value}}" case
17153
+ _this.interpolatedUpdateInstruction(getPropertyInterpolationExpression(value_4), templateIndex, input.name, input, value_4, params);
17154
+ }
17155
+ else {
17156
+ // [prop]="value" case
17157
+ propertyBindings.push({
17158
+ name: input.name,
17159
+ sourceSpan: input.sourceSpan,
17160
+ value: function () { return _this.convertPropertyBinding(value_4); }
17161
+ });
17162
+ }
17153
17163
  }
17154
17164
  }
17155
17165
  });
@@ -18886,7 +18896,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
18886
18896
  * Use of this source code is governed by an MIT-style license that can be
18887
18897
  * found in the LICENSE file at https://angular.io/license
18888
18898
  */
18889
- var VERSION$1 = new Version('9.0.6');
18899
+ var VERSION$1 = new Version('9.0.7');
18890
18900
 
18891
18901
  /**
18892
18902
  * @license
@@ -22452,9 +22462,9 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
22452
22462
  });
22453
22463
  }
22454
22464
  else {
22455
- // handle the symbols via export * directives.
22465
+ // Handle the symbols loaded by 'export *' directives.
22456
22466
  var resolvedModule = this_1.resolveModule(moduleExport.from, filePath);
22457
- if (resolvedModule) {
22467
+ if (resolvedModule && resolvedModule !== filePath) {
22458
22468
  var nestedExports = this_1.getSymbolsOf(resolvedModule);
22459
22469
  nestedExports.forEach(function (targetSymbol) {
22460
22470
  var sourceSymbol = _this.getStaticSymbol(filePath, targetSymbol.name);
@@ -25798,7 +25808,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
25798
25808
  */
25799
25809
  function refinedVariableType(value, mergedTable, query, templateElement) {
25800
25810
  if (value === '$implicit') {
25801
- // Special case the ngFor directive
25811
+ // Special case: ngFor directive
25802
25812
  var ngForDirective = templateElement.directives.find(function (d) {
25803
25813
  var name = identifierName(d.directive.type);
25804
25814
  return name == 'NgFor' || name == 'NgForOf';
@@ -25817,12 +25827,19 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
25817
25827
  }
25818
25828
  }
25819
25829
  }
25820
- // Special case the ngIf directive ( *ngIf="data$ | async as variable" )
25821
- if (value === 'ngIf') {
25830
+ if (value === 'ngIf' || value === '$implicit') {
25822
25831
  var ngIfDirective = templateElement.directives.find(function (d) { return identifierName(d.directive.type) === 'NgIf'; });
25823
25832
  if (ngIfDirective) {
25833
+ // Special case: ngIf directive. The NgIf structural directive owns a template context with
25834
+ // "$implicit" and "ngIf" members. These properties are typed as generics. Until the language
25835
+ // service uses an Ivy and TypecheckBlock backend, we cannot bind these values to a concrete
25836
+ // type without manual inference. To get the concrete type, look up the type of the "ngIf"
25837
+ // import on the NgIf directive bound to the template.
25838
+ //
25839
+ // See @angular/common/ng_if.ts for more information.
25824
25840
  var ngIfBinding = ngIfDirective.inputs.find(function (i) { return i.directiveName === 'ngIf'; });
25825
25841
  if (ngIfBinding) {
25842
+ // Check if there is a known type bound to the ngIf input.
25826
25843
  var bindingType = new AstType(mergedTable, query, {}).getType(ngIfBinding.value);
25827
25844
  if (bindingType) {
25828
25845
  return bindingType;
@@ -30677,6 +30694,8 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
30677
30694
  * Use of this source code is governed by an MIT-style license that can be
30678
30695
  * found in the LICENSE file at https://angular.io/license
30679
30696
  */
30697
+ // [Assert functions do not constraint type when they are guarded by a truthy
30698
+ // expression.](https://github.com/microsoft/TypeScript/issues/37295)
30680
30699
  function assertTNodeForLView(tNode, lView) {
30681
30700
  tNode.hasOwnProperty('tView_') && assertEqual(tNode.tView_, lView[TVIEW], 'This TNode does not belong to this LView.');
30682
30701
  }
@@ -30720,6 +30739,202 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
30720
30739
  var SVG_NAMESPACE = 'http://www.w3.org/2000/svg';
30721
30740
  var MATH_ML_NAMESPACE = 'http://www.w3.org/1998/MathML/';
30722
30741
 
30742
+ /**
30743
+ * @license
30744
+ * Copyright Google Inc. All Rights Reserved.
30745
+ *
30746
+ * Use of this source code is governed by an MIT-style license that can be
30747
+ * found in the LICENSE file at https://angular.io/license
30748
+ */
30749
+ /**
30750
+ * This property will be monkey-patched on elements, components and directives
30751
+ */
30752
+ var MONKEY_PATCH_KEY_NAME = '__ngContext__';
30753
+
30754
+ /**
30755
+ * @license
30756
+ * Copyright Google Inc. All Rights Reserved.
30757
+ *
30758
+ * Use of this source code is governed by an MIT-style license that can be
30759
+ * found in the LICENSE file at https://angular.io/license
30760
+ */
30761
+ /**
30762
+ * Most of the use of `document` in Angular is from within the DI system so it is possible to simply
30763
+ * inject the `DOCUMENT` token and are done.
30764
+ *
30765
+ * Ivy is special because it does not rely upon the DI and must get hold of the document some other
30766
+ * way.
30767
+ *
30768
+ * The solution is to define `getDocument()` and `setDocument()` top-level functions for ivy.
30769
+ * Wherever ivy needs the global document, it calls `getDocument()` instead.
30770
+ *
30771
+ * When running ivy outside of a browser environment, it is necessary to call `setDocument()` to
30772
+ * tell ivy what the global `document` is.
30773
+ *
30774
+ * Angular does this for us in each of the standard platforms (`Browser`, `Server`, and `WebWorker`)
30775
+ * by calling `setDocument()` when providing the `DOCUMENT` token.
30776
+ */
30777
+ var DOCUMENT = undefined;
30778
+ /**
30779
+ * Access the object that represents the `document` for this platform.
30780
+ *
30781
+ * Ivy calls this whenever it needs to access the `document` object.
30782
+ * For example to create the renderer or to do sanitization.
30783
+ */
30784
+ function getDocument() {
30785
+ if (DOCUMENT !== undefined) {
30786
+ return DOCUMENT;
30787
+ }
30788
+ else if (typeof document !== 'undefined') {
30789
+ return document;
30790
+ }
30791
+ // No "document" can be found. This should only happen if we are running ivy outside Angular and
30792
+ // the current platform is not a browser. Since this is not a supported scenario at the moment
30793
+ // this should not happen in Angular apps.
30794
+ // Once we support running ivy outside of Angular we will need to publish `setDocument()` as a
30795
+ // public API. Meanwhile we just return `undefined` and let the application fail.
30796
+ return undefined;
30797
+ }
30798
+
30799
+ /**
30800
+ * @license
30801
+ * Copyright Google Inc. All Rights Reserved.
30802
+ *
30803
+ * Use of this source code is governed by an MIT-style license that can be
30804
+ * found in the LICENSE file at https://angular.io/license
30805
+ */
30806
+ // TODO: cleanup once the code is merged in angular/angular
30807
+ var RendererStyleFlags3;
30808
+ (function (RendererStyleFlags3) {
30809
+ RendererStyleFlags3[RendererStyleFlags3["Important"] = 1] = "Important";
30810
+ RendererStyleFlags3[RendererStyleFlags3["DashCase"] = 2] = "DashCase";
30811
+ })(RendererStyleFlags3 || (RendererStyleFlags3 = {}));
30812
+ /** Returns whether the `renderer` is a `ProceduralRenderer3` */
30813
+ function isProceduralRenderer(renderer) {
30814
+ return !!(renderer.listen);
30815
+ }
30816
+ var ɵ0$2 = function (hostElement, rendererType) { return getDocument(); };
30817
+ var domRendererFactory3 = {
30818
+ createRenderer: ɵ0$2
30819
+ };
30820
+
30821
+ /**
30822
+ * @license
30823
+ * Copyright Google Inc. All Rights Reserved.
30824
+ *
30825
+ * Use of this source code is governed by an MIT-style license that can be
30826
+ * found in the LICENSE file at https://angular.io/license
30827
+ */
30828
+ /**
30829
+ * For efficiency reasons we often put several different data types (`RNode`, `LView`, `LContainer`)
30830
+ * in same location in `LView`. This is because we don't want to pre-allocate space for it
30831
+ * because the storage is sparse. This file contains utilities for dealing with such data types.
30832
+ *
30833
+ * How do we know what is stored at a given location in `LView`.
30834
+ * - `Array.isArray(value) === false` => `RNode` (The normal storage value)
30835
+ * - `Array.isArray(value) === true` => then the `value[0]` represents the wrapped value.
30836
+ * - `typeof value[TYPE] === 'object'` => `LView`
30837
+ * - This happens when we have a component at a given location
30838
+ * - `typeof value[TYPE] === true` => `LContainer`
30839
+ * - This happens when we have `LContainer` binding at a given location.
30840
+ *
30841
+ *
30842
+ * NOTE: it is assumed that `Array.isArray` and `typeof` operations are very efficient.
30843
+ */
30844
+ /**
30845
+ * Returns `RNode`.
30846
+ * @param value wrapped value of `RNode`, `LView`, `LContainer`
30847
+ */
30848
+ function unwrapRNode(value) {
30849
+ while (Array.isArray(value)) {
30850
+ value = value[HOST];
30851
+ }
30852
+ return value;
30853
+ }
30854
+ /**
30855
+ * Retrieve an `RNode` for a given `TNode` and `LView`.
30856
+ *
30857
+ * This function guarantees in dev mode to retrieve a non-null `RNode`.
30858
+ *
30859
+ * @param tNode
30860
+ * @param lView
30861
+ */
30862
+ function getNativeByTNode(tNode, lView) {
30863
+ ngDevMode && assertTNodeForLView(tNode, lView);
30864
+ ngDevMode && assertDataInRange(lView, tNode.index);
30865
+ var node = unwrapRNode(lView[tNode.index]);
30866
+ ngDevMode && !isProceduralRenderer(lView[RENDERER]) && assertDomNode(node);
30867
+ return node;
30868
+ }
30869
+ /**
30870
+ * Retrieve an `RNode` or `null` for a given `TNode` and `LView`.
30871
+ *
30872
+ * Some `TNode`s don't have associated `RNode`s. For example `Projection`
30873
+ *
30874
+ * @param tNode
30875
+ * @param lView
30876
+ */
30877
+ function getNativeByTNodeOrNull(tNode, lView) {
30878
+ var index = tNode.index;
30879
+ if (index !== -1) {
30880
+ ngDevMode && assertTNodeForLView(tNode, lView);
30881
+ var node = unwrapRNode(lView[index]);
30882
+ ngDevMode && node !== null && !isProceduralRenderer(lView[RENDERER]) && assertDomNode(node);
30883
+ return node;
30884
+ }
30885
+ return null;
30886
+ }
30887
+ function getTNode(tView, index) {
30888
+ ngDevMode && assertGreaterThan(index, -1, 'wrong index for TNode');
30889
+ ngDevMode && assertLessThan(index, tView.data.length, 'wrong index for TNode');
30890
+ return tView.data[index + HEADER_OFFSET];
30891
+ }
30892
+ function getComponentLViewByIndex(nodeIndex, hostView) {
30893
+ // Could be an LView or an LContainer. If LContainer, unwrap to find LView.
30894
+ ngDevMode && assertDataInRange(hostView, nodeIndex);
30895
+ var slotValue = hostView[nodeIndex];
30896
+ var lView = isLView(slotValue) ? slotValue : slotValue[HOST];
30897
+ return lView;
30898
+ }
30899
+ /**
30900
+ * Returns the monkey-patch value data present on the target (which could be
30901
+ * a component, directive or a DOM node).
30902
+ */
30903
+ function readPatchedData(target) {
30904
+ ngDevMode && assertDefined(target, 'Target expected');
30905
+ return target[MONKEY_PATCH_KEY_NAME] || null;
30906
+ }
30907
+ function readPatchedLView(target) {
30908
+ var value = readPatchedData(target);
30909
+ if (value) {
30910
+ return Array.isArray(value) ? value : value.lView;
30911
+ }
30912
+ return null;
30913
+ }
30914
+ /** Checks whether a given view is in creation mode */
30915
+ function isCreationMode(view) {
30916
+ return (view[FLAGS] & 4 /* CreationMode */) === 4 /* CreationMode */;
30917
+ }
30918
+ /**
30919
+ * Returns a boolean for whether the view is attached to the change detection tree.
30920
+ *
30921
+ * Note: This determines whether a view should be checked, not whether it's inserted
30922
+ * into a container. For that, you'll want `viewAttachedToContainer` below.
30923
+ */
30924
+ function viewAttachedToChangeDetector(view) {
30925
+ return (view[FLAGS] & 128 /* Attached */) === 128 /* Attached */;
30926
+ }
30927
+ /**
30928
+ * Resets the pre-order hook flags of the view.
30929
+ * @param lView the LView on which the flags are reset
30930
+ */
30931
+ function resetPreOrderHookFlags(lView) {
30932
+ lView[PREORDER_HOOK_FLAGS] = 0;
30933
+ }
30934
+ function getLContainerActiveIndex(lContainer) {
30935
+ return lContainer[ACTIVE_INDEX] >> 1 /* SHIFT */;
30936
+ }
30937
+
30723
30938
  /**
30724
30939
  * @license
30725
30940
  * Copyright Google Inc. All Rights Reserved.
@@ -31301,73 +31516,6 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
31301
31516
  return '<unknown>';
31302
31517
  }
31303
31518
 
31304
- /**
31305
- * @license
31306
- * Copyright Google Inc. All Rights Reserved.
31307
- *
31308
- * Use of this source code is governed by an MIT-style license that can be
31309
- * found in the LICENSE file at https://angular.io/license
31310
- */
31311
- /**
31312
- * Most of the use of `document` in Angular is from within the DI system so it is possible to simply
31313
- * inject the `DOCUMENT` token and are done.
31314
- *
31315
- * Ivy is special because it does not rely upon the DI and must get hold of the document some other
31316
- * way.
31317
- *
31318
- * The solution is to define `getDocument()` and `setDocument()` top-level functions for ivy.
31319
- * Wherever ivy needs the global document, it calls `getDocument()` instead.
31320
- *
31321
- * When running ivy outside of a browser environment, it is necessary to call `setDocument()` to
31322
- * tell ivy what the global `document` is.
31323
- *
31324
- * Angular does this for us in each of the standard platforms (`Browser`, `Server`, and `WebWorker`)
31325
- * by calling `setDocument()` when providing the `DOCUMENT` token.
31326
- */
31327
- var DOCUMENT = undefined;
31328
- /**
31329
- * Access the object that represents the `document` for this platform.
31330
- *
31331
- * Ivy calls this whenever it needs to access the `document` object.
31332
- * For example to create the renderer or to do sanitization.
31333
- */
31334
- function getDocument() {
31335
- if (DOCUMENT !== undefined) {
31336
- return DOCUMENT;
31337
- }
31338
- else if (typeof document !== 'undefined') {
31339
- return document;
31340
- }
31341
- // No "document" can be found. This should only happen if we are running ivy outside Angular and
31342
- // the current platform is not a browser. Since this is not a supported scenario at the moment
31343
- // this should not happen in Angular apps.
31344
- // Once we support running ivy outside of Angular we will need to publish `setDocument()` as a
31345
- // public API. Meanwhile we just return `undefined` and let the application fail.
31346
- return undefined;
31347
- }
31348
-
31349
- /**
31350
- * @license
31351
- * Copyright Google Inc. All Rights Reserved.
31352
- *
31353
- * Use of this source code is governed by an MIT-style license that can be
31354
- * found in the LICENSE file at https://angular.io/license
31355
- */
31356
- // TODO: cleanup once the code is merged in angular/angular
31357
- var RendererStyleFlags3;
31358
- (function (RendererStyleFlags3) {
31359
- RendererStyleFlags3[RendererStyleFlags3["Important"] = 1] = "Important";
31360
- RendererStyleFlags3[RendererStyleFlags3["DashCase"] = 2] = "DashCase";
31361
- })(RendererStyleFlags3 || (RendererStyleFlags3 = {}));
31362
- /** Returns whether the `renderer` is a `ProceduralRenderer3` */
31363
- function isProceduralRenderer(renderer) {
31364
- return !!(renderer.listen);
31365
- }
31366
- var ɵ0$2 = function (hostElement, rendererType) { return getDocument(); };
31367
- var domRendererFactory3 = {
31368
- createRenderer: ɵ0$2
31369
- };
31370
-
31371
31519
  /**
31372
31520
  * Assigns all attribute values to the provided element via the inferred renderer.
31373
31521
  *
@@ -32430,135 +32578,6 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
32430
32578
  }
32431
32579
  }
32432
32580
 
32433
- /**
32434
- * @license
32435
- * Copyright Google Inc. All Rights Reserved.
32436
- *
32437
- * Use of this source code is governed by an MIT-style license that can be
32438
- * found in the LICENSE file at https://angular.io/license
32439
- */
32440
- /**
32441
- * This property will be monkey-patched on elements, components and directives
32442
- */
32443
- var MONKEY_PATCH_KEY_NAME = '__ngContext__';
32444
-
32445
- /**
32446
- * @license
32447
- * Copyright Google Inc. All Rights Reserved.
32448
- *
32449
- * Use of this source code is governed by an MIT-style license that can be
32450
- * found in the LICENSE file at https://angular.io/license
32451
- */
32452
- /**
32453
- * For efficiency reasons we often put several different data types (`RNode`, `LView`, `LContainer`)
32454
- * in same location in `LView`. This is because we don't want to pre-allocate space for it
32455
- * because the storage is sparse. This file contains utilities for dealing with such data types.
32456
- *
32457
- * How do we know what is stored at a given location in `LView`.
32458
- * - `Array.isArray(value) === false` => `RNode` (The normal storage value)
32459
- * - `Array.isArray(value) === true` => then the `value[0]` represents the wrapped value.
32460
- * - `typeof value[TYPE] === 'object'` => `LView`
32461
- * - This happens when we have a component at a given location
32462
- * - `typeof value[TYPE] === true` => `LContainer`
32463
- * - This happens when we have `LContainer` binding at a given location.
32464
- *
32465
- *
32466
- * NOTE: it is assumed that `Array.isArray` and `typeof` operations are very efficient.
32467
- */
32468
- /**
32469
- * Returns `RNode`.
32470
- * @param value wrapped value of `RNode`, `LView`, `LContainer`
32471
- */
32472
- function unwrapRNode(value) {
32473
- while (Array.isArray(value)) {
32474
- value = value[HOST];
32475
- }
32476
- return value;
32477
- }
32478
- /**
32479
- * Retrieve an `RNode` for a given `TNode` and `LView`.
32480
- *
32481
- * This function guarantees in dev mode to retrieve a non-null `RNode`.
32482
- *
32483
- * @param tNode
32484
- * @param lView
32485
- */
32486
- function getNativeByTNode(tNode, lView) {
32487
- ngDevMode && assertTNodeForLView(tNode, lView);
32488
- ngDevMode && assertDataInRange(lView, tNode.index);
32489
- var node = unwrapRNode(lView[tNode.index]);
32490
- ngDevMode && !isProceduralRenderer(lView[RENDERER]) && assertDomNode(node);
32491
- return node;
32492
- }
32493
- /**
32494
- * Retrieve an `RNode` or `null` for a given `TNode` and `LView`.
32495
- *
32496
- * Some `TNode`s don't have associated `RNode`s. For example `Projection`
32497
- *
32498
- * @param tNode
32499
- * @param lView
32500
- */
32501
- function getNativeByTNodeOrNull(tNode, lView) {
32502
- var index = tNode.index;
32503
- if (index !== -1) {
32504
- ngDevMode && assertTNodeForLView(tNode, lView);
32505
- var node = unwrapRNode(lView[index]);
32506
- ngDevMode && node !== null && !isProceduralRenderer(lView[RENDERER]) && assertDomNode(node);
32507
- return node;
32508
- }
32509
- return null;
32510
- }
32511
- function getTNode(tView, index) {
32512
- ngDevMode && assertGreaterThan(index, -1, 'wrong index for TNode');
32513
- ngDevMode && assertLessThan(index, tView.data.length, 'wrong index for TNode');
32514
- return tView.data[index + HEADER_OFFSET];
32515
- }
32516
- function getComponentLViewByIndex(nodeIndex, hostView) {
32517
- // Could be an LView or an LContainer. If LContainer, unwrap to find LView.
32518
- ngDevMode && assertDataInRange(hostView, nodeIndex);
32519
- var slotValue = hostView[nodeIndex];
32520
- var lView = isLView(slotValue) ? slotValue : slotValue[HOST];
32521
- return lView;
32522
- }
32523
- /**
32524
- * Returns the monkey-patch value data present on the target (which could be
32525
- * a component, directive or a DOM node).
32526
- */
32527
- function readPatchedData(target) {
32528
- ngDevMode && assertDefined(target, 'Target expected');
32529
- return target[MONKEY_PATCH_KEY_NAME] || null;
32530
- }
32531
- function readPatchedLView(target) {
32532
- var value = readPatchedData(target);
32533
- if (value) {
32534
- return Array.isArray(value) ? value : value.lView;
32535
- }
32536
- return null;
32537
- }
32538
- /** Checks whether a given view is in creation mode */
32539
- function isCreationMode(view) {
32540
- return (view[FLAGS] & 4 /* CreationMode */) === 4 /* CreationMode */;
32541
- }
32542
- /**
32543
- * Returns a boolean for whether the view is attached to the change detection tree.
32544
- *
32545
- * Note: This determines whether a view should be checked, not whether it's inserted
32546
- * into a container. For that, you'll want `viewAttachedToContainer` below.
32547
- */
32548
- function viewAttachedToChangeDetector(view) {
32549
- return (view[FLAGS] & 128 /* Attached */) === 128 /* Attached */;
32550
- }
32551
- /**
32552
- * Resets the pre-order hook flags of the view.
32553
- * @param lView the LView on which the flags are reset
32554
- */
32555
- function resetPreOrderHookFlags(lView) {
32556
- lView[PREORDER_HOOK_FLAGS] = 0;
32557
- }
32558
- function getLContainerActiveIndex(lContainer) {
32559
- return lContainer[ACTIVE_INDEX] >> 1 /* SHIFT */;
32560
- }
32561
-
32562
32581
  /**
32563
32582
  * @license
32564
32583
  * Copyright Google Inc. All Rights Reserved.
@@ -38786,7 +38805,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
38786
38805
  /**
38787
38806
  * @publicApi
38788
38807
  */
38789
- var VERSION$2 = new Version$1('9.0.6');
38808
+ var VERSION$2 = new Version$1('9.0.7');
38790
38809
 
38791
38810
  /**
38792
38811
  * @license
@@ -50796,7 +50815,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
50796
50815
  * Use of this source code is governed by an MIT-style license that can be
50797
50816
  * found in the LICENSE file at https://angular.io/license
50798
50817
  */
50799
- var VERSION$3 = new Version$1('9.0.6');
50818
+ var VERSION$3 = new Version$1('9.0.7');
50800
50819
 
50801
50820
  exports.TypeScriptServiceHost = TypeScriptServiceHost;
50802
50821
  exports.VERSION = VERSION$3;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@angular/language-service",
3
- "version": "9.0.6",
3
+ "version": "9.0.7",
4
4
  "description": "Angular - language services",
5
5
  "main": "./bundles/language-service.umd.js",
6
6
  "module": "./fesm5/language-service.js",
@@ -178,7 +178,7 @@
178
178
  */
179
179
  function refinedVariableType(value, mergedTable, query, templateElement) {
180
180
  if (value === '$implicit') {
181
- // Special case the ngFor directive
181
+ // Special case: ngFor directive
182
182
  var ngForDirective = templateElement.directives.find(function (d) {
183
183
  var name = compiler_1.identifierName(d.directive.type);
184
184
  return name == 'NgFor' || name == 'NgForOf';
@@ -197,12 +197,19 @@
197
197
  }
198
198
  }
199
199
  }
200
- // Special case the ngIf directive ( *ngIf="data$ | async as variable" )
201
- if (value === 'ngIf') {
200
+ if (value === 'ngIf' || value === '$implicit') {
202
201
  var ngIfDirective = templateElement.directives.find(function (d) { return compiler_1.identifierName(d.directive.type) === 'NgIf'; });
203
202
  if (ngIfDirective) {
203
+ // Special case: ngIf directive. The NgIf structural directive owns a template context with
204
+ // "$implicit" and "ngIf" members. These properties are typed as generics. Until the language
205
+ // service uses an Ivy and TypecheckBlock backend, we cannot bind these values to a concrete
206
+ // type without manual inference. To get the concrete type, look up the type of the "ngIf"
207
+ // import on the NgIf directive bound to the template.
208
+ //
209
+ // See @angular/common/ng_if.ts for more information.
204
210
  var ngIfBinding = ngIfDirective.inputs.find(function (i) { return i.directiveName === 'ngIf'; });
205
211
  if (ngIfBinding) {
212
+ // Check if there is a known type bound to the ngIf input.
206
213
  var bindingType = new expression_type_1.AstType(mergedTable, query, {}).getType(ngIfBinding.value);
207
214
  if (bindingType) {
208
215
  return bindingType;
@@ -383,4 +390,4 @@
383
390
  return { start: sourceSpan.start.offset, end: sourceSpan.end.offset };
384
391
  }
385
392
  });
386
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expression_diagnostics.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/expression_diagnostics.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 {AST, AstPath, Attribute, BoundDirectivePropertyAst, BoundElementPropertyAst, BoundEventAst, BoundTextAst, CompileDirectiveSummary, CompileTypeMetadata, DirectiveAst, ElementAst, EmbeddedTemplateAst, Node, ParseSourceSpan, RecursiveTemplateAstVisitor, ReferenceAst, TemplateAst, TemplateAstPath, VariableAst, identifierName, templateVisitAll, tokenReference} from '@angular/compiler';\n\nimport {Diagnostic, createDiagnostic} from './diagnostic_messages';\nimport {AstType} from './expression_type';\nimport {BuiltinType, Definition, Span, Symbol, SymbolDeclaration, SymbolQuery, SymbolTable} from './symbols';\nimport * as ng from './types';\nimport {findOutputBinding, getPathToNodeAtPosition} from './utils';\n\nexport interface DiagnosticTemplateInfo {\n  fileName?: string;\n  offset: number;\n  query: SymbolQuery;\n  members: SymbolTable;\n  htmlAst: Node[];\n  templateAst: TemplateAst[];\n}\n\nexport function getTemplateExpressionDiagnostics(info: DiagnosticTemplateInfo): ng.Diagnostic[] {\n  const visitor = new ExpressionDiagnosticsVisitor(\n      info, (path: TemplateAstPath) => getExpressionScope(info, path));\n  templateVisitAll(visitor, info.templateAst);\n  return visitor.diagnostics;\n}\n\nfunction getReferences(info: DiagnosticTemplateInfo): SymbolDeclaration[] {\n  const result: SymbolDeclaration[] = [];\n\n  function processReferences(references: ReferenceAst[]) {\n    for (const reference of references) {\n      let type: Symbol|undefined = undefined;\n      if (reference.value) {\n        type = info.query.getTypeSymbol(tokenReference(reference.value));\n      }\n      result.push({\n        name: reference.name,\n        kind: 'reference',\n        type: type || info.query.getBuiltinType(BuiltinType.Any),\n        get definition() { return getDefinitionOf(info, reference); }\n      });\n    }\n  }\n\n  const visitor = new class extends RecursiveTemplateAstVisitor {\n    visitEmbeddedTemplate(ast: EmbeddedTemplateAst, context: any): any {\n      super.visitEmbeddedTemplate(ast, context);\n      processReferences(ast.references);\n    }\n    visitElement(ast: ElementAst, context: any): any {\n      super.visitElement(ast, context);\n      processReferences(ast.references);\n    }\n  };\n\n  templateVisitAll(visitor, info.templateAst);\n\n  return result;\n}\n\nfunction getDefinitionOf(info: DiagnosticTemplateInfo, ast: TemplateAst): Definition|undefined {\n  if (info.fileName) {\n    const templateOffset = info.offset;\n    return [{\n      fileName: info.fileName,\n      span: {\n        start: ast.sourceSpan.start.offset + templateOffset,\n        end: ast.sourceSpan.end.offset + templateOffset\n      }\n    }];\n  }\n}\n\n/**\n * Resolve all variable declarations in a template by traversing the specified\n * `path`.\n * @param info\n * @param path template AST path\n */\nfunction getVarDeclarations(\n    info: DiagnosticTemplateInfo, path: TemplateAstPath): SymbolDeclaration[] {\n  const results: SymbolDeclaration[] = [];\n  for (let current = path.head; current; current = path.childOf(current)) {\n    if (!(current instanceof EmbeddedTemplateAst)) {\n      continue;\n    }\n    for (const variable of current.variables) {\n      let symbol = getVariableTypeFromDirectiveContext(variable.value, info.query, current);\n\n      const kind = info.query.getTypeKind(symbol);\n      if (kind === BuiltinType.Any || kind === BuiltinType.Unbound) {\n        // For special cases such as ngFor and ngIf, the any type is not very useful.\n        // We can do better by resolving the binding value.\n        const symbolsInScope = info.query.mergeSymbolTable([\n          info.members,\n          // Since we are traversing the AST path from head to tail, any variables\n          // that have been declared so far are also in scope.\n          info.query.createSymbolTable(results),\n        ]);\n        symbol = refinedVariableType(variable.value, symbolsInScope, info.query, current);\n      }\n      results.push({\n        name: variable.name,\n        kind: 'variable',\n        type: symbol, get definition() { return getDefinitionOf(info, variable); },\n      });\n    }\n  }\n  return results;\n}\n\n/**\n * Resolve the type for the variable in `templateElement` by finding the structural\n * directive which has the context member. Returns any when not found.\n * @param value variable value name\n * @param query type symbol query\n * @param templateElement\n */\nfunction getVariableTypeFromDirectiveContext(\n    value: string, query: SymbolQuery, templateElement: EmbeddedTemplateAst): Symbol {\n  for (const {directive} of templateElement.directives) {\n    const context = query.getTemplateContext(directive.type.reference);\n    if (context) {\n      const member = context.get(value);\n      if (member && member.type) {\n        return member.type;\n      }\n    }\n  }\n  return query.getBuiltinType(BuiltinType.Any);\n}\n\n/**\n * Resolve a more specific type for the variable in `templateElement` by inspecting\n * all variables that are in scope in the `mergedTable`. This function is a special\n * case for `ngFor` and `ngIf`. If resolution fails, return the `any` type.\n * @param value variable value name\n * @param mergedTable symbol table for all variables in scope\n * @param query\n * @param templateElement\n */\nfunction refinedVariableType(\n    value: string, mergedTable: SymbolTable, query: SymbolQuery,\n    templateElement: EmbeddedTemplateAst): Symbol {\n  if (value === '$implicit') {\n    // Special case the ngFor directive\n    const ngForDirective = templateElement.directives.find(d => {\n      const name = identifierName(d.directive.type);\n      return name == 'NgFor' || name == 'NgForOf';\n    });\n    if (ngForDirective) {\n      const ngForOfBinding = ngForDirective.inputs.find(i => i.directiveName == 'ngForOf');\n      if (ngForOfBinding) {\n        // Check if there is a known type for the ngFor binding.\n        const bindingType = new AstType(mergedTable, query, {}).getType(ngForOfBinding.value);\n        if (bindingType) {\n          const result = query.getElementType(bindingType);\n          if (result) {\n            return result;\n          }\n        }\n      }\n    }\n  }\n\n  // Special case the ngIf directive ( *ngIf=\"data$ | async as variable\" )\n  if (value === 'ngIf') {\n    const ngIfDirective =\n        templateElement.directives.find(d => identifierName(d.directive.type) === 'NgIf');\n    if (ngIfDirective) {\n      const ngIfBinding = ngIfDirective.inputs.find(i => i.directiveName === 'ngIf');\n      if (ngIfBinding) {\n        const bindingType = new AstType(mergedTable, query, {}).getType(ngIfBinding.value);\n        if (bindingType) {\n          return bindingType;\n        }\n      }\n    }\n  }\n\n  // We can't do better, return any\n  return query.getBuiltinType(BuiltinType.Any);\n}\n\nfunction getEventDeclaration(\n    info: DiagnosticTemplateInfo, path: TemplateAstPath): SymbolDeclaration|undefined {\n  const event = path.tail;\n  if (!(event instanceof BoundEventAst)) {\n    // No event available in this context.\n    return;\n  }\n\n  const genericEvent: SymbolDeclaration = {\n    name: '$event',\n    kind: 'variable',\n    type: info.query.getBuiltinType(BuiltinType.Any),\n  };\n\n  const outputSymbol = findOutputBinding(event, path, info.query);\n  if (!outputSymbol) {\n    // The `$event` variable doesn't belong to an output, so its type can't be refined.\n    // TODO: type `$event` variables in bindings to DOM events.\n    return genericEvent;\n  }\n\n  // The raw event type is wrapped in a generic, like EventEmitter<T> or Observable<T>.\n  const ta = outputSymbol.typeArguments();\n  if (!ta || ta.length !== 1) return genericEvent;\n  const eventType = ta[0];\n\n  return {...genericEvent, type: eventType};\n}\n\n/**\n * Returns the symbols available in a particular scope of a template.\n * @param info parsed template information\n * @param path path of template nodes narrowing to the context the expression scope should be\n * derived for.\n */\nexport function getExpressionScope(\n    info: DiagnosticTemplateInfo, path: TemplateAstPath): SymbolTable {\n  let result = info.members;\n  const references = getReferences(info);\n  const variables = getVarDeclarations(info, path);\n  const event = getEventDeclaration(info, path);\n  if (references.length || variables.length || event) {\n    const referenceTable = info.query.createSymbolTable(references);\n    const variableTable = info.query.createSymbolTable(variables);\n    const eventsTable = info.query.createSymbolTable(event ? [event] : []);\n    result = info.query.mergeSymbolTable([result, referenceTable, variableTable, eventsTable]);\n  }\n  return result;\n}\n\nclass ExpressionDiagnosticsVisitor extends RecursiveTemplateAstVisitor {\n  private path: TemplateAstPath;\n  private directiveSummary: CompileDirectiveSummary|undefined;\n\n  diagnostics: ng.Diagnostic[] = [];\n\n  constructor(\n      private info: DiagnosticTemplateInfo,\n      private getExpressionScope: (path: TemplateAstPath, includeEvent: boolean) => SymbolTable) {\n    super();\n    this.path = new AstPath<TemplateAst>([]);\n  }\n\n  visitDirective(ast: DirectiveAst, context: any): any {\n    // Override the default child visitor to ignore the host properties of a directive.\n    if (ast.inputs && ast.inputs.length) {\n      templateVisitAll(this, ast.inputs, context);\n    }\n  }\n\n  visitBoundText(ast: BoundTextAst): void {\n    this.push(ast);\n    this.diagnoseExpression(ast.value, ast.sourceSpan.start.offset, false);\n    this.pop();\n  }\n\n  visitDirectiveProperty(ast: BoundDirectivePropertyAst): void {\n    this.push(ast);\n    this.diagnoseExpression(ast.value, this.attributeValueLocation(ast), false);\n    this.pop();\n  }\n\n  visitElementProperty(ast: BoundElementPropertyAst): void {\n    this.push(ast);\n    this.diagnoseExpression(ast.value, this.attributeValueLocation(ast), false);\n    this.pop();\n  }\n\n  visitEvent(ast: BoundEventAst): void {\n    this.push(ast);\n    this.diagnoseExpression(ast.handler, this.attributeValueLocation(ast), true);\n    this.pop();\n  }\n\n  visitVariable(ast: VariableAst): void {\n    const directive = this.directiveSummary;\n    if (directive && ast.value) {\n      const context = this.info.query.getTemplateContext(directive.type.reference) !;\n      if (context && !context.has(ast.value)) {\n        const missingMember =\n            ast.value === '$implicit' ? 'an implicit value' : `a member called '${ast.value}'`;\n\n        const span = this.absSpan(spanOf(ast.sourceSpan));\n        this.diagnostics.push(createDiagnostic(\n            span, Diagnostic.template_context_missing_member, directive.type.reference.name,\n            missingMember));\n      }\n    }\n  }\n\n  visitElement(ast: ElementAst, context: any): void {\n    this.push(ast);\n    super.visitElement(ast, context);\n    this.pop();\n  }\n\n  visitEmbeddedTemplate(ast: EmbeddedTemplateAst, context: any): any {\n    const previousDirectiveSummary = this.directiveSummary;\n\n    this.push(ast);\n\n    // Find directive that references this template\n    this.directiveSummary =\n        ast.directives.map(d => d.directive).find(d => hasTemplateReference(d.type)) !;\n\n    // Process children\n    super.visitEmbeddedTemplate(ast, context);\n\n    this.pop();\n\n    this.directiveSummary = previousDirectiveSummary;\n  }\n\n  private attributeValueLocation(ast: TemplateAst) {\n    const path = getPathToNodeAtPosition(this.info.htmlAst, ast.sourceSpan.start.offset);\n    const last = path.tail;\n    if (last instanceof Attribute && last.valueSpan) {\n      return last.valueSpan.start.offset;\n    }\n    return ast.sourceSpan.start.offset;\n  }\n\n  private diagnoseExpression(ast: AST, offset: number, event: boolean) {\n    const scope = this.getExpressionScope(this.path, event);\n    const analyzer = new AstType(scope, this.info.query, {event});\n    for (const diagnostic of analyzer.getDiagnostics(ast)) {\n      diagnostic.span = this.absSpan(diagnostic.span, offset);\n      this.diagnostics.push(diagnostic);\n    }\n  }\n\n  private push(ast: TemplateAst) { this.path.push(ast); }\n\n  private pop() { this.path.pop(); }\n\n  private absSpan(span: Span, additionalOffset: number = 0): Span {\n    return {\n      start: span.start + this.info.offset + additionalOffset,\n      end: span.end + this.info.offset + additionalOffset,\n    };\n  }\n}\n\nfunction hasTemplateReference(type: CompileTypeMetadata): boolean {\n  if (type.diDeps) {\n    for (let diDep of type.diDeps) {\n      if (diDep.token && diDep.token.identifier &&\n          identifierName(diDep.token !.identifier !) == 'TemplateRef')\n        return true;\n    }\n  }\n  return false;\n}\n\nfunction spanOf(sourceSpan: ParseSourceSpan): Span {\n  return {start: sourceSpan.start.offset, end: sourceSpan.end.offset};\n}\n"]}
393
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expression_diagnostics.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/expression_diagnostics.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 {AST, AstPath, Attribute, BoundDirectivePropertyAst, BoundElementPropertyAst, BoundEventAst, BoundTextAst, CompileDirectiveSummary, CompileTypeMetadata, DirectiveAst, ElementAst, EmbeddedTemplateAst, Node, ParseSourceSpan, RecursiveTemplateAstVisitor, ReferenceAst, TemplateAst, TemplateAstPath, VariableAst, identifierName, templateVisitAll, tokenReference} from '@angular/compiler';\n\nimport {Diagnostic, createDiagnostic} from './diagnostic_messages';\nimport {AstType} from './expression_type';\nimport {BuiltinType, Definition, Span, Symbol, SymbolDeclaration, SymbolQuery, SymbolTable} from './symbols';\nimport * as ng from './types';\nimport {findOutputBinding, getPathToNodeAtPosition} from './utils';\n\nexport interface DiagnosticTemplateInfo {\n  fileName?: string;\n  offset: number;\n  query: SymbolQuery;\n  members: SymbolTable;\n  htmlAst: Node[];\n  templateAst: TemplateAst[];\n}\n\nexport function getTemplateExpressionDiagnostics(info: DiagnosticTemplateInfo): ng.Diagnostic[] {\n  const visitor = new ExpressionDiagnosticsVisitor(\n      info, (path: TemplateAstPath) => getExpressionScope(info, path));\n  templateVisitAll(visitor, info.templateAst);\n  return visitor.diagnostics;\n}\n\nfunction getReferences(info: DiagnosticTemplateInfo): SymbolDeclaration[] {\n  const result: SymbolDeclaration[] = [];\n\n  function processReferences(references: ReferenceAst[]) {\n    for (const reference of references) {\n      let type: Symbol|undefined = undefined;\n      if (reference.value) {\n        type = info.query.getTypeSymbol(tokenReference(reference.value));\n      }\n      result.push({\n        name: reference.name,\n        kind: 'reference',\n        type: type || info.query.getBuiltinType(BuiltinType.Any),\n        get definition() { return getDefinitionOf(info, reference); }\n      });\n    }\n  }\n\n  const visitor = new class extends RecursiveTemplateAstVisitor {\n    visitEmbeddedTemplate(ast: EmbeddedTemplateAst, context: any): any {\n      super.visitEmbeddedTemplate(ast, context);\n      processReferences(ast.references);\n    }\n    visitElement(ast: ElementAst, context: any): any {\n      super.visitElement(ast, context);\n      processReferences(ast.references);\n    }\n  };\n\n  templateVisitAll(visitor, info.templateAst);\n\n  return result;\n}\n\nfunction getDefinitionOf(info: DiagnosticTemplateInfo, ast: TemplateAst): Definition|undefined {\n  if (info.fileName) {\n    const templateOffset = info.offset;\n    return [{\n      fileName: info.fileName,\n      span: {\n        start: ast.sourceSpan.start.offset + templateOffset,\n        end: ast.sourceSpan.end.offset + templateOffset\n      }\n    }];\n  }\n}\n\n/**\n * Resolve all variable declarations in a template by traversing the specified\n * `path`.\n * @param info\n * @param path template AST path\n */\nfunction getVarDeclarations(\n    info: DiagnosticTemplateInfo, path: TemplateAstPath): SymbolDeclaration[] {\n  const results: SymbolDeclaration[] = [];\n  for (let current = path.head; current; current = path.childOf(current)) {\n    if (!(current instanceof EmbeddedTemplateAst)) {\n      continue;\n    }\n    for (const variable of current.variables) {\n      let symbol = getVariableTypeFromDirectiveContext(variable.value, info.query, current);\n\n      const kind = info.query.getTypeKind(symbol);\n      if (kind === BuiltinType.Any || kind === BuiltinType.Unbound) {\n        // For special cases such as ngFor and ngIf, the any type is not very useful.\n        // We can do better by resolving the binding value.\n        const symbolsInScope = info.query.mergeSymbolTable([\n          info.members,\n          // Since we are traversing the AST path from head to tail, any variables\n          // that have been declared so far are also in scope.\n          info.query.createSymbolTable(results),\n        ]);\n        symbol = refinedVariableType(variable.value, symbolsInScope, info.query, current);\n      }\n      results.push({\n        name: variable.name,\n        kind: 'variable',\n        type: symbol, get definition() { return getDefinitionOf(info, variable); },\n      });\n    }\n  }\n  return results;\n}\n\n/**\n * Resolve the type for the variable in `templateElement` by finding the structural\n * directive which has the context member. Returns any when not found.\n * @param value variable value name\n * @param query type symbol query\n * @param templateElement\n */\nfunction getVariableTypeFromDirectiveContext(\n    value: string, query: SymbolQuery, templateElement: EmbeddedTemplateAst): Symbol {\n  for (const {directive} of templateElement.directives) {\n    const context = query.getTemplateContext(directive.type.reference);\n    if (context) {\n      const member = context.get(value);\n      if (member && member.type) {\n        return member.type;\n      }\n    }\n  }\n\n  return query.getBuiltinType(BuiltinType.Any);\n}\n\n/**\n * Resolve a more specific type for the variable in `templateElement` by inspecting\n * all variables that are in scope in the `mergedTable`. This function is a special\n * case for `ngFor` and `ngIf`. If resolution fails, return the `any` type.\n * @param value variable value name\n * @param mergedTable symbol table for all variables in scope\n * @param query\n * @param templateElement\n */\nfunction refinedVariableType(\n    value: string, mergedTable: SymbolTable, query: SymbolQuery,\n    templateElement: EmbeddedTemplateAst): Symbol {\n  if (value === '$implicit') {\n    // Special case: ngFor directive\n    const ngForDirective = templateElement.directives.find(d => {\n      const name = identifierName(d.directive.type);\n      return name == 'NgFor' || name == 'NgForOf';\n    });\n    if (ngForDirective) {\n      const ngForOfBinding = ngForDirective.inputs.find(i => i.directiveName == 'ngForOf');\n      if (ngForOfBinding) {\n        // Check if there is a known type for the ngFor binding.\n        const bindingType = new AstType(mergedTable, query, {}).getType(ngForOfBinding.value);\n        if (bindingType) {\n          const result = query.getElementType(bindingType);\n          if (result) {\n            return result;\n          }\n        }\n      }\n    }\n  }\n\n  if (value === 'ngIf' || value === '$implicit') {\n    const ngIfDirective =\n        templateElement.directives.find(d => identifierName(d.directive.type) === 'NgIf');\n    if (ngIfDirective) {\n      // Special case: ngIf directive. The NgIf structural directive owns a template context with\n      // \"$implicit\" and \"ngIf\" members. These properties are typed as generics. Until the language\n      // service uses an Ivy and TypecheckBlock backend, we cannot bind these values to a concrete\n      // type without manual inference. To get the concrete type, look up the type of the \"ngIf\"\n      // import on the NgIf directive bound to the template.\n      //\n      // See @angular/common/ng_if.ts for more information.\n      const ngIfBinding = ngIfDirective.inputs.find(i => i.directiveName === 'ngIf');\n      if (ngIfBinding) {\n        // Check if there is a known type bound to the ngIf input.\n        const bindingType = new AstType(mergedTable, query, {}).getType(ngIfBinding.value);\n        if (bindingType) {\n          return bindingType;\n        }\n      }\n    }\n  }\n\n  // We can't do better, return any\n  return query.getBuiltinType(BuiltinType.Any);\n}\n\nfunction getEventDeclaration(\n    info: DiagnosticTemplateInfo, path: TemplateAstPath): SymbolDeclaration|undefined {\n  const event = path.tail;\n  if (!(event instanceof BoundEventAst)) {\n    // No event available in this context.\n    return;\n  }\n\n  const genericEvent: SymbolDeclaration = {\n    name: '$event',\n    kind: 'variable',\n    type: info.query.getBuiltinType(BuiltinType.Any),\n  };\n\n  const outputSymbol = findOutputBinding(event, path, info.query);\n  if (!outputSymbol) {\n    // The `$event` variable doesn't belong to an output, so its type can't be refined.\n    // TODO: type `$event` variables in bindings to DOM events.\n    return genericEvent;\n  }\n\n  // The raw event type is wrapped in a generic, like EventEmitter<T> or Observable<T>.\n  const ta = outputSymbol.typeArguments();\n  if (!ta || ta.length !== 1) return genericEvent;\n  const eventType = ta[0];\n\n  return {...genericEvent, type: eventType};\n}\n\n/**\n * Returns the symbols available in a particular scope of a template.\n * @param info parsed template information\n * @param path path of template nodes narrowing to the context the expression scope should be\n * derived for.\n */\nexport function getExpressionScope(\n    info: DiagnosticTemplateInfo, path: TemplateAstPath): SymbolTable {\n  let result = info.members;\n  const references = getReferences(info);\n  const variables = getVarDeclarations(info, path);\n  const event = getEventDeclaration(info, path);\n  if (references.length || variables.length || event) {\n    const referenceTable = info.query.createSymbolTable(references);\n    const variableTable = info.query.createSymbolTable(variables);\n    const eventsTable = info.query.createSymbolTable(event ? [event] : []);\n    result = info.query.mergeSymbolTable([result, referenceTable, variableTable, eventsTable]);\n  }\n  return result;\n}\n\nclass ExpressionDiagnosticsVisitor extends RecursiveTemplateAstVisitor {\n  private path: TemplateAstPath;\n  private directiveSummary: CompileDirectiveSummary|undefined;\n\n  diagnostics: ng.Diagnostic[] = [];\n\n  constructor(\n      private info: DiagnosticTemplateInfo,\n      private getExpressionScope: (path: TemplateAstPath, includeEvent: boolean) => SymbolTable) {\n    super();\n    this.path = new AstPath<TemplateAst>([]);\n  }\n\n  visitDirective(ast: DirectiveAst, context: any): any {\n    // Override the default child visitor to ignore the host properties of a directive.\n    if (ast.inputs && ast.inputs.length) {\n      templateVisitAll(this, ast.inputs, context);\n    }\n  }\n\n  visitBoundText(ast: BoundTextAst): void {\n    this.push(ast);\n    this.diagnoseExpression(ast.value, ast.sourceSpan.start.offset, false);\n    this.pop();\n  }\n\n  visitDirectiveProperty(ast: BoundDirectivePropertyAst): void {\n    this.push(ast);\n    this.diagnoseExpression(ast.value, this.attributeValueLocation(ast), false);\n    this.pop();\n  }\n\n  visitElementProperty(ast: BoundElementPropertyAst): void {\n    this.push(ast);\n    this.diagnoseExpression(ast.value, this.attributeValueLocation(ast), false);\n    this.pop();\n  }\n\n  visitEvent(ast: BoundEventAst): void {\n    this.push(ast);\n    this.diagnoseExpression(ast.handler, this.attributeValueLocation(ast), true);\n    this.pop();\n  }\n\n  visitVariable(ast: VariableAst): void {\n    const directive = this.directiveSummary;\n    if (directive && ast.value) {\n      const context = this.info.query.getTemplateContext(directive.type.reference) !;\n      if (context && !context.has(ast.value)) {\n        const missingMember =\n            ast.value === '$implicit' ? 'an implicit value' : `a member called '${ast.value}'`;\n\n        const span = this.absSpan(spanOf(ast.sourceSpan));\n        this.diagnostics.push(createDiagnostic(\n            span, Diagnostic.template_context_missing_member, directive.type.reference.name,\n            missingMember));\n      }\n    }\n  }\n\n  visitElement(ast: ElementAst, context: any): void {\n    this.push(ast);\n    super.visitElement(ast, context);\n    this.pop();\n  }\n\n  visitEmbeddedTemplate(ast: EmbeddedTemplateAst, context: any): any {\n    const previousDirectiveSummary = this.directiveSummary;\n\n    this.push(ast);\n\n    // Find directive that references this template\n    this.directiveSummary =\n        ast.directives.map(d => d.directive).find(d => hasTemplateReference(d.type)) !;\n\n    // Process children\n    super.visitEmbeddedTemplate(ast, context);\n\n    this.pop();\n\n    this.directiveSummary = previousDirectiveSummary;\n  }\n\n  private attributeValueLocation(ast: TemplateAst) {\n    const path = getPathToNodeAtPosition(this.info.htmlAst, ast.sourceSpan.start.offset);\n    const last = path.tail;\n    if (last instanceof Attribute && last.valueSpan) {\n      return last.valueSpan.start.offset;\n    }\n    return ast.sourceSpan.start.offset;\n  }\n\n  private diagnoseExpression(ast: AST, offset: number, event: boolean) {\n    const scope = this.getExpressionScope(this.path, event);\n    const analyzer = new AstType(scope, this.info.query, {event});\n    for (const diagnostic of analyzer.getDiagnostics(ast)) {\n      diagnostic.span = this.absSpan(diagnostic.span, offset);\n      this.diagnostics.push(diagnostic);\n    }\n  }\n\n  private push(ast: TemplateAst) { this.path.push(ast); }\n\n  private pop() { this.path.pop(); }\n\n  private absSpan(span: Span, additionalOffset: number = 0): Span {\n    return {\n      start: span.start + this.info.offset + additionalOffset,\n      end: span.end + this.info.offset + additionalOffset,\n    };\n  }\n}\n\nfunction hasTemplateReference(type: CompileTypeMetadata): boolean {\n  if (type.diDeps) {\n    for (let diDep of type.diDeps) {\n      if (diDep.token && diDep.token.identifier &&\n          identifierName(diDep.token !.identifier !) == 'TemplateRef')\n        return true;\n    }\n  }\n  return false;\n}\n\nfunction spanOf(sourceSpan: ParseSourceSpan): Span {\n  return {start: sourceSpan.start.offset, end: sourceSpan.end.offset};\n}\n"]}
package/src/version.js CHANGED
@@ -22,6 +22,6 @@
22
22
  * Entry point for all public APIs of the common package.
23
23
  */
24
24
  var core_1 = require("@angular/core");
25
- exports.VERSION = new core_1.Version('9.0.6');
25
+ exports.VERSION = new core_1.Version('9.0.7');
26
26
  });
27
27
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xhbmd1YWdlLXNlcnZpY2Uvc3JjL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HOzs7Ozs7Ozs7Ozs7SUFFSDs7OztPQUlHO0lBRUgsc0NBQXNDO0lBRXpCLFFBQUEsT0FBTyxHQUFHLElBQUksY0FBTyxDQUFDLG1CQUFtQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbi8qKlxuICogQG1vZHVsZVxuICogQGRlc2NyaXB0aW9uXG4gKiBFbnRyeSBwb2ludCBmb3IgYWxsIHB1YmxpYyBBUElzIG9mIHRoZSBjb21tb24gcGFja2FnZS5cbiAqL1xuXG5pbXBvcnQge1ZlcnNpb259IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IG5ldyBWZXJzaW9uKCcwLjAuMC1QTEFDRUhPTERFUicpO1xuIl19