From 7c7b2d3b54084319ed0d6392f9ea13e00173f011 Mon Sep 17 00:00:00 2001 From: Jan-Philipp Litza Date: Sat, 29 Dec 2012 13:58:59 +0100 Subject: polished code and display of shiftview and used more icons --- includes/pages/user_shifts.php | 94 +++++++++++++++++++++++------------------- 1 file changed, 52 insertions(+), 42 deletions(-) (limited to 'includes/pages/user_shifts.php') diff --git a/includes/pages/user_shifts.php b/includes/pages/user_shifts.php index c26ad668..7db94247 100644 --- a/includes/pages/user_shifts.php +++ b/includes/pages/user_shifts.php @@ -350,7 +350,7 @@ function view_user_shifts() { FROM `Shifts` INNER JOIN `Room` USING (`RID`) LEFT JOIN (SELECT COUNT(*) AS special_needs , nat3.`shift_id` FROM `NeededAngelTypes` AS nat3 WHERE `shift_id` IS NOT NULL GROUP BY nat3.`shift_id`) AS nat2 ON nat2.`shift_id` = `Shifts`.`SID` - INNER JOIN `NeededAngelTypes` AS nat ON nat.`count` != 0 AND ((nat2.`special_needs` > 0 AND nat.`shift_id` = `Shifts`.`SID`) OR ((nat2.`special_needs` = 0 OR nat2.`special_needs` IS NULL) AND nat.`room_id` = `RID`)) + INNER JOIN `NeededAngelTypes` AS nat ON nat.`count` != 0 AND nat.`angel_type_id` IN (" . implode(',', $_SESSION['user_shifts']['types']) . ") AND ((nat2.`special_needs` > 0 AND nat.`shift_id` = `Shifts`.`SID`) OR ((nat2.`special_needs` = 0 OR nat2.`special_needs` IS NULL) AND nat.`room_id` = `RID`)) LEFT JOIN (SELECT se.`SID`, se.`TID`, COUNT(*) as count FROM `ShiftEntry` AS se GROUP BY se.`SID`, se.`TID`) AS entries ON entries.`SID` = `Shifts`.`SID` AND entries.`TID` = nat.`angel_type_id` WHERE `Shifts`.`RID` IN (" . implode(',', $_SESSION['user_shifts']['rooms']) . ") AND DATE(FROM_UNIXTIME(`start`)) IN ('" . implode("','", $_SESSION['user_shifts']['days']) . "') "; @@ -384,60 +384,71 @@ function view_user_shifts() { ) */ if(count($_SESSION['user_shifts']['days'])==1 && $_SESSION['user_shifts']['new_style']) { - $myrooms=$rooms; - foreach($myrooms as $k => $v) { + $myrooms = $rooms; + + // delete un-selected rooms from array + foreach($myrooms as $k => $v) if(array_search($v["id"],$_SESSION['user_shifts']['rooms'])===FALSE) unset($myrooms[$k]); - } + $first=date("U",strtotime($_SESSION['user_shifts']['days'][0]." 00:00:00")); $last=date("U",strtotime($_SESSION['user_shifts']['days'][0]." 23:59:59")); $maxshow=24*4; $block=array(); $todo=array(); - foreach($myrooms as $room) { - $rid=$room["id"]; - $block[$rid] = array_fill(0, $maxshow, 0); - foreach($shifts as $shift) { - if($shift["RID"]==$rid) { - // calculate number of parallel shifts in each timeslot for one room - $blocks=($shift["end"]-$shift["start"])/(15*60); - $firstblock=floor(($shift["start"]-$first)/(15*60)); - for($i=$firstblock;$i<$blocks+$firstblock && $i < $maxshow;$i++) { - $block[$rid][$i]++; - } - } - } + + // initialize $block array + foreach($myrooms as $room) + $block[$room["id"]] = array_fill(0, $maxshow, 0); + + // calculate number of parallel shifts in each timeslot for each room + foreach($shifts as $shift) { + $rid = $shift["RID"]; + $blocks = ($shift["end"]-$shift["start"]) / (15*60); + $firstblock = floor(($shift["start"]-$first) / (15*60)); + for($i = $firstblock; $i < $blocks + $firstblock && $i < $maxshow; $i++) + $block[$rid][$i]++; } - $shifts_table=""; - foreach($myrooms as $room) { - $rid=$room["id"]; + + $shifts_table = "
-
"; + foreach($myrooms as $key => $room) { + $rid = $room["id"]; + if(array_sum($block[$rid]) == 0) { + // do not display columns without entries + unset($block[$rid]); + unset($myrooms[$key]); + continue; + } $colspan = call_user_func_array('max', $block[$rid]); if($colspan == 0) $colspan = 1; $todo[$rid] = array_fill(0, $maxshow, $colspan); $shifts_table.=" 1)? ' colspan="' . $colspan . '"' : '') . ">${room['name']}\n"; } + unset($block, $blocks, $firstblock, $colspan, $key, $room); + $shifts_table.=""; - for($i=0;$i<$maxshow;$i++) { - $thistime=$first+($i*15*60); - if($thistime%(60*60)==0) { - $shifts_table.=""; + for($i = 0; $i < $maxshow; $i++) { + $thistime = $first + ($i*15*60); + if($thistime%(60*60) == 0) { + $shifts_table .= ""; } else { - $shifts_table.=""; + $shifts_table .= ""; } foreach($myrooms as $room) { - $rid=$room["id"]; + $rid = $room["id"]; foreach($shifts as $shift) { - if($shift["RID"]==$rid) { + if($shift["RID"] == $rid) { if(floor($shift["start"]/(15*60)) == $thistime/(15*60)) { - $blocks=($shift["end"]-$shift["start"])/(15*60); - if($blocks<1) $blocks=1; + $blocks = ($shift["end"]-$shift["start"])/(15*60); + if($blocks < 1) + $blocks = 1; // qqqqqq $is_free = false; $shifts_row = $shift['name']; if (in_array('admin_shifts', $privileges)) - $shifts_row .= ' [edit][x]'; - $shifts_row.= '
'; + $shifts_row .= ' ' . img_button('?p=user_shifts&edit_shift=' . $shift['SID'], 'pencil', 'edit') . img_button('?p=user_shifts&delete_shift=' . $shift['SID'], 'cross', 'delete'); + $shifts_row .= '
'; $query = "SELECT `NeededAngelTypes`.`count`, `AngelTypes`.`id`, `AngelTypes`.`restricted`, `UserAngelTypes`.`confirm_user_id`, `AngelTypes`.`name`, `UserAngelTypes`.`user_id` FROM `NeededAngelTypes` JOIN `AngelTypes` ON (`NeededAngelTypes`.`angel_type_id` = `AngelTypes`.`id`) @@ -460,7 +471,7 @@ function view_user_shifts() { $entries = sql_select("SELECT * FROM `ShiftEntry` JOIN `User` ON (`ShiftEntry`.`UID` = `User`.`UID`) WHERE `SID`=" . sql_escape($shift['SID']) . " AND `TID`=" . sql_escape($angeltype['id']) . " ORDER BY `Nick`"); $entry_list = array (); foreach ($entries as $entry) { - if($entry['Gekommen']==1) + if($entry['Gekommen'] == 1) $style="font-weight:bold;"; else $style="font-weight:normal;"; @@ -490,7 +501,7 @@ function view_user_shifts() { // User shift admins may join anybody in every shift $user_may_join_shift |= in_array('user_shifts_admin', $privileges); if ($user_may_join_shift) - $entry_list[] = '' . $inner_text . ' »'; + $entry_list[] = '' . $inner_text . ' »'; else { if(time() > $shift['start']) { $entry_list[] = $inner_text . ' (vorbei)'; @@ -510,7 +521,7 @@ function view_user_shifts() { $shifts_row .= '
'; } if (in_array('user_shifts_admin', $privileges)) { - $shifts_row .= 'Weitere Helfer eintragen »'; + $shifts_row .= 'Weitere Helfer eintragen »'; } } $shifts_table.='"; - for($j=0;$j<$blocks&& $i+$j < $maxshow;$j++) { + for($j=0; $j < $blocks && $i+$j < $maxshow; $j++) { $todo[$rid][$i+$j]--; } } } } // fill up row with empty '; + while($todo[$rid][$i]-- > 0) + $shifts_table .= ''; } - $shifts_table.="\n"; + $shifts_table .= "\n"; } - $shifts_table.='
-
".date("H:i",$thistime)."
" . date("H:i",$thistime) . "
'; @@ -518,19 +529,19 @@ function view_user_shifts() { $shifts_table.=$shifts_row; } $shifts_table.=" - while($todo[$rid][$i]--) - $shifts_table.='
'; + $shifts_table .= ''; // qqq } else { $shifts_table = array(); @@ -548,7 +559,7 @@ function view_user_shifts() { ); if (in_array('admin_shifts', $privileges)) - $shift_row['entries'] .= ' [edit] [x]'; + $shift_row['info'] .= ' ' . img_button('?p=user_shifts&edit_shift=' . $shift['SID'], 'pencil', 'edit') . img_button('?p=user_shifts&delete_shift=' . $shift['SID'], 'cross', 'delete'); $shift_row['entries'] .= '
'; $is_free = false; $shift_has_special_needs = 0 < sql_num_query("SELECT `id` FROM `NeededAngelTypes` WHERE `shift_id` = " . $shift['SID']); @@ -573,7 +584,7 @@ function view_user_shifts() { $entry_list = array (); foreach ($entries as $entry) { if (in_array('user_shifts_admin', $privileges)) - $entry_list[] = '' . $entry['Nick'] . ' [x]'; + $entry_list[] = '' . $entry['Nick'] . ' ' . img_button(page_link_to('user_shifts') . '&entry_id=' . $entry['id'], 'cross', 'delete'); else $entry_list[] = $entry['Nick']; } @@ -623,7 +634,6 @@ function view_user_shifts() { } if (($is_free && in_array(0, $_SESSION['user_shifts']['filled'])) || (!$is_free && in_array(1, $_SESSION['user_shifts']['filled']))) { $shifts_table[] = $shift_row; - $row_count++; $ical_shifts[] = $shift; } } -- cgit v1.2.3-54-g00ecf