fix: render code block without language (#276)
This commit is contained in:
		
							parent
							
								
									18d5fd4804
								
							
						
					
					
						commit
						0f06653636
					
				
					 4 changed files with 32 additions and 7 deletions
				
			
		|  | @ -1,7 +1,7 @@ | |||
| <script setup lang="ts"> | ||||
| const props = defineProps<{ | ||||
|   code: string | ||||
|   lang: string | ||||
|   lang?: string | ||||
| }>() | ||||
| 
 | ||||
| const raw = $computed(() => decodeURIComponent(props.code).replace(/'/g, '\'')) | ||||
|  | @ -13,7 +13,7 @@ const langMap: Record<string, string> = { | |||
| } | ||||
| 
 | ||||
| const highlighted = computed(() => { | ||||
|   return props.lang ? highlightCode(raw, langMap[props.lang] || props.lang as any) : raw | ||||
|   return props.lang ? highlightCode(raw, (langMap[props.lang] || props.lang) as any) : raw | ||||
| }) | ||||
| </script> | ||||
| 
 | ||||
|  |  | |||
|  | @ -38,7 +38,7 @@ function handleCodeBlock(el: Element) { | |||
|     const codeEl = el.childNodes[0] as Element | ||||
|     const classes = codeEl.attrs.find(i => i.name === 'class')?.value | ||||
|     const lang = classes?.split(/\s/g).find(i => i.startsWith('language-'))?.replace('language-', '') | ||||
|     const code = treeToText(codeEl.childNodes[0]) | ||||
|     const code = codeEl.childNodes[0] ? treeToText(codeEl.childNodes[0]) : '' | ||||
|     return h(ContentCode, { lang, code: encodeURIComponent(code) }) | ||||
|   } | ||||
| } | ||||
|  | @ -61,11 +61,10 @@ export function parseMastodonHTML(html: string, customEmojis: Record<string, Emo | |||
|       return `:${name}:` | ||||
|     }) | ||||
|     // handle code blocks
 | ||||
|     .replace(/>(```|~~~)([\s\S]+?)\1/g, (_1, _2, raw) => { | ||||
|       const plain = htmlToText(raw) | ||||
|       const [lang, ...code] = plain.split('\n') | ||||
|     .replace(/>(```|~~~)(\w*)([\s\S]+?)\1/g, (_1, _2, lang, raw) => { | ||||
|       const code = htmlToText(raw) | ||||
|       const classes = lang ? ` class="language-${lang}"` : '' | ||||
|       return `><pre><code${classes}>${code.join('\n')}</code></pre>` | ||||
|       return `><pre><code${classes}>${code}</code></pre>` | ||||
|     }) | ||||
| 
 | ||||
|   const tree = parseFragment(processed) | ||||
|  |  | |||
|  | @ -25,6 +25,22 @@ exports[`content-rich > code frame 2 1`] = ` | |||
| " | ||||
| `; | ||||
| 
 | ||||
| exports[`content-rich > code frame empty 1`] = ` | ||||
| "<p></p> | ||||
| <pre></pre> | ||||
| <br /> | ||||
| <p></p> | ||||
| " | ||||
| `; | ||||
| 
 | ||||
| exports[`content-rich > code frame no lang 1`] = ` | ||||
| "<p></p> | ||||
| <pre>hello world</pre> | ||||
| <br />no lang | ||||
| <p></p> | ||||
| " | ||||
| `; | ||||
| 
 | ||||
| exports[`content-rich > custom emoji 1`] = ` | ||||
| "Daniel Roe | ||||
| <img | ||||
|  |  | |||
|  | @ -39,6 +39,16 @@ describe('content-rich', () => { | |||
|     const { formatted } = await render('<p><span class=\"h-card\"><a href=\"https://mas.to/@antfu\" class=\"u-url mention\">@<span>antfu</span></a></span> Testing<br />```ts<br />const a = hello<br />```</p>') | ||||
|     expect(formatted).toMatchSnapshot() | ||||
|   }) | ||||
| 
 | ||||
|   it('code frame no lang', async () => { | ||||
|     const { formatted } = await render('<p>```<br />hello world<br />```<br />no lang</p>') | ||||
|     expect(formatted).toMatchSnapshot() | ||||
|   }) | ||||
| 
 | ||||
|   it('code frame empty', async () => { | ||||
|     const { formatted } = await render('<p>```<br /><br />```<br /></p>') | ||||
|     expect(formatted).toMatchSnapshot() | ||||
|   }) | ||||
| }) | ||||
| 
 | ||||
| async function render(content: string, emojis?: Record<string, Emoji>) { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue