Recommend.vue
4.3 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
<template>
<div class="md:mb-12 mb-6">
<div class="flex mb-6">
<div
class="relative bg-black/10 rounded-[50px] p-[3px] overflow-hidden"
slidertab="sliderTab"
>
<ul
class="flex relative whitespace-nowrap overflow-x-auto rounded-[100px] bg-[#5961f9]"
style="flex-wrap: inherit; overflow-y: unset"
role="tablist"
>
<li
class="w-auto h-auto cursor-pointer list-item whitespace-nowrap line-clamp-1"
>
<a
class="h-7 leading-7 px-3 block relative text-white text-center text-sm"
data-toggle="pill"
data-action="load_hot_post"
data-datas='{"data":{"title":"热门工具","type":"sites","order":"views","num":"12","mini":""}}'
>
<i
class="iconfont mr-2 font-bold text-xs"
:class="[`icon-${navIcon}`]"
></i>
{{ navTitle }}
</a>
</li>
</ul>
</div>
</div>
<div
class="grid grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 2xl:grid-cols-5 md:gap-6 gap-4"
>
<div
v-for="(item, index) in recommendList"
:key="index"
class="bg-white dark:bg-[#272929] rounded-xl shadow-md overflow-hidden hover:shadow-lg hover:translate-y-[-6px] transition-all duration-300"
>
<el-popconfirm
v-if="item.isPopup == '1'"
class="box-item"
:title="item.popupContent"
placement="top-start"
icon-color="#5961f9"
width="280"
:icon="Promotion"
confirm-button-text="确认前往"
cancel-button-text="取消"
@confirm="onConfirm(item.id)"
>
<template #reference>
<a
:href="config.public.baseUrl + '/site-details/' + item.id"
target="_blank"
@click.stop="onNuxtLink"
>
<div class="group p-3">
<div class="flex items-start space-x-4">
<img
loading="lazy"
:src="config.public.apiUrl + item.image"
:alt="item.title"
class="w-10 h-10 md:w-14 md:h-14 object-cover rounded-lg"
/>
<div>
<h3
class="font-bold dark:text-[#c6c9cf] md:text-base text-sm line-clamp-1 text-gray-800 transition group-hover:text-[#5961f9] dark:group-hover:text-white"
>
{{ item.title }}
</h3>
<p
class="text-gray-600 dark:text-[#6c757d] text-xs mt-1 md:line-clamp-2 line-clamp-1"
>
{{ item.description }}
</p>
</div>
</div>
</div>
</a>
</template>
</el-popconfirm>
<a
v-else
:href="config.public.baseUrl + '/site-details/' + item.id"
target="_blank"
>
<div class="group p-3">
<div class="flex items-start space-x-4">
<img
loading="lazy"
:src="config.public.apiUrl + item.image"
:alt="item.title"
class="w-10 h-10 md:w-14 md:h-14 object-cover rounded-lg"
/>
<div>
<h3
class="font-bold dark:text-[#c6c9cf] md:text-base text-sm line-clamp-1 text-gray-800 transition group-hover:text-[#5961f9] dark:group-hover:text-white"
>
{{ item.title }}
</h3>
<p
class="text-gray-600 dark:text-[#6c757d] text-xs mt-1 md:line-clamp-2 line-clamp-1"
>
{{ item.description }}
</p>
</div>
</div>
</div>
</a>
</div>
</div>
</div>
</template>
<script lang="ts" setup>
import { Promotion } from "@element-plus/icons-vue";
defineProps<{
recommendList: any[];
navTitle: string;
navIcon: string;
}>();
const config = useRuntimeConfig();
// 阻止默认行为
function onNuxtLink(event: any) {
event.preventDefault();
}
// 点击确认跳转
function onConfirm(id: number) {
window.open(`/site-details/${id}`);
}
</script>