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 '| '.$langs->trans("Description").' | ';
- print ''.$langs->trans("Value").' | ';
+ print ''.$langs->trans("Value").'* | ';
print ''.$langs->trans("Type").' | ';
print ''.$langs->trans("Action").' | ';
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);