From 2019e24b89a6eb3a35344a2e90f96a4c0074790d Mon Sep 17 00:00:00 2001 From: james Date: Thu, 19 Oct 2006 21:39:30 +0000 Subject: [PATCH] Add the 'one click' CWSF registration code! It current generates the XML but does not implement the sending to YSF (thats still to come!) --- admin/award_awards.php | 7 + admin/cwsfregister.php | 335 ++++++++++++++++++++++++++++++++++++++ common.inc.php | 10 ++ config/divisions_cwsf.php | 78 +++++++++ config/index.php | 1 + db/db.code.version.txt | 2 +- 6 files changed, 432 insertions(+), 1 deletion(-) create mode 100644 admin/cwsfregister.php create mode 100644 config/divisions_cwsf.php diff --git a/admin/award_awards.php b/admin/award_awards.php index 8c252726..5d3843ca 100644 --- a/admin/award_awards.php +++ b/admin/award_awards.php @@ -66,6 +66,7 @@ "award_types_id='".mysql_escape_string(stripslashes($_POST['award_types_id']))."', ". "presenter='".mysql_escape_string(stripslashes($_POST['presenter']))."', ". "excludefromac='".mysql_escape_string(stripslashes($_POST['excludefromac']))."', ". + "cwsfaward='".mysql_escape_string(stripslashes($_POST['cwsfaward']))."', ". "criteria='".mysql_escape_string(stripslashes($_POST['criteria']))."' ". "WHERE id='$id'"; @@ -140,6 +141,7 @@ award_awards.order, award_awards.presenter, award_awards.excludefromac, + award_awards.cwsfaward, award_types.id AS award_types_id, award_types.type, award_sponsors.id AS award_sponsors_id, @@ -169,6 +171,7 @@ echo mysql_error(); $award_sponsor=$r->organization; $award_awards_presenter=$r->presenter; $award_awards_excludefromac=$r->excludefromac; + $award_awards_cwsfaward=$r->cwsfaward; //select the current categories that this award is linked to $ccq=mysql_query("SELECT * FROM award_awards_projectcategories WHERE award_awards_id='$r->id'"); @@ -203,6 +206,7 @@ echo mysql_error(); if($_POST['eligibledivisions']) $currentdivisions=$_POST['eligibledivisions']; if($_POST['presenter']) $award_awards_presenter=$_POST['presenter']; if($_POST['excludefromac']) $award_awards_excludefromac=$_POST['excludefromac']; + if($_POST['cwsfaward']) $award_awards_cwsfaward=$_POST['cwsfaward']; echo "
\n"; @@ -292,6 +296,9 @@ echo mysql_error(); echo ""; if($award_awards_excludefromac==1) $ch="checked=\"checked\""; else $ch=""; echo "".i18n("Exclude this award from the award ceremony script").""; + echo ""; + if($award_awards_cwsfaward==1) $ch="checked=\"checked\""; else $ch=""; + echo "".i18n("This award identifies the students that will be attending the Canada-Wide Science Fair").""; echo "\n"; diff --git a/admin/cwsfregister.php b/admin/cwsfregister.php new file mode 100644 index 00000000..04a5b3c2 --- /dev/null +++ b/admin/cwsfregister.php @@ -0,0 +1,335 @@ + + Copyright (C) 2005 James Grant + + 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. +*/ + +function xmlCreateRecurse($d) +{ + global $indent; + global $output; + foreach($d AS $key=>$val) + { + if(is_numeric($key)) + { + if($val['xml_type']) + { + for($x=0;$x<$indent;$x++) $output.=" "; + $output.="<".$val['xml_type'].">\n"; + $indent++; + xmlCreateRecurse($val); + $indent--; + for($x=0;$x<$indent;$x++) $output.=" "; + $output.="\n"; + } + else + { + for($x=0;$x<$indent;$x++) $output.=" "; + $output.="<$key>\n"; + $indent++; + xmlCreateRecurse($val); + $indent--; + for($x=0;$x<$indent;$x++) $output.=" "; + $output.="\n"; + + } + } + else if(is_array($val)) + { + for($x=0;$x<$indent;$x++) $output.=" "; + $output.="<$key>\n"; + $indent++; + xmlCreateRecurse($val); + $indent--; + for($x=0;$x<$indent;$x++) $output.=" "; + $output.="\n"; + } + else + { + if($key!="xml_type" && $key!="projectid" && $key!="projectdivisions_id") + { + for($x=0;$x<$indent;$x++) $output.=" "; + $output.="<$key>$val\n"; + } + } + } +} + + + function get_cwsf_award_winners() + { + global $config; + $winners=array(); + + $q=mysql_query("SELECT * FROM award_awards WHERE cwsfaward='1' AND year='".$config['FAIRYEAR']."'"); + if(mysql_num_rows($q)==1) + { + $award=mysql_fetch_object($q); + $pq=mysql_query("SELECT * FROM award_prizes WHERE award_awards_id='$award->id'"); + while($prize=mysql_fetch_object($pq)) + { + $wq=mysql_query("SELECT + projects.id, + projects.projectnumber, + projects.title, + projects.summary, + projects.registrations_id, + projects.cwsfdivisionid, + projects.projectdivisions_id + + FROM + winners, + projects + WHERE + winners.projects_id=projects.id AND + awards_prizes_id='$prize->id' AND + winners.year='".$config['FAIRYEAR']."'"); + echo mysql_error(); + while($project=mysql_fetch_object($wq)) + { + $sq=mysql_query("SELECT * FROM students WHERE registrations_id='$project->registrations_id' AND year='".$config['FAIRYEAR']."'"); + $students=array(); + $cwsf_agecategory=0; + while($s=mysql_fetch_object($sq)) + { + if($s->grade>=7 && $s->grade<=8) + { + if($cwsf_agecategory<1) + $cwsf_agecategory=1; + } + if($s->grade>=9 && $s->grade<=10) + { + if($cwsf_agecategory<2) + $cwsf_agecategory=2; + } + if($s->grade>=11 && $s->grade<=13) + { + if($cwsf_agecategory<3) + $cwsf_agecategory=3; + } + $students[]=array( + "xml_type"=>"student", + "firstname"=>$s->firstname, + "lastname"=>$s->lastname, + "email"=>$s->email, + "gender"=>$s->sex, + "grade"=>$s->grade, + "language"=>$s->lang, + "birthdate"=>$s->dateofbirth, + "address1"=>$s->address, + "address2"=>"", + "city"=>$s->city, + "province"=>$s->province, + "postalcode"=>$s->postalcode, + "homephone"=>$s->phone, + "cellphone"=>"", + ); + } + $winners[]=array( + "xml_type"=>"project", + "projectid"=>$project->id, + "projectnumber"=>$project->projectnumber, + "title"=>$project->title, + "abstract"=>$project->summary, + "category_id"=>$cwsf_agecategory, + "division_id"=>$project->cwsfdivisionid, + "projectdivisions_id"=>$project->projectdivisions_id, + "students"=>$students, + ); + } + } + //print_r($award); + } + return $winners; + } + + + +?> +<< ".i18n("Back to Administration")."\n"; + echo "
"; + echo "
"; + + if(count($_POST['cwsfdivision'])) + { + foreach($_POST['cwsfdivision'] AS $p=>$d) + { + mysql_query("UPDATE projects SET cwsfdivisionid='$d' WHERE id='$p'"); + } + echo happy(i18n("CWSF Project Divisions saved")); + + } + + $ok=true; + //make sure we have the ysf_region_id and ysf_region_password + if(!$config['ysf_region_id']) + { + echo error(i18n("You have not yet specified your YSF Region ID. Go to the Configuration Variables page to set it")); + $ok=false; + } + if(!$config['ysf_region_password']) + { + echo error(i18n("You have not yet specified your YSF Region Password. Go to the Configuration Variables page to set it")); + $ok=false; + } + + if($ok) + { + $q=mysql_query("SELECT * FROM award_awards WHERE cwsfaward='1' AND year='".$config['FAIRYEAR']."'"); + if(!mysql_num_rows($q)) + { + echo error(i18n("Cannot find an award that is specified as the Canada-Wide Science Fair Award")); + echo i18n("Please go to the awards manager and select which award identifies your CWSF students"); + } + else if(mysql_num_rows($q)>1) + { + echo error(i18n("There is more than one award that is identified as your Canada-Wide Science Fair award.")); + echo i18n("Please go to the awards manager and choose only one award that identifies your CWSF students"); + } + else + { + $award=mysql_fetch_object($q); + echo "".i18n("CWSF Award").": ".$award->name."
"; + echo i18n("Please review the list of winning projects/students below. If it is all correct then you can click the 'Register for CWSF' button at the bottom of the page to send the information to YSF"); + echo "
"; + echo "
"; + $winners=get_cwsf_award_winners(); + echo "".i18n("Found %1 CWSF prize winners",array(count($winners))).""; + echo "
"; + $error=false; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + + foreach($winners AS $winner) + { + echo ""; + + } + echo ""; + echo "
".i18n("Project Information")."".i18n("Project Division / CWSF Project Division")."
"; + echo ""; + echo $winner['projectnumber']." - ".$winner['title']; + echo ""; + echo "
"; + foreach($winner['students'] AS $s) + { + echo " "; echo " "; echo " "; echo " "; + echo $s['firstname']." ".$s['lastname']; + echo " Email: ".$s['email']; + if(!$s['email']) + { + echo error(i18n("No Email Address"),"inline"); + $error=true; + } + echo " Grade: ".$s['grade']; + if(!$s['grade']) + { + echo error(i18n("No Grade"),"inline"); + $error=true; + } + + if(!$winner['division_id']) + { + echo "
"; + echo error(i18n("Choose a CWSF Division"),"inline"); + $error=true; + + } + echo "
"; + } + echo "
"; + + $t=mysql_query("SELECT * FROM projectdivisions WHERE year='".$config['FAIRYEAR']."' AND id='".$winner['projectdivisions_id']."'"); + $tr=mysql_fetch_object($t); + echo $tr->division; + echo "
"; + + echo "\n"; + + echo "
"; + echo ""; + echo "
"; + echo ""; + + if(!$error) + { + $reg=array("registration"=>array( + "ysf_region_id"=>$config['ysf_region_id'], + "ysf_region_password"=>$config['ysf_region_password'], + "projects"=>$winners + ) + ); + + $output=""; + xmlCreateRecurse($reg); + $xmldata=$output; + + echo "

".i18n("The following data will be sent to YSF")."

"; + echo "
"; + echo ""; + echo ""; + echo "
"; + echo "
"; + echo i18n("Warning! You can only use this feature once, and it will send whatever data is listed above. If you try to submit this data a second time to YSF it will not work. So please make sure everything is correct before submitting!"); + echo "
"; + echo "
"; + echo ""; + echo "
"; + } + else + { + echo error(i18n("You must correct the above errors before registration can proceed")); + + } + } + + + + } + + send_footer(); + +?> diff --git a/common.inc.php b/common.inc.php index 9184c9e1..2904d80d 100644 --- a/common.inc.php +++ b/common.inc.php @@ -843,4 +843,14 @@ function generatePassword() } +$CWSFDivisions=array( + 1=>"Biotechnology & Pharmaceutical Sciences", + 2=>"Computing & Information Technology", + 3=>"Earth & Environmental Sciences", + 4=>"Engineering", + 5=>"Health Sciences", + 6=>"Life Sciences", + 7=>"Physical & Mathematical Sciences" +); + ?> diff --git a/config/divisions_cwsf.php b/config/divisions_cwsf.php new file mode 100644 index 00000000..21bca53c --- /dev/null +++ b/config/divisions_cwsf.php @@ -0,0 +1,78 @@ + + Copyright (C) 2005 James Grant + + 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. +*/ +?> +<< ".i18n("Back to Configuration")."
"; + + if(count($_POST['cwsfdivision'])) + { + foreach($_POST['cwsfdivision'] AS $k=>$v) + { + mysql_query("UPDATE projectdivisions SET cwsfdivisionid='$v' WHERE id='$k' AND year='".$config['FAIRYEAR']."'"); + } + echo happy(i18n("Corresponding CWSF divisions saved")); + } + + echo "
"; + + echo "

".i18n("CWSF Project Divisions")."

"; + + + echo i18n("For each of your divisions, please select a corresponding CWSF division if applicable. If no corresponding CWSF division is chosen then you will need to manually select the CWSF division for each project that you register for the CWSF. You can select the 'most likely' division to use as a default which can then be changed on a per-project basis when you perform the automatic CWSF registration"); + +echo "
"; +echo "
"; + echo ""; + echo ""; + echo "\n"; + echo "\n"; + echo ""; + + $q=mysql_query("SELECT * FROM projectdivisions WHERE year='".$config['FAIRYEAR']."' ORDER BY id"); + while($r=mysql_fetch_object($q)) + { + echo ""; + echo " "; + echo " "; + echo ""; + } + echo ""; + echo "
".i18n("Your Division")."".i18n("Corresponding CWSF Division")."
".i18n($r->division).""; + echo "\n"; + echo "
"; + echo ""; + echo "
"; + echo "
"; + + send_footer(); +?> diff --git a/config/index.php b/config/index.php index 86ce090e..16bfbe04 100644 --- a/config/index.php +++ b/config/index.php @@ -31,6 +31,7 @@ echo "".i18n("Important Dates")."
"; echo "".i18n("Project Age Categories")."
"; echo "".i18n("Project Divisions")."
"; + echo "".i18n("CWSF Project Divisions")."
"; echo "".i18n("Project Sub-Divisions")."
"; echo "".i18n("Page Texts")."
"; echo "".i18n("Exhibitor Signature Page")."
"; diff --git a/db/db.code.version.txt b/db/db.code.version.txt index 9902f178..f04c001f 100644 --- a/db/db.code.version.txt +++ b/db/db.code.version.txt @@ -1 +1 @@ -28 +29