新增更多搜索结果页;将搜索结果列表封装组件;接入搜索聊天记录-群与用户概览接口

This commit is contained in:
wangyifeng 2024-12-30 17:03:40 +08:00
parent e5afaf2cd8
commit 3109e74a41
5 changed files with 199 additions and 170 deletions

View File

@ -9,3 +9,12 @@ export const ServeSeachQueryAll = (data) => {
data,
})
}
// ES搜索聊天记录-指定用户、指定群、群与用户概览
export const ServeTalkRecord = (data) => {
return request({
url: '/api/v1/elasticsearch/query-talk-record',
method: 'POST',
data,
})
}

View File

@ -66,6 +66,14 @@
"navigationStyle": "custom",
"enablePullDownRefresh":false
}
},
{
"path": "pages/search/moreResult/moreResult",
"type": "page",
"style": {
"navigationStyle": "custom",
"enablePullDownRefresh":false
}
}

View File

@ -36,7 +36,11 @@
></searchItem>
</div>
</div>
<div class="result-has-more" v-if="getHasMoreResult(searchResultKey)">
<div
class="result-has-more"
v-if="getHasMoreResult(searchResultKey)"
@click="toMoreResultPage(searchResultKey)"
>
<span class="text-[28rpx] font-regular">
{{ getHasMoreResult(searchResultKey) }}
</span>
@ -126,9 +130,25 @@ const getHasMoreResult = (searchResultKey) => {
}
return has_more_result
}
//
const toMoreResultPage = (searchResultKey) => {
uni.navigateTo({
url:
'/pages/search/moreResult/moreResult?searchResultKey=' +
searchResultKey +
'&searchText=' +
props.searchText,
})
}
</script>
<style lang="scss" scoped>
.search-list {
width: 100%;
display: flex;
flex-direction: row;
align-items: center;
justify-content: center;
.search-result-list {
width: 100%;
padding: 10rpx 18rpx;

View File

@ -25,71 +25,20 @@
!state.searchText ? 'align-items:center;justify-content:center;' : ''
"
>
<div class="search-result-list" v-if="state.searchText">
<div
class="search-result-each-part"
v-for="(searchResultValue,
searchResultKey,
searchResultIndex) in state.searchResult"
:key="searchResultKey"
>
<div
class="search-result-part"
v-if="
Array.isArray(state?.searchResult[searchResultKey]) &&
searchResultKey !== 'group_infos' &&
searchResultKey !== 'group_member_infos'
"
>
<div class="result-title">
<span class="text-[28rpx] font-regular">
{{ getResultKeysValue(searchResultKey) }}
</span>
</div>
<div class="result-list">
<div
class="result-list-each"
v-for="(item, index) in state?.searchResult[searchResultKey]"
:key="index"
>
<searchItem
v-if="index < 3"
:searchResultKey="searchResultKey"
:searchItem="item"
:searchText="state.searchText"
></searchItem>
</div>
</div>
<div
class="result-has-more"
v-if="getHasMoreResult(searchResultKey)"
>
<span class="text-[28rpx] font-regular">
{{ getHasMoreResult(searchResultKey) }}
</span>
</div>
</div>
</div>
</div>
<div class="search-no-result" v-if="!state.searchText">
<img
src="/src/static//image/search/search-no-data.png"
mode="widthFix"
/>
<span class="text-[28rpx] font-regular">{{ $t('search.hint') }}</span>
</div>
<searchList
:searchResult="state.searchResult"
:searchText="state.searchText"
></searchList>
</div>
</div>
</div>
</template>
<script setup>
import searchItem from './components/searchItem.vue'
import searchList from './components/searchList.vue'
import { ServeSeachQueryAll } from '@/api/search/index'
import { ref, watch, computed, onMounted, onUnmounted, reactive } from 'vue'
import { useAuth } from '@/store/auth'
import { useI18n } from 'vue-i18n'
import { nextTick } from 'process'
const { t } = useI18n()
const state = reactive({
searchText: '', //
searchResult: null, //
@ -103,74 +52,6 @@ const inputSearchText = (e) => {
queryAllSearch(searchText)
}
//key
const getResultKeysValue = (keys) => {
let resultKey = ''
switch (keys) {
case 'user_infos':
resultKey = t('index.mine.addressBook')
break
case 'group_infos':
resultKey = t('chat.type.group')
break
case 'group_member_infos':
resultKey = t('chat.type.group')
break
case 'combinedGroup':
resultKey = t('chat.type.group')
break
case 'general_infos':
resultKey = t('chat.type.record')
break
default:
resultKey = ''
}
return resultKey
}
//
const getHasMoreResult = (searchResultKey) => {
let has_more_result = ''
switch (searchResultKey) {
case 'user_infos':
if (
state.searchResult['user_count'] &&
state.searchResult['user_count'] > 3
) {
has_more_result = t('has_more') + t('index.mine.addressBook')
}
break
case 'group_infos':
if (
state.searchResult['group_count'] &&
state.searchResult['group_count'] > 3
) {
has_more_result = t('has_more') + t('chat.type.group')
}
break
case 'group_member_infos':
if (
state.searchResult['group_count'] &&
state.searchResult['group_count'] > 3
) {
has_more_result = t('has_more') + t('chat.type.group')
}
break
case 'combinedGroup':
if (
state.searchResult['group_count'] &&
state.searchResult['group_count'] > 3
) {
has_more_result = t('has_more') + t('chat.type.group')
}
break
case 'general_infos':
break
default:
}
return has_more_result
}
// ES-
const queryAllSearch = (searchText) => {
let params = {
@ -281,51 +162,6 @@ page {
flex-direction: row;
align-items: flex-start;
justify-content: flex-start;
.search-result-list {
width: 100%;
padding: 10rpx 18rpx;
.search-result-each-part {
margin: 46rpx 0 0;
.result-title {
padding: 0 0 10rpx;
span {
line-height: 40rpx;
color: $theme-hint-text;
}
}
.result-has-more {
padding: 10px 0;
border-bottom: 1px solid $theme-border-color;
span {
color: #191919;
line-height: 40rpx;
}
}
}
}
.search-no-result {
width: 476rpx;
height: 261rpx;
display: flex;
flex-direction: column;
align-items: center;
justify-content: flex-start;
img {
width: 100%;
height: 100%;
}
span {
color: $theme-hint-text;
margin: -20rpx 0 0;
line-height: 40rpx;
}
}
}
}
</style>

View File

@ -0,0 +1,156 @@
<template>
<div class="outer-layer search-page">
<div class="root">
<div class="searchRoot">
<tm-input
class="searchRoot_input"
placeholder="请输入…"
color="#F9F9FD"
:round="1"
prefix="tmicon-search"
prefixColor="#46299D"
v-model.lazy="state.searchText"
@input="inputSearchText"
></tm-input>
<span
class="searchRoot_cancelBtn text-[32rpx] font-medium"
@click="cancelSearch"
>
{{ $t('cancel') }}
</span>
</div>
<div
class="search-result"
:style="
!state.searchText ? 'align-items:center;justify-content:center;' : ''
"
>
<searchList
:searchResult="state.searchResult"
:searchText="state.searchText"
></searchList>
</div>
</div>
</div>
</template>
<script setup>
import searchList from '../components/searchList.vue'
import { onLoad } from '@dcloudio/uni-app'
import { ServeSeachQueryAll } from '@/api/search/index'
import { ref, watch, computed, onMounted, onUnmounted, reactive } from 'vue'
import { useAuth } from '@/store/auth'
import { nextTick } from 'process'
const state = reactive({
searchText: '', //
searchResult: null, //
searchResultPageSize: 10, //
searchResultKey: '',
})
onLoad((options) => {
console.log(options)
if (options.searchResultKey) {
state.searchResultKey = options.searchResultKey
}
if (options.searchText) {
state.searchText = options.searchText
}
})
//
const inputSearchText = (e) => {
console.log(e)
let searchText = e
queryAllSearch(searchText)
}
// ES-
const queryAllSearch = (searchText) => {
let talk_type = 0
if (state.searchResultKey === 'user_infos') {
talk_type = 1
} else if (state.searchResultKey === 'combinedGroup') {
talk_type = 2
} else if (state.searchResultKey === 'general_infos') {
talk_type = 0
}
let params = {
talk_type: talk_type, //12
receiver_id: 0, //recevier_id
key: searchText, //
size: state.searchResultPageSize, //
last_group_id: 0,
last_member_id: 0, //,
}
const resp = ServeTalkRecord(params)
resp.then(({ code, data }) => {
console.log(data)
if (code == 200) {
} else {
}
})
resp.catch(() => {})
}
//
const cancelSearch = () => {
uni.navigateBack({
delta: 1,
})
}
</script>
<style scoped lang="scss">
uni-page-body,
page {
height: 100%;
}
.outer-layer {
flex: 1;
display: flex;
flex-direction: column;
overflow: hidden;
}
.root {
flex: 1;
padding: 20rpx 32rpx;
min-height: 0;
display: flex;
flex-direction: column;
overflow: hidden;
}
.search-page {
.searchRoot {
padding: 0 16rpx;
display: flex;
flex-direction: row;
align-items: center;
justify-content: flex-start;
.searchRoot_input {
width: 100%;
}
.searchRoot_cancelBtn {
line-height: 44rpx;
color: $theme-primary;
margin: 0 0 0 20rpx;
flex-shrink: 0;
}
}
.search-result {
width: 100%;
flex: 1;
min-height: 0;
display: flex;
flex-direction: row;
align-items: flex-start;
justify-content: flex-start;
}
}
</style>