<template>
|
|
<view class="group-item" @click="goToDetail">
|
|
<view class="group-header">
|
|
<view class="group-avatar">
|
|
<image :src="item.image || '/static/image/logo.jpg'" mode="aspectFill"></image>
|
|
</view>
|
|
|
|
<view class="group-info">
|
|
<view class="group-name">{{ item.title || '群组名称' }}</view>
|
|
<view class="group-desc">{{ item.titleText || '群组描述' }}</view>
|
|
<view class="group-stats">
|
|
<text class="member-count">{{ item.num || 0 }}人</text>
|
|
<text v-if="item.classId_dictText" class="separator">·</text>
|
|
<text v-if="item.classId_dictText" class="location">{{ item.classId_dictText }}</text>
|
|
</view>
|
|
</view>
|
|
|
|
<view class="group-status">
|
|
<!-- 如果是自己发布的群组,显示编辑和删除按钮 -->
|
|
<view v-if="isOwner" class="admin-actions" @click.stop="">
|
|
<view class="action-btn edit-btn" @click="editGroup">
|
|
<uv-icon name="edit-pen" size="40rpx" color="#5baaff"></uv-icon>
|
|
</view>
|
|
<view class="action-btn delete-btn" @click="deleteGroup">
|
|
<uv-icon name="trash" size="40rpx" color="#ff4757"></uv-icon>
|
|
</view>
|
|
</view>
|
|
<!-- 否则显示进入按钮 -->
|
|
<view v-else class="join-btn">
|
|
<uv-icon name="arrow-right" size="24rpx" color="#5baaff"></uv-icon>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
import { mapState } from 'vuex'
|
|
|
|
export default {
|
|
props: {
|
|
item: {
|
|
type: Object,
|
|
default: () => ({})
|
|
},
|
|
edit : {
|
|
default : false
|
|
}
|
|
},
|
|
computed: {
|
|
...mapState(['userInfo']),
|
|
|
|
// 判断是否为群主
|
|
isOwner() {
|
|
return this.userInfo && this.item && this.userInfo.id === this.item.userId && this.edit
|
|
}
|
|
},
|
|
methods: {
|
|
// 跳转到群组详情
|
|
goToDetail() {
|
|
this.$utils.navigateTo(`/pages_order/group/groupDetail?id=${this.item.id}`)
|
|
},
|
|
|
|
// 编辑群组
|
|
editGroup() {
|
|
this.$utils.navigateTo(`/pages_order/group/createGroup?id=${this.item.id}`)
|
|
},
|
|
|
|
// 删除群组
|
|
deleteGroup() {
|
|
uni.showModal({
|
|
title: '确认删除',
|
|
content: '确定要删除这个群组吗?删除后无法恢复!',
|
|
confirmText: '删除',
|
|
confirmColor: '#ff4757',
|
|
success: (res) => {
|
|
if (res.confirm) {
|
|
this.confirmDeleteGroup()
|
|
}
|
|
}
|
|
})
|
|
},
|
|
|
|
// 确认删除群组
|
|
confirmDeleteGroup() {
|
|
uni.showLoading({
|
|
title: '删除中...'
|
|
})
|
|
|
|
this.$api('deleteGroup', { id: this.item.id }, res => {
|
|
uni.hideLoading()
|
|
if (res.code === 200) {
|
|
uni.showToast({
|
|
title: '删除成功',
|
|
icon: 'success'
|
|
})
|
|
// 通知父组件刷新列表
|
|
this.$emit('refresh')
|
|
} else {
|
|
uni.showToast({
|
|
title: res.message || '删除失败',
|
|
icon: 'none'
|
|
})
|
|
}
|
|
})
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style scoped lang="scss">
|
|
.group-item {
|
|
margin: 20rpx;
|
|
background-color: #fff;
|
|
padding: 30rpx;
|
|
border-radius: 20rpx;
|
|
box-shadow: 0 2rpx 12rpx rgba(0, 0, 0, 0.1);
|
|
transition: all 0.3s ease;
|
|
|
|
&:active {
|
|
transform: scale(0.98);
|
|
box-shadow: 0 1rpx 8rpx rgba(0, 0, 0, 0.15);
|
|
}
|
|
|
|
.group-header {
|
|
display: flex;
|
|
align-items: center;
|
|
|
|
.group-avatar {
|
|
width: 120rpx;
|
|
height: 120rpx;
|
|
margin-right: 20rpx;
|
|
border-radius: 20rpx;
|
|
overflow: hidden;
|
|
|
|
image {
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
}
|
|
|
|
.group-info {
|
|
flex: 1;
|
|
min-width: 0; // 防止文本溢出
|
|
|
|
.group-name {
|
|
font-size: 32rpx;
|
|
font-weight: bold;
|
|
color: #333;
|
|
margin-bottom: 8rpx;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.group-desc {
|
|
font-size: 26rpx;
|
|
color: #666;
|
|
margin-bottom: 8rpx;
|
|
line-height: 1.4;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.group-stats {
|
|
display: flex;
|
|
align-items: center;
|
|
font-size: 24rpx;
|
|
color: #999;
|
|
|
|
.member-count {
|
|
background: #f0f8ff;
|
|
color: #5baaff;
|
|
padding: 4rpx 12rpx;
|
|
border-radius: 12rpx;
|
|
font-size: 22rpx;
|
|
}
|
|
|
|
.separator {
|
|
margin: 0 8rpx;
|
|
color: #ddd;
|
|
}
|
|
|
|
.location {
|
|
color: #999;
|
|
font-size: 22rpx;
|
|
}
|
|
}
|
|
}
|
|
|
|
.group-status {
|
|
display: flex;
|
|
align-items: center;
|
|
|
|
.admin-actions {
|
|
display: flex;
|
|
gap: 16rpx;
|
|
|
|
.action-btn {
|
|
width: 44rpx;
|
|
height: 44rpx;
|
|
border-radius: 50%;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
transition: all 0.3s ease;
|
|
|
|
&.edit-btn {
|
|
background-color: rgba(91, 170, 255, 0.1);
|
|
|
|
&:active {
|
|
background-color: rgba(91, 170, 255, 0.2);
|
|
transform: scale(0.9);
|
|
}
|
|
}
|
|
|
|
&.delete-btn {
|
|
background-color: rgba(255, 71, 87, 0.1);
|
|
|
|
&:active {
|
|
background-color: rgba(255, 71, 87, 0.2);
|
|
transform: scale(0.9);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
.join-btn {
|
|
width: 60rpx;
|
|
height: 60rpx;
|
|
background-color: #f8f9fa;
|
|
border-radius: 50%;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
transition: all 0.3s ease;
|
|
|
|
&:active {
|
|
background-color: #e9ecef;
|
|
transform: scale(0.9);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</style>
|