Merge branch 'wyfMain-dev'
Some checks are pending
Check / lint (push) Waiting to run
Check / typecheck (push) Waiting to run
Check / build (build, 18.x, ubuntu-latest) (push) Waiting to run
Check / build (build, 18.x, windows-latest) (push) Waiting to run
Check / build (build:app, 18.x, ubuntu-latest) (push) Waiting to run
Check / build (build:app, 18.x, windows-latest) (push) Waiting to run
Check / build (build:mp-weixin, 18.x, ubuntu-latest) (push) Waiting to run
Check / build (build:mp-weixin, 18.x, windows-latest) (push) Waiting to run
Some checks are pending
Check / lint (push) Waiting to run
Check / typecheck (push) Waiting to run
Check / build (build, 18.x, ubuntu-latest) (push) Waiting to run
Check / build (build, 18.x, windows-latest) (push) Waiting to run
Check / build (build:app, 18.x, ubuntu-latest) (push) Waiting to run
Check / build (build:app, 18.x, windows-latest) (push) Waiting to run
Check / build (build:mp-weixin, 18.x, ubuntu-latest) (push) Waiting to run
Check / build (build:mp-weixin, 18.x, windows-latest) (push) Waiting to run
This commit is contained in:
commit
9e8e3aeba3
2
components.d.ts
vendored
2
components.d.ts
vendored
@ -30,6 +30,8 @@ declare module 'vue' {
|
|||||||
LoginMessage: typeof import('./src/components/talk/message/LoginMessage.vue')['default']
|
LoginMessage: typeof import('./src/components/talk/message/LoginMessage.vue')['default']
|
||||||
Message: typeof import('./src/components/x-message/message/index.vue')['default']
|
Message: typeof import('./src/components/x-message/message/index.vue')['default']
|
||||||
MixedMessage: typeof import('./src/components/talk/message/MixedMessage.vue')['default']
|
MixedMessage: typeof import('./src/components/talk/message/MixedMessage.vue')['default']
|
||||||
|
NButton: typeof import('naive-ui')['NButton']
|
||||||
|
NIcon: typeof import('naive-ui')['NIcon']
|
||||||
PageAnimation: typeof import('./src/components/page-animation/index.vue')['default']
|
PageAnimation: typeof import('./src/components/page-animation/index.vue')['default']
|
||||||
RevokeMessage: typeof import('./src/components/talk/message/RevokeMessage.vue')['default']
|
RevokeMessage: typeof import('./src/components/talk/message/RevokeMessage.vue')['default']
|
||||||
RouterLink: typeof import('vue-router')['RouterLink']
|
RouterLink: typeof import('vue-router')['RouterLink']
|
||||||
|
36
src/main.js
36
src/main.js
@ -14,6 +14,7 @@ import { vLoading } from '@/components/x-loading/index.js'
|
|||||||
import messagePopup from '@/components/x-message/useMessagePopup'
|
import messagePopup from '@/components/x-message/useMessagePopup'
|
||||||
import pageAnimation from '@/components/page-animation/index.vue'
|
import pageAnimation from '@/components/page-animation/index.vue'
|
||||||
import * as plugins from './plugins'
|
import * as plugins from './plugins'
|
||||||
|
import { useDialogueStore, useTalkStore } from '@/store'
|
||||||
const { showMessage } = messagePopup()
|
const { showMessage } = messagePopup()
|
||||||
dayjs.locale('zh-cn')
|
dayjs.locale('zh-cn')
|
||||||
if (import.meta.env.VITE_SHOW_CONSOLE === 'true') {
|
if (import.meta.env.VITE_SHOW_CONSOLE === 'true') {
|
||||||
@ -40,6 +41,41 @@ 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))
|
||||||
|
console.log("=====pushMsg",pushMsg)
|
||||||
|
//由于弹窗前处理了不该弹窗的场景,因此这里弹窗可以一并处理
|
||||||
|
//也就是都跳转到聊天页面
|
||||||
|
const talkStore = useTalkStore()
|
||||||
|
talkStore.toTalk(pushMsg?.payload?.talk_type, pushMsg?.payload?.receiver_id)
|
||||||
|
}
|
||||||
|
|
||||||
window.message = ['success', 'error', 'warning'].reduce((acc, type) => {
|
window.message = ['success', 'error', 'warning'].reduce((acc, type) => {
|
||||||
acc[type] = (message) => {
|
acc[type] = (message) => {
|
||||||
if (typeof message === 'string') {
|
if (typeof message === 'string') {
|
||||||
|
@ -381,7 +381,7 @@ const handleClickItem = (item) => {
|
|||||||
}
|
}
|
||||||
if(props?.manageType === 'searchRecord'){
|
if(props?.manageType === 'searchRecord'){
|
||||||
uni.navigateTo({
|
uni.navigateTo({
|
||||||
url: '/pages/search/searchByCondition/index?condition=member'
|
url: '/pages/search/searchByCondition/index?condition=member&groupMemberId=' + item.id
|
||||||
})
|
})
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -504,8 +504,7 @@ const toSearchByConditionPage = (flag) => {
|
|||||||
condition = 'link'
|
condition = 'link'
|
||||||
}
|
}
|
||||||
uni.navigateTo({
|
uni.navigateTo({
|
||||||
url:
|
url: '/pages/search/searchByCondition/index?condition=' + condition,
|
||||||
'/pages/search/searchByCondition/index?condition=' + condition
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -644,7 +643,8 @@ const toSearchPage = () => {
|
|||||||
'/pages/search/moreResult/moreResultDetail?talk_type=' +
|
'/pages/search/moreResult/moreResultDetail?talk_type=' +
|
||||||
dialogueParams.type +
|
dialogueParams.type +
|
||||||
'&receiver_id=' +
|
'&receiver_id=' +
|
||||||
dialogueParams.receiver_id,
|
dialogueParams.receiver_id +
|
||||||
|
'&hideFirstRecord=1',
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
@ -561,13 +561,18 @@ const state = ref({
|
|||||||
useCustomLoadMore: false, //是否使用自定义加载更多事件(下拉刷新、上拉加载)
|
useCustomLoadMore: false, //是否使用自定义加载更多事件(下拉刷新、上拉加载)
|
||||||
recordDate: "", //按日期查询聊天记录的开始日期
|
recordDate: "", //按日期查询聊天记录的开始日期
|
||||||
serveFindRecord: [], //调用接口查找到的聊天记录
|
serveFindRecord: [], //调用接口查找到的聊天记录
|
||||||
});
|
middleMsg: {}, //缓存中没有时,调用接口初次使用的依据记录
|
||||||
|
keepDialogInfo: false, //是否保存会话信息
|
||||||
|
})
|
||||||
|
|
||||||
uniOnload(async (options) => {
|
uniOnload(async (options) => {
|
||||||
console.log("onLoad" + options);
|
console.log('onLoad' + JSON.stringify(options))
|
||||||
if (options.sessionId) {
|
if (options.sessionId) {
|
||||||
state.value.sessionId = options.sessionId;
|
state.value.sessionId = options.sessionId;
|
||||||
}
|
}
|
||||||
|
if (options.keepDialogInfo) {
|
||||||
|
state.value.keepDialogInfo = options.keepDialogInfo === '1' ? true : false
|
||||||
|
}
|
||||||
if (options.msgInfo) {
|
if (options.msgInfo) {
|
||||||
const msgInfo = JSON.parse(decodeURIComponent(options.msgInfo));
|
const msgInfo = JSON.parse(decodeURIComponent(options.msgInfo));
|
||||||
queryRecordsByMsgInfo(msgInfo);
|
queryRecordsByMsgInfo(msgInfo);
|
||||||
@ -970,11 +975,11 @@ const withdrawerConfirm = () => {
|
|||||||
|
|
||||||
// 添加检查是否可以重新编辑撤回消息的函数
|
// 添加检查是否可以重新编辑撤回消息的函数
|
||||||
const canEditRevokedMessage = (item) => {
|
const canEditRevokedMessage = (item) => {
|
||||||
console.log(item);
|
// console.log(item)
|
||||||
if (item.is_revoke === 1 && item.msg_type === 1) {
|
if (item.is_revoke === 1 && item.msg_type === 1) {
|
||||||
const now = new Date().getTime();
|
const now = new Date().getTime()
|
||||||
const revokeTime = new Date(item.created_at).getTime();
|
const revokeTime = new Date(item.created_at).getTime()
|
||||||
console.log(now);
|
// console.log(now)
|
||||||
// 检查是否在5分钟内
|
// 检查是否在5分钟内
|
||||||
return now - revokeTime <= 5 * 60 * 1000;
|
return now - revokeTime <= 5 * 60 * 1000;
|
||||||
}
|
}
|
||||||
@ -1095,14 +1100,17 @@ watch(
|
|||||||
state.value.localPageLoadDone = true;
|
state.value.localPageLoadDone = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
// 只在正常加载模式下检查是否加载完缓存数据
|
||||||
|
if (!state.value.useCustomLoadMore) {
|
||||||
if (
|
if (
|
||||||
newValue[newValue.length - 1]?.sequence ===
|
newValue[newValue.length - 1]?.sequence ===
|
||||||
dialogueList?.records?.[0]?.sequence
|
dialogueList?.records?.[0]?.sequence
|
||||||
) {
|
) {
|
||||||
//相同意味着分页加载缓存中的聊天记录完毕
|
//相同意味着分页加载缓存中的聊天记录完毕
|
||||||
state.value.localPageLoadDone = true;
|
state.value.localPageLoadDone = true
|
||||||
} else {
|
} else {
|
||||||
state.value.localPageLoadDone = false;
|
state.value.localPageLoadDone = false
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -1130,7 +1138,13 @@ const onScrollToLower = async () => {
|
|||||||
);
|
);
|
||||||
console.log(moreRecords);
|
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);
|
console.log(virtualList.value);
|
||||||
} else {
|
} else {
|
||||||
@ -1174,12 +1188,19 @@ const onScrollToUpper = async () => {
|
|||||||
const moreRecords = await findTalkRecords(
|
const moreRecords = await findTalkRecords(
|
||||||
"",
|
"",
|
||||||
false,
|
false,
|
||||||
tempVirtualList[tempVirtualList.length - 1].sequence
|
tempVirtualList[tempVirtualList.length - 1].sequence,
|
||||||
);
|
)
|
||||||
console.log(moreRecords);
|
console.log(moreRecords)
|
||||||
|
|
||||||
|
// 格式化新加载的消息
|
||||||
|
const formattedMoreRecords = moreRecords.map((item) => ({
|
||||||
|
...item,
|
||||||
|
float: item.user_id === talkParams.uid ? 'right' : 'left',
|
||||||
|
}))
|
||||||
|
|
||||||
virtualList.value = tempVirtualList
|
virtualList.value = tempVirtualList
|
||||||
.concat(moreRecords.reverse())
|
.concat(formattedMoreRecords.reverse())
|
||||||
.reverse();
|
.reverse()
|
||||||
|
|
||||||
console.log(virtualList.value);
|
console.log(virtualList.value);
|
||||||
|
|
||||||
@ -1307,8 +1328,9 @@ const getMentionSelectLists = (mentionSelectList) => {
|
|||||||
|
|
||||||
//根据msg信息找到对应的聊天记录,并根据sequence等查看上下文
|
//根据msg信息找到对应的聊天记录,并根据sequence等查看上下文
|
||||||
const queryRecordsByMsgInfo = async (msgInfo) => {
|
const queryRecordsByMsgInfo = async (msgInfo) => {
|
||||||
console.log(msgInfo);
|
console.log(msgInfo)
|
||||||
const dialogueList = getDialogueList(talkParams.index_name);
|
state.value.middleMsg = msgInfo
|
||||||
|
const dialogueList = getDialogueList(talkParams.index_name)
|
||||||
const recordIndex = dialogueList?.records?.findIndex(
|
const recordIndex = dialogueList?.records?.findIndex(
|
||||||
(record) => record.msg_id === msgInfo.msg_id
|
(record) => record.msg_id === msgInfo.msg_id
|
||||||
);
|
);
|
||||||
@ -1324,6 +1346,15 @@ const queryRecordsByMsgInfo = async (msgInfo) => {
|
|||||||
// console.log(recordIndex-startRecordIndex)
|
// console.log(recordIndex-startRecordIndex)
|
||||||
recordsList = dialogueList.records.slice(startRecordIndex, endRecordIndex);
|
recordsList = dialogueList.records.slice(startRecordIndex, endRecordIndex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 格式化消息,确保每条消息都有正确的 float
|
||||||
|
recordsList = recordsList.map((item) => {
|
||||||
|
return {
|
||||||
|
...item,
|
||||||
|
float: item.user_id === talkParams.uid ? 'right' : 'left',
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
zpagingRef.value.complete(recordsList.reverse());
|
zpagingRef.value.complete(recordsList.reverse());
|
||||||
loadConfig.status = dialogueList?.records?.[0]?.sequence > 1 ? 1 : 2;
|
loadConfig.status = dialogueList?.records?.[0]?.sequence > 1 ? 1 : 2;
|
||||||
@ -1374,8 +1405,9 @@ const findTalkRecords = (record, isMiddle, sequence, appointParams) => {
|
|||||||
start_time: "",
|
start_time: "",
|
||||||
end_time: "",
|
end_time: "",
|
||||||
group_member_user_id: 0, //群成员id,当查询群历史消息的时候,需要指定群成员的时候送
|
group_member_user_id: 0, //群成员id,当查询群历史消息的时候,需要指定群成员的时候送
|
||||||
sort_sequence: "asc",
|
sort_sequence: 'asc',
|
||||||
};
|
create_time: state.value.middleMsg.created_at,
|
||||||
|
}
|
||||||
if (record) {
|
if (record) {
|
||||||
params = Object.assign({}, params, {
|
params = Object.assign({}, params, {
|
||||||
start_time: record,
|
start_time: record,
|
||||||
@ -1473,8 +1505,8 @@ const rpxToPx = (rpx) => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
onUnmounted(() => {
|
onUnmounted(() => {
|
||||||
if (!state.value.recordDate) {
|
if (!state.value.keepDialogInfo) {
|
||||||
dialogueStore.setDialogue({});
|
dialogueStore.setDialogue({})
|
||||||
}
|
}
|
||||||
clearMultiSelect();
|
clearMultiSelect();
|
||||||
});
|
});
|
||||||
|
@ -8,7 +8,11 @@
|
|||||||
<div class="avatarImg">
|
<div class="avatarImg">
|
||||||
<tm-badge
|
<tm-badge
|
||||||
:count="props.data.is_disturb === 1 ? props.data.unread_num : ''"
|
:count="props.data.is_disturb === 1 ? props.data.unread_num : ''"
|
||||||
:dot="props.data.is_disturb === 0 && props.data.unread_num"
|
:dot="
|
||||||
|
props.data.is_disturb === 0 && props.data.unread_num
|
||||||
|
? true
|
||||||
|
: false
|
||||||
|
"
|
||||||
:maxCount="99"
|
:maxCount="99"
|
||||||
class="badge"
|
class="badge"
|
||||||
color="#D03050"
|
color="#D03050"
|
||||||
@ -34,10 +38,13 @@
|
|||||||
<div class="chatInfo">
|
<div class="chatInfo">
|
||||||
<div class="chatInfo_1">
|
<div class="chatInfo_1">
|
||||||
<div class="name_center">
|
<div class="name_center">
|
||||||
<div class="text-[#000000] text-[32rpx]
|
<div
|
||||||
font-bold opacity-90 name_text">
|
class="text-[#000000] text-[32rpx] font-bold opacity-90 name_text"
|
||||||
|
>
|
||||||
{{ formatNameText(props.data.name) }}
|
{{ formatNameText(props.data.name) }}
|
||||||
<span v-if="props.data.talk_type === 2">({{props.data.group_member_num}})</span>
|
<span v-if="props.data.talk_type === 2">
|
||||||
|
({{ props.data.group_member_num }})
|
||||||
|
</span>
|
||||||
<span v-if="props.data.group_type === 2" class="depTag tag">
|
<span v-if="props.data.group_type === 2" class="depTag tag">
|
||||||
部门
|
部门
|
||||||
</span>
|
</span>
|
||||||
@ -48,9 +55,9 @@
|
|||||||
公司
|
公司
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div style="flex-shrink: 0;"
|
<div
|
||||||
|
style="flex-shrink: 0;"
|
||||||
class="text-[#000000] text-[28rpx] font-medium opacity-26 ml-[24rpx] time_right"
|
class="text-[#000000] text-[28rpx] font-medium opacity-26 ml-[24rpx] time_right"
|
||||||
>
|
>
|
||||||
{{ beautifyTime(props.data.updated_at) }}
|
{{ beautifyTime(props.data.updated_at) }}
|
||||||
@ -66,12 +73,12 @@
|
|||||||
<template #right>
|
<template #right>
|
||||||
<div class="flex flex-row flex-row-center-end">
|
<div class="flex flex-row flex-row-center-end">
|
||||||
<!-- 样式占位 -->
|
<!-- 样式占位 -->
|
||||||
<div style="width: 1px"></div>
|
<div style="width: 1px;"></div>
|
||||||
<div
|
<div
|
||||||
@click="handleTop"
|
@click="handleTop"
|
||||||
class="w-[156rpx] h-[154rpx] text-[#ffffff] bg-[#F09F1F] flex items-center justify-center"
|
class="w-[156rpx] h-[154rpx] text-[#ffffff] bg-[#F09F1F] flex items-center justify-center"
|
||||||
>
|
>
|
||||||
{{ props.data.is_top === 1 ? "取消置顶" : "置顶" }}
|
{{ props.data.is_top === 1 ? '取消置顶' : '置顶' }}
|
||||||
</div>
|
</div>
|
||||||
<div
|
<div
|
||||||
@click="handleDelete"
|
@click="handleDelete"
|
||||||
@ -89,17 +96,17 @@
|
|||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<script setup>
|
<script setup>
|
||||||
import avatarModule from "@/components/avatar-module/index.vue";
|
import avatarModule from '@/components/avatar-module/index.vue'
|
||||||
import { ref, reactive, defineProps, computed } from "vue";
|
import { ref, reactive, defineProps, computed } from 'vue'
|
||||||
import dayjs from "dayjs";
|
import dayjs from 'dayjs'
|
||||||
import { beautifyTime } from "@/utils/datetime";
|
import { beautifyTime } from '@/utils/datetime'
|
||||||
import { ServeClearTalkUnreadNum } from "@/api/chat";
|
import { ServeClearTalkUnreadNum } from '@/api/chat'
|
||||||
import { useTalkStore, useDialogueStore } from "@/store";
|
import { useTalkStore, useDialogueStore } from '@/store'
|
||||||
import { useSessionMenu } from "@/hooks";
|
import { useSessionMenu } from '@/hooks'
|
||||||
|
|
||||||
const talkStore = useTalkStore();
|
const talkStore = useTalkStore()
|
||||||
const { onToTopTalk, onRemoveTalk } = useSessionMenu();
|
const { onToTopTalk, onRemoveTalk } = useSessionMenu()
|
||||||
const dialogueStore = useDialogueStore();
|
const dialogueStore = useDialogueStore()
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
data: {
|
data: {
|
||||||
type: Object,
|
type: Object,
|
||||||
@ -111,17 +118,17 @@ const props = defineProps({
|
|||||||
default: -1,
|
default: -1,
|
||||||
required: true,
|
required: true,
|
||||||
},
|
},
|
||||||
});
|
})
|
||||||
|
|
||||||
// 添加格式化方法
|
// 添加格式化方法
|
||||||
const formatNameText = (text, maxLength = 16) => {
|
const formatNameText = (text, maxLength = 16) => {
|
||||||
return text.length > maxLength ? `${text.slice(0, maxLength - 1)}...` : text;
|
return text.length > maxLength ? `${text.slice(0, maxLength - 1)}...` : text
|
||||||
};
|
}
|
||||||
|
|
||||||
const cellClick = () => {
|
const cellClick = () => {
|
||||||
console.log(props.data);
|
console.log(props.data)
|
||||||
// 更新编辑信息
|
// 更新编辑信息
|
||||||
dialogueStore.setDialogue(props.data);
|
dialogueStore.setDialogue(props.data)
|
||||||
|
|
||||||
// 清空消息未读数
|
// 清空消息未读数
|
||||||
if (props.data.unread_num > 0) {
|
if (props.data.unread_num > 0) {
|
||||||
@ -132,24 +139,24 @@ const cellClick = () => {
|
|||||||
talkStore.updateItem({
|
talkStore.updateItem({
|
||||||
index_name: props.data.index_name,
|
index_name: props.data.index_name,
|
||||||
unread_num: 0,
|
unread_num: 0,
|
||||||
});
|
})
|
||||||
});
|
})
|
||||||
}
|
}
|
||||||
uni.navigateTo({
|
uni.navigateTo({
|
||||||
url: `/pages/dialog/index?sessionId=${props.data.id}`,
|
url: `/pages/dialog/index?sessionId=${props.data.id}`,
|
||||||
});
|
})
|
||||||
};
|
}
|
||||||
|
|
||||||
const handleTop = () => {
|
const handleTop = () => {
|
||||||
console.log(props.data, 1);
|
console.log(props.data, 1)
|
||||||
onToTopTalk(props.data);
|
onToTopTalk(props.data)
|
||||||
};
|
}
|
||||||
|
|
||||||
//点击删除会话
|
//点击删除会话
|
||||||
const handleDelete = () => {
|
const handleDelete = () => {
|
||||||
console.log(props.data);
|
console.log(props.data)
|
||||||
onRemoveTalk(props.data);
|
onRemoveTalk(props.data)
|
||||||
};
|
}
|
||||||
</script>
|
</script>
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
::v-deep .swipe_action {
|
::v-deep .swipe_action {
|
||||||
|
@ -125,6 +125,7 @@ import { ref, watch, computed } from 'vue'
|
|||||||
import { onShow, onLoad } from '@dcloudio/uni-app'
|
import { onShow, onLoad } from '@dcloudio/uni-app'
|
||||||
import { useChatList } from '@/store/chatList/index.js'
|
import { useChatList } from '@/store/chatList/index.js'
|
||||||
import { useAuth } from '@/store/auth'
|
import { useAuth } from '@/store/auth'
|
||||||
|
import { ServeClearTalkUnreadNum } from '@/api/chat'
|
||||||
import { useTalkStore, useUserStore, useDialogueStore } from '@/store'
|
import { useTalkStore, useUserStore, useDialogueStore } from '@/store'
|
||||||
import chatItem from './components/chatItem.vue'
|
import chatItem from './components/chatItem.vue'
|
||||||
import addCircle from '@/static/image/chatList/addCircle.png'
|
import addCircle from '@/static/image/chatList/addCircle.png'
|
||||||
@ -237,6 +238,7 @@ onLoad((options) => {
|
|||||||
if (items?.value?.length > 0) {
|
if (items?.value?.length > 0) {
|
||||||
items.value.forEach((openSession) => {
|
items.value.forEach((openSession) => {
|
||||||
if (openSession.index_name === options?.openSessionIndexName) {
|
if (openSession.index_name === options?.openSessionIndexName) {
|
||||||
|
setTimeout(() => {
|
||||||
dialogueStore.setDialogue(openSession)
|
dialogueStore.setDialogue(openSession)
|
||||||
if (openSession.unread_num > 0) {
|
if (openSession.unread_num > 0) {
|
||||||
ServeClearTalkUnreadNum({
|
ServeClearTalkUnreadNum({
|
||||||
@ -252,6 +254,7 @@ onLoad((options) => {
|
|||||||
uni.navigateTo({
|
uni.navigateTo({
|
||||||
url: `/pages/dialog/index?sessionId=${openSession.id}`,
|
url: `/pages/dialog/index?sessionId=${openSession.id}`,
|
||||||
})
|
})
|
||||||
|
}, 500)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -96,6 +96,7 @@ import {
|
|||||||
import HighlightText from './highLightText.vue'
|
import HighlightText from './highLightText.vue'
|
||||||
import { useI18n } from 'vue-i18n'
|
import { useI18n } from 'vue-i18n'
|
||||||
import { beautifyTime } from '@/utils/datetime'
|
import { beautifyTime } from '@/utils/datetime'
|
||||||
|
import { ChatMsgTypeMapping } from '@/constant/message'
|
||||||
const { t } = useI18n()
|
const { t } = useI18n()
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
searchItem: Object | Number,
|
searchItem: Object | Number,
|
||||||
@ -175,6 +176,13 @@ const keyMapping = {
|
|||||||
name: 'receiver_name',
|
name: 'receiver_name',
|
||||||
group_num: 'group_num',
|
group_num: 'group_num',
|
||||||
},
|
},
|
||||||
|
search_by_member_condition: {
|
||||||
|
avatar: 'avatar',
|
||||||
|
name: 'nickname',
|
||||||
|
created_at: 'created_at',
|
||||||
|
msg_type: 'msg_type',
|
||||||
|
detailKey: 'chatMessageType',
|
||||||
|
},
|
||||||
}
|
}
|
||||||
//获取key对应值
|
//获取key对应值
|
||||||
const getKeyValue = (keys) => {
|
const getKeyValue = (keys) => {
|
||||||
@ -254,6 +262,12 @@ const resultDetail = computed(() => {
|
|||||||
case 'extra':
|
case 'extra':
|
||||||
result_detail = props.searchItem?.extra
|
result_detail = props.searchItem?.extra
|
||||||
break
|
break
|
||||||
|
case 'chatMessageType':
|
||||||
|
result_detail =
|
||||||
|
props.searchItem?.msg_type === 1
|
||||||
|
? props.searchItem?.extra?.content
|
||||||
|
: ChatMsgTypeMapping[props.searchItem?.msg_type]
|
||||||
|
break
|
||||||
default:
|
default:
|
||||||
result_detail = ''
|
result_detail = ''
|
||||||
}
|
}
|
||||||
|
@ -36,7 +36,10 @@
|
|||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<div class="search-record-detail" v-if="props.searchRecordDetail">
|
<div
|
||||||
|
class="search-record-detail"
|
||||||
|
v-if="props.searchRecordDetail && !props?.hideFirstRecord"
|
||||||
|
>
|
||||||
<searchItem
|
<searchItem
|
||||||
@click="
|
@click="
|
||||||
clickSearchItem(
|
clickSearchItem(
|
||||||
@ -171,6 +174,10 @@ const props = defineProps({
|
|||||||
return {}
|
return {}
|
||||||
},
|
},
|
||||||
}, //接受者信息
|
}, //接受者信息
|
||||||
|
hideFirstRecord: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false,
|
||||||
|
}, //是否隐藏前缀及搜索群/用户主体信息
|
||||||
})
|
})
|
||||||
|
|
||||||
const { t } = useI18n()
|
const { t } = useI18n()
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
:apiRequest="ServeTalkRecord"
|
:apiRequest="ServeTalkRecord"
|
||||||
:apiParams="state.apiParams"
|
:apiParams="state.apiParams"
|
||||||
:searchText="state.searchText"
|
:searchText="state.searchText"
|
||||||
|
:hideFirstRecord="state.hideFirstRecord"
|
||||||
:isPagination="true"
|
:isPagination="true"
|
||||||
:searchRecordDetail="true"
|
:searchRecordDetail="true"
|
||||||
@lastIdChange="lastIdChange"
|
@lastIdChange="lastIdChange"
|
||||||
@ -30,6 +31,7 @@ const state = reactive({
|
|||||||
apiParams: '',
|
apiParams: '',
|
||||||
searchText: '',
|
searchText: '',
|
||||||
uid: computed(() => userStore.uid), //当前用户id
|
uid: computed(() => userStore.uid), //当前用户id
|
||||||
|
hideFirstRecord: false, //是否隐藏前缀及搜索群/用户主体信息
|
||||||
})
|
})
|
||||||
|
|
||||||
onLoad((options) => {
|
onLoad((options) => {
|
||||||
@ -55,6 +57,10 @@ onLoad((options) => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
console.log(JSON.parse(decodeURIComponent(state.apiParams)))
|
console.log(JSON.parse(decodeURIComponent(state.apiParams)))
|
||||||
|
|
||||||
|
if (options.hideFirstRecord) {
|
||||||
|
state.hideFirstRecord = options.hideFirstRecord === '1' ? true : false
|
||||||
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
//分页查询时,最后一条id变化
|
//分页查询时,最后一条id变化
|
||||||
@ -116,7 +122,7 @@ const clickSearchItem = (
|
|||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
uni.navigateTo({
|
uni.navigateTo({
|
||||||
url: '/pages/dialog/index?msgInfo=' + res,
|
url: '/pages/dialog/index?msgInfo=' + res + '&keepDialogInfo=1',
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
:auto="false"
|
:auto="false"
|
||||||
:loading-more-default-as-loading="true"
|
:loading-more-default-as-loading="true"
|
||||||
:inside-more="true"
|
:inside-more="true"
|
||||||
|
v-model="state.flatList"
|
||||||
>
|
>
|
||||||
<template #top v-if="state.showPageTitle">
|
<template #top v-if="state.showPageTitle">
|
||||||
<customNavbar :title="state.pageTitle"></customNavbar>
|
<customNavbar :title="state.pageTitle"></customNavbar>
|
||||||
@ -73,11 +74,7 @@
|
|||||||
>
|
>
|
||||||
<div
|
<div
|
||||||
class="search-by-condition-input"
|
class="search-by-condition-input"
|
||||||
v-if="
|
v-if="state.condition === 'file' || state.condition === 'link'"
|
||||||
state.condition === 'file' ||
|
|
||||||
state.condition === 'link' ||
|
|
||||||
state.condition === 'member'
|
|
||||||
"
|
|
||||||
>
|
>
|
||||||
<customInput
|
<customInput
|
||||||
:searchText="state.searchText"
|
:searchText="state.searchText"
|
||||||
@ -117,11 +114,24 @@
|
|||||||
v-for="(item, index) in conditionItem.monthResultList"
|
v-for="(item, index) in conditionItem.monthResultList"
|
||||||
:key="index"
|
:key="index"
|
||||||
:style="{
|
:style="{
|
||||||
border: state.condition === 'imgAndVideo' ? '0' : '',
|
border:
|
||||||
|
state.condition === 'imgAndVideo' ||
|
||||||
|
state.condition === 'member'
|
||||||
|
? '0'
|
||||||
|
: '',
|
||||||
padding:
|
padding:
|
||||||
state.condition === 'imgAndVideo' ? '0 0 10rpx' : '',
|
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
|
<div
|
||||||
class="condition-result-imgAndVideo"
|
class="condition-result-imgAndVideo"
|
||||||
v-if="state.condition === 'imgAndVideo'"
|
v-if="state.condition === 'imgAndVideo'"
|
||||||
@ -295,6 +305,7 @@ const state = reactive({
|
|||||||
cursor: 0, //上次查询的游标
|
cursor: 0, //上次查询的游标
|
||||||
msg_type: 0, //查询的消息类型
|
msg_type: 0, //查询的消息类型
|
||||||
group_member_id: 0, //群成员id
|
group_member_id: 0, //群成员id
|
||||||
|
flatList: [], // 用于存储扁平化的数据
|
||||||
})
|
})
|
||||||
|
|
||||||
onLoad((options) => {
|
onLoad((options) => {
|
||||||
@ -302,7 +313,10 @@ onLoad((options) => {
|
|||||||
if (options.condition) {
|
if (options.condition) {
|
||||||
state.condition = options.condition
|
state.condition = options.condition
|
||||||
if (options.condition === 'member') {
|
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') {
|
} else if (options.condition === 'date') {
|
||||||
state.showPageTitle = true
|
state.showPageTitle = true
|
||||||
state.pageTitle = t('search.condition.date')
|
state.pageTitle = t('search.condition.date')
|
||||||
@ -426,6 +440,7 @@ const selectDate = async (e) => {
|
|||||||
url:
|
url:
|
||||||
'/pages/dialog/index?sessionId=' +
|
'/pages/dialog/index?sessionId=' +
|
||||||
sessionId +
|
sessionId +
|
||||||
|
'&keepDialogInfo=1' +
|
||||||
'&recordDate=' +
|
'&recordDate=' +
|
||||||
parseTime(e, '{y}-{m}-{d}'),
|
parseTime(e, '{y}-{m}-{d}'),
|
||||||
})
|
})
|
||||||
@ -557,18 +572,25 @@ const queryAllSearch = () => {
|
|||||||
} else {
|
} else {
|
||||||
noMore = true
|
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) {
|
if (state.cursor === 0) {
|
||||||
state.searchResultList = dateList
|
zPaging.value?.complete(state.flatList)
|
||||||
zPaging.value?.complete(dateList)
|
|
||||||
} else {
|
} else {
|
||||||
state.searchResultList = dateList
|
zPaging.value?.completeByNoMore(state.flatList, noMore)
|
||||||
zPaging.value?.completeByNoMore(dateList, noMore)
|
|
||||||
}
|
}
|
||||||
state.cursor = data?.cursor
|
state.cursor = data?.cursor
|
||||||
} else {
|
} else {
|
||||||
if (state.cursor === 0) {
|
if (state.cursor === 0) {
|
||||||
state.searchResultList = []
|
state.searchResultList = []
|
||||||
|
state.flatList = []
|
||||||
}
|
}
|
||||||
zPaging.value?.complete([])
|
zPaging.value?.complete([])
|
||||||
}
|
}
|
||||||
@ -577,6 +599,7 @@ const queryAllSearch = () => {
|
|||||||
resp.catch(() => {
|
resp.catch(() => {
|
||||||
if (state.cursor === 0) {
|
if (state.cursor === 0) {
|
||||||
state.searchResultList = []
|
state.searchResultList = []
|
||||||
|
state.flatList = []
|
||||||
}
|
}
|
||||||
zPaging.value?.complete([])
|
zPaging.value?.complete([])
|
||||||
})
|
})
|
||||||
@ -637,6 +660,22 @@ const downloadAndOpenFile = (item) => {
|
|||||||
})
|
})
|
||||||
dtask.start()
|
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>
|
</script>
|
||||||
<style scoped lang="scss">
|
<style scoped lang="scss">
|
||||||
.search-by-date {
|
.search-by-date {
|
||||||
|
@ -144,6 +144,7 @@ export const useTalkStore = defineStore('talk', {
|
|||||||
|
|
||||||
ServeCreateTalkList({
|
ServeCreateTalkList({
|
||||||
talk_type,
|
talk_type,
|
||||||
|
receiver_id,
|
||||||
erp_user_id,
|
erp_user_id,
|
||||||
}).then(({ code, data, message }) => {
|
}).then(({ code, data, message }) => {
|
||||||
if (code == 200) {
|
if (code == 200) {
|
||||||
|
Loading…
Reference in New Issue
Block a user