const { isArray } = Array;
|
const { getPrototypeOf, prototype: objectProto, keys: getKeys } = Object;
|
|
/**
|
* Used in functions where either a list of arguments, a single array of arguments, or a
|
* dictionary of arguments can be returned. Returns an object with an `args` property with
|
* the arguments in an array, if it is a dictionary, it will also return the `keys` in another
|
* property.
|
*/
|
export function argsArgArrayOrObject<T, O extends Record<string, T>>(args: T[] | [O] | [T[]]): { args: T[]; keys: string[] | null } {
|
if (args.length === 1) {
|
const first = args[0];
|
if (isArray(first)) {
|
return { args: first, keys: null };
|
}
|
if (isPOJO(first)) {
|
const keys = getKeys(first);
|
return {
|
args: keys.map((key) => first[key]),
|
keys,
|
};
|
}
|
}
|
|
return { args: args as T[], keys: null };
|
}
|
|
function isPOJO(obj: any): obj is object {
|
return obj && typeof obj === 'object' && getPrototypeOf(obj) === objectProto;
|
}
|