var $projectMap = array(); // Project ids.
var $clientMap = array(); // Client ids.
var $invoiceMap = array(); // Invoice ids.
+ var $logMap = array(); // Time log ids.
// Constructor.
function __construct($group_id, $file, $indentation) {
}
fwrite($this->file, $this->indentation." </invoices>\n");
+ // Write time log entries and build logMap at the same time.
+ fwrite($this->file, $this->indentation." <log>\n");
+ $key = 0;
+ foreach ($users as $user_item) {
+ $records = ttTimeHelper::getAllRecords($user_item['id']);
+ foreach ($records as $record) {
+ $key++;
+ $this->logMap[$record['id']] = $key;
+ $log_part = $this->indentation.' '."<log_item id=\"$key\"";
+ $log_part .= " user_id=\"".$this->userMap[$record['user_id']]."\"";
+ $log_part .= " date=\"".$record['date']."\"";
+ $log_part .= " start=\"".$record['start']."\"";
+ $log_part .= " finish=\"".$record['finish']."\"";
+ $log_part .= " duration=\"".($record['start']?"":$record['duration'])."\"";
+ $log_part .= " client_id=\"".$this->clientMap[$record['client_id']]."\"";
+ $log_part .= " project_id=\"".$this->projectMap[$record['project_id']]."\"";
+ $log_part .= " task_id=\"".$this->taskMap[$record['task_id']]."\"";
+ $log_part .= " invoice_id=\"".$this->invoiceMap[$record['invoice_id']]."\"";
+ $log_part .= " comment=\"".htmlentities($record['comment'])."\"";
+ $log_part .= " billable=\"".$record['billable']."\"";
+ $log_part .= " paid=\"".$record['paid']."\"";
+ $log_part .= " status=\"".$record['status']."\"";
+ $log_part .= "></log_item>\n";
+ fwrite($this->file, $log_part);
+ }
+ }
+ fwrite($this->file, $this->indentation." </log>\n");
+ unset($records);
+
// Call self recursively for all subgroups.
foreach ($this->subgroups as $subgroup) {
$subgroup_helper = new ttGroupExportHelper($subgroup['id'], $this->file, $this->indentation.' ');