forked from science-ation/science-ation
146 lines
7.9 KiB
PHP
146 lines
7.9 KiB
PHP
<?php
|
|
/*
|
|
This file is a plug-in to the 'Science Fair In A Box' project
|
|
SFIAB Website: http://www.sfiab.ca
|
|
|
|
Copyright (C) 2011 At Work Software (dennis@spanogle.net>
|
|
Copyright (C) 2011 Dennis Spanogle <dennis@spanogle.net>
|
|
|
|
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.
|
|
*/
|
|
?>
|
|
<?php
|
|
include "sfiab_common.inc.php"; // check SFIAB install and get config etc.
|
|
include "eval_common.inc.php"; // get evaluations setup
|
|
// debug test
|
|
$CSVoption = $_GET['option'];
|
|
$Teamworknote = $_GET['teamnote'];
|
|
|
|
//$CSVoption = 1;
|
|
//$Teamworknote = "test";
|
|
//echo "opt= ".$CSVoption." note=".$Teamworknote;
|
|
//exit;
|
|
// This selects from judges_teams_timeslots_projects_link as top table - gets ONLY projects with assigned teams (I.E. Status = complete when schedule assignements are made
|
|
// It gets One record for each project - judges team assignment. I.E. one record for each required evaluation (Apperson Score Form)
|
|
$qstr = "SELECT eval_projects.team AS IsTeam, eval_projects.scheme_id, projects.projectnumber, projects.`language`, projects.floornumber, projects.title, ".
|
|
"projects.shorttitle, judges_teams.num AS team_num, judges_teams.name AS team_name, projectcategories.category, ".
|
|
"projectcategories.category_shortform, projectcategories.mingrade, projectcategories.maxgrade, projectdivisions.division, ".
|
|
"projectdivisions.division_shortform, projectdivisions.cwsfdivisionid, eval_projects.eval_score, eval_projects.final_score, ".
|
|
"eval_projects.eval_score_status, eval_projects.overall_status, eval_projects.last_change, projects.`year`, judges_timeslots.`date` AS tsdate, ".
|
|
"judges_timeslots.starttime AS tsstarttime, judges_timeslots.endtime AS tsendtime, judges_timeslots.name AS tsname, ".
|
|
"judges_timeslots.type AS tstype, judges_teams_timeslots_projects_link.judges_timeslots_id, judges_teams_timeslots_projects_link.projects_id, ".
|
|
"judges_teams.id, registrations.num, registrations.status, judges_teams_timeslots_projects_link.score ".
|
|
"FROM judges_teams, judges_teams_timeslots_projects_link, judges_timeslots, projects, eval_projects, projectcategories, projectdivisions, registrations ".
|
|
"WHERE judges_teams.id = judges_teams_timeslots_projects_link.judges_teams_id AND ".
|
|
"judges_teams_timeslots_projects_link.judges_timeslots_id = judges_timeslots.id AND ".
|
|
"judges_teams_timeslots_projects_link.projects_id = eval_projects.project_id AND projects.id = eval_projects.project_id AND ".
|
|
"projects.projectcategories_id = projectcategories.id AND projects.projectdivisions_id = projectdivisions.id AND ".
|
|
"projects.registrations_id = registrations.id ".
|
|
" ORDER BY projects.projectnumber, team_num";
|
|
$q = mysql_query($qstr);
|
|
if (!$q OR mysql_num_rows($q) == 0){
|
|
echo "Error reading tables or no records. (Did you Link SFIAB to Evaluations? Did 'score' get added to the judges_teams_timeslots_projects_link table?)<br />";
|
|
exit;
|
|
}
|
|
$filename = "EMPTY FILE Do Not Download Not Implemented.csv";
|
|
if ($CSVoption == 1)
|
|
{
|
|
// here is what I want in the data. may take several queries to get it. Need one record for each record in eval_projects_entries
|
|
$header = "\"ProjectNum\",\"AppersonNum\",\"ShortTitle\",\"Title\",\"IsTeamProject\",\"FloorNum\",\"Language\",\"TeamProjectNote\",\"JudgeTeamNum\",\"JudgeTeamName\",\"JudgeTeamTime\",\"JudgeTeamLeader\",\"Category\",\"CatShort\",\"Division\",\"DivShort\",\"Year\",\"AppersonBarCode\",\"scheme_Id\",\"score\"";
|
|
$filename = "SFIAB_Eval_Projects_Judges_Data.csv";
|
|
}
|
|
if ($CSVoption == 5 ){
|
|
// Apperson Scanner Student data.// "Student ID","FirstName","LastName"
|
|
$header = "\"Student ID\",\"FirstName\",\"LastName\"";
|
|
$filename = "SFIAB_Eval_Appperson_Student_data.csv";
|
|
|
|
}
|
|
// **********************************************write the header out to the file ************************************
|
|
$download = $header."\r\n";
|
|
$num_records = mysql_num_rows($q);
|
|
while($r=mysql_fetch_object($q)) {
|
|
// get some sepecial items from the raw data.
|
|
// this is for test only at this time. will be used in the Apperson Scanner export and import.
|
|
// to create the file necessary to preslug the score forms.
|
|
// Barcode = 1 or 2 for team, 4 digits exn, 4 digits team number, 2 digits checksum?
|
|
$AppPrjNum = substr($r->projectnumber , 1);
|
|
if ( strlen($AppPrjNum) < 4 )
|
|
{
|
|
$AppPrjNum = sprintf( "%04d",$AppPrjNum); // "0".$AppPrjNum;
|
|
}
|
|
$teamtime = $r->tsdate." ".$r->tsstarttime."-".$r->tsendtime;
|
|
$tcode = "1";
|
|
$Teamnote = "";
|
|
if ($r->IsTeam == "yes"){
|
|
$tcode = "2";
|
|
// passed $Teamworknote when page opened
|
|
$Teamnote = $Teamworknote;
|
|
}
|
|
$fmtTeamNum = sprintf("%04d", $r->team_num);
|
|
$StudentID = $tcode.$AppPrjNum.$fmtTeamNum;
|
|
// calculate the checksum
|
|
$checksum = (int)substr($StudentID,0,1);
|
|
$checksum += (int)substr($StudentID,1,1);
|
|
$checksum +=(int) substr($StudentID,2,1);
|
|
$checksum += (int)substr($StudentID,3,1);
|
|
$checksum += (int)substr($StudentID,4,1);
|
|
$checksum += (int)substr($StudentID,5,1);
|
|
$checksum += (int)substr($StudentID,6,1);
|
|
$checksum += (int)substr($StudentID,7,1);
|
|
$checksum += (int)substr($StudentID,8,1);
|
|
$checksum = sprintf("%02d",$checksum);
|
|
$AppBarCode = "<".$tcode.$AppPrjNum.$fmtTeamNum."/".$checksum.">";
|
|
// Get the Team leader name (to be done)
|
|
$TeamLeader = "n/a";
|
|
// ready to create the files
|
|
if($CSVoption == 1){
|
|
// $header = "\"ProjectNum\",\"AppersonNum\",\"ShortTitle\",\"Title\",\"IsTeam\",\"FloorNum\",\"Language\",\"TeamNote\",\"TeamNum \",\"TeamName\",\"TeamTime\",\"TeamLeader\",\"Category\",\"CatShort\",\"Division\",\"DivShort\",\"Year\",\"AppersonBarCode\",\"scheme_Id\",\"criteria_id\",\"Level_id\",\"score\"";
|
|
$title = str_replace("\"","'",$r->title);
|
|
$recordout = "\"".$r->projectnumber."\",\"".$AppPrjNum."\",\"".$r->shorttitle."\",\"".$title."\",\"".$r->IsTeam."\",\"".$r->floornumber."\",\"".$r->language."\",\"".$Teamnote."\",\"".
|
|
$r->team_num."\",\"".$r->team_name."\",\"".$teamtime."\",\"".$TeamLeader."\",\"".$r->category."\",\"".$r->category_shortform."\",\"".$r->division."\",\"".$r->division_shortform."\",\"".$r->year."\",\"".
|
|
$AppBarCode."\",\"".$r->scheme_id."\",\"".$r->score."\"";
|
|
// ********************************************write the record out to the file************************************************
|
|
$download = $download.$recordout."\r\n";
|
|
}
|
|
if ($CSVoption == 5){ // Apperson Scanner Student data
|
|
// "TPPPPJJJJ", "PRJ PPPPP 'TEAM' TITLETruncated?","JUN JJJJ JLASTNAME, JFIRSTNAME"
|
|
$Teamnote = "";
|
|
if ($r->IsTeam == "yes"){
|
|
$Teamnote = "(Team Project)";
|
|
}
|
|
$Firstname = "Proj ".$r->projectnumber." ".$Teamnote." ".$r->title;
|
|
if(strlen($Firstname) > 100){
|
|
$Firstname = substr($Firstname,100); // limit to 100 max in Apperson Datalink
|
|
}
|
|
// replace and double quotes in $Firstname with single quotes so CSV import will work.
|
|
$Firstname = str_replace("\"","'",$Firstname);
|
|
|
|
$recordout = "\"".$StudentID."\",\"".$Firstname."\",\"JudgeTeamNum ".$r->team_num."\"";
|
|
// ********************************************write the record out to the file************************************************
|
|
$download = $download.$recordout."\r\n";
|
|
}
|
|
} // while $r=mysql_fetch_object($q)
|
|
ob_start();
|
|
header("Content-type: text/x-csv");
|
|
header("Content-disposition: inline; filename=".$filename);
|
|
header("Content-length: ".strlen($download));
|
|
header("Pragma: public");
|
|
|
|
echo $download;
|
|
//header("Location: index.php");
|
|
//ob_get_status()
|
|
exit;
|
|
?>
|