* Copyright (C) 2005 James Grant * Copyright (C) 2024 AlgoLibre Inc. * * 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. */ ?> newPage(); $rep->setFontSize(11); } else if ($type == 'csv') { $rep = new lcsv(i18n('Judging Team Project Assignments')); } $teams = getJudgingTeams(); $q = $pdo->prepare("SELECT DISTINCT(date) AS d FROM judges_timeslots WHERE year='" . $config['FAIRYEAR'] . "'"); $q->execute(); if ($q->rowCount() > 1) $show_date = true; else $show_date = false; foreach ($teams as $team) { $table = array(); $table['header'] = array(i18n('Timeslot'), i18n('Proj #'), i18n('Project Title')); if ($show_date) $table['widths'] = array(2.5, 0.75, 3.75); else $table['widths'] = array(1.5, 0.75, 4.75); $table['dataalign'] = array('center', 'center', 'left'); $rep->heading($team['name'] . ' (' . $team['num'] . ')'); $memberlist = ''; if (count(get_value_from_array($team, 'members', []))) { foreach ($team['members'] as $member) { $memberlist .= $member['firstname'] . ' ' . $member['lastname']; if ($member['captain'] == 'yes') $memberlist .= '*'; $memberlist .= ', '; } $memberlist = substr($memberlist, 0, -2); } $rep->addText($memberlist); if (count($team['awards'])) { $rep->heading(i18n('Awards that this team judges') . ':'); foreach ($team['awards'] as $award) { $rep->addText($award['name']); $rep->addText(i18n('Criteria') . ': ' . $award['criteria']); // get category eligibility $q = $pdo->prepare("SELECT projectcategories.category FROM projectcategories, award_awards_projectcategories WHERE award_awards_projectcategories.projectcategories_id=projectcategories.id AND award_awards_projectcategories.award_awards_id='{$award['id']}' AND award_awards_projectcategories.year='{$config['FAIRYEAR']}' AND projectcategories.year='{$config['FAIRYEAR']}' ORDER BY category"); $q->execute(); show_pdo_errors_if_any($pdo); $cats = ''; while ($r = $q->fetch(PDO::FETCH_OBJ)) { if ($cats) $cats .= ', ' . i18n($r->category); else $cats = i18n($r->category); } $rep->addText(i18n('Categories') . ": $cats"); // get division eligibility $q = $pdo->prepare("SELECT projectdivisions.division_shortform FROM projectdivisions, award_awards_projectdivisions WHERE award_awards_projectdivisions.projectdivisions_id=projectdivisions.id AND award_awards_projectdivisions.award_awards_id='{$award['id']}' AND award_awards_projectdivisions.year='{$config['FAIRYEAR']}' AND projectdivisions.year='{$config['FAIRYEAR']}' ORDER BY division_shortform"); $q->execute(); show_pdo_errors_if_any($pdo); $divs = ''; while ($r = $q->fetch(PDO::FETCH_OBJ)) { if ($divs) $divs .= ', ' . i18n($r->division_shortform); else $divs = i18n($r->division_shortform); } $rep->addText(i18n('Divisions') . ": $divs"); } } $rep->nextLine(); // get the timeslots that this team has. $q = $pdo->prepare("SELECT judges_timeslots.id, judges_timeslots.date, judges_timeslots.starttime, judges_timeslots.endtime FROM judges_timeslots, judges_teams, judges_teams_timeslots_link WHERE judges_teams.id='" . $team['id'] . "' AND judges_teams.id=judges_teams_timeslots_link.judges_teams_id AND judges_timeslots.id=judges_teams_timeslots_link.judges_timeslots_id ORDER BY date,starttime "); $q->execute(); $numslots = $q->rowCount(); while ($r = $q->fetch(PDO::FETCH_OBJ)) { if ($show_date) $timeslot = format_date($r->date) . ' '; else $timeslot = ''; $timeslot .= format_time($r->starttime) . ' - ' . format_time($r->endtime); $projq = $pdo->prepare("SELECT projects.projectnumber, projects.id, projects.title FROM projects, judges_teams_timeslots_projects_link WHERE judges_teams_timeslots_projects_link.judges_timeslots_id='$r->id' AND judges_teams_timeslots_projects_link.judges_teams_id='" . $team['id'] . "' AND judges_teams_timeslots_projects_link.projects_id=projects.id AND judges_teams_timeslots_projects_link.year='" . $config['FAIRYEAR'] . "' ORDER BY projectnumber "); $projq->execute(); while ($proj = $projq->fetch(PDO::FETCH_OBJ)) { $table['data'][] = array($timeslot, $proj->projectnumber, $proj->title); // make the timeslot empty so we dont list it each time if there's more than one project in the timeslot $timeslot = ''; } } $rep->addTable($table); $rep->newPage(); unset($table); } $rep->output(); ?>