2015-09-25 14:48:17 -07:00
|
|
|
import {CONST, Type} from 'angular2/src/core/facade/lang';
|
2015-07-24 15:28:44 -07:00
|
|
|
|
2015-10-05 10:10:07 -07:00
|
|
|
/**
|
|
|
|
* Defines template and style encapsulation options available for Component's {@link View}.
|
|
|
|
*
|
|
|
|
* See {@link ViewMetadata#encapsulation}.
|
|
|
|
*/
|
|
|
|
export enum ViewEncapsulation {
|
|
|
|
/**
|
|
|
|
* Emulate `Native` scoping of styles by adding an attribute containing surrogate id to the Host
|
|
|
|
* Element and pre-processing the style rules provided via
|
|
|
|
* {@link ViewMetadata#styles} or {@link ViewMetadata#stylesUrls}, and adding the new Host Element
|
|
|
|
* attribute to all selectors.
|
|
|
|
*
|
|
|
|
* This is the default option.
|
|
|
|
*/
|
|
|
|
Emulated,
|
|
|
|
/**
|
|
|
|
* Use the native encapsulation mechanism of the renderer.
|
|
|
|
*
|
|
|
|
* For the DOM this means using [Shadow DOM](https://w3c.github.io/webcomponents/spec/shadow/) and
|
|
|
|
* creating a ShadowRoot for Component's Host Element.
|
|
|
|
*/
|
|
|
|
Native,
|
|
|
|
/**
|
|
|
|
* Don't provide any template or style encapsulation.
|
|
|
|
*/
|
|
|
|
None
|
|
|
|
}
|
|
|
|
|
|
|
|
export var VIEW_ENCAPSULATION_VALUES =
|
|
|
|
[ViewEncapsulation.Emulated, ViewEncapsulation.Native, ViewEncapsulation.None];
|
|
|
|
|
2014-09-19 16:38:37 -07:00
|
|
|
|
2015-03-17 19:22:13 +00:00
|
|
|
/**
|
2015-09-28 19:58:38 -07:00
|
|
|
* Metadata properties available for configuring Views.
|
2015-03-30 17:19:27 -07:00
|
|
|
*
|
2015-09-13 15:01:58 +02:00
|
|
|
* Each Angular component requires a single `@Component` and at least one `@View` annotation. The
|
2015-06-01 21:36:06 -07:00
|
|
|
* `@View` annotation specifies the HTML template to use, and lists the directives that are active
|
|
|
|
* within the template.
|
2015-03-30 17:19:27 -07:00
|
|
|
*
|
2015-05-20 09:48:15 -07:00
|
|
|
* When a component is instantiated, the template is loaded into the component's shadow root, and
|
2015-06-01 21:36:06 -07:00
|
|
|
* the expressions and statements in the template are evaluated against the component.
|
2015-03-30 17:19:27 -07:00
|
|
|
*
|
2015-08-14 10:03:45 -07:00
|
|
|
* For details on the `@Component` annotation, see {@link ComponentMetadata}.
|
2015-03-30 17:19:27 -07:00
|
|
|
*
|
|
|
|
* ## Example
|
|
|
|
*
|
|
|
|
* ```
|
|
|
|
* @Component({
|
2015-10-11 07:41:19 -07:00
|
|
|
* selector: 'greet',
|
2015-04-10 11:15:01 -07:00
|
|
|
* template: 'Hello {{name}}!',
|
|
|
|
* directives: [GreetUser, Bold]
|
2015-03-30 17:19:27 -07:00
|
|
|
* })
|
|
|
|
* class Greet {
|
|
|
|
* name: string;
|
|
|
|
*
|
|
|
|
* constructor() {
|
|
|
|
* this.name = 'World';
|
|
|
|
* }
|
|
|
|
* }
|
|
|
|
* ```
|
2015-03-17 19:22:13 +00:00
|
|
|
*/
|
2015-05-20 09:48:15 -07:00
|
|
|
@CONST()
|
2015-08-14 10:03:45 -07:00
|
|
|
export class ViewMetadata {
|
2015-07-07 22:09:19 +02:00
|
|
|
/**
|
2015-09-13 15:01:58 +02:00
|
|
|
* Specifies a template URL for an Angular component.
|
2015-07-07 22:09:19 +02:00
|
|
|
*
|
2015-09-28 19:58:38 -07:00
|
|
|
* NOTE: Only one of `templateUrl` or `template` can be defined per View.
|
|
|
|
*
|
|
|
|
* <!-- TODO: what's the url relative to? -->
|
2015-07-07 22:09:19 +02:00
|
|
|
*/
|
2015-07-06 16:32:29 -07:00
|
|
|
templateUrl: string;
|
|
|
|
|
2015-04-15 22:35:38 +00:00
|
|
|
/**
|
2015-09-13 15:01:58 +02:00
|
|
|
* Specifies an inline template for an Angular component.
|
2015-04-15 22:35:38 +00:00
|
|
|
*
|
2015-09-28 19:58:38 -07:00
|
|
|
* NOTE: Only one of `templateUrl` or `template` can be defined per View.
|
2015-04-15 22:35:38 +00:00
|
|
|
*/
|
2015-07-07 22:09:19 +02:00
|
|
|
template: string;
|
2015-04-15 22:35:38 +00:00
|
|
|
|
|
|
|
/**
|
2015-09-13 15:01:58 +02:00
|
|
|
* Specifies stylesheet URLs for an Angular component.
|
2015-09-28 19:58:38 -07:00
|
|
|
*
|
|
|
|
* <!-- TODO: what's the url relative to? -->
|
2015-04-15 22:35:38 +00:00
|
|
|
*/
|
2015-08-28 11:29:19 -07:00
|
|
|
styleUrls: string[];
|
2015-07-07 22:09:19 +02:00
|
|
|
|
|
|
|
/**
|
2015-09-13 15:01:58 +02:00
|
|
|
* Specifies an inline stylesheet for an Angular component.
|
2015-07-07 22:09:19 +02:00
|
|
|
*/
|
2015-08-28 11:29:19 -07:00
|
|
|
styles: string[];
|
2015-06-10 14:40:24 +02:00
|
|
|
|
2015-04-15 22:35:38 +00:00
|
|
|
/**
|
2015-04-17 13:01:07 -07:00
|
|
|
* Specifies a list of directives that can be used within a template.
|
2015-04-15 22:35:38 +00:00
|
|
|
*
|
|
|
|
* Directives must be listed explicitly to provide proper component encapsulation.
|
|
|
|
*
|
|
|
|
* ## Example
|
|
|
|
*
|
|
|
|
* ```javascript
|
|
|
|
* @Component({
|
2015-10-11 07:41:19 -07:00
|
|
|
* selector: 'my-component',
|
2015-09-13 15:01:58 +02:00
|
|
|
* directives: [NgFor]
|
2015-04-15 22:35:38 +00:00
|
|
|
* template: '
|
|
|
|
* <ul>
|
2015-05-13 11:30:59 +02:00
|
|
|
* <li *ng-for="#item of items">{{item}}</li>
|
2015-04-15 22:35:38 +00:00
|
|
|
* </ul>'
|
|
|
|
* })
|
|
|
|
* class MyComponent {
|
|
|
|
* }
|
|
|
|
* ```
|
|
|
|
*/
|
2015-10-08 09:57:10 -07:00
|
|
|
directives: Array<Type | any[]>;
|
2015-04-15 22:35:38 +00:00
|
|
|
|
2015-09-18 10:33:23 -07:00
|
|
|
pipes: Array<Type | any[]>;
|
2015-08-07 11:41:38 -07:00
|
|
|
|
2015-04-20 11:34:53 -07:00
|
|
|
/**
|
2015-07-24 15:28:44 -07:00
|
|
|
* Specify how the template and the styles should be encapsulated.
|
2015-08-28 21:03:19 -07:00
|
|
|
* The default is {@link ViewEncapsulation#Emulated `ViewEncapsulation.Emulated`} if the view
|
2015-08-02 22:29:05 -07:00
|
|
|
* has styles,
|
2015-08-28 21:03:19 -07:00
|
|
|
* otherwise {@link ViewEncapsulation#None `ViewEncapsulation.None`}.
|
2015-04-20 11:34:53 -07:00
|
|
|
*/
|
2015-07-24 15:28:44 -07:00
|
|
|
encapsulation: ViewEncapsulation;
|
2015-07-06 16:32:29 -07:00
|
|
|
|
2015-08-07 11:41:38 -07:00
|
|
|
constructor({templateUrl, template, directives, pipes, encapsulation, styles, styleUrls}: {
|
2015-07-07 22:09:19 +02:00
|
|
|
templateUrl?: string,
|
|
|
|
template?: string,
|
2015-09-18 10:33:23 -07:00
|
|
|
directives?: Array<Type | any[]>,
|
|
|
|
pipes?: Array<Type | any[]>,
|
2015-07-24 15:28:44 -07:00
|
|
|
encapsulation?: ViewEncapsulation,
|
2015-08-28 11:29:19 -07:00
|
|
|
styles?: string[],
|
|
|
|
styleUrls?: string[],
|
2015-07-07 22:09:19 +02:00
|
|
|
} = {}) {
|
|
|
|
this.templateUrl = templateUrl;
|
|
|
|
this.template = template;
|
|
|
|
this.styleUrls = styleUrls;
|
|
|
|
this.styles = styles;
|
|
|
|
this.directives = directives;
|
2015-08-07 11:41:38 -07:00
|
|
|
this.pipes = pipes;
|
2015-07-24 15:28:44 -07:00
|
|
|
this.encapsulation = encapsulation;
|
2015-07-07 22:09:19 +02:00
|
|
|
}
|
2015-06-12 23:51:42 -07:00
|
|
|
}
|