/// <reference types="jquery" />
import { GUISelector } from "./gui-selector";
import { Key } from "./key";
import { Mode } from "./mode";
import { EditorAPI } from "./mode-api";
/**
 * @param eventType The type of event being processed.
 *
 * @param element A DOM element in the **data tree** that was modified or had
 * the caret when the keydown event happened.
 *
 * @param event The jQuery event in question.
 */
export declare type KeyHandler = (eventType: "keypress" | "keydown" | "paste", el: Element, event: JQueryKeyEventObject) => void;
/**
 * An InputTrigger listens to keyboard events and to DOM changes that insert
 * text into an element. The object has to listen to both types of events
 * because:
 *
 * - Listening only to keyboard events would miss modifications to the DOM tree
 *   that happen programmatically.
 *
 * - Listening only to DOM changes would not trap keyboard events that do not
 *   **inherently** modify the DOM tree like a backspace key hit at the start of
 *   an element.
 *
 * The portion of InputTrigger objects that handle keyboard events attaches
 * itself to the editor to which the InputTrigger belongs in such a way that
 * allows for suppressing the generic handling of such events. See
 * [[addKeyHandler]] for more information.
 */
export declare class InputTrigger {
    private readonly editor;
    private readonly mode;
    private readonly selector;
    private readonly keyToHandler;
    private readonly textInputKeyToHandler;
    /**
     * @param editor The editor to which this ``InputTrigger`` belongs.
     *
     * @param mode The mode for which this ``InputTrigger`` is being created.
     *
     * @param selector This is a CSS selector which must be fit to be used in the
     * GUI tree. (For instance by being the output of
     * [["wed/domutil".toGUISelector]].)
     */
    constructor(editor: EditorAPI, mode: Mode, selector: GUISelector);
    /**
     * Adds a key handler to the object.
     *
     * The handler is called once per event. This means for instance that if a
     * paste event introduces the text "a;b;c" and we are listening for ";", the
     * handler will be called once, even though two ";" are added. It is up to the
     * handler to detect that ";" has been added more than once.
     *
     * Handlers that wish to stop further processing or prevent the browser's
     * default processing of an event must call the appropriate method on the
     * ``event`` object.
     *
     * Although it is possible to add multiple handlers for the same key to the
     * same ``InputTrigger`` object, the ``InputTrigger`` class does not define
     * how one handler could prevent another handler from executing. Calling the
     * methods on the ``event`` object does not in any way affect how an
     * ``InputTrigger`` calls its handlers. However, as stated above, these
     * methods can prevent further propagation of the JavaScript
     * event. Consequently, if more than one handler should handle the same key on
     * the same ``InputTrigger`` object, these handlers should either deal with
     * orthogonal concerns (e.g. one modifies the data DOM tree and the other does
     * logging), or provide their own mechanism to determine whether one can
     * prevent the other from executing.
     *
     * @param key The key we are interested in.
     *
     * @param handler The handler that will process events related to that key.
     */
    addKeyHandler(key: Key, handler: KeyHandler): void;
    private getNodeOfInterest();
    /**
     * Handles ``keydown`` events.
     *
     * @param _wedEvent The DOM event wed generated to trigger this handler.
     *
     * @param e The original DOM event that wed received.
     */
    private keydownHandler(_wedEvent, e);
    /**
     * Handles ``keypress`` events.
     *
     * @param _wedEvent The DOM event wed generated to trigger this handler.
     *
     * @param e The original DOM event that wed received.
     */
    private keypressHandler(_wedEvent, e);
    /**
     * Handles ``paste`` events.
     *
     * @param _wedEvent The DOM event wed generated to trigger this handler.
     *
     * @param e The original DOM event that wed received.
     *
     * @param caret The data caret.
     *
     * @param data The data that the user wants to insert.
     */
    private pasteHandler(_wedEvent, e, caret, data);
}
