* Copyright (C) 2005-2006 Laurent Destailleur * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * $Id$ * $Source$ */ /** \file htdocs/comm/mailing/fiche.php \ingroup mailing \brief Fiche mailing, onglet général \version $Revision$ */ require("./pre.inc.php"); $langs->load("mails"); $user->getrights("mailing"); if (! $user->rights->mailing->lire || $user->societe_id > 0) accessforbidden(); $message = ''; // Action envoi mailing pour tous if ($_GET["action"] == 'sendall') { // Pour des raisons de sécurité, on ne permet pas cette fonction via l'IHM, // on affiche donc juste un message $message='
'.$langs->trans("MailingNeedCommand").'
'; $message.='
'; $_GET["action"]=''; } // Action envoi test mailing if ($_POST["action"] == 'send') { $mil = new Mailing($db); $result=$mil->fetch($_POST["mailid"]); $mil->sendto = $_POST["sendto"]; if (! $mil->sendto) { $message='
'.$langs->trans("ErrorFieldRequired",$langs->trans("MailTo")).'
'; } if ($mil->sendto) { require_once(DOL_DOCUMENT_ROOT."/lib/CMailFile.class.php"); $arr_file = array(); $arr_mime = array(); $arr_name = array(); // Le message est-il en html $msgishtml=0; // Non par defaut if ($conf->fckeditor->enabled && $conf->global->FCKEDITOR_ENABLE_MAILING) $msgishtml=1; if (eregi('[ \t]*',$message)) $msgishtml=1; $mailfile = new CMailFile($mil->sujet,$mil->sendto,$mil->email_from,$mil->body, $arr_file,$arr_mime,$arr_name, '', '', 0, $msgishtml); $result=$mailfile->sendfile(); if ($result) { $message='
'.$langs->trans("MailSuccessfulySent",$mil->email_from,$mil->sendto).'
'; } else { $message='
'.$langs->trans("ResultKo").'
'.$mailfile->error.'
'; } $_GET["action"]=''; $_GET["id"]=$mil->id; } } // Action ajout mailing if ($_POST["action"] == 'add') { $message=''; $mil = new Mailing($db); $mil->email_from = trim($_POST["from"]); $mil->titre = trim($_POST["titre"]); $mil->sujet = trim($_POST["sujet"]); $mil->body = trim($_POST["body"]); if (! $mil->titre) $message.=($message?'
':'').$langs->trans("ErrorFieldRequired",$langs->trans("MailTitle")); if (! $mil->sujet) $message.=($message?'
':'').$langs->trans("ErrorFieldRequired",$langs->trans("MailTopic")); if (! $message) { if ($mil->create($user) >= 0) { Header("Location: fiche.php?id=".$mil->id); exit; } $message=$mil->error; } $message='
'.$message.'
'; $_GET["action"]="create"; } // Action mise a jour mailing if ($_POST["action"] == 'update') { $mil = new Mailing($db); $mil->id = $_POST["id"]; $mil->email_from = $_POST["from"]; $mil->titre = $_POST["titre"]; $mil->sujet = $_POST["sujet"]; $mil->body = $_POST["body"]; if ($mil->update()) { Header("Location: fiche.php?id=".$mil->id); } } // Action confirmation validation if ($_POST["action"] == 'confirm_valide') { if ($_POST["confirm"] == 'yes') { $mil = new Mailing($db); if ($mil->fetch($_GET["id"]) >= 0) { $mil->valid($user); Header("Location: fiche.php?id=".$mil->id); exit; } else { dolibarr_print_error($db); } } else { Header("Location: fiche.php?id=".$_GET["id"]); exit; } } if ($_POST["action"] == 'confirm_approve') { if ($_POST["confirm"] == 'yes') { $mil = new Mailing($db); if ($mil->fetch($_GET["id"]) >= 0) { $mil->approve($user); Header("Location: fiche.php?id=".$mil->id); exit; } else { dolibarr_print_error($db); } } else { Header("Location: fiche.php?id=".$_GET["id"]); exit; } } // Action confirmation suppression if ($_POST["action"] == 'confirm_delete') { if ($_POST["confirm"] == 'yes') { $mil = new Mailing($db); $mil->id = $_GET["id"]; if ($mil->delete($mil->id)) { Header("Location: index.php"); } } } if ($_POST["cancel"] == $langs->trans("Cancel")) { $action = ''; } llxHeader("","","Fiche Mailing"); /* * Mailing en mode création * */ $mil = new Mailing($db); if ($_GET["action"] == 'create') { print '
'."\n"; print ''; print_titre($langs->trans("NewMailing")); if ($message) print "$message
"; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print '
'.$langs->trans("MailFrom").'
'.$langs->trans("MailTitle").'
'.$langs->trans("MailTopic").'
'.$langs->trans("MailMessage").'
'; print '
'.$langs->trans("CommonSubstitutions").':
'; print '__ID__ = '.$langs->trans("IdRecord").'
'; print '__EMAIL__ = '.$langs->trans("EMail").'
'; print '__LASTNAME__ = '.$langs->trans("Lastname").'
'; print '__FIRSTNAME__ = '.$langs->trans("Firstname").'
'; print '
'; // éditeur wysiwyg if ($conf->fckeditor->enabled && $conf->global->FCKEDITOR_ENABLE_MAILING) { require_once(DOL_DOCUMENT_ROOT."/lib/doleditor.class.php"); $doleditor=new DolEditor('body',$objp->description,320,'dolibarr_mailings','',true); $doleditor->Create(); } else { print ''; } print '
'; print '
'; } else { $html = new Form($db); if ($mil->fetch($_GET["id"]) >= 0) { $h=0; $head[$h][0] = DOL_URL_ROOT."/comm/mailing/fiche.php?id=".$mil->id; $head[$h][1] = $langs->trans("MailCard"); $hselected = $h; $h++; $head[$h][0] = DOL_URL_ROOT."/comm/mailing/cibles.php?id=".$mil->id; $head[$h][1] = $langs->trans('MailRecipients'); $h++; /* $head[$h][0] = DOL_URL_ROOT."/comm/mailing/info.php?id=".$mil->id; $head[$h][1] = $langs->trans("MailHistory"); $h++; */ dolibarr_fiche_head($head, $hselected, $langs->trans("Mailing").": ".substr($mil->titre,0,20)); // Confirmation de la validation du mailing if ($_GET["action"] == 'valide') { $html->form_confirm("fiche.php?id=".$mil->id,$langs->trans("ValidMailing"),$langs->trans("ConfirmValidMailing"),"confirm_valide"); print '
'; } // Confirmation de l'approbation du mailing if ($_GET["action"] == 'approve') { $html->form_confirm("fiche.php?id=".$mil->id,"Approuver le mailing","Confirmez-vous l'approbation du mailing ?","confirm_approve"); print '
'; } // Confirmation de la suppression if ($_GET["action"] == 'delete') { $html->form_confirm("fiche.php?id=".$mil->id,$langs->trans("DeleteAMailing"),$langs->trans("ConfirmDeleteMailing"),"confirm_delete"); print '
'; } if ($_GET["action"] != 'edit') { /* * Mailing en mode visu * */ print ''; print ''; print ''; print ''; print ''; print ''; $uc = new User($db, $mil->user_creat); $uc->fetch(); print ''; print ''; print ''; if ($mil->statut > 0) { $uv = new User($db, $mil->user_valid); $uv->fetch(); print ''; print ''; print ''; } if ($mil->statut > 1) { print ''; print ''; print ''; } // Sujet print ''; // Message print ''; print ''; print ''; print '
'.$langs->trans("Ref").''.$mil->id.'
'.$langs->trans("MailTitle").''.$mil->titre.'
'.$langs->trans("MailFrom").''.htmlentities($mil->email_from).'
'.$langs->trans("Status").''.$mil->getLibStatut(4).'
'.$langs->trans("TotalNbOfDistinctRecipients").''.($mil->nbemail?$mil->nbemail:''.$langs->trans("NoTargetYet").'').'
'.$langs->trans("CreatedBy").''.$uc->getNomUrl(1).''.$langs->trans("Date").''.dolibarr_print_date($mil->date_creat,"%d %b %Y %H:%M").'
'.$langs->trans("ValidatedBy").''.$uv->getNomUrl(1).''.$langs->trans("Date").''.dolibarr_print_date($mil->date_valid,"%d %b %Y %H:%M").'
'.$langs->trans("SentBy").''.$langs->trans("Unknown").''.$langs->trans("Date").''.dolibarr_print_date($mil->date_envoi,"%d %b %Y %H:%M").'
'.$langs->trans("MailTopic").''.$mil->sujet.'
'.$langs->trans("MailMessage").''; print nl2br($mil->body); print '
'; print ""; if ($message) print "$message
"; /* * Boutons d'action */ if ($_GET["action"] == '') { print "\n\n
\n"; if ($mil->statut == 0 && $user->rights->mailing->creer) { print ''.$langs->trans("EditMailing").''; } //print ''.$langs->trans("PreviewMailing").''; print ''.$langs->trans("TestMailing").''; if ($mil->statut == 0 && $mil->nbemail > 0 && $user->rights->mailing->valider) { print ''.$langs->trans("ValidMailing").''; } if ($mil->statut == 1 && $mil->nbemail > 0 && $user->rights->mailing->valider) { print ''.$langs->trans("SendMailing").''; } if ($mil->statut <= 1 && $user->rights->mailing->supprimer) { print ''.$langs->trans("DeleteMailing").''; } print '

'; } if ($_GET["action"] == 'test') { print_titre($langs->trans("TestMailing")); // Créé l'objet formulaire mail include_once("../../html.formmail.class.php"); $formmail = new FormMail($db); $formmail->fromname = $mil->email_from; $formmail->frommail = $mil->email_from; $formmail->withfrom=0; $formmail->withto=$user->email?$user->email:1; $formmail->withcc=0; $formmail->withtopic=0; $formmail->withtopicreadonly=1; $formmail->withfile=0; $formmail->withbody=0; $formmail->withbodyreadonly=1; // Tableau des substitutions $formmail->substit["__FACREF__"]=$fac->ref; // Tableau des paramètres complémentaires du post $formmail->param["action"]="send"; $formmail->param["models"]="body"; $formmail->param["mailid"]=$mil->id; $formmail->param["returnurl"]=DOL_URL_ROOT."/comm/mailing/fiche.php?id=".$mil->id; $formmail->show_form(); print '
'; } } else { /* * Mailing en mode edition */ print '
'."\n"; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print '
'.$langs->trans("Ref").''.$mil->id.'
'.$langs->trans("MailTitle").'
'.$langs->trans("MailFrom").'
'.$langs->trans("MailTopic").'
'.$langs->trans("MailMessage").'
'; print '
'.$langs->trans("CommonSubstitutions").':
'; print '__ID__ = '.$langs->trans("IdRecord").'
'; print '__EMAIL__ = '.$langs->trans("EMail").'
'; print '__LASTNAME__ = '.$langs->trans("Lastname").'
'; print '__FIRSTNAME__ = '.$langs->trans("Firstname").'
'; print '
'; // éditeur wysiwyg if ($conf->fckeditor->enabled && $conf->global->FCKEDITOR_ENABLE_MAILING) { require_once(DOL_DOCUMENT_ROOT."/lib/doleditor.class.php"); $doleditor=new DolEditor('body',$mil->body,320,'dolibarr_mailings','',true); $doleditor->Create(); } else { print ''; } print '
'; print '
'; print ""; } } } $db->close(); llxFooter('$Date$ - $Revision$'); ?>