From 3b107f4d38059d71315cf2cbf9f2e7485d580518 Mon Sep 17 00:00:00 2001 From: Neko Ayaka Date: Fri, 11 Oct 2024 13:11:06 +0800 Subject: [PATCH] fix(unlazy-img): not properly handling mdit urls & bad format detection predicates Signed-off-by: Neko Ayaka --- packages/markdown-it-unlazy-img/src/index.ts | 23 +++++++++++++------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/packages/markdown-it-unlazy-img/src/index.ts b/packages/markdown-it-unlazy-img/src/index.ts index 3cb8351b..cde02800 100644 --- a/packages/markdown-it-unlazy-img/src/index.ts +++ b/packages/markdown-it-unlazy-img/src/index.ts @@ -119,6 +119,10 @@ export interface UnlazyImagesOptions { * @default { mapGlobPatterns: ['**\/.vitepress/cache/@nolebase/vitepress-plugin-thumbnail-hash/thumbhashes/map.json', '**\/thumbhashes/map.json'] } */ thumbhash?: ThumbnailImageThumbhashOptions + /** + * Log format not supported warning + */ + logFormatNotSupportedWarning?: boolean } const logModulePrefix = `${cyan(`@nolebase/markdown-it-unlazy-img`)}${gray(':')}` @@ -196,7 +200,7 @@ export const UnlazyImages: () => PluginWithOptions = () => const imageRule = md.renderer.rules.image! - md.renderer.rules.image = (tokens, idx, options, env, self) => { + md.renderer.rules.image = (tokens, idx, mdOptions, env, self) => { thumbhashMap = ensureThumbhashMap(thumbhash, thumbhashMap) if (!env.path && !env.relativePath) @@ -206,17 +210,20 @@ export const UnlazyImages: () => PluginWithOptions = () => const imgSrc = token.attrGet('src') if (!imgSrc) - return imageRule(tokens, idx, options, env, self) + return imageRule(tokens, idx, mdOptions, env, self) // Skip external URLs if (EXTERNAL_URL_RE.test(imgSrc)) - return imageRule(tokens, idx, options, env, self) + return imageRule(tokens, idx, mdOptions, env, self) // Skip unsupported image formats - if (['.png', '.jpg', '.jpeg'].every(ext => imgSrc.endsWith(ext))) { - console.warn(`${logModulePrefix} ${yellow('[WARN]')} unsupported image format for ${imgSrc}`) - return imageRule(tokens, idx, options, env, self) + if (!(['.png', '.jpg', '.jpeg'].some(ext => imgSrc.endsWith(ext)))) { + if (options?.logFormatNotSupportedWarning) { + console.warn(`${logModulePrefix} ${yellow('[WARN]')} unsupported image format for ${imgSrc}`) + } + + return imageRule(tokens, idx, mdOptions, env, self) } - let resolvedImgSrc = imgSrc + let resolvedImgSrc = decodeURIComponent(imgSrc) const props: { [name: string]: string | undefined @@ -266,7 +273,7 @@ export const UnlazyImages: () => PluginWithOptions = () => if (!matchedThumbhashData) { // Usually this should not happen console.warn(`${logModulePrefix} ${yellow(`[WARN]`)} thumbhash data not found for ${resolvedImgSrc}`) - return imageRule(tokens, idx, options, env, self) + return imageRule(tokens, idx, mdOptions, env, self) } // Apply all the attributes as