2011-12-12 21:20:53 +01:00
< ? php
2012-08-17 15:03:39 +02:00
class Dlg extends Handler_Protected {
2011-12-12 21:20:53 +01:00
private $param ;
2011-12-13 11:15:42 +01:00
2012-07-05 20:43:44 +02:00
function before ( $method ) {
if ( parent :: before ( $method )) {
2013-04-01 08:47:41 +02:00
header ( " Content-Type: text/html " ); # required for iframe
2013-04-17 18:12:14 +02:00
$this -> param = $this -> dbh -> escape_string ( $_REQUEST [ " param " ]);
2011-12-12 21:20:53 +01:00
return true ;
}
return false ;
}
2011-12-13 11:15:42 +01:00
2011-12-12 21:20:53 +01:00
function importOpml () {
2011-12-27 15:37:07 +01:00
print __ ( " If you have imported labels and/or filters, you might need to reload preferences to see your new data. " ) . " </p> " ;
2011-12-12 21:20:53 +01:00
print " <div class= \" prefFeedOPMLHolder \" > " ;
2013-04-17 18:12:14 +02:00
$this -> dbh -> query ( " BEGIN " );
2011-12-12 21:20:53 +01:00
2012-08-15 13:47:13 +02:00
print " <ul class='nomarks'> " ;
2011-12-12 21:20:53 +01:00
2013-04-17 16:34:18 +02:00
$opml = new Opml ( $_REQUEST );
2011-12-12 21:20:53 +01:00
2012-08-15 13:47:13 +02:00
$opml -> opml_import ( $_SESSION [ " uid " ]);
2011-12-12 21:20:53 +01:00
2013-04-17 18:12:14 +02:00
$this -> dbh -> query ( " COMMIT " );
2012-11-20 20:33:12 +01:00
2011-12-22 13:45:19 +01:00
print " </ul> " ;
2011-12-12 21:20:53 +01:00
print " </div> " ;
print " <div align='center'> " ;
print " <button dojoType= \" dijit.form.Button \"
2011-12-27 15:37:07 +01:00
onclick = \ " dijit.byId('opmlImportDlg').execute() \" > " .
2011-12-12 21:20:53 +01:00
__ ( 'Close this window' ) . " </button> " ;
print " </div> " ;
print " </div> " ;
//return;
}
function pubOPMLUrl () {
2013-04-17 14:23:15 +02:00
$url_path = Opml :: opml_publish_url ();
2011-12-12 21:20:53 +01:00
print __ ( " Your Public OPML URL is: " );
print " <div class= \" tagCloudContainer \" > " ;
print " <a id='pub_opml_url' href=' $url_path ' target='_blank'> $url_path </a> " ;
print " </div> " ;
print " <div align='center'> " ;
print " <button dojoType= \" dijit.form.Button \" onclick= \" return opmlRegenKey() \" > " .
__ ( 'Generate new URL' ) . " </button> " ;
print " <button dojoType= \" dijit.form.Button \" onclick= \" return closeInfoBox() \" > " .
__ ( 'Close this window' ) . " </button> " ;
print " </div> " ;
//return;
}
function explainError () {
print " <div class= \" errorExplained \" > " ;
if ( $this -> param == 1 ) {
print __ ( " Update daemon is enabled in configuration, but daemon process is not running, which prevents all feeds from updating. Please start the daemon process or contact instance owner. " );
$stamp = ( int ) file_get_contents ( LOCK_DIRECTORY . " /update_daemon.stamp " );
print " <p> " . __ ( " Last update: " ) . " " . date ( " Y.m.d, G:i " , $stamp );
}
if ( $this -> param == 3 ) {
print __ ( " Update daemon is taking too long to perform a feed update. This could indicate a problem like crash or a hang. Please check the daemon process or contact instance owner. " );
$stamp = ( int ) file_get_contents ( LOCK_DIRECTORY . " /update_daemon.stamp " );
print " <p> " . __ ( " Last update: " ) . " " . date ( " Y.m.d, G:i " , $stamp );
}
print " </div> " ;
print " <div align='center'> " ;
print " <button onclick= \" return closeInfoBox() \" > " .
__ ( 'Close this window' ) . " </button> " ;
print " </div> " ;
//return;
}
function printTagCloud () {
print " <div class= \" tagCloudContainer \" > " ;
2011-12-13 13:23:31 +01:00
// from here: http://www.roscripts.com/Create_tag_cloud-71.html
$query = " SELECT tag_name, COUNT(post_int_id) AS count
FROM ttrss_tags WHERE owner_uid = " . $_SESSION["uid"] . "
GROUP BY tag_name ORDER BY count DESC LIMIT 50 " ;
2013-04-17 18:12:14 +02:00
$result = $this -> dbh -> query ( $query );
2011-12-13 13:23:31 +01:00
$tags = array ();
2013-04-17 18:12:14 +02:00
while ( $line = $this -> dbh -> fetch_assoc ( $result )) {
2011-12-13 13:23:31 +01:00
$tags [ $line [ " tag_name " ]] = $line [ " count " ];
}
2013-04-17 16:34:18 +02:00
if ( count ( $tags ) == 0 ){ return ; }
2011-12-13 13:23:31 +01:00
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 ( " ' " , " \\ ' " , $key );
echo " <a href= \" javascript:viewfeed(' $key_escaped ') \" style= \" font-size: " .
$size . " px \" title= \" $value articles tagged with " .
$key . '">' . $key . '</a> ' ;
}
2011-12-12 21:20:53 +01:00
print " </div> " ;
print " <div align='center'> " ;
print " <button dojoType= \" dijit.form.Button \"
onclick = \ " return closeInfoBox() \" > " .
__ ( 'Close this window' ) . " </button> " ;
print " </div> " ;
}
function printTagSelect () {
2011-12-13 11:15:42 +01:00
2011-12-12 21:20:53 +01:00
print __ ( " Match: " ) . " " .
2012-11-22 13:07:40 +01:00
" <input class= \" noborder \" dojoType= \" dijit.form.RadioButton \" type= \" radio \" checked value= \" any \" name= \" tag_mode \" id= \" tag_mode_any \" > " ;
print " <label for= \" tag_mode_any \" > " . __ ( " Any " ) . " </label> " ;
print " " ;
print " <input class= \" noborder \" dojoType= \" dijit.form.RadioButton \" type= \" radio \" value= \" all \" name= \" tag_mode \" id= \" tag_mode_all \" > " ;
print " <label for= \" tag_mode_all \" > " . __ ( " All tags. " ) . " </input> " ;
2011-12-12 21:20:53 +01:00
print " <select id= \" all_tags \" name= \" all_tags \" title= \" " . __ ( 'Which Tags?' ) . " \" multiple= \" multiple \" size= \" 10 \" style= \" width : 100% \" > " ;
2013-04-17 18:12:14 +02:00
$result = $this -> dbh -> query ( " SELECT DISTINCT tag_name FROM ttrss_tags WHERE owner_uid = " . $_SESSION [ 'uid' ] . "
2011-12-12 21:20:53 +01:00
AND LENGTH ( tag_name ) <= 30 ORDER BY tag_name ASC " );
2013-04-17 18:12:14 +02:00
while ( $row = $this -> dbh -> fetch_assoc ( $result )) {
2011-12-12 21:20:53 +01:00
$tmp = htmlspecialchars ( $row [ " tag_name " ]);
2013-10-20 07:09:16 +02:00
print " <option value= \" $tmp\ " > $tmp </ option > " ;
2011-12-12 21:20:53 +01:00
}
print " </select> " ;
print " <div align='right'> " ;
print " <button dojoType= \" dijit.form.Button \" onclick= \" viewfeed(get_all_tags( $ ('all_tags')),
get_radio_checked ( $ ( 'tag_mode' ))); \ " > " . __ ( 'Display entries' ) . " </button> " ;
print " " ;
print " <button dojoType= \" dijit.form.Button \"
onclick = \ " return closeInfoBox() \" > " .
__ ( 'Close this window' ) . " </button> " ;
print " </div> " ;
}
function generatedFeed () {
2011-12-13 11:15:42 +01:00
2011-12-12 21:20:53 +01:00
$this -> params = explode ( " : " , $this -> param , 3 );
2013-04-17 18:12:14 +02:00
$feed_id = $this -> dbh -> escape_string ( $this -> params [ 0 ]);
2011-12-12 21:20:53 +01:00
$is_cat = ( bool ) $this -> params [ 1 ];
2013-04-17 16:34:18 +02:00
$key = get_feed_access_key ( $feed_id , $is_cat );
2011-12-12 21:20:53 +01:00
$url_path = htmlspecialchars ( $this -> params [ 2 ]) . " &key= " . $key ;
2013-03-28 11:01:25 +01:00
print " <h2> " . __ ( " You can view this feed as RSS using the following URL: " ) . " </h2> " ;
2011-12-12 21:20:53 +01:00
print " <div class= \" tagCloudContainer \" > " ;
print " <a id='gen_feed_url' href=' $url_path ' target='_blank'> $url_path </a> " ;
print " </div> " ;
print " <div align='center'> " ;
print " <button dojoType= \" dijit.form.Button \" onclick= \" return genUrlChangeKey(' $feed_id ', ' $is_cat ') \" > " .
__ ( 'Generate new URL' ) . " </button> " ;
print " <button dojoType= \" dijit.form.Button \" onclick= \" return closeInfoBox() \" > " .
__ ( 'Close this window' ) . " </button> " ;
print " </div> " ;
//return;
}
}
?>