diff --git a/htdocs/adherents/cartes/carte.php b/htdocs/adherents/cartes/carte.php index e572a90a856..b867fc688f4 100755 --- a/htdocs/adherents/cartes/carte.php +++ b/htdocs/adherents/cartes/carte.php @@ -26,6 +26,10 @@ */ require("./pre.inc.php"); + +require_once(DOL_DOCUMENT_ROOT.'/lib/pdf.lib.php'); +require_once(DOL_DOCUMENT_ROOT.'/includes/fpdf/fpdfi/fpdi_protection.php'); + require_once(DOL_DOCUMENT_ROOT."/lib/files.lib.php"); require_once(DOL_DOCUMENT_ROOT."/adherents/adherent.class.php"); require_once(DOL_DOCUMENT_ROOT."/includes/modules/member/PDF_card.class.php"); @@ -93,6 +97,8 @@ if ($result) { $objp = $db->fetch_object($result); + if ($objp->pays == '-') $objp->pays=''; + // List of values to scan for a replacement $replace = array ( $objp->prenom, @@ -115,7 +121,8 @@ if ($result) // imprime le texte specifique sur la carte $pdf->Add_PDF_card(preg_replace ($patterns, $replace, $conf->global->ADHERENT_CARD_TEXT), preg_replace ($patterns, $replace, $conf->global->ADHERENT_CARD_HEADER_TEXT), - preg_replace ($patterns, $replace, $conf->global->ADHERENT_CARD_FOOTER_TEXT), $langs); + preg_replace ($patterns, $replace, $conf->global->ADHERENT_CARD_FOOTER_TEXT), $langs, + preg_replace ($patterns, $replace, $conf->global->ADHERENT_CARD_TEXT_RIGHT)); $i++; } diff --git a/htdocs/admin/adherent.php b/htdocs/admin/adherent.php index 037491200ec..3c5101af5c0 100644 --- a/htdocs/admin/adherent.php +++ b/htdocs/admin/adherent.php @@ -212,6 +212,28 @@ if ($conf->global->MAIN_FEATURES_LEVEL >= 1) print "
\n"; } +/* + * Edition info modele document + */ +$constantes=array( + 'ADHERENT_CARD_HEADER_TEXT', + 'ADHERENT_CARD_TEXT', + 'ADHERENT_CARD_TEXT_RIGHT', + 'ADHERENT_CARD_FOOTER_TEXT' + ); +print_fiche_titre($langs->trans("MembersCards"),'',''); + +form_constantes($constantes); + +print '*'.$langs->trans("FollowingConstantsWillBeSubstituted").'
'; +print '%DOL_MAIN_URL_ROOT%, %ID%, %PRENOM%, %NOM%, %LOGIN%, %PASSWORD%,'; +print '%SOCIETE%, %ADRESSE%, %CP%, %VILLE%, %PAYS%, %EMAIL%, %NAISS%, %PHOTO%, %TYPE%,'; +//print '%INFOS%'; Deprecated +print '
'; + +print '
'; + + /* * Edition des variables globales non rattache a un theme specifique */ @@ -225,20 +247,18 @@ $constantes=array( 'ADHERENT_MAIL_RESIL_SUBJECT', 'ADHERENT_MAIL_RESIL', 'ADHERENT_MAIL_FROM', - 'ADHERENT_CARD_HEADER_TEXT', - 'ADHERENT_CARD_TEXT', - 'ADHERENT_CARD_FOOTER_TEXT', 'ADHERENT_ETIQUETTE_TYPE' ); print_fiche_titre($langs->trans("Other"),'',''); -print $langs->trans("FollowingConstantsWillBeSubstituted").'
'; +form_constantes($constantes); + +print '*'.$langs->trans("FollowingConstantsWillBeSubstituted").'
'; print '%DOL_MAIN_URL_ROOT%, %ID%, %PRENOM%, %NOM%, %LOGIN%, %PASSWORD%,'; print '%SOCIETE%, %ADRESSE%, %CP%, %VILLE%, %PAYS%, %EMAIL%, %NAISS%, %PHOTO%, %TYPE%,'; //print '%INFOS%'; Deprecated print '
'; -form_constantes($constantes); $db->close(); @@ -257,7 +277,7 @@ function form_constantes($tableau) print ''; print ''; print ''; - print ''; + print ''; print ''; print ''; print "\n"; diff --git a/htdocs/includes/modules/facture/modules_facture.php b/htdocs/includes/modules/facture/modules_facture.php index d317807e845..cb8c310dfb2 100644 --- a/htdocs/includes/modules/facture/modules_facture.php +++ b/htdocs/includes/modules/facture/modules_facture.php @@ -35,10 +35,9 @@ require_once(DOL_DOCUMENT_ROOT."/compta/bank/account.class.php"); // Requis ca /** - \class ModelePDFFactures - \brief Classe mere des modeles de facture + * \class ModelePDFFactures + * \brief Classe mere des modeles de facture */ - class ModelePDFFactures extends FPDF { var $error=''; @@ -89,8 +88,8 @@ class ModelePDFFactures extends FPDF } /** - \class ModeleNumRefFactures - \brief Classe mere des modeles de numerotation des references de facture + * \class ModeleNumRefFactures + * \brief Classe mere des modeles de numerotation des references de facture */ class ModeleNumRefFactures { diff --git a/htdocs/includes/modules/member/PDF_card.class.php b/htdocs/includes/modules/member/PDF_card.class.php index b2091e1ee9b..04f3014252b 100644 --- a/htdocs/includes/modules/member/PDF_card.class.php +++ b/htdocs/includes/modules/member/PDF_card.class.php @@ -54,14 +54,14 @@ //////////////////////////////////////////////////// /** - \file htdocs/adherents/cartes/PDF_card.class.php - \ingroup adherent - \brief Fichier de la classe permettant d'�diter au format PDF des �tiquettes au format Avery ou personnalis� - \author Steve Dillon - \author Laurent Passebecq - \author Rodolphe Quiedville - \author Jean Louis Bergamo. - \version $Id$ + * \file htdocs/adherents/cartes/PDF_card.class.php + * \ingroup adherent + * \brief Fichier de la classe permettant d'editer au format PDF des etiquettes au format Avery ou personnalise + * \author Steve Dillon + * \author Laurent Passebecq + * \author Rodolphe Quiedville + * \author Jean Louis Bergamo. + * \version $Id$ */ require_once(DOL_DOCUMENT_ROOT.'/lib/pdf.lib.php'); @@ -69,23 +69,23 @@ require_once(DOL_DOCUMENT_ROOT.'/includes/fpdf/fpdfi/fpdi_protection.php'); /** - \class PDF_card - \brief Classe afin d'�diter au format PDF des �tiquettes au format Avery ou personnalis� + * \class PDF_card + * \brief Classe afin d'editer au format PDF des etiquettes au format Avery ou personnalise */ class PDF_card extends FPDF { - // Propri�t�s priv�es - var $_Avery_Name = ''; // Nom du format de l'�tiquette - var $_Margin_Left = 0; // Marge de gauche de l'�tiquette - var $_Margin_Top = 0; // marge en haut de la page avant la premi�re �tiquette - var $_X_Space = 0; // Espace horizontal entre 2 bandes d'�tiquettes - var $_Y_Space = 0; // Espace vertical entre 2 bandes d'�tiquettes - var $_X_Number = 0; // Nombre d'�tiquettes sur la largeur de la page - var $_Y_Number = 0; // Nombre d'�tiquettes sur la hauteur de la page - var $_Width = 0; // Largeur de chaque �tiquette - var $_Height = 0; // Hauteur de chaque �tiquette - var $_Char_Size = 10; // Hauteur des caract�res - var $_Line_Height = 10; // Hauteur par d�faut d'une ligne + // Proprietes privees + var $_Avery_Name = ''; // Nom du format de l'etiquette + var $_Margin_Left = 0; // Marge de gauche de l'etiquette + var $_Margin_Top = 0; // marge en haut de la page avant la premiere etiquette + var $_X_Space = 0; // Espace horizontal entre 2 bandes d'etiquettes + var $_Y_Space = 0; // Espace vertical entre 2 bandes d'etiquettes + var $_X_Number = 0; // Nombre d'etiquettes sur la largeur de la page + var $_Y_Number = 0; // Nombre d'etiquettes sur la hauteur de la page + var $_Width = 0; // Largeur de chaque etiquette + var $_Height = 0; // Hauteur de chaque etiquette + var $_Char_Size = 10; // Hauteur des caracteres + var $_Line_Height = 10; // Hauteur par defaut d'une ligne var $_Metric = 'mm'; // Type of metric.. Will help to calculate good values var $_Metric_Doc = 'mm'; // Type of metric for the doc.. @@ -209,6 +209,8 @@ class PDF_card extends FPDF { */ function PDF_card ($format, $posX=1, $posY=1, $unit='mm') { + global $conf,$mysoc; + if (is_array($format)) { // Si c'est un format personnel alors on maj les valeurs $Tformat = $format; @@ -223,11 +225,13 @@ class PDF_card extends FPDF { } parent::FPDF('P', $unit, $Tformat['paper-size']); + + $this->SetMargins(0,0); $this->SetAutoPageBreak(false); $this->_Metric_Doc = $unit; - // Permet de commencer l'impression � l'�tiquette d�sir�e dans le cas o� la page a d�j� servie + // Permet de commencer l'impression de l'etiquette desiree dans le cas ou la page a deja servie if ($posX > 0) $posX--; else $posX=0; if ($posY > 0) $posY--; else $posY=0; $this->_COUNTX = $posX; @@ -236,7 +240,7 @@ class PDF_card extends FPDF { } - //M�thode qui permet de modifier la taille des caract�res + //Methode qui permet de modifier la taille des caracteres // Cela modiera aussi l'espace entre chaque ligne function Set_Char_Size($pt) { if ($pt > 3) { @@ -247,10 +251,10 @@ class PDF_card extends FPDF { } - // On imprime une �tiqette - function Add_PDF_card($texte,$header='',$footer='',$outputlangs) + // On imprime une etiquette + function Add_PDF_card($textleft,$header='',$footer='',$outputlangs,$textright='') { - global $langs; + global $mysoc,$conf,$langs; if (! is_object($outputlangs)) $outputlangs=$langs; // Force output charset to ISO, because, FPDF expects text to be encoded in ISO @@ -269,6 +273,19 @@ class PDF_card extends FPDF { $_PosX = $this->_Margin_Left+($this->_COUNTX*($this->_Width+$this->_X_Space)); $_PosY = $this->_Margin_Top+($this->_COUNTY*($this->_Height+$this->_Y_Space)); + $logo=$conf->mycompany->dir_output.'/logos/'.$mysoc->logo; + if (is_readable($logo)) + { + if (! empty($mysoc->logo_small) && is_readable($conf->mycompany->dir_output.'/logos/thumbs/'.$mysoc->logo_small)) + { + $logo=$conf->mycompany->dir_output.'/logos/thumbs/'.$mysoc->logo_small; + } + elseif (! empty($mysoc->logo) && is_readable($conf->mycompany->dir_output.'/logos/'.$mysoc->logo)) + { + $logo=$conf->mycompany->dir_output.'/logos/'.$mysoc->logo; + } + } + if ($this->_Avery_Name == "CARD") { $Tformat=$this->_Avery_Labels["CARD"]; @@ -284,14 +301,58 @@ class PDF_card extends FPDF { $this->image($Tformat['logo2'],$_PosX+$this->_Width-21,$_PosY+25,20,20); } - //$this->image('logo1.jpg',$_PosX+$this->_Width-21,$_PosY+1,20); + // Top if ($header!=''){ $this->SetXY($_PosX, $_PosY+1); $this->Cell($this->_Width, $this->_Line_Height, $outputlangs->convToOutputCharset($header),0,1,'C'); } - $this->SetXY($_PosX+3, $_PosY+3+$this->_Line_Height); - $this->MultiCell($this->_Width, $this->_Line_Height, $outputlangs->convToOutputCharset($texte)); - if ($footer!=''){ + + // Center + if ($textright=='') // Only a left part + { + if ($textleft == '%LOGO%') $this->Image($logo,$_PosX+$this->_Width-21,$_PosY+1,20); + else + { + $this->SetXY($_PosX+3, $_PosY+3+$this->_Line_Height); + $this->MultiCell($this->_Width, $this->_Line_Height, $outputlangs->convToOutputCharset($textleft)); + } + } + else if ($textleft!='' && $textright!='') // + { + if ($textleft == '%LOGO%') + { + $this->Image($logo,$_PosX+$this->_Width-21,$_PosY+1,20); + $this->SetXY($_PosX+22, $_PosY+3+$this->_Line_Height); + $this->MultiCell($this->_Width-20, $this->_Line_Height, $outputlangs->convToOutputCharset($textright),0,'R'); + } + else if ($textright == '%LOGO%') + { + $this->Image($logo,$_PosX+$this->_Width-21,$_PosY+1,20); + $this->SetXY($_PosX+2, $_PosY+3+$this->_Line_Height); + $this->MultiCell($this->_Width-20, $this->_Line_Height, $outputlangs->convToOutputCharset($textleft)); + } + else + { + $this->SetXY($_PosX+round($this->_Width/2), $_PosY+3+$this->_Line_Height); + $this->MultiCell(round($this->_Width/2)-2, $this->_Line_Height, $outputlangs->convToOutputCharset($textright),0,'R'); + $this->SetXY($_PosX+2, $_PosY+3+$this->_Line_Height); + $this->MultiCell(round($this->_Width/2), $this->_Line_Height, $outputlangs->convToOutputCharset($textleft)); + } + + } + else // Only a right part + { + if ($textright == '%LOGO%') $this->Image($logo,$_PosX+$this->_Width-21,$_PosY+1,20); + else + { + $this->SetXY($_PosX+2, $_PosY+3+$this->_Line_Height); + $this->MultiCell($this->_Width, $this->_Line_Height, $outputlangs->convToOutputCharset($textright),0,'R'); + } + } + + // Bottom + if ($footer!='') + { $this->SetXY($_PosX, $_PosY+$this->_Height-$this->_Line_Height-1); $this->Cell($this->_Width, $this->_Line_Height, $outputlangs->convToOutputCharset($footer),0,1,'C'); } @@ -300,7 +361,7 @@ class PDF_card extends FPDF { else { $this->SetXY($_PosX+3, $_PosY+3); - $this->MultiCell($this->_Width, $this->_Line_Height, $outputlangs->convToOutputCharset($texte)); + $this->MultiCell($this->_Width, $this->_Line_Height, $outputlangs->convToOutputCharset($textleft)); } $this->_COUNTY++; @@ -386,7 +447,7 @@ class PDF_card extends FPDF { // Give the height for a char size given. function _Get_Height_Chars($pt) { - // Tableau de concordance entre la hauteur des caract�res et de l'espacement entre les lignes + // Tableau de concordance entre la hauteur des caracteres et de l'espacement entre les lignes $_Table_Hauteur_Chars = array(6=>2, 7=>2.5, 8=>3, 9=>4, 10=>5, 11=>6, 12=>7, 13=>8, 14=>9, 15=>10); if (in_array($pt, array_keys($_Table_Hauteur_Chars))) { return $_Table_Hauteur_Chars[$pt]; diff --git a/htdocs/langs/en_US/members.lang b/htdocs/langs/en_US/members.lang index 62b0b6e4c43..188bf3c4ede 100644 --- a/htdocs/langs/en_US/members.lang +++ b/htdocs/langs/en_US/members.lang @@ -140,7 +140,8 @@ DescADHERENT_MAIL_RESIL=EMail for member resiliation DescADHERENT_MAIL_FROM=Sender EMail for automatic emails DescADHERENT_ETIQUETTE_TYPE=Labels format DescADHERENT_CARD_HEADER_TEXT=Text printed on top of member cards -DescADHERENT_CARD_TEXT=Text printed on member cards +DescADHERENT_CARD_TEXT=Text printed on member cards (align on left) +DescADHERENT_CARD_TEXT_RIGHT=Text printed on member cards (align on right) DescADHERENT_CARD_FOOTER_TEXT=Text printed on bottom of member cards ShowTypeCard=Show type '%s' HTPasswordExport=htpassword file generation diff --git a/htdocs/langs/fr_FR/members.lang b/htdocs/langs/fr_FR/members.lang index 8794bb86827..5b9b006b457 100644 --- a/htdocs/langs/fr_FR/members.lang +++ b/htdocs/langs/fr_FR/members.lang @@ -22,7 +22,7 @@ ThisIsContentOfYourCard=Voici les détails de votre fiche CardContent=Contenu de votre fiche adherent SetLinkToUser=Lier à un utilisateur Dolibarr SetLinkToThirdParty=Lier à un tiers Dolibarr -MembersCards=Cartes des adhérents +MembersCards=Cartes de visites MembersList=Liste des adhérents MembersListToValid=Liste des adhérents brouillons (à valider) MembersListValid=Liste des adhérents valides @@ -140,7 +140,8 @@ DescADHERENT_MAIL_RESIL=Mail de résiliation DescADHERENT_MAIL_FROM=Mail émetteur pour les mails automatique DescADHERENT_ETIQUETTE_TYPE=Format étiquettes DescADHERENT_CARD_HEADER_TEXT=Texte imprimé sur le haut des cartes adhérents -DescADHERENT_CARD_TEXT=Texte imprimé sur les cartes adhérents +DescADHERENT_CARD_TEXT=Texte imprimé sur les cartes adhérents (Aligné à gauche) +DescADHERENT_CARD_TEXT_RIGHT=Texte imprimé sur les cartes adhérents (Aligné à droite) DescADHERENT_CARD_FOOTER_TEXT=Texte imprimé sur le bas des cartes adhérents ShowTypeCard=Voir type '%s' HTPasswordExport=Generation fichier htpassword diff --git a/htdocs/lib/security.lib.php b/htdocs/lib/security.lib.php index 8d8959a13d8..ffd3538c0e6 100644 --- a/htdocs/lib/security.lib.php +++ b/htdocs/lib/security.lib.php @@ -139,7 +139,7 @@ function dol_loginfunction($langs,$conf,$mysoc) { $urllogo=DOL_URL_ROOT.'/viewimage.php?modulepart=companylogo&file='.urlencode('thumbs/'.$mysoc->logo_small); } - elseif (! empty($mysoc->logo_small) && is_readable($conf->mycompany->dir_output.'/logos/'.$mysoc->logo)) + elseif (! empty($mysoc->logo) && is_readable($conf->mycompany->dir_output.'/logos/'.$mysoc->logo)) { $urllogo=DOL_URL_ROOT.'/viewimage.php?modulepart=companylogo&file='.urlencode($mysoc->logo); $width=128; @@ -206,7 +206,7 @@ function dol_loginfunction($langs,$conf,$mysoc) if ($conf->global->MAIN_SMARTY) { global $smarty; - + $smarty->template_dir=$template_dir; $smarty->assign('conf_css', $conf_css);
'.$langs->trans("Description").''.$langs->trans("Value").''.$langs->trans("Value").'*'.$langs->trans("Type").''.$langs->trans("Action").'