mirror of
https://github.com/nuxt/nuxt.git
synced 2025-01-19 01:45:53 +00:00
71 lines
1.4 KiB
Vue
71 lines
1.4 KiB
Vue
|
<template>
|
||
|
<component
|
||
|
:is="component"
|
||
|
:to="to"
|
||
|
:aria-label="title"
|
||
|
class="flex flex-col items-center transition duration-200 p-6 rounded-md"
|
||
|
:class="hoverClass"
|
||
|
>
|
||
|
<InjectComponent
|
||
|
:component="image"
|
||
|
class="mb-4 transition duration-200 text-primary group-hover:text-primary-400"
|
||
|
:class="imageClass"
|
||
|
>
|
||
|
<img loading="lazy" :src="image" :alt="`A ${title} image`">
|
||
|
</InjectComponent>
|
||
|
<h3 class="mb-1 text-center text-body-lg lg:text-body-xl font-bold">
|
||
|
{{ title }}
|
||
|
</h3>
|
||
|
<p class="text-center text-sm lg:text-base mb-4">
|
||
|
{{ description }}
|
||
|
</p>
|
||
|
</component>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
import { defineComponent, computed } from '@nuxtjs/composition-api'
|
||
|
|
||
|
export default defineComponent({
|
||
|
props: {
|
||
|
image: {
|
||
|
type: String,
|
||
|
default: ''
|
||
|
},
|
||
|
imageClass: {
|
||
|
type: String,
|
||
|
default: ''
|
||
|
},
|
||
|
hoverClass: {
|
||
|
type: String,
|
||
|
default: ''
|
||
|
},
|
||
|
title: {
|
||
|
type: String,
|
||
|
default: ''
|
||
|
},
|
||
|
description: {
|
||
|
type: String,
|
||
|
default: ''
|
||
|
},
|
||
|
to: {
|
||
|
type: String,
|
||
|
default: ''
|
||
|
},
|
||
|
linkName: {
|
||
|
type: String,
|
||
|
default: ''
|
||
|
}
|
||
|
},
|
||
|
setup (props) {
|
||
|
const component = computed(() => {
|
||
|
if (props.to && !props.linkName) {
|
||
|
return 'Link'
|
||
|
}
|
||
|
return 'div'
|
||
|
})
|
||
|
|
||
|
return { component }
|
||
|
}
|
||
|
})
|
||
|
</script>
|