'First Name', 'lastname' => 'Last Name', 'email' => 'Email Address', 'password' => 'Password', 'passwordexpiry' => 'Password Expiry', 'phonehome' => 'Phone (Home)', 'phonecell' => 'Phone (Cell)', 'phonework' => 'Phone (Work)', 'phoneworkext' => 'Phone Ext. (Work)', 'organization' => 'Organization', 'created' => 'Created', 'lastlogin' => 'Last Login', 'address' =>"Address 1", 'address2' =>"Address 2", 'city' => 'City', 'province' => 'Province', 'postalcode' => 'Postal Code', 'deleted' => 'Deleted', 'deleteddatetime' => 'Deleted Date/Time', 'expertise_other' => 'Other Expertise/Notes', 'complete' => "Complete"); class person { var $id; function person($person_id=NULL) { if($person_id == NULL) { print("Empty constructor called\n"); $this->id = FALSE; } else { print("ID $person_id construction called\n"); $this->id = $person_id; } } }; class judge extends person { /* Static members for the table editor */ function tableEditorSetup($editor) { global $judges_fields; global $config; $cat = array(); $catf = array(); $q=mysql_query("SELECT * FROM projectcategories WHERE year='".$config['FAIRYEAR']."' ORDER BY id"); while($r=mysql_fetch_object($q)) { $cat[$r->id]=$r->category; $catf["catpref_{$r->id}"] = "Category Preference ({$r->category})"; } /* Setup the table editor with the fields we want to display * when displaying a list of judges, and also the type of each * field where required */ $l = array( 'id' => 'ID', 'firstname' => 'First Name', 'lastname' => 'Last Name' ); /* Most of these should be moved to the base class, as they * will be the same for all person groups */ $e = array_merge($judges_fields, array( 'language' => 'Language(s)', )); $e = array_merge($e, $catf); $editor->setTable('judges'); $editor->setListFields($l); $editor->setEditFields($e); print_r($e); print("
\n"); /* Build an array of langauges that we support */ $langs = array(); $q=mysql_query("SELECT * FROM languages WHERE active='Y'"); while($r=mysql_fetch_object($q)) { $langs[$r->lang] = $r->langname; } $editor->setFieldOptions('language', $langs); $editor->setFieldInputType('language', 'multicheck'); // $div = array(); // $q=mysql_query("SELECT * FROM projectdivisions WHERE year='".$config['FAIRYEAR']."' ORDER BY id"); // while($r=mysql_fetch_object($q)) { // $divshort[$r->id]=$r->division_shortform; // $div[$r->id]=$r->division; // } /* Pulled these out of register_judges.inc.php */ $preferencechoices=array( array('key' => -2, 'val' => "Very Low"), array('key' => -1, 'val' => "Low"), array('key' => 0, 'val' => "Indifferent"), array('key' => 1, 'val' => "Medium"), array('key' => 2, 'val' => "High") ); foreach($cat as $cid=>$category) { $editor->setFieldOptions("catpref_$cid", $preferencechoices); $editor->setFieldInputType("catpref_$cid", 'select'); } } /* Functions for $this */ function judge($judge_id=NULL) { global $judges_fields; person::person($judge_id); } function tableEditorLoad() { global $config; $id = $this->id; print("Loading Judge ID $id\n"); $q=mysql_query("SELECT judges.* FROM judges WHERE judges.id='$id'"); echo mysql_error(); /* We assume that the field names in the array we want to return * are the same as those in the database, so we'll turn the entire * query into a single associative array */ $j = mysql_fetch_assoc($q); /* Now turn on the ones this judge has selected */ $q=mysql_query("SELECT languages_lang FROM judges_languages WHERE judges_id='$id'"); $j['language'] = array(); if(mysql_num_rows($q)) { while($r=mysql_fetch_object($q)) { $j['language'][$r->languages_lang] = 1; } } $q=mysql_query("SELECT * FROM judges_catpref WHERE judges_id='$id' AND year='{$config['FAIRYEAR']}'"); if(mysql_num_rows($q)) { while($r=mysql_fetch_object($q)) { $j["catpref_{$r->projectcategories_id}"] = $r->rank; } } print_r($j); return $j; } function tableEditorSave($data) { /* If $this->id == false, then we need to INSERT a new record. * if it's a number, then we want an UPDATE statement */ global $judges_fields; global $config; $query = ""; /* Construct an insert query if we have to */ if($this->id == false) { $query = "INSERT INTO judges (id) VALUES ('')"; mysql_query($query); $this->id = mysql_insert_id(); } /* Now just update the record */ $query="UPDATE `judges` SET "; foreach($judges_fields AS $f=>$n) { $n = $data[$f]; $query .= "`$f`=$n,"; } //rip off the last comma $query=substr($query,0,-1); $query .= " WHERE id='{$this->id}'"; echo $query; mysql_query($query); print("data: \n"); print_r($data); print("-- \n"); /* judges_languages */ /* First delete all the languages, then insert the ones the judge * has selected */ $query = "DELETE FROM judges_languages WHERE judges_id='{$this->id}'"; mysql_query($query); print_r($data['language']); $keys = array_keys($data['language']); foreach($keys as $k) { $query = "INSERT INTO judges_languages (judges_id,languages_lang) VALUES ('{$this->id}','$k')"; print("$query"); mysql_query($query); } /* judges_catpref */ $query = "DELETE FROM judges_catpref WHERE judges_id='{$this->id}'"; print($query); mysql_query($query); /* Find all the catpref_[number] keys */ $keys = array_keys($data); foreach($keys as $k) { if(ereg("^catpref_([0-9]*)$", $k, $regs)) { if($data[$k] == "''") continue; $query = "INSERT INTO judges_catpref (judges_id,projectcategories_id,rank,year) values ('{$this->id}','{$regs[1]}',{$data[$k]},'{$config['FAIRYEAR']}')"; print($query."
\n"); mysql_query($query); } } } }; ?>