From ee83d1a9603a304c9328d3587e2db829fcec7aaf Mon Sep 17 00:00:00 2001 From: Stephen Blott Date: Thu, 13 Apr 2017 15:28:43 +0100 Subject: Ignore keybiard repeats. Keyboard repeats were interfering with smooth scrolling. But we should be ignoreing them anyway. --- lib/dom_utils.coffee | 27 ++++++++++++++------------- 1 file changed, 14 insertions(+), 13 deletions(-) diff --git a/lib/dom_utils.coffee b/lib/dom_utils.coffee index df9ca390..8764bdbe 100644 --- a/lib/dom_utils.coffee +++ b/lib/dom_utils.coffee @@ -318,19 +318,20 @@ DomUtils = consumeKeyup: (event, callback = null) -> @suppressEvent event keyChar = KeyboardUtils.getKeyCharString event - handlerStack.push - _name: "dom_utils/consumeKeyup" - keydown: (event) -> - @remove() - handlerStack.continueBubbling - keyup: (event) -> - return handlerStack.continueBubbling unless keyChar == KeyboardUtils.getKeyCharString event - @remove() - handlerStack.suppressEvent - # We cannot track keyup events if we lose the focus. - blur: (event) -> - @remove() if event.target == window - handlerStack.continueBubbling + unless event.repeat + handlerStack.push + _name: "dom_utils/consumeKeyup" + keydown: (event) -> + @remove() + handlerStack.continueBubbling + keyup: (event) -> + return handlerStack.continueBubbling unless keyChar == KeyboardUtils.getKeyCharString event + @remove() + handlerStack.suppressEvent + # We cannot track keyup events if we lose the focus. + blur: (event) -> + @remove() if event.target == window + handlerStack.continueBubbling callback?() handlerStack.suppressEvent -- cgit v1.2.3