export type TEventCallback = (options: T) => any; type EventRegistryObject = { [K in keyof E]?: TEventCallback; }; /** * @tutorial {@link http://fabricjs.com/fabric-intro-part-2#events} * @see {@link http://fabricjs.com/events|Events demo} */ export declare class Observable { private __eventListeners; /** * Observes specified event * @alias on * @param {string} eventName Event name (eg. 'after:render') * @param {EventRegistryObject} handlers key/value pairs (eg. {'after:render': handler, 'selection:cleared': handler}) * @param {Function} handler Function that receives a notification when an event of the specified type occurs * @return {Function} disposer */ on(eventName: K, handler: TEventCallback): VoidFunction; on(handlers: EventRegistryObject): VoidFunction; /** * Observes specified event **once** * @alias once * @param {string} eventName Event name (eg. 'after:render') * @param {EventRegistryObject} handlers key/value pairs (eg. {'after:render': handler, 'selection:cleared': handler}) * @param {Function} handler Function that receives a notification when an event of the specified type occurs * @return {Function} disposer */ once(eventName: K, handler: TEventCallback): VoidFunction; once(handlers: EventRegistryObject): VoidFunction; /** * @private * @param {string} eventName * @param {Function} [handler] */ private _removeEventListener; /** * Unsubscribe all event listeners for eventname. * Do not use this pattern. You could kill internal fabricJS events. * We know we should have protected events for internal flows, but we don't have yet * @deprecated * @param {string} eventName event name (eg. 'after:render') */ off(eventName: K): void; /** * unsubscribe an event listener * @param {string} eventName event name (eg. 'after:render') * @param {TEventCallback} handler event listener to unsubscribe */ off(eventName: K, handler: TEventCallback): void; /** * unsubscribe event listeners * @param handlers handlers key/value pairs (eg. {'after:render': handler, 'selection:cleared': handler}) */ off(handlers: EventRegistryObject): void; /** * unsubscribe all event listeners */ off(): void; /** * Fires event with an optional options object * @param {String} eventName Event name to fire * @param {Object} [options] Options object */ fire(eventName: K, options?: EventSpec[K]): void; } export {}; //# sourceMappingURL=Observable.d.ts.map