forked from Wavyzz/dolibarr
1916 lines
76 KiB
PHP
1916 lines
76 KiB
PHP
<?php
|
|
/* Copyright (C) 2001-2005 Rodolphe Quiedeville <rodolphe@quiedeville.org>
|
|
* Copyright (C) 2004-2018 Laurent Destailleur <eldy@users.sourceforge.net>
|
|
* Copyright (C) 2005 Simon TOSSER <simon@kornog-computing.com>
|
|
* Copyright (C) 2005-2017 Regis Houssin <regis.houssin@inodbox.com>
|
|
* Copyright (C) 2010-2013 Juanjo Menent <jmenent@2byte.es>
|
|
* Copyright (C) 2013 Florian Henry <florian.henry@open-concept.pro>
|
|
* Copyright (C) 2014 Cedric GROSS <c.gross@kreiz-it.fr>
|
|
* Copyright (C) 2015 Alexandre Spangaro <aspangaro@open-dsi.fr>
|
|
* Copyright (C) 2018-2019 Frédéric France <frederic.france@netlogic.fr>
|
|
* Copyright (C) 2019 Ferran Marcet <fmarcet@2byte.es>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/**
|
|
* \file htdocs/comm/action/card.php
|
|
* \ingroup agenda
|
|
* \brief Page for event card
|
|
*/
|
|
|
|
require '../../main.inc.php';
|
|
require_once DOL_DOCUMENT_ROOT.'/core/lib/agenda.lib.php';
|
|
require_once DOL_DOCUMENT_ROOT.'/core/lib/date.lib.php';
|
|
require_once DOL_DOCUMENT_ROOT.'/contact/class/contact.class.php';
|
|
require_once DOL_DOCUMENT_ROOT.'/user/class/user.class.php';
|
|
require_once DOL_DOCUMENT_ROOT.'/comm/action/class/cactioncomm.class.php';
|
|
require_once DOL_DOCUMENT_ROOT.'/comm/action/class/actioncomm.class.php';
|
|
require_once DOL_DOCUMENT_ROOT.'/core/class/html.formactions.class.php';
|
|
require_once DOL_DOCUMENT_ROOT.'/core/class/html.formfile.class.php';
|
|
require_once DOL_DOCUMENT_ROOT.'/core/class/html.form.class.php';
|
|
require_once DOL_DOCUMENT_ROOT.'/projet/class/project.class.php';
|
|
require_once DOL_DOCUMENT_ROOT.'/projet/class/task.class.php';
|
|
require_once DOL_DOCUMENT_ROOT.'/core/class/html.formprojet.class.php';
|
|
require_once DOL_DOCUMENT_ROOT.'/core/class/extrafields.class.php';
|
|
require_once DOL_DOCUMENT_ROOT.'/categories/class/categorie.class.php';
|
|
|
|
// Load translation files required by the page
|
|
$langs->loadLangs(array("companies", "other", "commercial", "bills", "orders", "agenda"));
|
|
|
|
$action = GETPOST('action', 'alpha');
|
|
$cancel = GETPOST('cancel', 'alpha');
|
|
$backtopage = GETPOST('backtopage', 'alpha');
|
|
$socpeopleassigned = GETPOST('socpeopleassigned', 'array');
|
|
$origin = GETPOST('origin', 'alpha');
|
|
$originid = GETPOST('originid', 'int');
|
|
$confirm = GETPOST('confirm', 'alpha');
|
|
|
|
$fulldayevent = GETPOST('fullday');
|
|
|
|
$aphour = GETPOST('aphour');
|
|
$apmin = GETPOST('apmin');
|
|
$p2hour = GETPOST('p2hour');
|
|
$p2min = GETPOST('p2min');
|
|
|
|
$datep = dol_mktime($fulldayevent ? '00' : $aphour, $fulldayevent ? '00' : $apmin, 0, GETPOST("apmonth"), GETPOST("apday"), GETPOST("apyear"));
|
|
$datef = dol_mktime($fulldayevent ? '23' : $p2hour, $fulldayevent ? '59' : $p2min, $fulldayevent ? '59' : '0', GETPOST("p2month"), GETPOST("p2day"), GETPOST("p2year"));
|
|
|
|
// Security check
|
|
$socid = GETPOST('socid', 'int');
|
|
$id = GETPOST('id', 'int');
|
|
if ($user->socid) $socid = $user->socid;
|
|
$result = restrictedArea($user, 'agenda', $id, 'actioncomm&societe', 'myactions|allactions', 'fk_soc', 'id');
|
|
if ($user->socid && $socid) $result = restrictedArea($user, 'societe', $socid);
|
|
|
|
$error = GETPOST("error");
|
|
$donotclearsession = GETPOST('donotclearsession') ?GETPOST('donotclearsession') : 0;
|
|
|
|
$cactioncomm = new CActionComm($db);
|
|
$object = new ActionComm($db);
|
|
$contact = new Contact($db);
|
|
$extrafields = new ExtraFields($db);
|
|
$formfile = new FormFile($db);
|
|
|
|
$form = new Form($db);
|
|
$formfile = new FormFile($db);
|
|
$formactions = new FormActions($db);
|
|
|
|
// Load object
|
|
if ($id > 0 && $action != 'add') {
|
|
$ret = $object->fetch($id);
|
|
if ($ret > 0) {
|
|
$ret = $object->fetch_optionals();
|
|
$ret1 = $object->fetch_userassigned();
|
|
}
|
|
if ($ret < 0 || $ret1 < 0) {
|
|
dol_print_error('', $object->error);
|
|
}
|
|
}
|
|
|
|
// fetch optionals attributes and labels
|
|
$extrafields->fetch_name_optionals_label($object->table_element);
|
|
|
|
//var_dump($_POST);
|
|
|
|
// Initialize technical object to manage hooks of page. Note that conf->hooks_modules contains array of hook context
|
|
$hookmanager->initHooks(array('actioncard', 'globalcard'));
|
|
|
|
$parameters = array('socid' => $socid);
|
|
$reshook = $hookmanager->executeHooks('doActions', $parameters, $object, $action); // Note that $action and $object may have been modified by some hooks
|
|
if ($reshook < 0) setEventMessages($hookmanager->error, $hookmanager->errors, 'errors');
|
|
|
|
|
|
/*
|
|
* Actions
|
|
*/
|
|
|
|
$listUserAssignedUpdated = false;
|
|
// Remove user to assigned list
|
|
if (empty($reshook) && (GETPOST('removedassigned') || GETPOST('removedassigned') == '0'))
|
|
{
|
|
$idtoremove = GETPOST('removedassigned');
|
|
|
|
if (!empty($_SESSION['assignedtouser'])) $tmpassigneduserids = json_decode($_SESSION['assignedtouser'], 1);
|
|
else $tmpassigneduserids = array();
|
|
|
|
foreach ($tmpassigneduserids as $key => $val)
|
|
{
|
|
if ($val['id'] == $idtoremove || $val['id'] == -1) unset($tmpassigneduserids[$key]);
|
|
}
|
|
//var_dump($_POST['removedassigned']);exit;
|
|
$_SESSION['assignedtouser'] = json_encode($tmpassigneduserids);
|
|
$donotclearsession = 1;
|
|
if ($action == 'add') $action = 'create';
|
|
if ($action == 'update') $action = 'edit';
|
|
|
|
$listUserAssignedUpdated = true;
|
|
}
|
|
|
|
// Add user to assigned list
|
|
if (empty($reshook) && (GETPOST('addassignedtouser') || GETPOST('updateassignedtouser')))
|
|
{
|
|
// Add a new user
|
|
if (GETPOST('assignedtouser') > 0)
|
|
{
|
|
$assignedtouser = array();
|
|
if (!empty($_SESSION['assignedtouser']))
|
|
{
|
|
$assignedtouser = json_decode($_SESSION['assignedtouser'], true);
|
|
}
|
|
$assignedtouser[GETPOST('assignedtouser')] = array('id'=>GETPOST('assignedtouser'), 'transparency'=>GETPOST('transparency'), 'mandatory'=>1);
|
|
$_SESSION['assignedtouser'] = json_encode($assignedtouser);
|
|
}
|
|
$donotclearsession = 1;
|
|
if ($action == 'add') $action = 'create';
|
|
if ($action == 'update') $action = 'edit';
|
|
|
|
$listUserAssignedUpdated = true;
|
|
}
|
|
|
|
// Link to a project
|
|
if (empty($reshook) && $action == 'classin' && ($user->rights->agenda->allactions->create ||
|
|
(($object->authorid == $user->id || $object->userownerid == $user->id) && $user->rights->agenda->myactions->create)))
|
|
{
|
|
//$object->fetch($id);
|
|
$object->setProject(GETPOST('projectid', 'int'));
|
|
}
|
|
|
|
// Action clone object
|
|
if (empty($reshook) && $action == 'confirm_clone' && $confirm == 'yes')
|
|
{
|
|
if (1 == 0 && !GETPOST('clone_content') && !GETPOST('clone_receivers'))
|
|
{
|
|
setEventMessages($langs->trans("NoCloneOptionsSpecified"), null, 'errors');
|
|
}
|
|
else
|
|
{
|
|
if ($id > 0) {
|
|
//$object->fetch($id);
|
|
if (!empty($object->socpeopleassigned)) {
|
|
reset($object->socpeopleassigned);
|
|
$object->contactid = key($object->socpeopleassigned);
|
|
}
|
|
$result = $object->createFromClone($user, GETPOST('socid', 'int'));
|
|
if ($result > 0) {
|
|
header("Location: ".$_SERVER['PHP_SELF'].'?id='.$result);
|
|
exit();
|
|
} else {
|
|
setEventMessages($object->error, $object->errors, 'errors');
|
|
$action = '';
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// Add event
|
|
if (empty($reshook) && $action == 'add')
|
|
{
|
|
$error = 0;
|
|
|
|
if (empty($backtopage))
|
|
{
|
|
if ($socid > 0) $backtopage = DOL_URL_ROOT.'/societe/agenda.php?socid='.$socid;
|
|
else $backtopage = DOL_URL_ROOT.'/comm/action/index.php';
|
|
}
|
|
|
|
if (!empty($socpeopleassigned[0]))
|
|
{
|
|
$result = $contact->fetch($socpeopleassigned[0]);
|
|
}
|
|
|
|
if ($cancel)
|
|
{
|
|
header("Location: ".$backtopage);
|
|
exit;
|
|
}
|
|
|
|
$percentage = in_array(GETPOST('status'), array(-1, 100)) ?GETPOST('status') : (in_array(GETPOST('complete'), array(-1, 100)) ?GETPOST('complete') : GETPOST("percentage")); // If status is -1 or 100, percentage is not defined and we must use status
|
|
|
|
// Clean parameters
|
|
$datep = dol_mktime($fulldayevent ? '00' : GETPOST("aphour", 'int'), $fulldayevent ? '00' : GETPOST("apmin", 'int'), $fulldayevent ? '00' : GETPOST("apsec", 'int'), GETPOST("apmonth", 'int'), GETPOST("apday", 'int'), GETPOST("apyear", 'int'));
|
|
$datef = dol_mktime($fulldayevent ? '23' : GETPOST("p2hour", 'int'), $fulldayevent ? '59' : GETPOST("p2min", 'int'), $fulldayevent ? '59' : GETPOST("apsec", 'int'), GETPOST("p2month", 'int'), GETPOST("p2day", 'int'), GETPOST("p2year", 'int'));
|
|
|
|
// Check parameters
|
|
if (!$datef && $percentage == 100)
|
|
{
|
|
$error++; $donotclearsession = 1;
|
|
$action = 'create';
|
|
setEventMessages($langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("DateEnd")), null, 'errors');
|
|
}
|
|
|
|
if (empty($conf->global->AGENDA_USE_EVENT_TYPE) && !GETPOST('label'))
|
|
{
|
|
$error++; $donotclearsession = 1;
|
|
$action = 'create';
|
|
setEventMessages($langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("Title")), null, 'errors');
|
|
}
|
|
|
|
// Initialisation objet cactioncomm
|
|
if (GETPOSTISSET('actioncode') && !GETPOST('actioncode', 'aZ09')) // actioncode is '0'
|
|
{
|
|
$error++; $donotclearsession = 1;
|
|
$action = 'create';
|
|
setEventMessages($langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("Type")), null, 'errors');
|
|
}
|
|
else
|
|
{
|
|
$object->type_code = GETPOST('actioncode', 'aZ09');
|
|
}
|
|
|
|
if (!$error)
|
|
{
|
|
// Initialisation objet actioncomm
|
|
$object->priority = GETPOST("priority") ?GETPOST("priority") : 0;
|
|
$object->fulldayevent = (!empty($fulldayevent) ? 1 : 0);
|
|
$object->location = GETPOST("location");
|
|
$object->label = trim(GETPOST('label'));
|
|
$object->fk_element = GETPOST("fk_element", 'int');
|
|
$object->elementtype = GETPOST("elementtype", 'alpha');
|
|
if (!GETPOST('label'))
|
|
{
|
|
if (GETPOST('actioncode', 'aZ09') == 'AC_RDV' && $contact->getFullName($langs))
|
|
{
|
|
$object->label = $langs->transnoentitiesnoconv("TaskRDVWith", $contact->getFullName($langs));
|
|
}
|
|
else
|
|
{
|
|
if ($langs->trans("Action".$object->type_code) != "Action".$object->type_code)
|
|
{
|
|
$object->label = $langs->transnoentitiesnoconv("Action".$object->type_code)."\n";
|
|
}
|
|
else {
|
|
$cactioncomm->fetch($object->type_code);
|
|
$object->label = $cactioncomm->label;
|
|
}
|
|
}
|
|
}
|
|
$object->fk_project = isset($_POST["projectid"]) ? $_POST["projectid"] : 0;
|
|
|
|
$taskid = GETPOST('taskid', 'int');
|
|
if (!empty($taskid)) {
|
|
$taskProject = new Task($db);
|
|
if ($taskProject->fetch($taskid) > 0) {
|
|
$object->fk_project = $taskProject->fk_project;
|
|
}
|
|
|
|
$object->fk_element = $taskid;
|
|
$object->elementtype = 'task';
|
|
}
|
|
|
|
$object->datep = $datep;
|
|
$object->datef = $datef;
|
|
$object->percentage = $percentage;
|
|
$object->duree = (((int) GETPOST('dureehour') * 60) + (int) GETPOST('dureemin')) * 60;
|
|
|
|
$transparency = (GETPOST("transparency") == 'on' ? 1 : 0);
|
|
|
|
$listofuserid = array();
|
|
if (!empty($_SESSION['assignedtouser'])) $listofuserid = json_decode($_SESSION['assignedtouser'], true);
|
|
$i = 0;
|
|
foreach ($listofuserid as $key => $value)
|
|
{
|
|
if ($i == 0) // First entry
|
|
{
|
|
if ($value['id'] > 0) $object->userownerid = $value['id'];
|
|
$object->transparency = $transparency;
|
|
}
|
|
|
|
$object->userassigned[$value['id']] = array('id'=>$value['id'], 'transparency'=>$transparency);
|
|
|
|
$i++;
|
|
}
|
|
}
|
|
|
|
if (!$error && !empty($conf->global->AGENDA_ENABLE_DONEBY))
|
|
{
|
|
if (GETPOST("doneby") > 0) $object->userdoneid = GETPOST("doneby", "int");
|
|
}
|
|
|
|
$object->note_private = trim(GETPOST("note", "none"));
|
|
|
|
if (isset($_POST["contactid"])) $object->contact = $contact;
|
|
|
|
if (GETPOST('socid', 'int') > 0)
|
|
{
|
|
$object->socid = GETPOST('socid', 'int');
|
|
$object->fetch_thirdparty();
|
|
|
|
$object->societe = $object->thirdparty; // For backward compatibility
|
|
}
|
|
|
|
// Check parameters
|
|
if (empty($object->userownerid) && empty($_SESSION['assignedtouser']))
|
|
{
|
|
$error++; $donotclearsession = 1;
|
|
$action = 'create';
|
|
setEventMessages($langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("ActionsOwnedBy")), null, 'errors');
|
|
}
|
|
if ($object->type_code == 'AC_RDV' && ($datep == '' || ($datef == '' && empty($fulldayevent))))
|
|
{
|
|
$error++; $donotclearsession = 1;
|
|
$action = 'create';
|
|
setEventMessages($langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("DateEnd")), null, 'errors');
|
|
}
|
|
|
|
if (!GETPOST('apyear') && !GETPOST('adyear'))
|
|
{
|
|
$error++; $donotclearsession = 1;
|
|
$action = 'create';
|
|
setEventMessages($langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("Date")), null, 'errors');
|
|
}
|
|
|
|
foreach ($socpeopleassigned as $cid)
|
|
{
|
|
$object->socpeopleassigned[$cid] = array('id' => $cid);
|
|
}
|
|
if (!empty($object->socpeopleassigned))
|
|
{
|
|
reset($object->socpeopleassigned);
|
|
$object->contactid = key($object->socpeopleassigned);
|
|
}
|
|
|
|
// Fill array 'array_options' with data from add form
|
|
$ret = $extrafields->setOptionalsFromPost(null, $object);
|
|
if ($ret < 0) $error++;
|
|
|
|
if (!$error)
|
|
{
|
|
$db->begin();
|
|
|
|
// Creation of action/event
|
|
$idaction = $object->create($user);
|
|
|
|
if ($idaction > 0)
|
|
{
|
|
if (!$object->error)
|
|
{
|
|
// Category association
|
|
$categories = GETPOST('categories', 'array');
|
|
$object->setCategories($categories);
|
|
|
|
unset($_SESSION['assignedtouser']);
|
|
|
|
$moreparam = '';
|
|
if ($user->id != $object->userownerid) $moreparam = "filtert=-1"; // We force to remove filter so created record is visible when going back to per user view.
|
|
|
|
$db->commit();
|
|
if (!empty($backtopage))
|
|
{
|
|
dol_syslog("Back to ".$backtopage.($moreparam ? (preg_match('/\?/', $backtopage) ? '&'.$moreparam : '?'.$moreparam) : ''));
|
|
header("Location: ".$backtopage.($moreparam ? (preg_match('/\?/', $backtopage) ? '&'.$moreparam : '?'.$moreparam) : ''));
|
|
}
|
|
elseif ($idaction)
|
|
{
|
|
header("Location: ".DOL_URL_ROOT.'/comm/action/card.php?id='.$idaction.($moreparam ? '&'.$moreparam : ''));
|
|
}
|
|
else
|
|
{
|
|
header("Location: ".DOL_URL_ROOT.'/comm/action/index.php'.($moreparam ? '?'.$moreparam : ''));
|
|
}
|
|
exit;
|
|
}
|
|
else
|
|
{
|
|
// If error
|
|
$db->rollback();
|
|
$langs->load("errors");
|
|
$error = $langs->trans($object->error);
|
|
setEventMessages($error, null, 'errors');
|
|
$action = 'create'; $donotclearsession = 1;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$db->rollback();
|
|
setEventMessages($object->error, $object->errors, 'errors');
|
|
$action = 'create'; $donotclearsession = 1;
|
|
}
|
|
}
|
|
}
|
|
|
|
/*
|
|
* Action update event
|
|
*/
|
|
if (empty($reshook) && $action == 'update')
|
|
{
|
|
if (empty($cancel))
|
|
{
|
|
$fulldayevent = GETPOST('fullday');
|
|
$aphour = GETPOST('aphour');
|
|
$apmin = GETPOST('apmin');
|
|
$p2hour = GETPOST('p2hour');
|
|
$p2min = GETPOST('p2min');
|
|
$percentage = in_array(GETPOST('status'), array(-1, 100)) ?GETPOST('status') : (in_array(GETPOST('complete'), array(-1, 100)) ?GETPOST('complete') : GETPOST("percentage")); // If status is -1 or 100, percentage is not defined and we must use status
|
|
|
|
// Clean parameters
|
|
if ($aphour == -1) $aphour = '0';
|
|
if ($apmin == -1) $apmin = '0';
|
|
if ($p2hour == -1) $p2hour = '0';
|
|
if ($p2min == -1) $p2min = '0';
|
|
|
|
$object->fetch($id);
|
|
$object->fetch_optionals();
|
|
$object->fetch_userassigned();
|
|
$object->oldcopy = clone $object;
|
|
|
|
$datep = dol_mktime($fulldayevent ? '00' : $aphour, $fulldayevent ? '00' : $apmin, 0, GETPOST("apmonth", 'int'), GETPOST("apday", 'int'), GETPOST("apyear", 'int'));
|
|
$datef = dol_mktime($fulldayevent ? '23' : $p2hour, $fulldayevent ? '59' : $p2min, $fulldayevent ? '59' : '0', GETPOST("p2month", 'int'), GETPOST("p2day", 'int'), GETPOST("p2year", 'int'));
|
|
|
|
$object->type_id = dol_getIdFromCode($db, GETPOST("actioncode", 'aZ09'), 'c_actioncomm');
|
|
$object->label = GETPOST("label", "alphanohtml");
|
|
$object->datep = $datep;
|
|
$object->datef = $datef;
|
|
$object->percentage = $percentage;
|
|
$object->priority = GETPOST("priority", "alphanohtml");
|
|
$object->fulldayevent = GETPOST("fullday") ? 1 : 0;
|
|
$object->location = GETPOST('location', "alphanohtml");
|
|
$object->socid = GETPOST("socid", "int");
|
|
$socpeopleassigned = GETPOST("socpeopleassigned", 'array');
|
|
$object->socpeopleassigned = array();
|
|
foreach ($socpeopleassigned as $cid) $object->socpeopleassigned[$cid] = array('id' => $cid);
|
|
$object->contactid = GETPOST("contactid", 'int');
|
|
if (empty($object->contactid) && !empty($object->socpeopleassigned)) {
|
|
reset($object->socpeopleassigned);
|
|
$object->contactid = key($object->socpeopleassigned);
|
|
}
|
|
$object->fk_project = GETPOST("projectid", 'int');
|
|
$object->note_private = trim(GETPOST("note", "none"));
|
|
$object->fk_element = GETPOST("fk_element", "int");
|
|
$object->elementtype = GETPOST("elementtype", "alphanohtml");
|
|
if (!$datef && $percentage == 100)
|
|
{
|
|
$error++; $donotclearsession = 1;
|
|
setEventMessages($langs->transnoentitiesnoconv("ErrorFieldRequired", $langs->transnoentitiesnoconv("DateEnd")), $object->errors, 'errors');
|
|
$action = 'edit';
|
|
}
|
|
|
|
$transparency = (GETPOST("transparency") == 'on' ? 1 : 0);
|
|
|
|
// Users
|
|
$listofuserid = array();
|
|
if (!empty($_SESSION['assignedtouser'])) // Now concat assigned users
|
|
{
|
|
// Restore array with key with same value than param 'id'
|
|
$tmplist1 = json_decode($_SESSION['assignedtouser'], true);
|
|
foreach ($tmplist1 as $key => $val)
|
|
{
|
|
if ($val['id'] > 0 && $val['id'] != $assignedtouser) $listofuserid[$val['id']] = $val;
|
|
}
|
|
}
|
|
else {
|
|
$assignedtouser = (!empty($object->userownerid) && $object->userownerid > 0 ? $object->userownerid : 0);
|
|
if ($assignedtouser) $listofuserid[$assignedtouser] = array('id'=>$assignedtouser, 'mandatory'=>0, 'transparency'=>($user->id == $assignedtouser ? $transparency : '')); // Owner first
|
|
}
|
|
$object->userassigned = array(); $object->userownerid = 0; // Clear old content
|
|
$i = 0;
|
|
foreach ($listofuserid as $key => $val)
|
|
{
|
|
if ($i == 0) $object->userownerid = $val['id'];
|
|
$object->userassigned[$val['id']] = array('id'=>$val['id'], 'mandatory'=>0, 'transparency'=>($user->id == $val['id'] ? $transparency : ''));
|
|
$i++;
|
|
}
|
|
|
|
$object->transparency = $transparency; // We set transparency on event (even if we can also store it on each user, standard says this property is for event)
|
|
// TODO store also transparency on owner user
|
|
|
|
if (!empty($conf->global->AGENDA_ENABLE_DONEBY))
|
|
{
|
|
if (GETPOST("doneby")) $object->userdoneid = GETPOST("doneby", "int");
|
|
}
|
|
|
|
// Check parameters
|
|
if (GETPOSTISSET('actioncode') && !GETPOST('actioncode', 'aZ09')) // actioncode is '0'
|
|
{
|
|
$error++; $donotclearsession = 1;
|
|
$action = 'edit';
|
|
setEventMessages($langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("Type")), null, 'errors');
|
|
}
|
|
else
|
|
{
|
|
$result = $cactioncomm->fetch(GETPOST('actioncode', 'aZ09'));
|
|
}
|
|
if (empty($object->userownerid))
|
|
{
|
|
$error++; $donotclearsession = 1;
|
|
$action = 'edit';
|
|
setEventMessages($langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("ActionsOwnedBy")), null, 'errors');
|
|
}
|
|
|
|
// Fill array 'array_options' with data from add form
|
|
$ret = $extrafields->setOptionalsFromPost(null, $object);
|
|
if ($ret < 0) $error++;
|
|
|
|
if (!$error) {
|
|
// check if an event resource is already in use
|
|
if (!empty($conf->global->RESOURCE_USED_IN_EVENT_CHECK) && $object->element == 'action') {
|
|
$eventDateStart = $object->datep;
|
|
$eventDateEnd = $object->datef;
|
|
|
|
$sql = "SELECT er.rowid, r.ref as r_ref, ac.id as ac_id, ac.label as ac_label";
|
|
$sql .= " FROM ".MAIN_DB_PREFIX."element_resources as er";
|
|
$sql .= " INNER JOIN ".MAIN_DB_PREFIX."resource as r ON r.rowid = er.resource_id AND er.resource_type = 'dolresource'";
|
|
$sql .= " INNER JOIN ".MAIN_DB_PREFIX."actioncomm as ac ON ac.id = er.element_id AND er.element_type = '".$db->escape($object->element)."'";
|
|
$sql .= " WHERE ac.id != ".$object->id;
|
|
$sql .= " AND er.resource_id IN (";
|
|
$sql .= " SELECT resource_id FROM ".MAIN_DB_PREFIX."element_resources";
|
|
$sql .= " WHERE element_id = ".$object->id;
|
|
$sql .= " AND element_type = '".$db->escape($object->element)."'";
|
|
$sql .= " AND busy = 1";
|
|
$sql .= ")";
|
|
$sql .= " AND er.busy = 1";
|
|
$sql .= " AND (";
|
|
|
|
// event date start between ac.datep and ac.datep2 (if datep2 is null we consider there is no end)
|
|
$sql .= " (ac.datep <= '".$db->idate($eventDateStart)."' AND (ac.datep2 IS NULL OR ac.datep2 >= '".$db->idate($eventDateStart)."'))";
|
|
// event date end between ac.datep and ac.datep2
|
|
if (!empty($eventDateEnd)) {
|
|
$sql .= " OR (ac.datep <= '".$db->idate($eventDateEnd)."' AND (ac.datep2 >= '".$db->idate($eventDateEnd)."'))";
|
|
}
|
|
// event date start before ac.datep and event date end after ac.datep2
|
|
$sql .= " OR (";
|
|
$sql .= "ac.datep >= '".$db->idate($eventDateStart)."'";
|
|
if (!empty($eventDateEnd)) {
|
|
$sql .= " AND (ac.datep2 IS NOT NULL AND ac.datep2 <= '".$db->idate($eventDateEnd)."')";
|
|
}
|
|
$sql .= ")";
|
|
|
|
$sql .= ")";
|
|
$resql = $db->query($sql);
|
|
if (!$resql) {
|
|
$error++;
|
|
$object->error = $db->lasterror();
|
|
$object->errors[] = $object->error;
|
|
} else {
|
|
if ($db->num_rows($resql) > 0) {
|
|
// already in use
|
|
$error++;
|
|
$object->error = $langs->trans('ErrorResourcesAlreadyInUse').' : ';
|
|
while ($obj = $db->fetch_object($resql)) {
|
|
$object->error .= '<br> - '.$langs->trans('ErrorResourceUseInEvent', $obj->r_ref, $obj->ac_label.' ['.$obj->ac_id.']');
|
|
}
|
|
$object->errors[] = $object->error;
|
|
}
|
|
$db->free($resql);
|
|
}
|
|
|
|
if ($error) {
|
|
setEventMessages($object->error, $object->errors, 'errors');
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!$error)
|
|
{
|
|
$db->begin();
|
|
|
|
$result = $object->update($user);
|
|
|
|
if ($result > 0)
|
|
{
|
|
// Category association
|
|
$categories = GETPOST('categories', 'array');
|
|
$object->setCategories($categories);
|
|
|
|
unset($_SESSION['assignedtouser']);
|
|
|
|
$db->commit();
|
|
}
|
|
else
|
|
{
|
|
setEventMessages($object->error, $object->errors, 'errors');
|
|
$db->rollback();
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!$error)
|
|
{
|
|
if (!empty($backtopage))
|
|
{
|
|
unset($_SESSION['assignedtouser']);
|
|
header("Location: ".$backtopage);
|
|
exit;
|
|
}
|
|
}
|
|
}
|
|
|
|
/*
|
|
* delete event
|
|
*/
|
|
if (empty($reshook) && $action == 'confirm_delete' && GETPOST("confirm") == 'yes')
|
|
{
|
|
$object->fetch($id);
|
|
$object->fetch_optionals();
|
|
$object->fetch_userassigned();
|
|
$object->oldcopy = clone $object;
|
|
|
|
if ($user->rights->agenda->myactions->delete
|
|
|| $user->rights->agenda->allactions->delete)
|
|
{
|
|
$result = $object->delete();
|
|
|
|
if ($result >= 0)
|
|
{
|
|
header("Location: index.php");
|
|
exit;
|
|
}
|
|
else
|
|
{
|
|
setEventMessages($object->error, $object->errors, 'errors');
|
|
}
|
|
}
|
|
}
|
|
|
|
/*
|
|
* Action move update, used when user move an event in calendar by drag'n drop
|
|
* TODO Move this into page comm/action/index that trigger this call by the drag and drop of event.
|
|
*/
|
|
if (empty($reshook) && GETPOST('actionmove', 'alpha') == 'mupdate')
|
|
{
|
|
$error = 0;
|
|
|
|
$shour = dol_print_date($object->datep, "%H");
|
|
$smin = dol_print_date($object->datep, "%M");
|
|
|
|
$newdate = GETPOST('newdate', 'alpha');
|
|
if (empty($newdate) || strpos($newdate, 'dayevent_') != 0)
|
|
{
|
|
header("Location: ".$backtopage);
|
|
exit;
|
|
}
|
|
|
|
$datep = dol_mktime($shour, $smin, 0, substr($newdate, 13, 2), substr($newdate, 15, 2), substr($newdate, 9, 4));
|
|
if ($datep != $object->datep)
|
|
{
|
|
if (!empty($object->datef))
|
|
{
|
|
$object->datef += $datep - $object->datep;
|
|
}
|
|
$object->datep = $datep;
|
|
|
|
if (!$error) {
|
|
// check if an event resource is already in use
|
|
if (!empty($conf->global->RESOURCE_USED_IN_EVENT_CHECK) && $object->element == 'action') {
|
|
$eventDateStart = $object->datep;
|
|
$eventDateEnd = $object->datef;
|
|
|
|
$sql = "SELECT er.rowid, r.ref as r_ref, ac.id as ac_id, ac.label as ac_label";
|
|
$sql .= " FROM ".MAIN_DB_PREFIX."element_resources as er";
|
|
$sql .= " INNER JOIN ".MAIN_DB_PREFIX."resource as r ON r.rowid = er.resource_id AND er.resource_type = 'dolresource'";
|
|
$sql .= " INNER JOIN ".MAIN_DB_PREFIX."actioncomm as ac ON ac.id = er.element_id AND er.element_type = '".$db->escape($object->element)."'";
|
|
$sql .= " WHERE ac.id != ".$object->id;
|
|
$sql .= " AND er.resource_id IN (";
|
|
$sql .= " SELECT resource_id FROM ".MAIN_DB_PREFIX."element_resources";
|
|
$sql .= " WHERE element_id = ".$object->id;
|
|
$sql .= " AND element_type = '".$db->escape($object->element)."'";
|
|
$sql .= " AND busy = 1";
|
|
$sql .= ")";
|
|
$sql .= " AND er.busy = 1";
|
|
$sql .= " AND (";
|
|
|
|
// event date start between ac.datep and ac.datep2 (if datep2 is null we consider there is no end)
|
|
$sql .= " (ac.datep <= '".$db->idate($eventDateStart)."' AND (ac.datep2 IS NULL OR ac.datep2 >= '".$db->idate($eventDateStart)."'))";
|
|
// event date end between ac.datep and ac.datep2
|
|
if (!empty($eventDateEnd)) {
|
|
$sql .= " OR (ac.datep <= '".$db->idate($eventDateEnd)."' AND (ac.datep2 >= '".$db->idate($eventDateEnd)."'))";
|
|
}
|
|
// event date start before ac.datep and event date end after ac.datep2
|
|
$sql .= " OR (";
|
|
$sql .= "ac.datep >= '".$db->idate($eventDateStart)."'";
|
|
if (!empty($eventDateEnd)) {
|
|
$sql .= " AND (ac.datep2 IS NOT NULL AND ac.datep2 <= '".$db->idate($eventDateEnd)."')";
|
|
}
|
|
$sql .= ")";
|
|
|
|
$sql .= ")";
|
|
$resql = $db->query($sql);
|
|
if (!$resql) {
|
|
$error++;
|
|
$object->error = $db->lasterror();
|
|
$object->errors[] = $object->error;
|
|
} else {
|
|
if ($db->num_rows($resql) > 0) {
|
|
// already in use
|
|
$error++;
|
|
$object->error = $langs->trans('ErrorResourcesAlreadyInUse').' : ';
|
|
while ($obj = $db->fetch_object($resql)) {
|
|
$object->error .= '<br> - '.$langs->trans('ErrorResourceUseInEvent', $obj->r_ref, $obj->ac_label.' ['.$obj->ac_id.']');
|
|
}
|
|
$object->errors[] = $object->error;
|
|
}
|
|
$db->free($resql);
|
|
}
|
|
|
|
if ($error) {
|
|
setEventMessages($object->error, $object->errors, 'errors');
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!$error) {
|
|
$db->begin();
|
|
$result = $object->update($user);
|
|
if ($result < 0) {
|
|
$error++;
|
|
setEventMessages($object->error, $object->errors, 'errors');
|
|
$db->rollback();
|
|
} else {
|
|
$db->commit();
|
|
}
|
|
}
|
|
}
|
|
if (!empty($backtopage))
|
|
{
|
|
header("Location: ".$backtopage);
|
|
exit;
|
|
}
|
|
else
|
|
{
|
|
$action = '';
|
|
}
|
|
}
|
|
|
|
// Actions to delete doc
|
|
$upload_dir = $conf->agenda->dir_output.'/'.dol_sanitizeFileName($object->ref);
|
|
$permissiontoadd = ($user->rights->agenda->allactions->create || (($object->authorid == $user->id || $object->userownerid == $user->id) && $user->rights->agenda->myactions->read));
|
|
if (empty($reshook)) {
|
|
include DOL_DOCUMENT_ROOT.'/core/actions_builddoc.inc.php';
|
|
}
|
|
|
|
|
|
/*
|
|
* View
|
|
*/
|
|
|
|
$form = new Form($db);
|
|
$formproject = new FormProjets($db);
|
|
|
|
$help_url = 'EN:Module_Agenda_En|FR:Module_Agenda|ES:M&omodulodulo_Agenda';
|
|
llxHeader('', $langs->trans("Agenda"), $help_url);
|
|
|
|
if ($action == 'create')
|
|
{
|
|
$contact = new Contact($db);
|
|
|
|
$socpeopleassigned = GETPOST("socpeopleassigned", 'array');
|
|
if (!empty($socpeopleassigned[0]))
|
|
{
|
|
$result = $contact->fetch($socpeopleassigned[0]);
|
|
if ($result < 0) dol_print_error($db, $contact->error);
|
|
}
|
|
|
|
dol_set_focus("#label");
|
|
|
|
if (!empty($conf->use_javascript_ajax))
|
|
{
|
|
print "\n".'<script type="text/javascript">';
|
|
print '$(document).ready(function () {
|
|
function setdatefields()
|
|
{
|
|
if ($("#fullday:checked").val() == null) {
|
|
$(".fulldaystarthour").removeAttr("disabled");
|
|
$(".fulldaystartmin").removeAttr("disabled");
|
|
$(".fulldayendhour").removeAttr("disabled");
|
|
$(".fulldayendmin").removeAttr("disabled");
|
|
$("#p2").removeAttr("disabled");
|
|
} else {
|
|
$(".fulldaystarthour").prop("disabled", true).val("00");
|
|
$(".fulldaystartmin").prop("disabled", true).val("00");
|
|
$(".fulldayendhour").prop("disabled", true).val("23");
|
|
$(".fulldayendmin").prop("disabled", true).val("59");
|
|
$("#p2").removeAttr("disabled");
|
|
}
|
|
}
|
|
setdatefields();
|
|
$("#fullday").change(function() {
|
|
console.log("setdatefields");
|
|
setdatefields();
|
|
});
|
|
$("#selectcomplete").change(function() {
|
|
if ($("#selectcomplete").val() == 100)
|
|
{
|
|
if ($("#doneby").val() <= 0) $("#doneby").val(\''.$user->id.'\');
|
|
}
|
|
if ($("#selectcomplete").val() == 0)
|
|
{
|
|
$("#doneby").val(-1);
|
|
}
|
|
});
|
|
$("#actioncode").change(function() {
|
|
if ($("#actioncode").val() == \'AC_RDV\') $("#dateend").addClass("fieldrequired");
|
|
else $("#dateend").removeClass("fieldrequired");
|
|
});
|
|
})';
|
|
print '</script>'."\n";
|
|
}
|
|
|
|
print '<form name="formaction" action="'.$_SERVER['PHP_SELF'].'" method="POST">';
|
|
print '<input type="hidden" name="token" value="'.newToken().'">';
|
|
print '<input type="hidden" name="action" value="add">';
|
|
print '<input type="hidden" name="donotclearsession" value="1">';
|
|
if ($backtopage) print '<input type="hidden" name="backtopage" value="'.($backtopage != '1' ? $backtopage : htmlentities($_SERVER["HTTP_REFERER"])).'">';
|
|
if (empty($conf->global->AGENDA_USE_EVENT_TYPE)) print '<input type="hidden" name="actioncode" value="'.dol_getIdFromCode($db, 'AC_OTH', 'c_actioncomm').'">';
|
|
|
|
if (GETPOST("actioncode", 'aZ09') == 'AC_RDV') print load_fiche_titre($langs->trans("AddActionRendezVous"), '', 'title_agenda');
|
|
else print load_fiche_titre($langs->trans("AddAnAction"), '', 'title_agenda');
|
|
|
|
dol_fiche_head();
|
|
|
|
print '<table class="border centpercent">';
|
|
|
|
// Type of event
|
|
if (!empty($conf->global->AGENDA_USE_EVENT_TYPE))
|
|
{
|
|
print '<tr><td class="titlefieldcreate"><span class="fieldrequired">'.$langs->trans("Type").'</span></b></td><td>';
|
|
$default = (empty($conf->global->AGENDA_USE_EVENT_TYPE_DEFAULT) ? '' : $conf->global->AGENDA_USE_EVENT_TYPE_DEFAULT);
|
|
$formactions->select_type_actions(GETPOST("actioncode", 'aZ09') ?GETPOST("actioncode", 'aZ09') : ($object->type_code ? $object->type_code : $default), "actioncode", "systemauto", 0, -1);
|
|
print '</td></tr>';
|
|
}
|
|
|
|
// Title
|
|
print '<tr><td'.(empty($conf->global->AGENDA_USE_EVENT_TYPE) ? ' class="fieldrequired titlefieldcreate"' : '').'>'.$langs->trans("Label").'</td><td><input type="text" id="label" name="label" class="soixantepercent" value="'.GETPOST('label').'"></td></tr>';
|
|
|
|
// Full day
|
|
print '<tr><td>'.$langs->trans("EventOnFullDay").'</td><td><input type="checkbox" id="fullday" name="fullday" '.(GETPOST('fullday') ? ' checked' : '').'></td></tr>';
|
|
|
|
// Date start
|
|
$datep = ($datep ? $datep : $object->datep);
|
|
if (GETPOST('datep', 'int', 1)) $datep = dol_stringtotime(GETPOST('datep', 'int', 1), 0);
|
|
print '<tr><td class="nowrap"><span class="fieldrequired">'.$langs->trans("DateActionStart").'</span></td><td>';
|
|
if (GETPOST("afaire") == 1) {
|
|
print $form->selectDate($datep, 'ap', 1, 1, 0, "action", 1, 2, 0, 'fulldaystart'); // Empty value not allowed for start date and hours if "todo"
|
|
} else {
|
|
print $form->selectDate($datep, 'ap', 1, 1, 1, "action", 1, 2, 0, 'fulldaystart');
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// Date end
|
|
$datef = ($datef ? $datef : $object->datef);
|
|
if (GETPOST('datef', 'int', 1)) $datef = dol_stringtotime(GETPOST('datef', 'int', 1), 0);
|
|
if (empty($datef) && !empty($datep) && !empty($conf->global->AGENDA_AUTOSET_END_DATE_WITH_DELTA_HOURS))
|
|
{
|
|
$datef = dol_time_plus_duree($datep, $conf->global->AGENDA_AUTOSET_END_DATE_WITH_DELTA_HOURS, 'h');
|
|
}
|
|
print '<tr><td><span id="dateend"'.(GETPOST("actioncode", 'aZ09') == 'AC_RDV' ? ' class="fieldrequired"' : '').'>'.$langs->trans("DateActionEnd").'</span></td><td>';
|
|
if (GETPOST("afaire") == 1) {
|
|
print $form->selectDate($datef, 'p2', 1, 1, 1, "action", 1, 2, 0, 'fulldayend');
|
|
} else {
|
|
print $form->selectDate($datef, 'p2', 1, 1, 1, "action", 1, 2, 0, 'fulldayend');
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// Dev in progress
|
|
$userepeatevent = ($conf->global->MAIN_FEATURES_LEVEL == 2 ? 1 : 0);
|
|
if ($userepeatevent)
|
|
{
|
|
// Repeat
|
|
print '<tr><td>'.$langs->trans("RepeatEvent").'</td><td colspan="3">';
|
|
print '<input type="hidden" name="recurid" value="'.$object->recurid.'">';
|
|
$arrayrecurrulefreq = array(
|
|
'no'=>$langs->trans("No"),
|
|
'MONTHLY'=>$langs->trans("EveryMonth"),
|
|
'WEEKLY'=>$langs->trans("EveryWeek"),
|
|
//'DAYLY'=>$langs->trans("EveryDay")
|
|
);
|
|
$selectedrecurrulefreq = 'no';
|
|
$selectedrecurrulebymonthday = '';
|
|
$selectedrecurrulebyday = '';
|
|
if ($object->recurrule && preg_match('/FREQ=([A-Z]+)/i', $object->recurrule, $reg)) $selectedrecurrulefreq = $reg[1];
|
|
if ($object->recurrule && preg_match('/FREQ=MONTHLY.*BYMONTHDAY=(\d+)/i', $object->recurrule, $reg)) $selectedrecurrulebymonthday = $reg[1];
|
|
if ($object->recurrule && preg_match('/FREQ=WEEKLY.*BYDAY(\d+)/i', $object->recurrule, $reg)) $selectedrecurrulebyday = $reg[1];
|
|
print $form->selectarray('recurrulefreq', $arrayrecurrulefreq, $selectedrecurrulefreq, 0, 0, 0, '', 0, 0, 0, '', 'marginrightonly');
|
|
// If recurrulefreq is MONTHLY
|
|
print '<div class="hidden marginrightonly inline-block repeateventBYMONTHDAY">';
|
|
print $langs->trans("DayOfMonth").': <input type="input" size="2" name="BYMONTHDAY" value="'.$selectedrecurrulebymonthday.'">';
|
|
print '</div>';
|
|
// If recurrulefreq is WEEKLY
|
|
print '<div class="hidden marginrightonly inline-block repeateventBYDAY">';
|
|
print $langs->trans("DayOfWeek").': <input type="input" size="4" name="BYDAY" value="'.$selectedrecurrulebyday.'">';
|
|
print '</div>';
|
|
print '<script type="text/javascript" language="javascript">
|
|
jQuery(document).ready(function() {
|
|
function init_repeat()
|
|
{
|
|
if (jQuery("#recurrulefreq").val() == \'MONTHLY\')
|
|
{
|
|
jQuery(".repeateventBYMONTHDAY").css("display", "inline-block"); /* use this instead of show because we want inline-block and not block */
|
|
jQuery(".repeateventBYDAY").hide();
|
|
}
|
|
else if (jQuery("#recurrulefreq").val() == \'WEEKLY\')
|
|
{
|
|
jQuery(".repeateventBYMONTHDAY").hide();
|
|
jQuery(".repeateventBYDAY").css("display", "inline-block"); /* use this instead of show because we want inline-block and not block */
|
|
}
|
|
else
|
|
{
|
|
jQuery(".repeateventBYMONTHDAY").hide();
|
|
jQuery(".repeateventBYDAY").hide();
|
|
}
|
|
}
|
|
init_repeat();
|
|
jQuery("#recurrulefreq").change(function() {
|
|
init_repeat();
|
|
});
|
|
});
|
|
</script>';
|
|
print '</td></tr>';
|
|
}
|
|
|
|
// Status
|
|
print '<tr><td>'.$langs->trans("Status").' / '.$langs->trans("Percentage").'</td>';
|
|
print '<td>';
|
|
$percent = -1;
|
|
if (isset($_GET['status']) || isset($_POST['status'])) $percent = GETPOST('status');
|
|
elseif (isset($_GET['percentage']) || isset($_POST['percentage'])) $percent = GETPOST('percentage');
|
|
else
|
|
{
|
|
if (GETPOST('complete') == '0' || GETPOST("afaire") == 1) $percent = '0';
|
|
elseif (GETPOST('complete') == 100 || GETPOST("afaire") == 2) $percent = 100;
|
|
}
|
|
$formactions->form_select_status_action('formaction', $percent, 1, 'complete', 0, 0, 'maxwidth200');
|
|
print '</td></tr>';
|
|
|
|
// Location
|
|
if (empty($conf->global->AGENDA_DISABLE_LOCATION))
|
|
{
|
|
print '<tr><td>'.$langs->trans("Location").'</td><td colspan="3"><input type="text" name="location" class="soixantepercent" value="'.(GETPOST('location') ?GETPOST('location') : $object->location).'"></td></tr>';
|
|
}
|
|
|
|
// Assigned to
|
|
print '<tr><td class="tdtop nowrap">'.$langs->trans("ActionAffectedTo").'</td><td>';
|
|
$listofuserid = array();
|
|
if (empty($donotclearsession))
|
|
{
|
|
$assignedtouser = GETPOST("assignedtouser") ?GETPOST("assignedtouser") : (!empty($object->userownerid) && $object->userownerid > 0 ? $object->userownerid : $user->id);
|
|
if ($assignedtouser) $listofuserid[$assignedtouser] = array('id'=>$assignedtouser, 'mandatory'=>0, 'transparency'=>$object->transparency); // Owner first
|
|
$listofuserid[$user->id]['transparency'] = GETPOSTISSET('transparency') ?GETPOST('transparency', 'alpha') : 1; // 1 by default at first init
|
|
$_SESSION['assignedtouser'] = json_encode($listofuserid);
|
|
}
|
|
else
|
|
{
|
|
if (!empty($_SESSION['assignedtouser']))
|
|
{
|
|
$listofuserid = json_decode($_SESSION['assignedtouser'], true);
|
|
}
|
|
$listofuserid[$user->id]['transparency'] = GETPOSTISSET('transparency') ?GETPOST('transparency', 'alpha') : 0; // 0 by default when refreshing
|
|
}
|
|
print '<div class="assignedtouser">';
|
|
print $form->select_dolusers_forevent(($action == 'create' ? 'add' : 'update'), 'assignedtouser', 1, '', 0, '', '', 0, 0, 0, 'AND u.statut != 0', 1, $listofuserid, $listofcontactid, $listofotherid);
|
|
print '</div>';
|
|
/*if (in_array($user->id,array_keys($listofuserid)))
|
|
{
|
|
print '<div class="myavailability">';
|
|
print $langs->trans("MyAvailability").': <input id="transparency" type="checkbox" name="transparency"'.(((! isset($_GET['transparency']) && ! isset($_POST['transparency'])) || GETPOST('transparency'))?' checked':'').'> '.$langs->trans("Busy");
|
|
print '</div>';
|
|
}*/
|
|
print '</td></tr>';
|
|
|
|
// Realised by
|
|
if (!empty($conf->global->AGENDA_ENABLE_DONEBY))
|
|
{
|
|
print '<tr><td class="nowrap">'.$langs->trans("ActionDoneBy").'</td><td>';
|
|
print $form->select_dolusers(GETPOST("doneby") ?GETPOST("doneby") : (!empty($object->userdoneid) && $percent == 100 ? $object->userdoneid : 0), 'doneby', 1);
|
|
print '</td></tr>';
|
|
}
|
|
|
|
if ($conf->categorie->enabled) {
|
|
// Categories
|
|
print '<tr><td>'.$langs->trans("Categories").'</td><td colspan="3">';
|
|
$cate_arbo = $form->select_all_categories(Categorie::TYPE_ACTIONCOMM, '', 'parent', 64, 0, 1);
|
|
print $form->multiselectarray('categories', $cate_arbo, GETPOST('categories', 'array'), '', 0, '', 0, '100%');
|
|
print "</td></tr>";
|
|
}
|
|
|
|
print '</table>';
|
|
|
|
|
|
print '<br><hr><br>';
|
|
|
|
|
|
print '<table class="border centpercent">';
|
|
|
|
if ($conf->societe->enabled)
|
|
{
|
|
// Related company
|
|
print '<tr><td class="titlefieldcreate nowrap">'.$langs->trans("ActionOnCompany").'</td><td>';
|
|
if (GETPOST('socid', 'int') > 0)
|
|
{
|
|
$societe = new Societe($db);
|
|
$societe->fetch(GETPOST('socid', 'int'));
|
|
print $societe->getNomUrl(1);
|
|
print '<input type="hidden" id="socid" name="socid" value="'.GETPOST('socid', 'int').'">';
|
|
}
|
|
else
|
|
{
|
|
$events = array();
|
|
$events[] = array('method' => 'getContacts', 'url' => dol_buildpath('/core/ajax/contacts.php?showempty=1', 1), 'htmlname' => 'contactid', 'params' => array('add-customer-contact' => 'disabled'));
|
|
//For external user force the company to user company
|
|
if (!empty($user->socid)) {
|
|
print $form->select_company($user->socid, 'socid', '', 1, 1, 0, $events, 0, 'minwidth300');
|
|
} else {
|
|
print $form->select_company('', 'socid', '', 'SelectThirdParty', 1, 0, $events, 0, 'minwidth300');
|
|
}
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// Related contact
|
|
print '<tr><td class="nowrap">'.$langs->trans("ActionOnContact").'</td><td>';
|
|
$preselectedids = GETPOST('socpeopleassigned', 'array');
|
|
if (GETPOST('contactid', 'int')) $preselectedids[GETPOST('contactid', 'int')] = GETPOST('contactid', 'int');
|
|
print $form->selectcontacts(GETPOST('socid', 'int'), $preselectedids, 'socpeopleassigned[]', 1, '', '', 0, 'quatrevingtpercent', false, 0, array(), false, 'multiple', 'contactid');
|
|
print '</td></tr>';
|
|
}
|
|
|
|
// Project
|
|
if (!empty($conf->projet->enabled))
|
|
{
|
|
$langs->load("projects");
|
|
|
|
$projectid = GETPOST('projectid', 'int');
|
|
|
|
print '<tr><td class="titlefieldcreate">'.$langs->trans("Project").'</td><td id="project-input-container" >';
|
|
|
|
$numproject = $formproject->select_projects((!empty($societe->id) ? $societe->id : -1), $projectid, 'projectid', 0, 0, 1, 1, 0, 0, 0, '', 0, 0, 'maxwidth500');
|
|
|
|
print ' <a href="'.DOL_URL_ROOT.'/projet/card.php?socid='.$societe->id.'&action=create"><span class="fa fa-plus-circle valignmiddle paddingleft" title="'.$langs->trans("AddProject").'"></span></a>';
|
|
$urloption = '?action=create&donotclearsession=1';
|
|
$url = dol_buildpath('comm/action/card.php', 2).$urloption;
|
|
|
|
// update task list
|
|
print "\n".'<script type="text/javascript">';
|
|
print '$(document).ready(function () {
|
|
$("#projectid").change(function () {
|
|
var url = "'.$url.'&projectid="+$("#projectid").val();
|
|
$.get(url, function(data) {
|
|
console.log($( data ).find("#taskid").html());
|
|
if (data) $("#taskid").html( $( data ).find("#taskid").html() ).select2();
|
|
})
|
|
});
|
|
})';
|
|
print '</script>'."\n";
|
|
|
|
print '</td></tr>';
|
|
|
|
print '<tr><td class="titlefieldcreate">'.$langs->trans("Task").'</td><td id="project-task-input-container" >';
|
|
|
|
$projectsListId = false;
|
|
if (!empty($projectid)) { $projectsListId = $projectid; }
|
|
$tid = GETPOST("projecttaskid") ?GETPOST("projecttaskid") : '';
|
|
$formproject->selectTasks((!empty($societe->id) ? $societe->id : -1), $tid, 'taskid', 24, 0, '1', 1, 0, 0, 'maxwidth500', $projectsListId);
|
|
print '</td></tr>';
|
|
}
|
|
|
|
// Object linked
|
|
if (!empty($origin) && !empty($originid))
|
|
{
|
|
include_once DOL_DOCUMENT_ROOT.'/core/lib/functions2.lib.php';
|
|
print '<tr><td class="titlefieldcreate">'.$langs->trans("LinkedObject").'</td>';
|
|
print '<td colspan="3">'.dolGetElementUrl($originid, $origin, 1).'</td></tr>';
|
|
print '<input type="hidden" name="fk_element" size="10" value="'.GETPOST('originid').'">';
|
|
print '<input type="hidden" name="elementtype" size="10" value="'.GETPOST('origin').'">';
|
|
print '<input type="hidden" name="originid" size="10" value="'.GETPOST('originid').'">';
|
|
print '<input type="hidden" name="origin" size="10" value="'.GETPOST('origin').'">';
|
|
}
|
|
|
|
$reg = array();
|
|
if (GETPOST("datep") && preg_match('/^([0-9][0-9][0-9][0-9])([0-9][0-9])([0-9][0-9])$/', GETPOST("datep"), $reg))
|
|
{
|
|
$object->datep = dol_mktime(0, 0, 0, $reg[2], $reg[3], $reg[1]);
|
|
}
|
|
|
|
// Priority
|
|
print '<tr><td class="titlefieldcreate nowrap">'.$langs->trans("Priority").'</td><td colspan="3">';
|
|
print '<input type="text" name="priority" value="'.(GETPOST('priority') ?GETPOST('priority') : ($object->priority ? $object->priority : '')).'" size="5">';
|
|
print '</td></tr>';
|
|
|
|
// Description
|
|
print '<tr><td class="tdtop">'.$langs->trans("Description").'</td><td>';
|
|
require_once DOL_DOCUMENT_ROOT.'/core/class/doleditor.class.php';
|
|
$doleditor = new DolEditor('note', (GETPOST('note', 'none') ? GETPOST('note', 'none') : $object->note_private), '', 180, 'dolibarr_notes', 'In', true, true, $conf->fckeditor->enabled, ROWS_4, '90%');
|
|
$doleditor->Create();
|
|
print '</td></tr>';
|
|
|
|
// Other attributes
|
|
$parameters = array();
|
|
$reshook = $hookmanager->executeHooks('formObjectOptions', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
|
|
print $hookmanager->resPrint;
|
|
if (empty($reshook))
|
|
{
|
|
print $object->showOptionals($extrafields, 'edit', $parameters);
|
|
}
|
|
|
|
print '</table>';
|
|
|
|
dol_fiche_end();
|
|
|
|
print '<div class="center">';
|
|
print '<input type="submit" class="button" value="'.$langs->trans("Add").'">';
|
|
print ' ';
|
|
print '<input type="button" class="button" name="cancel" value="'.$langs->trans("Cancel").'" onClick="javascript:history.go(-1)">';
|
|
print '</div>';
|
|
|
|
print "</form>";
|
|
}
|
|
|
|
// View or edit
|
|
if ($id > 0)
|
|
{
|
|
$result1 = $object->fetch($id);
|
|
if ($result1 <= 0)
|
|
{
|
|
$langs->load("errors");
|
|
print $langs->trans("ErrorRecordNotFound");
|
|
|
|
llxFooter();
|
|
exit;
|
|
}
|
|
|
|
$result2 = $object->fetch_thirdparty();
|
|
$result2 = $object->fetch_projet();
|
|
$result3 = $object->fetch_contact();
|
|
$result4 = $object->fetch_userassigned();
|
|
$result5 = $object->fetch_optionals();
|
|
|
|
if ($listUserAssignedUpdated || $donotclearsession)
|
|
{
|
|
$percentage = in_array(GETPOST('status'), array(-1, 100)) ?GETPOST('status') : (in_array(GETPOST('complete'), array(-1, 100)) ?GETPOST('complete') : GETPOST("percentage")); // If status is -1 or 100, percentage is not defined and we must use status
|
|
|
|
$datep = dol_mktime($fulldayevent ? '00' : $aphour, $fulldayevent ? '00' : $apmin, 0, $_POST["apmonth"], $_POST["apday"], $_POST["apyear"]);
|
|
$datef = dol_mktime($fulldayevent ? '23' : $p2hour, $fulldayevent ? '59' : $p2min, $fulldayevent ? '59' : '0', $_POST["p2month"], $_POST["p2day"], $_POST["p2year"]);
|
|
|
|
$object->type_id = dol_getIdFromCode($db, GETPOST("actioncode", 'aZ09'), 'c_actioncomm');
|
|
$object->label = GETPOST("label", "alphanohtml");
|
|
$object->datep = $datep;
|
|
$object->datef = $datef;
|
|
$object->percentage = $percentage;
|
|
$object->priority = GETPOST("priority", "alphanohtml");
|
|
$object->fulldayevent = GETPOST("fullday") ? 1 : 0;
|
|
$object->location = GETPOST('location', "alpanohtml");
|
|
$object->socid = GETPOST("socid", "int");
|
|
$socpeopleassigned = GETPOST("socpeopleassigned", 'array');
|
|
foreach ($socpeopleassigned as $tmpid) $object->socpeopleassigned[$id] = array('id' => $tmpid);
|
|
$object->contactid = GETPOST("contactid", 'int');
|
|
$object->fk_project = GETPOST("projectid", 'int');
|
|
|
|
$object_private = GETPOST("note", 'none');
|
|
}
|
|
|
|
if ($result2 < 0 || $result3 < 0 || $result4 < 0 || $result5 < 0)
|
|
{
|
|
dol_print_error($db, $object->error);
|
|
exit;
|
|
}
|
|
|
|
if ($object->authorid > 0) { $tmpuser = new User($db); $res = $tmpuser->fetch($object->authorid); $object->author = $tmpuser; }
|
|
if ($object->usermodid > 0) { $tmpuser = new User($db); $res = $tmpuser->fetch($object->usermodid); $object->usermod = $tmpuser; }
|
|
|
|
|
|
/*
|
|
* Show tabs
|
|
*/
|
|
|
|
$head = actions_prepare_head($object);
|
|
|
|
$now = dol_now();
|
|
$delay_warning = $conf->global->MAIN_DELAY_ACTIONS_TODO * 24 * 60 * 60;
|
|
|
|
// Confirmation suppression action
|
|
if ($action == 'delete')
|
|
{
|
|
print $form->formconfirm("card.php?id=".$id, $langs->trans("DeleteAction"), $langs->trans("ConfirmDeleteAction"), "confirm_delete", '', '', 1);
|
|
}
|
|
|
|
if ($action == 'edit')
|
|
{
|
|
if (!empty($conf->use_javascript_ajax))
|
|
{
|
|
print "\n".'<script type="text/javascript">';
|
|
print '$(document).ready(function () {
|
|
function setdatefields()
|
|
{
|
|
if ($("#fullday:checked").val() == null) {
|
|
$(".fulldaystarthour").removeAttr("disabled");
|
|
$(".fulldaystartmin").removeAttr("disabled");
|
|
$(".fulldayendhour").removeAttr("disabled");
|
|
$(".fulldayendmin").removeAttr("disabled");
|
|
} else {
|
|
$(".fulldaystarthour").prop("disabled", true).val("00");
|
|
$(".fulldaystartmin").prop("disabled", true).val("00");
|
|
$(".fulldayendhour").prop("disabled", true).val("23");
|
|
$(".fulldayendmin").prop("disabled", true).val("59");
|
|
}
|
|
}
|
|
setdatefields();
|
|
$("#fullday").change(function() {
|
|
setdatefields();
|
|
});
|
|
})';
|
|
print '</script>'."\n";
|
|
}
|
|
|
|
print '<form name="formaction" action="'.$_SERVER['PHP_SELF'].'" method="POST">';
|
|
print '<input type="hidden" name="token" value="'.newToken().'">';
|
|
print '<input type="hidden" name="action" value="update">';
|
|
print '<input type="hidden" name="id" value="'.$id.'">';
|
|
print '<input type="hidden" name="ref_ext" value="'.$object->ref_ext.'">';
|
|
if ($backtopage) print '<input type="hidden" name="backtopage" value="'.($backtopage != '1' ? $backtopage : htmlentities($_SERVER["HTTP_REFERER"])).'">';
|
|
if (empty($conf->global->AGENDA_USE_EVENT_TYPE)) print '<input type="hidden" name="actioncode" value="'.$object->type_code.'">';
|
|
|
|
dol_fiche_head($head, 'card', $langs->trans("Action"), 0, 'action');
|
|
|
|
print '<table class="border tableforfield" width="100%">';
|
|
|
|
// Ref
|
|
print '<tr><td class="titlefieldcreate">'.$langs->trans("Ref").'</td><td colspan="3">'.$object->id.'</td></tr>';
|
|
|
|
// Type of event
|
|
if (!empty($conf->global->AGENDA_USE_EVENT_TYPE))
|
|
{
|
|
print '<tr><td class="fieldrequired">'.$langs->trans("Type").'</td><td colspan="3">';
|
|
if ($object->type_code != 'AC_OTH_AUTO')
|
|
{
|
|
$formactions->select_type_actions(GETPOST("actioncode", 'aZ09') ?GETPOST("actioncode", 'aZ09') : $object->type_code, "actioncode", "systemauto");
|
|
}
|
|
else
|
|
{
|
|
print '<input type="hidden" name="actioncode" value="'.$object->type_code.'">'.$langs->trans("Action".$object->type_code);
|
|
}
|
|
print '</td></tr>';
|
|
}
|
|
|
|
// Title
|
|
print '<tr><td class="fieldrequired">'.$langs->trans("Title").'</td><td colspan="3"><input type="text" name="label" class="soixantepercent" value="'.$object->label.'"></td></tr>';
|
|
|
|
// Full day event
|
|
print '<tr><td>'.$langs->trans("EventOnFullDay").'</td><td colspan="3"><input type="checkbox" id="fullday" name="fullday" '.($object->fulldayevent ? ' checked' : '').'></td></tr>';
|
|
|
|
// Date start
|
|
print '<tr><td class="nowrap"><span class="fieldrequired">'.$langs->trans("DateActionStart").'</span></td><td colspan="3">';
|
|
if (GETPOST("afaire") == 1) {
|
|
print $form->selectDate($datep ? $datep : $object->datep, 'ap', 1, 1, 0, "action", 1, 1, 0, 'fulldaystart');
|
|
} elseif (GETPOST("afaire") == 2) {
|
|
print $form->selectDate($datep ? $datep : $object->datep, 'ap', 1, 1, 1, "action", 1, 1, 0, 'fulldaystart');
|
|
} else {
|
|
print $form->selectDate($datep ? $datep : $object->datep, 'ap', 1, 1, 1, "action", 1, 1, 0, 'fulldaystart');
|
|
}
|
|
print '</td></tr>';
|
|
// Date end
|
|
print '<tr><td>'.$langs->trans("DateActionEnd").'</td><td colspan="3">';
|
|
if (GETPOST("afaire") == 1) {
|
|
print $form->selectDate($datef ? $datef : $object->datef, 'p2', 1, 1, 1, "action", 1, 1, 0, 'fulldayend');
|
|
} elseif (GETPOST("afaire") == 2) {
|
|
print $form->selectDate($datef ? $datef : $object->datef, 'p2', 1, 1, 1, "action", 1, 1, 0, 'fulldayend');
|
|
} else {
|
|
print $form->selectDate($datef ? $datef : $object->datef, 'p2', 1, 1, 1, "action", 1, 1, 0, 'fulldayend');
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// Dev in progress
|
|
$userepeatevent = ($conf->global->MAIN_FEATURES_LEVEL == 2 ? 1 : 0);
|
|
if ($userepeatevent)
|
|
{
|
|
// Repeat
|
|
print '<tr><td>'.$langs->trans("RepeatEvent").'</td><td colspan="3">';
|
|
print '<input type="hidden" name="recurid" value="'.$object->recurid.'">';
|
|
$arrayrecurrulefreq = array(
|
|
'no'=>$langs->trans("No"),
|
|
'MONTHLY'=>$langs->trans("EveryMonth"),
|
|
'WEEKLY'=>$langs->trans("EveryWeek"),
|
|
//'DAYLY'=>$langs->trans("EveryDay"),
|
|
);
|
|
$selectedrecurrulefreq = 'no';
|
|
$selectedrecurrulebymonthday = '';
|
|
$selectedrecurrulebyday = '';
|
|
if ($object->recurrule && preg_match('/FREQ=([A-Z]+)/i', $object->recurrule, $reg)) $selectedrecurrulefreq = $reg[1];
|
|
if ($object->recurrule && preg_match('/FREQ=MONTHLY.*BYMONTHDAY=(\d+)/i', $object->recurrule, $reg)) $selectedrecurrulebymonthday = $reg[1];
|
|
if ($object->recurrule && preg_match('/FREQ=WEEKLY.*BYDAY(\d+)/i', $object->recurrule, $reg)) $selectedrecurrulebyday = $reg[1];
|
|
print $form->selectarray('recurrulefreq', $arrayrecurrulefreq, $selectedrecurrulefreq, 0, 0, 0, '', 0, 0, 0, '', 'marginrightonly');
|
|
// If recurrulefreq is MONTHLY
|
|
print '<div class="hidden marginrightonly inline-block repeateventBYMONTHDAY">';
|
|
print $langs->trans("DayOfMonth").': <input type="input" size="2" name="BYMONTHDAY" value="'.$selectedrecurrulebymonthday.'">';
|
|
print '</div>';
|
|
// If recurrulefreq is WEEKLY
|
|
print '<div class="hidden marginrightonly inline-block repeateventBYDAY">';
|
|
print $langs->trans("DayOfWeek").': <input type="input" size="4" name="BYDAY" value="'.$selectedrecurrulebyday.'">';
|
|
print '</div>';
|
|
print '<script type="text/javascript" language="javascript">
|
|
jQuery(document).ready(function() {
|
|
function init_repeat()
|
|
{
|
|
if (jQuery("#recurrulefreq").val() == \'MONTHLY\')
|
|
{
|
|
jQuery(".repeateventBYMONTHDAY").css("display", "inline-block"); /* use this instead of show because we want inline-block and not block */
|
|
jQuery(".repeateventBYDAY").hide();
|
|
}
|
|
else if (jQuery("#recurrulefreq").val() == \'WEEKLY\')
|
|
{
|
|
jQuery(".repeateventBYMONTHDAY").hide();
|
|
jQuery(".repeateventBYDAY").css("display", "inline-block"); /* use this instead of show because we want inline-block and not block */
|
|
}
|
|
else
|
|
{
|
|
jQuery(".repeateventBYMONTHDAY").hide();
|
|
jQuery(".repeateventBYDAY").hide();
|
|
}
|
|
}
|
|
init_repeat();
|
|
jQuery("#recurrulefreq").change(function() {
|
|
init_repeat();
|
|
});
|
|
});
|
|
</script>';
|
|
print '</td></tr>';
|
|
}
|
|
|
|
// Status
|
|
print '<tr><td class="nowrap">'.$langs->trans("Status").' / '.$langs->trans("Percentage").'</td><td colspan="3">';
|
|
$percent = GETPOST("percentage") ? GETPOST("percentage") : $object->percentage;
|
|
$formactions->form_select_status_action('formaction', $percent, 1);
|
|
print '</td></tr>';
|
|
|
|
// Location
|
|
if (empty($conf->global->AGENDA_DISABLE_LOCATION))
|
|
{
|
|
print '<tr><td>'.$langs->trans("Location").'</td><td colspan="3"><input type="text" name="location" class="soixantepercent" value="'.$object->location.'"></td></tr>';
|
|
}
|
|
|
|
// Assigned to
|
|
$listofuserid = array(); // User assigned
|
|
if (empty($donotclearsession))
|
|
{
|
|
if ($object->userownerid > 0)
|
|
{
|
|
$listofuserid[$object->userownerid] = array(
|
|
'id'=>$object->userownerid,
|
|
'type'=>'user',
|
|
//'transparency'=>$object->userassigned[$user->id]['transparency'],
|
|
'transparency'=>$object->transparency, // Force transparency on ownerfrom event
|
|
'answer_status'=>$object->userassigned[$object->userownerid]['answer_status'],
|
|
'mandatory'=>$object->userassigned[$object->userownerid]['mandatory']
|
|
);
|
|
}
|
|
if (!empty($object->userassigned)) // Now concat assigned users
|
|
{
|
|
// Restore array with key with same value than param 'id'
|
|
$tmplist1 = $object->userassigned;
|
|
foreach ($tmplist1 as $key => $val)
|
|
{
|
|
if ($val['id'] && $val['id'] != $object->userownerid)
|
|
{
|
|
$listofuserid[$val['id']] = $val;
|
|
}
|
|
}
|
|
}
|
|
$_SESSION['assignedtouser'] = json_encode($listofuserid);
|
|
}
|
|
else
|
|
{
|
|
if (!empty($_SESSION['assignedtouser']))
|
|
{
|
|
$listofuserid = json_decode($_SESSION['assignedtouser'], true);
|
|
}
|
|
}
|
|
$listofcontactid = $object->socpeopleassigned; // Contact assigned
|
|
$listofotherid = $object->otherassigned; // Other undefined email (not used yet)
|
|
|
|
print '<tr><td class="tdtop nowrap fieldrequired">'.$langs->trans("ActionAssignedTo").'</td><td colspan="3">';
|
|
print '<div class="assignedtouser">';
|
|
print $form->select_dolusers_forevent(($action == 'create' ? 'add' : 'update'), 'assignedtouser', 1, '', 0, '', '', 0, 0, 0, 'AND u.statut != 0', 1, $listofuserid, $listofcontactid, $listofotherid);
|
|
print '</div>';
|
|
/*if (in_array($user->id,array_keys($listofuserid)))
|
|
{
|
|
print '<div class="myavailability">';
|
|
print $langs->trans("MyAvailability").': <input id="transparency" type="checkbox" name="transparency"'.($listofuserid[$user->id]['transparency']?' checked':'').'>'.$langs->trans("Busy");
|
|
print '</div>';
|
|
}*/
|
|
print '</td></tr>';
|
|
|
|
// Realised by
|
|
if (!empty($conf->global->AGENDA_ENABLE_DONEBY))
|
|
{
|
|
print '<tr><td class="nowrap">'.$langs->trans("ActionDoneBy").'</td><td colspan="3">';
|
|
print $form->select_dolusers($object->userdoneid > 0 ? $object->userdoneid : -1, 'doneby', 1);
|
|
print '</td></tr>';
|
|
}
|
|
// Tags-Categories
|
|
if ($conf->categorie->enabled) {
|
|
print '<tr><td>'.$langs->trans("Categories").'</td><td colspan="3">';
|
|
$cate_arbo = $form->select_all_categories(Categorie::TYPE_ACTIONCOMM, '', 'parent', 64, 0, 1);
|
|
$c = new Categorie($db);
|
|
$cats = $c->containing($object->id, Categorie::TYPE_ACTIONCOMM);
|
|
$arrayselected = array();
|
|
foreach ($cats as $cat) {
|
|
$arrayselected[] = $cat->id;
|
|
}
|
|
print $form->multiselectarray('categories', $cate_arbo, $arrayselected, '', 0, '', 0, '100%');
|
|
print "</td></tr>";
|
|
}
|
|
|
|
print '</table>';
|
|
|
|
|
|
print '<br><hr><br>';
|
|
|
|
|
|
print '<table class="border tableforfield" width="100%">';
|
|
|
|
if ($conf->societe->enabled)
|
|
{
|
|
// Related company
|
|
print '<tr><td class="titlefieldcreate">'.$langs->trans("ActionOnCompany").'</td>';
|
|
print '<td>';
|
|
print '<div class="maxwidth200onsmartphone">';
|
|
$events = array(); // 'method'=parameter action of url, 'url'=url to call that return new list of contacts
|
|
$events[] = array('method' => 'getContacts', 'url' => dol_buildpath('/core/ajax/contacts.php?showempty=1', 1), 'htmlname' => 'contactid', 'params' => array('add-customer-contact' => 'disabled'));
|
|
// TODO Refresh also list of project if $conf->global->PROJECT_ALLOW_TO_LINK_FROM_OTHER_COMPANY not defined with list linked to socid ?
|
|
// FIXME If we change company, we may get a project that does not match
|
|
print $form->select_company($object->socid, 'socid', '', 'SelectThirdParty', 1, 0, $events, 0, 'minwidth200');
|
|
print '</div>';
|
|
print '</td></tr>';
|
|
|
|
// related contact
|
|
print '<tr><td>'.$langs->trans("ActionOnContact").'</td><td>';
|
|
print '<div class="maxwidth200onsmartphone">';
|
|
print $form->selectcontacts($object->socid, array_keys($object->socpeopleassigned), 'socpeopleassigned[]', 1, '', '', 1, 'quatrevingtpercent', false, 0, 0, array(), 'multiple', 'contactid');
|
|
print '</div>';
|
|
print '</td>';
|
|
print '</tr>';
|
|
}
|
|
|
|
// Project
|
|
if (!empty($conf->projet->enabled))
|
|
{
|
|
$langs->load("projects");
|
|
|
|
print '<tr><td class="titlefieldcreate">'.$langs->trans("Project").'</td><td>';
|
|
$numprojet = $formproject->select_projects(($object->socid > 0 ? $object->socid : -1), $object->fk_project, 'projectid', 0, 0, 1, 0, 0, 0, 0, '', 0, 0, 'maxwidth500');
|
|
if ($numprojet == 0)
|
|
{
|
|
print ' <a href="'.DOL_URL_ROOT.'/projet/card.php?socid='.$object->socid.'&action=create&backtopage='.urlencode($_SERVER["PHP_SELF"].'?id='.$object->id.'&action=edit').'"><span class="fa fa-plus-circle valignmiddle paddingleft" title="'.$langs->trans("AddProject").'"></span></a>';
|
|
}
|
|
print '</td></tr>';
|
|
}
|
|
|
|
// Priority
|
|
print '<tr><td class="titlefieldcreate nowrap">'.$langs->trans("Priority").'</td><td>';
|
|
print '<input type="text" name="priority" value="'.($object->priority ? $object->priority : '').'" size="5">';
|
|
print '</td></tr>';
|
|
|
|
// Object linked
|
|
if (!empty($object->fk_element) && !empty($object->elementtype))
|
|
{
|
|
include_once DOL_DOCUMENT_ROOT.'/core/lib/functions2.lib.php';
|
|
print '<tr>';
|
|
print '<td>'.$langs->trans("LinkedObject").'</td>';
|
|
|
|
if ($object->elementtype == 'task' && !empty($conf->projet->enabled))
|
|
{
|
|
print '<td id="project-task-input-container" >';
|
|
|
|
$urloption = '?action=create&donotclearsession=1'; // we use create not edit for more flexibility
|
|
$url = DOL_URL_ROOT.'/comm/action/card.php'.$urloption;
|
|
|
|
// update task list
|
|
print "\n".'<script type="text/javascript" >';
|
|
print '$(document).ready(function () {
|
|
$("#projectid").change(function () {
|
|
var url = "'.$url.'&projectid="+$("#projectid").val();
|
|
$.get(url, function(data) {
|
|
console.log($( data ).find("#fk_element").html());
|
|
if (data) $("#fk_element").html( $( data ).find("#taskid").html() ).select2();
|
|
})
|
|
});
|
|
})';
|
|
print '</script>'."\n";
|
|
|
|
$formproject->selectTasks((!empty($societe->id) ? $societe->id : -1), $object->fk_element, 'fk_element', 24, 0, 0, 1, 0, 0, 'maxwidth500', $object->fk_project);
|
|
print '<input type="hidden" name="elementtype" value="'.$object->elementtype.'">';
|
|
|
|
print '</td>';
|
|
}
|
|
else
|
|
{
|
|
print '<td>';
|
|
print dolGetElementUrl($object->fk_element, $object->elementtype, 1);
|
|
print '<input type="hidden" name="fk_element" value="'.$object->fk_element.'">';
|
|
print '<input type="hidden" name="elementtype" value="'.$object->elementtype.'">';
|
|
print '</td>';
|
|
}
|
|
|
|
print '</tr>';
|
|
}
|
|
|
|
// Description
|
|
print '<tr><td class="tdtop">'.$langs->trans("Description").'</td><td>';
|
|
// Editeur wysiwyg
|
|
require_once DOL_DOCUMENT_ROOT.'/core/class/doleditor.class.php';
|
|
$doleditor = new DolEditor('note', $object->note_private, '', 200, 'dolibarr_notes', 'In', true, true, $conf->fckeditor->enabled, ROWS_5, '90%');
|
|
$doleditor->Create();
|
|
print '</td></tr>';
|
|
|
|
// Other attributes
|
|
$parameters = array();
|
|
$reshook = $hookmanager->executeHooks('formObjectOptions', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
|
|
print $hookmanager->resPrint;
|
|
if (empty($reshook))
|
|
{
|
|
print $object->showOptionals($extrafields, 'edit', $parameters);
|
|
}
|
|
|
|
print '</table>';
|
|
|
|
dol_fiche_end();
|
|
|
|
print '<div class="center">';
|
|
print '<input type="submit" class="button" name="edit" value="'.$langs->trans("Save").'">';
|
|
print ' ';
|
|
print '<input type="submit" class="button" name="cancel" value="'.$langs->trans("Cancel").'">';
|
|
print '</div>';
|
|
|
|
print '</form>';
|
|
}
|
|
else
|
|
{
|
|
dol_fiche_head($head, 'card', $langs->trans("Action"), -1, 'action');
|
|
|
|
|
|
// Clone event
|
|
if ($action == 'clone')
|
|
{
|
|
$formconfirm = $form->formconfirm($_SERVER["PHP_SELF"].'?id='.GETPOST('id'), $langs->trans('ToClone'), $langs->trans('ConfirmCloneEvent', $object->label), 'confirm_clone', $formquestion, 'yes', 1);
|
|
|
|
print $formconfirm;
|
|
}
|
|
|
|
$linkback = '';
|
|
// Link to other agenda views
|
|
$linkback .= img_picto($langs->trans("BackToList"), 'object_list-alt', 'class="hideonsmartphone pictoactionview"');
|
|
$linkback .= '<a href="'.DOL_URL_ROOT.'/comm/action/list.php?restore_lastsearch_values=1">'.$langs->trans("BackToList").'</a>';
|
|
$linkback .= '</li>';
|
|
$linkback .= '<li class="noborder litext">';
|
|
$linkback .= img_picto($langs->trans("ViewCal"), 'object_calendar', 'class="hideonsmartphone pictoactionview"');
|
|
$linkback .= '<a href="'.DOL_URL_ROOT.'/comm/action/index.php?action=show_month&year='.dol_print_date($object->datep, '%Y').'&month='.dol_print_date($object->datep, '%m').'&day='.dol_print_date($object->datep, '%d').'">'.$langs->trans("ViewCal").'</a>';
|
|
$linkback .= '</li>';
|
|
$linkback .= '<li class="noborder litext">';
|
|
$linkback .= img_picto($langs->trans("ViewWeek"), 'object_calendarweek', 'class="hideonsmartphone pictoactionview"');
|
|
$linkback .= '<a href="'.DOL_URL_ROOT.'/comm/action/index.php?action=show_week&year='.dol_print_date($object->datep, '%Y').'&month='.dol_print_date($object->datep, '%m').'&day='.dol_print_date($object->datep, '%d').'">'.$langs->trans("ViewWeek").'</a>';
|
|
$linkback .= '</li>';
|
|
$linkback .= '<li class="noborder litext">';
|
|
$linkback .= img_picto($langs->trans("ViewDay"), 'object_calendarday', 'class="hideonsmartphone pictoactionview"');
|
|
$linkback .= '<a href="'.DOL_URL_ROOT.'/comm/action/index.php?action=show_day&year='.dol_print_date($object->datep, '%Y').'&month='.dol_print_date($object->datep, '%m').'&day='.dol_print_date($object->datep, '%d').'">'.$langs->trans("ViewDay").'</a>';
|
|
$linkback .= '</li>';
|
|
$linkback .= '<li class="noborder litext">';
|
|
$linkback .= img_picto($langs->trans("ViewPerUser"), 'object_calendarperuser', 'class="hideonsmartphone pictoactionview"');
|
|
$linkback .= '<a href="'.DOL_URL_ROOT.'/comm/action/peruser.php?action=show_peruser&year='.dol_print_date($object->datep, '%Y').'&month='.dol_print_date($object->datep, '%m').'&day='.dol_print_date($object->datep, '%d').'">'.$langs->trans("ViewPerUser").'</a>';
|
|
|
|
//$linkback.=$out;
|
|
|
|
$morehtmlref = '<div class="refidno">';
|
|
// Thirdparty
|
|
//$morehtmlref.='<br>'.$langs->trans('ThirdParty') . ' : ' . $object->thirdparty->getNomUrl(1);
|
|
// Project
|
|
if (!empty($conf->projet->enabled))
|
|
{
|
|
$langs->load("projects");
|
|
//$morehtmlref.='<br>'.$langs->trans('Project') . ' ';
|
|
$morehtmlref .= $langs->trans('Project').' ';
|
|
if ($user->rights->agenda->allactions->create ||
|
|
(($object->authorid == $user->id || $object->userownerid == $user->id) && $user->rights->agenda->myactions->create))
|
|
{
|
|
if ($action != 'classify') {
|
|
$morehtmlref .= '<a class="editfielda" href="'.$_SERVER['PHP_SELF'].'?action=classify&id='.$object->id.'">'.img_edit($langs->transnoentitiesnoconv('SetProject')).'</a> : ';
|
|
}
|
|
if ($action == 'classify') {
|
|
//$morehtmlref.=$form->form_project($_SERVER['PHP_SELF'] . '?id=' . $object->id, $object->socid, $object->fk_project, 'projectid', 0, 0, 1, 1);
|
|
$morehtmlref .= '<form method="post" action="'.$_SERVER['PHP_SELF'].'?id='.$object->id.'">';
|
|
$morehtmlref .= '<input type="hidden" name="action" value="classin">';
|
|
$morehtmlref .= '<input type="hidden" name="token" value="'.newToken().'">';
|
|
$morehtmlref .= $formproject->select_projects($object->socid, $object->fk_project, 'projectid', $maxlength, 0, 1, 0, 1, 0, 0, '', 1);
|
|
$morehtmlref .= '<input type="submit" class="button valignmiddle" value="'.$langs->trans("Modify").'">';
|
|
$morehtmlref .= '</form>';
|
|
} else {
|
|
$morehtmlref .= $form->form_project($_SERVER['PHP_SELF'].'?id='.$object->id, $object->socid, $object->fk_project, 'none', 0, 0, 0, 1);
|
|
}
|
|
} else {
|
|
if (!empty($object->fk_project)) {
|
|
$proj = new Project($db);
|
|
$proj->fetch($object->fk_project);
|
|
$morehtmlref .= '<a href="'.DOL_URL_ROOT.'/projet/card.php?id='.$object->fk_project.'" title="'.$langs->trans('ShowProject').'">';
|
|
$morehtmlref .= $proj->ref;
|
|
$morehtmlref .= '</a>';
|
|
if ($proj->title) $morehtmlref .= ' - '.$proj->title;
|
|
} else {
|
|
$morehtmlref .= '';
|
|
}
|
|
}
|
|
}
|
|
$morehtmlref .= '</div>';
|
|
|
|
|
|
dol_banner_tab($object, 'id', $linkback, ($user->socid ? 0 : 1), 'id', 'ref', $morehtmlref);
|
|
|
|
print '<div class="fichecenter">';
|
|
|
|
print '<div class="underbanner clearboth"></div>';
|
|
|
|
// Affichage fiche action en mode visu
|
|
print '<table class="border tableforfield" width="100%">';
|
|
|
|
// Type
|
|
if (!empty($conf->global->AGENDA_USE_EVENT_TYPE))
|
|
{
|
|
print '<tr><td class="titlefield">'.$langs->trans("Type").'</td><td colspan="3">'.$langs->trans($object->type).'</td></tr>';
|
|
}
|
|
|
|
// Full day event
|
|
print '<tr><td class="titlefield">'.$langs->trans("EventOnFullDay").'</td><td colspan="3">'.yn($object->fulldayevent, 3).'</td></tr>';
|
|
|
|
$rowspan = 4;
|
|
if (empty($conf->global->AGENDA_DISABLE_LOCATION)) $rowspan++;
|
|
|
|
// Date start
|
|
print '<tr><td>'.$langs->trans("DateActionStart").'</td><td colspan="3">';
|
|
if (!$object->fulldayevent) print dol_print_date($object->datep, 'dayhour');
|
|
else print dol_print_date($object->datep, 'day');
|
|
if ($object->percentage == 0 && $object->datep && $object->datep < ($now - $delay_warning)) print img_warning($langs->trans("Late"));
|
|
print '</td>';
|
|
print '</tr>';
|
|
|
|
// Date end
|
|
print '<tr><td>'.$langs->trans("DateActionEnd").'</td><td colspan="3">';
|
|
if (!$object->fulldayevent) print dol_print_date($object->datef, 'dayhour');
|
|
else print dol_print_date($object->datef, 'day');
|
|
if ($object->percentage > 0 && $object->percentage < 100 && $object->datef && $object->datef < ($now - $delay_warning)) print img_warning($langs->trans("Late"));
|
|
print '</td></tr>';
|
|
|
|
// Location
|
|
if (empty($conf->global->AGENDA_DISABLE_LOCATION))
|
|
{
|
|
print '<tr><td>'.$langs->trans("Location").'</td><td colspan="3">'.$object->location.'</td></tr>';
|
|
}
|
|
|
|
// Assigned to
|
|
print '<tr><td class="nowrap">'.$langs->trans("ActionAssignedTo").'</td><td colspan="3">';
|
|
$listofuserid = array();
|
|
if (empty($donotclearsession))
|
|
{
|
|
if ($object->userownerid > 0)
|
|
{
|
|
$listofuserid[$object->userownerid] = array(
|
|
'id'=>$object->userownerid,
|
|
'transparency'=>$object->transparency, // Force transparency on onwer from preoperty of event
|
|
'answer_status'=>$object->userassigned[$object->userownerid]['answer_status'],
|
|
'mandatory'=>$object->userassigned[$object->userownerid]['mandatory']
|
|
);
|
|
}
|
|
if (!empty($object->userassigned)) // Now concat assigned users
|
|
{
|
|
// Restore array with key with same value than param 'id'
|
|
$tmplist1 = $object->userassigned;
|
|
foreach ($tmplist1 as $key => $val)
|
|
{
|
|
if ($val['id'] && $val['id'] != $object->userownerid) $listofuserid[$val['id']] = $val;
|
|
}
|
|
}
|
|
$_SESSION['assignedtouser'] = json_encode($listofuserid);
|
|
}
|
|
else
|
|
{
|
|
if (!empty($_SESSION['assignedtouser']))
|
|
{
|
|
$listofuserid = json_decode($_SESSION['assignedtouser'], true);
|
|
}
|
|
}
|
|
|
|
$listofcontactid = array(); // not used yet
|
|
$listofotherid = array(); // not used yet
|
|
print '<div class="assignedtouser">';
|
|
print $form->select_dolusers_forevent('view', 'assignedtouser', 1, '', 0, '', '', 0, 0, 0, '', ($object->datep != $object->datef) ? 1 : 0, $listofuserid, $listofcontactid, $listofotherid);
|
|
print '</div>';
|
|
/*
|
|
if ($object->datep != $object->datef && in_array($user->id,array_keys($listofuserid)))
|
|
{
|
|
//var_dump($object->userassigned);
|
|
//var_dump($listofuserid);
|
|
print '<div class="myavailability">';
|
|
print $langs->trans("MyAvailability").': '.(($object->userassigned[$user->id]['transparency'] > 0)?$langs->trans("Busy"):$langs->trans("Available")); // We show nothing if event is assigned to nobody
|
|
print '</div>';
|
|
}
|
|
*/
|
|
print ' </td></tr>';
|
|
|
|
// Done by
|
|
if ($conf->global->AGENDA_ENABLE_DONEBY)
|
|
{
|
|
print '<tr><td class="nowrap">'.$langs->trans("ActionDoneBy").'</td><td colspan="3">';
|
|
if ($object->userdoneid > 0)
|
|
{
|
|
$tmpuser = new User($db);
|
|
$tmpuser->fetch($object->userdoneid);
|
|
print $tmpuser->getNomUrl(1);
|
|
}
|
|
print '</td></tr>';
|
|
}
|
|
// Categories
|
|
if ($conf->categorie->enabled) {
|
|
print '<tr><td class="valignmiddle">'.$langs->trans("Categories").'</td><td colspan="3">';
|
|
print $form->showCategories($object->id, Categorie::TYPE_ACTIONCOMM, 1);
|
|
print "</td></tr>";
|
|
}
|
|
|
|
print '</table>';
|
|
|
|
print '<br>';
|
|
|
|
print '<div class="underbanner clearboth"></div>';
|
|
print '<table class="border tableforfield centpercent">';
|
|
|
|
if ($conf->societe->enabled)
|
|
{
|
|
// Related company
|
|
print '<tr><td class="titlefield">'.$langs->trans("ActionOnCompany").'</td><td colspan="3">'.($object->thirdparty->id ? $object->thirdparty->getNomUrl(1) : ('<span class="opacitymedium">'.$langs->trans("None").'</span>'));
|
|
if (is_object($object->thirdparty) && $object->thirdparty->id > 0 && $object->type_code == 'AC_TEL')
|
|
{
|
|
if ($object->thirdparty->fetch($object->thirdparty->id))
|
|
{
|
|
print "<br>".dol_print_phone($object->thirdparty->phone);
|
|
}
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// Related contact
|
|
print '<tr><td>'.$langs->trans("ActionOnContact").'</td>';
|
|
print '<td colspan="3">';
|
|
|
|
if (!empty($object->socpeopleassigned))
|
|
{
|
|
foreach ($object->socpeopleassigned as $cid => $Tab)
|
|
{
|
|
$contact = new Contact($db);
|
|
$result = $contact->fetch($cid);
|
|
|
|
if ($result < 0) dol_print_error($db, $contact->error);
|
|
|
|
if ($result > 0)
|
|
{
|
|
print $contact->getNomUrl(1);
|
|
if ($object->type_code == 'AC_TEL')
|
|
{
|
|
if (!empty($contact->phone_pro)) print '('.dol_print_phone($contact->phone_pro).')';
|
|
}
|
|
print '<div class="paddingright"></div>';
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
print '<span class="opacitymedium">'.$langs->trans("None").'</span>';
|
|
}
|
|
print '</td></tr>';
|
|
}
|
|
|
|
// Priority
|
|
print '<tr><td class="nowrap" class="titlefield">'.$langs->trans("Priority").'</td><td colspan="3">';
|
|
print ($object->priority ? $object->priority : '');
|
|
print '</td></tr>';
|
|
|
|
// Object linked (if link is for thirdparty, contact, project it is a recording error. We should not have links in link table
|
|
// for such objects because there is already a dedicated field into table llx_actioncomm.
|
|
if (!empty($object->fk_element) && !empty($object->elementtype) && !in_array($object->elementtype, array('societe', 'contact', 'project')))
|
|
{
|
|
include_once DOL_DOCUMENT_ROOT.'/core/lib/functions2.lib.php';
|
|
print '<tr><td>'.$langs->trans("LinkedObject").'</td>';
|
|
$link = dolGetElementUrl($object->fk_element, $object->elementtype, 1);
|
|
print '<td colspan="3">';
|
|
if (empty($link)) print '<span class="opacitymedium">'.$langs->trans("ObjectDeleted").'</span>';
|
|
else print $link;
|
|
print '</td></tr>';
|
|
}
|
|
|
|
// Description
|
|
print '<tr><td class="tdtop">'.$langs->trans("Description").'</td><td colspan="3">';
|
|
print dol_string_onlythesehtmltags(dol_htmlentitiesbr($object->note_private));
|
|
print '</td></tr>';
|
|
|
|
// Other attributes
|
|
$cols = 3;
|
|
include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_view.tpl.php';
|
|
|
|
print '</table>';
|
|
|
|
print '</div>';
|
|
|
|
dol_fiche_end();
|
|
}
|
|
|
|
|
|
/*
|
|
* Barre d'actions
|
|
*/
|
|
|
|
print '<div class="tabsAction">';
|
|
|
|
$parameters = array();
|
|
$reshook = $hookmanager->executeHooks('addMoreActionsButtons', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
|
|
if (empty($reshook))
|
|
{
|
|
if ($action != 'edit')
|
|
{
|
|
if ($user->rights->agenda->allactions->create ||
|
|
(($object->authorid == $user->id || $object->userownerid == $user->id) && $user->rights->agenda->myactions->create))
|
|
{
|
|
print '<div class="inline-block divButAction"><a class="butAction" href="card.php?action=edit&id='.$object->id.'">'.$langs->trans("Modify").'</a></div>';
|
|
}
|
|
else
|
|
{
|
|
print '<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#" title="'.$langs->trans("NotAllowed").'">'.$langs->trans("Modify").'</a></div>';
|
|
}
|
|
|
|
if ($user->rights->agenda->allactions->create ||
|
|
(($object->authorid == $user->id || $object->userownerid == $user->id) && $user->rights->agenda->myactions->create))
|
|
{
|
|
print '<div class="inline-block divButAction"><a class="butAction" href="card.php?action=clone&object='.$object->element.'&id='.$object->id.'">'.$langs->trans("ToClone").'</a></div>';
|
|
}
|
|
else
|
|
{
|
|
print '<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#" title="'.$langs->trans("NotAllowed").'">'.$langs->trans("ToClone").'</a></div>';
|
|
}
|
|
|
|
if ($user->rights->agenda->allactions->delete ||
|
|
(($object->authorid == $user->id || $object->userownerid == $user->id) && $user->rights->agenda->myactions->delete))
|
|
{
|
|
print '<div class="inline-block divButAction"><a class="butActionDelete" href="card.php?action=delete&id='.$object->id.'">'.$langs->trans("Delete").'</a></div>';
|
|
}
|
|
else
|
|
{
|
|
print '<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#" title="'.$langs->trans("NotAllowed").'">'.$langs->trans("Delete").'</a></div>';
|
|
}
|
|
}
|
|
}
|
|
|
|
print '</div>';
|
|
|
|
if ($action != 'edit')
|
|
{
|
|
if (empty($conf->global->AGENDA_DISABLE_BUILDDOC))
|
|
{
|
|
print '<div style="clear:both;"></div><div class="fichecenter"><div class="fichehalfleft">';
|
|
print '<a name="builddoc"></a>'; // ancre
|
|
|
|
/*
|
|
* Documents generes
|
|
*/
|
|
|
|
$filedir = $conf->agenda->multidir_output[$conf->entity].'/'.$object->id;
|
|
$urlsource = $_SERVER["PHP_SELF"]."?id=".$object->id;
|
|
|
|
$genallowed = $user->rights->agenda->myactions->read;
|
|
$delallowed = $user->rights->agenda->myactions->create;
|
|
|
|
|
|
print $formfile->showdocuments('actions', $object->id, $filedir, $urlsource, $genallowed, $delallowed, '', 0, 0, 0, 0, 0, '', '', '', $object->default_lang);
|
|
|
|
print '</div><div class="fichehalfright"><div class="ficheaddleft">';
|
|
|
|
|
|
print '</div></div></div>';
|
|
}
|
|
}
|
|
}
|
|
|
|
// End of page
|
|
llxFooter();
|
|
$db->close();
|