2022-11-21 09:14:32 +01:00
|
|
|
import * as plugins from './smarttime.plugins.js';
|
2017-08-16 14:29:12 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* TimeStamp
|
|
|
|
* smart timestamp
|
|
|
|
*/
|
|
|
|
export class TimeStamp {
|
2018-03-11 16:44:32 +01:00
|
|
|
/**
|
|
|
|
* returns new TimeStamp from milliseconds
|
|
|
|
*/
|
2021-10-06 11:58:36 +02:00
|
|
|
public static fromMilliSeconds(milliSecondsArg: number) {
|
2018-03-11 16:44:32 +01:00
|
|
|
return new TimeStamp(milliSecondsArg);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* returns new TimeStamp for now with change set
|
|
|
|
* @param timeStampArg
|
|
|
|
*/
|
|
|
|
public static fromTimeStamp(timeStampArg: TimeStamp) {
|
|
|
|
const localTimeStamp = new TimeStamp();
|
|
|
|
localTimeStamp.change = localTimeStamp.milliSeconds - timeStampArg.milliSeconds;
|
|
|
|
return localTimeStamp;
|
|
|
|
}
|
|
|
|
|
2017-08-16 14:29:12 +02:00
|
|
|
/**
|
|
|
|
* The standard JavaScript Date
|
|
|
|
*/
|
2018-03-11 16:44:32 +01:00
|
|
|
public date: Date;
|
2017-08-16 14:29:12 +02:00
|
|
|
|
|
|
|
/**
|
2017-08-16 15:34:49 +02:00
|
|
|
* The time as linux time (milliseconds, not seconds though)
|
2017-08-16 14:29:12 +02:00
|
|
|
* good for comparison
|
|
|
|
*/
|
2018-03-11 16:44:32 +01:00
|
|
|
public milliSeconds: number;
|
2017-08-16 15:34:49 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The standard epoch time in seconds
|
|
|
|
*/
|
2018-03-11 16:44:32 +01:00
|
|
|
public epochtime: number;
|
2017-08-16 15:34:49 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* if derived from another TimeStamp points out the change in milliseconds
|
|
|
|
*/
|
2018-03-11 16:44:32 +01:00
|
|
|
public change: number = null;
|
2017-08-16 15:34:49 +02:00
|
|
|
|
2018-03-11 16:44:32 +01:00
|
|
|
constructor(creatorArg?: number) {
|
2017-08-16 14:29:12 +02:00
|
|
|
if (!creatorArg) {
|
2018-03-11 16:44:32 +01:00
|
|
|
this.date = new Date();
|
2017-08-16 15:34:49 +02:00
|
|
|
} else if (typeof creatorArg === 'number') {
|
2018-03-11 16:44:32 +01:00
|
|
|
this.date = new Date(creatorArg);
|
2017-08-16 14:29:12 +02:00
|
|
|
}
|
2018-03-11 16:44:32 +01:00
|
|
|
this.milliSeconds = this.date.getTime();
|
|
|
|
this.epochtime = Math.floor(this.milliSeconds / 1000);
|
2017-08-16 14:29:12 +02:00
|
|
|
}
|
|
|
|
|
2021-11-08 16:56:11 +01:00
|
|
|
/**
|
|
|
|
* returns a boolean for wether the timestamp is older than another timestamp
|
|
|
|
* @param TimeStampArg
|
|
|
|
* @param tresholdTimeArg
|
|
|
|
*/
|
|
|
|
public isOlderThanOtherTimeStamp(TimeStampArg: TimeStamp, tresholdTimeArg: number = 0) {
|
|
|
|
if (this.milliSeconds < TimeStampArg.milliSeconds - tresholdTimeArg) {
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-16 14:29:12 +02:00
|
|
|
/**
|
|
|
|
* Is the current instance older than the argument
|
|
|
|
* @param TimeStampArg
|
|
|
|
*/
|
2018-03-11 16:44:32 +01:00
|
|
|
public isOlderThan(TimeStampArg: TimeStamp, tresholdTimeArg: number = 0) {
|
|
|
|
if (this.milliSeconds + tresholdTimeArg < TimeStampArg.milliSeconds) {
|
|
|
|
return true;
|
2017-08-16 14:29:12 +02:00
|
|
|
} else {
|
2018-03-11 16:44:32 +01:00
|
|
|
return false;
|
2017-08-16 14:29:12 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-10 11:34:30 +02:00
|
|
|
/**
|
2021-11-08 16:56:11 +01:00
|
|
|
* returns a boolean for wether the timestamp is younger than another timestamp
|
2019-04-10 11:34:30 +02:00
|
|
|
* @param TimeStampArg
|
|
|
|
* @param tresholdTimeArg
|
|
|
|
*/
|
2018-03-11 18:20:33 +01:00
|
|
|
public isYoungerThanOtherTimeStamp(TimeStampArg: TimeStamp, tresholdTimeArg: number = 0) {
|
2018-03-11 16:44:32 +01:00
|
|
|
if (this.milliSeconds > TimeStampArg.milliSeconds + tresholdTimeArg) {
|
|
|
|
return true;
|
2017-08-16 14:29:12 +02:00
|
|
|
} else {
|
2018-03-11 16:44:32 +01:00
|
|
|
return false;
|
2017-08-16 14:29:12 +02:00
|
|
|
}
|
|
|
|
}
|
2018-03-11 18:20:33 +01:00
|
|
|
|
|
|
|
public isYoungerThanMilliSeconds(millisecondArg: number) {
|
2018-06-10 14:00:18 +02:00
|
|
|
const nowTimeStamp = new TimeStamp();
|
2018-03-11 18:20:33 +01:00
|
|
|
const compareEpochTime = nowTimeStamp.epochtime - millisecondArg;
|
|
|
|
const compareTimeStamp = new TimeStamp(compareEpochTime);
|
|
|
|
return this.isYoungerThanOtherTimeStamp(compareTimeStamp);
|
|
|
|
}
|
2017-08-16 14:29:12 +02:00
|
|
|
}
|