Compare commits
	
		
			No commits in common. "8eb0f0b4f224d815505dcded8e9abf06ec352a70" and "ba52f9a576786699b2afadfbdcc5e774fccf938b" have entirely different histories.
		
	
	
		
			8eb0f0b4f2
			...
			ba52f9a576
		
	
		
| @ -31,16 +31,15 @@ | ||||
|     "@uni-helper/axios-adapter": "^1.5.2", | ||||
|     "@uni-helper/localforage-adapter": "^1.0.2", | ||||
|     "@uni-helper/uni-use": "^0.19.12", | ||||
|     "@vueuse/core": "^9.13.0", | ||||
|     "@vueup/vue-quill": "^1.2.0", | ||||
|     "quill": "^1.3.7", | ||||
|     "quill-mention": "^4.1.0", | ||||
|     "@vueuse/core": "^9.13.0", | ||||
|     "axios": "^1.7.2", | ||||
|     "dayjs": "^1.11.12", | ||||
|     "less": "^4.2.0", | ||||
|     "lodash": "^4.17.21", | ||||
|     "nzh": "^1.0.13", | ||||
|     "pinia-plugin-persistedstate": "^4.1.3", | ||||
|     "quill-mention": "^6.0.2", | ||||
|     "vconsole": "^3.15.1", | ||||
|     "vue": "^3.3.8", | ||||
|     "vue-i18n": "11.0.0-rc.1" | ||||
|  | ||||
| @ -86,12 +86,9 @@ importers: | ||||
|       pinia-plugin-persistedstate: | ||||
|         specifier: ^4.1.3 | ||||
|         version: 4.1.3(pinia@2.0.36(typescript@5.5.4)(vue@3.4.35(typescript@5.5.4)))(rollup@4.19.2) | ||||
|       quill: | ||||
|         specifier: ^1.3.7 | ||||
|         version: 1.3.7 | ||||
|       quill-mention: | ||||
|         specifier: ^4.1.0 | ||||
|         version: 4.1.0 | ||||
|         specifier: ^6.0.2 | ||||
|         version: 6.0.2 | ||||
|       vconsole: | ||||
|         specifier: ^3.15.1 | ||||
|         version: 3.15.1 | ||||
| @ -3000,6 +2997,9 @@ packages: | ||||
|   fast-diff@1.2.0: | ||||
|     resolution: {integrity: sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==} | ||||
| 
 | ||||
|   fast-diff@1.3.0: | ||||
|     resolution: {integrity: sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==} | ||||
| 
 | ||||
|   fast-glob@3.3.2: | ||||
|     resolution: {integrity: sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==} | ||||
|     engines: {node: '>=8.6.0'} | ||||
| @ -3986,6 +3986,9 @@ packages: | ||||
|   parchment@1.1.4: | ||||
|     resolution: {integrity: sha512-J5FBQt/pM2inLzg4hEWmzQx/8h8D0CiDxaG3vyp9rKrQRSDgBlhjdP5jQGgosEajXPSQouXGHOmVdgo7QmJuOg==} | ||||
| 
 | ||||
|   parchment@3.0.0: | ||||
|     resolution: {integrity: sha512-HUrJFQ/StvgmXRcQ1ftY6VEZUq3jA2t9ncFN4F84J/vN0/FPpQF+8FKXb3l6fLces6q0uOHj6NJn+2xvZnxO6A==} | ||||
| 
 | ||||
|   parse-bmfont-ascii@1.0.6: | ||||
|     resolution: {integrity: sha512-U4RrVsUFCleIOBsIGYOMKjn9PavsGOXxbvYGtMOEfnId0SVNsgehXh1DxUdVPLoxd5mvcEtvmKs2Mmf0Mpa1ZA==} | ||||
| 
 | ||||
| @ -4259,12 +4262,20 @@ packages: | ||||
|   quill-delta@4.2.2: | ||||
|     resolution: {integrity: sha512-qjbn82b/yJzOjstBgkhtBjN2TNK+ZHP/BgUQO+j6bRhWQQdmj2lH6hXG7+nwwLF41Xgn//7/83lxs9n2BkTtTg==} | ||||
| 
 | ||||
|   quill-mention@4.1.0: | ||||
|     resolution: {integrity: sha512-dT8HLYeuGU8yjjUr5SgdOusFSqQ7FQt/DWefz4V/L2omJsZ9CVYWepg3GyqV/evNDV7LQtfM7cadxtYD2bi2ew==} | ||||
|   quill-delta@5.1.0: | ||||
|     resolution: {integrity: sha512-X74oCeRI4/p0ucjb5Ma8adTXd9Scumz367kkMK5V/IatcX6A0vlgLgKbzXWy5nZmCGeNJm2oQX0d2Eqj+ZIlCA==} | ||||
|     engines: {node: '>= 12.0.0'} | ||||
| 
 | ||||
|   quill-mention@6.0.2: | ||||
|     resolution: {integrity: sha512-ZyiEzLxtoNJ/hAjMyfVsugpXAcOdD2fbHmJT3yKuwpUxiDHdmutVJqOzpItqiVbcjUecnjAF+/Yo1IN3/W6iAg==} | ||||
| 
 | ||||
|   quill@1.3.7: | ||||
|     resolution: {integrity: sha512-hG/DVzh/TiknWtE6QmWAF/pxoZKYxfe3J/d/+ShUWkDvvkZQVTPeVmUJVu1uE6DDooC4fWTiCLh84ul89oNz5g==} | ||||
| 
 | ||||
|   quill@2.0.2: | ||||
|     resolution: {integrity: sha512-QfazNrhMakEdRG57IoYFwffUIr04LWJxbS/ZkidRFXYCQt63c1gK6Z7IHUXMx/Vh25WgPBU42oBaNzQ0K1R/xw==} | ||||
|     engines: {npm: '>=8.2.3'} | ||||
| 
 | ||||
|   range-parser@1.2.1: | ||||
|     resolution: {integrity: sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==} | ||||
|     engines: {node: '>= 0.6'} | ||||
| @ -8945,6 +8956,8 @@ snapshots: | ||||
| 
 | ||||
|   fast-diff@1.2.0: {} | ||||
| 
 | ||||
|   fast-diff@1.3.0: {} | ||||
| 
 | ||||
|   fast-glob@3.3.2: | ||||
|     dependencies: | ||||
|       '@nodelib/fs.stat': 2.0.5 | ||||
| @ -10140,6 +10153,8 @@ snapshots: | ||||
| 
 | ||||
|   parchment@1.1.4: {} | ||||
| 
 | ||||
|   parchment@3.0.0: {} | ||||
| 
 | ||||
|   parse-bmfont-ascii@1.0.6: {} | ||||
| 
 | ||||
|   parse-bmfont-binary@1.0.6: {} | ||||
| @ -10392,9 +10407,15 @@ snapshots: | ||||
|       lodash.clonedeep: 4.5.0 | ||||
|       lodash.isequal: 4.5.0 | ||||
| 
 | ||||
|   quill-mention@4.1.0: | ||||
|   quill-delta@5.1.0: | ||||
|     dependencies: | ||||
|       quill: 1.3.7 | ||||
|       fast-diff: 1.3.0 | ||||
|       lodash.clonedeep: 4.5.0 | ||||
|       lodash.isequal: 4.5.0 | ||||
| 
 | ||||
|   quill-mention@6.0.2: | ||||
|     dependencies: | ||||
|       quill: 2.0.2 | ||||
| 
 | ||||
|   quill@1.3.7: | ||||
|     dependencies: | ||||
| @ -10405,6 +10426,13 @@ snapshots: | ||||
|       parchment: 1.1.4 | ||||
|       quill-delta: 3.6.3 | ||||
| 
 | ||||
|   quill@2.0.2: | ||||
|     dependencies: | ||||
|       eventemitter3: 5.0.1 | ||||
|       lodash-es: 4.17.21 | ||||
|       parchment: 3.0.0 | ||||
|       quill-delta: 5.1.0 | ||||
| 
 | ||||
|   range-parser@1.2.1: {} | ||||
| 
 | ||||
|   raw-body@2.5.2: | ||||
|  | ||||
| @ -45,12 +45,3 @@ export const ServeTalkDate = (data) => { | ||||
|     data, | ||||
|   }) | ||||
| } | ||||
| 
 | ||||
| //获取会话Id
 | ||||
| export const ServeGetSessionId = (data) => { | ||||
|   return request({ | ||||
|     url: '/api/v1/talk/session/getId', | ||||
|     method: 'POST', | ||||
|     data, | ||||
|   }) | ||||
| } | ||||
| @ -21,20 +21,9 @@ | ||||
| <script setup> | ||||
| import { defineProps, defineEmits, reactive, watch } from 'vue' | ||||
| const props = defineProps({ | ||||
|   searchText: { | ||||
|     type: String, | ||||
|     default: '' | ||||
|   }, | ||||
|   first_talk_record_infos: { | ||||
|     type: Object, | ||||
|     default(){ | ||||
|       return {} | ||||
|     } | ||||
|   }, | ||||
|   disabled: { | ||||
|     type: Boolean, | ||||
|     default: false | ||||
|   }, | ||||
|   searchText: String, | ||||
|   first_talk_record_infos: Object, | ||||
|   disabled: Boolean, | ||||
| }) | ||||
| const state = reactive({ | ||||
|   searchText: '', //搜索内容 | ||||
|  | ||||
| @ -25,33 +25,33 @@ const getFileTypeIMG = computed(() => { | ||||
|   let objT = { | ||||
|     finishedImg: '', | ||||
|     blankImg: '', | ||||
|     progressColor: '', | ||||
|   } | ||||
|     progressColor: '' | ||||
|   }; | ||||
| 
 | ||||
|   switch (suffix) { | ||||
|     case 'pdf': | ||||
|       objT.finishedImg = filePaperPDF | ||||
|       objT.blankImg = filePaperPDFBlank | ||||
|       objT.progressColor = '#DE4E4E' | ||||
|       break | ||||
|       break; | ||||
|     case 'doc': | ||||
|     case 'docx': | ||||
|       objT.finishedImg = filePaperWord | ||||
|       objT.blankImg = filePaperWordBlank | ||||
|       objT.progressColor = '#2750B2' | ||||
|       break | ||||
|       break; | ||||
|     case 'xls': | ||||
|     case 'xlsx': | ||||
|       objT.finishedImg = filePaperExcel | ||||
|       objT.blankImg = filePaperExcelBlank | ||||
|       objT.progressColor = '#3C7F4B' | ||||
|       break | ||||
|       break; | ||||
|     case 'ppt': | ||||
|     case 'pptx': | ||||
|       objT.finishedImg = filePaperPPT | ||||
|       objT.blankImg = filePaperPPTBlank | ||||
|       objT.progressColor = '#B74B2B' | ||||
|       break | ||||
|       break; | ||||
|     default: | ||||
|       objT.finishedImg = filePaperOther | ||||
|       objT.blankImg = filePaperOtherBlank | ||||
| @ -60,78 +60,22 @@ const getFileTypeIMG = computed(() => { | ||||
|   return objT | ||||
| }) | ||||
| 
 | ||||
| const previewPDF = () => { | ||||
|   if (typeof plus !== 'undefined') { | ||||
|     downloadAndOpenFile() | ||||
|   } else { | ||||
|     document.addEventListener('plusready', () => { | ||||
|       downloadAndOpenFile() | ||||
|     }) | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| const downloadAndOpenFile = () => { | ||||
|   uni.showLoading({ title: '加载中...', mask: true }) | ||||
|   const downloadUrl = props?.extra?.path | ||||
|   if (!downloadUrl) { | ||||
|     uni.hideLoading() | ||||
|     uni.showToast({ title: '文件路径无效', icon: 'none' }) | ||||
|     return | ||||
|   } | ||||
|   const options = { | ||||
|     filename: '_doc/downloads/', // 保存路径 | ||||
|   } | ||||
|   const dtask = plus.downloader.createDownload(downloadUrl, options, function ( | ||||
|     d, | ||||
|     status, | ||||
|   ) { | ||||
|     if (status === 200) { | ||||
|       uni.hideLoading() | ||||
|       const filePath = d.filename | ||||
|       if (filePath) { | ||||
|         plus.runtime.openFile(filePath, {}, function () {}) | ||||
|       } else { | ||||
|         uni.showToast({ title: '文件路径无效', icon: 'none' }) | ||||
|       } | ||||
|     } else { | ||||
|       uni.hideLoading() | ||||
|     } | ||||
|   }) | ||||
|   dtask.start() | ||||
| } | ||||
| </script> | ||||
| 
 | ||||
| <template> | ||||
|   <section | ||||
|     class="file-message" | ||||
|     @click="previewPDF" | ||||
|     :class="{ left: data.float === 'left', right: data.float === 'right' }" | ||||
|   > | ||||
|     <div class="flex justify-between"> | ||||
|       <div | ||||
|         class="w-[228rpx] text-[32rpx] text-[#1A1A1A] h-[88rpx] leading-[44rpx] textEllipsis file_name" | ||||
|       > | ||||
|       <div class="w-[228rpx] text-[32rpx] text-[#1A1A1A] h-[88rpx] leading-[44rpx] textEllipsis file_name"> | ||||
|         {{ extra.name }} | ||||
|       </div> | ||||
|       <div | ||||
|         v-if="data.uploadStatus === 2 || !data.uploadStatus" | ||||
|         class="w-[95rpx]" | ||||
|       > | ||||
|         <tm-image | ||||
|           :width="95" | ||||
|           :height="95" | ||||
|           :src="getFileTypeIMG.finishedImg" | ||||
|         ></tm-image> | ||||
|       <div v-if="data.uploadStatus === 2 || !data.uploadStatus" class="w-[95rpx]"> | ||||
|         <tm-image :width="95" :height="95" :src="getFileTypeIMG.finishedImg"></tm-image> | ||||
|       </div> | ||||
|       <div | ||||
|         v-if="data.uploadStatus === 1 || data.uploadStatus === 3" | ||||
|         class="w-[95rpx]" | ||||
|       > | ||||
|         <tm-image | ||||
|           :width="95" | ||||
|           :height="95" | ||||
|           :src="getFileTypeIMG.blankImg" | ||||
|         ></tm-image> | ||||
|       <div v-if="data.uploadStatus === 1 || data.uploadStatus === 3"  class="w-[95rpx]"> | ||||
|         <tm-image :width="95" :height="95" :src="getFileTypeIMG.blankImg"></tm-image> | ||||
|           <wd-circle | ||||
|             customClass="circleProgress" | ||||
|             :modelValue="data.uploadCurrent" | ||||
| @ -143,9 +87,7 @@ const downloadAndOpenFile = () => { | ||||
|       </div> | ||||
|     </div> | ||||
|     <div class="divider mt-[28rpx]"></div> | ||||
|     <div class="text-[24rpx] text-[#747474] mt-[10rpx]"> | ||||
|       {{ fileFormatSize(extra.size) }} | ||||
|     </div> | ||||
|     <div class="text-[24rpx] text-[#747474] mt-[10rpx]">{{ fileFormatSize(extra.size) }}</div> | ||||
|     <!-- <div class="main"> | ||||
|       <div class="ext">{{ getFileNameSuffix(extra.name) }}</div> | ||||
|       <div class="file-box"> | ||||
| @ -275,7 +217,7 @@ const downloadAndOpenFile = () => { | ||||
| } | ||||
| 
 | ||||
| .divider { | ||||
|   background-color: #e7e7e7; | ||||
|   background-color: #E7E7E7; | ||||
|   height: 1rpx; | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -379,12 +379,6 @@ const handleClickItem = (item) => { | ||||
|     } | ||||
|     return | ||||
|   } | ||||
|   if(props?.manageType === 'searchRecord'){ | ||||
|     uni.navigateTo({ | ||||
|       url: '/pages/search/searchByCondition/index?condition=member' | ||||
|     }) | ||||
|     return | ||||
|   } | ||||
|   let itemList = dialogueParams.memberList | ||||
|   if ( | ||||
|     props?.manageType === 'admin' && | ||||
|  | ||||
| @ -96,9 +96,7 @@ | ||||
|             </div> | ||||
|           </div> | ||||
|           <div class="chat-records-search chat-settings-card"> | ||||
|             <div @click="toSearchPage"> | ||||
|             <customInput :disabled="true"></customInput> | ||||
|             </div> | ||||
|             <div class="record-search-types"> | ||||
|               <div | ||||
|                 class="record-search-types-each" | ||||
| @ -153,10 +151,8 @@ | ||||
|               @click="showConfirmPrompt(2)" | ||||
|               class="clear-chat-record-btn-each" | ||||
|               v-if=" | ||||
|                 groupParams?.groupInfo?.is_manager && | ||||
|                 dialogueParams.type === 2 && | ||||
|                 (groupParams?.groupInfo?.group_type === 1 || | ||||
|                   groupParams?.groupInfo?.group_type === 3) | ||||
|                 groupParams?.groupInfo?.is_manager && dialogueParams.type === 2 | ||||
|                 && (groupParams?.groupInfo?.group_type === 1 || groupParams?.groupInfo?.group_type === 3) | ||||
|               " | ||||
|             > | ||||
|               <span class="text-[32rpx] font-regular"> | ||||
| @ -167,10 +163,8 @@ | ||||
|               @click="showConfirmPrompt(3)" | ||||
|               class="clear-chat-record-btn-each" | ||||
|               v-if=" | ||||
|                 groupParams?.groupInfo?.is_manager && | ||||
|                 dialogueParams.type === 2 && | ||||
|                 (groupParams?.groupInfo?.group_type === 1 || | ||||
|                   groupParams?.groupInfo?.group_type === 3) | ||||
|                 groupParams?.groupInfo?.is_manager && dialogueParams.type === 2 | ||||
|                 && (groupParams?.groupInfo?.group_type === 1 || groupParams?.groupInfo?.group_type === 3) | ||||
|               " | ||||
|             > | ||||
|               <span class="text-[32rpx] font-regular"> | ||||
| @ -505,7 +499,10 @@ const toSearchByConditionPage = (flag) => { | ||||
|     } | ||||
|     uni.navigateTo({ | ||||
|       url: | ||||
|         '/pages/search/searchByCondition/index?condition=' + condition | ||||
|         '/pages/search/searchByCondition/index?condition=' + | ||||
|         condition + | ||||
|         '&receiver_id=' + | ||||
|         state.groupId, | ||||
|     }) | ||||
|   } | ||||
| } | ||||
| @ -632,21 +629,6 @@ const inviteMembersInGroup = async (memberList) => { | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| //点击跳转到搜索页面 | ||||
| const toSearchPage = () => { | ||||
|   // uni.navigateTo({ | ||||
|   //   url: | ||||
|   //     '/pages/search/searchByCondition/index?condition=text' | ||||
|   // }) | ||||
|   uni.navigateTo({ | ||||
|     url: | ||||
|       '/pages/search/moreResult/moreResultDetail?talk_type=' + | ||||
|       dialogueParams.type + | ||||
|       '&receiver_id=' + | ||||
|       dialogueParams.receiver_id, | ||||
|   }) | ||||
| } | ||||
| </script> | ||||
| <style scoped lang="scss"> | ||||
| .outer-layer { | ||||
|  | ||||
| @ -1,39 +1,25 @@ | ||||
| <template> | ||||
|   <div class="emojiRoot"> | ||||
|     <div | ||||
|       @click="() => photoActionsSelect(0)" | ||||
|       class="flex flex-col items-center" | ||||
|     > | ||||
|       <div | ||||
|         class="w-[106rpx] h-[106rpx] bg-[#F9F9F9] rounded-[60rpx] flex-center" | ||||
|       > | ||||
|     <div @click="()=>photoActionsSelect(0)" class="flex flex-col items-center"> | ||||
|       <div class="w-[106rpx] h-[106rpx] bg-[#F9F9F9] rounded-[60rpx] flex-center"> | ||||
|         <tm-image :width="53" :height="44" :src="photoAlbum"></tm-image> | ||||
|       </div> | ||||
|       <div class="mt-[6rpx] text-[#666666] text-[24rpx]">照片</div> | ||||
|     </div> | ||||
|     <div | ||||
|       @click="() => photoActionsSelect(1)" | ||||
|       class="flex flex-col items-center" | ||||
|     > | ||||
|       <div | ||||
|         class="w-[106rpx] h-[106rpx] bg-[#F9F9F9] rounded-[60rpx] flex-center" | ||||
|       > | ||||
|     <div @click="()=>photoActionsSelect(1)" class="flex flex-col items-center"> | ||||
|       <div class="w-[106rpx] h-[106rpx] bg-[#F9F9F9] rounded-[60rpx] flex-center"> | ||||
|         <tm-image :width="53" :height="44" :src="videoImg"></tm-image> | ||||
|       </div> | ||||
|       <div class="mt-[6rpx] text-[#666666] text-[24rpx]">视频</div> | ||||
|     </div> | ||||
|     <div @click="takePhoto" class="flex flex-col items-center"> | ||||
|       <div | ||||
|         class="w-[106rpx] h-[106rpx] bg-[#F9F9F9] rounded-[60rpx] flex-center" | ||||
|       > | ||||
|       <div class="w-[106rpx] h-[106rpx] bg-[#F9F9F9] rounded-[60rpx] flex-center"> | ||||
|         <tm-image :width="53" :height="44" :src="photoGraph"></tm-image> | ||||
|       </div> | ||||
|       <div class="mt-[6rpx] text-[#666666] text-[24rpx]">拍摄</div> | ||||
|     </div> | ||||
|     <div @click="chooseFile" class="flex flex-col items-center"> | ||||
|       <div | ||||
|         class="w-[106rpx] h-[106rpx] bg-[#F9F9F9] rounded-[60rpx] flex-center" | ||||
|       > | ||||
|       <div class="w-[106rpx] h-[106rpx] bg-[#F9F9F9] rounded-[60rpx] flex-center"> | ||||
|         <tm-image :width="53" :height="44" :src="folder"></tm-image> | ||||
|       </div> | ||||
|       <div class="mt-[6rpx] text-[#666666] text-[24rpx]">文件</div> | ||||
| @ -41,15 +27,10 @@ | ||||
|   </div> | ||||
| </template> | ||||
| <script setup> | ||||
| import { ref, reactive, defineProps, defineEmits } from 'vue' | ||||
| import dayjs from 'dayjs' | ||||
| import { ref, reactive, defineProps, defineEmits } from "vue" | ||||
| import dayjs from "dayjs"; | ||||
| import { beautifyTime } from '@/utils/datetime' | ||||
| import { | ||||
|   useDialogueListStore, | ||||
|   useDialogueStore, | ||||
|   useUserStore, | ||||
|   useUploadsStore, | ||||
| } from '@/store' | ||||
| import { useDialogueListStore, useDialogueStore, useUserStore,useUploadsStore } from '@/store' | ||||
| import { useSessionMenu } from '@/hooks' | ||||
| import photoAlbum from '@/static/image/chatList/photoAlbum.png' | ||||
| import photoGraph from '@/static/image/chatList/photoGraph.png' | ||||
| @ -62,34 +43,26 @@ const props = defineProps({ | ||||
|   sendUserInfo: { | ||||
|     type: Object, | ||||
|     default: {}, | ||||
|     required: true, | ||||
|     required: true | ||||
|   }, | ||||
|   talkParams: { | ||||
|     type: Object, | ||||
|     default: {}, | ||||
|     required: true, | ||||
|   }, | ||||
| }) | ||||
| 
 | ||||
| const state = reactive({ | ||||
|   base64Url: '' | ||||
| }) | ||||
|     required: true | ||||
|   } | ||||
| }); | ||||
| 
 | ||||
| const uploadsStore = useUploadsStore() | ||||
| const { | ||||
|   addDialogueRecord, | ||||
|   virtualList, | ||||
|   updateUploadProgress, | ||||
| } = useDialogueListStore() | ||||
| const { addDialogueRecord, virtualList, updateUploadProgress } = useDialogueListStore() | ||||
| const dialogueStore = useDialogueStore() | ||||
| const userStore = useUserStore() | ||||
| 
 | ||||
| const emit = defineEmits(['selectImg']) | ||||
| 
 | ||||
| const onProgressFn = (progress, id) => { | ||||
|   console.log((progress.loaded / progress.total) * 100, 'progress') | ||||
|   console.log(progress.loaded / progress.total * 100, 'progress'); | ||||
| 
 | ||||
|   updateUploadProgress(id, (progress.loaded / progress.total) * 100) | ||||
|   updateUploadProgress(id, progress.loaded / progress.total * 100) | ||||
| } | ||||
| 
 | ||||
| const photoActionsSelect = (index) => { | ||||
| @ -98,31 +71,28 @@ const photoActionsSelect = (index) => { | ||||
|       sourceType: ['album'], | ||||
|       count: 9, | ||||
|       success: async (res) => { | ||||
|         console.log(res, 'res') | ||||
|         console.log(res,'res'); | ||||
|         res.tempFiles.forEach(async (file) => { | ||||
|           let data = await onUploadImageVideo(file, 'image') | ||||
|           emit('selectImg', data, data.file_num) | ||||
|         }) | ||||
|       }, | ||||
|       } | ||||
|     }) | ||||
|   }else{ | ||||
|     uni.chooseVideo({ | ||||
|       sourceType: ['album'], | ||||
|       success: async (res) => { | ||||
|         console.log(res, 'res') | ||||
|         let data = await onUploadImageVideo( | ||||
|           res.tempFile, | ||||
|           'video', | ||||
|           res.tempFilePath, | ||||
|         ) | ||||
|         console.log(res,'res'); | ||||
|         let data = await onUploadImageVideo(res.tempFile, 'video',res.tempFilePath) | ||||
|         emit('selectImg', data, data.file_num) | ||||
|       }, | ||||
|       } | ||||
|     }) | ||||
|   } | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| const onUploadImageVideo = async (file, type = 'image',fileUrl) => { | ||||
|   console.log(file, 'file') | ||||
|   console.log(file, 'file'); | ||||
|   return new Promise(async (resolve) => { | ||||
|     if (type === 'image') { | ||||
|       let image = new Image() | ||||
| @ -130,20 +100,20 @@ const onUploadImageVideo = async (file, type = 'image', fileUrl) => { | ||||
|       image.onload = () => { | ||||
|         const form = new FormData() | ||||
|         form.append('file', file) | ||||
|         form.append('source', 'fonchain-chat') | ||||
|         form.append('urlParam', `width=${image.width}&height=${image.height}`) | ||||
|         form.append("source", "fonchain-chat"); | ||||
|         form.append("urlParam", `width=${image.width}&height=${image.height}`); | ||||
|         let randomId = uniqueId() | ||||
|         let newItem = { | ||||
|           avatar: userStore.avatar, | ||||
|           created_at: dayjs().format('YYYY-MM-DD HH:mm:ss'), | ||||
|           extra: { | ||||
|             height: image.height, | ||||
|             name: '', | ||||
|             name: "", | ||||
|             size: 0, | ||||
|             url: image.src, | ||||
|             width: image.width, | ||||
|             width: image.width | ||||
|           }, | ||||
|           float: 'right', | ||||
|           float: "right", | ||||
|           isCheck: false, | ||||
|           is_mark: 0, | ||||
|           is_read: 0, | ||||
| @ -161,8 +131,7 @@ const onUploadImageVideo = async (file, type = 'image', fileUrl) => { | ||||
|         } | ||||
| 
 | ||||
|         virtualList.value.unshift(newItem) | ||||
|         uploadImg(form, (e) => onProgressFn(e, randomId)).then( | ||||
|           ({ status, data, msg }) => { | ||||
|         uploadImg(form, (e) => onProgressFn(e, randomId)).then(({ status, data, msg }) => { | ||||
|           if (status == 0) { | ||||
|             resolve({ | ||||
|               type: 'image', | ||||
| @ -176,18 +145,17 @@ const onUploadImageVideo = async (file, type = 'image', fileUrl) => { | ||||
|             resolve('') | ||||
|             message.error(msg) | ||||
|           } | ||||
|           }, | ||||
|         ) | ||||
|         }) | ||||
|       } | ||||
|     } else { | ||||
|       uni.getVideoInfo({ | ||||
|         src:fileUrl, | ||||
|         success:(resp)=>{ | ||||
|           console.log(resp) | ||||
|         console.log(resp); | ||||
|         form.append('file', file) | ||||
|           form.append('source', 'fonchain-chat') | ||||
|           form.append('type', 'video') | ||||
|           form.append('urlParam', `width=${resp.width}&height=${resp.height}`) | ||||
|         form.append("source", "fonchain-chat"); | ||||
|         form.append("type", "video"); | ||||
|         form.append("urlParam", `width=${resp.width}&height=${resp.height}`); | ||||
|         let randomId = uniqueId() | ||||
|         let newItem = { | ||||
|           avatar: userStore.avatar, | ||||
| @ -195,11 +163,11 @@ const onUploadImageVideo = async (file, type = 'image', fileUrl) => { | ||||
|           extra: { | ||||
|             duration: parseInt(resp.duration), | ||||
|             height: resp.height, | ||||
|               name: '', | ||||
|             name: "", | ||||
|             url: fileUrl, | ||||
|               width: resp.width, | ||||
|             width: resp.width | ||||
|           }, | ||||
|             float: 'right', | ||||
|           float: "right", | ||||
|           isCheck: false, | ||||
|           is_mark: 0, | ||||
|           is_read: 0, | ||||
| @ -216,10 +184,9 @@ const onUploadImageVideo = async (file, type = 'image', fileUrl) => { | ||||
|           uploadStatus: 1,  // 1 上传中 2 上传成功 3 上传失败 | ||||
|         } | ||||
|         virtualList.value.unshift(newItem) | ||||
|           uploadImg(form, (e) => onProgressFn(e, randomId)).then( | ||||
|             ({ status, data, msg }) => { | ||||
|         uploadImg(form, (e) => onProgressFn(e, randomId)).then(({ status, data, msg }) => { | ||||
|           if (status == 0) { | ||||
|                 console.log(data) | ||||
|             console.log(data); | ||||
|             resolve({ | ||||
|               type: 'video', | ||||
|               url: data.ori_url, | ||||
| @ -232,9 +199,8 @@ const onUploadImageVideo = async (file, type = 'image', fileUrl) => { | ||||
|             // resolve('') | ||||
|             // message.error(msg) | ||||
|           } | ||||
|             }, | ||||
|           ) | ||||
|         }, | ||||
|         }) | ||||
|         } | ||||
|       }) | ||||
|       const form = new FormData() | ||||
|     } | ||||
| @ -243,59 +209,58 @@ const onUploadImageVideo = async (file, type = 'image', fileUrl) => { | ||||
| 
 | ||||
| const base64ToFile = (base64) => { | ||||
|   // base64转file | ||||
|   const [header, base64String] = base64.split(';base64,') | ||||
|   const imageType = header.split(':')[1] | ||||
|   const byteCharacters = atob(base64String) | ||||
|   const [header, base64String] = base64.split(";base64,"); | ||||
|   const imageType = header.split(":")[1]; | ||||
|   const byteCharacters = atob(base64String); | ||||
|   const byteArray = new Uint8Array( | ||||
|     Array.from(byteCharacters, (char) => char.charCodeAt(0)), | ||||
|   ) | ||||
|   return new File([new Blob([byteArray], { type: imageType })], 'example.png', { | ||||
|     type: imageType, | ||||
|   }) | ||||
|     Array.from(byteCharacters, (char) => char.charCodeAt(0)) | ||||
|   ); | ||||
|   return new File( | ||||
|     [new Blob([byteArray], { type: imageType })], | ||||
|     "example.png", | ||||
|     { type: imageType } | ||||
|   ); | ||||
| } | ||||
| 
 | ||||
| const choosePhoto = (filter = 'none', maximum = 9, multiple = true) => { | ||||
|   window.plus?.gallery.pick( | ||||
|     (res) => { | ||||
|       console.log(res) | ||||
|   window.plus?.gallery.pick((res) => { | ||||
|     console.log(res); | ||||
|     res.files.reverse() | ||||
|     res.files.forEach(async (filePath) => { | ||||
|       const suffix = filePath.split('.').pop()?.toLowerCase() || '' | ||||
|       if (['jpg', 'png'].includes(suffix)) { | ||||
|           console.log('进入图片') | ||||
|           window.plus?.io?.resolveLocalFileSystemURL( | ||||
|             filePath, | ||||
|             async (entry) => { | ||||
|         console.log("进入图片") | ||||
|         window.plus?.io?.resolveLocalFileSystemURL(filePath, async (entry) => { | ||||
|           entry.file((file) => { | ||||
|                 const fileReader = new plus.io.FileReader() | ||||
|                 fileReader.readAsDataURL(file) | ||||
|             const fileReader = new plus.io.FileReader(); | ||||
|             fileReader.readAsDataURL(file); | ||||
|             fileReader.onloadend = async (e) => { | ||||
|                   const base64Url = e.target.result | ||||
|                   const fileObj = base64ToFile(base64Url) | ||||
|               const base64Url = e.target.result; | ||||
|               const fileObj = base64ToFile(base64Url); | ||||
|               let data = await onUploadImageVideo(fileObj, 'image') | ||||
|               emit('selectImg', data) | ||||
|                 } | ||||
|             }; | ||||
|           }) | ||||
|         }, | ||||
|           (err) => { | ||||
|               console.log(err) | ||||
|             }, | ||||
|             console.log(err); | ||||
|           } | ||||
|         ) | ||||
|       } | ||||
|       if (['mp4', 'flv'].includes(suffix)) { | ||||
|           console.log(filePath, '进入视频') | ||||
|         console.log(filePath,"进入视频") | ||||
|         // const localUrl = plus.io.convertLocalFileSystemURL(filePath) | ||||
|         // console.log(localUrl); | ||||
| 
 | ||||
|         plus.io.getVideoInfo({ | ||||
|           filePath:filePath, | ||||
|           success:(event)=>{ | ||||
|               console.log(event) | ||||
|           console.log(event); | ||||
|         }, | ||||
|         fail:(err)=>{ | ||||
|               console.log(err) | ||||
|             }, | ||||
|           }) | ||||
|           console.log(err); | ||||
|         } | ||||
|         }); | ||||
|         // window.plus?.io?.resolveLocalFileSystemURL(localUrl, async (entry) => { | ||||
|         //   entry.file((file) => { | ||||
|         //     console.log(file,'file'); | ||||
| @ -315,73 +280,22 @@ const choosePhoto = (filter = 'none', maximum = 9, multiple = true) => { | ||||
|         // ) | ||||
|       } | ||||
|     }) | ||||
|     }, | ||||
|     (err) => { | ||||
|       console.log(err) | ||||
|   }, (err) => { | ||||
|     console.log(err); | ||||
|   }, | ||||
|     { | ||||
|       filter: filter, | ||||
|       maximum: maximum, | ||||
|       multiple: multiple, | ||||
|     }, | ||||
|     } | ||||
|   ) | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| const takePhoto = () => { | ||||
|   if (typeof plus !== 'undefined') { | ||||
|     getCamera() | ||||
|   } else { | ||||
|     document.addEventListener('plusready', () => { | ||||
|       getCamera() | ||||
|     }) | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| const getCamera = () => { | ||||
|   const cmr = plus.camera.getCamera() | ||||
|   cmr.captureImage( | ||||
|     (p) => { | ||||
|       plus.io.resolveLocalFileSystemURL( | ||||
|         p, | ||||
|         (entry) => { | ||||
|           compressAndShowImage(entry.toLocalURL(), entry.name) | ||||
|         }, | ||||
|         (err) => { | ||||
|           console.log(err) | ||||
|         }, | ||||
|       ) | ||||
|     }, | ||||
|     () => {}, | ||||
|     { index: '2' }, | ||||
|   ) | ||||
| } | ||||
| 
 | ||||
| const compressAndShowImage = (url, filename) => { | ||||
|   const dst = `_doc/upload/${filename}` | ||||
|   plus.zip.compressImage( | ||||
|     { src: url, dst, quality: 10, overwrite: true }, | ||||
|     (zip) => displayImage(zip.target), | ||||
|     (err) => { | ||||
|       console.log(err) | ||||
|     }, | ||||
|   ) | ||||
| } | ||||
| 
 | ||||
| const displayImage = (url) => { | ||||
|   plus.io.resolveLocalFileSystemURL(url, (entry) => { | ||||
|     entry.file((file) => { | ||||
|       const fileReader = new plus.io.FileReader() | ||||
|       fileReader.readAsDataURL(file) | ||||
|       fileReader.onloadend = async (e) => { | ||||
|         state.base64Url = e.target.result | ||||
|         const imageFile = base64ToFile(state.base64Url) | ||||
|         let data = await onUploadImageVideo(imageFile, 'image') | ||||
|         emit('selectImg', data, data.file_num) | ||||
|       } | ||||
|     }) | ||||
|   }) | ||||
| } | ||||
| 
 | ||||
| const chooseFile = () => { | ||||
|   uni.chooseFile({ | ||||
|     count: 1, | ||||
| @ -397,7 +311,7 @@ const chooseFile = () => { | ||||
|             size: res.tempFiles[0].size, | ||||
|             path: res.tempFilePaths[0], | ||||
|           }, | ||||
|         float: 'right', | ||||
|           float: "right", | ||||
|           isCheck: false, | ||||
|           is_mark: 0, | ||||
|           is_read: 0, | ||||
| @ -415,9 +329,12 @@ const chooseFile = () => { | ||||
|         } | ||||
|       virtualList.value.unshift(newItem) | ||||
|       uploadsStore.initUploadFile(res.tempFiles[0], props.talkParams,randomId) | ||||
|     }, | ||||
|     } | ||||
|   }) | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| </script> | ||||
| <style lang="scss" scoped> | ||||
| .emojiRoot { | ||||
|  | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -136,7 +136,7 @@ const cellClick = () => { | ||||
| 		}); | ||||
| 	} | ||||
| 	uni.navigateTo({ | ||||
| 		url: `/pages/dialog/index?sessionId=${props.data.id}`, | ||||
| 		url: `/pages/dialog/index?sessionId=${props.data.id}&talkType=${props.data.talk_type}&receiverId=${props.data.receiver_id}&indexName=${props.data.index_name}`, | ||||
| 	}); | ||||
| }; | ||||
| 
 | ||||
|  | ||||
| @ -250,7 +250,7 @@ onLoad((options) => { | ||||
|             }) | ||||
|           } | ||||
|           uni.navigateTo({ | ||||
|             url: `/pages/dialog/index?sessionId=${openSession.id}`, | ||||
|             url: `/pages/dialog/index?sessionId=${openSession.id}&talkType=${openSession.talk_type}&receiverId=${openSession.receiver_id}&indexName=${openSession.index_name}`, | ||||
|           }) | ||||
|         } | ||||
|       }) | ||||
|  | ||||
| @ -99,26 +99,11 @@ import { beautifyTime } from '@/utils/datetime' | ||||
| const { t } = useI18n() | ||||
| const props = defineProps({ | ||||
|   searchItem: Object | Number, | ||||
|   searchResultKey: { | ||||
|     type: String, | ||||
|     default: '', | ||||
|   }, | ||||
|   searchText: { | ||||
|     type: String, | ||||
|     default: '', | ||||
|   }, //搜索内容 | ||||
|   searchRecordDetail: { | ||||
|     type: Boolean, | ||||
|     default: false, | ||||
|   }, //是否是搜索聊天记录详情 | ||||
|   pointerIconSrc: { | ||||
|     type: String, | ||||
|     default: '', | ||||
|   }, //箭头图标 | ||||
|   conditionType: { | ||||
|     type: Number, | ||||
|     default: 0, | ||||
|   }, //搜索类型 | ||||
|   searchResultKey: String, | ||||
|   searchText: String, //搜索内容 | ||||
|   searchRecordDetail: Boolean, //是否是搜索聊天记录详情 | ||||
|   pointerIconSrc: String, //箭头图标 | ||||
|   conditionType: Number, //搜索类型 | ||||
| }) | ||||
| // 映射表-查找对应结构下的属性名 | ||||
| const keyMapping = { | ||||
| @ -208,8 +193,10 @@ const imgText = computed(() => { | ||||
| }) | ||||
| // 映射表-根据groupType设置对应值 | ||||
| const groupTypeMapping = { | ||||
|   0: {}, | ||||
|   1: {}, | ||||
|   0: { | ||||
|   }, | ||||
|   1: { | ||||
|   }, | ||||
|   2: { | ||||
|     result_type: t('index.mine.department'), | ||||
|     result_type_color: '#377EC6', | ||||
|  | ||||
| @ -19,7 +19,6 @@ | ||||
|         'font-size': '28rpx', | ||||
|         'font-weight': 400, | ||||
|       }" | ||||
|       :refresher-enabled="false" | ||||
|     > | ||||
|       <template #top> | ||||
|         <div class="searchRoot"> | ||||
| @ -140,37 +139,14 @@ const state = reactive({ | ||||
| }) | ||||
| 
 | ||||
| const props = defineProps({ | ||||
|   searchResultPageSize: { | ||||
|     type: Number, | ||||
|     default: 0, | ||||
|   }, //搜索结果每页数据量 | ||||
|   listLimit: { | ||||
|     type: Boolean, | ||||
|     default: false, | ||||
|   }, //是否限制列表内数据数量 | ||||
|   apiParams: { | ||||
|     type: String, | ||||
|     default: '', | ||||
|   }, //请求参数 | ||||
|   searchResultPageSize: Number, //搜索结果每页数据量 | ||||
|   listLimit: Boolean, //是否限制列表内数据数量 | ||||
|   apiParams: String, //请求参数 | ||||
|   apiRequest: Function, //请求 | ||||
|   searchText: { | ||||
|     type: String, | ||||
|     default: '', | ||||
|   }, //搜索内容 | ||||
|   isPagination: { | ||||
|     type: Boolean, | ||||
|     default: false, | ||||
|   }, //是否分页 | ||||
|   searchRecordDetail: { | ||||
|     type: Boolean, | ||||
|     default: false, | ||||
|   }, //是否是搜索聊天记录的详情 | ||||
|   first_talk_record_infos: { | ||||
|     type: Object, | ||||
|     default() { | ||||
|       return {} | ||||
|     }, | ||||
|   }, //接受者信息 | ||||
|   searchText: String, //搜索内容 | ||||
|   isPagination: Boolean, //是否分页 | ||||
|   searchRecordDetail: Boolean, //是否是搜索聊天记录的详情 | ||||
|   first_talk_record_infos: Object, //接受者信息 | ||||
| }) | ||||
| 
 | ||||
| const { t } = useI18n() | ||||
| @ -300,12 +276,8 @@ const queryAllSearch = (pageNum, searchResultPageSize) => { | ||||
|           ) | ||||
|           let total = data.count | ||||
|           if (props.searchRecordDetail) { | ||||
|             if(state?.first_talk_record_infos?.talk_type === 1){ | ||||
|               total = data.user_record_count | ||||
|             } else if (state?.first_talk_record_infos?.talk_type === 2){ | ||||
|             total = data.group_record_count | ||||
|           } | ||||
|           } | ||||
|           zPaging.value?.completeByTotal([data], total) | ||||
|         } else { | ||||
|           zPaging.value?.complete([data]) | ||||
| @ -394,12 +366,6 @@ const getHasMoreResult = (searchResultKey) => { | ||||
|       } | ||||
|       break | ||||
|     case 'general_infos': | ||||
|     if ( | ||||
|         state.searchResult['record_count'] && | ||||
|         state.searchResult['record_count'] > 3 | ||||
|       ) { | ||||
|         has_more_result = t('has_more') + t('chat.type.record') | ||||
|       } | ||||
|       break | ||||
|     default: | ||||
|   } | ||||
| @ -413,40 +379,12 @@ const toMoreResultPage = (searchResultKey) => { | ||||
| 
 | ||||
| //点击了搜索结果项 | ||||
| const clickSearchItem = (searchResultKey, searchItem) => { | ||||
|   console.log(searchResultKey, searchItem) | ||||
|   let talk_type = searchItem.talk_type | ||||
|   let receiver_id = searchItem.receiver_id | ||||
|   if (searchResultKey === 'user_infos') { | ||||
|     talk_type = 1 | ||||
|     receiver_id = searchItem.id | ||||
|   } else if (searchResultKey === 'combinedGroup') { | ||||
|     talk_type = searchItem.type || 2 | ||||
|     receiver_id = searchItem.group_id || searchItem.id | ||||
|   } else if (searchResultKey === 'general_infos') { | ||||
|     if (searchItem.talk_type === 1) { | ||||
|       if (searchItem.user_id === state.uid) { | ||||
|         //发送人是自己,接收人不需要变 | ||||
|       } | ||||
|       if (searchItem.receiver_id === state.uid) { | ||||
|         //接收人是自己,这里需要变成对方 | ||||
|         let temp_id = searchItem.receiver_id | ||||
|         let temp_name = searchItem.receiver_name | ||||
|         let temp_avatar = searchItem.receiver_avatar | ||||
|         searchItem.receiver_id = searchItem.user_id | ||||
|         searchItem.receiver_name = searchItem.user_name | ||||
|         searchItem.receiver_avatar = searchItem.user_avatar | ||||
|         searchItem.user_id = temp_id | ||||
|         searchItem.user_name = temp_name | ||||
|         searchItem.user_avatar = temp_avatar | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   emits( | ||||
|     'clickSearchItem', | ||||
|     state.searchText, | ||||
|     searchResultKey, | ||||
|     talk_type, | ||||
|     receiver_id, | ||||
|     searchItem.talk_type, | ||||
|     searchItem.receiver_id, | ||||
|     encodeURIComponent(JSON.stringify(searchItem)), | ||||
|   ) | ||||
| } | ||||
|  | ||||
| @ -13,7 +13,7 @@ | ||||
| </template> | ||||
| <script setup> | ||||
| import searchList from './components/searchList.vue' | ||||
| import { ServeSeachQueryAll, ServeGetSessionId } from '@/api/search/index' | ||||
| import { ServeSeachQueryAll } from '@/api/search/index' | ||||
| import { onMounted } from 'vue' | ||||
| import { handleSetWebviewStyle } from '@/utils/common' | ||||
| 
 | ||||
| @ -37,7 +37,7 @@ const toMoreResultPage = (searchResultKey, searchText) => { | ||||
| } | ||||
| 
 | ||||
| //点击了搜索结果项 | ||||
| const clickSearchItem = async ( | ||||
| const clickSearchItem = ( | ||||
|   searchText, | ||||
|   searchResultKey, | ||||
|   talk_type, | ||||
| @ -47,25 +47,17 @@ const clickSearchItem = async ( | ||||
|   console.log(searchResultKey) | ||||
|   const result = JSON.parse(decodeURIComponent(res)) | ||||
|   console.log(result) | ||||
|   console.log(talk_type, receiver_id) | ||||
|   const sessionId = await getSessionId(talk_type, receiver_id) | ||||
|   if (searchResultKey === 'user_infos') { | ||||
|     dialogueStore.setDialogue({ | ||||
|       name: result.nickname, | ||||
|       talk_type: 1, | ||||
|       receiver_id: receiver_id, | ||||
|     }) | ||||
|     uni.navigateTo({ | ||||
|       url: '/pages/dialog/index?sessionId=' + sessionId, | ||||
|     }) | ||||
| 
 | ||||
| 
 | ||||
|   } else if (searchResultKey === 'combinedGroup') { | ||||
|     dialogueStore.setDialogue({ | ||||
|       name: result.name || result.group_name, | ||||
|       talk_type: result.type || 2, | ||||
|       receiver_id: result.group_id || result.id, | ||||
|       receiver_id: result.id || result.group_id, | ||||
|     }) | ||||
|     uni.navigateTo({ | ||||
|       url: '/pages/dialog/index?sessionId=' + sessionId | ||||
|       url: '/pages/dialog/index', | ||||
|     }) | ||||
|   } else if (searchResultKey === 'general_infos') { | ||||
|     uni.navigateTo({ | ||||
| @ -79,25 +71,5 @@ const clickSearchItem = async ( | ||||
|     }) | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| //获取会话Id | ||||
| const getSessionId = (talk_type, receiver_id) => { | ||||
|   return new Promise((resolve, reject) => { | ||||
|     let params = { | ||||
|       talkType: talk_type, | ||||
|       receiverId: receiver_id, | ||||
|     } | ||||
|     const resp = ServeGetSessionId(params) | ||||
|     console.log(resp) | ||||
|     resp.then(({ code, data }) => { | ||||
|       console.log(data) | ||||
|       if (code == 200) { | ||||
|         resolve(data?.sessionId) | ||||
|       } else { | ||||
|       } | ||||
|     }) | ||||
|     resp.catch(() => {}) | ||||
|   }) | ||||
| } | ||||
| </script> | ||||
| <style scoped lang="scss"></style> | ||||
|  | ||||
| @ -21,7 +21,6 @@ import { | ||||
|   ServeQueryUser, | ||||
|   ServeQueryGroup, | ||||
|   ServeTalkRecord, | ||||
|   ServeGetSessionId, | ||||
| } from '@/api/search/index' | ||||
| import { reactive } from 'vue' | ||||
| 
 | ||||
| @ -31,9 +30,9 @@ const dialogueStore = useDialogueStore() | ||||
| 
 | ||||
| const state = reactive({ | ||||
|   apiRequest: Function, | ||||
|   apiParams: '', | ||||
|   searchText: '', | ||||
|   searchResultKey: '', | ||||
|   apiParams: String, | ||||
|   searchText: String, | ||||
|   searchResultKey: String, | ||||
| }) | ||||
| 
 | ||||
| onLoad((options) => { | ||||
| @ -91,7 +90,7 @@ const lastIdChange = (last_id, last_group_id, last_member_id) => { | ||||
| } | ||||
| 
 | ||||
| //点击了搜索结果项 | ||||
| const clickSearchItem = async ( | ||||
| const clickSearchItem = ( | ||||
|   searchText, | ||||
|   searchResultKey, | ||||
|   talk_type, | ||||
| @ -101,57 +100,21 @@ const clickSearchItem = async ( | ||||
|   console.log(state.searchResultKey) | ||||
|   const result = JSON.parse(decodeURIComponent(res)) | ||||
|   console.log(result) | ||||
|   console.log(talk_type, receiver_id) | ||||
|   const sessionId = await getSessionId(talk_type, receiver_id) | ||||
|   if (state.searchResultKey === 'user_infos') { | ||||
|     dialogueStore.setDialogue({ | ||||
|       name: result.nickname, | ||||
|       talk_type: 1, | ||||
|       receiver_id: receiver_id, | ||||
|     }) | ||||
|     uni.navigateTo({ | ||||
|       url: '/pages/dialog/index?sessionId=' + sessionId, | ||||
|     }) | ||||
|   } else if (state.searchResultKey === 'combinedGroup') { | ||||
|     dialogueStore.setDialogue({ | ||||
|       name: result.name || result.group_name, | ||||
|       talk_type: result.type || 2, | ||||
|       receiver_id: result.group_id || result.id, | ||||
|       receiver_id: result.id || result.group_id, | ||||
|     }) | ||||
|     uni.navigateTo({ | ||||
|       url: '/pages/dialog/index?sessionId=' + sessionId, | ||||
|       url: '/pages/dialog/index', | ||||
|     }) | ||||
|   } else if (state.searchResultKey === 'general_infos') { | ||||
|     uni.navigateTo({ | ||||
|       url: | ||||
|         '/pages/search/moreResult/moreResultDetail?searchText=' + | ||||
|         searchText + | ||||
|         '&talk_type=' + | ||||
|         talk_type + | ||||
|         '&receiver_id=' + | ||||
|         receiver_id, | ||||
|       url: '/pages/search/moreResult/moreResultDetail?searchText=' + searchText, | ||||
|     }) | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| //获取会话Id | ||||
| const getSessionId = (talk_type, receiver_id) => { | ||||
|   return new Promise((resolve, reject) => { | ||||
|     let params = { | ||||
|       talkType: talk_type, | ||||
|       receiverId: receiver_id, | ||||
|     } | ||||
|     const resp = ServeGetSessionId(params) | ||||
|     console.log(resp) | ||||
|     resp.then(({ code, data }) => { | ||||
|       console.log(data) | ||||
|       if (code == 200) { | ||||
|         resolve(data?.sessionId) | ||||
|       } else { | ||||
|       } | ||||
|     }) | ||||
|     resp.catch(() => {}) | ||||
|   }) | ||||
| } | ||||
| </script> | ||||
| <style scoped lang="scss"></style> | ||||
|  | ||||
| @ -27,8 +27,8 @@ const dialogueStore = useDialogueStore() | ||||
| const userStore = useUserStore() | ||||
| 
 | ||||
| const state = reactive({ | ||||
|   apiParams: '', | ||||
|   searchText: '', | ||||
|   apiParams: String, | ||||
|   searchText: String, | ||||
|   uid: computed(() => userStore.uid), //当前用户id | ||||
| }) | ||||
| 
 | ||||
|  | ||||
| @ -64,8 +64,7 @@ | ||||
|           v-if=" | ||||
|             state.condition === 'imgAndVideo' || | ||||
|             state.condition === 'file' || | ||||
|             state.condition === 'link' || | ||||
|             state.condition === 'member' | ||||
|             state.condition === 'link' | ||||
|           " | ||||
|           :style="{ | ||||
|             padding: state.condition === 'imgAndVideo' ? '0 27rpx' : '', | ||||
| @ -73,11 +72,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" | ||||
| @ -178,7 +173,6 @@ | ||||
|                     </div> | ||||
|                     <div | ||||
|                       class="condition-each-result-attachments" | ||||
|                       @click="previewPDF(item)" | ||||
|                       v-if=" | ||||
|                         state.condition === 'file' || state.condition === 'link' | ||||
|                       " | ||||
| @ -261,7 +255,7 @@ import useZPaging from '@/uni_modules/z-paging/components/z-paging/js/hooks/useZ | ||||
| import { parseTime } from '@/utils/datetime' | ||||
| import { onMounted, reactive, computed, ref } from 'vue' | ||||
| import { onLoad } from '@dcloudio/uni-app' | ||||
| import { ServeTalkDate, ServeGetSessionId } from '@/api/search/index' | ||||
| import { ServeTalkDate } from '@/api/search/index' | ||||
| import { ServeFindTalkRecords } from '@/api/chat/index' | ||||
| import { useDialogueStore } from '@/store' | ||||
| import { useI18n } from 'vue-i18n' | ||||
| @ -279,6 +273,7 @@ const dialogueParams = reactive({ | ||||
| let nowDay = new Date().setHours(0, 0, 0, 0) | ||||
| 
 | ||||
| const state = reactive({ | ||||
|   receiver_id: '', //目标人id | ||||
|   pageTitle: '', //页面标题 | ||||
|   dateStyle: [], //日期样式 | ||||
|   nowDate: new Date(nowDay), //当前时间 | ||||
| @ -294,16 +289,16 @@ const state = reactive({ | ||||
|   searchResultList: [], //搜索结果列表 | ||||
|   cursor: 0, //上次查询的游标 | ||||
|   msg_type: 0, //查询的消息类型 | ||||
|   group_member_id: 0, //群成员id | ||||
| }) | ||||
| 
 | ||||
| onLoad((options) => { | ||||
|   console.log(options) | ||||
|   if (options.receiver_id) { | ||||
|     state.receiver_id = Number(options.receiver_id) | ||||
|   } | ||||
|   if (options.condition) { | ||||
|     state.condition = options.condition | ||||
|     if (options.condition === 'member') { | ||||
|       // queryAllSearch() | ||||
|     } else if (options.condition === 'date') { | ||||
|     if (options.condition === 'date') { | ||||
|       state.showPageTitle = true | ||||
|       state.pageTitle = t('search.condition.date') | ||||
|       ServeQueryTalkDate(parseTime(state.nowDate, '{y}{m}')) | ||||
| @ -357,7 +352,7 @@ const ServeQueryTalkDate = (month) => { | ||||
|   let params = { | ||||
|     month: month, | ||||
|     talk_type: dialogueParams.talk_type, //1私聊2群聊 | ||||
|     receiver_id: dialogueParams.receiver_id, //目标人id | ||||
|     receiver_id: state.receiver_id, //目标人id | ||||
|   } | ||||
|   const resp = ServeTalkDate(params) | ||||
|   console.log(resp) | ||||
| @ -392,7 +387,7 @@ const ServeQueryTalkDate = (month) => { | ||||
| } | ||||
| 
 | ||||
| //点击选择日期 | ||||
| const selectDate = async (e) => { | ||||
| const selectDate = (e) => { | ||||
|   if (e == parseTime(state.nowDate, '{y}/{m}/{d}')) { | ||||
|     console.log('==今日') | ||||
|     state.dateStyle = [ | ||||
| @ -418,37 +413,6 @@ const selectDate = async (e) => { | ||||
|       }, | ||||
|     ] | ||||
|   } | ||||
|   const sessionId = await getSessionId( | ||||
|     dialogueParams.talk_type, | ||||
|     dialogueParams.receiver_id, | ||||
|   ) | ||||
|   uni.navigateTo({ | ||||
|     url: | ||||
|       '/pages/dialog/index?sessionId=' + | ||||
|       sessionId + | ||||
|       '&recordDate=' + | ||||
|       parseTime(e, '{y}-{m}-{d}'), | ||||
|   }) | ||||
| } | ||||
| 
 | ||||
| //获取会话Id | ||||
| const getSessionId = (talk_type, receiver_id) => { | ||||
|   return new Promise((resolve, reject) => { | ||||
|     let params = { | ||||
|       talkType: talk_type, | ||||
|       receiverId: receiver_id, | ||||
|     } | ||||
|     const resp = ServeGetSessionId(params) | ||||
|     console.log(resp) | ||||
|     resp.then(({ code, data }) => { | ||||
|       console.log(data) | ||||
|       if (code == 200) { | ||||
|         resolve(data?.sessionId) | ||||
|       } else { | ||||
|       } | ||||
|     }) | ||||
|     resp.catch(() => {}) | ||||
|   }) | ||||
| } | ||||
| 
 | ||||
| //点击确认选择月份 | ||||
| @ -502,7 +466,7 @@ const queryAllSearch = () => { | ||||
|     direction: 'up', //down向下查最新,up向上查老数据 | ||||
|     start_time: '', | ||||
|     end_time: '', | ||||
|     group_member_user_id: state.group_member_id, //群成员id,当查询群历史消息的时候,需要指定群成员的时候送 | ||||
|     group_member_user_id: 0, //群成员id,当查询群历史消息的时候,需要指定群成员的时候送 | ||||
|     file_name: state.msg_type === 6 ? state.searchText : '', | ||||
|   } | ||||
|   console.log(params) | ||||
| @ -600,43 +564,6 @@ const fileTypeAvatar = (fileType) => { | ||||
|   } | ||||
|   return file_type_avatar | ||||
| } | ||||
| 
 | ||||
| const previewPDF = (item) => { | ||||
|   console.log(item) | ||||
|   if (typeof plus !== 'undefined') { | ||||
|     downloadAndOpenFile(item) | ||||
|   } else { | ||||
|     document.addEventListener('plusready', () => { | ||||
|       downloadAndOpenFile(item) | ||||
|     }) | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| const downloadAndOpenFile = (item) => { | ||||
|   uni.showLoading({ title: '加载中...', mask: true }) | ||||
|   const downloadUrl = item?.extra?.path | ||||
|   const options = { | ||||
|     filename: '_doc/downloads/', // 保存路径 | ||||
|   } | ||||
|   const dtask = plus.downloader.createDownload(downloadUrl, options, function ( | ||||
|     d, | ||||
|     status, | ||||
|   ) { | ||||
|     if (status === 200) { | ||||
|       uni.hideLoading() | ||||
|       const filePath = d.filename | ||||
|       plus.runtime.openFile( | ||||
|         filePath, | ||||
|         {}, | ||||
|         function () {}, | ||||
|         function (error) {}, | ||||
|       ) | ||||
|     } else { | ||||
|       uni.hideLoading() | ||||
|     } | ||||
|   }) | ||||
|   dtask.start() | ||||
| } | ||||
| </script> | ||||
| <style scoped lang="scss"> | ||||
| .search-by-date { | ||||
| @ -743,7 +670,6 @@ body::v-deep .round-3 { | ||||
|                   span { | ||||
|                     line-height: 40rpx; | ||||
|                     color: $theme-text; | ||||
|                     word-break: break-all; | ||||
|                   } | ||||
|                 } | ||||
|                 .attachment-sub-info { | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user