From 053174bb4b71d4ce490e4317caaddbc9ef2fe2fd Mon Sep 17 00:00:00 2001 From: Adam Matthiesen Date: Sun, 22 Dec 2024 03:29:26 -0800 Subject: [PATCH] Refactor Astro Markdown rendering logic in Renderer.js and contentRenderer.ts --- .../src/components/Renderer.js | 1 - .../src/lib/contentRenderer.ts | 38 ++++++------------- 2 files changed, 12 insertions(+), 27 deletions(-) diff --git a/packages/studiocms_renderers/src/components/Renderer.js b/packages/studiocms_renderers/src/components/Renderer.js index 2b6f82711..5e9904bb7 100644 --- a/packages/studiocms_renderers/src/components/Renderer.js +++ b/packages/studiocms_renderers/src/components/Renderer.js @@ -1,4 +1,3 @@ -import rendererConfig from 'studiocms:renderer/config'; import contentRenderer from 'studiocms:renderer/current'; import { HTMLString } from 'astro/runtime/server/index.js'; diff --git a/packages/studiocms_renderers/src/lib/contentRenderer.ts b/packages/studiocms_renderers/src/lib/contentRenderer.ts index 6047e2734..56f69b6b1 100644 --- a/packages/studiocms_renderers/src/lib/contentRenderer.ts +++ b/packages/studiocms_renderers/src/lib/contentRenderer.ts @@ -9,24 +9,20 @@ const { renderer } = rendererConfig; /** * Content Renderer * - * Renders content based on the renderer configuration + * Renders content using the specified renderer from the StudioCMS configuration * * @param content - The content to render - * @param renderer - The renderer function to use - * @returns The rendered content - * - * @example - * function sampleRenderer(content: string): Promise { - * // Assuming the renderer function processes the content and returns a string - * return `

${content}

`; - * } - * - * const renderedContent = contentRenderer({ - * content: 'Hello, world!', - * renderer: sampleRenderer, - * }); + * @returns The rendered content as a HTML string */ export async function contentRenderer(content: string): Promise { + if (typeof renderer === 'object') { + if (!renderer.renderer || !renderer.name) { + throw new Error('Invalid custom renderer'); + } + logger.debug(`Using custom renderer: ${renderer.name}`); + return await renderer.renderer(content); + } + switch (renderer) { case 'astro': logger.debug('Using built-in renderer: astro remark'); @@ -38,18 +34,8 @@ export async function contentRenderer(content: string): Promise { logger.debug('Using built-in renderer: mdx'); return await renderAstroMDX(content); default: - try { - logger.debug(`Using custom renderer: ${renderer.name}`); - return await renderer.renderer(content); - } catch (e) { - if (e instanceof Error) { - logger.error( - `Error rendering with ${renderer.name}: ${e.message}, falling back to astro remark\n\n${e.stack}` - ); - } - logger.error(`Error rendering with ${renderer.name}: ${e}, falling back to astro remark`); - return await renderAstroMD(content); - } + logger.error(`Unknown renderer: ${renderer}, falling back to astro remark`); + return await renderAstroMD(content); } }