Files
estel_docs/app/components/content/SmartIcon.vue
2025-07-27 17:24:02 +08:00

33 lines
755 B
Vue

<template>
<!-- Iconify Icons -->
<Icon v-if="checkIcon(name)" :name :size />
<!-- Emojis -->
<span
v-else-if="/(\u00a9|\u00ae|[\u2000-\u3300]|\ud83c[\ud000-\udfff]|\ud83d[\ud000-\udfff]|\ud83e[\ud000-\udfff])/g.test(name)"
:style="`font-size: ${size}px;`"
>{{ name }}</span>
<!-- Link -->
<NuxtImg
v-else
:src="name"
:style="`width: ${size}px; height: ${size}px;`"
class="inline"
/>
</template>
<script setup lang="ts">
import { stringToIcon, validateIconName } from '@iconify/utils';
const { size = 16 } = defineProps<{
name: string;
size?: number;
}>();
function checkIcon(name: string): boolean {
if (name.includes('http'))
return false;
return validateIconName(stringToIcon(name));
}
</script>