%PDF- %PDF-
| Direktori : /www/varak.net/losik.varak.net/vendor/phpoffice/phpspreadsheet/src/PhpSpreadsheet/Writer/ |
| Current File : //www/varak.net/losik.varak.net/vendor/phpoffice/phpspreadsheet/src/PhpSpreadsheet/Writer/Pdf.php |
<?php
namespace PhpOffice\PhpSpreadsheet\Writer;
use PhpOffice\PhpSpreadsheet\Settings;
use PhpOffice\PhpSpreadsheet\Spreadsheet;
/**
* Copyright (c) 2006 - 2015 PhpSpreadsheet.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*
* @category PhpSpreadsheet
*
* @copyright Copyright (c) 2006 - 2015 PhpSpreadsheet (https://github.com/PHPOffice/PhpSpreadsheet)
* @license http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt LGPL
*/
class Pdf implements IWriter
{
/**
* The wrapper for the requested PDF rendering engine.
*
* @var PDF\Core
*/
private $renderer = null;
/**
* Instantiate a new renderer of the configured type within this container class.
*
* @param Spreadsheet $spreadsheet PhpSpreadsheet object
*
* @throws Exception when PDF library is not configured
*/
public function __construct(Spreadsheet $spreadsheet)
{
$pdfLibraryName = Settings::getPdfRendererName();
if (is_null($pdfLibraryName)) {
throw new Exception('PDF Rendering library has not been defined.');
}
$rendererName = '\\PhpOffice\\PhpSpreadsheet\\Writer\\Pdf\\' . $pdfLibraryName;
$this->renderer = new $rendererName($spreadsheet);
}
/**
* 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
*/
public function __call($name, $arguments)
{
if ($this->renderer === null) {
throw new Exception('PDF Rendering library has not been defined.');
}
return call_user_func_array([$this->renderer, $name], $arguments);
}
/**
* {@inheritdoc}
*/
public function save($pFilename)
{
$this->renderer->save($pFilename);
}
}