连云港陪玩陪聊
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
chunwan/pages/xiaoxi/index.vue

335 lines
8.3 KiB

4 months ago
<template>
<view class="xiaoxi">
<view class="xiaoxi-navbar">
<u-navbar :is-back="false" title="消息">
<view slot="right">
4 months ago
<view class="search" @click="clearInfo()">
4 months ago
<image src="@/static/icon-clear.png"></image>
</view>
</view>
</u-navbar>
</view>
<view class="xiaoxi-tab">
<view class="tab">
<u-tabs :list="list" bg-color="transparent" :is-scroll="false" active-color="#222222" inactive-color="#666666" font-size="30" :active-item-style="activeStyle" bar-height="10" bar-width="60" v-model="current" @change="changeTabs"></u-tabs>
</view>
</view>
<view class="xiaoxi-select" v-if="current == 1">
<view class="select">
<view class="item" @click="selectItem(0)" :class="tabIndex == 0?'item-on':''">好友</view>
<view class="item" @click="selectItem(1)" :class="tabIndex == 1?'item-on':''">关注</view>
<view class="item" @click="selectItem(2)" :class="tabIndex == 2?'item-on':''">粉丝</view>
</view>
</view>
<view class="xiaoxi-list">
3 months ago
<view class="item" v-if="current == 0" @click="openPage('/pages/xiaoxi/dashan')">
3 months ago
<view class="pic"><image src="@/static/dashan.png"><view class="num" v-if="count">{{count<=99?count:"+99"}}</view></image></view>
4 months ago
<view class="info">
3 months ago
<view class="name">搭讪消息</view>
4 months ago
<view class="desc">上学和工作哪个更快来呢上学的...</view>
</view>
</view>
3 months ago
<view class="item" v-if="current == 0" @click="openPage('/pages/xiaoxi/xitong')">
4 months ago
<view class="pic"><image src="@/static/xitong.png"></image></view>
<view class="info">
3 months ago
<view class="name">系统消息</view>
<view class="desc">{{xiaoxiinfo.noticeTitle?xiaoxiinfo.noticeTitle:'暂无消息'}}</view>
4 months ago
</view>
</view>
3 months ago
<view class="item" @click="openPage('/pages/xiaoxi/fangke')">
4 months ago
<view class="pic"><image src="@/static/kan.png"></image></view>
<view class="info">
3 months ago
<view class="name">谁看过我</view>
4 months ago
<view class="desc">对你感兴趣的人一直默默关注你</view>
</view>
3 months ago
</view>
<u-swipe-action v-for="(a,i) in frindList" :index="i" :key="a.userid" @click="click" :options="options">
<view class="item" @click.stop="toChat(a)">
<view class="pic"><image :src="a.faceImage"></image><view class="num" v-if="a.noReadCount">{{a.noReadCount<=99?a.noReadCount:"+99"}}</view></view>
<view class="info">
<view class="name">{{a.nickname}}<text>{{a.createTime}}</text></view>
<view class="desc" v-if="a.type==3">{{a.message}}</view>
<view class="desc" v-if="a.type==1">你有一条新的语音</view>
<view class="desc" v-if="a.type==2">你有一条新的视频</view>
<view class="desc" v-if="a.type==4">你有一张新的图片</view>
<view class="desc" v-if="a.type==5">你有一个新的礼物</view>
3 months ago
<view class="desc" v-if="a.type==6">{{a.message}}</view>
3 months ago
</view>
4 months ago
</view>
3 months ago
</u-swipe-action>
4 months ago
</view>
</view>
</template>
<script>
export default {
data() {
return {
tabIndex: 0,
current: 0,
list:[{'name': '消息'},{'name': '好友'}],
3 months ago
activeStyle:{'fontSize': '35rpx'},
3 months ago
frindList: [],
3 months ago
type: 0,
3 months ago
count: 0,
xiaoxiinfo: {},
options: [
{
text: '删除',
style: {
backgroundColor: '#dd524d'
}
}
]
4 months ago
}
},
3 months ago
onShow() {
3 months ago
this.getList();
this.dashaCount();
3 months ago
this.getXiaoxiList();
if(uni.getStorageSync("isOpen") && uni.getStorageSync("userInfo").id){
this.watchSocket();
}
4 months ago
},
3 months ago
methods: {
3 months ago
watchSocket() {
const that = this;
uni.onSocketMessage(function (res) {
const obj = res.data?JSON.parse(res.data):{}
if(obj.topic == 'message'){
if(obj.type <= 7){
if(uni.getStorageSync("userInfo").id == obj.sellerId){
if(obj.userMsgVoice == 1){
uni.$emit("playAudio")
}
if(obj.userMsgShock == 1){
uni.vibrateLong({
complete: function (res) {
console.log('success',res);
}
});
}
that.getList()
}
}else{
console.log("挂断了")
}
}
});
},
3 months ago
//去聊天
async toChat(a) {
const { code, data } = await this.$api.findZegoToken({
userId: uni.getStorageSync("userInfo").id,
sellerId: a.userid
})
if(code == 200){
uni.setStorageSync("chatToken",data.token);
uni.navigateTo({
3 months ago
url: "/pages/users/chat/index?id="+a.userid+"&roomId="+data.roomId
3 months ago
})
}
},
async click(i){
const { code, data, msg } = await this.$api.cleanOneMsg({
msgId: this.frindList[i].msgId,otherUserStatus: this.frindList[i].otherUserStatus, userId: uni.getStorageSync("userInfo").id
})
if(code == 200){
uni.showToast({
title: "删除成功"
})
this.getList();
}else{
uni.showToast({
title: msg,
icon: "none",
position: "bottom"
})
}
},
async getXiaoxiList() {
const {code,data} = await this.$api.systemNoticeList({
userId: uni.getStorageSync("userInfo").id,
limit: 1,
page: 1
})
if(code == 200){
this.xiaoxiinfo = data.toal == 0?{}:data.list[0]
}
},
async dashaCount() {
const { code, data } = await this.$api.dashaCount({
userId: uni.getStorageSync("userInfo").id
})
if(code == 200){
this.count = data
}
},
3 months ago
async getList() {
const { code, data } = await this.$api.findFrindList({
3 months ago
userId: uni.getStorageSync("userInfo").id,
type: this.type
3 months ago
})
if(code == 200){
this.frindList = data
}
},
openPage(url) {
uni.navigateTo({
url
})
3 months ago
},
//清空
clearInfo() {
const that = this;
4 months ago
uni.showModal({
title: "提示",
content: "确定要清空所有未读消息吗?",
confirmColor: "#000",
3 months ago
async success(res){
if(res.confirm){
const { code, data } = await that.$api.cleanAllMsg({userId: uni.getStorageSync("userInfo").id});
if(code == 200){
uni.showToast({
title: "清除成功"
})
that.getList();
that.dashaCount();
}
4 months ago
}
}
})
},
4 months ago
selectItem(index) {
3 months ago
this.tabIndex = index;
if(index == 0){
this.type = 5
this.getList();
}else if(index == 1){
this.type = 1
this.getList();
}else if(index == 2){
this.type = 3
this.getList();
}
4 months ago
},
changeTabs(index){
3 months ago
this.current = index
if(index==0){
3 months ago
this.type = 0
3 months ago
this.getList();
}else{
this.type = 5
this.getList();
}
4 months ago
},
}
}
</script>
<style scoped lang="scss">
3 months ago
.xiaoxi{
background-color: #fff;
min-height: 100vh;
4 months ago
overflow: hidden;
&-navbar{
image{
width: 45rpx;
height: 45rpx;
margin-right: 30rpx;
}
}
&-tab{
display: flex;
margin-top: 10rpx;
overflow: hidden;
.tab{
width: 250rpx;
}
}
&-select{
padding: 20rpx 25rpx;
overflow: hidden;
.select{
display: flex;
justify-content: center;
border-radius: 20rpx;
border: 1px solid #CCCCCC;
overflow: hidden;
.item{
flex: 1;
text-align: center;
line-height: 80rpx;
border-left: 1px solid #CCCCCC;
&:first-child{
border-left-color: #fff;
}
&-on{
4 months ago
&:first-child{
border-left-color: #000000;
}
4 months ago
background-color: #000000;
color: #FFFFFF;
}
}
}
}
&-list{
padding: 0 25rpx 25rpx;
overflow: hidden;
.item{
display: flex;
align-items: center;
.pic{
width: 90rpx;
height: 90rpx;
margin-right: 20rpx;
position: relative;
.num{
width: 30rpx;
height: 30rpx;
line-height: 30rpx;
background: #FC2C2C;
border-radius: 50%;
font-weight: 500;
font-size: 18rpx;
color: #FFFFFF;
text-align: center;
position: absolute;
right: 0;
top: 0;
z-index: 2;
}
image{
width: 100%;
height: 100%;
border-radius: 50%;
}
}
.info{
padding: 30rpx 0;
flex: 1;
border-bottom: 1px solid #EAEAEA;
.name{
font-weight: 400;
font-size: 30rpx;
color: #222222;
text{
float: right;
font-weight: 400;
font-size: 24rpx;
color: #AAAAAA;
}
}
.desc{
font-weight: 400;
font-size: 24rpx;
color: #AAAAAA;
margin-top: 15rpx;
}
}
}
}
}
</style>