summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: f244bf6)
raw | patch | inline | side by side (parent: f244bf6)
author | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Thu, 29 Jul 2010 13:19:40 +0000 (13:19 +0000) | ||
committer | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Thu, 29 Jul 2010 13:19:40 +0000 (13:19 +0000) |
git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@19241 594d385d-05f5-0310-b6e9-bd551577e9d8
gosa-core/include/class_baseSelector.inc | patch | blob | history |
index 0b26ffe0bbdda9f530448fe31c623eb7d1c6a110..8a30178d724a5b4fa24de9f321e8b4a7528f2105 100644 (file)
class baseSelector {
- private $base;
- private $pid;
- private $action;
- private $height= 500;
- private $submitButton= true;
- protected $tree;
- protected $pathMapping;
- protected $lastState;
+ private $base;
+ private $pid;
+ private $action;
+ private $height= 500;
+ private $submitButton= true;
+ protected $tree;
+ protected $pathMapping;
+ protected $lastState;
+
+
+ function __construct($bases, $base= "")
+ {
+ // Initialize pid
+ $this->pid= preg_replace("/[^0-9]/", "", microtime(TRUE));
+
+ // Transfer data
+ $this->setBases($bases);
+ $this->setBase($base);
+ }
- function __construct($bases, $base= "")
- {
- // Initialize pid
- $this->pid= preg_replace("/[^0-9]/", "", microtime(TRUE));
+ function setSubmitButton($flag)
+ {
+ $this->submitButton= $flag;
+ }
- // Transfer data
- $this->setBases($bases);
- $this->setBase($base);
- }
+ function setHeight($value)
+ {
+ $this->height= $value;
+ }
- function setSubmitButton($flag)
- {
- $this->submitButton= $flag;
- }
+ function setBase($base)
+ {
+ if (isset($this->pathMapping[$base])) {
+ $this->base= $base;
+ $this->update(true);
+ }
+ }
- function setHeight($value)
- {
- $this->height= $value;
- }
+
+ function checkBase($base)
+ {
+ return isset($this->pathMapping[$base]);
+ }
- function setBase($base)
- {
- if (isset($this->pathMapping[$base])) {
- $this->base= $base;
- $this->update(true);
+ function checkLastBaseUpdate()
+ {
+ return $this->lastState;
}
- }
- function checkBase($base)
- {
- return isset($this->pathMapping[$base]);
- }
+ function setBases($bases)
+ {
+ global $config;
+ $this->pathMapping= array();
+ $selected= $this->base == $config->current['BASE']?"Selected":"";
+ $first= true;
+ $last_indent= 2;
- function checkLastBaseUpdate()
- {
- return $this->lastState;
- }
+ foreach ($bases as $base => $dummy) {
+ // Build path style display
+ $elements= explode(',', substr($base, 0, strlen($base) - strlen($config->current['BASE'])));
+ $elements= array_reverse($elements, true);
- function setBases($bases)
- {
- global $config;
+ $this->pathMapping[$base]= $base == $config->current['BASE']? '/' : ldap::fix(preg_replace('/(^|,)[a-z0-9]+=/i', '/', implode(',', $elements)));
+ $this->pathMapping[$base]= stripslashes( $this->pathMapping[$base]);
+ }
- $this->pathMapping= array();
- $selected= $this->base == $config->current['BASE']?"Selected":"";
- $first= true;
- $last_indent= 2;
+ // Save bases to session for autocompletion
+ session::global_set('pathMapping', $this->pathMapping);
+ session::global_set('department_info', $config->department_info);
+ }
- foreach ($bases as $base => $dummy) {
- // Build path style display
- $elements= explode(',', substr($base, 0, strlen($base) - strlen($config->current['BASE'])));
- $elements= array_reverse($elements, true);
+ 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(get_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;
+ }
+ }
+ }
+ }
+ }
- $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;
+ /* Skip if there's no change */
+ if (($this->tree && $this->base == $last_base) && !$force) {
+ return true;
}
- }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;
- }
+
+ $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."')\"
- /* Skip if there's no change */
- if (($this->tree && $this->base == $last_base) && !$force) {
- return true;
- }
+ value=\"".preg_replace('/"/','"',$this->pathMapping[$this->base])."\">";
- $link= "onclick=\"\$('bs_rebase_".$this->pid."').value='".base64_encode($config->current['BASE'])."'; $('submit_tree_base_".$this->pid."').click();\"";
+ // Autocompleter
+ $this->tree.= "<div id='autocomplete_".$this->pid."' class='autocomplete'></div>".
+ "<script type='text/javascript'>".
+ "new Ajax.Autocompleter('bs_input_".$this->pid."', 'autocomplete_".$this->pid."', 'autocomplete.php?type=base', { minChars: 3, frequency: 0.5 });";
+ if ($this->submitButton) {
+ $this->tree.= "$('bs_input_".$this->pid."').observe('keypress', function(event) { if(event.keyCode == Event.KEY_RETURN) { $('submit_base_".$this->pid."').click(); } });";
+ }
+ $this->tree.= "</script>";
- $this->tree= "<input style='width:160px' type='text' size='35'
- name='bs_input_{$this->pid}' id='bs_input_{$this->pid}'
+ $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";
+ $first= true;
+ $last_indent= 2;
- 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); \"
+ foreach ($this->pathMapping as $base => $dummy) {
- onmouseout=\" mouseIsStillOver=false;
- rtimer=Element.hide.delay(0.25,'bs_".$this->pid."')\"
+ // Skip root for tree
+ if ($base == $config->current['BASE']) {
+ continue;
+ }
- value=\"".preg_replace('/"/','"',$this->pathMapping[$this->base])."\">";
+ // 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.= "</li>\n";
+ }
+ if ($indent > $last_indent) {
+ $this->tree.= "<ul>\n";
+ }
+ if ($indent < $last_indent) {
+ for ($i= 0; $i < ($last_indent-$indent); $i++) {
+ $this->tree.= "</li></ul>\n";
+ }
+ $this->tree.= "</li>\n";
+ }
+ $selected= $this->base == $base?" class='treeListSelected'":"";
+ $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;
+ }
- // Autocompleter
- $this->tree.= "<div id='autocomplete_".$this->pid."' class='autocomplete'></div>".
- "<script type='text/javascript'>".
- "new Ajax.Autocompleter('bs_input_".$this->pid."', 'autocomplete_".$this->pid."', 'autocomplete.php?type=base', { minChars: 3, frequency: 0.5 });";
- if ($this->submitButton) {
- $this->tree.= "$('bs_input_".$this->pid."').observe('keypress', function(event) { if(event.keyCode == Event.KEY_RETURN) { $('submit_base_".$this->pid."').click(); } });";
- }
- $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";
- $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.= "</li>\n";
- }
- if ($indent > $last_indent) {
- $this->tree.= "<ul>\n";
- }
- if ($indent < $last_indent) {
- for ($i= 0; $i < ($last_indent-$indent); $i++) {
- $this->tree.= "</li></ul>\n";
+ // Close tree
+ for ($i= 1; $i<$last_indent; $i++) {
+ $this->tree.= "</li></ul>\n";
}
- $this->tree.= "</li>\n";
- }
- $selected= $this->base == $base?" class='treeListSelected'":"";
- $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;
- }
+ $this->tree.= "</div>\n";
- // Close tree
- 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.= 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."'>";
- // Draw submitter if required
- if ($this->submitButton) {
- $this->tree.= image('images/lists/submit.png', "submit_base_".$this->pid, _("Submit"));
+ $this->lastState= true;
+ return true;
}
- $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;
- }
+ function gennonbreaks($string)
+ {
+ return str_replace('-', '‑', str_replace(' ', ' ', $string));
+ }
- function gennonbreaks($string)
- {
- return str_replace('-', '‑', str_replace(' ', ' ', $string));
- }
+ function render()
+ {
+ return $this->tree;
+ }
- function render()
- {
- return $this->tree;
- }
+ function getBase()
+ {
+ return $this->base;
+ }
- function getBase()
- {
- return $this->base;
- }
+ function getAction()
+ {
+ // 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;
+ }
- function getAction()
- {
- // 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);
+ }
- if ($this->action) {
- return array("targets" => array($this->base), "action" => $this->action);
+ return null;
}
- return null;
- }
-
}
?>