make advanced-search working in new addressbook

This commit is contained in:
Cornelius Weiß 2006-10-24 19:20:37 +00:00
parent 7eec77c451
commit d4d81a940c
2 changed files with 59 additions and 14 deletions

View File

@ -51,16 +51,14 @@ class contacts_admin_prefs
'no_lang' => true, 'no_lang' => true,
'link' => false 'link' => false
), ),
/* array( array(
'text' => '<a class="textSidebox" href="'.$GLOBALS['egw']->link('/index.php',array( 'text' => '<a class="textSidebox" href="'.$GLOBALS['egw']->link('/index.php',array(
'menuaction' => 'etemplate.nextmatch_widget.open_advsearch', 'menuaction' => 'addressbook.uicontacts.search',)).
'function' => 'addressbook.uicontacts.search',
'prefix' => 'nm')).
'" onclick="window.open(this.href,\'_blank\',\'dependent=yes,width=850,height=480,scrollbars=yes,status=yes\'); '" onclick="window.open(this.href,\'_blank\',\'dependent=yes,width=850,height=480,scrollbars=yes,status=yes\');
return false;">'.lang('Advanced search').'</a>', return false;">'.lang('Advanced search').'</a>',
'no_lang' => true, 'no_lang' => true,
'link' => false 'link' => false
),*/ ),
// Disabled til they are working again // Disabled til they are working again
// 'import contacts' => $GLOBALS['egw']->link('/index.php','menuaction=addressbook.uiXport.import'), // 'import contacts' => $GLOBALS['egw']->link('/index.php','menuaction=addressbook.uiXport.import'),
// 'export contacts' => $GLOBALS['egw']->link('/index.php','menuaction=addressbook.uiXport.export'), // 'export contacts' => $GLOBALS['egw']->link('/index.php','menuaction=addressbook.uiXport.export'),

View File

@ -594,9 +594,23 @@ class uicontacts extends bocontacts
{ {
$query['col_filter'][] = $query['order'].' LIKE '.$GLOBALS['egw']->db->quote($query['searchletter'].'%'); $query['col_filter'][] = $query['order'].' LIKE '.$GLOBALS['egw']->db->quote($query['searchletter'].'%');
} }
$wildcard = '%';
$op = 'OR';
if (is_array($query['search'])) // Advanced Search
{
$op = $query['search']['operator'];
$wildcard = $query['search']['meth_select'];
$advanced_search = $query['search'];
$query['search'] = array_intersect_key($query['search'],array_flip($this->get_contact_columns()));
foreach ($query['search'] as $key => $value) {
if(!$value) unset($query['search'][$key]);
}
}
$rows = parent::search($query['search'],$id_only ? array('id','org_name','n_family','n_given','n_fileas') : false, $rows = parent::search($query['search'],$id_only ? array('id','org_name','n_family','n_given','n_fileas') : false,
$order,'','%',false,'OR',array((int)$query['start'],(int) $query['num_rows']),$query['col_filter']); $order,'',$wildcard,false,$op,array((int)$query['start'],(int) $query['num_rows']),$query['col_filter']);
if( is_array($advanced_search) ) {
$query['search'] = '';
}
// do we need the custom fields // do we need the custom fields
if (!$id_only && $this->prefs['custom_colum'] != 'never' && $rows && $this->customfields) if (!$id_only && $this->prefs['custom_colum'] != 'never' && $rows && $this->customfields)
{ {
@ -748,6 +762,9 @@ class uicontacts extends bocontacts
{ {
$GLOBALS['egw_info']['flags']['app_header'] .= ' - '.lang("Search for '%1'",$query['search']); $GLOBALS['egw_info']['flags']['app_header'] .= ' - '.lang("Search for '%1'",$query['search']);
} }
if(is_array($advanced_search)) {
$GLOBALS['egw_info']['flags']['app_header'] .= ' - '.lang("Advanced search");
}
return $this->total; return $this->total;
} }
@ -1252,11 +1269,29 @@ $readonlys['button[vcard]'] = true;
return 'mailto:' . $email; return 'mailto:' . $email;
} }
function search() function search($_content=array())
{ {
$GLOBALS['egw_info']['flags']['app_header'] = lang('Addressbook'). ' - '. lang('Advanced search'); if(!empty($_content)) {
$GLOBALS['egw_info']['flags']['currentapp'] = 'addressbook'; $response = new xajaxResponse();
$GLOBALS['egw']->translation->add_app('addressbook');
$index_nm = $GLOBALS['egw']->session->appsession($do_email ? 'email' : 'index','addressbook');
$index_nm['search'] = $_content;
$GLOBALS['egw']->session->appsession($do_email ? 'email' : 'index','addressbook',$index_nm);
$response->addScript("
var index_link = opener.location;
opener.location= index_link;
window.close();
");
return $response->getXML();
}
else {
}
$GLOBALS['egw_info']['flags']['include_xajax'] = true;
$GLOBALS['egw_info']['flags']['java_script'] .= $this->js();
$GLOBALS['egw_info']['etemplate']['advanced_search'] = true;
// initialize etemplate arrays // initialize etemplate arrays
$content = $sel_options = $readonlys = $preserv = array(); $content = $sel_options = $readonlys = $preserv = array();
@ -1266,15 +1301,27 @@ $readonlys['button[vcard]'] = true;
$sel_options['tid'][] = lang('all'); $sel_options['tid'][] = lang('all');
//foreach($this->content_types as $type => $data) $sel_options['tid'][$type] = $data['name']; //foreach($this->content_types as $type => $data) $sel_options['tid'][$type] = $data['name'];
// some changes for the new addressbook // configure search options
$sel_options['owner'] = $this->get_addressbooks(EGW_ACL_READ,lang('all')); $sel_options['owner'] = $this->get_addressbooks(EGW_ACL_READ,lang('all'));
$sel_options['operator'] = array(
'OR' => 'OR',
'AND' => 'AND'
);
$sel_options['meth_select'] = array(
'%' => lang('contains'),
false => lang('exact'),
);
// configure edit template as search dialog
$readonlys['change_photo'] = true; $readonlys['change_photo'] = true;
$readonlys['fileas_type'] = true; $readonlys['fileas_type'] = true;
$readonlys['creator'] = true; $readonlys['creator'] = true;
$readonlys['button'] = true; $readonlys['button'] = true;
$readonlys['personal|organisation|home|details|links']['links'] = true;
$content['hidebuttons'] = true; $content['hidebuttons'] = true;
$GLOBALS['egw_info']['flags']['java_script'] .= $this->js(); $content['no_tid'] = true;
$this->tmpl->read('addressbook.edit');
$this->tmpl->read('addressbook.search');
return $this->tmpl->exec('addressbook.uicontacts.search',$content,$sel_options,$readonlys,$preserv,2); return $this->tmpl->exec('addressbook.uicontacts.search',$content,$sel_options,$readonlys,$preserv,2);
} }