forked from science-ation/science-ation
279 lines
6.5 KiB
PHP
279 lines
6.5 KiB
PHP
<?
|
|
function getJudgingTeams()
|
|
{
|
|
global $config;
|
|
global $pdo;
|
|
$q=$pdo->prepare("SELECT judges_teams.id,
|
|
judges_teams.num,
|
|
judges_teams.name
|
|
FROM
|
|
judges_teams
|
|
WHERE
|
|
judges_teams.year='".$config['FAIRYEAR']."'
|
|
ORDER BY
|
|
num,name
|
|
");
|
|
$q->execute();
|
|
|
|
$lastteamid=-1;
|
|
$lastteamnum=-1;
|
|
show_pdo_errors_if_any($pdo);
|
|
$teams=array();
|
|
while($r=$q->fetch(PDO::FETCH_OBJ))
|
|
{
|
|
$teams[$r->id]['id']=$r->id;
|
|
$teams[$r->id]['num']=$r->num;
|
|
$teams[$r->id]['name']=$r->name;
|
|
$lastteamid=$r->id;
|
|
$lastteamnum=$r->num;
|
|
|
|
/* Load timeslots */
|
|
$rounds = array();
|
|
$tq = $pdo->prepare("SELECT * FROM judges_teams_timeslots_link
|
|
LEFT JOIN judges_timeslots ON judges_timeslots.id=judges_teams_timeslots_link.judges_timeslots_id
|
|
WHERE judges_teams_timeslots_link.judges_teams_id='{$r->id}'");
|
|
$tq->execute();
|
|
$teams[$r->id]['timeslots'] = array();
|
|
$teams[$r->id]['rounds'] = array();
|
|
while($ts = $tq->fetch(PDO::FETCH_ASSOC)) {
|
|
$teams[$r->id]['timeslots'][] = $ts;
|
|
$rounds[$ts['round_id']] = $ts['round_id'];
|
|
}
|
|
foreach($rounds as $round_id) {
|
|
$tq = $pdo->prepare("SELECT * FROM judges_timeslots WHERE id='{$round_id}'");
|
|
$tq->execute();
|
|
$teams[$r->id]['rounds'][] = $tq->fetch(PDO::FETCH_ASSOC);
|
|
}
|
|
|
|
//get the members for this team
|
|
$mq=$pdo->prepare("SELECT
|
|
users.id AS judges_id,
|
|
users.firstname,
|
|
users.lastname,
|
|
judges_teams_link.captain
|
|
|
|
FROM
|
|
users,
|
|
judges_teams_link
|
|
WHERE
|
|
judges_teams_link.users_id=users.id AND
|
|
judges_teams_link.judges_teams_id='$r->id'
|
|
ORDER BY
|
|
captain DESC,
|
|
lastname,
|
|
firstname");
|
|
$mq->execute();
|
|
show_pdo_errors_if_any($pdo);
|
|
|
|
|
|
$teamlangs=array();
|
|
while($mr=$mq->fetch(PDO::FETCH_OBJ))
|
|
{
|
|
$u = user_load($mr->judges_id, false);
|
|
$judgelangs = join('/', $u['languages']);
|
|
foreach($u['languages'] AS $l) {
|
|
if(!in_array($l,$teamlangs))
|
|
$teamlangs[]=$l;
|
|
}
|
|
|
|
$teams[$lastteamid]['members'][]=array(
|
|
"id"=>$mr->judges_id,
|
|
"firstname"=>$mr->firstname,
|
|
"lastname"=>$mr->lastname,
|
|
"captain"=>$mr->captain,
|
|
"languages"=>$judgelangs,
|
|
"languages_array"=>$u['languages']
|
|
);
|
|
}
|
|
$teams[$r->id]['languages_members']=$teamlangs;
|
|
|
|
//we also need to add all the languages that the team must JUDGE to the teams languages.
|
|
$lq=$pdo->prepare("SELECT projects.language
|
|
FROM judges_teams_timeslots_projects_link
|
|
LEFT JOIN projects ON judges_teams_timeslots_projects_link.projects_id=projects.id
|
|
WHERE judges_teams_timeslots_projects_link.year='{$config['FAIRYEAR']}' AND
|
|
judges_teams_id='$r->id' AND language!='' ");
|
|
$lq->execute();
|
|
show_pdo_errors_if_any($pdo);
|
|
$projectlangs=array();
|
|
while($lr=$lq->fetch(PDO::FETCH_OBJ)) {
|
|
if(!in_array($lr->language,$projectlangs))
|
|
$projectlangs[]=$lr->language;
|
|
if(!in_array($lr->language,$teamlangs))
|
|
$teamlangs[]=$lr->language;
|
|
}
|
|
$teams[$r->id]['languages_projects']=$projectlangs;
|
|
$teams[$r->id]['languages']=$teamlangs;
|
|
|
|
//get the awards for this team
|
|
$aq=$pdo->prepare("SELECT award_awards.id,
|
|
award_awards.name,
|
|
award_awards.criteria,
|
|
award_awards.award_types_id,
|
|
award_types.type AS award_type
|
|
FROM
|
|
award_awards,
|
|
judges_teams_awards_link,
|
|
award_types
|
|
WHERE
|
|
judges_teams_awards_link.award_awards_id=award_awards.id
|
|
AND judges_teams_awards_link.judges_teams_id='$r->id'
|
|
AND award_awards.award_types_id=award_types.id
|
|
AND award_types.year='{$config['FAIRYEAR']}'
|
|
ORDER BY
|
|
name
|
|
");
|
|
$aq->execute();
|
|
while($ar=$aq->fetch(PDO::FETCH_OBJ))
|
|
{
|
|
$teams[$r->id]['awards'][]=array(
|
|
"id"=>$ar->id,
|
|
"name"=>$ar->name,
|
|
"criteria"=>$ar->criteria,
|
|
"award_types_id"=>$ar->award_types_id,
|
|
"award_type"=>$ar->award_type
|
|
);
|
|
}
|
|
}
|
|
return $teams;
|
|
}
|
|
|
|
function getJudgingTeam($teamid)
|
|
{
|
|
global $config;
|
|
global $pdo;
|
|
$q=$pdo->prepare("SELECT judges_teams.id,
|
|
judges_teams.num,
|
|
judges_teams.name
|
|
|
|
FROM
|
|
judges_teams
|
|
WHERE
|
|
judges_teams.year='".$config['FAIRYEAR']."' AND
|
|
judges_teams.id='$teamid'
|
|
ORDER BY
|
|
num,
|
|
name
|
|
");
|
|
$q->execute();
|
|
|
|
$team=array();
|
|
|
|
$first=true;
|
|
while($r=$q->fetch(PDO::FETCH_OBJS))
|
|
{
|
|
$team['id']=$r->id;
|
|
$team['num']=$r->num;
|
|
$team['name']=$r->name;
|
|
|
|
//get the members for this team
|
|
$mq=$pdo->prepare("SELECT
|
|
users.id AS judges_id,
|
|
users.firstname,
|
|
users.lastname,
|
|
judges_teams_link.captain
|
|
|
|
FROM
|
|
users,
|
|
judges_teams_link
|
|
WHERE
|
|
judges_teams_link.users_id=users.id AND
|
|
judges_teams_link.judges_teams_id='$r->id'
|
|
ORDER BY
|
|
captain DESC,
|
|
lastname,
|
|
firstname");
|
|
$mq->execute();
|
|
show_pdo_errors_if_any();
|
|
|
|
|
|
while($mr=$mq->fetch(PDO::FETCH_OBJ))
|
|
{
|
|
$team['members'][]=array(
|
|
"id"=>$mr->judges_id,
|
|
"firstname"=>$mr->firstname,
|
|
"lastname"=>$mr->lastname,
|
|
"captain"=>$mr->captain
|
|
);
|
|
}
|
|
|
|
|
|
//get the awards for this team
|
|
$aq=$pdo->prepare("SELECT award_awards.id,
|
|
award_awards.name,
|
|
award_awards.award_types_id,
|
|
award_types.type AS award_type
|
|
FROM
|
|
award_awards,
|
|
judges_teams_awards_link,
|
|
award_types
|
|
WHERE
|
|
judges_teams_awards_link.award_awards_id=award_awards.id
|
|
AND judges_teams_awards_link.judges_teams_id='$r->id'
|
|
AND award_awards.award_types_id=award_types.id
|
|
AND award_types.year='{$config['FAIRYEAR']}'
|
|
ORDER BY
|
|
name
|
|
");
|
|
$aq->execute();
|
|
while($ar=$aq->fetch(PDO::OBJ))
|
|
{
|
|
$team['awards'][]=array(
|
|
"id"=>$ar->id,
|
|
"name"=>$ar->name,
|
|
"award_types_id"=>$ar->award_types_id,
|
|
"award_type"=>$ar->award_type
|
|
);
|
|
}
|
|
|
|
|
|
}
|
|
|
|
return $team;
|
|
|
|
}
|
|
|
|
function getJudgingEligibilityCode() {
|
|
global $config;
|
|
switch($config['project_status']) {
|
|
case 'open' :
|
|
return " AND registrations.status != 'open' ";
|
|
break;
|
|
case 'payment_pending' :
|
|
return " AND registrations.status IN ('paymentpending', 'complete')";
|
|
break;
|
|
case 'complete' :
|
|
return " AND registrations.status = 'complete'";
|
|
break;
|
|
}
|
|
}
|
|
|
|
function teamMemberToName($member)
|
|
{
|
|
return $member["firstname"] . " " . $member["lastname"];
|
|
}
|
|
|
|
function judges_load_all()
|
|
{
|
|
global $config;
|
|
|
|
$ret = array();
|
|
|
|
$query = "SELECT id FROM users WHERE types LIKE '%judge%'
|
|
AND year='{$config['FAIRYEAR']}'
|
|
AND deleted='no'
|
|
ORDER BY lastname, firstname";
|
|
$r = $pdo->prepare($query);
|
|
$r->execute();
|
|
while($i = $r->fetch(PDO::FETCH_ASSOC)) {
|
|
$u = user_load($i['id']);
|
|
if($u['judge_complete'] == 'no') continue;
|
|
if($u['judge_active'] == 'no') continue;
|
|
|
|
$ret[$i['id']] = $u;
|
|
}
|
|
return $ret;
|
|
}
|
|
|
|
?>
|