From b8154610d470a91727d3e118345424aa72f7a32a Mon Sep 17 00:00:00 2001 From: Ronny Zulaikha <75528127+ronzulu@users.noreply.github.com> Date: Tue, 10 Sep 2024 13:52:26 +1000 Subject: [PATCH] Fixed (#1061) --- src/util/RenderMarkdownWrapper.ts | 48 +++---------------------------- 1 file changed, 4 insertions(+), 44 deletions(-) diff --git a/src/util/RenderMarkdownWrapper.ts b/src/util/RenderMarkdownWrapper.ts index 8422b8c6..d6792515 100644 --- a/src/util/RenderMarkdownWrapper.ts +++ b/src/util/RenderMarkdownWrapper.ts @@ -46,8 +46,10 @@ export class RenderMarkdownWrapper { if (link.target.extension !== "md") { this.embedMediaFile(el, link.target); } else { - el.innerText = ""; - this.renderTransclude(el, link, recursiveDepth); + // We get here if there is a transclusion link, such as "![[Test Embed]]" + // In version 1.12.4 and earlier we used the deprecated Obsidian MarkdownRenderer.renderMarkdown() and we + // needed to have our own method "renderTransclude()" that loaded the referenced file and rendered it. + // In version 1.12.5, we started using MarkdownRenderer.render() instead, which does this automatically. } } }); @@ -115,46 +117,4 @@ export class RenderMarkdownWrapper { el.innerText = target.path; } } - - private async renderTransclude( - el: HTMLElement, - link: { - text: string; - file: string; - heading: string; - blockId: string; - target: TFile; - }, - recursiveDepth: number, - ) { - const cache = this.app.metadataCache.getCache(link.target.path); - const text = await this.app.vault.cachedRead(link.target); - let blockText; - if (link.heading) { - const clean = (s: string) => s.replace(NON_LETTER_SYMBOLS_REGEX, ""); - const headingIndex = cache.headings?.findIndex( - (h) => clean(h.heading) === clean(link.heading), - ); - const heading = cache.headings[headingIndex]; - - const startAt = heading.position.start.offset; - const endAt = - cache.headings.slice(headingIndex + 1).find((h) => h.level <= heading.level) - ?.position?.start?.offset || text.length; - - blockText = text.substring(startAt, endAt); - } else if (link.blockId) { - const block = cache.blocks[link.blockId]; - const startAt = block.position.start.offset; - const endAt = block.position.end.offset; - blockText = text.substring(startAt, endAt); - } else { - blockText = text; - } - - // We are operating here within the parent container. - // It already has the rtl div if necessary. - // We don't need another rtl div, so we can set direction to Unspecified - this.renderMarkdownWrapper(blockText, el, TextDirection.Unspecified, recursiveDepth + 1); - } }