isPluginEnabled('ts')) { header('Location: feature_disabled.php'); exit(); } $cl_timesheet_id = (int)$request->getParameter('id'); $timesheet = ttTimesheetHelper::getTimesheet($cl_timesheet_id); if (!$timesheet) { header('Location: access_denied.php'); exit(); } // End of access checks. if ($request->isPost()) { $cl_description = trim($request->getParameter('description')); } $fileHelper = new ttFileHelper($err); $files = $fileHelper::getEntityFiles($cl_timesheet_id, 'timesheet'); $form = new Form('fileUploadForm'); $form->addInput(array('type'=>'hidden','name'=>'id','value'=>$cl_timesheet_id)); $form->addInput(array('type'=>'upload','name'=>'newfile','value'=>$i18n->get('button.submit'))); $form->addInput(array('type'=>'textarea','name'=>'description','style'=>'width: 250px; height: 40px;','value'=>$cl_description)); $form->addInput(array('type'=>'submit','name'=>'btn_submit','value'=>$i18n->get('button.add'))); if ($request->isPost()) { // We are adding a new file. // Validate user input. if (!$_FILES['newfile']['name']) $err->add($i18n->get('error.upload')); if (!ttValidString($cl_description, true)) $err->add($i18n->get('error.field'), $i18n->get('label.description')); // Finished validating user input. if ($err->no()) { $fields = array('entity_type'=>'timesheet', 'entity_id' => $cl_timesheet_id, 'file_name' => $_FILES['newfile']['name'], 'description'=>$cl_description); if ($fileHelper->putFile($fields)) { header('Location: timesheet_files.php?id='.$cl_timesheet_id); exit(); } } } // isPost $smarty->assign('can_edit', true); // Relying on access checks above. $smarty->assign('forms', array($form->getName()=>$form->toArray())); $smarty->assign('files', $files); $smarty->assign('title', $i18n->get('title.timesheet_files').': '.$timesheet['name']); $smarty->assign('content_page_name', 'entity_files.tpl'); $smarty->display('index.tpl');