forked from science-ation/science-ation
d50debde12
- Implement new/delete award (still needs some eyecandy) - Update the order tables to recalc the order without fetching it from the server - Only thing left to do is make sure saving eligiblity works. :
756 lines
28 KiB
PHP
756 lines
28 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.
|
|
*/
|
|
?>
|
|
<?
|
|
require_once('../common.inc.php');
|
|
require_once('../user.inc.php');
|
|
user_auth_required('committee', 'admin');
|
|
|
|
switch($_GET['action']) {
|
|
case 'awardinfo_load':
|
|
$id = intval($_GET['id']);
|
|
$q=mysql_query("SELECT * FROM award_awards WHERE id='$id'");
|
|
$ret = mysql_fetch_assoc($q);
|
|
echo json_encode($ret);
|
|
exit;
|
|
|
|
|
|
case 'award_create':
|
|
$q=mysql_query("INSERT INTO award_awards (year,self_nominate,schedule_judges)
|
|
VALUES ('{$config['FAIRYEAR']}','yes','yes')");
|
|
$ret = array('id' => mysql_insert_id() );
|
|
echo json_encode($ret);
|
|
exit;
|
|
|
|
case 'award_delete':
|
|
$id=intval($_GET['id']);
|
|
mysql_query("DELETE FROM award_prizes WHERE award_awards_id='$id'");
|
|
mysql_query("DELETE FROM award_awards_projectcategories WHERE award_awards_id='$id'");
|
|
mysql_query("DELETE FROM award_awards_projectdivisions WHERE award_awards_id='$id'");
|
|
mysql_query("DELETE FROM award_awards WHERE id='$id'");
|
|
exit;
|
|
|
|
case 'awardinfo_save':
|
|
/* Scrub the data while we save it */
|
|
$id=intval($_GET['id']);
|
|
|
|
$q = "UPDATE award_awards SET
|
|
name='".mysql_escape_string(stripslashes($_GET['name']))."',
|
|
`order`='".intval($_GET['order'])."',
|
|
sponsors_id='".intval($_GET['sponsors_id'])."',
|
|
award_types_id='".intval($_GET['award_types_id'])."',
|
|
presenter='".mysql_escape_string(stripslashes($_GET['presenter']))."',
|
|
excludefromac='".(($_GET['excludefromac'] == 1) ? 1 : 0)."',
|
|
cwsfaward='".(($_GET['cwsfaward'] == 1) ? 1 : 0)."',
|
|
self_nominate='".(($_GET['self_nominate'] == 'yes') ? 'yes' : 'no')."',
|
|
schedule_judges='".(($_GET['schedule_judges'] == 'yes') ? 'yes' : 'no')."',
|
|
criteria='".mysql_escape_string(stripslashes($_GET['criteria']))."',
|
|
description='".mysql_escape_string(stripslashes($_GET['description']))."'
|
|
WHERE id='$id'";
|
|
echo happy(i18n('Award Info Saved'));
|
|
mysql_query($q);
|
|
exit;
|
|
|
|
case 'eligibilty_load':
|
|
$id = intval($_GET['id']);
|
|
//select the current categories that this award is linked to
|
|
$reg = array();
|
|
$q=mysql_query("SELECT * FROM award_awards_projectcategories WHERE award_awards_id='$id'");
|
|
while($r=mysql_fetch_assoc($q)) {
|
|
$ret['categories'][] = $r['projectcategories_id'];
|
|
}
|
|
|
|
//select the current categories that this award is linked to
|
|
$q=mysql_query("SELECT * FROM award_awards_projectdivisions WHERE award_awards_id='$id'");
|
|
while($r=mysql_fetch_assoc($q)) {
|
|
$ret['divisions'][] = $r['projectdivisions_id'];
|
|
}
|
|
echo json_encode($ret);
|
|
exit;
|
|
|
|
case 'eligibility_save':
|
|
$id = intval($_GET['id']);
|
|
|
|
//now add the new ones
|
|
if(!is_array($_GET['categories']) || !is_array($_GET['divisions'])) {
|
|
echo error(i18n("Invalid data"));
|
|
exit;
|
|
}
|
|
|
|
//wipe out any old award-category links
|
|
mysql_query("DELETE FROM award_awards_projectcategories WHERE award_awards_id='$id'");
|
|
|
|
foreach($_GET['categories'] AS $cat) {
|
|
mysql_query("INSERT INTO award_awards_projectcategories (award_awards_id,projectcategories_id,year)
|
|
VALUES ('$id','$cat','{$config['FAIRYEAR']}')");
|
|
}
|
|
|
|
//wipe out any old award-divisions links
|
|
mysql_query("DELETE FROM award_awards_projectdivisions WHERE award_awards_id='$id'");
|
|
|
|
//now add the new ones
|
|
foreach($_POST['eligibledivisions'] AS $div) {
|
|
mysql_query("INSERT INTO award_awards_projectdivisions (award_awards_id,projectdivisions_id,year)
|
|
VALUES ('$id','$div','{$config['FAIRYEAR']}')");
|
|
}
|
|
echo happy(i18n("Saved."));
|
|
exit;
|
|
|
|
case 'prize_order':
|
|
$order = 0;
|
|
foreach ($_GET['prizelist'] as $position=>$id) {
|
|
if($id == '') continue;
|
|
$order++;
|
|
mysql_query("UPDATE `award_prizes` SET `order`='$order' WHERE `id`='$id'");
|
|
}
|
|
// print_r($_GET);
|
|
// echo happy(i18n("Order Updated."));
|
|
exit;
|
|
|
|
case 'award_order':
|
|
$order = 0;
|
|
foreach ($_GET['awardlist'] as $position=>$id) {
|
|
if($id == '') continue;
|
|
$order++;
|
|
mysql_query("UPDATE `award_awards` SET `order`='$order' WHERE `id`='$id'");
|
|
}
|
|
// echo happy(i18n("Order Updated."));
|
|
exit;
|
|
|
|
case 'prizeinfo_load':
|
|
$id = intval($_GET['id']);
|
|
$q = mysql_query("SELECT * FROM award_prizes WHERE award_awards_id='$id' ORDER BY `order`");
|
|
while($r=mysql_fetch_assoc($q)) {
|
|
$ret[] = $r;
|
|
}
|
|
echo json_encode($ret);
|
|
exit;
|
|
case 'prize_load':
|
|
$id = intval($_GET['id']);
|
|
$q = mysql_query("SELECT * FROM award_prizes WHERE id='$id'");
|
|
$ret=mysql_fetch_assoc($q);
|
|
echo json_encode($ret);
|
|
exit;
|
|
|
|
case 'prize_save':
|
|
print_R($_GET);
|
|
$id = intval($_GET['id']);
|
|
if($id == -1) {
|
|
$aaid = intval($_GET['award_awards_id']);
|
|
mysql_query("INSERT INTO award_prizes(award_awards_id,year) VALUES ('$aaid','{$config['FAIRYEAR']}');");
|
|
$id = mysql_insert_id();
|
|
echo happy(i18n("Created new prize"));
|
|
}
|
|
$q="UPDATE award_prizes SET
|
|
prize='".mysql_escape_string(stripslashes($_GET['prize']))."',
|
|
cash='".intval($_GET['cash'])."',
|
|
scholarship='".intval($_GET['scholarship'])."',
|
|
value='".intval($_GET['value'])."',
|
|
number='".intval($_GET['number'])."',
|
|
excludefromac='".(($_GET['excludefromac']==1)? 1 : 0)."',
|
|
trophystudentkeeper='".(($_GET['trophystudentkeeper']==1) ? 1 : 0)."',
|
|
trophystudentreturn='".(($_GET['trophystudentreturn']==1) ? 1 : 0)."',
|
|
trophyschoolkeeper='".(($_GET['trophyschoolkeeper']==1) ? 1 : 0)."',
|
|
trophyschoolreturn='".(($_GET['trophyschoolreturn']==1) ? 1 : 0)."'
|
|
WHERE id='$id'";
|
|
mysql_query($q);
|
|
// echo $q;
|
|
// echo mysql_error();
|
|
echo happy(i18n("Prize saved"));
|
|
exit;
|
|
|
|
case 'prize_delete':
|
|
$id = intval($_GET['id']);
|
|
mysql_query("DELETE FROM award_prizes WHERE id='$id'");
|
|
// echo "DELETE FROM award_prizes WHERE id='$id'";
|
|
echo happy(i18n("Prize deleted"));
|
|
exit;
|
|
}
|
|
|
|
send_header("Awards Management",
|
|
array('Committee Main' => 'committee_main.php',
|
|
'Administration' => 'admin/index.php',
|
|
'Awards Main' => 'admin/awards.php') );
|
|
|
|
require_once('../htabs.inc.php');
|
|
|
|
?>
|
|
<script type="text/javascript" src="../js/jquery.tablednd_0_5.js"></script>
|
|
<script type="text/javascript">
|
|
|
|
var award_id = 0;
|
|
|
|
function update_awardinfo()
|
|
{
|
|
var id = award_id;
|
|
// alert("id="+award_id);
|
|
$.getJSON("<?=$_SERVER['PHP_SELF']?>?action=awardinfo_load&id="+id,
|
|
function(json){
|
|
$("#awardinfo_id").val(json.id);
|
|
$("#awardinfo_name").val(json.name);
|
|
$("#awardinfo_order").val(json.order);
|
|
$("#awardinfo_sponsors_id").val(json.sponsors_id);
|
|
$("#awardinfo_presenter").val(json.presenter);
|
|
$("#awardinfo_description").val(json.description);
|
|
$("#awardinfo_criteria").val(json.criteria);
|
|
$("#awardinfo_award_types_id").val(json.award_types_id);
|
|
// For some reason, with checkboxes, these have to be arrays
|
|
$("#awardinfo_excludefromac").val([json.excludefromac]);
|
|
$("#awardinfo_cwsfaward").val([json.cwsfaward]);
|
|
$("#awardinfo_selfnominate").val([json.self_nominate]);
|
|
$("#awardinfo_schedulejudges").val([json.schedule_judges]);
|
|
});
|
|
}
|
|
|
|
|
|
function save_awardinfo()
|
|
{
|
|
$("#awardinfo_info").load("<?$_SERVER['PHP_SELF']?>?action=awardinfo_save", $("#awardinfo").serialize());
|
|
return 0;
|
|
}
|
|
|
|
function update_eligibility()
|
|
{
|
|
var id = award_id;
|
|
$.getJSON("<?=$_SERVER['PHP_SELF']?>?action=eligibilty_load&id="+id,
|
|
function(json){
|
|
$("[name=eligiblecategories]").val(json.categories);
|
|
$("[name=eligibledivisions]").val(json.divisions);
|
|
});
|
|
}
|
|
|
|
function update_prizeinfo()
|
|
{
|
|
var id = award_id;
|
|
/* This is wasteful, but it saves inlining the code below */
|
|
$.getJSON("<?=$_SERVER['PHP_SELF']?>?action=prizeinfo_load&id="+id,
|
|
function(json) {
|
|
$(".prizelist_tr").remove();
|
|
for( var i in json ) {
|
|
var p = json[i];
|
|
var oc = " onclick=\"edit_prize("+p.id+");\" ";
|
|
$("#prizelist").append("<tr class=\"prizelist_tr\" id=\""+p.id+"\"><td class=\"drag_handle\" style=\"cursor:move; text-align:center;\" id=\"prizelist_order_"+p.id+"\">"+p.order+"</td>"+
|
|
"<td style=\"cursor:pointer; text-align:center;\" "+oc+" >"+p.number+"</td>"+
|
|
"<td style=\"cursor:pointer;\" "+oc+" >"+p.prize+"</td>"+
|
|
"<td style=\"cursor:pointer; width:4em; text-align:right; padding-left:2em; padding-right:2em;\" "+oc+">"+p.cash+"</td>"+
|
|
"<td style=\"cursor:pointer; width:4em; text-align:right; padding-left:2em; padding-right:2em;\" "+oc+">"+p.scholarship+"</td>"+
|
|
"<td style=\"cursor:pointer; width:4em; text-align:right; padding-left:2em; padding-right:2em;\" "+oc+">"+p.value+"</td>"+
|
|
"<td style=\"text-align:center;\">"+
|
|
" <a onclick=\"edit_prize("+p.id+");\" href=\"#\"><img border=\"0\" src=\"<?=$config['SFIABDIRECTORY']?>/images/16/edit.<?=$config['icon_extension']?>\"></a> "+
|
|
"<a onclick=\"prize_delete("+p.id+");\" href=\"#\" ><img border=0 src=\"<?=$config['SFIABDIRECTORY']?>/images/16/button_cancel.<?=$config['icon_extension']?>\"></a>"+
|
|
"</td></tr>");
|
|
}
|
|
$("#prizelist").tableDnD({
|
|
onDrop: function(table, row) {
|
|
var order = $.tableDnD.serialize();
|
|
$("#prizeinfo_info").load("<?=$_SERVER['PHP_SELF']?>?action=prize_order&"+order);
|
|
/* Change the order */
|
|
var rows = table.tBodies[0].rows;
|
|
for (var i=0; i<rows.length; i++) {
|
|
$("#prizelist_order_"+rows[i].id).html(i);
|
|
}
|
|
},
|
|
dragHandle: "drag_handle",
|
|
});
|
|
});
|
|
}
|
|
|
|
function edit_prize(id)
|
|
{
|
|
$.getJSON("<?=$_SERVER['PHP_SELF']?>?action=prize_load&id="+id,
|
|
function(json){
|
|
$("#prizeinfo_edit_header").html("<?=i18n("Edit Prize")?>");
|
|
$("#prizeinfo_id").val(json.id);
|
|
$("#prizeinfo_prize").val(json.prize);
|
|
$("#prizeinfo_cash").val(json.cash);
|
|
$("#prizeinfo_scholarship").val(json.scholarship);
|
|
$("#prizeinfo_value").val(json.value);
|
|
$("#prizeinfo_number").val(json.number);
|
|
$("#prizeinfo_trophystudentkeeper").val([json.trophystudentkeeper]);
|
|
$("#prizeinfo_trophystudentreturn").val([json.trophystudentreturn]);
|
|
$("#prizeinfo_trophyschoolreturn").val([json.trophyschoolreturn]);
|
|
$("#prizeinfo_trophyschoolkeeper").val([json.trophyschoolkeeper]);
|
|
$("#prizeinfo_excludefromac").val([json.excludefromac]);
|
|
$(".prizeinfo").removeAttr("disabled");
|
|
$("#prizeinfo_save").removeAttr("disabled");
|
|
});
|
|
}
|
|
|
|
function prize_save()
|
|
{
|
|
$("#prizeinfo_info").load("<?$_SERVER['PHP_SELF']?>?action=prize_save", $("#prizeinfo").serialize());
|
|
update_prizeinfo();
|
|
return 0;
|
|
}
|
|
|
|
function prize_delete(id)
|
|
{
|
|
var confirm = confirmClick('Are you sure you want to delete this prize?');
|
|
if(confirm == true) {
|
|
$("#prizeinfo_info").load("<?$_SERVER['PHP_SELF']?>?action=prize_delete&id="+id);
|
|
update_prizeinfo();
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
function prize_create()
|
|
{
|
|
var id = award_id;
|
|
$(".prizeinfo").val("");
|
|
$("#prizeinfo_id").val("-1");
|
|
$("#prizeinfo_award_awards_id").val(id);
|
|
$("#prizeinfo_edit_header").html("<?=i18n("New Prize")?>");
|
|
$(".prizeinfo").removeAttr("disabled");
|
|
$("#prizeinfo_save").removeAttr("disabled");
|
|
}
|
|
|
|
|
|
/* Setup the popup window */
|
|
$(document).ready(function() {
|
|
$("#popup_editor").dialog({
|
|
bgiframe: true, autoOpen: false,
|
|
modal: true, resizable: false,
|
|
draggable: false
|
|
});
|
|
});
|
|
|
|
</script>
|
|
<?
|
|
|
|
/* Begin popup */
|
|
echo "<div id=\"popup_editor\" title=\"Award Editor\" style=\"display: none\">";
|
|
|
|
htabs_begin('editortabs', array('awardinfo' => array('label' =>'Award',
|
|
'callback' => 'update_awardinfo'),
|
|
'eligibility' => array('label' =>'Eligibility',
|
|
'callback' => 'update_eligibility'),
|
|
'prizes'=> array('label' => 'Prizes',
|
|
'callback' => 'update_prizeinfo'),
|
|
),'awardinfo');
|
|
|
|
htabs_tab_begin('awardinfo');
|
|
?>
|
|
<h2><?=i18n("Award Info")?></h2>
|
|
<div id="awardinfo_info"></div>
|
|
<form id="awardinfo">
|
|
<input type="hidden" name="id" id="awardinfo_id" value="0" />
|
|
<table class="tableedit">
|
|
<tr><td class="left"><?=i18n("Name")?>:</td>
|
|
<td class="right"><input type="text" id="awardinfo_name" name="name" value="Loading..." size="50" maxlength="128">
|
|
<script type="text/javascript">translateButton('name');</script>
|
|
</td></tr>
|
|
<tr><td class="left"><?=i18n("Order")?>:</td>
|
|
<td class="right"><input type="text" id="awardinfo_order" name="order" value="" size="5" maxlength="5" />(<?=i18n("presentation order")?>)
|
|
</td></tr>
|
|
<tr><td class="left"><?=i18n("Sponsor")?>:</td><td class="right">
|
|
<?
|
|
$sq=mysql_query("SELECT id,organization FROM sponsors ORDER BY organization");
|
|
echo "<select id=\"awardinfo_sponsors_id\" name=\"sponsors_id\">";
|
|
//only show the "choose a sponsor" option if we are adding,if we are editing, then they must have already chosen one.
|
|
echo $firstsponsor;
|
|
while($sr=mysql_fetch_object($sq)) {
|
|
echo "<option value=\"$sr->id\">".i18n($sr->organization)."</option>";
|
|
}
|
|
?>
|
|
</select></td></tr>
|
|
<tr><td class="left"><?=i18n("Presenter")?>:</td>
|
|
<td class="right"><input type="text" id="awardinfo_presenter" name="presenter" value="Loading..." size="50" maxlength="128" />
|
|
</td></tr>
|
|
<tr><td class="left"><?=i18n("Type")?>:</td><td class="right">
|
|
<?
|
|
$tq=mysql_query("SELECT id,type FROM award_types WHERE year='{$config['FAIRYEAR']}' ORDER BY type");
|
|
echo "<select id=\"awardinfo_award_types_id\" name=\"award_types_id\">";
|
|
//only show the "choose a type" option if we are adding,if we are editing, then they must have already chosen one.
|
|
echo $firsttype;
|
|
while($tr=mysql_fetch_object($tq)) {
|
|
echo "<option value=\"$tr->id\">".i18n($tr->type)."</option>";
|
|
}
|
|
?>
|
|
</select></td></tr>
|
|
<tr><td class="left"><?=i18n("Criteria")?>:</td>
|
|
<td class="right"><textarea id="awardinfo_criteria" name="criteria" rows="3" cols="50">Loading...</textarea><script type="text/javascript">translateButton('criteria');</script></td></tr>
|
|
<tr><td class="left"><?=i18n("Description")?>:</td>
|
|
<td class="right"><textarea id="awardinfo_description" name="description" rows="3" cols="50">Loading...</textarea><script type="text/javascript">translateButton('description');</script></td></tr>
|
|
</table>
|
|
|
|
<h2>Options</h2>
|
|
<table class="tableedit">
|
|
<tr><td class="left">
|
|
<input type="checkbox" id="awardinfo_excludefromac" name="excludefromac" value="1"></td>
|
|
<td class="right"><?=i18n("Exclude this award from the award ceremony script")?></td></tr>
|
|
<tr><td class="left">
|
|
<input type="checkbox" id="awardinfo_cwsfaward" name="cwsfaward" value="1"></td>
|
|
<td class="right"><?=i18n("This award identifies the students that will be attending the Canada-Wide Science Fair")?></td></tr>
|
|
<tr><td class="left">
|
|
<input type="checkbox" id="awardinfo_selfnominate" name="self_nominate" value="yes"></td>
|
|
<td class="right"><?=i18n("Students can self-nominate for this award (this is usually checked for special awards)")?></td></tr>
|
|
<tr><td class="left">
|
|
<input type="checkbox" id="awardinfo_schedulejudges" name="schedule_judges" value="yes"></td>
|
|
<td class="right"><?=i18n("Allow the Automatic Judge Scheduler to assign judges to this award (usually checked)")?></td></tr>
|
|
</table></form>
|
|
<input type="submit" onClick="save_awardinfo();" value="Save" />
|
|
<?
|
|
htabs_tab_end();
|
|
|
|
htabs_tab_begin('eligibility');
|
|
?>
|
|
<h2><?=i18n("Award Info")?></h2>
|
|
<table class="tableedit">
|
|
<tr><td class="left"><?=i18n("Age Categories")?>:</td><td class="right">
|
|
<?
|
|
// if(count($currentcategories)==0) $class="class=\"error\""; else $class="";
|
|
|
|
//now select all the categories so we can list them all
|
|
$cq=mysql_query("SELECT * FROM projectcategories WHERE year='{$config['FAIRYEAR']}' ORDER BY mingrade");
|
|
echo mysql_error();
|
|
while($cr=mysql_fetch_object($cq)) {
|
|
echo "<input type=\"checkbox\" id=\"eligibility_categories_{$cr->id}\" name=\"eligiblecategories\" value=\"$cr->id\" />".i18n($cr->category)."<br />";
|
|
}
|
|
echo "</td></tr>";
|
|
|
|
echo "<tr><td class=\"left\">".i18n("Divisions").":</td><td class=\"right\">";
|
|
$dq=mysql_query("SELECT * FROM projectdivisions WHERE year='{$config['FAIRYEAR']}' ORDER BY division");
|
|
echo mysql_error();
|
|
while($dr=mysql_fetch_object($dq)) {
|
|
echo "<input type=\"checkbox\" id=\"eligibility_divisions_{$dr->id}\" name=\"eligibledivisions\" value=\"$dr->id\" />".i18n($dr->division)."<br />";
|
|
}
|
|
|
|
echo "</td>";
|
|
echo "</tr>";
|
|
// if(count($currentcategories)==0 || count($currentdivisions)==0)
|
|
// echo "<tr><td colspan=\"2\" class=\"error\">".i18n("At least one age category and one division must be selected")."</td></tr>";
|
|
echo "</table>";
|
|
htabs_tab_end();
|
|
|
|
htabs_tab_begin('prizes');
|
|
?>
|
|
<div id="prizeinfo_info"></div>
|
|
<h2><?=i18n("Prizes")?></h2>
|
|
<br />
|
|
<table id="prizelist" class="tableview">
|
|
<tr class="nodrop nodrag">
|
|
<th style="width:4em"><?=i18n("Script Order")?></th>
|
|
<th><?=i18n("# Available")?></th>
|
|
<th style="width: 15em"><?=i18n("Prize Description")?></th>
|
|
<th><?=i18n("Cash")?></th>
|
|
<th><?=i18n("Scholarship")?></th>
|
|
<th><?=i18n("Value")?></th>
|
|
<th><?=i18n("Actions")?></th>
|
|
</tr></table>
|
|
<br >
|
|
* <?=i18n("Click on the Script Order and drag to re-order the prizes")?>
|
|
<br >
|
|
<hr>
|
|
|
|
<br /><h2 id="prizeinfo_edit_header">Click on a prize to edit</h2><br />
|
|
<form id="prizeinfo">
|
|
<input type="hidden" id="prizeinfo_id" name="id" value=""/>
|
|
<input type="hidden" id="prizeinfo_award_awards_id" name="award_awards_id" value=""/>
|
|
<table class="tableedit">
|
|
<tr> <td class="left"><?=i18n("Prize Description")?>:</td>
|
|
<td class="right"><input type="text" id="prizeinfo_prize" class="prizeinfo" name="prize" value="" size="40" maxlength="128" disabled="disabled"/><script type="text/javascript">translateButton('prize');</script></td>
|
|
</tr><tr>
|
|
<td class="left"><?=i18n("Cash Amount")?> ($):</td>
|
|
<td class="right"><input type="text" id="prizeinfo_cash" class="prizeinfo" name="cash" value="" size="10" maxlength="10" disabled="disabled" /></td>
|
|
</tr><tr>
|
|
<td class="left"><?=i18n("Scholarship Amount")?> ($):</td>
|
|
<td class="right"><input type="text" id="prizeinfo_scholarship" class="prizeinfo" name="scholarship" value="" size="10" maxlength="10" disabled="disabled" /></td>
|
|
</tr><tr>
|
|
<td class="left"><?=i18n("Prize Value")?> ($):</td>
|
|
<td class="right"><input type="text" id="prizeinfo_value" class="prizeinfo" name="value" value="" size="10" maxlength="10" disabled="disabled" /></td>
|
|
</tr><tr>
|
|
<td class="left"><?=i18n("Number available")?>:</td>
|
|
<td class="right"><input type="text" id="prizeinfo_number" class="prizeinfo" name="number" value="" size="3" maxlength="5" disabled="disabled" /></td>
|
|
</tr><tr>
|
|
<td class="left" valign="top"><?=i18n("Plaque/Trophy")?>:</td>
|
|
<td class="right">
|
|
<table class="tableedit" cols="4">
|
|
<tr> <td align="right"><input type="checkbox" id="prizeinfo_trophystudentkeeper" class="prizeinfo" name="trophystudentkeeper" value="1" disabled="disabled"></td>
|
|
<td ><?=i18n("Student(s) keeper trophy")?></td>
|
|
<td align="right"><input type="checkbox" id="prizeinfo_trophystudentreturn" class="prizeinfo" name="trophystudentreturn" value="1" disabled="disabled"></td>
|
|
<td ><?=i18n("Student(s) annual return/reuse trophy")?></td>
|
|
</tr><tr>
|
|
<td align="right"><input type="checkbox" id="prizeinfo_trophyschoolkeeper" class="prizeinfo" name="trophyschoolkeeper" value="1" disabled="disabled"></td>
|
|
<td><?=i18n("School keeper trophy")?></td>
|
|
<td align="right"><input type="checkbox" id="prizeinfo_trophyschoolreturn" class="prizeinfo" name="trophyschoolreturn" value="1" disabled="disabled"></td>
|
|
<td><?=i18n("School annual return/reuse trophy")?></td>
|
|
</tr></table></td>
|
|
</tr><tr>
|
|
<td class="left"><?=i18n("Awards Ceremony")?>:</td>
|
|
|
|
<td class="right"><input type="checkbox" id="prizeinfo_excludefromac" class="prizeinfo" name="excludefromac" value="1" disabled="disabled"><?=i18n("Exclude this prize from the award ceremony script")?></td>
|
|
</tr>
|
|
</table>
|
|
</form>
|
|
<br />
|
|
<input type="submit" onClick="prize_create();" value="<?=i18n("Create New Prize")?>" />
|
|
<input type="submit" id="prizeinfo_save" onClick="prize_save();" value="<?=i18n("Save Prize")?>" disabled="disabled" />
|
|
|
|
<?
|
|
htabs_tab_end();
|
|
|
|
htabs_end();
|
|
|
|
/* End popup */
|
|
echo '</div>';
|
|
|
|
|
|
/* Here's all the code for the award list, except for the AJAX queries which are
|
|
* at the top of this file */
|
|
?>
|
|
<script type="text/javascript">
|
|
|
|
function popup_editor(id)
|
|
{
|
|
var w = (document.documentElement.clientWidth * 0.8);
|
|
var h = (document.documentElement.clientHeight * 0.8);
|
|
|
|
$('#popup_editor').dialog('option', 'width', w);
|
|
$('#popup_editor').dialog('option', 'height', h);
|
|
$("#popup_editor").dialog('open');
|
|
|
|
award_id = id;
|
|
htabs_open("editortabs");
|
|
return 0;
|
|
}
|
|
|
|
function award_create()
|
|
{
|
|
$.getJSON("<?=$_SERVER['PHP_SELF']?>?action=award_create",
|
|
function(json) {
|
|
popup_editor(json.id);
|
|
/* Ensure we open on the first tab */
|
|
// $("#htabs_awardinfo_tab").click();
|
|
});
|
|
// alert("ok");
|
|
return 0;
|
|
}
|
|
|
|
function award_delete(id)
|
|
{
|
|
var conf = confirmClick('<?=i18n("Are you sure you want to remove this award?")?>');
|
|
if(conf == true) {
|
|
$("#info_info").load("<?$_SERVER['PHP_SELF']?>?action=award_delete&id="+id);
|
|
/* The TRs need to have just a numeric ID, which could conflict with other lists, so
|
|
* tag each TR with a class too, and select both the class and the ID */
|
|
$(".awardlist_tr#"+id).fadeTo('slow', 0);
|
|
$(".awardlist_tr#"+id).remove();
|
|
}
|
|
|
|
}
|
|
|
|
$(document).ready(function() {
|
|
$("#awardlist").tableDnD({
|
|
onDrop: function(table, row) {
|
|
var order = $.tableDnD.serialize();
|
|
// $(row).fadeTo('fast',1);
|
|
$("#award_info").load("<?=$_SERVER['PHP_SELF']?>?action=award_order&"+order);
|
|
|
|
/* Change the order */
|
|
var rows = table.tBodies[0].rows;
|
|
for (var i=0; i<rows.length; i++) {
|
|
$("#awardlist_order_"+rows[i].id).html(i);
|
|
}
|
|
},
|
|
onDragStart: function(table, row) {
|
|
// $(row).fadeTo('fast',0.2);
|
|
},
|
|
dragHandle: "drag_handle"
|
|
});
|
|
|
|
// $(".awardlist_tr#166").css('background-color','red');
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
<div id="info_info"></div>
|
|
|
|
<?
|
|
|
|
|
|
/* List filtering */
|
|
if($_GET['sponsors_id'] && $_GET['sponsors_id']!="all")
|
|
$_SESSION['sponsors_id']=$_GET['sponsors_id'];
|
|
else if($_GET['sponsors_id']=="all")
|
|
unset($_SESSION['sponsors_id']);
|
|
|
|
if($_GET['award_types_id'] && $_GET['award_types_id']!="all")
|
|
$_SESSION['award_types_id']=$_GET['award_types_id'];
|
|
else if($_GET['award_types_id']=="all")
|
|
unset($_SESSION['award_types_id']);
|
|
|
|
/*
|
|
if($_GET['award_sponsors_confirmed'] && $_GET['award_sponsors_confirmed']!="all")
|
|
$_SESSION['award_sponsors_confirmed']=$_GET['award_sponsors_confirmed'];
|
|
|
|
if($_GET['sponsors_id']=="all")
|
|
unset($_SESSION['sponsors_id']);
|
|
if($_GET['award_types_id']=="all")
|
|
unset($_SESSION['award_types_id']);
|
|
if($_GET['award_sponsors_confirmed']=="all")
|
|
unset($_SESSION['award_sponsors_confirmed']);
|
|
*/
|
|
|
|
$award_types_id=$_SESSION['award_types_id'];
|
|
$sponsors_id=$_SESSION['sponsors_id'];
|
|
//$award_sponsors_confirmed=$_SESSION['award_sponsors_confirmed'];
|
|
|
|
echo "<br />";
|
|
echo i18n("Filter By:");
|
|
echo "<form method=\"get\" action=\"award_awards.php\" name=\"filterchange\">";
|
|
|
|
echo "<table><tr><td colspan=\"2\">";
|
|
|
|
$q=mysql_query("SELECT id,organization FROM sponsors ORDER BY organization");
|
|
echo "<select name=\"sponsors_id\" onchange=\"document.forms.filterchange.submit()\">";
|
|
echo "<option value=\"all\">".i18n("All Sponsors")."</option>";
|
|
while($r=mysql_fetch_object($q)) {
|
|
if($r->id == $sponsors_id) {
|
|
$sel="selected=\"selected\"";
|
|
$sponsors_organization=$r->organization;
|
|
} else
|
|
$sel="";
|
|
echo "<option $sel value=\"$r->id\">".i18n($r->organization)."</option>";
|
|
}
|
|
echo "</select>";
|
|
echo "</td></tr>";
|
|
echo "<tr><td>";
|
|
|
|
$q=mysql_query("SELECT id,type FROM award_types WHERE year='{$config['FAIRYEAR']}' ORDER BY type");
|
|
echo "<select name=\"award_types_id\" onchange=\"document.forms.filterchange.submit()\">";
|
|
echo "<option value=\"all\">".i18n("All Award Types")."</option>";
|
|
while($r=mysql_fetch_object($q)) {
|
|
if($r->id == $award_types_id) {
|
|
$sel="selected=\"selected\"";
|
|
$award_types_type=$r->type;
|
|
} else
|
|
$sel="";
|
|
echo "<option $sel value=\"$r->id\">".i18n($r->type)."</option>";
|
|
}
|
|
echo "</select>";
|
|
echo "</td><td>";
|
|
|
|
/*
|
|
//FIXME: 'confirmed' no longer exists, we need to lookup their sponsorship record and check the status there, either pending, confirmed or received, dunno if it makes sense to put that here or not..
|
|
|
|
echo "<select name=\"award_sponsors_confirmed\" onchange=\"document.forms.filterchange.submit()\">";
|
|
if($award_sponsors_confirmed=="all") $sel="selected=\"selected\""; else $sel="";
|
|
echo "<option value=\"all\">".i18n("Any Status")."</option>";
|
|
if($award_sponsors_confirmed=="yes") $sel="selected=\"selected\""; else $sel="";
|
|
echo "<option $sel value=\"yes\">".i18n("Confirmed Only")."</option>";
|
|
if($award_sponsors_confirmed=="no") $sel="selected=\"selected\""; else $sel="";
|
|
echo "<option $sel value=\"no\">".i18n("Unconfirmed Only")."</option>";
|
|
echo "</select>";
|
|
*/
|
|
echo "</form>";
|
|
echo "</td></tr>";
|
|
echo "</table>";
|
|
|
|
?>
|
|
<br />
|
|
<a href="#" onClick="award_create();"><?=i18n("Create New Award")?></a>
|
|
<br /><br />
|
|
|
|
<?
|
|
/* For some reason, this submit button opens the dialog then it closes right away, but it doesn't
|
|
* if the entry is done through the a href */
|
|
//<input type="submit" onClick="award_create();" value="<?=i18n("Create New Award")>" />
|
|
|
|
if($sponsors_id) $where_asi="AND sponsors_id='$sponsors_id'";
|
|
if($award_types_id) $where_ati="AND award_types_id='$award_types_id'";
|
|
// if($award_sponsors_confirmed) $where_asc="AND award_sponsors.confirmed='$award_sponsors_confirmed'";
|
|
|
|
if(!$orderby) $orderby="order";
|
|
|
|
$q=mysql_query("SELECT
|
|
award_awards.id,
|
|
award_awards.name,
|
|
award_awards.order,
|
|
award_awards.award_source_fairs_id,
|
|
award_types.type,
|
|
sponsors.organization
|
|
FROM
|
|
award_awards,
|
|
award_types,
|
|
sponsors
|
|
WHERE
|
|
award_awards.year='{$config['FAIRYEAR']}'
|
|
$where_asi
|
|
$where_ati
|
|
$where_asc
|
|
AND award_awards.sponsors_id=sponsors.id
|
|
AND award_awards.award_types_id=award_types.id
|
|
AND award_types.year='{$config['FAIRYEAR']}'
|
|
ORDER BY `$orderby`");
|
|
|
|
echo mysql_error();
|
|
|
|
if(mysql_num_rows($q))
|
|
{
|
|
echo "<table id=\"awardlist\" class=\"tableview\" >";
|
|
echo "<tr class=\"nodrop nodrag\">";
|
|
echo " <th>".i18n("Order")."</th>";
|
|
echo " <th>".i18n("Sponsor")."</th>";
|
|
echo " <th>".i18n("Type")."</th>";
|
|
echo " <th>".i18n("Name")."</th>";
|
|
echo " <th>".i18n("Prizes")."</th>";
|
|
echo " <th>".i18n("Actions")."</th>";
|
|
echo "</tr>\n";
|
|
|
|
|
|
$hasexternal=false;
|
|
while($r=mysql_fetch_object($q)) {
|
|
$cl = ($r->award_source_fairs_id) ? externalaward : '';
|
|
$eh = "style=\"cursor:pointer;\" onclick=\"popup_editor({$r->id});\"";
|
|
echo "<tr class=\"$cl awardlist_tr\" id=\"{$r->id}\" >\n";
|
|
echo " <td id=\"awardlist_order_{$r->id}\" class=\"drag_handle\" style=\"cursor:move; text-align:right;\">{$r->order}</td>\n";
|
|
echo " <td $eh>{$r->organization}</td>\n";
|
|
echo " <td $eh>{$r->type}</td>\n";
|
|
echo " <td $eh>{$r->name}</td>\n";
|
|
|
|
$numq=mysql_query("SELECT COUNT(id) AS num FROM award_prizes WHERE award_awards_id='{$r->id}'");
|
|
$numr=mysql_fetch_assoc($numq);
|
|
echo " <td $eh align=\"center\">{$numr['num']}</td>";
|
|
|
|
echo " <td align=\"center\">";
|
|
echo "<img border=\"0\" src=\"{$config['SFIABDIRECTORY']}/images/16/edit.{$config['icon_extension']}\">";
|
|
echo " ";
|
|
echo "<a onclick=\"award_delete({$r->id});\" href=\"#\" ><img border=0 src=\"{$config['SFIABDIRECTORY']}/images/16/button_cancel.{$config['icon_extension']}\"></a>";
|
|
|
|
echo " </td>\n";
|
|
echo "</tr>\n";
|
|
}
|
|
if($hasexternal)
|
|
echo "<tr class=\"externalaward\"><td colspan=\"6\">".i18n("Indicates award imported from an external source")."</td></tr>";
|
|
echo "</table>\n";
|
|
echo "</form>";
|
|
}
|
|
echo "<br />";
|
|
echo "<a href=\"award_prizes.php?award_awards_id=-1\">Edit prizes for the generic prize template</a>";
|
|
|
|
|
|
send_footer();
|
|
|
|
?>
|