diff --git a/htdocs/comm/action/document.php b/htdocs/comm/action/document.php
index 042f330b199..6a576c580ca 100755
--- a/htdocs/comm/action/document.php
+++ b/htdocs/comm/action/document.php
@@ -51,6 +51,19 @@ if ($user->societe_id > 0)
$socid = $user->societe_id;
}
+$act = new ActionComm($db);
+
+if ($objectid > 0)
+{
+ $ret = $act->fetch($objectid);
+ if ($ret > 0) {
+ $company=new Societe($db);
+ $company->fetch($act->societe->id);
+ $act->societe=$company; // For backward compatibility
+ $act->thirdparty=$company;
+ }
+}
+
// Get parameters
$sortfield = GETPOST("sortfield",'alpha');
$sortorder = GETPOST("sortorder",'alpha');
@@ -79,7 +92,7 @@ if ($action == 'delete')
{
$upload_dir = $conf->agenda->dir_output.'/'.dol_sanitizeFileName($objectid);
$file = $upload_dir . '/' . $_GET['urlfile']; // Do not use urldecode here ($_GET and $_REQUEST are already decoded by PHP).
- $ret=dol_delete_file($file);
+ $ret=dol_delete_file($file,0,0,0,$act);
if ($ret) setEventMessage($langs->trans("FileWasRemoved", GETPOST('urlfile')));
else setEventMessage($langs->trans("ErrorFailToDeleteFile", GETPOST('urlfile')), 'errors');
$action='';
@@ -96,184 +109,172 @@ $help_url='EN:Module_Agenda_En|FR:Module_Agenda|ES:M&omodulodulo_Agenda';
llxHeader('',$langs->trans("Agenda"),$help_url);
-if ($objectid > 0)
+if ($act->id > 0)
{
- $act = new ActionComm($db);
- if ($act->fetch($objectid))
+ $upload_dir = $conf->agenda->dir_output.'/'.dol_sanitizeFileName($objectid);
+
+ $author=new User($db);
+ $author->fetch($act->author->id);
+ $act->author=$author;
+
+ if ($act->contact->id) $act->fetch_contact($act->contact->id);
+
+ $head=actions_prepare_head($act);
+ dol_fiche_head($head, 'documents', $langs->trans("Action"),0,'action');
+
+ // Affichage fiche action en mode visu
+ print '
';
+
+ $linkback = ''.$langs->trans("BackToList").'';
+
+ // Ref
+ print '| '.$langs->trans("Ref").' | ';
+ print $form->showrefnav($act, 'id', $linkback, ($user->societe_id?0:1), 'id', 'ref', '');
+ print ' |
';
+
+ // Type
+ if (! empty($conf->global->AGENDA_USE_EVENT_TYPE))
{
- $upload_dir = $conf->agenda->dir_output.'/'.dol_sanitizeFileName($objectid);
+ print '| '.$langs->trans("Type").' | '.$act->type.' |
';
+ }
- $company=new Societe($db);
- $company->fetch($act->societe->id);
- $act->societe=$company;
+ // Title
+ print '| '.$langs->trans("Title").' | '.$act->label.' |
';
- $author=new User($db);
- $author->fetch($act->author->id);
- $act->author=$author;
+ // Full day event
+ print '| '.$langs->trans("EventOnFullDay").' | '.yn($act->fulldayevent).' |
';
- if ($act->contact->id) $act->fetch_contact($act->contact->id);
+ // Date start
+ print '| '.$langs->trans("DateActionStart").' | ';
+ if (! $act->fulldayevent) print dol_print_date($act->datep,'dayhour');
+ else print dol_print_date($act->datep,'day');
+ if ($act->percentage == 0 && $act->datep && $act->datep < ($now - $delay_warning)) print img_warning($langs->trans("Late"));
+ print ' | ';
+ print ''."\n";
+ print ''."\n";
+ print ''."\n";
+ print ''."\n";
+ print ' | ';
+ print '
';
- $head=actions_prepare_head($act);
- dol_fiche_head($head, 'documents', $langs->trans("Action"),0,'action');
+ // Date end
+ print '| '.$langs->trans("DateActionEnd").' | ';
+ if (! $act->fulldayevent) print dol_print_date($act->datef,'dayhour');
+ else print dol_print_date($act->datef,'day');
+ if ($act->percentage > 0 && $act->percentage < 100 && $act->datef && $act->datef < ($now- $delay_warning)) print img_warning($langs->trans("Late"));
+ print ' |
';
- // Affichage fiche action en mode visu
- print '';
+ // Status
+ print '| '.$langs->trans("Status").' / '.$langs->trans("Percentage").' | ';
+ print $act->getLibStatut(4);
+ print ' |
';
- $linkback = ''.$langs->trans("BackToList").'';
+ // Location
+ print '| '.$langs->trans("Location").' | '.$act->location.' |
';
- // Ref
- print '| '.$langs->trans("Ref").' | ';
- print $form->showrefnav($act, 'id', $linkback, ($user->societe_id?0:1), 'id', 'ref', '');
- print ' |
';
- // Type
- if (! empty($conf->global->AGENDA_USE_EVENT_TYPE))
+ print '
';
+
+
+ // Third party - Contact
+ print '| '.$langs->trans("ActionOnCompany").' | '.($act->societe->id?$act->societe->getNomUrl(1):$langs->trans("None"));
+ if ($act->societe->id && $act->type_code == 'AC_TEL')
+ {
+ if ($act->societe->fetch($act->societe->id))
{
- print ' |
| '.$langs->trans("Type").' | '.$act->type.' |
';
+ print "
".dol_print_phone($act->societe->tel);
}
-
- // Title
- print '| '.$langs->trans("Title").' | '.$act->label.' |
';
-
- // Full day event
- print '| '.$langs->trans("EventOnFullDay").' | '.yn($act->fulldayevent).' |
';
-
- // Date start
- print '| '.$langs->trans("DateActionStart").' | ';
- if (! $act->fulldayevent) print dol_print_date($act->datep,'dayhour');
- else print dol_print_date($act->datep,'day');
- if ($act->percentage == 0 && $act->datep && $act->datep < ($now - $delay_warning)) print img_warning($langs->trans("Late"));
- print ' | ';
- print ''."\n";
- print ''."\n";
- print ''."\n";
- print ''."\n";
- print ' | ';
- print '
';
-
- // Date end
- print '| '.$langs->trans("DateActionEnd").' | ';
- if (! $act->fulldayevent) print dol_print_date($act->datef,'dayhour');
- else print dol_print_date($act->datef,'day');
- if ($act->percentage > 0 && $act->percentage < 100 && $act->datef && $act->datef < ($now- $delay_warning)) print img_warning($langs->trans("Late"));
- print ' |
';
-
- // Status
- print '| '.$langs->trans("Status").' / '.$langs->trans("Percentage").' | ';
- print $act->getLibStatut(4);
- print ' |
';
-
- // Location
- print '| '.$langs->trans("Location").' | '.$act->location.' |
';
-
-
- print '
';
-
-
- // Third party - Contact
- print '| '.$langs->trans("ActionOnCompany").' | '.($act->societe->id?$act->societe->getNomUrl(1):$langs->trans("None"));
- if ($act->societe->id && $act->type_code == 'AC_TEL')
- {
- if ($act->societe->fetch($act->societe->id))
- {
- print " ".dol_print_phone($act->societe->tel);
- }
- }
- print ' | ';
- print ''.$langs->trans("Contact").' | ';
- print '';
- if ($act->contact->id > 0)
- {
- print $act->contact->getNomUrl(1);
- if ($act->contact->id && $act->type_code == 'AC_TEL')
- {
- if ($act->contact->fetch($act->contact->id))
- {
- print " ".dol_print_phone($act->contact->phone_pro);
- }
- }
- }
- else
- {
- print $langs->trans("None");
- }
-
- print ' |
';
-
- // Project
- if (! empty($conf->projet->enabled))
- {
- print '| '.$langs->trans("Project").' | ';
- if ($act->fk_project)
- {
- $project=new Project($db);
- $project->fetch($act->fk_project);
- print $project->getNomUrl(1);
- }
- print ' |
';
- }
-
- // Priority
- print '| '.$langs->trans("Priority").' | ';
- print ($act->priority?$act->priority:'');
- print ' |
';
-
-
- print '
';
-
- // Construit liste des fichiers
- $filearray=dol_dir_list($upload_dir,"files",0,'','\.meta$',$sortfield,(strtolower($sortorder)=='desc'?SORT_DESC:SORT_ASC),1);
- $totalsize=0;
- foreach($filearray as $key => $file)
+ }
+ print '';
+ print '| '.$langs->trans("Contact").' | ';
+ print '';
+ if ($act->contact->id > 0)
+ {
+ print $act->contact->getNomUrl(1);
+ if ($act->contact->id && $act->type_code == 'AC_TEL')
{
- $totalsize+=$file['size'];
+ if ($act->contact->fetch($act->contact->id))
+ {
+ print " ".dol_print_phone($act->contact->phone_pro);
+ }
}
-
-
- print ' | | '.$langs->trans("NbOfAttachedFiles").' | '.count($filearray).' |
';
- print '| '.$langs->trans("TotalSizeOfAttachedFiles").' | '.$totalsize.' '.$langs->trans("bytes").' |
';
- print '
';
-
- print '';
-
-
- // Affiche formulaire upload
- $formfile=new FormFile($db);
- $formfile->form_attach_new_file(DOL_URL_ROOT.'/comm/action/document.php?id='.$act->id,'',0,0,($user->rights->agenda->myactions->create||$user->rights->agenda->allactions->create),50,$act);
-
-
- // List of document
- $param='&id='.$act->id;
- $formfile->list_of_documents($filearray,$act,'actions',$param,0,'',$user->rights->agenda->myactions->create);
}
else
{
- dol_print_error($db);
+ print $langs->trans("None");
}
+
+ print '';
+
+ // Project
+ if (! empty($conf->projet->enabled))
+ {
+ print '| '.$langs->trans("Project").' | ';
+ if ($act->fk_project)
+ {
+ $project=new Project($db);
+ $project->fetch($act->fk_project);
+ print $project->getNomUrl(1);
+ }
+ print ' |
';
+ }
+
+ // Priority
+ print '| '.$langs->trans("Priority").' | ';
+ print ($act->priority?$act->priority:'');
+ print ' |
';
+
+
+ print '
';
+
+ // Construit liste des fichiers
+ $filearray=dol_dir_list($upload_dir,"files",0,'','\.meta$',$sortfield,(strtolower($sortorder)=='desc'?SORT_DESC:SORT_ASC),1);
+ $totalsize=0;
+ foreach($filearray as $key => $file)
+ {
+ $totalsize+=$file['size'];
+ }
+
+
+ print '| '.$langs->trans("NbOfAttachedFiles").' | '.count($filearray).' |
';
+ print '| '.$langs->trans("TotalSizeOfAttachedFiles").' | '.$totalsize.' '.$langs->trans("bytes").' |
';
+ print '
';
+
+ print '';
+
+
+ // Affiche formulaire upload
+ $formfile=new FormFile($db);
+ $formfile->form_attach_new_file(DOL_URL_ROOT.'/comm/action/document.php?id='.$act->id,'',0,0,($user->rights->agenda->myactions->create||$user->rights->agenda->allactions->create),50,$act);
+
+
+ // List of document
+ $param='&id='.$act->id;
+ $formfile->list_of_documents($filearray,$act,'actions',$param,0,'',$user->rights->agenda->myactions->create);
}
else
{