diff --git a/htdocs/admin/mails_templates.php b/htdocs/admin/mails_templates.php index 6f79d58551a..4539689568c 100644 --- a/htdocs/admin/mails_templates.php +++ b/htdocs/admin/mails_templates.php @@ -70,6 +70,7 @@ $massaction = GETPOST('massaction', 'alpha'); $confirm = GETPOST('confirm', 'alpha'); // Result of a confirmation $mode = GETPOST('mode', 'aZ09'); $optioncss = GETPOST('optioncss', 'alpha'); +$backtopage = GETPOST('backtopage'); $contextpage = GETPOST('contextpage', 'aZ09'); $id = $rowid = (GETPOSTINT('id') ? GETPOSTINT('id') : GETPOSTINT('rowid')); @@ -287,15 +288,21 @@ if ($rowid > 0) { * Actions */ -if (GETPOST('cancel', 'alpha')) { +if (GETPOST('cancel', 'alpha') || GETPOST('actioncancel', 'alpha')) { $action = 'list'; $massaction = ''; + + if (!empty($backtopage)) { + header("Location: ".$backtopage); + exit(1); + } } if (!GETPOST('confirmmassaction', 'alpha') && $massaction != 'presend' && $massaction != 'confirm_presend') { $massaction = ''; } $parameters = array(); +$object = null; $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'); @@ -439,6 +446,11 @@ if (empty($reshook)) { if ($result) { // Add is ok setEventMessages($langs->transnoentities("RecordSaved"), null, 'mesgs'); $_POST = array('id' => 25); // Clean $_POST array, we keep only id + + if (!empty($backtopage)) { + header("Location: ".$backtopage); + exit(1); + } } else { if ($db->errno() == 'DB_ERROR_RECORD_ALREADY_EXISTS') { setEventMessages($langs->transnoentities("ErrorRecordAlreadyExists"), null, 'errors'); @@ -740,6 +752,7 @@ if ($action == 'create') { print ''; print ''; print ''; + print ''; print '