1 | /**
|
---|
2 | * @license
|
---|
3 | * Copyright Google LLC All Rights Reserved.
|
---|
4 | *
|
---|
5 | * Use of this source code is governed by an MIT-style license that can be
|
---|
6 | * found in the LICENSE file at https://angular.io/license
|
---|
7 | */
|
---|
8 | import { Directive, Input, TemplateRef, ViewContainerRef, ɵstringify as stringify } from '@angular/core';
|
---|
9 | /**
|
---|
10 | * A structural directive that conditionally includes a template based on the value of
|
---|
11 | * an expression coerced to Boolean.
|
---|
12 | * When the expression evaluates to true, Angular renders the template
|
---|
13 | * provided in a `then` clause, and when false or null,
|
---|
14 | * Angular renders the template provided in an optional `else` clause. The default
|
---|
15 | * template for the `else` clause is blank.
|
---|
16 | *
|
---|
17 | * A [shorthand form](guide/structural-directives#asterisk) of the directive,
|
---|
18 | * `*ngIf="condition"`, is generally used, provided
|
---|
19 | * as an attribute of the anchor element for the inserted template.
|
---|
20 | * Angular expands this into a more explicit version, in which the anchor element
|
---|
21 | * is contained in an `<ng-template>` element.
|
---|
22 | *
|
---|
23 | * Simple form with shorthand syntax:
|
---|
24 | *
|
---|
25 | * ```
|
---|
26 | * <div *ngIf="condition">Content to render when condition is true.</div>
|
---|
27 | * ```
|
---|
28 | *
|
---|
29 | * Simple form with expanded syntax:
|
---|
30 | *
|
---|
31 | * ```
|
---|
32 | * <ng-template [ngIf]="condition"><div>Content to render when condition is
|
---|
33 | * true.</div></ng-template>
|
---|
34 | * ```
|
---|
35 | *
|
---|
36 | * Form with an "else" block:
|
---|
37 | *
|
---|
38 | * ```
|
---|
39 | * <div *ngIf="condition; else elseBlock">Content to render when condition is true.</div>
|
---|
40 | * <ng-template #elseBlock>Content to render when condition is false.</ng-template>
|
---|
41 | * ```
|
---|
42 | *
|
---|
43 | * Shorthand form with "then" and "else" blocks:
|
---|
44 | *
|
---|
45 | * ```
|
---|
46 | * <div *ngIf="condition; then thenBlock else elseBlock"></div>
|
---|
47 | * <ng-template #thenBlock>Content to render when condition is true.</ng-template>
|
---|
48 | * <ng-template #elseBlock>Content to render when condition is false.</ng-template>
|
---|
49 | * ```
|
---|
50 | *
|
---|
51 | * Form with storing the value locally:
|
---|
52 | *
|
---|
53 | * ```
|
---|
54 | * <div *ngIf="condition as value; else elseBlock">{{value}}</div>
|
---|
55 | * <ng-template #elseBlock>Content to render when value is null.</ng-template>
|
---|
56 | * ```
|
---|
57 | *
|
---|
58 | * @usageNotes
|
---|
59 | *
|
---|
60 | * The `*ngIf` directive is most commonly used to conditionally show an inline template,
|
---|
61 | * as seen in the following example.
|
---|
62 | * The default `else` template is blank.
|
---|
63 | *
|
---|
64 | * {@example common/ngIf/ts/module.ts region='NgIfSimple'}
|
---|
65 | *
|
---|
66 | * ### Showing an alternative template using `else`
|
---|
67 | *
|
---|
68 | * To display a template when `expression` evaluates to false, use an `else` template
|
---|
69 | * binding as shown in the following example.
|
---|
70 | * The `else` binding points to an `<ng-template>` element labeled `#elseBlock`.
|
---|
71 | * The template can be defined anywhere in the component view, but is typically placed right after
|
---|
72 | * `ngIf` for readability.
|
---|
73 | *
|
---|
74 | * {@example common/ngIf/ts/module.ts region='NgIfElse'}
|
---|
75 | *
|
---|
76 | * ### Using an external `then` template
|
---|
77 | *
|
---|
78 | * In the previous example, the then-clause template is specified inline, as the content of the
|
---|
79 | * tag that contains the `ngIf` directive. You can also specify a template that is defined
|
---|
80 | * externally, by referencing a labeled `<ng-template>` element. When you do this, you can
|
---|
81 | * change which template to use at runtime, as shown in the following example.
|
---|
82 | *
|
---|
83 | * {@example common/ngIf/ts/module.ts region='NgIfThenElse'}
|
---|
84 | *
|
---|
85 | * ### Storing a conditional result in a variable
|
---|
86 | *
|
---|
87 | * You might want to show a set of properties from the same object. If you are waiting
|
---|
88 | * for asynchronous data, the object can be undefined.
|
---|
89 | * In this case, you can use `ngIf` and store the result of the condition in a local
|
---|
90 | * variable as shown in the following example.
|
---|
91 | *
|
---|
92 | * {@example common/ngIf/ts/module.ts region='NgIfAs'}
|
---|
93 | *
|
---|
94 | * This code uses only one `AsyncPipe`, so only one subscription is created.
|
---|
95 | * The conditional statement stores the result of `userStream|async` in the local variable `user`.
|
---|
96 | * You can then bind the local `user` repeatedly.
|
---|
97 | *
|
---|
98 | * The conditional displays the data only if `userStream` returns a value,
|
---|
99 | * so you don't need to use the
|
---|
100 | * safe-navigation-operator (`?.`)
|
---|
101 | * to guard against null values when accessing properties.
|
---|
102 | * You can display an alternative template while waiting for the data.
|
---|
103 | *
|
---|
104 | * ### Shorthand syntax
|
---|
105 | *
|
---|
106 | * The shorthand syntax `*ngIf` expands into two separate template specifications
|
---|
107 | * for the "then" and "else" clauses. For example, consider the following shorthand statement,
|
---|
108 | * that is meant to show a loading page while waiting for data to be loaded.
|
---|
109 | *
|
---|
110 | * ```
|
---|
111 | * <div class="hero-list" *ngIf="heroes else loading">
|
---|
112 | * ...
|
---|
113 | * </div>
|
---|
114 | *
|
---|
115 | * <ng-template #loading>
|
---|
116 | * <div>Loading...</div>
|
---|
117 | * </ng-template>
|
---|
118 | * ```
|
---|
119 | *
|
---|
120 | * You can see that the "else" clause references the `<ng-template>`
|
---|
121 | * with the `#loading` label, and the template for the "then" clause
|
---|
122 | * is provided as the content of the anchor element.
|
---|
123 | *
|
---|
124 | * However, when Angular expands the shorthand syntax, it creates
|
---|
125 | * another `<ng-template>` tag, with `ngIf` and `ngIfElse` directives.
|
---|
126 | * The anchor element containing the template for the "then" clause becomes
|
---|
127 | * the content of this unlabeled `<ng-template>` tag.
|
---|
128 | *
|
---|
129 | * ```
|
---|
130 | * <ng-template [ngIf]="heroes" [ngIfElse]="loading">
|
---|
131 | * <div class="hero-list">
|
---|
132 | * ...
|
---|
133 | * </div>
|
---|
134 | * </ng-template>
|
---|
135 | *
|
---|
136 | * <ng-template #loading>
|
---|
137 | * <div>Loading...</div>
|
---|
138 | * </ng-template>
|
---|
139 | * ```
|
---|
140 | *
|
---|
141 | * The presence of the implicit template object has implications for the nesting of
|
---|
142 | * structural directives. For more on this subject, see
|
---|
143 | * [Structural Directives](https://angular.io/guide/built-in-directives#one-per-element).
|
---|
144 | *
|
---|
145 | * @ngModule CommonModule
|
---|
146 | * @publicApi
|
---|
147 | */
|
---|
148 | export class NgIf {
|
---|
149 | constructor(_viewContainer, templateRef) {
|
---|
150 | this._viewContainer = _viewContainer;
|
---|
151 | this._context = new NgIfContext();
|
---|
152 | this._thenTemplateRef = null;
|
---|
153 | this._elseTemplateRef = null;
|
---|
154 | this._thenViewRef = null;
|
---|
155 | this._elseViewRef = null;
|
---|
156 | this._thenTemplateRef = templateRef;
|
---|
157 | }
|
---|
158 | /**
|
---|
159 | * The Boolean expression to evaluate as the condition for showing a template.
|
---|
160 | */
|
---|
161 | set ngIf(condition) {
|
---|
162 | this._context.$implicit = this._context.ngIf = condition;
|
---|
163 | this._updateView();
|
---|
164 | }
|
---|
165 | /**
|
---|
166 | * A template to show if the condition expression evaluates to true.
|
---|
167 | */
|
---|
168 | set ngIfThen(templateRef) {
|
---|
169 | assertTemplate('ngIfThen', templateRef);
|
---|
170 | this._thenTemplateRef = templateRef;
|
---|
171 | this._thenViewRef = null; // clear previous view if any.
|
---|
172 | this._updateView();
|
---|
173 | }
|
---|
174 | /**
|
---|
175 | * A template to show if the condition expression evaluates to false.
|
---|
176 | */
|
---|
177 | set ngIfElse(templateRef) {
|
---|
178 | assertTemplate('ngIfElse', templateRef);
|
---|
179 | this._elseTemplateRef = templateRef;
|
---|
180 | this._elseViewRef = null; // clear previous view if any.
|
---|
181 | this._updateView();
|
---|
182 | }
|
---|
183 | _updateView() {
|
---|
184 | if (this._context.$implicit) {
|
---|
185 | if (!this._thenViewRef) {
|
---|
186 | this._viewContainer.clear();
|
---|
187 | this._elseViewRef = null;
|
---|
188 | if (this._thenTemplateRef) {
|
---|
189 | this._thenViewRef =
|
---|
190 | this._viewContainer.createEmbeddedView(this._thenTemplateRef, this._context);
|
---|
191 | }
|
---|
192 | }
|
---|
193 | }
|
---|
194 | else {
|
---|
195 | if (!this._elseViewRef) {
|
---|
196 | this._viewContainer.clear();
|
---|
197 | this._thenViewRef = null;
|
---|
198 | if (this._elseTemplateRef) {
|
---|
199 | this._elseViewRef =
|
---|
200 | this._viewContainer.createEmbeddedView(this._elseTemplateRef, this._context);
|
---|
201 | }
|
---|
202 | }
|
---|
203 | }
|
---|
204 | }
|
---|
205 | /**
|
---|
206 | * Asserts the correct type of the context for the template that `NgIf` will render.
|
---|
207 | *
|
---|
208 | * The presence of this method is a signal to the Ivy template type-check compiler that the
|
---|
209 | * `NgIf` structural directive renders its template with a specific context type.
|
---|
210 | */
|
---|
211 | static ngTemplateContextGuard(dir, ctx) {
|
---|
212 | return true;
|
---|
213 | }
|
---|
214 | }
|
---|
215 | NgIf.decorators = [
|
---|
216 | { type: Directive, args: [{ selector: '[ngIf]' },] }
|
---|
217 | ];
|
---|
218 | NgIf.ctorParameters = () => [
|
---|
219 | { type: ViewContainerRef },
|
---|
220 | { type: TemplateRef }
|
---|
221 | ];
|
---|
222 | NgIf.propDecorators = {
|
---|
223 | ngIf: [{ type: Input }],
|
---|
224 | ngIfThen: [{ type: Input }],
|
---|
225 | ngIfElse: [{ type: Input }]
|
---|
226 | };
|
---|
227 | /**
|
---|
228 | * @publicApi
|
---|
229 | */
|
---|
230 | export class NgIfContext {
|
---|
231 | constructor() {
|
---|
232 | this.$implicit = null;
|
---|
233 | this.ngIf = null;
|
---|
234 | }
|
---|
235 | }
|
---|
236 | function assertTemplate(property, templateRef) {
|
---|
237 | const isTemplateRefOrNull = !!(!templateRef || templateRef.createEmbeddedView);
|
---|
238 | if (!isTemplateRefOrNull) {
|
---|
239 | throw new Error(`${property} must be a TemplateRef, but received '${stringify(templateRef)}'.`);
|
---|
240 | }
|
---|
241 | }
|
---|
242 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng_if.js","sourceRoot":"","sources":["../../../../../../../packages/common/src/directives/ng_if.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Directive, EmbeddedViewRef, Input, TemplateRef, ViewContainerRef, ɵstringify as stringify} from '@angular/core';\n\n\n/**\n * A structural directive that conditionally includes a template based on the value of\n * an expression coerced to Boolean.\n * When the expression evaluates to true, Angular renders the template\n * provided in a `then` clause, and when  false or null,\n * Angular renders the template provided in an optional `else` clause. The default\n * template for the `else` clause is blank.\n *\n * A [shorthand form](guide/structural-directives#asterisk) of the directive,\n * `*ngIf=\"condition\"`, is generally used, provided\n * as an attribute of the anchor element for the inserted template.\n * Angular expands this into a more explicit version, in which the anchor element\n * is contained in an `<ng-template>` element.\n *\n * Simple form with shorthand syntax:\n *\n * ```\n * <div *ngIf=\"condition\">Content to render when condition is true.</div>\n * ```\n *\n * Simple form with expanded syntax:\n *\n * ```\n * <ng-template [ngIf]=\"condition\"><div>Content to render when condition is\n * true.</div></ng-template>\n * ```\n *\n * Form with an \"else\" block:\n *\n * ```\n * <div *ngIf=\"condition; else elseBlock\">Content to render when condition is true.</div>\n * <ng-template #elseBlock>Content to render when condition is false.</ng-template>\n * ```\n *\n * Shorthand form with \"then\" and \"else\" blocks:\n *\n * ```\n * <div *ngIf=\"condition; then thenBlock else elseBlock\"></div>\n * <ng-template #thenBlock>Content to render when condition is true.</ng-template>\n * <ng-template #elseBlock>Content to render when condition is false.</ng-template>\n * ```\n *\n * Form with storing the value locally:\n *\n * ```\n * <div *ngIf=\"condition as value; else elseBlock\">{{value}}</div>\n * <ng-template #elseBlock>Content to render when value is null.</ng-template>\n * ```\n *\n * @usageNotes\n *\n * The `*ngIf` directive is most commonly used to conditionally show an inline template,\n * as seen in the following  example.\n * The default `else` template is blank.\n *\n * {@example common/ngIf/ts/module.ts region='NgIfSimple'}\n *\n * ### Showing an alternative template using `else`\n *\n * To display a template when `expression` evaluates to false, use an `else` template\n * binding as shown in the following example.\n * The `else` binding points to an `<ng-template>`  element labeled `#elseBlock`.\n * The template can be defined anywhere in the component view, but is typically placed right after\n * `ngIf` for readability.\n *\n * {@example common/ngIf/ts/module.ts region='NgIfElse'}\n *\n * ### Using an external `then` template\n *\n * In the previous example, the then-clause template is specified inline, as the content of the\n * tag that contains the `ngIf` directive. You can also specify a template that is defined\n * externally, by referencing a labeled `<ng-template>` element. When you do this, you can\n * change which template to use at runtime, as shown in the following example.\n *\n * {@example common/ngIf/ts/module.ts region='NgIfThenElse'}\n *\n * ### Storing a conditional result in a variable\n *\n * You might want to show a set of properties from the same object. If you are waiting\n * for asynchronous data, the object can be undefined.\n * In this case, you can use `ngIf` and store the result of the condition in a local\n * variable as shown in the following example.\n *\n * {@example common/ngIf/ts/module.ts region='NgIfAs'}\n *\n * This code uses only one `AsyncPipe`, so only one subscription is created.\n * The conditional statement stores the result of `userStream|async` in the local variable `user`.\n * You can then bind the local `user` repeatedly.\n *\n * The conditional displays the data only if `userStream` returns a value,\n * so you don't need to use the\n * safe-navigation-operator (`?.`)\n * to guard against null values when accessing properties.\n * You can display an alternative template while waiting for the data.\n *\n * ### Shorthand syntax\n *\n * The shorthand syntax `*ngIf` expands into two separate template specifications\n * for the \"then\" and \"else\" clauses. For example, consider the following shorthand statement,\n * that is meant to show a loading page while waiting for data to be loaded.\n *\n * ```\n * <div class=\"hero-list\" *ngIf=\"heroes else loading\">\n *  ...\n * </div>\n *\n * <ng-template #loading>\n *  <div>Loading...</div>\n * </ng-template>\n * ```\n *\n * You can see that the \"else\" clause references the `<ng-template>`\n * with the `#loading` label, and the template for the \"then\" clause\n * is provided as the content of the anchor element.\n *\n * However, when Angular expands the shorthand syntax, it creates\n * another `<ng-template>` tag, with `ngIf` and `ngIfElse` directives.\n * The anchor element containing the template for the \"then\" clause becomes\n * the content of this unlabeled `<ng-template>` tag.\n *\n * ```\n * <ng-template [ngIf]=\"heroes\" [ngIfElse]=\"loading\">\n *  <div class=\"hero-list\">\n *   ...\n *  </div>\n * </ng-template>\n *\n * <ng-template #loading>\n *  <div>Loading...</div>\n * </ng-template>\n * ```\n *\n * The presence of the implicit template object has implications for the nesting of\n * structural directives. For more on this subject, see\n * [Structural Directives](https://angular.io/guide/built-in-directives#one-per-element).\n *\n * @ngModule CommonModule\n * @publicApi\n */\n@Directive({selector: '[ngIf]'})\nexport class NgIf<T = unknown> {\n  private _context: NgIfContext<T> = new NgIfContext<T>();\n  private _thenTemplateRef: TemplateRef<NgIfContext<T>>|null = null;\n  private _elseTemplateRef: TemplateRef<NgIfContext<T>>|null = null;\n  private _thenViewRef: EmbeddedViewRef<NgIfContext<T>>|null = null;\n  private _elseViewRef: EmbeddedViewRef<NgIfContext<T>>|null = null;\n\n  constructor(private _viewContainer: ViewContainerRef, templateRef: TemplateRef<NgIfContext<T>>) {\n    this._thenTemplateRef = templateRef;\n  }\n\n  /**\n   * The Boolean expression to evaluate as the condition for showing a template.\n   */\n  @Input()\n  set ngIf(condition: T) {\n    this._context.$implicit = this._context.ngIf = condition;\n    this._updateView();\n  }\n\n  /**\n   * A template to show if the condition expression evaluates to true.\n   */\n  @Input()\n  set ngIfThen(templateRef: TemplateRef<NgIfContext<T>>|null) {\n    assertTemplate('ngIfThen', templateRef);\n    this._thenTemplateRef = templateRef;\n    this._thenViewRef = null;  // clear previous view if any.\n    this._updateView();\n  }\n\n  /**\n   * A template to show if the condition expression evaluates to false.\n   */\n  @Input()\n  set ngIfElse(templateRef: TemplateRef<NgIfContext<T>>|null) {\n    assertTemplate('ngIfElse', templateRef);\n    this._elseTemplateRef = templateRef;\n    this._elseViewRef = null;  // clear previous view if any.\n    this._updateView();\n  }\n\n  private _updateView() {\n    if (this._context.$implicit) {\n      if (!this._thenViewRef) {\n        this._viewContainer.clear();\n        this._elseViewRef = null;\n        if (this._thenTemplateRef) {\n          this._thenViewRef =\n              this._viewContainer.createEmbeddedView(this._thenTemplateRef, this._context);\n        }\n      }\n    } else {\n      if (!this._elseViewRef) {\n        this._viewContainer.clear();\n        this._thenViewRef = null;\n        if (this._elseTemplateRef) {\n          this._elseViewRef =\n              this._viewContainer.createEmbeddedView(this._elseTemplateRef, this._context);\n        }\n      }\n    }\n  }\n\n  /** @internal */\n  public static ngIfUseIfTypeGuard: void;\n\n  /**\n   * Assert the correct type of the expression bound to the `ngIf` input within the template.\n   *\n   * The presence of this static field is a signal to the Ivy template type check compiler that\n   * when the `NgIf` structural directive renders its template, the type of the expression bound\n   * to `ngIf` should be narrowed in some way. For `NgIf`, the binding expression itself is used to\n   * narrow its type, which allows the strictNullChecks feature of TypeScript to work with `NgIf`.\n   */\n  static ngTemplateGuard_ngIf: 'binding';\n\n  /**\n   * Asserts the correct type of the context for the template that `NgIf` will render.\n   *\n   * The presence of this method is a signal to the Ivy template type-check compiler that the\n   * `NgIf` structural directive renders its template with a specific context type.\n   */\n  static ngTemplateContextGuard<T>(dir: NgIf<T>, ctx: any):\n      ctx is NgIfContext<Exclude<T, false|0|''|null|undefined>> {\n    return true;\n  }\n}\n\n/**\n * @publicApi\n */\nexport class NgIfContext<T = unknown> {\n  public $implicit: T = null!;\n  public ngIf: T = null!;\n}\n\nfunction assertTemplate(property: string, templateRef: TemplateRef<any>|null): void {\n  const isTemplateRefOrNull = !!(!templateRef || templateRef.createEmbeddedView);\n  if (!isTemplateRefOrNull) {\n    throw new Error(`${property} must be a TemplateRef, but received '${stringify(templateRef)}'.`);\n  }\n}\n"]} |
---|