2022-08-17 15:09:43 +02:00
|
|
|
<template>
|
|
|
|
<n-card class="colored-card">
|
|
|
|
<n-space justify="space-between" align="center">
|
|
|
|
<n-icon class="icon" size="40" :component="icon" />
|
|
|
|
</n-space>
|
|
|
|
<n-h3 class="title">
|
|
|
|
<n-ellipsis>{{ title }}</n-ellipsis>
|
|
|
|
</n-h3>
|
|
|
|
|
|
|
|
<div class="description">
|
|
|
|
<n-ellipsis :line-clamp="2" :tooltip="false">
|
|
|
|
<slot />
|
|
|
|
</n-ellipsis>
|
|
|
|
</div>
|
|
|
|
</n-card>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script setup lang="ts">
|
|
|
|
import { toRefs, type Component } from 'vue';
|
|
|
|
|
|
|
|
const props = defineProps<{ icon: Component; title: string }>();
|
|
|
|
const { icon, title } = toRefs(props);
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style lang="less" scoped>
|
|
|
|
.colored-card {
|
|
|
|
background: rgb(37, 99, 108);
|
|
|
|
background: linear-gradient(48deg, rgba(37, 99, 108, 1) 0%, rgba(59, 149, 111, 1) 60%, rgba(20, 160, 88, 1) 100%);
|
|
|
|
color: #fff;
|
2022-08-17 17:33:44 +02:00
|
|
|
border: none;
|
2022-08-17 15:09:43 +02:00
|
|
|
|
|
|
|
.icon {
|
|
|
|
opacity: 0.7;
|
|
|
|
}
|
|
|
|
|
|
|
|
.title {
|
|
|
|
color: #fff;
|
|
|
|
|
|
|
|
margin: 5px 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
.description {
|
|
|
|
opacity: 0.8;
|
|
|
|
|
|
|
|
margin: 5px 0;
|
|
|
|
|
|
|
|
::v-deep(a) {
|
|
|
|
color: inherit;
|
|
|
|
text-decoration: underline;
|
|
|
|
font-weight: bold;
|
2022-08-18 11:09:25 +02:00
|
|
|
transition: color ease 0.2s;
|
2022-08-17 15:09:43 +02:00
|
|
|
|
|
|
|
&:hover {
|
|
|
|
color: rgb(20, 20, 20);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</style>
|