Expansion of link_to custom fields

This commit is contained in:
Nathan Gray 2012-04-11 20:03:11 +00:00
parent 2bb445453e
commit 4feaa8375e
4 changed files with 24 additions and 8 deletions

View File

@ -48,6 +48,11 @@ class addressbook_merge extends bo_merge
{ {
return false; return false;
} }
if($content && strpos($content, '$$#') !== 0)
{
$this->cf_link_to_expand($this->contacts->read($id), $content, $replacements,'addressbook');
}
// Links // Links
$replacements += array( $replacements += array(
'$$links$$' => $this->get_links('addressbook', $id, '!'.egw_link::VFS_APPNAME), '$$links$$' => $this->get_links('addressbook', $id, '!'.egw_link::VFS_APPNAME),

View File

@ -104,13 +104,13 @@ class calendar_merge extends bo_merge
protected function get_replacements($id,&$content=null) protected function get_replacements($id,&$content=null)
{ {
$prefix = ''; $prefix = '';
// List events ? // List events ?
if(is_array($id) && !$id['id'] && !$id[0]['id']) if(is_array($id) && !$id['id'] && !$id[0]['id'])
{ {
$events = $this->bo->search($this->query + $id + array( $events = $this->bo->search($this->query + $id + array(
'offset' => 0, 'offset' => 0,
'order' => 'cal_start', 'order' => 'cal_start',
'cfs' => strpos($content, '#') !== false ? array_keys(config::get_customfields('calendar')) : null
)); ));
if(strpos($content,'$$calendar/') !== false || strpos($content, '$$table/day') !== false) if(strpos($content,'$$calendar/') !== false || strpos($content, '$$table/day') !== false)
{ {
@ -146,7 +146,7 @@ class calendar_merge extends bo_merge
$n = 0; $n = 0;
foreach($events as $event) foreach($events as $event)
{ {
$values = $this->calendar_replacements($event,sprintf($prefix,++$n)); $values = $this->calendar_replacements($event,sprintf($prefix,++$n), $content);
if(is_array($id) && $id['start']) if(is_array($id) && $id['start'])
{ {
foreach(self::$range_tags as $key => $format) foreach(self::$range_tags as $key => $format)
@ -168,7 +168,7 @@ class calendar_merge extends bo_merge
* @param boolean $last_event_too=false also include information about the last event * @param boolean $last_event_too=false also include information about the last event
* @return array * @return array
*/ */
public function calendar_replacements($id,$prefix = '') public function calendar_replacements($id,$prefix = '', &$content = '')
{ {
$replacements = array(); $replacements = array();
if(!is_array($id) || !$id['start']) { if(!is_array($id) || !$id['start']) {
@ -203,6 +203,11 @@ class calendar_merge extends bo_merge
$duration = ($event['end'] - $event['start'])/60; $duration = ($event['end'] - $event['start'])/60;
$replacements['$$'.($prefix?$prefix.'/':'').'calendar_duration$$'] = floor($duration/60).lang('h').($duration%60 ? $duration%60 : ''); $replacements['$$'.($prefix?$prefix.'/':'').'calendar_duration$$'] = floor($duration/60).lang('h').($duration%60 ? $duration%60 : '');
if($content && strpos($content, '$$#') !== 0)
{
$this->cf_link_to_expand($event, $content, $replacements);
}
$custom = config::get_customfields('calendar'); $custom = config::get_customfields('calendar');
foreach($custom as $name => $field) foreach($custom as $name => $field)
{ {

View File

@ -1121,7 +1121,7 @@ abstract class bo_merge
// Custom field placeholders look like {{#name}} // Custom field placeholders look like {{#name}}
// Placeholders that need expanded will look like {{#name/placeholder}} // Placeholders that need expanded will look like {{#name/placeholder}}
preg_match_all('/[${]{2}(([\w]+\/)*)#([\w]+)\/(.*?)[$}]{2}/', $content, $matches); preg_match_all('/\${2}(([^\/#]*?\/)?)#([^$\/]+)\/(.*?)[$}]{2}/', $content, $matches);
list($placeholders, $prefixes, $pre, $cf, $sub) = $matches; list($placeholders, $prefixes, $pre, $cf, $sub) = $matches;
foreach($cf as $index => $field) foreach($cf as $index => $field)

View File

@ -60,7 +60,7 @@ class timesheet_merge extends bo_merge
*/ */
protected function get_replacements($id,&$content=null) protected function get_replacements($id,&$content=null)
{ {
if (!($replacements = $this->timesheet_replacements($id))) if (!($replacements = $this->timesheet_replacements($id, '', $content)))
{ {
return false; return false;
} }
@ -87,7 +87,7 @@ class timesheet_merge extends bo_merge
* @param string $prefix='' prefix like eg. 'erole' * @param string $prefix='' prefix like eg. 'erole'
* @return array|boolean * @return array|boolean
*/ */
public function timesheet_replacements($id,$prefix='') public function timesheet_replacements($id,$prefix='', &$content = null)
{ {
$record = new timesheet_egw_record($id); $record = new timesheet_egw_record($id);
$info = array(); $info = array();
@ -110,6 +110,11 @@ class timesheet_merge extends bo_merge
{ {
$selects['ts_'.$name] = $value; $selects['ts_'.$name] = $value;
} }
if($content && strpos($content, '#') !== 0)
{
$this->cf_link_to_expand($record->get_record_array(), $content, $info);
}
importexport_export_csv::convert($record, $types, 'timesheet', $selects); importexport_export_csv::convert($record, $types, 'timesheet', $selects);
$array = $record->get_record_array(); $array = $record->get_record_array();
@ -118,6 +123,7 @@ class timesheet_merge extends bo_merge
{ {
$array[$key] = self::number_format($array[$key],2,$this->mimetype); $array[$key] = self::number_format($array[$key],2,$this->mimetype);
} }
// Set any missing custom fields, or the marker will stay // Set any missing custom fields, or the marker will stay
foreach($this->bo->customfields as $name => $field) foreach($this->bo->customfields as $name => $field)
{ {