index 00a9e1090d7d3d1dc99d0477fa44bb59e48e7c98..e66ff530847801ca0e05e62f6bbf5a9548465a8f 100644 (file)
var $useSpan= false;
var $height= 0;
var $scrollPosition= 0;
var $useSpan= false;
var $height= 0;
var $scrollPosition= 0;
+ var $baseSelector;
function listing($filename)
function listing($filename)
}
}
}
}
}
}
+
+ // Instanciate base selector
+ $this->baseSelector= new baseSelector($this->bases, $this->base);
}
}
// Some browsers don't have the ability do do scrollable table bodies, filter them
// here.
$switch= false;
// Some browsers don't have the ability do do scrollable table bodies, filter them
// here.
$switch= false;
- if (preg_match('/(Opera|Konqueror|Safari|msie)/i', $_SERVER['HTTP_USER_AGENT'])){
+ if (preg_match('/(Opera|Konqueror|Safari)/i', $_SERVER['HTTP_USER_AGENT'])){
$switch= true;
}
$switch= true;
}
$height= $this->height;
}
$height= $this->height;
}
- $result.= "<table cellpadding='0' cellspacing='0' border='0'><tr><td><div class='listContainer' id='d_scrollbody' style='border-top:1px solid #B0B0B0;border-right:1px solid #B0B0B0;width:700px;min-height:".($height+25)."px;'>\n";
-
- $height= "";
- if ($switch){
- $height= "height:100%;";
- }
- $result.= "<table summary='$this->headline' style='${height}width:100%; table-layout:fixed;' cellspacing='0' cellpadding='0' id='t_scrolltable'>\n";
+ $result.= "<div class='listContainer' id='d_scrollbody' style='border-top:1px solid #B0B0B0;border-right:1px solid #B0B0B0;width:100%;min-height:".($height+25)."px;'>\n";
+ $result.= "<table summary='$this->headline' style='width:100%; table-layout:fixed' cellspacing='0' cellpadding='0' id='t_scrolltable'>\n";
$this->numColumns= count($this->colprops) + ($this->multiSelect?1:0);
// Build list header
$this->numColumns= count($this->colprops) + ($this->multiSelect?1:0);
// Build list header
// Complete list by sorting entries for _sort$index and appending them to the output
$entryIterator= new listingSortIterator($this->entries, $this->sortDirection[$this->sortColumn], "_sort".$this->sortColumn, $this->sortType);
foreach ($entryIterator as $row => $entry){
// Complete list by sorting entries for _sort$index and appending them to the output
$entryIterator= new listingSortIterator($this->entries, $this->sortDirection[$this->sortColumn], "_sort".$this->sortColumn, $this->sortType);
foreach ($entryIterator as $row => $entry){
- $alt++;
$result.="<tr class='rowxp".($alt&1)."'>\n";
$result.= $entry['_rendered'];
$result.="</tr>\n";
$result.="<tr class='rowxp".($alt&1)."'>\n";
$result.= $entry['_rendered'];
$result.="</tr>\n";
+ $alt++;
}
// Need to fill the list if it's not full (nobody knows why this is 22 ;-))
}
// Need to fill the list if it's not full (nobody knows why this is 22 ;-))
}
// Close list body
}
// Close list body
- $result.= "</tbody></table></div></td></tr>";
+ $result.= "</tbody></table></div>";
// Add the footer if requested
if ($this->showFooter) {
// Add the footer if requested
if ($this->showFooter) {
- $result.= "<tr><td class='nlistFooter'>";
+ $result.= "<div class='nlistFooter'><div style='padding:3px'>";
foreach ($this->objectTypes as $objectType) {
if (isset($this->objectTypeCount[$objectType['label']])) {
foreach ($this->objectTypes as $objectType) {
if (isset($this->objectTypeCount[$objectType['label']])) {
}
}
}
}
- $result.= "</td></tr>";
+ $result.= "</div></div>";
}
// Close list
}
// Close list
- $result.= "</table>";
$result.= $switch?"<input type='hidden' id='list_workaround'>":"";
// Add scroll positioner
$result.= $switch?"<input type='hidden' id='list_workaround'>":"";
// Add scroll positioner
global $config;
$ui= get_userinfo();
global $config;
$ui= get_userinfo();
+ // 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);
+ }
+ }
+
+ // Save base
+ $refresh= false;
+ if ($this->baseMode) {
+ $this->base= $this->baseSelector->getBase();
+ session::global_set("CurrentMainBase", $this->base);
+ $refresh= true;
+ }
+
+
// Reset object counter / DN mapping
$this->objectTypeCount= array();
$this->objectDnMapping= array();
// Do not do anything if this is not our PID
// Reset object counter / DN mapping
$this->objectTypeCount= array();
$this->objectDnMapping= array();
// Do not do anything if this is not our PID
- if(!(isset($_REQUEST['PID']) && $_REQUEST['PID'] != $this->pid)) {
+ if($refresh || !(isset($_REQUEST['PID']) && $_REQUEST['PID'] != $this->pid)) {
// Save position if set
if (isset($_POST['position_'.$this->pid]) && is_numeric($_POST['position_'.$this->pid])) {
$this->scrollPosition= $_POST['position_'.$this->pid];
}
// Save position if set
if (isset($_POST['position_'.$this->pid]) && is_numeric($_POST['position_'.$this->pid])) {
$this->scrollPosition= $_POST['position_'.$this->pid];
}
- // Save base
- if (isset($_POST['BASE']) && $this->baseMode) {
- $base= base64_decode(get_post('BASE'));
- if (isset($this->bases[$base])) {
- $this->base= $base;
- session::global_set("CurrentMainBase", $this->base);
- }
- }
-
// Override the base if we got a message from the browser navigation
if ($this->departmentBrowser && isset($_GET['act'])) {
if (preg_match('/^department_([0-9]+)$/', validate($_GET['act']), $match)){
if (isset($this->departments[$match[1]])){
$this->base= $this->departments[$match[1]]['dn'];
// Override the base if we got a message from the browser navigation
if ($this->departmentBrowser && isset($_GET['act'])) {
if (preg_match('/^department_([0-9]+)$/', validate($_GET['act']), $match)){
if (isset($this->departments[$match[1]])){
$this->base= $this->departments[$match[1]]['dn'];
+ if ($this->baseMode) {
+ $this->baseSelector->setBase($this->base);
+ }
session::global_set("CurrentMainBase", $this->base);
}
}
session::global_set("CurrentMainBase", $this->base);
}
}
if ($action == 'ROOT') {
$deps= $ui->get_module_departments($this->categories);
$this->base= $deps[0];
if ($action == 'ROOT') {
$deps= $ui->get_module_departments($this->categories);
$this->base= $deps[0];
+ $this->baseSelector->setBase($this->base);
+ session::global_set("CurrentMainBase", $this->base);
}
if ($action == 'BACK') {
$deps= $ui->get_module_departments($this->categories);
$base= preg_replace("/^[^,]+,/", "", $this->base);
if(in_array_ics($base, $deps)){
$this->base= $base;
}
if ($action == 'BACK') {
$deps= $ui->get_module_departments($this->categories);
$base= preg_replace("/^[^,]+,/", "", $this->base);
if(in_array_ics($base, $deps)){
$this->base= $base;
+ $this->baseSelector->setBase($this->base);
+ session::global_set("CurrentMainBase", $this->base);
}
}
if ($action == 'HOME') {
$ui= get_userinfo();
}
}
if ($action == 'HOME') {
$ui= get_userinfo();
- $this->base= $this->filter->getObjectBase($ui->dn);
+ $this->base= get_base_from_people($ui->dn);
+ $this->baseSelector->setBase($this->base);
+ session::global_set("CurrentMainBase", $this->base);
}
}
}
}
function setBase($base)
{
$this->base= $base;
function setBase($base)
{
$this->base= $base;
+ if ($this->baseMode) {
+ $this->baseSelector->setBase($this->base);
+ }
}
}
return;
}
return;
}
- $result= "<select name='BASE' onChange='mainform.submit()' size='1'>";
- $firstDN= null;
- $found= false;
- foreach ($this->bases as $key=>$value) {
- // Keep first entry to fall back eventually
- if(!$firstDN) {
- $firstDN= $key;
- }
-
- // Prepare to render entry
- $selected= "";
- if ($key == $this->base) {
- $selected= " selected";
- $found= true;
- }
- // Encode key in b64 to avoid strange characters
- $result.= "\n<option value=\"".base64_encode($key)."\"$selected>".$value."</option>";
- }
-
- $result.= "</select>";
-
- // Reset the currently used base to the first DN we found if there
- // was no match.
- if(!$found){
- $this->base = $firstDN;
- }
-
- return $result;
+ return $this->baseSelector->render();
}
}
$listhead ="";
/* Check if we are in users home department */
$listhead ="";
/* Check if we are in users home department */
- if(!count($deps) || $this->filter->base == $this->filter->getObjectBase($ui->dn)){
+ if(!count($deps) || $this->filter->base == get_base_from_people($ui->dn)){
$enableHome = false;
}
$enableHome = false;
}
$checkAcl= "";
// Category or detailed permission?
$checkAcl= "";
// Category or detailed permission?
- if (strpos('/', $module) === false) {
+ if (strpos($module, '/') !== false) {
if (preg_match('/([a-zA-Z0-9]+):([rwcdm]+)/', $sAcl, $m) ) {
$checkAcl= $ui->get_permissions($dn, $module, $m[1]);
$sAcl= $m[2];
if (preg_match('/([a-zA-Z0-9]+):([rwcdm]+)/', $sAcl, $m) ) {
$checkAcl= $ui->get_permissions($dn, $module, $m[1]);
$sAcl= $m[2];
foreach($k_ids as $department){
$this->bases[$department] = $ids[$department];
}
foreach($k_ids as $department){
$this->bases[$department] = $ids[$department];
}
+
+ // Populate base selector if already present
+ if ($this->baseSelector && $this->baseMode) {
+ $this->baseSelector->setBases($this->bases);
+ }
}
}
}
}
+ function getEntries()
+ {
+ return $this->entries;
+ }
+
+
function getType($dn)
{
if (isset($this->objectDnMapping[$dn])) {
function getType($dn)
{
if (isset($this->objectDnMapping[$dn])) {