2016-10-22 14:57:10 +00:00
|
|
|
<?php
|
|
|
|
/* vim: set expandtab sw=4 ts=4 sts=4: */
|
|
|
|
/**
|
|
|
|
* TCPDF wrapper class.
|
|
|
|
*
|
|
|
|
* @package PhpMyAdmin
|
|
|
|
*/
|
2017-04-20 10:55:30 +00:00
|
|
|
if (! defined('PHPMYADMIN')) {
|
|
|
|
exit;
|
|
|
|
}
|
2016-10-22 14:57:10 +00:00
|
|
|
|
|
|
|
require_once TCPDF_INC;
|
|
|
|
|
2017-04-20 10:55:30 +00:00
|
|
|
/**
|
|
|
|
* PDF font to use.
|
|
|
|
*/
|
|
|
|
define('PMA_PDF_FONT', 'DejaVuSans');
|
|
|
|
|
2016-10-22 14:57:10 +00:00
|
|
|
/**
|
|
|
|
* PDF export base class providing basic configuration.
|
|
|
|
*
|
|
|
|
* @package PhpMyAdmin
|
|
|
|
*/
|
2017-04-20 10:55:30 +00:00
|
|
|
class PMA_PDF extends TCPDF
|
2016-10-22 14:57:10 +00:00
|
|
|
{
|
|
|
|
var $footerset;
|
|
|
|
var $Alias = array();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructs PDF and configures standard parameters.
|
|
|
|
*
|
|
|
|
* @param string $orientation page orientation
|
|
|
|
* @param string $unit unit
|
2017-04-20 10:55:30 +00:00
|
|
|
* @param mixed $format the format used for pages
|
2016-10-22 14:57:10 +00:00
|
|
|
* @param boolean $unicode true means that the input text is unicode
|
|
|
|
* @param string $encoding charset encoding; default is UTF-8.
|
|
|
|
* @param boolean $diskcache if true reduce the RAM memory usage by caching
|
|
|
|
* temporary data on filesystem (slower).
|
|
|
|
*
|
2017-04-20 10:55:30 +00:00
|
|
|
* @return void
|
2016-10-22 14:57:10 +00:00
|
|
|
* @access public
|
|
|
|
*/
|
|
|
|
public function __construct($orientation = 'P', $unit = 'mm', $format = 'A4',
|
2017-04-20 10:55:30 +00:00
|
|
|
$unicode = true, $encoding = 'UTF-8', $diskcache = false
|
2016-10-22 14:57:10 +00:00
|
|
|
) {
|
2017-04-20 10:55:30 +00:00
|
|
|
parent::__construct();
|
2016-10-22 14:57:10 +00:00
|
|
|
$this->SetAuthor('phpMyAdmin ' . PMA_VERSION);
|
|
|
|
$this->AddFont('DejaVuSans', '', 'dejavusans.php');
|
|
|
|
$this->AddFont('DejaVuSans', 'B', 'dejavusansb.php');
|
2017-04-20 10:55:30 +00:00
|
|
|
$this->SetFont(PMA_PDF_FONT, '', 14);
|
|
|
|
$this->setFooterFont(array(PMA_PDF_FONT, '', 14));
|
2016-10-22 14:57:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function must be named "Footer" to work with the TCPDF library
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2017-04-20 10:55:30 +00:00
|
|
|
function Footer()
|
2016-10-22 14:57:10 +00:00
|
|
|
{
|
|
|
|
// Check if footer for this page already exists
|
|
|
|
if (!isset($this->footerset[$this->page])) {
|
|
|
|
$this->SetY(-15);
|
2017-04-20 10:55:30 +00:00
|
|
|
$this->SetFont(PMA_PDF_FONT, '', 14);
|
|
|
|
$this->Cell(0, 6, __('Page number:') . ' ' . $this->getAliasNumPage() . '/' . $this->getAliasNbPages(), 'T', 0, 'C');
|
|
|
|
$this->Cell(0, 6, PMA_Util::localisedDate(), 0, 1, 'R');
|
2016-10-22 14:57:10 +00:00
|
|
|
$this->SetY(20);
|
|
|
|
|
|
|
|
// set footerset
|
|
|
|
$this->footerset[$this->page] = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-04-20 10:55:30 +00:00
|
|
|
/**
|
|
|
|
* Function to test an empty string (was in tcpdf < 6.0)
|
|
|
|
*
|
|
|
|
* @param string $str to test
|
|
|
|
*
|
|
|
|
* @return boolean
|
|
|
|
*/
|
|
|
|
public function empty_string($str) {
|
|
|
|
return (is_null($str) OR (is_string($str) AND (strlen($str) == 0)));
|
|
|
|
}
|
|
|
|
|
2016-10-22 14:57:10 +00:00
|
|
|
/**
|
|
|
|
* Function to set alias which will be expanded on page rendering.
|
|
|
|
*
|
|
|
|
* @param string $name name of the alias
|
|
|
|
* @param string $value value of the alias
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2017-04-20 10:55:30 +00:00
|
|
|
function SetAlias($name, $value)
|
2016-10-22 14:57:10 +00:00
|
|
|
{
|
2017-04-20 10:55:30 +00:00
|
|
|
$this->Alias[$this->UTF8ToUTF16BE($name)] = $this->UTF8ToUTF16BE($value);
|
2016-10-22 14:57:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-04-20 10:55:30 +00:00
|
|
|
* Improved with alias expading.
|
2016-10-22 14:57:10 +00:00
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2017-04-20 10:55:30 +00:00
|
|
|
function _putpages()
|
2016-10-22 14:57:10 +00:00
|
|
|
{
|
|
|
|
if (count($this->Alias) > 0) {
|
2017-04-20 10:55:30 +00:00
|
|
|
$nb = count($this->pages);
|
|
|
|
for ($n = 1;$n <= $nb;$n++) {
|
2016-10-22 14:57:10 +00:00
|
|
|
$this->pages[$n] = strtr($this->pages[$n], $this->Alias);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
parent::_putpages();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Displays an error message
|
|
|
|
*
|
2017-04-20 10:55:30 +00:00
|
|
|
* @param string $error_message the error mesage
|
2016-10-22 14:57:10 +00:00
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2017-04-20 10:55:30 +00:00
|
|
|
function Error($error_message = '')
|
2016-10-22 14:57:10 +00:00
|
|
|
{
|
2017-04-20 10:55:30 +00:00
|
|
|
PMA_Message::error(
|
2016-10-22 14:57:10 +00:00
|
|
|
__('Error while creating PDF:') . ' ' . $error_message
|
|
|
|
)->display();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sends file as a download to user.
|
|
|
|
*
|
|
|
|
* @param string $filename file name
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2017-04-20 10:55:30 +00:00
|
|
|
function Download($filename)
|
2016-10-22 14:57:10 +00:00
|
|
|
{
|
|
|
|
$pdfData = $this->getPDFData();
|
2017-04-20 10:55:30 +00:00
|
|
|
PMA_Response::getInstance()->disable();
|
|
|
|
PMA_downloadHeader($filename, 'application/pdf', strlen($pdfData));
|
2016-10-22 14:57:10 +00:00
|
|
|
echo $pdfData;
|
|
|
|
}
|
|
|
|
}
|