science-ation/admin/cwsfregister.php
james 2019e24b89 Add the 'one click' CWSF registration code!
It current generates the XML but does not implement the sending to YSF (thats still to come!)
2006-10-19 21:39:30 +00:00

336 lines
9.1 KiB
PHP

<?
/*
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.
*/
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.="</".$val['xml_type'].">\n";
}
else
{
for($x=0;$x<$indent;$x++) $output.=" ";
$output.="<$key>\n";
$indent++;
xmlCreateRecurse($val);
$indent--;
for($x=0;$x<$indent;$x++) $output.=" ";
$output.="</$key>\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.="</$key>\n";
}
else
{
if($key!="xml_type" && $key!="projectid" && $key!="projectdivisions_id")
{
for($x=0;$x<$indent;$x++) $output.=" ";
$output.="<$key>$val</$key>\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;
}
?>
<?
require("../common.inc.php");
require("../projects.inc.php");
auth_required('admin');
send_header("Administration - One-Click CWSF Registration");
echo "<a href=\"index.php\">&lt;&lt; ".i18n("Back to Administration")."</a>\n";
echo "<br />";
echo "<br />";
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 "<b>".i18n("CWSF Award").":</b> ".$award->name."<br />";
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 "<br />";
echo "<br />";
$winners=get_cwsf_award_winners();
echo "<b>".i18n("Found %1 CWSF prize winners",array(count($winners)))."</b>";
echo "<br />";
$error=false;
echo "<form method=\"post\" action=\"cwsfregister.php\">";
echo "<table class=\"viewtable\">";
echo "<tr><th>".i18n("Project Information")."</th>";
echo "<th>".i18n("Project Division / CWSF Project Division")."</th>";
echo "</tr>";
foreach($winners AS $winner)
{
echo "<tr><td>";
echo "<b>";
echo $winner['projectnumber']." - ".$winner['title'];
echo "</b>";
echo "<br />";
foreach($winner['students'] AS $s)
{
echo "&nbsp;"; echo "&nbsp;"; echo "&nbsp;"; echo "&nbsp;";
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 "<br />";
echo error(i18n("Choose a CWSF Division"),"inline");
$error=true;
}
echo "<br />";
}
echo "</td><td>";
$t=mysql_query("SELECT * FROM projectdivisions WHERE year='".$config['FAIRYEAR']."' AND id='".$winner['projectdivisions_id']."'");
$tr=mysql_fetch_object($t);
echo $tr->division;
echo "<br />";
echo "<select name=\"cwsfdivision[".$winner['projectid']."]\">";
echo "<option value=\"\">".i18n("No corresponding CWSF division")."</option>\n";
foreach($CWSFDivisions AS $k=>$v)
{
if($winner['division_id'])
{
if($k==$winner['division_id']) $sel="selected=\"selected\""; else $sel="";
}
else
{
if($k==$tr->cwsfdivisionid) $sel="selected=\"selected\""; else $sel="";
}
echo "<option $sel value=\"$k\">".i18n($v)."</option>\n";
}
echo "</select>\n";
echo "</td></tr>";
}
echo "<tr><td></td><td>";
echo "<input type=\"submit\" value=\"Save CWSF Divisions\">";
echo "</td></tr>";
echo "</table>";
echo "</form>";
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 "<h3>".i18n("The following data will be sent to YSF")."</h3>";
echo "<form method=\"post\" action=\"cwsfregister.php\">";
echo "<input type=\"hidden\" name=\"action\" value=\"register\">";
echo "<textarea rows=\"15\" cols=\"80\" name=\"xml\">";
echo $xmldata;
echo "</textarea>";
echo "<br />";
echo "<br />";
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 "<br />";
echo "<br />";
echo "<input type=\"submit\" value=\"".i18n("Register for CWSF")."\">";
echo "</form>";
}
else
{
echo error(i18n("You must correct the above errors before registration can proceed"));
}
}
}
send_footer();
?>