2009-12-18 12:56:12 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @copyright 2009 City of Bloomington, Indiana
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU/GPL, see LICENSE.txt
|
|
|
|
* @author Cliff Ingham <inghamn@bloomington.in.gov>
|
|
|
|
*/
|
2009-12-18 17:40:05 +00:00
|
|
|
class Interment
|
2009-12-18 12:56:12 +00:00
|
|
|
{
|
|
|
|
private $id;
|
|
|
|
private $section;
|
|
|
|
private $lot;
|
|
|
|
private $book;
|
|
|
|
private $pageNumber;
|
|
|
|
private $deceasedDate;
|
|
|
|
private $lastname;
|
|
|
|
private $firstname;
|
|
|
|
private $middleInitial;
|
|
|
|
private $birthPlace;
|
|
|
|
private $lastResidence;
|
|
|
|
private $age;
|
|
|
|
private $sex;
|
2009-12-18 14:28:25 +00:00
|
|
|
private $cemetery_id;
|
2009-12-18 12:56:12 +00:00
|
|
|
private $notes;
|
|
|
|
private $lot2;
|
|
|
|
|
2009-12-18 14:28:25 +00:00
|
|
|
private $cemetery;
|
|
|
|
|
2009-12-18 12:56:12 +00:00
|
|
|
/**
|
|
|
|
* 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();
|
2009-12-18 17:40:05 +00:00
|
|
|
$sql = 'select * from interments where id=?';
|
2009-12-18 12:56:12 +00:00
|
|
|
$result = $zend_db->fetchRow($sql,array($id));
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($result) {
|
|
|
|
foreach ($result as $field=>$value) {
|
|
|
|
if ($value) {
|
|
|
|
if ($field == 'deceasedDate') {
|
|
|
|
$value = (false === strpos($value,'0000')) ? new Date($value) : null;
|
|
|
|
}
|
|
|
|
$this->$field = $value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
2009-12-18 17:40:05 +00:00
|
|
|
throw new Exception('interments/unknownInterment');
|
2009-12-18 12:56:12 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
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.
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Saves this record back to the database
|
|
|
|
*/
|
|
|
|
public function save()
|
|
|
|
{
|
|
|
|
$this->validate();
|
|
|
|
|
|
|
|
$data = array();
|
|
|
|
$data['section'] = $this->section ? $this->section : null;
|
|
|
|
$data['lot'] = $this->lot ? $this->lot : null;
|
|
|
|
$data['book'] = $this->book ? $this->book : null;
|
|
|
|
$data['pageNumber'] = $this->pageNumber ? $this->pageNumber : null;
|
|
|
|
$data['deceasedDate'] = $this->deceasedDate ? $this->deceasedDate->format('Y-m-d') : null;
|
|
|
|
$data['lastname'] = $this->lastname ? $this->lastname : null;
|
|
|
|
$data['firstname'] = $this->firstname ? $this->firstname : null;
|
|
|
|
$data['middleInitial'] = $this->middleInitial ? $this->middleInitial : null;
|
|
|
|
$data['birthPlace'] = $this->birthPlace ? $this->birthPlace : null;
|
|
|
|
$data['lastResidence'] = $this->lastResidence ? $this->lastResidence : null;
|
|
|
|
$data['age'] = $this->age ? $this->age : null;
|
|
|
|
$data['sex'] = $this->sex ? $this->sex : null;
|
2009-12-18 14:28:25 +00:00
|
|
|
$data['cemetery_id'] = $this->cemetery_id ? $this->cemetery_id : null;
|
2009-12-18 12:56:12 +00:00
|
|
|
$data['notes'] = $this->notes ? $this->notes : null;
|
|
|
|
$data['lot2'] = $this->lot2 ? $this->lot2 : null;
|
|
|
|
|
|
|
|
if ($this->id) {
|
|
|
|
$this->update($data);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$this->insert($data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private function update($data)
|
|
|
|
{
|
|
|
|
$zend_db = Database::getConnection();
|
2009-12-18 17:40:05 +00:00
|
|
|
$zend_db->update('interments',$data,"id='{$this->id}'");
|
2009-12-18 12:56:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
private function insert($data)
|
|
|
|
{
|
|
|
|
$zend_db = Database::getConnection();
|
2009-12-18 17:40:05 +00:00
|
|
|
$zend_db->insert('interments',$data);
|
|
|
|
$this->id = $zend_db->lastInsertId('interments','id');
|
2009-12-18 12:56:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------
|
|
|
|
// Generic Getters
|
|
|
|
//----------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function getId()
|
|
|
|
{
|
|
|
|
return $this->id;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getSection()
|
|
|
|
{
|
|
|
|
return $this->section;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getLot()
|
|
|
|
{
|
|
|
|
return $this->lot;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getBook()
|
|
|
|
{
|
|
|
|
return $this->book;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getPageNumber()
|
|
|
|
{
|
|
|
|
return $this->pageNumber;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the date/time in the desired format
|
|
|
|
*
|
|
|
|
* Format is specified using PHP's date() syntax
|
|
|
|
* http://www.php.net/manual/en/function.date.php
|
|
|
|
* If no format is given, the Date object is returned
|
|
|
|
*
|
|
|
|
* @param string $format
|
|
|
|
* @return string|DateTime
|
|
|
|
*/
|
|
|
|
public function getDeceasedDate($format=null)
|
|
|
|
{
|
|
|
|
if ($format && $this->deceasedDate) {
|
|
|
|
return $this->deceasedDate->format($format);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return $this->deceasedDate;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getLastname()
|
|
|
|
{
|
|
|
|
return $this->lastname;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getFirstname()
|
|
|
|
{
|
|
|
|
return $this->firstname;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return char
|
|
|
|
*/
|
|
|
|
public function getMiddleInitial()
|
|
|
|
{
|
|
|
|
return $this->middleInitial;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getBirthPlace()
|
|
|
|
{
|
|
|
|
return $this->birthPlace;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getLastResidence()
|
|
|
|
{
|
|
|
|
return $this->lastResidence;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function getAge()
|
|
|
|
{
|
|
|
|
return $this->age;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getSex()
|
|
|
|
{
|
|
|
|
return $this->sex;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return text
|
|
|
|
*/
|
|
|
|
public function getNotes()
|
|
|
|
{
|
|
|
|
return $this->notes;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getLot2()
|
|
|
|
{
|
|
|
|
return $this->lot2;
|
|
|
|
}
|
|
|
|
|
2009-12-18 14:28:25 +00:00
|
|
|
/**
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function getCemetery_id()
|
|
|
|
{
|
|
|
|
return $this->cemetery_id;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Cemetery
|
|
|
|
*/
|
|
|
|
public function getCemetery()
|
|
|
|
{
|
|
|
|
if ($this->cemetery_id) {
|
|
|
|
if (!$this->cemetery) {
|
|
|
|
$this->cemetery = new Cemetery($this->cemetery_id);
|
|
|
|
}
|
|
|
|
return $this->cemetery;
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
2009-12-18 12:56:12 +00:00
|
|
|
//----------------------------------------------------------------
|
|
|
|
// Generic Setters
|
|
|
|
//----------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $string
|
|
|
|
*/
|
|
|
|
public function setSection($string)
|
|
|
|
{
|
|
|
|
$this->section = trim($string);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $string
|
|
|
|
*/
|
|
|
|
public function setLot($string)
|
|
|
|
{
|
|
|
|
$this->lot = trim($string);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $string
|
|
|
|
*/
|
|
|
|
public function setBook($string)
|
|
|
|
{
|
|
|
|
$this->book = trim($string);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $string
|
|
|
|
*/
|
|
|
|
public function setPageNumber($string)
|
|
|
|
{
|
|
|
|
$this->pageNumber = trim($string);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the date
|
|
|
|
*
|
|
|
|
* Date arrays should match arrays produced by getdate()
|
|
|
|
*
|
|
|
|
* Date string formats should be in something strtotime() understands
|
|
|
|
* http://www.php.net/manual/en/function.strtotime.php
|
|
|
|
*
|
|
|
|
* @param int|string|array $date
|
|
|
|
*/
|
|
|
|
public function setDeceasedDate($date)
|
|
|
|
{
|
|
|
|
if ($date) {
|
|
|
|
$this->deceasedDate = new Date($date);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$this->deceasedDate = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $string
|
|
|
|
*/
|
|
|
|
public function setLastname($string)
|
|
|
|
{
|
|
|
|
$this->lastname = trim($string);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $string
|
|
|
|
*/
|
|
|
|
public function setFirstname($string)
|
|
|
|
{
|
|
|
|
$this->firstname = trim($string);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param char $char
|
|
|
|
*/
|
|
|
|
public function setMiddleInitial($char)
|
|
|
|
{
|
|
|
|
$this->middleInitial = $char;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $string
|
|
|
|
*/
|
|
|
|
public function setBirthPlace($string)
|
|
|
|
{
|
|
|
|
$this->birthPlace = trim($string);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $string
|
|
|
|
*/
|
|
|
|
public function setLastResidence($string)
|
|
|
|
{
|
|
|
|
$this->lastResidence = trim($string);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param int $int
|
|
|
|
*/
|
|
|
|
public function setAge($int)
|
|
|
|
{
|
|
|
|
$this->age = preg_replace("/[^0-9]/","",$int);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $string
|
|
|
|
*/
|
|
|
|
public function setSex($string)
|
|
|
|
{
|
|
|
|
$this->sex = trim($string);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2009-12-18 14:28:25 +00:00
|
|
|
* @param int $int
|
|
|
|
*/
|
|
|
|
public function setCemetery_id($int)
|
|
|
|
{
|
|
|
|
$this->cemetery = new Cemetery($int);
|
|
|
|
$this->cemetery_id = $int;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param Cemetery $cemetery
|
2009-12-18 12:56:12 +00:00
|
|
|
*/
|
2009-12-18 14:28:25 +00:00
|
|
|
public function setCemetery($cemetery)
|
2009-12-18 12:56:12 +00:00
|
|
|
{
|
2009-12-18 14:28:25 +00:00
|
|
|
$this->cemetery_id = $cemetery->getId();
|
|
|
|
$this->cemetery = $cemetery;
|
2009-12-18 12:56:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param text $text
|
|
|
|
*/
|
|
|
|
public function setNotes($text)
|
|
|
|
{
|
|
|
|
$this->notes = $text;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $string
|
|
|
|
*/
|
|
|
|
public function setLot2($string)
|
|
|
|
{
|
|
|
|
$this->lot2 = trim($string);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//----------------------------------------------------------------
|
|
|
|
// Custom Functions
|
|
|
|
// We recommend adding all your custom code down here at the bottom
|
|
|
|
//----------------------------------------------------------------
|
2009-12-18 20:57:41 +00:00
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getURL()
|
|
|
|
{
|
|
|
|
return BASE_URL.'/interments/viewInterment.php?interment_id='.$this->id;
|
|
|
|
}
|
|
|
|
|
2009-12-18 16:54:06 +00:00
|
|
|
/**
|
|
|
|
* Returns the list of available sections
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public static function getSections(Cemetery $cemetery=null)
|
|
|
|
{
|
|
|
|
$zend_db = Database::getConnection();
|
|
|
|
$select = new Zend_Db_Select($zend_db);
|
2009-12-18 17:40:05 +00:00
|
|
|
$select->distinct()->from('interments','section');
|
2009-12-18 16:54:06 +00:00
|
|
|
$select->where('section is not null');
|
|
|
|
if ($cemetery) {
|
|
|
|
$select->where('cemetery_id=?',$cemetery->getId());
|
|
|
|
}
|
|
|
|
$select->order(array('section'));
|
|
|
|
return $zend_db->fetchCol($select);
|
|
|
|
}
|
2009-12-18 20:57:41 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getFullname()
|
|
|
|
{
|
|
|
|
$name = array();
|
|
|
|
if ($this->firstname) {
|
|
|
|
$name[] = $this->firstname;
|
|
|
|
}
|
|
|
|
if ($this->middleInitial) {
|
|
|
|
$name[] = $this->middleInitial;
|
|
|
|
}
|
|
|
|
if ($this->lastname) {
|
|
|
|
$name[] = $this->lastname;
|
|
|
|
}
|
|
|
|
return implode(' ',$name);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getSectionMapURL($section,$type='highlight')
|
|
|
|
{
|
|
|
|
$section = preg_replace('/[^a-z\-]/','',strtolower($section));
|
|
|
|
$type = $type=='highlight' ? 'highlight' : 'zoom';
|
|
|
|
|
|
|
|
$mapDirectory = "images/cemeteries/{$this->cemetery_id}";
|
|
|
|
$filename = "$type/$section.jpg";
|
|
|
|
|
|
|
|
if (file_exists(APPLICATION_HOME."/html/$mapDirectory/$filename")) {
|
|
|
|
return BASE_URL."$mapDirectory/$filename";
|
|
|
|
}
|
|
|
|
}
|
2009-12-18 12:56:12 +00:00
|
|
|
}
|