Improvements to CRM view hook filtering

- Don't use linked filter, leave that for the user.  Use action, action_id instead, which can't be cleared.
- Don't store query in the session, it will conflict with app tab.  etemplate2 preserves it in the request.
This commit is contained in:
Nathan Gray 2014-03-26 19:36:54 +00:00
parent 24fd900626
commit beab0aca19

View File

@ -273,7 +273,10 @@ class infolog_ui
unset($query['no_actions']); unset($query['no_actions']);
$parent_id = $query['col_filter']['parent_id']; $parent_id = $query['col_filter']['parent_id'];
unset($query['col_filter']['parent_id']); unset($query['col_filter']['parent_id']);
if(!$query['action'])
{
egw_cache::setSession('infolog', $query['session_for'].'session_data', $query); egw_cache::setSession('infolog', $query['session_for'].'session_data', $query);
}
$query['actions'] = $this->get_actions($query); $query['actions'] = $this->get_actions($query);
$query['row_id'] = 'info_id'; $query['row_id'] = 'info_id';
$query['row_modified'] = 'info_datemodified'; $query['row_modified'] = 'info_datemodified';
@ -287,36 +290,55 @@ class infolog_ui
//echo "<p>infolog_ui.get_rows(start=$query[start],search='$query[search]',filter='$query[filter]',cat_id=$query[cat_id],action='$query[action]/$query[action_id]',col_filter=".print_r($query['col_filter'],True).",sort=$query[sort],order=$query[order])</p>\n"; //echo "<p>infolog_ui.get_rows(start=$query[start],search='$query[search]',filter='$query[filter]',cat_id=$query[cat_id],action='$query[action]/$query[action_id]',col_filter=".print_r($query['col_filter'],True).",sort=$query[sort],order=$query[order])</p>\n";
if (!isset($query['start'])) $query['start'] = 0; if (!isset($query['start'])) $query['start'] = 0;
// handle linked filter (show only entries linked to a certain other entry) // handle action and linked filter (show only entries linked to a certain other entry)
$link_filters = array();
$links = array();
if ($query['col_filter']['linked']) if ($query['col_filter']['linked'])
{ {
if(!is_array($query['col_filter']['linked'])) $link_filters['linked'] = $query['col_filter']['linked'];
$links['linked'] = array();
unset($query['col_filter']['linked']);
}
if($query['action'] && in_array($query['action'], array_keys($GLOBALS['egw_info']['apps'])) && $query['action_id'])
{
$link_filters['action'] = array('app'=>$query['action'], 'id' => $query['action_id']);
$links['action'] = array();
}
foreach($link_filters as $key => $link)
{
if(!is_array($link))
{ {
// Legacy string style // Legacy string style
list($app,$id) = explode(':',$query['col_filter']['linked']); list($app,$id) = explode(':',$link);
} }
else else
{ {
// Full info // Full info
$app = $query['col_filter']['linked']['app']; $app = $link['app'];
$id = $query['col_filter']['linked']['id']; $id = $link['id'];
} }
if(!is_array($id)) $id = explode(',',$id); if(!is_array($id)) $id = explode(',',$id);
if (!($links = egw_link::get_links_multiple($app,$id,true,'infolog'))) if (!($linked = egw_link::get_links_multiple($app,$id,true,'infolog')))
{ {
$rows = array(); // no infologs linked to project --> no rows to return $rows = array(); // no infologs linked to selected link --> no rows to return
return 0; return 0;
} }
$query['col_filter']['info_id'] = array();
foreach($links as $infos) foreach($linked as $infos)
{ {
$query['col_filter']['info_id'] = array_merge($query['col_filter']['info_id'],$infos); $links[$key] = array_merge($links[$key],$infos);
} }
$query['col_filter']['info_id'] = array_unique($query['col_filter']['info_id']); $links[$key] = array_unique($links[$key]);
if($key == 'linked')
{
$linked = array('app' => $app, 'id' => $id, 'title' => (count($id) == 1 ? egw_link::title($app, $id) : lang('multiple'))); $linked = array('app' => $app, 'id' => $id, 'title' => (count($id) == 1 ? egw_link::title($app, $id) : lang('multiple')));
} }
unset($query['col_filter']['linked']); }
if(count($links))
{
$query['col_filter']['info_id'] = count($links) > 1 ? call_user_func_array('array_intersect', $links) : $links[$key];
}
// check if we have a custom, type-specific template // check if we have a custom, type-specific template
unset($query['template']); unset($query['template']);
@ -394,7 +416,7 @@ class infolog_ui
$parent_first = count($parents) == 1; $parent_first = count($parents) == 1;
$parent_index = 0; $parent_index = 0;
// et2 nextmatch listens to total, and only displays that many rows, so add parent in or we'll lose the last row // et2 nextmatch listens to total, and only displays that many rows, so add parent in or we'll lose the last row
if($parent_first || $query['action'] = 'sp' && is_array($query['action_id'])) $query['total']++; if($parent_first || $query['action'] == 'sp' && is_array($query['action_id'])) $query['total']++;
// Check to see if we need to remove description // Check to see if we need to remove description
foreach($infos as $id => $info) foreach($infos as $id => $info)
@ -812,14 +834,7 @@ class infolog_ui
} }
break; break;
default: default:
if(in_array($action, array_keys(egw_link::app_list()))) // Nothing
{
if(is_array($action_id))
{
$action_id = implode(',',$action_id);
}
$values['nm']['col_filter']['linked'] = "$action:$action_id";
}
} }
$readonlys['cancel'] = $action != 'sp'; $readonlys['cancel'] = $action != 'sp';