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. */ ?> 'committee_main.php', 'Administration' => 'admin/index.php', 'Judges' => 'admin/judges.php') ); ?> 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; //if the team is empty, we'll add the first person as the captain $team=getJudgingTeam($team_id); if(count($team['members'])) $captain='no'; else $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 users_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 (users_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($_GET['action']=="del" && $_GET['team_num'] && $_GET['team_id'] && $_GET['users_id']) { mysql_query("DELETE FROM judges_teams_link WHERE users_id='".$_GET['users_id']."' AND judges_teams_id='".$_GET['team_id']."' AND year='".$config['FAIRYEAR']."'"); echo happy(i18n("Removed judge from team #%1 (%2)",array($_GET['team_num'],$_GET['team_name']))); //if there is still members left in the team, make sure we have a captain still $q=mysql_query("SELECT * FROM judges_teams_link WHERE judges_teams_id='".$_GET['team_id']."' AND year='".$config['FAIRYEAR']."'"); if(mysql_num_rows($q)) { //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->users_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='".$_GET['team_id']."' AND users_id='$firstjudge' AND year='".$config['FAIRYEAR']."'"); echo notice(i18n("Team captain was removed. A new team captain has been automatically assigned")); } } } if($_GET['action']=="empty" && $_GET['team_num'] && $_GET['team_id']) { mysql_query("DELETE FROM judges_teams_link WHERE judges_teams_id='".$_GET['team_id']."' AND year='".$config['FAIRYEAR']."'"); echo happy(i18n("Emptied all judges from team #%1 (%2)",array($_GET['team_num'],$_GET['team_name']))); } 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 users_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 users_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.users_id AND judges.id NOT IN (SELECT users_id AS id FROM judges_teams_link WHERE judges_teams_link.year='".$config['FAIRYEAR']."') ORDER BY lastname, firstname"; */ /* Load all the judges (judge_complete=yes, deleted=no, year=fairyear) */ $judgelist = judges_load_all(); /* Load all the team links */ /* $querystr="SELECT judges.id, judges.firstname, judges.lastname FROM judges, judges_years WHERE judges_years.year='".$config['FAIRYEAR']."' AND judges.id=judges_years.users_id AND judges.complete='yes' ORDER BY lastname, firstname"; $q=mysql_query($querystr); $judgelist=array(); while($r=mysql_fetch_object($q)) { $judgelist[$r->id]=$r; } */ if($_SESSION['viewstate']['judges_teams_list_show']=='unassigned') { $querystr="SELECT judges.id, judges.firstname, judges.lastname FROM judges, judges_teams_link, judges_years WHERE judges_years.year='".$config['FAIRYEAR']."' AND judges_teams_link.year='".$config['FAIRYEAR']."' AND judges.id=judges_years.users_id AND judges.id=judges_teams_link.users_id AND judges.complete='yes' ORDER BY lastname, firstname"; $q=mysql_query($querystr); while($r=mysql_fetch_object($q)) { //remove anyone we find here from the list of all judges unset($judgelist[$r->id]); } } echo "
"; echo i18n("Listing %1 judges",array(count($judgelist))); echo "
"; echo "
"; echo mysql_error(); echo ""; echo "
"; $teams=getJudgingTeams(); foreach($teams AS $team) { echo "
"; echo ""; echo "
"; echo ""; echo ""; echo "\n"; echo "\n"; if(count($team['members'])) { foreach($team['members'] AS $member) { echo ""; } echo ""; } else { echo ""; } echo "
#".$team['num'].": "; echo $team['name']; echo "
"; echo ""; echo ""; if($member['captain']=="yes") { echo ""; echo ""; echo " "; } else { echo ""; echo ""; echo " "; } echo ""; echo $member['firstname']." ".$member['lastname']; echo " (".$member['languages'].")"; echo "
"; echo ""; echo " ".i18n("Empty All Members")." "; echo ""; echo ""; echo "
"; echo error(i18n("Team has no members"),"inline"); echo "
"; echo "
"; } echo "
"; echo "
"; echo "
"; send_footer(); ?>