# Contributte\PdfResponse

# Content

# Usage

# How to prepare PDF from template

// in a Presenter
public function actionPdf()
{
	$template = $this->createTemplate();
	$template->setFile(__DIR__ . "/path/to/template.latte");
	$template->someValue = 123;
	// Tip: In template to make a new page use <pagebreak>

	$pdf = new \Contributte\PdfResponse\PdfResponse($template);

	// optional
	$pdf->documentTitle = date("Y-m-d") . " My super title"; // creates filename 2012-06-30-my-super-title.pdf
	$pdf->pageFormat = "A4-L"; // wide format
	$pdf->getMPDF()->setFooter("|© www.mysite.com|"); // footer

	// do something with $pdf
	$this->sendResponse($pdf);
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

# Save file to server

public function actionPdf()
{
	$template = $this->createTemplate();
	$template->setFile(__DIR__ . "/path/to/template.latte");

	$pdf = new \Contributte\PdfResponse\PdfResponse($template);

	$pdf->save(__DIR__ . "/path/to/directory"); // as a filename $this->documentTitle will be used
	$pdf->save(__DIR__ . "/path/to/directory", "filename"); // OR use a custom name
}
1
2
3
4
5
6
7
8
9
10

# Attach file to an email

public function actionPdf()
{
	$template = $this->createTemplate();
	$template->setFile(__DIR__ . "/path/to/template.latte");

	$pdf = new \Contributte\PdfResponse\PdfResponse($template);

	$savedFile = $pdf->save(__DIR__ . "/path/to/directory");
	$mail = new Nette\Mail\Message;
	$mail->addTo("john@doe.com");
	$mail->addAttachment($savedFile);
	$mailer = new SendmailMailer();
	$mailer->send($mail);
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14

# Force file to download

public function actionPdf()
{
	$template = $this->createTemplate();
	$template->setFile(__DIR__ . "/path/to/template.latte");

	$pdf = new \Contributte\PdfResponse\PdfResponse($template);
	$pdf->setSaveMode(PdfResponse::DOWNLOAD); //default behavior
	$this->sendResponse($pdf);
}
1
2
3
4
5
6
7
8
9

# Force file to display in a browser

public function actionPdf()
{
	$template = $this->createTemplate();
	$template->setFile(__DIR__ . "/path/to/template.latte");

	$pdf = new \Contributte\PdfResponse\PdfResponse($template);
	$pdf->setSaveMode(PdfResponse::INLINE);
	$this->sendResponse($pdf);
}
1
2
3
4
5
6
7
8
9

# Set a pdf background easily

public function actionPdf()
{
	$pdf = new \Contributte\PdfResponse\PdfResponse('');
	$pdf->setBackgroundTemplate(__DIR__ . "/path/to/an/existing/file.pdf");

	// to write into an existing document use the following statements
	$mpdf = $pdf->getMPDF();
	$mpdf->WriteFixedPosHTML('hello world', 1, 10, 10, 10);

	// to write to another page
	$mpdf->AddPage();

	// to move to exact page, use
	$mpdf->page = 3; // = move to 3rd page

	$this->sendResponse($pdf);
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17

# Create pdf with latte only

public function actionPdf()
{
	$latte = new Latte\Engine;
	$latte->setTempDirectory('/path/to/cache');
	$latte->addFilter('money', function($val) { return ...; }); // formerly registerHelper()

	$latte->onCompile[] = function($latte) {
		$latte->addMacro(...); // when you want add some own macros, see http://goo.gl/d5A1u2
	};

	$template = $latte->renderToString(__DIR__ . "/path/to/template.latte");

	$pdf = new \Contributte\PdfResponse\PdfResponse($template);
	$this->sendResponse($pdf);
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

# Configuration of custom temp dir for mPDF in PdfResponse

services:
	-
		factory: Contributte\PdfResponse\PdfResponse
		setup:
			- $mpdfConfig([tempDir: %tempDir%/mpdf])
1
2
3
4
5

# See also


Thanks for testing, reporting and contributing.