rosehill/classes/Section.php

236 lines
4.7 KiB
PHP
Raw Permalink Normal View History

<?php
/**
* @copyright 2009 City of Bloomington, Indiana
* @license http://www.gnu.org/licenses/agpl.txt GNU/AGPL, see LICENSE.txt
* @author Cliff Ingham <inghamn@bloomington.in.gov>
*/
class Section
{
private $id;
private $cemetery_id;
private $code;
private $name;
private $cemetery;
/**
* Populates the object with data
*
* Passing in an associative array of data will populate this object without
* hitting the database.
*
* Passing in a scalar will load the data from the database.
* This will load all fields in the table as properties of this class.
* You may want to replace this with, or add your own extra, custom loading
*
* @param int|array $id
*/
public function __construct($id=null)
{
if ($id) {
if (is_array($id)) {
$result = $id;
}
else {
$zend_db = Database::getConnection();
$sql = 'select * from sections where id=?';
$result = $zend_db->fetchRow($sql,array($id));
}
if ($result) {
foreach ($result as $field=>$value) {
if ($value) {
$this->$field = $value;
}
}
}
else {
throw new Exception('sections/unknownSection');
}
}
else {
// This is where the code goes to generate a new, empty instance.
// Set any default values for properties that need it here
}
}
/**
* Throws an exception if anything's wrong
* @throws Exception $e
*/
public function validate()
{
// Check for required fields here. Throw an exception if anything is missing.
if (!$this->cemetery_id || !$this->code) {
throw new Excepction('missingRequiredFields');
}
}
/**
* Saves this record back to the database
*/
public function save()
{
$this->validate();
$data = array();
$data['cemetery_id'] = $this->cemetery_id;
$data['code'] = $this->code;
$data['name'] = $this->name ? $this->name : null;
if ($this->id) {
$this->update($data);
}
else {
$this->insert($data);
}
}
private function update($data)
{
$zend_db = Database::getConnection();
$zend_db->update('sections',$data,"id='{$this->id}'");
}
private function insert($data)
{
$zend_db = Database::getConnection();
$zend_db->insert('sections',$data);
$this->id = $zend_db->lastInsertId('sections','id');
}
//----------------------------------------------------------------
// Generic Getters
//----------------------------------------------------------------
/**
* @return int
*/
public function getId()
{
return $this->id;
}
/**
* @return int
*/
public function getCemetery_id()
{
return $this->cemetery_id;
}
/**
* @return string
*/
public function getCode()
{
return $this->code;
}
/**
* @return string
*/
public function getName()
{
return $this->name;
}
/**
* @return Cemetery
*/
public function getCemetery()
{
if ($this->cemetery_id) {
if (!$this->cemetery) {
$this->cemetery = new Cemetery($this->cemetery_id);
}
return $this->cemetery;
}
return null;
}
//----------------------------------------------------------------
// Generic Setters
//----------------------------------------------------------------
/**
* @param int $int
*/
public function setCemetery_id($int)
{
$this->cemetery = new Cemetery($int);
$this->cemetery_id = $int;
}
/**
* @param string $string
*/
public function setCode($string)
{
$this->code = trim($string);
}
/**
* @param string $string
*/
public function setName($string)
{
$this->name = trim($string);
}
/**
* @param Cemetery $cemetery
*/
public function setCemetery($cemetery)
{
$this->cemetery_id = $cemetery->getId();
$this->cemetery = $cemetery;
}
//----------------------------------------------------------------
// Custom Functions
// We recommend adding all your custom code down here at the bottom
//----------------------------------------------------------------
public function __toString()
{
return $this->name ? $this->name : $this->code;
}
private function getMapDirectory()
{
return 'images/cemeteries/'.$this->cemetery_id;
}
/**
* Returns the URL to the map image
*
* @param string $type Either 'highlight' or 'zoom'
* @return string
*/
public function getMap($type='highlight')
{
$imageDir = $this->getMapDirectory();
$type = $type=='highlight' ? 'highlight' : 'zoom';
$glob = glob(APPLICATION_HOME."/html/$imageDir/$type/{$this->id}.*");
if (count($glob)) {
$filename = basename($glob[0]);
return BASE_URL."/$imageDir/$type/$filename";
}
}
/**
* @param array|string $file Either an entry from $_FILES or a path to a file
*/
public function saveMap($file,$type)
{
$imageDir = $this->getMapDirectory();
$type = $type=='highlight' ? 'highlight' : 'zoom';
$directory = APPLICATION_HOME."/html/$imageDir/$type";
Map::saveFile($directory,$file,$this->id);
}
}