egroupware/infolog/inc/class.infolog_egw_record.inc.php

157 lines
3.3 KiB
PHP
Raw Normal View History

2010-11-08 18:19:22 +01:00
<?php
/**
* eGroupWare - Infolog - importexport
*
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
* @package infolog
* @subpackage importexport
* @link http://www.egroupware.org
* @author Nathan Gray
* @copyright Nathan Gray
* @version $Id$
*/
/**
* class infolog_egw_record
*
* compability layer for iface_egw_record needet for importexport
*/
class infolog_egw_record implements importexport_iface_egw_record
{
private $identifier = '';
private $record = array();
private static $bo;
2010-11-08 18:19:22 +01:00
// Used in conversions
static $types = array(
2012-12-31 21:38:00 +01:00
'select' => array('info_type', 'info_status', 'info_priority', 'info_pricelist'),
'select-cat' => array('info_cat'),
'select-account' => array('info_owner','info_responsible','modifier'),
2012-12-31 21:38:00 +01:00
'date-time' => array('info_startdate', 'info_enddate','info_datecompleted', 'info_datemodified','info_created'),
'links' => array('info_link_id'),
);
2010-11-08 18:19:22 +01:00
/**
* constructor
* reads record from backend if identifier is given.
*
* @param string $_identifier
*/
public function __construct( $_identifier='' ){
$this->identifier = $_identifier;
if(self::$bo == null) self::$bo = new infolog_bo();
2010-11-08 18:19:22 +01:00
if($_identifier) {
$this->set_record(self::$bo->read($this->identifier));
2010-11-08 18:19:22 +01:00
}
}
/**
* magic method to set attributes of record
*
* @param string $_attribute_name
*/
public function __get($_attribute_name) {
return $this->record[$_attribute_name];
}
/**
* magig method to set attributes of record
*
* @param string $_attribute_name
* @param data $data
*/
public function __set($_attribute_name, $data) {
$this->record[$_attribute_name] = $data;
}
/**
* converts this object to array.
* @abstract We need such a function cause PHP5
* dosn't allow objects do define it's own casts :-(
* once PHP can deal with object casts we will change to them!
*
* @return array complete record as associative array
*/
public function get_record_array() {
return $this->record;
}
/**
* gets title of record
*
*@return string tiltle
*/
public function get_title() {
if (empty($this->record)) {
$this->get_record();
}
return self::$bo->link_title($this->record);
2010-11-08 18:19:22 +01:00
}
/**
* sets complete record from associative array
*
* @todo add some checks
* @return void
*/
public function set_record(array $_record){
$this->record = $_record;
}
/**
* gets identifier of this record
*
* @return string identifier of current record
*/
public function get_identifier() {
return $this->identifier;
}
/**
* saves record into backend
*
* @return string identifier
*/
public function save ( $_dst_identifier ) {
}
/**
* copys current record to record identified by $_dst_identifier
*
* @param string $_dst_identifier
* @return string dst_identifier
*/
public function copy ( $_dst_identifier ) {
}
/**
* moves current record to record identified by $_dst_identifier
* $this will become moved record
*
* @param string $_dst_identifier
* @return string dst_identifier
*/
public function move ( $_dst_identifier ) {
}
/**
* delets current record from backend
*
*/
public function delete () {
}
/**
* destructor
*
*/
public function __destruct() {
}
} // end of egw_addressbook_record
?>