New TCPDF signature page

This commit is contained in:
dave 2010-06-09 17:05:21 +00:00
parent fa56770b8a
commit d1c607f575
3 changed files with 462 additions and 462 deletions

View File

@ -3,8 +3,8 @@
This file is part of the 'Science Fair In A Box' project This file is part of the 'Science Fair In A Box' project
SFIAB Website: http://www.sfiab.ca SFIAB Website: http://www.sfiab.ca
Copyright (C) 2005 Sci-Tech Ontario Inc <info@scitechontario.org>
Copyright (C) 2005 James Grant <james@lightbox.org> Copyright (C) 2005 James Grant <james@lightbox.org>
Copyright (C) 2010 David Grant <dave@lightbox.org>
This program is free software; you can redistribute it and/or This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public modify it under the terms of the GNU General Public
@ -22,43 +22,39 @@
*/ */
?> ?>
<? <?
require("common.inc.php"); require_once('common.inc.php');
include "register_participants.inc.php"; require_once('register_participants.inc.php');
require("lpdf.php"); require_once('tcpdf.inc.php');
//anyone can access a sample, we dont need to be authenticated or anything for that //anyone can access a sample, we dont need to be authenticated or anything for that
if($_GET['sample']) { if($_GET['sample']) {
$registration_number=12345; $registration_number=12345;
$registration_id=0; $registration_id=0;
} } else {
else {
//authenticate based on email address and registration number from the SESSION //authenticate based on email address and registration number from the SESSION
if(!$_SESSION['email']) if(!$_SESSION['email']) {
{
header("Location: register_participants.php"); header("Location: register_participants.php");
exit; exit;
} }
if(!$_SESSION['registration_number']) if(!$_SESSION['registration_number']) {
{
header("Location: register_participants.php"); header("Location: register_participants.php");
exit; exit;
} }
$q=mysql_query("SELECT registrations.id AS regid, students.id AS studentid, students.firstname FROM registrations,students ". $q=mysql_query("SELECT registrations.id AS regid, students.id AS studentid, students.firstname
"WHERE students.email='".$_SESSION['email']."' ". FROM registrations,students
"AND registrations.num='".$_SESSION['registration_number']."' ". WHERE students.email='{$_SESSION['email']}'
"AND registrations.id='".$_SESSION['registration_id']."' ". AND registrations.num='{$_SESSION['registration_number']}'
"AND students.registrations_id=registrations.id ". AND registrations.id='{$_SESSION['registration_id']}'
"AND registrations.year=".$config['FAIRYEAR']." ". AND students.registrations_id=registrations.id
"AND students.year=".$config['FAIRYEAR']); AND registrations.year={$config['FAIRYEAR']}
AND students.year={$config['FAIRYEAR']}");
$registration_number=$_SESSION['registration_number']; $registration_number=$_SESSION['registration_number'];
$registration_id=$_SESSION['registration_id']; $registration_id=$_SESSION['registration_id'];
echo mysql_error(); echo mysql_error();
if(mysql_num_rows($q)==0) if(mysql_num_rows($q)==0) {
{
header("Location: register_participants.php"); header("Location: register_participants.php");
exit; exit;
@ -68,29 +64,16 @@ echo mysql_error();
} }
//END OF AUTH, now lets try to generate a PDF using only PHP :) this should be fun! //END OF AUTH, now lets try to generate a PDF using only PHP :) this should be fun!
$pdf=new lpdf( i18n($config['fairname']),
i18n("Participant Signature Page (".$registration_number.")"),
$_SERVER['DOCUMENT_ROOT'].$config['SFIABDIRECTORY']."/data/logo-200.gif"
);
$pdf->newPage();
$height['sigspace']=0.40; $pdf=new pdf( "Participant Signature Page ($registration_number)" );
$pdf->setFontSize(11); $pdf->setFontSize(11);
$pdf->SetFont('times');
$height_sigspace = 15; //mm
$height_sigfont = $pdf->GetFontSize(); //mm
/* $pdf->AddPage();
//The title of the fair
$yloc=10.25;
$height['title']=0.25;
$height['subtitle']=0.22;
$height['topbox']=0.8;
$height['exhibitortitle']=0.2;
$height['exhibitorbox']=1.3;
$height['exhibitorsigtext']=0.13;
$height['parenttitle']=0.2;
$height['parentbox']=2.80;
$height['parentsigtext']=0.13;
*/
if($_GET['sample']) { if($_GET['sample']) {
$projectinfo->title="Sample Project Title"; $projectinfo->title="Sample Project Title";
@ -101,9 +84,7 @@ $pdf->newPage();
$studentinfo->grade="10"; $studentinfo->grade="10";
$studentinfoarray[]=$studentinfo; $studentinfoarray[]=$studentinfo;
$rr->school="SampleSchool"; $rr->school="SampleSchool";
} } else {
else
{
//grab the project info //grab the project info
$q=mysql_query("SELECT projects.*, $q=mysql_query("SELECT projects.*,
projectcategories.category, projectcategories.category,
@ -123,217 +104,116 @@ $pdf->newPage();
$studentinfoarray[]=$si; $studentinfoarray[]=$si;
} }
$topboxtext=i18n("Registration Number").": ".$registration_number."\n". $plural = (count($studentinfoarray)>1) ? 's' : '';
i18n("Project Title").": $projectinfo->title\n".
i18n($projectinfo->category)." / ".i18n($projectinfo->division)."\n";
if(count($studentinfoarray)>1)
$plural="s";
else
$plural="";
$pdf->heading(i18n("Registration Summary")); $pdf->WriteHTML("<h3>".i18n('Registration Summary')."</h3>
$pdf->addText($topboxtext); <p>
$pdf->nextline(); ".i18n('Registration Number').": $registration_number <br/>
".i18n('Project Title').": {$projectinfo->title} <br/>
".i18n($projectinfo->category)." / ".i18n($projectinfo->division));
$pdf->addTextX("Exhibitor$plural: ", 0.75); $students = "";
foreach($studentinfoarray AS $studentinfo) {
foreach($studentinfoarray AS $studentinfo)
{
if(!$_GET['sample']) { if(!$_GET['sample']) {
$qq = mysql_query("SELECT school FROM schools WHERE id={$studentinfo->schools_id}"); $qq = mysql_query("SELECT school FROM schools WHERE id={$studentinfo->schools_id}");
$rr = mysql_fetch_object($qq); $rr = mysql_fetch_object($qq);
} }
if($students != '') $students .= '<br/>';
$pdf->addTextX("$studentinfo->firstname $studentinfo->lastname, Grade {$studentinfo->grade}, {$rr->school}", 1.5); $students .= "{$studentinfo->firstname} {$studentinfo->lastname}, Grade {$studentinfo->grade}, {$rr->school}";
$pdf->nextline();
} }
//strip off the last comma $e = i18n("Exhibitor$plural").":";
//add the newline $w = $pdf->GetStringWidth($e) + 2;
// $topboxtext.="\n"; $pdf->WriteHTML("<table><tr><td width=\"{$w}mm\">$e</td><td>$students</td></tr></table>");
$pdf->WriteHTML("<hr>");
$pdf->hr(); function sig($pdf, $text)
{
global $height_sigspace, $height_font;
$x = $pdf->GetX();
/* One cell for the whole thing, to force a page break if needed, leave
* the current pos to the right so the Y is unchanged */
$pdf->Cell(0, $height_sigspace + $height_font, '', 0, 0);
/* Restore X, and indent a bit, move Y down the signature space */
$pdf->SetXY($x + 15, $pdf->GetY() + $height_sigspace);
/* Box with a top line, then a space, then a box with a top line for the date */
$pdf->Cell(85, $height_font, $text, 'T', 0, 'C');
$pdf->SetX($pdf->GetX() + 15);
$pdf->Cell(60, $height_font, i18n('Date'), 'T', 1, 'C');
}
$q=mysql_query("SELECT * FROM signaturepage WHERE name='exhibitordeclaration'"); $q=mysql_query("SELECT * FROM signaturepage WHERE name='exhibitordeclaration'");
$r=mysql_fetch_object($q); $r=mysql_fetch_assoc($q);
if($r->use) if($r['use']) {
{ $t = nl2br($r['text']);
$pdf->heading(i18n("Exhibitor Declaration")); $pdf->WriteHTML("<h3>".i18n('Exhibitor Declaration')."</h3>$t");
$studentbox=$r->text; foreach($studentinfoarray AS $studentinfo) {
/* sig($pdf, i18n("%1 %2 (signature)",array($studentinfo->firstname,$studentinfo->lastname)));
$studentbox="The following section is to be read and signed by the exhibitor$plural.\n\n".
($plural?"We":"I")." certify that:\n".
" - The preparation of this project is mainly ".($plural?"our":"my")." own work\n".
" - ".($plural?"We":"I")." have read the rules and regulations and agree to abide by them\n".
" - ".($plural?"We":"I")." agree that the decision of the judges will be final\n";
*/
$pdf->addText($studentbox);
foreach($studentinfoarray AS $studentinfo)
{
//we want to make sure the vspace, line, and text under the line dont
//get wrapped onto multiple pages, so make sure we have enough space for the whole thing before we
//start, and if we dont, make a new page. normal stop for footer is at 0.9, so 1.65 gives 0.75 inches
//which should be enough... i think :)
if($pdf->yloc< 1.65 )
$pdf->newPage();
$pdf->vspace($height['sigspace']);
//signature line
$pdf->hline(1,4.5);
//date line
$pdf->hline(5,7);
//go to next line
$pdf->nextLine();
//show their name
$pdf->addTextX(i18n("%1 %2 (signature)",array($studentinfo->firstname,$studentinfo->lastname)),1.25);
//show the Date text
$pdf->addTextX(i18n("Date"),5.25);
//go to next line
$pdf->nextLine();
} }
$pdf->WriteHTML("<br><hr>");
$pdf->hr();
} }
$q=mysql_query("SELECT * FROM signaturepage WHERE name='parentdeclaration'"); $q=mysql_query("SELECT * FROM signaturepage WHERE name='parentdeclaration'");
$r=mysql_fetch_object($q); $r=mysql_fetch_assoc($q);
if($r->use) if($r['use']) {
{ $t = nl2br($r['text']);
//now for the parent/guardian signatures $pdf->WriteHTML("<h3>".i18n('Parent/Guardian Declaration')."</h3>$t");
$pdf->heading(i18n("Parent/Guardian Declaration"));
$parentbox=$r->text;
$pdf->addText($parentbox);
foreach($studentinfoarray AS $studentinfo)
{
//we want to make sure the vspace, line, and text under the line dont
//get wrapped onto multiple pages, so make sure we have enough space for the whole thing before we
//start, and if we dont, make a new page. normal stop for footer is at 0.9, so 1.65 gives 0.75 inches
//which should be enough... i think :)
if($pdf->yloc< 1.65 )
$pdf->newPage();
$pdf->vspace($height['sigspace']);
//signature line
$pdf->hline(1,4.5);
//date line
$pdf->hline(5,7);
$pdf->nextLine();
//show their name
$pdf->addTextX(i18n("Parent/Guardian of %1 %2 (signature)",array($studentinfo->firstname,$studentinfo->lastname)),1.25);
//show the Date text
$pdf->addTextX(i18n("Date"),5.25);
$pdf->nextLine();
foreach($studentinfoarray AS $studentinfo) {
sig($pdf, i18n("Parent/Guardian of %1 %2 (signature)",array($studentinfo->firstname,$studentinfo->lastname)));
} }
$pdf->hr(); $pdf->WriteHTML("<br><hr>");
} }
$q=mysql_query("SELECT * FROM signaturepage WHERE name='teacherdeclaration'"); $q=mysql_query("SELECT * FROM signaturepage WHERE name='teacherdeclaration'");
$r=mysql_fetch_object($q); $r=mysql_fetch_assoc($q);
if($r->use) if($r['use']) {
{ $t = nl2br($r['text']);
//now for the teacher signature $pdf->WriteHTML("<h3>".i18n('Teacher Declaration')."</h3>$t");
$pdf->heading(i18n("Teacher Declaration")); sig($pdf, i18n('Teacher Signature'));
$pdf->WriteHTML("<br><hr>");
$teacherbox=$r->text;
$pdf->addText($teacherbox);
//we want to make sure the vspace, line, and text under the line dont
//get wrapped onto multiple pages, so make sure we have enough space for the whole thing before we
//start, and if we dont, make a new page. normal stop for footer is at 0.9, so 1.65 gives 0.75 inches
//which should be enough... i think :)
if($pdf->yloc< 1.65 )
$pdf->newPage();
//we only need 1 teacher signature line, we can assume (maybe incorrectly) that both students
//have the same teacher.. if they are not the same, then they can get the best teacher to sign
//it doesnt matter.
$pdf->vspace($height['sigspace']);
//signature line
$pdf->hline(1,4.5);
//date line
$pdf->hline(5,7);
$pdf->nextLine();
//show their name
$pdf->addTextX(i18n("Teacher Signature"),1.25);
//show the Date text
$pdf->addTextX(i18n("Date"),5.25);
$pdf->nextLine();
$pdf->hr();
} }
$q=mysql_query("SELECT * FROM signaturepage WHERE name='regfee'"); $q=mysql_query("SELECT * FROM signaturepage WHERE name='regfee'");
$r=mysql_fetch_object($q); $r=mysql_fetch_assoc($q);
if($r->use) if($r['use']) {
{ $pdf->WriteHTML("<h3>".i18n('Registration Fee Summary')."</h3><br>");
//now for the teacher signature
$pdf->heading(i18n("Registration Fee Summary"));
$pdf->nextLine();
list($regfee, $rfeedata) = computeRegistrationFee($registration_id); list($regfee, $rfeedata) = computeRegistrationFee($registration_id);
$pdf->addTextX(i18n('Item'), 3.5); $x = $pdf->GetX() + 20;
$pdf->addTextX(i18n('Unit'), 5.1); $pdf->SetX($x);
$pdf->addTextX(i18n('Qty'), 5.5); $pdf->Cell(60, 0, i18n('Item'), 'B', 0, 'C');
$pdf->addTextX(i18n('Extended'), 5.9); $pdf->Cell(15, 0, i18n('Unit'), 'B', 0, 'C');
$pdf->vspace(0.05); $pdf->Cell(10, 0, i18n('Qty'), 'B', 0, 'C');
$pdf->hline(1.75,6.75); $pdf->Cell(20, 0, i18n('Extended'), 'B', 1, 'C');
foreach($rfeedata as $rf) { foreach($rfeedata as $rf) {
$pdf->nextLine();
$u = "$".sprintf("%.02f", $rf['base']); $u = "$".sprintf("%.02f", $rf['base']);
$e = "$".sprintf("%.02f", $rf['ext']); $e = "$".sprintf("%.02f", $rf['ext']);
$pdf->addTextX($rf['text'], 2); $pdf->SetX($x);
$pdf->addTextX("$u", 5); $pdf->Cell(60, 0, $rf['text'], 0, 0, 'L');
$pdf->addTextX($rf['num'], 5.6); $pdf->Cell(15, 0, $u, 0, 0, 'R');
$pdf->addTextX("$e", 6); $pdf->Cell(10, 0, $rf['num'], 0, 0, 'C');
$pdf->Cell(20, 0, $e, 0, 1, 'R');
} }
$pdf->vspace(0.05);
$pdf->hline(1.75,6.75);
$pdf->nextLine();
$t = "$".sprintf("%.02f", $regfee); $t = "$".sprintf("%.02f", $regfee);
$pdf->SetX($x);
$pdf->addTextX(i18n('Total (including all taxes)'), 4.2); $pdf->Cell(85, 0, i18n('Total (including all taxes)'), 'T', 0, 'R');
$pdf->addTextX("$t", 6); $pdf->Cell(20, 0, $t, 'T', 1, 'R');
$pdf->nextLine(); $pdf->WriteHTML("<br><hr>");
$pdf->hr();
} }
$q=mysql_query("SELECT * FROM signaturepage WHERE name='postamble'"); $q=mysql_query("SELECT * FROM signaturepage WHERE name='postamble'");
$r=mysql_fetch_object($q); $r=mysql_fetch_assoc($q);
if($r->use) if($r['use']) {
{ $t = nl2br($r['text']);
//now for the teacher signature $pdf->WriteHTML("<h3>".i18n('Additional Information')."</h3>$t");
$pdf->heading(i18n("Additional Information")); $pdf->WriteHTML("<br><hr>");
$box=$r->text;
$pdf->addText($box);
} }
/*
header("Content-type: application/pdf");
header("Content-disposition: inline; filename=sfiab_sig_".$_SESSION['registration_id'].".pdf");
header("Content-length: ".strlen($pdfdata));
*/
echo $pdf->output(); echo $pdf->output();
?> ?>

View File

@ -0,0 +1,339 @@
<?
/*
This file is part of the 'Science Fair In A Box' project
SFIAB Website: http://www.sfiab.ca
Copyright (C) 2005 Sci-Tech Ontario Inc <info@scitechontario.org>
Copyright (C) 2005 James Grant <james@lightbox.org>
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, version 2.
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; see the file COPYING. If not, write to
the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.
*/
?>
<?
require("common.inc.php");
include "register_participants.inc.php";
require("lpdf.php");
//anyone can access a sample, we dont need to be authenticated or anything for that
if($_GET['sample']) {
$registration_number=12345;
$registration_id=0;
}
else {
//authenticate based on email address and registration number from the SESSION
if(!$_SESSION['email'])
{
header("Location: register_participants.php");
exit;
}
if(!$_SESSION['registration_number'])
{
header("Location: register_participants.php");
exit;
}
$q=mysql_query("SELECT registrations.id AS regid, students.id AS studentid, students.firstname FROM registrations,students ".
"WHERE students.email='".$_SESSION['email']."' ".
"AND registrations.num='".$_SESSION['registration_number']."' ".
"AND registrations.id='".$_SESSION['registration_id']."' ".
"AND students.registrations_id=registrations.id ".
"AND registrations.year=".$config['FAIRYEAR']." ".
"AND students.year=".$config['FAIRYEAR']);
$registration_number=$_SESSION['registration_number'];
$registration_id=$_SESSION['registration_id'];
echo mysql_error();
if(mysql_num_rows($q)==0)
{
header("Location: register_participants.php");
exit;
}
$authinfo=mysql_fetch_object($q);
}
//END OF AUTH, now lets try to generate a PDF using only PHP :) this should be fun!
$pdf=new lpdf( i18n($config['fairname']),
i18n("Participant Signature Page (".$registration_number.")"),
$_SERVER['DOCUMENT_ROOT'].$config['SFIABDIRECTORY']."/data/logo-200.gif"
);
$pdf->newPage();
$height['sigspace']=0.40;
$pdf->setFontSize(11);
/*
//The title of the fair
$yloc=10.25;
$height['title']=0.25;
$height['subtitle']=0.22;
$height['topbox']=0.8;
$height['exhibitortitle']=0.2;
$height['exhibitorbox']=1.3;
$height['exhibitorsigtext']=0.13;
$height['parenttitle']=0.2;
$height['parentbox']=2.80;
$height['parentsigtext']=0.13;
*/
if($_GET['sample']) {
$projectinfo->title="Sample Project Title";
$projectinfo->division="Proj Division";
$projectinfo->category="Proj Category";
$studentinfo->firstname="SampleFirst";
$studentinfo->lastname="SampleLast";
$studentinfo->grade="10";
$studentinfoarray[]=$studentinfo;
$rr->school="SampleSchool";
}
else
{
//grab the project info
$q=mysql_query("SELECT projects.*,
projectcategories.category,
projectdivisions.division
FROM projects
JOIN projectdivisions ON projects.projectdivisions_id=projectdivisions.id
JOIN projectcategories ON projects.projectcategories_id=projectcategories.id
WHERE registrations_id='".$_SESSION['registration_id']."'
AND projects.year='".$config['FAIRYEAR']."'
AND projectdivisions.year='".$config['FAIRYEAR']."'
AND projectcategories.year='".$config['FAIRYEAR']."'
");
$projectinfo=mysql_fetch_object($q);
$q=mysql_query("SELECT * FROM students WHERE registrations_id='".$_SESSION['registration_id']."' AND year='".$config['FAIRYEAR']."'");
while($si=mysql_fetch_object($q))
$studentinfoarray[]=$si;
}
$topboxtext=i18n("Registration Number").": ".$registration_number."\n".
i18n("Project Title").": $projectinfo->title\n".
i18n($projectinfo->category)." / ".i18n($projectinfo->division)."\n";
if(count($studentinfoarray)>1)
$plural="s";
else
$plural="";
$pdf->heading(i18n("Registration Summary"));
$pdf->addText($topboxtext);
$pdf->nextline();
$pdf->addTextX("Exhibitor$plural: ", 0.75);
foreach($studentinfoarray AS $studentinfo)
{
if(!$_GET['sample']) {
$qq = mysql_query("SELECT school FROM schools WHERE id={$studentinfo->schools_id}");
$rr = mysql_fetch_object($qq);
}
$pdf->addTextX("$studentinfo->firstname $studentinfo->lastname, Grade {$studentinfo->grade}, {$rr->school}", 1.5);
$pdf->nextline();
}
//strip off the last comma
//add the newline
// $topboxtext.="\n";
$pdf->hr();
$q=mysql_query("SELECT * FROM signaturepage WHERE name='exhibitordeclaration'");
$r=mysql_fetch_object($q);
if($r->use)
{
$pdf->heading(i18n("Exhibitor Declaration"));
$studentbox=$r->text;
/*
$studentbox="The following section is to be read and signed by the exhibitor$plural.\n\n".
($plural?"We":"I")." certify that:\n".
" - The preparation of this project is mainly ".($plural?"our":"my")." own work\n".
" - ".($plural?"We":"I")." have read the rules and regulations and agree to abide by them\n".
" - ".($plural?"We":"I")." agree that the decision of the judges will be final\n";
*/
$pdf->addText($studentbox);
foreach($studentinfoarray AS $studentinfo)
{
//we want to make sure the vspace, line, and text under the line dont
//get wrapped onto multiple pages, so make sure we have enough space for the whole thing before we
//start, and if we dont, make a new page. normal stop for footer is at 0.9, so 1.65 gives 0.75 inches
//which should be enough... i think :)
if($pdf->yloc< 1.65 )
$pdf->newPage();
$pdf->vspace($height['sigspace']);
//signature line
$pdf->hline(1,4.5);
//date line
$pdf->hline(5,7);
//go to next line
$pdf->nextLine();
//show their name
$pdf->addTextX(i18n("%1 %2 (signature)",array($studentinfo->firstname,$studentinfo->lastname)),1.25);
//show the Date text
$pdf->addTextX(i18n("Date"),5.25);
//go to next line
$pdf->nextLine();
}
$pdf->hr();
}
$q=mysql_query("SELECT * FROM signaturepage WHERE name='parentdeclaration'");
$r=mysql_fetch_object($q);
if($r->use)
{
//now for the parent/guardian signatures
$pdf->heading(i18n("Parent/Guardian Declaration"));
$parentbox=$r->text;
$pdf->addText($parentbox);
foreach($studentinfoarray AS $studentinfo)
{
//we want to make sure the vspace, line, and text under the line dont
//get wrapped onto multiple pages, so make sure we have enough space for the whole thing before we
//start, and if we dont, make a new page. normal stop for footer is at 0.9, so 1.65 gives 0.75 inches
//which should be enough... i think :)
if($pdf->yloc< 1.65 )
$pdf->newPage();
$pdf->vspace($height['sigspace']);
//signature line
$pdf->hline(1,4.5);
//date line
$pdf->hline(5,7);
$pdf->nextLine();
//show their name
$pdf->addTextX(i18n("Parent/Guardian of %1 %2 (signature)",array($studentinfo->firstname,$studentinfo->lastname)),1.25);
//show the Date text
$pdf->addTextX(i18n("Date"),5.25);
$pdf->nextLine();
}
$pdf->hr();
}
$q=mysql_query("SELECT * FROM signaturepage WHERE name='teacherdeclaration'");
$r=mysql_fetch_object($q);
if($r->use)
{
//now for the teacher signature
$pdf->heading(i18n("Teacher Declaration"));
$teacherbox=$r->text;
$pdf->addText($teacherbox);
//we want to make sure the vspace, line, and text under the line dont
//get wrapped onto multiple pages, so make sure we have enough space for the whole thing before we
//start, and if we dont, make a new page. normal stop for footer is at 0.9, so 1.65 gives 0.75 inches
//which should be enough... i think :)
if($pdf->yloc< 1.65 )
$pdf->newPage();
//we only need 1 teacher signature line, we can assume (maybe incorrectly) that both students
//have the same teacher.. if they are not the same, then they can get the best teacher to sign
//it doesnt matter.
$pdf->vspace($height['sigspace']);
//signature line
$pdf->hline(1,4.5);
//date line
$pdf->hline(5,7);
$pdf->nextLine();
//show their name
$pdf->addTextX(i18n("Teacher Signature"),1.25);
//show the Date text
$pdf->addTextX(i18n("Date"),5.25);
$pdf->nextLine();
$pdf->hr();
}
$q=mysql_query("SELECT * FROM signaturepage WHERE name='regfee'");
$r=mysql_fetch_object($q);
if($r->use)
{
//now for the teacher signature
$pdf->heading(i18n("Registration Fee Summary"));
$pdf->nextLine();
list($regfee, $rfeedata) = computeRegistrationFee($registration_id);
$pdf->addTextX(i18n('Item'), 3.5);
$pdf->addTextX(i18n('Unit'), 5.1);
$pdf->addTextX(i18n('Qty'), 5.5);
$pdf->addTextX(i18n('Extended'), 5.9);
$pdf->vspace(0.05);
$pdf->hline(1.75,6.75);
foreach($rfeedata as $rf) {
$pdf->nextLine();
$u = "$".sprintf("%.02f", $rf['base']);
$e = "$".sprintf("%.02f", $rf['ext']);
$pdf->addTextX($rf['text'], 2);
$pdf->addTextX("$u", 5);
$pdf->addTextX($rf['num'], 5.6);
$pdf->addTextX("$e", 6);
}
$pdf->vspace(0.05);
$pdf->hline(1.75,6.75);
$pdf->nextLine();
$t = "$".sprintf("%.02f", $regfee);
$pdf->addTextX(i18n('Total (including all taxes)'), 4.2);
$pdf->addTextX("$t", 6);
$pdf->nextLine();
$pdf->hr();
}
$q=mysql_query("SELECT * FROM signaturepage WHERE name='postamble'");
$r=mysql_fetch_object($q);
if($r->use)
{
//now for the teacher signature
$pdf->heading(i18n("Additional Information"));
$box=$r->text;
$pdf->addText($box);
}
/*
header("Content-type: application/pdf");
header("Content-disposition: inline; filename=sfiab_sig_".$_SESSION['registration_id'].".pdf");
header("Content-length: ".strlen($pdfdata));
*/
echo $pdf->output();
?>

View File

@ -1,219 +0,0 @@
<?
/*
This file is part of the 'Science Fair In A Box' project
SFIAB Website: http://www.sfiab.ca
Copyright (C) 2005 James Grant <james@lightbox.org>
Copyright (C) 2010 David Grant <dave@lightbox.org>
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, version 2.
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; see the file COPYING. If not, write to
the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.
*/
?>
<?
require_once('common.inc.php');
require_once('register_participants.inc.php');
require_once('tcpdf.inc.php');
//anyone can access a sample, we dont need to be authenticated or anything for that
if($_GET['sample']) {
$registration_number=12345;
$registration_id=0;
} else {
//authenticate based on email address and registration number from the SESSION
if(!$_SESSION['email']) {
header("Location: register_participants.php");
exit;
}
if(!$_SESSION['registration_number']) {
header("Location: register_participants.php");
exit;
}
$q=mysql_query("SELECT registrations.id AS regid, students.id AS studentid, students.firstname
FROM registrations,students
WHERE students.email='{$_SESSION['email']}'
AND registrations.num='{$_SESSION['registration_number']}'
AND registrations.id='{$_SESSION['registration_id']}'
AND students.registrations_id=registrations.id
AND registrations.year={$config['FAIRYEAR']}
AND students.year={$config['FAIRYEAR']}");
$registration_number=$_SESSION['registration_number'];
$registration_id=$_SESSION['registration_id'];
echo mysql_error();
if(mysql_num_rows($q)==0) {
header("Location: register_participants.php");
exit;
}
$authinfo=mysql_fetch_object($q);
}
//END OF AUTH, now lets try to generate a PDF using only PHP :) this should be fun!
$pdf=new pdf( "Participant Signature Page ($registration_number)" );
$pdf->setFontSize(11);
$pdf->SetFont('times');
$height_sigspace = 15; //mm
$height_sigfont = $pdf->GetFontSize(); //mm
$pdf->AddPage();
if($_GET['sample']) {
$projectinfo->title="Sample Project Title";
$projectinfo->division="Proj Division";
$projectinfo->category="Proj Category";
$studentinfo->firstname="SampleFirst";
$studentinfo->lastname="SampleLast";
$studentinfo->grade="10";
$studentinfoarray[]=$studentinfo;
$rr->school="SampleSchool";
} else {
//grab the project info
$q=mysql_query("SELECT projects.*,
projectcategories.category,
projectdivisions.division
FROM projects
JOIN projectdivisions ON projects.projectdivisions_id=projectdivisions.id
JOIN projectcategories ON projects.projectcategories_id=projectcategories.id
WHERE registrations_id='".$_SESSION['registration_id']."'
AND projects.year='".$config['FAIRYEAR']."'
AND projectdivisions.year='".$config['FAIRYEAR']."'
AND projectcategories.year='".$config['FAIRYEAR']."'
");
$projectinfo=mysql_fetch_object($q);
$q=mysql_query("SELECT * FROM students WHERE registrations_id='".$_SESSION['registration_id']."' AND year='".$config['FAIRYEAR']."'");
while($si=mysql_fetch_object($q))
$studentinfoarray[]=$si;
}
$plural = (count($studentinfoarray)>1) ? 's' : '';
$pdf->WriteHTML("<h3>".i18n('Registration Summary')."</h3>
<p>
".i18n('Registration Number').": $registration_number <br/>
".i18n('Project Title').": {$projectinfo->title} <br/>
".i18n($projectinfo->category)." / ".i18n($projectinfo->division));
$students = "";
foreach($studentinfoarray AS $studentinfo) {
if(!$_GET['sample']) {
$qq = mysql_query("SELECT school FROM schools WHERE id={$studentinfo->schools_id}");
$rr = mysql_fetch_object($qq);
}
if($students != '') $students .= '<br/>';
$students .= "{$studentinfo->firstname} {$studentinfo->lastname}, Grade {$studentinfo->grade}, {$rr->school}";
}
$e = i18n("Exhibitor$plural").":";
$w = $pdf->GetStringWidth($e) + 2;
$pdf->WriteHTML("<table><tr><td width=\"{$w}mm\">$e</td><td>$students</td></tr></table>");
$pdf->WriteHTML("<hr>");
function sig($pdf, $text)
{
global $height_sigspace, $height_font;
$x = $pdf->GetX();
/* One cell for the whole thing, to force a page break if needed, leave
* the current pos to the right so the Y is unchanged */
$pdf->Cell(0, $height_sigspace + $height_font, '', 0, 0);
/* Restore X, and indent a bit, move Y down the signature space */
$pdf->SetXY($x + 15, $pdf->GetY() + $height_sigspace);
/* Box with a top line, then a space, then a box with a top line for the date */
$pdf->Cell(85, $height_font, $text, 'T', 0, 'C');
$pdf->SetX($pdf->GetX() + 15);
$pdf->Cell(60, $height_font, i18n('Date'), 'T', 1, 'C');
}
$q=mysql_query("SELECT * FROM signaturepage WHERE name='exhibitordeclaration'");
$r=mysql_fetch_assoc($q);
if($r['use']) {
$t = nl2br($r['text']);
$pdf->WriteHTML("<h3>".i18n('Exhibitor Declaration')."</h3>$t");
foreach($studentinfoarray AS $studentinfo) {
sig($pdf, i18n("%1 %2 (signature)",array($studentinfo->firstname,$studentinfo->lastname)));
}
$pdf->WriteHTML("<br><hr>");
}
$q=mysql_query("SELECT * FROM signaturepage WHERE name='parentdeclaration'");
$r=mysql_fetch_assoc($q);
if($r['use']) {
$t = nl2br($r['text']);
$pdf->WriteHTML("<h3>".i18n('Parent/Guardian Declaration')."</h3>$t");
foreach($studentinfoarray AS $studentinfo) {
sig($pdf, i18n("Parent/Guardian of %1 %2 (signature)",array($studentinfo->firstname,$studentinfo->lastname)));
}
$pdf->WriteHTML("<br><hr>");
}
$q=mysql_query("SELECT * FROM signaturepage WHERE name='teacherdeclaration'");
$r=mysql_fetch_assoc($q);
if($r['use']) {
$t = nl2br($r['text']);
$pdf->WriteHTML("<h3>".i18n('Teacher Declaration')."</h3>$t");
sig($pdf, i18n('Teacher Signature'));
$pdf->WriteHTML("<br><hr>");
}
$q=mysql_query("SELECT * FROM signaturepage WHERE name='regfee'");
$r=mysql_fetch_assoc($q);
if($r['use']) {
$pdf->WriteHTML("<h3>".i18n('Registration Fee Summary')."</h3><br>");
list($regfee, $rfeedata) = computeRegistrationFee($registration_id);
$x = $pdf->GetX() + 20;
$pdf->SetX($x);
$pdf->Cell(60, 0, i18n('Item'), 'B', 0, 'C');
$pdf->Cell(15, 0, i18n('Unit'), 'B', 0, 'C');
$pdf->Cell(10, 0, i18n('Qty'), 'B', 0, 'C');
$pdf->Cell(20, 0, i18n('Extended'), 'B', 1, 'C');
foreach($rfeedata as $rf) {
$u = "$".sprintf("%.02f", $rf['base']);
$e = "$".sprintf("%.02f", $rf['ext']);
$pdf->SetX($x);
$pdf->Cell(60, 0, $rf['text'], 0, 0, 'L');
$pdf->Cell(15, 0, $u, 0, 0, 'R');
$pdf->Cell(10, 0, $rf['num'], 0, 0, 'C');
$pdf->Cell(20, 0, $e, 0, 1, 'R');
}
$t = "$".sprintf("%.02f", $regfee);
$pdf->SetX($x);
$pdf->Cell(85, 0, i18n('Total (including all taxes)'), 'T', 0, 'R');
$pdf->Cell(20, 0, $t, 'T', 1, 'R');
$pdf->WriteHTML("<br><hr>");
}
$q=mysql_query("SELECT * FROM signaturepage WHERE name='postamble'");
$r=mysql_fetch_assoc($q);
if($r['use']) {
$t = nl2br($r['text']);
$pdf->WriteHTML("<h3>".i18n('Additional Information')."</h3>$t");
$pdf->WriteHTML("<br><hr>");
}
echo $pdf->output();
?>