shadcn-vue/apps/www/.vitepress/theme/components/Stackblitz.vue
2023-10-21 20:23:59 +08:00

36 lines
886 B
Vue

<script setup lang="ts">
import { onMounted, ref } from 'vue'
import { Icon } from '@iconify/vue'
import { makeStackblitzParams } from '../utils/codeeditor'
import Tooltip from './Tooltip.vue'
import { type Style } from '@/lib/registry/styles'
const props = defineProps<{
name: string
style: Style
}>()
const sources = ref<Record<string, string>>({})
onMounted(() => {
const importName = `../../../src/lib/registry/${props.style}/example/${props.name}.vue?raw`
import(/* @vite-ignore */importName).then(
res => (sources.value['App.vue'] = res.default),
)
})
function handleClick() {
makeStackblitzParams(props.name, props.style, sources.value)
}
</script>
<template>
<div>
<Tooltip :content="`Open ${name} in Stackblitz`">
<button @click="handleClick">
<Icon icon="simple-icons:stackblitz" />
</button>
</Tooltip>
</div>
</template>