forked from Wavyzz/dolibarr
Fix: Bug #362 and clean code
This commit is contained in:
@@ -1,7 +1,7 @@
|
|||||||
<?php
|
<?php
|
||||||
/* Copyright (C) 2005 Rodolphe Quiedeville <rodolphe@quiedeville.org>
|
/* Copyright (C) 2005 Rodolphe Quiedeville <rodolphe@quiedeville.org>
|
||||||
* Copyright (C) 2006-2010 Laurent Destailleur <eldy@users.sourceforge.net>
|
* Copyright (C) 2006-2010 Laurent Destailleur <eldy@users.sourceforge.net>
|
||||||
* Copyright (C) 2010 Regis Houssin <regis@dolibarr.fr>
|
* Copyright (C) 2010-2012 Regis Houssin <regis@dolibarr.fr>
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
@@ -33,17 +33,21 @@ require_once(DOL_DOCUMENT_ROOT.'/core/class/html.formcompany.class.php');
|
|||||||
$langs->load("projects");
|
$langs->load("projects");
|
||||||
$langs->load("companies");
|
$langs->load("companies");
|
||||||
|
|
||||||
$taskid = isset($_GET["id"])?$_GET["id"]:'';
|
$id=GETPOST('id','int');
|
||||||
$id = GETPOST('id','int');
|
$ref=GETPOST('ref','alpha');
|
||||||
$ref= GETPOST('ref');
|
$action=GETPOST('action','alpha');
|
||||||
$action=GETPOST('action');
|
$confirm=GETPOST('confirm','alpha');
|
||||||
$withproject=GETPOST('withproject');
|
$withproject=GETPOST('withproject','int');
|
||||||
|
$project_ref=GETPOST('project_ref','alpha');
|
||||||
|
|
||||||
// Security check
|
// Security check
|
||||||
$socid=0;
|
$socid=0;
|
||||||
if ($user->societe_id > 0) $socid = $user->societe_id;
|
if ($user->societe_id > 0) $socid = $user->societe_id;
|
||||||
//$result = restrictedArea($user, 'projet', $taskid, 'projet_task');
|
//$result = restrictedArea($user, 'projet', $id, 'projet_task');
|
||||||
if (!$user->rights->projet->lire) accessforbidden();
|
if (! $user->rights->projet->lire) accessforbidden();
|
||||||
|
|
||||||
|
$object = new Task($db);
|
||||||
|
$projectstatic = new Project($db);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -53,31 +57,28 @@ if (!$user->rights->projet->lire) accessforbidden();
|
|||||||
// Add new contact
|
// Add new contact
|
||||||
if ($action == 'addcontact' && $user->rights->projet->creer)
|
if ($action == 'addcontact' && $user->rights->projet->creer)
|
||||||
{
|
{
|
||||||
|
$result = $object->fetch($id);
|
||||||
|
|
||||||
$result = 0;
|
if ($result > 0 && $id > 0)
|
||||||
$task = new Task($db);
|
|
||||||
$result = $task->fetch($taskid);
|
|
||||||
|
|
||||||
if ($result > 0 && $taskid > 0)
|
|
||||||
{
|
{
|
||||||
$result = $task->add_contact($_POST["contactid"], $_POST["type"], $_POST["source"]);
|
$result = $object->add_contact($_POST["contactid"], $_POST["type"], $_POST["source"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($result >= 0)
|
if ($result >= 0)
|
||||||
{
|
{
|
||||||
Header("Location: contact.php?id=".$task->id);
|
Header("Location: ".$_SERVER["PHP_SELF"]."?id=".$object->id);
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if ($task->error == 'DB_ERROR_RECORD_ALREADY_EXISTS')
|
if ($object->error == 'DB_ERROR_RECORD_ALREADY_EXISTS')
|
||||||
{
|
{
|
||||||
$langs->load("errors");
|
$langs->load("errors");
|
||||||
$mesg = '<div class="error">'.$langs->trans("ErrorThisContactIsAlreadyDefinedAsThisType").'</div>';
|
$mesg = '<div class="error">'.$langs->trans("ErrorThisContactIsAlreadyDefinedAsThisType").'</div>';
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$mesg = '<div class="error">'.$task->error.'</div>';
|
$mesg = '<div class="error">'.$object->error.'</div>';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -85,10 +86,9 @@ if ($action == 'addcontact' && $user->rights->projet->creer)
|
|||||||
// bascule du statut d'un contact
|
// bascule du statut d'un contact
|
||||||
if ($action == 'swapstatut' && $user->rights->projet->creer)
|
if ($action == 'swapstatut' && $user->rights->projet->creer)
|
||||||
{
|
{
|
||||||
$task = new Task($db);
|
if ($object->fetch($id))
|
||||||
if ($task->fetch($taskid))
|
|
||||||
{
|
{
|
||||||
$result=$task->swapContactStatus(GETPOST('ligne'));
|
$result=$object->swapContactStatus(GETPOST('ligne'));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -99,13 +99,12 @@ if ($action == 'swapstatut' && $user->rights->projet->creer)
|
|||||||
// Efface un contact
|
// Efface un contact
|
||||||
if ($action == 'deleteline' && $user->rights->projet->creer)
|
if ($action == 'deleteline' && $user->rights->projet->creer)
|
||||||
{
|
{
|
||||||
$task = new Task($db);
|
$object->fetch($id);
|
||||||
$task->fetch($taskid);
|
$result = $object->delete_contact($_GET["lineid"]);
|
||||||
$result = $task->delete_contact($_GET["lineid"]);
|
|
||||||
|
|
||||||
if ($result >= 0)
|
if ($result >= 0)
|
||||||
{
|
{
|
||||||
Header("Location: contact.php?id=".$task->id);
|
Header("Location: ".$_SERVER["PHP_SELF"]."?id=".$object->id);
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -114,6 +113,22 @@ if ($action == 'deleteline' && $user->rights->projet->creer)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Retreive First Task ID of Project if withprojet is on to allow project prev next to work
|
||||||
|
if (! empty($project_ref) && ! empty($withproject))
|
||||||
|
{
|
||||||
|
if ($projectstatic->fetch(0,$project_ref) > 0)
|
||||||
|
{
|
||||||
|
$tasksarray=$object->getTasksArray(0, 0, $projectstatic->id, $socid, 0);
|
||||||
|
if (count($tasksarray) > 0)
|
||||||
|
{
|
||||||
|
$id=$tasksarray[0]->id;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Header("Location: ".DOL_URL_ROOT.'/projet/tasks.php?id='.$projectstatic->id.(empty($mode)?'':'&mode='.$mode));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* View
|
* View
|
||||||
@@ -125,8 +140,6 @@ $form = new Form($db);
|
|||||||
$formcompany = new FormCompany($db);
|
$formcompany = new FormCompany($db);
|
||||||
$contactstatic = new Contact($db);
|
$contactstatic = new Contact($db);
|
||||||
$userstatic = new User($db);
|
$userstatic = new User($db);
|
||||||
$project = new Project($db);
|
|
||||||
$task = new Task($db);
|
|
||||||
|
|
||||||
|
|
||||||
/* *************************************************************************** */
|
/* *************************************************************************** */
|
||||||
@@ -137,19 +150,19 @@ $task = new Task($db);
|
|||||||
|
|
||||||
if ($id > 0 || ! empty($ref))
|
if ($id > 0 || ! empty($ref))
|
||||||
{
|
{
|
||||||
if ($task->fetch($id,$ref) > 0)
|
if ($object->fetch($id) > 0)
|
||||||
{
|
{
|
||||||
$result=$project->fetch($task->fk_project);
|
$result=$projectstatic->fetch($object->fk_project);
|
||||||
if (! empty($project->socid)) $project->societe->fetch($project->socid);
|
if (! empty($projectstatic->socid)) $projectstatic->societe->fetch($projectstatic->socid);
|
||||||
|
|
||||||
$userWrite = $project->restrictedProjectArea($user,'write');
|
$userWrite = $projectstatic->restrictedProjectArea($user,'write');
|
||||||
|
|
||||||
if ($withproject)
|
if ($withproject)
|
||||||
{
|
{
|
||||||
// Tabs for project
|
// Tabs for project
|
||||||
$tab='tasks';
|
$tab='tasks';
|
||||||
$head=project_prepare_head($project);
|
$head=project_prepare_head($projectstatic);
|
||||||
dol_fiche_head($head, $tab, $langs->trans("Project"),0,($project->public?'projectpub':'project'));
|
dol_fiche_head($head, $tab, $langs->trans("Project"),0,($projectstatic->public?'projectpub':'project'));
|
||||||
|
|
||||||
$param=($mode=='mine'?'&mode=mine':'');
|
$param=($mode=='mine'?'&mode=mine':'');
|
||||||
|
|
||||||
@@ -162,28 +175,28 @@ if ($id > 0 || ! empty($ref))
|
|||||||
// Define a complementary filter for search of next/prev ref.
|
// Define a complementary filter for search of next/prev ref.
|
||||||
if (! $user->rights->projet->all->lire)
|
if (! $user->rights->projet->all->lire)
|
||||||
{
|
{
|
||||||
$projectsListId = $project->getProjectsAuthorizedForUser($user,$mine,0);
|
$projectsListId = $projectstatic->getProjectsAuthorizedForUser($user,$mine,0);
|
||||||
$project->next_prev_filter=" rowid in (".(count($projectsListId)?join(',',array_keys($projectsListId)):'0').")";
|
$projectstatic->next_prev_filter=" rowid in (".(count($projectsListId)?join(',',array_keys($projectsListId)):'0').")";
|
||||||
}
|
}
|
||||||
print $form->showrefnav($project,'ref','',1,'ref','ref','',$param);
|
print $form->showrefnav($projectstatic,'project_ref','',1,'ref','ref','',$param.'&withproject=1');
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
print '<tr><td>'.$langs->trans("Label").'</td><td>'.$project->title.'</td></tr>';
|
print '<tr><td>'.$langs->trans("Label").'</td><td>'.$projectstatic->title.'</td></tr>';
|
||||||
|
|
||||||
print '<tr><td>'.$langs->trans("Company").'</td><td>';
|
print '<tr><td>'.$langs->trans("Company").'</td><td>';
|
||||||
if (! empty($project->societe->id)) print $project->societe->getNomUrl(1);
|
if (! empty($projectstatic->societe->id)) print $projectstatic->societe->getNomUrl(1);
|
||||||
else print ' ';
|
else print ' ';
|
||||||
print '</td>';
|
print '</td>';
|
||||||
print '</tr>';
|
print '</tr>';
|
||||||
|
|
||||||
// Visibility
|
// Visibility
|
||||||
print '<tr><td>'.$langs->trans("Visibility").'</td><td>';
|
print '<tr><td>'.$langs->trans("Visibility").'</td><td>';
|
||||||
if ($project->public) print $langs->trans('SharedProject');
|
if ($projectstatic->public) print $langs->trans('SharedProject');
|
||||||
else print $langs->trans('PrivateProject');
|
else print $langs->trans('PrivateProject');
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Statut
|
// Statut
|
||||||
print '<tr><td>'.$langs->trans("Status").'</td><td>'.$project->getLibStatut(4).'</td></tr>';
|
print '<tr><td>'.$langs->trans("Status").'</td><td>'.$projectstatic->getLibStatut(4).'</td></tr>';
|
||||||
|
|
||||||
print '</table>';
|
print '</table>';
|
||||||
|
|
||||||
@@ -193,12 +206,12 @@ if ($id > 0 || ! empty($ref))
|
|||||||
}
|
}
|
||||||
|
|
||||||
// To verify role of users
|
// To verify role of users
|
||||||
//$userAccess = $project->restrictedProjectArea($user); // We allow task affected to user even if a not allowed project
|
//$userAccess = $projectstatic->restrictedProjectArea($user); // We allow task affected to user even if a not allowed project
|
||||||
//$arrayofuseridoftask=$task->getListContactId('internal');
|
//$arrayofuseridoftask=$object->getListContactId('internal');
|
||||||
|
|
||||||
dol_htmloutput_mesg($mesg);
|
dol_htmloutput_mesg($mesg);
|
||||||
|
|
||||||
$head = task_prepare_head($task);
|
$head = task_prepare_head($object);
|
||||||
dol_fiche_head($head, 'task_contact', $langs->trans("Task"), 0, 'projecttask');
|
dol_fiche_head($head, 'task_contact', $langs->trans("Task"), 0, 'projecttask');
|
||||||
|
|
||||||
|
|
||||||
@@ -208,33 +221,33 @@ if ($id > 0 || ! empty($ref))
|
|||||||
print '<table class="border" width="100%">';
|
print '<table class="border" width="100%">';
|
||||||
|
|
||||||
$param=(GETPOST('withproject')?'&withproject=1':'');
|
$param=(GETPOST('withproject')?'&withproject=1':'');
|
||||||
$linkback=GETPOST('withproject')?'<a href="'.DOL_URL_ROOT.'/projet/tasks.php?id='.$project->id.'">'.$langs->trans("BackToList").'</a>':'';
|
$linkback=GETPOST('withproject')?'<a href="'.DOL_URL_ROOT.'/projet/tasks.php?id='.$projectstatic->id.'">'.$langs->trans("BackToList").'</a>':'';
|
||||||
|
|
||||||
// Ref
|
// Ref
|
||||||
print '<tr><td width="30%">'.$langs->trans('Ref').'</td><td colspan="3">';
|
print '<tr><td width="30%">'.$langs->trans('Ref').'</td><td colspan="3">';
|
||||||
if (! GETPOST('withproject') || empty($project->id))
|
if (! GETPOST('withproject') || empty($projectstatic->id))
|
||||||
{
|
{
|
||||||
$projectsListId = $project->getProjectsAuthorizedForUser($user,$mine,1);
|
$projectsListId = $projectstatic->getProjectsAuthorizedForUser($user,$mine,1);
|
||||||
$task->next_prev_filter=" fk_projet in (".$projectsListId.")";
|
$object->next_prev_filter=" fk_projet in (".$projectsListId.")";
|
||||||
}
|
}
|
||||||
else $task->next_prev_filter=" fk_projet = ".$project->id;
|
else $object->next_prev_filter=" fk_projet = ".$projectstatic->id;
|
||||||
print $form->showrefnav($task,'id',$linkback,1,'rowid','ref','',$param);
|
print $form->showrefnav($object,'id',$linkback,1,'rowid','ref','',$param);
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Label
|
// Label
|
||||||
print '<tr><td>'.$langs->trans("Label").'</td><td>'.$task->label.'</td></tr>';
|
print '<tr><td>'.$langs->trans("Label").'</td><td>'.$object->label.'</td></tr>';
|
||||||
|
|
||||||
// Project
|
// Project
|
||||||
if (empty($withproject))
|
if (empty($withproject))
|
||||||
{
|
{
|
||||||
print '<tr><td>'.$langs->trans("Project").'</td><td>';
|
print '<tr><td>'.$langs->trans("Project").'</td><td>';
|
||||||
print $project->getNomUrl(1);
|
print $projectstatic->getNomUrl(1);
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Customer
|
// Customer
|
||||||
print "<tr><td>".$langs->trans("Company")."</td>";
|
print "<tr><td>".$langs->trans("Company")."</td>";
|
||||||
print '<td colspan="3">';
|
print '<td colspan="3">';
|
||||||
if ($project->societe->id > 0) print $project->societe->getNomUrl(1);
|
if ($projectstatic->societe->id > 0) print $projectstatic->societe->getNomUrl(1);
|
||||||
else print ' ';
|
else print ' ';
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
}
|
}
|
||||||
@@ -283,11 +296,11 @@ if ($id > 0 || ! empty($ref))
|
|||||||
|
|
||||||
print '<td colspan="1">';
|
print '<td colspan="1">';
|
||||||
// On recupere les id des users deja selectionnes
|
// On recupere les id des users deja selectionnes
|
||||||
$contactsofproject=$project->getListContactId('internal');
|
$contactsofproject=$projectstatic->getListContactId('internal');
|
||||||
$form->select_users($user->id,'contactid',0,'',0,'',$contactsofproject);
|
$form->select_users($user->id,'contactid',0,'',0,'',$contactsofproject);
|
||||||
print '</td>';
|
print '</td>';
|
||||||
print '<td>';
|
print '<td>';
|
||||||
$formcompany->selectTypeContact($task, '', 'type','internal','rowid');
|
$formcompany->selectTypeContact($object, '', 'type','internal','rowid');
|
||||||
print '</td>';
|
print '</td>';
|
||||||
print '<td align="right" colspan="3" ><input type="submit" class="button" value="'.$langs->trans("Add").'"></td>';
|
print '<td align="right" colspan="3" ><input type="submit" class="button" value="'.$langs->trans("Add").'"></td>';
|
||||||
print '</tr>';
|
print '</tr>';
|
||||||
@@ -295,13 +308,13 @@ if ($id > 0 || ! empty($ref))
|
|||||||
print '</form>';
|
print '</form>';
|
||||||
|
|
||||||
// Line to add an external contact. Only if project linked to a third party.
|
// Line to add an external contact. Only if project linked to a third party.
|
||||||
if ($project->socid)
|
if ($projectstatic->socid)
|
||||||
{
|
{
|
||||||
print '<form action="'.$_SERVER["PHP_SELF"].'?id='.$id.'" method="POST">';
|
print '<form action="'.$_SERVER["PHP_SELF"].'?id='.$object->id.'" method="POST">';
|
||||||
print '<input type="hidden" name="token" value="'.$_SESSION['newtoken'].'">';
|
print '<input type="hidden" name="token" value="'.$_SESSION['newtoken'].'">';
|
||||||
print '<input type="hidden" name="action" value="addcontact">';
|
print '<input type="hidden" name="action" value="addcontact">';
|
||||||
print '<input type="hidden" name="source" value="external">';
|
print '<input type="hidden" name="source" value="external">';
|
||||||
print '<input type="hidden" name="id" value="'.$id.'">';
|
print '<input type="hidden" name="id" value="'.$object->id.'">';
|
||||||
|
|
||||||
$var=!$var;
|
$var=!$var;
|
||||||
print "<tr $bc[$var]>";
|
print "<tr $bc[$var]>";
|
||||||
@@ -311,18 +324,18 @@ if ($id > 0 || ! empty($ref))
|
|||||||
print '</td>';
|
print '</td>';
|
||||||
|
|
||||||
print '<td colspan="1">';
|
print '<td colspan="1">';
|
||||||
$thirdpartyofproject=$project->getListContactId('thirdparty');
|
$thirdpartyofproject=$projectstatic->getListContactId('thirdparty');
|
||||||
$selectedCompany = isset($_GET["newcompany"])?$_GET["newcompany"]:$project->societe->id;
|
$selectedCompany = isset($_GET["newcompany"])?$_GET["newcompany"]:$projectstatic->societe->id;
|
||||||
$selectedCompany = $formcompany->selectCompaniesForNewContact($task, 'id', $selectedCompany, 'newcompany',$thirdpartyofproject);
|
$selectedCompany = $formcompany->selectCompaniesForNewContact($object, 'id', $selectedCompany, 'newcompany',$thirdpartyofproject);
|
||||||
print '</td>';
|
print '</td>';
|
||||||
|
|
||||||
print '<td colspan="1">';
|
print '<td colspan="1">';
|
||||||
$contactofproject=$project->getListContactId('external');
|
$contactofproject=$projectstatic->getListContactId('external');
|
||||||
$nbofcontacts=$form->select_contacts($selectedCompany,'','contactid',0,'',$contactofproject);
|
$nbofcontacts=$form->select_contacts($selectedCompany,'','contactid',0,'',$contactofproject);
|
||||||
if ($nbofcontacts == 0) print $langs->trans("NoContactDefined");
|
if ($nbofcontacts == 0) print $langs->trans("NoContactDefined");
|
||||||
print '</td>';
|
print '</td>';
|
||||||
print '<td>';
|
print '<td>';
|
||||||
$formcompany->selectTypeContact($task, '', 'type','external','rowid');
|
$formcompany->selectTypeContact($object, '', 'type','external','rowid');
|
||||||
print '</td>';
|
print '</td>';
|
||||||
print '<td align="right" colspan="3" ><input type="submit" class="button" value="'.$langs->trans("Add").'"';
|
print '<td align="right" colspan="3" ><input type="submit" class="button" value="'.$langs->trans("Add").'"';
|
||||||
if (! $nbofcontacts) print ' disabled="disabled"';
|
if (! $nbofcontacts) print ' disabled="disabled"';
|
||||||
@@ -348,7 +361,7 @@ if ($id > 0 || ! empty($ref))
|
|||||||
|
|
||||||
foreach(array('internal','external') as $source)
|
foreach(array('internal','external') as $source)
|
||||||
{
|
{
|
||||||
$tab = $task->liste_contact(-1,$source);
|
$tab = $object->liste_contact(-1,$source);
|
||||||
$num=count($tab);
|
$num=count($tab);
|
||||||
|
|
||||||
$i = 0;
|
$i = 0;
|
||||||
@@ -405,9 +418,9 @@ if ($id > 0 || ! empty($ref))
|
|||||||
// Statut
|
// Statut
|
||||||
print '<td align="center">';
|
print '<td align="center">';
|
||||||
// Activation desativation du contact
|
// Activation desativation du contact
|
||||||
if ($task->statut >= 0) print '<a href="'.$_SERVER["PHP_SELF"].'?id='.$task->id.'&action=swapstatut&ligne='.$tab[$i]['rowid'].'">';
|
if ($object->statut >= 0) print '<a href="'.$_SERVER["PHP_SELF"].'?id='.$object->id.'&action=swapstatut&ligne='.$tab[$i]['rowid'].'">';
|
||||||
print $contactstatic->LibStatut($tab[$i]['status'],3);
|
print $contactstatic->LibStatut($tab[$i]['status'],3);
|
||||||
if ($task->statut >= 0) print '</a>';
|
if ($object->statut >= 0) print '</a>';
|
||||||
print '</td>';
|
print '</td>';
|
||||||
|
|
||||||
// Icon update et delete
|
// Icon update et delete
|
||||||
@@ -415,7 +428,7 @@ if ($id > 0 || ! empty($ref))
|
|||||||
if ($user->rights->projet->creer)
|
if ($user->rights->projet->creer)
|
||||||
{
|
{
|
||||||
print ' ';
|
print ' ';
|
||||||
print '<a href="'.$_SERVER["PHP_SELF"].'?id='.$task->id.'&action=deleteline&lineid='.$tab[$i]['rowid'].'">';
|
print '<a href="'.$_SERVER["PHP_SELF"].'?id='.$object->id.'&action=deleteline&lineid='.$tab[$i]['rowid'].'">';
|
||||||
print img_delete();
|
print img_delete();
|
||||||
print '</a>';
|
print '</a>';
|
||||||
}
|
}
|
||||||
@@ -436,6 +449,5 @@ if ($id > 0 || ! empty($ref))
|
|||||||
|
|
||||||
|
|
||||||
llxFooter();
|
llxFooter();
|
||||||
|
|
||||||
$db->close();
|
$db->close();
|
||||||
?>
|
?>
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
/* Copyright (C) 2010 Regis Houssin <regis@dolibarr.fr>
|
/* Copyright (C) 2010-2012 Regis Houssin <regis@dolibarr.fr>
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
@@ -32,12 +32,14 @@ require_once(DOL_DOCUMENT_ROOT."/core/class/html.formfile.class.php");
|
|||||||
$langs->load('projects');
|
$langs->load('projects');
|
||||||
$langs->load('other');
|
$langs->load('other');
|
||||||
|
|
||||||
$action=GETPOST('action');
|
$action=GETPOST('action','alpha');
|
||||||
|
$confirm=GETPOST('confirm','alpha');
|
||||||
$mine = $_REQUEST['mode']=='mine' ? 1 : 0;
|
$mine = $_REQUEST['mode']=='mine' ? 1 : 0;
|
||||||
//if (! $user->rights->projet->all->lire) $mine=1; // Special for projects
|
//if (! $user->rights->projet->all->lire) $mine=1; // Special for projects
|
||||||
$id = GETPOST('id','int');
|
$id = GETPOST('id','int');
|
||||||
$ref= GETPOST('ref');
|
$ref= GETPOST('ref','alpha');
|
||||||
$withproject=GETPOST('withproject');
|
$withproject=GETPOST('withproject','int');
|
||||||
|
$project_ref = GETPOST('project_ref','alpha');
|
||||||
|
|
||||||
// Security check
|
// Security check
|
||||||
$socid=0;
|
$socid=0;
|
||||||
@@ -57,21 +59,23 @@ if (! $sortorder) $sortorder="ASC";
|
|||||||
if (! $sortfield) $sortfield="name";
|
if (! $sortfield) $sortfield="name";
|
||||||
|
|
||||||
|
|
||||||
|
$object = new Task($db);
|
||||||
|
$projectstatic = new Project($db);
|
||||||
|
|
||||||
$task = new Task($db);
|
if ($id > 0 || ! empty($ref))
|
||||||
|
|
||||||
if ($task->fetch($id,$ref) > 0)
|
|
||||||
{
|
{
|
||||||
$projectstatic = new Project($db);
|
if ($object->fetch($id,$ref) > 0)
|
||||||
$projectstatic->fetch($task->fk_project);
|
{
|
||||||
|
$projectstatic->fetch($object->fk_project);
|
||||||
if (! empty($projectstatic->socid)) $projectstatic->societe->fetch($projectstatic->socid);
|
|
||||||
|
if (! empty($projectstatic->socid)) $projectstatic->societe->fetch($projectstatic->socid);
|
||||||
$upload_dir = $conf->projet->dir_output.'/'.dol_sanitizeFileName($projectstatic->ref).'/'.dol_sanitizeFileName($task->ref);
|
|
||||||
}
|
$upload_dir = $conf->projet->dir_output.'/'.dol_sanitizeFileName($projectstatic->ref).'/'.dol_sanitizeFileName($object->ref);
|
||||||
else
|
}
|
||||||
{
|
else
|
||||||
dol_print_error($db);
|
{
|
||||||
|
dol_print_error($db);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -118,143 +122,155 @@ if ($action=='delete')
|
|||||||
$mesg = '<div class="ok">'.$langs->trans("FileWasRemoved").'</div>';
|
$mesg = '<div class="ok">'.$langs->trans("FileWasRemoved").'</div>';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Retreive First Task ID of Project if withprojet is on to allow project prev next to work
|
||||||
|
if (! empty($project_ref) && ! empty($withproject))
|
||||||
|
{
|
||||||
|
if ($projectstatic->fetch(0,$project_ref) > 0)
|
||||||
|
{
|
||||||
|
$tasksarray=$object->getTasksArray(0, 0, $projectstatic->id, $socid, 0);
|
||||||
|
if (count($tasksarray) > 0)
|
||||||
|
{
|
||||||
|
$id=$tasksarray[0]->id;
|
||||||
|
$object->fetch($id);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Header("Location: ".DOL_URL_ROOT.'/projet/tasks.php?id='.$projectstatic->id.(empty($mode)?'':'&mode='.$mode));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* View
|
* View
|
||||||
*/
|
*/
|
||||||
|
|
||||||
$form = new Form($db);
|
$form = new Form($db);
|
||||||
$project = new Project($db);
|
|
||||||
$task = new Task($db);
|
|
||||||
|
|
||||||
llxHeader('',$langs->trans('Project'));
|
llxHeader('',$langs->trans('Project'));
|
||||||
|
|
||||||
if ($id > 0 || ! empty($ref))
|
if ($object->id > 0)
|
||||||
{
|
{
|
||||||
if ($task->fetch($id,$ref) >= 0)
|
if (! empty($projectstatic->socid)) $projectstatic->societe->fetch($projectstatic->socid);
|
||||||
{
|
|
||||||
$result=$project->fetch($task->fk_project);
|
$userWrite = $projectstatic->restrictedProjectArea($user,'write');
|
||||||
if (! empty($project->socid)) $project->societe->fetch($project->socid);
|
|
||||||
|
if (! empty($withproject))
|
||||||
$userWrite = $project->restrictedProjectArea($user,'write');
|
{
|
||||||
|
// Tabs for project
|
||||||
if ($withproject)
|
$tab='tasks';
|
||||||
{
|
$head=project_prepare_head($projectstatic);
|
||||||
// Tabs for project
|
dol_fiche_head($head, $tab, $langs->trans("Project"),0,($projectstatic->public?'projectpub':'project'));
|
||||||
$tab='tasks';
|
|
||||||
$head=project_prepare_head($project);
|
$param=($mode=='mine'?'&mode=mine':'');
|
||||||
dol_fiche_head($head, $tab, $langs->trans("Project"),0,($project->public?'projectpub':'project'));
|
|
||||||
|
print '<table class="border" width="100%">';
|
||||||
$param=($mode=='mine'?'&mode=mine':'');
|
|
||||||
|
// Ref
|
||||||
print '<table class="border" width="100%">';
|
print '<tr><td width="30%">';
|
||||||
|
print $langs->trans("Ref");
|
||||||
// Ref
|
print '</td><td>';
|
||||||
print '<tr><td width="30%">';
|
// Define a complementary filter for search of next/prev ref.
|
||||||
print $langs->trans("Ref");
|
if (! $user->rights->projet->all->lire)
|
||||||
print '</td><td>';
|
{
|
||||||
// Define a complementary filter for search of next/prev ref.
|
$projectsListId = $projectstatic->getProjectsAuthorizedForUser($user,$mine,0);
|
||||||
if (! $user->rights->projet->all->lire)
|
$projectstatic->next_prev_filter=" rowid in (".(count($projectsListId)?join(',',array_keys($projectsListId)):'0').")";
|
||||||
{
|
}
|
||||||
$projectsListId = $project->getProjectsAuthorizedForUser($user,$mine,0);
|
print $form->showrefnav($projectstatic,'project_ref','',1,'ref','ref','',$param.'&withproject=1');
|
||||||
$project->next_prev_filter=" rowid in (".(count($projectsListId)?join(',',array_keys($projectsListId)):'0').")";
|
print '</td></tr>';
|
||||||
}
|
|
||||||
print $form->showrefnav($project,'ref','',1,'ref','ref','',$param);
|
print '<tr><td>'.$langs->trans("Label").'</td><td>'.$projectstatic->title.'</td></tr>';
|
||||||
print '</td></tr>';
|
|
||||||
|
print '<tr><td>'.$langs->trans("Company").'</td><td>';
|
||||||
print '<tr><td>'.$langs->trans("Label").'</td><td>'.$project->title.'</td></tr>';
|
if (! empty($projectstatic->societe->id)) print $projectstatic->societe->getNomUrl(1);
|
||||||
|
else print ' ';
|
||||||
print '<tr><td>'.$langs->trans("Company").'</td><td>';
|
print '</td>';
|
||||||
if (! empty($project->societe->id)) print $project->societe->getNomUrl(1);
|
print '</tr>';
|
||||||
else print ' ';
|
|
||||||
print '</td>';
|
// Visibility
|
||||||
print '</tr>';
|
print '<tr><td>'.$langs->trans("Visibility").'</td><td>';
|
||||||
|
if ($projectstatic->public) print $langs->trans('SharedProject');
|
||||||
// Visibility
|
else print $langs->trans('PrivateProject');
|
||||||
print '<tr><td>'.$langs->trans("Visibility").'</td><td>';
|
print '</td></tr>';
|
||||||
if ($project->public) print $langs->trans('SharedProject');
|
|
||||||
else print $langs->trans('PrivateProject');
|
// Statut
|
||||||
print '</td></tr>';
|
print '<tr><td>'.$langs->trans("Status").'</td><td>'.$projectstatic->getLibStatut(4).'</td></tr>';
|
||||||
|
|
||||||
// Statut
|
print '</table>';
|
||||||
print '<tr><td>'.$langs->trans("Status").'</td><td>'.$project->getLibStatut(4).'</td></tr>';
|
|
||||||
|
dol_fiche_end();
|
||||||
print '</table>';
|
|
||||||
|
print '<br>';
|
||||||
dol_fiche_end();
|
}
|
||||||
|
|
||||||
print '<br>';
|
$head = task_prepare_head($object);
|
||||||
}
|
dol_fiche_head($head, 'task_document', $langs->trans("Task"), 0, 'projecttask');
|
||||||
|
|
||||||
$head = task_prepare_head($task);
|
$param=(GETPOST('withproject')?'&withproject=1':'');
|
||||||
dol_fiche_head($head, 'task_document', $langs->trans("Task"), 0, 'projecttask');
|
$linkback=GETPOST('withproject')?'<a href="'.DOL_URL_ROOT.'/projet/tasks.php?id='.$projectstatic->id.'">'.$langs->trans("BackToList").'</a>':'';
|
||||||
|
|
||||||
$param=(GETPOST('withproject')?'&withproject=1':'');
|
// Files list constructor
|
||||||
$linkback=GETPOST('withproject')?'<a href="'.DOL_URL_ROOT.'/projet/tasks.php?id='.$project->id.'">'.$langs->trans("BackToList").'</a>':'';
|
$filearray=dol_dir_list($upload_dir,"files",0,'','\.meta$',$sortfield,(strtolower($sortorder)=='desc'?SORT_DESC:SORT_ASC),1);
|
||||||
|
$totalsize=0;
|
||||||
// Files list constructor
|
foreach($filearray as $key => $file)
|
||||||
$filearray=dol_dir_list($upload_dir,"files",0,'','\.meta$',$sortfield,(strtolower($sortorder)=='desc'?SORT_DESC:SORT_ASC),1);
|
{
|
||||||
$totalsize=0;
|
$totalsize+=$file['size'];
|
||||||
foreach($filearray as $key => $file)
|
}
|
||||||
{
|
|
||||||
$totalsize+=$file['size'];
|
print '<table class="border" width="100%">';
|
||||||
}
|
|
||||||
|
// Ref
|
||||||
print '<table class="border" width="100%">';
|
print '<tr><td width="30%">';
|
||||||
|
print $langs->trans("Ref");
|
||||||
// Ref
|
print '</td><td colspan="3">';
|
||||||
print '<tr><td width="30%">';
|
if (empty($withproject) || empty($projectstatic->id))
|
||||||
print $langs->trans("Ref");
|
{
|
||||||
print '</td><td colspan="3">';
|
$projectsListId = $projectstatic->getProjectsAuthorizedForUser($user,$mine,1);
|
||||||
if (! GETPOST('withproject') || empty($project->id))
|
$object->next_prev_filter=" fk_projet in (".$projectsListId.")";
|
||||||
{
|
}
|
||||||
$projectsListId = $project->getProjectsAuthorizedForUser($user,$mine,1);
|
else $object->next_prev_filter=" fk_projet = ".$projectstatic->id;
|
||||||
$task->next_prev_filter=" fk_projet in (".$projectsListId.")";
|
print $form->showrefnav($object,'id',$linkback,1,'rowid','ref','',$param);
|
||||||
}
|
print '</td>';
|
||||||
else $task->next_prev_filter=" fk_projet = ".$project->id;
|
print '</tr>';
|
||||||
print $form->showrefnav($task,'id',$linkback,1,'rowid','ref','',$param);
|
|
||||||
print '</td>';
|
// Label
|
||||||
print '</tr>';
|
print '<tr><td>'.$langs->trans("Label").'</td><td colspan="3">'.$object->label.'</td></tr>';
|
||||||
|
|
||||||
// Label
|
// Project
|
||||||
print '<tr><td>'.$langs->trans("Label").'</td><td colspan="3">'.$task->label.'</td></tr>';
|
if (empty($withproject))
|
||||||
|
{
|
||||||
// Project
|
print '<tr><td>'.$langs->trans("Project").'</td><td colspan="3">';
|
||||||
if (empty($withproject))
|
print $projectstatic->getNomUrl(1);
|
||||||
{
|
print '</td></tr>';
|
||||||
print '<tr><td>'.$langs->trans("Project").'</td><td colspan="3">';
|
|
||||||
print $projectstatic->getNomUrl(1);
|
// Third party
|
||||||
print '</td></tr>';
|
print '<td>'.$langs->trans("Company").'</td><td colspan="3">';
|
||||||
|
if ($projectstatic->societe->id) print $projectstatic->societe->getNomUrl(1);
|
||||||
// Third party
|
else print ' ';
|
||||||
print '<td>'.$langs->trans("Company").'</td><td colspan="3">';
|
print '</td></tr>';
|
||||||
if ($projectstatic->societe->id) print $projectstatic->societe->getNomUrl(1);
|
}
|
||||||
else print ' ';
|
|
||||||
print '</td></tr>';
|
// Files infos
|
||||||
}
|
print '<tr><td>'.$langs->trans("NbOfAttachedFiles").'</td><td colspan="3">'.count($filearray).'</td></tr>';
|
||||||
|
print '<tr><td>'.$langs->trans("TotalSizeOfAttachedFiles").'</td><td colspan="3">'.$totalsize.' '.$langs->trans("bytes").'</td></tr>';
|
||||||
// Files infos
|
|
||||||
print '<tr><td>'.$langs->trans("NbOfAttachedFiles").'</td><td colspan="3">'.count($filearray).'</td></tr>';
|
print "</table>\n";
|
||||||
print '<tr><td>'.$langs->trans("TotalSizeOfAttachedFiles").'</td><td colspan="3">'.$totalsize.' '.$langs->trans("bytes").'</td></tr>';
|
|
||||||
|
dol_fiche_end();
|
||||||
print "</table>\n";
|
|
||||||
|
print '<br>';
|
||||||
dol_fiche_end();
|
|
||||||
|
dol_htmloutput_mesg($mesg);
|
||||||
print '<br>';
|
|
||||||
|
|
||||||
dol_htmloutput_mesg($mesg);
|
// Affiche formulaire upload
|
||||||
|
$formfile=new FormFile($db);
|
||||||
|
$formfile->form_attach_new_file(DOL_URL_ROOT.'/projet/tasks/document.php?id='.$object->id,'',0,0,$user->rights->projet->creer);
|
||||||
// Affiche formulaire upload
|
|
||||||
$formfile=new FormFile($db);
|
|
||||||
$formfile->form_attach_new_file(DOL_URL_ROOT.'/projet/tasks/document.php?id='.$task->id,'',0,0,$user->rights->projet->creer);
|
// List of document
|
||||||
|
$param='&id='.$object->id;
|
||||||
|
$formfile->list_of_documents($filearray,$object,'projet',$param,0,dol_sanitizeFileName($projectstatic->ref).'/'.dol_sanitizeFileName($object->ref).'/');
|
||||||
// List of document
|
|
||||||
$param='&id='.$task->id;
|
|
||||||
$formfile->list_of_documents($filearray,$task,'projet',$param,0,dol_sanitizeFileName($project->ref).'/'.dol_sanitizeFileName($task->ref).'/');
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -264,6 +280,5 @@ else
|
|||||||
|
|
||||||
|
|
||||||
llxFooter();
|
llxFooter();
|
||||||
|
|
||||||
$db->close();
|
$db->close();
|
||||||
?>
|
?>
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
/* Copyright (C) 2010 Regis Houssin <regis@dolibarr.fr>
|
/* Copyright (C) 2010-2012 Regis Houssin <regis@dolibarr.fr>
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
@@ -28,12 +28,14 @@ require_once(DOL_DOCUMENT_ROOT."/core/lib/project.lib.php");
|
|||||||
|
|
||||||
$langs->load('projects');
|
$langs->load('projects');
|
||||||
|
|
||||||
$action=GETPOST('action');
|
$action=GETPOST('action','alpha');
|
||||||
|
$confirm=GETPOST('confirm','alpha');
|
||||||
$mine = $_REQUEST['mode']=='mine' ? 1 : 0;
|
$mine = $_REQUEST['mode']=='mine' ? 1 : 0;
|
||||||
//if (! $user->rights->projet->all->lire) $mine=1; // Special for projects
|
//if (! $user->rights->projet->all->lire) $mine=1; // Special for projects
|
||||||
$id = GETPOST('id','int');
|
$id = GETPOST('id','int');
|
||||||
$ref= GETPOST('ref', 'alpha');
|
$ref= GETPOST('ref', 'alpha');
|
||||||
$withproject=GETPOST('withproject');
|
$withproject=GETPOST('withproject','int');
|
||||||
|
$project_ref = GETPOST('project_ref','alpha');
|
||||||
|
|
||||||
// Security check
|
// Security check
|
||||||
$socid=0;
|
$socid=0;
|
||||||
@@ -42,7 +44,39 @@ if (!$user->rights->projet->lire) accessforbidden();
|
|||||||
//$result = restrictedArea($user, 'projet', $id, '', 'task'); // TODO ameliorer la verification
|
//$result = restrictedArea($user, 'projet', $id, '', 'task'); // TODO ameliorer la verification
|
||||||
|
|
||||||
$object = new Task($db);
|
$object = new Task($db);
|
||||||
$object->fetch($id, $ref);
|
$projectstatic = new Project($db);
|
||||||
|
|
||||||
|
if ($id > 0 || ! empty($ref))
|
||||||
|
{
|
||||||
|
if ($object->fetch($id,$ref) > 0)
|
||||||
|
{
|
||||||
|
$projectstatic->fetch($object->fk_project);
|
||||||
|
if (! empty($projectstatic->socid)) $projectstatic->societe->fetch($projectstatic->socid);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
dol_print_error($db);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Retreive First Task ID of Project if withprojet is on to allow project prev next to work
|
||||||
|
if (! empty($project_ref) && ! empty($withproject))
|
||||||
|
{
|
||||||
|
if ($projectstatic->fetch(0,$project_ref) > 0)
|
||||||
|
{
|
||||||
|
$tasksarray=$object->getTasksArray(0, 0, $projectstatic->id, $socid, 0);
|
||||||
|
if (count($tasksarray) > 0)
|
||||||
|
{
|
||||||
|
$id=$tasksarray[0]->id;
|
||||||
|
$object->fetch($id);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Header("Location: ".DOL_URL_ROOT.'/projet/tasks.php?id='.$projectstatic->id.(empty($mode)?'':'&mode='.$mode));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -70,24 +104,20 @@ else if ($action == 'setnote_private' && $user->rights->ficheinter->creer)
|
|||||||
llxHeader();
|
llxHeader();
|
||||||
|
|
||||||
$form = new Form($db);
|
$form = new Form($db);
|
||||||
$project = new Project($db);
|
|
||||||
$userstatic = new User($db);
|
$userstatic = new User($db);
|
||||||
|
|
||||||
$now=dol_now();
|
$now=dol_now();
|
||||||
|
|
||||||
if ($id > 0 || ! empty($ref))
|
if ($object->id > 0)
|
||||||
{
|
{
|
||||||
$result=$project->fetch($object->fk_project);
|
$userWrite = $projectstatic->restrictedProjectArea($user,'write');
|
||||||
if (! empty($project->socid)) $project->societe->fetch($project->socid);
|
|
||||||
|
|
||||||
$userWrite = $project->restrictedProjectArea($user,'write');
|
if (! empty($withproject))
|
||||||
|
|
||||||
if ($withproject)
|
|
||||||
{
|
{
|
||||||
// Tabs for project
|
// Tabs for project
|
||||||
$tab='tasks';
|
$tab='tasks';
|
||||||
$head=project_prepare_head($project);
|
$head=project_prepare_head($projectstatic);
|
||||||
dol_fiche_head($head, $tab, $langs->trans("Project"),0,($project->public?'projectpub':'project'));
|
dol_fiche_head($head, $tab, $langs->trans("Project"),0,($projectstatic->public?'projectpub':'project'));
|
||||||
|
|
||||||
$param=($mode=='mine'?'&mode=mine':'');
|
$param=($mode=='mine'?'&mode=mine':'');
|
||||||
|
|
||||||
@@ -100,30 +130,30 @@ if ($id > 0 || ! empty($ref))
|
|||||||
// Define a complementary filter for search of next/prev ref.
|
// Define a complementary filter for search of next/prev ref.
|
||||||
if (! $user->rights->projet->all->lire)
|
if (! $user->rights->projet->all->lire)
|
||||||
{
|
{
|
||||||
$projectsListId = $project->getProjectsAuthorizedForUser($user,$mine,0);
|
$projectsListId = $projectstatic->getProjectsAuthorizedForUser($user,$mine,0);
|
||||||
$project->next_prev_filter=" rowid in (".(count($projectsListId)?join(',',array_keys($projectsListId)):'0').")";
|
$projectstatic->next_prev_filter=" rowid in (".(count($projectsListId)?join(',',array_keys($projectsListId)):'0').")";
|
||||||
}
|
}
|
||||||
print $form->showrefnav($project,'ref','',1,'ref','ref','',$param);
|
print $form->showrefnav($projectstatic,'project_ref','',1,'ref','ref','',$param.'&withproject=1');
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Project
|
// Project
|
||||||
print '<tr><td>'.$langs->trans("Label").'</td><td>'.$project->title.'</td></tr>';
|
print '<tr><td>'.$langs->trans("Label").'</td><td>'.$projectstatic->title.'</td></tr>';
|
||||||
|
|
||||||
// Company
|
// Company
|
||||||
print '<tr><td>'.$langs->trans("Company").'</td><td>';
|
print '<tr><td>'.$langs->trans("Company").'</td><td>';
|
||||||
if (! empty($project->societe->id)) print $project->societe->getNomUrl(1);
|
if (! empty($projectstatic->societe->id)) print $projectstatic->societe->getNomUrl(1);
|
||||||
else print ' ';
|
else print ' ';
|
||||||
print '</td>';
|
print '</td>';
|
||||||
print '</tr>';
|
print '</tr>';
|
||||||
|
|
||||||
// Visibility
|
// Visibility
|
||||||
print '<tr><td>'.$langs->trans("Visibility").'</td><td>';
|
print '<tr><td>'.$langs->trans("Visibility").'</td><td>';
|
||||||
if ($project->public) print $langs->trans('SharedProject');
|
if ($projectstatic->public) print $langs->trans('SharedProject');
|
||||||
else print $langs->trans('PrivateProject');
|
else print $langs->trans('PrivateProject');
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Statut
|
// Statut
|
||||||
print '<tr><td>'.$langs->trans("Status").'</td><td>'.$project->getLibStatut(4).'</td></tr>';
|
print '<tr><td>'.$langs->trans("Status").'</td><td>'.$projectstatic->getLibStatut(4).'</td></tr>';
|
||||||
|
|
||||||
print '</table>';
|
print '</table>';
|
||||||
|
|
||||||
@@ -138,16 +168,16 @@ if ($id > 0 || ! empty($ref))
|
|||||||
print '<table class="border" width="100%">';
|
print '<table class="border" width="100%">';
|
||||||
|
|
||||||
$param=(GETPOST('withproject')?'&withproject=1':'');
|
$param=(GETPOST('withproject')?'&withproject=1':'');
|
||||||
$linkback=GETPOST('withproject')?'<a href="'.DOL_URL_ROOT.'/projet/tasks.php?id='.$project->id.'">'.$langs->trans("BackToList").'</a>':'';
|
$linkback=GETPOST('withproject')?'<a href="'.DOL_URL_ROOT.'/projet/tasks.php?id='.$projectstatic->id.'">'.$langs->trans("BackToList").'</a>':'';
|
||||||
|
|
||||||
// Ref
|
// Ref
|
||||||
print '<tr><td width="30%">'.$langs->trans("Ref").'</td><td>';
|
print '<tr><td width="30%">'.$langs->trans("Ref").'</td><td>';
|
||||||
if (! GETPOST('withproject') || empty($project->id))
|
if (empty($withproject) || empty($projectstatic->id))
|
||||||
{
|
{
|
||||||
$projectsListId = $project->getProjectsAuthorizedForUser($user,$mine,1);
|
$projectsListId = $projectstatic->getProjectsAuthorizedForUser($user,$mine,1);
|
||||||
$object->next_prev_filter=" fk_projet in (".$projectsListId.")";
|
$object->next_prev_filter=" fk_projet in (".$projectsListId.")";
|
||||||
}
|
}
|
||||||
else $object->next_prev_filter=" fk_projet = ".$project->id;
|
else $object->next_prev_filter=" fk_projet = ".$projectstatic->id;
|
||||||
print $form->showrefnav($object,'id',$linkback,1,'rowid','ref','',$param);
|
print $form->showrefnav($object,'id',$linkback,1,'rowid','ref','',$param);
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
@@ -158,12 +188,12 @@ if ($id > 0 || ! empty($ref))
|
|||||||
if (empty($withproject))
|
if (empty($withproject))
|
||||||
{
|
{
|
||||||
print '<tr><td>'.$langs->trans("Project").'</td><td colspan="3">';
|
print '<tr><td>'.$langs->trans("Project").'</td><td colspan="3">';
|
||||||
print $project->getNomUrl(1);
|
print $projectstatic->getNomUrl(1);
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Third party
|
// Third party
|
||||||
print '<tr><td>'.$langs->trans("Company").'</td><td>';
|
print '<tr><td>'.$langs->trans("Company").'</td><td>';
|
||||||
if ($project->societe->id > 0) print $project->societe->getNomUrl(1);
|
if ($projectstatic->societe->id > 0) print $projectstatic->societe->getNomUrl(1);
|
||||||
else print' ';
|
else print' ';
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
}
|
}
|
||||||
@@ -180,7 +210,7 @@ if ($id > 0 || ! empty($ref))
|
|||||||
dol_fiche_end();
|
dol_fiche_end();
|
||||||
}
|
}
|
||||||
|
|
||||||
llxFooter();
|
|
||||||
|
|
||||||
|
llxFooter();
|
||||||
$db->close();
|
$db->close();
|
||||||
?>
|
?>
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
<?php
|
<?php
|
||||||
/* Copyright (C) 2005 Rodolphe Quiedeville <rodolphe@quiedeville.org>
|
/* Copyright (C) 2005 Rodolphe Quiedeville <rodolphe@quiedeville.org>
|
||||||
* Copyright (C) 2006-2011 Laurent Destailleur <eldy@users.sourceforge.net>
|
* Copyright (C) 2006-2012 Laurent Destailleur <eldy@users.sourceforge.net>
|
||||||
* Copyright (C) 2010 Regis Houssin <regis@dolibarr.fr>
|
* Copyright (C) 2010-2012 Regis Houssin <regis@dolibarr.fr>
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
@@ -19,7 +19,7 @@
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* \file htdocs/projet/tasks/task.php
|
* \file htdocs/projet/tasks/task.php
|
||||||
* \ingroup projet
|
* \ingroup project
|
||||||
* \brief Page of a project task
|
* \brief Page of a project task
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -29,17 +29,20 @@ require_once(DOL_DOCUMENT_ROOT."/projet/class/task.class.php");
|
|||||||
require_once(DOL_DOCUMENT_ROOT."/core/lib/project.lib.php");
|
require_once(DOL_DOCUMENT_ROOT."/core/lib/project.lib.php");
|
||||||
require_once(DOL_DOCUMENT_ROOT."/core/class/html.formother.class.php");
|
require_once(DOL_DOCUMENT_ROOT."/core/class/html.formother.class.php");
|
||||||
|
|
||||||
$taskid = GETPOST('id','int');
|
$id=GETPOST('id','int');
|
||||||
$taskref = GETPOST("ref");
|
$ref=GETPOST('ref','alpha');
|
||||||
$id = GETPOST('id','int');
|
$action=GETPOST('action','alpha');
|
||||||
$ref= GETPOST('ref');
|
$confirm=GETPOST('confirm','alpha');
|
||||||
$action=GETPOST('action');
|
$withproject=GETPOST('withproject','int');
|
||||||
$withproject=GETPOST('withproject');
|
$project_ref=GETPOST('project_ref','alpha');
|
||||||
|
|
||||||
// Security check
|
// Security check
|
||||||
$socid=0;
|
$socid=0;
|
||||||
if ($user->societe_id > 0) $socid = $user->societe_id;
|
if ($user->societe_id > 0) $socid = $user->societe_id;
|
||||||
if (!$user->rights->projet->lire) accessforbidden();
|
if (! $user->rights->projet->lire) accessforbidden();
|
||||||
|
|
||||||
|
$object = new Task($db);
|
||||||
|
$projectstatic = new Project($db);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -57,44 +60,38 @@ if ($action == 'update' && ! $_POST["cancel"] && $user->rights->projet->creer)
|
|||||||
}
|
}
|
||||||
if (! $error)
|
if (! $error)
|
||||||
{
|
{
|
||||||
$task = new Task($db);
|
$object->fetch($id);
|
||||||
$task->fetch($id);
|
|
||||||
|
|
||||||
$tmparray=explode('_',$_POST['task_parent']);
|
$tmparray=explode('_',$_POST['task_parent']);
|
||||||
$task_parent=$tmparray[1];
|
$task_parent=$tmparray[1];
|
||||||
if (empty($task_parent)) $task_parent = 0; // If task_parent is ''
|
if (empty($task_parent)) $task_parent = 0; // If task_parent is ''
|
||||||
|
|
||||||
$task->label = $_POST["label"];
|
$object->label = $_POST["label"];
|
||||||
$task->description = $_POST['description'];
|
$object->description = $_POST['description'];
|
||||||
$task->fk_task_parent = $task_parent;
|
$object->fk_task_parent = $task_parent;
|
||||||
$task->date_start = dol_mktime(12,0,0,$_POST['dateomonth'],$_POST['dateoday'],$_POST['dateoyear']);
|
$object->date_start = dol_mktime(12,0,0,$_POST['dateomonth'],$_POST['dateoday'],$_POST['dateoyear']);
|
||||||
$task->date_end = dol_mktime(12,0,0,$_POST['dateemonth'],$_POST['dateeday'],$_POST['dateeyear']);
|
$object->date_end = dol_mktime(12,0,0,$_POST['dateemonth'],$_POST['dateeday'],$_POST['dateeyear']);
|
||||||
$task->progress = $_POST['progress'];
|
$object->progress = $_POST['progress'];
|
||||||
|
|
||||||
$result=$task->update($user);
|
$result=$object->update($user);
|
||||||
|
|
||||||
$taskid=$task->id; // On retourne sur la fiche tache
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$taskid=$_POST["id"];
|
|
||||||
$action='edit';
|
$action='edit';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($action == 'confirm_delete' && $_POST["confirm"] == "yes" && $user->rights->projet->supprimer)
|
if ($action == 'confirm_delete' && $confirm == "yes" && $user->rights->projet->supprimer)
|
||||||
{
|
{
|
||||||
$task = new Task($db);
|
if ($object->fetch($id) >= 0 )
|
||||||
if ($task->fetch($id) >= 0 )
|
|
||||||
{
|
{
|
||||||
$projet = new Project($db);
|
$result=$projecstatict->fetch($object->fk_projet);
|
||||||
$result=$projet->fetch($task->fk_projet);
|
if (! empty($projecstatic->socid))
|
||||||
if (! empty($projet->socid))
|
|
||||||
{
|
{
|
||||||
$projet->societe->fetch($projet->socid);
|
$projecstatic->societe->fetch($projecstatic->socid);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($task->delete($user) > 0)
|
if ($object->delete($user) > 0)
|
||||||
{
|
{
|
||||||
Header("Location: index.php");
|
Header("Location: index.php");
|
||||||
exit;
|
exit;
|
||||||
@@ -102,12 +99,28 @@ if ($action == 'confirm_delete' && $_POST["confirm"] == "yes" && $user->rights->
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
$langs->load("errors");
|
$langs->load("errors");
|
||||||
$mesg='<div class="error">'.$langs->trans($task->error).'</div>';
|
$mesg='<div class="error">'.$langs->trans($object->error).'</div>';
|
||||||
$_POST["action"]='';
|
$action='';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Retreive First Task ID of Project if withprojet is on to allow project prev next to work
|
||||||
|
if (! empty($project_ref) && ! empty($withproject))
|
||||||
|
{
|
||||||
|
if ($projectstatic->fetch('',$project_ref) > 0)
|
||||||
|
{
|
||||||
|
$tasksarray=$object->getTasksArray(0, 0, $projectstatic->id, $socid, 0);
|
||||||
|
if (count($tasksarray) > 0)
|
||||||
|
{
|
||||||
|
$id=$tasksarray[0]->id;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Header("Location: ".DOL_URL_ROOT.'/projet/tasks.php?id='.$projectstatic->id.(empty($mode)?'':'&mode='.$mode));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* View
|
* View
|
||||||
@@ -117,24 +130,22 @@ llxHeader("",$langs->trans("Task"));
|
|||||||
|
|
||||||
$form = new Form($db);
|
$form = new Form($db);
|
||||||
$formother = new FormOther($db);
|
$formother = new FormOther($db);
|
||||||
$project = new Project($db);
|
|
||||||
$task = new Task($db);
|
|
||||||
|
|
||||||
if ($taskid)
|
if ($id > 0 || ! empty($ref))
|
||||||
{
|
{
|
||||||
if ($task->fetch($taskid) > 0)
|
if ($object->fetch($id) > 0)
|
||||||
{
|
{
|
||||||
$result=$project->fetch($task->fk_project);
|
$result=$projectstatic->fetch($object->fk_project);
|
||||||
if (! empty($project->socid)) $project->societe->fetch($project->socid);
|
if (! empty($projectstatic->socid)) $projectstatic->societe->fetch($projectstatic->socid);
|
||||||
|
|
||||||
$userWrite = $project->restrictedProjectArea($user,'write');
|
$userWrite = $projectstatic->restrictedProjectArea($user,'write');
|
||||||
|
|
||||||
if ($withproject)
|
if (! empty($withproject))
|
||||||
{
|
{
|
||||||
// Tabs for project
|
// Tabs for project
|
||||||
$tab='tasks';
|
$tab='tasks';
|
||||||
$head=project_prepare_head($project);
|
$head=project_prepare_head($projectstatic);
|
||||||
dol_fiche_head($head, $tab, $langs->trans("Project"),0,($project->public?'projectpub':'project'));
|
dol_fiche_head($head, $tab, $langs->trans("Project"),0,($projectstatic->public?'projectpub':'project'));
|
||||||
|
|
||||||
$param=($mode=='mine'?'&mode=mine':'');
|
$param=($mode=='mine'?'&mode=mine':'');
|
||||||
|
|
||||||
@@ -147,28 +158,28 @@ if ($taskid)
|
|||||||
// Define a complementary filter for search of next/prev ref.
|
// Define a complementary filter for search of next/prev ref.
|
||||||
if (! $user->rights->projet->all->lire)
|
if (! $user->rights->projet->all->lire)
|
||||||
{
|
{
|
||||||
$projectsListId = $project->getProjectsAuthorizedForUser($user,$mine,0);
|
$projectsListId = $projectstatic->getProjectsAuthorizedForUser($user,$mine,0);
|
||||||
$project->next_prev_filter=" rowid in (".(count($projectsListId)?join(',',array_keys($projectsListId)):'0').")";
|
$projectstatic->next_prev_filter=" rowid in (".(count($projectsListId)?join(',',array_keys($projectsListId)):'0').")";
|
||||||
}
|
}
|
||||||
print $form->showrefnav($project,'ref','',1,'ref','ref','',$param);
|
print $form->showrefnav($projectstatic,'project_ref','',1,'ref','ref','',$param.'&withproject=1');
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
print '<tr><td>'.$langs->trans("Label").'</td><td>'.$project->title.'</td></tr>';
|
print '<tr><td>'.$langs->trans("Label").'</td><td>'.$projectstatic->title.'</td></tr>';
|
||||||
|
|
||||||
print '<tr><td>'.$langs->trans("Company").'</td><td>';
|
print '<tr><td>'.$langs->trans("Company").'</td><td>';
|
||||||
if (! empty($project->societe->id)) print $project->societe->getNomUrl(1);
|
if (! empty($projectstatic->societe->id)) print $projectstatic->societe->getNomUrl(1);
|
||||||
else print ' ';
|
else print ' ';
|
||||||
print '</td>';
|
print '</td>';
|
||||||
print '</tr>';
|
print '</tr>';
|
||||||
|
|
||||||
// Visibility
|
// Visibility
|
||||||
print '<tr><td>'.$langs->trans("Visibility").'</td><td>';
|
print '<tr><td>'.$langs->trans("Visibility").'</td><td>';
|
||||||
if ($project->public) print $langs->trans('SharedProject');
|
if ($projectstatic->public) print $langs->trans('SharedProject');
|
||||||
else print $langs->trans('PrivateProject');
|
else print $langs->trans('PrivateProject');
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Statut
|
// Statut
|
||||||
print '<tr><td>'.$langs->trans("Status").'</td><td>'.$project->getLibStatut(4).'</td></tr>';
|
print '<tr><td>'.$langs->trans("Status").'</td><td>'.$projectstatic->getLibStatut(4).'</td></tr>';
|
||||||
|
|
||||||
print '</table>';
|
print '</table>';
|
||||||
|
|
||||||
@@ -184,7 +195,7 @@ if ($taskid)
|
|||||||
|
|
||||||
if ($user->rights->projet->all->creer || $user->rights->projet->creer)
|
if ($user->rights->projet->all->creer || $user->rights->projet->creer)
|
||||||
{
|
{
|
||||||
if ($project->public || $userWrite > 0)
|
if ($projectstatic->public || $userWrite > 0)
|
||||||
{
|
{
|
||||||
print '<a class="butAction" href="'.$_SERVER['PHP_SELF'].'?id='.$object->id.'&action=create'.$param.'">'.$langs->trans('AddTask').'</a>';
|
print '<a class="butAction" href="'.$_SERVER['PHP_SELF'].'?id='.$object->id.'&action=create'.$param.'">'.$langs->trans('AddTask').'</a>';
|
||||||
}
|
}
|
||||||
@@ -202,12 +213,12 @@ if ($taskid)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
// To verify role of users
|
// To verify role of users
|
||||||
//$userAccess = $project->restrictedProjectArea($user); // We allow task affected to user even if a not allowed project
|
//$userAccess = $projectstatic->restrictedProjectArea($user); // We allow task affected to user even if a not allowed project
|
||||||
//$arrayofuseridoftask=$task->getListContactId('internal');
|
//$arrayofuseridoftask=$object->getListContactId('internal');
|
||||||
|
|
||||||
dol_htmloutput_mesg($mesg);
|
dol_htmloutput_mesg($mesg);
|
||||||
|
|
||||||
$head=task_prepare_head($task);
|
$head=task_prepare_head($object);
|
||||||
dol_fiche_head($head, 'task_task', $langs->trans("Task"),0,'projecttask');
|
dol_fiche_head($head, 'task_task', $langs->trans("Task"),0,'projecttask');
|
||||||
|
|
||||||
if ($action == 'edit' && $user->rights->projet->creer)
|
if ($action == 'edit' && $user->rights->projet->creer)
|
||||||
@@ -216,56 +227,56 @@ if ($taskid)
|
|||||||
print '<input type="hidden" name="token" value="'.$_SESSION['newtoken'].'">';
|
print '<input type="hidden" name="token" value="'.$_SESSION['newtoken'].'">';
|
||||||
print '<input type="hidden" name="action" value="update">';
|
print '<input type="hidden" name="action" value="update">';
|
||||||
print '<input type="hidden" name="withproject" value="'.$withproject.'">';
|
print '<input type="hidden" name="withproject" value="'.$withproject.'">';
|
||||||
print '<input type="hidden" name="id" value="'.$task->id.'">';
|
print '<input type="hidden" name="id" value="'.$object->id.'">';
|
||||||
|
|
||||||
print '<table class="border" width="100%">';
|
print '<table class="border" width="100%">';
|
||||||
|
|
||||||
// Ref
|
// Ref
|
||||||
print '<tr><td width="30%">'.$langs->trans("Ref").'</td>';
|
print '<tr><td width="30%">'.$langs->trans("Ref").'</td>';
|
||||||
print '<td>'.$task->ref.'</td></tr>';
|
print '<td>'.$object->ref.'</td></tr>';
|
||||||
|
|
||||||
// Label
|
// Label
|
||||||
print '<tr><td>'.$langs->trans("Label").'</td>';
|
print '<tr><td>'.$langs->trans("Label").'</td>';
|
||||||
print '<td><input size="30" name="label" value="'.$task->label.'"></td></tr>';
|
print '<td><input size="30" name="label" value="'.$object->label.'"></td></tr>';
|
||||||
|
|
||||||
// Project
|
// Project
|
||||||
if (empty($withproject))
|
if (empty($withproject))
|
||||||
{
|
{
|
||||||
print '<tr><td>'.$langs->trans("Project").'</td><td colspan="3">';
|
print '<tr><td>'.$langs->trans("Project").'</td><td colspan="3">';
|
||||||
print $project->getNomUrl(1);
|
print $projectstatic->getNomUrl(1);
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Third party
|
// Third party
|
||||||
print '<td>'.$langs->trans("Company").'</td><td colspan="3">';
|
print '<td>'.$langs->trans("Company").'</td><td colspan="3">';
|
||||||
if ($project->societe->id) print $project->societe->getNomUrl(1);
|
if ($projectstatic->societe->id) print $projectstatic->societe->getNomUrl(1);
|
||||||
else print ' ';
|
else print ' ';
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Task parent
|
// Task parent
|
||||||
print '<tr><td>'.$langs->trans("ChildOfTask").'</td><td>';
|
print '<tr><td>'.$langs->trans("ChildOfTask").'</td><td>';
|
||||||
print $formother->selectProjectTasks($task->fk_task_parent,$project->id, 'task_parent', $user->admin?0:1, 0);
|
print $formother->selectProjectTasks($object->fk_task_parent,$projectstatic->id, 'task_parent', $user->admin?0:1, 0);
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Date start
|
// Date start
|
||||||
print '<tr><td>'.$langs->trans("DateStart").'</td><td>';
|
print '<tr><td>'.$langs->trans("DateStart").'</td><td>';
|
||||||
print $form->select_date($task->date_start,'dateo');
|
print $form->select_date($object->date_start,'dateo');
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Date end
|
// Date end
|
||||||
print '<tr><td>'.$langs->trans("DateEnd").'</td><td>';
|
print '<tr><td>'.$langs->trans("DateEnd").'</td><td>';
|
||||||
print $form->select_date($task->date_end?$task->date_end:-1,'datee');
|
print $form->select_date($object->date_end?$object->date_end:-1,'datee');
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Progress
|
// Progress
|
||||||
print '<tr><td>'.$langs->trans("Progress").'</td><td colspan="3">';
|
print '<tr><td>'.$langs->trans("Progress").'</td><td colspan="3">';
|
||||||
print $formother->select_percent($task->progress,'progress');
|
print $formother->select_percent($object->progress,'progress');
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Description
|
// Description
|
||||||
print '<tr><td valign="top">'.$langs->trans("Description").'</td>';
|
print '<tr><td valign="top">'.$langs->trans("Description").'</td>';
|
||||||
print '<td>';
|
print '<td>';
|
||||||
print '<textarea name="description" wrap="soft" cols="80" rows="'.ROWS_3.'">'.$task->description.'</textarea>';
|
print '<textarea name="description" wrap="soft" cols="80" rows="'.ROWS_3.'">'.$object->description.'</textarea>';
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
print '</table>';
|
print '</table>';
|
||||||
@@ -283,7 +294,7 @@ if ($taskid)
|
|||||||
* Fiche tache en mode visu
|
* Fiche tache en mode visu
|
||||||
*/
|
*/
|
||||||
$param=($withproject?'&withproject=1':'');
|
$param=($withproject?'&withproject=1':'');
|
||||||
$linkback=$withproject?'<a href="'.DOL_URL_ROOT.'/projet/tasks.php?id='.$project->id.'">'.$langs->trans("BackToList").'</a>':'';
|
$linkback=$withproject?'<a href="'.DOL_URL_ROOT.'/projet/tasks.php?id='.$projectstatic->id.'">'.$langs->trans("BackToList").'</a>':'';
|
||||||
|
|
||||||
if ($action == 'delete')
|
if ($action == 'delete')
|
||||||
{
|
{
|
||||||
@@ -297,51 +308,51 @@ if ($taskid)
|
|||||||
print '<tr><td width="30%">';
|
print '<tr><td width="30%">';
|
||||||
print $langs->trans("Ref");
|
print $langs->trans("Ref");
|
||||||
print '</td><td colspan="3">';
|
print '</td><td colspan="3">';
|
||||||
if (! GETPOST('withproject') || empty($project->id))
|
if (! GETPOST('withproject') || empty($projectstatic->id))
|
||||||
{
|
{
|
||||||
$projectsListId = $project->getProjectsAuthorizedForUser($user,$mine,1);
|
$projectsListId = $projectstatic->getProjectsAuthorizedForUser($user,$mine,1);
|
||||||
$task->next_prev_filter=" fk_projet in (".$projectsListId.")";
|
$object->next_prev_filter=" fk_projet in (".$projectsListId.")";
|
||||||
}
|
}
|
||||||
else $task->next_prev_filter=" fk_projet = ".$project->id;
|
else $object->next_prev_filter=" fk_projet = ".$projectstatic->id;
|
||||||
print $form->showrefnav($task,'id',$linkback,1,'rowid','ref','',$param);
|
print $form->showrefnav($object,'id',$linkback,1,'rowid','ref','',$param);
|
||||||
print '</td>';
|
print '</td>';
|
||||||
print '</tr>';
|
print '</tr>';
|
||||||
|
|
||||||
// Label
|
// Label
|
||||||
print '<tr><td>'.$langs->trans("Label").'</td><td colspan="3">'.$task->label.'</td></tr>';
|
print '<tr><td>'.$langs->trans("Label").'</td><td colspan="3">'.$object->label.'</td></tr>';
|
||||||
|
|
||||||
// Project
|
// Project
|
||||||
if (empty($withproject))
|
if (empty($withproject))
|
||||||
{
|
{
|
||||||
print '<tr><td>'.$langs->trans("Project").'</td><td colspan="3">';
|
print '<tr><td>'.$langs->trans("Project").'</td><td colspan="3">';
|
||||||
print $project->getNomUrl(1);
|
print $projectstatic->getNomUrl(1);
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Third party
|
// Third party
|
||||||
print '<td>'.$langs->trans("Company").'</td><td colspan="3">';
|
print '<td>'.$langs->trans("Company").'</td><td colspan="3">';
|
||||||
if ($project->societe->id) print $project->societe->getNomUrl(1);
|
if ($projectstatic->societe->id) print $projectstatic->societe->getNomUrl(1);
|
||||||
else print ' ';
|
else print ' ';
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Date start
|
// Date start
|
||||||
print '<tr><td>'.$langs->trans("DateStart").'</td><td colspan="3">';
|
print '<tr><td>'.$langs->trans("DateStart").'</td><td colspan="3">';
|
||||||
print dol_print_date($task->date_start,'day');
|
print dol_print_date($object->date_start,'day');
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Date end
|
// Date end
|
||||||
print '<tr><td>'.$langs->trans("DateEnd").'</td><td colspan="3">';
|
print '<tr><td>'.$langs->trans("DateEnd").'</td><td colspan="3">';
|
||||||
print dol_print_date($task->date_end,'day');
|
print dol_print_date($object->date_end,'day');
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Progress
|
// Progress
|
||||||
print '<tr><td>'.$langs->trans("Progress").'</td><td colspan="3">';
|
print '<tr><td>'.$langs->trans("Progress").'</td><td colspan="3">';
|
||||||
print $task->progress.' %';
|
print $object->progress.' %';
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Description
|
// Description
|
||||||
print '<td valign="top">'.$langs->trans("Description").'</td><td colspan="3">';
|
print '<td valign="top">'.$langs->trans("Description").'</td><td colspan="3">';
|
||||||
print nl2br($task->description);
|
print nl2br($object->description);
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
print '</table>';
|
print '</table>';
|
||||||
@@ -361,7 +372,7 @@ if ($taskid)
|
|||||||
// Modify
|
// Modify
|
||||||
if ($user->rights->projet->creer)
|
if ($user->rights->projet->creer)
|
||||||
{
|
{
|
||||||
print '<a class="butAction" href="'.$_SERVER['PHP_SELF'].'?id='.$task->id.'&action=edit&withproject='.$withproject.'">'.$langs->trans('Modify').'</a>';
|
print '<a class="butAction" href="'.$_SERVER['PHP_SELF'].'?id='.$object->id.'&action=edit&withproject='.$withproject.'">'.$langs->trans('Modify').'</a>';
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -369,9 +380,9 @@ if ($taskid)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Delete
|
// Delete
|
||||||
if ($user->rights->projet->supprimer && ! $task->hasChildren())
|
if ($user->rights->projet->supprimer && ! $object->hasChildren())
|
||||||
{
|
{
|
||||||
print '<a class="butActionDelete" href="'.$_SERVER['PHP_SELF'].'?id='.$task->id.'&action=delete&withproject='.$withproject.'">'.$langs->trans('Delete').'</a>';
|
print '<a class="butActionDelete" href="'.$_SERVER['PHP_SELF'].'?id='.$object->id.'&action=delete&withproject='.$withproject.'">'.$langs->trans('Delete').'</a>';
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -385,6 +396,5 @@ if ($taskid)
|
|||||||
|
|
||||||
|
|
||||||
llxFooter();
|
llxFooter();
|
||||||
|
|
||||||
$db->close();
|
$db->close();
|
||||||
?>
|
?>
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
/* Copyright (C) 2005 Rodolphe Quiedeville <rodolphe@quiedeville.org>
|
/* Copyright (C) 2005 Rodolphe Quiedeville <rodolphe@quiedeville.org>
|
||||||
* Copyright (C) 2006-2012 Laurent Destailleur <eldy@users.sourceforge.net>
|
* Copyright (C) 2006-2012 Laurent Destailleur <eldy@users.sourceforge.net>
|
||||||
* Copyright (C) 2010 Regis Houssin <regis@dolibarr.fr>
|
* Copyright (C) 2010-2012 Regis Houssin <regis@dolibarr.fr>
|
||||||
* Copyright (C) 2011 Juanjo Menent <jmenent@2byte.es>
|
* Copyright (C) 2011 Juanjo Menent <jmenent@2byte.es>
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
@@ -20,7 +20,7 @@
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* \file htdocs/projet/tasks/time.php
|
* \file htdocs/projet/tasks/time.php
|
||||||
* \ingroup projet
|
* \ingroup project
|
||||||
* \brief Page to add new time spent on a task
|
* \brief Page to add new time spent on a task
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -32,17 +32,21 @@ require_once(DOL_DOCUMENT_ROOT."/core/lib/date.lib.php");
|
|||||||
|
|
||||||
$langs->load('projects');
|
$langs->load('projects');
|
||||||
|
|
||||||
$taskid = isset($_GET["id"])?$_GET["id"]:'';
|
$id=GETPOST('id','int');
|
||||||
$id = GETPOST('id','int');
|
$ref=GETPOST('ref','alpha');
|
||||||
$ref= GETPOST('ref');
|
$action=GETPOST('action','alpha');
|
||||||
$action=GETPOST('action');
|
$confirm=GETPOST('confirm','alpha');
|
||||||
$withproject=GETPOST('withproject');
|
$withproject=GETPOST('withproject','int');
|
||||||
|
$project_ref=GETPOST('project_ref','alpha');
|
||||||
|
|
||||||
// Security check
|
// Security check
|
||||||
$socid=0;
|
$socid=0;
|
||||||
if ($user->societe_id > 0) $socid = $user->societe_id;
|
if ($user->societe_id > 0) $socid = $user->societe_id;
|
||||||
if (!$user->rights->projet->lire) accessforbidden();
|
if (!$user->rights->projet->lire) accessforbidden();
|
||||||
|
|
||||||
|
$object = new Task($db);
|
||||||
|
$projectstatic = new Project($db);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Actions
|
* Actions
|
||||||
@@ -64,28 +68,27 @@ if ($action == 'addtimespent' && $user->rights->projet->creer)
|
|||||||
|
|
||||||
if (! $error)
|
if (! $error)
|
||||||
{
|
{
|
||||||
$task = new Task($db);
|
$object->fetch($id);
|
||||||
$task->fetch($_POST["id"]);
|
|
||||||
|
|
||||||
$task->timespent_note = $_POST["timespent_note"];
|
$object->timespent_note = $_POST["timespent_note"];
|
||||||
$task->timespent_duration = $_POST["timespent_durationhour"]*60*60; // We store duration in seconds
|
$object->timespent_duration = $_POST["timespent_durationhour"]*60*60; // We store duration in seconds
|
||||||
$task->timespent_duration+= $_POST["timespent_durationmin"]*60; // We store duration in seconds
|
$object->timespent_duration+= $_POST["timespent_durationmin"]*60; // We store duration in seconds
|
||||||
$task->timespent_date = dol_mktime(12,0,0,$_POST["timemonth"],$_POST["timeday"],$_POST["timeyear"]);
|
$object->timespent_date = dol_mktime(12,0,0,$_POST["timemonth"],$_POST["timeday"],$_POST["timeyear"]);
|
||||||
$task->timespent_fk_user = $_POST["userid"];
|
$object->timespent_fk_user = $_POST["userid"];
|
||||||
|
|
||||||
$result=$task->addTimeSpent($user);
|
$result=$object->addTimeSpent($user);
|
||||||
if ($result >= 0)
|
if ($result >= 0)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$mesg='<div class="error">'.$langs->trans($task->error).'</div>';
|
$mesg='<div class="error">'.$langs->trans($object->error).'</div>';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$_POST["action"]='';
|
$action='';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -101,44 +104,59 @@ if ($action == 'updateline' && ! $_POST["cancel"] && $user->rights->projet->cree
|
|||||||
|
|
||||||
if (! $error)
|
if (! $error)
|
||||||
{
|
{
|
||||||
$task = new Task($db);
|
$object->fetch($id);
|
||||||
$task->fetch($_POST["id"]);
|
|
||||||
|
|
||||||
$task->timespent_id = $_POST["lineid"];
|
$object->timespent_id = $_POST["lineid"];
|
||||||
$task->timespent_note = $_POST["timespent_note_line"];
|
$object->timespent_note = $_POST["timespent_note_line"];
|
||||||
$task->timespent_old_duration = $_POST["old_duration"];
|
$object->timespent_old_duration = $_POST["old_duration"];
|
||||||
$task->timespent_duration = $_POST["new_durationhour"]*60*60; // We store duration in seconds
|
$object->timespent_duration = $_POST["new_durationhour"]*60*60; // We store duration in seconds
|
||||||
$task->timespent_duration+= $_POST["new_durationmin"]*60; // We store duration in seconds
|
$object->timespent_duration+= $_POST["new_durationmin"]*60; // We store duration in seconds
|
||||||
$task->timespent_date = dol_mktime(12,0,0,$_POST["timelinemonth"],$_POST["timelineday"],$_POST["timelineyear"]);
|
$object->timespent_date = dol_mktime(12,0,0,$_POST["timelinemonth"],$_POST["timelineday"],$_POST["timelineyear"]);
|
||||||
$task->timespent_fk_user = $_POST["userid_line"];
|
$object->timespent_fk_user = $_POST["userid_line"];
|
||||||
|
|
||||||
$result=$task->updateTimeSpent($user);
|
$result=$object->updateTimeSpent($user);
|
||||||
if ($result >= 0)
|
if ($result >= 0)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$mesg='<div class="error">'.$langs->trans($task->error).'</div>';
|
$mesg='<div class="error">'.$langs->trans($object->error).'</div>';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$_POST["action"]='';
|
$action='';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($action == 'confirm_delete' && $_REQUEST["confirm"] == "yes" && $user->rights->projet->creer)
|
if ($action == 'confirm_delete' && $confirm == "yes" && $user->rights->projet->creer)
|
||||||
{
|
{
|
||||||
$task = new Task($db);
|
$object->fetchTimeSpent($_GET['lineid']);
|
||||||
$task->fetchTimeSpent($_GET['lineid']);
|
$result = $object->delTimeSpent($user);
|
||||||
$result = $task->delTimeSpent($user);
|
|
||||||
|
|
||||||
if (!$result)
|
if (!$result)
|
||||||
{
|
{
|
||||||
$langs->load("errors");
|
$langs->load("errors");
|
||||||
$mesg='<div class="error">'.$langs->trans($task->error).'</div>';
|
$mesg='<div class="error">'.$langs->trans($object->error).'</div>';
|
||||||
$_POST["action"]='';
|
$action='';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Retreive First Task ID of Project if withprojet is on to allow project prev next to work
|
||||||
|
if (! empty($project_ref) && ! empty($withproject))
|
||||||
|
{
|
||||||
|
if ($projectstatic->fetch(0,$project_ref) > 0)
|
||||||
|
{
|
||||||
|
$tasksarray=$object->getTasksArray(0, 0, $projectstatic->id, $socid, 0);
|
||||||
|
if (count($tasksarray) > 0)
|
||||||
|
{
|
||||||
|
$id=$tasksarray[0]->id;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Header("Location: ".DOL_URL_ROOT.'/projet/tasks.php?id='.$projectstatic->id.(empty($mode)?'':'&mode='.$mode));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -147,10 +165,6 @@ if ($action == 'confirm_delete' && $_REQUEST["confirm"] == "yes" && $user->right
|
|||||||
* View
|
* View
|
||||||
*/
|
*/
|
||||||
|
|
||||||
$form = new Form($db);
|
|
||||||
$project = new Project($db);
|
|
||||||
$task = new Task($db);
|
|
||||||
|
|
||||||
llxHeader("",$langs->trans("Task"));
|
llxHeader("",$langs->trans("Task"));
|
||||||
|
|
||||||
$form = new Form($db);
|
$form = new Form($db);
|
||||||
@@ -160,19 +174,19 @@ if ($id > 0 || ! empty($ref))
|
|||||||
/*
|
/*
|
||||||
* Fiche projet en mode visu
|
* Fiche projet en mode visu
|
||||||
*/
|
*/
|
||||||
if ($task->fetch($id,$ref) >= 0)
|
if ($object->fetch($id) >= 0)
|
||||||
{
|
{
|
||||||
$result=$project->fetch($task->fk_project);
|
$result=$projectstatic->fetch($object->fk_project);
|
||||||
if (! empty($project->socid)) $project->societe->fetch($project->socid);
|
if (! empty($projectstatic->socid)) $projectstatic->societe->fetch($projectstatic->socid);
|
||||||
|
|
||||||
$userWrite = $project->restrictedProjectArea($user,'write');
|
$userWrite = $projectstatic->restrictedProjectArea($user,'write');
|
||||||
|
|
||||||
if ($withproject)
|
if ($withproject)
|
||||||
{
|
{
|
||||||
// Tabs for project
|
// Tabs for project
|
||||||
$tab='tasks';
|
$tab='tasks';
|
||||||
$head=project_prepare_head($project);
|
$head=project_prepare_head($projectstatic);
|
||||||
dol_fiche_head($head, $tab, $langs->trans("Project"),0,($project->public?'projectpub':'project'));
|
dol_fiche_head($head, $tab, $langs->trans("Project"),0,($projectstatic->public?'projectpub':'project'));
|
||||||
|
|
||||||
$param=($mode=='mine'?'&mode=mine':'');
|
$param=($mode=='mine'?'&mode=mine':'');
|
||||||
|
|
||||||
@@ -185,28 +199,28 @@ if ($id > 0 || ! empty($ref))
|
|||||||
// Define a complementary filter for search of next/prev ref.
|
// Define a complementary filter for search of next/prev ref.
|
||||||
if (! $user->rights->projet->all->lire)
|
if (! $user->rights->projet->all->lire)
|
||||||
{
|
{
|
||||||
$projectsListId = $project->getProjectsAuthorizedForUser($user,$mine,0);
|
$projectsListId = $projectstatic->getProjectsAuthorizedForUser($user,$mine,0);
|
||||||
$project->next_prev_filter=" rowid in (".(count($projectsListId)?join(',',array_keys($projectsListId)):'0').")";
|
$projectstatic->next_prev_filter=" rowid in (".(count($projectsListId)?join(',',array_keys($projectsListId)):'0').")";
|
||||||
}
|
}
|
||||||
print $form->showrefnav($project,'ref','',1,'ref','ref','',$param);
|
print $form->showrefnav($projectstatic,'project_ref','',1,'ref','ref','',$param.'&withproject=1');
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
print '<tr><td>'.$langs->trans("Label").'</td><td>'.$project->title.'</td></tr>';
|
print '<tr><td>'.$langs->trans("Label").'</td><td>'.$projectstatic->title.'</td></tr>';
|
||||||
|
|
||||||
print '<tr><td>'.$langs->trans("Company").'</td><td>';
|
print '<tr><td>'.$langs->trans("Company").'</td><td>';
|
||||||
if (! empty($project->societe->id)) print $project->societe->getNomUrl(1);
|
if (! empty($projectstatic->societe->id)) print $projectstatic->societe->getNomUrl(1);
|
||||||
else print ' ';
|
else print ' ';
|
||||||
print '</td>';
|
print '</td>';
|
||||||
print '</tr>';
|
print '</tr>';
|
||||||
|
|
||||||
// Visibility
|
// Visibility
|
||||||
print '<tr><td>'.$langs->trans("Visibility").'</td><td>';
|
print '<tr><td>'.$langs->trans("Visibility").'</td><td>';
|
||||||
if ($project->public) print $langs->trans('SharedProject');
|
if ($projectstatic->public) print $langs->trans('SharedProject');
|
||||||
else print $langs->trans('PrivateProject');
|
else print $langs->trans('PrivateProject');
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Statut
|
// Statut
|
||||||
print '<tr><td>'.$langs->trans("Status").'</td><td>'.$project->getLibStatut(4).'</td></tr>';
|
print '<tr><td>'.$langs->trans("Status").'</td><td>'.$projectstatic->getLibStatut(4).'</td></tr>';
|
||||||
|
|
||||||
print '</table>';
|
print '</table>';
|
||||||
|
|
||||||
@@ -215,48 +229,48 @@ if ($id > 0 || ! empty($ref))
|
|||||||
print '<br>';
|
print '<br>';
|
||||||
}
|
}
|
||||||
|
|
||||||
$head=task_prepare_head($task);
|
$head=task_prepare_head($object);
|
||||||
dol_fiche_head($head, 'task_time', $langs->trans("Task"),0,'projecttask');
|
dol_fiche_head($head, 'task_time', $langs->trans("Task"),0,'projecttask');
|
||||||
|
|
||||||
dol_htmloutput_mesg($mesg);
|
dol_htmloutput_mesg($mesg);
|
||||||
|
|
||||||
if ($action == 'deleteline')
|
if ($action == 'deleteline')
|
||||||
{
|
{
|
||||||
$ret=$form->form_confirm($_SERVER["PHP_SELF"]."?id=".$_GET["id"].'&lineid='.$_GET["lineid"],$langs->trans("DeleteATimeSpent"),$langs->trans("ConfirmDeleteATimeSpent"),"confirm_delete",'','',1);
|
$ret=$form->form_confirm($_SERVER["PHP_SELF"]."?id=".$object->id.'&lineid='.$_GET["lineid"],$langs->trans("DeleteATimeSpent"),$langs->trans("ConfirmDeleteATimeSpent"),"confirm_delete",'','',1);
|
||||||
if ($ret == 'html') print '<br>';
|
if ($ret == 'html') print '<br>';
|
||||||
}
|
}
|
||||||
|
|
||||||
print '<table class="border" width="100%">';
|
print '<table class="border" width="100%">';
|
||||||
|
|
||||||
$param=($withproject?'&withproject=1':'');
|
$param=($withproject?'&withproject=1':'');
|
||||||
$linkback=$withproject?'<a href="'.DOL_URL_ROOT.'/projet/tasks.php?id='.$project->id.'">'.$langs->trans("BackToList").'</a>':'';
|
$linkback=$withproject?'<a href="'.DOL_URL_ROOT.'/projet/tasks.php?id='.$projectstatic->id.'">'.$langs->trans("BackToList").'</a>':'';
|
||||||
|
|
||||||
// Ref
|
// Ref
|
||||||
print '<tr><td width="30%">';
|
print '<tr><td width="30%">';
|
||||||
print $langs->trans("Ref");
|
print $langs->trans("Ref");
|
||||||
print '</td><td colspan="3">';
|
print '</td><td colspan="3">';
|
||||||
if (! GETPOST('withproject') || empty($project->id))
|
if (! GETPOST('withproject') || empty($projectstatic->id))
|
||||||
{
|
{
|
||||||
$projectsListId = $project->getProjectsAuthorizedForUser($user,$mine,1);
|
$projectsListId = $projectstatic->getProjectsAuthorizedForUser($user,$mine,1);
|
||||||
$task->next_prev_filter=" fk_projet in (".$projectsListId.")";
|
$object->next_prev_filter=" fk_projet in (".$projectsListId.")";
|
||||||
}
|
}
|
||||||
else $task->next_prev_filter=" fk_projet = ".$project->id;
|
else $object->next_prev_filter=" fk_projet = ".$projectstatic->id;
|
||||||
print $form->showrefnav($task,'id',$linkback,1,'rowid','ref','',$param);
|
print $form->showrefnav($object,'id',$linkback,1,'rowid','ref','',$param);
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Label
|
// Label
|
||||||
print '<tr><td>'.$langs->trans("Label").'</td><td colspan="3">'.$task->label.'</td></tr>';
|
print '<tr><td>'.$langs->trans("Label").'</td><td colspan="3">'.$object->label.'</td></tr>';
|
||||||
|
|
||||||
// Project
|
// Project
|
||||||
if (empty($withproject))
|
if (empty($withproject))
|
||||||
{
|
{
|
||||||
print '<tr><td>'.$langs->trans("Project").'</td><td>';
|
print '<tr><td>'.$langs->trans("Project").'</td><td>';
|
||||||
print $project->getNomUrl(1);
|
print $projectstatic->getNomUrl(1);
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
|
|
||||||
// Third party
|
// Third party
|
||||||
print '<td>'.$langs->trans("Company").'</td><td>';
|
print '<td>'.$langs->trans("Company").'</td><td>';
|
||||||
if ($project->societe->id) print $project->societe->getNomUrl(1);
|
if ($projectstatic->societe->id) print $projectstatic->societe->getNomUrl(1);
|
||||||
else print ' ';
|
else print ' ';
|
||||||
print '</td></tr>';
|
print '</td></tr>';
|
||||||
}
|
}
|
||||||
@@ -273,10 +287,10 @@ if ($id > 0 || ! empty($ref))
|
|||||||
{
|
{
|
||||||
print '<br>';
|
print '<br>';
|
||||||
|
|
||||||
print '<form method="POST" action="'.$_SERVER["PHP_SELF"].'?id='.$task->id.'">';
|
print '<form method="POST" action="'.$_SERVER["PHP_SELF"].'?id='.$object->id.'">';
|
||||||
print '<input type="hidden" name="token" value="'.$_SESSION['newtoken'].'">';
|
print '<input type="hidden" name="token" value="'.$_SESSION['newtoken'].'">';
|
||||||
print '<input type="hidden" name="action" value="addtimespent">';
|
print '<input type="hidden" name="action" value="addtimespent">';
|
||||||
print '<input type="hidden" name="id" value="'.$task->id.'">';
|
print '<input type="hidden" name="id" value="'.$object->id.'">';
|
||||||
|
|
||||||
print '<table class="noborder" width="100%">';
|
print '<table class="noborder" width="100%">';
|
||||||
|
|
||||||
@@ -298,7 +312,7 @@ if ($id > 0 || ! empty($ref))
|
|||||||
|
|
||||||
// Contributor
|
// Contributor
|
||||||
print '<td nowrap="nowrap">';
|
print '<td nowrap="nowrap">';
|
||||||
$contactoftask=$task->getListContactId('internal');
|
$contactoftask=$object->getListContactId('internal');
|
||||||
print img_object('','user');
|
print img_object('','user');
|
||||||
print $form->select_users($_POST["userid"]?$_POST["userid"]:$user->id,'userid',0,'',0,'',$contactoftask);
|
print $form->select_users($_POST["userid"]?$_POST["userid"]:$user->id,'userid',0,'',0,'',$contactoftask);
|
||||||
print '</td>';
|
print '</td>';
|
||||||
@@ -329,7 +343,7 @@ if ($id > 0 || ! empty($ref))
|
|||||||
$sql.= ", u.name, u.firstname";
|
$sql.= ", u.name, u.firstname";
|
||||||
$sql .= " FROM ".MAIN_DB_PREFIX."projet_task_time as t";
|
$sql .= " FROM ".MAIN_DB_PREFIX."projet_task_time as t";
|
||||||
$sql .= " , ".MAIN_DB_PREFIX."user as u";
|
$sql .= " , ".MAIN_DB_PREFIX."user as u";
|
||||||
$sql .= " WHERE t.fk_task =".$task->id;
|
$sql .= " WHERE t.fk_task =".$object->id;
|
||||||
$sql .= " AND t.fk_user = u.rowid";
|
$sql .= " AND t.fk_user = u.rowid";
|
||||||
$sql .= " ORDER BY t.task_date DESC";
|
$sql .= " ORDER BY t.task_date DESC";
|
||||||
|
|
||||||
@@ -353,10 +367,10 @@ if ($id > 0 || ! empty($ref))
|
|||||||
dol_print_error($db);
|
dol_print_error($db);
|
||||||
}
|
}
|
||||||
|
|
||||||
print '<form method="POST" action="'.$_SERVER["PHP_SELF"].'?id='.$task->id.'">';
|
print '<form method="POST" action="'.$_SERVER["PHP_SELF"].'?id='.$object->id.'">';
|
||||||
print '<input type="hidden" name="token" value="'.$_SESSION['newtoken'].'">';
|
print '<input type="hidden" name="token" value="'.$_SESSION['newtoken'].'">';
|
||||||
print '<input type="hidden" name="action" value="updateline">';
|
print '<input type="hidden" name="action" value="updateline">';
|
||||||
print '<input type="hidden" name="id" value="'.$task->id.'">';
|
print '<input type="hidden" name="id" value="'.$object->id.'">';
|
||||||
|
|
||||||
print '<table class="noborder" width="100%">';
|
print '<table class="noborder" width="100%">';
|
||||||
print '<tr class="liste_titre">';
|
print '<tr class="liste_titre">';
|
||||||
@@ -427,7 +441,7 @@ if ($id > 0 || ! empty($ref))
|
|||||||
|
|
||||||
// Edit and delete icon
|
// Edit and delete icon
|
||||||
print '<td align="center" valign="middle" width="80">';
|
print '<td align="center" valign="middle" width="80">';
|
||||||
if ($_GET['action'] == 'editline' && $_GET['lineid'] == $task_time->rowid)
|
if ($action == 'editline' && $_GET['lineid'] == $task_time->rowid)
|
||||||
{
|
{
|
||||||
print '<input type="hidden" name="lineid" value="'.$_GET['lineid'].'">';
|
print '<input type="hidden" name="lineid" value="'.$_GET['lineid'].'">';
|
||||||
print '<input type="submit" class="button" name="save" value="'.$langs->trans("Save").'">';
|
print '<input type="submit" class="button" name="save" value="'.$langs->trans("Save").'">';
|
||||||
@@ -437,12 +451,12 @@ if ($id > 0 || ! empty($ref))
|
|||||||
else if ($user->rights->projet->creer)
|
else if ($user->rights->projet->creer)
|
||||||
{
|
{
|
||||||
print ' ';
|
print ' ';
|
||||||
print '<a href="'.$_SERVER["PHP_SELF"].'?id='.$task->id.'&action=editline&lineid='.$task_time->rowid.'">';
|
print '<a href="'.$_SERVER["PHP_SELF"].'?id='.$object->id.'&action=editline&lineid='.$task_time->rowid.'">';
|
||||||
print img_edit();
|
print img_edit();
|
||||||
print '</a>';
|
print '</a>';
|
||||||
|
|
||||||
print ' ';
|
print ' ';
|
||||||
print '<a href="'.$_SERVER["PHP_SELF"].'?id='.$task->id.'&action=deleteline&lineid='.$task_time->rowid.'">';
|
print '<a href="'.$_SERVER["PHP_SELF"].'?id='.$object->id.'&action=deleteline&lineid='.$task_time->rowid.'">';
|
||||||
print img_delete();
|
print img_delete();
|
||||||
print '</a>';
|
print '</a>';
|
||||||
}
|
}
|
||||||
@@ -460,7 +474,7 @@ if ($id > 0 || ! empty($ref))
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$db->close();
|
|
||||||
|
|
||||||
llxFooter();
|
llxFooter();
|
||||||
|
$db->close();
|
||||||
?>
|
?>
|
||||||
|
|||||||
Reference in New Issue
Block a user