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 * - *
- * - * - * - * - *
- * `, - * 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!

- *
- * - * - * - *

- * - * - * - * - * - *

- * `, - * directives: [NgSwitch, NgSwitchCase, NgSwitchDefault] - * }) - * export class App { - * value = 'init'; - * - * inc() { - * this.value = this.value === 'init' ? 0 : this.value + 1; - * } - * } + * @howToUse * ``` + * + * ... + * ... + * ... + * + * + * + * + * + * ...

+ *
+ * ``` + * @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]'})