X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Futils%2FUtils.ts;h=c5a276bc92609e21bb55f79f2df4549a5f0fe447;hb=769d3b106c5e4744487bc633da4e4ee93f8f1bf4;hp=54b0751022130ba18e3a238cc58a78d741acb39e;hpb=991fb26bd3814b583395f5d2623acfae7a3ee3f0;p=e-mobility-charging-stations-simulator.git diff --git a/src/utils/Utils.ts b/src/utils/Utils.ts index 54b07510..c5a276bc 100644 --- a/src/utils/Utils.ts +++ b/src/utils/Utils.ts @@ -3,13 +3,16 @@ import { inspect } from 'node:util'; import { formatDuration, + hoursToMinutes, + hoursToSeconds, isDate, millisecondsToHours, millisecondsToMinutes, millisecondsToSeconds, + minutesToSeconds, secondsToMilliseconds, } from 'date-fns'; -import clone from 'just-clone'; +import deepClone from 'deep-clone'; import { Constants } from './Constants'; import { type TimestampedData, WebSocketCloseEventStatusString } from '../types'; @@ -36,9 +39,14 @@ export const formatDurationMilliSeconds = (duration: number): string => { duration = convertToInt(duration); const days = Math.floor(duration / (24 * 3600 * 1000)); const hours = Math.floor(millisecondsToHours(duration) - days * 24); - const minutes = Math.floor(millisecondsToMinutes(duration) - days * 24 * 60 - hours * 60); + const minutes = Math.floor( + millisecondsToMinutes(duration) - days * 24 * 60 - hoursToMinutes(hours), + ); const seconds = Math.floor( - millisecondsToSeconds(duration) - days * 24 * 3600 - hours * 3600 - minutes * 60, + millisecondsToSeconds(duration) - + days * 24 * 3600 - + hoursToSeconds(hours) - + minutesToSeconds(minutes), ); return formatDuration({ days, @@ -52,8 +60,8 @@ export const formatDurationSeconds = (duration: number): string => { return formatDurationMilliSeconds(secondsToMilliseconds(duration)); }; -// More efficient date validation function than the one provided by date-fns -export const isValidDate = (date: unknown): boolean => { +// More efficient time validation function than the one provided by date-fns +export const isValidTime = (date: unknown): boolean => { if (typeof date === 'number') { return !isNaN(date); } else if (isDate(date)) { @@ -68,8 +76,8 @@ export const convertToDate = ( if (isNullOrUndefined(value)) { return value as null | undefined; } - if (value instanceof Date) { - return value; + if (isDate(value)) { + return value as Date; } if (isString(value) || typeof value === 'number') { return new Date(value!); @@ -198,8 +206,19 @@ export const isObject = (item: unknown): boolean => { ); }; -export const cloneObject = (object: T): T => { - return clone(object); +type CloneableData = + | number + | string + | boolean + | null + | undefined + | Date + | CloneableData[] + | { [key: string]: CloneableData }; + +export const cloneObject = (object: T): T => { + // eslint-disable-next-line @typescript-eslint/no-unsafe-call + return deepClone(object as CloneableData) as T; }; export const hasOwnProp = (object: unknown, property: PropertyKey): boolean => { @@ -262,11 +281,12 @@ export const insertAt = (str: string, subStr: string, pos: number): string => * Computes the retry delay in milliseconds using an exponential backoff algorithm. * * @param retryNumber - the number of retries that have already been attempted + * @param maxDelayRatio - the maximum ratio of the delay that can be randomized * @returns delay in milliseconds */ export const exponentialDelay = (retryNumber = 0, maxDelayRatio = 0.2): number => { const delay = Math.pow(2, retryNumber) * 100; - const randomSum = delay * maxDelayRatio * secureRandom(); // 0-20% of the delay + const randomSum = delay * maxDelayRatio * secureRandom(); // 0-(maxDelayRatio*100)% of the delay return delay + randomSum; };