2007-11-29 22:30:35 +00:00
< ?
/*
This file is part of the 'Science Fair In A Box' project
SFIAB Website : http :// www . sfiab . ca
Copyright ( C ) 2007 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 .
*/
2009-09-21 07:18:39 +00:00
require_once ( '../common.inc.php' );
require_once ( '../user.inc.php' );
require_once ( '../projects.inc.php' );
require_once ( 'curl.inc.php' );
user_auth_required ( 'committee' , 'admin' );
//function get_cwsf_award_winners()
2010-04-18 22:40:10 +00:00
function get_winners ( $awardid , $fairs_id )
2009-09-21 07:18:39 +00:00
{
global $config ;
2007-11-29 22:30:35 +00:00
2009-09-21 07:18:39 +00:00
/* Mappings of the name we want => to the column name returned in MYSQL */
$school_fields = array ( 'schoolname' => 'school' ,
'schoollang' => 'schoollang' ,
'schoollevel' => 'schoollevel' ,
'board' => 'board' ,
'district' => 'district' ,
'phone' => 'phone' ,
'fax' => 'fax' ,
'address' => 'address' ,
'city' => 'city' ,
'province_code' => 'province_code' ,
'postalcode' => 'postalcode' ,
2009-10-11 03:32:14 +00:00
'schoolemail' => 'schoolemail' );
/* 'principal' => 'principal' ,
2009-09-21 07:18:39 +00:00
'sciencehead' => 'sciencehead' ,
'scienceheademail' => 'scienceheademail' ,
2009-10-11 03:32:14 +00:00
'scienceheadphone' => 'scienceheadphone' ); */
2009-09-21 07:18:39 +00:00
$student_fields = array ( 'firstname' => 'firstname' ,
'lastname' => 'lastname' ,
'email' => 'email' ,
'gender' => 'sex' ,
'grade' => 'grade' ,
'language' => 'lang' ,
'birthdate' => 'dateofbirth' ,
'address' => 'address' ,
'city' => 'city' ,
'province' => 'province' ,
'postalcode' => 'postalcode' ,
'phone' => 'phone' ,
'teachername' => 'teachername' ,
'teacheremail' => 'teacheremail' );
2010-04-18 22:39:55 +00:00
$awards = array ();
if ( $awardid == - 1 ) {
/* Get all for this fair */
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT * FROM award_awards WHERE award_source_fairs_id=' $fairs_id ' AND year=' { $config [ 'FAIRYEAR' ] } ' " );
if ( $q -> rowCount () == 0 ) {
2010-04-18 22:39:55 +00:00
error_ ( " Can't find award id $awardid " );
return false ;
}
2024-12-07 01:54:02 +00:00
while ( $a = $q -> fetch ( PDO :: FETCH_ASSOC )) {
2010-04-18 22:39:55 +00:00
$awards [] = $a ;
}
} else {
/* Get the award */
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT * FROM award_awards WHERE id=' $awardid ' AND year=' { $config [ 'FAIRYEAR' ] } ' " );
$q -> execute ();
if ( $q -> rowCount () != 1 ) {
2010-04-18 22:39:55 +00:00
error_ ( " Can't find award id $awardid " );
return false ;
}
2024-12-07 01:54:02 +00:00
$award = $q -> fetch ( PDO :: FETCH_ASSOC );
2010-04-18 22:39:55 +00:00
$awards [] = $award ;
2009-09-21 07:18:39 +00:00
}
2009-09-23 05:53:33 +00:00
/* Get the fair for the div/cat mappings */
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT * FROM fairs WHERE id=' { $award [ 'award_source_fairs_id' ] } ' " );
$q -> execute ();
$fair = $q -> fetch ( PDO :: FETCH_ASSOC );
2010-04-18 22:39:55 +00:00
$catmap = unserialize ( $fair [ 'catmap' ]);
$divmap = unserialize ( $fair [ 'divmap' ]);
foreach ( $awards as $award ) {
2010-04-18 22:40:08 +00:00
$winners = array ( 'id' => $award [ 'id' ],
'award_name' => $award [ 'name' ],
2010-04-18 22:39:55 +00:00
'external_identifier' => $award [ 'external_identifier' ],
'year' => $config [ 'FAIRYEAR' ],
'prizes' => array ());
2007-11-29 22:30:35 +00:00
2010-04-18 22:39:55 +00:00
if ( $fair [ 'type' ] != 'sfiab' ) {
/* YSC Compatability */
$winners [ 'external_postback' ] = $award [ 'external_postback' ];
}
/* Get the prizes */
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT * FROM award_prizes WHERE award_awards_id=' { $award [ 'id' ] } ' " );
$q -> execute ();
while ( $prize = $q -> fetch ( PDO :: FETCH_ASSOC )) {
2010-04-18 22:39:55 +00:00
$pid = $prize [ 'id' ];
2024-12-07 01:54:02 +00:00
$wq = $pdo -> prepare ( " SELECT projects.* FROM award_prizes
2010-04-18 22:39:55 +00:00
LEFT JOIN winners ON winners . awards_prizes_id = award_prizes . id
LEFT JOIN projects ON projects . id = winners . projects_id
WHERE
awards_prizes_id = '$pid' AND
winners . year = '{$config[' FAIRYEAR ']}' " );
2024-12-07 01:54:02 +00:00
$wq -> execute ();
echo $pdo -> erroInfo ();
2010-04-18 22:39:55 +00:00
/* Get all projects assigned to this prize */
$prizewinners = array ();
2024-12-07 01:54:02 +00:00
while ( $project = $wq -> fetch ( PDO :: FETCH_ASSOC )) {
2010-04-18 22:39:55 +00:00
/* Get the students */
2024-12-07 01:54:02 +00:00
$sq = $pdo -> prepare ( " SELECT * FROM students WHERE registrations_id=' { $project [ 'registrations_id' ] } '
2010-04-18 22:39:55 +00:00
AND year = '{$config[' FAIRYEAR ']}' " );
2024-12-07 01:54:02 +00:00
$sq -> execute ();
2010-04-18 22:39:55 +00:00
$students = array ();
2024-12-07 01:54:02 +00:00
while ( $s = $sq -> fetch ( PDO :: FETCH_ASSOC )) {
2010-04-18 22:39:55 +00:00
/* Get the student's school */
2024-12-07 01:54:02 +00:00
$schoolq = $pdo -> prepare ( " SELECT * FROM schools WHERE id=' { $s [ 'schools_id' ] } ' " );
$schoolq -> execute ();
$schoolr = $schoolq -> fetch ( PDO :: FETCH_ASSOC );
2010-04-18 22:39:55 +00:00
$school = array ( " xml_type " => " school " ); /* for ysc compatability */
foreach ( $school_fields as $k => $v )
$school [ $k ] = $schoolr [ $v ];
/* Pack up the student data too */
$student = array ( 'xml_type' => 'student' , /* for ysc compatability */
'school' => $school );
foreach ( $student_fields as $k => $v )
$student [ $k ] = $s [ $v ];
$students [] = $student ;
}
/* Turn our load ID into a server-side cat/div id */
$cat_id = $catmap [ $project [ 'projectcategories_id' ]];
$div_id = $divmap [ $project [ 'projectdivisions_id' ]];
/* Save the project info => students */
$prizewinners [] = array ( 'xml_type' => 'project' , /* for ysc compatability */
'projectid' => $project [ 'id' ],
'projectnumber' => $project [ 'projectnumber' ],
'title' => $project [ 'title' ],
'abstract' => $project [ 'summary' ],
'language' => $project [ 'language' ],
'projectcategories_id' => $cat_id ,
'projectdivisions_id' => $div_id ,
2010-04-18 22:40:08 +00:00
'client_projectdivisions_id' => $project [ 'projectdivisions_id' ],
2010-04-18 22:39:55 +00:00
'students' => $students );
2007-11-29 22:30:35 +00:00
}
2010-04-18 22:39:55 +00:00
/* Save the prize info => projects */
$winners [ 'prizes' ][ $prize [ 'prize' ]] = array (
2010-04-18 22:40:08 +00:00
'id' => $prize [ 'id' ],
'name' => $prize [ 'prize' ],
2010-04-18 22:39:55 +00:00
'xml_type' => 'prize' , /* For ysc compatability */
'identifier' => $prize [ 'external_identifier' ], /* for ysc compatability */
'projects' => $prizewinners );
2007-11-29 22:30:35 +00:00
}
2010-04-18 22:39:55 +00:00
$all_winners [] = $winners ;
2007-11-29 22:30:35 +00:00
}
2010-04-18 22:39:55 +00:00
return $all_winners ;
2009-09-21 07:18:39 +00:00
}
2010-04-18 22:40:10 +00:00
function count_winners ( $awardid , $fairs_id )
{
global $config ;
$count = 0 ;
$awards = array ();
if ( $awardid == - 1 ) {
/* Get all for this fair */
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT * FROM award_awards WHERE award_source_fairs_id=' $fairs_id ' AND year=' { $config [ 'FAIRYEAR' ] } ' " );
$q -> execute ();
if ( $q -> rowCount () == 0 ) {
2010-04-18 22:40:10 +00:00
error_ ( " Can't find award id $awardid " );
return 0 ;
}
2024-12-07 01:54:02 +00:00
while ( $a = $q -> fetch ( PDO :: FETCH_ASSOC )) {
2010-04-18 22:40:10 +00:00
$awards [] = $a ;
}
} else {
/* Get the award */
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT * FROM award_awards WHERE id=' $awardid ' AND year=' { $config [ 'FAIRYEAR' ] } ' " );
$q -> execute ();
if ( $q -> rowcount () != 1 ) {
2010-04-18 22:40:10 +00:00
error_ ( " Can't find award id $awardid " );
return 0 ;
}
2024-12-07 01:54:02 +00:00
$award = $q -> fetch ( PDO :: FETCH_ASSOC );
2010-04-18 22:40:10 +00:00
$awards [] = $award ;
}
foreach ( $awards as $award ) {
/* Get the prizes */
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT * FROM award_prizes WHERE award_awards_id=' { $award [ 'id' ] } ' " );
$q -> execute ();
while ( $prize = $q -> fetch ( PDO :: FETCH_ASSOC )) {
2010-04-18 22:40:10 +00:00
$pid = $prize [ 'id' ];
2024-12-07 01:54:02 +00:00
$wq = $pdo -> prepare ( " SELECT COUNT(projects.id) as C FROM award_prizes
2010-04-18 22:40:10 +00:00
LEFT JOIN winners ON winners . awards_prizes_id = award_prizes . id
LEFT JOIN projects ON projects . id = winners . projects_id
WHERE
awards_prizes_id = '$pid' AND
winners . year = '{$config[' FAIRYEAR ']}' " );
2024-12-07 01:54:02 +00:00
$wq -> execute ();
$wc = $wq -> fetch ( PDO :: FETCH_ASSOC );
2010-04-18 22:40:10 +00:00
$count += $wc [ 'C' ];
}
}
return $count ;
}
2010-04-18 22:40:08 +00:00
function load_server_cats_divs ( $fairs_id )
{
global $config ;
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT * FROM fairs WHERE id=' $fairs_id ' " );
$q -> execute ();
$fair = $q -> fetch ( PDO :: FETCH_ASSOC );
2010-04-18 22:40:08 +00:00
$req = array ( 'get_categories' => array ( 'year' => $config [ 'FAIRYEAR' ]),
'get_divisions' => array ( 'year' => $config [ 'FAIRYEAR' ])
);
$data = curl_query ( $fair , $req );
/* If selected mappings don't exist, try to discover some */
if ( trim ( $fair [ 'catmap' ]) != '' ) {
$catmap = unserialize ( $fair [ 'catmap' ]);
} else {
$catmap = array ();
/* Load ours */
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT * FROM projectcategories WHERE year=' { $config [ 'FAIRYEAR' ] } ' ORDER BY mingrade " );
$q -> execute ();
while ( $r = $q -> fetch ( PDO :: FETCH_OBJ )) {
2010-04-18 22:40:08 +00:00
foreach ( $data [ 'categories' ] as $id => $c ) {
if ( $c [ 'mingrade' ] == $r -> mingrade ) {
$catmap [ $r -> id ] = $id ;
break ;
}
}
}
}
if ( trim ( $fair [ 'divmap' ]) != '' ) {
$divmap = unserialize ( $fair [ 'divmap' ]);
} else {
$ret [ 'divmap' ] = array ();
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT * FROM projectdivisions WHERE year=' { $config [ 'FAIRYEAR' ] } ' ORDER BY id " );
$q -> execute ();
while ( $r = $q -> fetch ( PDO :: FETCH_OBJ )) {
2010-04-18 22:40:08 +00:00
$lowest = 999 ;
$lowest_id = 0 ;
foreach ( $data [ 'divisions' ] as $id => $d ) {
/* Who knew levenshtein was builtin to php as of PHP 4 */
$l = levenshtein ( $d [ 'division' ], $r -> division );
if ( $l < $lowest ) {
$lowest = $l ;
$lowest_id = $id ;
}
}
$divmap [ $r -> id ] = $lowest_id ;
}
}
return array ( $data [ 'categories' ], $data [ 'divisions' ], $catmap , $divmap );
}
2009-09-21 07:18:39 +00:00
switch ( $_GET [ 'action' ]) {
case 'award_upload' :
2010-04-18 22:40:08 +00:00
$award_awards_id = intval ( $_POST [ 'award_awards_id' ]);
$fairs_id = intval ( $_POST [ 'fairs_id' ]);
$divs = $_POST [ 'div' ];
$cats = $_POST [ 'cat' ];
2010-04-18 22:39:55 +00:00
$all_winners = get_winners ( $award_awards_id , $fairs_id );
2009-09-21 07:18:39 +00:00
/* Get the fair */
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT * FROM fairs WHERE id=' $fairs_id }' " );
$q -> execute ();
$fair = $q -> fetch ( PDO :: FETCH_ASSOC );;
2009-09-21 07:18:39 +00:00
2009-09-21 07:48:54 +00:00
echo '<br />' ;
2010-04-18 22:40:08 +00:00
/* Check that we ' re going to upload something , and override the
* divisions / cats with the divisions taht were set , and the categories
* that were computed */
2010-04-18 22:39:55 +00:00
$upload_something = false ;
2010-04-18 22:40:08 +00:00
foreach ( $all_winners as & $w ) {
foreach ( $w [ 'prizes' ] as & $p ) {
2010-04-18 22:40:10 +00:00
if ( count ( $p [ 'projects' ]))
$upload_something = true ;
/* Only update divs / cats for SFIAB fairs , the
* YSC / STO awards system doesn ' t care about divisions , but YSC
* registration does , but that ' s a different bit of code */
2010-04-21 07:05:00 +00:00
if ( $fair [ 'type' ] != 'sfiab' ) continue ;
2010-04-18 22:40:10 +00:00
2010-04-18 22:40:08 +00:00
foreach ( $p [ 'projects' ] as & $pr ) {
$div_id = intval ( $divs [ $w [ 'id' ]][ $p [ 'id' ]][ $pr [ 'projectid' ]]);
$pr [ 'projectdivisions_id' ] = $div_id ;
$cat_id = intval ( $cats [ $w [ 'id' ]][ $p [ 'id' ]][ $pr [ 'projectid' ]]);
$pr [ 'projectcategories_id' ] = $cat_id ;
2010-03-30 16:47:30 +00:00
}
2009-09-21 07:18:39 +00:00
}
2010-04-18 22:39:55 +00:00
}
if ( $upload_something == false ) {
echo notice ( i18n ( 'No winners to be uploaded' ));
exit ;
}
2010-04-18 22:40:08 +00:00
2010-04-18 22:39:55 +00:00
if ( $fair [ 'type' ] == 'ysc' ) {
if ( $award_awards_id == - 1 ) {
echo " Multiple uploads not supported for YSC targets. \n " ;
exit ;
}
/* Pull the single - award out , get_winners () will never
* return more than one award for YSC targets */
$winners = array_shift ( $all_winners );
$w = array ();
foreach ( $winners [ 'prizes' ] as $prize_name => $prize ) {
$w [] = $prize ;
2007-11-29 22:30:35 +00:00
}
2010-04-18 22:39:55 +00:00
$req = array ( " awardwinners " => array (
" username " => $fair [ 'username' ],
" password " => $fair [ 'password' ],
" identifier " => $winners [ 'external_identifier' ],
" prizes " => $w ,
)
);
$url = $winners [ 'external_postback' ];
} else {
$req = array ();
$req [ 'awards_upload' ] = $all_winners ;
$url = '' ; /* url is ignored for type = sfiab */
}
echo i18n ( " Sending winners to %1... " , array ( '<b>' . $fair [ 'name' ] . '</b>' ));
echo '<br />' ;
// echo "<pre>"; print_r($req); echo "</pre>";
$data = curl_query ( $fair , $req , $url );
if ( $data [ 'error' ] != 0 ) {
echo error ( " Server said: " . htmlspecialchars ( print_r ( $data , true )));
} else {
if ( is_array ( $data [ 'notice' ]))
echo notice ( " { $fair [ 'name' ] } server said: <pre> " . join ( " \n " , $data [ 'notice' ]) . " </pre> " );
else if ( is_array ( $data [ 'message' ]))
echo notice ( " { $fair [ 'name' ] } server said: <pre> " . join ( " \n " , $data [ 'message' ]) . " </pre> " );
else if ( $data [ 'message' ])
echo notice ( " { $fair [ 'name' ] } server said: <pre> " . $data [ 'message' ] . " </pre> " );
else
echo notice ( " { $fair [ 'name' ] } server said: <pre> " . htmlspecialchars ( print_r ( $data , true )) . " </pre> " );
echo happy ( i18n ( " Upload completed successfully " ));
2009-09-23 05:53:33 +00:00
}
exit ;
2010-04-18 22:39:55 +00:00
2009-09-23 05:53:33 +00:00
case 'catdiv_load' :
2010-04-18 22:40:08 +00:00
$fairs_id = intval ( $_GET [ 'fairs_id' ]);
list ( $c , $d , $cm , $dm ) = load_server_cats_divs ( $fairs_id );
$divs = projectdivisions_load ();
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT * FROM fairs WHERE id=' $fairs_id }' " );
$q -> execute ();
$fair = $q -> fetch ( PDO :: FETCH_ASSOC );
2009-09-23 05:53:33 +00:00
2010-04-18 22:40:08 +00:00
?> <h4><?=i18n("Division Mapping")?></h4>
< br />
2009-09-23 05:53:33 +00:00
2010-04-18 22:40:08 +00:00
< form id = " catdiv_form " >
< input type = " hidden " name = " fairs_id " value = " <?= $fairs_id ?> " />
2009-09-23 05:53:33 +00:00
2010-04-18 22:40:08 +00:00
< table class = " editor " >
< tr >< th >< ? = i18n ( " Our Division " ) ?> </th><th><?=i18n("%1 Division", array($fair['abbrv']))?></th></tr>
< ?
foreach ( $divs as $div ) {
echo " <tr><td class= \" label \" > { $div [ 'division' ] } => </td> " ;
echo " <td><select name= \" div[ { $div [ 'id' ] } ] \" class= \" upload_div \" > " ;
$mapto = $dm [ $div [ 'id' ]];
foreach ( $d as $sdiv ) {
$sel = ( $sdiv [ 'id' ] == $mapto ) ? 'selected="selected"' : '' ;
echo " <option $sel value= \" { $sdiv [ 'id' ] } \" > { $sdiv [ 'division' ] } </option> " ;
2009-09-23 05:53:33 +00:00
}
2010-04-18 22:40:08 +00:00
echo '</select></td></tr>' ;
2009-09-23 05:53:33 +00:00
}
2010-04-18 22:40:08 +00:00
?>
</ table >
</ form >
< br />
< ?
2009-09-23 05:53:33 +00:00
exit ;
case 'catdiv_save' :
2010-04-18 22:40:08 +00:00
$fairs_id = intval ( $_POST [ 'fairs_id' ]);
2009-09-23 05:53:33 +00:00
$cat = array ();
2010-04-18 22:40:08 +00:00
// foreach($_POST['cat'] AS $key=>$c) {
// $cat[intval($key)] = intval($c);
// }
2009-09-23 05:53:33 +00:00
$div = array ();
foreach ( $_POST [ 'div' ] AS $key => $d ) {
$div [ intval ( $key )] = intval ( $d );
2007-11-29 22:30:35 +00:00
}
2009-09-21 07:18:39 +00:00
2024-12-07 01:54:02 +00:00
$catmap = serialize ( $cat );
$divmap = serialize ( $div );
$q = $pdo -> prepare ( " UPDATE fairs SET catmap=' $catmap ',divmap=' $divmap ' WHERE id=' $fairs_id ' " );
$q -> execute ();
echo $pdo -> errorInfo ();
2009-09-23 05:53:33 +00:00
2010-04-18 22:40:08 +00:00
happy_ ( " Category/Division mapping information saved " );
2009-09-21 07:18:39 +00:00
exit ;
2009-09-25 19:15:43 +00:00
case 'additional_materials' :
$award_awards_id = intval ( $_GET [ 'award_awards_id' ]);
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT award_source_fairs_id,external_identifier FROM award_awards WHERE id=' $award_awards_id ' " );
$q -> execute ();
$a = $q -> fetch ( PDO :: FETCH_ASSOC );
$q = $pdo -> prepare ( " SELECT * FROM fairs WHERE id=' { $a [ 'award_source_fairs_id' ] } ' " );
$q -> execute ();
$fair = $q -> fetch ( PDO :: FETCH_ASSOC );
2009-09-25 19:15:43 +00:00
$req = array ( 'award_additional_materials' => array (
'year' => $config [ 'FAIRYEAR' ],
'identifier' => $a [ 'external_identifier' ])
);
$data = curl_query ( $fair , $req , $url );
foreach ( $data [ 'award_additional_materials' ][ 'pdf' ][ 'header' ] as $h )
header ( $h );
echo base64_decode ( $data [ 'award_additional_materials' ][ 'pdf' ][ 'data64' ]);
exit ;
2010-04-18 22:40:08 +00:00
case 'load' :
$award_awards_id = intval ( $_GET [ 'id' ]);
$fairs_id = intval ( $_GET [ 'fairs_id' ]);
$winners = get_winners ( $award_awards_id , $fairs_id );
$divs = projectdivisions_load ();
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT * FROM fairs WHERE id=' $fairs_id }' " );
$q -> execute ();
$fair = $q -> fetch ( PDO :: FETCH_ASSOC );
2010-04-18 22:40:08 +00:00
echo i18n ( " The following list of winning projects/students will be sent to: <b>%1</b>. Use the 'Edit Default Division Assignments' button to change the default mappings for divisions. You can over-ride any division assignment by changing it in the list below. Category assignments are done automatically based on grade. When you are happy with the list below, click the 'Upload Winners' button. " , array ( $fair [ 'name' ]));
2010-04-18 22:40:10 +00:00
if ( $fair [ 'type' ] != 'sfiab' ) {
echo '<br /><br />' ;
echo i18n ( 'This server does not collection Division information, all division selection is disabled.' );
$server_cats = array ();
$server_divs = array ();
$catmap = array ();
$divmap = array ();
$division_disabled = true ;
} else {
list ( $server_cats , $server_divs , $catmap , $divmap ) = load_server_cats_divs ( $fairs_id );
$division_disabled = false ;
}
2010-04-18 22:40:08 +00:00
?>
2010-04-18 22:40:10 +00:00
< br />< br />
< button onClick = " popup_divmap(<?= $fairs_id ?>);return false; " < ? = $division_disabled ? 'disabled="disabled' : '' ?>
title = " <?=i18n( " Edit Default Division Assignments " )?> " >< ? = i18n ( " Edit Default Division Assignments " ) ?> </button>
2010-04-18 22:40:08 +00:00
< form id = " winner_divs_form " >
< input type = " hidden " name = " fairs_id " value = " <?= $fairs_id ?> " />
< input type = " hidden " name = " award_awards_id " value = " <?= $award_awards_id ?> " />
< table class = " tableview " >
< ?
2010-04-18 22:40:10 +00:00
2010-04-18 22:40:08 +00:00
foreach ( $winners as & $w ) {
echo " <tr><td style= \" border: 0px; \" colspan= \" 3 \" > " ;
echo " <br /><h3> { $w [ 'award_name' ] } </h3> " ;
foreach ( $w [ 'prizes' ] as & $p ) {
echo " <tr><td style= \" border: 0px; \" colspan= \" 3 \" > " ;
echo " <h4> { $p [ 'name' ] } </h4> " ;
echo '</td></tr>' ;
2010-04-18 22:40:10 +00:00
if ( count ( $p [ 'projects' ]) == 0 ) {
echo i18n ( 'No winners to upload' );
continue ;
}
2010-04-18 22:40:08 +00:00
foreach ( $p [ 'projects' ] as & $pr ) {
?> <tr><td style="border: 0px;"> </td>
< td >< b >< ? = $pr [ 'projectnumber' ] ?> - <?=$pr['title']?></b><br/>
< ? $highest_grade = 0 ;
foreach ( $pr [ 'students' ] as & $s ) {
echo i18n ( " Name " ) . " : " ;
echo $s [ 'firstname' ] . " " . $s [ 'lastname' ];
echo " <br /> " ;
echo " " ; echo " " ; echo " " ; echo " " ;
echo i18n ( " Grade " ) . " : " . $s [ 'grade' ];
echo " <br /> " ;
echo " " ; echo " " ; echo " " ; echo " " ;
echo i18n ( " School " ) . " : " . $s [ 'school' ][ 'schoolname' ];
echo '<br />' ;
if ( $s [ 'grade' ] > $highest_grade ) $highest_grade = $s [ 'grade' ];
}
$server_cat = '' ;
foreach ( $server_cats as $c ) {
if ( $highest_grade >= $c [ 'mingrade' ] && $highest_grade <= $c [ 'maxgrade' ]) {
$server_cat = $c [ 'id' ];
}
}
?>
</ td >
< td >
< table class = " default " >
< tr > < td align = " right " style = " border: 0px; " >< ? = i18n ( 'Our division' ) ?> :</td>
< td >< b >< ? = $divs [ $pr [ 'client_projectdivisions_id' ]][ 'division' ] ?> </td>
</ tr >
< ?
2010-04-18 22:40:10 +00:00
if ( $division_disabled == false ) {
?> <tr> <td align="right"><?=i18n('%1 Division', array($fair['abbrv']))?>:</td>
< td >< select name = " div[<?= $w['id'] ?>][<?= $p['id'] ?>][<?= $pr['projectid'] ?>] " >
< ?
$mapto = $divmap [ $pr [ 'client_projectdivisions_id' ]];
foreach ( $server_divs as $d ) {
$sel = ( $mapto == $d [ 'id' ]) ? 'selected="selected"' : '' ;
echo " <option $sel value= \" { $d [ 'id' ] } \" > { $d [ 'division' ] } </option> " ;
}
?> </select>
< input type = " hidden " name = " cat[<?= $w['id'] ?>][<?= $p['id'] ?>][<?= $pr['projectid'] ?>] " value = " <?= $server_cat ?> " />
</ td >
</ tr >
< tr > < td align = " right " >< ? = i18n ( '%1 Category' , array ( $fair [ 'abbrv' ])) ?> :</td>
< td >< b >< ? = $server_cats [ $server_cat ][ 'category' ] ?> (<?=i18n('Grade')?> <?=$server_cats[$server_cat]['mingrade']?> - <?=$server_cats[$server_cat]['maxgrade']?>)</td>
</ tr >
< ? }
?> </table>
2010-04-18 22:40:08 +00:00
</ td ></ tr >
< ?
}
}
}
echo '</table></form><br />' ;
exit ;
2009-09-21 07:18:39 +00:00
}
send_header ( " Award Upload " ,
array ( 'Committee Main' => 'committee_main.php' ,
'Administration' => 'admin/index.php' ,
'Awards Main' => 'admin/awards.php' )
);
echo " <br /> " ;
?>
< script type = " text/javascript " >
2009-09-23 05:53:33 +00:00
var fairs_id = - 1 ;
var award_awards_id = - 1 ;
2009-09-21 07:18:39 +00:00
2009-09-23 05:53:33 +00:00
function catdiv_save ()
{
$ ( " #debug " ) . load ( " <?= $_SERVER['PHP_SELF'] ?>?action=catdiv_save " ,
$ ( '#catdiv_form' ) . serializeArray ());
return false ;
}
2010-04-18 22:40:08 +00:00
function popup_upload_load ()
2009-09-23 05:53:33 +00:00
{
2010-04-18 22:40:08 +00:00
var ids = " &id= " + award_awards_id + " &fairs_id= " + fairs_id ;
$ ( " #popup_upload " ) . load ( " <?= $_SERVER['PHP_SELF'] ?>?action=load " + ids );
2009-09-23 05:53:33 +00:00
}
function popup_upload ( fid , aaid )
{
2010-04-18 22:40:08 +00:00
var w = ( document . documentElement . clientWidth * 0.8 );
2009-09-23 05:53:33 +00:00
var h = ( document . documentElement . clientHeight * 0.8 );
fairs_id = fid ;
award_awards_id = aaid ;
2009-09-21 07:18:39 +00:00
2010-04-18 22:40:08 +00:00
/* Load dialog content ( it ' s in a function because we use it when
* the div editor closes too , to reload the content */
popup_upload_load ();
2009-09-23 05:53:33 +00:00
/* Show the dialog */
$ ( '#popup_upload' ) . dialog ( 'option' , 'width' , w );
$ ( '#popup_upload' ) . dialog ( 'option' , 'height' , h );
$ ( " #popup_upload " ) . dialog ( 'open' );
return true ;
}
2010-04-18 22:40:08 +00:00
function popup_divmap ( fid )
{
var w = ( document . documentElement . clientWidth * 0.4 );
var h = ( document . documentElement . clientHeight * 0.6 );
/* Load dialog content */
$ ( " #popup_divmap " ) . load ( " <?= $_SERVER['PHP_SELF'] ?>?action=catdiv_load&fairs_id= " + fairs_id );
/* Show the dialog */
$ ( '#popup_divmap' ) . dialog ( 'option' , 'width' , w );
$ ( '#popup_divmap' ) . dialog ( 'option' , 'height' , h );
$ ( " #popup_divmap " ) . dialog ( 'open' );
return true ;
}
2009-09-23 05:53:33 +00:00
/* Setup the popup window */
$ ( document ) . ready ( function () {
$ ( " #popup_upload " ) . dialog ({
bgiframe : true , autoOpen : false ,
modal : true , resizable : false ,
draggable : false ,
2010-04-18 22:40:08 +00:00
buttons : {
" <?=i18n('Cancel')?> " : function () {
$ ( this ) . dialog ( " close " );
},
" <?=i18n('Upload Winners')?> " : function () {
$ ( " #award_upload_status " ) . load ( " <?= $_SERVER['PHP_SELF'] ?>?action=award_upload " ,
$ ( '#winner_divs_form' ) . serializeArray ());
/* Don't need to wait for the .load to complete before closing */
$ ( this ) . dialog ( " close " );
}
}
2009-09-23 05:53:33 +00:00
});
2010-04-18 22:40:08 +00:00
$ ( " #popup_divmap " ) . dialog ({
bgiframe : true , autoOpen : false ,
modal : true , resizable : false ,
draggable : false ,
buttons : {
" <?=i18n('Cancel')?> " : function () {
$ ( this ) . dialog ( " close " );
},
" <?=i18n('Save Mappings')?> " : function () {
$ ( " #debug " ) . load ( " <?= $_SERVER['PHP_SELF'] ?>?action=catdiv_save " ,
$ ( '#catdiv_form' ) . serializeArray (), function () {
popup_upload_load ();
}
);
/* Don't need to wait for the .load to complete before closing */
$ ( this ) . dialog ( " close " );
}
2009-09-23 05:53:33 +00:00
}
});
});
2009-09-21 07:18:39 +00:00
</ script >
2009-09-23 05:53:33 +00:00
2010-04-18 22:40:08 +00:00
< div id = " popup_upload " title = " Upload Award " style = " display: none " ></ div >
< div id = " popup_divmap " title = " Edit Mappings " style = " display: none " ></ div >
2009-09-23 05:53:33 +00:00
2010-04-18 22:39:55 +00:00
2009-09-21 07:18:39 +00:00
< ?
if ( ! function_exists ( 'curl_init' )) {
echo error ( i18n ( " CURL Support Missing " ));
echo notice ( i18n ( " Your PHP installation does not support CURL. You will need to have CURL support added by your system administrator before being able to access external award sources " ));
send_footer ();
exit ;
}
2010-04-18 22:39:55 +00:00
/* Fairs first */
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT fairs.id, fairs.name, fairs.type, COUNT(award_awards.id) as AWARD_COUNT FROM fairs
2010-04-18 22:39:55 +00:00
LEFT JOIN award_awards ON award_awards . award_source_fairs_id = fairs . id
WHERE award_awards . award_source_fairs_id IS NOT NULL
AND award_awards . year = '{$config[' FAIRYEAR ']}'
GROUP BY fairs . id
ORDER BY fairs . name " );
2024-12-07 01:54:02 +00:00
$q -> execute ();
echo $q -> errorInfo ();
2010-04-18 22:39:55 +00:00
?>
< h4 >< ? = i18n ( 'Upload all winners to a source' ) ?> :</h4>
< table class = " tableview " >< thead >
< tr >< th >< ? = i18n ( " Source Name " ) ?> </th>
< th >< ? = i18n ( " Number of Awards " ) ?> </th>
2010-04-18 22:40:10 +00:00
< th >< ? = i18n ( " Winners<br />Assigned " ) ?> </th>
2010-04-18 22:39:55 +00:00
< th >< ? = i18n ( " Send All " ) ?> </th>
</ tr ></ thead >
< ?
2024-12-07 01:54:02 +00:00
while ( $r = $q -> fetch ( PDO :: FETCH_OBJ )) {
2010-04-18 22:40:10 +00:00
$count = count_winners ( - 1 , $r -> id );
?>
< tr >< td >< ? = $r -> name ?> </td>
< td align = " center " >< ? = $r -> AWARD_COUNT ?> </td>
< td align = " center " >< ? = $count ?> </td>
< td align = " center " >
< ?
2010-04-18 22:39:55 +00:00
if ( $r -> type == 'sfiab' )
echo " <a href= \" # \" onClick= \" popup_upload( { $r -> id } ,-1) \" > " . i18n ( " Send All " ) . " </a> " ;
else
echo " Not available yet, we're working on it! " ;
echo " </td></tr> " ;
}
?>
</ table >
< br />
< br />
< ?
2024-12-07 01:54:02 +00:00
$q = $pdo -> prepare ( " SELECT award_awards.id, award_awards.name AS awardname,
2009-09-23 05:53:33 +00:00
fairs . name as fairname , award_source_fairs_id ,
2009-09-25 19:15:43 +00:00
fairs . type as fairtype , award_awards . external_additional_materials
2009-09-23 05:53:33 +00:00
FROM award_awards
2009-09-21 07:18:39 +00:00
LEFT JOIN fairs ON fairs . id = award_awards . award_source_fairs_id
WHERE award_awards . award_source_fairs_id IS NOT NULL
AND award_awards . year = '{$config[' FAIRYEAR ']}'
ORDER BY fairs . name , award_awards . name " );
2024-12-07 01:54:02 +00:00
$q -> execute ();
echo $pdo -> errorInfo ();
2009-09-21 07:18:39 +00:00
?>
2010-04-18 22:39:55 +00:00
< h4 >< ? = i18n ( 'Upload individual winners to a source' ) ?> :</h4>
2009-09-21 07:18:39 +00:00
2010-03-31 18:44:42 +00:00
< table class = " tableview " >< thead >
2009-09-21 07:18:39 +00:00
< tr >< th >< ? = i18n ( " Award Name " ) ?> </th>
< th >< ? = i18n ( " Source Name " ) ?> </th>
2010-04-18 22:40:10 +00:00
< th >< ? = i18n ( " Winners<br />Assigned " ) ?> </th>
2009-09-21 07:18:39 +00:00
< th >< ? = i18n ( " Send " ) ?> </th>
2009-09-25 19:15:43 +00:00
< th >< ? = i18n ( " Additional<br />Info " ) ?> </th>
2010-03-31 18:44:42 +00:00
</ tr ></ thead >
2009-09-21 07:18:39 +00:00
< ?
2024-12-07 01:54:02 +00:00
while ( $r = $q -> fetch ( PDO :: FETCH_OBJ )) {
2010-04-18 22:40:10 +00:00
$count = count_winners ( $r -> id , $r -> award_source_fairs_id );
?>
< tr >< td >< ? = $r -> awardname ?> </td>
< td >< ? = $r -> fairname ?> </td>
< td align = " center " >< ? = $count ?> </td>
< td align = " center " >
< ?
if ( $count > 0 )
$onclick = " popup_upload( { $r -> award_source_fairs_id } , { $r -> id } );return false; " ;
else
$onclick = " alert(' " . i18n ( 'Assign a winner first' ) . " ');return false; " ;
?>
< a href = " # " onClick = " <?= $onclick ?> " >< ? = i18n ( " send " ) ?> </a>
</ td >< td >
< ? if ( $r -> external_additional_materials ) {
2009-09-25 19:15:43 +00:00
echo " <a href= \" { $_SERVER [ 'PHP_SELF' ] } ?action=additional_materials&award_awards_id= { $r -> id } \" target= \" _blank \" > " . i18n ( " download " ) . " </a> " ;
}
2010-04-18 22:40:10 +00:00
echo '</td></tr>' ;
2009-09-21 07:18:39 +00:00
}
?>
</ table >
< br />
< div id = " award_upload_status " ></ div >
2010-04-18 22:40:08 +00:00
2009-09-21 07:18:39 +00:00
< ?
2009-09-25 07:11:43 +00:00
/*<a href="award_upload.php?action=send<?=$sendurl?>"><?=i18n("Send all awards")?></a> */
2009-09-21 07:18:39 +00:00
send_footer ();
2007-11-29 22:30:35 +00:00
?>