Merge remote-tracking branch 'origin/dev-hjf'

This commit is contained in:
huxuejian 2026-02-06 17:20:49 +08:00
commit 4079f52ed6
3 changed files with 86 additions and 47 deletions

View File

@ -1,22 +1,14 @@
<template> <template>
<view class="bg-gray-100 min-h-screen"> <view class="bg-gray-100 min-h-screen">
<!-- Category Tabs --> <!-- Category Tabs -->
<scroll-view <scroll-view scroll-x class="bg-white whitespace-nowrap px-15 py-10 sticky top-0 z-10 w-full"
scroll-x :show-scrollbar="false">
class="bg-white whitespace-nowrap px-15 py-10 sticky top-0 z-10 w-full" <view v-for="(tab, index) in tabs" :key="index"
:show-scrollbar="false" class="inline-block px-15 py-5 mr-10 text-sm rounded-full border transition-colors" :class="[
>
<view
v-for="(tab, index) in tabs"
:key="index"
class="inline-block px-15 py-5 mr-10 text-sm rounded-full border transition-colors"
:class="[
activeCateId === tab.value activeCateId === tab.value
? 'bg-orange-100 text-orange-500 border-orange-500' ? 'bg-orange-100 text-orange-500 border-orange-500'
: 'bg-white text-gray-600 border-gray-200', : 'bg-white text-gray-600 border-gray-200',
]" ]" @click="selectCate(tab.value)">
@click="selectCate(tab.value)"
>
{{ tab.name }} {{ tab.name }}
</view> </view>
</scroll-view> </scroll-view>
@ -32,18 +24,9 @@
</view> </view>
<view v-else class="p-15"> <view v-else class="p-15">
<view <view v-for="(item, index) in list" :key="item._id" class="article-card flex"
v-for="(item, index) in list" :class="{ 'mb-15': index < list.length - 1 }" @click="goToDetail(item)">
:key="item._id" <image class="flex-shrink-0 cover" :src="item.cover || '/static/home/health-education.png'" mode="aspectFill" />
class="article-card flex"
:class="{ 'mb-15': index < list.length - 1 }"
@click="goToDetail(item)"
>
<image
class="flex-shrink-0 cover"
:src="item.cover || '/static/home/health-education.png'"
mode="aspectFill"
/>
<view class="w-0 flex-grow"> <view class="w-0 flex-grow">
<view class="article-title truncate mb-10"> <view class="article-title truncate mb-10">
{{ item.title || "宣教文章" }} {{ item.title || "宣教文章" }}
@ -161,9 +144,11 @@ onReachBottom(() => {
.min-h-screen { .min-h-screen {
min-height: 100vh; min-height: 100vh;
} }
.bg-gray-100 { .bg-gray-100 {
background-color: #f7f8fa; background-color: #f7f8fa;
} }
.bg-white { .bg-white {
background-color: #ffffff; background-color: #ffffff;
} }
@ -171,18 +156,22 @@ onReachBottom(() => {
.p-15 { .p-15 {
padding: 30rpx; padding: 30rpx;
} }
.px-15 { .px-15 {
padding-left: 30rpx; padding-left: 30rpx;
padding-right: 30rpx; padding-right: 30rpx;
} }
.py-10 { .py-10 {
padding-top: 20rpx; padding-top: 20rpx;
padding-bottom: 20rpx; padding-bottom: 20rpx;
} }
.py-5 { .py-5 {
padding-top: 10rpx; padding-top: 10rpx;
padding-bottom: 10rpx; padding-bottom: 10rpx;
} }
.px-5 { .px-5 {
padding-left: 10rpx; padding-left: 10rpx;
padding-right: 10rpx; padding-right: 10rpx;
@ -191,21 +180,27 @@ onReachBottom(() => {
.mr-10 { .mr-10 {
margin-right: 20rpx; margin-right: 20rpx;
} }
.mr-5 { .mr-5 {
margin-right: 10rpx; margin-right: 10rpx;
} }
.ml-2 { .ml-2 {
margin-left: 10rpx; margin-left: 10rpx;
} }
.mr-2 { .mr-2 {
margin-right: 10rpx; margin-right: 10rpx;
} }
.mb-15 { .mb-15 {
margin-bottom: 20rpx; margin-bottom: 20rpx;
} }
.mb-10 { .mb-10 {
margin-bottom: 20rpx; margin-bottom: 20rpx;
} }
.mt-1 { .mt-1 {
margin-top: 6rpx; margin-top: 6rpx;
} }
@ -213,27 +208,35 @@ onReachBottom(() => {
.flex { .flex {
display: flex; display: flex;
} }
.items-start { .items-start {
align-items: flex-start; align-items: flex-start;
} }
.items-center { .items-center {
align-items: center; align-items: center;
} }
.justify-between { .justify-between {
justify-content: space-between; justify-content: space-between;
} }
.flex-1 { .flex-1 {
flex: 1; flex: 1;
} }
.flex-grow { .flex-grow {
flex-grow: 1; flex-grow: 1;
} }
.flex-shrink-0 { .flex-shrink-0 {
flex-shrink: 0; flex-shrink: 0;
} }
.w-0 { .w-0 {
width: 0; width: 0;
} }
.relative { .relative {
position: relative; position: relative;
} }
@ -242,12 +245,15 @@ onReachBottom(() => {
border-width: 1px; border-width: 1px;
border-style: solid; border-style: solid;
} }
.rounded-full { .rounded-full {
border-radius: 9999px; border-radius: 9999px;
} }
.rounded { .rounded {
border-radius: 8rpx; border-radius: 8rpx;
} }
.rounded-lg { .rounded-lg {
border-radius: 12rpx; border-radius: 12rpx;
} }
@ -259,15 +265,19 @@ onReachBottom(() => {
.text-xs { .text-xs {
font-size: 22rpx; font-size: 22rpx;
} }
.text-sm { .text-sm {
font-size: 28rpx; font-size: 28rpx;
} }
.text-base { .text-base {
font-size: 32rpx; font-size: 32rpx;
} }
.font-bold { .font-bold {
font-weight: 600; font-weight: 600;
} }
.leading-normal { .leading-normal {
line-height: 1.4; line-height: 1.4;
} }
@ -275,9 +285,11 @@ onReachBottom(() => {
.text-orange-500 { .text-orange-500 {
color: #f29e38; color: #f29e38;
} }
.bg-orange-100 { .bg-orange-100 {
background-color: #fff8eb; background-color: #fff8eb;
} }
.border-orange-500 { .border-orange-500 {
border-color: #f29e38; border-color: #f29e38;
} }
@ -285,12 +297,15 @@ onReachBottom(() => {
.text-gray-600 { .text-gray-600 {
color: #333333; color: #333333;
} }
.text-gray-400 { .text-gray-400 {
color: #999999; color: #999999;
} }
.text-gray-800 { .text-gray-800 {
color: #1a1a1a; color: #1a1a1a;
} }
.border-gray-200 { .border-gray-200 {
border-color: #e5e5e5; border-color: #e5e5e5;
} }
@ -298,6 +313,7 @@ onReachBottom(() => {
.text-green-600 { .text-green-600 {
color: #4b8d5f; color: #4b8d5f;
} }
.border-green-600 { .border-green-600 {
border-color: #4b8d5f; border-color: #4b8d5f;
} }
@ -305,18 +321,23 @@ onReachBottom(() => {
.sticky { .sticky {
position: sticky; position: sticky;
} }
.top-0 { .top-0 {
top: 0; top: 0;
} }
.z-10 { .z-10 {
z-index: 10; z-index: 10;
} }
.w-full { .w-full {
width: 100%; width: 100%;
} }
.whitespace-nowrap { .whitespace-nowrap {
white-space: nowrap; white-space: nowrap;
} }
.inline-block { .inline-block {
display: inline-block; display: inline-block;
} }
@ -339,7 +360,7 @@ onReachBottom(() => {
transition: all 0.3s; transition: all 0.3s;
min-height: 188rpx; min-height: 188rpx;
padding: 20rpx; padding: 20rpx;
align-items: flex-start; align-items: center;
width: 100%; width: 100%;
box-sizing: border-box; box-sizing: border-box;
} }
@ -350,8 +371,8 @@ onReachBottom(() => {
} }
.cover { .cover {
width: 272rpx; width: 200rpx;
height: 151rpx; height: 112rpx;
border-radius: 12rpx; border-radius: 12rpx;
margin-right: 20rpx; margin-right: 20rpx;
object-fit: cover; object-fit: cover;

View File

@ -9,18 +9,10 @@
</view> </view>
<view class="mt-10"> <view class="mt-10">
<view <view v-for="(article, index) in articles" :key="article._id" class="article-card flex"
v-for="(article, index) in articles" :class="{ 'mb-15': index < articles.length - 1 }" @click="goToDetail(article)">
:key="article._id" <image class="flex-shrink-0 cover" :src="article.cover || '/static/home/health-education.png'"
class="article-card flex" mode="aspectFill" />
:class="{ 'mb-15': index < articles.length - 1 }"
@click="goToDetail(article)"
>
<image
class="flex-shrink-0 cover"
:src="article.cover || '/static/home/health-education.png'"
mode="aspectFill"
/>
<view class="w-0 flex-grow"> <view class="w-0 flex-grow">
<view class="article-title truncate mb-10"> <view class="article-title truncate mb-10">
{{ article.title }} {{ article.title }}
@ -134,7 +126,7 @@ watch(
transition: all 0.3s; transition: all 0.3s;
min-height: 188rpx; min-height: 188rpx;
padding: 20rpx; padding: 20rpx;
align-items: flex-start; align-items: center;
width: 100%; width: 100%;
box-sizing: border-box; box-sizing: border-box;
} }
@ -145,8 +137,8 @@ watch(
} }
.cover { .cover {
width: 272rpx; width: 200rpx;
height: 151rpx; height: 112rpx;
border-radius: 12rpx; border-radius: 12rpx;
margin-right: 20rpx; margin-right: 20rpx;
object-fit: cover; object-fit: cover;

View File

@ -54,6 +54,8 @@
</view> </view>
<view v-if="qrcode && qrcode.guide" class="team-introduce-wrapper"> <view v-if="qrcode && qrcode.guide" class="team-introduce-wrapper">
<view class="team-introduce flex items-center"> <view class="team-introduce flex items-center">
<!-- 边框层 -->
<view class="team-introduce-border"></view>
<!-- 顶部小三角形 --> <!-- 顶部小三角形 -->
<view class="triangle-wrapper"> <view class="triangle-wrapper">
<view class="team-triangle"></view> <view class="team-triangle"></view>
@ -190,11 +192,32 @@ onMounted(() => {
overflow: visible; overflow: visible;
} }
.team-introduce-border {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
border: 1px solid #fff;
border-radius: 16rpx;
pointer-events: none;
-webkit-mask-image: linear-gradient(to right, #000 0, #000 50rpx, transparent 50rpx, transparent 70rpx, #000 70rpx),
linear-gradient(#000, #000);
mask-image: linear-gradient(to right, #000 0, #000 50rpx, transparent 50rpx, transparent 70rpx, #000 70rpx),
linear-gradient(#000, #000);
-webkit-mask-size: 100% 1px, 100% 100%;
mask-size: 100% 1px, 100% 100%;
-webkit-mask-position: 0 0, 0 1px;
mask-position: 0 0, 0 1px;
-webkit-mask-repeat: no-repeat;
mask-repeat: no-repeat;
}
.triangle-wrapper { .triangle-wrapper {
position: absolute; position: absolute;
top: -12rpx; top: -12rpx;
left: 60rpx; left: 60rpx;
width: 24rpx; width: 32rpx;
height: 12rpx; height: 12rpx;
overflow: hidden; overflow: hidden;
z-index: 10; z-index: 10;
@ -204,13 +227,16 @@ onMounted(() => {
.team-triangle { .team-triangle {
position: absolute; position: absolute;
left: 50%; left: 50%;
bottom: -10rpx; bottom: -9rpx;
width: 16rpx; width: 16rpx;
height: 16rpx; height: 16rpx;
background: linear-gradient(186deg, background: linear-gradient(186deg,
rgba(255, 255, 255, 0.4) 13.34%, rgba(255, 255, 255, 0.4) 13.34%,
rgba(255, 255, 255, 0.6) 99.17%); rgba(255, 255, 255, 0.6) 99.17%);
transform: translateX(-50%) rotate(45deg); transform: translateX(-50%) rotate(45deg);
border-top: 1px solid #fff;
border-left: 1px solid #fff;
box-sizing: border-box;
} }
.introduce-text { .introduce-text {