angular-cd-timer
Version:
Cd-Timer is a Angular CLI component with countup, countdown and multiple options.
270 lines • 30.7 kB
JavaScript
import { Component, EventEmitter, Input, Output } from '@angular/core';
import * as i0 from "@angular/core";
export class CdTimerComponent {
constructor(elt, renderer) {
this.elt = elt;
this.renderer = renderer;
this.onStart = new EventEmitter();
this.onStop = new EventEmitter();
this.onTick = new EventEmitter();
this.onComplete = new EventEmitter();
// Initialization
this.autoStart = true;
this.startTime = 0;
this.endTime = 0;
this.timeoutId = null;
this.countdown = false;
this.format = 'default';
}
ngAfterViewInit() {
const ngContentNode = this.elt.nativeElement.lastChild; // Get last child, defined by user or span
this.ngContentSchema = ngContentNode ? ngContentNode.nodeValue : '';
if (this.autoStart === undefined || this.autoStart === true) {
this.start();
}
}
ngOnDestroy() {
this.resetTimeout();
}
/**
* Start the timer
*/
start() {
this.initVar();
this.resetTimeout();
this.computeTimeUnits();
this.startTickCount();
this.onStart.emit(this);
}
/**
* Resume the timer
*/
resume() {
this.resetTimeout();
this.startTickCount();
}
/**
* Stop the timer
*/
stop() {
this.clear();
this.onStop.emit(this);
}
/**
* Reset the timer
*/
reset() {
this.initVar();
this.resetTimeout();
this.clear();
this.computeTimeUnits();
this.renderText();
}
/**
* Get the time information
* @returns TimeInterface
*/
get() {
return {
seconds: this.seconds,
minutes: this.minutes,
hours: this.hours,
days: this.days,
timer: this.timeoutId,
tick_count: this.tickCounter
};
}
/**
* Initialize variable before start
*/
initVar() {
this.startTime = this.startTime || 0;
this.endTime = this.endTime || 0;
this.countdown = this.countdown || false;
this.tickCounter = this.startTime;
// Disable countdown if start time not defined
if (this.countdown && this.startTime === 0) {
this.countdown = false;
}
// Determine auto format
if (!this.format) {
this.format = (this.ngContentSchema.length > 5) ? 'user' : 'default';
}
}
/**
* Reset timeout
*/
resetTimeout() {
if (this.timeoutId) {
clearInterval(this.timeoutId);
}
}
/**
* Render the time to DOM
*/
renderText() {
let outputText;
if (this.format === 'user') {
// User presentation
const items = {
'seconds': this.seconds,
'minutes': this.minutes,
'hours': this.hours,
'days': this.days
};
outputText = this.ngContentSchema;
for (const key of Object.keys(items)) {
outputText = outputText.replace('[' + key + ']', items[key].toString());
}
}
else if (this.format === 'intelli') {
// Intelli presentation
outputText = '';
if (this.days > 0) {
outputText += this.days.toString() + 'day' + ((this.days > 1) ? 's' : '') + ' ';
}
if ((this.hours > 0) || (this.days > 0)) {
outputText += this.hours.toString() + 'h ';
}
if (((this.minutes > 0) || (this.hours > 0)) && (this.days === 0)) {
outputText += this.minutes.toString().padStart(2, '0') + 'min ';
}
if ((this.hours === 0) && (this.days === 0)) {
outputText += this.seconds.toString().padStart(2, '0') + 's';
}
}
else if (this.format === 'hms') {
// Hms presentation
outputText = this.hours.toString().padStart(2, '0') + ':';
outputText += this.minutes.toString().padStart(2, '0') + ':';
outputText += this.seconds.toString().padStart(2, '0');
}
else if (this.format === 'ms') {
// ms presentation
outputText = '';
if (this.hours > 0) {
outputText = this.hours.toString().padStart(2, '0') + ':';
}
outputText += this.minutes.toString().padStart(2, '0') + ':';
outputText += this.seconds.toString().padStart(2, '0');
}
else {
// Default presentation
outputText = this.days.toString() + 'd ';
outputText += this.hours.toString() + 'h ';
outputText += this.minutes.toString() + 'm ';
outputText += this.seconds.toString() + 's';
}
this.renderer.setProperty(this.elt.nativeElement, 'innerHTML', outputText);
}
clear() {
this.resetTimeout();
this.timeoutId = null;
}
/**
* Compute each unit (seconds, minutes, hours, days) for further manipulation
* @protected
*/
computeTimeUnits() {
if (!this.maxTimeUnit || this.maxTimeUnit === 'day') {
this.seconds = Math.floor(this.tickCounter % 60);
this.minutes = Math.floor((this.tickCounter / 60) % 60);
this.hours = Math.floor((this.tickCounter / 3600) % 24);
this.days = Math.floor((this.tickCounter / 3600) / 24);
}
else if (this.maxTimeUnit === 'second') {
this.seconds = this.tickCounter;
this.minutes = 0;
this.hours = 0;
this.days = 0;
}
else if (this.maxTimeUnit === 'minute') {
this.seconds = Math.floor(this.tickCounter % 60);
this.minutes = Math.floor(this.tickCounter / 60);
this.hours = 0;
this.days = 0;
}
else if (this.maxTimeUnit === 'hour') {
this.seconds = Math.floor(this.tickCounter % 60);
this.minutes = Math.floor((this.tickCounter / 60) % 60);
this.hours = Math.floor(this.tickCounter / 3600);
this.days = 0;
}
this.renderText();
}
/**
* Start tick count, base of this component
* @protected
*/
startTickCount() {
const that = this;
that.timeoutId = setInterval(function () {
let counter;
if (that.countdown) {
// Compute finish counter for countdown
counter = that.tickCounter;
if (that.startTime > that.endTime) {
counter = that.tickCounter - that.endTime - 1;
}
}
else {
// Compute finish counter for timer
counter = that.tickCounter - that.startTime;
if (that.endTime > that.startTime) {
counter = that.endTime - that.tickCounter - 1;
}
}
that.computeTimeUnits();
const timer = {
seconds: that.seconds,
minutes: that.minutes,
hours: that.hours,
days: that.days,
timer: that.timeoutId,
tick_count: that.tickCounter
};
that.onTick.emit(timer);
if (counter < 0) {
that.stop();
that.onComplete.emit(that);
return;
}
if (that.countdown) {
that.tickCounter--;
}
else {
that.tickCounter++;
}
}, 1000); // Each seconds
}
}
CdTimerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: CdTimerComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
CdTimerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.3", type: CdTimerComponent, selector: "cd-timer", inputs: { startTime: "startTime", endTime: "endTime", countdown: "countdown", autoStart: "autoStart", maxTimeUnit: "maxTimeUnit", format: "format" }, outputs: { onStart: "onStart", onStop: "onStop", onTick: "onTick", onComplete: "onComplete" }, ngImport: i0, template: ' <ng-content></ng-content>', isInline: true });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: CdTimerComponent, decorators: [{
type: Component,
args: [{
selector: 'cd-timer',
template: ' <ng-content></ng-content>'
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { startTime: [{
type: Input
}], endTime: [{
type: Input
}], countdown: [{
type: Input
}], autoStart: [{
type: Input
}], maxTimeUnit: [{
type: Input
}], format: [{
type: Input
}], onStart: [{
type: Output
}], onStop: [{
type: Output
}], onTick: [{
type: Output
}], onComplete: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-cd-timer.component.js","sourceRoot":"","sources":["../../../../projects/angular-cd-timer/src/lib/angular-cd-timer.component.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport {\n  AfterViewInit,\n  Component, ElementRef, EventEmitter, Input, OnDestroy, Output, Renderer2\n} from '@angular/core';\nimport {TimeInterface} from './angular-cd-timer.interface';\n\n@Component({\n  selector: 'cd-timer',\n  template: ' <ng-content></ng-content>'\n})\nexport class CdTimerComponent implements AfterViewInit, OnDestroy {\n  private timeoutId: any;\n  private tickCounter: number;\n  private ngContentSchema: string;\n\n  private seconds: number;\n  private minutes: number;\n  private hours: number;\n  private days: number;\n\n  @Input() startTime: number;\n  @Input() endTime: number;\n  @Input() countdown: boolean;\n  @Input() autoStart: boolean;\n  @Input() maxTimeUnit: string;\n  @Input() format: string;\n  @Output() onStart: EventEmitter<CdTimerComponent> = new EventEmitter<CdTimerComponent>();\n  @Output() onStop: EventEmitter<CdTimerComponent> = new EventEmitter<CdTimerComponent>();\n  @Output() onTick: EventEmitter<TimeInterface> = new EventEmitter<TimeInterface>();\n  @Output() onComplete: EventEmitter<CdTimerComponent> = new EventEmitter<CdTimerComponent>();\n\n  constructor(private elt: ElementRef, private renderer: Renderer2) {\n    // Initialization\n    this.autoStart  = true;\n    this.startTime  = 0;\n    this.endTime    = 0;\n    this.timeoutId  = null;\n    this.countdown  = false;\n    this.format     = 'default';\n  }\n\n  ngAfterViewInit() {\n    const ngContentNode = this.elt.nativeElement.lastChild;    // Get last child, defined by user or span\n    this.ngContentSchema = ngContentNode ? ngContentNode.nodeValue : '';\n    if (this.autoStart === undefined || this.autoStart === true) {\n      this.start();\n    }\n  }\n\n  ngOnDestroy() {\n    this.resetTimeout();\n  }\n\n  /**\n   * Start the timer\n   */\n  public start() {\n    this.initVar();\n    this.resetTimeout();\n    this.computeTimeUnits();\n    this.startTickCount();\n\n    this.onStart.emit(this);\n  }\n\n  /**\n   * Resume the timer\n   */\n  public resume() {\n    this.resetTimeout();\n\n    this.startTickCount();\n  }\n\n  /**\n   * Stop the timer\n   */\n  public stop() {\n    this.clear();\n\n    this.onStop.emit(this);\n  }\n\n  /**\n   * Reset the timer\n   */\n  public reset() {\n    this.initVar();\n    this.resetTimeout();\n    this.clear();\n    this.computeTimeUnits();\n    this.renderText();\n  }\n\n  /**\n   * Get the time information\n   * @returns TimeInterface\n   */\n  public get() {\n    return {\n      seconds: this.seconds,\n      minutes: this.minutes,\n      hours: this.hours,\n      days: this.days,\n      timer: this.timeoutId,\n      tick_count: this.tickCounter\n    };\n  }\n\n  /**\n   * Initialize variable before start\n   */\n  private initVar() {\n    this.startTime = this.startTime || 0;\n    this.endTime   = this.endTime || 0;\n    this.countdown = this.countdown || false;\n    this.tickCounter = this.startTime;\n\n    // Disable countdown if start time not defined\n    if (this.countdown && this.startTime === 0) {\n      this.countdown = false;\n    }\n\n    // Determine auto format\n    if (!this.format) {\n      this.format = (this.ngContentSchema.length > 5) ? 'user' : 'default';\n    }\n  }\n\n  /**\n   * Reset timeout\n   */\n  private resetTimeout() {\n    if (this.timeoutId) {\n      clearInterval(this.timeoutId);\n    }\n  }\n\n  /**\n   * Render the time to DOM\n   */\n  private renderText() {\n    let outputText;\n    if (this.format === 'user') {\n      // User presentation\n      const items = {\n        'seconds': this.seconds,\n        'minutes': this.minutes,\n        'hours': this.hours,\n        'days': this.days\n      };\n\n      outputText = this.ngContentSchema;\n\n      for (const key of Object.keys(items)) {\n        outputText = outputText.replace('[' + key + ']', (items as any)[key].toString());\n      }\n    } else if (this.format === 'intelli') {\n      // Intelli presentation\n      outputText = '';\n      if (this.days > 0) {\n        outputText += this.days.toString() + 'day' + ((this.days > 1) ? 's' : '') + ' ';\n      }\n      if ((this.hours > 0) || (this.days > 0)) {\n        outputText += this.hours.toString() + 'h ';\n      }\n      if (((this.minutes > 0) || (this.hours > 0)) && (this.days === 0)) {\n        outputText += this.minutes.toString().padStart(2, '0') + 'min ';\n      }\n      if ((this.hours === 0) && (this.days === 0)) {\n        outputText += this.seconds.toString().padStart(2, '0') + 's';\n      }\n    } else if (this.format === 'hms') {\n      // Hms presentation\n      outputText = this.hours.toString().padStart(2, '0') + ':';\n      outputText += this.minutes.toString().padStart(2, '0') + ':';\n      outputText += this.seconds.toString().padStart(2, '0');\n    } else if (this.format === 'ms') {\n      // ms presentation\n      outputText = '';\n      if(this.hours>0) {\n        outputText = this.hours.toString().padStart(2, '0') + ':';\n      }\n      outputText += this.minutes.toString().padStart(2, '0') + ':';\n      outputText += this.seconds.toString().padStart(2, '0');\n    } else {\n      // Default presentation\n      outputText = this.days.toString() + 'd ';\n      outputText += this.hours.toString() + 'h ';\n      outputText += this.minutes.toString() + 'm ';\n      outputText += this.seconds.toString() + 's';\n    }\n\n    this.renderer.setProperty(this.elt.nativeElement, 'innerHTML', outputText);\n  }\n\n  private clear() {\n    this.resetTimeout();\n    this.timeoutId = null;\n  }\n\n  /**\n   * Compute each unit (seconds, minutes, hours, days) for further manipulation\n   * @protected\n   */\n  protected computeTimeUnits() {\n    if (!this.maxTimeUnit || this.maxTimeUnit === 'day') {\n      this.seconds  = Math.floor(this.tickCounter % 60);\n      this.minutes  = Math.floor((this.tickCounter / 60) % 60);\n      this.hours    = Math.floor((this.tickCounter / 3600) % 24);\n      this.days     = Math.floor((this.tickCounter / 3600) / 24);\n    } else if (this.maxTimeUnit === 'second') {\n      this.seconds  = this.tickCounter;\n      this.minutes  = 0;\n      this.hours    = 0;\n      this.days     = 0;\n    } else if (this.maxTimeUnit === 'minute') {\n      this.seconds  = Math.floor(this.tickCounter % 60);\n      this.minutes  = Math.floor(this.tickCounter / 60);\n      this.hours    = 0;\n      this.days     = 0;\n    } else if (this.maxTimeUnit === 'hour') {\n      this.seconds  = Math.floor(this.tickCounter % 60);\n      this.minutes  = Math.floor((this.tickCounter / 60) % 60);\n      this.hours    = Math.floor(this.tickCounter / 3600);\n      this.days     = 0;\n    }\n\n    this.renderText();\n  }\n\n  /**\n   * Start tick count, base of this component\n   * @protected\n   */\n  protected startTickCount () {\n    const that = this;\n\n    that.timeoutId = setInterval(function() {\n      let counter;\n\n      if (that.countdown) {\n        // Compute finish counter for countdown\n        counter = that.tickCounter;\n\n        if (that.startTime > that.endTime) {\n          counter = that.tickCounter - that.endTime - 1;\n        }\n      } else {\n        // Compute finish counter for timer\n        counter = that.tickCounter - that.startTime;\n\n        if (that.endTime > that.startTime) {\n          counter = that.endTime - that.tickCounter - 1;\n        }\n      }\n\n      that.computeTimeUnits();\n\n      const timer: TimeInterface = {\n        seconds: that.seconds,\n        minutes: that.minutes,\n        hours: that.hours,\n        days: that.days,\n        timer: that.timeoutId,\n        tick_count: that.tickCounter\n      };\n\n      that.onTick.emit(timer);\n\n      if (counter < 0) {\n        that.stop();\n\n        that.onComplete.emit(that);\n        return;\n      }\n\n      if (that.countdown) {\n        that.tickCounter--;\n      } else {\n        that.tickCounter++;\n      }\n    }, 1000); // Each seconds\n  }\n\n}\n"]}