Copyright (C) 2005 James Grant 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. */ ?> << ".i18n("Back to Administration")."\n"; echo "<< ".i18n("Back to Judges")."\n"; if($_POST['action']=="add" && $_POST['team_num'] && count($_POST['judgelist'])>0) { //first check if this team exists. $q=mysql_query("SELECT id,name FROM judges_teams WHERE num='".$_POST['team_num']."' AND year='".$config['FAIRYEAR']."'"); if(mysql_num_rows($q)) { $r=mysql_fetch_object($q); $team_id=$r->id; $team_name=$r->name; $captain='no'; } else { echo notice(i18n("Creating new team #%1 with name '%2'",array($_POST['team_num'],$_POST['new_team_name']))); mysql_query("INSERT INTO judges_teams (num,name,year) VALUES ('".$_POST['team_num']."','".$_POST['new_team_name']."','".$config['FAIRYEAR']."')"); $team_id=mysql_insert_id(); $team_name=$_POST['new_team_name']; $captain='yes'; } $added=0; foreach($_POST['judgelist'] AS $selectedjudge) { //before we insert them, we need to make sure they dont already belong to this team. We can not have the same judge assigned to the same team multiple times. $q=mysql_query("SELECT * FROM judges_teams_link WHERE judges_id='$selectedjudge' AND judges_teams_id='$team_id'"); if(mysql_num_rows($q)) { echo notice(i18n("Judge (%1) already belongs to judging team: %2",array($selectedjudge,$team_name))); } else { //lets make the first one we add a captain, the rest, non-captains :) mysql_query("INSERT INTO judges_teams_link (judges_id,judges_teams_id,captain,year) VALUES ('$selectedjudge','$team_id','$captain','".$config['FAIRYEAR']."')"); $added++; } //if this is alreayd no, then who cares, but if its the first one that is going into the new team, then //captain will be yes, and we only want the first one assigned to a new team to be the captain //sno now we can set this back to no $captain='no'; } if($added==1) $j=i18n("judge"); else $j=i18n("judges"); echo happy(i18n("%1 %2 added to team #%3 (%4)",array($added,$j,$_POST['team_num'],$team_name))); } if($_POST['action']=="del" && $_POST['team_num'] && $_POST['team_id'] && $_POST['judges_id']) { mysql_query("DELETE FROM judges_teams_link WHERE judges_id='".$_POST['judges_id']."' AND judges_teams_id='".$_POST['team_id']."' AND year='".$config['FAIRYEAR']."'"); echo happy(i18n("Removed judge from team #%1 (%2)",array($_POST['team_num'],$_POST['team_name']))); $q=mysql_query("SELECT * FROM judges_teams_link WHERE judges_teams_id='".$_POST['team_id']."' AND year='".$config['FAIRYEAR']."'"); if(mysql_num_rows($q)==0) { mysql_query("DELETE FROM judges_teams WHERE year='".$config['FAIRYEAR']."' AND id='".$_POST['team_id']."'"); echo notice(i18n("Removed empty team #%1 (%2)",array($_POST['team_num'],$_POST['team_name']))); } else { //make sure the team still has a captain! //FIXME: this might best come from the "i am willing to be a team captain" question under the judges profile $gotcaptain=false; $first=true; while($r=mysql_fetch_object($q)) { if($first) { $firstjudge=$r->judges_id; $first=false; } if($r->captain=="yes") { $gotcaptain=true; break; } } if(!$gotcaptain) { //make the first judge the captain mysql_query("UPDATE judges_teams_link SET captain='yes' WHERE judges_teams_id='".$_POST['team_id']."' AND judges_id='$firstjudge' AND year='".$config['FAIRYEAR']."'"); echo notice(i18n("Team captain was removed. A new team captain has been automatically assigned")); } } } if($_POST['action']=="saveteamnames") { if(count($_POST['team_names'])) { foreach($_POST['team_names'] AS $team_id=>$team_name) { mysql_query("UPDATE judges_teams SET name='".mysql_escape_string(stripslashes($team_name))."' WHERE id='$team_id'"); } echo happy(i18n("Team names successfully saved")); } } if($_GET['action']=="addcaptain") { //teams can have as many captains as they want, so just add it. mysql_query("UPDATE judges_teams_link SET captain='yes' WHERE judges_teams_id='".$_GET['team_id']."' AND judges_id='".$_GET['judge_id']."'"); echo happy(i18n("Team captain assigned")); } if($_GET['action']=="removecaptain") { //teams must always have at least one captain, so if we only have one, and we are trying to remove it, dont let them! $q=mysql_query("SELECT * FROM judges_teams_link WHERE captain='yes' AND judges_teams_id='".$_GET['team_id']."'"); if(mysql_num_rows($q)<2) { echo error(i18n("A judge team must always have at least one captain")); } else { mysql_query("UPDATE judges_teams_link SET captain='no' WHERE judges_teams_id='".$_GET['team_id']."' AND judges_id='".$_GET['judge_id']."'"); echo happy(i18n("Team captain removed")); } } if(!$_SESSION['viewstate']['judges_teams_list_show']) $_SESSION['viewstate']['judges_teams_list_show']='unassigned'; //now update the judges_teams_list_show viewstate if($_GET['judges_teams_list_show']) $_SESSION['viewstate']['judges_teams_list_show']=$_GET['judges_teams_list_show']; echo "
"; echo ""; echo ""; echo ""; echo ""; echo ""; echo ""; echo ""; echo ""; echo ""; echo ""; echo ""; echo ""; echo "
".i18n("Judges List"); echo "
"; echo ""; echo "
".i18n("Judge Teams")."
"; echo ""; if($_SESSION['viewstate']['judges_teams_list_show']=='all') { echo ""; echo ""; } else { echo ""; echo ""; } echo "
".i18n("show unassigned")."".i18n("show all")."".i18n("show unassigned")."".i18n("show all")."
"; /* //mysql 4.0 does not support subqueries - it is supported as of mysql 4.1 //this means we cant use NOT IN (SELECT..) so, we will have to workaround this //at least for now. $querystr="SELECT judges.id, judges.firstname, judges.lastname FROM judges, judges_years WHERE judges_years.year='".$config['FAIRYEAR']."' AND judges.id=judges_years.judges_id AND judges.id NOT IN (SELECT judges_id AS id FROM judges_teams_link WHERE judges_teams_link.year='".$config['FAIRYEAR']."') ORDER BY lastname, firstname"; */ if($_SESSION['viewstate']['judges_teams_list_show']=='all') { $querystr="SELECT judges.id, judges.firstname, judges.lastname FROM judges, judges_years WHERE judges_years.year='".$config['FAIRYEAR']."' AND judges.id=judges_years.judges_id AND judges.complete='yes' ORDER BY lastname, firstname"; } else { $querystr="SELECT judges.id, judges.firstname, judges.lastname, judges_teams_link.judges_id FROM judges LEFT JOIN judges_teams_link ON judges.id = judges_teams_link.judges_id, judges_years WHERE judges_years.year='".$config['FAIRYEAR']."' AND judges.id=judges_years.judges_id AND judges_teams_link.judges_id IS NULL AND judges.complete='yes' ORDER BY lastname, firstname"; } $q=mysql_query($querystr); echo mysql_error(); echo ""; echo "
"; $q=mysql_query("SELECT judges_teams.id, judges_teams.num, judges_teams.name, judges.id AS judges_id, judges.firstname, judges.lastname, judges_teams_link.captain FROM judges, judges_teams, judges_teams_link WHERE judges_teams.year='".$config['FAIRYEAR']."' AND judges_teams_link.judges_id=judges.id AND judges_teams_link.judges_teams_id=judges_teams.id ORDER BY name, num, captain DESC, lastname, firstname"); $lastteamid=-1; $lastteamnum=-1; echo mysql_error(); $teams=array(); while($r=mysql_fetch_object($q)) { if($r->id!=$lastteamid) { $teams[$r->id]['id']=$r->id; $teams[$r->id]['num']=$r->num; $teams[$r->id]['name']=$r->name; $lastteamid=$r->id; $lastteamnum=$r->num; } $teams[$lastteamid]['members'][]=array( "id"=>$r->judges_id, "firstname"=>$r->firstname, "lastname"=>$r->lastname, "captain"=>$r->captain ); } //echo nl2br(print_r($teams,true)); if($lastteamnum==-1) $newteamid=1; else $newteamid=$lastteamnum+1; echo ""; echo "
"; echo ""; echo ""; echo ""; echo ""; echo "
New #$newteamid:
"; echo "
"; foreach($teams AS $team) { echo "
"; echo ""; echo "
"; echo ""; echo ""; echo "\n"; echo "\n"; foreach($team['members'] AS $member) { echo ""; } echo "
#".$team['num'].": "; echo ""; echo "
"; echo ""; echo ""; if($member['captain']=="yes") { echo ""; echo ""; echo " "; } else { echo ""; echo ""; echo " "; } echo ""; echo $member['firstname']." ".$member['lastname']; echo ""; echo "
"; echo "
"; } echo "
"; echo ""; echo "
"; echo "
"; send_footer(); ?>