From 9cee8bcc83cc894f3f3479ffbc489b10bb795bce Mon Sep 17 00:00:00 2001
From: Victor Berchet
Date: Mon, 12 Sep 2016 10:20:33 -0700
Subject: [PATCH] docs(common): add directives docs
Closes #11581
---
.../common/src/directives/ng_class.ts | 67 +++-------
.../common/src/directives/ng_plural.ts | 76 +++++------
.../common/src/directives/ng_style.ts | 54 ++------
.../common/src/directives/ng_switch.ts | 120 ++++++++++--------
.../src/directives/ng_template_outlet.ts | 18 ++-
5 files changed, 143 insertions(+), 192 deletions(-)
diff --git a/modules/@angular/common/src/directives/ng_class.ts b/modules/@angular/common/src/directives/ng_class.ts
index 72c4270ed4..291059914e 100644
--- a/modules/@angular/common/src/directives/ng_class.ts
+++ b/modules/@angular/common/src/directives/ng_class.ts
@@ -11,65 +11,32 @@ import {CollectionChangeRecord, Directive, DoCheck, ElementRef, Input, IterableD
import {isListLikeIterable} from '../facade/collection';
import {isPresent} from '../facade/lang';
+
+
/**
- * The `NgClass` directive conditionally adds and removes CSS classes on an HTML element based on
- * an expression's evaluation result.
+ * @ngModule CommonModule
*
- * The result of an expression evaluation is interpreted differently depending on type of
- * the expression evaluation result:
- * - `string` - all the CSS classes listed in a string (space delimited) are added
- * - `Array` - all the CSS classes (Array elements) are added
- * - `Object` - each key corresponds to a CSS class name while values are interpreted as expressions
- * evaluating to `Boolean`. If a given expression evaluates to `true` a corresponding CSS class
- * is added - otherwise it is removed.
- *
- * While the `NgClass` directive can interpret expressions evaluating to `string`, `Array`
- * or `Object`, the `Object`-based version is the most often used and has an advantage of keeping
- * all the CSS class names in a template.
- *
- * ### Example ([live demo](http://plnkr.co/edit/a4YdtmWywhJ33uqfpPPn?p=preview)):
+ * @whatItDoes Adds and removes CSS classes on an HTML element.
*
+ * @howToUse
* ```
- * import {Component} from '@angular/core';
- * import {NgClass} from '@angular/common';
+ * ...
*
- * @Component({
- * selector: 'toggle-button',
- * inputs: ['isDisabled'],
- * template: `
- *
- * Click me!
- *
`,
- * styles: [`
- * .button {
- * width: 120px;
- * border: medium solid black;
- * }
+ * ...
*
- * .active {
- * background-color: red;
- * }
+ * ...
*
- * .disabled {
- * color: gray;
- * border: medium solid gray;
- * }
- * `],
- * directives: [NgClass]
- * })
- * class ToggleButton {
- * isOn = false;
- * isDisabled = false;
- *
- * toggle(newState) {
- * if (!this.isDisabled) {
- * this.isOn = newState;
- * }
- * }
- * }
+ * ...
* ```
*
+ * @description
+ *
+ * The CSS classes are updated as follow depending on the type of the expression evaluation:
+ * - `string` - the CSS classes listed in a string (space delimited) are added,
+ * - `Array` - the CSS classes (Array elements) are added,
+ * - `Object` - keys are CSS class names that get added when the expression given in the value
+ * evaluates to a truthy value, otherwise class are removed.
+ *
* @stable
*/
@Directive({selector: '[ngClass]'})
diff --git a/modules/@angular/common/src/directives/ng_plural.ts b/modules/@angular/common/src/directives/ng_plural.ts
index 2b6091cc7f..33dd2bca8c 100644
--- a/modules/@angular/common/src/directives/ng_plural.ts
+++ b/modules/@angular/common/src/directives/ng_plural.ts
@@ -14,48 +14,35 @@ import {SwitchView} from './ng_switch';
/**
- * `ngPlural` is an i18n directive that displays DOM sub-trees that match the switch expression
- * value, or failing that, DOM sub-trees that match the switch expression's pluralization category.
+ * @ngModule CommonModule
+ *
+ * @whatItDoes Adds / removes DOM sub-trees based on a numeric value. Tailored for pluralization.
+ *
+ * @howToUse
+ * ```
+ *
+ * there is nothing
+ * there is one
+ * there are a few
+ * there are exactly #
+ *
+ * ```
+ *
+ * @description
+ *
+ * Displays DOM sub-trees that match the switch expression value, or failing that, DOM sub-trees
+ * that match the switch expression's pluralization category.
*
* To use this directive you must provide a container element that sets the `[ngPlural]` attribute
- * to a
- * switch expression.
- * - Inner elements defined with an `[ngPluralCase]` attribute will display based on their
- * expression.
- * - If `[ngPluralCase]` is set to a value starting with `=`, it will only display if the value
- * matches the switch expression exactly.
- * - Otherwise, the view will be treated as a "category match", and will only display if exact
- * value matches aren't found and the value maps to its category for the defined locale.
+ * to a switch expression. Inner elements with a `[ngPluralCase]` will display based on their
+ * expression:
+ * - if `[ngPluralCase]` is set to a value starting with `=`, it will only display if the value
+ * matches the switch expression exactly,
+ * - otherwise, the view will be treated as a "category match", and will only display if exact
+ * value matches aren't found and the value maps to its category for the defined locale.
*
- * ```typescript
- * @Component({
- * selector: 'app',
- * // best practice is to define the locale at the application level
- * providers: [{provide: LOCALE_ID, useValue: 'en_US'}]
- * })
- * @View({
- * template: `
- *
Value = {{value}}
- *
+ * See http://cldr.unicode.org/index/cldr-spec/plural-rules
*
- *
- * there is nothing
- * there is one
- * there are a few
- * there is some number
- *
- * `,
- * directives: [NgPlural, NgPluralCase]
- * })
- * export class App {
- * value = 'init';
- *
- * inc() {
- * this.value = this.value === 'init' ? 0 : this.value + 1;
- * }
- * }
- *
- * ```
* @experimental
*/
@Directive({selector: '[ngPlural]'})
@@ -98,6 +85,19 @@ export class NgPlural {
}
/**
+ * @ngModule CommonModule
+ *
+ * @whatItDoes Creates a view that will be added/removed from the parent {@link NgPlural} when the
+ * given expression matches the plural expression according to CLDR rules.
+ *
+ * @howToUse
+ *
+ * ...
+ * ...
+ *
+ *
+ * See {@link NgPlural} for more details and example.
+ *
* @experimental
*/
@Directive({selector: '[ngPluralCase]'})
diff --git a/modules/@angular/common/src/directives/ng_style.ts b/modules/@angular/common/src/directives/ng_style.ts
index 93e3e62bbb..dcedef2f4f 100644
--- a/modules/@angular/common/src/directives/ng_style.ts
+++ b/modules/@angular/common/src/directives/ng_style.ts
@@ -9,56 +9,24 @@
import {Directive, DoCheck, ElementRef, Input, KeyValueChangeRecord, KeyValueDiffer, KeyValueDiffers, Renderer} from '@angular/core';
/**
- * The `NgStyle` directive changes styles based on a result of expression evaluation.
+ * @ngModule CommonModule
*
- * An expression assigned to the `ngStyle` property must evaluate to an object and the
- * corresponding element styles are updated based on changes to this object. Style names to update
- * are taken from the object's keys, and values - from the corresponding object's values.
- *
- * ### Syntax
- *
- * - ``
- * - ``
- * - `` - here the `styleExp` must evaluate to an object
- *
- * ### Example ([live demo](http://plnkr.co/edit/YamGS6GkUh9GqWNQhCyM?p=preview)):
+ * @whatItDoes Update an HTML element styles.
*
+ * @howToUse
* ```
- * import {Component} from '@angular/core';
- * import {NgStyle} from '@angular/common';
+ * ...
*
- * @Component({
- * selector: 'ngStyle-example',
- * template: `
- *
- * Change style of this text!
- *
+ * ...
*
- *
- *
- *
- *
- *
- * `,
- * directives: [NgStyle]
- * })
- * export class NgStyleExample {
- * style = 'normal';
- * weight = 'normal';
- * size = '20px';
- *
- * changeStyle($event: any) {
- * this.style = $event.target.checked ? 'italic' : 'normal';
- * }
- *
- * changeWeight($event: any) {
- * this.weight = $event.target.checked ? 'bold' : 'normal';
- * }
- * }
+ * ...
* ```
*
- * In this example the `font-style`, `font-size` and `font-weight` styles will be updated
- * based on the `style` property's value changes.
+ * @description
+ *
+ * The styles are updated according to the value of the expression evaluation:
+ * - keys are style names with an option `.` suffix (ie 'top.px', 'font-style.em'),
+ * - values are the values assigned to those properties (expressed in the given unit).
*
* @stable
*/
diff --git a/modules/@angular/common/src/directives/ng_switch.ts b/modules/@angular/common/src/directives/ng_switch.ts
index 5f76a482a3..0b6d66a239 100644
--- a/modules/@angular/common/src/directives/ng_switch.ts
+++ b/modules/@angular/common/src/directives/ng_switch.ts
@@ -22,58 +22,44 @@ export class SwitchView {
}
/**
- * Adds or removes DOM sub-trees when their match expressions match the switch expression.
+ * @ngModule CommonModule
*
- * Elements within `NgSwitch` but without `NgSwitchCase` or `NgSwitchDefault` directives will be
- * preserved at the location as specified in the template.
+ * @whatItDoes Adds / removes DOM sub-trees when the nest match expressions matches the switch
+ * expression.
*
- * `NgSwitch` simply inserts nested elements based on which match expression matches the value
- * obtained from the evaluated switch expression. In other words, you define a container element
- * (where you place the directive with a switch expression on the
- * `[ngSwitch]="..."` attribute), define any inner elements inside of the directive and
- * place a `[ngSwitchCase]` attribute per element.
- *
- * The `ngSwitchCase` property is used to inform `NgSwitch` which element to display when the
- * expression is evaluated. If a matching expression is not found via a `ngSwitchCase` property
- * then an element with the `ngSwitchDefault` attribute is displayed.
- *
- * ### Example ([live demo](http://plnkr.co/edit/DQMTII95CbuqWrl3lYAs?p=preview))
- *
- * ```typescript
- * @Component({
- * selector: 'app',
- * template: `
- *
Value = {{value}}
- *
- *
- *
- *
increment to start
- *
0, increment again
- *
1, increment again
- *
2, stop incrementing
- *
> 2, STOP!
- *
- *
- *
- *
- *
- * increment to start
- * 0, increment again
- * 1, increment again
- * 2, stop incrementing
- * > 2, STOP!
- *
+ *
+ * ```
+ * @description
+ *
+ * `NgSwitch` stamps out nested views when their match expression value matches the value of the
+ * switch expression.
+ *
+ * In other words:
+ * - you define a container element (where you place the directive with a switch expression on the
+ * `[ngSwitch]="..."` attribute)
+ * - you define inner views inside the `NgSwitch` and place a `*ngSwitchCase` attribute on the view
+ * root elements.
+ *
+ * Elements within `NgSwitch` but outside of a `NgSwitchCase` or `NgSwitchDefault` directives will
+ * be
+ * preserved at the location.
+ *
+ * The `ngSwitchCase` directive informs the parent `NgSwitch` of which view to display when the
+ * expression is evaluated.
+ * When no matching expression is found on a `ngSwitchCase` view, the `ngSwitchDefault` view is
+ * stamped out.
*
* @stable
*/
@@ -169,10 +155,23 @@ export class NgSwitch {
}
/**
- * Insert the sub-tree when the `ngSwitchCase` expression evaluates to the same value as the
- * enclosing switch expression.
+ * @ngModule CommonModule
*
- * If multiple match expression match the switch expression value, all of them are displayed.
+ * @whatItDoes Creates a view that will be added/removed from the parent {@link NgSwitch} when the
+ * given expression evaluate to respectively the same/different value as the switch
+ * expression.
+ *
+ * @howToUse
+ *
+ * ...
+ *
+ *
+ * @description
+ *
+ * Insert the sub-tree when the expression evaluates to the same value as the enclosing switch
+ * expression.
+ *
+ * If multiple match expressions match the switch expression value, all of them are displayed.
*
* See {@link NgSwitch} for more details and example.
*
@@ -202,8 +201,21 @@ export class NgSwitchCase {
}
/**
- * Default case statements are displayed when no match expression matches the switch expression
- * value.
+ * @ngModule CommonModule
+ * @whatItDoes Creates a view that is added to the parent {@link NgSwitch} when no case expressions
+ * match the
+ * switch expression.
+ *
+ * @howToUse
+ *
+ * ...
+ * ...
+ *
+ *
+ * @description
+ *
+ * Insert the sub-tree when no case expressions evaluate to the same value as the enclosing switch
+ * expression.
*
* See {@link NgSwitch} for more details and example.
*
diff --git a/modules/@angular/common/src/directives/ng_template_outlet.ts b/modules/@angular/common/src/directives/ng_template_outlet.ts
index 7a32e04da6..fe1a73cc12 100644
--- a/modules/@angular/common/src/directives/ng_template_outlet.ts
+++ b/modules/@angular/common/src/directives/ng_template_outlet.ts
@@ -9,21 +9,25 @@
import {Directive, EmbeddedViewRef, Input, OnChanges, TemplateRef, ViewContainerRef} from '@angular/core';
/**
- * Creates and inserts an embedded view based on a prepared `TemplateRef`.
- * You can attach a context object to the `EmbeddedViewRef` by setting `[ngOutletContext]`.
- * `[ngOutletContext]` should be an object, the object's keys will be the local template variables
- * available within the `TemplateRef`.
+ * @ngModule CommonModule
*
- * Note: using the key `$implicit` in the context object will set it's value as default.
- *
- * ### Syntax
+ * @whatItDoes Inserts an embedded view from a prepared `TemplateRef`
*
+ * @howToUse
* ```
*
*
* ```
*
+ * @description
+ *
+ * You can attach a context object to the `EmbeddedViewRef` by setting `[ngOutletContext]`.
+ * `[ngOutletContext]` should be an object, the object's keys will be the local template variables
+ * available within the `TemplateRef`.
+ *
+ * Note: using the key `$implicit` in the context object will set it's value as default.
+ *
* @experimental
*/
@Directive({selector: '[ngTemplateOutlet]'})