From 8e4306ae3b3358b73002af6fb46310c865cb6829 Mon Sep 17 00:00:00 2001
From: jacob <jacob>
Date: Thu, 14 Oct 2010 14:10:49 +0000
Subject: [PATCH] Updated volunteer preferences to work with the new interface
 and with the new conference id system

---
 admin/volunteer_positions_manager.php |   4 +-
 db/db.code.version.txt                |   2 +-
 db/db.update.212.php                  |  36 +++++++
 user_edit.php                         |   3 +-
 volunteer.inc.php                     |  12 ++-
 volunteer_position.php                | 133 ++++++++++++++------------
 6 files changed, 119 insertions(+), 71 deletions(-)
 create mode 100644 db/db.update.212.php

diff --git a/admin/volunteer_positions_manager.php b/admin/volunteer_positions_manager.php
index 02ee90c5..7bb59ac8 100644
--- a/admin/volunteer_positions_manager.php
+++ b/admin/volunteer_positions_manager.php
@@ -41,13 +41,13 @@
 				"start"=>"Start Day/Time",
 				"end"=>"End Day/Time"
 			), null, 
-			array("year" => $config['FAIRYEAR'] )
+			array("conferences_id" => $conference['id'] )
 			);
 
  $editor->setPrimaryKey("id");
  $editor->setDefaultSortField("start,name");
  $editor->setRecordType("Volunteer Position");
- $editor->filterList('year',$config['FAIRYEAR']);
+ $editor->filterList('conferences_id',$conference['id']);
  $editor->execute();
 
  send_footer();
diff --git a/db/db.code.version.txt b/db/db.code.version.txt
index dba40afc..0d389107 100644
--- a/db/db.code.version.txt
+++ b/db/db.code.version.txt
@@ -1 +1 @@
-211
+212
diff --git a/db/db.update.212.php b/db/db.update.212.php
new file mode 100644
index 00000000..fcbe7f6b
--- /dev/null
+++ b/db/db.update.212.php
@@ -0,0 +1,36 @@
+<?
+function db_update_212_pre() 
+{
+}
+
+function db_update_212_post()
+{
+	$tables=array("volunteer_positions_signup", "volunteer_positions");
+
+	// add the conferences_id field
+	foreach($tables as $tableName){
+		$query = "ALTER TABLE `$tableName` ADD `conferences_id` INT NOT NULL";
+		mysql_query($query);
+		echo $query . ";\n";
+	}
+
+	// get the year => conference_id links
+	$q1 = mysql_query("SELECT year, id FROM conferences WHERE year > 0");
+
+	//update the tables
+	while($r = mysql_fetch_assoc($q1)){
+		foreach($tables as $tableName){
+			$query = "UPDATE `$tableName` SET `conferences_id` = {$r['id']} WHERE `year` = {$r['year']}";
+			mysql_query($query);
+			echo $query . ";\n";
+		}
+	}
+
+	// add the conferences_id field
+	foreach($tables as $tableName){
+		$query = "ALTER TABLE `$tableName` DROP `year`";
+		mysql_query($query);
+		echo $query . ";\n";
+	}
+}
+?>
diff --git a/user_edit.php b/user_edit.php
index 2add0ac0..09d8625a 100644
--- a/user_edit.php
+++ b/user_edit.php
@@ -26,6 +26,7 @@ require_once('common.inc.php');
 require_once('user.inc.php');
 require_once('user_edit.inc.php');
 require_once('judge.inc.php');
+require_once('volunteer.inc.php');
 
 $edit_id = isset($_GET['users_id']) ? intval($_GET['users_id']) : $_SESSION['users_id'];
 if($edit_id != $_SESSION['users_id']) 
@@ -142,7 +143,7 @@ $tabs = array(	'fairinfo' => array(
 			'label' => 'Volunteer Positions',
 			'types' => array('volunteer'),
 			'file' => 'volunteer_position.php',
-			'disabled' => true,
+			'status_func' => 'volunteer_status_position',
 			),
 		'fairstats' => array(
 			'label' => 'Fair Statistics and Information',
diff --git a/volunteer.inc.php b/volunteer.inc.php
index 4da00227..44eabc4b 100644
--- a/volunteer.inc.php
+++ b/volunteer.inc.php
@@ -27,10 +27,10 @@
 
 function volunteer_status_position($u)
 {
-	global $config;
-	/* See if they have selected something */
-	$q = "SELECT * FROM volunteer_positions_signup WHERE users_id='{$u['id']}' 
-			AND year='{$config['FAIRYEAR']}'";
+	global $conference;
+	if($conferenceid === null) $conferenceid = $conference['id'];
+	// See if they have selected something
+	$q = "SELECT * FROM volunteer_positions_signup WHERE users_id = '{$u['id']}' AND conferences_id = $conferenceid";
 	$r = mysql_query($q);
 	if(mysql_num_rows($r) >= 1) {
 		return "complete";
@@ -40,6 +40,7 @@ function volunteer_status_position($u)
 
 function volunteer_status_update(&$u)
 {
+/*
 	global $config;
 
 	if(   user_personal_info_status($u) == 'complete'
@@ -50,7 +51,8 @@ function volunteer_status_update(&$u)
 
 	user_save($u);
 	return ($u['volunteer_complete'] == 'yes') ? 'complete' : 'incomplete';
-
+*/
+return 'complete';
 }
 
 ?>
diff --git a/volunteer_position.php b/volunteer_position.php
index ad93349d..9b2a8d08 100644
--- a/volunteer_position.php
+++ b/volunteer_position.php
@@ -23,38 +23,35 @@
 */
 ?>
 <?
- require_once("common.inc.php");
- require_once("user.inc.php");
- require_once("volunteer.inc.php");
+require_once("common.inc.php");
+require_once("user.inc.php");
+require_once("volunteer.inc.php");
 
-
- if($_SESSION['embed'] == true) {
- 	$u = user_load($_SESSION['embed_edit_id']);
- } else {
-	user_auth_required('volunteer');
+// not sure if this needs to be retained for backwards compatability
+if(array_key_exists('embed_edit_id', $_SESSION)){
+	$u = user_load($_SESSION['embed_edit_id']);
+}else{
 	$u = user_load($_SESSION['users_id']);
- }
+}
 
-
- if($_POST['action']=="save")
- {
+if($_GET['action']=="save"){
 	$vals = '';
- 	if(is_array($_POST['posn'])) {
+	if(is_array($_POST['posn'])) {
 
 		/* Load available IDs */
 		$posns = array();
-		$q = "SELECT * FROM volunteer_positions WHERE year='{$config['FAIRYEAR']}'";
+		$q = "SELECT * FROM volunteer_positions WHERE conferences_id='{$conference['id']}'";
 		$r = mysql_query($q);
 		while($p = mysql_fetch_object($r)) {
 			$posns[] = $p->id;
 		}
 
-		/* Match selections with avaiulable positions */
+		/* Match selections with available positions */
 		foreach($_POST['posn'] as $id=>$val) {
 			if(!in_array($id, $posns)) continue;
 
 			if($vals != '') $vals .=',';
-			$vals .= "('{$u['id']}','$id','{$config['FAIRYEAR']}')";
+			$vals .= "('{$u['id']}','$id','{$conference['id']}')";
 		}
 	} 
 			
@@ -62,67 +59,81 @@
 	mysql_query("DELETE FROM volunteer_positions_signup 
 			WHERE 
 				users_id='{$u['id']}' 
-				AND year='{$config['FAIRYEAR']}' ");
+				AND conferences_id='{$conference['id']}' ");
 		echo mysql_error();
 
 	/* Add new selections if there are any */
 	if($vals != '') {
-		$q = "INSERT INTO volunteer_positions_signup (users_id, volunteer_positions_id,year) 
+		$q = "INSERT INTO volunteer_positions_signup (users_id, volunteer_positions_id,conferences_id) 
 				VALUES $vals";
 		$r=mysql_query($q);
 		echo mysql_error();
 
 	}
+	$newstatus = volunteer_status_position($u);
+?>
+	<script type="text/javascript">
+		user_update_tab_status('volunteerpos','<?=$newstatus?>');
+	</script>
+<?php
 
-	message_push(notice(i18n("Volunteer Positions successfully updated")));
- }
+	//message_push(notice(i18n("Volunteer Positions successfully updated")));
+	exit;
+}
 
 /* update overall status */
 volunteer_status_update($u);
 
-if($_SESSION['embed'] != true) {
-	//output the current status
-	$newstatus=volunteer_status_position($u);
-	if($newstatus!='complete')
-		message_push(error(i18n("Volunteer Position Selection Incomplete")));
-	else
-		message_push(happy(i18n("Volunteer Position Selection Complete")));
+?>
+
+<script type="text/javascript">
+function volunteer_save()
+{
+	$("#debug").load("<?=$config['SFIABDIRECTORY']?>/volunteer_position.php?action=save&users_id=<?=$u['id']?>", $("#volunteer_form").serializeArray());
+        return false;
 }
 
-if($_SESSION['embed'] == true) {
- 	echo "<br />";
-	display_messages();
-	echo "<h3>".i18n('Volutneer Positions')."</h3>";
- 	echo "<br />";
-} else {
-	//send the header
-	send_header("Volunteer Positions", 
- 		array("Volunteer Registration" => "volunteer_main.php")
-		);
+$(document).ready(function() {
+	$("#volunteer_form").validate({
+		submitHandler: function() {
+			volunteer_save();
+			return false;
+		},
+		cancelHandler: function() {
+			volunteer_save();
+			return false;
+		}
+	});
+
+	user_update_tab_status('volunteerpos');
+
+//	$("#volunteer_form").valid();
+});
+</script>
+
+<?php
+
+echo "<div>";
+display_messages();
+echo "<h4>".i18n('Volunteer Positions')." - <span class=\"status_volunteerpos\"></span></h4>";
+echo "</div>";
+
+echo "<form id=\"volunteer_form\" class=\"editor\">\n";
+echo "<table>\n";
+
+/* Read current selections */
+$checked_positions = array();
+$r = mysql_query("SELECT * FROM volunteer_positions_signup WHERE users_id = '{$u['id']}' AND conferences_id='{$conference['id']}'");
+while($p = mysql_fetch_object($r)) {
+	$checked_positions[] = $p->volunteer_positions_id;
 }
 
- $s = ($_SESSION['embed'] == true) ? $_SESSION['embed_submit_url'] : 'volunteer_position.php';
- echo "<form name=\"personalform\" method=\"post\" action=\"$s\">\n";
- echo "<input type=\"hidden\" name=\"action\" value=\"save\" />\n";
- echo "<table>\n";
+/* Load available volunteer positions */
+$q = "SELECT *,UNIX_TIMESTAMP(start) as ustart, UNIX_TIMESTAMP(end) as uend FROM volunteer_positions WHERE conferences_id = {$conference['id']}";
+$r = mysql_query($q);
+while($p = mysql_fetch_object($r)) {
 
- /* Read current selections */
- $q = "SELECT * FROM volunteer_positions_signup WHERE
- 		users_id = '{$u['id']}' 
- 		AND year='{$config['FAIRYEAR']}'";
- $r = mysql_query($q);
- $checked_positions = array();
- while($p = mysql_fetch_object($r)) {
- 	$checked_positions[] = $p->volunteer_positions_id;
- }
-
- /* Load available volunteer positions */
- $q = "SELECT *,UNIX_TIMESTAMP(start) as ustart, UNIX_TIMESTAMP(end) as uend
- 			FROM volunteer_positions WHERE year='{$config['FAIRYEAR']}'";
- $r = mysql_query($q);
- while($p = mysql_fetch_object($r)) {
-
- 	echo '<tr><td>';
+	echo '<tr><td>';
 
 	$checked = false;
 	
@@ -157,10 +168,8 @@ if($_SESSION['embed'] == true) {
 }
 
 echo "</table>";
-echo "<input type=\"submit\" value=\"".i18n("Save Position Selection")."\" />\n";
+echo "<button>" . i18n("Save Information") . "</button>";
 echo "</form>";
 
- echo "<br />";
-
- if($_SESSION['embed'] != true) send_footer();
+echo "<br />";
 ?>