From 69c6e94d35e5e94e5ce26f0f2b78c1708333f6d4 Mon Sep 17 00:00:00 2001 From: Andrew Dolgov Date: Fri, 31 Aug 2012 15:14:12 +0400 Subject: [PATCH] implement basic filter search --- classes/pref/filters.php | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/classes/pref/filters.php b/classes/pref/filters.php index 1645639ed..11487c877 100644 --- a/classes/pref/filters.php +++ b/classes/pref/filters.php @@ -106,6 +106,8 @@ class Pref_Filters extends Handler_Protected { $root['name'] = __('Filters'); $root['items'] = array(); + $filter_search = $_SESSION["prefs_filter_search"]; + $result = db_query($this->link, "SELECT *, (SELECT action_id FROM ttrss_filters2_actions WHERE filter_id = ttrss_filters2.id ORDER BY id LIMIT 1) AS action_id, @@ -117,6 +119,7 @@ class Pref_Filters extends Handler_Protected { FROM ttrss_filters2 WHERE owner_uid = ".$_SESSION["uid"]." ORDER BY action_id,reg_exp"); + $action_id = -1; $folder = array(); $folder['items'] = array(); @@ -137,6 +140,19 @@ class Pref_Filters extends Handler_Protected { $name = $this->getFilterName($line["id"]); + $match_ok = false; + if ($filter_search) { + $rules_result = db_query($this->link, + "SELECT reg_exp FROM ttrss_filters2_rules WHERE filter_id = ".$line["id"]); + + while ($rule_line = db_fetch_assoc($rules_result)) { + if (mb_strpos($rule_line['reg_exp'], $filter_search) !== false) { + $match_ok = true; + break; + } + } + } + $filter = array(); $filter['id'] = 'FILTER:' . $line['id']; $filter['bare_id'] = $line['id']; @@ -145,7 +161,9 @@ class Pref_Filters extends Handler_Protected { $filter['checkbox'] = false; $filter['enabled'] = sql_bool_to_bool($line["enabled"]); - array_push($folder['items'], $filter); + if (!$filter_search || $match_ok) { + array_push($folder['items'], $filter); + } } if (count($folder['items']) > 0) {