summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--classes/dlg.php2
-rwxr-xr-xclasses/feeds.php4
-rw-r--r--index.php20
-rw-r--r--js/feedlist.js9
-rwxr-xr-xjs/functions.js14
-rwxr-xr-xjs/prefs.js11
-rw-r--r--js/tt-rss.js622
-rwxr-xr-xjs/viewfeed.js582
8 files changed, 620 insertions, 644 deletions
diff --git a/classes/dlg.php b/classes/dlg.php
index d73a53618..50cbd12dd 100644
--- a/classes/dlg.php
+++ b/classes/dlg.php
@@ -190,7 +190,7 @@ class Dlg extends Handler_Protected {
print_warning(__("You are using default tt-rss password. Please change it in the Preferences (Personal data / Authentication)."));
print "<div align='center'>";
- print "<button dojoType=\"dijit.form.Button\" onclick=\"gotoPreferences()\">".
+ print "<button dojoType=\"dijit.form.Button\" onclick=\"document.location.href = 'prefs.php'\">".
__('Open Preferences')."</button> ";
print "<button dojoType=\"dijit.form.Button\"
onclick=\"return closeInfoBox()\">".
diff --git a/classes/feeds.php b/classes/feeds.php
index a5f384ed0..576d8e78b 100755
--- a/classes/feeds.php
+++ b/classes/feeds.php
@@ -95,7 +95,7 @@ class Feeds extends Handler_Protected {
$reply .= "</span> "; */
$reply .= "<select dojoType=\"dijit.form.Select\"
- onchange=\"headlineActionsChange(this)\">";
+ onchange=\"Headlines.onActionChanged(this)\">";
$reply .= "<option value=\"0\" disabled='1'>".__('Select...')."</option>";
@@ -299,7 +299,7 @@ class Feeds extends Handler_Protected {
$label_cache = $line["label_cache"];
$labels = false;
- $mouseover_attrs = "onmouseover='postMouseIn(event, $id)' onmouseout='postMouseOut($id)'";
+ $mouseover_attrs = "onmouseover='Article.mouseIn($id)' onmouseout='Article.mouseOut($id)'";
if ($label_cache) {
$label_cache = json_decode($label_cache, true);
diff --git a/index.php b/index.php
index 8b4b954ef..c8ff3f7c9 100644
--- a/index.php
+++ b/index.php
@@ -240,18 +240,18 @@
<div dojoType="dijit.form.DropDownButton">
<span><?php echo __('Actions...') ?></span>
<div dojoType="dijit.Menu" style="display: none">
- <div dojoType="dijit.MenuItem" onclick="quickMenuGo('qmcPrefs')"><?php echo __('Preferences...') ?></div>
- <div dojoType="dijit.MenuItem" onclick="quickMenuGo('qmcSearch')"><?php echo __('Search...') ?></div>
+ <div dojoType="dijit.MenuItem" onclick="App.onActionSelected('qmcPrefs')"><?php echo __('Preferences...') ?></div>
+ <div dojoType="dijit.MenuItem" onclick="App.onActionSelected('qmcSearch')"><?php echo __('Search...') ?></div>
<div dojoType="dijit.MenuItem" disabled="1"><?php echo __('Feed actions:') ?></div>
- <div dojoType="dijit.MenuItem" onclick="quickMenuGo('qmcAddFeed')"><?php echo __('Subscribe to feed...') ?></div>
- <div dojoType="dijit.MenuItem" onclick="quickMenuGo('qmcEditFeed')"><?php echo __('Edit this feed...') ?></div>
- <div dojoType="dijit.MenuItem" onclick="quickMenuGo('qmcRemoveFeed')"><?php echo __('Unsubscribe') ?></div>
+ <div dojoType="dijit.MenuItem" onclick="App.onActionSelected('qmcAddFeed')"><?php echo __('Subscribe to feed...') ?></div>
+ <div dojoType="dijit.MenuItem" onclick="App.onActionSelected('qmcEditFeed')"><?php echo __('Edit this feed...') ?></div>
+ <div dojoType="dijit.MenuItem" onclick="App.onActionSelected('qmcRemoveFeed')"><?php echo __('Unsubscribe') ?></div>
<div dojoType="dijit.MenuItem" disabled="1"><?php echo __('All feeds:') ?></div>
- <div dojoType="dijit.MenuItem" onclick="quickMenuGo('qmcCatchupAll')"><?php echo __('Mark as read') ?></div>
- <div dojoType="dijit.MenuItem" onclick="quickMenuGo('qmcShowOnlyUnread')"><?php echo __('(Un)hide read feeds') ?></div>
+ <div dojoType="dijit.MenuItem" onclick="App.onActionSelected('qmcCatchupAll')"><?php echo __('Mark as read') ?></div>
+ <div dojoType="dijit.MenuItem" onclick="App.onActionSelected('qmcShowOnlyUnread')"><?php echo __('(Un)hide read feeds') ?></div>
<div dojoType="dijit.MenuItem" disabled="1"><?php echo __('Other actions:') ?></div>
- <div dojoType="dijit.MenuItem" onclick="quickMenuGo('qmcToggleWidescreen')"><?php echo __('Toggle widescreen mode') ?></div>
- <div dojoType="dijit.MenuItem" onclick="quickMenuGo('qmcHKhelp')"><?php echo __('Keyboard shortcuts help') ?></div>
+ <div dojoType="dijit.MenuItem" onclick="App.onActionSelected('qmcToggleWidescreen')"><?php echo __('Toggle widescreen mode') ?></div>
+ <div dojoType="dijit.MenuItem" onclick="App.onActionSelected('qmcHKhelp')"><?php echo __('Keyboard shortcuts help') ?></div>
<?php
foreach (PluginHost::getInstance()->get_hooks(PluginHost::HOOK_ACTION_ITEM) as $p) {
@@ -260,7 +260,7 @@
?>
<?php if (!$_SESSION["hide_logout"]) { ?>
- <div dojoType="dijit.MenuItem" onclick="quickMenuGo('qmcLogout')"><?php echo __('Logout') ?></div>
+ <div dojoType="dijit.MenuItem" onclick="App.onActionSelected('qmcLogout')"><?php echo __('Logout') ?></div>
<?php } ?>
</div>
</div>
diff --git a/js/feedlist.js b/js/feedlist.js
index ad863f94c..c295bf22b 100644
--- a/js/feedlist.js
+++ b/js/feedlist.js
@@ -6,6 +6,7 @@ const Feeds = {
infscroll_disabled: 0,
_infscroll_timeout: false,
_search_query: false,
+ last_search_query: [],
_viewfeed_wait_timeout: false,
_counters_prev: [],
// NOTE: this implementation is incomplete
@@ -206,7 +207,7 @@ const Feeds = {
Utils.setLoadingProgress(50);
- document.onkeydown = App.hotkeyHandler;
+ document.onkeydown = () => { App.hotkeyHandler(event) };
window.setInterval(() => { hotkeyPrefixTimeout() }, 3 * 1000);
window.setInterval(() => { Headlines.catchupBatchedArticles() }, 10 * 1000);
@@ -436,7 +437,7 @@ const Feeds = {
str = __("Mark %w in %s as read?");
}
- const mark_what = last_search_query && last_search_query[0] ? __("search results") : __("all articles");
+ const mark_what = this.last_search_query && this.last_search_query[0] ? __("search results") : __("all articles");
const fn = this.getFeedName(feed, is_cat);
str = str.replace("%s", fn)
@@ -448,8 +449,8 @@ const Feeds = {
const catchup_query = {
op: 'rpc', method: 'catchupFeed', feed_id: feed,
- is_cat: is_cat, mode: mode, search_query: last_search_query[0],
- search_lang: last_search_query[1]
+ is_cat: is_cat, mode: mode, search_query: this.last_search_query[0],
+ search_lang: this.last_search_query[1]
};
notify_progress("Loading, please wait...", true);
diff --git a/js/functions.js b/js/functions.js
index 1a0fca484..b6d86b51c 100755
--- a/js/functions.js
+++ b/js/functions.js
@@ -1025,7 +1025,7 @@ function uploadIconHandler(rc) {
switch (rc) {
case 0:
notify_info("Upload complete.");
- if (inPreferences()) {
+ if (App.isPrefs()) {
Feeds.reload();
} else {
setTimeout('Feeds.reload(false, false)', 50);
@@ -1050,7 +1050,7 @@ function removeFeedIcon(id) {
xhrPost("backend.php", query, (transport) => {
notify_info("Feed icon removed.");
- if (inPreferences()) {
+ if (App.isPrefs()) {
Feeds.reload();
} else {
setTimeout('Feeds.reload(false, false)', 50);
@@ -1090,7 +1090,7 @@ function addLabel(select, callback) {
xhrPost("backend.php", query, (transport) => {
if (callback) {
callback(transport);
- } else if (inPreferences()) {
+ } else if (App.isPrefs()) {
updateLabelList();
} else {
Feeds.reload();
@@ -1317,7 +1317,7 @@ function editFilterTest(query) {
function quickAddFilter() {
let query;
- if (!inPreferences()) {
+ if (!App.isPrefs()) {
query = { op: "pref-filters", method: "newfilter",
feed: Feeds.getActiveFeedId(), is_cat: Feeds.activeFeedIsCat() };
} else {
@@ -1385,7 +1385,7 @@ function quickAddFilter() {
const query = dojo.formToQuery("filter_new_form");
xhrPost("backend.php", query, (transport) => {
- if (inPreferences()) {
+ if (App.isPrefs()) {
updateFilterList();
}
@@ -1395,7 +1395,7 @@ function quickAddFilter() {
},
href: "backend.php?" + dojo.objectToQuery(query)});
- if (!inPreferences()) {
+ if (!App.isPrefs()) {
const selectedText = getSelectionText();
const lh = dojo.connect(dialog, "onLoad", function(){
@@ -1453,7 +1453,7 @@ function unsubscribeFeed(feed_id, title) {
xhrPost("backend.php", query, (transport) => {
if (dijit.byId("feedEditDlg")) dijit.byId("feedEditDlg").hide();
- if (inPreferences()) {
+ if (App.isPrefs()) {
Feeds.reload();
} else {
if (feed_id == Feeds.getActiveFeedId())
diff --git a/js/prefs.js b/js/prefs.js
index a9417cf3c..8308a747f 100755
--- a/js/prefs.js
+++ b/js/prefs.js
@@ -65,7 +65,7 @@ const App = {
});
},
initSecondStage: function() {
- document.onkeydown = this.hotkeyHandler;
+ document.onkeydown = () => { App.hotkeyHandler(event) };
Utils.setLoadingProgress(50);
notify("");
@@ -111,8 +111,11 @@ const App = {
console.log("unhandled action: " + action_name + "; keycode: " + event.which);
}
}
+ },
+ isPrefs: function() {
+ return true;
}
-}
+};
function notify_callback2(transport, sticky) {
notify_info(transport.responseText, sticky);
@@ -909,10 +912,6 @@ function labelColorReset() {
}
}
-function inPreferences() {
- return true;
-}
-
function editProfiles() {
if (dijit.byId("profileEditDlg"))
diff --git a/js/tt-rss.js b/js/tt-rss.js
index 02cf1ddb6..46f100e27 100644
--- a/js/tt-rss.js
+++ b/js/tt-rss.js
@@ -1,10 +1,9 @@
/* global dijit, __ */
-let hotkey_actions = {};
-
const App = {
global_unread: -1,
_widescreen_mode: false,
+ hotkey_actions: {},
init: function() {
window.onerror = function (message, filename, lineno, colno, error) {
@@ -57,7 +56,7 @@ const App = {
return false;
Utils.setLoadingProgress(30);
- init_hotkey_actions();
+ App.initHotkeyActions();
const a = document.createElement('audio');
const hasAudio = !!a.canPlayType;
@@ -179,7 +178,7 @@ const App = {
const action_name = Utils.keyeventToAction(event);
if (action_name) {
- const action_func = hotkey_actions[action_name];
+ const action_func = this.hotkey_actions[action_name];
if (action_func != null) {
action_func();
@@ -233,331 +232,328 @@ const App = {
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.getActiveFeedId(), Feeds.activeFeedIsCat());
-function init_hotkey_actions() {
- hotkey_actions["next_feed"] = function () {
- const rv = dijit.byId("feedTree").getNextFeed(
- Feeds.getActiveFeedId(), Feeds.activeFeedIsCat());
-
- if (rv) Feeds.viewfeed({feed: rv[0], is_cat: rv[1], delayed: true})
- };
- hotkey_actions["prev_feed"] = function () {
- const rv = dijit.byId("feedTree").getPreviousFeed(
- Feeds.getActiveFeedId(), Feeds.activeFeedIsCat());
-
- if (rv) Feeds.viewfeed({feed: rv[0], is_cat: rv[1], delayed: true})
- };
- hotkey_actions["next_article"] = function () {
- Headlines.moveToPost('next');
- };
- hotkey_actions["prev_article"] = function () {
- Headlines.moveToPost('prev');
- };
- hotkey_actions["next_article_noscroll"] = function () {
- Headlines.moveToPost('next', true);
- };
- hotkey_actions["prev_article_noscroll"] = function () {
- Headlines.moveToPost('prev', true);
- };
- hotkey_actions["next_article_noexpand"] = function () {
- Headlines.moveToPost('next', true, true);
- };
- hotkey_actions["prev_article_noexpand"] = function () {
- Headlines.moveToPost('prev', true, true);
- };
- hotkey_actions["search_dialog"] = function () {
- Feeds.search();
- };
- hotkey_actions["toggle_mark"] = function () {
- Headlines.selectionToggleMarked();
- };
- hotkey_actions["toggle_publ"] = function () {
- Headlines.selectionTogglePublished();
- };
- hotkey_actions["toggle_unread"] = function () {
- Headlines.selectionToggleUnread({no_error: 1});
- };
- hotkey_actions["edit_tags"] = function () {
- const id = Article.getActiveArticleId();
- if (id) {
- Article.editArticleTags(id);
- }
- }
- hotkey_actions["open_in_new_window"] = function () {
- if (Article.getActiveArticleId()) {
- Article.openArticleInNewWindow(Article.getActiveArticleId());
- }
- };
- hotkey_actions["catchup_below"] = function () {
- catchupRelativeToArticle(1);
- };
- hotkey_actions["catchup_above"] = function () {
- catchupRelativeToArticle(0);
- };
- hotkey_actions["article_scroll_down"] = function () {
- scrollArticle(40);
- };
- hotkey_actions["article_scroll_up"] = function () {
- scrollArticle(-40);
- };
- hotkey_actions["close_article"] = function () {
- if (App.isCombinedMode()) {
- Article.cdmCollapseActive();
- } else {
- Article.closeArticlePanel();
- }
- };
- hotkey_actions["email_article"] = function () {
- if (typeof emailArticle != "undefined") {
- emailArticle();
- } else if (typeof mailtoArticle != "undefined") {
- mailtoArticle();
- } else {
- alert(__("Please enable mail plugin first."));
- }
- };
- hotkey_actions["select_all"] = function () {
- Headlines.selectArticles('all');
- };
- hotkey_actions["select_unread"] = function () {
- Headlines.selectArticles('unread');
- };
- hotkey_actions["select_marked"] = function () {
- Headlines.selectArticles('marked');
- };
- hotkey_actions["select_published"] = function () {
- Headlines.selectArticles('published');
- };
- hotkey_actions["select_invert"] = function () {
- Headlines.selectArticles('invert');
- };
- hotkey_actions["select_none"] = function () {
- Headlines.selectArticles('none');
- };
- hotkey_actions["feed_refresh"] = function () {
- if (Feeds.getActiveFeedId() != undefined) {
- Feeds.viewfeed({feed: Feeds.getActiveFeedId(), is_cat: Feeds.activeFeedIsCat()});
- }
- };
- hotkey_actions["feed_unhide_read"] = function () {
- Feeds.toggleDispRead();
- };
- hotkey_actions["feed_subscribe"] = function () {
- CommonDialogs.quickAddFeed();
- };
- hotkey_actions["feed_debug_update"] = function () {
- if (!Feeds.activeFeedIsCat() && parseInt(Feeds.getActiveFeedId()) > 0) {
- window.open("backend.php?op=feeds&method=update_debugger&feed_id=" + Feeds.getActiveFeedId() +
- "&csrf_token=" + getInitParam("csrf_token"));
- } else {
- alert("You can't debug this kind of feed.");
- }
- };
-
- hotkey_actions["feed_debug_viewfeed"] = function () {
- Feeds.viewfeed({feed: Feeds.getActiveFeedId(), is_cat: Feeds.activeFeedIsCat(), viewfeed_debug: true});
- };
-
- hotkey_actions["feed_edit"] = function () {
- if (Feeds.activeFeedIsCat())
- alert(__("You can't edit this kind of feed."));
- else
- editFeed(Feeds.getActiveFeedId());
- };
- hotkey_actions["feed_catchup"] = function () {
- if (Feeds.getActiveFeedId() != undefined) {
- Feeds.catchupCurrentFeed();
- }
- };
- hotkey_actions["feed_reverse"] = function () {
- Headlines.reverseHeadlineOrder();
- };
- hotkey_actions["feed_toggle_vgroup"] = function () {
- xhrPost("backend.php", {op: "rpc", method: "togglepref", key: "VFEED_GROUP_BY_FEED"}, () => {
- Feeds.viewCurrentFeed();
- })
- };
- hotkey_actions["catchup_all"] = function () {
- Feeds.catchupAllFeeds();
- };
- hotkey_actions["cat_toggle_collapse"] = function () {
- if (Feeds.activeFeedIsCat()) {
- dijit.byId("feedTree").collapseCat(Feeds.getActiveFeedId());
- }
- };
- hotkey_actions["goto_all"] = function () {
- Feeds.viewfeed({feed: -4});
- };
- hotkey_actions["goto_fresh"] = function () {
- Feeds.viewfeed({feed: -3});
- };
- hotkey_actions["goto_marked"] = function () {
- Feeds.viewfeed({feed: -1});
- };
- hotkey_actions["goto_published"] = function () {
- Feeds.viewfeed({feed: -2});
- };
- hotkey_actions["goto_tagcloud"] = function () {
- Utils.displayDlg(__("Tag cloud"), "printTagCloud");
- };
- hotkey_actions["goto_prefs"] = function () {
- gotoPreferences();
- };
- hotkey_actions["select_article_cursor"] = function () {
- const id = getArticleUnderPointer();
- if (id) {
- const row = $("RROW-" + id);
-
- if (row) {
- const cb = dijit.getEnclosingWidget(
- row.select(".rchk")[0]);
-
- if (cb) {
- if (!row.hasClassName("active"))
- cb.attr("checked", !cb.attr("checked"));
-
- toggleSelectRowById(cb, "RROW-" + id);
- return false;
- }
+ if (rv) Feeds.viewfeed({feed: rv[0], is_cat: rv[1], delayed: true})
+ };
+ this.hotkey_actions["prev_feed"] = function () {
+ const rv = dijit.byId("feedTree").getPreviousFeed(
+ Feeds.getActiveFeedId(), Feeds.activeFeedIsCat());
+
+ if (rv) Feeds.viewfeed({feed: rv[0], is_cat: rv[1], delayed: true})
+ };
+ this.hotkey_actions["next_article"] = function () {
+ Headlines.moveToPost('next');
+ };
+ this.hotkey_actions["prev_article"] = function () {
+ Headlines.moveToPost('prev');
+ };
+ this.hotkey_actions["next_article_noscroll"] = function () {
+ Headlines.moveToPost('next', true);
+ };
+ this.hotkey_actions["prev_article_noscroll"] = function () {
+ Headlines.moveToPost('prev', true);
+ };
+ this.hotkey_actions["next_article_noexpand"] = function () {
+ Headlines.moveToPost('next', true, true);
+ };
+ this.hotkey_actions["prev_article_noexpand"] = function () {
+ Headlines.moveToPost('prev', true, true);
+ };
+ 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.getActiveArticleId();
+ if (id) {
+ Article.editArticleTags(id);
}
}
- };
- hotkey_actions["create_label"] = function () {
- addLabel();
- };
- hotkey_actions["create_filter"] = function () {
- quickAddFilter();
- };
- hotkey_actions["collapse_sidebar"] = function () {
- Feeds.viewCurrentFeed();
- };
- hotkey_actions["toggle_embed_original"] = function () {
- if (typeof embedOriginalArticle != "undefined") {
- if (Article.getActiveArticleId())
- embedOriginalArticle(Article.getActiveArticleId());
- } else {
- alert(__("Please enable embed_original plugin first."));
- }
- };
- hotkey_actions["toggle_widescreen"] = function () {
- if (!App.isCombinedMode()) {
- App._widescreen_mode = !App._widescreen_mode;
+ this.hotkey_actions["open_in_new_window"] = function () {
+ if (Article.getActiveArticleId()) {
+ Article.openArticleInNewWindow(Article.getActiveArticleId());
+ }
+ };
+ this.hotkey_actions["catchup_below"] = function () {
+ Headlines.catchupRelativeToArticle(1);
+ };
+ this.hotkey_actions["catchup_above"] = function () {
+ Headlines.catchupRelativeToArticle(0);
+ };
+ this.hotkey_actions["article_scroll_down"] = function () {
+ Article.scrollArticle(40);
+ };
+ this.hotkey_actions["article_scroll_up"] = function () {
+ Article.scrollArticle(-40);
+ };
+ this.hotkey_actions["close_article"] = function () {
+ if (App.isCombinedMode()) {
+ Article.cdmCollapseActive();
+ } else {
+ Article.closeArticlePanel();
+ }
+ };
+ this.hotkey_actions["email_article"] = function () {
+ if (typeof emailArticle != "undefined") {
+ emailArticle();
+ } else if (typeof mailtoArticle != "undefined") {
+ mailtoArticle();
+ } else {
+ alert(__("Please enable mail plugin first."));
+ }
+ };
+ this.hotkey_actions["select_all"] = function () {
+ Headlines.selectArticles('all');
+ };
+ this.hotkey_actions["select_unread"] = function () {
+ Headlines.selectArticles('unread');
+ };
+ this.hotkey_actions["select_marked"] = function () {
+ Headlines.selectArticles('marked');
+ };
+ this.hotkey_actions["select_published"] = function () {
+ Headlines.selectArticles('published');
+ };
+ this.hotkey_actions["select_invert"] = function () {
+ Headlines.selectArticles('invert');
+ };
+ this.hotkey_actions["select_none"] = function () {
+ Headlines.selectArticles('none');
+ };
+ this.hotkey_actions["feed_refresh"] = function () {
+ if (Feeds.getActiveFeedId() != undefined) {
+ Feeds.viewfeed({feed: Feeds.getActiveFeedId(), is_cat: Feeds.activeFeedIsCat()});
+ }
+ };
+ this.hotkey_actions["feed_unhide_read"] = function () {
+ Feeds.toggleDispRead();
+ };
+ this.hotkey_actions["feed_subscribe"] = function () {
+ CommonDialogs.quickAddFeed();
+ };
+ this.hotkey_actions["feed_debug_update"] = function () {
+ if (!Feeds.activeFeedIsCat() && parseInt(Feeds.getActiveFeedId()) > 0) {
+ window.open("backend.php?op=feeds&method=update_debugger&feed_id=" + Feeds.getActiveFeedId() +
+ "&csrf_token=" + getInitParam("csrf_token"));
+ } else {
+ alert("You can't debug this kind of feed.");
+ }
+ };
- // reset stored sizes because geometry changed
- setCookie("ttrss_ci_width", 0);
- setCookie("ttrss_ci_height", 0);
+ this.hotkey_actions["feed_debug_viewfeed"] = function () {
+ Feeds.viewfeed({feed: Feeds.getActiveFeedId(), is_cat: Feeds.activeFeedIsCat(), viewfeed_debug: true});
+ };
- App.switchPanelMode(App._widescreen_mode);
- } else {
- alert(__("Widescreen is not available in combined mode."));
- }
- };
- hotkey_actions["help_dialog"] = function () {
- Utils.helpDialog("main");
- };
- hotkey_actions["toggle_combined_mode"] = function () {
- notify_progress("Loading, please wait...");
+ this.hotkey_actions["feed_edit"] = function () {
+ if (Feeds.activeFeedIsCat())
+ alert(__("You can't edit this kind of feed."));
+ else
+ editFeed(Feeds.getActiveFeedId());
+ };
+ this.hotkey_actions["feed_catchup"] = function () {
+ if (Feeds.getActiveFeedId() != undefined) {
+ Feeds.catchupCurrentFeed();
+ }
+ };
+ this.hotkey_actions["feed_reverse"] = function () {
+ Headlines.reverseHeadlineOrder();
+ };
+ this.hotkey_actions["feed_toggle_vgroup"] = function () {
+ xhrPost("backend.php", {op: "rpc", method: "togglepref", key: "VFEED_GROUP_BY_FEED"}, () => {
+ Feeds.viewCurrentFeed();
+ })
+ };
+ this.hotkey_actions["catchup_all"] = function () {
+ Feeds.catchupAllFeeds();
+ };
+ this.hotkey_actions["cat_toggle_collapse"] = function () {
+ if (Feeds.activeFeedIsCat()) {
+ dijit.byId("feedTree").collapseCat(Feeds.getActiveFeedId());
+ }
+ };
+ this.hotkey_actions["goto_all"] = function () {
+ Feeds.viewfeed({feed: -4});
+ };
+ this.hotkey_actions["goto_fresh"] = function () {
+ Feeds.viewfeed({feed: -3});
+ };
+ this.hotkey_actions["goto_marked"] = function () {
+ Feeds.viewfeed({feed: -1});
+ };
+ this.hotkey_actions["goto_published"] = function () {
+ Feeds.viewfeed({feed: -2});
+ };
+ this.hotkey_actions["goto_tagcloud"] = function () {
+ Utils.displayDlg(__("Tag cloud"), "printTagCloud");
+ };
+ this.hotkey_actions["goto_prefs"] = function () {
+ document.location.href = "prefs.php";
+ };
+ this.hotkey_actions["select_article_cursor"] = function () {
+ const id = Article.getArticleUnderPointer();
+ if (id) {
+ const row = $("RROW-" + id);
- const value = App.isCombinedMode() ? "false" : "true";
+ if (row) {
+ const cb = dijit.getEnclosingWidget(
+ row.select(".rchk")[0]);
- xhrPost("backend.php", {op: "rpc", method: "setpref", key: "COMBINED_DISPLAY_MODE", value: value}, () => {
- setInitParam("combined_display_mode",
- !getInitParam("combined_display_mode"));
+ if (cb) {
+ if (!row.hasClassName("active"))
+ cb.attr("checked", !cb.attr("checked"));
- Article.closeArticlePanel();
+ toggleSelectRowById(cb, "RROW-" + id);
+ return false;
+ }
+ }
+ }
+ };
+ this.hotkey_actions["create_label"] = function () {
+ addLabel();
+ };
+ this.hotkey_actions["create_filter"] = function () {
+ quickAddFilter();
+ };
+ this.hotkey_actions["collapse_sidebar"] = function () {
Feeds.viewCurrentFeed();
- })
- };
- hotkey_actions["toggle_cdm_expanded"] = function () {
- notify_progress("Loading, please wait...");
+ };
+ this.hotkey_actions["toggle_embed_original"] = function () {
+ if (typeof embedOriginalArticle != "undefined") {
+ if (Article.getActiveArticleId())
+ embedOriginalArticle(Article.getActiveArticleId());
+ } else {
+ alert(__("Please enable embed_original plugin first."));
+ }
+ };
+ this.hotkey_actions["toggle_widescreen"] = function () {
+ if (!App.isCombinedMode()) {
+ App._widescreen_mode = !App._widescreen_mode;
- const value = getInitParam("cdm_expanded") ? "false" : "true";
+ // reset stored sizes because geometry changed
+ setCookie("ttrss_ci_width", 0);
+ setCookie("ttrss_ci_height", 0);
- xhrPost("backend.php", {op: "rpc", method: "setpref", key: "CDM_EXPANDED", value: value}, () => {
- setInitParam("cdm_expanded", !getInitParam("cdm_expanded"));
- Feeds.viewCurrentFeed();
- });
- };
-}
+ App.switchPanelMode(App._widescreen_mode);
+ } else {
+ alert(__("Widescreen is not available in combined mode."));
+ }
+ };
+ this.hotkey_actions["help_dialog"] = function () {
+ Utils.helpDialog("main");
+ };
+ this.hotkey_actions["toggle_combined_mode"] = function () {
+ notify_progress("Loading, please wait...");
-function quickMenuGo(opid) {
- switch (opid) {
- case "qmcPrefs":
- gotoPreferences();
- break;
- case "qmcLogout":
- document.location.href = "backend.php?op=logout";
- break;
- case "qmcTagCloud":
- Utils.displayDlg(__("Tag cloud"), "printTagCloud");
- 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.activeFeedIsCat())
- alert(__("You can't edit this kind of feed."));
- else
- editFeed(Feeds.getActiveFeedId());
- break;
- case "qmcRemoveFeed":
- var actid = Feeds.getActiveFeedId();
-
- if (Feeds.activeFeedIsCat()) {
- alert(__("You can't unsubscribe from the category."));
- return;
- }
+ const value = App.isCombinedMode() ? "false" : "true";
- if (!actid) {
- alert(__("Please select some feed first."));
- return;
- }
+ xhrPost("backend.php", {op: "rpc", method: "setpref", key: "COMBINED_DISPLAY_MODE", value: value}, () => {
+ setInitParam("combined_display_mode",
+ !getInitParam("combined_display_mode"));
+
+ Article.closeArticlePanel();
+ Feeds.viewCurrentFeed();
+ })
+ };
+ this.hotkey_actions["toggle_cdm_expanded"] = function () {
+ notify_progress("Loading, please wait...");
- var fn = Feeds.getFeedName(actid);
+ const value = getInitParam("cdm_expanded") ? "false" : "true";
- var pr = __("Unsubscribe from %s?").replace("%s", fn);
+ xhrPost("backend.php", {op: "rpc", method: "setpref", key: "CDM_EXPANDED", value: value}, () => {
+ setInitParam("cdm_expanded", !getInitParam("cdm_expanded"));
+ Feeds.viewCurrentFeed();
+ });
+ };
+ },
+ onActionSelected: function(opid) {
+ switch (opid) {
+ case "qmcPrefs":
+ gotoPreferences();
+ break;
+ case "qmcLogout":
+ document.location.href = "backend.php?op=logout";
+ break;
+ case "qmcTagCloud":
+ Utils.displayDlg(__("Tag cloud"), "printTagCloud");
+ 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.activeFeedIsCat())
+ alert(__("You can't edit this kind of feed."));
+ else
+ editFeed(Feeds.getActiveFeedId());
+ break;
+ case "qmcRemoveFeed":
+ var actid = Feeds.getActiveFeedId();
+
+ if (Feeds.activeFeedIsCat()) {
+ alert(__("You can't unsubscribe from the category."));
+ return;
+ }
- if (confirm(pr)) {
- unsubscribeFeed(actid);
- }
- break;
- case "qmcCatchupAll":
- Feeds.catchupAllFeeds();
- break;
- case "qmcShowOnlyUnread":
- Feeds.toggleDispRead();
- break;
- case "qmcToggleWidescreen":
- if (!App.isCombinedMode()) {
- App._widescreen_mode = !App._widescreen_mode;
-
- // reset stored sizes because geometry changed
- setCookie("ttrss_ci_width", 0);
- setCookie("ttrss_ci_height", 0);
-
- App.switchPanelMode(App._widescreen_mode);
- } else {
- alert(__("Widescreen is not available in combined mode."));
+ if (!actid) {
+ alert(__("Please select some feed first."));
+ return;
+ }
+
+ var fn = Feeds.getFeedName(actid);
+
+ var pr = __("Unsubscribe from %s?").replace("%s", fn);
+
+ if (confirm(pr)) {
+ unsubscribeFeed(actid);
+ }
+ break;
+ case "qmcCatchupAll":
+ Feeds.catchupAllFeeds();
+ break;
+ case "qmcShowOnlyUnread":
+ Feeds.toggleDispRead();
+ break;
+ case "qmcToggleWidescreen":
+ if (!App.isCombinedMode()) {
+ App._widescreen_mode = !App._widescreen_mode;
+
+ // reset stored sizes because geometry changed
+ setCookie("ttrss_ci_width", 0);
+ setCookie("ttrss_ci_height", 0);
+
+ App.switchPanelMode(App._widescreen_mode);
+ } else {
+ alert(__("Widescreen is not available in combined mode."));
+ }
+ break;
+ case "qmcHKhelp":
+ Utils.helpDialog("main");
+ break;
+ default:
+ console.log("quickMenuGo: unknown action: " + opid);
}
- break;
- case "qmcHKhelp":
- Utils.helpDialog("main");
- break;
- default:
- console.log("quickMenuGo: unknown action: " + opid);
+ },
+ isPrefs: function() {
+ return false;
}
-}
-
-function inPreferences() {
- return false;
-}
+};
function hash_get(key) {
const kv = window.location.hash.substring(1).toQueryParams();
@@ -569,7 +565,3 @@ function hash_set(key, value) {
kv[key] = value;
window.location.hash = $H(kv).toQueryString();
}
-
-function gotoPreferences() {
- document.location.href = "prefs.php";
-}
diff --git a/js/viewfeed.js b/js/viewfeed.js
index cbbea8a05..e8995712a 100755
--- a/js/viewfeed.js
+++ b/js/viewfeed.js
@@ -1,8 +1,5 @@
/* global dijit, __, ngettext */
-let post_under_pointer = false;
-let last_search_query;
-
const ArticleCache = {
has_storage: 'sessionStorage' in window && window['sessionStorage'] !== null,
set: function(id, obj) {
@@ -118,7 +115,7 @@ const Article = {
c.attr('content', article);
PluginHost.run(PluginHost.HOOK_ARTICLE_RENDERED, c.domNode);
- correctHeadlinesOffset(Article.getActiveArticleId());
+ Headlines.correctHeadlinesOffset(Article.getActiveArticleId());
try {
c.focus();
@@ -126,7 +123,7 @@ const Article = {
}
},
view: function(id, noexpand) {
- Article.setActiveArticleId(id);
+ this.setActiveArticleId(id);
if (!noexpand) {
console.log("loading article", id);
@@ -135,7 +132,7 @@ const Article = {
/* only request uncached articles */
- getRelativePostIds(id).each((n) => {
+ this.getRelativePostIds(id).each((n) => {
if (!ArticleCache.get(n))
cids.push(n);
});
@@ -313,6 +310,49 @@ const Article = {
},
getActiveArticleId: function() {
return this._active_article_id;
+ },
+ scrollArticle: function(offset) {
+ if (!App.isCombinedMode()) {
+ const ci = $("content-insert");
+ if (ci) {
+ ci.scrollTop += offset;
+ }
+ } else {
+ const hi = $("headlines-frame");
+ if (hi) {
+ hi.scrollTop += offset;
+ }
+
+ }
+ },
+ getRelativePostIds: function(id, limit) {
+
+ const tmp = [];
+
+ if (!limit) limit = 6; //3
+
+ const ids = Headlines.getLoadedArticleIds();
+
+ for (let i = 0; i < ids.length; i++) {
+ if (ids[i] == id) {
+ for (let k = 1; k <= limit; k++) {
+ //if (i > k-1) tmp.push(ids[i-k]);
+ if (i < ids.length - k) tmp.push(ids[i + k]);
+ }
+ break;
+ }
+ }
+
+ return tmp;
+ },
+ mouseIn: function(id) {
+ this.post_under_pointer = id;
+ },
+ mouseOut: function(id) {
+ this.post_under_pointer = false;
+ },
+ getArticleUnderPointer: function() {
+ return this.post_under_pointer;
}
};
@@ -485,7 +525,7 @@ const Headlines = {
ft.firstChild.innerHTML = "<img class='anchor marked-pic' src='images/page_white_go.png' " +
"onclick=\"Article.cdmScrollToArticleId(" + id + ", true)\">" + ft.firstChild.innerHTML;
- initFloatingMenu();
+ this.initFloatingMenu();
const cb = ft.select(".rchk")[0];
@@ -546,7 +586,7 @@ const Headlines = {
is_cat = reply['headlines']['is_cat'];
feed_id = reply['headlines']['id'];
- last_search_query = reply['headlines']['search_query'];
+ Feeds.last_search_query = reply['headlines']['search_query'];
if (feed_id != -7 && (feed_id != Feeds.getActiveFeedId() || is_cat != Feeds.activeFeedIsCat()))
return;
@@ -602,7 +642,7 @@ const Headlines = {
if (!hsp) hsp = new Element("DIV", {"id": "headlines-spacer"});
dijit.byId('headlines-frame').domNode.appendChild(hsp);
- initHeadlinesMenu();
+ this.initHeadlinesMenu();
if (Feeds.infscroll_disabled)
hsp.innerHTML = "<a href='#' onclick='Feeds.openNextUnreadFeed()'>" +
@@ -646,7 +686,7 @@ const Headlines = {
markHeadline(ids[i]);
} */
- initHeadlinesMenu();
+ this.initHeadlinesMenu();
if (Feeds.infscroll_disabled) {
hsp.innerHTML = "<a href='#' onclick='Feeds.openNextUnreadFeed()'>" +
@@ -894,7 +934,7 @@ const Headlines = {
if (!noscroll && article && article.offsetTop + article.offsetHeight >
ctr.scrollTop + ctr.offsetHeight) {
- scrollArticle(ctr.offsetHeight / 4);
+ Article.scrollArticle(ctr.offsetHeight / 4);
} else if (next_id) {
Article.setActiveArticleId(next_id);
@@ -902,7 +942,7 @@ const Headlines = {
}
} else if (next_id) {
- correctHeadlinesOffset(next_id);
+ Headlines.correctHeadlinesOffset(next_id);
Article.view(next_id, noexpand);
}
}
@@ -917,17 +957,17 @@ const Headlines = {
const ctr = $("headlines-frame");
if (!noscroll && article && article.offsetTop < ctr.scrollTop) {
- scrollArticle(-ctr.offsetHeight / 3);
+ Article.scrollArticle(-ctr.offsetHeight / 3);
} else if (!noscroll && prev_article &&
prev_article.offsetTop < ctr.scrollTop) {
- scrollArticle(-ctr.offsetHeight / 4);
+ Article.scrollArticle(-ctr.offsetHeight / 4);
} else if (prev_id) {
Article.setActiveArticleId(prev_id);
Article.cdmScrollToArticleId(prev_id, noscroll);
}
} else if (prev_id) {
- correctHeadlinesOffset(prev_id);
+ Headlines.correctHeadlinesOffset(prev_id);
Article.view(prev_id, noexpand);
}
}
@@ -986,7 +1026,7 @@ const Headlines = {
xhrPost("backend.php", query, (transport) => {
Utils.handleRpcJson(transport);
- updateHeadlineLabels(transport);
+ this.onLabelsUpdated(transport);
});
},
selectionAssignLabel: function(id, ids) {
@@ -1004,7 +1044,7 @@ const Headlines = {
xhrPost("backend.php", query, (transport) => {
Utils.handleRpcJson(transport);
- updateHeadlineLabels(transport);
+ this.onLabelsUpdated(transport);
});
},
deleteSelection: function() {
@@ -1212,362 +1252,306 @@ const Headlines = {
} else {
if (callback) callback();
}
- }
-};
-
-function postMouseIn(e, id) {
- post_under_pointer = id;
-}
-
-function postMouseOut(id) {
- post_under_pointer = false;
-}
-
-function catchupRelativeToArticle(below, id) {
+ },
+ catchupRelativeToArticle: function(below, id) {
- if (!id) id = Article.getActiveArticleId();
+ if (!id) id = Article.getActiveArticleId();
- if (!id) {
- alert(__("No article is selected."));
- return;
- }
+ if (!id) {
+ alert(__("No article is selected."));
+ return;
+ }
- const visible_ids = Headlines.getLoadedArticleIds();
+ const visible_ids = this.getLoadedArticleIds();
- const ids_to_mark = [];
+ const ids_to_mark = [];
- if (!below) {
- for (let i = 0; i < visible_ids.length; i++) {
- if (visible_ids[i] != id) {
- const e = $("RROW-" + visible_ids[i]);
+ if (!below) {
+ for (let i = 0; i < visible_ids.length; i++) {
+ if (visible_ids[i] != id) {
+ const e = $("RROW-" + visible_ids[i]);
- if (e && e.hasClassName("Unread")) {
- ids_to_mark.push(visible_ids[i]);
+ if (e && e.hasClassName("Unread")) {
+ ids_to_mark.push(visible_ids[i]);
+ }
+ } else {
+ break;
}
- } else {
- break;
}
- }
- } else {
- for (let i = visible_ids.length - 1; i >= 0; i--) {
- if (visible_ids[i] != id) {
- const e = $("RROW-" + visible_ids[i]);
+ } else {
+ for (let i = visible_ids.length - 1; i >= 0; i--) {
+ if (visible_ids[i] != id) {
+ const e = $("RROW-" + visible_ids[i]);
- if (e && e.hasClassName("Unread")) {
- ids_to_mark.push(visible_ids[i]);
+ if (e && e.hasClassName("Unread")) {
+ ids_to_mark.push(visible_ids[i]);
+ }
+ } else {
+ break;
}
- } else {
- break;
}
}
- }
- if (ids_to_mark.length == 0) {
- alert(__("No articles found to mark"));
- } else {
- const msg = ngettext("Mark %d article as read?", "Mark %d articles as read?", ids_to_mark.length).replace("%d", ids_to_mark.length);
+ if (ids_to_mark.length == 0) {
+ alert(__("No articles found to mark"));
+ } else {
+ const msg = ngettext("Mark %d article as read?", "Mark %d articles as read?", ids_to_mark.length).replace("%d", ids_to_mark.length);
- if (getInitParam("confirm_feed_catchup") != 1 || confirm(msg)) {
+ if (getInitParam("confirm_feed_catchup") != 1 || confirm(msg)) {
- for (var i = 0; i < ids_to_mark.length; i++) {
- var e = $("RROW-" + ids_to_mark[i]);
- e.removeClassName("Unread");
- }
+ for (var i = 0; i < ids_to_mark.length; i++) {
+ var e = $("RROW-" + ids_to_mark[i]);
+ e.removeClassName("Unread");
+ }
- const query = { op: "rpc", method: "catchupSelected",
- cmode: 0, ids: ids_to_mark.toString() };
+ const query = {
+ op: "rpc", method: "catchupSelected",
+ cmode: 0, ids: ids_to_mark.toString()
+ };
- xhrPost("backend.php", query, (transport) => {
- Utils.handleRpcJson(transport);
+ xhrPost("backend.php", query, (transport) => {
+ Utils.handleRpcJson(transport);
+ });
+ }
+ }
+ },
+ onLabelsUpdated: function(transport) {
+ const data = JSON.parse(transport.responseText);
+
+ if (data) {
+ data['info-for-headlines'].each(function (elem) {
+ $$(".HLLCTR-" + elem.id).each(function (ctr) {
+ ctr.innerHTML = elem.labels;
+ });
});
}
- }
-}
+ },
+ onActionChanged: function(elem) {
+ eval(elem.value);
+ elem.attr('value', 'false');
+ },
+ correctHeadlinesOffset: function(id) {
+ const container = $("headlines-frame");
+ const row = $("RROW-" + id);
-function getArticleUnderPointer() {
- return post_under_pointer;
-}
+ if (!container || !row) return;
-function scrollArticle(offset) {
- if (!App.isCombinedMode()) {
- const ci = $("content-insert");
- if (ci) {
- ci.scrollTop += offset;
- }
- } else {
- const hi = $("headlines-frame");
- if (hi) {
- hi.scrollTop += offset;
- }
+ const viewport = container.offsetHeight;
- }
-}
+ const rel_offset_top = row.offsetTop - container.scrollTop;
+ const rel_offset_bottom = row.offsetTop + row.offsetHeight - container.scrollTop;
-function updateHeadlineLabels(transport) {
- const data = JSON.parse(transport.responseText);
+ //console.log("Rtop: " + rel_offset_top + " Rbtm: " + rel_offset_bottom);
+ //console.log("Vport: " + viewport);
- if (data) {
- data['info-for-headlines'].each(function (elem) {
- $$(".HLLCTR-" + elem.id).each(function (ctr) {
- ctr.innerHTML = elem.labels;
- });
- });
- }
-}
+ if (rel_offset_top <= 0 || rel_offset_top > viewport) {
+ container.scrollTop = row.offsetTop;
+ } else if (rel_offset_bottom > viewport) {
+ container.scrollTop = row.offsetTop + row.offsetHeight - viewport;
+ }
+ },
+ initFloatingMenu: function() {
+ if (!dijit.byId("floatingMenu")) {
-function getRelativePostIds(id, limit) {
+ const menu = new dijit.Menu({
+ id: "floatingMenu",
+ targetNodeIds: ["floatingTitle"]
+ });
- const tmp = [];
+ this.headlinesMenuCommon(menu);
- if (!limit) limit = 6; //3
+ menu.startup();
+ }
+ },
+ headlinesMenuCommon: function(menu) {
- const ids = Headlines.getLoadedArticleIds();
+ menu.addChild(new dijit.MenuItem({
+ label: __("Open original article"),
+ onClick: function (event) {
+ Article.openArticleInNewWindow(this.getParent().currentTarget.getAttribute("data-article-id"));
+ }
+ }));
- for (let i = 0; i < ids.length; i++) {
- if (ids[i] == id) {
- for (let k = 1; k <= limit; k++) {
- //if (i > k-1) tmp.push(ids[i-k]);
- if (i < ids.length - k) tmp.push(ids[i + k]);
+ menu.addChild(new dijit.MenuItem({
+ label: __("Display article URL"),
+ onClick: function (event) {
+ Article.displayArticleUrl(this.getParent().currentTarget.getAttribute("data-article-id"));
}
- break;
- }
- }
+ }));
- return tmp;
-}
+ menu.addChild(new dijit.MenuSeparator());
-function correctHeadlinesOffset(id) {
- const container = $("headlines-frame");
- const row = $("RROW-" + id);
+ menu.addChild(new dijit.MenuItem({
+ label: __("Toggle unread"),
+ onClick: function () {
- if (!container || !row) return;
+ let ids = Headlines.getSelectedArticleIds2();
+ // cast to string
+ const id = (this.getParent().currentTarget.getAttribute("data-article-id")) + "";
+ ids = ids.length != 0 && ids.indexOf(id) != -1 ? ids : [id];
- const viewport = container.offsetHeight;
+ Headlines.selectionToggleUnread({ids: ids, no_error: 1});
+ }
+ }));
- const rel_offset_top = row.offsetTop - container.scrollTop;
- const rel_offset_bottom = row.offsetTop + row.offsetHeight - container.scrollTop;
+ menu.addChild(new dijit.MenuItem({
+ label: __("Toggle starred"),
+ onClick: function () {
+ let ids = Headlines.getSelectedArticleIds2();
+ // cast to string
+ const id = (this.getParent().currentTarget.getAttribute("data-article-id")) + "";
+ ids = ids.length != 0 && ids.indexOf(id) != -1 ? ids : [id];
- //console.log("Rtop: " + rel_offset_top + " Rbtm: " + rel_offset_bottom);
- //console.log("Vport: " + viewport);
+ Headlines.selectionToggleMarked(ids);
+ }
+ }));
- if (rel_offset_top <= 0 || rel_offset_top > viewport) {
- container.scrollTop = row.offsetTop;
- } else if (rel_offset_bottom > viewport) {
- container.scrollTop = row.offsetTop + row.offsetHeight - viewport;
- }
-}
+ menu.addChild(new dijit.MenuItem({
+ label: __("Toggle published"),
+ onClick: function () {
+ let ids = Headlines.getSelectedArticleIds2();
+ // cast to string
+ const id = (this.getParent().currentTarget.getAttribute("data-article-id")) + "";
+ ids = ids.length != 0 && ids.indexOf(id) != -1 ? ids : [id];
-function headlineActionsChange(elem) {
- eval(elem.value);
- elem.attr('value', 'false');
-}
+ Headlines.selectionTogglePublished(ids);
+ }
+ }));
-function initFloatingMenu() {
- if (!dijit.byId("floatingMenu")) {
+ menu.addChild(new dijit.MenuSeparator());
- const menu = new dijit.Menu({
- id: "floatingMenu",
- targetNodeIds: ["floatingTitle"]
- });
+ menu.addChild(new dijit.MenuItem({
+ label: __("Mark above as read"),
+ onClick: function () {
+ Headlines.catchupRelativeToArticle(0, this.getParent().currentTarget.getAttribute("data-article-id"));
+ }
+ }));
- headlinesMenuCommon(menu);
+ menu.addChild(new dijit.MenuItem({
+ label: __("Mark below as read"),
+ onClick: function () {
+ Headlines.catchupRelativeToArticle(1, this.getParent().currentTarget.getAttribute("data-article-id"));
+ }
+ }));
- menu.startup();
- }
-}
-function headlinesMenuCommon(menu) {
+ const labels = getInitParam("labels");
- menu.addChild(new dijit.MenuItem({
- label: __("Open original article"),
- onClick: function (event) {
- Article.openArticleInNewWindow(this.getParent().currentTarget.getAttribute("data-article-id"));
- }
- }));
+ if (labels && labels.length) {
- menu.addChild(new dijit.MenuItem({
- label: __("Display article URL"),
- onClick: function (event) {
- Article.displayArticleUrl(this.getParent().currentTarget.getAttribute("data-article-id"));
- }
- }));
+ menu.addChild(new dijit.MenuSeparator());
- menu.addChild(new dijit.MenuSeparator());
+ const labelAddMenu = new dijit.Menu({ownerMenu: menu});
+ const labelDelMenu = new dijit.Menu({ownerMenu: menu});
- menu.addChild(new dijit.MenuItem({
- label: __("Toggle unread"),
- onClick: function () {
+ labels.each(function (label) {
+ const bare_id = label.id;
+ const name = label.caption;
- let ids = Headlines.getSelectedArticleIds2();
- // cast to string
- const id = (this.getParent().currentTarget.getAttribute("data-article-id")) + "";
- ids = ids.length != 0 && ids.indexOf(id) != -1 ? ids : [id];
+ labelAddMenu.addChild(new dijit.MenuItem({
+ label: name,
+ labelId: bare_id,
+ onClick: function () {
- Headlines.selectionToggleUnread({ids: ids, no_error: 1});
- }
- }));
+ let ids = Headlines.getSelectedArticleIds2();
+ // cast to string
+ const id = (this.getParent().ownerMenu.currentTarget.getAttribute("data-article-id")) + "";
- menu.addChild(new dijit.MenuItem({
- label: __("Toggle starred"),
- onClick: function () {
- let ids = Headlines.getSelectedArticleIds2();
- // cast to string
- const id = (this.getParent().currentTarget.getAttribute("data-article-id")) + "";
- ids = ids.length != 0 && ids.indexOf(id) != -1 ? ids : [id];
+ ids = ids.length != 0 && ids.indexOf(id) != -1 ? ids : [id];
- Headlines.selectionToggleMarked(ids);
- }
- }));
+ Headlines.selectionAssignLabel(this.labelId, ids);
+ }
+ }));
- menu.addChild(new dijit.MenuItem({
- label: __("Toggle published"),
- onClick: function () {
- let ids = Headlines.getSelectedArticleIds2();
- // cast to string
- const id = (this.getParent().currentTarget.getAttribute("data-article-id")) + "";
- ids = ids.length != 0 && ids.indexOf(id) != -1 ? ids : [id];
+ labelDelMenu.addChild(new dijit.MenuItem({
+ label: name,
+ labelId: bare_id,
+ onClick: function () {
+ let ids = Headlines.getSelectedArticleIds2();
+ // cast to string
+ const id = (this.getParent().ownerMenu.currentTarget.getAttribute("data-article-id")) + "";
- Headlines.selectionTogglePublished(ids);
- }
- }));
+ ids = ids.length != 0 && ids.indexOf(id) != -1 ? ids : [id];
- menu.addChild(new dijit.MenuSeparator());
+ Headlines.selectionRemoveLabel(this.labelId, ids);
+ }
+ }));
- menu.addChild(new dijit.MenuItem({
- label: __("Mark above as read"),
- onClick: function () {
- catchupRelativeToArticle(0, this.getParent().currentTarget.getAttribute("data-article-id"));
- }
- }));
+ });
- menu.addChild(new dijit.MenuItem({
- label: __("Mark below as read"),
- onClick: function () {
- catchupRelativeToArticle(1, this.getParent().currentTarget.getAttribute("data-article-id"));
- }
- }));
+ menu.addChild(new dijit.PopupMenuItem({
+ label: __("Assign label"),
+ popup: labelAddMenu
+ }));
+ menu.addChild(new dijit.PopupMenuItem({
+ label: __("Remove label"),
+ popup: labelDelMenu
+ }));
- const labels = getInitParam("labels");
+ }
+ },
+ initHeadlinesMenu: function() {
+ if (!dijit.byId("headlinesMenu")) {
- if (labels && labels.length) {
+ const menu = new dijit.Menu({
+ id: "headlinesMenu",
+ targetNodeIds: ["headlines-frame"],
+ selector: ".hlMenuAttach"
+ });
- menu.addChild(new dijit.MenuSeparator());
+ this.headlinesMenuCommon(menu);
- const labelAddMenu = new dijit.Menu({ownerMenu: menu});
- const labelDelMenu = new dijit.Menu({ownerMenu: menu});
+ menu.startup();
+ }
- labels.each(function (label) {
- const bare_id = label.id;
- const name = label.caption;
+ /* vgroup feed title menu */
- labelAddMenu.addChild(new dijit.MenuItem({
- label: name,
- labelId: bare_id,
- onClick: function () {
+ if (!dijit.byId("headlinesFeedTitleMenu")) {
- let ids = Headlines.getSelectedArticleIds2();
- // cast to string
- const id = (this.getParent().ownerMenu.currentTarget.getAttribute("data-article-id")) + "";
+ const menu = new dijit.Menu({
+ id: "headlinesFeedTitleMenu",
+ targetNodeIds: ["headlines-frame"],
+ selector: "div.cdmFeedTitle"
+ });
- ids = ids.length != 0 && ids.indexOf(id) != -1 ? ids : [id];
+ menu.addChild(new dijit.MenuItem({
+ label: __("Select articles in group"),
+ onClick: function (event) {
+ Headlines.selectArticles("all",
+ "#headlines-frame > div[id*=RROW]" +
+ "[data-orig-feed-id='" + this.getParent().currentTarget.getAttribute("data-feed-id") + "']");
- Headlines.selectionAssignLabel(this.labelId, ids);
}
}));
- labelDelMenu.addChild(new dijit.MenuItem({
- label: name,
- labelId: bare_id,
+ menu.addChild(new dijit.MenuItem({
+ label: __("Mark group as read"),
onClick: function () {
- let ids = Headlines.getSelectedArticleIds2();
- // cast to string
- const id = (this.getParent().ownerMenu.currentTarget.getAttribute("data-article-id")) + "";
-
- ids = ids.length != 0 && ids.indexOf(id) != -1 ? ids : [id];
+ Headlines.selectArticles("none");
+ Headlines.selectArticles("all",
+ "#headlines-frame > div[id*=RROW]" +
+ "[data-orig-feed-id='" + this.getParent().currentTarget.getAttribute("data-feed-id") + "']");
- Headlines.selectionRemoveLabel(this.labelId, ids);
+ Headlines.catchupSelection();
}
}));
- });
-
- menu.addChild(new dijit.PopupMenuItem({
- label: __("Assign label"),
- popup: labelAddMenu
- }));
-
- menu.addChild(new dijit.PopupMenuItem({
- label: __("Remove label"),
- popup: labelDelMenu
- }));
-
- }
-}
-
-function initHeadlinesMenu() {
- if (!dijit.byId("headlinesMenu")) {
-
- const menu = new dijit.Menu({
- id: "headlinesMenu",
- targetNodeIds: ["headlines-frame"],
- selector: ".hlMenuAttach"
- });
-
- headlinesMenuCommon(menu);
-
- menu.startup();
- }
-
- /* vgroup feed title menu */
-
- if (!dijit.byId("headlinesFeedTitleMenu")) {
-
- const menu = new dijit.Menu({
- id: "headlinesFeedTitleMenu",
- targetNodeIds: ["headlines-frame"],
- selector: "div.cdmFeedTitle"
- });
-
- menu.addChild(new dijit.MenuItem({
- label: __("Select articles in group"),
- onClick: function (event) {
- Headlines.selectArticles("all",
- "#headlines-frame > div[id*=RROW]" +
- "[data-orig-feed-id='" + this.getParent().currentTarget.getAttribute("data-feed-id") + "']");
-
- }
- }));
-
- menu.addChild(new dijit.MenuItem({
- label: __("Mark group as read"),
- onClick: function () {
- Headlines.selectArticles("none");
- Headlines.selectArticles("all",
- "#headlines-frame > div[id*=RROW]" +
- "[data-orig-feed-id='" + this.getParent().currentTarget.getAttribute("data-feed-id") + "']");
-
- Headlines.catchupSelection();
- }
- }));
-
- menu.addChild(new dijit.MenuItem({
- label: __("Mark feed as read"),
- onClick: function () {
- Feeds.catchupFeedInGroup(this.getParent().currentTarget.getAttribute("data-feed-id"));
- }
- }));
+ menu.addChild(new dijit.MenuItem({
+ label: __("Mark feed as read"),
+ onClick: function () {
+ Feeds.catchupFeedInGroup(this.getParent().currentTarget.getAttribute("data-feed-id"));
+ }
+ }));
- menu.addChild(new dijit.MenuItem({
- label: __("Edit feed"),
- onClick: function () {
- editFeed(this.getParent().currentTarget.getAttribute("data-feed-id"));
- }
- }));
+ menu.addChild(new dijit.MenuItem({
+ label: __("Edit feed"),
+ onClick: function () {
+ editFeed(this.getParent().currentTarget.getAttribute("data-feed-id"));
+ }
+ }));
- menu.startup();
+ menu.startup();
+ }
}
-}
-
-
-
+};