- patch from Klaus Leithoff: implementing lettersearch for ACL

- bugfix from Sebastian Ebeling
This commit is contained in:
Ralf Becker 2006-12-06 14:53:03 +00:00
parent 622bd2d65c
commit 94359ad8fd
2 changed files with 83 additions and 7 deletions

View File

@ -30,10 +30,19 @@
function index() function index()
{ {
$query_types = array(
'all' => 'all fields',
'lid' => 'LoginID',
'start' => 'start with',
'exact' => 'exact',
);
$acl_app = get_var('acl_app',array('POST','GET')); $acl_app = get_var('acl_app',array('POST','GET'));
$start = get_var('start',array('POST','GET'),0); $start = get_var('start',array('POST','GET'),0);
$query = get_var('query',array('POST','GET')); $query = get_var('query',array('POST','GET'));
$owner = get_var('owner',array('POST','GET'),$GLOBALS['egw_info']['user']['account_id']); $owner = get_var('owner',array('POST','GET'),$GLOBALS['egw_info']['user']['account_id']);
$search_type= get_var('search_type',array('POST','GET'));
if (!$acl_app) if (!$acl_app)
{ {
@ -50,7 +59,7 @@
{ {
$referer = $GLOBALS['egw']->common->get_referer('/preferences/index.php'); $referer = $GLOBALS['egw']->common->get_referer('/preferences/index.php');
} }
//echo '<p align="right">'."referer='$referer'</p>\n"; //echo '<p align="right">'."search_type='$search_type'</p>\n";
$GLOBALS['egw_info']['flags']['currentapp'] = $acl_app; $GLOBALS['egw_info']['flags']['currentapp'] = $acl_app;
@ -159,7 +168,8 @@
); );
$this->template->set_file($templates); $this->template->set_file($templates);
$this->template->set_block('preferences','list','list'); // refers to list area in acl.tpl (which is named as preferences)
$this->template->set_block('list','letter_search','letter_search_cells'); // refers to the area letter_search (nested within area list)
if ($submit) if ($submit)
{ {
$this->template->set_var('errors',lang('ACL grants have been updated')); $this->template->set_var('errors',lang('ACL grants have been updated'));
@ -171,6 +181,7 @@
'owner' => $owner, 'owner' => $owner,
'acl_app' => $acl_app, 'acl_app' => $acl_app,
'referer' => $referer, 'referer' => $referer,
'search_type' => $search_type, // KL 20061204 added to have a search type available
); );
$var = Array( $var = Array(
'errors' => '', 'errors' => '',
@ -200,10 +211,12 @@
'type' => 'both', 'type' => 'both',
'start' => $start, 'start' => $start,
'query' => $query, 'query' => $query,
'query_type' => $search_type, //KL 20061204 added to have query_type available
'order' => 'account_type,account_lid', 'order' => 'account_type,account_lid',
'sort' => 'ASC', 'sort' => 'ASC',
)); ));
$totalentries = $GLOBALS['egw']->accounts->total; $totalentries = $GLOBALS['egw']->accounts->total;
$shownentries = count($accounts);
$memberships = array(); $memberships = array();
foreach((array) $GLOBALS['egw']->accounts->membership($owner) as $data) foreach((array) $GLOBALS['egw']->accounts->membership($owner) as $data)
@ -214,9 +227,12 @@
$processed = Array(); $processed = Array();
foreach((array)$accounts as $uid => $data) foreach((array)$accounts as $uid => $data)
{ {
if ($data['account_type'] == 'u' && $uid == $owner || !$uid) if ($data['account_type'] == 'u' && $data['account_id'] == $owner)
{
$shownentries--;
$totalentries--;
continue; /* no need to grant to self if user */ continue; /* no need to grant to self if user */
}
if ($data['account_type'] != $header_type) if ($data['account_type'] != $header_type)
{ {
$this->template->set_var('string',$data['account_type'] == 'g' ? lang('Groups') : lang('Users')); $this->template->set_var('string',$data['account_type'] == 'g' ? lang('Groups') : lang('Users'));
@ -241,16 +257,43 @@
'acl_app' => $acl_app, 'acl_app' => $acl_app,
'owner' => $owner, 'owner' => $owner,
'referer' => $referer, 'referer' => $referer,
'search_type' => is_array($query_types) ? $search_type : '',
'search_value' => isset($query) && $query ? $GLOBALS['egw']->html->htmlspecialchars($query) : '',
'query' => isset($query) && $query ? $GLOBALS['egw']->html->htmlspecialchars($query) : '',
); );
$var = Array( $var = Array(
'nml' => $GLOBALS['egw']->nextmatchs->left('/index.php',$start,$totalentries,$extra_parms), 'nml' => $GLOBALS['egw']->nextmatchs->left('/index.php',$start,$totalentries,$extra_parms),
'nmr' => $GLOBALS['egw']->nextmatchs->right('/index.php',$start,$totalentries,$extra_parms), 'nmr' => $GLOBALS['egw']->nextmatchs->right('/index.php',$start,$totalentries,$extra_parms),
'lang_groups' => lang('showing %1 - %2 of %3',$start+1,$start+$shownentries,$totalentries),
'search_type' => is_array($query_types) ? $GLOBALS['egw']->html->select('search_type',$search_type,$query_types) : '',
'search_value' => isset($query) && $query ? $GLOBALS['egw']->html->htmlspecialchars($query) : '', 'search_value' => isset($query) && $query ? $GLOBALS['egw']->html->htmlspecialchars($query) : '',
'search' => lang('search'), 'search' => lang('search'),
'processed' => urlencode(serialize($processed)) 'processed' => urlencode(serialize($processed))
); );
$letters = lang('alphabet');
$letters = explode(',',substr($letters,-1) != '*' ? $letters : 'a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z');
$extra_parms['search_type'] = 'start';
foreach($letters as $letter)
{
$extra_parms['query'] = $letter;
$this->template->set_var(array(
'letter' => $letter,
'link' => $GLOBALS['egw']->link('/index.php',$extra_parms),
'class' => $query == $letter && $search_type == 'start' ? 'letter_box_active' : 'letter_box',
));
$this->template->fp('letter_search_cells','letter_search',True);
}
unset($extra_parms['query']);
unset($extra_parms['search_value']);
unset($extra_parms['search_type']);
$this->template->set_var(array(
'letter' => lang('all'),
'link' => $GLOBALS['egw']->link('/index.php',$extra_parms),
'class' => $search_type != 'start' || !in_array($query,$letters) ? 'letter_box_active' : 'letter_box',
));
$this->template->fp('letter_search_cells','letter_search',True);
$this->template->set_var($var); $this->template->set_var($var);
$this->template->pfp('out','preferences'); $this->template->pfp('out','preferences');

View File

@ -1,11 +1,43 @@
<!-- BEGIN list -->
<style type="text/css">
.letter_box,.letter_box_active {
background-color: #D3DCE3;
width: 25px;
border: 1px solid #D3DCE3;
text-align: center;
cursor: pointer;
cusror: hand;
}
.letter_box_active {
font-weight: bold;
background-color: #E8F0F0;
}
.letter_box_active,.letter_box:hover {
border: 1px solid black;
background-color: #E8F0F0;
}
</style>
{errors} {errors}
<table border="0" align="center" width="50%"> <table border="0" align="center" width="50%">
<tr> <tr>
<td colspan="5">
<table width="100%"><tr>
<!-- BEGIN letter_search -->
<td class="{class}" onclick="location.href='{link}';">{letter}</td>
<!-- END letter_search -->
</tr></table>
</td>
</tr>
<tr>
<td colspan="5" align="center">{lang_groups}</td>
</tr>
<tr>
{nml} {nml}
<td width="40%"> <td width="40%">
<div align="center"> <div align="center">
<form method="POST" action="{action_url}"> <form method="POST" action="{action_url}">
{common_hidden_vars_form} {common_hidden_vars_form}
{search_type}
<input type="text" name="query" value="{search_value}"> <input type="text" name="query" value="{search_value}">
<input type="submit" name="search" value="{search}"> <input type="submit" name="search" value="{search}">
</form> </form>
@ -14,6 +46,7 @@
{nmr} {nmr}
</tr> </tr>
</table> </table>
<!-- END list -->
<form method="POST" action="{action_url}"> <form method="POST" action="{action_url}">
{common_hidden_vars_form} {common_hidden_vars_form}
<input type="hidden" name="processed" value="{processed}"> <input type="hidden" name="processed" value="{processed}">