New: Add a more accurate setup for identity card of members (need for the solution linux congress)
This commit is contained in:
parent
382f11a514
commit
e24379f0be
@ -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++;
|
||||
}
|
||||
|
||||
|
||||
@ -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";
|
||||
|
||||
@ -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
|
||||
{
|
||||
|
||||
@ -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];
|
||||
|
||||
@ -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
|
||||
|
||||
@ -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
|
||||
|
||||
@ -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);
|
||||
|
||||
Loading…
Reference in New Issue
Block a user