2005-01-24 18:00:03 +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 .
*/
?>
2004-12-10 19:59:18 +00:00
< ?
require ( " common.inc.php " );
include " register_participants.inc.php " ;
//authenticate based on email address and registration number from the SESSION
if ( ! $_SESSION [ 'email' ])
{
header ( " Location: register_participants.php " );
exit ;
}
if ( ! ( $_SESSION [ 'registration_number' ] && $_SESSION [ 'registration_id' ]))
{
header ( " Location: register_participants.php " );
exit ;
}
2025-01-28 17:33:03 -05:00
global $pdo ;
2024-12-09 01:06:15 -05:00
$q = $pdo -> prepare ( " SELECT registrations.id AS regid, students.id AS studentid, students.firstname FROM registrations,students " .
2004-12-10 19:59:18 +00:00
" WHERE students.email=' " . $_SESSION [ 'email' ] . " ' " .
" AND registrations.num=' " . $_SESSION [ 'registration_number' ] . " ' " .
" AND registrations.id=' " . $_SESSION [ 'registration_id' ] . " ' " .
" AND students.registrations_id=registrations.id " .
" AND registrations.year= " . $config [ 'FAIRYEAR' ] . " " .
" AND students.year= " . $config [ 'FAIRYEAR' ]);
2024-12-09 01:06:15 -05:00
$q -> execute ();
2025-01-03 15:15:13 -05:00
show_pdo_errors_if_any ( $pdo );
2004-12-10 19:59:18 +00:00
2024-12-09 01:06:15 -05:00
if ( $q -> rowCount () == 0 )
2004-12-10 19:59:18 +00:00
{
header ( " Location: register_participants.php " );
exit ;
}
2024-12-09 01:06:15 -05:00
$r = $q -> fetch ( PDO :: FETCH_OBJ );
2004-12-10 19:59:18 +00:00
send_header ( " Participant Registration - Mentor Information " );
echo " <a href= \" register_participants_main.php \" ><< " . i18n ( " Back to Participant Registration Summary " ) . " </a><br /> " ;
echo " <br /> " ;
//now do any data saves
2025-01-19 21:13:25 -05:00
if ( get_value_from_array ( $_POST , 'action' ) == " save " )
2004-12-10 19:59:18 +00:00
{
2005-01-13 18:50:07 +00:00
if ( registrationFormsReceived ())
2004-12-10 19:59:18 +00:00
{
2005-01-13 18:50:07 +00:00
echo error ( i18n ( " Cannot make changes to forms once they have been received by the fair " ));
}
2005-05-12 17:32:50 +00:00
else if ( registrationDeadlinePassed ())
{
echo error ( i18n ( " Cannot make changes to forms after registration deadline " ));
}
2005-01-13 18:50:07 +00:00
else
{
$x = 1 ;
while ( $_POST [ " num " ][ $x ])
2004-12-10 19:59:18 +00:00
{
2005-01-13 18:50:07 +00:00
if ( $_POST [ 'id' ][ $x ] == 0 )
2004-12-10 19:59:18 +00:00
{
2005-01-13 18:50:07 +00:00
//only insert if we have a name
2006-02-01 21:08:59 +00:00
if ( $_POST [ 'lastname' ][ $x ])
2005-01-13 18:50:07 +00:00
{
//INSERT new record
2024-12-09 01:06:15 -05:00
$stmt = $pdo -> prepare ( " INSERT INTO mentors (registrations_id,firstname,lastname,email,phone,organization,position,description,year) VALUES ( " .
2005-01-13 18:50:07 +00:00
" ' " . $_SESSION [ 'registration_id' ] . " ', " .
2024-12-09 01:06:15 -05:00
" ' " . stripslashes ( $_POST [ 'firstname' ][ $x ]) . " ', " .
" ' " . stripslashes ( $_POST [ 'lastname' ][ $x ]) . " ', " .
" ' " . stripslashes ( $_POST [ 'email' ][ $x ]) . " ', " .
" ' " . stripslashes ( $_POST [ 'phone' ][ $x ]) . " ', " .
" ' " . stripslashes ( $_POST [ 'organization' ][ $x ]) . " ', " .
" ' " . stripslashes ( $_POST [ 'position' ][ $x ]) . " ', " .
" ' " . stripslashes ( $_POST [ 'description' ][ $x ]) . " ', " .
2005-01-13 18:50:07 +00:00
" ' " . $config [ 'FAIRYEAR' ] . " ') " );
2024-12-09 01:06:15 -05:00
$stmt -> execute ();
2025-01-03 15:15:13 -05:00
show_pdo_errors_if_any ( $pdo );
2004-12-10 19:59:18 +00:00
2005-01-13 18:50:07 +00:00
echo notice ( i18n ( " %1 %2 successfully added " , array ( $_POST [ 'firstname' ][ $x ], $_POST [ 'lastname' ][ $x ])));
}
2004-12-10 19:59:18 +00:00
2005-01-13 18:50:07 +00:00
}
else
{
//UPDATE existing record
2024-12-09 01:06:15 -05:00
$stmt = $pdo -> prepare ( " UPDATE mentors SET " .
" firstname=' " . stripslashes ( $_POST [ 'firstname' ][ $x ]) . " ', " .
" lastname=' " . stripslashes ( $_POST [ 'lastname' ][ $x ]) . " ', " .
" email=' " . stripslashes ( $_POST [ 'email' ][ $x ]) . " ', " .
" phone=' " . stripslashes ( $_POST [ 'phone' ][ $x ]) . " ', " .
" organization=' " . stripslashes ( $_POST [ 'organization' ][ $x ]) . " ', " .
" position=' " . stripslashes ( $_POST [ 'position' ][ $x ]) . " ', " .
" description=' " . stripslashes ( $_POST [ 'description' ][ $x ]) . " ' " .
2005-01-13 18:50:07 +00:00
" WHERE id=' " . $_POST [ 'id' ][ $x ] . " ' " );
2024-12-09 01:06:15 -05:00
$stmt -> execute ();
2005-01-13 18:50:07 +00:00
echo notice ( i18n ( " %1 %2 successfully updated " , array ( $_POST [ 'firstname' ][ $x ], $_POST [ 'lastname' ][ $x ])));
2004-12-10 19:59:18 +00:00
2005-01-13 18:50:07 +00:00
}
$x ++ ;
2004-12-10 19:59:18 +00:00
}
}
}
2025-01-19 21:13:25 -05:00
if ( get_value_from_array ( $_GET , 'action' ) == " removementor " )
2004-12-10 19:59:18 +00:00
{
2005-01-13 18:50:07 +00:00
if ( registrationFormsReceived ())
2004-12-10 19:59:18 +00:00
{
2005-01-13 18:50:07 +00:00
echo error ( i18n ( " Cannot make changes to forms once they have been received by the fair " ));
2004-12-10 19:59:18 +00:00
}
else
{
2005-01-13 18:50:07 +00:00
//first make sure this is one belonging to this registration id
2024-12-09 01:06:15 -05:00
$q = $pdo -> prepare ( " SELECT id FROM mentors WHERE id=' " . $_GET [ 'removementor' ] . " ' AND registrations_id=' " . $_SESSION [ 'registration_id' ] . " ' " );
$q -> execute ();
if ( $q -> rowCount () == 1 )
2005-01-13 18:50:07 +00:00
{
2024-12-09 01:06:15 -05:00
$stmt = $pdo -> prepare ( " DELETE FROM mentors WHERE id=' " . $_GET [ 'removementor' ] . " ' AND registrations_id=' " . $_SESSION [ 'registration_id' ] . " ' " );
$stmt -> execute ();
2005-01-13 18:50:07 +00:00
echo notice ( i18n ( " Mentor successfully removed " ));
}
else
{
echo error ( i18n ( " Invalid mentor to remove " ));
}
2004-12-10 19:59:18 +00:00
}
}
//now query and display
2024-12-09 01:06:15 -05:00
$q = $pdo -> prepare ( " SELECT nummentors FROM registrations WHERE id=' " . $_SESSION [ 'registration_id' ] . " ' AND year=' " . $config [ 'FAIRYEAR' ] . " ' " );
$q -> execute ();
$r = $q -> fetch ( PDO :: FETCH_OBJ );
2004-12-10 19:59:18 +00:00
$registrations_nummentors = $r -> nummentors ;
2024-12-09 01:06:15 -05:00
$q = $pdo -> prepare ( " SELECT * FROM mentors WHERE registrations_id=' " . $_SESSION [ 'registration_id' ] . " ' AND year=' " . $config [ 'FAIRYEAR' ] . " ' " );
$q -> execute ();
$numfound = $q -> rowCount ();
2004-12-10 19:59:18 +00:00
if ( isset ( $_GET [ 'nummentors' ]))
{
2024-12-09 01:06:15 -05:00
$stmt = $pdo -> prepare ( " UPDATE registrations SET nummentors=' " . $_GET [ 'nummentors' ] . " ' WHERE id=' " . $_SESSION [ 'registration_id' ] . " ' " );
$stmt -> execute ();
2004-12-10 19:59:18 +00:00
$registrations_nummentors = $_GET [ 'nummentors' ];
$numtoshow = $_GET [ 'nummentors' ];
}
else
$numtoshow = $numfound ;
//output the current status
$newstatus = mentorStatus ();
if ( $newstatus != " complete " )
{
echo error ( i18n ( " Mentor Information Incomplete " ));
}
else if ( $newstatus == " complete " )
{
echo happy ( i18n ( " Mentor Information Complete " ));
}
echo " <form name= \" nummentorsform \" method= \" get \" action= \" register_participants_mentor.php \" > " ;
echo i18n ( " Number of mentors that helped with the project: " );
echo " <select name= \" nummentors \" onchange= \" document.forms.nummentorsform.submit() \" > \n " ;
if ( $registrations_nummentors == null ) $sel = " selected= \" selected \" " ; else $sel = " " ;
echo " <option $sel value= \" \" > " . i18n ( " Choose " ) . " </option> \n " ;
2004-12-10 20:09:21 +00:00
for ( $x = $config [ 'minmentorsperproject' ]; $x <= $config [ 'maxmentorsperproject' ]; $x ++ )
2004-12-10 19:59:18 +00:00
{
//dont let them go less than the number we found. to go less, they must delete each record individually
if ( $x < $numfound )
continue ;
if ( $numtoshow == $x && $registrations_nummentors != null ) $selected = " selected= \" selected \" " ; else $selected = " " ;
echo " <option $selected value= \" $x\ " > $x </ option > \n " ;
}
echo " </select> " ;
echo " </form> " ;
echo " <form name= \" mentordata \" method= \" post \" action= \" register_participants_mentor.php \" > " ;
echo " <input type= \" hidden \" name= \" action \" value= \" save \" /> " ;
for ( $x = 1 ; $x <= $numtoshow ; $x ++ )
{
2024-12-09 01:06:15 -05:00
$mentorinfo = $q -> fetch ( PDO :: FETCH_OBJ );
2004-12-10 19:59:18 +00:00
echo " <h3> " . i18n ( " Mentor %1 Details " , array ( $x )) . " </h3> " ;
//if we have a valid mentor, set their ID, so we can UPDATE when we submit
//if there is no record for this mentor, then set the ID to 0, so we will INSERT when we submit
if ( $mentorinfo -> id ) $id = $mentorinfo -> id ; else $id = 0 ;
//true should work here, it just has to be set to _something_ for it to work.
echo " <input type= \" hidden \" name= \" num[ $x ] \" value= \" true \" /> " ;
//save the ID, or 0 if it doesnt exist
echo " <input type= \" hidden \" name= \" id[ $x ] \" value= \" $id\ " /> " ;
echo " <table> " ;
echo " <tr> \n " ;
2006-01-12 16:27:47 +00:00
echo " <td> " . i18n ( " First Name " ) . " </td><td><input type= \" text \" name= \" firstname[ $x ] \" value= \" $mentorinfo->firstname\ " /> " .REQUIREDFIELD. " </ td > \n " ;
echo " <td> " . i18n ( " Last Name " ) . " </td><td><input type= \" text \" name= \" lastname[ $x ] \" value= \" $mentorinfo->lastname\ " /> " .REQUIREDFIELD. " </ td > \n " ;
2004-12-10 19:59:18 +00:00
echo " </tr> \n " ;
echo " <tr> \n " ;
2006-01-12 16:27:47 +00:00
echo " <td> " . i18n ( " Email Address " ) . " </td><td><input type= \" text \" name= \" email[ $x ] \" value= \" $mentorinfo->email\ " /> " .REQUIREDFIELD. " </ td > \n " ;
echo " <td> " . i18n ( " Phone " ) . " </td><td><input type= \" text \" name= \" phone[ $x ] \" value= \" $mentorinfo->phone\ " /> " .REQUIREDFIELD. " </ td > \n " ;
2004-12-10 19:59:18 +00:00
echo " </tr> \n " ;
echo " <tr> \n " ;
2006-01-12 16:27:47 +00:00
echo " <td> " . i18n ( " Organization " ) . " </td><td><input type= \" text \" name= \" organization[ $x ] \" value= \" $mentorinfo->organization\ " /> " .REQUIREDFIELD. " </ td > \n " ;
2004-12-10 19:59:18 +00:00
echo " <td> " . i18n ( " Position " ) . " </td><td><input type= \" text \" name= \" position[ $x ] \" value= \" $mentorinfo->position\ " /></ td > \n " ;
echo " </tr> \n " ;
echo " <tr> \n " ;
echo " <td> " . i18n ( " Description of help " ) . " </td> " ;
2006-01-12 16:27:47 +00:00
echo " <td colspan=3><textarea rows= \" 3 \" cols= \" 60 \" name= \" description[ $x ] \" > " . htmlspecialchars ( $mentorinfo -> description ) . " </textarea> " . REQUIREDFIELD . " </td> \n " ;
2004-12-10 19:59:18 +00:00
echo " </tr> \n " ;
echo " </table> " ;
if ( $mentorinfo -> id )
{
2007-12-21 19:24:12 +00:00
echo " <div align= \" right \" ><a onclick= \" return confirmClick(' " . i18n ( " Are you sure you want to remove this mentor? " ) . " '); \" class= \" caution \" href= \" register_participants_mentor.php?action=removementor&removementor= $mentorinfo->id\ " >< img src = \ " " . $config [ 'SFIABDIRECTORY' ] . " /images/16/button_cancel. " . $config [ 'icon_extension' ] . " \" border=0> " . i18n ( " Remove this Mentor from project " ) . " </a></div> " ;
2004-12-10 19:59:18 +00:00
}
echo " <br /> " ;
echo " <br /> " ;
}
if ( $numtoshow )
{
echo " <input type= \" submit \" value= \" " . i18n ( " Save Mentor Information " ) . " \" /> \n " ;
}
echo " </form> " ;
send_footer ();
?>