@api.stream/studio-kit
Version:
Client SDK for building studio experiences with API.stream
53 lines (52 loc) • 3.21 kB
TypeScript
/**
* This file contains logical helpers with zero app dependencies
* that produce no side effects (pure functions)
*/
import deepEqual from 'fast-deep-equal';
import type * as Compositor from './compositor/index';
export { camelCase, cloneDeep, debounce, every, isArray, isEqual, kebabCase, omit, pick, pull, sortBy } from 'lodash-es';
export { deepEqual };
export declare const generateId: () => string;
export declare const insertAt: <T>(index: number, ins: T | T[], arr: T[], replace?: boolean) => (T | (T extends readonly (infer InnerArr)[] ? InnerArr : T))[];
export declare const replaceItem: <T>(match: T | ((item: T) => Boolean), newItem: T, arr: T[]) => (T | (T extends readonly (infer InnerArr)[] ? InnerArr : T))[];
export declare const swapIndex: <T>(indexA: number, indexB: number, arr: T[]) => T[];
export declare const swapItems: <T extends string | number>(itemA: T, itemB: T, arr: T[]) => T[];
export declare const toDataNode: (node: Compositor.SceneNode) => Compositor.DataNode;
export declare const toSceneNode: (node: Compositor.DataNode) => Compositor.SceneNode;
export declare const toSceneTree: (nodes: Compositor.DataNode[], rootId: Compositor.NodeId) => Compositor.SceneNode;
export declare const forEachDown: (node: Compositor.SceneNode, fn: (next: Compositor.SceneNode, parent?: Compositor.SceneNode) => void) => void;
type GraphNode = {
children?: GraphNode[];
};
export declare const mapDown: <T extends GraphNode, U extends GraphNode>(node: T, fn: (next: T) => U) => U;
export declare const mapDownAsync: (node: Compositor.SceneNode, fn: (next: Compositor.SceneNode) => Promise<Compositor.SceneNode>) => Promise<Compositor.SceneNode>;
export declare const getElementAttributes: (x: HTMLElement) => {
[props: string]: string;
};
export declare const asArray: <T>(x: T | T[]) => T[];
export declare const sizeToNum: (x: string | number | null, parentSize: number) => number;
export declare const asSize: (x: string | number | null) => string;
export declare const asDuration: (x: string | number | null) => string;
/**
* Find
* @param {Node} tree - Root node
* @param {string|object|function} [condition] - Condition to match node.
*/
export declare const find: (tree: any, condition: string | object | Function) => Compositor.SceneNode;
/**
* Find All
* @param {Node} tree - Root node
* @param {string|object|function} [condition] - Condition to match node.
*/
export declare const findAll: (tree: any, condition: string | object | Function) => Compositor.SceneNode[];
export declare const lookupDevice: (devices: MediaDeviceInfo[], src: string) => {
videoDevice: MediaDeviceInfo;
audioDevice: MediaDeviceInfo | null;
} | null;
export declare const connectDevice: (id: string) => Promise<MediaStream>;
declare type Builtin = Date | Function | Uint8Array | string | number | boolean | undefined;
export declare type DeepPartial<T> = T extends Builtin ? T : T extends Array<infer U> ? Array<DeepPartial<U>> : T extends ReadonlyArray<infer U> ? ReadonlyArray<DeepPartial<U>> : T extends {} ? {
[K in keyof T]?: DeepPartial<T[K]>;
} : Partial<T>;
/** Convert a Map to an array of its values */
export declare const values: <T>(map: Map<any, T>) => T[];