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; 
 | 
} 
 |