simple-keyboard/build/index.d.ts

330 lines
8.9 KiB
TypeScript
Raw Normal View History

2018-11-28 21:52:58 +08:00
declare module 'simple-keyboard' {
interface KeyboardLayoutObject {
2019-04-10 08:44:10 +08:00
[key: string]: string[];
2018-11-28 21:52:58 +08:00
}
interface KeyboardButtonTheme {
class: string;
buttons: string;
}
2019-08-12 08:28:04 +08:00
interface KeyboardButtonAttributes {
attribute: string;
value: string;
buttons: string;
}
2018-11-28 21:52:58 +08:00
interface KeyboardOptions {
/**
* Modify the keyboard layout.
*/
layout?: KeyboardLayoutObject;
/**
* Specifies which layout should be used.
*/
layoutName?: string;
/**
* Replaces variable buttons (such as `{bksp}`) with a human-friendly name (e.g.: `backspace`).
*/
display?: { [button: string]: string };
/**
* By default, when you set the display property, you replace the default one. This setting merges them instead.
*/
mergeDisplay?: boolean;
/**
* A prop to add your own css classes to the keyboard wrapper. You can add multiple classes separated by a space.
*/
theme?: string;
/**
* A prop to add your own css classes to one or several buttons.
*/
buttonTheme?: KeyboardButtonTheme[];
2019-08-12 08:28:04 +08:00
/**
* A prop to add your own attributes to one or several buttons.
*/
buttonAttributes?: KeyboardButtonAttributes[];
2018-11-28 21:52:58 +08:00
/**
* Runs a `console.log` every time a key is pressed. Displays the buttons pressed and the current input.
*/
debug?: boolean;
/**
* Specifies whether clicking the "ENTER" button will input a newline (`\n`) or not.
*/
newLineOnEnter?: boolean;
/**
* Specifies whether clicking the "TAB" button will input a tab character (`\t`) or not.
*/
tabCharOnTab?: boolean;
/**
* Allows you to use a single simple-keyboard instance for several inputs.
*/
inputName?: string;
/**
* `number`: Restrains all of simple-keyboard inputs to a certain length. This should be used in addition to the input elements maxlengthattribute.
*
* `{ [inputName: string]: number }`: Restrains simple-keyboards individual inputs to a certain length. This should be used in addition to the input elements maxlengthattribute.
*/
2019-04-10 08:44:10 +08:00
maxLength?: any;
2018-11-28 21:52:58 +08:00
/**
* When set to true, this option synchronizes the internal input of every simple-keyboard instance.
*/
syncInstanceInputs?: boolean;
/**
* Enable highlighting of keys pressed on physical keyboard.
*/
physicalKeyboardHighlight?: boolean;
/**
* Presses keys highlighted by physicalKeyboardHighlight
*/
physicalKeyboardHighlightPress?: boolean;
/**
* Define the text color that the physical keyboard highlighted key should have.
*/
physicalKeyboardHighlightTextColor?: string;
/**
* Define the background color that the physical keyboard highlighted key should have.
*/
physicalKeyboardHighlightBgColor?: string;
2018-11-28 21:52:58 +08:00
/**
* Calling preventDefault for the mousedown events keeps the focus on the input.
*/
preventMouseDownDefault?: boolean;
2020-09-28 06:35:26 +08:00
/**
* Calling preventDefault for the mouseup events.
*/
preventMouseUpDefault?: boolean;
2019-11-21 06:01:09 +08:00
/**
* Stops pointer down events on simple-keyboard buttons from bubbling to parent elements.
*/
stopMouseDownPropagation?: boolean;
2018-11-28 21:52:58 +08:00
2020-09-28 06:35:26 +08:00
/**
* Stops pointer up events on simple-keyboard buttons from bubbling to parent elements.
*/
stopMouseUpPropagation?: boolean;
2018-12-14 13:28:18 +08:00
/**
* Render buttons as a button element instead of a div element.
*/
useButtonTag?: boolean;
/**
* A prop to ensure characters are always be added/removed at the end of the string.
*/
disableCaretPositioning?: boolean;
2019-01-25 12:03:14 +08:00
/**
* Restrains input(s) change to the defined regular expression pattern.
*/
inputPattern?: any;
2019-03-07 08:37:49 +08:00
/**
* Instructs simple-keyboard to use touch events instead of click events.
*/
useTouchEvents?: boolean;
/**
* Enable useTouchEvents automatically when touch device is detected.
*/
autoUseTouchEvents?: boolean;
2019-03-08 09:53:23 +08:00
/**
* Opt out of PointerEvents handling, falling back to the prior mouse event logic.
*/
useMouseEvents?: boolean;
2019-07-14 13:08:51 +08:00
/**
* Disable button hold action.
*/
disableButtonHold?: boolean;
2020-10-16 12:09:09 +08:00
/**
* Adds unicode right-to-left control characters to input return values.
*/
rtl?: boolean;
2018-11-28 21:52:58 +08:00
/**
* Executes the callback function on key press. Returns button layout name (i.e.: "{shift}").
*/
2018-12-03 03:48:46 +08:00
onKeyPress?: (button: string) => any;
2018-11-28 21:52:58 +08:00
/**
* Executes the callback function on key release.
*/
onKeyReleased?: (button: string) => any;
2018-11-28 21:52:58 +08:00
/**
* Executes the callback function on input change. Returns the current input's string.
*/
2018-12-03 03:48:46 +08:00
onChange?: (input: string) => any;
2018-11-28 21:52:58 +08:00
2019-03-07 08:37:49 +08:00
/**
* Executes the callback function before the first simple-keyboard render.
*/
beforeFirstRender?: () => void;
/**
* Executes the callback function before a simple-keyboard render.
*/
beforeRender?: () => void;
2018-11-28 21:52:58 +08:00
/**
* Executes the callback function every time simple-keyboard is rendered (e.g: when you change layouts).
*/
onRender?: () => void;
/**
* Executes the callback function once simple-keyboard is rendered for the first time (on initialization).
*/
onInit?: () => void;
/**
* Executes the callback function on input change. Returns the input object with all defined inputs.
*/
onChangeAll?: (inputs: any) => any;
2020-02-09 00:37:03 +08:00
/**
* Module classes to be loaded by simple-keyboard.
*/
modules?: any[];
2020-06-12 13:34:08 +08:00
/**
* Module options can have any format
*/
[name: string]: any;
2018-11-28 21:52:58 +08:00
}
2018-12-03 03:48:46 +08:00
class Keyboard {
2018-11-28 21:52:58 +08:00
constructor(selector: string, options: KeyboardOptions);
2020-03-13 07:36:59 +08:00
constructor(selector: HTMLDivElement, options: KeyboardOptions);
2018-11-28 21:52:58 +08:00
constructor(options: KeyboardOptions);
2019-08-11 12:15:13 +08:00
/**
* Options
*/
2018-12-03 03:48:46 +08:00
options: KeyboardOptions;
2018-11-28 21:52:58 +08:00
2019-04-10 08:44:10 +08:00
/**
* Utilities
*/
utilities?: any;
2019-08-11 12:15:13 +08:00
/**
* caretPosition
*/
caretPosition?: number;
/**
* caretPositionEnd
*/
caretPositionEnd?: number;
/**
* Changes the internal caret position
* @param {number} position The caret's start position
* @param {number} positionEnd The caret's end position
*/
setCaretPosition(position: number, positionEnd?: number): void;
2020-09-03 12:08:24 +08:00
/**
* Retrieves the internal caret position
*/
getCaretPosition(): number;
/**
* Retrieves the internal end caret position
*/
getCaretPositionEnd(): number;
2018-11-28 21:52:58 +08:00
/**
* Adds/Modifies an entry to the `buttonTheme`. Basically a way to add a class to a button.
* @param {string} buttons List of buttons to select (separated by a space).
* @param {string} className Classes to give to the selected buttons (separated by space).
*/
addButtonTheme(buttons: string, className: string): void;
/**
* Removes/Amends an entry to the `buttonTheme`. Basically a way to remove a class previously added to a button through buttonTheme or addButtonTheme.
* @param {string} buttons List of buttons to select (separated by a space).
* @param {string} className Classes to give to the selected buttons (separated by space).
*/
removeButtonTheme(buttons: string, className: string): void;
/**
* Clear the keyboard's input.
*
* @param {string} [inputName] optional - the internal input to select
*/
clearInput(inputName?: string): void;
/**
* Get the keyboards input (You can also get it from the onChange prop).
* @param {string} [inputName] optional - the internal input to select
*/
2018-12-05 09:06:52 +08:00
getInput(inputName?: string): string;
2018-11-28 21:52:58 +08:00
/**
* Set the keyboards input.
* @param {string} input the input value
* @param {string} inputName optional - the internal input to select
*/
setInput(input: string, inputName?: string): void;
2021-01-04 06:17:15 +08:00
/**
* Replaces the entire internal input object.
* @param {string} input the input object
*/
replaceInput(input: any): void;
2018-11-28 21:52:58 +08:00
/**
* Set new option or modify existing ones after initialization.
* @param {KeyboardOptions} option The option to set
*/
setOptions(options: KeyboardOptions): void;
/**
* Send a command to all simple-keyboard instances at once (if you have multiple instances).
* @param {function(instance: object, key: string)} callback Function to run on every instance
*/
dispatch(callback: (instance: any, key: string) => void): void;
/**
* Get the DOM Element of a button. If there are several buttons with the same name, an array of the DOM Elements is returned.
* @param {string} button The button layout name to select
*/
2018-12-05 09:06:52 +08:00
getButtonElement(button: string): HTMLElement | HTMLElement[];
2019-06-02 15:04:55 +08:00
/**
* Clears keyboard listeners and DOM elements.
*/
destroy(): void;
2020-12-22 08:26:34 +08:00
/**
* Iterate on each button (ForEach)
*/
recurseButtons(fn: any): void;
2018-11-28 21:52:58 +08:00
}
export default Keyboard;
}