2018-12-02 15:38:27 +00:00
|
|
|
'use strict'
|
2018-12-02 14:18:59 +00:00
|
|
|
/* global dijit,__ */
|
2018-12-02 14:00:58 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
let App;
|
2018-12-02 14:00:58 +00:00
|
|
|
let CommonDialogs;
|
|
|
|
let Filters;
|
2018-12-02 14:18:59 +00:00
|
|
|
let Feeds;
|
|
|
|
let Headlines;
|
|
|
|
let Article;
|
2018-12-03 06:33:44 +00:00
|
|
|
let PluginHost;
|
2018-11-29 18:03:55 +00:00
|
|
|
|
2018-12-03 07:51:14 +00:00
|
|
|
const Plugins = {};
|
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
require(["dojo/_base/kernel",
|
|
|
|
"dojo/_base/declare",
|
|
|
|
"dojo/ready",
|
|
|
|
"dojo/parser",
|
|
|
|
"fox/AppBase",
|
|
|
|
"dojo/_base/loader",
|
|
|
|
"dojo/_base/html",
|
|
|
|
"dojo/query",
|
|
|
|
"dijit/ProgressBar",
|
|
|
|
"dijit/ColorPalette",
|
|
|
|
"dijit/Dialog",
|
|
|
|
"dijit/form/Button",
|
|
|
|
"dijit/form/ComboButton",
|
|
|
|
"dijit/form/CheckBox",
|
|
|
|
"dijit/form/DropDownButton",
|
|
|
|
"dijit/form/FilteringSelect",
|
|
|
|
"dijit/form/Form",
|
|
|
|
"dijit/form/RadioButton",
|
|
|
|
"dijit/form/Select",
|
|
|
|
"dijit/form/MultiSelect",
|
|
|
|
"dijit/form/SimpleTextarea",
|
|
|
|
"dijit/form/TextBox",
|
|
|
|
"dijit/form/ComboBox",
|
|
|
|
"dijit/form/ValidationTextBox",
|
|
|
|
"dijit/InlineEditBox",
|
|
|
|
"dijit/layout/AccordionContainer",
|
|
|
|
"dijit/layout/BorderContainer",
|
|
|
|
"dijit/layout/ContentPane",
|
|
|
|
"dijit/layout/TabContainer",
|
|
|
|
"dijit/PopupMenuItem",
|
|
|
|
"dijit/Menu",
|
|
|
|
"dijit/Toolbar",
|
|
|
|
"dijit/Tree",
|
|
|
|
"dijit/tree/dndSource",
|
|
|
|
"dijit/tree/ForestStoreModel",
|
|
|
|
"dojo/data/ItemFileWriteStore",
|
2018-12-03 06:33:44 +00:00
|
|
|
"fox/PluginHost",
|
2018-12-02 18:52:50 +00:00
|
|
|
"fox/CommonFilters",
|
2018-12-03 06:33:44 +00:00
|
|
|
"fox/CommonDialogs",
|
2018-12-02 18:52:50 +00:00
|
|
|
"fox/Feeds",
|
|
|
|
"fox/Headlines",
|
|
|
|
"fox/Article",
|
|
|
|
"fox/FeedStoreModel",
|
2019-04-07 10:21:52 +00:00
|
|
|
"fox/FeedTree",
|
2019-04-13 20:36:15 +00:00
|
|
|
"fox/Toolbar",
|
2020-02-28 11:04:29 +00:00
|
|
|
"fox/form/ValidationTextArea",
|
2019-04-13 20:36:15 +00:00
|
|
|
"fox/form/Select",
|
|
|
|
"fox/form/ComboButton",
|
|
|
|
"fox/form/DropDownButton"], function (dojo, declare, ready, parser, AppBase) {
|
2018-12-02 18:52:50 +00:00
|
|
|
|
|
|
|
ready(function () {
|
|
|
|
try {
|
|
|
|
const _App = declare("fox.App", AppBase, {
|
|
|
|
global_unread: -1,
|
|
|
|
_widescreen_mode: false,
|
|
|
|
hotkey_actions: {},
|
|
|
|
constructor: function () {
|
2019-12-15 08:57:26 +00:00
|
|
|
this.setupNightModeDetection(() => {
|
|
|
|
parser.parse();
|
|
|
|
|
|
|
|
if (!this.checkBrowserFeatures())
|
|
|
|
return;
|
|
|
|
|
|
|
|
this.setLoadingProgress(30);
|
|
|
|
this.initHotkeyActions();
|
|
|
|
|
|
|
|
const a = document.createElement('audio');
|
|
|
|
const hasAudio = !!a.canPlayType;
|
|
|
|
const hasSandbox = "sandbox" in document.createElement("iframe");
|
|
|
|
const hasMp3 = !!(a.canPlayType && a.canPlayType('audio/mpeg;').replace(/no/, ''));
|
|
|
|
const clientTzOffset = new Date().getTimezoneOffset() * 60;
|
|
|
|
|
|
|
|
const params = {
|
|
|
|
op: "rpc", method: "sanityCheck", hasAudio: hasAudio,
|
|
|
|
hasMp3: hasMp3,
|
|
|
|
clientTzOffset: clientTzOffset,
|
|
|
|
hasSandbox: hasSandbox
|
|
|
|
};
|
|
|
|
|
|
|
|
xhrPost("backend.php", params, (transport) => {
|
|
|
|
try {
|
|
|
|
App.backendSanityCallback(transport);
|
|
|
|
} catch (e) {
|
|
|
|
App.Error.report(e);
|
|
|
|
}
|
|
|
|
});
|
2018-12-01 14:42:21 +00:00
|
|
|
});
|
2018-12-02 18:52:50 +00:00
|
|
|
},
|
2018-12-11 09:30:48 +00:00
|
|
|
checkBrowserFeatures: function() {
|
|
|
|
let errorMsg = "";
|
|
|
|
|
2018-12-11 14:58:10 +00:00
|
|
|
['MutationObserver'].each(function(wf) {
|
2018-12-11 09:30:48 +00:00
|
|
|
if (! (wf in window)) {
|
|
|
|
errorMsg = `Browser feature check failed: <code>window.${wf}</code> not found.`;
|
|
|
|
throw $break;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
if (errorMsg) {
|
2018-12-11 10:18:38 +00:00
|
|
|
this.Error.fatal(errorMsg, {info: navigator.userAgent});
|
2018-12-11 09:30:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return errorMsg == "";
|
|
|
|
},
|
2018-12-02 18:52:50 +00:00
|
|
|
initSecondStage: function () {
|
|
|
|
this.enableCsrfSupport();
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
Feeds.reload();
|
|
|
|
Article.close();
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
if (parseInt(Cookie.get("ttrss_fh_width")) > 0) {
|
|
|
|
dijit.byId("feeds-holder").domNode.setStyle(
|
|
|
|
{width: Cookie.get("ttrss_fh_width") + "px"});
|
|
|
|
}
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
dijit.byId("main").resize();
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
dojo.connect(dijit.byId('feeds-holder'), 'resize',
|
|
|
|
function (args) {
|
|
|
|
if (args && args.w >= 0) {
|
|
|
|
Cookie.set("ttrss_fh_width", args.w, App.getInitParam("cookie_lifetime"));
|
|
|
|
}
|
|
|
|
});
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
dojo.connect(dijit.byId('content-insert'), 'resize',
|
|
|
|
function (args) {
|
|
|
|
if (args && args.w >= 0 && args.h >= 0) {
|
|
|
|
Cookie.set("ttrss_ci_width", args.w, App.getInitParam("cookie_lifetime"));
|
|
|
|
Cookie.set("ttrss_ci_height", args.h, App.getInitParam("cookie_lifetime"));
|
|
|
|
}
|
|
|
|
});
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-05 07:03:58 +00:00
|
|
|
const toolbar = document.forms["toolbar-main"];
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
dijit.getEnclosingWidget(toolbar.view_mode).attr('value',
|
|
|
|
App.getInitParam("default_view_mode"));
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
dijit.getEnclosingWidget(toolbar.order_by).attr('value',
|
|
|
|
App.getInitParam("default_view_order_by"));
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-02 19:08:18 +00:00
|
|
|
App.setLoadingProgress(50);
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
this._widescreen_mode = App.getInitParam("widescreen");
|
|
|
|
this.switchPanelMode(this._widescreen_mode);
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
Headlines.initScrollHandler();
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
if (App.getInitParam("simple_update")) {
|
|
|
|
console.log("scheduling simple feed updater...");
|
|
|
|
window.setInterval(() => { Feeds.updateRandom() }, 30 * 1000);
|
|
|
|
}
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-16 16:05:37 +00:00
|
|
|
if (App.getInitParam('check_for_updates')) {
|
|
|
|
window.setInterval(() => {
|
|
|
|
App.checkForUpdates();
|
|
|
|
}, 3600 * 1000);
|
|
|
|
}
|
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
console.log("second stage ok");
|
2018-12-08 17:06:07 +00:00
|
|
|
|
|
|
|
PluginHost.run(PluginHost.HOOK_INIT_COMPLETE, null);
|
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
},
|
2018-12-16 16:05:37 +00:00
|
|
|
checkForUpdates: function() {
|
|
|
|
console.log('checking for updates...');
|
|
|
|
|
|
|
|
xhrJson("backend.php", {op: 'rpc', method: 'checkforupdates'})
|
|
|
|
.then((reply) => {
|
|
|
|
console.log('update reply', reply);
|
|
|
|
|
|
|
|
if (reply.id) {
|
|
|
|
$("updates-available").show();
|
|
|
|
} else {
|
|
|
|
$("updates-available").hide();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
2018-12-02 18:52:50 +00:00
|
|
|
updateTitle: function() {
|
|
|
|
let tmp = "Tiny Tiny RSS";
|
2018-12-01 15:25:32 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
if (this.global_unread > 0) {
|
|
|
|
tmp = "(" + this.global_unread + ") " + tmp;
|
|
|
|
}
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
document.title = tmp;
|
|
|
|
},
|
|
|
|
onViewModeChanged: function() {
|
2020-01-24 13:04:12 +00:00
|
|
|
const view_mode = document.forms["toolbar-main"].view_mode.value;
|
|
|
|
|
|
|
|
$$("body")[0].setAttribute("view-mode", view_mode);
|
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
return Feeds.reloadCurrent('');
|
|
|
|
},
|
|
|
|
isCombinedMode: function() {
|
|
|
|
return App.getInitParam("combined_display_mode");
|
|
|
|
},
|
2019-04-07 10:21:52 +00:00
|
|
|
hotkeyHandler: function(event) {
|
2018-12-02 18:52:50 +00:00
|
|
|
if (event.target.nodeName == "INPUT" || event.target.nodeName == "TEXTAREA") return;
|
|
|
|
|
Refactor hotkeys to use keypress instead of keydown
keydown returns the "raw" key in event.which. Depending on the keyboard
layout, this may not be what is wanted. For example, on a German
keyboard, Shift+7 has to be pressed to get a slash. However, event.which
will be 55, which corresponds to "7". In the keypress event, however,
event.which will be 47, which corresponds to "/".
Sadly, several important keys (such as escape and the arrow keys) do not
trigger a keypress event. Therefore, they have to be handled using a
keydown event.
This change refactors the hotkey support to make use of keypress events
whenever possible. This will make hotkeys work regardless of the user's
keyboard layout. Escape and arrow keys are still handled via keydown
events.
There should be only one change in behavior: I could not make Ctrl+/
work and therefore rebound the help dialog to "?".
2019-03-11 10:29:10 +00:00
|
|
|
// Arrow buttons and escape are not reported via keypress, handle them via keydown.
|
2020-05-03 12:35:17 +00:00
|
|
|
// escape = 27, left = 37, up = 38, right = 39, down = 40, pgup = 33, pgdn = 34, insert = 45, delete = 46
|
|
|
|
if (event.type == "keydown" && event.which != 27 && (event.which < 33 || event.which > 46)) return;
|
Refactor hotkeys to use keypress instead of keydown
keydown returns the "raw" key in event.which. Depending on the keyboard
layout, this may not be what is wanted. For example, on a German
keyboard, Shift+7 has to be pressed to get a slash. However, event.which
will be 55, which corresponds to "7". In the keypress event, however,
event.which will be 47, which corresponds to "/".
Sadly, several important keys (such as escape and the arrow keys) do not
trigger a keypress event. Therefore, they have to be handled using a
keydown event.
This change refactors the hotkey support to make use of keypress events
whenever possible. This will make hotkeys work regardless of the user's
keyboard layout. Escape and arrow keys are still handled via keydown
events.
There should be only one change in behavior: I could not make Ctrl+/
work and therefore rebound the help dialog to "?".
2019-03-11 10:29:10 +00:00
|
|
|
|
2018-12-02 19:08:18 +00:00
|
|
|
const action_name = App.keyeventToAction(event);
|
2018-12-02 18:52:50 +00:00
|
|
|
|
|
|
|
if (action_name) {
|
|
|
|
const action_func = this.hotkey_actions[action_name];
|
|
|
|
|
|
|
|
if (action_func != null) {
|
2019-12-09 19:42:43 +00:00
|
|
|
action_func(event);
|
2018-12-02 18:52:50 +00:00
|
|
|
event.stopPropagation();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
switchPanelMode: function(wide) {
|
2018-12-08 06:46:48 +00:00
|
|
|
//if (App.isCombinedMode()) return;
|
2018-12-01 14:42:21 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
const article_id = Article.getActive();
|
2018-12-01 14:05:28 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
if (wide) {
|
|
|
|
dijit.byId("headlines-wrap-inner").attr("design", 'sidebar');
|
|
|
|
dijit.byId("content-insert").attr("region", "trailing");
|
2010-11-11 19:59:01 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
dijit.byId("content-insert").domNode.setStyle({width: '50%',
|
|
|
|
height: 'auto',
|
|
|
|
borderTopWidth: '0px' });
|
2009-01-17 10:14:45 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
if (parseInt(Cookie.get("ttrss_ci_width")) > 0) {
|
|
|
|
dijit.byId("content-insert").domNode.setStyle(
|
|
|
|
{width: Cookie.get("ttrss_ci_width") + "px" });
|
|
|
|
}
|
2013-02-28 11:56:22 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
$("headlines-frame").setStyle({ borderBottomWidth: '0px' });
|
|
|
|
$("headlines-frame").addClassName("wide");
|
2013-03-28 15:20:12 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
} else {
|
2013-04-24 15:49:37 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
dijit.byId("content-insert").attr("region", "bottom");
|
2018-12-01 14:05:28 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
dijit.byId("content-insert").domNode.setStyle({width: 'auto',
|
|
|
|
height: '50%',
|
|
|
|
borderTopWidth: '0px'});
|
2009-01-17 10:14:45 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
if (parseInt(Cookie.get("ttrss_ci_height")) > 0) {
|
|
|
|
dijit.byId("content-insert").domNode.setStyle(
|
|
|
|
{height: Cookie.get("ttrss_ci_height") + "px" });
|
|
|
|
}
|
2018-12-01 14:05:28 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
$("headlines-frame").setStyle({ borderBottomWidth: '1px' });
|
|
|
|
$("headlines-frame").removeClassName("wide");
|
2018-12-01 14:05:28 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
}
|
2009-01-17 10:14:45 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
Article.close();
|
2010-11-16 08:41:31 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
if (article_id) Article.view(article_id);
|
2010-11-16 09:23:06 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
xhrPost("backend.php", {op: "rpc", method: "setpanelmode", wide: wide ? 1 : 0});
|
|
|
|
},
|
|
|
|
initHotkeyActions: function() {
|
|
|
|
this.hotkey_actions["next_feed"] = function () {
|
|
|
|
const rv = dijit.byId("feedTree").getNextFeed(
|
|
|
|
Feeds.getActive(), Feeds.activeIsCat());
|
2013-05-08 05:18:43 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
if (rv) Feeds.open({feed: rv[0], is_cat: rv[1], delayed: true})
|
|
|
|
};
|
|
|
|
this.hotkey_actions["prev_feed"] = function () {
|
|
|
|
const rv = dijit.byId("feedTree").getPreviousFeed(
|
|
|
|
Feeds.getActive(), Feeds.activeIsCat());
|
2018-12-01 18:51:00 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
if (rv) Feeds.open({feed: rv[0], is_cat: rv[1], delayed: true})
|
|
|
|
};
|
2019-12-11 03:53:32 +00:00
|
|
|
this.hotkey_actions["next_article_or_scroll"] = function (event) {
|
2019-12-09 20:23:54 +00:00
|
|
|
Headlines.move('next', {event: event});
|
2018-12-02 18:52:50 +00:00
|
|
|
};
|
2019-12-11 03:53:32 +00:00
|
|
|
this.hotkey_actions["prev_article_or_scroll"] = function (event) {
|
2019-12-09 20:23:54 +00:00
|
|
|
Headlines.move('prev', {event: event});
|
2018-12-02 18:52:50 +00:00
|
|
|
};
|
2019-12-09 20:23:54 +00:00
|
|
|
this.hotkey_actions["next_article_noscroll"] = function (event) {
|
|
|
|
Headlines.move('next', {noscroll: true, event: event});
|
2018-12-02 18:52:50 +00:00
|
|
|
};
|
2019-12-09 20:23:54 +00:00
|
|
|
this.hotkey_actions["prev_article_noscroll"] = function (event) {
|
|
|
|
Headlines.move('prev', {noscroll: true, event: event});
|
2018-12-02 18:52:50 +00:00
|
|
|
};
|
2019-12-09 20:23:54 +00:00
|
|
|
this.hotkey_actions["next_article_noexpand"] = function (event) {
|
|
|
|
Headlines.move('next', {noscroll: true, noexpand: true, event: event});
|
2018-12-02 18:52:50 +00:00
|
|
|
};
|
2019-12-09 20:23:54 +00:00
|
|
|
this.hotkey_actions["prev_article_noexpand"] = function (event) {
|
|
|
|
Headlines.move('prev', {noscroll: true, noexpand: true, event: event});
|
2018-12-02 18:52:50 +00:00
|
|
|
};
|
|
|
|
this.hotkey_actions["search_dialog"] = function () {
|
|
|
|
Feeds.search();
|
|
|
|
};
|
|
|
|
this.hotkey_actions["toggle_mark"] = function () {
|
|
|
|
Headlines.selectionToggleMarked();
|
|
|
|
};
|
|
|
|
this.hotkey_actions["toggle_publ"] = function () {
|
|
|
|
Headlines.selectionTogglePublished();
|
|
|
|
};
|
|
|
|
this.hotkey_actions["toggle_unread"] = function () {
|
|
|
|
Headlines.selectionToggleUnread({no_error: 1});
|
|
|
|
};
|
|
|
|
this.hotkey_actions["edit_tags"] = function () {
|
|
|
|
const id = Article.getActive();
|
|
|
|
if (id) {
|
|
|
|
Article.editTags(id);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
this.hotkey_actions["open_in_new_window"] = function () {
|
|
|
|
if (Article.getActive()) {
|
|
|
|
Article.openInNewWindow(Article.getActive());
|
|
|
|
}
|
|
|
|
};
|
|
|
|
this.hotkey_actions["catchup_below"] = function () {
|
|
|
|
Headlines.catchupRelativeTo(1);
|
|
|
|
};
|
|
|
|
this.hotkey_actions["catchup_above"] = function () {
|
|
|
|
Headlines.catchupRelativeTo(0);
|
|
|
|
};
|
2019-12-09 19:42:43 +00:00
|
|
|
this.hotkey_actions["article_scroll_down"] = function (event) {
|
2019-12-11 03:53:32 +00:00
|
|
|
const ctr = App.isCombinedMode() ? $("headlines-frame") : $("content-insert");
|
|
|
|
|
|
|
|
if (ctr)
|
|
|
|
Article.scroll(ctr.offsetHeight / 2, event);
|
2018-12-02 18:52:50 +00:00
|
|
|
};
|
2019-12-09 19:42:43 +00:00
|
|
|
this.hotkey_actions["article_scroll_up"] = function (event) {
|
2019-12-11 03:53:32 +00:00
|
|
|
const ctr = App.isCombinedMode() ? $("headlines-frame") : $("content-insert");
|
|
|
|
|
|
|
|
if (ctr)
|
|
|
|
Article.scroll(-ctr.offsetHeight / 2, event);
|
2018-12-02 18:52:50 +00:00
|
|
|
};
|
2019-12-09 19:42:43 +00:00
|
|
|
this.hotkey_actions["next_article_page"] = function (event) {
|
|
|
|
Headlines.scrollByPages(1, event);
|
2019-12-05 14:00:02 +00:00
|
|
|
};
|
2019-12-09 19:42:43 +00:00
|
|
|
this.hotkey_actions["prev_article_page"] = function (event) {
|
|
|
|
Headlines.scrollByPages(-1, event);
|
2019-12-05 14:00:02 +00:00
|
|
|
};
|
2019-12-09 19:42:43 +00:00
|
|
|
this.hotkey_actions["article_page_down"] = function (event) {
|
|
|
|
Article.scrollByPages(1, event);
|
2019-12-04 12:50:49 +00:00
|
|
|
};
|
2019-12-09 19:42:43 +00:00
|
|
|
this.hotkey_actions["article_page_up"] = function (event) {
|
|
|
|
Article.scrollByPages(-1, event);
|
2019-12-04 12:50:49 +00:00
|
|
|
};
|
2018-12-02 18:52:50 +00:00
|
|
|
this.hotkey_actions["close_article"] = function () {
|
|
|
|
if (App.isCombinedMode()) {
|
|
|
|
Article.cdmUnsetActive();
|
|
|
|
} else {
|
|
|
|
Article.close();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
this.hotkey_actions["email_article"] = function () {
|
2018-12-03 11:21:50 +00:00
|
|
|
if (typeof Plugins.Mail != "undefined") {
|
|
|
|
Plugins.Mail.onHotkey(Headlines.getSelected());
|
2018-12-02 18:52:50 +00:00
|
|
|
} else {
|
2018-12-03 11:21:50 +00:00
|
|
|
alert(__("Please enable mail or mailto plugin first."));
|
2018-12-02 18:52:50 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
this.hotkey_actions["select_all"] = function () {
|
|
|
|
Headlines.select('all');
|
|
|
|
};
|
|
|
|
this.hotkey_actions["select_unread"] = function () {
|
|
|
|
Headlines.select('unread');
|
|
|
|
};
|
|
|
|
this.hotkey_actions["select_marked"] = function () {
|
|
|
|
Headlines.select('marked');
|
|
|
|
};
|
|
|
|
this.hotkey_actions["select_published"] = function () {
|
|
|
|
Headlines.select('published');
|
|
|
|
};
|
|
|
|
this.hotkey_actions["select_invert"] = function () {
|
|
|
|
Headlines.select('invert');
|
|
|
|
};
|
|
|
|
this.hotkey_actions["select_none"] = function () {
|
|
|
|
Headlines.select('none');
|
|
|
|
};
|
|
|
|
this.hotkey_actions["feed_refresh"] = function () {
|
2019-12-11 03:53:32 +00:00
|
|
|
if (typeof Feeds.getActive() != "undefined") {
|
2018-12-02 18:52:50 +00:00
|
|
|
Feeds.open({feed: Feeds.getActive(), is_cat: Feeds.activeIsCat()});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
this.hotkey_actions["feed_unhide_read"] = function () {
|
|
|
|
Feeds.toggleUnread();
|
|
|
|
};
|
|
|
|
this.hotkey_actions["feed_subscribe"] = function () {
|
|
|
|
CommonDialogs.quickAddFeed();
|
|
|
|
};
|
|
|
|
this.hotkey_actions["feed_debug_update"] = function () {
|
|
|
|
if (!Feeds.activeIsCat() && parseInt(Feeds.getActive()) > 0) {
|
|
|
|
window.open("backend.php?op=feeds&method=update_debugger&feed_id=" + Feeds.getActive() +
|
|
|
|
"&csrf_token=" + App.getInitParam("csrf_token"));
|
|
|
|
} else {
|
|
|
|
alert("You can't debug this kind of feed.");
|
|
|
|
}
|
|
|
|
};
|
2018-12-01 18:51:00 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
this.hotkey_actions["feed_debug_viewfeed"] = function () {
|
|
|
|
Feeds.open({feed: Feeds.getActive(), is_cat: Feeds.activeIsCat(), viewfeed_debug: true});
|
|
|
|
};
|
2018-12-01 18:51:00 +00:00
|
|
|
|
2018-12-02 18:52:50 +00:00
|
|
|
this.hotkey_actions["feed_edit"] = function () {
|
|
|
|
if (Feeds.activeIsCat())
|
|
|
|
alert(__("You can't edit this kind of feed."));
|
|
|
|
else
|
|
|
|
CommonDialogs.editFeed(Feeds.getActive());
|
|
|
|
};
|
|
|
|
this.hotkey_actions["feed_catchup"] = function () {
|
2019-12-11 03:53:32 +00:00
|
|
|
if (typeof Feeds.getActive() != "undefined") {
|
2018-12-02 18:52:50 +00:00
|
|
|
Feeds.catchupCurrent();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
this.hotkey_actions["feed_reverse"] = function () {
|
|
|
|
Headlines.reverse();
|
|
|
|
};
|
|
|
|
this.hotkey_actions["feed_toggle_vgroup"] = function () {
|
|
|
|
xhrPost("backend.php", {op: "rpc", method: "togglepref", key: "VFEED_GROUP_BY_FEED"}, () => {
|
|
|
|
Feeds.reloadCurrent();
|
|
|
|
})
|
|
|
|
};
|
|
|
|
this.hotkey_actions["catchup_all"] = function () {
|
|
|
|
Feeds.catchupAll();
|
|
|
|
};
|
|
|
|
this.hotkey_actions["cat_toggle_collapse"] = function () {
|
|
|
|
if (Feeds.activeIsCat()) {
|
|
|
|
dijit.byId("feedTree").collapseCat(Feeds.getActive());
|
|
|
|
}
|
|
|
|
};
|
2019-04-12 07:28:45 +00:00
|
|
|
this.hotkey_actions["goto_read"] = function () {
|
|
|
|
Feeds.open({feed: -6});
|
|
|
|
};
|
2018-12-02 18:52:50 +00:00
|
|
|
this.hotkey_actions["goto_all"] = function () {
|
|
|
|
Feeds.open({feed: -4});
|
|
|
|
};
|
|
|
|
this.hotkey_actions["goto_fresh"] = function () {
|
|
|
|
Feeds.open({feed: -3});
|
|
|
|
};
|
|
|
|
this.hotkey_actions["goto_marked"] = function () {
|
|
|
|
Feeds.open({feed: -1});
|
|
|
|
};
|
|
|
|
this.hotkey_actions["goto_published"] = function () {
|
|
|
|
Feeds.open({feed: -2});
|
|
|
|
};
|
|
|
|
this.hotkey_actions["goto_tagcloud"] = function () {
|
2018-12-02 19:08:18 +00:00
|
|
|
App.displayDlg(__("Tag cloud"), "printTagCloud");
|
2018-12-02 18:52:50 +00:00
|
|
|
};
|
|
|
|
this.hotkey_actions["goto_prefs"] = function () {
|
|
|
|
document.location.href = "prefs.php";
|
|
|
|
};
|
|
|
|
this.hotkey_actions["select_article_cursor"] = function () {
|
|
|
|
const id = Article.getUnderPointer();
|
|
|
|
if (id) {
|
|
|
|
const row = $("RROW-" + id);
|
|
|
|
|
2018-12-10 18:19:33 +00:00
|
|
|
if (row)
|
|
|
|
row.toggleClassName("Selected");
|
2018-12-02 18:52:50 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
this.hotkey_actions["create_label"] = function () {
|
|
|
|
CommonDialogs.addLabel();
|
|
|
|
};
|
|
|
|
this.hotkey_actions["create_filter"] = function () {
|
|
|
|
Filters.quickAddFilter();
|
|
|
|
};
|
|
|
|
this.hotkey_actions["collapse_sidebar"] = function () {
|
2018-12-03 17:49:37 +00:00
|
|
|
Feeds.toggle();
|
2018-12-02 18:52:50 +00:00
|
|
|
};
|
2020-02-28 05:03:25 +00:00
|
|
|
this.hotkey_actions["toggle_full_text"] = function () {
|
2020-02-27 06:47:20 +00:00
|
|
|
if (typeof Plugins.Af_Readability != "undefined") {
|
2018-12-02 18:52:50 +00:00
|
|
|
if (Article.getActive())
|
2020-02-27 06:47:20 +00:00
|
|
|
Plugins.Af_Readability.embed(Article.getActive());
|
2018-12-02 18:52:50 +00:00
|
|
|
} else {
|
2020-02-27 06:47:20 +00:00
|
|
|
alert(__("Please enable af_readability first."));
|
2018-12-02 18:52:50 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
this.hotkey_actions["toggle_widescreen"] = function () {
|
|
|
|
if (!App.isCombinedMode()) {
|
|
|
|
App._widescreen_mode = !App._widescreen_mode;
|
|
|
|
|
|
|
|
// reset stored sizes because geometry changed
|
|
|
|
Cookie.set("ttrss_ci_width", 0);
|
|
|
|
Cookie.set("ttrss_ci_height", 0);
|
|
|
|
|
|
|
|
App.switchPanelMode(App._widescreen_mode);
|
|
|
|
} else {
|
|
|
|
alert(__("Widescreen is not available in combined mode."));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
this.hotkey_actions["help_dialog"] = function () {
|
2018-12-02 19:08:18 +00:00
|
|
|
App.helpDialog("main");
|
2018-12-02 18:52:50 +00:00
|
|
|
};
|
|
|
|
this.hotkey_actions["toggle_combined_mode"] = function () {
|
|
|
|
const value = App.isCombinedMode() ? "false" : "true";
|
|
|
|
|
|
|
|
xhrPost("backend.php", {op: "rpc", method: "setpref", key: "COMBINED_DISPLAY_MODE", value: value}, () => {
|
|
|
|
App.setInitParam("combined_display_mode",
|
|
|
|
!App.getInitParam("combined_display_mode"));
|
|
|
|
|
|
|
|
Article.close();
|
2018-12-10 12:06:47 +00:00
|
|
|
Headlines.renderAgain();
|
2018-12-02 18:52:50 +00:00
|
|
|
})
|
|
|
|
};
|
|
|
|
this.hotkey_actions["toggle_cdm_expanded"] = function () {
|
|
|
|
const value = App.getInitParam("cdm_expanded") ? "false" : "true";
|
|
|
|
|
|
|
|
xhrPost("backend.php", {op: "rpc", method: "setpref", key: "CDM_EXPANDED", value: value}, () => {
|
|
|
|
App.setInitParam("cdm_expanded", !App.getInitParam("cdm_expanded"));
|
2018-12-10 12:06:47 +00:00
|
|
|
Headlines.renderAgain();
|
2018-12-02 18:52:50 +00:00
|
|
|
});
|
|
|
|
};
|
|
|
|
},
|
|
|
|
onActionSelected: function(opid) {
|
|
|
|
switch (opid) {
|
|
|
|
case "qmcPrefs":
|
|
|
|
document.location.href = "prefs.php";
|
|
|
|
break;
|
|
|
|
case "qmcLogout":
|
|
|
|
document.location.href = "backend.php?op=logout";
|
|
|
|
break;
|
|
|
|
case "qmcTagCloud":
|
2018-12-02 19:08:18 +00:00
|
|
|
App.displayDlg(__("Tag cloud"), "printTagCloud");
|
2018-12-02 18:52:50 +00:00
|
|
|
break;
|
|
|
|
case "qmcSearch":
|
|
|
|
Feeds.search();
|
|
|
|
break;
|
|
|
|
case "qmcAddFeed":
|
|
|
|
CommonDialogs.quickAddFeed();
|
|
|
|
break;
|
|
|
|
case "qmcDigest":
|
|
|
|
window.location.href = "backend.php?op=digest";
|
|
|
|
break;
|
|
|
|
case "qmcEditFeed":
|
|
|
|
if (Feeds.activeIsCat())
|
|
|
|
alert(__("You can't edit this kind of feed."));
|
|
|
|
else
|
|
|
|
CommonDialogs.editFeed(Feeds.getActive());
|
|
|
|
break;
|
|
|
|
case "qmcRemoveFeed":
|
|
|
|
const actid = Feeds.getActive();
|
|
|
|
|
|
|
|
if (!actid) {
|
|
|
|
alert(__("Please select some feed first."));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (Feeds.activeIsCat()) {
|
|
|
|
alert(__("You can't unsubscribe from the category."));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const fn = Feeds.getName(actid);
|
|
|
|
|
|
|
|
if (confirm(__("Unsubscribe from %s?").replace("%s", fn))) {
|
|
|
|
CommonDialogs.unsubscribeFeed(actid);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case "qmcCatchupAll":
|
|
|
|
Feeds.catchupAll();
|
|
|
|
break;
|
|
|
|
case "qmcShowOnlyUnread":
|
|
|
|
Feeds.toggleUnread();
|
|
|
|
break;
|
|
|
|
case "qmcToggleWidescreen":
|
|
|
|
if (!App.isCombinedMode()) {
|
|
|
|
App._widescreen_mode = !App._widescreen_mode;
|
|
|
|
|
|
|
|
// reset stored sizes because geometry changed
|
|
|
|
Cookie.set("ttrss_ci_width", 0);
|
|
|
|
Cookie.set("ttrss_ci_height", 0);
|
|
|
|
|
|
|
|
App.switchPanelMode(App._widescreen_mode);
|
|
|
|
} else {
|
|
|
|
alert(__("Widescreen is not available in combined mode."));
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case "qmcHKhelp":
|
2018-12-02 19:08:18 +00:00
|
|
|
App.helpDialog("main");
|
2018-12-02 18:52:50 +00:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
console.log("quickMenuGo: unknown action: " + opid);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
isPrefs: function() {
|
|
|
|
return false;
|
2018-12-01 18:51:00 +00:00
|
|
|
}
|
2018-12-02 18:52:50 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
App = new _App();
|
|
|
|
} catch (e) {
|
2019-12-14 06:39:44 +00:00
|
|
|
if (App && App.Error)
|
|
|
|
App.Error.report(e);
|
|
|
|
else
|
|
|
|
alert(e + "\n\n" + e.stack);
|
2008-05-15 16:27:11 +00:00
|
|
|
}
|
2018-12-02 18:52:50 +00:00
|
|
|
});
|
|
|
|
});
|
2010-02-18 13:05:35 +00:00
|
|
|
|
2013-02-28 09:06:54 +00:00
|
|
|
function hash_get(key) {
|
2018-11-29 17:07:23 +00:00
|
|
|
const kv = window.location.hash.substring(1).toQueryParams();
|
2017-03-04 11:34:44 +00:00
|
|
|
return kv[key];
|
2013-02-28 09:06:54 +00:00
|
|
|
}
|
2018-12-01 08:18:35 +00:00
|
|
|
|
2013-02-28 09:06:54 +00:00
|
|
|
function hash_set(key, value) {
|
2018-11-29 17:07:23 +00:00
|
|
|
const kv = window.location.hash.substring(1).toQueryParams();
|
2017-03-04 11:34:44 +00:00
|
|
|
kv[key] = value;
|
|
|
|
window.location.hash = $H(kv).toQueryString();
|
2013-02-28 09:06:54 +00:00
|
|
|
}
|