X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=gosa-core%2Finclude%2Fclass_baseSelector.inc;h=4da32961e827ac04fa56158b03c0ad07e3a89090;hb=7d0eab6bb81d3010130879061ea00542071f5b76;hp=baea70e5fcc27eaec6b724b3adc670990a8d7d55;hpb=98d4da0c93f8df24dc0c9bd4a92c90c27b461755;p=gosa.git
diff --git a/gosa-core/include/class_baseSelector.inc b/gosa-core/include/class_baseSelector.inc
index baea70e5f..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,28 +42,54 @@ class baseSelector {
function __construct($bases, $base= "")
{
+ // Initialize pid
+ $this->pid= preg_replace("/[^0-9]/", "", microtime(TRUE));
+
+ // Transfer data
$this->setBases($bases);
$this->setBase($base);
}
+ function setSubmitButton($flag)
+ {
+ $this->submitButton= $flag;
+ }
+
+
+ function setHeight($value)
+ {
+ $this->height= $value;
+ }
+
+
function setBase($base)
{
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;
@@ -69,12 +100,84 @@ class baseSelector {
$elements= array_reverse($elements, true);
$this->pathMapping[$base]= $base == $config->current['BASE']? '/' : ldap::fix(preg_replace('/(^|,)[a-z0-9]+=/i', '/', implode(',', $elements)));
+ }
+
+ // Save bases to session for autocompletion
+ session::global_set('pathMapping', $this->pathMapping);
+ }
+
+
+ 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.= "pid."')\">
/ ["._("Root")."]\n";
+ $first= true;
+ $last_indent= 2;
+
+ foreach ($this->pathMapping as $base => $dummy) {
// Skip root for tree
if ($base == $config->current['BASE']) {
continue;
}
+ // Build path style display
+ $elements= explode(',', substr($base, 0, strlen($base) - strlen($config->current['BASE'])));
+
$indent= count($elements);
if (!$first && ($indent == $last_indent)) {
$this->tree.= "\n";
@@ -89,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;
@@ -101,23 +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.= "";
- // Save bases to session for autocompletion
- session::global_set('pathMapping', $this->pathMapping);
+ $this->lastState= true;
+ return true;
}
-
function render()
{
- $result= "";
- return $result;
- }
-
-
- function update()
- {
- echo "update";
+ return $this->tree;
}
@@ -129,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;
}
}