New: Add a more accurate setup for identity card of members (need for the solution linux congress)

This commit is contained in:
Laurent Destailleur 2010-02-07 04:31:19 +00:00
parent 382f11a514
commit e24379f0be
7 changed files with 139 additions and 50 deletions

View File

@ -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++;
}

View File

@ -212,6 +212,28 @@ if ($conf->global->MAIN_FEATURES_LEVEL >= 1)
print "<hr>\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").'<br>';
print '%DOL_MAIN_URL_ROOT%, %ID%, %PRENOM%, %NOM%, %LOGIN%, %PASSWORD%,';
print '%SOCIETE%, %ADRESSE%, %CP%, %VILLE%, %PAYS%, %EMAIL%, %NAISS%, %PHOTO%, %TYPE%,';
//print '%INFOS%'; Deprecated
print '<br>';
print '<br>';
/*
* 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").'<br>';
form_constantes($constantes);
print '*'.$langs->trans("FollowingConstantsWillBeSubstituted").'<br>';
print '%DOL_MAIN_URL_ROOT%, %ID%, %PRENOM%, %NOM%, %LOGIN%, %PASSWORD%,';
print '%SOCIETE%, %ADRESSE%, %CP%, %VILLE%, %PAYS%, %EMAIL%, %NAISS%, %PHOTO%, %TYPE%,';
//print '%INFOS%'; Deprecated
print '<br>';
form_constantes($constantes);
$db->close();
@ -257,7 +277,7 @@ function form_constantes($tableau)
print '<table class="noborder" width="100%">';
print '<tr class="liste_titre">';
print '<td>'.$langs->trans("Description").'</td>';
print '<td>'.$langs->trans("Value").'</td>';
print '<td>'.$langs->trans("Value").'*</td>';
print '<td>'.$langs->trans("Type").'</td>';
print '<td align="center" width="80">'.$langs->trans("Action").'</td>';
print "</tr>\n";

View File

@ -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
{

View File

@ -54,14 +54,14 @@
////////////////////////////////////////////////////
/**
\file htdocs/adherents/cartes/PDF_card.class.php
\ingroup adherent
\brief Fichier de la classe permettant d'<EFBFBD>diter au format PDF des <EFBFBD>tiquettes au format Avery ou personnalis<EFBFBD>
\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'<EFBFBD>diter au format PDF des <EFBFBD>tiquettes au format Avery ou personnalis<EFBFBD>
* \class PDF_card
* \brief Classe afin d'editer au format PDF des etiquettes au format Avery ou personnalise
*/
class PDF_card extends FPDF {
// Propri<EFBFBD>t<EFBFBD>s priv<69>es
var $_Avery_Name = ''; // Nom du format de l'<EFBFBD>tiquette
var $_Margin_Left = 0; // Marge de gauche de l'<EFBFBD>tiquette
var $_Margin_Top = 0; // marge en haut de la page avant la premi<EFBFBD>re <20>tiquette
var $_X_Space = 0; // Espace horizontal entre 2 bandes d'<EFBFBD>tiquettes
var $_Y_Space = 0; // Espace vertical entre 2 bandes d'<EFBFBD>tiquettes
var $_X_Number = 0; // Nombre d'<EFBFBD>tiquettes sur la largeur de la page
var $_Y_Number = 0; // Nombre d'<EFBFBD>tiquettes sur la hauteur de la page
var $_Width = 0; // Largeur de chaque <EFBFBD>tiquette
var $_Height = 0; // Hauteur de chaque <EFBFBD>tiquette
var $_Char_Size = 10; // Hauteur des caract<EFBFBD>res
var $_Line_Height = 10; // Hauteur par d<EFBFBD>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 <EFBFBD> l'<27>tiquette d<>sir<69>e dans le cas o<> la page a d<>j<EFBFBD> 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<EFBFBD>thode qui permet de modifier la taille des caract<63>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 <EFBFBD>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<EFBFBD>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];

View File

@ -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

View File

@ -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

View File

@ -139,7 +139,7 @@ function dol_loginfunction($langs,$conf,$mysoc)
{
$urllogo=DOL_URL_ROOT.'/viewimage.php?modulepart=companylogo&amp;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&amp;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);