2015-02-12 15:23:08 -05:00
< ? php
session_start ();
require_once ( " config.inc.php " );
2015-02-20 05:16:28 -05:00
require_once ( $yaptc_inc . " functions.inc.php " );
2015-02-12 15:23:08 -05:00
$yaptc_pagename = " Punch Log " ;
require_once ( $yaptc_inc . " header.inc.php " );
require_once ( $yaptc_inc . " menu.inc.php " );
2015-02-20 05:16:28 -05:00
if ( getSessionStatus () == false ) :
2015-02-19 11:02:13 -05:00
killSession ();
2015-02-20 05:16:28 -05:00
else : ?>
<!-- ********** BEGIN CONTENT ********** -->
2015-02-19 11:02:13 -05:00
2015-02-24 10:37:52 -05:00
2015-02-20 05:16:28 -05:00
< ? php
2015-02-12 15:23:08 -05:00
$userid = $_SESSION [ 'user_id' ];
2015-02-18 05:13:53 -05:00
$timenow = date ( 'Y-m-d H:i' );
// This is to get the current user status - in or out - and the notes and times associated for use in the form
2015-02-20 01:57:34 -05:00
$result = $yaptc_db -> prepare ( " SELECT punches.id as punchid, users.id as user, punches.intime as intime, punches.outtime as outtime, punches.notes as notes FROM punches INNER JOIN users ON punches.userid = users.id WHERE users.id = $userid ORDER BY punches.id DESC LIMIT 1 " );
2015-02-12 15:23:08 -05:00
$result -> execute ();
$last = $result -> fetchObject ();
2015-02-18 05:13:53 -05:00
2015-02-23 10:49:32 -05:00
// Let's build the page - this is the header with current status IF allowed
if ( $yaptc_allowadvancedpunch == 'yes' ) :
2015-02-12 15:23:08 -05:00
echo " <h2 class= \" content-subhead \" >Advanced Punch</h2> " ;
2015-02-18 05:13:53 -05:00
if ( ! isset ( $last -> user )) {
echo " <p>You do not appear to have any punches on record.</p> " ;
$status = " Out " ;
} else {
if ( ! empty ( $last -> outtime )) { $status = " Out " ; $statustime = $last -> outtime ; } else { $status = " In " ; $statustime = $last -> intime ; $punchid = $last -> punchid ; $notes = $last -> notes ; }
echo " <p>You have been Punched $status since " . date ( 'g:i a \o\n M jS, Y' , strtotime ( $statustime )) . " .</p> " ;
2015-02-12 15:23:08 -05:00
}
2015-02-18 05:13:53 -05:00
2015-02-12 15:23:08 -05:00
echo " <p>Use this form to enter a specific time on your punch. NOTE: changing the time from the current time will cause a flag on your log for the administrator to review, so we suggest you enter a reason why in the notes field (i.e. forgot punch, working from home, system down, etc).</p> " ;
echo " <form class= \" pure-form pure-form-stacked \" action= \" punchlog.php \" method= \" post \" > " ;
echo " <fieldset> " ;
2015-02-18 05:13:53 -05:00
echo " <label for= \" punchtime \" >Punch Time</label> " ;
echo " <input type= \" text \" name= \" punchtime \" placeholder= \" $timenow\ " maxlength = \ " 20 \" > " ;
2015-02-12 15:23:08 -05:00
echo " <label for= \" notes \" >Notes</label> " ;
2015-02-18 05:13:53 -05:00
if ( isset ( $notes )) {
2015-02-12 15:23:08 -05:00
echo " <input type= \" text \" name= \" notes \" placeholder= \" Enter notes if needed \" maxlength= \" 255 \" value= \" $notes\ " > " ;
2015-02-18 05:13:53 -05:00
} else {
echo " <input type= \" text \" name= \" notes \" placeholder= \" Enter notes if needed \" maxlength= \" 255 \" > " ;
}
2015-02-12 15:23:08 -05:00
echo " <div class= \" pure-controls \" > " ;
if ( $status == " In " ) {
echo " <button type= \" submit \" class= \" pure-button button-xlarge button-success pure-button-disabled \" >Punch IN</button> " ;
echo " <button type= \" submit \" class= \" pure-button button-xlarge button-error \" >Punch OUT</button> " ;
} else {
echo " <button type= \" submit \" class= \" pure-button button-xlarge button-success \" >Punch IN</button> " ;
echo " <button type= \" submit \" class= \" pure-button button-xlarge button-error pure-button-disabled \" >Punch OUT</button> " ;
}
echo " </div> " ;
2015-02-18 05:13:53 -05:00
// If the posted variables are not empty, we must be trying to insert a new punch. Use the form values to insert new record
if ( ! empty ( $_POST )) {
// Is the notes field set? If so, use, otherwise set to null
if ( isset ( $_POST [ 'notes' ])) { if ( ! empty ( $_POST [ 'notes' ])) { $p_notes = $_POST [ 'notes' ]; } else { $p_notes = NULL ; } } else { $p_notes = NULL ; }
// Is the punch time field set? If so, use, otherwise set to now
if ( isset ( $_POST [ 'punchtime' ])) {
if ( ! empty ( $_POST [ 'punchtime' ])) { $p_punchtime = $_POST [ 'punchtime' ] . ':00' ; $p_modified = " 1 " ; } else { $p_punchtime = $timenow . ':00' ; $p_modified = " 0 " ; }
} else { $p_punchtime = $timenow . ':00' ; $p_modified = " 0 " ; }
// Is the user currently punched in? If so, insert the punch out record, otherwise, insert a new punch in
2015-02-12 15:23:08 -05:00
if ( $status == " In " ) {
2015-02-18 05:13:53 -05:00
$query = " UPDATE punches SET outtime = :p_punchtime, notes = :p_notes, modified = :p_modified WHERE id = :p_punchid " ;
2015-02-20 01:57:34 -05:00
$stmt = $yaptc_db -> prepare ( $query );
2015-02-18 05:13:53 -05:00
$stmt -> execute ( array (
2015-02-12 15:23:08 -05:00
':p_punchid' => $punchid ,
':p_notes' => $p_notes ,
2015-02-18 05:13:53 -05:00
':p_punchtime' => $p_punchtime ,
':p_modified' => $p_modified ,
2015-02-12 15:23:08 -05:00
));
} else {
2015-02-18 05:13:53 -05:00
$query = " INSERT INTO punches (userid, notes, intime, modified) VALUES (:p_userid, :p_notes, :p_punchtime, :p_modified) " ;
2015-02-20 01:57:34 -05:00
$stmt = $yaptc_db -> prepare ( $query );
2015-02-18 05:13:53 -05:00
$stmt -> execute ( array (
':p_userid' => $_SESSION [ 'user_id' ],
2015-02-12 15:23:08 -05:00
':p_notes' => $p_notes ,
2015-02-18 05:13:53 -05:00
':p_punchtime' => $p_punchtime ,
':p_modified' => $p_modified ,
2015-02-12 15:23:08 -05:00
));
2015-02-18 05:13:53 -05:00
}
2015-02-12 15:23:08 -05:00
2015-02-18 05:13:53 -05:00
// And then send user back to this page to see the updates
2015-02-12 15:23:08 -05:00
header ( 'Location: ' . $_SERVER [ 'PHP_SELF' ]);
}
2015-02-18 05:13:53 -05:00
// Close out the form...
2015-02-12 15:23:08 -05:00
echo " </fieldset> " ;
echo " </form> " ;
2015-02-23 10:49:32 -05:00
endif ;
2015-02-12 15:23:08 -05:00
2015-02-24 10:37:52 -05:00
2015-02-12 15:23:08 -05:00
echo " <h2 class= \" content-subhead \" >Punch History</h2> " ;
echo " <p>Below is your full punch history, sorted newest to oldest.</p> " ;
2015-02-20 05:16:28 -05:00
?>
2015-02-12 15:23:08 -05:00
2015-02-24 10:37:52 -05:00
< table class = " pure-table " >
< thead >< tr >< th > In </ th >< th > Out </ th >< th > Name </ th >< th > Hours </ th >< th > Flagged </ th >< th > Notes </ th ></ tr ></ thead >
< tbody >< ? php foreach ( listPunches ( $db , $session_user [ " 0 " ][ " userid " ]) as $row ) : ?>
< tr >< td >< ? php echo $row [ 'intime' ]; ?> </td><td><?php echo $row['outtime']; ?></td><td><?php echo $row['lastname'] . ", " . $row['firstname']; ?></td><td><?php echo $row['punchhours']; ?></td><td><?php echo $row['modified']; ?></td><td><?php echo $row['notes']; ?></td></tr><?php endforeach; ?>
</ tbody >
</ table >
2015-02-12 15:23:08 -05:00
2015-02-20 05:16:28 -05:00
<!-- ********** END CONTENT ********** -->
< ? php endif ; require_once ( $yaptc_inc . " footer.inc.php " ); ?>