From 12a7d6534fda05a55579f826368ff848fb0e756f Mon Sep 17 00:00:00 2001 From: Nathan Gray Date: Fri, 11 Feb 2011 18:36:27 +0000 Subject: [PATCH] Forgotten merge file --- timesheet/inc/class.timesheet_merge.inc.php | 188 ++++++++++++++++++++ 1 file changed, 188 insertions(+) create mode 100644 timesheet/inc/class.timesheet_merge.inc.php diff --git a/timesheet/inc/class.timesheet_merge.inc.php b/timesheet/inc/class.timesheet_merge.inc.php new file mode 100644 index 0000000000..95421d260b --- /dev/null +++ b/timesheet/inc/class.timesheet_merge.inc.php @@ -0,0 +1,188 @@ + + * @author Nathan Gray + * @package timesheet + * @copyright (c) 2007-9 by Ralf Becker + * @copyright 2011 Nathan Gray + * @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License + * @version $Id$ + */ + +/** + * Timesheet - document merge object + */ +class timesheet_merge extends bo_merge +{ + /** + * Functions that can be called via menuaction + * + * @var array + */ + var $public_functions = array( + 'show_replacements' => true, + 'timesheet_replacements' => true, + ); + + /** + * Business object to pull records from + */ + protected $bo = null; + + /** + * Constructor + * + */ + function __construct() + { + parent::__construct(); + $this->bo = new timesheet_bo(); + } + + /** + * Get replacements + * + * @param int $id id of entry + * @param string &$content=null content to create some replacements only if they are use + * @return array|boolean + */ + protected function get_replacements($id,&$content=null) + { + if (!($replacements = $this->timesheet_replacements($id))) + { + return false; + } + if (!(strpos($content,'$$ts_project/') === false)) + { + // Check to see if it's actually a project, then load + if($replacements['$$pm_id$$']) + { + if(!$this->pm) + { + $this->pm = new projectmanager_merge(); + } + $this->pm->projectmanager_bo = new projectmanager_bo($replacements['$$pm_id$$']); + $replacements += $this->pm->projectmanager_replacements($replacements['$$pm_id$$'],'ts_project'); + } + } + return $replacements; + } + + /** + * Get timesheet replacements + * + * @param int $id id of entry + * @param string $prefix='' prefix like eg. 'erole' + * @return array|boolean + */ + public function timesheet_replacements($id,$prefix='') + { + $record = new timesheet_egw_record($id); + $info = array(); + + // Get project manager ID + $links = solink::get_links('timesheet',$id,'projectmanager'); + if($links) + { + $record->pm_id = current($links); + } + + // Convert to human friendly values + $types = timesheet_export_csv::$types; + $_selects = array('status' => $this->bo->status_labels); + foreach($_selects as $name => $value) + { + $selects['ts_'.$name] = $value; + $types['select'][] = 'ts_'.$name; + } + importexport_export_csv::convert($record, $types, 'timesheet', $selects); + + // Set any missing custom fields, or the marker will stay + $array = $record->get_record_array(); + foreach($this->bo->customfields as $name => $field) + { + if(!$array['#'.$name]) $array['#'.$name] = ''; + } + + // Add markers + foreach($array as $key => &$value) + { + if(!$value) $value = ''; + $info['$$'.($prefix ? $prefix.'/':'').$key.'$$'] = $value; + } + return $info; + } + + /** + * Generate table with replacements for the preferences + * + */ + public function show_replacements() + { + $GLOBALS['egw_info']['flags']['app_header'] = lang('timesheet').' - '.lang('Replacements for inserting entries into documents'); + $GLOBALS['egw_info']['flags']['nonavbar'] = false; + common::egw_header(); + + echo "\n"; + echo '"; + + $n = 0; + $fields = array('ts_id' => lang('Timesheet ID')) + $this->bo->field2label; + foreach($fields as $name => $label) + { + if (in_array($name,array('pl_id','customfields'))) continue; // dont show them + + if (in_array($name,array('ts_title', 'ts_description')) && $n&1) // main values, which should be in the first column + { + echo "\n"; + $n++; + } + if (!($n&1)) echo ''; + echo ''; + if ($n&1) echo "\n"; + $n++; + } + + echo '"; + foreach($this->bo->customfields as $name => $field) + { + echo '\n"; + } + + echo ''; + $pm_merge = new projectmanager_merge(); + $n = 0; + foreach($pm_merge->projectmanager_fields as $name => $label) + { + if (!($n&1)) echo ''; + echo ''; + if ($n&1) echo "\n"; + $n++; + } + + echo '"; + foreach(array( + 'date' => lang('Date'), + 'user/n_fn' => lang('Name of current user, all other contact fields are valid too'), + 'user/account_lid' => lang('Username'), + 'pagerepeat' => lang('For serial letter use this tag. Put the content, you want to repeat between two Tags.'), + 'label' => lang('Use this tag for addresslabels. Put the content, you want to repeat, between two tags.'), + 'labelplacement' => lang('Tag to mark positions for address labels'), + 'IF fieldname' => lang('Example $$IF n_prefix~Mr~Hello Mr.~Hello Ms.$$ - search the field "n_prefix", for "Mr", if found, write Hello Mr., else write Hello Ms.'), + 'NELF' => lang('Example $$NELF role$$ - if field role is not empty, you will get a new line with the value of field role'), + 'NENVLF' => lang('Example $$NELFNV role$$ - if field role is not empty, set a LF without any value of the field'), + 'LETTERPREFIX' => lang('Example $$LETTERPREFIX$$ - Gives a letter prefix without double spaces, if the title is emty for example'), + 'LETTERPREFIXCUSTOM' => lang('Example $$LETTERPREFIXCUSTOM n_prefix title n_family$$ - Example: Mr Dr. James Miller'), + ) as $name => $label) + { + echo '\n"; + } + + echo "

'.lang('Timesheet fields:')."

$$'.$name.'$$'.$label.'

'.lang('Custom fields').":

$$#'.$name.'$$'.$field['label']."

'.lang('Project fields').':

$$ts_project/'.$name.'$$'.$label.'

'.lang('General fields:')."

$$'.$name.'$$'.$label."
\n"; + + common::egw_footer(); + } +}