X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=gosa-core%2Finclude%2Fclass_baseSelector.inc;h=0b26ffe0bbdda9f530448fe31c623eb7d1c6a110;hb=e1e757ca6816d818fa1a393b66f165ffefb1afe7;hp=18f363e3fabb2dddc9a2b7f8b20d235236054b88;hpb=d262f0b8e5bc54bfe76b60970ffe3b86e0c84fe0;p=gosa.git
diff --git a/gosa-core/include/class_baseSelector.inc b/gosa-core/include/class_baseSelector.inc
index 18f363e3f..0b26ffe0b 100644
--- a/gosa-core/include/class_baseSelector.inc
+++ b/gosa-core/include/class_baseSelector.inc
@@ -23,42 +23,65 @@
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.
- #'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= "")
{
+ // 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 +92,111 @@ class baseSelector {
$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);
+ session::global_set('department_info', $config->department_info);
+ }
+
+
+ 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]) || !$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;
+ }
+ }
+ }
+ }
+ }
+
+ }
+
+ /* 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=\" 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
+ $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,34 +211,45 @@ 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.= "
- ".
+ image($config->department_info[$base]['img'])." ".
+ $this->gennonbreaks($config->department_info[$base]['name']).
+ ($config->department_info[$base]['description']==''?'':' ['.$this->gennonbreaks($config->department_info[$base]['description']).']').
+ "";
$last_indent= $indent;
$first= false;
}
// Close tree
- for ($i= 0; $i<$last_indent; $i++) {
+ for ($i= 1; $i<$last_indent; $i++) {
$this->tree.= "
\n";
}
+ $this->tree.= "
\n";
-echo $this->tree;
+ // Draw submitter if required
+ if ($this->submitButton) {
+ $this->tree.= image('images/lists/submit.png', "submit_base_".$this->pid, _("Submit"));
+ }
+ $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()
+ function gennonbreaks($string)
{
- $result= "";
- return $result;
+ return str_replace('-', '‑', str_replace(' ', ' ', $string));
}
- function update()
+ function render()
{
- echo "update";
+ return $this->tree;
}
@@ -128,10 +261,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;
}
}