X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/timetracker.git/blobdiff_plain/db9bfb69eeab1f5c75f65373c370990445014305..ee49ee74b2a7d3c6daaa2d4bc6397b0c89e3099b:/mobile/project_edit.php diff --git a/mobile/project_edit.php b/mobile/project_edit.php new file mode 100644 index 00000000..c1eb1804 --- /dev/null +++ b/mobile/project_edit.php @@ -0,0 +1,133 @@ +getParameter('id'); + +$users = ttTeamHelper::getActiveUsers(); +foreach ($users as $user_item) + $all_users[$user_item['id']] = $user_item['name']; + +$tasks = ttTeamHelper::getActiveTasks($user->team_id); +foreach ($tasks as $task_item) + $all_tasks[$task_item['id']] = $task_item['name']; + +if ($request->isPost()) { + $cl_name = trim($request->getParameter('project_name')); + $cl_description = trim($request->getParameter('description')); + $cl_status = $request->getParameter('status'); + $cl_users = $request->getParameter('users', array()); + $cl_tasks = $request->getParameter('tasks', array()); +} else { + $project = ttProjectHelper::get($cl_project_id); + $cl_name = $project['name']; + $cl_description = $project['description']; + $cl_status = $project['status']; + + $mdb2 = getConnection(); + $sql = "select user_id from tt_user_project_binds where status = 1 and project_id = $cl_project_id"; + $res = $mdb2->query($sql); + if (is_a($res, 'PEAR_Error')) + die($res->getMessage()); + while ($row = $res->fetchRow()) + $cl_users[] = $row['user_id']; + + $cl_tasks = explode(',', $project['tasks']); +} + +$form = new Form('projectForm'); +$form->addInput(array('type'=>'hidden','name'=>'id','value'=>$cl_project_id)); +$form->addInput(array('type'=>'text','maxlength'=>'100','name'=>'project_name','value'=>$cl_name)); +$form->addInput(array('type'=>'textarea','name'=>'description','class'=>'mobile-textarea','value'=>$cl_description)); +$form->addInput(array('type'=>'combobox','name'=>'status','value'=>$cl_status, + 'data'=>array(ACTIVE=>$i18n->getKey('dropdown.status_active'),INACTIVE=>$i18n->getKey('dropdown.status_inactive')))); +$form->addInput(array('type'=>'checkboxgroup','name'=>'users','data'=>$all_users,'layout'=>'H','value'=>$cl_users)); +if (MODE_PROJECTS_AND_TASKS == $user->tracking_mode) + $form->addInput(array('type'=>'checkboxgroup','name'=>'tasks','data'=>$all_tasks,'layout'=>'H','value'=>$cl_tasks)); +$form->addInput(array('type'=>'submit','name'=>'btn_save','value'=>$i18n->getKey('button.save'))); +$form->addInput(array('type'=>'submit','name'=>'btn_copy','value'=>$i18n->getKey('button.copy'))); + +if ($request->isPost()) { + // Validate user input. + if (!ttValidString($cl_name)) $err->add($i18n->getKey('error.field'), $i18n->getKey('label.thing_name')); + if (!ttValidString($cl_description, true)) $err->add($i18n->getKey('error.field'), $i18n->getKey('label.description')); + + if ($err->no()) { + if ($request->getParameter('btn_save')) { + $existing_project = ttProjectHelper::getProjectByName($cl_name); + if (!$existing_project || ($cl_project_id == $existing_project['id'])) { + // Update project information. + if (ttProjectHelper::update(array( + 'id' => $cl_project_id, + 'name' => $cl_name, + 'description' => $cl_description, + 'status' => $cl_status, + 'users' => $cl_users, + 'tasks' => $cl_tasks))) { + header('Location: projects.php'); + exit(); + } else + $err->add($i18n->getKey('error.db')); + } else + $err->add($i18n->getKey('error.project_exists')); + } + + if ($request->getParameter('btn_copy')) { + if (!ttProjectHelper::getProjectByName($cl_name)) { + if (ttProjectHelper::insert(array( + 'team_id' => $user->team_id, + 'name' => $cl_name, + 'description' => $cl_description, + 'users' => $cl_users, + 'tasks' => $cl_tasks, + 'status' => ACTIVE))) { + header('Location: projects.php'); + exit(); + } else + $err->add($i18n->getKey('error.db')); + } else + $err->add($i18n->getKey('error.project_exists')); + } + } +} // isPost + +$smarty->assign('forms', array($form->getName()=>$form->toArray())); +$smarty->assign('onload', 'onLoad="document.projectForm.project_name.focus()"'); +$smarty->assign('title', $i18n->getKey('title.edit_project')); +$smarty->assign('content_page_name', 'mobile/project_edit.tpl'); +$smarty->display('mobile/index.tpl');