summaryrefslogtreecommitdiff
path: root/searx/static
diff options
context:
space:
mode:
authorKirill Isakov <ukwt@ya.ru>2016-04-24 21:04:53 +0600
committerKirill Isakov <ukwt@ya.ru>2016-04-24 21:04:53 +0600
commit7b48a663503018dd47b81c94afd9c4df6d62467a (patch)
treea9197a84aebc8fa71cc4ff4917a5f7d5d896f727 /searx/static
parent0d6625e0703e3c4edfd0cdbca815795bb20c32b3 (diff)
downloadsearxng-7b48a663503018dd47b81c94afd9c4df6d62467a.tar.gz
searxng-7b48a663503018dd47b81c94afd9c4df6d62467a.zip
Add auto page scrolling to selected result
Diffstat (limited to 'searx/static')
-rw-r--r--searx/static/plugins/js/vim_hotkeys.js49
1 files changed, 45 insertions, 4 deletions
diff --git a/searx/static/plugins/js/vim_hotkeys.js b/searx/static/plugins/js/vim_hotkeys.js
index 740b78ff2..f7f5989c2 100644
--- a/searx/static/plugins/js/vim_hotkeys.js
+++ b/searx/static/plugins/js/vim_hotkeys.js
@@ -140,8 +140,21 @@ $(document).ready(function() {
next = which;
} else {
switch (which) {
- // case 'visible':
- // TODO
+ case 'visible':
+ var top = $(window).scrollTop();
+ var bot = top + $(window).height();
+ var results = $('.result');
+
+ for (var i = 0; i < results.length; i++) {
+ next = $(results[i]);
+ var etop = next.offset().top;
+ var ebot = etop + next.height();
+
+ if ((ebot <= bot) && (etop > top)) {
+ break;
+ }
+ }
+ break;
case 'down':
next = current.next('.result');
if (next.length === 0) {
@@ -163,8 +176,11 @@ $(document).ready(function() {
}
}
- current.removeAttr('data-vim-selected').removeClass('well well-sm');
- next.attr('data-vim-selected', 'true').addClass('well well-sm');
+ if (next) {
+ current.removeAttr('data-vim-selected').removeClass('well well-sm');
+ next.attr('data-vim-selected', 'true').addClass('well well-sm');
+ scrollPageToSelected();
+ }
}
}
@@ -193,6 +209,31 @@ $(document).ready(function() {
}
}
+ function scrollPageToSelected() {
+ var sel = $('.result[data-vim-selected]');
+ if (sel.length !== 1) {
+ return;
+ }
+
+ var wnd = $(window);
+
+ var wtop = wnd.scrollTop();
+ var etop = sel.offset().top;
+
+ var offset = 30;
+
+ if (wtop > etop) {
+ wnd.scrollTop(etop - offset);
+ } else {
+ var ebot = etop + sel.height();
+ var wbot = wtop + wnd.height();
+
+ if (wbot < ebot) {
+ wnd.scrollTop(ebot - wnd.height() + offset);
+ }
+ }
+ }
+
function scrollPage(amount) {
return function() {
window.scrollBy(0, amount);