* Calendar: using equally sized, non-overlaping columns for multiple events at the same time

- old overlapping events failed for more then 6 columns
- clicking on events opened the frist/underlaying event not the visible one
This commit is contained in:
Ralf Becker 2011-02-11 15:43:40 +00:00
parent 94c616bf12
commit ec7cc493ef

View File

@ -1409,8 +1409,11 @@ function open_edit(series)
// displaying all event columns of the day // displaying all event columns of the day
foreach($eventCols as $n => $eventCol) foreach($eventCols as $n => $eventCol)
{ {
$html .= $this->eventColWidget($eventCol,!$n ? 0 : 60-10*(count($eventCols)-$n), // equal sized columns
count($eventCols) == 1 ? 100 : (!$n ? 80 : 50),$indent."\t", $width = 95.0 / count($eventCols);
$left = 2.5 + $n * $width;
$html .= $this->eventColWidget($eventCol,$left,$width,$indent."\t",
$owner ? $owner : $this->user); $owner ? $owner : $this->user);
} }
$html .= $indent."</div>\n"; // calDayCol $html .= $indent."</div>\n"; // calDayCol
@ -1501,11 +1504,12 @@ function open_edit(series)
* @param string $indent string for correct indention * @param string $indent string for correct indention
* @param int $owner owner of the eventCol * @param int $owner owner of the eventCol
*/ */
function eventColWidget($events,$left,$width,$indent,$owner) function eventColWidget($events,$left,$width,$indent,$owner,$z_index=null)
{ {
if ($this->debug > 1 || $this->debug==='eventColWidget') $this->bo->debug_message('uiviews::eventColWidget(%1,left=%2,width=%3,)',False,$events,$left,$width); if ($this->debug > 1 || $this->debug==='eventColWidget') $this->bo->debug_message('uiviews::eventColWidget(%1,left=%2,width=%3,)',False,$events,$left,$width);
$html = $indent.'<div class="calEventCol" style="left: '.$left.'%; width:'.$width.'%;'. $html = $indent.'<div class="calEventCol" style="left: '.$left.'%; width:'.$width.'%;'.
(!is_null($z_index) ? ' z-index:'.$z_index.';' : '').
(!$this->use_time_grid ? ' top: '.$this->rowHeight.'%;' : '').'">'."\n"; (!$this->use_time_grid ? ' top: '.$this->rowHeight.'%;' : '').'">'."\n";
foreach($events as $event) foreach($events as $event)
{ {