moment.js pipes for Angular 2.0
This module works with the latest release candidate of Angular 2.0.
For the stable AngularJS 1.x version of this module, please see angular-moment.
npm install --save angular2-moment
If you use typescript, and typings, you may also need to install typings for moment.js:
typings install --save moment
First you need to install moment:
npm install moment --save
Don´t forget to update your systemjs.config.js:
packages: {
app: {
main: './main.js',
defaultExtension: 'js'
},
'moment': {
main: './moment.js',
defaultExtension: 'js'
},
'angular2-moment': {
main: './index.js',
defaultExtension: 'js'
}
}
Starting with RC 6, the <time>
tag is no longer needed to use the moment pipes.
@Component({
selector: 'app',
template: `
Last updated: {{myDate | amTimeAgo}}
`
})
Import MomentModule
into your app's modules:
import {MomentModule} from 'angular2-moment';
@NgModule({
imports: [
MomentModule
]
})
This makes all the angular2-moment
pipes available for use in your app components.
Use an older version of the library, such as 0.8.2. You can find the documentation here.
Takes an optional omitSuffix
argument that defaults to false
.
@Component({
selector: 'app',
template: `
Last updated: <time>{{myDate | amTimeAgo}}</time>
`
})
Prints Last updated: a few seconds ago
@Component({
selector: 'app',
template: `
Last updated: <time>{{myDate | amTimeAgo:true}}</time>
`
})
Prints Last updated: a few seconds
@Component({
selector: 'app',
template: `
Last updated: <time>{{myDate | amCalendar}}</time>
`
})
Prints Last updated: Today at 14:00
@Component({
selector: 'app',
template: `
Last updated: <time>{{myDate | amDateFormat:'LL'}}</time>
`
})
Prints Last updated: January 24, 2016
@Component({
selector: 'app',
template: `
Last updated: <time>{{ (1456263980 | amFromUnix) | amDateFormat:'hh:mmA'}}</time>
`
})
Prints Last updated: 01:46PM
@Component({
selector: 'app',
template: `
Uptime: <time>{{ 365 | amDuration:'seconds' }}</time>
`
})
Prints Uptime: 6 minutes
@Component({
selector: 'app',
template: `
Expiration: <time>{{nextDay | amDifference: today :'days' : true}}</time> days
`
})
Prints Expiration: 1 day
import {NgModule, Component} from 'angular2/core';
import {BrowserModule} from '@angular/platform-browser';
import {platformBrowserDynamic} from '@angular/platform-browser-dynamic';
import {MomentModule} from 'angular2-moment';
@Component({
selector: 'app',
template: `
Last updated: <b>{{myDate | amTimeAgo}}</b>, <b>{{myDate | amCalendar}}</b>, <b>{{myDate | amDateFormat:'LL'}}</b>
`
})
export class AppComponent {
myDate: Date;
constructor() {
this.myDate = new Date();
}
}
@NgModule({
imports: [
BrowserModule,
MomentModule
],
declarations: [ AppComponent ]
bootstrap: [ AppComponent ]
})
class AppModule {}
platformBrowserDynamic().bootstrapModule(AppModule);