You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
apply-assistant-v3/root/NEUIKit/pages/Friend/add-friend/index.vue

249 lines
6.0 KiB
Vue

<template>
<div style="height:calc(100vh - 10px);padding-top: 10px;" class="g_bg_f_5">
<!-- <NavBar :title="t('addFriendText')" /> -->
<div class="search-input-wrapper">
<Icon
iconClassName="search-icon"
:size="15"
color="#A6ADB6"
type="icon-sousuo"
></Icon>
<input
class="search-input"
type="text"
@input="onInputValueChange"
@confirm="handleSearch"
placeholder-class="placeholder"
confirm-type="search"
:placeholder="t('enterAccount')"
/>
</div>
<Empty
:text="t('noExistUser')"
v-if="searchResState == 'searchEmpty'"
></Empty>
<div class="user-wrapper" v-else-if="searchResState === 'searchResult'">
<Avatar
class="user-avatar"
:account="(userInfo && userInfo.accountId) || ''"
/>
<div class="user-info">
<div class="user-nick">
{{ (userInfo && userInfo.name) || (userInfo && userInfo.accountId) }}
</div>
<div class="user-id">{{ userInfo && userInfo.accountId }}</div>
</div>
<!-- 如果是好友之间去聊天,如果不是好友,添加好友 -->
<button
v-if="relation !== 'stranger'"
class="go-chat-button"
type="primary"
@click="gotoChat"
>
{{ t('chatButtonText') }}
</button>
<button v-else class="go-chat-button" type="primary" @click="applyFriend">
{{ t('addText') }}
</button>
</div>
</div>
</template>
<script lang="ts" setup>
import { onUnmounted, ref } from '../../../utils/transformVue'
import Avatar from '../../../components/Avatar.vue'
import NavBar from '../../../components/NavBar.vue'
import Icon from '../../../components/Icon.vue'
import Empty from '../../../components/Empty.vue'
import { t } from '../../../utils/i18n'
import { customRedirectTo } from '../../../utils/customNavigate'
import { autorun } from 'mobx'
import { deepClone } from '../../../utils'
import type { Relation } from '@xkit-yx/im-store-v2'
import { V2NIMConst } from 'nim-web-sdk-ng/dist/v2/NIM_UNIAPP_SDK'
import { V2NIMUser } from 'nim-web-sdk-ng/dist/v2/NIM_UNIAPP_SDK/V2NIMUserService'
// 搜索结果状态
const searchResState = ref<'beginSearch' | 'searchEmpty' | 'searchResult'>(
'beginSearch'
)
const userInfo = ref<V2NIMUser>()
const relation = ref<Relation>('stranger')
const uninstallRelationWatch = autorun(() => {
// 这行打印用于触发 autorun 执行,不能删除
console.log('friends: ', uni.$UIKitStore.uiStore.friends)
if (userInfo.value?.accountId) {
relation.value = uni.$UIKitStore.uiStore.getRelation(
userInfo.value?.accountId
).relation
}
})
// 搜索好友
const handleSearch = async (event: any) => {
try {
const user: V2NIMUser = deepClone(
await uni.$UIKitStore.userStore.getUserActive(event.detail.value)
)
if (!user) {
searchResState.value = 'searchEmpty'
} else {
userInfo.value = user
relation.value = uni.$UIKitStore.uiStore.getRelation(
user.accountId
).relation
searchResState.value = 'searchResult'
}
} catch (error) {
searchResState.value = 'searchEmpty'
uni.showToast({
title: t('searchFailText'),
icon: 'error',
})
}
}
// 添加好友
const applyFriend = async () => {
const account = userInfo.value?.accountId
if (account) {
try {
await uni.$UIKitStore.friendStore.addFriendActive(account, {
addMode: V2NIMConst.V2NIMFriendAddMode.V2NIM_FRIEND_MODE_TYPE_APPLY,
postscript: '',
})
// 发送申请成功后解除黑名单
await uni.$UIKitStore.relationStore.removeUserFromBlockListActive(account)
uni.showToast({
title: t('applyFriendSuccessText'),
icon: 'success',
})
} catch (error) {
uni.showToast({
title: t('applyFriendFailText'),
icon: 'error',
})
}
}
}
// 去聊天
const gotoChat = async () => {
const to = userInfo.value?.accountId
if (to) {
try {
const conversationId =
uni.$UIKitNIM.V2NIMConversationIdUtil.p2pConversationId(to)
await uni.$UIKitStore.uiStore.selectConversation(conversationId)
customRedirectTo({
url: '/pages/Chat/index',
})
} catch (error) {
uni.showToast({
title: t('gotoChatFailText'),
icon: 'error',
})
}
}
}
const onInputValueChange = (event: any) => {
//删除搜索内容,页面回到最原始状态,搜索结果都清空
if (event.detail.value === '') {
searchResState.value = 'beginSearch'
}
}
onUnmounted(() => {
uninstallRelationWatch()
})
</script>
<style lang="scss" scoped>
@import '../../styles/common.scss';
@import "../../../base.scss";
.search-input-wrapper {
display: flex;
align-items: center;
background-color: #fff;
box-sizing: border-box;
margin: 10px;
padding: 3px;
border-radius: 20px;
margin-top: 0px;
padding-left: 10px;
.search-icon {
color: #a6adb6;
font-family: iconfont;
background-size: 100% 100%;
width: 20px;
height: 20px;
font-size: 20px;
padding-left: 10px;
padding-bottom: 5px;
display: inline-block;
}
.search-input {
display: inline-block;
// background-color: #f2f4f5;
width: 85%;
padding: 4px;
}
.placeholder {
color: #a6adb6;
}
}
.user-wrapper {
display: flex;
background-color: #fff;
justify-content: space-between;
align-items: center;
padding: 20px 10px;
box-sizing: border-box;
.user-avatar {
flex: 0 0 40px;
height: 40px;
border-radius: 50%;
display: inline-block;
}
.user-info {
flex: 1;
margin-left: 15px;
overflow: hidden;
.user-nick {
width: 100%;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
.user-id {
width: 100%;
font-size: 14px;
color: #b5b6b8;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
}
.go-chat-button {
height: 30px;
font-size: 14px;
line-height: 30px;
margin: 5px;
flex: 0 0 70px;
}
}
</style>