1b6f35a76SGreg Roach<?php 2b6f35a76SGreg Roach 3b6f35a76SGreg Roach/** 4b6f35a76SGreg Roach * webtrees: online genealogy 589f7189bSGreg Roach * Copyright (C) 2021 webtrees development team 6b6f35a76SGreg Roach * This program is free software: you can redistribute it and/or modify 7b6f35a76SGreg Roach * it under the terms of the GNU General Public License as published by 8b6f35a76SGreg Roach * the Free Software Foundation, either version 3 of the License, or 9b6f35a76SGreg Roach * (at your option) any later version. 10b6f35a76SGreg Roach * This program is distributed in the hope that it will be useful, 11b6f35a76SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of 12b6f35a76SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13b6f35a76SGreg Roach * GNU General Public License for more details. 14b6f35a76SGreg Roach * You should have received a copy of the GNU General Public License 1589f7189bSGreg Roach * along with this program. If not, see <https://www.gnu.org/licenses/>. 16b6f35a76SGreg Roach */ 17b6f35a76SGreg Roach 18b6f35a76SGreg Roachdeclare(strict_types=1); 19b6f35a76SGreg Roach 20b6f35a76SGreg Roachnamespace Fisharebest\Webtrees\Report; 21b6f35a76SGreg Roach 22b6f35a76SGreg Roachuse Fisharebest\Webtrees\MediaFile; 23b6f35a76SGreg Roachuse Fisharebest\Webtrees\Webtrees; 24f7cf8a15SGreg Roachuse League\Flysystem\FilesystemOperator; 25b6f35a76SGreg Roach 26b6f35a76SGreg Roachuse function count; 27b6f35a76SGreg Roach 28b6f35a76SGreg Roach/** 29b6f35a76SGreg Roach * Class PdfRenderer 30b6f35a76SGreg Roach */ 31b6f35a76SGreg Roachclass PdfRenderer extends AbstractRenderer 32b6f35a76SGreg Roach{ 33b6f35a76SGreg Roach /** 34b6f35a76SGreg Roach * PDF compression - Zlib extension is required 35b6f35a76SGreg Roach * 36b6f35a76SGreg Roach * @var bool const 37b6f35a76SGreg Roach */ 38b6f35a76SGreg Roach private const COMPRESSION = true; 39b6f35a76SGreg Roach 40b6f35a76SGreg Roach /** 41b6f35a76SGreg Roach * If true reduce the RAM memory usage by caching temporary data on filesystem (slower). 42b6f35a76SGreg Roach * 43b6f35a76SGreg Roach * @var bool const 44b6f35a76SGreg Roach */ 45b6f35a76SGreg Roach private const DISK_CACHE = false; 46b6f35a76SGreg Roach 47b6f35a76SGreg Roach /** 48b6f35a76SGreg Roach * true means that the input text is unicode (PDF) 49b6f35a76SGreg Roach * 50b6f35a76SGreg Roach * @var bool const 51b6f35a76SGreg Roach */ 52b6f35a76SGreg Roach private const UNICODE = true; 53b6f35a76SGreg Roach 54345fcc8aSGreg Roach // Font sub-setting in TCPDF is slow. 55b6f35a76SGreg Roach private const SUBSETTING = false; 56b6f35a76SGreg Roach 57345fcc8aSGreg Roach public TcpdfWrapper $tcpdf; 58b6f35a76SGreg Roach 59345fcc8aSGreg Roach /** @var array<ReportPdfFootnote> Array of elements in the footer notes */ 60345fcc8aSGreg Roach public array $printedfootnotes = []; 61b6f35a76SGreg Roach 620a709a28SGreg Roach // The last cell height 63345fcc8aSGreg Roach public float $lastCellHeight = 0.0; 64b6f35a76SGreg Roach 650a709a28SGreg Roach // The largest font size within a TextBox to calculate the height 66345fcc8aSGreg Roach public float $largestFontHeight = 0.0; 67b6f35a76SGreg Roach 680a709a28SGreg Roach // The last pictures page number 69345fcc8aSGreg Roach public int $lastpicpage = 0; 70b6f35a76SGreg Roach 71b6f35a76SGreg Roach /** 72b6f35a76SGreg Roach * PDF Header -PDF 73b6f35a76SGreg Roach * 74b6f35a76SGreg Roach * @return void 75b6f35a76SGreg Roach */ 76b6f35a76SGreg Roach public function header(): void 77b6f35a76SGreg Roach { 78b6f35a76SGreg Roach foreach ($this->headerElements as $element) { 79b6f35a76SGreg Roach if ($element instanceof ReportBaseElement) { 80b6f35a76SGreg Roach $element->render($this); 81b6f35a76SGreg Roach } elseif ($element === 'footnotetexts') { 82b6f35a76SGreg Roach $this->footnotes(); 83b6f35a76SGreg Roach } elseif ($element === 'addpage') { 84b6f35a76SGreg Roach $this->newPage(); 85b6f35a76SGreg Roach } 86b6f35a76SGreg Roach } 87b6f35a76SGreg Roach } 88b6f35a76SGreg Roach 89b6f35a76SGreg Roach /** 90b6f35a76SGreg Roach * PDF Body -PDF 91b6f35a76SGreg Roach * 92b6f35a76SGreg Roach * @return void 93b6f35a76SGreg Roach */ 94b6f35a76SGreg Roach public function body(): void 95b6f35a76SGreg Roach { 96b6f35a76SGreg Roach $this->tcpdf->AddPage(); 97b6f35a76SGreg Roach 9877bab461SGreg Roach foreach ($this->bodyElements as $element) { 99b6f35a76SGreg Roach if ($element instanceof ReportBaseElement) { 100b6f35a76SGreg Roach $element->render($this); 101b6f35a76SGreg Roach } elseif ($element === 'footnotetexts') { 102b6f35a76SGreg Roach $this->footnotes(); 103b6f35a76SGreg Roach } elseif ($element === 'addpage') { 104b6f35a76SGreg Roach $this->newPage(); 105b6f35a76SGreg Roach } 106b6f35a76SGreg Roach } 107b6f35a76SGreg Roach } 108b6f35a76SGreg Roach 109b6f35a76SGreg Roach /** 11077bab461SGreg Roach * Generate footnotes 111b6f35a76SGreg Roach * 112b6f35a76SGreg Roach * @return void 113b6f35a76SGreg Roach */ 114b6f35a76SGreg Roach public function footnotes(): void 115b6f35a76SGreg Roach { 116b6f35a76SGreg Roach foreach ($this->printedfootnotes as $element) { 11752135727SGreg Roach if ($this->tcpdf->GetY() + $element->getFootnoteHeight($this) > $this->tcpdf->getPageHeight()) { 118b6f35a76SGreg Roach $this->tcpdf->AddPage(); 119b6f35a76SGreg Roach } 120b6f35a76SGreg Roach 121b6f35a76SGreg Roach $element->renderFootnote($this); 122b6f35a76SGreg Roach 123b6f35a76SGreg Roach if ($this->tcpdf->GetY() > $this->tcpdf->getPageHeight()) { 124b6f35a76SGreg Roach $this->tcpdf->AddPage(); 125b6f35a76SGreg Roach } 126b6f35a76SGreg Roach } 127b6f35a76SGreg Roach } 128b6f35a76SGreg Roach 129b6f35a76SGreg Roach /** 130b6f35a76SGreg Roach * PDF Footer -PDF 131b6f35a76SGreg Roach * 132b6f35a76SGreg Roach * @return void 133b6f35a76SGreg Roach */ 134b6f35a76SGreg Roach public function footer(): void 135b6f35a76SGreg Roach { 136b6f35a76SGreg Roach foreach ($this->footerElements as $element) { 137b6f35a76SGreg Roach if ($element instanceof ReportBaseElement) { 138b6f35a76SGreg Roach $element->render($this); 139b6f35a76SGreg Roach } elseif ($element === 'footnotetexts') { 140b6f35a76SGreg Roach $this->footnotes(); 141b6f35a76SGreg Roach } elseif ($element === 'addpage') { 142b6f35a76SGreg Roach $this->newPage(); 143b6f35a76SGreg Roach } 144b6f35a76SGreg Roach } 145b6f35a76SGreg Roach } 146b6f35a76SGreg Roach 147b6f35a76SGreg Roach /** 148b6f35a76SGreg Roach * Remove the header. 149b6f35a76SGreg Roach * 150b6f35a76SGreg Roach * @param int $index 151b6f35a76SGreg Roach * 152b6f35a76SGreg Roach * @return void 153b6f35a76SGreg Roach */ 154b6f35a76SGreg Roach public function removeHeader(int $index): void 155b6f35a76SGreg Roach { 156b6f35a76SGreg Roach unset($this->headerElements[$index]); 157b6f35a76SGreg Roach } 158b6f35a76SGreg Roach 159b6f35a76SGreg Roach /** 160b6f35a76SGreg Roach * Remove the body. 161b6f35a76SGreg Roach * 162b6f35a76SGreg Roach * @param int $index 163b6f35a76SGreg Roach * 164b6f35a76SGreg Roach * @return void 165b6f35a76SGreg Roach */ 166b6f35a76SGreg Roach public function removeBody(int $index): void 167b6f35a76SGreg Roach { 168b6f35a76SGreg Roach unset($this->bodyElements[$index]); 169b6f35a76SGreg Roach } 170b6f35a76SGreg Roach 171b6f35a76SGreg Roach /** 172b6f35a76SGreg Roach * Clear the Header -PDF 173b6f35a76SGreg Roach * 174b6f35a76SGreg Roach * @return void 175b6f35a76SGreg Roach */ 176b6f35a76SGreg Roach public function clearHeader(): void 177b6f35a76SGreg Roach { 178b6f35a76SGreg Roach unset($this->headerElements); 179b6f35a76SGreg Roach $this->headerElements = []; 180b6f35a76SGreg Roach } 181b6f35a76SGreg Roach 182b6f35a76SGreg Roach /** 183b6f35a76SGreg Roach * Get the currently used style name -PDF 184b6f35a76SGreg Roach * 185b6f35a76SGreg Roach * @return string 186b6f35a76SGreg Roach */ 187b6f35a76SGreg Roach public function getCurrentStyle(): string 188b6f35a76SGreg Roach { 189b6f35a76SGreg Roach return $this->currentStyle; 190b6f35a76SGreg Roach } 191b6f35a76SGreg Roach 192b6f35a76SGreg Roach /** 193b6f35a76SGreg Roach * Setup a style for usage -PDF 194b6f35a76SGreg Roach * 195b6f35a76SGreg Roach * @param string $s Style name 196b6f35a76SGreg Roach * 197b6f35a76SGreg Roach * @return void 198b6f35a76SGreg Roach */ 199b6f35a76SGreg Roach public function setCurrentStyle(string $s): void 200b6f35a76SGreg Roach { 201b6f35a76SGreg Roach $this->currentStyle = $s; 202ceab9748SGreg Roach $style = $this->getStyle($s); 203*b4c5c807SGreg Roach $this->tcpdf->setFont($style['font'], $style['style'], $style['size']); 204b6f35a76SGreg Roach } 205b6f35a76SGreg Roach 206b6f35a76SGreg Roach /** 207b6f35a76SGreg Roach * Get the style -PDF 208b6f35a76SGreg Roach * 209b6f35a76SGreg Roach * @param string $s Style name 210b6f35a76SGreg Roach * 21176d39c55SGreg Roach * @return array<string,string> 212b6f35a76SGreg Roach */ 213b6f35a76SGreg Roach public function getStyle(string $s): array 214b6f35a76SGreg Roach { 215ceab9748SGreg Roach if (!isset($this->styles[$s])) { 216b6f35a76SGreg Roach $s = $this->getCurrentStyle(); 217ceab9748SGreg Roach $this->styles[$s] = $s; 218b6f35a76SGreg Roach } 219b6f35a76SGreg Roach 220ceab9748SGreg Roach return $this->styles[$s]; 221b6f35a76SGreg Roach } 222b6f35a76SGreg Roach 223b6f35a76SGreg Roach /** 224b6f35a76SGreg Roach * Add margin when static horizontal position is used -PDF 225b6f35a76SGreg Roach * RTL supported 226b6f35a76SGreg Roach * 227b6f35a76SGreg Roach * @param float $x Static position 228b6f35a76SGreg Roach * 229b6f35a76SGreg Roach * @return float 230b6f35a76SGreg Roach */ 231b6f35a76SGreg Roach public function addMarginX(float $x): float 232b6f35a76SGreg Roach { 233b6f35a76SGreg Roach $m = $this->tcpdf->getMargins(); 234b6f35a76SGreg Roach if ($this->tcpdf->getRTL()) { 235b6f35a76SGreg Roach $x += $m['right']; 236b6f35a76SGreg Roach } else { 237b6f35a76SGreg Roach $x += $m['left']; 238b6f35a76SGreg Roach } 239*b4c5c807SGreg Roach $this->tcpdf->setX($x); 240b6f35a76SGreg Roach 241b6f35a76SGreg Roach return $x; 242b6f35a76SGreg Roach } 243b6f35a76SGreg Roach 244b6f35a76SGreg Roach /** 245b6f35a76SGreg Roach * Get the maximum line width to draw from the curren position -PDF 246b6f35a76SGreg Roach * RTL supported 247b6f35a76SGreg Roach * 248b6f35a76SGreg Roach * @return float 249b6f35a76SGreg Roach */ 250b6f35a76SGreg Roach public function getMaxLineWidth(): float 251b6f35a76SGreg Roach { 252b6f35a76SGreg Roach $m = $this->tcpdf->getMargins(); 253b6f35a76SGreg Roach if ($this->tcpdf->getRTL()) { 25452135727SGreg Roach return $this->tcpdf->getRemainingWidth() + $m['right']; 255b6f35a76SGreg Roach } 256b6f35a76SGreg Roach 25752135727SGreg Roach return $this->tcpdf->getRemainingWidth() + $m['left']; 258b6f35a76SGreg Roach } 259b6f35a76SGreg Roach 260b6f35a76SGreg Roach /** 261b6f35a76SGreg Roach * Get the height of the footnote. 262b6f35a76SGreg Roach * 263b6f35a76SGreg Roach * @return float 264b6f35a76SGreg Roach */ 265b6f35a76SGreg Roach public function getFootnotesHeight(): float 266b6f35a76SGreg Roach { 267b6f35a76SGreg Roach $h = 0; 268b6f35a76SGreg Roach foreach ($this->printedfootnotes as $element) { 269b6f35a76SGreg Roach $h += $element->getHeight($this); 270b6f35a76SGreg Roach } 271b6f35a76SGreg Roach 272b6f35a76SGreg Roach return $h; 273b6f35a76SGreg Roach } 274b6f35a76SGreg Roach 275b6f35a76SGreg Roach /** 276b6f35a76SGreg Roach * Returns the the current font size height -PDF 277b6f35a76SGreg Roach * 278b6f35a76SGreg Roach * @return float 279b6f35a76SGreg Roach */ 280b6f35a76SGreg Roach public function getCurrentStyleHeight(): float 281b6f35a76SGreg Roach { 282b6f35a76SGreg Roach if ($this->currentStyle === '') { 283ceab9748SGreg Roach return $this->default_font_size; 284b6f35a76SGreg Roach } 285ceab9748SGreg Roach $style = $this->getStyle($this->currentStyle); 286b6f35a76SGreg Roach 287b6f35a76SGreg Roach return (float) $style['size']; 288b6f35a76SGreg Roach } 289b6f35a76SGreg Roach 290b6f35a76SGreg Roach /** 291b6f35a76SGreg Roach * Checks the Footnote and numbers them 292b6f35a76SGreg Roach * 293b6f35a76SGreg Roach * @param ReportPdfFootnote $footnote 294b6f35a76SGreg Roach * 295b6f35a76SGreg Roach * @return ReportPdfFootnote|bool object if already numbered, false otherwise 296b6f35a76SGreg Roach */ 297b6f35a76SGreg Roach public function checkFootnote(ReportPdfFootnote $footnote) 298b6f35a76SGreg Roach { 299b6f35a76SGreg Roach $ct = count($this->printedfootnotes); 300b6f35a76SGreg Roach $val = $footnote->getValue(); 301b6f35a76SGreg Roach $i = 0; 302b6f35a76SGreg Roach while ($i < $ct) { 30377bab461SGreg Roach if ($this->printedfootnotes[$i]->getValue() === $val) { 304b6f35a76SGreg Roach // If this footnote already exist then set up the numbers for this object 305b6f35a76SGreg Roach $footnote->setNum($i + 1); 306b6f35a76SGreg Roach $footnote->setAddlink((string) ($i + 1)); 307b6f35a76SGreg Roach 308b6f35a76SGreg Roach return $this->printedfootnotes[$i]; 309b6f35a76SGreg Roach } 310b6f35a76SGreg Roach $i++; 311b6f35a76SGreg Roach } 312b6f35a76SGreg Roach // If this Footnote has not been set up yet 313b6f35a76SGreg Roach $footnote->setNum($ct + 1); 314b6f35a76SGreg Roach $footnote->setAddlink((string) $this->tcpdf->AddLink()); 315b6f35a76SGreg Roach $this->printedfootnotes[] = $footnote; 316b6f35a76SGreg Roach 317b6f35a76SGreg Roach return false; 318b6f35a76SGreg Roach } 319b6f35a76SGreg Roach 320b6f35a76SGreg Roach /** 321b6f35a76SGreg Roach * Used this function instead of AddPage() 322b6f35a76SGreg Roach * This function will make sure that images will not be overwritten 323b6f35a76SGreg Roach * 324b6f35a76SGreg Roach * @return void 325b6f35a76SGreg Roach */ 326b6f35a76SGreg Roach public function newPage(): void 327b6f35a76SGreg Roach { 328b6f35a76SGreg Roach if ($this->lastpicpage > $this->tcpdf->getPage()) { 329b6f35a76SGreg Roach $this->tcpdf->setPage($this->lastpicpage); 330b6f35a76SGreg Roach } 331b6f35a76SGreg Roach $this->tcpdf->AddPage(); 332b6f35a76SGreg Roach } 333b6f35a76SGreg Roach 334b6f35a76SGreg Roach /** 335b6f35a76SGreg Roach * Add a page if needed -PDF 336b6f35a76SGreg Roach * 337b6f35a76SGreg Roach * @param float $height Cell height 338b6f35a76SGreg Roach * 339b6f35a76SGreg Roach * @return bool true in case of page break, false otherwise 340b6f35a76SGreg Roach */ 341b6f35a76SGreg Roach public function checkPageBreakPDF(float $height): bool 342b6f35a76SGreg Roach { 343b6f35a76SGreg Roach return $this->tcpdf->checkPageBreak($height); 344b6f35a76SGreg Roach } 345b6f35a76SGreg Roach 346b6f35a76SGreg Roach /** 347b6f35a76SGreg Roach * Returns the remaining width between the current position and margins -PDF 348b6f35a76SGreg Roach * 349b6f35a76SGreg Roach * @return float Remaining width 350b6f35a76SGreg Roach */ 351b6f35a76SGreg Roach public function getRemainingWidthPDF(): float 352b6f35a76SGreg Roach { 353b6f35a76SGreg Roach return $this->tcpdf->getRemainingWidth(); 354b6f35a76SGreg Roach } 355b6f35a76SGreg Roach /** 356b6f35a76SGreg Roach * PDF Setup - ReportPdf 357b6f35a76SGreg Roach * 358b6f35a76SGreg Roach * @return void 359b6f35a76SGreg Roach */ 360b6f35a76SGreg Roach public function setup(): void 361b6f35a76SGreg Roach { 362b6f35a76SGreg Roach parent::setup(); 363b6f35a76SGreg Roach 364345fcc8aSGreg Roach $this->tcpdf = new TcpdfWrapper( 365345fcc8aSGreg Roach $this->orientation, 366345fcc8aSGreg Roach self::UNITS, 367345fcc8aSGreg Roach [$this->page_width, $this->page_height], 368345fcc8aSGreg Roach self::UNICODE, 369345fcc8aSGreg Roach 'UTF-8', 370345fcc8aSGreg Roach self::DISK_CACHE 371345fcc8aSGreg Roach ); 372b6f35a76SGreg Roach 373*b4c5c807SGreg Roach $this->tcpdf->setMargins($this->left_margin, $this->top_margin, $this->right_margin); 374b6f35a76SGreg Roach $this->tcpdf->setHeaderMargin($this->header_margin); 375b6f35a76SGreg Roach $this->tcpdf->setFooterMargin($this->footer_margin); 376*b4c5c807SGreg Roach $this->tcpdf->setAutoPageBreak(true, $this->bottom_margin); 377b6f35a76SGreg Roach $this->tcpdf->setFontSubsetting(self::SUBSETTING); 378*b4c5c807SGreg Roach $this->tcpdf->setCompression(self::COMPRESSION); 379b6f35a76SGreg Roach $this->tcpdf->setRTL($this->rtl); 380*b4c5c807SGreg Roach $this->tcpdf->setCreator(Webtrees::NAME . ' ' . Webtrees::VERSION); 381*b4c5c807SGreg Roach $this->tcpdf->setAuthor($this->rauthor); 382*b4c5c807SGreg Roach $this->tcpdf->setTitle($this->title); 383*b4c5c807SGreg Roach $this->tcpdf->setSubject($this->rsubject); 384*b4c5c807SGreg Roach $this->tcpdf->setKeywords($this->rkeywords); 385*b4c5c807SGreg Roach $this->tcpdf->setHeaderData('', 0, $this->title); 386f6351d1fSGreg Roach $this->tcpdf->setHeaderFont([$this->default_font, '', $this->default_font_size]); 387b6f35a76SGreg Roach 388b6f35a76SGreg Roach if ($this->show_generated_by) { 389b6f35a76SGreg Roach // The default style name for Generated by.... is 'genby' 39077bab461SGreg Roach $element = new ReportPdfCell(0.0, 10.0, '', 'C', '', 'genby', 1, ReportBaseElement::CURRENT_POSITION, ReportBaseElement::CURRENT_POSITION, 0, 0, '', '', true); 391b6f35a76SGreg Roach $element->addText($this->generated_by); 392b6f35a76SGreg Roach $element->setUrl(Webtrees::URL); 393345fcc8aSGreg Roach $this->addElementToFooter($element); 394b6f35a76SGreg Roach } 395b6f35a76SGreg Roach } 396b6f35a76SGreg Roach 397b6f35a76SGreg Roach /** 398b6f35a76SGreg Roach * Run the report. 399b6f35a76SGreg Roach * 400b6f35a76SGreg Roach * @return void 401b6f35a76SGreg Roach */ 402b6f35a76SGreg Roach public function run(): void 403b6f35a76SGreg Roach { 404b6f35a76SGreg Roach $this->body(); 405b6f35a76SGreg Roach echo $this->tcpdf->Output('doc.pdf', 'S'); 406b6f35a76SGreg Roach } 407b6f35a76SGreg Roach 408b6f35a76SGreg Roach /** 409b6f35a76SGreg Roach * Create a new Cell object. 410b6f35a76SGreg Roach * 41177bab461SGreg Roach * @param float $width cell width (expressed in points) 41277bab461SGreg Roach * @param float $height cell height (expressed in points) 41377bab461SGreg Roach * @param string $border Border style 41477bab461SGreg Roach * @param string $align Text alignment 415b6f35a76SGreg Roach * @param string $bgcolor Background color code 416b6f35a76SGreg Roach * @param string $style The name of the text style 417b6f35a76SGreg Roach * @param int $ln Indicates where the current position should go after the call 418b6f35a76SGreg Roach * @param mixed $top Y-position 419b6f35a76SGreg Roach * @param mixed $left X-position 420b6f35a76SGreg Roach * @param int $fill Indicates if the cell background must be painted (1) or transparent (0). Default value: 1 421b6f35a76SGreg Roach * @param int $stretch Stretch carachter mode 422b6f35a76SGreg Roach * @param string $bocolor Border color 423b6f35a76SGreg Roach * @param string $tcolor Text color 424b6f35a76SGreg Roach * @param bool $reseth 425b6f35a76SGreg Roach * 426b6f35a76SGreg Roach * @return ReportBaseCell 427b6f35a76SGreg Roach */ 42877bab461SGreg Roach public function createCell(float $width, float $height, string $border, string $align, string $bgcolor, string $style, int $ln, $top, $left, int $fill, int $stretch, string $bocolor, string $tcolor, bool $reseth): ReportBaseCell 429b6f35a76SGreg Roach { 430b6f35a76SGreg Roach return new ReportPdfCell($width, $height, $border, $align, $bgcolor, $style, $ln, $top, $left, $fill, $stretch, $bocolor, $tcolor, $reseth); 431b6f35a76SGreg Roach } 432b6f35a76SGreg Roach 433b6f35a76SGreg Roach /** 434b6f35a76SGreg Roach * Create a new TextBox object. 435b6f35a76SGreg Roach * 436b6f35a76SGreg Roach * @param float $width Text box width 437b6f35a76SGreg Roach * @param float $height Text box height 438b6f35a76SGreg Roach * @param bool $border 439b6f35a76SGreg Roach * @param string $bgcolor Background color code in HTML 440b6f35a76SGreg Roach * @param bool $newline 441b6f35a76SGreg Roach * @param float $left 442b6f35a76SGreg Roach * @param float $top 443b6f35a76SGreg Roach * @param bool $pagecheck 444b6f35a76SGreg Roach * @param string $style 445b6f35a76SGreg Roach * @param bool $fill 446b6f35a76SGreg Roach * @param bool $padding 447b6f35a76SGreg Roach * @param bool $reseth 448b6f35a76SGreg Roach * 449b6f35a76SGreg Roach * @return ReportBaseTextbox 450b6f35a76SGreg Roach */ 451b6f35a76SGreg Roach public function createTextBox( 452b6f35a76SGreg Roach float $width, 453b6f35a76SGreg Roach float $height, 454b6f35a76SGreg Roach bool $border, 455b6f35a76SGreg Roach string $bgcolor, 456b6f35a76SGreg Roach bool $newline, 457b6f35a76SGreg Roach float $left, 458b6f35a76SGreg Roach float $top, 459b6f35a76SGreg Roach bool $pagecheck, 460b6f35a76SGreg Roach string $style, 461b6f35a76SGreg Roach bool $fill, 462b6f35a76SGreg Roach bool $padding, 463b6f35a76SGreg Roach bool $reseth 464b6f35a76SGreg Roach ): ReportBaseTextbox { 465b6f35a76SGreg Roach return new ReportPdfTextBox($width, $height, $border, $bgcolor, $newline, $left, $top, $pagecheck, $style, $fill, $padding, $reseth); 466b6f35a76SGreg Roach } 467b6f35a76SGreg Roach 468b6f35a76SGreg Roach /** 469b6f35a76SGreg Roach * Create a text element. 470b6f35a76SGreg Roach * 471b6f35a76SGreg Roach * @param string $style 472b6f35a76SGreg Roach * @param string $color 473b6f35a76SGreg Roach * 474b6f35a76SGreg Roach * @return ReportBaseText 475b6f35a76SGreg Roach */ 476b6f35a76SGreg Roach public function createText(string $style, string $color): ReportBaseText 477b6f35a76SGreg Roach { 478b6f35a76SGreg Roach return new ReportPdfText($style, $color); 479b6f35a76SGreg Roach } 480b6f35a76SGreg Roach 481b6f35a76SGreg Roach /** 482b6f35a76SGreg Roach * Create a new Footnote object. 483b6f35a76SGreg Roach * 484b6f35a76SGreg Roach * @param string $style Style name 485b6f35a76SGreg Roach * 486b6f35a76SGreg Roach * @return ReportBaseFootnote 487b6f35a76SGreg Roach */ 48824f2a3afSGreg Roach public function createFootnote(string $style): ReportBaseFootnote 489b6f35a76SGreg Roach { 490b6f35a76SGreg Roach return new ReportPdfFootnote($style); 491b6f35a76SGreg Roach } 492b6f35a76SGreg Roach 493b6f35a76SGreg Roach /** 494b6f35a76SGreg Roach * Create a new image object. 495b6f35a76SGreg Roach * 496b6f35a76SGreg Roach * @param string $file Filename 497b6f35a76SGreg Roach * @param float $x 498b6f35a76SGreg Roach * @param float $y 499b6f35a76SGreg Roach * @param float $w Image width 500b6f35a76SGreg Roach * @param float $h Image height 501b6f35a76SGreg Roach * @param string $align L:left, C:center, R:right or empty to use x/y 502b6f35a76SGreg Roach * @param string $ln T:same line, N:next line 503b6f35a76SGreg Roach * 504b6f35a76SGreg Roach * @return ReportBaseImage 505b6f35a76SGreg Roach */ 506b6f35a76SGreg Roach public function createImage(string $file, float $x, float $y, float $w, float $h, string $align, string $ln): ReportBaseImage 507b6f35a76SGreg Roach { 508b6f35a76SGreg Roach return new ReportPdfImage($file, $x, $y, $w, $h, $align, $ln); 509b6f35a76SGreg Roach } 510b6f35a76SGreg Roach 511b6f35a76SGreg Roach /** 512b6f35a76SGreg Roach * Create a new image object from Media Object. 513b6f35a76SGreg Roach * 514b6f35a76SGreg Roach * @param MediaFile $media_file 515b6f35a76SGreg Roach * @param float $x 516b6f35a76SGreg Roach * @param float $y 517b6f35a76SGreg Roach * @param float $w Image width 518b6f35a76SGreg Roach * @param float $h Image height 519b6f35a76SGreg Roach * @param string $align L:left, C:center, R:right or empty to use x/y 520b6f35a76SGreg Roach * @param string $ln T:same line, N:next line 521f7cf8a15SGreg Roach * @param FilesystemOperator $data_filesystem 522b6f35a76SGreg Roach * 523b6f35a76SGreg Roach * @return ReportBaseImage 524b6f35a76SGreg Roach */ 525b6f35a76SGreg Roach public function createImageFromObject( 526b6f35a76SGreg Roach MediaFile $media_file, 527b6f35a76SGreg Roach float $x, 528b6f35a76SGreg Roach float $y, 529b6f35a76SGreg Roach float $w, 530b6f35a76SGreg Roach float $h, 531b6f35a76SGreg Roach string $align, 532b6f35a76SGreg Roach string $ln, 533f7cf8a15SGreg Roach FilesystemOperator $data_filesystem 534b6f35a76SGreg Roach ): ReportBaseImage { 535b6f35a76SGreg Roach return new ReportPdfImage('@' . $media_file->fileContents($data_filesystem), $x, $y, $w, $h, $align, $ln); 536b6f35a76SGreg Roach } 537b6f35a76SGreg Roach 538b6f35a76SGreg Roach /** 539b6f35a76SGreg Roach * Create a line. 540b6f35a76SGreg Roach * 541b6f35a76SGreg Roach * @param float $x1 542b6f35a76SGreg Roach * @param float $y1 543b6f35a76SGreg Roach * @param float $x2 544b6f35a76SGreg Roach * @param float $y2 545b6f35a76SGreg Roach * 546b6f35a76SGreg Roach * @return ReportBaseLine 547b6f35a76SGreg Roach */ 548b6f35a76SGreg Roach public function createLine(float $x1, float $y1, float $x2, float $y2): ReportBaseLine 549b6f35a76SGreg Roach { 550b6f35a76SGreg Roach return new ReportPdfLine($x1, $y1, $x2, $y2); 551b6f35a76SGreg Roach } 552b6f35a76SGreg Roach} 553