X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=tasks.php;fp=tasks.php;h=7c5f0d46785cd13cd2c192c4edffd07819a3ff53;hb=d50da3563583a7c18e5dd76fd751cee19bf8bdaa;hp=561c1d9fb96e625fa441d67683af85836fd98745;hpb=2001b81dd9d0e90d86484fa09e6ddaebb5340c0a;p=contractor-progress.git diff --git a/tasks.php b/tasks.php index 561c1d9..7c5f0d4 100644 --- a/tasks.php +++ b/tasks.php @@ -88,12 +88,12 @@ function tasks_display_main() { $task_id = format_int($_REQUEST['tasks_id']);; $client_id = logged_in(); if(logged_in_as_contractor()) { - $row = db_get_row('tasks', 'title,url,description,state,price', 'where id=%i', $task_id); + $row = db_get_row('tasks', 'title,url,description,state,price,client_id', 'where id=%i', $task_id); } else { - $row = db_get_row('tasks', 'title,url,description,state,price', 'where id=%i && client_id=%i', $task_id, $client_id); + $row = db_get_row('tasks', 'title,url,description,state,price,client_id', 'where id=%i && client_id=%i', $task_id, $client_id); } if($row) { - list($title, $url, $description, $state, $price) = $row; + list($title, $url, $description, $state, $price, $owner_id) = $row; tem_set('task_id', $task_id); tem_set('title', $title); tem_set('url', $url); @@ -111,7 +111,10 @@ function tasks_display_main() { case TASK_NEEDS_CLARIFICATION: case TASK_NEEDS_QUOTE: case TASK_BUG: + tem_show('normal_edit_link'); + break; case TASK_NEEDS_GO_AHEAD: + tem_show('approve_price_link'); tem_show('normal_edit_link'); tem_show('price_row'); break; @@ -119,11 +122,16 @@ function tasks_display_main() { tem_show('normal_edit_link'); tem_show('working_link'); tem_show('price_row'); + break; case TASK_WORKING: tem_show('price_row'); tem_show('needs_testing_link'); break; case TASK_NEEDS_TESTING: + if($owner_id == logged_in()) { + tem_show('finished_link'); + } + # FALL THROUGH case TASK_FINISHED: tem_show('price_row'); tem_show('mark_paid_link'); # FIXME @@ -229,7 +237,7 @@ function tasks_edit_main() { message("Error: only Jason can say when he's done."); return './'; } - db_update('tasks', 'state', TASK_NEEDS_TESTING, 'where id=%i', $id); + db_update('tasks', 'state,finished_at', TASK_NEEDS_TESTING, date('Y-m-d'), 'where id=%i', $id); message('Task awaits testing.'); return './'; }