Compare commits
	
		
			No commits in common. "e6075849fe06f345445ce619ed81fb5b12ea96ea" and "2d28872a12c909f29c140f6a4147b1dd1ed2fb00" have entirely different histories.
		
	
	
		
			e6075849fe
			...
			2d28872a12
		
	
		
| @ -13,10 +13,9 @@ | |||||||
|       v-model="virtualList" |       v-model="virtualList" | ||||||
|       :loading-more-custom-style="{ display: 'none', height: '0' }" |       :loading-more-custom-style="{ display: 'none', height: '0' }" | ||||||
|       @scrolltolower="onScrollToLower" |       @scrolltolower="onScrollToLower" | ||||||
|       @scrolltoupper="onScrollToUpper" |  | ||||||
|     > |     > | ||||||
|       <template #top> |       <template #top> | ||||||
|         <customNavbar :title="talkParams.username" id="navBarArea"> |         <customNavbar :title="talkParams.username"> | ||||||
|           <template |           <template | ||||||
|             #subTitle |             #subTitle | ||||||
|             v-if="talkStore?.findItem(talkParams.index_name)?.group_type === 4" |             v-if="talkStore?.findItem(talkParams.index_name)?.group_type === 4" | ||||||
| @ -48,7 +47,7 @@ | |||||||
|         <div |         <div | ||||||
|           class="message-item" |           class="message-item" | ||||||
|           v-for="item in virtualList" |           v-for="item in virtualList" | ||||||
|           :id="`zp-id-${item.msg_id}`" |           :id="`zp-id-${item.zp_index}`" | ||||||
|           :key="item.zp_index" |           :key="item.zp_index" | ||||||
|           style="transform: scaleY(-1);" |           style="transform: scaleY(-1);" | ||||||
|         > |         > | ||||||
| @ -189,7 +188,7 @@ | |||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|       <template #bottom> |       <template #bottom> | ||||||
|         <div class="footBox" id="footBoxArea"> |         <div class="footBox"> | ||||||
|           <div v-if="!dialogueStore.isOpenMultiSelect"> |           <div v-if="!dialogueStore.isOpenMultiSelect"> | ||||||
|             <div |             <div | ||||||
|               class="pt-[16rpx] ml-[32rpx] mr-[32rpx] flex items-start justify-between" |               class="pt-[16rpx] ml-[32rpx] mr-[32rpx] flex items-start justify-between" | ||||||
| @ -537,20 +536,13 @@ const state = ref({ | |||||||
|   mentionSelectHeight: 0, //选择要提醒人的区域高度 |   mentionSelectHeight: 0, //选择要提醒人的区域高度 | ||||||
|   selectAreaHeight: 0, //选择要提醒人的可选人员列表区域高度 |   selectAreaHeight: 0, //选择要提醒人的可选人员列表区域高度 | ||||||
|   isShowMentionSelect: false, //是否显示要提醒人的选择区域 |   isShowMentionSelect: false, //是否显示要提醒人的选择区域 | ||||||
|   useCustomLoadMore: false, //是否使用自定义加载更多事件(下拉刷新、上拉加载) |   revokedMessages: {}, // 存储撤回的消息,格式为 {msg_id: {content, revokeTime, ...}} | ||||||
| }) | }) | ||||||
| 
 | 
 | ||||||
| uniOnload((options) => { | uniOnload((options) => { | ||||||
|   if (options.sessionId) { |   if (options.sessionId) { | ||||||
|     state.value.sessionId = options.sessionId |     state.value.sessionId = options.sessionId | ||||||
|   } |   } | ||||||
|   if (options.msgInfo) { |  | ||||||
|     const msgInfo = JSON.parse(decodeURIComponent(options.msgInfo)) |  | ||||||
|     queryRecordsByMsgInfo(msgInfo) |  | ||||||
|     state.value.useCustomLoadMore = true |  | ||||||
|     return |  | ||||||
|   } |  | ||||||
|   initData() |  | ||||||
| }) | }) | ||||||
| 
 | 
 | ||||||
| const handleEmojiPanel = () => { | const handleEmojiPanel = () => { | ||||||
| @ -1072,79 +1064,12 @@ watch( | |||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| const onScrollToLower = () => { | const onScrollToLower = () => { | ||||||
|   if (state.value.useCustomLoadMore) { |  | ||||||
|     const tempVirtualList = lodash.cloneDeep(virtualList.value).reverse() |  | ||||||
|     const dialogueList = getDialogueList(talkParams.index_name) |  | ||||||
|     const recordIndex = dialogueList.records.findIndex( |  | ||||||
|       (record) => record.msg_id === tempVirtualList[0].msg_id, |  | ||||||
|     ) |  | ||||||
|     if (recordIndex === -1) { |  | ||||||
|     } else { |  | ||||||
|       if (tempVirtualList[0].sequence > dialogueList.records[0].sequence) { |  | ||||||
|         virtualList.value = dialogueList.records |  | ||||||
|           .slice(0, recordIndex) |  | ||||||
|           .concat(tempVirtualList) |  | ||||||
|           .reverse() |  | ||||||
|         // zpagingRef.value.setLocalPaging( |  | ||||||
|         //   dialogueList.records |  | ||||||
|         //     .slice(0, recordIndex) |  | ||||||
|         //     .concat(tempVirtualList) |  | ||||||
|         //     .reverse(), |  | ||||||
|         //   // zpagingRef.value.scrollIntoViewById('zp-id-' + virtualList.value[virtualList.value.length - 1].msg_id) |  | ||||||
|         // ) |  | ||||||
| 
 |  | ||||||
|         console.log(virtualList.value) |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     return |  | ||||||
|   } |  | ||||||
|   if (state.value.localPageLoadDone) { |   if (state.value.localPageLoadDone) { | ||||||
|     //本地缓存的聊天记录分页加载完之后,才可以请求接口 |     //本地缓存的聊天记录分页加载完之后,才可以请求接口 | ||||||
|     onRefreshLoad() |     onRefreshLoad() | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| //本来的下拉刷新——列表倒置后为上拉加载 |  | ||||||
| const onScrollToUpper = () => { |  | ||||||
|   if (state.value.useCustomLoadMore) { |  | ||||||
|     const tempVirtualList = lodash.cloneDeep(virtualList.value).reverse() |  | ||||||
|     const dialogueList = getDialogueList(talkParams.index_name) |  | ||||||
|     const recordIndex = dialogueList.records.findIndex( |  | ||||||
|       (record) => |  | ||||||
|         record.msg_id === tempVirtualList[tempVirtualList.length - 1].msg_id, |  | ||||||
|     ) |  | ||||||
|     if (recordIndex === -1) { |  | ||||||
|     } else { |  | ||||||
|       if ( |  | ||||||
|         tempVirtualList[tempVirtualList.length - 1].sequence < |  | ||||||
|         dialogueList.records[dialogueList.records.length - 1].sequence |  | ||||||
|       ) { |  | ||||||
|         virtualList.value = tempVirtualList |  | ||||||
|           .concat( |  | ||||||
|             dialogueList.records.slice( |  | ||||||
|               recordIndex + 1, |  | ||||||
|               dialogueList.records.length, |  | ||||||
|             ), |  | ||||||
|           ) |  | ||||||
|           .reverse() |  | ||||||
|         // zpagingRef.value.setLocalPaging( |  | ||||||
|         //   tempVirtualList |  | ||||||
|         //     .concat( |  | ||||||
|         //       dialogueList.records.slice( |  | ||||||
|         //         recordIndex + 1, |  | ||||||
|         //         dialogueList.records.length, |  | ||||||
|         //       ), |  | ||||||
|         //     ) |  | ||||||
|         //     .reverse(), |  | ||||||
|         //   // zpagingRef.value.scrollIntoViewById('zp-id-' + virtualList.value[virtualList.value.length - 1].msg_id) |  | ||||||
|         // ) |  | ||||||
| 
 |  | ||||||
|         console.log(virtualList.value) |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const clearMultiSelect = () => { | const clearMultiSelect = () => { | ||||||
|   dialogueStore.setMultiSelect(false) |   dialogueStore.setMultiSelect(false) | ||||||
|   virtualList.value.forEach((item) => { |   virtualList.value.forEach((item) => { | ||||||
| @ -1221,13 +1146,11 @@ const getMentionSelectLists = (mentionSelectList) => { | |||||||
|     mentionUsers[0].insert.slice(0, -2) + mentionUsers[0].insert.slice(-1) |     mentionUsers[0].insert.slice(0, -2) + mentionUsers[0].insert.slice(-1) | ||||||
|   console.log(mentionUsers[0].insert) |   console.log(mentionUsers[0].insert) | ||||||
|   mentionSelectList.forEach((mentionSelectItem) => { |   mentionSelectList.forEach((mentionSelectItem) => { | ||||||
|  |     mentionUserIds.push(mentionSelectItem.erp_user_id) | ||||||
|     mentionUserIds.push(mentionSelectItem.id) |     mentionUserIds.push(mentionSelectItem.id) | ||||||
|     mentionUsers.push({ |     mentionUsers.push({ | ||||||
|       insert: '@' + mentionSelectItem.nickname + ' ', |       insert: '@' + mentionSelectItem.nickname + ' ', | ||||||
|       attributes: { |       attributes: { | ||||||
|         // mention: { |  | ||||||
|         //   id: mentionSelectItem.id, |  | ||||||
|         // }, |  | ||||||
|         color: '#1890ff', |         color: '#1890ff', | ||||||
|       }, |       }, | ||||||
|     }) |     }) | ||||||
| @ -1236,61 +1159,8 @@ const getMentionSelectLists = (mentionSelectList) => { | |||||||
|   hideMentionSelect() |   hideMentionSelect() | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| //根据msg信息找到对应的聊天记录,并根据sequence等查看上下文 |  | ||||||
| const queryRecordsByMsgInfo = (msgInfo) => { |  | ||||||
|   console.log(msgInfo) |  | ||||||
|   const dialogueList = getDialogueList(talkParams.index_name) |  | ||||||
|   const recordIndex = dialogueList.records.findIndex( |  | ||||||
|     (record) => record.msg_id === msgInfo.msg_id, |  | ||||||
|   ) |  | ||||||
|   if (recordIndex === -1) { |  | ||||||
|   } else { |  | ||||||
|     // console.log(recordIndex) |  | ||||||
|     const startRecordIndex = Math.max(0, recordIndex - 10) |  | ||||||
|     const endRecordIndex = Math.max(0, recordIndex + 10) |  | ||||||
|     // console.log(dialogueList.records.slice(startRecordIndex, endRecordIndex)) |  | ||||||
|     // console.log(recordIndex-startRecordIndex) |  | ||||||
|     const recordsList = dialogueList.records.slice( |  | ||||||
|       startRecordIndex, |  | ||||||
|       endRecordIndex, |  | ||||||
|     ) |  | ||||||
|     nextTick(() => { |  | ||||||
|       zpagingRef.value.complete(recordsList.reverse()) |  | ||||||
|       loadConfig.status = dialogueList.records?.[0]?.sequence > 1 ? 1 : 2 |  | ||||||
|       nextTick(() => { |  | ||||||
|         let offset = uni.getSystemInfoSync().windowHeight |  | ||||||
|         const navBarAreaQuery = uni.createSelectorQuery() |  | ||||||
|         navBarAreaQuery |  | ||||||
|           .select('#navBarArea') |  | ||||||
|           .boundingClientRect((res) => { |  | ||||||
|             if (res) { |  | ||||||
|               // console.log('元素高度:', res.height) |  | ||||||
|               offset = offset - res.height |  | ||||||
|             } |  | ||||||
|           }) |  | ||||||
|           .exec() |  | ||||||
|         const footBoxAreaQuery = uni.createSelectorQuery() |  | ||||||
|         footBoxAreaQuery |  | ||||||
|           .select('#footBoxArea') |  | ||||||
|           .boundingClientRect((res) => { |  | ||||||
|             if (res) { |  | ||||||
|               // console.log('元素高度:', res.height) |  | ||||||
|               offset = offset - res.height |  | ||||||
|             } |  | ||||||
|           }) |  | ||||||
|           .exec() |  | ||||||
|         setTimeout(() => { |  | ||||||
|           zpagingRef.value.scrollIntoViewById( |  | ||||||
|             'zp-id-' + msgInfo.msg_id, |  | ||||||
|             offset - 60, |  | ||||||
|           ) |  | ||||||
|         }, 1000) |  | ||||||
|       }) |  | ||||||
|     }) |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| onMounted(async () => { | onMounted(async () => { | ||||||
|  |   initData() | ||||||
|   nextTick(() => { |   nextTick(() => { | ||||||
|     state.value.mentionSelectHeight = pxTorPx( |     state.value.mentionSelectHeight = pxTorPx( | ||||||
|       uni.getSystemInfoSync().windowHeight * 0.86, |       uni.getSystemInfoSync().windowHeight * 0.86, | ||||||
| @ -1620,10 +1490,6 @@ onUnmounted(() => { | |||||||
|         height: 44rpx; |         height: 44rpx; | ||||||
|         display: inline-block; |         display: inline-block; | ||||||
|       } |       } | ||||||
| 
 |  | ||||||
|       span { |  | ||||||
|         user-select: all; |  | ||||||
|       } |  | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
| @ -361,7 +361,6 @@ const clickSearchItem = (searchResultKey, searchItem) => { | |||||||
|     searchResultKey, |     searchResultKey, | ||||||
|     searchItem.talk_type, |     searchItem.talk_type, | ||||||
|     searchItem.receiver_id, |     searchItem.receiver_id, | ||||||
|     encodeURIComponent(JSON.stringify(searchItem)), |  | ||||||
|   ) |   ) | ||||||
| } | } | ||||||
| </script> | </script> | ||||||
|  | |||||||
| @ -10,7 +10,6 @@ | |||||||
|         :isPagination="true" |         :isPagination="true" | ||||||
|         :searchRecordDetail="true" |         :searchRecordDetail="true" | ||||||
|         @lastIdChange="lastIdChange" |         @lastIdChange="lastIdChange" | ||||||
|         @clickSearchItem="clickSearchItem" |  | ||||||
|       ></searchList> |       ></searchList> | ||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
| @ -20,9 +19,6 @@ import searchList from '../components/searchList.vue' | |||||||
| import { onLoad } from '@dcloudio/uni-app' | import { onLoad } from '@dcloudio/uni-app' | ||||||
| import { ServeTalkRecord } from '@/api/search/index' | import { ServeTalkRecord } from '@/api/search/index' | ||||||
| import { reactive } from 'vue' | import { reactive } from 'vue' | ||||||
| import { useDialogueStore } from "@/store"; |  | ||||||
| 
 |  | ||||||
| const dialogueStore = useDialogueStore(); |  | ||||||
| 
 | 
 | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|   apiParams: String, |   apiParams: String, | ||||||
| @ -71,24 +67,5 @@ const lastIdChange = (last_id, last_group_id, last_member_id) => { | |||||||
|     ), |     ), | ||||||
|   ) |   ) | ||||||
| } | } | ||||||
| 
 |  | ||||||
| //点击了搜索结果项 |  | ||||||
| const clickSearchItem = ( |  | ||||||
|   searchText, |  | ||||||
|   searchResultKey, |  | ||||||
|   talk_type, |  | ||||||
|   receiver_id, |  | ||||||
|   res, |  | ||||||
| ) => { |  | ||||||
|   let result = JSON.parse(decodeURIComponent(res)) |  | ||||||
|   dialogueStore.setDialogue({ |  | ||||||
|     name: result.receiver_name, |  | ||||||
|     talk_type: talk_type, |  | ||||||
|     receiver_id: receiver_id, |  | ||||||
|   }) |  | ||||||
|   uni.navigateTo({ |  | ||||||
|     url: '/pages/dialog/index?msgInfo=' + res, |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| </script> | </script> | ||||||
| <style scoped lang="scss"></style> | <style scoped lang="scss"></style> | ||||||
|  | |||||||
| @ -5,7 +5,7 @@ import { userInfoApi } from "@/api/user"; | |||||||
| import {ref} from 'vue' | import {ref} from 'vue' | ||||||
| export const useAuth = createGlobalState(() => { | export const useAuth = createGlobalState(() => { | ||||||
|   // const token = useStorage('token', '', uniStorage)
 |   // const token = useStorage('token', '', uniStorage)
 | ||||||
|   const token = ref("79b5c732d96d2b27a48a99dfd4a5566c43aaa5796242e854ebe3ffc198d6876b9628e7b764d9af65ab5dbb2d517ced88170491b74b048c0ba827c0d3741462cb89dc59ed46653a449af837a8262941caaef1334d640773710f8cd96473bacfb190cba595a5d6a9c87d70f0999a3ebb41147213b31b4bdccffca66a56acf3baab5af0154f0dce360079f37709f78e13711036899344bddb0fb4cf0f2890287cb62c3fcbe33368caa5e213624577be8b8420ab75b1f50775ee16142a4321c5d56995f37354a66a969da98d95ba6e65d142ed097e04b411c1ebad2f62866d0ec7e1838420530a9941dbbcd00490199f8b8942f76b6f248056e8ae1134eda922b6ba0e5d75a00b2e866b08fec48a0d1de7e6dff8d8a40ac1eb46bf79c6331a1a3cd43209d09865bc0ee5dc9c23d2413e0d85d2380202ce4de1e128063926efae4cb1") |   const token = ref("79b5c732d96d2b27a48a99dfd4a5566c43aaa5796242e854ebe3ffc198d6876b9628e7b764d9af65ab5dbb2d517ced88170491b74b048c0ba827c0d3741462cb89dc59ed46653a449af837a8262941caba0afc18e7cb819d125e8c04282beb5d4dd454307169f7eb51cd3dbbee20c1a17784f78ad30c3b3a102bd03c3218080beedae501a95c365d360a7a0d682cba2eca94a2915c13f0bdcb42f2eab9458cb4bd89ae6f3200fe4893d64caf1bce02894aab876f94f7825d23be507733468deba21734b6d666b75fd0bee74753fdd6ca5def7ec42cd7dbb47750e61cac6965f34fd71b52be66a472d3ee5b1e4661e59db28983527a8af787c5212a06f9b116a37a6679c7ce23b7307a093ea17841ab84695183fbec1f0e683a48ed05133f80a21c30d1cdd7faf3123e3cd69a8da6ae9240e08767898cf1c5f156be8c175066f9") | ||||||
|   const refreshToken = useStorage('refreshToken', '', uniStorage) |   const refreshToken = useStorage('refreshToken', '', uniStorage) | ||||||
|   const userInfo = useStorage('userInfo', {}, uniStorage) |   const userInfo = useStorage('userInfo', {}, uniStorage) | ||||||
|   const leaderList = useStorage('leaderList', [], uniStorage) |   const leaderList = useStorage('leaderList', [], uniStorage) | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user