This bundle facilitates easy use of the TCPDF PDF generation library in Symfony2 applications.
composer require whiteoctober/tcpdf-bundle
Add the bundle to the registerBundles() method in your kernel:
In Symfony < 4:
// app/AppKernel.php
<?php
public function registerBundles()
{
$bundles = array(
// ...
new WhiteOctober\TCPDFBundle\WhiteOctoberTCPDFBundle(),
);
}In Symfony 4:
// config/bundles.php
return [
// ...
WhiteOctober\TCPDFBundle\WhiteOctoberTCPDFBundle::class => ['all' => true],
// ...
];(This project is not yet configured with Symfony Flex, so this change to config/bundles.php won't be done automatically.)
If you want to do service autowiring, you'll need to add an alias for the service:
# app/config/services.yml (Symfony 3)
# config/services.yaml (Symfony 4)
services:
# ...
# the `white_october.tcpdf` service will be injected when a
# `WhiteOctober\TCPDFBundle\Controller\TCPDFController` type-hint is detected
WhiteOctober\TCPDFBundle\Controller\TCPDFController: '@white_october.tcpdf'You can obtain the white_october.tcpdf service from the container,
and then create a new TCPDF object via the service:
$pdfObj = $container->get("white_october.tcpdf")->create();From hereon in, you are using a TCPDF object to work with as normal.
You can pass parameters to TCPDF like this:
# app/config/config.yml (Symfony < 4)
# config/packages/white_october_tcpdf.yaml (Symfony 4)
white_october_tcpdf:
tcpdf:
k_title_magnification: 2You can see the default parameter values in
WhiteOctober\TCPDFBundle\DependencyInjection\Configuration::addTCPDFConfig.
If you want, you can use TCPDF's own defaults instead:
white_october_tcpdf:
tcpdf:
k_tcpdf_external_config: false # the values set by this bundle will be ignored If you want to use your own custom TCPDF-based class, you can use
the class parameter in your configuration:
# app/config/config.yml (Symfony < 4)
# config/packages/white_october_tcpdf.yaml (Symfony 4)
white_october_tcpdf:
class: 'Acme\MyBundle\MyTCPDFClass'The class must extend from the TCPDF class; an exception will be
thrown if this is not the case.
This bundle is under the MIT license. See the complete license in the bundle:
Resources/meta/LICENSE
We welcome contributions to this project, including pull requests and issues (and discussions on existing issues).
If you'd like to contribute code but aren't sure what, the issues list is a good place to start. If you're a first-time code contributor, you may find Github's guide to forking projects helpful.
All contributors (whether contributing code, involved in issue discussions, or involved in any other way) must abide by our code of conduct.