2016-06-23 12:47:54 -04:00
|
|
|
/**
|
|
|
|
* @license
|
2020-05-19 15:08:49 -04:00
|
|
|
* Copyright Google LLC All Rights Reserved.
|
2016-06-23 12:47:54 -04:00
|
|
|
*
|
|
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
|
|
* found in the LICENSE file at https://angular.io/license
|
|
|
|
*/
|
|
|
|
|
2016-06-08 19:38:52 -04:00
|
|
|
import {Attribute, Component, Directive, Pipe} from '@angular/core';
|
2015-11-30 11:28:54 -05:00
|
|
|
|
2017-09-22 13:51:03 -04:00
|
|
|
class CustomDirective {}
|
2015-11-30 11:28:54 -05:00
|
|
|
|
2016-08-19 15:51:01 -04:00
|
|
|
@Component({selector: 'greet', template: 'Hello {{name}}!'})
|
2015-11-30 11:28:54 -05:00
|
|
|
class Greet {
|
|
|
|
name: string = 'World';
|
|
|
|
}
|
|
|
|
|
|
|
|
// #docregion attributeFactory
|
|
|
|
@Component({selector: 'page', template: 'Title: {{title}}'})
|
|
|
|
class Page {
|
|
|
|
title: string;
|
2020-04-13 19:40:21 -04:00
|
|
|
constructor(@Attribute('title') title: string) {
|
|
|
|
this.title = title;
|
|
|
|
}
|
2015-11-30 11:28:54 -05:00
|
|
|
}
|
|
|
|
// #enddocregion
|
|
|
|
|
|
|
|
// #docregion attributeMetadata
|
|
|
|
@Directive({selector: 'input'})
|
|
|
|
class InputAttrDirective {
|
2016-02-11 20:01:17 -05:00
|
|
|
constructor(@Attribute('type') type: string) {
|
2015-11-30 11:28:54 -05:00
|
|
|
// type would be 'text' in this example
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// #enddocregion
|
|
|
|
|
|
|
|
@Directive({selector: 'input'})
|
|
|
|
class InputDirective {
|
|
|
|
constructor() {
|
|
|
|
// Add some logic.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Pipe({name: 'lowercase'})
|
|
|
|
class Lowercase {
|
2020-04-13 19:40:21 -04:00
|
|
|
transform(v: string, args: any[]) {
|
|
|
|
return v.toLowerCase();
|
|
|
|
}
|
2015-11-30 11:28:54 -05:00
|
|
|
}
|