// +----------------------------------------------------------------------+
import('ttUserHelper');
+import('ttFileHelper');
// Class ttTimesheetHelper is used to help with project related tasks.
class ttTimesheetHelper {
$end_date = new DateAndTime($user->date_format, $fields['end_date']);
$end = $end_date->toString(DB_DATEFORMAT);
- $sql = "insert into tt_timesheets (user_id, group_id, org_id, client_id, project_id, name, comment, start_date, end_date)".
+ $created_part = ', now(), '.$mdb2->quote($_SERVER['REMOTE_ADDR']).', '.$user->id;
+
+ $sql = "insert into tt_timesheets (user_id, group_id, org_id, client_id, project_id, name, comment,".
+ " start_date, end_date, created, created_ip, created_by)".
" values ($user_id, $group_id, $org_id, ".$mdb2->quote($client_id).", ".$mdb2->quote($project_id).", ".$mdb2->quote($name).
- ", ".$mdb2->quote($comment).", ".$mdb2->quote($start).", ".$mdb2->quote($end).")";
+ ", ".$mdb2->quote($comment).", ".$mdb2->quote($start).", ".$mdb2->quote($end).$created_part.")";
$affected = $mdb2->exec($sql);
if (is_a($affected, 'PEAR_Error'))
return false;
$group_id = $user->getGroup();
$org_id = $user->org_id;
+ $includeFiles = $user->isPluginEnabled('at');
+ if ($includeFiles) {
+ $filePart = ', if(Sub1.entity_id is null, 0, 1) as has_files';
+ $fileJoin = " left join (select distinct entity_id from tt_files".
+ " where entity_type = 'timesheet' and group_id = $group_id and org_id = $org_id and status = 1) Sub1".
+ " on (ts.id = Sub1.entity_id)";
+ }
+
$result = array();
$sql = "select ts.id, ts.name, ts.client_id, c.name as client_name,".
- " ts.submit_status, ts.approve_status from tt_timesheets ts".
- " left join tt_clients c on (c.id = ts.client_id)".
+ " ts.submit_status, ts.approve_status $filePart from tt_timesheets ts".
+ " left join tt_clients c on (c.id = ts.client_id) $fileJoin".
" where ts.status = 1 and ts.group_id = $group_id and ts.org_id = $org_id and ts.user_id = $user_id".
" order by ts.name";
$res = $mdb2->query($sql);
$group_id = $user->getGroup();
$org_id = $user->org_id;
+ $includeFiles = $user->isPluginEnabled('at');
+ if ($includeFiles) {
+ $filePart = ', if(Sub1.entity_id is null, 0, 1) as has_files';
+ $fileJoin = " left join (select distinct entity_id from tt_files".
+ " where entity_type = 'timesheet' and group_id = $group_id and org_id = $org_id and status = 1) Sub1".
+ " on (ts.id = Sub1.entity_id)";
+ }
+
$result = array();
$sql = "select ts.id, ts.name, ts.client_id, c.name as client_name,".
- " ts.submit_status, ts.approve_status from tt_timesheets ts".
- " left join tt_clients c on (c.id = ts.client_id)".
+ " ts.submit_status, ts.approve_status $filePart from tt_timesheets ts".
+ " left join tt_clients c on (c.id = ts.client_id) $fileJoin".
" where ts.status = 0 and ts.group_id = $group_id and ts.org_id = $org_id and ts.user_id = $user_id".
" order by ts.name";
$res = $mdb2->query($sql);
global $user;
$mdb2 = getConnection();
+ // Delete associated files.
+ if ($user->isPluginEnabled('at')) {
+ import('ttFileHelper');
+ global $err;
+ $fileHelper = new ttFileHelper($err);
+ if (!$fileHelper->deleteEntityFiles($timesheet_id, 'timesheet'))
+ return false;
+ }
+
$user_id = $user->getUser();
$group_id = $user->getGroup();
$org_id = $user->org_id;
$affected = $mdb2->exec($sql);
if (is_a($affected, 'PEAR_Error')) return false;
+ $modified_part = ', modified = now(), modified_ip = '.$mdb2->quote($_SERVER['REMOTE_ADDR']).', modified_by = '.$user->id;
+
// Delete timesheet.
- $sql = "update tt_timesheets set status = null".
+ $sql = "update tt_timesheets set status = null".$modified_part.
" where id = $timesheet_id and user_id = $user_id and group_id = $group_id and org_id = $org_id";
$affected = $mdb2->exec($sql);
return (!is_a($affected, 'PEAR_Error'));
$comment = $fields['comment'];
$status = $fields['status']; // Timesheet status.
- $sql = "update tt_timesheets set name = ".$mdb2->quote($name).", comment = ".$mdb2->quote($comment).
+ $modified_part = ', modified = now(), modified_ip = '.$mdb2->quote($_SERVER['REMOTE_ADDR']).', modified_by = '.$user->id;
+
+ $sql = "update tt_timesheets set name = ".$mdb2->quote($name).
+ ", comment = ".$mdb2->quote($comment).$modified_part.
", status = ".$mdb2->quote($status).
" where id = $timesheet_id and user_id = $user_id and group_id = $group_id and org_id = $org_id";
$affected = $mdb2->exec($sql);
$group_id = $user->getGroup();
$org_id = $user->org_id;
+ $modified_part = ', modified = now(), modified_ip = '.$mdb2->quote($_SERVER['REMOTE_ADDR']).', modified_by = '.$user->id;
+
$timesheet_id = $fields['timesheet_id'];
- $sql = "update tt_timesheets set submit_status = 1".
+ $sql = "update tt_timesheets set submit_status = 1".$modified_part.
" where id = $timesheet_id and user_id = $user_id and group_id = $group_id and org_id = $org_id";
$affected = $mdb2->exec($sql);
return (!is_a($affected, 'PEAR_Error'));
$timesheet_id = $fields['timesheet_id'];
$comment = $fields['comment'];
- $sql = "update tt_timesheets set approve_status = 1, approve_comment = ".$mdb2->quote($comment).
+ $modified_part = ', modified = now(), modified_ip = '.$mdb2->quote($_SERVER['REMOTE_ADDR']).', modified_by = '.$user->id;
+
+ $sql = "update tt_timesheets set approve_status = 1, approve_comment = ".$mdb2->quote($comment).$modified_part.
" where id = $timesheet_id and submit_status = 1 and user_id = $user_id and group_id = $group_id and org_id = $org_id";
$affected = $mdb2->exec($sql);
return (!is_a($affected, 'PEAR_Error'));
$timesheet_id = $fields['timesheet_id'];
$comment = $fields['comment'];
- $sql = "update tt_timesheets set approve_status = 0, approve_comment = ".$mdb2->quote($comment).
+ $modified_part = ', modified = now(), modified_ip = '.$mdb2->quote($_SERVER['REMOTE_ADDR']).', modified_by = '.$user->id;
+
+ $sql = "update tt_timesheets set approve_status = 0, approve_comment = ".$mdb2->quote($comment).$modified_part.
" where id = $timesheet_id and submit_status = 1 and user_id = $user_id and group_id = $group_id and org_id = $org_id";
$affected = $mdb2->exec($sql);
return (!is_a($affected, 'PEAR_Error'));