'use strict' /* global __, ngettext */ define(["dojo/_base/declare"], function (declare) { Article = { getScoreClass: function (score) { if (score > 500) { return "score-high"; } else if (score > 0) { return "score-half-high"; } else if (score < -100) { return "score-low"; } else if (score < 0) { return "score-half-low"; } else { return "score-neutral"; } }, getScorePic: function (score) { if (score > 500) { return "trending_up"; } else if (score > 0) { return "trending_up"; } else if (score < 0) { return "trending_down"; } else { return "trending_neutral"; } }, selectionSetScore: function () { const ids = Headlines.getSelected(); if (ids.length > 0) { const score = prompt(__("Please enter new score for selected articles:")); if (parseInt(score) != undefined) { ids.each((id) => { const row = $("RROW-" + id); if (row) { row.setAttribute("data-score", score); const pic = row.select(".icon-score")[0]; pic.innerHTML = Article.getScorePic(score); pic.setAttribute("title", score); ["score-low", "score-high", "score-half-low", "score-half-high", "score-neutral"] .each(function(scl) { if (row.hasClassName(scl)) row.removeClassName(scl); }); row.addClassName(Article.getScoreClass(score)); } }); } } else { alert(__("No articles selected.")); } }, setScore: function (id, pic) { const row = $("RROW-"+id); const origpic = row.down("i[score-id*=score-]"); const contentpic = row.down("i[score-id*=score-content-]"); const so = $("slide-out"); if (row) { const score_old = row.getAttribute("data-score"); const score = prompt(__("Please enter new score for this article:"), score_old); if (parseInt(score) != undefined) { row.setAttribute("data-score", score); const pic = row.select(".icon-score")[0]; if (pic) { pic.innerHTML = Article.getScorePic(score); pic.setAttribute("title", score); } if (origpic) { origpic.innerHTML = Article.getScorePic(score); origpic.setAttribute("title", score); } if (contentpic) { contentpic.innerHTML = Article.getScorePic(score); contentpic.setAttribute("title", score); } console.log(so); if (so) { const sopic = so.down("i[score-id*=score-content-]"); console.log(sopic); sopic.innerHTML = Article.getScorePic(score); sopic.setAttribute("title", score); } ["score-low", "score-high", "score-half-low", "score-half-high", "score-neutral"] .each(function(scl) { if (row.hasClassName(scl)) row.removeClassName(scl); if (so && so.hasClassName(scl)) so.removeClassName(scl); }); row.addClassName(Article.getScoreClass(score)); if (so) so.addClassName(Article.getScoreClass(score)); } } }, cdmUnsetActive: function (event) { const row = $("RROW-" + Article.getActive()); if (row) { row.removeClassName("active"); if (event) event.stopPropagation(); return false; } }, close: function () { if (dijit.byId("content-insert")) dijit.byId("headlines-wrap-inner").removeChild( dijit.byId("content-insert")); Article.setActive(0); }, displayUrl: function (id) { const query = {op: "rpc", method: "getlinktitlebyid", id: id}; xhrJson("backend.php", query, (reply) => { if (reply && reply.link) { prompt(__("Article URL:"), reply.link); } }); }, openInNewWindow: function (id) { const w = window.open(""); if (w) { w.opener = null; w.location = "backend.php?op=article&method=redirect&id=" + id; Headlines.toggleUnread(id, 0); } }, render: function (article) { App.cleanupMemory("content-insert"); dijit.byId("headlines-wrap-inner").addChild( dijit.byId("content-insert")); const c = dijit.byId("content-insert"); try { c.domNode.scrollTop = 0; } catch (e) { } c.attr('content', article); PluginHost.run(PluginHost.HOOK_ARTICLE_RENDERED, c.domNode); Headlines.correctHeadlinesOffset(Article.getActive()); try { c.focus(); } catch (e) { } }, formatComments: function(hl) { let comments = ""; if (hl.comments) { let comments_msg = __("comments"); if (hl.num_comments > 0) { comments_msg = hl.num_comments + " " + ngettext("comment", "comments", hl.num_comments) } comments = `(${comments_msg})`; } return comments; }, formatOriginallyFrom: function(hl) { return hl.orig_feed ? ` ${__('Originally from:')} ${hl.orig_feed[0]} ` : ""; }, unpack: function(row) { if (row.hasAttribute("data-content")) { console.log("unpacking: " + row.id); const container = row.querySelector(".content-inner"); container.innerHTML = row.getAttribute("data-content").trim(); // blank content element might screw up onclick selection and keyboard moving if (container.textContent.length == 0) container.innerHTML += " "; row.removeAttribute("data-content"); PluginHost.run(PluginHost.HOOK_ARTICLE_RENDERED_CDM, row); } }, view: function (id, noexpand) { this.setActive(id); if (!noexpand) { const hl = Headlines.objectById(id); if (hl) { const comments = this.formatComments(hl); const originally_from = this.formatOriginallyFrom(hl); const article = `