mirror of
				https://git.tt-rss.org/fox/tt-rss.git
				synced 2025-10-25 09:51:00 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			178 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			178 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 	function module_pref_feed_browser($link) {
 | |
| 
 | |
| 		if (!ENABLE_FEED_BROWSER) {
 | |
| 			print __("Feed browser is administratively disabled.");
 | |
| 			return;
 | |
| 		}
 | |
| 
 | |
| 		$subop = $_REQUEST["subop"];
 | |
| 
 | |
| 		if ($subop == "details") {
 | |
| 			$id = db_escape_string($_GET["id"]);
 | |
| 
 | |
| 			print "<div class=\"browserFeedInfo\">";
 | |
| 			print "<b>".__('Feed information:')."</b>";
 | |
| 
 | |
| 			$result = db_query($link, "SELECT 
 | |
| 					feed_url,site_url,
 | |
| 					".SUBSTRING_FOR_DATE."(last_updated,1,19) AS last_updated 
 | |
| 				FROM ttrss_feeds WHERE id = '$id' AND
 | |
| 					auth_login = '' AND auth_pass = '' AND private IS NOT true
 | |
| 					AND feed_url NOT LIKE '%:%@%/%'");
 | |
| 
 | |
| 			if (db_num_rows($result) == 1) {
 | |
| 
 | |
| 				print "<div class=\"detailsPart\">";
 | |
| 
 | |
| 				$feed_url = db_fetch_result($result, 0, "feed_url");
 | |
| 				$site_url = db_fetch_result($result, 0, "site_url");
 | |
| 				$last_updated = db_fetch_result($result, 0, "last_updated");
 | |
| 	
 | |
| 				if (get_pref($link, 'HEADLINES_SMART_DATE')) {
 | |
| 					$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));
 | |
| 				}
 | |
| 	
 | |
| 				print __("Site:")." <a target=\"_blank\" href='$site_url'>$site_url</a> ".
 | |
| 					"(<a target=\"_blank\" href='$feed_url'>feed</a>), ".
 | |
| 					__("Last updated:")." $last_updated";
 | |
| 	
 | |
| 				print "</div>";
 | |
| 	
 | |
| 				$result = db_query($link, "SELECT 
 | |
| 						ttrss_entries.title,
 | |
| 						content,link,
 | |
| 						".SUBSTRING_FOR_DATE."(date_entered,1,19) as date_entered,
 | |
| 						".SUBSTRING_FOR_DATE."(updated,1,19) as updated
 | |
| 					FROM ttrss_entries,ttrss_user_entries
 | |
| 					WHERE	ttrss_entries.id = ref_id AND feed_id = '$id'
 | |
| 					ORDER BY updated DESC LIMIT 5");
 | |
| 	
 | |
| 				if (db_num_rows($result) > 0) {
 | |
| 					
 | |
| 					print "<b>".__('Last headlines:')."</b><br>";
 | |
| 					
 | |
| 					print "<div class=\"detailsPart\">";
 | |
| 					print "<ul class=\"compact\">";
 | |
| 					while ($line = db_fetch_assoc($result)) {
 | |
| 	
 | |
| 						if (get_pref($link, 'HEADLINES_SMART_DATE')) {
 | |
| 							$entry_dt = smart_date_time(strtotime($line["updated"]));
 | |
| 						} else {
 | |
| 							$short_date = get_pref($link, 'SHORT_DATE_FORMAT');
 | |
| 							$entry_dt = date($short_date, strtotime($line["updated"]));
 | |
| 						}				
 | |
| 			
 | |
| 						print "<li><a target=\"_blank\" href=\"" . $line["link"] . "\">" . $line["title"] . "</a>" .
 | |
| 							" <span class=\"insensitive\">($entry_dt)</span></li>";	
 | |
| 					}		
 | |
| 					print "</ul></div>";
 | |
| 				}
 | |
| 			} else {
 | |
| 				print "<p>".__("Feed not found.")."</p>";
 | |
| 			}
 | |
| 
 | |
| 			print "</div>";
 | |
| 				
 | |
| 			return;
 | |
| 		}
 | |
| 
 | |
| 		set_pref($link, "_PREFS_ACTIVE_TAB", "feedBrowser");
 | |
| 
 | |
| 		print "<div class=\"insensitive\">".__('This panel shows feeds subscribed by other users of this system, just in case you are interested in them too.')."</div>";
 | |
| 
 | |
| 		$limit = db_escape_string($_GET["limit"]);
 | |
| 
 | |
| 		if (!$limit) $limit = 25;
 | |
| 
 | |
| 		$owner_uid = $_SESSION["uid"];
 | |
| 			
 | |
| 		$result = db_query($link, "SELECT feed_url,COUNT(id) AS subscribers
 | |
| 	  		FROM ttrss_feeds WHERE (SELECT COUNT(id) = 0 FROM ttrss_feeds AS tf 
 | |
| 				WHERE tf.feed_url = ttrss_feeds.feed_url 
 | |
| 				AND (private IS true OR feed_url LIKE '%:%@%/%' OR 
 | |
| 					owner_uid = '$owner_uid')) GROUP BY feed_url 
 | |
| 						ORDER BY subscribers DESC LIMIT $limit");
 | |
| 
 | |
| 		print "<br/>";
 | |
| 			
 | |
| 		print "<div style=\"float : right\">
 | |
| 			".__('Top')." <select id=\"feedBrowserLimit\">";
 | |
| 
 | |
| 		foreach (array(25, 50, 100) as $l) {
 | |
| 			$issel = ($l == $limit) ? "selected" : "";
 | |
| 			print "<option $issel>$l</option>";
 | |
| 		}
 | |
| 			
 | |
| 		print "</select>
 | |
| 			<input type=\"submit\" class=\"button\"
 | |
| 				onclick=\"updateBigFeedBrowser()\" value=\"".__('Show')."\">
 | |
| 		</div>";
 | |
| 
 | |
| 		if (db_num_rows($result) > 0) {
 | |
| 
 | |
| 			print "<div id=\"fbrOpToolbar\">
 | |
| 				<input type='submit' class='button' onclick=\"feedBrowserSubscribe()\" 
 | |
| 				disabled=\"true\" value=\"".__('Subscribe')."\"></div>";
 | |
| 	
 | |
| 			print "<ul class='nomarks' id='browseBigFeedList'>";
 | |
| 	
 | |
| 			$feedctr = 0;
 | |
| 	
 | |
| 			while ($line = db_fetch_assoc($result)) {
 | |
| 				$feed_url = $line["feed_url"];
 | |
| 				$subscribers = $line["subscribers"];
 | |
| 	
 | |
| 				// mysql returns NULL records first by default
 | |
| 				if (DB_TYPE == "mysql") $order_fix = "DESC";
 | |
| 	
 | |
| 				$det_result = db_query($link, "SELECT site_url,title,id 
 | |
| 					FROM ttrss_feeds WHERE feed_url = '$feed_url' 
 | |
| 					ORDER BY last_updated $order_fix 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\">";
 | |
| 				}
 | |
| 	
 | |
| 				$check_box = "<input onclick='toggleSelectFBListRow(this)' class='feedBrowseCB' 
 | |
| 					type=\"checkbox\" id=\"FBCHK-" . $details["id"] . "\">";
 | |
| 	
 | |
| 				$class = ($feedctr % 2) ? "even" : "odd";
 | |
| 	
 | |
| 				print "<li class='$class' id=\"FBROW-".$details["id"]."\">$check_box".
 | |
| 					"$feed_icon ";
 | |
| 					
 | |
| 				print "<a href=\"javascript:browserToggleExpand('".$details["id"]."')\">" . 
 | |
| 					$details["title"] ."</a> " .
 | |
| 					"<span class='subscribers'>($subscribers)</span>";
 | |
| 				
 | |
| 				print "<div class=\"browserDetails\" style=\"display : none\" id=\"BRDET-" . $details["id"] . "\">";
 | |
| 				print "</div>";
 | |
| 					
 | |
| 				print "</li>";
 | |
| 	
 | |
| 				++$feedctr;
 | |
| 			}
 | |
| 	
 | |
| 			print "</ul>";
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		if ($feedctr == 0) {
 | |
| 			print "<div>".__('No feeds found.')."</div>";
 | |
| 		}
 | |
| 
 | |
| 		print "</div>";
 | |
| 	}
 | |
| ?>
 |