From 4879ba94b0984b7188fc38dcb786bf3fadf8a6c2 Mon Sep 17 00:00:00 2001 From: Marcin Kurczewski Date: Wed, 5 Mar 2014 22:14:30 +0100 Subject: [PATCH] Fixed problem with keyboard shortcuts on Flash Previous attempt - f226c3eb0ca2397bfc360b0a474424d4aadfdf96. Approach introduced in this commit is theoretically much better, but it still might not be perfect. --- public_html/media/js/core.js | 56 +++++++++++++++++++++++++++---- public_html/media/js/post-view.js | 30 +++++++++++++++-- 2 files changed, 77 insertions(+), 9 deletions(-) diff --git a/public_html/media/js/core.js b/public_html/media/js/core.js index cacd6b39..0bf79348 100644 --- a/public_html/media/js/core.js +++ b/public_html/media/js/core.js @@ -304,15 +304,59 @@ function attachTagIt(element) +//prevent keybindings from executing when flash posts are focused +var oldMousetrapBind = Mousetrap.bind; +Mousetrap.bind = function(key, func, args) +{ + oldMousetrapBind(key, function() + { + if ($(document.activeElement).parents('.post-type-flash').length > 0) + return false; + + func(); + }, args); +}; + + + //hotkeys $(function() { - Mousetrap.bind('q', function() { $('#top-nav input').focus(); return false; }, 'keyup'); - Mousetrap.bind('w', function() { $('body,html').animate({scrollTop: '-=150px'}, 200); }); - Mousetrap.bind('s', function() { $('body,html').animate({scrollTop: '+=150px'}, 200); }); - Mousetrap.bind('a', function() { var url = $('.paginator:visible .prev:not(.disabled) a').attr('href'); if (typeof url !== 'undefined') window.location.href = url; }, 'keyup'); - Mousetrap.bind('d', function() { var url = $('.paginator:visible .next:not(.disabled) a').attr('href'); if (typeof url !== 'undefined') window.location.href = url; }, 'keyup'); - Mousetrap.bind('p', function() { $('.post a').eq(0).focus(); return false; }, 'keyup'); + Mousetrap.bind('q', function() + { + $('#top-nav input').focus(); + return false; + }, 'keyup'); + + Mousetrap.bind('w', function() + { + $('body,html').animate({scrollTop: '-=150px'}, 200); + }); + + Mousetrap.bind('s', function() + { + $('body,html').animate({scrollTop: '+=150px'}, 200); + }); + + Mousetrap.bind('a', function() + { + var url = $('.paginator:visible .prev:not(.disabled) a').attr('href'); + if (typeof url !== 'undefined') + window.location.href = url; + }, 'keyup'); + + Mousetrap.bind('d', function() + { + var url = $('.paginator:visible .next:not(.disabled) a').attr('href'); + if (typeof url !== 'undefined') + window.location.href = url; + }, 'keyup'); + + Mousetrap.bind('p', function() + { + $('.post a').eq(0).focus(); + return false; + }, 'keyup'); }); diff --git a/public_html/media/js/post-view.js b/public_html/media/js/post-view.js index ad077643..51060b3e 100644 --- a/public_html/media/js/post-view.js +++ b/public_html/media/js/post-view.js @@ -140,7 +140,31 @@ $(function() $.ajax(ajaxData); }); - Mousetrap.bind('a', function() { var a = $('#sidebar .left a'); var url = a.attr('href'); if (typeof url !== 'undefined') { a.click(); window.location.href = url; } }, 'keyup'); - Mousetrap.bind('d', function() { var a = $('#sidebar .right a'); var url = a.attr('href'); if (typeof url !== 'undefined') { a.click(); window.location.href = url; } }, 'keyup'); - Mousetrap.bind('e', function() { $('a.edit-post').trigger('click'); return false; }, 'keyup'); + Mousetrap.bind('a', function() + { + var a = $('#sidebar .left a'); + var url = a.attr('href'); + if (typeof url !== 'undefined') + { + a.click(); + window.location.href = url; + } + }, 'keyup'); + + Mousetrap.bind('d', function() + { + var a = $('#sidebar .right a'); + var url = a.attr('href'); + if (typeof url !== 'undefined') + { + a.click(); + window.location.href = url; + } + }, 'keyup'); + + Mousetrap.bind('e', function() + { + $('a.edit-post').trigger('click'); + return false; + }, 'keyup'); });