parent
4e585bca28
commit
857bef9e4f
|
@ -6,7 +6,7 @@ import {ListWrapper, Map} from 'angular2/src/facade/collection';
|
||||||
|
|
||||||
const _WHEN_DEFAULT = CONST_EXPR(new Object());
|
const _WHEN_DEFAULT = CONST_EXPR(new Object());
|
||||||
|
|
||||||
export class SwitchView {
|
class SwitchView {
|
||||||
constructor(private _viewContainerRef: ViewContainerRef, private _templateRef: TemplateRef) {}
|
constructor(private _viewContainerRef: ViewContainerRef, private _templateRef: TemplateRef) {}
|
||||||
|
|
||||||
create(): void { this._viewContainerRef.createEmbeddedView(this._templateRef); }
|
create(): void { this._viewContainerRef.createEmbeddedView(this._templateRef); }
|
||||||
|
@ -15,28 +15,59 @@ export class SwitchView {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The `NgSwitch` directive is used to conditionally swap DOM structure on your template based on a
|
* Adds or removes DOM sub-trees when their match expressions match the switch expression.
|
||||||
* scope expression.
|
*
|
||||||
* Elements within `NgSwitch` but without `NgSwitchWhen` or `NgSwitchDefault` directives will be
|
* Elements within `NgSwitch` but without `NgSwitchWhen` or `NgSwitchDefault` directives will be
|
||||||
* preserved at the location as specified in the template.
|
* preserved at the location as specified in the template.
|
||||||
*
|
*
|
||||||
* `NgSwitch` simply chooses nested elements and makes them visible based on which element matches
|
* `NgSwitch` simply inserts nested elements based on which match expression matches the value
|
||||||
* the value obtained from the evaluated expression. In other words, you define a container element
|
* obtained from the evaluated switch expression. In other words, you define a container element
|
||||||
* (where you place the directive), place an expression on the **`[ng-switch]="..."` attribute**),
|
* (where you place the directive with a switch expression on the
|
||||||
* define any inner elements inside of the directive and place a `[ng-switch-when]` attribute per
|
* **`[ng-switch]="..."` attribute**), define any inner elements inside of the directive and
|
||||||
* element.
|
* place a `[ng-switch-when]` attribute per element.
|
||||||
* The when attribute is used to inform NgSwitch which element to display when the expression is
|
|
||||||
* evaluated. If a matching expression is not found via a when attribute then an element with the
|
|
||||||
* default attribute is displayed.
|
|
||||||
*
|
*
|
||||||
* ### Example
|
* The `ng-switch-when` property is used to inform `NgSwitch` which element to display when the
|
||||||
|
* expression is evaluated. If a matching expression is not found via a `ng-switch-when` property
|
||||||
|
* then an element with the `ng-switch-default` attribute is displayed.
|
||||||
*
|
*
|
||||||
* ```
|
* ### Example ([live demo](http://plnkr.co/edit/DQMTII95CbuqWrl3lYAs?p=preview))
|
||||||
* <ANY [ng-switch]="expression">
|
*
|
||||||
* <template [ng-switch-when]="whenExpression1">...</template>
|
* ```typescript
|
||||||
* <template [ng-switch-when]="whenExpression1">...</template>
|
* @Component({selector: 'app'})
|
||||||
* <template ng-switch-default>...</template>
|
* @View({
|
||||||
* </ANY>
|
* template: `
|
||||||
|
* <p>Value = {{value}}</p>
|
||||||
|
* <button (click)="inc()">Increment</button>
|
||||||
|
*
|
||||||
|
* <div [ng-switch]="value">
|
||||||
|
* <p *ng-switch-when="'init'">increment to start</p>
|
||||||
|
* <p *ng-switch-when="0">0, increment again</p>
|
||||||
|
* <p *ng-switch-when="1">1, increment again</p>
|
||||||
|
* <p *ng-switch-when="2">2, stop incrementing</p>
|
||||||
|
* <p *ng-switch-default>> 2, STOP!</p>
|
||||||
|
* </div>
|
||||||
|
*
|
||||||
|
* <!-- alternate syntax -->
|
||||||
|
*
|
||||||
|
* <p [ng-switch]="value">
|
||||||
|
* <template ng-switch-when="init">increment to start</template>
|
||||||
|
* <template [ng-switch-when]="0">0, increment again</template>
|
||||||
|
* <template [ng-switch-when]="1">1, increment again</template>
|
||||||
|
* <template [ng-switch-when]="2">2, stop incrementing</template>
|
||||||
|
* <template ng-switch-default>> 2, STOP!</template>
|
||||||
|
* </p>
|
||||||
|
* `,
|
||||||
|
* directives: [NgSwitch, NgSwitchWhen, NgSwitchDefault]
|
||||||
|
* })
|
||||||
|
* export class App {
|
||||||
|
* value = 'init';
|
||||||
|
*
|
||||||
|
* inc() {
|
||||||
|
* this.value = this.value === 'init' ? 0 : this.value + 1;
|
||||||
|
* }
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* bootstrap(App).catch(err => console.error(err));
|
||||||
* ```
|
* ```
|
||||||
*/
|
*/
|
||||||
@Directive({selector: '[ng-switch]', inputs: ['ngSwitch']})
|
@Directive({selector: '[ng-switch]', inputs: ['ngSwitch']})
|
||||||
|
@ -130,19 +161,12 @@ export class NgSwitch {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defines a case statement as an expression.
|
* Insert the sub-tree when the `ng-switch-when` expression evaluates to the same value as the
|
||||||
|
* enclosing switch expression.
|
||||||
*
|
*
|
||||||
* If multiple `NgSwitchWhen` match the `NgSwitch` value, all of them are displayed.
|
* If multiple match expression match the switch expression value, all of them are displayed.
|
||||||
*
|
*
|
||||||
* Example:
|
* See {@link NgSwitch} for more details and example.
|
||||||
*
|
|
||||||
* ```
|
|
||||||
* // match against a context variable
|
|
||||||
* <template [ng-switch-when]="contextVariable">...</template>
|
|
||||||
*
|
|
||||||
* // match against a constant string
|
|
||||||
* <template ng-switch-when="stringValue">...</template>
|
|
||||||
* ```
|
|
||||||
*/
|
*/
|
||||||
@Directive({selector: '[ng-switch-when]', inputs: ['ngSwitchWhen']})
|
@Directive({selector: '[ng-switch-when]', inputs: ['ngSwitchWhen']})
|
||||||
export class NgSwitchWhen {
|
export class NgSwitchWhen {
|
||||||
|
@ -151,9 +175,11 @@ export class NgSwitchWhen {
|
||||||
_value: any = _WHEN_DEFAULT;
|
_value: any = _WHEN_DEFAULT;
|
||||||
/** @internal */
|
/** @internal */
|
||||||
_view: SwitchView;
|
_view: SwitchView;
|
||||||
|
private _switch: NgSwitch;
|
||||||
|
|
||||||
constructor(viewContainer: ViewContainerRef, templateRef: TemplateRef,
|
constructor(viewContainer: ViewContainerRef, templateRef: TemplateRef,
|
||||||
@Host() private _switch: NgSwitch) {
|
@Host() ngSwitch: NgSwitch) {
|
||||||
|
this._switch = ngSwitch;
|
||||||
this._view = new SwitchView(viewContainer, templateRef);
|
this._view = new SwitchView(viewContainer, templateRef);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -164,15 +190,10 @@ export class NgSwitchWhen {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defines a default case statement.
|
* Default case statements are displayed when no match expression matches the switch expression
|
||||||
|
* value.
|
||||||
*
|
*
|
||||||
* Default case statements are displayed when no `NgSwitchWhen` match the `ng-switch` value.
|
* See {@link NgSwitch} for more details and example.
|
||||||
*
|
|
||||||
* Example:
|
|
||||||
*
|
|
||||||
* ```
|
|
||||||
* <template ng-switch-default>...</template>
|
|
||||||
* ```
|
|
||||||
*/
|
*/
|
||||||
@Directive({selector: '[ng-switch-default]'})
|
@Directive({selector: '[ng-switch-default]'})
|
||||||
export class NgSwitchDefault {
|
export class NgSwitchDefault {
|
||||||
|
|
Loading…
Reference in New Issue