implement basic hotkeys map support in digest; implement next/prev feed hotkeys

This commit is contained in:
Andrew Dolgov 2013-01-20 12:11:36 +04:00
parent 7d8f56571b
commit 4aa5bd593c
2 changed files with 68 additions and 5 deletions

View File

@ -1,5 +1,7 @@
var last_feeds = []; var last_feeds = [];
var init_params = {}; var init_params = {};
var hotkeys_map = false;
var hotkey_prefix = false;
var _active_feed_id = false; var _active_feed_id = false;
var _update_timeout = false; var _update_timeout = false;
@ -565,8 +567,13 @@ function parse_feeds(transport) {
redraw_feedlist(feeds); redraw_feedlist(feeds);
} }
if (reply['hotkeys']) {
hotkeys_map = reply['hotkeys'];
}
} catch (e) { } catch (e) {
exception_error("parse_feeds", e); console.log(e);
//exception_error("parse_feeds", e);
} }
} }
@ -647,7 +654,7 @@ function parse_headlines(transport, replace, no_effects) {
function init_second_stage() { function init_second_stage() {
try { try {
new Ajax.Request("backend.php", { new Ajax.Request("backend.php", {
parameters: "backend.php?op=digest&method=digestinit", parameters: "backend.php?op=digest&method=digestinit&init=1",
onComplete: function(transport) { onComplete: function(transport) {
parse_feeds(transport); parse_feeds(transport);
Element.hide("overlay"); Element.hide("overlay");
@ -834,15 +841,64 @@ function hotkey_handler(e) {
var keychar = String.fromCharCode(keycode); var keychar = String.fromCharCode(keycode);
if (!shift_key) keychar = keychar.toLowerCase();
if (keycode == 16) return; // ignore lone shift if (keycode == 16) return; // ignore lone shift
if (keycode == 17) return; // ignore lone ctrl if (keycode == 17) return; // ignore lone ctrl
var hotkey = keychar.search(/[a-zA-Z0-9]/) != -1 ? keychar : "(" + keycode + ")";
hotkey = hotkey_prefix ? hotkey_prefix + " " + hotkey : hotkey;
hotkey_prefix = false;
var hotkey_action = false;
var hotkeys = getInitParam("hotkeys");
for (sequence in hotkeys[1]) {
if (sequence == hotkey) {
hotkey_action = hotkeys[1][sequence];
break;
}
}
switch (keycode) { switch (keycode) {
case 27: // esc case 27: // esc
close_article(); close_article();
return false;
}
switch (hotkey_action) {
case "next_feed":
var feeds = $$("#feeds li");
for (var i = 0; i < feeds.length; i++) {
var base_id = feeds[i].id.replace("F-", "");
if (base_id == _active_feed_id) {
if (feeds[i+1]) {
viewfeed(feeds[i+1].id.replace("F-", ""));
}
break; break;
}
}
return false;
case "prev_feed":
var feeds = $$("#feeds li");
for (var i = 0; i < feeds.length; i++) {
var base_id = feeds[i].id.replace("F-", "");
if (base_id == _active_feed_id) {
if (feeds[i-1]) {
viewfeed(feeds[i-1].id.replace("F-", ""));
}
break;
}
}
return false;
case "next_article":
return false;
case "prev_article":
return false;
default: default:
console.log("KP: CODE=" + keycode + " CHAR=" + keychar); console.log("unhandled action: " + hotkey_action + "; hotkey: " + hotkey);
} }

View File

@ -1,4 +1,5 @@
<?php <?php
// TODO: digest should register digest specific hotkey actions within tt-rss
class Digest extends Plugin implements IHandler { class Digest extends Plugin implements IHandler {
private $link; private $link;
@ -90,13 +91,19 @@ class Digest extends Plugin implements IHandler {
function digestinit() { function digestinit() {
$tmp_feeds = api_get_feeds($this->link, -4, true, false, 0); $tmp_feeds = api_get_feeds($this->link, -4, true, false, 0);
$params = array();
$feeds = array(); $feeds = array();
foreach ($tmp_feeds as $f) { foreach ($tmp_feeds as $f) {
if ($f['id'] > 0 || $f['id'] == -4) array_push($feeds, $f); if ($f['id'] > 0 || $f['id'] == -4) array_push($feeds, $f);
} }
print json_encode(array("feeds" => $feeds)); if ($_REQUEST["init"] == 1) {
$params["hotkeys"] = get_hotkeys_map($link);
}
$params["feeds"] = $feeds;
print json_encode($params);
} }
} }