Compare commits
	
		
			No commits in common. "d55616e2e73d9dab7ce485135de6b70a1320c60c" and "c0f4248385bd46f4d774a027d118bcc4d450541a" have entirely different histories.
		
	
	
		
			d55616e2e7
			...
			c0f4248385
		
	
		
| @ -35,7 +35,7 @@ export const ServeTalkRecords = (data = {}) => { | ||||
| 
 | ||||
| // 获取转发会话记录详情列表服务接口
 | ||||
| export const ServeGetForwardRecords = (data = {}) => { | ||||
|   return get('/api/v1/talk/records/forward/v2', data) | ||||
|   return get('/api/v1/talk/records/forward', data) | ||||
| } | ||||
| 
 | ||||
| // 对话列表置顶服务接口
 | ||||
|  | ||||
| @ -2,12 +2,12 @@ import { post, get, upload } from '@/utils/request' | ||||
| 
 | ||||
| //ES搜索-主页搜索什么都有、指定用户、指定群、群与用户概览
 | ||||
| export const ServeSeachQueryAll = (data = {}) => { | ||||
|   return post('/api/v1/elasticsearch/query-all/v2', data) | ||||
|   return post('/api/v1/elasticsearch/query-all', data) | ||||
| } | ||||
| 
 | ||||
| // ES搜索用户数据
 | ||||
| export const ServeQueryUser = (data) => { | ||||
|   return post('/api/v1/elasticsearch/query-user/v2', data) | ||||
|   return post('/api/v1/elasticsearch/query-user', data) | ||||
| } | ||||
| 
 | ||||
| // ES搜索群组数据
 | ||||
|  | ||||
| @ -168,14 +168,36 @@ | ||||
|                         </n-scrollbar> | ||||
|                       </div> | ||||
|                       <div class="condition-result-imgAndVideo-area" v-if="item?.extra?.url"> | ||||
|                         <div class="message-component-wrapper"> | ||||
|                           <component | ||||
|                             :is="MessageComponents[item.msg_type] || 'unknown-message'" | ||||
|                             :extra="item.extra" | ||||
|                             :data="item" | ||||
|                           /> | ||||
|                         <template v-if="item?.msg_type === 3"> | ||||
|                           <n-image | ||||
|                             :src="item?.extra?.url" | ||||
|                             :lazy="true" | ||||
|                             :preview-src="item?.extra?.url" | ||||
|                             :width="131" | ||||
|                             :height="131" | ||||
|                             object-fit="cover" | ||||
|                           ></n-image> | ||||
|                         </template> | ||||
|                         <template v-else-if="item?.msg_type === 5"> | ||||
|                           <div class="video-preview" @click="onPlay(item?.extra?.url)"> | ||||
|                             <video :src="item?.extra?.url" :controls="false"></video> | ||||
|                             <!-- <n-image | ||||
|                               :src=" | ||||
|                                 item?.extra?.url | ||||
|                                   ? item?.extra?.url + '#t=0.001' | ||||
|                                   : item?.extra?.cover | ||||
|                               " | ||||
|                               :width="131" | ||||
|                               :height="131" | ||||
|                               object-fit="cover" | ||||
|                             ></n-image> --> | ||||
|                             <div class="btn-video"> | ||||
|                               <!-- <img :src="playCircle" /> --> | ||||
|                               <n-icon :component="Play" size="40" /> | ||||
|                             </div> | ||||
|                           </div> | ||||
|                         </template> | ||||
|                       </div> | ||||
|                     </div> | ||||
|                     <!-- <div | ||||
|                       class="condition-each-result-main" | ||||
| @ -304,13 +326,8 @@ import { ServeTalkDate, ServeGetSessionId } from '@/api/search.js' | ||||
| import { parseTime } from '@/utils/datetime' | ||||
| import { fileFormatSize, fileSuffix } from '@/utils/strings' | ||||
| import { NImage, NInfiniteScroll, NScrollbar, NIcon, NDatePicker } from 'naive-ui' | ||||
| import { MessageComponents } from '@/constant/message' | ||||
| 
 | ||||
| const emits = defineEmits([ | ||||
|   'clearSearchMemberByAlphabet', | ||||
|   'getDisabledDateArray', | ||||
|   'hideSearchResultModal' | ||||
| ]) | ||||
| const emits = defineEmits(['clearSearchMemberByAlphabet', 'getDisabledDateArray', 'hideSearchResultModal']) | ||||
| 
 | ||||
| const dialogueStore = useDialogueStore() | ||||
| // 当前对话参数 | ||||
| @ -1109,31 +1126,4 @@ body:deep(.round-3) { | ||||
|     margin: 13px 0 0; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .message-component-wrapper { | ||||
|   width: 131px; | ||||
|   height: 131px; | ||||
|   display: inline-block; | ||||
|   overflow: hidden; | ||||
|   position: relative; | ||||
| 
 | ||||
|   .im-message-video, | ||||
|   .im-message-image, | ||||
|   .image-container { | ||||
|     width: 100% !important; | ||||
|     height: 100% !important; | ||||
|   } | ||||
| 
 | ||||
|   :deep(.n-image) { | ||||
|     width: 100% !important; | ||||
|     height: 100% !important; | ||||
|   } | ||||
| 
 | ||||
|   :deep(img), | ||||
|   :deep(video) { | ||||
|     width: 100% !important; | ||||
|     height: 100% !important; | ||||
|     object-fit: cover !important; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -372,7 +372,7 @@ const resultDetail = computed(() => { | ||||
|   border: 0; | ||||
| } | ||||
| .search-item:hover { | ||||
|   background-color: rgba(70, 41, 157, 0.1); | ||||
|   background-color: #f8f8f8; | ||||
| 
 | ||||
|   .info-detail-searchRecordDetail { | ||||
|     .searchRecordDetail-fastLocal { | ||||
|  | ||||
| @ -41,13 +41,13 @@ | ||||
|                 > | ||||
|                   <searchItem | ||||
|                     @click="clickSearchItem(searchResultKey, item)" | ||||
|                     v-if=" | ||||
|                       (searchResultKey === 'user_infos' | ||||
|                         ? state.userInfosShowAll || (props.listLimit && index < 3) | ||||
|                     v-if="( | ||||
|                       searchResultKey === 'user_infos' | ||||
|                         ? (state.userInfosShowAll || (props.listLimit && index < 3)) | ||||
|                         : searchResultKey === 'combinedGroup' | ||||
|                         ? state.groupInfosShowAll || (props.listLimit && index < 3) | ||||
|                         : props.listLimit && index < 3) || !props.listLimit | ||||
|                     " | ||||
|                           ? (state.groupInfosShowAll || (props.listLimit && index < 3)) | ||||
|                           : (props.listLimit && index < 3) | ||||
|                     ) || !props.listLimit" | ||||
|                     :searchResultKey="searchResultKey" | ||||
|                     :searchItem="item" | ||||
|                     :searchText="state.searchText" | ||||
| @ -403,58 +403,12 @@ const queryAllSearch = (doClearSearchResult) => { | ||||
|             } else if (state?.first_talk_record_infos?.talk_type === 2) { | ||||
|               total = data.group_record_count | ||||
|             } | ||||
|             let noMoreSearchResultRecord = true | ||||
|             if ( | ||||
|               Object.keys(data).includes('talk_record_infos') && | ||||
|               state.searchResult['talk_record_infos']?.length > 0 | ||||
|             ) { | ||||
|               //搜聊天记录详情 | ||||
|               if (state.searchResult['talk_record_infos']?.length < total) { | ||||
|                 noMoreSearchResultRecord = false | ||||
|           } | ||||
|             } | ||||
|             if (noMoreSearchResultRecord) { | ||||
|           if (total < props.searchResultPageSize) { | ||||
|             state.hasMore = false | ||||
|           } else { | ||||
|             state.hasMore = true | ||||
|           } | ||||
|           } else { | ||||
|             let noMoreSearchResultUser = true | ||||
|             let noMoreSearchResultGroup = true | ||||
|             let noMoreSearchResultGeneral = true | ||||
|             if ( | ||||
|               Object.keys(data).includes('user_infos') && | ||||
|               state.searchResult['user_infos']?.length > 0 | ||||
|             ) { | ||||
|               //搜人 | ||||
|               if (state.searchResult['user_infos']?.length < total) { | ||||
|                 noMoreSearchResultUser = false | ||||
|               } | ||||
|             } | ||||
|             if ( | ||||
|               Object.keys(data).includes('group_member_infos' || 'group_infos') && | ||||
|               state.searchResult['combinedGroup']?.length > 0 | ||||
|             ) { | ||||
|               //搜群 | ||||
|               if (state.searchResult['combinedGroup']?.length < total) { | ||||
|                 noMoreSearchResultGroup = false | ||||
|               } | ||||
|             } | ||||
|             if ( | ||||
|               Object.keys(data).includes('general_infos') && | ||||
|               state.searchResult['general_infos']?.length > 0 | ||||
|             ) { | ||||
|               //搜聊天记录 | ||||
|               if (state.searchResult['general_infos']?.length < total) { | ||||
|                 noMoreSearchResultGeneral = false | ||||
|               } | ||||
|             } | ||||
|             if (noMoreSearchResultUser && noMoreSearchResultGroup && noMoreSearchResultGeneral) { | ||||
|               state.hasMore = false | ||||
|             } else { | ||||
|               state.hasMore = true | ||||
|             } | ||||
|           } | ||||
|           emits('resultTotalCount', total) | ||||
|           // zPaging.value?.completeByTotal([data], total) | ||||
|         } else { | ||||
| @ -719,21 +673,18 @@ async function loadMoreGroupInfos() { | ||||
|     const resp = await ServeQueryGroup(params) | ||||
|     if (resp.code === 200) { | ||||
|       const groupInfos = Array.isArray(resp.data.group_infos) ? resp.data.group_infos : [] | ||||
|       const groupMemberInfos = Array.isArray(resp.data.group_member_infos) | ||||
|         ? resp.data.group_member_infos | ||||
|         : [] | ||||
|       const groupMemberInfos = Array.isArray(resp.data.group_member_infos) ? resp.data.group_member_infos : [] | ||||
| 
 | ||||
|       // 给新数据加上 groupTempType | ||||
|       groupInfos.forEach((item) => { | ||||
|       groupInfos.forEach(item => { | ||||
|         item.groupTempType = 'group_infos' | ||||
|         item.group_type = item.type // 保持一致性 | ||||
|       }) | ||||
|       groupMemberInfos.forEach((item) => { | ||||
|       groupMemberInfos.forEach(item => { | ||||
|         item.groupTempType = 'group_member_infos' | ||||
|       }) | ||||
| 
 | ||||
|       const isFirstLoad = | ||||
|         (!state.groupInfosLastGroupId && !state.groupInfosLastMemberId) || | ||||
|       const isFirstLoad = (!state.groupInfosLastGroupId && !state.groupInfosLastMemberId) || | ||||
|         (state.groupInfosLastGroupId === 0 && state.groupInfosLastMemberId === 0) | ||||
|       if (isFirstLoad) { | ||||
|         // 第一次加载,直接替换 | ||||
| @ -746,9 +697,7 @@ async function loadMoreGroupInfos() { | ||||
|       } else { | ||||
|         // 后续加载,追加 | ||||
|         const allGroupInfos = (state.searchResult.group_infos || []).concat(groupInfos) | ||||
|         const allGroupMemberInfos = (state.searchResult.group_member_infos || []).concat( | ||||
|           groupMemberInfos | ||||
|         ) | ||||
|         const allGroupMemberInfos = (state.searchResult.group_member_infos || []).concat(groupMemberInfos) | ||||
|         state.searchResult = { | ||||
|           ...state.searchResult, | ||||
|           group_infos: allGroupInfos, | ||||
| @ -759,9 +708,10 @@ async function loadMoreGroupInfos() { | ||||
|       state.groupInfosLastGroupId = resp.data.last_group_id | ||||
|       state.groupInfosLastMemberId = resp.data.last_member_id | ||||
|       // 判断是否全部加载完 | ||||
|       const noMoreData = | ||||
|       const noMoreData = ( | ||||
|         (!groupInfos.length && !groupMemberInfos.length) || | ||||
|         (resp.data.last_group_id === 0 && resp.data.last_member_id === 0) | ||||
|       ) | ||||
|       if (noMoreData) { | ||||
|         state.groupInfosExpand = true | ||||
|       } | ||||
| @ -824,7 +774,7 @@ async function loadMoreGroupInfos() { | ||||
|           } | ||||
|         } | ||||
|         .result-has-more:hover { | ||||
|           background-color: rgba(70, 41, 157, 0.1); | ||||
|           background-color: #f8f8f8; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
| @ -7,15 +7,10 @@ import { ITalkRecord } from '@/types/chat' | ||||
| import { useInject } from '@/hooks' | ||||
| import customModal  from '@/components/common/customModal.vue' | ||||
| import { voiceToText } from '@/api/chat.js' | ||||
| import { parseTime } from '@/utils/datetime' | ||||
| const props = defineProps({ | ||||
|   msgId: { | ||||
|     type: String, | ||||
|     required: true | ||||
|   }, | ||||
|   createdAt: { | ||||
|     type: String, | ||||
|     required: false   | ||||
|   } | ||||
| }) | ||||
| const isShow=defineModel<boolean>('show') | ||||
| @ -29,8 +24,7 @@ const onMaskClick = () => { | ||||
| 
 | ||||
| const onLoadData = () => { | ||||
|   ServeGetForwardRecords({ | ||||
|     msg_id: props.msgId, | ||||
|     biz_date: parseTime(new Date(props.createdAt), '{y}{m}') | ||||
|     msg_id: props.msgId | ||||
|   }).then((res) => { | ||||
|     if (res.code == 200) { | ||||
|       items.value = res.data.items || [] | ||||
|  | ||||
| @ -33,7 +33,7 @@ const onClick = () => { | ||||
|       <span>转发:聊天会话记录 ({{ extra.msg_ids.length }}条)</span> | ||||
|     </div> | ||||
| 
 | ||||
|     <ForwardRecord v-model:show="isShowRecord"  :msg-id="data.msg_id" @close="isShowRecord = false" :created-at="data.created_at"/> | ||||
|     <ForwardRecord v-model:show="isShowRecord"  :msg-id="data.msg_id" @close="isShowRecord = false" /> | ||||
|   </section> | ||||
| </template> | ||||
| 
 | ||||
|  | ||||
| @ -171,9 +171,6 @@ const state = reactive({ | ||||
|       title: '姓名 【工号】', | ||||
|       field: 'nickName', | ||||
|       width: 200, | ||||
|       ellipsis: { | ||||
|         tooltip: true | ||||
|       }, | ||||
|       render(row, index) { | ||||
|         return row.nickName + '【' + row.jobNum + '】' | ||||
|       } | ||||
| @ -182,9 +179,7 @@ const state = reactive({ | ||||
|       title: '岗位名称', | ||||
|       field: 'positionName', | ||||
|       width: 400, | ||||
|       ellipsis: { | ||||
|         tooltip: true | ||||
|       }, | ||||
|       ellipsis: true, | ||||
|       render(row, index) { | ||||
|         let positionNames = Array.isArray(row.depPositions) | ||||
|           ? row.depPositions.flatMap((dep) => | ||||
| @ -197,7 +192,7 @@ const state = reactive({ | ||||
|     { | ||||
|       title: '操作', | ||||
|       field: 'action', | ||||
|       width: 180, | ||||
|       width: 200, | ||||
|       align: 'center', | ||||
|       fixed: 'right', | ||||
|       render(row, index) { | ||||
| @ -218,10 +213,7 @@ const state = reactive({ | ||||
|     { | ||||
|       title: '群聊名称', | ||||
|       field: 'groupName', | ||||
|       width: 400, | ||||
|       ellipsis: { | ||||
|         tooltip: true | ||||
|       }, | ||||
|       width: 200, | ||||
|       render(row, index) { | ||||
|         return row.group_name | ||||
|       } | ||||
| @ -229,7 +221,7 @@ const state = reactive({ | ||||
|     { | ||||
|       title: '群类型', | ||||
|       field: 'groupType', | ||||
|       width: 200, | ||||
|       width: 400, | ||||
|       ellipsis: true, | ||||
|       render(row, index) { | ||||
|         let groupType = row.group_type | ||||
| @ -247,7 +239,7 @@ const state = reactive({ | ||||
|     { | ||||
|       title: '操作', | ||||
|       field: 'action', | ||||
|       width: 180, | ||||
|       width: 200, | ||||
|       align: 'center', | ||||
|       fixed: 'right', | ||||
|       render(row, index) { | ||||
| @ -1185,7 +1177,6 @@ html[theme-mode='dark'] { | ||||
|         background-color: #46299d; | ||||
|         color: #fff; | ||||
|       } | ||||
| 
 | ||||
|       .groupChatList-pagination { | ||||
|         display: flex; | ||||
|         justify-content: flex-end; | ||||
| @ -1270,7 +1261,4 @@ html[theme-mode='dark'] { | ||||
|     } | ||||
|   } | ||||
| } | ||||
| :deep(.n-data-table .n-data-table-tr:not(.n-data-table-tr--summary):hover > .n-data-table-td) { | ||||
|   background-color: rgba(70, 41, 157, 0.1) !important; | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -715,12 +715,6 @@ const loadMoreReadListDetail = () => { | ||||
|     state.value.loadingReadListDetail = false | ||||
|   }) | ||||
| } | ||||
| 
 | ||||
| const onCustomSkipBottomEvent = () => { | ||||
|   console.log('onCustomSkipBottomEvent') | ||||
|   onLoad({ ...props, limit: 30 }) | ||||
|   // scrollToBottom() | ||||
| } | ||||
| </script> | ||||
| 
 | ||||
| <template> | ||||
| @ -948,7 +942,7 @@ const onCustomSkipBottomEvent = () => { | ||||
|     </div> | ||||
| 
 | ||||
|     <!-- 置底按钮 --> | ||||
|     <SkipBottom v-model="skipBottom" :customSkipBottomEvent="true" @customSkipBottomEvent="onCustomSkipBottomEvent"/> | ||||
|     <SkipBottom v-model="skipBottom" /> | ||||
|   </section> | ||||
| 
 | ||||
|   <!-- 右键菜单 --> | ||||
|  | ||||
| @ -3,26 +3,20 @@ import { useDialogueStore } from '@/store' | ||||
| import { DoubleDown } from '@icon-park/vue-next' | ||||
| import { scrollToBottom } from '@/utils/dom' | ||||
| 
 | ||||
| const props = defineProps(['modelValue', 'customSkipBottomEvent']) | ||||
| 
 | ||||
| const emit = defineEmits(['customSkipBottomEvent']) | ||||
| defineProps(['modelValue']) | ||||
| 
 | ||||
| const dialogueStore = useDialogueStore() | ||||
| 
 | ||||
| // 聊天版本滚动到底部 | ||||
| const onSkipBottom = () => { | ||||
|   console.log('onSkipBottom') | ||||
|   if(props?.customSkipBottomEvent){ | ||||
|     emit('customSkipBottomEvent') | ||||
|   }else{ | ||||
|   scrollToBottom() | ||||
| } | ||||
| } | ||||
| </script> | ||||
| 
 | ||||
| <template> | ||||
|   <!-- 置底按钮 --> | ||||
|   <div class="skip-bottom pointer" :class="{ show: props?.modelValue }" @click="onSkipBottom"> | ||||
|   <div class="skip-bottom pointer" :class="{ show: modelValue }" @click="onSkipBottom"> | ||||
|     <span v-if="dialogueStore.unreadBubble">{{ dialogueStore.unreadBubble }} 条未读消息</span> | ||||
|     <span v-else>回到底部</span> | ||||
|     <n-icon size="14" color="#fff" :component="DoubleDown" /> | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user