File size: 728 Bytes
697285c
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
10f1462
 
 
 
697285c
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
<script lang="ts">
	import { afterUpdate } from 'svelte';
	import CopyToClipBoardBtn from './CopyToClipBoardBtn.svelte';

	export let code = '';
	export let lang = '';

	$: highlightedCode = '';

	afterUpdate(async () => {
		const { default: hljs } = await import('highlight.js');
		const language = hljs.getLanguage(lang);

		highlightedCode = hljs.highlightAuto(code, language?.aliases).value;
	});
</script>

<div class="group relative rounded-lg my-4">
	<pre class="overflow-auto px-5 py-3.5"><code class="language-{lang}"
			>{@html highlightedCode || code}</code
		></pre>
	<CopyToClipBoardBtn
		classNames="absolute top-2 right-2 invisible opacity-0 group-hover:visible group-hover:opacity-100"
		value={code}
	/>
</div>