From 4c9d0490c6a8c724d04c246cd5ba3cf75ec80259 Mon Sep 17 00:00:00 2001 From: Andrew Dolgov Date: Sun, 26 Aug 2012 12:36:08 +0400 Subject: rework filter dialog to make feed/category selection easier --- include/functions.php | 100 +++++++++++++++++++++++++++++++++++++++++--------- 1 file changed, 82 insertions(+), 18 deletions(-) (limited to 'include') diff --git a/include/functions.php b/include/functions.php index 151cf13a5..262b544bb 100644 --- a/include/functions.php +++ b/include/functions.php @@ -1887,34 +1887,98 @@ } function print_feed_select($link, $id, $default_id = "", - $attributes = "", $include_all_feeds = true) { + $attributes = "", $include_all_feeds = true, + $root_id = false, $nest_level = 0) { - print ""; + if ($include_all_feeds) { + $is_selected = ("0" == $default_id) ? "selected=\"1\"" : ""; + print ""; + } } - $result = db_query($link, "SELECT id,title FROM ttrss_feeds - WHERE owner_uid = ".$_SESSION["uid"]." ORDER BY title"); + if (get_pref($link, 'ENABLE_FEED_CATS')) { - if (db_num_rows($result) > 0 && $include_all_feeds) { - print ""; - } + if ($root_id) + $parent_qpart = "parent_cat = '$root_id'"; + else + $parent_qpart = "parent_cat IS NULL"; - while ($line = db_fetch_assoc($result)) { - if ($line["id"] == $default_id) { - $is_selected = "selected=\"1\""; - } else { - $is_selected = ""; + $result = db_query($link, "SELECT id,title, + (SELECT COUNT(id) FROM ttrss_feed_categories AS c2 WHERE + c2.parent_cat = ttrss_feed_categories.id) AS num_children + FROM ttrss_feed_categories + WHERE owner_uid = ".$_SESSION["uid"]." AND $parent_qpart ORDER BY title"); + + while ($line = db_fetch_assoc($result)) { + + for ($i = 0; $i < $nest_level; $i++) + $line["title"] = " - " . $line["title"]; + + $is_selected = ("CAT:".$line["id"] == $default_id) ? "selected=\"1\"" : ""; + + printf("", + $line["id"], htmlspecialchars($line["title"])); + + if ($line["num_children"] > 0) + print_feed_select($link, $id, $default_id, $attributes, + $include_all_feeds, $line["id"], $nest_level+1); + + $feed_result = db_query($link, "SELECT id,title FROM ttrss_feeds + WHERE cat_id = '".$line["id"]."' AND owner_uid = ".$_SESSION["uid"] . " ORDER BY title"); + + while ($fline = db_fetch_assoc($feed_result)) { + $is_selected = ($fline["id"] == $default_id) ? "selected=\"1\"" : ""; + + $fline["title"] = " + " . $fline["title"]; + + for ($i = 0; $i < $nest_level; $i++) + $fline["title"] = " - " . $fline["title"]; + + printf("", + $fline["id"], htmlspecialchars($fline["title"])); + } } - $title = truncate_string(htmlspecialchars($line["title"]), 40); + if (!$root_id) { + $is_selected = ($default_id == "CAT:0") ? "selected=\"1\"" : ""; + + printf("", + __("Uncategorized")); + + $feed_result = db_query($link, "SELECT id,title FROM ttrss_feeds + WHERE cat_id IS NULL AND owner_uid = ".$_SESSION["uid"] . " ORDER BY title"); + + while ($fline = db_fetch_assoc($feed_result)) { + $is_selected = ($fline["id"] == $default_id && !$default_is_cat) ? "selected=\"1\"" : ""; - printf("", - $line["id"], $title); + $fline["title"] = " + " . $fline["title"]; + + for ($i = 0; $i < $nest_level; $i++) + $fline["title"] = " - " . $fline["title"]; + + printf("", + $fline["id"], htmlspecialchars($fline["title"])); + } + } + + } else { + $result = db_query($link, "SELECT id,title FROM ttrss_feeds + WHERE owner_uid = ".$_SESSION["uid"]." ORDER BY title"); + + while ($line = db_fetch_assoc($result)) { + + $is_selected = ($line["id"] == $default_id) ? "selected=\"1\"" : ""; + + printf("", + $line["id"], htmlspecialchars($line["title"])); + } } - print ""; + if (!$root_id) { + print ""; + } } function print_feed_cat_select($link, $id, $default_id, -- cgit v1.2.3-54-g00ecf