处理按群成员搜索聊天记录页面的接口调用与跳转;处理聊天信息推送的信息接收与跳转

This commit is contained in:
wangyifeng 2025-03-19 19:58:23 +08:00
parent d7c813977d
commit 92a7d74c6c
6 changed files with 150 additions and 27 deletions

View File

@ -14,6 +14,7 @@ import { vLoading } from '@/components/x-loading/index.js'
import messagePopup from '@/components/x-message/useMessagePopup'
import pageAnimation from '@/components/page-animation/index.vue'
import * as plugins from './plugins'
import { useDialogueStore, useTalkStore } from '@/store'
const { showMessage } = messagePopup()
dayjs.locale('zh-cn')
if (import.meta.env.VITE_SHOW_CONSOLE === 'true') {
@ -40,6 +41,40 @@ export function createApp() {
})
},
})
//获取当前聊天页面所在页面并通过当前的receiver_id判断是否要创建本地通知栏消息
window.getCurrentChatRoute = (msg) => {
let pushMsg = JSON.parse(decodeURIComponent(msg))
//当前所在聊天会话的receiver_id
const receiver_id = pushMsg?.payload?.receiver_id
// 获取当前页面路径
const pages = getCurrentPages()
const page = pages[pages.length - 1]
console.log(page.route)
const dialogueStore = useDialogueStore()
console.log(dialogueStore?.talk?.receiver_id)
if (
page?.route === 'pages/dialog/index' &&
receiver_id === dialogueStore?.talk?.receiver_id
) {
return
}
let OAWebView = plus.webview.all()
//all里面第一个是入口webview
OAWebView[0].evalJS(`doCreatePushMessage('${msg}')`)
}
//处理聊天推送弹窗点开
window.openUniPushMsg = (msg) => {
console.log("=====点击通知栏消息")
let pushMsg = JSON.parse(decodeURIComponent(msg))
//由于弹窗前处理了不该弹窗的场景,因此这里弹窗可以一并处理
//也就是都跳转到聊天页面
const talkStore = useTalkStore()
talkStore.toTalk(pushMsg?.payload?.talk_type, pushMsg?.payload?.receiver_id)
}
window.message = ['success', 'error', 'warning'].reduce((acc, type) => {
acc[type] = (message) => {
if (typeof message === 'string') {

View File

@ -381,7 +381,7 @@ const handleClickItem = (item) => {
}
if(props?.manageType === 'searchRecord'){
uni.navigateTo({
url: '/pages/search/searchByCondition/index?condition=member'
url: '/pages/search/searchByCondition/index?condition=member&groupMemberId=' + item.id
})
return
}

View File

@ -561,13 +561,18 @@ const state = ref({
useCustomLoadMore: false, //使
recordDate: '', //
serveFindRecord: [], //
middleMsg: {}, //使
keepDialogInfo: false, //
})
uniOnload(async (options) => {
console.log('onLoad' + options)
console.log('onLoad' + JSON.stringify(options))
if (options.sessionId) {
state.value.sessionId = options.sessionId
}
if (options.keepDialogInfo) {
state.value.keepDialogInfo = options.keepDialogInfo === '1' ? true : false
}
if (options.msgInfo) {
const msgInfo = JSON.parse(decodeURIComponent(options.msgInfo))
queryRecordsByMsgInfo(msgInfo)
@ -974,11 +979,11 @@ const withdrawerConfirm = () => {
//
const canEditRevokedMessage = (item) => {
console.log(item)
// console.log(item)
if (item.is_revoke === 1 && item.msg_type === 1) {
const now = new Date().getTime()
const revokeTime = new Date(item.created_at).getTime()
console.log(now)
// console.log(now)
// 5
return now - revokeTime <= 5 * 60 * 1000
}
@ -1099,6 +1104,8 @@ watch(
state.value.localPageLoadDone = true
return
}
//
if (!state.value.useCustomLoadMore) {
if (
newValue[newValue.length - 1]?.sequence ===
dialogueList?.records?.[0]?.sequence
@ -1109,6 +1116,7 @@ watch(
state.value.localPageLoadDone = false
}
}
}
},
{
deep: true,
@ -1134,7 +1142,13 @@ const onScrollToLower = async () => {
)
console.log(moreRecords)
virtualList.value = moreRecords.concat(tempVirtualList).reverse()
//
const formattedMoreRecords = moreRecords.map((item) => ({
...item,
float: item.user_id === talkParams.uid ? 'right' : 'left',
}))
virtualList.value = formattedMoreRecords.concat(tempVirtualList).reverse()
console.log(virtualList.value)
} else {
@ -1181,7 +1195,16 @@ const onScrollToUpper = async () => {
tempVirtualList[tempVirtualList.length - 1].sequence,
)
console.log(moreRecords)
virtualList.value = tempVirtualList.concat(moreRecords.reverse()).reverse()
//
const formattedMoreRecords = moreRecords.map((item) => ({
...item,
float: item.user_id === talkParams.uid ? 'right' : 'left',
}))
virtualList.value = tempVirtualList
.concat(formattedMoreRecords.reverse())
.reverse()
console.log(virtualList.value)
@ -1309,6 +1332,7 @@ const getMentionSelectLists = (mentionSelectList) => {
//msgsequence
const queryRecordsByMsgInfo = async (msgInfo) => {
console.log(msgInfo)
state.value.middleMsg = msgInfo
const dialogueList = getDialogueList(talkParams.index_name)
const recordIndex = dialogueList?.records?.findIndex(
(record) => record.msg_id === msgInfo.msg_id,
@ -1325,6 +1349,15 @@ const queryRecordsByMsgInfo = async (msgInfo) => {
// console.log(recordIndex-startRecordIndex)
recordsList = dialogueList.records.slice(startRecordIndex, endRecordIndex)
}
// float
recordsList = recordsList.map((item) => {
return {
...item,
float: item.user_id === talkParams.uid ? 'right' : 'left',
}
})
nextTick(() => {
zpagingRef.value.complete(recordsList.reverse())
loadConfig.status = dialogueList?.records?.[0]?.sequence > 1 ? 1 : 2
@ -1376,6 +1409,7 @@ const findTalkRecords = (record, isMiddle, sequence, appointParams) => {
end_time: '',
group_member_user_id: 0, //id
sort_sequence: 'asc',
create_time: state.value.middleMsg.created_at,
}
if (record) {
params = Object.assign({}, params, {
@ -1474,7 +1508,7 @@ const rpxToPx = (rpx) => {
}
onUnmounted(() => {
if (!state.value.recordDate) {
if (!state.value.keepDialogInfo) {
dialogueStore.setDialogue({})
}
clearMultiSelect()

View File

@ -96,6 +96,7 @@ import {
import HighlightText from './highLightText.vue'
import { useI18n } from 'vue-i18n'
import { beautifyTime } from '@/utils/datetime'
import { ChatMsgTypeMapping } from '@/constant/message'
const { t } = useI18n()
const props = defineProps({
searchItem: Object | Number,
@ -175,6 +176,13 @@ const keyMapping = {
name: 'receiver_name',
group_num: 'group_num',
},
search_by_member_condition: {
avatar: 'avatar',
name: 'nickname',
created_at: 'created_at',
msg_type: 'msg_type',
detailKey: 'chatMessageType',
},
}
//key
const getKeyValue = (keys) => {
@ -254,6 +262,12 @@ const resultDetail = computed(() => {
case 'extra':
result_detail = props.searchItem?.extra
break
case 'chatMessageType':
result_detail =
props.searchItem?.msg_type === 1
? props.searchItem?.extra?.content
: ChatMsgTypeMapping[props.searchItem?.msg_type]
break
default:
result_detail = ''
}

View File

@ -9,6 +9,7 @@
:auto="false"
:loading-more-default-as-loading="true"
:inside-more="true"
v-model="state.flatList"
>
<template #top v-if="state.showPageTitle">
<customNavbar :title="state.pageTitle"></customNavbar>
@ -73,11 +74,7 @@
>
<div
class="search-by-condition-input"
v-if="
state.condition === 'file' ||
state.condition === 'link' ||
state.condition === 'member'
"
v-if="state.condition === 'file' || state.condition === 'link'"
>
<customInput
:searchText="state.searchText"
@ -117,11 +114,24 @@
v-for="(item, index) in conditionItem.monthResultList"
:key="index"
:style="{
border: state.condition === 'imgAndVideo' ? '0' : '',
border:
state.condition === 'imgAndVideo' ||
state.condition === 'member'
? '0'
: '',
padding:
state.condition === 'imgAndVideo' ? '0 0 10rpx' : '',
}"
>
<div class="condition-result-member">
<searchItem
@click="toDialogueByMember(item)"
:searchResultKey="'search_by_member_condition'"
:searchItem="item"
:searchText="state.searchText"
:searchRecordDetail="true"
></searchItem>
</div>
<div
class="condition-result-imgAndVideo"
v-if="state.condition === 'imgAndVideo'"
@ -295,6 +305,7 @@ const state = reactive({
cursor: 0, //
msg_type: 0, //
group_member_id: 0, //id
flatList: [], //
})
onLoad((options) => {
@ -302,7 +313,10 @@ onLoad((options) => {
if (options.condition) {
state.condition = options.condition
if (options.condition === 'member') {
// queryAllSearch()
state.showPageTitle = true
state.pageTitle = t('search.condition.member')
state.group_member_id = options.groupMemberId
queryAllSearch()
} else if (options.condition === 'date') {
state.showPageTitle = true
state.pageTitle = t('search.condition.date')
@ -426,6 +440,7 @@ const selectDate = async (e) => {
url:
'/pages/dialog/index?sessionId=' +
sessionId +
'&keepDialogInfo=1' +
'&recordDate=' +
parseTime(e, '{y}-{m}-{d}'),
})
@ -557,18 +572,25 @@ const queryAllSearch = () => {
} else {
noMore = true
}
console.log(dateList)
//
state.searchResultList = dateList
// z-paging
state.flatList = dateList.reduce((acc, group) => {
return acc.concat(group.monthResultList)
}, [])
if (state.cursor === 0) {
state.searchResultList = dateList
zPaging.value?.complete(dateList)
zPaging.value?.complete(state.flatList)
} else {
state.searchResultList = dateList
zPaging.value?.completeByNoMore(dateList, noMore)
zPaging.value?.completeByNoMore(state.flatList, noMore)
}
state.cursor = data?.cursor
} else {
if (state.cursor === 0) {
state.searchResultList = []
state.flatList = []
}
zPaging.value?.complete([])
}
@ -577,6 +599,7 @@ const queryAllSearch = () => {
resp.catch(() => {
if (state.cursor === 0) {
state.searchResultList = []
state.flatList = []
}
zPaging.value?.complete([])
})
@ -637,6 +660,22 @@ const downloadAndOpenFile = (item) => {
})
dtask.start()
}
//
const toDialogueByMember = async (msgInfo) => {
const sessionId = await getSessionId(
dialogueParams.talk_type,
dialogueParams.receiver_id,
)
uni.navigateTo({
url:
'/pages/dialog/index?sessionId=' +
sessionId +
'&keepDialogInfo=1' +
'&msgInfo=' +
encodeURIComponent(JSON.stringify(msgInfo)),
})
}
</script>
<style scoped lang="scss">
.search-by-date {

View File

@ -144,6 +144,7 @@ export const useTalkStore = defineStore('talk', {
ServeCreateTalkList({
talk_type,
receiver_id,
erp_user_id,
}).then(({ code, data, message }) => {
if (code == 200) {