2011-07-15 17:50:57 +02:00
< ? php
2011-07-19 19:12:36 +02:00
2011-10-11 19:47:49 +02:00
// Zeigt die Schichten an, die ein Benutzer belegt
2011-07-15 17:50:57 +02:00
function user_myshifts () {
2012-12-26 19:53:27 +01:00
global $LETZTES_AUSTRAGEN ;
global $user , $privileges ;
$msg = " " ;
2011-07-15 17:50:57 +02:00
2012-12-26 19:53:27 +01:00
if ( isset ( $_REQUEST [ 'id' ]) && in_array ( " user_shifts_admin " , $privileges ) && preg_match ( " /^[0-9] { 1,} $ / " , $_REQUEST [ 'id' ]) && sql_num_query ( " SELECT * FROM `User` WHERE `UID`= " . sql_escape ( $_REQUEST [ 'id' ])) > 0 ) {
$id = $_REQUEST [ 'id' ];
} else {
$id = $user [ 'UID' ];
}
2011-11-09 08:47:58 +01:00
2012-12-26 19:53:27 +01:00
list ( $shifts_user ) = sql_select ( " SELECT * FROM `User` WHERE `UID`= " . sql_escape ( $id ) . " LIMIT 1 " );
2011-11-09 08:47:58 +01:00
2012-12-28 20:55:13 +01:00
if ( $id != $user [ 'UID' ]) {
2012-12-26 19:53:27 +01:00
$msg .= info ( sprintf ( " You are viewing %s's shifts. " , $shifts_user [ 'Nick' ]), true );
2012-12-28 20:55:13 +01:00
if ( in_array ( 'admin_user' , $privileges ))
$msg .= buttons ( array ( button ( page_link_to ( 'admin_user' ) . '&id=' . $shifts_user [ 'UID' ], " Edit " . $shifts_user [ 'Nick' ], 'edit' )));
}
2011-11-09 08:47:58 +01:00
2012-12-26 19:53:27 +01:00
if ( isset ( $_REQUEST [ 'reset' ])) {
if ( $_REQUEST [ 'reset' ] == " ack " ) {
user_reset_ical_key ( $user );
success ( " Key geändert. " );
redirect ( page_link_to ( 'user_myshifts' ));
}
return template_render ( '../templates/user_myshifts_reset.html' , array ());
}
elseif ( isset ( $_REQUEST [ 'edit' ]) && preg_match ( " /^[0-9]* $ / " , $_REQUEST [ 'edit' ])) {
$id = $_REQUEST [ 'edit' ];
$shift = sql_select ( " SELECT `ShiftEntry`.`Comment`, `ShiftEntry`.`UID`, `Shifts`.*, `Room`.`Name`, `AngelTypes`.`name` as `angel_type` FROM `ShiftEntry` JOIN `AngelTypes` ON (`ShiftEntry`.`TID` = `AngelTypes`.`id`) JOIN `Shifts` ON (`ShiftEntry`.`SID` = `Shifts`.`SID`) JOIN `Room` ON (`Shifts`.`RID` = `Room`.`RID`) WHERE `ShiftEntry`.`id`= " . sql_escape ( $id ) . " AND `UID`= " . sql_escape ( $shifts_user [ 'UID' ]) . " LIMIT 1 " );
if ( count ( $shift ) > 0 ) {
$shift = $shift [ 0 ];
2011-07-19 19:56:15 +02:00
2012-12-26 19:53:27 +01:00
if ( isset ( $_REQUEST [ 'submit' ])) {
$comment = strip_request_item_nl ( 'comment' );
$user_source = User ( $shift [ 'UID' ]);
sql_query ( " UPDATE `ShiftEntry` SET `Comment`=' " . sql_escape ( $comment ) . " ' WHERE `id`= " . sql_escape ( $id ) . " LIMIT 1 " );
engelsystem_log ( " Updated " . $user_source [ 'Nick' ] . " 's shift " . $shift [ 'name' ] . " from " . date ( " y-m-d H:i " , $shift [ 'start' ]) . " to " . date ( " y-m-d H:i " , $shift [ 'end' ]) . " with comment " . $comment );
success ( " Schicht gespeichert. " );
redirect ( page_link_to ( 'user_myshifts' ));
}
2011-12-29 15:58:28 +01:00
2012-12-26 19:53:27 +01:00
return template_render ( '../templates/user_shifts_add.html' , array (
'angel' => $shifts_user [ 'Nick' ],
'date' => date ( " Y-m-d H:i " , $shift [ 'start' ]) . ', ' . shift_length ( $shift ),
'location' => $shift [ 'Name' ],
'title' => $shift [ 'name' ],
'type' => $shift [ 'angel_type' ],
'comment' => $shift [ 'Comment' ]
));
} else
redirect ( page_link_to ( 'user_myshifts' ));
}
elseif ( isset ( $_REQUEST [ 'cancel' ]) && preg_match ( " /^[0-9]* $ / " , $_REQUEST [ 'cancel' ])) {
$id = $_REQUEST [ 'cancel' ];
$shift = sql_select ( " SELECT * FROM `ShiftEntry` WHERE `id`= " . sql_escape ( $id ) . " AND `UID`= " . sql_escape ( $shifts_user [ 'UID' ]) . " LIMIT 1 " );
if ( count ( $shift ) > 0 ) {
$shift = $shift [ 0 ];
2012-12-29 15:38:55 +01:00
if (( $shift [ 'start' ] > time () + $LETZTES_AUSTRAGEN * 3600 ) || in_array ( 'user_shifts_admin' , $privileges )) {
2012-12-26 19:53:27 +01:00
sql_query ( " DELETE FROM `ShiftEntry` WHERE `id`= " . sql_escape ( $id ) . " LIMIT 1 " );
$msg .= success ( Get_Text ( " pub_myshifts_signed_off " ), true );
} else
$msg .= error ( Get_Text ( " pub_myshifts_too_late " ), true );
} else
redirect ( page_link_to ( 'user_myshifts' ));
}
$shifts = sql_select ( " SELECT * FROM `ShiftEntry` JOIN `Shifts` ON (`ShiftEntry`.`SID` = `Shifts`.`SID`) JOIN `Room` ON (`Shifts`.`RID` = `Room`.`RID`) WHERE `UID`= " . sql_escape ( $shifts_user [ 'UID' ]) . " ORDER BY `start` " );
2011-07-19 19:56:15 +02:00
2012-12-26 19:53:27 +01:00
$html = " " ;
2012-12-29 14:41:09 +01:00
$timesum = 0 ;
2012-12-26 19:53:27 +01:00
foreach ( $shifts as $shift ) {
if ( time () > $shift [ 'end' ])
$html .= '<tr class="done">' ;
else
$html .= '<tr>' ;
$html .= '<td>' . date ( " Y-m-d " , $shift [ 'start' ]) . '</td>' ;
$html .= '<td>' . date ( " H:i " , $shift [ 'start' ]) . ' - ' . date ( " H:i " , $shift [ 'end' ]) . '</td>' ;
$html .= '<td>' . $shift [ 'Name' ] . '</td>' ;
2012-12-28 20:55:13 +01:00
$html .= '<td>' . $shift [ 'name' ];
$needed_angel_types_source = sql_select ( " SELECT DISTINCT `AngelTypes`.* FROM `ShiftEntry` JOIN `AngelTypes` ON `ShiftEntry`.`TID`=`AngelTypes`.`id` WHERE `ShiftEntry`.`SID`= " . sql_escape ( $shift [ 'SID' ]) . " ORDER BY `AngelTypes`.`name` " );
foreach ( $needed_angel_types_source as $needed_angel_type ) {
$html .= '<br><b>' . $needed_angel_type [ 'name' ] . ':</b> ' ;
$users_source = sql_select ( " SELECT `User`.* FROM `ShiftEntry` JOIN `User` ON `ShiftEntry`.`UID`=`User`.`UID` WHERE `ShiftEntry`.`SID`= " . sql_escape ( $shift [ 'SID' ]) . " AND `ShiftEntry`.`TID`= " . sql_escape ( $needed_angel_type [ 'id' ]));
$shift_entries = array ();
foreach ( $users_source as $user_source ) {
2012-12-29 15:38:55 +01:00
if ( $user [ 'UID' ] == $user_source [ 'UID' ])
$shift_entries [] = '<b>' . $user_source [ 'Nick' ] . '</b>' ;
else
$shift_entries [] = $user_source [ 'Nick' ];
2012-12-28 20:55:13 +01:00
}
$html .= join ( " , " , $shift_entries );
2012-12-29 14:41:09 +01:00
$timesum += ( $shift [ 'end' ] - $shift [ 'start' ]) / ( 60 * 60 );
2012-12-28 20:55:13 +01:00
}
$html .= '</td>' ;
2012-12-26 19:53:27 +01:00
$html .= '<td>' . $shift [ 'Comment' ] . '</td>' ;
$html .= '<td>' ;
2012-12-27 14:46:55 +01:00
if ( $id == $user [ 'UID' ])
2012-12-29 13:58:59 +01:00
$html .= img_button ( page_link_to ( 'user_myshifts' ) . '&edit=' . $shift [ 'id' ], 'pencil' , 'edit' );
2012-12-27 14:46:55 +01:00
if (( $shift [ 'start' ] - time () > $LETZTES_AUSTRAGEN * 3600 ) || in_array ( 'user_shifts_admin' , $privileges ))
2012-12-29 13:58:59 +01:00
$html .= img_button ( page_link_to ( 'user_myshifts' ) . (( $id != $user [ 'UID' ]) ? '&id=' . $id : '' ) . '&cancel=' . $shift [ 'id' ], 'cross' , 'sign_off' );
2012-12-26 19:53:27 +01:00
$html .= '</td>' ;
$html .= '</tr>' ;
}
if ( $html == " " )
$html = '<tr><td>' . ucfirst ( Get_Text ( 'none' )) . '...</td><td></td><td></td><td></td><td></td><td>' . sprintf ( Get_Text ( 'pub_myshifts_goto_shifts' ), page_link_to ( 'user_shifts' )) . '</td></tr>' ;
2011-10-11 22:18:36 +02:00
2012-12-26 19:53:27 +01:00
return msg () . template_render ( '../templates/user_myshifts.html' , array (
'intro' => sprintf ( Get_Text ( 'pub_myshifts_intro' ), $LETZTES_AUSTRAGEN ),
'shifts' => $html ,
2012-12-29 14:41:09 +01:00
'time_sum' => $timesum ,
2012-12-26 19:53:27 +01:00
'msg' => $msg ,
'ical_text' => sprintf ( Get_Text ( 'inc_schicht_ical_text' ),
page_link_to_absolute ( 'ical' ) . '&key=' . $shifts_user [ 'ical_key' ],
page_link_to ( 'user_myshifts' ) . '&reset' ),
));
2011-07-19 19:12:36 +02:00
}
2012-12-12 00:22:30 +01:00
?>