From fc566cf0e2db557bf5678c1085c1802466a300a5 Mon Sep 17 00:00:00 2001 From: squidfunk Date: Mon, 4 Sep 2023 14:06:51 +0200 Subject: [PATCH] Fixed further regression in blog plugin navigation --- material/plugins/blog/plugin.py | 9 ++++----- src/plugins/blog/plugin.py | 9 ++++----- 2 files changed, 8 insertions(+), 10 deletions(-) diff --git a/material/plugins/blog/plugin.py b/material/plugins/blog/plugin.py index f74d87a8a..634c57f2f 100644 --- a/material/plugins/blog/plugin.py +++ b/material/plugins/blog/plugin.py @@ -34,7 +34,7 @@ from mkdocs.structure import StructureItem from mkdocs.structure.files import File, Files, InclusionLevel from mkdocs.structure.nav import Navigation, Section from mkdocs.structure.pages import Page -from mkdocs.utils import get_relative_url +from mkdocs.utils import copy_file, get_relative_url from paginate import Page as Pagination from shutil import rmtree from tempfile import mkdtemp @@ -225,10 +225,6 @@ class BlogPlugin(BasePlugin[BlogConfig]): for at in range(1, len(view.pages)): self._attach_at(view.parent, view, view.pages[at]) - # Replace source file system path - view.pages[at].file.src_uri = view.file.src_uri - view.pages[at].file.abs_src_path = view.file.abs_src_path - # Prepare post for rendering (run later) - allow other plugins to alter # the contents or metadata of a post before it is rendered and make sure # that the post includes a separator, which is essential for rendering @@ -640,6 +636,9 @@ class BlogPlugin(BasePlugin[BlogConfig]): file = self._path_to_file(path, config) files.append(file) + # Copy file to temporary directory + copy_file(view.file.abs_src_path, file.abs_src_path) + # Create view and attach to previous page if not isinstance(file.page, View): yield View(None, file, config) diff --git a/src/plugins/blog/plugin.py b/src/plugins/blog/plugin.py index f74d87a8a..634c57f2f 100644 --- a/src/plugins/blog/plugin.py +++ b/src/plugins/blog/plugin.py @@ -34,7 +34,7 @@ from mkdocs.structure import StructureItem from mkdocs.structure.files import File, Files, InclusionLevel from mkdocs.structure.nav import Navigation, Section from mkdocs.structure.pages import Page -from mkdocs.utils import get_relative_url +from mkdocs.utils import copy_file, get_relative_url from paginate import Page as Pagination from shutil import rmtree from tempfile import mkdtemp @@ -225,10 +225,6 @@ class BlogPlugin(BasePlugin[BlogConfig]): for at in range(1, len(view.pages)): self._attach_at(view.parent, view, view.pages[at]) - # Replace source file system path - view.pages[at].file.src_uri = view.file.src_uri - view.pages[at].file.abs_src_path = view.file.abs_src_path - # Prepare post for rendering (run later) - allow other plugins to alter # the contents or metadata of a post before it is rendered and make sure # that the post includes a separator, which is essential for rendering @@ -640,6 +636,9 @@ class BlogPlugin(BasePlugin[BlogConfig]): file = self._path_to_file(path, config) files.append(file) + # Copy file to temporary directory + copy_file(view.file.abs_src_path, file.abs_src_path) + # Create view and attach to previous page if not isinstance(file.page, View): yield View(None, file, config)