js-awe
Version:
Awesome js utils including - plan: An Asynchronous control flow with a functional taste - Chrono: record and visualize timelines in the console
1,282 lines (1,146 loc) • 52 kB
TypeScript
import * as F from 'fluture';
export { F };
import * as ramda from 'ramda';
export { ramda as R };
// anonymize.js
/**
* Change each number, uppercase letter and lowercase letter
* for a random number, uppercase letter and lowercase letter.
* Rest of characters are kept equal, resulting in a same length
* string. The algorithm returns string filled with * in cases that
* changes were less than half of the characters.
* @param toAnonymise The string to change.
* @returns the randomized string.
*/
declare function anonymize(toAnonymise: string): string
declare function cloneCopy(to: any, from: any, firstCleanTo: any, shallow: any): any;
/**
*
* @param pathSearch - The search query containing wildcards: account.**.name any that starts with account and ends with name.
* @param flagString - The flag strings to add to regex: i (case insensitive), g (global), m (multiline), s (dot matches all), u (unicode), y (sticky).
* @param separator - The separator characted used in pathSearch to separate different words. account.name -> .
* @param matchFromStart - If true, the regex will match from the start of the string.
* @param matchToEnd - If true, the regex will match to the end of the string.
* @returns The regex equivalent to pathSearch.
*/
declare function wildcardToRegExp(pathSearch: string, flagsString: string, separator?: string, matchFromStart?: boolean, matchToEnd?: boolean): RegExp;
declare function promiseAll(obj: any): any;
/**
* Create events by calling time(eventNames) and finish them by calling
* timeEnd(eventNames). You can print the result in console by calling
* report()
*/
declare interface Chrono {
/**
* Create event/s and start the timer.
* @param eventNames Name of the event or array with event names.
* @example
* // Single event
* chrono.time('step1');
*
* // Multiple events
* chrono.time(['step1', 'step2']);
*/
time(eventNames: string | string[]): void;
/**
* Stop the timer for the event/s.
* @param eventNames Name of the event or array with event names.
* @example
* // Single event
* chrono.timeEnd('step1');
*
* // Multiple events
* chrono.timeEnd(['step1', 'step2']);
*/
timeEnd(eventNames: string | string[]): void
/**
* Print the report of the events in the console.
*/
report(): void
/**
* This is an implementation of Chrono().time() to use in a pipeline of functions. Prepare the time event function that will be
* triggered in the execution of the pipeline. As this is for logging purposes, data is passed to the next function. This function
* takes the input and passes it to the next function without modifications.
* @param event Name of the event or array with event names.
* @returns A function that takes the input data and passes it to the next function without modifications.
* @example
* const pipeline = [
* chrono.setTime('step1'),
* // other functions in the pipeline
* ];
*
* const result = pipeline.reduce((data, fn) => fn(data), inputData);
*/
setTime: (event: string | string[]) => <T>(data: T) => T;
/**
* This is an implementation of Chrono().timeEnd() to use in a pipeline of functions. Prepare the timeEnd event function that will be
* triggered in the execution of the pipeline. As this is for logging purposes, data is passed to the next function. This function
* takes the input and passes it to the next function without modifications.
* @param event Name of the event or array with event names.
* @returns A function that takes the input data and passes it to the next function without modifications.
* @example
* const pipeline = [
* // other functions in the pipeline
* chrono.setTimeEnd('step1'),
* ];
*
* const result = pipeline.reduce((data, fn) => fn(data), inputData);
*/
setTimeEnd: (event: string | string[]) => <T>(data: T) => T;
/**
* This is an implementation of Chrono().report() to use in a pipeline of functions. Its execution will log the event reports as in
* Chrono().report() and returns the same data received as input.
* @returns A function that takes the input data, logs the event reports, and returns the same data.
* @example
* const pipeline = [
* // other functions in the pipeline
* chrono.logReport,
* ];
*
* const result = pipeline.reduce((data, fn) => fn(data), inputData);
*/
logReport: <T>(data: T) => T;
/**
* Get the current state of the Chrono timer.
* @returns The current state of the Chrono timer.
*/
getChronoState: () => {};
/**
* Set the Chrono timer state using the Performance API format.
* @param performanceGetEntriesByTypeOjb The Performance API object returned by `performance.getEntriesByType('measure')`.
*/
setChronoStateUsingPerformanceAPIFormat: (performanceGetEntriesByTypeOjb: any) => void;
/**
* Get the Chrono timer state using the Performance API format.
* @returns The Chrono timer state in the Performance API format.
*/
getChronoStateUsingPerformanceAPIFormat: () => any[];
/**
* Calculate the average time for each event.
*/
average: () => void;
}
declare function Chrono(): Chrono
declare function fetchImproved(...args: any[]): Promise<{
status: number;
body: unknown;
}>;
//# sourceMappingURL=fetchImproved.d.ts.map
declare function fletch({ url, options }?: {
url: any;
options: any;
}): F.FutureInstance<any, {
status: number;
body: unknown;
}>;
declare function promiseFunToFutureFun(futurizePromFun: any): (...input: any[]) => F.FutureInstance<any, any>;
declare function ffletchMaker(fetchsDef: any, delay: any): (input: any) => F.FutureInstance<any, any>;
/**
* @fileoverview TypeScript declarations for jsUtils module.
* @module jsUtils
*/
/**
* Utility functions for JavaScript.
* @namespace jsUtils
*/
/**
* Logs a message with a prefix.
* @param {string} title - The prefix for the log message.
* @param {(message: T) => string} displayFunc - The function to display the log message.
* @returns {(message: T) => string} - The log function.
*/
declare function logWithPrefix<T>(title: string, displayFunc: (message: T) => string): (message: T) => string;
/**
* Capitalizes the first letter of a string.
* @param {string} str - The string to capitalize.
* @returns {string} - The capitalized string.
*/
declare function firstCapital(str: string): string;
/**
* String template functionality. Given a string with "text {{var1}} text2 {{var2}}"
* and a state object {var1: 'foo', var2: 'bar'}, it returns a string substituting
* the template variables for their values. "text foo text2 bar"
* The state can be a string, an object, or an array.
* For mode=url, a state array is converted into a list of values separated by commas.
* For mode=url, a state object is converted into query field=value separated by '&'.
* If mode is different from 'url', the state is stringified.
* @param {string} strToResolveVars - The string with variables to be substituted. The string can represent a JSON or URL.
* @param {Record<string, string>} state - The state with the values to substitute the template variables.
* @param {string} [mode] - The mode for converting the state. 'url' for converting state arrays into comma-separated field=value1,value2
* and objects into field=value & field2=value2. If mode is not specified, the state is stringified.
* @returns {string} - The string after substituting the template variables for their corresponding values from the state object.
*/
declare function varSubsDoubleBracket(strToResolveVars: string, state: Record<string, string>, mode?: 'url'): string;
/**
* Converts a query object to a string representation.
* @param {Record<string, string>} query - The query object to convert.
* @returns {string} - The string representation of the query object.
*/
declare function queryObjToStr(query: Record<string, string>): string;
/**
* Converts an Error object to a brief string with stacktrace.
* @param {Error} error - The Error instance to summarize.
* @param {number} [maxStackTraces] - The maximum number of stack traces to include in the summary.
* @returns {string} - A brief string summarizing the error.
*/
declare function summarizeError(error: Error, maxStackTraces?: number): string;
/**
* Custom error class that extends the Error class.
* @class CustomError
* @extends Error
*/
declare class CustomError extends Error {
/**
* Creates an instance of CustomError.
* @param {string} [name='GENERIC'] - The name of the error.
* @param {string} message - The message of the error.
* @param {object} [data={ status: 500 }] - Additional data about the error.
*/
constructor(name?: string, message?: string, data?: { status: number });
data: { status: number };
summarizeError(error: CustomError): string;
}
/**
* Creates a custom error class with the given error name.
* @param {string} errorName - The name of the custom error class.
* @returns {typeof CustomError} - The custom error class.
*/
declare function createCustomErrorClass(errorName: string): {
new (name?: string, message?: string, data?: { status: number }): {
name: string;
data: { status: number };
map(func: (value: any) => any): any;
chain(func: (value: any) => any): any;
message: string;
stack?: string;
};
of: typeof CustomError;
captureStackTrace(targetObject: object, constructorOpt?: (...args: any[]) => any): void;
prepareStackTrace?: (err: Error, stackTraces: NodeJS.CallSite[]) => any;
stackTraceLimit: number;
};
/**
* Checks if a type is a basic type primitive: string, number, boolean, symbol, bigint.
* @param {unknown} variableToCheck - The variable to check.
* @returns {boolean} - true if the type is a basic type primitive, false otherwise.
*/
declare function isBasicType(variableToCheck: unknown): boolean;
/**
* Composes a URL from the gateway URL, service name, and service path.
* @param {string} gatewayUrl - The gateway URL.
* @param {string} serviceName - The service name.
* @param {string} servicePath - The service path.
* @returns {object} - The composed URL object.
*/
declare function urlCompose(gatewayUrl: string, serviceName: string, servicePath: string): {
gatewayUrl: string;
serviceName: string;
servicePath: string;
url: string;
};
/**
* Decomposes a URL into the gateway URL, service name, and service path.
* @param {string} url - The URL to decompose.
* @param {string[]} listOfServiceNames - The list of service names.
* @returns {Array<{ gatewayUrl: string, serviceName: string, servicePath: string }>} - The decomposed URL object.
*/
declare function urlDecompose(url: string, listOfServiceNames: string[]): Array<{ gatewayUrl: string, serviceName: string, servicePath: string }>;
/**
* Returns the index of the nth match of a substring toMatch in the stringToInspect.
* Returns -1 if the nth match is not found.
* @param {string} stringToInspect - The string to inspect in.
* @param {string} toMatch - The substring to match.
* @param {number} nth - The nth number match to find.
* @returns {number} - The index of the nth match.
*/
declare function indexOfNthMatch(stringToInspect: string, toMatch: string, nth: number): number;
/**
* Colors a message with the specified color.
* @param {string} message - The message to color.
* @param {string} color - The color to apply.
* @returns {string} - The colored message.
*/
declare function colorMessage(message: string, color: string): string;
/**
* Colors a message based on the status.
* @param {string} message - The message to color.
* @param {number} status - The status to determine the color.
* @returns {string} - The colored message.
*/
declare function colorMessageByStatus(message: string, status: number): string;
/**
* Gets the color based on the status.
* @param {number} status - The status to determine the color.
* @returns {string} - The color.
*/
declare function colorByStatus(status: number): string;
/**
* Finds the deep key in an object.
* @param {object} objIni - The initial object.
* @param {string} keyToFind - The key to find.
* @returns {Array<[string[], any]>} - The array of found keys and their values.
*/
declare function findDeepKey(objIni: object, keyToFind: string): Array<[string[], any]>;
/**
* Freezes an object deeply.
* @param {object} o - The object to freeze.
* @returns {object} - The frozen object.
*/
declare function deepFreeze<T>(o: T): T;
/**
* Gets the value at the specified path in an object.
* @param {object} obj - The object to get the value from.
* @param {string | string[]} valuePath - The path to the value.
* @returns {any} - The value at the specified path.
*/
declare function getAt(obj: object, valuePath: string | string[]): any;
/**
* Sets the value at the specified path in an object.
* @param {object} obj - The object to set the value in.
* @param {string | string[]} valuePath - The path to the value.
* @param {any} value - The value to set.
* @returns {string} - The result of setting the value.
*/
declare function setAt(obj: object, valuePath: string | string[], value: any): string;
/**
* Replaces array indices in a path string with asterisks.
* For example, converts 'users.0.profiles.0.name' to 'users.*.profiles.*.name'.
* @param {string} path - The path string to process.
* @returns {string} - The path with array indices replaced by asterisks.
*/
declare function pathReplacingArrayIndexWithAsterisk(path: string): string;
/**
* Remove if exists the '$.' indicating the root of the path.
* For example, converts '$.users.0.profiles.0.name' to 'users.0.profiles.0.name'.
* @param {string} path - The path string to process.
* @returns {string} - The path with array indices replaced by asterisks.
*/
declare function stripDollarRoot(path: string): string
/**
* Creates a sorter function to use as a parameter in array.prototype.sort(sorter).
* It can order by several fields. If fields are equal, it will uneven using subsequent fields.
* @param {string | string[]} paths - List of paths to sort by. One path for each field to order by. Route path is of the shape 'person.details.age'. If it is only one field, it can be a string.
* @param {boolean} [isAsc=true] - Optional. Default: true. true: to order ascending. false: to order descending.
* @returns {Function} - A sorter function to include in array.prototype.sort(sorter).
*/
declare function sorterByPaths(paths: string | string[], isAsc?: boolean): (objA: object, objB: object) => number;
/**
* Creates a sorter function to use as a parameter in array.prototype.sort(sorter).
* It can order by several fields and specifying an order by each field.
* @param {string | string[]} paths - List of paths to sort by. One path for each field to order by. Route path is of the shape 'person.details.age'. If it is only one field, it can be a string.
* @param {boolean | boolean[]} [isAsc=true] - Optional. Default: true. true: to order ascending. false: to order descending. You can specify an array [true, false] to order by each field.
* @returns {Function} - A sorter function to include in array.prototype.sort(sorter).
*/
declare function sorterByFields(paths: string | string[], isAsc?: boolean | boolean[]): (objA: object, objB: object) => number;
/**
* Finds the index of a value in a sorted array.
* If value is not found, it returns -1
* @param {Array<string | number | Date>} arr - The sorted array to search in.
* @param {string | number | Date} val - The value to find in the array.
* @returns {number} - The index of the value in the array, or -1 if the value is not found.
*/
declare function findIndexInSortedArray(arr: Array<string | number | Date>, val: string | number | Date): number;
/**
* Finds the index of the specified value in a sorted array or the index of the previous value if the specified value is not found.
* If the value to search for is less than the first value in the array, it returns -1.
* @param {Array<string | number | Date>} arr - The sorted array to search in.
* @param {string | number | Date} val - The value to search for.
* @returns {number} - The index of the specified value in the array, or the index of the previous value if the specified value is not found.
*/
declare function findIndexOrPreviousInSortedArray(arr: Array<string | number | Date>, val: string | number | Date): number;
/**
* Finds the index of the specified value in the sorted array or the next available index if the value is not found.
* If the value to search for is greater than the last value in the array, it returns the length of the array.
* @param {Array<string | number | Date>} arr - The sorted array to search in.
* @param {string | number | Date} val - The value to search for in the array.
* @returns {number} - The index of the value in the array, or the next available index if the value is not found.
*/
declare function findIndexOrNextInSortedArray(arr: Array<string | number | Date>, val: string | number | Date): number;
/**
* Returns the value if it is not undefined, null or NaN. Otherwise, it returns the default value.
* @param {any} value - The value to check.
* @param {any} defaultValue - The default value to return if the value is undefined, null or NaN.
* @returns {any} - The value or the default value.
*/
declare function defaultValue<T>(value: T | undefined | null | number, defaultValue: T): T;
/**
* Filters and maps an array.
* @param {(value: any, index: number, array: any[]) => any} mapWithUndefinedFilterFun - The function to map and filter the array.
* @param {any[]} data - The data to filter and map.
* @returns {any[]} - The filtered and mapped array.
*/
declare function filterFlatMap(mapWithUndefinedFilterFun: (value: any, index: number, array: any[]) => any, data: any[]): any[];
/**
* Sorts an array in ascending or descending order.
* @param {boolean} [isAsc=true] - Optional. Default: true. true: to order ascending. false: to order descending.
* @returns {(a: any, b: any) => number} - A sorter function to use with array.prototype.sort(sorter).
*/
declare function arraySorter(isAsc?: boolean): (a: any, b: any) => number;
/**
* Checks if an object is a Promise.
* @param {any} obj - The object to check.
* @returns {boolean} - true if the object is a Promise, false otherwise.
*/
declare function isPromise(obj: any): boolean;
/**
* Sleeps for the specified number of milliseconds.
* @param {number} ms - The number of milliseconds to sleep.
* @returns {Promise<void>} - A Promise that resolves after the specified number of milliseconds.
*/
declare function sleep(ms: number): Promise<void>;
/**
* Sleeps for the specified number of milliseconds and resolves with the specified value.
* @param {number} ms - The number of milliseconds to sleep.
* @param {T} value - The value to resolve with.
* @returns {Promise<T>} - A Promise that resolves after the specified number of milliseconds with the specified value.
*/
declare function sleepWithValue<T>(ms: number, value: T): Promise<T>;
/**
* Sleeps for the specified number of milliseconds and executes the specified function with the specified parameters.
* @param {number} ms - The number of milliseconds to sleep.
* @param {Function} func - The function to execute.
* @param {...any} params - The parameters to pass to the function.
* @returns {Promise<any>} - A Promise that resolves after the specified number of milliseconds with the result of the function.
*/
declare function sleepWithFunction(ms: number, func: (...args: any[]) => any, ...params: any[]): Promise<any>;
/**
* Negates a function.
* @param {Function} funct - The function to negate.
* @returns {Function} - The negated function.
*/
declare function notTo(funct: (...params: any[]) => boolean): (...params: any[]) => boolean;
/**
* Converts an array to an object using the specified default value function.
* @param {any[]} arr - The array to convert.
* @param {(current: any, index: number) => any} defaultValueFunction - The function to generate the default value.
* @returns {object} - The converted object.
*/
declare function arrayToObject(arr: any[], defaultValueFunction: (current: any, index: number) => any): object;
/**
* Converts an array of objects to an object.
* @param {any[]} iterable - The array of objects to convert.
* @returns {object} - The converted object.
*/
declare function arrayOfObjectsToObject(iterable: any[]): object;
/**
* Removes duplicates from an array.
* @param {any[]} arr - The array to remove duplicates from.
* @returns {any[]} - The array without duplicates.
*/
declare function removeDuplicates(arr: any[]): any[];
/**
* Traverses an object and applies a reviver function to each node.
* @param {object} objIni - The object to traverse.
* @param {(value: any, path: string[], parent: any, prop: string) => any} reviver - The function to be called for each node.
* @param {boolean} [pureFunction=true] - true: work with a deep clone of objIni, false: work with objIni passed as a parameter.
* @returns {object} - The object after applying the reviver actions.
*/
declare function traverse(objIni: object, reviver: (value: any, path: string[], parent: any, prop: string) => any, pureFunction?: boolean): object;
/**
* Takes vertical slices of a two-nested array and calls a function with each slice.
* @param {(verticalSlice: object[], runIndex: number) => any} functionToRun - The function to run with each vertical slice.
* @param {string[]} verFields - The fields inside each item of the traverse array that contains the second nested arrays to iterate vertically.
* @param {object[]} toTraverse - The array to traverse.
* @returns {void}
*/
declare function traverseVertically(functionToRun: (verticalSlice: object[], runIndex: number) => any, verFields: string[], toTraverse: object[]): void;
/**
* Projects a subset of a JSON object based on specified paths, optionally removing properties marked for deletion.
*
* @param {string[]} paths - An array of strings representing the paths to the properties in the JSON object that should be included in the output.
* @param {object} json - The JSON object from which the properties specified by paths will be extracted.
* @param {boolean} [removeWithDelete=true] - A boolean indicating whether properties in the JSON object marked with a specific delete flag should be removed from the output. Defaults to true, meaning properties marked for deletion will be removed.
*
* @returns {object} - A new JSON object containing only the properties specified by the paths array. If removeWithDelete is true, any properties marked for deletion will not be included in the returned object.
*
* @example
* // Assuming a JSON object `data` as follows:
* // {
* // user: {
* // name: "John Doe",
* // age: 30,
* // email: "johndoe@example.com",
* // _delete: { email: true }
* // }
* // }
* // And calling the function with paths to include the user's name and email:
* project(['user.name', 'user.email'], data);
* // Returns: { user: { name: "John Doe" } }
* // Note: The email property is not included in the output because it's marked for deletion.
*/
declare function project(paths: string[], json: any): any
/**
* Given objDest and shouldUpdateOnlyEmptyFields generates function that expect inputObj to copy all properties from inputObj to objDest.
*
* @param {Object} objDest Destination object for the copy.
* @param {boolean} shouldUpdateOnlyEmptyFields? true: does not replace destination fields with values.
* @example
* // returns {isin:123456, name:'test'}
* copyPropsWithValue({isin:123456}, true)({isin:123, name:'test'});
* // returns {isin:123, name:'test'}
* copyPropsWithValue({isin:123456}, false)({isin:123, name:'test'});
* @returns {Function} A function that takes an input object for props to be copied in objDest.
*/
declare function copyPropsWithValue(objDest: any, shouldUpdateOnlyEmptyFields?: boolean): (inputObj: any) => any;
/**
* Given objDest, copyRules and shouldUpdateOnlyEmptyFields generates function that expect input object to copy only properties indicated by copyRules from inputObj to objDest.
*
* @param {Object} objDest - The destination object to copy properties into.
* @param {Array<string|Object>} copyRules - An array of rules specifying which properties to copy.
* Each rule can be either a string (for same-named properties) or an object with 'from' and 'to' keys.
* @param {boolean} [shouldUpdateOnlyEmptyFields=false] - If true, only update fields in the destination object that are empty.
* @returns {Function} A function that takes an input object for props to be copied in objDest.
*
* @example
* let objTo = {a:{b:2},c:3};
* let objFrom = {a:{b:4},c:8,d:{e:{f:12}}};
* copyPropsWithValueUsingRules(objTo, [{from:'a.b', to:'c'}, {from:'d.e.f', to:'d'}])(objFrom);
* // objTo is now {a:{b:2},c:4,d:12}
*
* @example
* let objTo = {a:{b:2},c:3};
* let objFrom = {a:{b:4},c:8,d:{e:{f:12}}};
* copyPropsWithValueUsingRules(objTo, [{from:'a.b', to:'c'}, {from:'d.e.f', to:'d.f'}, {from:'d.e.g', to:'d.g'}], true)(objFrom);
* // objTo is now {a:{b:2},c:3,d:{f:12}}
*/
declare function copyPropsWithValueUsingRules(objDest: any, copyRules: any, shouldUpdateOnlyEmptyFields?: boolean): (inputObj: any) => any;
declare class EnumMap {
/**
* Emulates Enums in JavaScript.
* @param {string[] | [BasicType, any][] | {[key: BasicType]: any}[] | Map<BasicType, any>} values - The values to initialize the EnumMap with.
* @example
* ```
* const DAYS = new EnumMap(['SUNDAY', 'MONDAY', 'TUESDAY', 'WEDNESDAY', 'THURSDAY', 'FRIDAY', 'SATURDAY']);
* DAYS.SUNDAY //? 0
* DAYS.SATURDAY //? 6
* const NUM_TO_DAY = DAYS.invert()
* NUM_TO_DAY[0] //? 'SUNDAY'
* ```
*/
constructor(values: any | Map<any, any> | [string, any][] | {[key: string]: any}[]);
/**
* Inverts the EnumMap. values are the key, and the keys are the values.
* @returns {EnumMap} The active enum value.
* @example
* ```
* const DAYS = new EnumMap(['SUNDAY', 'MONDAY', 'TUESDAY', 'WEDNESDAY', 'THURSDAY', 'FRIDAY', 'SATURDAY']);
* const NUM_TO_DAY = DAYS.invert()
* NUM_TO_DAY[0] //? 'SUNDAY'
*/
invert(): EnumMap;
}
declare class Enum {
/**
* Creates an instance of Enum.
* @param {Array<string>} values - The values of the enum.
* @param {object} rules - The rules defining valid transitions between enum values.
*/
constructor(values: Array<string>, rules: object);
/**
* A Proxy handler method for getting a property value.
*/
get: (_target: any, prop: any) => any;
/**
* A Proxy handler method for setting a property value.
*/
set: (_undefined: any, prop: any, value: any) => boolean;
/**
* Gets the current active value of the enum.
* @returns {string} The active enum value.
*/
getValue: () => string;
}
/**
* Creates a state machine transition function.
* @param {object} states - The states of the state machine.
* @param {object} events - The events of the state machine.
* @param {object} transitions - The transitions of the state machine.
* @returns {Function} A function that transitions the state machine.
*/
declare function transition(states: any, events: any, transitions: any): {
(event: any): any;
valueOf(): any;
};
/**
* Pushes a unique key into a table.
* @param row
* @param table
* @param indexes
* @returns
* @example
* ```
* pushUniqueKey({id: 1, name: 'John'}, [{id: 1, name: 'John'}], [0]) //?
* ```
* This will produce
* ```
* [{id: 1, name: 'John'}]
* ```
*/
declare function pushUniqueKey(row: any, table: any[], indexes?: number[]): any;
/**
* Pushes a unique key into a table or changes the existing row.
* @param newRow
* @param table
* @param indexes
* @param mergeFun
* @returns
* @example
* ```
* pushUniqueKeyOrChange({id: 1, name: 'John'}, [{id: 1, name: 'John'}], [0], (oldRow, newRow) => ({...oldRow, ...newRow})) //?
* ```
* This will produce
* ```
* [{id: 1, name: 'John'}]
* ```
*/
declare function pushUniqueKeyOrChange(newRow: any, table: any, indexes: number[], mergeFun: any): any;
/**
* Pushes a value at a given position in an array.
* @param pos
* @param value
* @param arr
* @returns
* @example
* ```
* pushAt(1, 'a', ['b', 'c']) //?
* ```
* This will produce
* ```
* ['b', 'a', 'c']
* ```
*/
declare function pushAt(pos: any, value: any, arr: any): any;
/**
* Memoizes a function.
* @returns
* @example
* ```
* const memoizeMap = memoize().memoizeMap;
* const memoizeWithHashFun = memoize().memoizeWithHashFun;
* ```
*/
declare function memoize(): {
memoizeMap: (func: any, ...params: any[]) => any;
memoizeWithHashFun: (func: any, hashFunc: any, ...params: any[]) => any;
};
/**
* Fills an array with a given value.
* @param mapper
* @param lenOrWhileTruthFun
* @returns
* @example
* ```
* fillWith('a', 3) //?
* ```
* This will produce
* ```
* ['a', 'a', 'a']
* ```
*/
declare function fillWith(mapper: any, lenOrWhileTruthFun: any): any[];
/**
* Number to string with fixed integer and decimals
* @param num - The number to convert.
* @param intLength - The length of the integer part.
* @param decLength - The length of the decimal part.
* @returns The number as a string with fixed integer and decimal parts.
* @example
* ```
* numberToFixedString(123.456, 5, 2) //?
* ```
* This will produce
* ```
* '00123.46'
*/
declare function numberToFixedString(num:number, intLength:number, decLength:number): string;
type Month = '01' | '02' | '03' | '04' | '05' | '06' | '07' | '08' | '09' | '10' | '11' | '12';
type Day = '01' | '02' | '03' | '04' | '05' | '06' | '07' | '08' | '09' | '10' | '11' | '12' | '13' | '14' | '15' | '16' | '17' | '18' | '19' | '20' | '21' | '22' | '23' | '24' | '25' | '26' | '27' | '28' | '29' | '30' | '31';
type Separator = '/' | '-'
type StringDate = `${number}${Separator}${Month}${Separator}${Day}${string}`;
/**
* Checks if a value is a valid Date: instance of Date and not NaN.
* @param value - The value to check.
* @returns Returns `true` if it is valid date, `false` otherwise.
*/
declare function isDate(d: any): boolean;
/**
* Checks if a value is empty: undefined, null, '', 0, 0n, NaN, [], {}
* Empty differs from falsy as we have added: [] and {} that are truthy And removed: false
* @param value - The value to check.
* @returns Returns `true` if the value is empty, `false` otherwise.
*/
declare function isEmpty(value: any): boolean;
/**
* Checks if a value is a string and a date.
* @param stringDate - The string to check.
* @returns Returns `true` if the string is a date, `false` otherwise.
*/
declare function isStringADate(stringDate: string): boolean;
/**
* Formats a date.
* @param format - The format of the date.
* @param date - The date to format.
* @returns The formatted date.
*/
declare function formatDate(format: any, date?: Date | StringDate | number): string | undefined;
/**
* Formats a date.
* @param format - The format of the date.
* @returns A function that formats a date.
*/
declare function dateFormatter(format: string): (date: Date | StringDate | number) => string | undefined;
/**
* Represents the days of the week.
* @type {EnumMap}
* @example
* ```
* DAYS.SUNDAY //? 0
* DAYS.SATURDAY //? 6
* DAYS.next(DAYS.SATURDAY) //? 0
* const NUM_TO_DAY = DAYS.invert()
* NUM_TO_DAY[0] //? 'SUNDAY'
* NUM_TO_DAY[6] //? 'SATURDAY'
* ```
*/
declare const DAYS: EnumMap;
/**
* Convert a string without timezone as UTC time returning the number representing the date in ms
* @param date - The date string to convert.
* @returns a number representing the date in ms.
*/
declare function YYYY_MM_DD_hh_mm_ss_ToUtcDate(dateYYYY_MM_DD_hh_mm_ss: string): number;
/**
* Converts a date object to an object.
* @param date - The date object to convert.
* @returns An object literal with numeric properties representing the date.
*/
declare function dateToObj(date: Date | StringDate | number): {
YYYY: number;
MM: number;
DD: number;
hh: number;
mm: number;
ss: number;
mil: number;
} | undefined;
/**
* Day difference between to dates.
* @param date - The date object to convert.
* @returns A number with the difference in days between endDate and iniDate.
*/
declare function diffInDaysYYYY_MM_DD(iniDate: Date | StringDate | number, endDate: Date | StringDate | number): number;
/**
* Adds days to a date.
* @param daysToSubtract - The number of days to add.
* @param date - The date to add days to.
* @returns The date with the added days.
*/
declare function addDays(daysToSubtract: number, date: Date | StringDate | number): Date;
/**
* Subtracts days from a date.
* @param daysToSubtract - The number of days to subtract.
* @param date - The date to subtract days from.
* @returns The date with the subtracted days.
*/
declare function subtractDays(daysToSubtract: number, date: Date | StringDate | number): Date;
/**
* Returns the closest to param date that could be equal or less and that is of a specific dayOfWeek: 0:monday to 6:Sunday.
* @param dayOfWeek - The day of the week. 0: Sunday, 1: Monday, 2: Tuesday, 3: Wednesday, 4: Thursday, 5: Friday, 6: Saturday.
* @param date - The date subject to calculation. If the date requested correspond to the dayOfWeek, the same input date is returned.
* @returns The calculated date.
*/
declare function previousDayOfWeek(dayOfWeek: 0 | 1 | 2 | 3 | 4 | 5 | 6, date: Date | StringDate | number): Date;
/**
* Returns the closest to param date that could be equal or great and that is of a specific dayOfWeek: 0:monday to 6:Sunday.
* @param dayOfWeek - The day of the week. 0: Sunday, 1: Monday, 2: Tuesday, 3: Wednesday, 4: Thursday, 5: Friday, 6: Saturday.
* @param date - The date subject to calculation. If the date requested correspond to the dayOfWeek, the same input date is returned.
* @returns The calculated date.
*/
declare function nextDayOfWeek(dayOfWeek: 0 | 1 | 2 | 3 | 4 | 5 | 6, date: Date | StringDate | number): Date;
/**
* Returns the date in the current week Monday to Sunday that is of a specific day 1:Monday...6:Saturday,0:Sunday
* @param dayOfWeek - The day of the week. 0: Sunday, 1: Monday, 2: Tuesday, 3: Wednesday, 4: Thursday, 5: Friday, 6: Saturday.
* @param date - The date subject to calculation. If the date requested correspond to the dayOfWeek, the same input date is returned.
* @returns The calculated date.
*/
declare function dayOfWeek(dayOfWeek: 0 | 1 | 2 | 3 | 4 | 5 | 6, date: Date | StringDate | number): Date;
/**
* Gets the same date or the previous Friday for weekends.
* @param date - The date to get the same date or the previous Friday.
* @returns The same date or the previous Friday.
*/
declare function getSameDateOrPreviousFridayForWeekends(date: Date | StringDate | number): Date;
/**
* Checks if a date is midnight.
* @param date - The date to check.
* @returns Returns `true` if the date is midnight, `false` otherwise.
*/
declare function isDateMidnight(date: Date):boolean | undefined;
/**
* Sets a date to midnight.
* @param date - The date to set to midnight.
* @returns The date set to midnight.
*/
declare function setDateToMidnight(date: Date | StringDate | number): Date;
/**
* Replaces all occurrences of a substring in a string.
* @param str - The string to replace the substring in.
* @param fromTo - The substring to replace and the new substring.
* @returns The string with the replaced substring.
*/
declare function replaceAll(str: any, ...fromTo: any[]): any;
/**
* Cleans a string by removing all non-alphanumeric characters.
* @param str - The string to clean.
* @returns The cleaned string.
*/
declare function cleanString(str: any): any;
/**
* Repeats a function a specified number of times.
* @param numberOfTimes - The number of times to repeat the function.
* @returns An object with functions to repeat the function.
*/
declare function repeat(numberOfTimes: any): {
times: (funToRepeat: (index?:number)=>any) => any[];
awaitTimes: (funToRepeat: (index?:number)=>any) => Promise<any[]>;
breakNextIteration: () => void;
value: (value: any) => any[];
};
interface CallReset {
reset: (callAtTheBegginingParam?: boolean) => void;
stop: () => void;
}
type OneInReturnType = {
call<T extends (...args: any[]) => any>(runFunc: T): ((...args: Parameters<T>) => ReturnType<T> | undefined) & CallReset;
};
/**
* Calls a function one in a specified period. It allows to .reset() the counter, .stop() the counter, or to .setCount(newCount) manually
* @param {number} period - The period in which the function can only be called once.
* @returns {{ call: (runFunc: Function) => { (...args: any[]): any; reset: () => void; stop: () => void; setCount: (newCount: number) => void; } }}
*
* @example
* ```
* const myTraceLog = (logPrefix) => console.log(`${logPrefix} Called`);
* const callEvery1000 = oneIn(1000).call(myTraceLog);
*
* callEvery1000('LOG: '); // Call the function
* callEvery1000.toReset(); // Reset the counter
* callEvery1000.toStop(); // Don't call any longer
* callEvery1000.setCount(5); // to Call one In 5 times
* ```
*/
declare function oneIn(period: number, callAtTheBeggining?: boolean): OneInReturnType;
declare function loopIndexGenerator(initValue: any, iterations: any): Generator<any, void, unknown>;
/**
* Retries a function with a sleep time between each retry.
* @template T The type of the parameters for the function to run.
* @param times The number of times to retry the function.
* @param updateSleepTimeFun A function that updates the sleep time between retries.
* @param funToRun The function to run.
* @param funToRunParams The parameters for the function to run.
* @param {function} shouldStopRetrying The function that determines whether to stop retrying based on the result of the function.
* @param {string} logString The fields that the caller to retry wants the retry to Log to show traceability.
* @returns A Promise that resolves with the result of the function.
*/
declare function retryWithSleep<T>(
times: number,
updateSleepTimeFun: ((currentSleepTime: number, index: number) => number) | ((currentSleepTime: number) => number) | (() => number),
funToRun: (...params: T[]) => any,
funToRunParams: T[] | undefined,
shouldStopRetrying?: (result?: any) => boolean,
logString?: string
): Promise<any>;
/**
* Processes the exit with the given error.
* @param error - The error object.
*/
declare function processExit(error: any): void;
declare const log: any;
declare namespace RE {
export { groupByWithCalc };
export { innerRightJoinWith };
export { unionWithHashKeys };
export { updateWithHashKeys };
export { between };
export { matchByPropId };
export { splitCond };
export { filterMap };
export { mapWithNext };
export { mapWithPrevious };
export { partialAtPos };
export { pipeWithChain };
export { pipe };
export { pipeWhile };
export { parallel };
export { runFutureFunctionsInParallel };
export { runFunctionsSyncOrParallel };
export { pickPaths };
export { mergeArrayOfObjectsRenamingProps };
export { RLog };
export { findSolution };
export { something };
export { uncurry };
}
/**
* Calculate the new value for the acum and current of the match.
* @param acum first value always start with undefined. then it
* will have the accumulation. Use (acum??0) for safety.
* @param current value of the field to merge.
*/
declare function mergeFields(acum?:any,current?:any, acumRow?:any, currentRow?:any):any
type mergeFieldsType = typeof mergeFields
interface objCalc {
[fieldCalc:string]: mergeFieldsType
}
/**
* Group the records that using the hash(row) as input produces
* the same key and apply fied calculations using each field of
* the calc object.
* @param groupBy hash function of the input row
* @param mergeFieldsObject Object with fields and how to calculate the new value
*/
declare function groupByWithCalc(
groupBy:(row:any)=>any,
calc:objCalc
):(data:any[]) => any[]
/**
* Returns true if records need to be merged
* @param leftRow row form left data to match
* @param rightRow row from right data to match
* @return true if merge is required
*/
declare function leftRightMatchingD(leftRow?:any, rightRow?:any):boolean
/**
* update matched records
* @param key each of the fields for a match record
* @param leftValue left value of the key
* @param rightValue right value of the key
* @return the new value to be assigned to the key
*/
declare function updateD(key?:string, leftValue?:any, rightValue?:any):any
/**
* introduce the rightData to join
* @param rightData each of the fields for a match record
* @return the final result for the innerRightJoinWith
*/
declare function injectRightDataD(rightData:any[]):any[]
declare function injectLeftData(leftData:any[]):typeof injectRightDataD
/**
* Right join using condition and merge function by keys.
* Response will be for each record in the right will be match with 1..N records in the left.
* Left record that dont match will not be present in the response.
* Each record will be composed of the sum of fields from right and left.
* If there are coincident field names. the update function will be called to resolve the value.
* If update is not present, the default behaviour will be to choose the value from right.
* last chain function call is to introduce right Data.
* @param leftRightMatching matchinf function
* @param update update function
* @param leftData leftData
* @return a function ready to receive rightData
*/
declare function innerRightJoinWith(
leftRightMatching:typeof leftRightMatchingD,
update:undefined | typeof updateD,
leftData:any[]
):typeof injectRightDataD
/**
* Right join using condition and merge function by keys.
* Data is introduce calling in sequence 3 times first
* the params 2nd with left data and 3rd with right data.
* @param leftRightMatching matchinf function
* @param update update function
* @return a function ready to receive rightData that when
* invoke returns a function ready to receive leftData. Last
* invaction with leftData will get the final result.
*/
declare function innerRightJoinWith(
leftRightMatching:typeof leftRightMatchingD,
update:typeof updateD
):typeof injectLeftData
/**
* Add input rows which hash is not present in the target
* duplicates in the target will be deleted keeping the last row.
* @param isAsc undefined: does not order. true: return result in asc order. false: in desc order
* @param hashAddNoDups hash function for the input data
* @param addNoDupsToTheEnd input data
* @param hashMaster hash function for the target data
* @param master target data
*/
declare function unionWithHashKeysUnc<T,P>(
isAsc: boolean|undefined,
hashAddNoDups: (elem: T) => string,
addNoDupsToTheEnd: T[],
hashMaster: (elem: P) => string,
master: P[]
): (T|P)[];
/**
* Add input rows which hash is not present in the target
* duplicates in the target will be deleted keeping the last row.
* @param isAsc undefined: does not order. true: return result in asc order. false: in desc order
* @param hashAddNoDups hash function for the input data
* @param addNoDupsToTheEnd input data
* @param hashMaster hash function for the target data
* @return a function ready to receive the target data
*/
declare function unionWithHashKeys<Source,Target>(
isAsc: boolean|undefined,
hashAddNoDups: (elem: Source) => string,
addNoDupsToTheEnd: Source[],
hashMaster: (elem: Target) => string,
):(master: Target[]) => (Target|Source)[];
/**
* Given the input records will replace the target matched records. To match the records
* specific hash functions for each data set are provided and executed.
* @param isAsc undefined: does not order. true: return result in asc order. false: in desc order
* @param getHashNewRecords hash function for the input data
* @param newRecords input data
* @param getHashOldRecords hash function for the target data
* @return a function ready to receive the target data
*/
declare function updateWithHashKeys<NewRecord, OldRecord>(
isAsc: boolean | undefined,
getHashNewRecords: (elem: NewRecord) => string,
newRecords: NewRecord[],
getHashOldRecords: (elem: OldRecord) => string
): (oldRecords: OldRecord[]) => (NewRecord | OldRecord)[]
declare const between: any;
declare const matchByPropId: any;
declare const splitCond: any;
declare function filterMap<T,U>(filterFun:(el:T, index:number, data:T[])=>unknown, mapFun:(el:T,index:number, data:T[])=>U, data:T[]): U[];
declare const mapWithNext: any;
declare const mapWithPrevious: any;
/**
* Exclude elements of the subject Array that matches
* the valuesToRemove.
* You can specify the field in both Arrays for the match.
* a field with value undefined will math using the value instead
* of the values of the property indicated by the field
*/
declare function exclude<T>(fieldToRemove:string|undefined, valuesToRemove: any[], fieldSubject:string|undefined, subjectArray:T[]):T[];
declare function pipeWithChain(...func: any[]): (...params: any[]) => any;
declare function pipe(...func: any[]): (...params: any[]) => any;
declare function pipeWhile(funCond: any, ini: any): (...funcs: any[]) => (...inputs: any[]) => any;
declare function parallel(numberOfthreads?: number): (futuresOrValues: any) => F.FutureInstance<any, any[]>;
declare function runFutureFunctionsInParallel(numberOfThreads?: number): (functionsToRunInParallel: any) => (data: any) => F.FutureInstance<any, any[]>;
declare function runFunctionsSyncOrParallel(numberOfThreads?: number): (functionsToRun: any) => (data: any) => any;
declare function RLog(prefix: any): (...obj: any[]) => any;
declare function findSolution(solutionToFind: any, solutions: any): any;
declare function something(lib: any): (...args: any[]) => any;
declare const pickPaths: any;
declare const mergeArrayOfObjectsRenamingProps: any;
declare function uncurry(withLog?: boolean): (funcParam: any) => (...args: any[]) => any;
declare function partialAtPos(fun: any, pos: any): (...paramValues: any[]) => any;
type PlanOptions = {
numberOfThreads?: number;
mockupsObj?: object;
};
type Plan = {
/**
* ```plainText
* |-> fun2A -> fun3-|
* fun1 --| |-> fun5
* |-> fun2B -> fun4-|
*
* ```
*
* ```javascript
* const myCalc = plan().build([
* fun1,
* [fun2A, fun3],
* [fun2B, fun4],
* fun5
* ])
* ```
*/
build: (planDef: any[]) => (...args: any[]) => any;
/**
* plan utility function to wrap a function to use in a plan pipeline. The tipical scenario for using this is:
* ```javascript
* plan().build(
* [
* queryAllCustomersWithBalanceGreatThan2000,
* map(fetchAddres, 5) // mapThreads = 5
* ]
* )
* ```
* As queryAllCustomersWithBalanceGreatThan2000 could return 50k customers. We could be banned for the fetchAddress API.
* so we need to call in batch of 5 calls. This does not affect the the default value numberOfThreads=Infinity for the
* rest of the pipeline.
* @param fun function to apply to every element of the input.
* @param mapThreads The functions will be run in batchs of size mapThreads.
* @returns a function that can be included in the pipeline.
*/
map: (fun: (data: any ) => any, mapThreads?: number) => (data: any) => any[];
identity: <T>(param: T) => T;
};
/**
* ```plainText
* |-> fun2A -> fun3-|
* fun1 --| |-> fun5
* |-> fun2B -> fun4-|
*
* ```
* ```javascript
* const myCalc = plan().build([
* fun1,
* [fun2A, fun3],
* [fun2B, fun4],
* fun5
* ])
*
* myCalc(3).then(result => console.log(result))
* ```
*
* @param options: { numberOfThreads: 3 (default Infinity)
* , mockupsObj {fun1:3,fun5:Promise.resolve(4)}} (substitute the function for a value) }
* @return An object with two method functions: build, plan
*/
declare function plan(options?: PlanOptions): Plan;
declare function sanitize(obj: any, sanitizers: string[], noSanitzedUptoLogLevel: any): any;
declare function lengthSanitizer(_: any, value: any): string;
declare function bearerSanitizer(_: any, bearerToken: any): string;
type AddColumn = ({ type, id, title }: { type: any; id: any; title: any }) => AddColumnReturn
type AddColumnReturn = {
addColumn: AddColumn
draw: Draw
}
type Draw = () => string
type TableReturn = {
addColumn: AddColumn
auto: () => { draw: Draw }
}
/**
* stringify data in a tabular format so you can log it with:
* console.log(Table(data).auto().draw())
* You can use two modes. Using auto as above gives a log
* similar to console.table(data).
* Using addColumns you select the fields and specify the format
* console.log(Table(data).
* .addColumn({ type: Text(), id: 'event', title: 'Events' })
* .addColumn({ type: Timeline(), id: 'intervals' }).draw())
* .draw())
* @param data The data to draw in the console.
* @returns .
*/
declare function Table(data: any): TableReturn
declare function center(text: any, size: any): any;
declare function left(text: any, size: any): any;
declare function Text({ HEADING_IDENTATION, ROW_IDENTATION }?: {
HEADING_IDENTATION: typeof center;
ROW_IDENTATION: typeof left;
}): {
loadParams: (paramId: any) => (paramTitle: any) => {
id: any;
load: (columnData: any) => void;
getSize: () => any;
heading: {
nextValue: () => Generator<any, void, unknown>;
};
row: {
nextValue: () => Generator<any, void, unknown>;
};
};
};
declare function Timeline(): {
loadParams: (paramId: any) => (paramTitle: any) => {
id: any;