class MpdfGenerator in PDF generator API 8
Same name and namespace in other branches
- 2.x src/Plugin/PdfGenerator/MpdfGenerator.php \Drupal\pdf_api\Plugin\PdfGenerator\MpdfGenerator
A PDF generator plugin for the mPDF library.
Plugin annotation
@PdfGenerator(
id = "mpdf",
module = "pdf_api",
title = @Translation("mPDF"),
description = @Translation("PDF generator using the mPDF generator.")
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\pdf_api\Plugin\PdfGeneratorBase implements PdfGeneratorInterface
- class \Drupal\pdf_api\Plugin\PdfGenerator\MpdfGenerator implements ContainerFactoryPluginInterface
- class \Drupal\pdf_api\Plugin\PdfGeneratorBase implements PdfGeneratorInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of MpdfGenerator
File
- src/
Plugin/ PdfGenerator/ MpdfGenerator.php, line 28 - Contains \Drupal\pdf_api\Plugin\MpdfGenerator.
Namespace
Drupal\pdf_api\Plugin\PdfGeneratorView source
class MpdfGenerator extends PdfGeneratorBase implements ContainerFactoryPluginInterface {
/**
* Instance of the mPdf class library.
*
* @var \mPdf
*/
protected $generator;
/**
* The saved header content.
*
* @var string
*/
protected $headerContent;
/**
* The saved PDF content.
*
* @var string
*/
protected $pdfContent;
/**
* The saved footer content.
*
* @var string
*/
protected $footerContent;
/**
* {@inheritdoc}
*/
public function __construct(array $configuration, $plugin_id, array $plugin_definition) {
parent::__construct($configuration, $plugin_id, $plugin_definition);
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
return new static($configuration, $plugin_id, $plugin_definition);
}
/**
* {@inheritdoc}
*/
public function setter($pdf_content, $pdf_location, $save_pdf, $paper_orientation, $paper_size, $footer_content, $header_content, $path_to_binary = '') {
$this
->setPageSize($paper_size);
$this
->setPageOrientation($paper_orientation);
// Save until the generator is constructed in the preGenerate method.
$this->headerContent = $header_content;
$this->pdfContent = $pdf_content;
$this->footerContent = $footer_content;
}
/**
* {@inheritdoc}
*/
public function getObject() {
return $this->generator;
}
/**
* {@inheritdoc}
*/
public function setHeader($text) {
$this->generator
->SetHeader($text);
}
/**
* {@inheritdoc}
*/
public function addPage($html) {
$this->generator
->addPage($html);
}
/**
* {@inheritdoc}
*/
public function setPageOrientation($orientation = PdfGeneratorInterface::PORTRAIT) {
if ($orientation == PdfGeneratorInterface::PORTRAIT) {
$orientation = 'P';
}
else {
$orientation = 'L';
}
$this
->setOptions(array(
'orientation' => $orientation,
));
}
/**
* {@inheritdoc}
*/
public function setPageSize($page_size) {
if ($this
->isValidPageSize($page_size)) {
$this
->setOptions(array(
'sheet-size' => $page_size,
));
}
}
/**
* Sets the password in PDF.
*
* @param string $password
* The password which will be used in PDF.
*/
public function setPassword($password) {
if (isset($password) && $password != NULL) {
// Print and Copy is allowed.
$this->generator
->SetProtection(array(
'print',
'copy',
), $password, $password);
}
}
/**
* {@inheritdoc}
*/
public function setFooter($text) {
// $this->generator->SetFooter($text);
}
/**
* {@inheritdoc}
*/
public function save($location) {
$this
->preGenerate();
$this->generator
->Output($location, 'F');
}
/**
* {@inheritdoc}
*/
public function send() {
$this->generator
->Output("", "I");
}
/**
* {@inheritdoc}
*/
public function stream($filelocation) {
$this->generator
->Output($filelocation, 'F');
}
/**
* Set the global options from the plugin into the mPDF generator class.
*/
protected function preGenerate() {
/*
* We have to pass the initial page size and orientation that we want to
* the constructor, so we delay making the generator until we have those
* details.
*
* mPDF is also strange in its handling of parameters. We can't just set
* the page size and orientation separately (as you'd expect) but need to
* combine them in the format argument for them to be effective from the
* get-go.
*/
$options = $this->options;
$config = [];
$orientation = '';
$orientation = $options['orientation'] ? $options['orientation'] : 'P';
$config['format'] = $this
->isValidPageSize($options['sheet-size']) ? $options['sheet-size'] : 'A4';
if ($orientation == 'L') {
$config['format'] .= '-' . $orientation;
}
$this->generator = new mPDF($config);
// Apply any other options.
unset($options['orientation']);
unset($options['sheet-size']);
$this->generator
->AddPageByArray($options);
$this
->setHeader($this->headerContent);
$this
->setFooter($this->footerContent);
$stylesheet = '.node_view { display: none; }';
$this->generator
->WriteHTML($stylesheet, 1);
$this->generator
->WriteHTML(utf8_encode($this->pdfContent), 0);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
MpdfGenerator:: |
protected | property | The saved footer content. | |
MpdfGenerator:: |
protected | property | Instance of the mPdf class library. | |
MpdfGenerator:: |
protected | property | The saved header content. | |
MpdfGenerator:: |
protected | property | The saved PDF content. | |
MpdfGenerator:: |
public | function |
Add a page to the generated PDF. Overrides PdfGeneratorInterface:: |
|
MpdfGenerator:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
|
MpdfGenerator:: |
public | function |
Returns instances of PDF libraries. Overrides PdfGeneratorInterface:: |
|
MpdfGenerator:: |
protected | function | Set the global options from the plugin into the mPDF generator class. | |
MpdfGenerator:: |
public | function |
Generate and save the PDF at a specific location. Overrides PdfGeneratorInterface:: |
|
MpdfGenerator:: |
public | function |
The name of the file to be downloaded. Overrides PdfGeneratorInterface:: |
|
MpdfGenerator:: |
public | function |
Sets the footer in the PDF. Overrides PdfGeneratorInterface:: |
|
MpdfGenerator:: |
public | function |
Sets the header in the PDF. Overrides PdfGeneratorInterface:: |
|
MpdfGenerator:: |
public | function |
Set the paper orientation of the generated PDF pages. Overrides PdfGeneratorInterface:: |
|
MpdfGenerator:: |
public | function |
Set the page size of the generated PDF pages. Overrides PdfGeneratorInterface:: |
|
MpdfGenerator:: |
public | function | Sets the password in PDF. | |
MpdfGenerator:: |
public | function |
Set the various options for PDF. Overrides PdfGeneratorInterface:: |
|
MpdfGenerator:: |
public | function |
Stream the PDF to the browser. Overrides PdfGeneratorInterface:: |
|
MpdfGenerator:: |
public | function |
Constructs a \Drupal\Component\Plugin\PluginBase object. Overrides PluginBase:: |
|
PdfGeneratorBase:: |
protected | property | The global options for the PDF generator. | |
PdfGeneratorBase:: |
public | function |
Display error messages. Overrides PdfGeneratorInterface:: |
|
PdfGeneratorBase:: |
public | function |
Returns the administrative description for this generator plugin. Overrides PdfGeneratorInterface:: |
|
PdfGeneratorBase:: |
public | function |
Returns the administrative id for this generator plugin. Overrides PdfGeneratorInterface:: |
|
PdfGeneratorBase:: |
public | function |
Returns the administrative label for this generator plugin. Overrides PdfGeneratorInterface:: |
|
PdfGeneratorBase:: |
protected | function | Get the dimensions of a given page size. | |
PdfGeneratorBase:: |
public | function |
Get stderr from teh command that was run. Overrides PdfGeneratorInterface:: |
1 |
PdfGeneratorBase:: |
public | function |
Get stdout from the command that was run. Overrides PdfGeneratorInterface:: |
1 |
PdfGeneratorBase:: |
protected | function | Checks if a given page size is valid. | |
PdfGeneratorBase:: |
protected | function | Get an array of all valid page sizes, keyed by the page size name. | |
PdfGeneratorBase:: |
public | function | Set global options. | |
PdfGeneratorInterface:: |
constant | Landscape paper orientation. | ||
PdfGeneratorInterface:: |
constant | Portrait paper orientation. | ||
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
3 |
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. |