X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/253132afdf54b9200bcf33c95c0414798a3554d5..refs/pull/986/head:/app/Services/ExportService.php diff --git a/app/Services/ExportService.php b/app/Services/ExportService.php index 78cef41a4..01e87f167 100644 --- a/app/Services/ExportService.php +++ b/app/Services/ExportService.php @@ -9,14 +9,16 @@ class ExportService { protected $entityRepo; + protected $imageService; /** * ExportService constructor. * @param $entityRepo */ - public function __construct(EntityRepo $entityRepo) + public function __construct(EntityRepo $entityRepo, ImageService $imageService) { $this->entityRepo = $entityRepo; + $this->imageService = $imageService; } /** @@ -24,12 +26,13 @@ class ExportService * Includes required CSS & image content. Images are base64 encoded into the HTML. * @param Page $page * @return mixed|string + * @throws \Throwable */ public function pageToContainedHtml(Page $page) { + $this->entityRepo->renderPage($page); $pageHtml = view('pages/export', [ - 'page' => $page, - 'pageContent' => $this->entityRepo->renderPage($page) + 'page' => $page ])->render(); return $this->containHtml($pageHtml); } @@ -38,11 +41,12 @@ class ExportService * Convert a chapter to a self-contained HTML file. * @param Chapter $chapter * @return mixed|string + * @throws \Throwable */ public function chapterToContainedHtml(Chapter $chapter) { $pages = $this->entityRepo->getChapterChildren($chapter); - $pages->each(function($page) { + $pages->each(function ($page) { $page->html = $this->entityRepo->renderPage($page); }); $html = view('chapters/export', [ @@ -56,6 +60,7 @@ class ExportService * Convert a book to a self-contained HTML file. * @param Book $book * @return mixed|string + * @throws \Throwable */ public function bookToContainedHtml(Book $book) { @@ -71,12 +76,13 @@ class ExportService * Convert a page to a PDF file. * @param Page $page * @return mixed|string + * @throws \Throwable */ public function pageToPdf(Page $page) { + $this->entityRepo->renderPage($page); $html = view('pages/pdf', [ - 'page' => $page, - 'pageContent' => $this->entityRepo->renderPage($page) + 'page' => $page ])->render(); return $this->htmlToPdf($html); } @@ -85,11 +91,12 @@ class ExportService * Convert a chapter to a PDF file. * @param Chapter $chapter * @return mixed|string + * @throws \Throwable */ public function chapterToPdf(Chapter $chapter) { $pages = $this->entityRepo->getChapterChildren($chapter); - $pages->each(function($page) { + $pages->each(function ($page) { $page->html = $this->entityRepo->renderPage($page); }); $html = view('chapters/export', [ @@ -103,6 +110,7 @@ class ExportService * Convert a book to a PDF file * @param Book $book * @return string + * @throws \Throwable */ public function bookToPdf(Book $book) { @@ -118,6 +126,7 @@ class ExportService * Convert normal webpage HTML to a PDF. * @param $html * @return string + * @throws \Exception */ protected function htmlToPdf($html) { @@ -127,7 +136,7 @@ class ExportService $pdf = \SnappyPDF::loadHTML($containedHtml); $pdf->setOption('print-media-type', true); } else { - $pdf = \PDF::loadHTML($containedHtml); + $pdf = \DomPDF::loadHTML($containedHtml); } return $pdf->output(); } @@ -136,6 +145,7 @@ class ExportService * Bundle of the contents of a html file to be self-contained. * @param $htmlContent * @return mixed|string + * @throws \Exception */ protected function containHtml($htmlContent) { @@ -145,23 +155,14 @@ class ExportService // Replace image src with base64 encoded image strings if (isset($imageTagsOutput[0]) && count($imageTagsOutput[0]) > 0) { foreach ($imageTagsOutput[0] as $index => $imgMatch) { - $oldImgString = $imgMatch; + $oldImgTagString = $imgMatch; $srcString = $imageTagsOutput[2][$index]; - $isLocal = strpos(trim($srcString), 'http') !== 0; - if ($isLocal) { - $pathString = public_path(trim($srcString, '/')); - } else { - $pathString = $srcString; + $imageEncoded = $this->imageService->imageUriToBase64($srcString); + if ($imageEncoded === null) { + $imageEncoded = $srcString; } - if ($isLocal && !file_exists($pathString)) continue; - try { - $imageContent = file_get_contents($pathString); - $imageEncoded = 'data:image/' . pathinfo($pathString, PATHINFO_EXTENSION) . ';base64,' . base64_encode($imageContent); - $newImageString = str_replace($srcString, $imageEncoded, $oldImgString); - } catch (\ErrorException $e) { - $newImageString = ''; - } - $htmlContent = str_replace($oldImgString, $newImageString, $htmlContent); + $newImgTagString = str_replace($srcString, $imageEncoded, $oldImgTagString); + $htmlContent = str_replace($oldImgTagString, $newImgTagString, $htmlContent); } } @@ -238,17 +239,4 @@ class ExportService } return $text; } - } - - - - - - - - - - - -