* Copyright (C) 2006-2009 Laurent Destailleur * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ /** * \file htdocs/projet/tasks/task.php * \ingroup projet * \brief Fiche t�ches d'un projet * \version $Id$ */ require("./pre.inc.php"); require_once(DOL_DOCUMENT_ROOT."/lib/project.lib.php"); if (!$user->rights->projet->lire) accessforbidden(); /* * Actions */ if ($_POST["action"] == 'confirm_delete' && $_POST["confirm"] == "yes" && $user->rights->projet->creer) { $task = new Task($db); if ($task->fetch($_GET["id"]) >= 0 ) { $projet = new Project($db); $result=$projet->fetch($task->fk_projet); if (! empty($projet->socid)) { $projet->societe->fetch($projet->socid); } if ($task->delete($user) > 0) { Header("Location: index.php"); exit; } else { $langs->load("errors"); $mesg='
'.$langs->trans($task->error).'
'; $_POST["action"]=''; } } } /* * View */ llxHeader("",$langs->trans("Task")); $html = new Form($db); $projectstatic = new Project($db); if ($_GET["id"] > 0) { /* * Fiche projet en mode visu * */ $task = new Task($db); if ($task->fetch($_GET["id"]) >= 0 ) { $projet = new Project($db); $result=$projet->fetch($task->fk_projet); if (! empty($projet->socid)) $projet->societe->fetch($projet->socid); $head=task_prepare_head($task); dol_fiche_head($head, 'tasks', $langs->trans("Task")); if ($mesg) print $mesg.'
'; if ($_GET["action"] == 'delete') { $ret=$html->form_confirm($_SERVER["PHP_SELF"]."?id=".$_GET["id"],$langs->trans("DeleteATask"),$langs->trans("ConfirmDeleteATask"),"confirm_delete"); if ($ret == 'html') print '
'; } print '
'; print ''; print ''; print ''; print ''; print ''; print ''; print ''; /* List of time spent */ $sql = "SELECT t.task_date, t.task_duration, t.fk_user, u.login, u.rowid"; $sql .= " FROM ".MAIN_DB_PREFIX."projet_task_time as t"; $sql .= " , ".MAIN_DB_PREFIX."user as u"; $sql .= " WHERE t.fk_task =".$task->id; $sql .= " AND t.fk_user = u.rowid"; $sql .= " ORDER BY t.task_date DESC"; $var=true; $resql = $db->query($sql); if ($resql) { $num = $db->num_rows($resql); $i = 0; $tasks = array(); while ($i < $num) { $row = $db->fetch_object($resql); $tasks[$i] = $row; $i++; } $db->free($resql); } else { dol_print_error($db); } print '
'.$langs->trans("Ref").''.$task->id.'
'.$langs->trans("Label").''.$task->title.'
'.$langs->trans("Project").''; print $projet->getNomUrl(1); print '
'.$langs->trans("Company").''; if ($projet->societe->id) print $projet->societe->getNomUrl(1); else print ' '; print '
'; print ''; /* * Actions */ print '
'; if ($user->rights->projet->creer) { print ''.$langs->trans('Delete').''; } print '
'; print '
'; print ''; print ''; print ''; print ''; print ''; print ''; print "\n"; foreach ($tasks as $task_time) { $var=!$var; print ""; // Date print ''; // Time spent $heure = intval($task_time->task_duration); $minutes = round((($task_time->task_duration - $heure) * 60),0); $minutes = substr("00"."$minutes", -2); print '\n"; // User $user->id=$task_time->rowid; $user->nom=$task_time->login; print ''; print "\n"; } print "
'.$langs->trans("Date").''.$langs->trans("TimeSpent").''.$langs->trans("By").'
'.dol_print_date($db->jdate($task_time->task_date),'day').' '.dol_print_date($db->jdate($task_time->task_date),'%A').''.$heure." h ".$minutes."'.$user->getNomUrl(1).'
"; } } $db->close(); llxFooter('$Date$ - $Revision$'); ?>