add public methods type definitions

This commit is contained in:
Armno 2018-11-27 23:43:20 +07:00
parent 5c40dd3109
commit b5cbfa780b

View File

@ -1,6 +1,57 @@
declare module 'simple-keyboard' { declare module "simple-keyboard" {
class SimpleKeyboard { class SimpleKeyboard {
constructor(selector: string, options: SimpleKeyboardOptions); constructor(selector: string, options: SimpleKeyboardOptions);
/**
* 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 keyboards 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
*/
getInput(inputName: string): void;
/**
* 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;
/**
* Set new option or modify existing ones after initialization.
* @param {SimpleKeyboardOptions} option The option to set
*/
setOptions(options: SimpleKeyboardOptions): 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
*/
getButtonElement(button: string);
} }
interface SimpleKeyboardOptions { interface SimpleKeyboardOptions {
@ -48,8 +99,69 @@ declare module 'simple-keyboard' {
* Specifies whether clicking the TAB button will input a tab character (\t) or not. * Specifies whether clicking the TAB button will input a tab character (\t) or not.
*/ */
tabCharOnTab: boolean; 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.
* any: Restrains simple-keyboards individual inputs to a certain length. This should be used in addition to the input elements maxlengthattribute.
*/
// @TODO: specify type for `any`;
maxLength: number | any;
/**
* 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;
/**
* Calling preventDefault for the mousedown events keeps the focus on the input.
*/
preventMouseDownDefault: 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;
/**
* Executes the callback function on key press. Returns button layout name (i.e.: {shift}).
*/
onKeyPress: (button: string) => string;
/**
* Executes the callback function on input change. Returns the current inputs string.
*/
onChange: (input: string) => string;
/**
* Executes the callback function every time simple-keyboard is rendered (e.g: when you change layouts).
*/
onRender: () => any;
/**
* Executes the callback function once simple-keyboard is rendered for the first time (on initialization).
*/
onInit: () => any;
/**
* Executes the callback function on input change. Returns the input object with all defined inputs.
*/
onChangeAll: (inputs: any) => any;
} }
export default SimpleKeyboard; export default SimpleKeyboard;
} }