X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=gosa-core%2Finclude%2Fclass_sortableListing.inc;h=3af979b285c2ac88fa4a9f016fb592e53e15da6c;hb=928e5d63d17e08ba4b364838c75509d454d4fa74;hp=9ea6d40eebcdd508b8c146c382221db2527daa32;hpb=7b6cc3fcd2298d95bb246f950561efa69af62c7c;p=gosa.git diff --git a/gosa-core/include/class_sortableListing.inc b/gosa-core/include/class_sortableListing.inc index 9ea6d40ee..3af979b28 100644 --- a/gosa-core/include/class_sortableListing.inc +++ b/gosa-core/include/class_sortableListing.inc @@ -1,9 +1,9 @@ setListData($data, $displayData); + + // Get list of used IDs + if(!session::is_set('sortableListing_USED_IDS')){ + session::set('sortableListing_USED_IDS',array()); + } + $usedIds = session::get('sortableListing_USED_IDS'); + + // Generate instance wide unique ID + $id = ""; + while($id == "" || in_array($id, $usedIds)){ + + // Wait 1 msec to ensure that we definately get a new id + if($id != "") usleep(1); + $tmp= gettimeofday(); + $id = 'l'.md5(microtime().$tmp['sec']); + } + + // Only keep the last 10 list IDsi + $usedIds = array_slice($usedIds, count($usedIds) -10, 10); + $usedIds[] = $id; + session::set('sortableListing_USED_IDS',$usedIds); + $this->id = $id; + + // Set reorderable flag + $this->reorderable= $reorderable; + if (!$reorderable) { + $this->sortData(); + } + } + + public function setReorderable($bool) + { + $this->reorderable= $bool; + } + + public function setDefaultSortColumn($id) + { + $this->sortColumn = $id; + } + + public function setListData($data, $displayData= null) + { // Save data to display $this->setData($data); if (!$displayData) { $displayData= array(); - foreach ($data as $value) { - $displayData[]= array($value); + foreach ($data as $key => $value) { + $displayData[$key]= array("data" => array($value)); } - } else { - $this->setDisplayData($displayData); } - - // Generate instance wide unique ID - $tmp= gettimeofday(); - $this->id= 'l'.md5($tmp['sec']); + $this->setDisplayData($displayData); } - function setData($data) + private function setData($data) { $this->data= $data; } - function setDisplayData($data) + private function setDisplayData($data) { if (!is_array($data)) { - die ("sortableList needs an array as data!"); + trigger_error ("sortableList needs an array as data!"); } // Transfer information - $this->displayData= $data; + $this->displayData= array(); + $this->modes= array(); + $this->mapping= array(); + foreach ($data as $key => $value) { + $this->displayData[]= $value['data']; + if (isset($value['mode'])) { + $this->modes[]= $value['mode']; + } + } + $this->keys= array_keys($data); // Create initial mapping - $this->mapping= array_keys($data); + if(count($this->keys)){ + $this->mapping= range(0, abs(count($this->keys)-1)); + } $this->current_mapping= $this->mapping; // Find the number of coluns @@ -92,84 +151,101 @@ class sortableListing { } else { $this->columns= 1; } + + // Preset sort orders to 'down' + for ($column= 0; $column<$this->columns; $column++) { + if(!isset($this->sortDirection[$column])){ + $this->sortDirection[$column]= true; + } + } } - function setWidth($width) + public function setWidth($width) { $this->width= $width; } - function setInstantDelete($flag) + public function setInstantDelete($flag) { $this->instantDelete= $flag; } - function setEditable($flag) + public function setColorAlternate($flag) + { + $this->colorAlternate= $flag; + } + + + public function setEditable($flag) { $this->editable= $flag; } - function setDeleteable($flag) + public function setDeleteable($flag) { $this->deleteable= $flag; } - function setHeight($height) + public function setHeight($height) { $this->height= $height; } - function setCssClass($css) + public function setCssClass($css) { $this->cssclass= $css; } - function setHeader($header) + public function setHeader($header) { $this->header= $header; } - function setColspecs($specs) + public function setColspecs($specs) { $this->colspecs= $specs; } - function render() + public function render() { - $result= "
\n"; - $result.= "cssclass)?" class='".$this->cssclass."'":"").">\n"; + $result= "
\n"; + $result.= "
cssclass)?" class='".$this->cssclass."'":"").">\n"; $action_width= 0; if (strpos($this->acl, 'w') === false) { - $edit_image= $this->editable?""._("Edit")."":""; + $edit_image= $this->editable?image("images/lists/edit-grey.png"):""; } else { - $edit_image= $this->editable?"":""; + $edit_image= $this->editable?image('images/lists/edit.png', "%ID", _("Edit this entry")):""; } if (strpos($this->acl, 'd') === false) { - $delete_image= $this->deleteable?""._("Delete")."":""; + $delete_image= $this->deleteable?image('images/lists/trash-grey.png'):""; } else { - $delete_image= $this->deleteable?"":""; + $delete_image= $this->deleteable?image('images/lists/trash.png', "%ID", _("Delete this entry")):""; } // Do we need colspecs? - $action_width= ($this->editable?20:0) + ($this->deleteable?20:0); + $action_width= ($this->editable?30:0) + ($this->deleteable?30:0); if ($this->colspecs) { $result.= " \n"; for ($i= 0; $i<$this->columns; $i++) { - $result.= " \n"; + if(isset($this->colspecs[$i]) && $this->colspecs[$i] != '*'){ + $result.= " \n"; + }else{ + $result.= " \n"; + } } // Extend by another column if we've actions specified if ($action_width) { - $result.= " \n"; + $result.= " \n"; } $result.= " \n"; } @@ -177,8 +253,20 @@ class sortableListing { // Do we need a header? if ($this->header) { $result.= " \n \n"; + $first= " style='border-left:0'"; for ($i= 0; $i<$this->columns; $i++) { - $result.= " "; + $link= "href='?plug=".$_GET['plug']."&PID=".$this->id."&act=SORT_$i'"; + $sorter= ""; + if ($i == $this->sortColumn){ + $sorter= " ".image("images/lists/sort-".($this->sortDirection[$i]?"up":"down").".png", null, $this->sortDirection[$i]?_("Sort ascending"):_("Sort descending")); + } + + if ($this->reorderable) { + $result.= " ".(isset($this->header[$i])?$this->header[$i]:"").""; + } else { + $result.= " ".(isset($this->header[$i])?$this->header[$i]:"")."$sorter"; + } + $first= ""; } if ($action_width) { $result.= ""; @@ -188,46 +276,115 @@ class sortableListing { // Render table body if we've read permission $result.= " \n"; + $reorderable= $this->reorderable?"":" style='cursor:default'"; if (strpos($this->acl, 'r') !== false) { foreach ($this->mapping as $nr => $row) { - $result.= " \n"; + $editable= $this->editable?" onClick='$(\"edit_".$this->id."_$nr\").click()'":""; + + $id= ""; + if (isset($this->modes[$row])) { + switch ($this->modes[$row]) { + case LIST_DISABLED: + $id= " sortableListItemDisabled"; + $editable= ""; + break; + case LIST_MARKED: + $id= " sortableListItemMarked"; + break; + } + } + + $result.= " \n"; + $first= " style='border:0'"; + foreach ($this->displayData[$row] as $column) { - $result.= " \n"; + $result.= " ".$column."\n"; + $first= ""; } + if ($action_width) { $result.= ""; } + $result.= " \n"; } - } else { - $result.= " \n"; } + // Add spacer + $result.= " "; + $num= $action_width?$this->columns:$this->columns-1; + for ($i= 0; $i<$num; $i++) { + $result.= ""; + } + $result.= "\n"; + $result.= " \n
".(isset($this->header[$i])?$this->header[$i]:"")." 
".htmlentities($column)."".str_replace('%ID', "edit_".$this->id."_$nr", $edit_image). str_replace('%ID', "del_".$this->id."_$nr", $delete_image)."
\n
\n"; +# $result.= " \n"; + $result.= " \n"; $result.= " \n"; // Append script stuff if needed $result.= ''; return $result; } - function update() + public function update() + { + + // Filter GET with "act" attributes + if (!$this->reorderable){ + if(isset($_GET['act']) && isset($_GET['PID']) && $this->id == $_GET['PID']) { + + $key= validate($_GET['act']); + if (preg_match('/^SORT_([0-9]+)$/', $key, $match)) { + + // Switch to new column or invert search order? + $column= $match[1]; + if ($this->sortColumn != $column) { + $this->sortColumn= $column; + } else { + $this->sortDirection[$column]= !$this->sortDirection[$column]; + } + + } + } + + // Update mapping according to sort parameters + $this->sortData(); + } + } + + + public function save_object() { + // Do not do anything if this is not our PID, or there's even no PID available... + if(isset($_REQUEST['PID']) && $_REQUEST['PID'] != $this->id) { + return; + } + // Do not do anything if we're not posted - or have no permission if (strpos($this->acl, 'w') !== false && isset($_POST['reorder_'.$this->id])){ + if (isset($_POST['position_'.$this->id]) && is_numeric($_POST['position_'.$this->id])) { + $this->scrollPosition= $_POST['position_'.$this->id]; + } + // Move requested? $move= $_POST['reorder_'.$this->id]; if ($move != "") { @@ -245,11 +402,22 @@ class sortableListing { } // Delete requested? + $this->action = ""; if (strpos($this->acl, 'd') !== false){ foreach ($_POST as $key => $value) { - if (preg_match('/^del_'.$this->id.'_([0-9]+)_x.*$/', $key, $matches)) { + if (preg_match('/^del_'.$this->id.'_([0-9]+)$/', $key, $matches)) { $this->active_index= $this->mapping[$matches[1]]; + + // Ignore request if mode requests it + if (isset($this->modes[$this->active_index]) && $this->modes[$this->active_index] == LIST_DISABLED) { + $this->active_index= null; + continue; + } + + // Set action $this->action= "delete"; + + // Remove value if requested if ($this->instantDelete) { $this->deleteEntry($this->active_index); } @@ -260,8 +428,15 @@ class sortableListing { // Edit requested? if (strpos($this->acl, 'w') !== false){ foreach ($_POST as $key => $value) { - if (preg_match('/^edit_'.$this->id.'_([0-9]+)_x.*$/', $key, $matches)) { + if (preg_match('/^edit_'.$this->id.'_([0-9]+)$/', $key, $matches)) { $this->active_index= $this->mapping[$matches[1]]; + + // Ignore request if mode requests it + if (isset($this->modes[$this->active_index]) && $this->modes[$this->active_index] == LIST_DISABLED) { + $this->active_index= null; + continue; + } + $this->action= "edit"; } } @@ -269,7 +444,7 @@ class sortableListing { } - function getAction() + public function getAction() { // Do not do anything if we're not posted if(!isset($_POST['reorder_'.$this->id])) { @@ -288,7 +463,7 @@ class sortableListing { } - function deleteEntry($id) + private function deleteEntry($id) { // Remove mapping $index= array_search($id, $this->mapping); @@ -300,27 +475,116 @@ class sortableListing { } - function getMaintainedData() + public function getMaintainedData() { $tmp= array(); - foreach ($this->mapping as $src => $dst) { - $tmp[$src]= $this->data[$dst]; + $realKey = $this->keys[$dst]; + $tmp[$realKey] = $this->data[$realKey]; } - return $tmp; } - function isModified() + public function isModified() { return $this->modified; } - function setAcl($acl) + public function setAcl($acl) { $this->acl= $acl; } + + public function sortData() + { + if(!count($this->data)) return; + + // Extract data + $tmp= array(); + foreach($this->displayData as $item) { + if (isset($item[$this->sortColumn])){ + $tmp[]= $item[$this->sortColumn]; + } else { + $tmp[]= ""; + } + } + + // Sort entries + if ($this->sortDirection[$this->sortColumn]) { + asort($tmp); + } else { + arsort($tmp); + } + + // Adapt mapping accordingly + $this->mapping= array(); + foreach ($tmp as $key => $value) { + $this->mapping[]= $key; + } + } + + + public function addEntry($entry, $displayEntry= null, $key= null) + { + // Only add if not already there + if (!$key) { + if (in_array($entry, $this->data)) { + return; + } + } else { + if (isset($this->data[$key])) { + return; + } + } + + // Prefill with default value if not specified + if (!$displayEntry) { + $displayEntry= array('data' => array($entry)); + } + + // Append to data and mapping + if ($key) { + $this->data[$key]= $entry; + $this->keys[]= $key; + } else { + $this->data[]= $entry; + $this->keys[]= count($this->mapping); + } + $this->displayData[]= $displayEntry['data']; + $this->mapping[]= count($this->mapping); + $this->modified= true; + + // Find the number of coluns + reset($this->displayData); + $first= current($this->displayData); + if (is_array($first)) { + $this->columns= count($first); + } else { + $this->columns= 1; + } + + // Preset sort orders to 'down' + for ($column= 0; $column<$this->columns; $column++) { + if(!isset($this->sortDirection[$column])){ + $this->sortDirection[$column]= true; + } + } + + + // Sort data after we've added stuff + $this->sortData(); + } + + + public function getKey($index) { + return isset($this->keys[$index])?$this->keys[$index]:null; + } + + public function getData($index) { + $realkey = $this->keys[$index]; + return($this->data[$realkey]); + } }