X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=WEB-INF%2Flib%2FttGroupExportHelper.class.php;h=8a7b7e7706632a4fe39e2f199d77c6836f012ea5;hb=ed41335d63e71a11d30e92f4367106e9398adf9d;hp=59bdc8c8d5e2092adc04ceff0e6896a06a657102;hpb=179facbe37379829ddffc9ee2e29ca6c3d969ce8;p=timetracker.git diff --git a/WEB-INF/lib/ttGroupExportHelper.class.php b/WEB-INF/lib/ttGroupExportHelper.class.php index 59bdc8c8..8a7b7e77 100644 --- a/WEB-INF/lib/ttGroupExportHelper.class.php +++ b/WEB-INF/lib/ttGroupExportHelper.class.php @@ -123,7 +123,8 @@ class ttGroupExportHelper { // Write group info. $group = $this->getGroupAttrs(); - $group_part = "taskMap[$record['task_id']]."\""; $log_part .= " timesheet_id=\"".$this->timesheetMap[$record['timesheet_id']]."\""; $log_part .= " invoice_id=\"".$this->invoiceMap[$record['invoice_id']]."\""; - $log_part .= " comment=\"".htmlspecialchars($record['comment'])."\""; + $log_part .= " comment=\"".$this->encodeLineBreaks($record['comment'])."\""; $log_part .= " billable=\"".$record['billable']."\""; $log_part .= " approved=\"".$record['approved']."\""; $log_part .= " paid=\"".$record['paid']."\""; @@ -459,8 +460,7 @@ class ttGroupExportHelper { $expense_item_part .= " user_id=\"".$this->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 .= " timesheet_id=\"".$this->timesheetMap[$expense_item['timesheet_id']]."\""; - $expense_item_part .= " name=\"".htmlspecialchars($expense_item['name'])."\""; + $expense_item_part .= " name=\"".$this->encodeLineBreaks($expense_item['name'])."\""; $expense_item_part .= " cost=\"".$expense_item['cost']."\""; $expense_item_part .= " invoice_id=\"".$this->invoiceMap[$expense_item['invoice_id']]."\""; $expense_item_part .= " approved=\"".$expense_item['approved']."\""; @@ -489,6 +489,23 @@ class ttGroupExportHelper { unset($predefined_expense_part); } + // Write templates. + $templates = $this->getRecordsFromTable('tt_templates'); + if (count($templates) > 0) { + fwrite($this->file, $this->indentation." \n"); + foreach ($templates as $template) { + $template_part = $this->indentation.' '."\n"; + fwrite($this->file, $template_part); + } + fwrite($this->file, $this->indentation." \n"); + unset($templates); + unset($template_part); + } + // Write monthly quotas. $quotas = ttTeamHelper::getMonthlyQuotas($this->group_id); if (count($quotas) > 0) { @@ -618,4 +635,18 @@ class ttGroupExportHelper { fwrite($this->file, $this->indentation."\n"); } + + // encodeLineBreaks encodes line breaks with an escape sequence. + // We do this, because our strings are attribute values inside XML tags. + // + // If we don't, we lose line breaks after importing data because + // XML parser converts line breaks into a single white character. + // + // TODO: investigate whether we need to encode \t, etc. + private function encodeLineBreaks($source) { + $result = htmlspecialchars($source); + $result = str_replace ("\n", ' ', $result); + $result = str_replace ("\r", ' ', $result); + return $result; + } }