science-ation/plugins/evaluations/eval_export_download.php

146 lines
7.9 KiB
PHP
Raw Normal View History

<?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;
?>