Support Multiple uploads for SFIAB targets

This commit is contained in:
dave 2010-04-18 22:39:55 +00:00
parent 14df5adc39
commit a5a431605a

View File

@ -27,7 +27,7 @@ require_once('curl.inc.php');
user_auth_required('committee', 'admin'); user_auth_required('committee', 'admin');
//function get_cwsf_award_winners() //function get_cwsf_award_winners()
function get_winners($awardid, $catmap_str=NULL, $divmap_str=NULL) function get_winners($awardid, $fairs_id, $catmap_str=NULL, $divmap_str=NULL)
{ {
global $config; global $config;
@ -65,7 +65,18 @@ function get_winners($awardid, $catmap_str=NULL, $divmap_str=NULL)
'teacheremail'=>'teacheremail'); 'teacheremail'=>'teacheremail');
$awards = array();
if($awardid == -1) {
/* Get all for this fair */
$q=mysql_query("SELECT * FROM award_awards WHERE award_source_fairs_id='$fairs_id' AND year='{$config['FAIRYEAR']}'");
if(mysql_num_rows($q) == 0) {
error_("Can't find award id $awardid");
return false;
}
while($a = mysql_fetch_assoc($q)) {
$awards[] = $a;
}
} else {
/* Get the award */ /* Get the award */
$q=mysql_query("SELECT * FROM award_awards WHERE id='$awardid' AND year='{$config['FAIRYEAR']}'"); $q=mysql_query("SELECT * FROM award_awards WHERE id='$awardid' AND year='{$config['FAIRYEAR']}'");
if(mysql_num_rows($q)!=1) { if(mysql_num_rows($q)!=1) {
@ -73,17 +84,26 @@ function get_winners($awardid, $catmap_str=NULL, $divmap_str=NULL)
return false; return false;
} }
$award=mysql_fetch_assoc($q); $award=mysql_fetch_assoc($q);
$awards[] = $award;
}
/* Get the fair for the div/cat mappings */ /* Get the fair for the div/cat mappings */
$q = mysql_query("SELECT * FROM fairs WHERE id='{$award['award_source_fairs_id']}'"); $q = mysql_query("SELECT * FROM fairs WHERE id='{$award['award_source_fairs_id']}'");
$fair = mysql_fetch_assoc($q); $fair = mysql_fetch_assoc($q);
$catmap = unserialize(($catmap_str != NULL) ? $catmap_str : $fair['catmap']); $catmap = unserialize($fair['catmap']);
$divmap = unserialize(($divmap_str != NULL) ? $divmap_str : $fair['divmap']); $divmap = unserialize($fair['divmap']);
$winners=array( 'prizes' => array(),
'award_name' => $award['name'], foreach($awards as $award) {
$winners=array( 'award_name' => $award['name'],
'external_identifier' => $award['external_identifier'], 'external_identifier' => $award['external_identifier'],
'external_postback' => $award['external_postback']); 'year' => $config['FAIRYEAR'],
'prizes' => array());
if($fair['type'] != 'sfiab') {
/* YSC Compatability */
$winners['external_postback'] = $award['external_postback'];
}
/* Get the prizes */ /* Get the prizes */
$q=mysql_query("SELECT * FROM award_prizes WHERE award_awards_id='{$award['id']}'"); $q=mysql_query("SELECT * FROM award_prizes WHERE award_awards_id='{$award['id']}'");
@ -143,25 +163,46 @@ function get_winners($awardid, $catmap_str=NULL, $divmap_str=NULL)
'identifier'=>$prize['external_identifier'], /* for ysc compatability */ 'identifier'=>$prize['external_identifier'], /* for ysc compatability */
'projects'=>$prizewinners); 'projects'=>$prizewinners);
} }
return $winners; $all_winners[] = $winners;
}
return $all_winners;
} }
switch($_GET['action']) { switch($_GET['action']) {
case 'award_upload': case 'award_upload':
$award_awards_id = intval($_GET['id']); $award_awards_id = intval($_GET['id']);
$winners = get_winners($award_awards_id); $fairs_id = intval($_GET['fairs_id']);
$all_winners = get_winners($award_awards_id, $fairs_id);
/* Get the fair */ /* Get the fair */
$q = mysql_query("SELECT award_source_fairs_id FROM award_awards WHERE id='$award_awards_id'"); $q = mysql_query("SELECT * FROM fairs WHERE id='$fairs_id}'");
$a = mysql_fetch_assoc($q);
$q = mysql_query("SELECT * FROM fairs WHERE id='{$a['award_source_fairs_id']}'");
$fair = mysql_fetch_assoc($q); $fair = mysql_fetch_assoc($q);
echo '<br />'; echo '<br />';
if($winners == false) { /* Check that we're going to upload something */
echo notice(i18n('No winners selected for this award')); $upload_something = false;
} else { foreach($all_winners as $w) {
foreach($w['prizes'] as $p) {
if(count($p['projects'])) {
$upload_something = true;
break;
}
}
}
if($upload_something == false) {
echo notice(i18n('No winners to be uploaded'));
exit;
}
if($fair['type'] == 'ysc') { 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(); $w = array();
foreach($winners['prizes'] as $prize_name=>$prize) { foreach($winners['prizes'] as $prize_name=>$prize) {
$w[] = $prize; $w[] = $prize;
@ -175,12 +216,12 @@ case 'award_upload':
); );
$url = $winners['external_postback']; $url = $winners['external_postback'];
} else { } else {
$req = array('award_upload' => $winners); $req = array();
$req['award_upload']['year'] = $config['FAIRYEAR']; $req['awards_upload'] = $all_winners;
$url = ''; /* url is ignored for type = sfiab */ $url = ''; /* url is ignored for type = sfiab */
} }
echo i18n("Sending %1 winners to %2...", array('<b>'.$winners['award_name'].'</b>', echo i18n("Sending winners to %1...", array('<b>'.$fair['name'].'</b>'));
'<b>'.$fair['name'].'</b>'));
echo '<br />'; echo '<br />';
// echo "<pre>"; print_r($req); echo "</pre>"; // echo "<pre>"; print_r($req); echo "</pre>";
@ -193,15 +234,14 @@ case 'award_upload':
echo notice("{$fair['name']} server said: <pre>".join("\n", $data['notice'])."</pre>"); echo notice("{$fair['name']} server said: <pre>".join("\n", $data['notice'])."</pre>");
else if(is_array($data['message'])) else if(is_array($data['message']))
echo notice("{$fair['name']} server said: <pre>".join("\n", $data['message'])."</pre>"); echo notice("{$fair['name']} server said: <pre>".join("\n", $data['message'])."</pre>");
else if($data['message']) { else if($data['message'])
echo notice("{$fair['name']} server said: <pre>".$data['message']."</pre>"); echo notice("{$fair['name']} server said: <pre>".$data['message']."</pre>");
}
else else
echo notice("{$fair['name']} server said: <pre>".htmlspecialchars(print_r($data,true))."</pre>"); echo notice("{$fair['name']} server said: <pre>".htmlspecialchars(print_r($data,true))."</pre>");
echo happy(i18n("Upload completed successfully")); echo happy(i18n("Upload completed successfully"));
} }
}
exit; exit;
case 'catdiv_load': case 'catdiv_load':
$fairs_id = intval($_GET['id']); $fairs_id = intval($_GET['id']);
$q = mysql_query("SELECT * FROM fairs WHERE id='$fairs_id'"); $q = mysql_query("SELECT * FROM fairs WHERE id='$fairs_id'");
@ -277,7 +317,8 @@ case 'catdiv_save':
case 'confirm_load': case 'confirm_load':
$award_awards_id = intval($_GET['id']); $award_awards_id = intval($_GET['id']);
$winners = get_winners($award_awards_id); $fairs_id = intval($_GET['fairs_id']);
$winners = get_winners($award_awards_id, $fairs_id);
print_r($winners); print_r($winners);
exit; exit;
@ -340,7 +381,7 @@ function catdiv_load()
} }
function award_upload(id) function award_upload(id)
{ {
$("#award_upload_status").load("<?=$_SERVER['PHP_SELF']?>?action=award_upload&id="+id); $("#award_upload_status").load("<?=$_SERVER['PHP_SELF']?>?action=award_upload&id="+id+"&fairs_id="+fairs_id);
} }
function catdiv_save() function catdiv_save()
@ -360,7 +401,7 @@ function catdiv_next()
function confirm_load() function confirm_load()
{ {
$("#confirm_data").load("<?=$_SERVER['PHP_SELF']?>?action=confirm_load&id="+award_awards_id); $("#confirm_data").load("<?=$_SERVER['PHP_SELF']?>?action=confirm_load&id="+award_awards_id+"&fairs_id="+fairs_id);
} }
function confirm_upload() function confirm_upload()
@ -465,7 +506,6 @@ $(document).ready(function() {
echo "<option value=\"-1\">Loading...</option>"; echo "<option value=\"-1\">Loading...</option>";
echo '</select></td></tr>'; echo '</select></td></tr>';
} }
/* <input type="submit" onClick="catdiv_save();return false;" value="<?=i18n("Save")?>" /></td>*/
?> ?>
</table> </table>
<br /> <br />
@ -498,6 +538,7 @@ $(document).ready(function() {
</div></div> </div></div>
<? <?
@ -508,6 +549,44 @@ if(!function_exists('curl_init')) {
exit; exit;
} }
/* Fairs first */
$q = mysql_query("SELECT fairs.id, fairs.name, fairs.type, COUNT(award_awards.id) as AWARD_COUNT FROM fairs
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 ");
echo mysql_error();
?>
<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>
<th><?=i18n("Send All")?></th>
</tr></thead>
<?
while($r=mysql_fetch_object($q)) {
echo "<tr><td>{$r->name}</td>\n";
echo "<td>{$r->AWARD_COUNT}</td>";
echo "<td align=\"center\">";
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 />
<?
$q = mysql_query("SELECT award_awards.id, award_awards.name AS awardname, $q = mysql_query("SELECT award_awards.id, award_awards.name AS awardname,
fairs.name as fairname, award_source_fairs_id, fairs.name as fairname, award_source_fairs_id,
fairs.type as fairtype, award_awards.external_additional_materials fairs.type as fairtype, award_awards.external_additional_materials
@ -519,6 +598,7 @@ $q = mysql_query("SELECT award_awards.id, award_awards.name AS awardname,
echo mysql_error(); echo mysql_error();
?> ?>
<h4><?=i18n('Upload individual winners to a source')?>:</h4>
<table class="tableview"><thead> <table class="tableview"><thead>
<tr><th><?=i18n("Award Name")?></th> <tr><th><?=i18n("Award Name")?></th>