X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/timetracker.git/blobdiff_plain/56f1fd19f2c9c72878395b3275f03f192ccca082..b5c16658c0a91c98bb4e41bb6c0e1cc254222a68:/WEB-INF/lib/ttGroupExportHelper.class.php diff --git a/WEB-INF/lib/ttGroupExportHelper.class.php b/WEB-INF/lib/ttGroupExportHelper.class.php index fecfba8a..e18f8c9f 100644 --- a/WEB-INF/lib/ttGroupExportHelper.class.php +++ b/WEB-INF/lib/ttGroupExportHelper.class.php @@ -40,13 +40,15 @@ class ttGroupExportHelper { // The following arrays are maps between entity ids in the file versus the database. // We write to the file sequentially (1,2,3...) while in the database the entities have different ids. - var $userMap = array(); // User ids. - var $roleMap = array(); // Role ids. - var $taskMap = array(); // Task ids. - var $projectMap = array(); // Project ids. - var $clientMap = array(); // Client ids. - var $invoiceMap = array(); // Invoice ids. - var $logMap = array(); // Time log ids. + var $userMap = array(); + var $roleMap = array(); + var $taskMap = array(); + var $projectMap = array(); + var $clientMap = array(); + var $invoiceMap = array(); + var $logMap = array(); + var $customFieldMap = array(); + var $customFieldOptionMap = array(); // Constructor. function __construct($group_id, $file, $indentation) { @@ -231,6 +233,16 @@ class ttGroupExportHelper { foreach ($invoices as $key=>$invoice_item) $this->invoiceMap[$invoice_item['id']] = $key + 1; + // Prepare custom fields map. + $custom_fields = ttTeamHelper::getAllCustomFields($this->group_id); + foreach ($custom_fields as $key=>$custom_field) + $this->customFieldMap[$custom_field['id']] = $key + 1; + + // Prepare custom field options map. + $custom_field_options = ttTeamHelper::getAllCustomFieldOptions($this->group_id); + foreach ($custom_field_options as $key=>$option) + $this->customFieldOptionMap[$option['id']] = $key + 1; + // Write roles. fwrite($this->file, $this->indentation." \n"); foreach ($roles as $role) { @@ -373,6 +385,66 @@ class ttGroupExportHelper { fwrite($this->file, $this->indentation." \n"); unset($records); + // Write custom fields. + fwrite($this->file, $this->indentation." \n"); + foreach ($custom_fields as $custom_field) { + $custom_field_part = $this->indentation.' '."customFieldMap[$custom_field['id']]."\""; + $custom_field_part .= " type=\"".$custom_field['type']."\""; + $custom_field_part .= " label=\"".htmlentities($custom_field['label'])."\""; + $custom_field_part .= " required=\"".$custom_field['required']."\""; + $custom_field_part .= " status=\"".$custom_field['status']."\""; + $custom_field_part .= ">\n"; + fwrite($this->file, $custom_field_part); + } + fwrite($this->file, $this->indentation." \n"); + unset($custom_fields); + + // Write custom field options. + fwrite($this->file, $this->indentation." \n"); + foreach ($custom_field_options as $option) { + $custom_field_option_part = $this->indentation.' '."customFieldOptionMap[$option['id']]."\""; + $custom_field_option_part .= " field_id=\"".$this->customFieldMap[$option['field_id']]."\""; + $custom_field_option_part .= " value=\"".htmlentities($option['value'])."\""; + $custom_field_option_part .= ">\n"; + fwrite($this->file, $custom_field_option_part); + } + fwrite($this->file, $this->indentation." \n"); + unset($custom_field_options); + + // Write custom field log. + $custom_field_log = ttTeamHelper::getCustomFieldLog($this->group_id); + fwrite($this->file, $this->indentation." \n"); + foreach ($custom_field_log as $entry) { + $custom_field_log_part = $this->indentation.' '."logMap[$entry['log_id']]."\""; + $custom_field_log_part .= " field_id=\"".$this->customFieldMap[$entry['field_id']]."\""; + $custom_field_log_part .= " option_id=\"".$this->customFieldOptionMap[$entry['option_id']]."\""; + $custom_field_log_part .= " value=\"".htmlentities($entry['value'])."\""; + $custom_field_log_part .= " status=\"".$entry['status']."\""; + $custom_field_log_part .= ">\n"; + fwrite($this->file, $custom_field_log_part); + } + fwrite($this->file, $this->indentation." \n"); + unset($custom_field_log); + + // Write expense items. + $expense_items = ttTeamHelper::getExpenseItems($this->group_id); + fwrite($this->file, $this->indentation." \n"); + foreach ($expense_items as $expense_item) { + $expense_item_part = $this->indentation.' '."userMap[$expense_item['user_id']]."\""; + $expense_item_part .= " client_id=\"".$this->clientMap[$expense_item['client_id']]."\""; + $expense_item_part .= " project_id=\"".$this->projectMap[$expense_item['project_id']]."\""; + $expense_item_part .= " name=\"".htmlentities($expense_item['name'])."\""; + $expense_item_part .= " cost=\"".$expense_item['cost']."\""; + $expense_item_part .= " invoice_id=\"".$this->invoiceMap[$expense_item['invoice_id']]."\""; + $expense_item_part .= " paid=\"".$expense_item['paid']."\""; + $expense_item_part .= " status=\"".$expense_item['status']."\""; + $expense_item_part .= ">\n"; + fwrite($this->file, $expense_item_part); + } + fwrite($this->file, $this->indentation." \n"); + unset($expense_items); + // Call self recursively for all subgroups. foreach ($this->subgroups as $subgroup) { $subgroup_helper = new ttGroupExportHelper($subgroup['id'], $this->file, $this->indentation.' ');