RIP tag cloud: last of the vanilla popup dialog system
This commit is contained in:
parent
9330bde991
commit
ad7842c98a
|
@ -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>";
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -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",
|
||||||
|
|
40
js/App.js
40
js/App.js
|
@ -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;
|
||||||
|
|
Loading…
Reference in New Issue