X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/63cb6015a8c6db453f5551e50c04bf6ebbc0f3f1..refs/pull/3918/head:/app/Entities/Tools/PageContent.php diff --git a/app/Entities/Tools/PageContent.php b/app/Entities/Tools/PageContent.php index ea6a185f1..9aa2e8d35 100644 --- a/app/Entities/Tools/PageContent.php +++ b/app/Entities/Tools/PageContent.php @@ -5,6 +5,8 @@ namespace BookStack\Entities\Tools; use BookStack\Entities\Models\Page; use BookStack\Entities\Tools\Markdown\MarkdownToHtml; use BookStack\Exceptions\ImageUploadException; +use BookStack\Facades\Theme; +use BookStack\Theming\ThemeEvents; use BookStack\Uploads\ImageRepo; use BookStack\Uploads\ImageService; use BookStack\Util\HtmlContentFilter; @@ -372,23 +374,30 @@ class PageContent continue; } - // Find page and skip this if page not found + // Find page to use, and default replacement to empty string for non-matches. /** @var ?Page $matchedPage */ $matchedPage = Page::visible()->find($pageId); - if ($matchedPage === null) { - $html = str_replace($fullMatch, '', $html); - continue; + $replacement = ''; + + if ($matchedPage && count($splitInclude) === 1) { + // If we only have page id, just insert all page html and continue. + $replacement = $matchedPage->html; + } elseif ($matchedPage && count($splitInclude) > 1) { + // Otherwise, if our include tag defines a section, load that specific content + $innerContent = $this->fetchSectionOfPage($matchedPage, $splitInclude[1]); + $replacement = trim($innerContent); } - // If we only have page id, just insert all page html and continue. - if (count($splitInclude) === 1) { - $html = str_replace($fullMatch, $matchedPage->html, $html); - continue; - } + $themeReplacement = Theme::dispatch( + ThemeEvents::PAGE_INCLUDE_PARSE, + $includeId, + $replacement, + clone $this->page, + $matchedPage ? (clone $matchedPage) : null, + ); - // Create and load HTML into a document - $innerContent = $this->fetchSectionOfPage($matchedPage, $splitInclude[1]); - $html = str_replace($fullMatch, trim($innerContent), $html); + // Perform the content replacement + $html = str_replace($fullMatch, $themeReplacement ?? $replacement, $html); } return $html;