index 01750129fc844b538790203cde9f68a23888965d..0b26ffe0bbdda9f530448fe31c623eb7d1c6a110 100644 (file)
private $submitButton= true;
protected $tree;
protected $pathMapping;
private $submitButton= true;
protected $tree;
protected $pathMapping;
+ protected $lastState;
- // It would be better to get a dn -> [name, description, type] array
- // to avoid these tasks be done several times. Skipping for the moment.
- #'dc' => 'plugins/departments/images/domain.png',
- #'dc' => 'plugins/departments/images/dc.png',
- #'l' => 'plugins/departments/images/locality.png',
- #'c' => 'plugins/departments/images/country.png',
- #'o' => 'plugins/departments/images/organization.png',
- #'ou' => 'plugins/departments/images/folder.png',
function __construct($bases, $base= "")
{
function __construct($bases, $base= "")
{
}
}
+ function checkBase($base)
+ {
+ return isset($this->pathMapping[$base]);
+ }
+
+
+ function checkLastBaseUpdate()
+ {
+ return $this->lastState;
+ }
+
+
function setBases($bases)
{
global $config;
function setBases($bases)
{
global $config;
$elements= array_reverse($elements, true);
$this->pathMapping[$base]= $base == $config->current['BASE']? '/' : ldap::fix(preg_replace('/(^|,)[a-z0-9]+=/i', '/', implode(',', $elements)));
$elements= array_reverse($elements, true);
$this->pathMapping[$base]= $base == $config->current['BASE']? '/' : ldap::fix(preg_replace('/(^|,)[a-z0-9]+=/i', '/', implode(',', $elements)));
+ $this->pathMapping[$base]= stripslashes( $this->pathMapping[$base]);
}
// Save bases to session for autocompletion
session::global_set('pathMapping', $this->pathMapping);
}
// Save bases to session for autocompletion
session::global_set('pathMapping', $this->pathMapping);
+ session::global_set('department_info', $config->department_info);
}
}
// Analyze for base changes if needed
$this->action= null;
$last_base= $this->base;
// Analyze for base changes if needed
$this->action= null;
$last_base= $this->base;
- if(isset($_REQUEST['PID']) && $_REQUEST['PID'] == $this->pid) {
- if (isset($_REQUEST['REBASE'])) {
- $new_base= base64_decode($_REQUEST['REBASE']);
+ if(isset($_REQUEST['BPID']) && $_REQUEST['BPID'] == $this->pid) {
+ if (isset($_POST['bs_rebase_'.$this->pid]) && !empty($_POST['bs_rebase_'.$this->pid])) {
+ $new_base= base64_decode($_POST['bs_rebase_'.$this->pid]);
+
if (isset($this->pathMapping[$new_base])) {
$this->base= $new_base;
$this->action= 'rebase';
} else {
if (isset($this->pathMapping[$new_base])) {
$this->base= $new_base;
$this->action= 'rebase';
} else {
+ $this->lastState= false;
return false;
}
return false;
}
- }
- } elseif (isset($_POST['bs_input_'.$this->pid])) {
-
- // Take over input field base
- if ($this->submitButton && isset($_POST['submit_base_'.$this->pid.'_x']) || !$this->submitButton) {
-
- // Check if base is available
- foreach ($this->pathMapping as $key => $path) {
- if (mb_strtolower($path) == mb_strtolower($_POST['bs_input_'.$this->pid])) {
- $this->base= $key;
- break;
+ }else{
+
+ // Input field set?
+ if (isset($_POST['bs_input_'.$this->pid])) {
+
+ // Take over input field base
+ if ($this->submitButton && isset($_POST['submit_base_'.$this->pid]) || !$this->submitButton) {
+
+ // Check if base is available
+ $this->lastState= false;
+ foreach ($this->pathMapping as $key => $path) {
+ if (mb_strtolower($path) == mb_strtolower(get_post('bs_input_'.$this->pid))) {
+ $this->base= $key;
+ $this->lastState= true;
+ break;
+ }
+ }
}
}
}
}
- }
+ }
}
}
return true;
}
return true;
}
- $link= "href='?plug=".$_GET['plug']."&PID=".$this->pid."&REBASE=".base64_encode($config->current['BASE'])."'";
- $this->tree= "<input type='text' size='35' name='bs_input_".$this->pid."' id='bs_input_".$this->pid."' onkeydown=\"\$('bs_".$this->pid."').hide()\" onfocus=\"\$('bs_".$this->pid."').hide()\" onmouseover=\"Element.clonePosition(\$('bs_".$this->pid."'), 'bs_input_".$this->pid."', {setHeight: false, setWidth: false, offsetTop:(Element.getHeight('bs_input_".$this->pid."'))});\$('bs_".$this->pid."').show();\" onmouseout=\"rtimer= Element.hide.delay(0.25, 'bs_".$this->pid."')\" value=\"".htmlentities($this->pathMapping[$this->base])."\">";
+ $link= "onclick=\"\$('bs_rebase_".$this->pid."').value='".base64_encode($config->current['BASE'])."'; $('submit_tree_base_".$this->pid."').click();\"";
+
+
+ $this->tree= "<input style='width:160px' type='text' size='35'
+ name='bs_input_{$this->pid}' id='bs_input_{$this->pid}'
+
+ onkeydown=\" \$('bs_{$this->pid}').hide(); \"
+ onfocus=\" \$('bs_{$this->pid}').hide(); \"
+ onmouseover=\" mouseIsStillOver = true;
+ function showIt()
+ {
+ if(mouseIsStillOver){
+ \$('bs_".$this->pid."').show();
+ }
+ };
+ Element.clonePosition(\$('bs_".$this->pid."'),
+ 'bs_input_".$this->pid."',
+ {setHeight: false, setWidth: false, offsetTop:(Element.getHeight('bs_input_".$this->pid."'))});
+ rtimer=showIt.delay(0.25); \"
+
+ onmouseout=\" mouseIsStillOver=false;
+ rtimer=Element.hide.delay(0.25,'bs_".$this->pid."')\"
+
+ value=\"".preg_replace('/"/','"',$this->pathMapping[$this->base])."\">";
// Autocompleter
// Autocompleter
$this->tree.= "</script>";
$selected= $this->base == $config->current['BASE']?"Selected":"";
$this->tree.= "</script>";
$selected= $this->base == $config->current['BASE']?"Selected":"";
- $this->tree.= "<div class='treeList' style='display:none;max-height:".$this->height."px' id='bs_".$this->pid."' onmouseover=\"window.clearTimeout(rtimer);\" onmouseout=\"rtimer= Element.hide.delay(0.25, 'bs_".$this->pid."')\"><a class='treeList$selected' $link>/ ["._("Root")."]</a><ul class='treeList'>\n";
+ $this->tree.= "<div class='treeList' style='display:none;max-height:".$this->height."px' id='bs_".$this->pid."' onmouseover=\"window.clearTimeout(rtimer);\" onmouseout=\"rtimer= Element.hide.delay(0.25, 'bs_".$this->pid."')\"><a class='treeList$selected' $link>/ ["._("Root")."]</a><ul class='treeList'>\n";
$first= true;
$last_indent= 2;
$first= true;
$last_indent= 2;
$this->tree.= "</li>\n";
}
$selected= $this->base == $base?" class='treeListSelected'":"";
$this->tree.= "</li>\n";
}
$selected= $this->base == $base?" class='treeListSelected'":"";
- $link= "href='?plug=".$_GET['plug']."&PID=".$this->pid."&REBASE=".base64_encode($base)."'";
- $this->tree.= "<li><a$selected $link>".str_replace(' ', ' ', ldap::fix(preg_replace('/^[a-z0-9]+=([^,]+),.*$/i', '$1', $base)))."</a>";
+ $link= "onclick=\"\$('bs_rebase_".$this->pid."').value='".base64_encode($base)."';$('submit_tree_base_".$this->pid."').click();\"";
+ $this->tree.= "<li>".
+ image($config->department_info[$base]['img'])." <a$selected $link>".
+ $this->gennonbreaks($config->department_info[$base]['name']).
+ ($config->department_info[$base]['description']==''?'':' <span class="informal">['.$this->gennonbreaks($config->department_info[$base]['description']).']</span>').
+ "</a>";
$last_indent= $indent;
$first= false;
}
// Close tree
$last_indent= $indent;
$first= false;
}
// Close tree
- for ($i= 0; $i<$last_indent; $i++) {
+ for ($i= 1; $i<$last_indent; $i++) {
$this->tree.= "</li></ul>\n";
}
$this->tree.= "</div>\n";
// Draw submitter if required
if ($this->submitButton) {
$this->tree.= "</li></ul>\n";
}
$this->tree.= "</div>\n";
// Draw submitter if required
if ($this->submitButton) {
- $this->tree.= " <input class='center' type='image' src='images/lists/submit.png' align='middle' title='"._("Submit")."' name='submit_base_".$this->pid."' id='submit_base_".$this->pid."' alt='"._("Submit")."'>";
+ $this->tree.= image('images/lists/submit.png', "submit_base_".$this->pid, _("Submit"));
}
}
+ $this->tree.= "<input type='submit' style='display:none' name='submit_tree_base_".$this->pid."' id='submit_tree_base_".$this->pid."'>";
+ $this->tree.= "<input type='hidden' name='bs_rebase_".$this->pid."' id='bs_rebase_".$this->pid."'>";
+ $this->tree.= "<input type='hidden' name='BPID' id='BPID' value='".$this->pid."'>";
+ $this->lastState= true;
return true;
}
return true;
}
+
+ function gennonbreaks($string)
+ {
+ return str_replace('-', '‑', str_replace(' ', ' ', $string));
+ }
+
+
function render()
{
return $this->tree;
function render()
{
return $this->tree;
function getAction()
{
function getAction()
{
- // Do not do anything if this is not our PID, or there's even no PID available...
- if(!isset($_REQUEST['PID']) || $_REQUEST['PID'] != $this->pid) {
+ // Do not do anything if this is not our BPID, or there's even no BPID available...
+ if(!isset($_REQUEST['BPID']) || $_REQUEST['BPID'] != $this->pid) {
return;
}
return;
}