2006-12-15 18:45:06 +00:00
< ?
/*
This file is part of the 'Science Fair In A Box' project
SFIAB Website : http :// www . sfiab . ca
2006-12-15 19:51:32 +00:00
Copyright ( C ) 2005 - 2006 Sci - Tech Ontario Inc < info @ scitechontario . org >
Copyright ( C ) 2005 - 2006 James Grant < james @ lightbox . org >
2006-12-15 18:45:06 +00:00
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 .
*/
2014-02-27 21:38:16 +00:00
// This file was modified Jan of 2014 by Richard Sin
// Project type has been added and can be toggled by configuration.
// Feedback box also has been added for flagging purposes
2006-12-15 18:45:06 +00:00
?>
< ?
2010-01-24 06:47:17 +00:00
require_once ( '../common.inc.php' );
require_once ( '../user.inc.php' );
require_once ( '../register_participants.inc.php' );
$auth_type = user_auth_required ( array ( 'fair' , 'committee' ), 'admin' );
2006-12-15 18:45:06 +00:00
2010-01-21 20:32:57 +00:00
$registrations_id = intval ( $_GET [ 'id' ]);
$action = $_GET [ 'action' ];
2006-12-15 18:45:06 +00:00
2010-01-24 06:47:17 +00:00
/* Extra restrictions for auth_type = fair */
if ( $auth_type == 'fair' ) {
$fairs_id = $_SESSION [ 'fairs_id' ];
if ( $registrations_id == - 1 && ( $action == 'registration_load' || $action == 'registration_save' )) {
/* we can't check the project it hasn't been created. */
} else {
/* Make sure they have permission to laod this student , check
the master copy of the fairs_id in the project */
$q = mysql_query ( " SELECT * FROM projects WHERE
registrations_id = '$registrations_id'
AND year = '{$config[' FAIRYEAR ']}'
AND fairs_id = $fairs_id " );
if ( mysql_num_rows ( $q ) != 1 ) {
echo " permission denied. " ;
exit ;
}
/* Ok, they have permission */
}
}
2010-01-21 20:32:57 +00:00
switch ( $action ) {
case 'project_load' :
project_load ();
break ;
case 'project_regenerate_number' :
/* Save first */
project_save ();
2006-12-15 18:45:06 +00:00
2010-01-21 20:32:57 +00:00
/* Now generate */
$q = mysql_query ( " SELECT id FROM projects WHERE registrations_id=' { $registrations_id } ' AND year=' { $config [ 'FAIRYEAR' ] } ' " );
$i = mysql_fetch_assoc ( $q );
$id = $i [ 'id' ];
2007-03-04 20:28:51 +00:00
2007-12-29 08:46:40 +00:00
mysql_query ( " UPDATE projects SET projectnumber=NULL,projectsort=NULL,
projectnumber_seq = '0' , projectsort_seq = '0'
WHERE id = '$id' " );
echo mysql_error ();
2010-01-21 20:32:57 +00:00
list ( $pn , $ps , $pns , $pss ) = generateProjectNumber ( $registrations_id );
2007-03-04 20:28:51 +00:00
// print("Generated Project Number [$pn]");
2007-12-29 08:46:40 +00:00
mysql_query ( " UPDATE projects SET projectnumber=' $pn ',projectsort=' $ps ',
projectnumber_seq = '$pns' , projectsort_seq = '$pss'
WHERE id = '$id' " );
2010-01-21 20:32:57 +00:00
happy_ ( " Generated and Saved Project Number: $pn " );
break ;
case 'project_save' :
project_save ();
break ;
default :
break ;
}
2006-12-15 18:45:06 +00:00
2010-01-21 20:32:57 +00:00
exit ;
2006-12-15 18:45:06 +00:00
2010-01-21 20:32:57 +00:00
function project_save ()
{
global $registrations_id , $config ;
2006-12-15 18:45:06 +00:00
2010-01-21 20:32:57 +00:00
//first, lets make sure this project really does belong to them
$q = mysql_query ( " SELECT * FROM projects WHERE registrations_id=' { $registrations_id } ' AND year=' { $config [ 'FAIRYEAR' ] } ' " );
$projectinfo = mysql_fetch_object ( $q );
if ( ! projectinfo ) {
echo error ( i18n ( " Invalid project to update " ));
}
2006-12-15 18:45:06 +00:00
2010-01-21 20:32:57 +00:00
$summarywords = preg_split ( " /[ \ s,]+/ " , $_POST [ 'summary' ]);
$summarywordcount = count ( $summarywords );
if ( $summarywordcount > $config [ 'participant_project_summary_wordmax' ])
$summarycountok = 0 ;
else
$summarycountok = 1 ;
2014-02-27 21:38:16 +00:00
//check if it is flagged then update it
if ( empty ( $_POST [ 'feedback' ])) {
mysql_query ( " UPDATE projects SET " .
" flagged='0' " .
" WHERE id=' " . intval ( $_POST [ 'id' ]) . " ' " );
} else {
mysql_query ( " UPDATE projects SET " .
" flagged='1' " .
" WHERE id=' " . intval ( $_POST [ 'id' ]) . " ' " );
}
echo mysql_error ();
happy_ ( " Flagging process successfully updated " );
2010-01-21 20:32:57 +00:00
if ( $config [ 'participant_project_title_charmax' ] && strlen ( stripslashes ( $_POST [ 'title' ])) > $config [ 'participant_project_title_charmax' ]) { //0 for no limit, eg 255 database field limit
$title = substr ( stripslashes ( $_POST [ 'title' ]), 0 , $config [ 'participant_project_title_charmax' ]);
error_ ( " Project title truncated to %1 characters " , array ( $config [ 'participant_project_title_charmax' ]));
} else
$title = stripslashes ( $_POST [ 'title' ]);
mysql_query ( " UPDATE projects SET " .
2010-03-25 14:27:13 +00:00
" title=' " . mysql_escape_string ( iconv ( " UTF-8 " , " ISO-8859-1//TRANSLIT " , $title )) . " ', " .
" projectdivisions_id=' " . intval ( $_POST [ 'projectdivisions_id' ]) . " ', " .
2014-02-27 21:38:16 +00:00
" projecttype=' " . mysql_escape_string ( stripslashes ( $_POST [ 'projecttype' ])) . " ', " .
2010-01-21 20:32:57 +00:00
" language=' " . mysql_escape_string ( stripslashes ( $_POST [ 'language' ])) . " ', " .
" req_table=' " . mysql_escape_string ( stripslashes ( $_POST [ 'req_table' ])) . " ', " .
" req_electricity=' " . mysql_escape_string ( stripslashes ( $_POST [ 'req_electricity' ])) . " ', " .
2010-03-25 14:27:13 +00:00
" req_special=' " . mysql_escape_string ( iconv ( " UTF-8 " , " ISO-8859-1//TRANSLIT " , stripslashes ( $_POST [ 'req_special' ]))) . " ', " .
" summary=' " . mysql_escape_string ( iconv ( " UTF-8 " , " ISO-8859-1//TRANSLIT " , stripslashes ( $_POST [ 'summary' ]))) . " ', " .
2010-01-21 20:32:57 +00:00
" summarycountok=' $summarycountok ', " .
2014-02-27 21:38:16 +00:00
" feedback=' " . mysql_escape_string ( iconv ( " UTF-8 " , " ISO-8859-1//TRANSLIT " , stripslashes ( $_POST [ 'feedback' ]))) . " ', " .
2010-01-21 20:32:57 +00:00
" projectsort=' " . mysql_escape_string ( stripslashes ( $_POST [ 'projectsort' ])) . " ' " .
2010-03-25 14:27:13 +00:00
" WHERE id=' " . intval ( $_POST [ 'id' ]) . " ' " );
2010-01-21 20:32:57 +00:00
echo mysql_error ();
happy_ ( " Project information successfully updated " );
//check if they changed the project number
if ( $_POST [ 'projectnumber' ] != $projectinfo -> projectnumber ) {
//check if hte new one is available
$q = mysql_query ( " SELECT * FROM projects WHERE year=' " . $config [ 'FAIRYEAR' ] . " ' AND projectnumber=' " . $_POST [ 'projectnumber' ] . " ' " );
if ( mysql_num_rows ( $q )) {
error_ ( " Could not change project number. %1 is already in use " , array ( $_POST [ 'projectnumber' ]));
} else {
mysql_query ( " UPDATE projects SET
projectnumber = '".$_POST[' projectnumber ']."'
WHERE id = '".$_POST[' id ']."' " );
happy_ ( " Project number successfully changed to %1 " , array ( $_POST [ 'projectnumber' ]));
}
2006-12-15 18:45:06 +00:00
}
2010-01-21 20:32:57 +00:00
}
2006-12-15 18:45:06 +00:00
2010-01-21 20:32:57 +00:00
function project_load ()
{
global $registrations_id , $config ;
//now lets find out their MAX grade, so we can pre-set the Age Category
$q = mysql_query ( " SELECT MAX(grade) AS maxgrade FROM students WHERE registrations_id=' " . $registrations_id . " ' " );
$gradeinfo = mysql_fetch_object ( $q );
//now lets grab all the age categories, so we can choose one based on the max grade
$q = mysql_query ( " SELECT * FROM projectcategories WHERE year=' " . $config [ 'FAIRYEAR' ] . " ' ORDER BY id " );
while ( $r = mysql_fetch_object ( $q )) {
//save these in an array, just incase we need them later (FIXME: remove this array if we dont need it)
$agecategories [ $r -> id ][ 'category' ] = $r -> category ;
$agecategories [ $r -> id ][ 'mingrade' ] = $r -> mingrade ;
$agecategories [ $r -> id ][ 'maxgrade' ] = $r -> maxgrade ;
if ( $gradeinfo -> maxgrade >= $r -> mingrade && $gradeinfo -> maxgrade <= $r -> maxgrade )
$projectcategories_id = $r -> id ;
}
//now select their project info
$q = mysql_query ( " SELECT * FROM projects WHERE registrations_id=' " . $registrations_id . " ' AND year=' " . $config [ 'FAIRYEAR' ] . " ' " );
//check if it exists, if we didnt find any record, lets insert one
$projectinfo = mysql_fetch_object ( $q );
2012-03-22 14:56:50 +00:00
if ( ! $projectinfo ) {
mysql_query ( " INSERT INTO projects (registrations_id,projectcategories_id,year) VALUES (' " . $registrations_id . " ',' $projectcategories_id ',' " . $config [ 'FAIRYEAR' ] . " ') " );
//and then pull it back out
$q = mysql_query ( " SELECT * FROM projects WHERE registrations_id=' " . $registrations_id . " ' AND year=' " . $config [ 'FAIRYEAR' ] . " ' " );
$projectinfo = mysql_fetch_object ( $q );
}
2006-12-15 18:45:06 +00:00
2010-01-21 20:32:57 +00:00
//make sure that if they changed their grade on the student page, we update their projectcategories_id accordingly
if ( $projectcategories_id && $projectinfo -> projectcategories_id != $projectcategories_id ) {
echo notice ( i18n ( " Age category changed, updating to %1 " , array ( $agecategories [ $projectcategories_id ][ 'category' ])));
mysql_query ( " UPDATE projects SET projectcategories_id=' $projectcategories_id ' WHERE id=' $projectinfo->id ' " );
}
2006-12-15 18:45:06 +00:00
2010-01-21 20:32:57 +00:00
//output the current status
2006-12-15 18:45:06 +00:00
?>
< script language = " javascript " type = " text/javascript " >
function countwords ()
{
var wordmax =< ? = $config [ 'participant_project_summary_wordmax' ]; ?> ;
var summaryobj = document . getElementById ( 'summary' );
var wordcountobj = document . getElementById ( 'wordcount' );
var wordcountmessageobj = document . getElementById ( 'wordcountmessage' );
var wordarray = summaryobj . value . replace ( / \s +/ g , " " ) . split ( " " );
var wordcount = wordarray . length ;
if ( wordcount > wordmax )
wordcountmessageobj . className = " incomplete " ;
else
wordcountmessageobj . className = " complete " ;
wordcountobj . innerHTML = wordcount ;
}
</ script >
< ?
2010-01-21 20:32:57 +00:00
if ( ! $projectinfo ) {
echo error ( i18n ( " Invalid project to edit " ));
exit ;
}
?>
< form id = " project_form " >
< input type = " hidden " name = " id " value = " <?= $projectinfo->id ?> " >
< table >
< tr > < td >< ? = i18n ( " Project Title " ) ?> : </td>
< td >< input type = " text " name = " title " size = " 50 " value = " <?=htmlspecialchars( $projectinfo->title )?> " />< ? = REQUIREDFIELD ?>
< ?
if ( $config [ 'participant_project_title_charmax' ])
echo i18n ( " (Max %1 characters) " , array ( $config [ 'participant_project_title_charmax' ]));
?>
</ td >
</ tr >< tr >
< td >< ? = i18n ( " Project Number " ) ?> : </td>
< td >< input type = " text " name = " projectnumber " size = " 10 " value = " <?= $projectinfo->projectnumber ?> " />
< input type = " button " id = " project_regenerate_number " value = " <?=i18n( " Re - Generate Project Number " )?> " />
</ td >
</ tr >< tr >
< td >< ? = i18n ( " Project Sort " ) ?> : </td>
2014-02-27 21:38:16 +00:00
< td >< input type = " text " name = " projectsort " size = " 10 " value = " <?= $projectinfo->projectsort ?> " /></ td ></ tr >
< ?
if ( $config [ 'project_type' ] == 'yes' ){
$q = mysql_query ( " SELECT * FROM projecttypes ORDER BY type " );
2015-03-20 19:24:37 +00:00
echo " <tr><td> " . i18n ( " Project Type " ) . " : </td><td> " ;
2014-02-27 21:38:16 +00:00
echo " <select name= \" projecttype \" > \n " ;
echo " <option value= \" \" > " . i18n ( " Select a project type " ) . " </option> \n " ;
//FIXME: need to fix the loading glitch
while ( $r = mysql_fetch_object ( $q ))
{
if ( $r -> type == $projectinfo -> projecttype )
{
$sel = " selected= \" selected \" " ;
}
else
{
$sel = " " ;
}
echo " <option $sel value= \" $r->type\ " > " .htmlspecialchars(i18n( $r->type )). " </ option > \n " ;
}
echo " </select> " . REQUIREDFIELD . " </td></tr> " ;
}
?>
< tr >
2010-01-21 20:32:57 +00:00
< td >< ? = i18n ( " Age Category " ) ?> : </td>
< td >< ? = i18n ( $agecategories [ $projectcategories_id ][ 'category' ]) ?> (<?=i18n("Grades %1-%2",array($agecategories[$projectcategories_id]['mingrade'],$agecategories[$projectcategories_id]['maxgrade']))?>)</td>
</ tr >< tr >
< td >< ? = i18n ( " Division " ) ?> : </td>
< td >
< ?
//###### Feature Specific - filtering divisions by category
if ( $config [ 'filterdivisionbycategory' ] == " yes " ){
$q = mysql_query ( " SELECT projectdivisions.* FROM projectdivisions,projectcategoriesdivisions_link WHERE projectdivisions.id=projectdivisions_id AND projectcategories_id= " . $projectcategories_id . " AND projectdivisions.year=' " . $config [ 'FAIRYEAR' ] . " ' AND projectcategoriesdivisions_link.year=' " . $config [ 'FAIRYEAR' ] . " ' ORDER BY division " );
echo mysql_error ();
//###
} else
$q = mysql_query ( " SELECT * FROM projectdivisions WHERE year=' " . $config [ 'FAIRYEAR' ] . " ' ORDER BY division " );
echo " <select name= \" projectdivisions_id \" > " ;
echo " <option value= \" \" > " . i18n ( " Select a division " ) . " </option> \n " ;
while ( $r = mysql_fetch_object ( $q )) {
if ( $r -> id == $projectinfo -> projectdivisions_id ) $sel = " selected= \" selected \" " ; else $sel = " " ;
echo " <option $sel value= \" $r->id\ " > " .htmlspecialchars(i18n( $r->division )). " </ option > \n " ;
2006-12-15 18:45:06 +00:00
}
2010-01-21 20:32:57 +00:00
echo " </select> " . REQUIREDFIELD ;
if ( $config [ 'usedivisionselector' ] == " yes " ) {
?>
< script language = " javascript " type = " text/javascript " >
function openDivSelWindow ()
{
divselwin = window . open ( 'register_participants_project_divisionselector.php' , 'divsel' , 'width=500,height=220,toolbar=no,location=no,directories=no,status=no,menubar=no,scrollbars=no' )
if ( divselwin . opener == null ) divselwin . opener = self ;
return false ;
}
</ script >
2006-12-15 18:45:06 +00:00
< ?
2010-01-21 20:32:57 +00:00
}
2006-12-15 18:45:06 +00:00
2010-01-21 20:32:57 +00:00
echo " <br /> " ;
echo i18n ( " WARNING! If you change the division you must manually change the project number too! It will NOT be assigned a new number automatically " );
echo " </td></tr> " ;
2006-12-15 18:45:06 +00:00
2010-01-21 20:32:57 +00:00
echo " <tr><td> " . i18n ( " Language " ) . " : </td><td> " ;
echo " <select name= \" language \" > \n " ;
2006-12-15 18:45:06 +00:00
2010-01-21 20:32:57 +00:00
if ( $projectinfo -> language )
$currentlang = $projectinfo -> language ;
else
$currentlang = $_SESSION [ 'lang' ];
foreach ( $config [ 'languages' ] AS $key => $val ) {
if ( $currentlang == $key ) $selected = " selected= \" selected \" " ; else $selected = " " ;
2006-12-15 18:45:06 +00:00
2010-01-21 20:32:57 +00:00
echo " <option $selected value= \" $key\ " > $val </ option > " ;
}
echo " </select> " . REQUIREDFIELD ;
echo " </td></tr> " ;
2006-12-15 18:45:06 +00:00
2010-01-21 20:32:57 +00:00
echo " <tr><td> " . i18n ( " Requirements " ) . " : </td><td> " ;
2006-12-15 18:45:06 +00:00
echo " <table> " ;
2010-01-21 20:32:57 +00:00
if ( $config [ 'participant_project_table' ] == " no " ) {
2007-01-02 20:33:16 +00:00
//if we arent asking them if they want a table or not, then we set it to 'yes' assuming everyone will get a table
echo " <input type= \" hidden \" name= \" req_table \" value= \" yes \" /> " ;
2010-01-21 20:32:57 +00:00
} else {
2007-01-02 20:33:16 +00:00
echo " <tr> " ;
echo " <td> " . i18n ( " Table " ) . REQUIREDFIELD . " </td> " ;
if ( $projectinfo -> req_table == " yes " ) $check = " checked= \" checked \" " ; else $check = " " ;
echo " <td><input $check type= \" radio \" name= \" req_table \" value= \" yes \" />Yes</td> " ;
echo " <td width= \" 20 \" > </td> " ;
if ( $projectinfo -> req_table == " no " ) $check = " checked= \" checked \" " ; else $check = " " ;
echo " <td><input $check type= \" radio \" name= \" req_table \" value= \" no \" />No</td> " ;
echo " </tr> " ;
}
2006-12-15 18:45:06 +00:00
2007-01-02 20:33:16 +00:00
if ( $config [ 'participant_project_electricity' ] == " no " )
{
//if we arent asking them if they want electricity or not, then we set it to 'yes' assuming everyone will get electricity
echo " <input type= \" hidden \" name= \" req_electricity \" value= \" yes \" /> " ;
}
else
{
echo " <tr> " ;
echo " <td> " . i18n ( " Electricity " ) . REQUIREDFIELD . " </td> " ;
if ( $projectinfo -> req_electricity == " yes " ) $check = " checked= \" checked \" " ; else $check = " " ;
echo " <td><input $check type= \" radio \" name= \" req_electricity \" value= \" yes \" />Yes</td> " ;
echo " <td width= \" 20 \" > </td> " ;
if ( $projectinfo -> req_electricity == " no " ) $check = " checked= \" checked \" " ; else $check = " " ;
echo " <td><input $check type= \" radio \" name= \" req_electricity \" value= \" no \" />No</td> " ;
echo " </tr> " ;
}
2006-12-15 18:45:06 +00:00
echo " <tr> " ;
echo " <td> " . i18n ( " Special " ) . " </td> " ;
echo " <td colspan= \" 3 \" ><input type= \" text \" name= \" req_special \" value= \" $projectinfo->req_special\ " /></ td > " ;
echo " </tr> " ;
echo " </table> " ;
2010-01-21 20:32:57 +00:00
echo " </td></tr> " ;
2007-03-04 20:28:51 +00:00
2010-01-21 20:32:57 +00:00
echo " <tr><td> " . i18n ( " Summary " ) . " : </td><td><textarea onchange='countwords()' onkeypress='countwords()' cols= \" 60 \" rows= \" 12 \" id= \" summary \" name= \" summary \" > " . htmlspecialchars ( $projectinfo -> summary ) . " </textarea> " . REQUIREDFIELD . " <br /> " ;
2007-03-04 20:28:51 +00:00
2010-01-21 20:32:57 +00:00
$summarywords = preg_split ( " /[ \ s,]+/ " , $projectinfo -> summary );
$summarywordcount = count ( $summarywords );
if ( $summarywordcount > $config [ 'participant_project_summary_wordmax' ])
echo " <div id= \" wordcountmessage \" class= \" incomplete \" > " ;
else
echo " <div id= \" wordcountmessage \" class= \" complete \" > " ;
2007-03-04 20:28:51 +00:00
2010-01-21 20:32:57 +00:00
echo " <span id= \" wordcount \" > $summarywordcount </span>/ " ;
echo i18n ( " %1 words maximum " , array ( $config [ 'participant_project_summary_wordmax' ]));
echo " </div> " ;
2006-12-15 18:45:06 +00:00
2014-02-27 21:38:16 +00:00
echo " <tr><td> " . i18n ( " Feedback " ) . " : </td><td><textarea cols= \" 60 \" rows= \" 4 \" id= \" feedback \" name= \" feedback \" > " . htmlspecialchars ( $projectinfo -> feedback ) . " </textarea><br /> " ;
2010-01-21 20:32:57 +00:00
?>
</ td ></ tr >
</ table >
< input type = " button " id = " project_save " value = " <?=i18n( " Save Project Information " )?> " />
</ form >
< ?
2006-12-15 18:45:06 +00:00
}
?>