2007-01-09 19:05:23 +00:00
|
|
|
<?
|
|
|
|
|
|
|
|
/* Just the fields in the tours table, we use this twice */
|
|
|
|
$tours_fields = array( 'name' => 'Tour Name',
|
2007-12-20 01:05:04 +00:00
|
|
|
'num' => 'Tour Number',
|
2007-01-09 19:05:23 +00:00
|
|
|
'description' => 'Description',
|
|
|
|
'capacity' => 'Capacity',
|
|
|
|
'grade_min' => 'Minimum Grade',
|
|
|
|
'grade_max' => 'Maximum Grade',
|
2007-01-20 08:10:26 +00:00
|
|
|
'year' => 'Year',
|
|
|
|
'contact' => 'Contact',
|
|
|
|
'location' => 'Location');
|
2007-01-09 19:05:23 +00:00
|
|
|
|
|
|
|
class tours {
|
|
|
|
|
|
|
|
/* Static members for the table editor */
|
|
|
|
function tableEditorSetup($editor)
|
|
|
|
{
|
|
|
|
global $tours_fields;
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
/* Setup the table editor with the fields we want to display
|
|
|
|
* when displaying a list of tours, and also the type of each
|
|
|
|
* field where required */
|
2007-12-20 01:05:04 +00:00
|
|
|
$l = array( 'num' => 'Tour Number',
|
2007-01-09 19:05:23 +00:00
|
|
|
'name' => 'Tour Name',
|
|
|
|
'capacity' => 'Capacity',
|
|
|
|
'grade_min' => 'Minimum Grade',
|
|
|
|
'grade_max' => 'Maximum Grade',
|
|
|
|
'year' => 'Year',
|
|
|
|
);
|
|
|
|
|
|
|
|
/* Most of these should be moved to the base class, as they
|
|
|
|
* will be the same for all person groups */
|
|
|
|
|
|
|
|
$editor->setTable('tours');
|
|
|
|
$editor->setRecordType('Tour');
|
|
|
|
$editor->setListFields($l);
|
2007-12-20 01:05:04 +00:00
|
|
|
$editor->setPrimaryKey('id');
|
2007-01-09 19:05:23 +00:00
|
|
|
$editor->setEditFields($tours_fields);
|
|
|
|
|
|
|
|
$editor->setFieldOptions('year', array(
|
|
|
|
array('key' => 'NULL', 'val' => 'Inactive'),
|
|
|
|
array('key' => $config['FAIRYEAR'], 'val' => $config['FAIRYEAR'])));
|
|
|
|
|
|
|
|
// print_r($e);
|
|
|
|
print("<br>\n");
|
2007-01-21 18:46:12 +00:00
|
|
|
|
|
|
|
/* Build an array of grades */
|
|
|
|
$gradechoices = array();
|
|
|
|
for($g = $config['mingrade']; $g <= $config['maxgrade']; $g++) {
|
|
|
|
$gradechoices[] = array('key' => $g, 'val' => "Grade $g");
|
|
|
|
}
|
2007-01-09 19:05:23 +00:00
|
|
|
|
|
|
|
$editor->setFieldOptions("grade_min", $gradechoices);
|
|
|
|
$editor->setFieldInputType("grade_min", 'select');
|
|
|
|
$editor->setFieldOptions("grade_max", $gradechoices);
|
|
|
|
$editor->setFieldInputType("grade_max", 'select');
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Functions for $this */
|
|
|
|
|
|
|
|
|
|
|
|
function tours($tour_id=NULL)
|
|
|
|
{
|
|
|
|
if($tour_id == NULL) {
|
|
|
|
$this->id = FALSE;
|
|
|
|
} else {
|
|
|
|
$this->id = $tour_id;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function tableEditorLoad()
|
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
$id = $this->id;
|
|
|
|
|
|
|
|
// print("Loading Judge ID $id\n");
|
|
|
|
|
2024-12-09 01:06:15 -05:00
|
|
|
$q=$pdo->prepare("SELECT tours.*
|
2007-01-09 19:05:23 +00:00
|
|
|
FROM tours
|
|
|
|
WHERE tours.id='$id'");
|
2024-12-09 01:06:15 -05:00
|
|
|
$q->execute();
|
|
|
|
echo $pdo->errorInfo();
|
2007-01-09 19:05:23 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* 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 */
|
2024-12-09 01:06:15 -05:00
|
|
|
$j = $q->fetch(PDO::FETCH_ASSOC);
|
2007-01-09 19:05:23 +00:00
|
|
|
|
|
|
|
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 $tours_fields;
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
$query = "";
|
|
|
|
|
|
|
|
/* Construct an insert query if we have to */
|
|
|
|
if($this->id == false) {
|
|
|
|
$query = "INSERT INTO tours (id) VALUES ('')";
|
2024-12-09 01:06:15 -05:00
|
|
|
$stmt = $pdo->prepare($query);
|
|
|
|
$stmt->execute();
|
|
|
|
$this->id = $pdo->lastInsertId();
|
2007-01-09 19:05:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Give it a proper year when saving */
|
|
|
|
|
|
|
|
/* Now just update the record */
|
|
|
|
$query="UPDATE `tours` SET ";
|
|
|
|
|
|
|
|
foreach($tours_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;
|
2024-12-09 01:06:15 -05:00
|
|
|
$stmt = $pdo->prepare($query);
|
|
|
|
$stmt->execute();
|
2007-01-09 19:05:23 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
function tableEditorDelete()
|
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
$id = $this->id;
|
|
|
|
|
2024-12-09 01:06:15 -05:00
|
|
|
$stmt=$pdo->prepare("DELETE FROM tours_choice WHERE tour_id='$id' AND year=".$config['FAIRYEAR']."'");
|
|
|
|
$stmt->execute();
|
|
|
|
$stmt=$pdo->prepare("DELETE FROM tours WHERE id='$id' AND year='".$config['FAIRYEAR']."'");
|
|
|
|
$stmt->execute();
|
2007-01-09 19:05:23 +00:00
|
|
|
|
|
|
|
echo happy(i18n("Successfully removed tour from this year's fair"));
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
?>
|