Compare commits
2 Commits
Author | SHA1 | Date | |
---|---|---|---|
34227e5c4b | |||
7e8352ed2a |
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@ztimson/utils",
|
"name": "@ztimson/utils",
|
||||||
"version": "0.27.5",
|
"version": "0.27.7",
|
||||||
"description": "Utility library",
|
"description": "Utility library",
|
||||||
"author": "Zak Timson",
|
"author": "Zak Timson",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
@@ -42,6 +42,8 @@ export const CliBackground = {
|
|||||||
GREY: "\x1b[100m",
|
GREY: "\x1b[100m",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export type LogLevels = 'debug' | 'log' | 'info' | 'warn' | 'error';
|
||||||
|
|
||||||
export enum LOG_LEVEL {
|
export enum LOG_LEVEL {
|
||||||
ERROR = 0,
|
ERROR = 0,
|
||||||
WARN = 1,
|
WARN = 1,
|
||||||
|
29
src/misc.ts
29
src/misc.ts
@@ -1,3 +1,4 @@
|
|||||||
|
import {LogLevels} from './logger.ts';
|
||||||
import {PathEvent} from './path-events.ts';
|
import {PathEvent} from './path-events.ts';
|
||||||
import {md5} from './string';
|
import {md5} from './string';
|
||||||
|
|
||||||
@@ -14,6 +15,34 @@ export function compareVersions(target: string, vs: string): -1 | 0 | 1 {
|
|||||||
(tMajor < vMajor || tMinor < vMinor || tPatch < vPatch) ? -1 : 0;
|
(tMajor < vMajor || tMinor < vMinor || tPatch < vPatch) ? -1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a console object to intercept logs with optional passthrough
|
||||||
|
* @param {null | {debug: Function, log: Function, info: Function, warn: Function, error: Function}} out Passthrough logs, null to silence
|
||||||
|
* @param {{[K in LogLevels]?: LogLevels | "none"}} map Map log levels: {log: 'debug', warn: 'error'} = Suppress debug logs, elevate warnings
|
||||||
|
* @returns {{debug: Function, log: Function, info: Function, warn: Function, error: Function, stderr: string[], stdout: string[]}}
|
||||||
|
*/
|
||||||
|
export function consoleInterceptor(
|
||||||
|
out: null | {debug: Function, log: Function, info: Function, warn: Function, error: Function} = console,
|
||||||
|
map?: {[K in LogLevels]?: LogLevels | 'none'}
|
||||||
|
): {debug: Function, log: Function, info: Function, warn: Function, error: Function, output: {debug: any[], log: any[], info: any[], warn: any[], error: any[], stderr: any[], stdout: any[]}} {
|
||||||
|
const logs: any = {debug: [], log: [], info: [], warn: [], error: [], stderr: [], stdout: [],}
|
||||||
|
const cWrapper = (type: 'debug' | 'log' | 'info' | 'warn' | 'error') => ((...args: any[]) => {
|
||||||
|
if(out) out[type](...args);
|
||||||
|
logs[type].push(...args);
|
||||||
|
if(type == 'error') logs.stderr.push(...args);
|
||||||
|
else logs.stdout.push(...args);
|
||||||
|
});
|
||||||
|
return {
|
||||||
|
debug: map?.debug != 'none' ? cWrapper(map?.debug || 'debug') : () => {},
|
||||||
|
log: map?.log != 'none' ? cWrapper(map?.log || 'log') : () => {},
|
||||||
|
info: map?.info != 'none' ? cWrapper(map?.info || 'info') : () => {},
|
||||||
|
warn: map?.warn != 'none' ? cWrapper(map?.warn || 'warn') : () => {},
|
||||||
|
error: map?.error != 'none' ? cWrapper(map?.error || 'error') : () => {},
|
||||||
|
output: logs
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Escape any regex special characters to avoid misinterpretation during search
|
* Escape any regex special characters to avoid misinterpretation during search
|
||||||
* @param {string} value String which should be escaped
|
* @param {string} value String which should be escaped
|
||||||
|
44
src/time.ts
44
src/time.ts
@@ -34,6 +34,50 @@ export function dayOfYear(date: Date): number {
|
|||||||
/**
|
/**
|
||||||
* Format date
|
* Format date
|
||||||
*
|
*
|
||||||
|
* Year:
|
||||||
|
* - YYYY = 2025 (4-digit year)
|
||||||
|
* - YY = 25 (2-digit year)
|
||||||
|
*
|
||||||
|
* Month:
|
||||||
|
* - MMMM = January (full month name)
|
||||||
|
* - MMM = Jan (abbreviated month name)
|
||||||
|
* - MM = 01 (zero-padded month number)
|
||||||
|
* - M = 1 (month number)
|
||||||
|
*
|
||||||
|
* Day:
|
||||||
|
* - DDD = 123 (day of year)
|
||||||
|
* - DD = 01 (zero-padded day)
|
||||||
|
* - Do = 1st (day with ordinal suffix)
|
||||||
|
* - D = 1 (day number)
|
||||||
|
* - dddd = Monday (full day name)
|
||||||
|
* - ddd = Mon (abbreviated day name)
|
||||||
|
*
|
||||||
|
* Hour:
|
||||||
|
* - HH = 13 (24-hour format, zero-padded)
|
||||||
|
* - H = 13 (24-hour format)
|
||||||
|
* - hh = 01 (12-hour format, zero-padded)
|
||||||
|
* - h = 1 (12-hour format)
|
||||||
|
*
|
||||||
|
* Minute:
|
||||||
|
* - mm = 05 (zero-padded minutes)
|
||||||
|
* - m = 5 (minutes)
|
||||||
|
*
|
||||||
|
* Second:
|
||||||
|
* - ss = 09 (zero-padded seconds)
|
||||||
|
* - s = 9 (seconds)
|
||||||
|
*
|
||||||
|
* Millisecond:
|
||||||
|
* - SSS = 123 (3-digit milliseconds)
|
||||||
|
*
|
||||||
|
* AM/PM:
|
||||||
|
* - A = AM/PM (uppercase)
|
||||||
|
* - a = am/pm (lowercase)
|
||||||
|
*
|
||||||
|
* Timezone:
|
||||||
|
* - ZZ = +0500 (timezone offset without colon)
|
||||||
|
* - Z = +05:00 (timezone offset with colon)
|
||||||
|
* - z = EST (timezone abbreviation)
|
||||||
|
*
|
||||||
* @param {string} format How date string will be formatted, default: `YYYY-MM-DD H:mm A`
|
* @param {string} format How date string will be formatted, default: `YYYY-MM-DD H:mm A`
|
||||||
* @param {Date | number | string} date Date or timestamp, defaults to now
|
* @param {Date | number | string} date Date or timestamp, defaults to now
|
||||||
* @param tz Set timezone offset
|
* @param tz Set timezone offset
|
||||||
|
Reference in New Issue
Block a user