2005-01-24 18:00:03 +00:00
< ?
2025-01-29 03:30:48 +00:00
/*
* This file is part of the 'Science Fair In A Box' project
* SFIAB Website : http :// www . sfiab . ca
*
* Copyright ( C ) 2005 Sci - Tech Ontario Inc < info @ scitechontario . org >
* Copyright ( C ) 2005 James Grant < james @ lightbox . org >
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public
* License as published by the Free Software Foundation , version 2.
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; see the file COPYING . If not , write to
* the Free Software Foundation , Inc . , 59 Temple Place - Suite 330 ,
* Boston , MA 02111 - 1307 , USA .
*/
2005-01-24 18:00:03 +00:00
?>
2004-11-30 23:18:35 +00:00
< ?
2025-01-29 03:30:48 +00:00
require ( 'common.inc.php' );
require ( './config/signaturepage_or_permissionform.php' );
include 'register_participants.inc.php' ;
include 'projects.inc.php' ;
// authenticate based on email address and registration number from the SESSION
if ( ! $_SESSION [ 'email' ]) {
header ( 'Location: register_participants.php' );
2004-11-30 23:18:35 +00:00
exit ;
2025-01-29 03:30:48 +00:00
}
if ( ! ( $_SESSION [ 'registration_number' ] && $_SESSION [ 'registration_id' ])) {
header ( 'Location: register_participants.php' );
2004-11-30 23:18:35 +00:00
exit ;
2025-01-29 03:30:48 +00:00
}
global $pdo ;
$q = $pdo -> prepare ( 'SELECT registrations.status AS status, registrations.id AS regid, students.id AS studentid, students.firstname FROM registrations,students '
2025-02-09 17:24:37 +00:00
. " WHERE students.email=? "
. " AND registrations.num=? "
. " AND registrations.id=? "
2025-01-29 03:30:48 +00:00
. 'AND students.registrations_id=registrations.id '
2025-02-09 17:24:37 +00:00
. 'AND registrations.year=?'
. 'AND students.year=?' );
$q -> execute ([ $_SESSION [ 'email' ], $_SESSION [ 'registration_number' ], $_SESSION [ 'registration_id' ], $config [ 'FAIRYEAR' ], $config [ 'FAIRYEAR' ]]);
2025-01-03 15:15:13 -05:00
show_pdo_errors_if_any ( $pdo );
2004-11-30 23:18:35 +00:00
2025-01-29 03:30:48 +00:00
if ( $q -> rowCount () == 0 ) {
header ( 'Location: register_participants.php?action=logout' );
2004-11-30 23:18:35 +00:00
exit ;
2025-01-29 03:30:48 +00:00
}
$r = $q -> fetch ( PDO :: FETCH_OBJ );
send_header ( 'Participant Registration - Summary' );
// only display the named greeting if we have their name
if ( $r -> firstname ) {
echo i18n ( 'Hello <b>%1</b>' , array ( $r -> firstname ));
echo '<br />' ;
}
echo '<br />' ;
if ( registrationFormsReceived ()) {
// now select their project number
2025-02-09 17:24:37 +00:00
$q = $pdo -> prepare ( " SELECT projectnumber FROM projects WHERE registrations_id=? AND year=? " );
$q -> execute ([ $_SESSION [ 'registration_id' ], $config [ 'FAIRYEAR' ]]);
2025-01-29 03:30:48 +00:00
$projectinfo = $q -> fetch ( PDO :: FETCH_OBJ );
if ( $r -> status == 'complete' ) {
echo i18n ( 'Congratulations, you are successfully registered for the %1. No further changes may be made to any of your forms.' , array ( $config [ 'fairname' ]));
} else if ( $r -> status == 'paymentpending' ) {
echo i18n ( 'We have received your forms but are missing your registration fee. You are NOT registered for the fair until your registration fee has been received' );
2005-01-13 18:50:07 +00:00
}
2025-01-29 03:30:48 +00:00
echo '<br />' ;
echo i18n ( 'Your project number is:' );
2006-09-17 16:26:12 +00:00
echo " <span style= \" font-size: 2.0em; font-weight: bold \" > $projectinfo->projectnumber </span> " ;
2025-01-29 03:30:48 +00:00
} else {
echo i18n ( 'Please use the checklist below to complete your registration. Click on an item in the table to edit that information. When you have entered all information, the <b>Status</b> field will change to <b>Complete</b>' );
}
echo '<br />' ;
echo '<br />' ;
echo '<table><tr><td>' ;
echo '<table class="summarytable">' ;
echo '<tr><th>' . i18n ( 'Registration Item' ) . '</th><th>' . i18n ( 'Status' ) . '</th></tr>' ;
// participant information
echo '<tr><td>' ;
echo '<a href="register_participants_students.php">' ;
echo i18n ( 'Student Information' );
echo '</a>' ;
echo '</td><td>' ;
// check to see if its complete
$statusstudent = studentStatus ();
echo outputStatus ( $statusstudent );
echo '</td></tr>' ;
// participant emergency contact information
echo '<tr><td>' ;
if ( $statusstudent == 'complete' )
echo '<a href="register_participants_emergencycontact.php">' ;
echo i18n ( 'Emergency Contact Information' );
if ( $statusstudent == 'complete' )
echo '</a>' ;
echo '</td><td>' ;
// check to see if its complete
$statusemergencycontact = emergencycontactStatus ();
echo outputStatus ( $statusemergencycontact );
echo '</td></tr>' ;
// project information - project requires students, so only show the link if the students is complete
echo '<tr><td>' ;
if ( $statusstudent == 'complete' )
echo '<a href="register_participants_project.php">' ;
echo i18n ( 'Project Information' );
if ( $statusstudent == 'complete' )
echo '</a>' ;
echo '</td><td>' ;
// check to see if its complete
$statusproject = projectStatus ();
echo outputStatus ( $statusproject );
echo '</td></tr>' ;
if ( $config [ 'participant_mentor' ] == 'yes' ) {
// mentor information
echo '<tr><td>' ;
echo '<a href="register_participants_mentor.php">' ;
echo i18n ( 'Mentor Information' );
echo '</a>' ;
echo '</td><td>' ;
// check to see if its complete
$statusmentor = mentorStatus ();
echo outputStatus ( $statusmentor );
echo '</td></tr>' ;
} else {
// if mentorship isnt required, then assume its complete so the checks below will still work properly
$statusmentor = 'complete' ;
}
2006-09-17 16:26:12 +00:00
2025-01-29 03:30:48 +00:00
// safety information
echo '<tr><td>' ;
echo '<a href="register_participants_safety.php">' ;
echo i18n ( 'Safety Information' );
echo '</a>' ;
echo '</td><td>' ;
// check to see if its complete
$statussafety = safetyStatus ();
echo outputStatus ( $statussafety );
echo '</td></tr>' ;
if ( $config [ 'tours_enable' ] == 'yes' ) {
echo '<tr><td>' ;
echo '<a href="register_participants_tours.php">' ;
echo i18n ( 'Tour Selection' );
echo '</a>' ;
echo '</td><td>' ;
// check to see if its complete
$statustour = tourStatus ();
echo outputStatus ( $statustour );
echo '</td></tr>' ;
} else {
$statustour = 'complete' ;
}
2007-01-09 19:05:23 +00:00
2025-01-29 03:30:48 +00:00
// name check
echo '<tr><td>' ;
echo '<a href="register_participants_namecheck.php">' ;
echo i18n ( 'Double Check your Name' );
echo '</a>' ;
echo '</td><td>' ;
// check to see if its complete
$statusnamecheck = namecheckStatus ( $_SESSION [ 'registration_id' ]);
echo outputStatus ( $statusnamecheck );
echo '</td></tr>' ;
2025-02-09 18:41:20 +00:00
2025-01-29 03:30:48 +00:00
// FIXME: this should be a global detection so we can use the results elsewhere, especially for all the reports!
if ( function_exists ( 'pdf_new' ))
$sigfile = 'register_participants_signature.php' ;
else if ( file_exists ( 'tcpdf/tcpdf.php' ))
$sigfile = 'register_participants_signature_tcpdf.php' ;
else
$sigfile = '' ;
// signature page
if ( $statusstudent == 'complete' && $statusproject == 'complete' && $statusmentor == 'complete' && $statussafety == 'complete' && $statusemergencycontact == 'complete' && $statustour == 'complete' && $statusnamecheck == 'complete' )
$all_complete = true ;
else
$all_complete = false ;
echo '<tr><td>' ;
2025-02-09 18:41:20 +00:00
if ( $all_complete == true ){
echo " <a href= \" /content/register_participants_signature.php \" > " ;
echo i18n ( " $participationform " );
2025-01-29 03:30:48 +00:00
echo '</a>' ;
2025-02-09 18:41:20 +00:00
}
else {
echo " Complete the above information to access " . $participationform ;
}
// echo i18n("$participationform");
// if ($all_complete == true)
// echo '</a>';
// else
// echo '<br /><font color="red">(' . i18n('Available when ALL above sections are "Complete"') . ')</font>';
2025-01-29 03:30:48 +00:00
echo '</td><td>' ;
echo i18n ( 'Print' );
// check to see if its complete
echo '</td></tr>' ;
// received information
2025-02-09 18:41:20 +00:00
// echo '<tr><td>' . i18n("$participationform Received") . '</td><td>';
// if (registrationFormsReceived())
// echo outputStatus('complete');
// else
// echo outputStatus('incomplete');
// // check to see if its complete
// echo '</td></tr>';
2025-01-29 03:30:48 +00:00
echo '</table>' ;
echo '</td>' ;
echo '<td align="left" width="50%">' ;
if ( $config [ 'specialawardnomination' ] != 'none' ) {
echo '<table class="summarytable">' ;
echo '<tr><th>' . i18n ( 'Special Award Nominations' ) . '</th></tr>' ;
2005-05-12 15:47:21 +00:00
2007-03-05 02:26:56 +00:00
$sp_proj_ok = true ;
2025-01-29 03:30:48 +00:00
if ( $statusstudent == 'incomplete' || $statusproject == 'incomplete' ) {
2007-03-05 02:26:56 +00:00
$sp_proj_ok = false ;
}
2007-01-21 05:45:36 +00:00
$special_awards_open = false ;
2025-01-29 03:30:48 +00:00
if ( $config [ 'specialawardnomination_aftersignatures' ] == 'no' ) {
2007-01-21 05:45:36 +00:00
$special_awards_open = true ;
} else {
$special_awards_open = ( registrationFormsReceived ()) ? true : false ;
}
2025-01-29 03:30:48 +00:00
if ( $special_awards_open == true ) {
if ( $config [ 'specialawardnomination' ] == 'date' ) {
2025-02-09 17:24:37 +00:00
$q = $pdo -> prepare ( " SELECT (NOW()>? AND NOW()<?) AS datecheck " );
$q -> execute ([ $config [ 'dates' ][ 'specawardregopen' ], $config [ 'dates' ][ 'specawardregclose' ]]);
2025-01-29 03:30:48 +00:00
$r = $q -> fetch ( PDO :: FETCH_OBJ );
// this will return 1 if its between the dates, 0 otherwise.
if ( $r -> datecheck == 1 ) {
echo '<tr><td><a href="register_participants_spawards.php">' . i18n ( 'Self-nominate for special awards' ) . '</a></td></tr>' ;
} else {
echo '<tr><td>' . error ( i18n ( 'Special award self-nomination is only available from %1 to %2' , array ( $config [ 'dates' ][ 'specawardregopen' ], $config [ 'dates' ][ 'specawardregclose' ])), 'inline' ) . '</td></tr>' ;
2006-01-16 18:38:32 +00:00
}
2025-01-29 03:30:48 +00:00
} else if ( $config [ 'specialawardnomination' ] == 'registration' ) {
if ( $sp_proj_ok == false ) {
echo '<tr><td><font color="red">(' . i18n ( 'Available when your Student Information and Project Information is "Complete"' ) . ')</font></td></tr>' ;
2007-03-05 02:26:56 +00:00
} else {
2025-01-29 03:30:48 +00:00
echo '<tr><td><a href="register_participants_spawards.php">' . i18n ( 'Self-nominate for special awards' ) . '</a></td></tr>' ;
2007-03-05 02:26:56 +00:00
}
2005-05-12 15:47:21 +00:00
}
2025-02-09 17:24:37 +00:00
$q = $pdo -> prepare ( " SELECT * FROM projects WHERE registrations_id=? AND year=? " );
$q -> execute ([ $_SESSION [ 'registration_id' ], $config [ 'FAIRYEAR' ]]);
2025-01-29 03:30:48 +00:00
$project = $q -> fetch ( PDO :: FETCH_OBJ );
$nominatedawards = getSpecialAwardsNominatedForProject ( $project -> id );
$num = count ( $nominatedawards );
$noawards = getNominatedForNoSpecialAwardsForProject ( $project -> id );
echo '<tr><td>' ;
if ( $num ) {
echo happy ( i18n ( 'You are nominated for %1 awards' , array ( $num )), 'inline' );
echo '</td></tr>' ;
echo '<tr><td>' ;
$c = 1 ;
foreach ( $nominatedawards AS $na ) {
echo $c . '. ' . $na [ 'name' ] . '<br />' ;
2005-05-11 21:39:39 +00:00
$c ++ ;
}
2025-01-29 03:30:48 +00:00
} else if ( $noawards == true ) {
echo happy ( i18n ( 'You are nominated for 0 awards' ), 'inline' );
} else {
echo error ( i18n ( 'You are nominated for 0 awards' ), 'inline' );
2005-05-11 21:39:39 +00:00
}
2025-01-29 03:30:48 +00:00
echo '</td></tr>' ;
} else {
echo '<tr><td>' . error ( i18n ( " We must receive your $signatureformpermissionform before you can nominate yourself for special awards " )) . '</td></tr>' ;
2005-05-11 04:13:27 +00:00
}
2005-05-12 15:47:21 +00:00
2025-01-29 03:30:48 +00:00
echo '</table>' ;
}
echo '</td></tr>' ;
echo '</table>' ;
echo '<br /><br />' ;
function regfee_line ( $item , $unit , $qty , $tot , $extra )
{
echo '<tr><td>' . i18n ( $item ) . '</td>' ;
echo '<td>($' . sprintf ( '%.02f' , $unit ) . '</td>' ;
2007-01-21 01:40:46 +00:00
echo " <td>* $qty )</td> " ;
2025-01-29 03:30:48 +00:00
echo '<td>$' . sprintf ( '%.02f' , $tot ) . '</td>' ;
echo '<td><font size=-1>' . i18n ( $extra ) . '</font></td>' ;
echo '</tr>' ;
}
2007-03-12 02:05:40 +00:00
2025-01-29 03:30:48 +00:00
if ( $config [ 'regfee_show_info' ] == 'yes' ) {
echo '<h3>' . i18n ( 'Registration Fee Information' ) . '</h3>' ;
2007-01-21 01:40:46 +00:00
2007-03-12 02:05:40 +00:00
list ( $regfee , $rfeedata ) = computeRegistrationFee ( $_SESSION [ 'registration_id' ]);
2007-01-21 01:40:46 +00:00
2025-01-29 03:30:48 +00:00
$extra_after = '' ;
echo '<table>' ;
foreach ( $rfeedata as $rf ) {
2008-01-23 07:53:10 +00:00
$ex = '' ;
2025-01-29 03:30:48 +00:00
if ( $rf [ 'id' ] == 'tshirt' ) {
$ex = '*' ;
2007-03-12 02:05:40 +00:00
$extra_after = " * If you do not wish to order a T-Shirt, please select your T-Shirt size as 'None' on the Student Information Page " ;
2007-01-21 01:40:46 +00:00
}
2025-01-29 03:30:48 +00:00
regfee_line ( $rf [ 'text' ], $rf [ 'base' ], $rf [ 'num' ], $rf [ 'ext' ], $ex );
2007-01-21 01:40:46 +00:00
}
2025-01-29 03:30:48 +00:00
echo '<tr><td align=right colspan=3>' . i18n ( 'Total (including all taxes)' ) . '</td><td><b>$' . sprintf ( '%.02f' , $regfee ) . '</b></td><td></td></tr>' ;
echo '</table><br />' ;
2007-01-31 07:30:43 +00:00
echo i18n ( $extra_after );
2007-03-05 02:26:56 +00:00
2025-01-29 03:30:48 +00:00
echo '<br />' ;
echo '<br />' ;
echo '<br />' ;
2007-01-21 01:40:46 +00:00
}
2025-01-29 03:30:48 +00:00
echo '<h3>' . i18n ( 'Registration Instructions' ) . '</h3>' ;
2004-11-30 23:18:35 +00:00
2025-01-29 03:30:48 +00:00
// now get the text of special instructions for the bottom of this page:
output_page_text ( 'register_participants_main_instructions' );
2005-01-07 04:46:52 +00:00
2025-01-29 03:30:48 +00:00
echo '<br /><br />' ;
2004-12-02 23:15:42 +00:00
2025-01-29 03:30:48 +00:00
echo '<a href="register_participants.php?action=logout">' . i18n ( 'Logout' ) . '</a>' ;
2004-11-30 23:18:35 +00:00
2025-01-29 03:30:48 +00:00
send_footer ();
2004-11-30 23:18:35 +00:00
?>