X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=gosa-core%2Finclude%2Fclass_baseSelector.inc;h=4da32961e827ac04fa56158b03c0ad07e3a89090;hb=7d0eab6bb81d3010130879061ea00542071f5b76;hp=9ca0a429542758b63d761508c383eb411812e8f0;hpb=31e0e749270442feeecd317a34312e9556fd773f;p=gosa.git
diff --git a/gosa-core/include/class_baseSelector.inc b/gosa-core/include/class_baseSelector.inc
index 9ca0a4295..4da32961e 100644
--- a/gosa-core/include/class_baseSelector.inc
+++ b/gosa-core/include/class_baseSelector.inc
@@ -23,8 +23,13 @@
class baseSelector {
private $base;
+ private $pid;
+ private $action;
+ private $height= 500;
+ 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.
@@ -37,9 +42,24 @@ class baseSelector {
function __construct($bases, $base= "")
{
+ // Initialize pid
+ $this->pid= preg_replace("/[^0-9]/", "", microtime(TRUE));
+
+ // Transfer data
$this->setBases($bases);
$this->setBase($base);
- $this->update();
+ }
+
+
+ function setSubmitButton($flag)
+ {
+ $this->submitButton= $flag;
+ }
+
+
+ function setHeight($value)
+ {
+ $this->height= $value;
}
@@ -47,19 +67,29 @@ class baseSelector {
{
if (isset($this->pathMapping[$base])) {
$this->base= $base;
- } else {
- die("Invalid base selected");
+ $this->update(true);
}
}
+ function checkBase($base)
+ {
+ return isset($this->pathMapping[$base]);
+ }
+
+
+ function checkLastBaseUpdate()
+ {
+ return $this->lastState;
+ }
+
+
function setBases($bases)
{
global $config;
$this->pathMapping= array();
$selected= $this->base == $config->current['BASE']?"Selected":"";
- $this->tree= "
"._("Root")."\n";
$first= true;
$last_indent= 2;
@@ -77,12 +107,64 @@ class baseSelector {
}
- function update()
+ function update($force= false)
{
global $config;
+ // Analyze for base changes if needed
+ $this->action= null;
+ $last_base= $this->base;
+ 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 {
+ $this->lastState= false;
+ return false;
+ }
+ }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.'_x']) || !$this->submitButton) {
+
+ // Check if base is available
+ $this->lastState= false;
+ foreach ($this->pathMapping as $key => $path) {
+ if (mb_strtolower($path) == mb_strtolower($_POST['bs_input_'.$this->pid])) {
+ $this->base= $key;
+ $this->lastState= true;
+ break;
+ }
+ }
+ }
+ }
+ }
+
+ }
+
+ /* Skip if there's no change */
+ if (($this->tree && $this->base == $last_base) && !$force) {
+ return true;
+ }
+
+ $link= "onclick=\"\$('bs_rebase_".$this->pid."').value='".base64_encode($config->current['BASE'])."'; $('submit_tree_base_".$this->pid."').click();\"";
+ $this->tree= "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=\"".preg_replace('/"/', '"',$this->pathMapping[$this->base])."\">";
+
+ // Autocompleter
+ $this->tree.= "".
+ "";
+
$selected= $this->base == $config->current['BASE']?"Selected":"";
- $this->tree= ""._("Root")."\n";
+ $this->tree.= "pid."')\">
/ ["._("Root")."]\n";
$first= true;
$last_indent= 2;
@@ -110,7 +192,8 @@ class baseSelector {
$this->tree.= "\n";
}
$selected= $this->base == $base?" class='treeListSelected'":"";
- $this->tree.= "- ".ldap::fix(preg_replace('/^[a-z0-9]+=([^,]+),.*$/i', '$1', $base))."";
+ $link= "onclick=\"\$('bs_rebase_".$this->pid."').value='".base64_encode($base)."';$('submit_tree_base_".$this->pid."').click();\"";
+ $this->tree.= "
- ".str_replace(' ', ' ', ldap::fix(preg_replace('/^[a-z0-9]+=([^,]+),.*$/i', '$1', $base)))."";
$last_indent= $indent;
$first= false;
@@ -122,13 +205,21 @@ class baseSelector {
}
$this->tree.= "
\n";
-echo $this->tree;
+ // Draw submitter if required
+ if ($this->submitButton) {
+ $this->tree.= " ";
+ }
+ $this->tree.= "";
+ $this->tree.= "";
+ $this->tree.= "";
+
+ $this->lastState= true;
+ return true;
}
function render()
{
- $result= "";
- return $result;
+ return $this->tree;
}
@@ -140,10 +231,16 @@ echo $this->tree;
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) {
- # return;
- #}
+ // 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;
+ }
+
+ if ($this->action) {
+ return array("targets" => array($this->base), "action" => $this->action);
+ }
+
+ return null;
}
}