RIP tag cloud: last of the vanilla popup dialog system

This commit is contained in:
Andrew Dolgov 2021-02-12 18:43:30 +03:00
parent 9330bde991
commit ad7842c98a
3 changed files with 0 additions and 120 deletions

View File

@ -1,78 +0,0 @@
<?php
class Dlg extends Handler_Protected {
private $param;
private $params;
function before($method) {
if (parent::before($method)) {
header("Content-Type: text/html"); # required for iframe
$this->param = ($_REQUEST["param"] ?? false);
return true;
}
return false;
}
function printTagCloud() {
print "<div class='panel text-center'>";
// from here: http://www.roscripts.com/Create_tag_cloud-71.html
$sth = $this->pdo->prepare("SELECT tag_name, COUNT(post_int_id) AS count
FROM ttrss_tags WHERE owner_uid = ?
GROUP BY tag_name ORDER BY count DESC LIMIT 50");
$sth->execute([$_SESSION['uid']]);
$tags = array();
while ($line = $sth->fetch()) {
$tags[$line["tag_name"]] = $line["count"];
}
if(count($tags) == 0 ){ return; }
ksort($tags);
$max_size = 32; // max font size in pixels
$min_size = 11; // min font size in pixels
// largest and smallest array values
$max_qty = max(array_values($tags));
$min_qty = min(array_values($tags));
// find the range of values
$spread = $max_qty - $min_qty;
if ($spread == 0) { // we don't want to divide by zero
$spread = 1;
}
// set the font-size increment
$step = ($max_size - $min_size) / ($spread);
// loop through the tag array
foreach ($tags as $key => $value) {
// calculate font-size
// find the $value in excess of $min_qty
// multiply by the font-size increment ($size)
// and add the $min_size set above
$size = round($min_size + (($value - $min_qty) * $step));
$key_escaped = str_replace("'", "\\'", (string)$key);
echo "<a href=\"#\" onclick=\"Feeds.open({feed:'$key_escaped'}) \" style=\"font-size: " .
$size . "px\" title=\"$value articles tagged with " .
$key . '">' . $key . '</a> ';
}
print "</div>";
print "<footer class='text-center'>";
print "<button dojoType='dijit.form.Button'
onclick=\"return CommonDialogs.closeInfoBox()\">".
__('Close this window')."</button>";
print "</footer>";
}
}

View File

@ -638,7 +638,6 @@ class RPC extends Handler_Protected {
"goto_marked" => __("Starred"), "goto_marked" => __("Starred"),
"goto_published" => __("Published"), "goto_published" => __("Published"),
"goto_read" => __("Recently read"), "goto_read" => __("Recently read"),
"goto_tagcloud" => __("Tag cloud"),
"goto_prefs" => __("Preferences")), "goto_prefs" => __("Preferences")),
__("Other") => array( __("Other") => array(
"create_label" => __("Create label"), "create_label" => __("Create label"),
@ -711,7 +710,6 @@ class RPC extends Handler_Protected {
"g s" => "goto_marked", "g s" => "goto_marked",
"g p" => "goto_published", "g p" => "goto_published",
"g r" => "goto_read", "g r" => "goto_read",
"g t" => "goto_tagcloud",
"g P" => "goto_prefs", "g P" => "goto_prefs",
"r" => "select_article_cursor", "r" => "select_article_cursor",
"c l" => "create_label", "c l" => "create_label",

View File

@ -320,40 +320,6 @@ const App = {
dialog.show(); dialog.show();
}); });
},
displayDlg: function(title, id, param, callback) {
Notify.progress("Loading, please wait...", true);
const query = {op: "dlg", method: id, param: param};
xhrPost("backend.php", query, (transport) => {
try {
const content = transport.responseText;
let dialog = dijit.byId("infoBox");
if (!dialog) {
dialog = new fox.SingleUseDialog({
title: title,
id: 'infoBox',
content: content
});
} else {
dialog.attr('title', title);
dialog.attr('content', content);
}
dialog.show();
Notify.close();
if (callback) callback(transport);
} catch (e) {
this.Error.report(e);
}
});
return false;
}, },
handleRpcJson: function(transport) { handleRpcJson: function(transport) {
@ -1082,9 +1048,6 @@ const App = {
this.hotkey_actions["goto_published"] = () => { this.hotkey_actions["goto_published"] = () => {
Feeds.open({feed: -2}); Feeds.open({feed: -2});
}; };
this.hotkey_actions["goto_tagcloud"] = () => {
this.displayDlg(__("Tag cloud"), "printTagCloud");
};
this.hotkey_actions["goto_prefs"] = () => { this.hotkey_actions["goto_prefs"] = () => {
App.openPreferences(); App.openPreferences();
}; };
@ -1162,9 +1125,6 @@ const App = {
case "qmcLogout": case "qmcLogout":
App.postCurrentWindow("public.php", {op: "logout", csrf_token: __csrf_token}); App.postCurrentWindow("public.php", {op: "logout", csrf_token: __csrf_token});
break; break;
case "qmcTagCloud":
this.displayDlg(__("Tag cloud"), "printTagCloud");
break;
case "qmcSearch": case "qmcSearch":
Feeds.search(); Feeds.search();
break; break;