Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

onkeyup event in Safari on IOS7 from a bluetooth keyboard

I have the following setup:

  • Bluetooth scanner
  • iPad
  • Webpage with a textfield for scan input

Usage:

  • User focus textfield and scan barcode with bluetooth scanner
  • Scanner adds ENTER (13) at the end of the scan

Problem:

On Safari in IOS7 there seems to be a change on how keyboard events are handled on bluetooth devices. The code ...

window.onkeyup = function (e) {
    console.log(e.KeyboardEvent)
}

... should return information about the key pressed. Instead i get ...

keyCode: 0
keyIdentifier: "Unidentified"

... no matter which key I press.

Same result booth form bluetooth scanner and bluetooth keyboard.

Thanks / E

like image 540
EmilPennlov Avatar asked Oct 22 '22 00:10

EmilPennlov


1 Answers

Seems that "onkeypress" works as expected though.

Since this was a problem a bumbed in to in a Sencha Touch project and Sencha Touch doesn't have a keypress event on textfields I'm posting the code that solved my problem.

{
    xtype:'searchfield',
    name:'search',
    placeHolder:'search',
    listeners: {
        painted: {
            fn: function () {
                var me = this;
                me.element.dom.onkeypress = function (e) {
                    if (e.keyCode === 13) {
                        me.fireEvent('searchkeypress', me, e);
                    }
                };
            }
        }
    }
}
like image 62
EmilPennlov Avatar answered Oct 24 '22 03:10

EmilPennlov