smarttime/ts/smarttime.classes.timer.ts

87 lines
2.0 KiB
TypeScript
Raw Normal View History

2022-11-21 09:14:32 +01:00
import * as plugins from './smarttime.plugins.js';
2018-03-11 16:44:32 +01:00
2022-11-21 09:14:32 +01:00
import { TimeStamp } from './smarttime.classes.timestamp.js';
2018-03-11 16:44:32 +01:00
export type TimerState = 'initiated' | 'started' | 'paused' | 'completed';
export class Timer {
/**
* the original amount of milliseconds for this Timer
*/
public timeInMilliseconds: number;
/**
* the state of the timer
*/
public state: TimerState = 'initiated';
/**
* completed Promise
*/
public completed: Promise<void>;
/**
* a reference to when the Timeout started
*/
public startedAt: TimeStamp;
/**
* a reference to when a Timer has been potentially paused
*/
public pausedAt: TimeStamp;
get timeLeft(): number {
return this.timeInMilliseconds - this.pausedAt.change;
}
/**
* the current timeout the needs to be canceled when this Timer is stopped
*/
2023-10-20 12:50:47 +02:00
private currentTimeout: NodeJS.Timeout;
2018-03-11 16:44:32 +01:00
// a deferred triggeted when Timer has completed
2018-07-13 00:03:08 +02:00
private completedDeferred = plugins.smartpromise.defer<void>();
2018-03-11 16:44:32 +01:00
constructor(timeInMillisecondsArg: number) {
this.timeInMilliseconds = timeInMillisecondsArg;
this.completed = this.completedDeferred.promise;
}
/**
* starts the timer
*/
public start() {
if (!this.startedAt) {
this.currentTimeout = setTimeout(() => {
this.completedDeferred.resolve();
}, this.timeInMilliseconds);
this.startedAt = new TimeStamp();
} else {
throw new Error('timer has been started before. Please use resume instead');
}
}
public pause() {
2018-11-23 19:26:41 +01:00
if (this.startedAt) {
clearTimeout(this.currentTimeout);
this.currentTimeout = null;
this.pausedAt = TimeStamp.fromTimeStamp(this.startedAt);
}
2018-03-11 16:44:32 +01:00
}
public resume() {
if (this.startedAt) {
this.currentTimeout = setTimeout(() => {
this.completedDeferred.resolve();
}, this.timeLeft);
2018-11-23 18:29:38 +01:00
} else {
throw new Error('timer has NOT been started before. Please use .start() instead');
2018-03-11 16:44:32 +01:00
}
}
2018-11-23 18:29:38 +01:00
public reset() {
this.pause();
this.startedAt = null;
this.pausedAt = null;
}
2018-03-11 16:44:32 +01:00
}