aboutsummaryrefslogtreecommitdiffstats
path: root/content_scripts/mode_insert.coffee
diff options
context:
space:
mode:
authorStephen Blott2015-01-09 09:10:32 +0000
committerStephen Blott2015-01-09 09:10:32 +0000
commit4d965865619b33f40b12ff46ef47d90ca2f61b82 (patch)
tree19deb06a3c9a2523cf1ae81c227efaa9ff29f786 /content_scripts/mode_insert.coffee
parent3962a65cc259bd33cf429922967dedc31f979943 (diff)
parent359fbbbcd286f16de5b23db5f4bb8dbbb2b5b6ac (diff)
downloadvimium-4d965865619b33f40b12ff46ef47d90ca2f61b82.tar.bz2
Merge branch 'modes-dev' into modes
Diffstat (limited to 'content_scripts/mode_insert.coffee')
-rw-r--r--content_scripts/mode_insert.coffee13
1 files changed, 13 insertions, 0 deletions
diff --git a/content_scripts/mode_insert.coffee b/content_scripts/mode_insert.coffee
index 7f1d5ddc..bfc79aa9 100644
--- a/content_scripts/mode_insert.coffee
+++ b/content_scripts/mode_insert.coffee
@@ -64,6 +64,19 @@ class InsertModeBlocker extends Mode
super options
@onExit -> triggerSuppressor.unsuppress()
+ @push
+ "click": (event) =>
+ @alwaysContinueBubbling =>
+ # The user knows best; so, if the user clicks on something, we get out of the way.
+ @exit event
+ # However, there's a corner case. If the active element is focusable, then we would have been in
+ # insert mode had we not been blocking the trigger. Now, clicking on the element will not generate
+ # a new focus event, so the insert-mode trigger will not fire. We have to handle this case
+ # specially.
+ if document.activeElement and
+ event.target == document.activeElement and DomUtils.isEditable document.activeElement
+ new InsertMode document.activeElement
+
root = exports ? window
root.InsertMode = InsertMode
root.InsertModeTrigger = InsertModeTrigger