2019-05-23 18:00:49 +00:00
|
|
|
import { BaseToneOptions } from "../Tone";
|
2019-06-18 01:52:02 +00:00
|
|
|
import { isDefined, isObject, isUndef } from "./TypeCheck";
|
2019-05-22 04:14:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Recursively merge an object
|
|
|
|
* @param target the object to merge into
|
|
|
|
* @param sources the source objects to merge
|
|
|
|
*/
|
|
|
|
export function deepMerge<T>(target: T, ...sources: T[]): T {
|
|
|
|
if (!sources.length) { return target; }
|
|
|
|
const source = sources.shift();
|
|
|
|
|
|
|
|
if (isObject(target) && isObject(source)) {
|
|
|
|
for (const key in source) {
|
|
|
|
if (isObject(source[key])) {
|
|
|
|
if (!target[key]) { Object.assign(target, { [key]: {} }); }
|
|
|
|
deepMerge(target[key], source[key] as any);
|
|
|
|
} else {
|
|
|
|
Object.assign(target, { [key]: source[key] as any });
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return deepMerge(target, ...sources);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Convert an args array into an object.
|
|
|
|
*/
|
|
|
|
export function optionsFromArguments<T>(defaults: T, argsArray: IArguments, keys: string[]): T {
|
|
|
|
const opts: any = {};
|
|
|
|
const args = Array.from(argsArray);
|
|
|
|
if (args.length === 1 && isObject(args[0])) {
|
|
|
|
deepMerge(opts, args[0]);
|
|
|
|
} else {
|
|
|
|
for (let i = 0; i < keys.length; i++) {
|
|
|
|
if (isDefined(args[i])) {
|
|
|
|
opts[keys[i]] = args[i];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return deepMerge(defaults, opts);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return this instances default values by calling Constructor.getDefaults()
|
|
|
|
*/
|
|
|
|
export function getDefaultsFromInstance<T>(instance: T): BaseToneOptions {
|
|
|
|
type ToneClass = {
|
|
|
|
constructor: ToneClass;
|
|
|
|
getDefaults: () => BaseToneOptions;
|
|
|
|
} & T;
|
|
|
|
|
|
|
|
return (instance as ToneClass).constructor.getDefaults();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-06-18 01:52:02 +00:00
|
|
|
* Returns the fallback if the given object is undefined.
|
2019-05-22 04:14:43 +00:00
|
|
|
* Take an array of arguments and return a formatted options object.
|
|
|
|
*/
|
2019-06-18 01:52:02 +00:00
|
|
|
export function defaultArg<T>(given: T, fallback: T): T {
|
|
|
|
if (isUndef(given)) {
|
|
|
|
return fallback;
|
|
|
|
} else {
|
|
|
|
return given;
|
|
|
|
}
|
|
|
|
}
|