fuse-angular/src/app/core/components/countdown/countdown.component.ts

54 lines
1.4 KiB
TypeScript
Raw Normal View History

2017-07-28 13:03:32 +00:00
import { Component, Input, OnInit } from '@angular/core';
import * as moment from 'moment';
2017-08-14 14:17:49 +00:00
import { Observable } from 'rxjs/Rx';
2017-07-28 13:03:32 +00:00
@Component({
selector : 'fuse-countdown',
templateUrl: './countdown.component.html',
styleUrls : ['./countdown.component.scss']
})
export class FuseCountdownComponent implements OnInit
{
@Input('eventDate') eventDate;
countdown: any;
constructor()
{
this.countdown = {
days : '',
hours : '',
minutes: '',
seconds: ''
};
}
ngOnInit()
{
const currDate = moment();
const eventDate = moment(this.eventDate);
let diff = eventDate.diff(currDate, 'seconds');
const countDown =
Observable
.interval(1000)
.map(value => {
return diff = diff - 1;
})
.map(value => {
const timeLeft = moment.duration(value, 'seconds');
return {
days : timeLeft.asDays().toFixed(0),
hours : timeLeft.hours(),
minutes: timeLeft.minutes(),
seconds: timeLeft.seconds()
};
});
countDown.subscribe(value => {
this.countdown = value;
});
}
}