This repository has been archived on 2024-04-08. You can view files and clone it, but cannot push or open issues or pull requests.

71 lines
1.9 KiB
PHP
Raw Normal View History

2011-05-23 20:01:27 +10:00
<?php defined('SYSPATH') or die('No direct access allowed.');
/**
* This class overrides Kohana's ORM
*
2012-11-26 16:57:18 +11:00
* @package PTA/Modifications
2011-05-23 20:01:27 +10:00
* @category Classes
* @category Helpers
* @author Deon George
* @copyright (c) 2010 Deon George
* @license http://dev.leenooks.net/license.html
*/
2012-11-26 16:57:18 +11:00
abstract class ORM extends Kohana_ORM {
2012-11-22 14:13:14 +11:00
protected $_table_names_plural = FALSE;
protected $_model_names_plural = FALSE;
2011-05-23 20:01:27 +10:00
private $_object_formated = array();
private $_formated = FALSE;
// Our filters used to display values in a friendly format
protected $_display_filters = array();
// Override check() so that it doesnt throw an exception.
// @todo Need to figure out how to show the items that fail validation
final public function check(Validation $extra_validation = NULL) {
// Determine if any external validation failed
$extra_errors = ($extra_validation AND ! $extra_validation->check());
// Always build a new validation object
$this->_validation();
$array = $this->_validation;
if (($this->_valid = $array->check()) === FALSE OR $extra_errors)
{
return FALSE;
}
return $this;
}
/**
* Format fields for display purposes
*
* @param string column name
* @return mixed
*/
private function _format() {
foreach ($this->_display_filters as $column => $formats)
$this->_object_formated[$column] = $this->run_filter($column,$this->__get($column),array($column=>$formats));
$this->_formated = TRUE;
}
/**
* Return a formated columns, as per the model definition
*/
public function display($column) {
// Trigger a load of the record.
$value = $this->__get($column);
// If some of our fields need to be formated for display purposes.
2012-11-26 16:57:18 +11:00
if (! $this->_formated AND $this->_display_filters)
2011-05-23 20:01:27 +10:00
$this->_format();
if (isset($this->_object_formated[$column]))
return $this->_object_formated[$column];
else
2011-06-24 11:27:21 +10:00
return HTML::nbsp($value);
2011-05-23 20:01:27 +10:00
}
}
?>