index 6ca5c31ae9db4990472894146897bbc2fa60b7d7..e519909af16a7635f88377eabe54c7e8fee2bf73 100644 (file)
isset($config['sortType'])) {
$this->sortAttribute= $config['sortAttribute'];
$this->sortType= $config['sortType'];
- $sorter= " ".image("images/lists/sort-".($this->sortDirection[$index]?"up":"down").".png", null, $this->sortDirection[$index]?_("Up"):_("Down"), "text-top");
+ $sorter= " ".image("images/lists/sort-".($this->sortDirection[$index]?"up":"down").".png", null, $this->sortDirection[$index]?_("Sort ascending"):_("Sort descending"), "text-top");
}
$sortable= (isset($config['sortAttribute']));
if (preg_match('/Konqueror/i', $_SERVER['HTTP_USER_AGENT'])){
$width= "28px";
}
- $result.= "<td class='listheader' style='text-align:center;padding:0;width:$width;'><input type='checkbox' id='select_all' name='select_all' title='"._("Select all")."' onClick='toggle_all_(\"listing_selected_[0-9]*$\",\"select_all\");' ></td>\n";
+ $result.= "<td class='listheader' style='text-align:center;padding:0;width:$width;'>";
+ if($this->multiSelect){
+ $result.= "<input type='checkbox' id='select_all' name='select_all'
+ title='"._("Select all")."' onClick='toggle_all_(\"listing_selected_[0-9]*$\",\"select_all\");' >";
+ }else{
+ $result.= " ";
+ }
+ $result.="</td>\n";
}
foreach ($this->header as $header) {
$result.= $header;
// Fill with department browser if configured this way
$departmentIterator= new departmentSortIterator($this->departments, $this->sortDirection[$this->sortColumn]);
foreach ($departmentIterator as $row => $entry){
- $result.="<tr>";
+ $rowResult= "<tr>";
// Render multi select if needed
if ($this->multiSelect || $this->singleSelect) {
- $result.="<td style='text-align:center;padding:0;' class='list1'> </td>";
+ $rowResult.="<td style='text-align:center;padding:0;' class='list1'> </td>";
}
// Render defined department columns, fill the rest with some stuff
$colspan= $config['span'];
$this->useSpan= true;
}
- $result.="<td colspan='$colspan' ".$this->colprops[$index]." class='list1'>".$this->renderCell($config['value'], $entry, $row)."</td>";
+ $rowResult.="<td colspan='$colspan' ".$this->colprops[$index]." class='list1'>".$this->renderCell($config['value'], $entry, $row)."</td>";
$rest-= $colspan;
}
// Fill remaining cols with nothing
$last= $this->numColumns - $rest;
for ($i= 0; $i<$rest; $i++){
- $result.= "<td ".$this->colprops[$last+$i-1]." class='list1'> </td>";
+ $rowResult.= "<td ".$this->colprops[$last+$i-1]." class='list1'> </td>";
}
- $result.="</tr>";
+ $rowResult.="</tr>";
+ // Apply label to objecttype icon?
+ if (preg_match("/<objectType:([^:]+):(.*)\/>/i", $rowResult, $matches)){
+ $objectType= image($matches[1], null, LDAP::fix(base64_decode($matches[2])));
+ $rowResult= preg_replace("/<objectType[^>]+>/", $objectType, $rowResult);
+ }
+ $result.= $rowResult;
$alt++;
}
+
+
$deps= $alt;
}
$entryIterator= new listingSortIterator($this->entries, $this->sortDirection[$this->sortColumn], "_sort".$this->sortColumn, $this->sortType);
foreach ($entryIterator as $row => $entry){
+ // Apply label to objecttype icon?
+ if (preg_match("/<objectType:([^:]+):(.*)\/>/i", $entry['_rendered'], $matches)){
+ if (preg_match("/<rowLabel:([a-z0-9_-]*)\/>/i", $entry['_rendered'], $m)) {
+ $objectType= image($matches[1]."[".$m[1]."]", null, LDAP::fix(base64_decode($matches[2])));
+ } else {
+ $objectType= image($matches[1], null, LDAP::fix(base64_decode($matches[2])));
+ }
+ $entry['_rendered']= preg_replace("/<objectType[^>]+>/", $objectType, $entry['_rendered']);
+ $entry['_rendered']= preg_replace("/<rowLabel[^>]+>/", '', $entry['_rendered']);
+ }
+
// Apply custom class to row?
if (preg_match("/<rowClass:([a-z0-9_-]*)\/>/i", $entry['_rendered'], $matches)) {
$result.="<tr class='".$matches[1]."'>\n";
$result.= '</script>';
$smarty= get_smarty();
- $smarty->assign("usePrototype", "true");
+
$smarty->assign("FILTER", $this->filter->render());
$smarty->assign("SIZELIMIT", print_sizelimit_warning());
$smarty->assign("LIST", $result);
// Take care of base selector
if ($this->baseMode) {
$this->baseSelector->update();
+
// Check if a wrong base was supplied
if(!$this->baseSelector->checkLastBaseUpdate()){
msg_dialog::display(_("Error"), msgPool::check_base(), ERROR_DIALOG);
$objectType= $this->getObjectType($this->objectTypes, $classes);
if ($objectType) {
$this->objectDnMapping[$dn]= $objectType["objectClass"];
- $result= image($objectType["image"], null, LDAP::fix($dn));
+ $result= "<objectType:".$objectType["image"].":".base64_encode(LDAP::fix($dn))."/>";
if (!isset($this->objectTypeCount[$objectType['label']])) {
$this->objectTypeCount[$objectType['label']]= 0;
}
/* Draw back button */
if($enableBack){
- $result["BACK"]= image('images/lists/back.png', 'BACK', _("Go up one department"));
+ $result["BACK"]= image('images/lists/back.png', 'BACK', _("Go to preceding level"));
}else{
- $result["BACK"]= image('images/lists/back-grey.png', null, _("Go up one department"));
+ $result["BACK"]= image('images/lists/back-grey.png', null, _("Go to preceding level"));
}
/* Draw home button */
/* Draw home button */
if($enableHome){
- $result["HOME"]= image('images/lists/home.png', 'HOME', _("Go to users department"));
+ $result["HOME"]= image('images/lists/home.png', 'HOME', _("Go to current users level"));
}else{
- $result["HOME"]= image('images/lists/home-grey.png', null, _("Go to users department"));
+ $result["HOME"]= image('images/lists/home-grey.png', null, _("Go to current users level"));
}
// Draw snapshot button
if($ui->allow_snapshot_create($dn, $category)){
- $result.= image('images/snapshot.png', "listing_snapshot_$row", _("Create a new snapshot from this object"));
+ $result.= image('images/snapshot.png', "listing_snapshot_$row", _("Create new snapshot for this object"));
}else{
$result.= image('images/empty.png');
}
function getType($dn)
{
+ $dn = LDAP::fix($dn);
if (isset($this->objectDnMapping[$dn])) {
return $this->objectDnMapping[$dn];
}