2014-09-30 23:37:45 +02:00
|
|
|
<?php
|
|
|
|
/**
|
2016-03-19 14:06:07 +01:00
|
|
|
* EGroupware eTemplate - Entry Widget
|
2014-09-30 23:37:45 +02:00
|
|
|
*
|
|
|
|
* This is the server side for a widget that loads a particular entry from an
|
|
|
|
* application, and displays the value of a particular field
|
|
|
|
*
|
|
|
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
2016-03-19 14:06:07 +01:00
|
|
|
* @package api
|
|
|
|
* @subpackage etemplate
|
2014-09-30 23:37:45 +02:00
|
|
|
* @link http://www.egroupware.org
|
|
|
|
* @author Ralf Becker <RalfBecker@outdoor-training.de>
|
2016-03-22 10:10:08 +01:00
|
|
|
* @version $Id$
|
2014-09-30 23:37:45 +02:00
|
|
|
*/
|
|
|
|
|
2016-03-19 14:06:07 +01:00
|
|
|
namespace EGroupware\Api\Etemplate\Widget;
|
|
|
|
|
2014-09-30 23:37:45 +02:00
|
|
|
/**
|
2016-03-19 14:06:07 +01:00
|
|
|
* eTemplate Entry widget
|
2014-09-30 23:37:45 +02:00
|
|
|
*
|
|
|
|
* This widget can be used to fetch fields of any entry specified by its ID.
|
|
|
|
* The entry is loaded once and shared amoung widget that need it.
|
|
|
|
*/
|
2016-03-19 14:06:07 +01:00
|
|
|
abstract class Entry extends Transformer
|
2014-09-30 23:37:45 +02:00
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var $prefix string Prefix for the ID to avoid conflicts between the
|
|
|
|
* record and the original value
|
|
|
|
*/
|
|
|
|
const ID_PREFIX = '~';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* (Array of) comma-separated list of legacy options to automatically replace when parsing with set_attrs
|
|
|
|
*
|
|
|
|
* @var string|array
|
|
|
|
*/
|
|
|
|
protected $legacy_options = 'field';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Array with a transformation description, based on attributes to modify.
|
|
|
|
*
|
2016-03-19 14:06:07 +01:00
|
|
|
* @see Transformer::$transformation
|
2014-09-30 23:37:45 +02:00
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected static $transformation = array(
|
|
|
|
'type' => array(
|
|
|
|
'entry-fields' => array( // List of fields
|
|
|
|
'sel_options' => array('__callback__' => 'get_field_list'),
|
|
|
|
'type' => 'select',
|
|
|
|
'no_lang' => true,
|
|
|
|
'options' => 'None',
|
|
|
|
),
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Load entry
|
|
|
|
*
|
|
|
|
* @param string $cname
|
|
|
|
*/
|
2015-01-14 21:10:34 +01:00
|
|
|
public function beforeSendToClient($cname, array $expand=array())
|
2014-09-30 23:37:45 +02:00
|
|
|
{
|
|
|
|
$attrs = $this->attrs;
|
|
|
|
|
|
|
|
$attrs['type'] = $this->type;
|
|
|
|
$attrs['id'] = $this->id;
|
2016-03-19 14:06:07 +01:00
|
|
|
|
2014-09-30 23:37:45 +02:00
|
|
|
$form_name = self::form_name($cname, $this->id);
|
2014-10-01 19:29:22 +02:00
|
|
|
$data_id = $attrs['value'] ? self::form_name($cname, $attrs['value']) : self::form_name($cname, self::ID_PREFIX . $this->id);
|
2014-12-10 01:07:23 +01:00
|
|
|
|
2014-10-01 00:08:57 +02:00
|
|
|
// No need to proceed
|
2014-10-01 19:29:22 +02:00
|
|
|
if(!$data_id) return;
|
2014-10-01 00:08:57 +02:00
|
|
|
|
2014-09-30 23:37:45 +02:00
|
|
|
// Find out which record to load
|
|
|
|
$value = self::get_array(self::$request->content, $form_name, false, true);
|
2014-12-10 01:07:23 +01:00
|
|
|
if(!$value)
|
2014-09-30 23:37:45 +02:00
|
|
|
{
|
2014-12-10 01:07:23 +01:00
|
|
|
// Try here... legacy / fallback / just make it work
|
|
|
|
$value = self::get_array(self::$request->content, $data_id, true, false);
|
|
|
|
$data = static::get_entry($value, $attrs);
|
2014-09-30 23:37:45 +02:00
|
|
|
}
|
2014-12-10 01:07:23 +01:00
|
|
|
else
|
|
|
|
{
|
|
|
|
// Get the record itself
|
|
|
|
$data = self::get_array(self::$request->content, $data_id, true, false);
|
|
|
|
if(!$data)
|
|
|
|
{
|
|
|
|
$data = static::get_entry($value, $attrs);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set the new value so transformer can find it. Use prefix to avoid changing the original value
|
|
|
|
$new_value =& self::get_array(self::$request->content, self::ID_PREFIX .$this->id, true, false);
|
2016-03-19 14:06:07 +01:00
|
|
|
if (true) $new_value = $data;
|
2014-09-30 23:37:45 +02:00
|
|
|
$this->id = self::ID_PREFIX . $this->id . "[{$attrs['field']}]";
|
|
|
|
|
|
|
|
$old_type = self::getElementAttribute($this->id, 'type');
|
|
|
|
|
2015-01-14 21:10:34 +01:00
|
|
|
parent::beforeSendToClient($cname, $expand);
|
2014-09-30 23:37:45 +02:00
|
|
|
|
|
|
|
// Check for conflict - more than one with same id/field and different type
|
|
|
|
if($old_type && $old_type != $this->type)
|
|
|
|
{
|
2014-10-01 19:29:22 +02:00
|
|
|
//self::set_validation_error($this->id, lang('%1, duplicate ID', $this));
|
2014-09-30 23:37:45 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get entry data
|
|
|
|
*
|
|
|
|
* @param int|string|array $value
|
|
|
|
* @param array $attrs
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
abstract function get_entry($value, array $attrs);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a list of fields available for display
|
|
|
|
*
|
|
|
|
* @return Array
|
|
|
|
*/
|
|
|
|
protected static function get_field_list()
|
|
|
|
{
|
|
|
|
return array();
|
|
|
|
}
|
|
|
|
}
|