From 601ce45c4de09da079e60be40e144c5b61d4d288 Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Mon, 26 Sep 2016 14:35:52 +0200 Subject: [PATCH] allow to specify multiple cat_id's --- api/src/Categories.php | 2 +- api/src/Contacts/Sql.php | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/api/src/Categories.php b/api/src/Categories.php index cc2257b8bc..da6c22fb99 100644 --- a/api/src/Categories.php +++ b/api/src/Categories.php @@ -156,7 +156,7 @@ class Categories */ function return_all_children($cat_id) { - $all_children = (array) $cat_id; + $all_children = array_map('intval', (array)$cat_id); $children = $this->return_array('subs',0,False,'','','',True,$cat_id,-1,'id'); if (is_array($children) && count($children)) diff --git a/api/src/Contacts/Sql.php b/api/src/Contacts/Sql.php index e64397bb8f..019ba50329 100644 --- a/api/src/Contacts/Sql.php +++ b/api/src/Contacts/Sql.php @@ -118,7 +118,7 @@ class Sql extends Api\Storage if ($advanced_search || (isset($param['wildcard']) && !empty($param['wildcard']))) $wildcard = ($param['wildcard']?$param['wildcard']:''); // fix cat_id filter to search in comma-separated multiple cats and return subcats - if ((int)$filter['cat_id']) + if ($filter['cat_id']) { $filter[] = $this->_cat_filter($filter['cat_id']); unset($filter['cat_id']); @@ -285,7 +285,7 @@ class Sql extends Api\Storage $filter['cat_id'] = substr($filter['cat_id'],1); $not = 'NOT'; } - $filter[] = $this->_cat_filter((int)$filter['cat_id'],$not); + $filter[] = $this->_cat_filter($filter['cat_id'],$not); unset($filter['cat_id']); } @@ -430,7 +430,7 @@ class Sql extends Api\Storage * fix cat_id filter to search in comma-separated multiple cats and return subcats * * @internal - * @param int $cat_id + * @param int|array $cat_id * @return string sql to filter by given cat */ function _cat_filter($cat_id, $not='') @@ -439,7 +439,7 @@ class Sql extends Api\Storage { $GLOBALS['egw']->categories = new Api\Categories; } - foreach($GLOBALS['egw']->categories->return_all_children((int)$cat_id) as $cat) + foreach($GLOBALS['egw']->categories->return_all_children($cat_id) as $cat) { $cat_filter[] = $this->db->concat("','",cat_id,"','")." $not LIKE '%,$cat,%'"; }