2006-10-01 12:05:20 +02:00
< ? php
2006-10-02 05:22:20 +02:00
2008-09-11 08:06:25 +02:00
function batch_edit_cbox ( $elem , $label = false ) {
2008-09-11 08:52:19 +02:00
print " <input type= \" checkbox \" title= \" " . __ ( " Check to enable field " ) . " \"
2008-09-11 08:06:25 +02:00
onchange = \ " batchFeedsToggleField(this, ' $elem ', ' $label ') \" > " ;
}
2006-10-01 12:05:20 +02:00
function module_pref_feeds ( $link ) {
2006-10-02 05:22:20 +02:00
global $update_intervals ;
global $purge_intervals ;
2008-01-25 18:46:01 +01:00
global $update_methods ;
2006-10-02 05:22:20 +02:00
2006-10-01 12:05:20 +02:00
$subop = $_REQUEST [ " subop " ];
$quiet = $_REQUEST [ " quiet " ];
2010-01-11 13:40:35 +01:00
$mode = $_REQUEST [ " mode " ];
2006-10-01 12:05:20 +02:00
2010-01-14 10:47:28 +01:00
if ( $subop == " removeicon " ) {
$feed_id = db_escape_string ( $_REQUEST [ " feed_id " ]);
$result = db_query ( $link , " SELECT id FROM ttrss_feeds
WHERE id = '$feed_id' AND owner_uid = " . $_SESSION["uid"] );
if ( db_num_rows ( $result ) != 0 ) {
unlink ( ICONS_DIR . " / $feed_id .ico " );
}
return ;
}
2010-01-14 09:28:57 +01:00
if ( $subop == " uploadicon " ) {
2010-01-14 10:47:28 +01:00
$icon_file = $_FILES [ 'icon_file' ][ 'tmp_name' ];
$feed_id = db_escape_string ( $_REQUEST [ " feed_id " ]);
if ( is_file ( $icon_file ) && $feed_id ) {
2010-02-10 16:32:35 +01:00
if ( filesize ( $icon_file ) < 20000 ) {
2010-01-14 10:47:28 +01:00
$result = db_query ( $link , " SELECT id FROM ttrss_feeds
WHERE id = '$feed_id' AND owner_uid = " . $_SESSION["uid"] );
if ( db_num_rows ( $result ) != 0 ) {
unlink ( ICONS_DIR . " / $feed_id .ico " );
move_uploaded_file ( $icon_file , ICONS_DIR . " / $feed_id .ico " );
$rc = 0 ;
} else {
$rc = 2 ;
}
} else {
$rc = 1 ;
}
} else {
$rc = 2 ;
}
2010-01-14 09:28:57 +01:00
print " <script type= \" text/javascript \" > " ;
2010-01-14 10:47:28 +01:00
print " parent.uploadIconHandler( $rc ); " ;
2010-01-14 09:28:57 +01:00
print " </script> " ;
return ;
}
2010-01-13 11:44:20 +01:00
/* if ( $subop == " massSubscribe " ) {
2009-12-29 16:49:27 +01:00
$ids = split ( " , " , db_escape_string ( $_REQUEST [ " ids " ]));
2006-10-01 12:05:20 +02:00
$subscribed = array ();
foreach ( $ids as $id ) {
2010-01-11 13:40:35 +01:00
if ( $mode == 1 ) {
$result = db_query ( $link , " SELECT feed_url,title FROM ttrss_feeds
WHERE id = '$id' " );
} else if ( $mode == 2 ) {
2010-01-11 13:44:44 +01:00
$result = db_query ( $link , " SELECT * FROM ttrss_archived_feeds
2010-01-11 13:40:35 +01:00
WHERE id = '$id' AND owner_uid = " . $_SESSION["uid"] );
$orig_id = db_escape_string ( db_fetch_result ( $result , 0 , " id " ));
2010-01-11 13:44:44 +01:00
$site_url = db_escape_string ( db_fetch_result ( $result , 0 , " site_url " ));
2010-01-11 13:40:35 +01:00
}
2006-10-01 12:05:20 +02:00
$feed_url = db_escape_string ( db_fetch_result ( $result , 0 , " feed_url " ));
$title = db_escape_string ( db_fetch_result ( $result , 0 , " title " ));
2010-01-11 13:40:35 +01:00
2006-10-01 12:05:20 +02:00
$title_orig = db_fetch_result ( $result , 0 , " title " );
2010-01-11 13:40:35 +01:00
2006-10-01 12:05:20 +02:00
$result = db_query ( $link , " SELECT id FROM ttrss_feeds WHERE
2010-01-11 13:40:35 +01:00
feed_url = '$feed_url' AND owner_uid = " . $_SESSION["uid"] );
2006-10-01 12:05:20 +02:00
if ( db_num_rows ( $result ) == 0 ) {
2010-01-11 13:40:35 +01:00
if ( $mode == 1 ) {
$result = db_query ( $link ,
" INSERT INTO ttrss_feeds (owner_uid,feed_url,title,cat_id)
VALUES ( '".$_SESSION["uid"]."' , '$feed_url' , '$title' , NULL ) " );
} else if ( $mode == 2 ) {
$result = db_query ( $link ,
2010-01-11 13:44:44 +01:00
" INSERT INTO ttrss_feeds (id,owner_uid,feed_url,title,cat_id,site_url)
VALUES ( '$orig_id' , '".$_SESSION["uid"]."' , '$feed_url' , '$title' , NULL , '$site_url' ) " );
2010-01-11 13:40:35 +01:00
}
2006-10-01 12:05:20 +02:00
array_push ( $subscribed , $title_orig );
}
}
if ( count ( $subscribed ) > 0 ) {
2007-03-05 10:37:40 +01:00
$msg = " <b> " . __ ( 'Subscribed to feeds:' ) . " </b> " .
2007-03-02 20:16:45 +01:00
" <ul class= \" nomarks \" > " ;
2006-10-01 12:05:20 +02:00
foreach ( $subscribed as $title ) {
2007-03-02 20:16:45 +01:00
$msg .= " <li> $title </li> " ;
2006-10-01 12:05:20 +02:00
}
2007-03-02 20:16:45 +01:00
$msg .= " </ul> " ;
print format_notice ( $msg );
2006-10-01 12:05:20 +02:00
}
2010-01-13 11:44:20 +01:00
return ;
} */
/* if ( $subop == " browse " ) {
2006-10-01 12:05:20 +02:00
2009-01-23 19:54:57 +01:00
print " <div id= \" infoBoxTitle \" > " . __ ( 'Feed Browser' ) . " </div> " ;
2006-10-01 12:05:20 +02:00
print " <div class= \" infoBoxContents \" > " ;
2009-12-29 16:49:27 +01:00
$browser_search = db_escape_string ( $_REQUEST [ " search " ]);
2006-10-01 12:05:20 +02:00
2009-01-23 19:54:57 +01:00
//print "<p>".__("Showing top 25 registered feeds, sorted by popularity:")."</p>";
2009-01-24 06:01:17 +01:00
2010-01-11 13:40:35 +01:00
print " <form onsubmit='return false;' display='inline' name='feed_browser' id='feed_browser'> " ;
2009-01-24 06:01:17 +01:00
print "
< div style = 'float : right' >
2009-10-09 12:30:21 +02:00
< img style = 'display : none'
id = 'feed_browser_spinner' src = 'images/indicator_white.gif' >
2010-01-11 13:40:35 +01:00
< input name = \ " search \" size= \" 20 \" type= \" search \"
2010-01-12 13:56:29 +01:00
onchange = \ " javascript:updateFeedBrowser() \" value= \" $browser_search\ " >
< button onclick = \ " javascript:updateFeedBrowser() \" > " . __ ( 'Search' ) . " </button>
2009-01-24 06:01:17 +01:00
</ div > " ;
2010-01-11 13:40:35 +01:00
print " <select name= \" mode \" onchange= \" updateFeedBrowser() \" >
< option value = '1' > " . __('Popular feeds') . " </ option >
< option value = '2' > " . __('Feed archive') . " </ option >
</ select > " ;
print __ ( " limit: " );
2010-01-12 13:56:29 +01:00
print " <select name= \" limit \" onchange='updateFeedBrowser()'> " ;
2009-01-24 06:01:17 +01:00
foreach ( array ( 25 , 50 , 100 , 200 ) as $l ) {
$issel = ( $l == $limit ) ? " selected " : " " ;
print " <option $issel > $l </option> " ;
}
2010-01-11 13:40:35 +01:00
print " </select> " ;
2009-01-23 19:54:57 +01:00
print " <p> " ;
2006-10-01 12:05:20 +02:00
2009-01-23 19:54:57 +01:00
$owner_uid = $_SESSION [ " uid " ];
2006-10-01 12:05:20 +02:00
2009-01-23 19:54:57 +01:00
print " <ul class='browseFeedList' id='browseFeedList'> " ;
2010-01-12 12:44:41 +01:00
print_feed_browser ( $link , $search , 25 );
2006-10-01 12:05:20 +02:00
print " </ul> " ;
print " <div align='center'>
2010-01-12 12:44:41 +01:00
< button onclick = \ " feedBrowserSubscribe() \" > " . __ ( 'Subscribe' ) . " </button>
< button onclick = \ " closeInfoBox() \" > " . __ ( 'Cancel' ) . " </button></div> " ;
2006-10-01 12:05:20 +02:00
print " </div> " ;
return ;
2010-01-13 11:44:20 +01:00
} */
2006-10-01 12:05:20 +02:00
if ( $subop == " editfeed " ) {
$feed_id = db_escape_string ( $_REQUEST [ " id " ]);
$result = db_query ( $link ,
" SELECT * FROM ttrss_feeds WHERE id = ' $feed_id ' AND
owner_uid = " . $_SESSION["uid"] );
2007-05-19 16:09:16 +02:00
$title = htmlspecialchars ( db_fetch_result ( $result ,
0 , " title " ));
2006-10-01 12:05:20 +02:00
$icon_file = ICONS_DIR . " / $feed_id .ico " ;
if ( file_exists ( $icon_file ) && filesize ( $icon_file ) > 0 ) {
$feed_icon = " <img width= \" 16 \" height= \" 16 \"
src = \ " " . ICONS_URL . " / $feed_id .ico \" > " ;
} else {
$feed_icon = " " ;
}
2008-08-06 09:51:28 +02:00
print " <div id= \" infoBoxTitle \" > " . __ ( 'Feed Editor' ) . " </div> " ;
2006-10-01 12:05:20 +02:00
print " <div class= \" infoBoxContents \" > " ;
2007-03-02 21:58:29 +01:00
print " <form id= \" edit_feed_form \" onsubmit= \" return false \" > " ;
2006-10-01 12:05:20 +02:00
print " <input type= \" hidden \" name= \" id \" value= \" $feed_id\ " > " ;
print " <input type= \" hidden \" name= \" op \" value= \" pref-feeds \" > " ;
print " <input type= \" hidden \" name= \" subop \" value= \" editSave \" > " ;
2008-08-06 09:51:28 +02:00
print " <div class= \" dlgSec \" > " . __ ( " Feed " ) . " </div> " ;
print " <div class= \" dlgSecCont \" > " ;
2006-10-01 12:05:20 +02:00
2008-08-06 09:51:28 +02:00
/* Title */
print " <input style= \" font-size : 16px \" size= \" 40 \" onkeypress= \" return filterCR(event, feedEditSave) \"
name = \ " title \" value= \" $title\ " > " ;
/* Feed URL */
2006-10-01 12:05:20 +02:00
$feed_url = db_fetch_result ( $result , 0 , " feed_url " );
2007-05-19 16:09:16 +02:00
$feed_url = htmlspecialchars ( db_fetch_result ( $result ,
0 , " feed_url " ));
2008-08-06 09:51:28 +02:00
print " <br/> " ;
print __ ( 'URL:' ) . " " ;
print " <input size= \" 40 \" onkeypress= \" return filterCR(event, feedEditSave) \"
name = \ " feed_url \" value= \" $feed_url\ " > " ;
/* Category */
2006-10-01 12:05:20 +02:00
if ( get_pref ( $link , 'ENABLE_FEED_CATS' )) {
$cat_id = db_fetch_result ( $result , 0 , " cat_id " );
2008-08-06 09:51:28 +02:00
print " <br/> " ;
print __ ( 'Place in category:' ) . " " ;
2006-10-01 12:05:20 +02:00
$parent_feed = db_fetch_result ( $result , 0 , " parent_feed " );
if ( sprintf ( " %d " , $parent_feed ) > 0 ) {
$disabled = " disabled " ;
} else {
$disabled = " " ;
}
2008-08-06 09:51:28 +02:00
print_feed_cat_select ( $link , " cat_id " , $cat_id , $disabled );
2006-10-01 12:05:20 +02:00
}
2008-08-06 09:51:28 +02:00
/* Link to */
2006-10-01 12:05:20 +02:00
2008-08-06 09:51:28 +02:00
print " <br/> " ;
2006-10-01 12:05:20 +02:00
2008-08-06 09:51:28 +02:00
print __ ( 'Link to feed:' ) . " " ;
2006-10-01 12:05:20 +02:00
$tmp_result = db_query ( $link , " SELECT COUNT(id) AS count
FROM ttrss_feeds WHERE parent_feed = '$feed_id' " );
$linked_count = db_fetch_result ( $tmp_result , 0 , " count " );
$parent_feed = db_fetch_result ( $result , 0 , " parent_feed " );
if ( $linked_count > 0 ) {
$disabled = " disabled " ;
} else {
$disabled = " " ;
}
2008-08-06 09:51:28 +02:00
print " <select $disabled name= \" parent_feed \" > " ;
2006-10-01 12:05:20 +02:00
2007-03-05 10:37:40 +01:00
print " <option value= \" 0 \" > " . __ ( 'Not linked' ) . " </option> " ;
2006-10-01 12:05:20 +02:00
if ( get_pref ( $link , 'ENABLE_FEED_CATS' )) {
if ( $cat_id ) {
$cat_qpart = " AND cat_id = ' $cat_id ' " ;
} else {
$cat_qpart = " AND cat_id IS NULL " ;
}
}
$tmp_result = db_query ( $link , " SELECT id,title FROM ttrss_feeds
WHERE id != '$feed_id' AND owner_uid = " . $_SESSION["uid"] . " AND
( SELECT COUNT ( id ) FROM ttrss_feeds AS T2 WHERE T2 . id = ttrss_feeds . parent_feed ) = 0
$cat_qpart ORDER BY title " );
if ( db_num_rows ( $tmp_result ) > 0 ) {
print " <option disabled>--------</option> " ;
}
while ( $tmp_line = db_fetch_assoc ( $tmp_result )) {
if ( $tmp_line [ " id " ] == $parent_feed ) {
$is_selected = " selected " ;
} else {
$is_selected = " " ;
}
2009-10-09 11:25:58 +02:00
2009-10-22 09:55:50 +02:00
$linked_title = truncate_string ( htmlspecialchars ( $tmp_line [ " title " ]), 40 );
2009-10-09 11:25:58 +02:00
2006-10-01 12:05:20 +02:00
printf ( " <option $is_selected value='%d'>%s</option> " ,
2009-10-22 09:55:50 +02:00
$tmp_line [ " id " ], $linked_title );
2006-10-01 12:05:20 +02:00
}
print " </select> " ;
2010-01-14 09:28:57 +01:00
2008-08-06 09:51:28 +02:00
print " </div> " ;
2006-10-01 12:05:20 +02:00
2008-08-06 10:43:17 +02:00
print " <div class= \" dlgSec \" > " . __ ( " Update " ) . " </div> " ;
2008-08-06 09:51:28 +02:00
print " <div class= \" dlgSecCont \" > " ;
2006-10-01 12:05:20 +02:00
2008-08-06 09:51:28 +02:00
/* Update Interval */
2006-10-01 12:05:20 +02:00
2008-08-06 09:51:28 +02:00
$update_interval = db_fetch_result ( $result , 0 , " update_interval " );
print_select_hash ( " update_interval " , $update_interval , $update_intervals );
2008-01-25 18:46:01 +01:00
2008-08-06 09:51:28 +02:00
/* Update method */
2010-06-30 11:16:20 +02:00
$update_method = db_fetch_result ( $result , 0 , " update_method " );
2008-08-06 09:51:28 +02:00
2010-06-30 11:16:20 +02:00
print " " . __ ( 'using' ) . " " ;
print_select_hash ( " update_method " , $update_method , $update_methods );
2008-01-25 18:46:01 +01:00
2009-01-20 16:01:20 +01:00
$purge_interval = db_fetch_result ( $result , 0 , " purge_interval " );
2009-01-20 13:35:59 +01:00
if ( FORCE_ARTICLE_PURGE == 0 ) {
2008-08-06 09:51:28 +02:00
2009-01-20 13:35:59 +01:00
/* Purge intl */
print " <br/> " ;
print __ ( 'Article purging:' ) . " " ;
2008-08-06 09:51:28 +02:00
2009-01-20 13:35:59 +01:00
print_select_hash ( " purge_interval " , $purge_interval , $purge_intervals );
2008-08-06 09:51:28 +02:00
2009-01-20 16:01:20 +01:00
} else {
print " <input type='hidden' name='purge_interval' value=' $purge_interval '> " ;
2009-01-20 13:35:59 +01:00
}
2008-08-06 09:51:28 +02:00
print " </div> " ;
print " <div class= \" dlgSec \" > " . __ ( " Authentication " ) . " </div> " ;
print " <div class= \" dlgSecCont \" > " ;
2007-05-19 16:09:16 +02:00
$auth_login = htmlspecialchars ( db_fetch_result ( $result , 0 , " auth_login " ));
2006-10-01 12:05:20 +02:00
2009-05-12 11:06:01 +02:00
print " <table> " ;
print " <tr><td> " . __ ( 'Login:' ) . " </td><td> " ;
2008-08-06 09:51:28 +02:00
print " <input size= \" 20 \" onkeypress= \" return filterCR(event, feedEditSave) \"
name = \ " auth_login \" value= \" $auth_login\ " > " ;
2009-05-12 11:06:01 +02:00
print " </tr><tr><td> " . __ ( " Password: " ) . " </td><td> " ;
2006-10-01 12:05:20 +02:00
2007-05-19 16:09:16 +02:00
$auth_pass = htmlspecialchars ( db_fetch_result ( $result , 0 , " auth_pass " ));
2006-10-01 12:05:20 +02:00
2008-08-06 09:51:28 +02:00
print " <input size= \" 20 \" type= \" password \" name= \" auth_pass \"
2006-10-01 12:05:20 +02:00
onkeypress = \ " return filterCR(event, feedEditSave) \"
2008-08-06 09:51:28 +02:00
value = \ " $auth_pass\ " > " ;
2006-10-01 12:05:20 +02:00
2009-05-12 11:06:01 +02:00
print " </td></tr></table> " ;
2008-08-06 09:51:28 +02:00
print " </div> " ;
print " <div class= \" dlgSec \" > " . __ ( " Options " ) . " </div> " ;
print " <div class= \" dlgSecCont \" > " ;
2006-10-01 12:05:20 +02:00
2008-08-06 09:51:28 +02:00
print " <div style= \" line-height : 100% \" > " ;
2006-10-01 12:05:20 +02:00
2008-09-30 13:34:49 +02:00
$private = sql_bool_to_bool ( db_fetch_result ( $result , 0 , " private " ));
if ( $private ) {
$checked = " checked " ;
} else {
$checked = " " ;
}
2008-08-06 09:51:28 +02:00
print " <input type= \" checkbox \" name= \" private \" id= \" private \"
2010-01-11 13:54:14 +01:00
$checked >& nbsp ; < label for = \ " private \" > " . __ ( 'Hide from Popular feeds' ) . " </label> " ;
2006-10-01 12:05:20 +02:00
$rtl_content = sql_bool_to_bool ( db_fetch_result ( $result , 0 , " rtl_content " ));
if ( $rtl_content ) {
$checked = " checked " ;
} else {
$checked = " " ;
}
2008-08-06 09:51:28 +02:00
print " <br/><input type= \" checkbox \" id= \" rtl_content \" name= \" rtl_content \"
$checked >& nbsp ; < label for = \ " rtl_content \" > " . __ ( 'Right-to-left content' ) . " </label> " ;
2006-10-01 12:05:20 +02:00
$include_in_digest = sql_bool_to_bool ( db_fetch_result ( $result , 0 , " include_in_digest " ));
if ( $include_in_digest ) {
$checked = " checked " ;
} else {
$checked = " " ;
}
2008-08-06 09:51:28 +02:00
print " <br/><input type= \" checkbox \" id= \" include_in_digest \"
2006-10-01 12:05:20 +02:00
name = \ " include_in_digest \"
2008-08-06 09:51:28 +02:00
$checked >& nbsp ; < label for = \ " include_in_digest \" > " . __ ( 'Include in e-mail digest' ) . " </label> " ;
2006-10-01 12:05:20 +02:00
2009-10-06 12:15:29 +02:00
$always_display_enclosures = sql_bool_to_bool ( db_fetch_result ( $result , 0 , " always_display_enclosures " ));
if ( $always_display_enclosures ) {
$checked = " checked " ;
} else {
$checked = " " ;
}
print " <br/><input type= \" checkbox \" id= \" always_display_enclosures \"
name = \ " always_display_enclosures \"
$checked >& nbsp ; < label for = \ " always_display_enclosures \" > " . __ ( 'Always display image attachments' ) . " </label> " ;
2007-08-26 06:00:30 +02:00
$cache_images = sql_bool_to_bool ( db_fetch_result ( $result , 0 , " cache_images " ));
if ( $cache_images ) {
$checked = " checked " ;
} else {
$checked = " " ;
}
2010-06-30 10:57:11 +02:00
if ( SIMPLEPIE_CACHE_IMAGES ) {
2007-08-26 06:00:30 +02:00
$disabled = " " ;
$label_class = " " ;
} else {
$disabled = " disabled " ;
$label_class = " class='insensitive' " ;
}
2008-08-06 09:51:28 +02:00
print " <br/><input type= \" checkbox \" id= \" cache_images \"
2007-08-26 06:00:30 +02:00
name = \ " cache_images \" $disabled
2008-08-06 09:51:28 +02:00
$checked >& nbsp ; < label $label_class for = \ " cache_images \" > " .
2007-08-26 06:00:30 +02:00
__ ( 'Cache images locally' ) . " </label> " ;
2006-10-01 12:05:20 +02:00
2008-08-06 09:51:28 +02:00
print " </div> " ;
print " </div> " ;
2006-10-01 12:05:20 +02:00
print " </form> " ;
2010-01-14 09:28:57 +01:00
/* Icon */
print " <br/> " ;
2010-01-14 10:47:28 +01:00
print " <div class= \" dlgSec \" > " . __ ( " Icon " ) . " </div> " ;
2010-01-14 09:28:57 +01:00
print " <div class= \" dlgSecCont \" > " ;
print " <iframe name= \" icon_upload_iframe \"
style = \ " width: 400px; height: 100px; display: none; \" ></iframe> " ;
print " <form style='display : block' target= \" icon_upload_iframe \"
enctype = \ " multipart/form-data \" method= \" POST \"
action = \ " backend.php \" >
2010-01-14 10:47:28 +01:00
< input id = \ " icon_file \" size= \" 10 \" name= \" icon_file \" type= \" file \" >
2010-01-14 09:28:57 +01:00
< input type = \ " hidden \" name= \" op \" value= \" pref-feeds \" >
2010-01-14 10:47:28 +01:00
< input type = \ " hidden \" name= \" feed_id \" value= \" $feed_id\ " >
2010-01-14 09:28:57 +01:00
< input type = \ " hidden \" name= \" subop \" value= \" uploadicon \" >
< button onclick = \ " return uploadFeedIcon(); \"
type = \ " submit \" > " . __ ( 'Replace' ) . " </button>
2010-01-14 10:47:28 +01:00
< button onclick = \ " return removeFeedIcon( $feed_id ); \"
type = \ " submit \" > " . __ ( 'Remove' ) . " </button>
2010-01-14 09:28:57 +01:00
</ form > " ;
2010-01-14 10:47:28 +01:00
print " </div> " ;
2010-01-14 09:28:57 +01:00
2008-11-17 06:49:06 +01:00
$title = htmlspecialchars ( $title , ENT_QUOTES );
2008-08-06 09:51:28 +02:00
print " <div class='dlgButtons'>
2008-08-07 05:17:24 +02:00
< div style = \ " float : left \" >
2010-01-12 13:27:04 +01:00
< button onclick = 'return unsubscribeFeed($feed_id, \"$title\")' > " .
__ ( 'Unsubscribe' ) . " </button>
2008-08-07 05:17:24 +02:00
</ div >
2010-01-12 13:27:04 +01:00
< button onclick = \ " return feedEditSave() \" > " . __ ( 'Save' ) . " </button>
< button onclick = \ " return feedEditCancel() \" > " . __ ( 'Cancel' ) . " </button>
2008-08-06 10:18:02 +02:00
</ div > " ;
2006-10-01 12:05:20 +02:00
return ;
}
2008-09-11 08:06:25 +02:00
if ( $subop == " editfeeds " ) {
$feed_ids = db_escape_string ( $_REQUEST [ " ids " ]);
2008-09-11 08:36:41 +02:00
print " <div id= \" infoBoxTitle \" > " . __ ( 'Multiple Feed Editor' ) . " </div> " ;
2008-09-11 08:06:25 +02:00
print " <div class= \" infoBoxContents \" > " ;
print " <form id= \" batch_edit_feed_form \" onsubmit= \" return false \" > " ;
print " <input type= \" hidden \" name= \" ids \" value= \" $feed_ids\ " > " ;
print " <input type= \" hidden \" name= \" op \" value= \" pref-feeds \" > " ;
print " <input type= \" hidden \" name= \" subop \" value= \" batchEditSave \" > " ;
print " <div class= \" dlgSec \" > " . __ ( " Feed " ) . " </div> " ;
print " <div class= \" dlgSecCont \" > " ;
/* Title */
print " <input disabled style= \" font-size : 16px \" size= \" 35 \" onkeypress= \" return filterCR(event, feedEditSave) \"
name = \ " title \" value= \" $title\ " > " ;
batch_edit_cbox ( " title " );
/* Feed URL */
print " <br/> " ;
print __ ( 'URL:' ) . " " ;
print " <input disabled size= \" 40 \" onkeypress= \" return filterCR(event, feedEditSave) \"
name = \ " feed_url \" value= \" $feed_url\ " > " ;
batch_edit_cbox ( " feed_url " );
/* Category */
if ( get_pref ( $link , 'ENABLE_FEED_CATS' )) {
print " <br/> " ;
print __ ( 'Place in category:' ) . " " ;
print_feed_cat_select ( $link , " cat_id " , $cat_id , " disabled " );
batch_edit_cbox ( " cat_id " );
}
print " </div> " ;
print " <div class= \" dlgSec \" > " . __ ( " Update " ) . " </div> " ;
print " <div class= \" dlgSecCont \" > " ;
/* Update Interval */
print_select_hash ( " update_interval " , $update_interval , $update_intervals ,
" disabled " );
batch_edit_cbox ( " update_interval " );
/* Update method */
2010-06-30 11:16:20 +02:00
print " " . __ ( 'using' ) . " " ;
print_select_hash ( " update_method " , $update_method , $update_methods ,
" disabled " );
batch_edit_cbox ( " update_method " );
2008-09-11 08:06:25 +02:00
/* Purge intl */
2009-01-20 13:35:59 +01:00
if ( FORCE_ARTICLE_PURGE != 0 ) {
2008-09-11 08:06:25 +02:00
2009-01-20 13:35:59 +01:00
print " <br/> " ;
2008-09-11 08:06:25 +02:00
2009-01-20 13:35:59 +01:00
print __ ( 'Article purging:' ) . " " ;
2008-09-11 08:06:25 +02:00
2009-01-20 13:35:59 +01:00
print_select_hash ( " purge_interval " , $purge_interval , $purge_intervals ,
" disabled " );
batch_edit_cbox ( " purge_interval " );
}
2008-09-11 08:06:25 +02:00
print " </div> " ;
print " <div class= \" dlgSec \" > " . __ ( " Authentication " ) . " </div> " ;
print " <div class= \" dlgSecCont \" > " ;
print __ ( 'Login:' ) . " " ;
print " <input disabled size= \" 15 \" onkeypress= \" return filterCR(event, feedEditSave) \"
name = \ " auth_login \" value= \" $auth_login\ " > " ;
batch_edit_cbox ( " auth_login " );
print " " . __ ( " Password: " ) . " " ;
print " <input disabled size= \" 15 \" type= \" password \" name= \" auth_pass \"
onkeypress = \ " return filterCR(event, feedEditSave) \"
value = \ " $auth_pass\ " > " ;
batch_edit_cbox ( " auth_pass " );
print " </div> " ;
print " <div class= \" dlgSec \" > " . __ ( " Options " ) . " </div> " ;
print " <div class= \" dlgSecCont \" > " ;
print " <div style= \" line-height : 100% \" > " ;
print " <input disabled type= \" checkbox \" name= \" private \" id= \" private \"
2010-01-12 09:50:22 +01:00
$checked >& nbsp ; < label id = \ " private_l \" class='insensitive' for= \" private \" > " . __ ( 'Hide from Popular feeds' ) . " </label> " ;
2008-09-11 08:06:25 +02:00
print " " ; batch_edit_cbox ( " private " , " private_l " );
print " <br/><input disabled type= \" checkbox \" id= \" rtl_content \" name= \" rtl_content \"
$checked >& nbsp ; < label class = 'insensitive' id = \ " rtl_content_l \" for= \" rtl_content \" > " . __ ( 'Right-to-left content' ) . " </label> " ;
print " " ; batch_edit_cbox ( " rtl_content " , " rtl_content_l " );
print " <br/><input disabled type= \" checkbox \" id= \" include_in_digest \"
name = \ " include_in_digest \"
$checked >& nbsp ; < label id = \ " include_in_digest_l \" class='insensitive' for= \" include_in_digest \" > " . __ ( 'Include in e-mail digest' ) . " </label> " ;
print " " ; batch_edit_cbox ( " include_in_digest " , " include_in_digest_l " );
2009-10-06 12:36:25 +02:00
print " <br/><input disabled type= \" checkbox \" id= \" always_display_enclosures \"
name = \ " always_display_enclosures \"
$checked >& nbsp ; < label id = \ " always_display_enclosures_l \" class='insensitive' for= \" always_display_enclosures \" > " . __ ( 'Always display image attachments' ) . " </label> " ;
print " " ; batch_edit_cbox ( " always_display_enclosures " , " always_display_enclosures_l " );
2008-09-11 08:06:25 +02:00
print " <br/><input disabled type= \" checkbox \" id= \" cache_images \"
name = \ " cache_images \"
$checked >& nbsp ; < label class = 'insensitive' id = \ " cache_images_l \"
for = \ " cache_images \" > " .
__ ( 'Cache images locally' ) . " </label> " ;
2010-06-30 10:57:11 +02:00
if ( SIMPLEPIE_CACHE_IMAGES ) {
2008-09-11 08:06:25 +02:00
print " " ; batch_edit_cbox ( " cache_images " , " cache_images_l " );
}
print " </div> " ;
print " </div> " ;
print " </form> " ;
print " <div class='dlgButtons'>
< input type = \ " submit \" class= \" button \"
onclick = \ " return feedsEditSave() \" value= \" " . __ ( 'Save' ) . " \" >
< input type = 'submit' class = 'button'
onclick = \ " return feedEditCancel() \" value= \" " . __ ( 'Cancel' ) . " \" >
</ div > " ;
return ;
}
2008-09-11 08:36:41 +02:00
if ( $subop == " editSave " || $subop == " batchEditSave " ) {
2006-10-01 12:05:20 +02:00
$feed_title = db_escape_string ( trim ( $_POST [ " title " ]));
$feed_link = db_escape_string ( trim ( $_POST [ " feed_url " ]));
$upd_intl = db_escape_string ( $_POST [ " update_interval " ]);
$purge_intl = db_escape_string ( $_POST [ " purge_interval " ]);
2008-09-11 08:36:41 +02:00
$feed_id = db_escape_string ( $_POST [ " id " ]); /* editSave */
$feed_ids = db_escape_string ( $_POST [ " ids " ]); /* batchEditSave */
2006-10-01 12:05:20 +02:00
$cat_id = db_escape_string ( $_POST [ " cat_id " ]);
$auth_login = db_escape_string ( trim ( $_POST [ " auth_login " ]));
$auth_pass = db_escape_string ( trim ( $_POST [ " auth_pass " ]));
$parent_feed = db_escape_string ( $_POST [ " parent_feed " ]);
$private = checkbox_to_sql_bool ( db_escape_string ( $_POST [ " private " ]));
$rtl_content = checkbox_to_sql_bool ( db_escape_string ( $_POST [ " rtl_content " ]));
$include_in_digest = checkbox_to_sql_bool (
db_escape_string ( $_POST [ " include_in_digest " ]));
2007-08-26 06:00:30 +02:00
$cache_images = checkbox_to_sql_bool (
db_escape_string ( $_POST [ " cache_images " ]));
2008-01-25 18:46:01 +01:00
$update_method = ( int ) db_escape_string ( $_POST [ " update_method " ]);
2006-10-01 12:05:20 +02:00
2009-10-06 12:15:29 +02:00
$always_display_enclosures = checkbox_to_sql_bool (
db_escape_string ( $_POST [ " always_display_enclosures " ]));
2006-10-01 12:05:20 +02:00
if ( get_pref ( $link , 'ENABLE_FEED_CATS' )) {
if ( $cat_id && $cat_id != 0 ) {
$category_qpart = " cat_id = ' $cat_id ', " ;
$category_qpart_nocomma = " cat_id = ' $cat_id ' " ;
} else {
$category_qpart = 'cat_id = NULL,' ;
$category_qpart_nocomma = 'cat_id = NULL' ;
}
} else {
$category_qpart = " " ;
$category_qpart_nocomma = " " ;
}
if ( $parent_feed && $parent_feed != 0 ) {
$parent_qpart = " parent_feed = ' $parent_feed ' " ;
} else {
$parent_qpart = 'parent_feed = NULL' ;
}
2010-06-30 10:57:11 +02:00
if ( SIMPLEPIE_CACHE_IMAGES ) {
2007-08-26 06:00:30 +02:00
$cache_images_qpart = " cache_images = $cache_images , " ;
} else {
$cache_images_qpart = " " ;
}
2008-09-11 08:36:41 +02:00
if ( $subop == " editSave " ) {
$result = db_query ( $link , " UPDATE ttrss_feeds SET
$category_qpart $parent_qpart ,
title = '$feed_title' , feed_url = '$feed_link' ,
update_interval = '$upd_intl' ,
purge_interval = '$purge_intl' ,
auth_login = '$auth_login' ,
auth_pass = '$auth_pass' ,
private = $private ,
rtl_content = $rtl_content ,
$cache_images_qpart
include_in_digest = $include_in_digest ,
2009-10-06 12:15:29 +02:00
always_display_enclosures = $always_display_enclosures ,
2008-09-11 08:36:41 +02:00
update_method = '$update_method'
2008-09-17 07:11:53 +02:00
WHERE id = '$feed_id' AND owner_uid = " . $_SESSION["uid"] );
2008-09-11 08:36:41 +02:00
if ( get_pref ( $link , 'ENABLE_FEED_CATS' )) {
# update linked feed categories
$result = db_query ( $link , " UPDATE ttrss_feeds SET
$category_qpart_nocomma WHERE parent_feed = '$feed_id' AND
owner_uid = " . $_SESSION["uid"] );
}
} else if ( $subop == " batchEditSave " ) {
$feed_data = array ();
2006-10-01 12:05:20 +02:00
2008-09-11 08:36:41 +02:00
foreach ( array_keys ( $_POST ) as $k ) {
if ( $k != " op " && $k != " subop " && $k != " ids " ) {
$feed_data [ $k ] = $_POST [ $k ];
}
}
db_query ( $link , " BEGIN " );
foreach ( array_keys ( $feed_data ) as $k ) {
$qpart = " " ;
switch ( $k ) {
case " title " :
$qpart = " title = ' $feed_title ' " ;
break ;
case " feed_url " :
$qpart = " feed_url = ' $feed_link ' " ;
break ;
case " update_interval " :
$qpart = " update_interval = ' $upd_intl ' " ;
break ;
case " purge_interval " :
$qpart = " purge_interval = ' $purge_intl ' " ;
break ;
case " auth_login " :
$qpart = " auth_login = ' $auth_login ' " ;
break ;
case " auth_pass " :
$qpart = " auth_pass = ' $auth_pass ' " ;
break ;
case " private " :
$qpart = " private = ' $private ' " ;
break ;
case " include_in_digest " :
$qpart = " include_in_digest = ' $include_in_digest ' " ;
break ;
2009-10-06 12:36:25 +02:00
case " always_display_enclosures " :
$qpart = " always_display_enclosures = ' $always_display_enclosures ' " ;
break ;
2008-09-11 08:45:39 +02:00
case " cache_images " :
$qpart = " cache_images = ' $cache_images ' " ;
break ;
case " rtl_content " :
$qpart = " rtl_content = ' $rtl_content ' " ;
break ;
2008-09-11 08:36:41 +02:00
case " update_method " :
$qpart = " update_method = ' $update_method ' " ;
break ;
case " cat_id " :
$qpart = $category_qpart_nocomma ;
break ;
}
if ( $qpart ) {
2008-09-11 09:01:34 +02:00
db_query ( $link ,
2008-09-11 08:36:41 +02:00
" UPDATE ttrss_feeds SET $qpart WHERE id IN ( $feed_ids )
2008-09-11 08:52:19 +02:00
AND owner_uid = " . $_SESSION["uid"] );
print " <br/> " ;
2008-09-11 08:36:41 +02:00
}
}
db_query ( $link , " COMMIT " );
2006-10-01 12:05:20 +02:00
}
2008-09-11 08:36:41 +02:00
2006-10-01 12:05:20 +02:00
}
if ( $subop == " remove " ) {
2009-12-29 16:49:27 +01:00
$ids = split ( " , " , db_escape_string ( $_REQUEST [ " ids " ]));
2006-10-01 12:05:20 +02:00
2009-01-18 10:32:45 +01:00
foreach ( $ids as $id ) {
2009-12-28 10:04:21 +01:00
remove_feed ( $link , $id , $_SESSION [ " uid " ]);
2006-10-01 12:05:20 +02:00
}
2010-01-13 21:59:02 +01:00
return ;
2006-10-01 12:05:20 +02:00
}
2007-08-26 06:13:50 +02:00
if ( $subop == " clear " ) {
2009-12-29 16:49:27 +01:00
$id = db_escape_string ( $_REQUEST [ " id " ]);
2007-08-26 06:13:50 +02:00
clear_feed_articles ( $link , $id );
}
2008-04-30 12:12:41 +02:00
if ( $subop == " rescore " ) {
2009-12-29 16:49:27 +01:00
$ids = split ( " , " , db_escape_string ( $_REQUEST [ " ids " ]));
2008-04-30 12:12:41 +02:00
foreach ( $ids as $id ) {
$filters = load_filters ( $link , $id , $_SESSION [ " uid " ], 6 );
$result = db_query ( $link , " SELECT title, content, link, ref_id FROM
ttrss_user_entries , ttrss_entries
WHERE ref_id = id AND feed_id = '$id' AND
owner_uid = " . $_SESSION['uid'] . "
2008-04-30 12:54:26 +02:00
" );
2008-04-30 12:12:41 +02:00
$scores = array ();
while ( $line = db_fetch_assoc ( $result )) {
$article_filters = get_article_filters ( $filters , $line [ 'title' ],
$line [ 'content' ], $line [ 'link' ]);
$new_score = calculate_article_score ( $article_filters );
if ( ! $scores [ $new_score ]) $scores [ $new_score ] = array ();
array_push ( $scores [ $new_score ], $line [ 'ref_id' ]);
}
foreach ( array_keys ( $scores ) as $s ) {
if ( $s > 1000 ) {
db_query ( $link , " UPDATE ttrss_user_entries SET score = ' $s ',
marked = true WHERE
2008-05-04 06:46:14 +02:00
ref_id IN ( " . join(',', $scores[$s] ) . " ) " );
2008-05-17 04:34:49 +02:00
} else if ( $s < - 500 ) {
db_query ( $link , " UPDATE ttrss_user_entries SET score = ' $s ',
unread = false WHERE
ref_id IN ( " . join(',', $scores[$s] ) . " ) " );
2008-05-04 06:46:14 +02:00
} else {
db_query ( $link , " UPDATE ttrss_user_entries SET score = ' $s ' WHERE
ref_id IN ( " . join(',', $scores[$s] ) . " ) " );
}
}
}
print __ ( " All done. " );
}
if ( $subop == " rescoreAll " ) {
$result = db_query ( $link ,
" SELECT id FROM ttrss_feeds WHERE owner_uid = " . $_SESSION [ 'uid' ]);
while ( $feed_line = db_fetch_assoc ( $result )) {
$id = $feed_line [ " id " ];
$filters = load_filters ( $link , $id , $_SESSION [ " uid " ], 6 );
$tmp_result = db_query ( $link , " SELECT title, content, link, ref_id FROM
ttrss_user_entries , ttrss_entries
WHERE ref_id = id AND feed_id = '$id' AND
owner_uid = " . $_SESSION['uid'] . "
" );
$scores = array ();
while ( $line = db_fetch_assoc ( $tmp_result )) {
$article_filters = get_article_filters ( $filters , $line [ 'title' ],
$line [ 'content' ], $line [ 'link' ]);
$new_score = calculate_article_score ( $article_filters );
if ( ! $scores [ $new_score ]) $scores [ $new_score ] = array ();
array_push ( $scores [ $new_score ], $line [ 'ref_id' ]);
}
foreach ( array_keys ( $scores ) as $s ) {
if ( $s > 1000 ) {
db_query ( $link , " UPDATE ttrss_user_entries SET score = ' $s ',
marked = true WHERE
2008-04-30 12:12:41 +02:00
ref_id IN ( " . join(',', $scores[$s] ) . " ) " );
} else {
db_query ( $link , " UPDATE ttrss_user_entries SET score = ' $s ' WHERE
ref_id IN ( " . join(',', $scores[$s] ) . " ) " );
}
}
}
print __ ( " All done. " );
}
2006-10-01 12:05:20 +02:00
if ( $subop == " add " ) {
2010-01-13 10:48:49 +01:00
$feed_url = db_escape_string ( trim ( $_REQUEST [ " feed_url " ]));
$cat_id = db_escape_string ( $_REQUEST [ " cat_id " ]);
$p_from = db_escape_string ( $_REQUEST [ " from " ]);
2006-10-01 12:05:20 +02:00
2010-01-13 10:48:49 +01:00
/* only read authentication information from POST */
2006-10-31 09:37:40 +01:00
2010-01-13 10:48:49 +01:00
$auth_login = db_escape_string ( trim ( $_POST [ " auth_login " ]));
$auth_pass = db_escape_string ( trim ( $_POST [ " auth_pass " ]));
2006-10-31 09:37:40 +01:00
2010-01-13 10:48:49 +01:00
if ( $p_from != 'tt-rss' ) {
print " <html>
< head >
< title > Tiny Tiny RSS </ title >
< link rel = \ " stylesheet \" type= \" text/css \" href= \" utility.css \" >
</ head >
< body >
< img class = \ " floatingLogo \" src= \" images/ttrss_logo.png \"
alt = \ " Tiny Tiny RSS \" />
< h1 > Subscribe to feed ...</ h1 > " ;
}
2008-02-24 13:18:08 +01:00
2010-01-13 10:48:49 +01:00
$rc = subscribe_to_feed ( $link , $feed_url , $cat_id , $auth_login , $auth_pass );
switch ( $rc ) {
case 1 :
print_notice ( T_sprintf ( " Subscribed to <b>%s</b>. " , $feed_url ));
break ;
case 2 :
print_error ( T_sprintf ( " Could not subscribe to <b>%s</b>. " , $feed_url ));
break ;
case 0 :
print_warning ( T_sprintf ( " Already subscribed to <b>%s</b>. " , $feed_url ));
break ;
}
2006-12-18 06:56:55 +01:00
2010-01-13 10:48:49 +01:00
if ( $p_from != 'tt-rss' ) {
$tt_uri = ( $_SERVER [ 'HTTPS' ] != " on " ? 'http://' : 'https://' ) . $_SERVER [ 'HTTP_HOST' ] . preg_replace ( '/backend\.php.*$/' , 'tt-rss.php' , $_SERVER [ " REQUEST_URI " ]);
2006-12-18 06:56:55 +01:00
2010-01-13 10:48:49 +01:00
$tp_uri = ( $_SERVER [ 'HTTPS' ] != " on " ? 'http://' : 'https://' ) . $_SERVER [ 'HTTP_HOST' ] . preg_replace ( '/backend\.php.*$/' , 'prefs.php' , $_SERVER [ " REQUEST_URI " ]);
2009-01-22 17:30:37 +01:00
2010-01-13 10:48:49 +01:00
$result = db_query ( $link , " SELECT id FROM ttrss_feeds WHERE
feed_url = '$feed_url' AND owner_uid = " . $_SESSION["uid"] );
2006-12-18 06:56:55 +01:00
2010-01-13 10:48:49 +01:00
$feed_id = db_fetch_result ( $result , 0 , " id " );
2006-10-31 09:37:40 +01:00
2010-01-13 10:48:49 +01:00
print " <p> " ;
if ( $feed_id ) {
print " <form method= \" GET \" style='display: inline'
action = \ " $tp_uri\ " >
< input type = \ " hidden \" name= \" tab \" value= \" feedConfig \" >
< input type = \ " hidden \" name= \" subop \" value= \" editFeed \" >
< input type = \ " hidden \" name= \" subopparam \" value= \" $feed_id\ " >
< input type = \ " submit \" value= \" " . __ ( " Edit subscription options " ) . " \" >
</ form > " ;
2006-10-31 09:37:40 +01:00
}
2007-05-14 07:41:04 +02:00
2010-01-13 10:48:49 +01:00
print " <form style='display: inline' method= \" GET \" action= \" $tt_uri\ " >
< input type = \ " submit \" value= \" " . __ ( " Return to Tiny Tiny RSS " ) . " \" >
</ form ></ p > " ;
print " </body></html> " ;
return ;
2006-10-01 12:05:20 +02:00
}
}
if ( $subop == " categorize " ) {
2010-07-01 10:26:27 +02:00
$ids = split ( " , " , db_escape_string ( $_REQUEST [ " ids " ]));
2006-10-01 12:05:20 +02:00
2010-07-01 10:26:27 +02:00
$cat_id = db_escape_string ( $_REQUEST [ " cat_id " ]);
2006-10-01 12:05:20 +02:00
2010-07-01 10:26:27 +02:00
if ( $cat_id == 0 ) {
$cat_id_qpart = 'NULL' ;
} else {
$cat_id_qpart = " ' $cat_id ' " ;
}
2006-10-01 12:05:20 +02:00
2010-07-01 10:26:27 +02:00
db_query ( $link , " BEGIN " );
2006-10-01 12:05:20 +02:00
2010-07-01 10:26:27 +02:00
foreach ( $ids as $id ) {
db_query ( $link , " UPDATE ttrss_feeds SET cat_id = $cat_id_qpart
WHERE id = '$id' AND parent_feed IS NULL
AND owner_uid = " . $_SESSION["uid"] );
2006-10-01 12:05:20 +02:00
2010-07-01 10:26:27 +02:00
# update linked feed categories
db_query ( $link , " UPDATE ttrss_feeds SET
cat_id = $cat_id_qpart WHERE parent_feed = '$id' AND
owner_uid = " . $_SESSION["uid"] );
2006-10-01 12:05:20 +02:00
}
2010-07-01 10:26:27 +02:00
db_query ( $link , " COMMIT " );
2006-10-01 12:05:20 +02:00
}
2006-10-04 07:40:00 +02:00
if ( $subop == " editCats " ) {
$action = $_REQUEST [ " action " ];
if ( $action == " save " ) {
2007-08-20 09:29:39 +02:00
$cat_title = db_escape_string ( trim ( $_REQUEST [ " value " ]));
2009-12-29 16:49:27 +01:00
$cat_id = db_escape_string ( $_REQUEST [ " cid " ]);
2007-08-20 09:29:39 +02:00
2009-01-20 17:48:38 +01:00
db_query ( $link , " BEGIN " );
$result = db_query ( $link , " SELECT title FROM ttrss_feed_categories
WHERE id = '$cat_id' AND owner_uid = " . $_SESSION["uid"] );
if ( db_num_rows ( $result ) == 1 ) {
$old_title = db_fetch_result ( $result , 0 , " title " );
if ( $cat_title != " " ) {
$result = db_query ( $link , " UPDATE ttrss_feed_categories SET
title = '$cat_title' WHERE id = '$cat_id' AND
owner_uid = " . $_SESSION["uid"] );
print $cat_title ;
} else {
print $old_title ;
}
} else {
print $_REQUEST [ " value " ];
}
db_query ( $link , " COMMIT " );
2007-08-20 09:29:39 +02:00
return ;
2006-10-04 07:40:00 +02:00
}
2007-08-20 09:29:39 +02:00
print " <div id= \" infoBoxTitle \" > " . __ ( 'Category editor' ) . " </div> " ;
print " <div class= \" infoBoxContents \" > " ;
2006-10-04 07:40:00 +02:00
if ( $action == " add " ) {
2010-07-01 10:26:27 +02:00
$feed_cat = db_escape_string ( trim ( $_REQUEST [ " cat " ]));
$result = db_query ( $link ,
" SELECT id FROM ttrss_feed_categories
WHERE title = '$feed_cat' AND owner_uid = " . $_SESSION["uid"] );
if ( db_num_rows ( $result ) == 0 ) {
2006-10-04 07:40:00 +02:00
$result = db_query ( $link ,
2010-07-01 10:26:27 +02:00
" INSERT INTO ttrss_feed_categories (owner_uid,title)
VALUES ( '".$_SESSION["uid"]."' , '$feed_cat' ) " );
2006-10-04 07:40:00 +02:00
2010-07-01 10:26:27 +02:00
} else {
print_warning ( T_sprintf ( " Category <b> $ %s</b> already exists in the database. " ,
$feed_cat ));
2006-10-04 07:40:00 +02:00
}
2010-07-01 10:26:27 +02:00
2006-10-04 07:40:00 +02:00
}
if ( $action == " remove " ) {
2009-12-29 16:49:27 +01:00
$ids = split ( " , " , db_escape_string ( $_REQUEST [ " ids " ]));
2006-10-04 07:40:00 +02:00
2009-12-28 10:04:21 +01:00
foreach ( $ids as $id ) {
remove_feed_category ( $link , $id , $_SESSION [ " uid " ]);
2006-10-04 07:40:00 +02:00
}
}
2010-01-13 16:31:51 +01:00
print " <div>
2006-10-04 07:40:00 +02:00
< input id = \ " fadd_cat \"
2006-10-04 08:40:45 +02:00
onkeypress = \ " return filterCR(event, addFeedCat) \"
2010-01-12 14:04:59 +01:00
size = \ " 40 \" >
< button onclick = \ " javascript:addFeedCat() \" > " .
__ ( 'Create category' ) . " </button></div> " ;
2006-10-04 07:40:00 +02:00
$result = db_query ( $link , " SELECT title,id FROM ttrss_feed_categories
WHERE owner_uid = " . $_SESSION["uid"] . "
ORDER BY title " );
print " <p> " ;
if ( db_num_rows ( $result ) != 0 ) {
2010-01-12 14:04:59 +01:00
print __ ( 'Select:' ) . "
2007-05-14 09:56:49 +02:00
< a href = \ " javascript:selectPrefRows('fcat', true) \" > " . __ ( 'All' ) . " </a>,
2010-01-12 14:04:59 +01:00
< a href = \ " javascript:selectPrefRows('fcat', false) \" > " . __ ( 'None' ) . " </a> " ;
2006-10-04 07:40:00 +02:00
print " <div class= \" prefFeedCatHolder \" > " ;
2007-03-02 21:58:29 +01:00
print " <form id= \" feed_cat_edit_form \" onsubmit= \" return false \" > " ;
2006-10-04 07:40:00 +02:00
print " <table width= \" 100% \" class= \" prefFeedCatList \"
cellspacing = \ " 0 \" id= \" prefFeedCatList \" > " ;
$lnum = 0 ;
while ( $line = db_fetch_assoc ( $result )) {
$class = ( $lnum % 2 ) ? " even " : " odd " ;
$cat_id = $line [ " id " ];
2007-08-20 09:29:39 +02:00
$this_row_id = " id= \" FCATR- $cat_id\ " " ;
2006-10-04 07:40:00 +02:00
print " <tr class= \" $class\ " $this_row_id > " ;
2007-05-19 16:09:16 +02:00
$edit_title = htmlspecialchars ( $line [ " title " ]);
2006-10-04 07:40:00 +02:00
2007-08-20 09:29:39 +02:00
print " <td width='5%' align='center'><input
onclick = 'toggleSelectPrefRow(this, \"fcat\");'
type = \ " checkbox \" id= \" FCCHK- $cat_id\ " ></ td > " ;
print " <td><span id= \" FCATT- $cat_id\ " > " .
$edit_title . " </span></td> " ;
2006-10-04 07:40:00 +02:00
print " </tr> " ;
++ $lnum ;
}
print " </table> " ;
print " </form> " ;
print " </div> " ;
2006-10-04 08:14:16 +02:00
} else {
2007-03-05 10:37:40 +01:00
print " <p> " . __ ( 'No feed categories defined.' ) . " </p> " ;
2006-10-04 08:14:16 +02:00
}
2006-10-04 07:40:00 +02:00
2010-01-12 14:04:59 +01:00
print " <div class='dlgButtons'>
< div style = 'float : left' >
< button onclick = \ " return removeSelectedFeedCats() \" > " .
__ ( 'Remove' ) . " </button>
</ div > " ;
2006-10-04 07:40:00 +02:00
2010-01-12 14:04:59 +01:00
print " <button onclick= \" selectTab('feedConfig') \" > " .
__ ( 'Close this window' ) . " </button></div> " ;
2006-10-04 07:40:00 +02:00
2006-10-04 08:14:16 +02:00
print " </div> " ;
2006-10-04 07:40:00 +02:00
return ;
}
2006-10-01 12:05:20 +02:00
if ( $quiet ) return ;
2007-05-14 07:41:04 +02:00
set_pref ( $link , " _PREFS_ACTIVE_TAB " , " feedConfig " );
2006-12-01 07:26:05 +01:00
$result = db_query ( $link , " SELECT COUNT(id) AS num_errors
2006-10-01 12:05:20 +02:00
FROM ttrss_feeds WHERE last_error != '' AND owner_uid = " . $_SESSION["uid"] );
2006-12-01 07:26:05 +01:00
$num_errors = db_fetch_result ( $result , 0 , " num_errors " );
2006-10-01 12:05:20 +02:00
2006-12-01 07:26:05 +01:00
if ( $num_errors > 0 ) {
2006-10-01 12:05:20 +02:00
2007-03-05 10:37:40 +01:00
print format_notice ( " <a href= \" javascript:showFeedsWithErrors() \" > " .
__ ( 'Some feeds have update errors (click for details)' ) . " </a> " );
2006-10-01 12:05:20 +02:00
}
2009-12-29 16:49:27 +01:00
$feed_search = db_escape_string ( $_REQUEST [ " search " ]);
2006-10-01 12:05:20 +02:00
2009-12-29 16:49:27 +01:00
if ( array_key_exists ( " search " , $_REQUEST )) {
2006-10-01 12:05:20 +02:00
$_SESSION [ " prefs_feed_search " ] = $feed_search ;
} else {
$feed_search = $_SESSION [ " prefs_feed_search " ];
}
2010-01-12 13:56:29 +01:00
print " <div style='float : right'>
2007-11-30 09:06:17 +01:00
< input id = \ " feed_search \" size= \" 20 \" type= \" search \"
2008-05-17 05:11:51 +02:00
onfocus = \ " javascript:disableHotkeys(); \"
onblur = \ " javascript:enableHotkeys(); \"
2006-10-01 12:05:20 +02:00
onchange = \ " javascript:updateFeedList() \" value= \" $feed_search\ " >
2010-01-12 13:56:29 +01:00
< button onclick = \ " javascript:updateFeedList() \" > " .
__ ( 'Search' ) . " </button>
2006-10-01 12:05:20 +02:00
</ div > " ;
2007-03-05 14:45:34 +01:00
2010-02-03 14:54:17 +01:00
print " <button onclick= \" quickAddFeed() \" > "
2010-01-12 13:56:29 +01:00
. __ ( 'Subscribe to feed' ) . " </button> " ;
2010-01-11 16:43:53 +01:00
2010-02-03 14:54:17 +01:00
print " <button onclick= \" editSelectedFeed() \" > " .
2010-01-12 13:56:29 +01:00
__ ( 'Edit feeds' ) . " </button> " ;
2010-01-11 16:43:53 +01:00
if ( get_pref ( $link , 'ENABLE_FEED_CATS' )) {
2010-01-12 13:56:29 +01:00
print " <button onclick= \" javascript:editFeedCats() \" > " .
__ ( 'Edit categories' ) . " </button> " ;
2010-01-11 16:43:53 +01:00
}
2010-01-12 13:56:29 +01:00
print " <button onclick= \" javascript:removeSelectedFeeds() \" > "
. __ ( 'Unsubscribe' ) . " </button> " ;
2010-01-11 16:43:53 +01:00
2010-01-28 16:52:46 +01:00
if ( defined ( '_ENABLE_FEED_DEBUGGING' )) {
2006-10-01 12:05:20 +02:00
2010-01-28 16:52:46 +01:00
print " <select id= \" feedActionChooser \" onchange= \" feedActionChange() \" >
< option value = \ " facDefault \" selected> " . __ ( 'More actions...' ) . " </option> " ;
if ( FORCE_ARTICLE_PURGE == 0 ) {
print
" <option value= \" facPurge \" > " . __ ( 'Manual purge' ) . " </option> " ;
}
print "
< option value = \ " facClear \" > " . __ ( 'Clear feed data' ) . " </option>
< option value = \ " facRescore \" > " . __ ( 'Rescore articles' ) . " </option> " ;
print " </select> " ;
2010-01-28 16:49:17 +01:00
2010-01-28 16:52:46 +01:00
}
2010-01-28 16:49:17 +01:00
2009-12-29 16:49:27 +01:00
$feeds_sort = db_escape_string ( $_REQUEST [ " sort " ]);
2006-10-01 12:05:20 +02:00
if ( ! $feeds_sort || $feeds_sort == " undefined " ) {
$feeds_sort = $_SESSION [ " pref_sort_feeds " ];
if ( ! $feeds_sort ) $feeds_sort = " title " ;
}
$_SESSION [ " pref_sort_feeds " ] = $feeds_sort ;
if ( $feed_search ) {
2009-10-07 13:12:21 +02:00
$feed_search = split ( " " , $feed_search );
$tokens = array ();
foreach ( $feed_search as $token ) {
$token = trim ( $token );
array_push ( $tokens , " (UPPER(F1.title) LIKE UPPER('% $token %') OR
UPPER ( C1 . title ) LIKE UPPER ( '%$token%' ) OR
UPPER ( F1 . feed_url ) LIKE UPPER ( '%$token%' )) " );
}
$search_qpart = " ( " . join ( $tokens , " AND " ) . " ) AND " ;
2006-10-01 12:05:20 +02:00
} else {
$search_qpart = " " ;
}
2007-05-18 08:12:17 +02:00
$show_last_article_info = false ;
$show_last_article_checked = " " ;
$show_last_article_qpart = " " ;
2009-12-29 16:49:27 +01:00
if ( $_REQUEST [ " slat " ] == " true " ) {
2007-05-18 08:12:17 +02:00
$show_last_article_info = true ;
$show_last_article_checked = " checked " ;
2008-04-21 06:53:19 +02:00
$show_last_article_qpart = " , (SELECT " . SUBSTRING_FOR_DATE . " (MAX(updated),1,16) FROM ttrss_user_entries,
2007-05-18 08:12:17 +02:00
ttrss_entries WHERE ref_id = ttrss_entries . id
AND feed_id = F1 . id ) AS last_article " ;
2007-05-18 08:14:32 +02:00
} else if ( $feeds_sort == " last_article " ) {
$feeds_sort = " title " ;
}
if ( get_pref ( $link , 'ENABLE_FEED_CATS' )) {
$order_by_qpart = " category, $feeds_sort ,title " ;
} else {
$order_by_qpart = " $feeds_sort ,title " ;
2007-05-18 08:12:17 +02:00
}
2006-10-01 12:05:20 +02:00
$result = db_query ( $link , " SELECT
F1 . id ,
F1 . title ,
F1 . feed_url ,
2008-04-28 12:08:44 +02:00
" .SUBSTRING_FOR_DATE. " ( F1 . last_updated , 1 , 16 ) AS last_updated ,
2006-10-01 12:05:20 +02:00
F1 . parent_feed ,
F1 . update_interval ,
2007-05-14 07:51:18 +02:00
F1 . last_error ,
2006-10-01 12:05:20 +02:00
F1 . purge_interval ,
F1 . cat_id ,
F2 . title AS parent_title ,
C1 . title AS category ,
2007-05-18 08:12:17 +02:00
F1 . include_in_digest
$show_last_article_qpart
2006-10-01 12:05:20 +02:00
FROM
ttrss_feeds AS F1
LEFT JOIN ttrss_feeds AS F2
ON ( F1 . parent_feed = F2 . id )
LEFT JOIN ttrss_feed_categories AS C1
ON ( F1 . cat_id = C1 . id )
WHERE
$search_qpart F1 . owner_uid = '".$_SESSION["uid"]."'
ORDER by $order_by_qpart " );
if ( db_num_rows ( $result ) != 0 ) {
// print "<div id=\"infoBoxShadow\"><div id=\"infoBox\">PLACEHOLDER</div></div>";
print " <p><table width= \" 100% \" cellspacing= \" 0 \"
class = \ " prefFeedList \" id= \" prefFeedList \" > " ;
2007-05-18 08:12:17 +02:00
print " <tr><td class= \" selectPrompt \" colspan= \" 8 \" > " .
" <div style='float : right'> " .
" <input id='show_last_article_times' type='checkbox' onchange='feedlistToggleSLAT()'
$show_last_article_checked >< label
for = 'show_last_article_times' > " .__('Show last article times'). " </ label ></ div > " .
__ ( 'Select:' ) . "
2007-05-14 09:56:49 +02:00
< a href = \ " javascript:selectPrefRows('feed', true) \" > " . __ ( 'All' ) . " </a>,
< a href = \ " javascript:selectPrefRows('feed', false) \" > " . __ ( 'None' ) . " </a>
2006-10-01 12:05:20 +02:00
</ td </ tr > " ;
if ( ! get_pref ( $link , 'ENABLE_FEED_CATS' )) {
print " <tr class= \" title \" >
< td width = '5%' align = 'center' >& nbsp ; </ td > " ;
if ( get_pref ( $link , 'ENABLE_FEED_ICONS' )) {
print " <td width='3%'> </td> " ;
}
2007-05-19 06:41:50 +02:00
print " <td width='60%'><a href= \" javascript:updateFeedList('title') \" > " . __ ( 'Title' ) . " </a></td> " ;
if ( $show_last_article_info ) {
print " <td width='20%' align='right'><a href= \" javascript:updateFeedList('last_article') \" > " . __ ( 'Last Article' ) . " </a></td> " ;
}
print " <td width='20%' align='right'><a href= \" javascript:updateFeedList('last_updated') \" > " . __ ( 'Updated' ) . " </a></td> " ;
2006-10-01 12:05:20 +02:00
}
$lnum = 0 ;
$cur_cat_id = - 1 ;
while ( $line = db_fetch_assoc ( $result )) {
$feed_id = $line [ " id " ];
$cat_id = $line [ " cat_id " ];
2007-05-19 16:09:16 +02:00
$edit_title = htmlspecialchars ( $line [ " title " ]);
$edit_cat = htmlspecialchars ( $line [ " category " ]);
2006-10-01 12:05:20 +02:00
2007-05-14 07:51:18 +02:00
$last_error = $line [ " last_error " ];
2007-03-09 19:12:31 +01:00
if ( ! $edit_cat ) $edit_cat = __ ( " Uncategorized " );
2006-10-01 12:05:20 +02:00
$last_updated = $line [ " last_updated " ];
2007-04-26 08:30:05 +02:00
if ( ! $last_updated ) {
$last_updated = " — " ;
} else if ( get_pref ( $link , 'HEADLINES_SMART_DATE' )) {
2006-10-01 12:05:20 +02:00
$last_updated = smart_date_time ( strtotime ( $last_updated ));
} else {
$short_date = get_pref ( $link , 'SHORT_DATE_FORMAT' );
$last_updated = date ( $short_date , strtotime ( $last_updated ));
}
$last_article = $line [ " last_article " ];
2007-04-26 08:30:05 +02:00
if ( ! $last_article ) {
$last_article = " — " ;
} else if ( get_pref ( $link , 'HEADLINES_SMART_DATE' )) {
2006-10-01 12:05:20 +02:00
$last_article = smart_date_time ( strtotime ( $last_article ));
} else {
$short_date = get_pref ( $link , 'SHORT_DATE_FORMAT' );
$last_article = date ( $short_date , strtotime ( $last_article ));
}
if ( get_pref ( $link , 'ENABLE_FEED_CATS' ) && $cur_cat_id != $cat_id ) {
$lnum = 0 ;
print " <tr><td colspan= \" 6 \" class= \" feedEditCat \" > $edit_cat </td></tr> " ;
print " <tr class= \" title \" >
< td width = '5%' >& nbsp ; </ td > " ;
if ( get_pref ( $link , 'ENABLE_FEED_ICONS' )) {
print " <td width='3%'> </td> " ;
}
2007-05-18 08:12:17 +02:00
print " <td width='60%'><a href= \" javascript:updateFeedList('title') \" > " . __ ( 'Title' ) . " </a></td> " ;
if ( $show_last_article_info ) {
print " <td width='20%' align='right'>
< a href = \ " javascript:updateFeedList('last_article') \" > " . __ ( 'Last Article' ) . " </a></td> " ;
}
print " <td width='20%' align='right'>
< a href = \ " javascript:updateFeedList('last_updated') \" > " . __ ( 'Updated' ) . " </a></td> " ;
2006-10-01 12:05:20 +02:00
$cur_cat_id = $cat_id ;
}
$class = ( $lnum % 2 ) ? " even " : " odd " ;
$this_row_id = " id= \" FEEDR- $feed_id\ " " ;
print " <tr class= \" $class\ " $this_row_id > " ;
$icon_file = ICONS_DIR . " / $feed_id .ico " ;
if ( file_exists ( $icon_file ) && filesize ( $icon_file ) > 0 ) {
$feed_icon = " <img class= \" tinyFeedIcon \" src= \" " . ICONS_URL . " / $feed_id .ico \" > " ;
} else {
$feed_icon = " <img class= \" tinyFeedIcon \" src= \" images/blank_icon.gif \" > " ;
}
print " <td class='feedSelect'><input onclick='toggleSelectPrefRow(this, \" feed \" );'
type = \ " checkbox \" id= \" FRCHK- " . $line [ " id " ] . " \" ></td> " ;
2008-05-17 17:36:35 +02:00
$onclick = " onclick='editFeed( $feed_id )' title=' " . __ ( 'Click to edit' ) . " ' " ;
2006-10-01 12:05:20 +02:00
if ( get_pref ( $link , 'ENABLE_FEED_ICONS' )) {
2008-05-17 17:36:35 +02:00
print " <td $onclick class='feedIcon'> $feed_icon </td> " ;
2006-10-01 12:05:20 +02:00
}
2007-05-14 07:51:18 +02:00
if ( $last_error ) {
2007-08-20 17:41:02 +02:00
$edit_title = " <span class= \" feed_error \" > $edit_title </span> " ;
2007-05-14 07:51:18 +02:00
$last_updated = " <span class= \" feed_error \" > $last_updated </span> " ;
$last_article = " <span class= \" feed_error \" > $last_article </span> " ;
2006-10-01 12:05:20 +02:00
}
$parent_title = $line [ " parent_title " ];
if ( $parent_title ) {
2009-01-25 18:19:09 +01:00
$linked_to = sprintf ( __ ( " (linked to %s) " ), $parent_title );
$parent_title = " <span class='groupPrompt'> $linked_to </span> " ;
2006-10-01 12:05:20 +02:00
}
2008-05-17 17:36:35 +02:00
print " <td $onclick > " . " $edit_title $parent_title " . " </td> " ;
2006-10-01 12:05:20 +02:00
2007-05-18 08:12:17 +02:00
if ( $show_last_article_info ) {
2008-05-17 17:36:35 +02:00
print " <td align='right' $onclick > " .
" $last_article </td> " ;
2007-05-18 08:12:17 +02:00
}
2006-10-01 12:05:20 +02:00
2008-07-25 09:48:15 +02:00
print " <td $onclick align='right'> $last_updated </td> " ;
2006-10-01 12:05:20 +02:00
print " </tr> " ;
++ $lnum ;
}
print " </table> " ;
2007-10-18 07:06:20 +02:00
print " <p> " ;
2007-10-18 06:51:29 +02:00
2009-10-06 11:37:24 +02:00
} else {
print " <p> " ;
if ( ! $feed_search ) {
print_warning ( __ ( " You don't have any subscribed feeds. " ));
} else {
print_warning ( __ ( 'No matching feeds found.' ));
}
print " </p> " ;
2006-10-01 12:05:20 +02:00
}
2010-01-13 21:59:02 +01:00
print " <h3> " . __ ( 'OPML' ) . " </h3> " ;
2006-10-04 08:16:13 +02:00
2010-01-13 21:59:02 +01:00
/* print " <div style='float : left'>
2006-10-01 12:05:20 +02:00
< form enctype = \ " multipart/form-data \" method= \" POST \" action= \" opml.php \" >
2007-08-21 13:28:13 +02:00
" .__('File:'). " < input id = \ " opml_file \" name= \" opml_file \" type= \" file \" >
< input type = \ " hidden \" name= \" op \" value= \" Import \" >
2010-01-12 13:56:29 +01:00
< button onclick = \ " return validateOpmlImport(); \"
type = \ " submit \" > " . __ ( 'Import' ) . " </button>
2006-10-04 08:16:13 +02:00
</ form ></ div > " ;
2010-01-13 21:59:02 +01:00
print " " ; */
2010-06-29 12:35:13 +02:00
print " <p> " . __ ( " Using OPML you can export and import your feeds and Tiny Tiny RSS settings. " );
2010-06-30 11:45:53 +02:00
print " <div class= \" insensitive \" > " . __ ( " Note: Only main settings profile can be migrated using OPML. " ) . " </div> " ;
2010-06-30 11:13:57 +02:00
2010-06-29 12:35:13 +02:00
print " </p> " ;
2010-01-14 09:28:57 +01:00
print " <iframe name= \" upload_iframe \"
2010-01-13 21:59:02 +01:00
style = \ " width: 400px; height: 100px; display: none; \" ></iframe> " ;
print " <div style='float : left'> " ;
print " <form style='display : block' target= \" upload_iframe \"
enctype = \ " multipart/form-data \" method= \" POST \"
action = \ " backend.php \" >
< input id = \ " opml_file \" name= \" opml_file \" type= \" file \" >
< input type = \ " hidden \" name= \" op \" value= \" dlg \" >
< input type = \ " hidden \" name= \" id \" value= \" importOpml \" >
< button onclick = \ " return opmlImport(); \"
type = \ " submit \" > " . __ ( 'Import' ) . " </button>
</ form > " ;
print " </div> " ;
2006-10-04 08:16:13 +02:00
2010-01-12 13:56:29 +01:00
print " <button onclick= \" gotoExportOpml() \" > " .
__ ( 'Export OPML' ) . " </button> " ;
2006-10-04 08:16:13 +02:00
2010-06-30 11:13:57 +02:00
if ( ! get_pref ( $link , " _PREFS_OPML_PUBLISH_KEY " )){
set_pref ( $link , " _PREFS_OPML_PUBLISH_KEY " , generate_publish_key ());
}
print " <p> " . __ ( 'Your OPML can be published publicly and can be subscribed by anyone who knows the URL below.' );
print " <div class= \" insensitive \" > " . __ ( " Note: Published OPML does not include your Tiny Tiny RSS settings, feeds that require authentication or feeds hidden from Popular feeds. " ) . " </div> " . " </p> " ;
2007-08-09 14:45:30 +02:00
2010-06-30 11:13:57 +02:00
print " <button onclick= \" return displayDlg('pubOPMLUrl') \" > " .
__ ( 'Display URL' ) . " </button> " ;
if ( strpos ( $_SERVER [ 'HTTP_USER_AGENT' ], " Firefox " ) !== false ) {
print " <h3> " . __ ( " Firefox Integration " ) . " </h3> " ;
2007-08-31 02:55:33 +02:00
2010-06-30 11:13:57 +02:00
print " <p> " . __ ( 'This Tiny Tiny RSS site can be used as a Firefox Feed Reader by clicking the link below.' ) . " </p> " ;
2010-01-12 17:46:07 +01:00
2010-06-30 11:13:57 +02:00
print " <p " ;
2010-01-12 17:46:07 +01:00
2010-06-30 11:13:57 +02:00
print " <button onclick='window.navigator.registerContentHandler( " .
2007-08-31 02:55:33 +02:00
" \" application/vnd.mozilla.maybe.feed \" , " .
" \" " . add_feed_url () . " \" , " . " \" Tiny Tiny RSS \" )'> " .
2010-01-12 17:46:07 +01:00
__ ( 'Click here to register this site as a feed reader.' ) .
" </button> " ;
2007-08-31 02:55:33 +02:00
2010-06-30 11:13:57 +02:00
print " </p> " ;
}
2007-08-31 02:55:33 +02:00
2007-08-21 03:22:29 +02:00
print " <h3> " . __ ( " Published articles " ) . " </h3> " ;
2007-08-09 14:45:30 +02:00
if ( ! get_pref ( $link , " _PREFS_PUBLISH_KEY " )) {
set_pref ( $link , " _PREFS_PUBLISH_KEY " , generate_publish_key ());
}
2008-03-20 06:34:43 +01:00
print " <p> " . __ ( 'Published articles are exported as a public RSS feed and can be subscribed by anyone who knows the URL specified below.' ) . " </p> " ;
2007-08-09 14:45:30 +02:00
2010-01-12 17:46:07 +01:00
print " <button onclick= \" return displayDlg('pubUrl') \" > " .
__ ( 'Display URL' ) . " </button> " ;
2010-06-30 11:13:57 +02:00
2007-08-09 14:45:30 +02:00
2006-10-01 12:05:20 +02:00
}
2009-01-23 19:54:57 +01:00
2010-01-11 13:40:35 +01:00
function print_feed_browser ( $link , $search , $limit , $mode = 1 ) {
2009-01-23 19:54:57 +01:00
2009-01-24 06:01:17 +01:00
$owner_uid = $_SESSION [ " uid " ];
if ( $search ) {
$search_qpart = " AND (UPPER(feed_url) LIKE UPPER('% $search %') OR
UPPER ( title ) LIKE UPPER ( '%$search%' )) " ;
} else {
$search_qpart = " " ;
}
2010-01-11 13:40:35 +01:00
if ( $mode == 1 ) {
$result = db_query ( $link , " SELECT feed_url, subscribers FROM
ttrss_feedbrowser_cache WHERE ( SELECT COUNT ( id ) = 0 FROM ttrss_feeds AS tf
WHERE tf . feed_url = ttrss_feedbrowser_cache . feed_url
AND owner_uid = '$owner_uid' ) $search_qpart
ORDER BY subscribers DESC LIMIT $limit " );
} else if ( $mode == 2 ) {
2010-01-13 11:44:20 +01:00
$result = db_query ( $link , " SELECT *,
( SELECT COUNT ( * ) FROM ttrss_user_entries WHERE
orig_feed_id = ttrss_archived_feeds . id ) AS articles_archived
FROM
ttrss_archived_feeds
WHERE
2010-01-11 13:40:35 +01:00
( SELECT COUNT ( * ) FROM ttrss_feeds
WHERE ttrss_feeds . feed_url = ttrss_archived_feeds . feed_url AND
owner_uid = '$owner_uid' ) = 0 AND
owner_uid = '$owner_uid' $search_qpart
ORDER BY id DESC LIMIT $limit " );
}
2009-01-23 19:54:57 +01:00
$feedctr = 0 ;
while ( $line = db_fetch_assoc ( $result )) {
2010-01-11 13:40:35 +01:00
if ( $mode == 1 ) {
2009-01-23 19:54:57 +01:00
2010-07-01 09:47:39 +02:00
$feed_url = $line [ " feed_url " ];
2010-01-11 13:40:35 +01:00
$subscribers = $line [ " subscribers " ];
2010-07-01 09:47:39 +02:00
2010-01-11 13:40:35 +01:00
$det_result = db_query ( $link , " SELECT site_url,title,id
FROM ttrss_feeds WHERE feed_url = '$feed_url' LIMIT 1 " );
$details = db_fetch_assoc ( $det_result );
$icon_file = ICONS_DIR . " / " . $details [ " id " ] . " .ico " ;
if ( file_exists ( $icon_file ) && filesize ( $icon_file ) > 0 ) {
$feed_icon = " <img class= \" tinyFeedIcon \" src= \" " . ICONS_URL .
" / " . $details [ " id " ] . " .ico \" > " ;
} else {
$feed_icon = " <img class= \" tinyFeedIcon \" src= \" images/blank_icon.gif \" > " ;
}
2010-01-13 11:44:20 +01:00
$check_box = " <input onclick='toggleSelectListRow(this)'
class = 'feedBrowseCB'
2010-01-11 13:40:35 +01:00
type = \ " checkbox \" id= \" FBCHK- " . $details [ " id " ] . " \" > " ;
$class = ( $feedctr % 2 ) ? " even " : " odd " ;
2010-07-01 09:47:39 +02:00
$feed_url = htmlspecialchars ( $line [ " feed_url " ]);
2010-01-11 13:40:35 +01:00
if ( $details [ " site_url " ]) {
2010-01-13 11:44:20 +01:00
$site_url = " <a target= \" _blank \" href= \" " .
htmlspecialchars ( $details [ " site_url " ]) . " \" >
2010-01-11 13:40:35 +01:00
< img style = 'border-width : 0px' src = 'images/www.png' alt = 'www' ></ a > " ;
} else {
$site_url = " " ;
}
2010-01-18 13:10:37 +01:00
$feed_url = " <a target= \" _blank \" href= \" $feed_url\ " >< img
style = 'border-width : 0px; vertical-align : middle'
src = 'images/feed-icon-12x12.png' ></ a > " ;
2010-01-13 11:44:20 +01:00
print " <li title= \" " . htmlspecialchars ( $details [ " site_url " ]) . " \"
class = '$class' id = \ " FBROW- " . $details [ " id " ] . " \" > $check_box " .
2010-01-18 13:10:37 +01:00
" $feed_icon $feed_url " . htmlspecialchars ( $details [ " title " ]) .
2010-01-11 13:40:35 +01:00
" <span class='subscribers'>( $subscribers )</span>
2010-01-13 11:44:20 +01:00
$site_url </ li > " ;
2010-01-11 13:40:35 +01:00
} else if ( $mode == 2 ) {
2010-01-13 11:44:20 +01:00
$feed_url = htmlspecialchars ( $line [ " feed_url " ]);
$site_url = htmlspecialchars ( $line [ " site_url " ]);
$title = htmlspecialchars ( $line [ " title " ]);
2010-01-11 14:42:11 +01:00
$icon_file = ICONS_DIR . " / " . $line [ " id " ] . " .ico " ;
2010-01-11 13:40:35 +01:00
2010-01-11 14:42:11 +01:00
if ( file_exists ( $icon_file ) && filesize ( $icon_file ) > 0 ) {
$feed_icon = " <img class= \" tinyFeedIcon \" src= \" " . ICONS_URL .
" / " . $line [ " id " ] . " .ico \" > " ;
} else {
$feed_icon = " <img class= \" tinyFeedIcon \" src= \" images/blank_icon.gif \" > " ;
}
2010-01-11 13:40:35 +01:00
$check_box = " <input onclick='toggleSelectListRow(this)' class='feedBrowseCB'
type = \ " checkbox \" id= \" FBCHK- " . $line [ " id " ] . " \" > " ;
$class = ( $feedctr % 2 ) ? " even " : " odd " ;
2010-01-13 11:44:20 +01:00
if ( $line [ 'articles_archived' ] > 0 ) {
$archived = sprintf ( __ ( " %d archived articles " ), $line [ 'articles_archived' ]);
$archived = " <span class='subscribers'>( $archived )</span> " ;
} else {
$archived = '' ;
}
2010-01-11 13:40:35 +01:00
if ( $line [ " site_url " ]) {
2010-01-13 11:44:20 +01:00
$site_url = " <a target= \" _blank \" href= \" $site_url\ " >
2010-01-11 13:40:35 +01:00
< img style = 'border-width : 0px' src = 'images/www.png' alt = 'www' ></ a > " ;
} else {
$site_url = " " ;
}
2010-01-18 13:10:37 +01:00
$feed_url = " <a target= \" _blank \" href= \" $feed_url\ " >< img
style = 'border-width : 0px; vertical-align : middle'
src = 'images/feed-icon-12x12.png' ></ a > " ;
2010-01-13 11:44:20 +01:00
print " <li title=' " . $line [ 'site_url' ] . " ' class=' $class '
id = \ " FBROW- " . $line [ " id " ] . " \" > " .
2010-01-18 13:10:37 +01:00
$check_box . " $feed_icon $feed_url " . $title .
$archived . $site_url . " </li> " ;
2009-01-23 19:54:57 +01:00
2009-01-24 06:14:06 +01:00
}
2010-01-11 13:40:35 +01:00
++ $feedctr ;
2009-01-23 19:54:57 +01:00
}
if ( $feedctr == 0 ) {
print " <li style= \" text-align : center \" ><p> " . __ ( 'No feeds found.' ) . " </p></li> " ;
}
return $feedctr ;
}
2010-01-13 10:48:49 +01:00
2006-10-01 12:05:20 +02:00
?>