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 element ’ s maxlengthattribute .
*
* ` { [inputName: string]: number } ` : Restrains simple - keyboard ’ s individual inputs to a certain length . This should be used in addition to the input element ’ s 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 ;
2020-10-21 08:54:31 +08:00
/ * *
* 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 ;
2019-01-17 08:38:42 +08:00
/ * *
* 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
2019-07-14 23:55:03 +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 .
* /
module s? : 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 ;
2020-08-08 05:52:12 +08:00
/ * *
* 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 keyboard ’ s 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 keyboard ’ s 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 ;
}