61 lines
1.4 KiB
Vue
Raw Normal View History

2022-10-31 11:19:22 +08:00
<script lang="ts" setup>
2024-11-18 19:40:44 +08:00
import type { ListItem } from "./data"
2022-10-28 18:05:16 +08:00
interface Props {
list: ListItem[]
}
const props = defineProps<Props>()
2022-10-31 11:19:22 +08:00
</script>
2022-10-28 18:05:16 +08:00
2022-10-31 11:19:22 +08:00
<template>
<el-empty v-if="props.list.length === 0" />
2024-11-18 19:40:44 +08:00
<el-card v-for="(item, index) in props.list" v-else :key="index" shadow="never" class="card-container">
2022-10-31 11:19:22 +08:00
<template #header>
<div class="card-header">
<div>
<span>
<span class="card-title">{{ item.title }}</span>
<el-tag v-if="item.extra" :type="item.status" effect="plain" size="small">{{ item.extra }}</el-tag>
</span>
2024-11-18 19:40:44 +08:00
<div class="card-time">
{{ item.datetime }}
</div>
2022-10-31 11:19:22 +08:00
</div>
<div v-if="item.avatar" class="card-avatar">
2024-11-18 19:40:44 +08:00
<img :src="item.avatar" width="34">
2022-10-31 11:19:22 +08:00
</div>
</div>
</template>
<div class="card-body">
{{ item.description ?? "No Data" }}
</div>
</el-card>
</template>
<style lang="scss" scoped>
.card-container {
margin-bottom: 10px;
.card-header {
display: flex;
justify-content: space-between;
align-items: center;
.card-title {
font-weight: bold;
margin-right: 10px;
}
.card-time {
font-size: 12px;
2024-03-28 21:34:24 +08:00
color: var(--el-text-color-secondary);
2022-10-31 11:19:22 +08:00
}
.card-avatar {
display: flex;
align-items: center;
}
}
.card-body {
font-size: 12px;
}
}
</style>