<? /* * 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 ('../common.inc.php'); require_once ('../user.inc.php'); user_auth_required('committee', 'admin'); require ('judges.inc.php'); require ('../projects.inc.php'); send_header('Judging Teams Projects', array('Committee Main' => 'committee_main.php', 'Administration' => 'admin/index.php', 'Judges' => 'admin/judges.php')); ?> <script language="javascript" type="text/javascript"> function assign(ts) { document.forms.teamsprojects.timeslot.value=ts; document.forms.teamsprojects.submit(); } function eligibleclick() { if(document.forms.teamsprojects.showeligible.checked) { window.location.href="judges_teams_projects.php?action=edit&edit="+document.forms.teamsprojects.edit.value+"&judges_projects_list_eligible=true"; } else { window.location.href="judges_teams_projects.php?action=edit&edit="+document.forms.teamsprojects.edit.value+"&judges_projects_list_eligible=false"; } } </script> <? echo '<br />'; $action = null; if (get_value_from_array($_GET, 'actio')) $action = $_GET['action']; else if (get_value_from_array($_POST, 'action')) $action = $_POST['action']; if (get_value_from_array($_GET, 'edit')) $edit = $_GET['edit']; else if (get_value_from_array($_POST, 'edit')) $edit = $_POST['edit']; if (!get_value_from_2d_array($_SESSION, 'viewstate', 'judges_projects_list_show')) $_SESSION['viewstate']['judges_projects_list_show'] = 'unassigned'; // now update the judges_teams_list_show viewstate if (get_value_from_array($_GET, 'judges_projects_list_show')) $_SESSION['viewstate']['judges_projects_list_show'] = $_GET['judges_projects_list_show']; if (!get_value_from_2d_array($_SESSION, 'viewstate', 'judges_projects_list_eligible')) $_SESSION['viewstate']['judges_projects_list_eligible'] = 'true'; // now update the judges_teams_list_show viewstate if (get_value_from_array($_GET, 'judges_projects_list_eligible')) $_SESSION['viewstate']['judges_projects_list_eligible'] = $_GET['judges_projects_list_eligible']; if (get_value_from_array($_GET, 'action') == 'delete' && $_GET['delete'] && $_GET['edit']) { $stmt = $pdo->prepare("DELETE FROM judges_teams_timeslots_projects_link WHERE id=?"); $stmt->execute([$_GET['delete']]); echo happy(i18n('Judging team project successfully removed')); $action = 'edit'; } if (get_value_from_array($_POST, 'action') == 'assign' && $_POST['edit'] && $_POST['timeslot'] && $_POST['project_id']) { $stmt = $pdo->prepare("INSERT INTO judges_teams_timeslots_projects_link (judges_teams_id,judges_timeslots_id,projects_id,year) VALUES (?,?,?,?)"); $stmt->execute([$_POST['edit'],$_POST['timeslot'],$_POST['project_id'],$config['FAIRYEAR']]); echo happy(i18n('Project assigned to team timeslot')); } $q = $pdo->prepare("SELECT DISTINCT(date) AS d FROM judges_timeslots WHERE year=?"); $q->execute([$config['FAIRYEAR']]); if ($q->rowCount() > 1) $show_date = true; else $show_date = false; if (($action == 'edit' || $action == 'assign') && $edit) { echo '<a href="judges_teams_projects.php">Back to Judging Teams Projects List</a>'; echo '<form name="teamsprojects" method="post" action="judges_teams_projects.php">'; echo "<input type=\"hidden\" name=\"action\" value=\"assign\">\n"; echo "<input type=\"hidden\" name=\"edit\" value=\"$edit\">\n"; echo "<input type=\"hidden\" name=\"timeslot\" value=\"\">\n"; $team = getJudgingTeam($edit); echo '<b>' . $team['name'] . ' (#' . $team['num'] . ')</b><br />'; if (count($team['members'])) { $memberlist = ' '; foreach ($team['members'] AS $member) { if ($member['captain'] == 'yes') $memberlist .= '<i>'; $memberlist .= $member['firstname'] . ' ' . $member['lastname']; if ($member['captain'] == 'yes') $memberlist .= '</i>'; $memberlist .= ', '; } echo '<b>' . i18n('Judging Team Members') . ': </b>'; $memberlist = substr($memberlist, 0, -2); echo '<br />'; } else $memberlist = error(i18n('Team has no members assigned to it. <a href="judges_teams_members.php">Assign Judges Here</a>')); echo $memberlist; echo '<br />'; echo '<br />'; // we need award_ids for use below to get the eligible projects, so lets build the array here while we're displaying the awards $award_ids = array(); if (count($team['awards'])) { $awardlist = ' '; foreach ($team['awards'] AS $award) { $awardlist .= $award['name']; $awardlist .= ', '; $award_ids[] = $award['id']; } echo '<b>' . i18n('Judging Team Awards') . ': </b>'; $awardlist = substr($awardlist, 0, -2); echo '<br />'; } else $awardlist = error(i18n('Team has no awards assigned to it. <a href="judges_teams.php">Assign Awards Here</a>')); echo $awardlist; // 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=? 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([$team['id']]); $numslots = $q - rowCount(); if ($numslots) { echo '<br />'; echo '<br />'; if ($_SESSION['viewstate']['judges_projects_list_eligible'] == 'true') $ch = 'checked="checked"'; else $ch = ''; echo "<input $ch onclick=\"eligibleclick()\" type=\"checkbox\" name=\"showeligible\"> " . i18n('Only show projects eligible/nominated for awards assigned to this team'); echo '<table>'; echo '</tr>'; echo '<tr>'; if ($_SESSION['viewstate']['judges_projects_list_show'] == 'all') { echo "<td align=left><a href=\"judges_teams_projects.php?action=$action&edit=$edit&judges_projects_list_show=unassigned\">" . i18n('show unassigned') . '</a></td>'; echo '<td align=right><b>' . i18n('show all') . '</b></td>'; } else { echo '<td align=left><b>' . i18n('show unassigned') . '</b></td>'; echo "<td align=right><a href=\"judges_teams_projects.php?action=$action&edit=$edit&judges_projects_list_show=all\">" . i18n('show all') . '</a></td>'; } echo '<td> </td>'; echo '</tr>'; echo '<tr><td colspan=2>'; if ($_SESSION['viewstate']['judges_projects_list_show'] == 'all') { $querystr = 'SELECT projects.id, projects.projectnumber, projects.title, registrations.status FROM projects, registrations WHERE projectnumber is not null ' . getJudgingEligibilityCode() . " AND projects.registrations_id=registrations.id AND projects.year=? ORDER BY projectnumber"; } else if ($_SESSION['viewstate']['judges_projects_list_show'] == 'unassigned') { $querystr = "SELECT projects.id, projects.projectnumber, projects.title, registrations.status FROM projects LEFT JOIN judges_teams_timeslots_projects_link ON projects.id = judges_teams_timeslots_projects_link.projects_id, registrations WHERE projectnumber is not null ' . getJudgingEligibilityCode(). ' AND projects.registrations_id=registrations.id AND judges_teams_timeslots_projects_link.projects_id IS NULL AND projects.year=? ORDER BY projectnumber"; } $pq = $pdo->prepare($querystr); $pq->execute([$config['FAIRYEAR'],$config['FAIRYEAR']]); show_pdo_errors_if_any($pdo); $eligibleprojects = getProjectsEligibleOrNominatedForAwards($award_ids); // echo nl2br(print_r($eligibleprojects,true)); // the keys are the project numbers, so lets get an array of those too so we can use in_array below $eligibleprojectsnumbers = array_keys($eligibleprojects); // echo nl2br(print_r($eligibleprojects,true)); $numprojects = 0; echo '<select name="project_id">'; echo '<option value="">' . i18n('Choose Project to Assign to Timeslot') . "</option>\n"; while ($pr = $pq->fetch(PDO::FETCH_OBJ)) { if ($_SESSION['viewstate']['judges_projects_list_eligible'] == 'true') { if (in_array($pr->projectnumber, $eligibleprojectsnumbers)) { echo "<option value=\"$pr->id\">$pr->projectnumber - $pr->title</option>\n"; $numprojects++; } } else { echo "<option value=\"$pr->id\">$pr->projectnumber - $pr->title</option>\n"; $numprojects++; } } echo '</select>'; echo '</td><td>'; echo i18n('%1 projects listed', array($numprojects)); echo '</td></tr>'; echo '</table>'; echo '<br />'; echo '<br />'; echo '<table class="summarytable">'; echo '<tr>'; echo '<th>' . i18n('Timeslot') . '</th>'; echo '<th>' . i18n('Project') . '</th>'; echo '</tr>'; while ($r = $q->fetch(PDO::FETCH_OBJ)) { echo '<tr><td>'; echo '<nobr>'; if ($show_date) echo format_date($r->date) . ' '; echo format_time($r->starttime); echo ' - '; echo format_time($r->endtime); echo '</nobr>'; echo '</td><td>'; $projq = $pdo->prepare("SELECT judges_teams_timeslots_projects_link.id AS link_id, projects.projectnumber, projects.id, projects.title FROM projects, judges_teams_timeslots_projects_link WHERE judges_teams_timeslots_projects_link.judges_timeslots_id=? AND judges_teams_timeslots_projects_link.judges_teams_id=? AND judges_teams_timeslots_projects_link.projects_id=projects.id AND judges_teams_timeslots_projects_link.year=? ORDER BY projectnumber "); $projq->execute([$r->id,$team['id'],$config['FAIRYEAR']]); show_pdo_errors_if_any($pdo); while ($proj = $projq->fetch(PDO::FETCH_OBJ)) { echo '<a onclick="return confirmClick(\'Are you sure you want to remove this project from this team timeslot?\')" href="judges_teams_projects.php?action=delete&delete=' . $proj->link_id . '&edit=' . $team['id'] . '"><img border=0 src="' . $config['SFIABDIRECTORY'] . '/images/16/button_cancel.' . $config['icon_extension'] . '"></a>'; echo "$proj->projectnumber - $proj->title <br />"; } echo "<input name=\"assignbtn[$r->id]\" type=\"button\" onclick=\"assign('$r->id')\" value=\"" . i18n('Assign') . '">'; echo '</td></tr>'; } echo '</table>'; } else { echo error(i18n('Team has no timeslots assigned to it. <a href="judges_teams_timeslots.php">Assign Timeslots Here</a>')); } echo '</form>'; } else { echo '<input type="hidden" name="action" value="assign">'; echo '<table class="tableview">'; echo '<thead><tr>'; echo '<th>' . i18n('Team') . '</th>'; echo '<th>' . i18n('Timeslots and Projects') . '</th>'; echo '</tr></thead>'; $teams = getJudgingTeams(); foreach ($teams AS $team) { echo '<tr>'; echo '<td width="200">'; echo '<b>' . $team['name'] . ' (#' . $team['num'] . ')</b><br />'; $memberlist = ''; if (count(get_value_from_array($team, 'members', []))) { foreach ($team['members'] AS $member) { echo ' '; $err = false; foreach ($team['languages_projects'] AS $projectlang) { if (!in_array($projectlang, $member['languages_array'])) { $err = true; break; } } if ($err) echo '<span class="error">'; if ($member['captain'] == 'yes') echo '<i>'; echo $member['firstname'] . ' ' . $member['lastname'] . ' (' . $member['languages'] . ')<br />'; if ($member['captain'] == 'yes') echo '</i>'; if ($err) echo '</span>'; } } echo '</td>'; echo '<td>'; // 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=? 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([$team['id']]); $numslots = $q->rowCount(); echo '<a href="judges_teams_projects.php?action=edit&edit=' . $team['id'] . '">' . i18n('Edit team project assignments') . '</a>'; echo '<table class="tableview" style="margin-left: 0px; width: 100%; font-size: 1.0em;">'; while ($r = $q->fetch(PDO::FETCH_OBJ)) { echo '<tr><td width="100" align="center">'; echo '<nobr>'; if ($show_date) echo format_date($r->date) . ' '; echo format_time($r->starttime); echo ' - '; echo format_time($r->endtime); echo '</nobr>'; echo '</td><td>'; $projq = $pdo->prepare("SELECT projects.projectnumber, projects.id, projects.title, projects.language FROM projects, judges_teams_timeslots_projects_link WHERE judges_teams_timeslots_projects_link.judges_timeslots_id=? AND judges_teams_timeslots_projects_link.judges_teams_id=? AND judges_teams_timeslots_projects_link.projects_id=projects.id AND judges_teams_timeslots_projects_link.year=? ORDER BY projectnumber "); $projq->execute([$r->id,$team['id'],$config['FAIRYEAR']]); show_pdo_errors_if_any($pdo); while ($proj = $projq->fetch(PDO::FETCH_OBJ)) { if (!in_array($proj->language, $team['languages_members'])) echo '<span class="error">'; echo "$proj->projectnumber - $proj->title ($proj->language)"; if (!in_array($proj->language, $team['languages_members'])) echo "</span>\n"; echo '<br />'; } echo '</td></tr>'; } echo '</table>'; echo '</td>'; echo '</tr>'; } echo '</table>'; } send_footer(); ?>