2014-04-13 23:17:39 +07:00
|
|
|
<?php
|
|
|
|
|
/**
|
2014-05-05 13:06:53 +04:00
|
|
|
* This file is part of PHPWord - A pure PHP library for reading and writing
|
|
|
|
|
* word processing documents.
|
|
|
|
|
*
|
|
|
|
|
* PHPWord is free software distributed under the terms of the GNU Lesser
|
|
|
|
|
* General Public License version 3 as published by the Free Software Foundation.
|
|
|
|
|
*
|
|
|
|
|
* For the full copyright and license information, please read the LICENSE
|
|
|
|
|
* file that was distributed with this source code. For the full list of
|
|
|
|
|
* contributors, visit https://github.com/PHPOffice/PHPWord/contributors.
|
2014-04-13 23:17:39 +07:00
|
|
|
*
|
|
|
|
|
* @link https://github.com/PHPOffice/PhpWord
|
2014-05-05 12:38:31 +04:00
|
|
|
* @copyright 2010-2014 PHPWord contributors
|
2014-05-04 21:03:28 +04:00
|
|
|
* @license http://www.gnu.org/licenses/lgpl.txt LGPL version 3
|
2014-04-13 23:17:39 +07:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
namespace PhpOffice\PhpWord\Writer;
|
|
|
|
|
|
|
|
|
|
use PhpOffice\PhpWord\Exception\Exception;
|
|
|
|
|
use PhpOffice\PhpWord\PhpWord;
|
|
|
|
|
use PhpOffice\PhpWord\Settings;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* PDF Writer
|
|
|
|
|
*/
|
|
|
|
|
class PDF
|
|
|
|
|
{
|
|
|
|
|
/**
|
|
|
|
|
* The wrapper for the requested PDF rendering engine
|
|
|
|
|
*
|
2014-04-14 10:07:35 +07:00
|
|
|
* @var \PhpOffice\PhpWord\Writer\PDF\AbstractRenderer
|
2014-04-13 23:17:39 +07:00
|
|
|
*/
|
|
|
|
|
private $renderer = null;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Instantiate a new renderer of the configured type within this container class
|
|
|
|
|
*
|
|
|
|
|
* @param \PhpOffice\PhpWord\PhpWord $phpWord
|
2014-05-14 19:41:44 +07:00
|
|
|
* @throws \PhpOffice\PhpWord\Exception\Exception
|
2014-04-13 23:17:39 +07:00
|
|
|
*/
|
|
|
|
|
public function __construct(PhpWord $phpWord)
|
|
|
|
|
{
|
|
|
|
|
$pdfLibraryName = Settings::getPdfRendererName();
|
|
|
|
|
$pdfLibraryPath = Settings::getPdfRendererPath();
|
|
|
|
|
if (is_null($pdfLibraryName) || is_null($pdfLibraryPath)) {
|
|
|
|
|
throw new Exception("PDF rendering library or library path has not been defined.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$includePath = str_replace('\\', '/', get_include_path());
|
|
|
|
|
$rendererPath = str_replace('\\', '/', $pdfLibraryPath);
|
|
|
|
|
if (strpos($rendererPath, $includePath) === false) {
|
|
|
|
|
set_include_path(get_include_path() . PATH_SEPARATOR . $pdfLibraryPath);
|
|
|
|
|
}
|
|
|
|
|
|
2014-05-07 09:47:02 +07:00
|
|
|
$rendererName = get_class($this) . '\\' . $pdfLibraryName;
|
2014-04-13 23:17:39 +07:00
|
|
|
$this->renderer = new $rendererName($phpWord);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Magic method to handle direct calls to the configured PDF renderer wrapper class.
|
|
|
|
|
*
|
|
|
|
|
* @param string $name Renderer library method name
|
|
|
|
|
* @param mixed[] $arguments Array of arguments to pass to the renderer method
|
|
|
|
|
* @return mixed Returned data from the PDF renderer wrapper method
|
2014-05-14 19:41:44 +07:00
|
|
|
* @throws \PhpOffice\PhpWord\Exception\Exception
|
2014-04-13 23:17:39 +07:00
|
|
|
*/
|
|
|
|
|
public function __call($name, $arguments)
|
|
|
|
|
{
|
|
|
|
|
if ($this->renderer === null) {
|
|
|
|
|
throw new Exception("PDF Rendering library has not been defined.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return call_user_func_array(array($this->renderer, $name), $arguments);
|
|
|
|
|
}
|
|
|
|
|
}
|