import { StateObject } from '../state/stateObject'; export declare const root: any; export declare const fromJson: any; export declare const toJson: any; export declare const forEach: any; export declare const extend: typeof _extend; export declare const equals: any; export declare function identity(x: any): any; export declare function noop(): any; export type Mapper = (x: X, key?: string | number) => T; export interface TypedMap { [key: string]: T; } export type Predicate = (x?: X) => boolean; export type PredicateBinary = (x?: X, y?: Y) => boolean; /** * An ng1-style injectable * * This could be a (non-minified) function such as: * ```js * function injectableFunction(SomeDependency) { * * } * ``` * * or an explicitly annotated function (minify safe) * ```js * injectableFunction.$inject = [ 'SomeDependency' ]; * function injectableFunction(SomeDependency) { * * } * ``` * * or an array style annotated function (minify safe) * ```js * ['SomeDependency', function injectableFunction(SomeDependency) { * * }]; * ``` */ export type IInjectable = Function | any[]; export interface Obj extends Object { [key: string]: any; } /** * Builds proxy functions on the `to` object which pass through to the `from` object. * * For each key in `fnNames`, creates a proxy function on the `to` object. * The proxy function calls the real function on the `from` object. * * * #### Example: * This example creates an new class instance whose functions are prebound to the new'd object. * ```js * class Foo { * constructor(data) { * // Binds all functions from Foo.prototype to 'this', * // then copies them to 'this' * bindFunctions(Foo.prototype, this, this); * this.data = data; * } * * log() { * console.log(this.data); * } * } * * let myFoo = new Foo([1,2,3]); * var logit = myFoo.log; * logit(); // logs [1, 2, 3] from the myFoo 'this' instance * ``` * * #### Example: * This example creates a bound version of a service function, and copies it to another object * ``` * * var SomeService = { * this.data = [3, 4, 5]; * this.log = function() { * console.log(this.data); * } * } * * // Constructor fn * function OtherThing() { * // Binds all functions from SomeService to SomeService, * // then copies them to 'this' * bindFunctions(SomeService, this, SomeService); * } * * let myOtherThing = new OtherThing(); * myOtherThing.log(); // logs [3, 4, 5] from SomeService's 'this' * ``` * * @param source A function that returns the source object which contains the original functions to be bound * @param target A function that returns the target object which will receive the bound functions * @param bind A function that returns the object which the functions will be bound to * @param fnNames The function names which will be bound (Defaults to all the functions found on the 'from' object) * @param latebind If true, the binding of the function is delayed until the first time it's invoked */ export declare function createProxyFunctions(source: Function, target: Obj, bind: Function, fnNames?: string[], latebind?: boolean): Obj; /** * prototypal inheritance helper. * Creates a new object which has `parent` object as its prototype, and then copies the properties from `extra` onto it */ export declare const inherit: (parent: Obj, extra?: Obj) => any; /** Given an array, returns true if the object is found in the array, (using indexOf) */ export declare const inArray: typeof _inArray; export declare function _inArray(array: any[], obj: any): boolean; export declare function _inArray(array: any[]): (obj: any) => boolean; /** * Given an array, and an item, if the item is found in the array, it removes it (in-place). * The same array is returned */ export declare const removeFrom: typeof _removeFrom; export declare function _removeFrom(array: T[], obj: T): T[]; export declare function _removeFrom(array: T[]): (obj: T) => T[]; /** pushes a values to an array and returns the value */ export declare const pushTo: typeof _pushTo; export declare function _pushTo(arr: T[], val: T): T; export declare function _pushTo(arr: T[]): (val: T) => T; /** Given an array of (deregistration) functions, calls all functions and removes each one from the source array */ export declare const deregAll: (functions: Function[]) => void; /** * Applies a set of defaults to an options object. The options object is filtered * to only those properties of the objects in the defaultsList. * Earlier objects in the defaultsList take precedence when applying defaults. */ export declare function defaults(opts: any, ...defaultsList: Obj[]): any; /** Reduce function that merges each element of the list into a single object, using extend */ export declare const mergeR: (memo: Obj, item: Obj) => any; /** * Finds the common ancestor path between two states. * * @param {Object} first The first state. * @param {Object} second The second state. * @return {Array} Returns an array of state names in descending order, not including the root. */ export declare function ancestors(first: StateObject, second: StateObject): StateObject[]; /** * Return a copy of the object only containing the whitelisted properties. * * #### Example: * ``` * var foo = { a: 1, b: 2, c: 3 }; * var ab = pick(foo, ['a', 'b']); // { a: 1, b: 2 } * ``` * @param obj the source object * @param propNames an Array of strings, which are the whitelisted property names */ export declare function pick(obj: Obj, propNames: string[]): Obj; /** * Return a copy of the object omitting the blacklisted properties. * * @example * ``` * * var foo = { a: 1, b: 2, c: 3 }; * var ab = omit(foo, ['a', 'b']); // { c: 3 } * ``` * @param obj the source object * @param propNames an Array of strings, which are the blacklisted property names */ export declare function omit(obj: Obj, propNames: string[]): Obj; /** Given an array of objects, maps each element to a named property of the element. */ export declare function pluck(collection: Obj[], propName: string): T[]; /** Given an object, maps each property of the object to a named property of the property. */ export declare function pluck(collection: { [key: string]: any; }, propName: string): { [key: string]: any; }; /** Given an array of objects, returns a new array containing only the elements which passed the callback predicate */ export declare function filter(collection: T[], callback: (t: T, key?: number) => boolean): T[]; /** Given an object, returns a new object with only those properties that passed the callback predicate */ export declare function filter(collection: TypedMap, callback: (t: T, key?: string) => boolean): TypedMap; /** Given an object, return the first property of that object which passed the callback predicate */ export declare function find(collection: TypedMap, callback: Predicate): T; /** Given an array of objects, returns the first object which passed the callback predicate */ export declare function find(collection: T[], callback: Predicate): T; /** Given an object, returns a new object, where each property is transformed by the callback function */ export declare let mapObj: (collection: { [key: string]: T; }, callback: Mapper, target?: typeof collection) => { [key: string]: U; }; /** Given an array, returns a new array, where each element is transformed by the callback function */ export declare function map(collection: T[], callback: Mapper, target?: typeof collection): U[]; export declare function map(collection: { [key: string]: T; }, callback: Mapper, target?: typeof collection): { [key: string]: U; }; /** * Given an object, return its enumerable property values * * @example * ``` * * let foo = { a: 1, b: 2, c: 3 } * let vals = values(foo); // [ 1, 2, 3 ] * ``` */ export declare const values: (obj: TypedMap) => T[]; /** * Reduce function that returns true if all of the values are truthy. * * @example * ``` * * let vals = [ 1, true, {}, "hello world"]; * vals.reduce(allTrueR, true); // true * * vals.push(0); * vals.reduce(allTrueR, true); // false * ``` */ export declare const allTrueR: (memo: boolean, elem: any) => any; /** * Reduce function that returns true if any of the values are truthy. * * * @example * ``` * * let vals = [ 0, null, undefined ]; * vals.reduce(anyTrueR, true); // false * * vals.push("hello world"); * vals.reduce(anyTrueR, true); // true * ``` */ export declare const anyTrueR: (memo: boolean, elem: any) => any; /** * Reduce function which un-nests a single level of arrays * @example * ``` * * let input = [ [ "a", "b" ], [ "c", "d" ], [ [ "double", "nested" ] ] ]; * input.reduce(unnestR, []) // [ "a", "b", "c", "d", [ "double, "nested" ] ] * ``` */ export declare const unnestR: (memo: any[], elem: any[]) => any[]; /** * Reduce function which recursively un-nests all arrays * * @example * ``` * * let input = [ [ "a", "b" ], [ "c", "d" ], [ [ "double", "nested" ] ] ]; * input.reduce(unnestR, []) // [ "a", "b", "c", "d", "double, "nested" ] * ``` */ export declare const flattenR: (memo: any[], elem: any) => any[]; /** * Reduce function that pushes an object to an array, then returns the array. * Mostly just for [[flattenR]] and [[uniqR]] */ export declare function pushR(arr: any[], obj: any): any[]; /** Reduce function that filters out duplicates */ export declare const uniqR: (acc: T[], token: T) => T[]; /** * Return a new array with a single level of arrays unnested. * * @example * ``` * * let input = [ [ "a", "b" ], [ "c", "d" ], [ [ "double", "nested" ] ] ]; * unnest(input) // [ "a", "b", "c", "d", [ "double, "nested" ] ] * ``` */ export declare const unnest: (arr: any[]) => any; /** * Return a completely flattened version of an array. * * @example * ``` * * let input = [ [ "a", "b" ], [ "c", "d" ], [ [ "double", "nested" ] ] ]; * flatten(input) // [ "a", "b", "c", "d", "double, "nested" ] * ``` */ export declare const flatten: (arr: any[]) => any; /** * Given a .filter Predicate, builds a .filter Predicate which throws an error if any elements do not pass. * @example * ``` * * let isNumber = (obj) => typeof(obj) === 'number'; * let allNumbers = [ 1, 2, 3, 4, 5 ]; * allNumbers.filter(assertPredicate(isNumber)); //OK * * let oneString = [ 1, 2, 3, 4, "5" ]; * oneString.filter(assertPredicate(isNumber, "Not all numbers")); // throws Error(""Not all numbers""); * ``` */ export declare const assertPredicate: (predicate: Predicate, errMsg: string | Function) => Predicate; /** * Given a .map function, builds a .map function which throws an error if any mapped elements do not pass a truthyness test. * @example * ``` * * var data = { foo: 1, bar: 2 }; * * let keys = [ 'foo', 'bar' ] * let values = keys.map(assertMap(key => data[key], "Key not found")); * // values is [1, 2] * * let keys = [ 'foo', 'bar', 'baz' ] * let values = keys.map(assertMap(key => data[key], "Key not found")); * // throws Error("Key not found") * ``` */ export declare const assertMap: (mapFn: (t: T) => U, errMsg: string | Function) => (t: T) => U; export declare function assertFn(predicateOrMap: Function, errMsg?: string | Function): any; /** * Like _.pairs: Given an object, returns an array of key/value pairs * * @example * ``` * * pairs({ foo: "FOO", bar: "BAR }) // [ [ "foo", "FOO" ], [ "bar": "BAR" ] ] * ``` */ export declare const pairs: (obj: Obj) => any[][]; /** * Given two or more parallel arrays, returns an array of tuples where * each tuple is composed of [ a[i], b[i], ... z[i] ] * * @example * ``` * * let foo = [ 0, 2, 4, 6 ]; * let bar = [ 1, 3, 5, 7 ]; * let baz = [ 10, 30, 50, 70 ]; * arrayTuples(foo, bar); // [ [0, 1], [2, 3], [4, 5], [6, 7] ] * arrayTuples(foo, bar, baz); // [ [0, 1, 10], [2, 3, 30], [4, 5, 50], [6, 7, 70] ] * ``` */ export declare function arrayTuples(...args: any[]): any[]; /** * Reduce function which builds an object from an array of [key, value] pairs. * * Each iteration sets the key/val pair on the memo object, then returns the memo for the next iteration. * * Each keyValueTuple should be an array with values [ key: string, value: any ] * * @example * ``` * * var pairs = [ ["fookey", "fooval"], ["barkey", "barval"] ] * * var pairsToObj = pairs.reduce((memo, pair) => applyPairs(memo, pair), {}) * // pairsToObj == { fookey: "fooval", barkey: "barval" } * * // Or, more simply: * var pairsToObj = pairs.reduce(applyPairs, {}) * // pairsToObj == { fookey: "fooval", barkey: "barval" } * ``` */ export declare function applyPairs(memo: TypedMap, keyValTuple: any[]): TypedMap; /** Get the last element of an array */ export declare function tail(arr: T[]): T; /** * shallow copy from src to dest */ export declare function copy(src: Obj, dest?: Obj): any; /** Like Object.assign() */ export declare function _extend(toObj: Obj, ...fromObjs: Obj[]): any; export declare const silenceUncaughtInPromise: (promise: Promise) => Promise; export declare const silentRejection: (error: any) => Promise;