+ // Save as new record.
+ if ($request->getParameter('btn_copy')) {
+ // We need to:
+ // 1) Prohibit saving into locked range.
+ // 2) Prohibit saving uncompleted unlocked entries when another uncompleted entry exists.
+
+ // Now, step by step.
+ if ($err->no()) {
+ // 1) Prohibit saving into locked range.
+ if ($user->isDateLocked($new_date))
+ $err->add($i18n->get('error.range_locked'));
+
+ // 2) Prohibit saving uncompleted unlocked entries when another uncompleted entry exists.
+ $uncompleted = ($cl_finish == '' && $cl_duration == '');
+ if ($uncompleted) {
+ $not_completed_rec = ttTimeHelper::getUncompleted($user_id);
+ if ($not_completed_rec) {
+ // We have another not completed record.
+ $err->add($i18n->get('error.uncompleted_exists')." <a href = 'time_edit.php?id=".$not_completed_rec['id']."'>".$i18n->get('error.goto_uncompleted')."</a>");
+ }
+ }
+ }
+
+ // Prohibit creating an overlapping record.
+ if ($err->no()) {
+ if (ttTimeHelper::overlaps($user_id, $new_date->toString(DB_DATEFORMAT), $cl_start, $cl_finish))
+ $err->add($i18n->get('error.overlap'));
+ }
+
+ // Now, a new insert.
+ if ($err->no()) {
+
+ $id = ttTimeHelper::insert(array(
+ 'date'=>$new_date->toString(DB_DATEFORMAT),
+ 'user_id'=>$user_id,
+ 'group_id'=>$user->getGroup(),
+ 'org_id' => $user->org_id,
+ 'client'=>$cl_client,
+ 'project'=>$cl_project,
+ 'task'=>$cl_task,
+ 'start'=>$cl_start,
+ 'finish'=>$cl_finish,
+ 'duration'=>$cl_duration,
+ 'note'=>$cl_note,
+ 'billable'=>$cl_billable,
+ 'paid'=>$cl_paid));
+
+ // Insert a custom field if we have it.
+ $res = true;
+ if ($id && $custom_fields && $cl_cf_1) {
+ if ($custom_fields->fields[0]['type'] == CustomFields::TYPE_TEXT)
+ $res = $custom_fields->insert($id, $custom_fields->fields[0]['id'], null, $cl_cf_1);
+ elseif ($custom_fields->fields[0]['type'] == CustomFields::TYPE_DROPDOWN)
+ $res = $custom_fields->insert($id, $custom_fields->fields[0]['id'], $cl_cf_1, null);
+ }
+ if ($id && $res) {
+ header('Location: time.php?date='.$new_date->toString(DB_DATEFORMAT));
+ exit();
+ }
+ $err->add($i18n->get('error.db'));
+ }
+ }
+