Compare commits
	
		
			No commits in common. "1edb639ad9e5eab8dae4c3bbef1e04a11b88d9f4" and "8ecee151806ad17868b8c42780f8638c05d2f07f" have entirely different histories.
		
	
	
		
			1edb639ad9
			...
			8ecee15180
		
	
		
							
								
								
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -24,5 +24,3 @@ makefile | |||||||
| *.njsproj | *.njsproj | ||||||
| *.sln | *.sln | ||||||
| *.sw? | *.sw? | ||||||
| components.d.ts |  | ||||||
| auto-imports.d.ts |  | ||||||
|  | |||||||
							
								
								
									
										75
									
								
								auto-imports.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								auto-imports.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,75 @@ | |||||||
|  | /* eslint-disable */ | ||||||
|  | /* prettier-ignore */ | ||||||
|  | // @ts-nocheck
 | ||||||
|  | // noinspection JSUnusedGlobalSymbols
 | ||||||
|  | // Generated by unplugin-auto-import
 | ||||||
|  | // biome-ignore lint: disable
 | ||||||
|  | export {} | ||||||
|  | declare global { | ||||||
|  |   const EffectScope: typeof import('vue')['EffectScope'] | ||||||
|  |   const computed: typeof import('vue')['computed'] | ||||||
|  |   const createApp: typeof import('vue')['createApp'] | ||||||
|  |   const customRef: typeof import('vue')['customRef'] | ||||||
|  |   const defineAsyncComponent: typeof import('vue')['defineAsyncComponent'] | ||||||
|  |   const defineComponent: typeof import('vue')['defineComponent'] | ||||||
|  |   const effectScope: typeof import('vue')['effectScope'] | ||||||
|  |   const getCurrentInstance: typeof import('vue')['getCurrentInstance'] | ||||||
|  |   const getCurrentScope: typeof import('vue')['getCurrentScope'] | ||||||
|  |   const h: typeof import('vue')['h'] | ||||||
|  |   const inject: typeof import('vue')['inject'] | ||||||
|  |   const isProxy: typeof import('vue')['isProxy'] | ||||||
|  |   const isReactive: typeof import('vue')['isReactive'] | ||||||
|  |   const isReadonly: typeof import('vue')['isReadonly'] | ||||||
|  |   const isRef: typeof import('vue')['isRef'] | ||||||
|  |   const markRaw: typeof import('vue')['markRaw'] | ||||||
|  |   const nextTick: typeof import('vue')['nextTick'] | ||||||
|  |   const onActivated: typeof import('vue')['onActivated'] | ||||||
|  |   const onBeforeMount: typeof import('vue')['onBeforeMount'] | ||||||
|  |   const onBeforeUnmount: typeof import('vue')['onBeforeUnmount'] | ||||||
|  |   const onBeforeUpdate: typeof import('vue')['onBeforeUpdate'] | ||||||
|  |   const onDeactivated: typeof import('vue')['onDeactivated'] | ||||||
|  |   const onErrorCaptured: typeof import('vue')['onErrorCaptured'] | ||||||
|  |   const onMounted: typeof import('vue')['onMounted'] | ||||||
|  |   const onRenderTracked: typeof import('vue')['onRenderTracked'] | ||||||
|  |   const onRenderTriggered: typeof import('vue')['onRenderTriggered'] | ||||||
|  |   const onScopeDispose: typeof import('vue')['onScopeDispose'] | ||||||
|  |   const onServerPrefetch: typeof import('vue')['onServerPrefetch'] | ||||||
|  |   const onUnmounted: typeof import('vue')['onUnmounted'] | ||||||
|  |   const onUpdated: typeof import('vue')['onUpdated'] | ||||||
|  |   const onWatcherCleanup: typeof import('vue')['onWatcherCleanup'] | ||||||
|  |   const provide: typeof import('vue')['provide'] | ||||||
|  |   const reactive: typeof import('vue')['reactive'] | ||||||
|  |   const readonly: typeof import('vue')['readonly'] | ||||||
|  |   const ref: typeof import('vue')['ref'] | ||||||
|  |   const resolveComponent: typeof import('vue')['resolveComponent'] | ||||||
|  |   const shallowReactive: typeof import('vue')['shallowReactive'] | ||||||
|  |   const shallowReadonly: typeof import('vue')['shallowReadonly'] | ||||||
|  |   const shallowRef: typeof import('vue')['shallowRef'] | ||||||
|  |   const toRaw: typeof import('vue')['toRaw'] | ||||||
|  |   const toRef: typeof import('vue')['toRef'] | ||||||
|  |   const toRefs: typeof import('vue')['toRefs'] | ||||||
|  |   const toValue: typeof import('vue')['toValue'] | ||||||
|  |   const triggerRef: typeof import('vue')['triggerRef'] | ||||||
|  |   const unref: typeof import('vue')['unref'] | ||||||
|  |   const useAttrs: typeof import('vue')['useAttrs'] | ||||||
|  |   const useCssModule: typeof import('vue')['useCssModule'] | ||||||
|  |   const useCssVars: typeof import('vue')['useCssVars'] | ||||||
|  |   const useDialog: typeof import('naive-ui')['useDialog'] | ||||||
|  |   const useId: typeof import('vue')['useId'] | ||||||
|  |   const useLoadingBar: typeof import('naive-ui')['useLoadingBar'] | ||||||
|  |   const useMessage: typeof import('naive-ui')['useMessage'] | ||||||
|  |   const useModel: typeof import('vue')['useModel'] | ||||||
|  |   const useNotification: typeof import('naive-ui')['useNotification'] | ||||||
|  |   const useSlots: typeof import('vue')['useSlots'] | ||||||
|  |   const useTemplateRef: typeof import('vue')['useTemplateRef'] | ||||||
|  |   const watch: typeof import('vue')['watch'] | ||||||
|  |   const watchEffect: typeof import('vue')['watchEffect'] | ||||||
|  |   const watchPostEffect: typeof import('vue')['watchPostEffect'] | ||||||
|  |   const watchSyncEffect: typeof import('vue')['watchSyncEffect'] | ||||||
|  | } | ||||||
|  | // for type re-export
 | ||||||
|  | declare global { | ||||||
|  |   // @ts-ignore
 | ||||||
|  |   export type { Component, Slot, Slots, ComponentPublicInstance, ComputedRef, DirectiveBinding, ExtractDefaultPropTypes, ExtractPropTypes, ExtractPublicPropTypes, InjectionKey, PropType, Ref, MaybeRef, MaybeRefOrGetter, VNode, WritableComputedRef } from 'vue' | ||||||
|  |   import('vue') | ||||||
|  | } | ||||||
							
								
								
									
										1
									
								
								components.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								components.d.ts
									
									
									
									
										vendored
									
									
								
							| @ -15,7 +15,6 @@ declare module 'vue' { | |||||||
|     AvatarModule: typeof import('./src/components/avatar-module/index.vue')['default'] |     AvatarModule: typeof import('./src/components/avatar-module/index.vue')['default'] | ||||||
|     CodeMessage: typeof import('./src/components/talk/message/CodeMessage.vue')['default'] |     CodeMessage: typeof import('./src/components/talk/message/CodeMessage.vue')['default'] | ||||||
|     ConfigTab: typeof import('./src/components/group/manage/ConfigTab.vue')['default'] |     ConfigTab: typeof import('./src/components/group/manage/ConfigTab.vue')['default'] | ||||||
|     ConfirmBox: typeof import('./src/components/confirm-box/index.vue')['default'] |  | ||||||
|     ContactModal: typeof import('./src/components/user/ContactModal.vue')['default'] |     ContactModal: typeof import('./src/components/user/ContactModal.vue')['default'] | ||||||
|     CustomBtn: typeof import('./src/components/common/customBtn.vue')['default'] |     CustomBtn: typeof import('./src/components/common/customBtn.vue')['default'] | ||||||
|     CustomModal: typeof import('./src/components/common/customModal.vue')['default'] |     CustomModal: typeof import('./src/components/common/customModal.vue')['default'] | ||||||
|  | |||||||
							
								
								
									
										7
									
								
								env/.env.test
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								env/.env.test
									
									
									
									
										vendored
									
									
								
							| @ -2,10 +2,9 @@ ENV = 'development' | |||||||
| 
 | 
 | ||||||
| VITE_BASE=/ | VITE_BASE=/ | ||||||
| VUE_APP_PREVIEW=false | VUE_APP_PREVIEW=false | ||||||
| #VITE_BASE_API=http://192.168.88.21:9503 |  | ||||||
| 
 |  | ||||||
| #VITE_SOCKET_API=ws://192.168.88.21:9504 |  | ||||||
| VITE_BASE_API=http://114.218.158.24:8503 | VITE_BASE_API=http://114.218.158.24:8503 | ||||||
|  VITE_SOCKET_API=ws://114.218.158.24:8504 | # VITE_BASE_API=http://192.168.88.21:9503 | ||||||
| VITE_EPR_BASEURL=http://114.218.158.24:9020 | VITE_EPR_BASEURL=http://114.218.158.24:9020 | ||||||
|  | VITE_SOCKET_API=ws://114.218.158.24:8504 | ||||||
|  | # VITE_SOCKET_API=ws://192.168.88.21:9504 | ||||||
| VUE_APP_WEBSITE_NAME="" | VUE_APP_WEBSITE_NAME="" | ||||||
| @ -1,49 +0,0 @@ | |||||||
| <script setup> |  | ||||||
| import { ref, watch } from 'vue' |  | ||||||
| import XNModal from '@/components/x-naive-ui/x-n-modal/index.vue' |  | ||||||
| const emit = defineEmits(['cancel','confirm']) |  | ||||||
| const show=defineModel('show') |  | ||||||
| const props = defineProps({ |  | ||||||
|   title:{ |  | ||||||
|     type:String, |  | ||||||
|     default:'提示' |  | ||||||
|   }, |  | ||||||
|   content:{ |  | ||||||
|     type:String, |  | ||||||
|     default:'内容' |  | ||||||
|   }, |  | ||||||
|   cancelText:{ |  | ||||||
|     type:String, |  | ||||||
|     default:'取消' |  | ||||||
|   }, |  | ||||||
|   confirmText:{ |  | ||||||
|     type:String, |  | ||||||
|     default:'确定' |  | ||||||
|   } |  | ||||||
| }) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <template> |  | ||||||
|      |  | ||||||
|   <XNModal v-model:show="show" :closable="false" class="w-724px"    content-style="padding:0px"  @after-leave="emit('after-leave')"> |  | ||||||
|    <div class="flex flex-col w-full px-25px pb-49px"> |  | ||||||
|     <div class="text-20px text-#1F2225 w-full text-center border-b-1px border-b-solid border-b-#E9E9E9 py-20px">{{ title }}</div> |  | ||||||
|     <div class="py-60px text-center text-20px text-#1F2225"> |  | ||||||
|         {{ content }} |  | ||||||
|     </div> |  | ||||||
|     <div class="flex w-full justify-center"> |  | ||||||
|         <n-button color="#C7C7C9" class="text-14px text-#fff w-161px h-34px mr-10px" |  | ||||||
|           @click="() => { show=false; emit('cancel') }" |  | ||||||
|         >{{ cancelText }}</n-button> |  | ||||||
|         <n-button color="#46299D" class="text-14px text-#fff w-161px h-34px" |  | ||||||
|           @click="() => { show=false; emit('confirm') }" |  | ||||||
|         >{{ confirmText }}</n-button> |  | ||||||
|     </div> |  | ||||||
|    </div> |  | ||||||
|   </XNModal> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <style scoped> |  | ||||||
| </style> |  | ||||||
| @ -1,32 +0,0 @@ | |||||||
| import { createVNode, nextTick, render } from 'vue' |  | ||||||
| import ConfirmBox from './index.vue' |  | ||||||
| 
 |  | ||||||
| export function confirmBox(options) { |  | ||||||
|   return new Promise((resolve, reject) => { |  | ||||||
|     const container = document.createElement('div') |  | ||||||
|     document.body.appendChild(container) |  | ||||||
| 
 |  | ||||||
|     const props = { |  | ||||||
|       ...options, |  | ||||||
|       show: false, |  | ||||||
|       onCancel: () => { |  | ||||||
|         reject() |  | ||||||
| 
 |  | ||||||
|       }, |  | ||||||
|       onAfterLeave:()=>{ |  | ||||||
|         render(null, container) |  | ||||||
|         document.body.removeChild(container) |  | ||||||
|       }, |  | ||||||
|       onConfirm: () => { |  | ||||||
|         resolve() |  | ||||||
|      |  | ||||||
|       }, |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     const vnode = createVNode(ConfirmBox, props) |  | ||||||
|     render(vnode, container) |  | ||||||
|     nextTick(() => { |  | ||||||
|       vnode.component.props.show = true |  | ||||||
|     }) |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| @ -52,6 +52,7 @@ import { ServeUploadImage } from '@/api/upload' | |||||||
| import { uploadImg } from '@/api/upload' | import { uploadImg } from '@/api/upload' | ||||||
| // 引入事件总线钩子 | // 引入事件总线钩子 | ||||||
| import { useEventBus } from '@/hooks' | import { useEventBus } from '@/hooks' | ||||||
|  | 
 | ||||||
| // 注册Quill编辑器的自定义格式 | // 注册Quill编辑器的自定义格式 | ||||||
| Quill.register('formats/emoji', EmojiBlot)       // 注册表情格式 | Quill.register('formats/emoji', EmojiBlot)       // 注册表情格式 | ||||||
| Quill.register('formats/quote', QuoteBlot)       // 注册引用格式 | Quill.register('formats/quote', QuoteBlot)       // 注册引用格式 | ||||||
| @ -146,12 +147,12 @@ const editorOption = { | |||||||
|         if (!props.members.length) { |         if (!props.members.length) { | ||||||
|           return renderList([]) |           return renderList([]) | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|         let list = [ |         let list = [ | ||||||
|  |           { id: 0, nickname: '所有人', avatar: defAvatar, value: '所有人' }, | ||||||
|           ...props.members |           ...props.members | ||||||
|         ] as any |         ] | ||||||
| if((dialogueStore.groupInfo as any).is_manager){ | 
 | ||||||
|   list.unshift({ id: 0, nickname: '所有人', avatar: defAvatar, value: '所有人' }) |  | ||||||
| } |  | ||||||
|         const items = list.filter( |         const items = list.filter( | ||||||
|           (item: any) => item.nickname.toLowerCase().indexOf(searchTerm) !== -1 |           (item: any) => item.nickname.toLowerCase().indexOf(searchTerm) !== -1 | ||||||
|         ) |         ) | ||||||
|  | |||||||
| @ -71,8 +71,9 @@ function getFileExtension(filename) { | |||||||
| // 切换播放状态 | // 切换播放状态 | ||||||
| const togglePlay = () => { | const togglePlay = () => { | ||||||
|   isPlaying.value = !isPlaying.value |   isPlaying.value = !isPlaying.value | ||||||
|  |    | ||||||
|   if (props.extra.is_uploading && props.extra.upload_id) { |   if (props.extra.is_uploading && props.extra.upload_id) { | ||||||
|     const action = isPlaying.value ? 'pauseUpload' : 'resumeUpload' |     const action = isPlaying.value ? 'resumeUpload' : 'pauseUpload' | ||||||
|     uploadsStore[action](props.extra.upload_id) |     uploadsStore[action](props.extra.upload_id) | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @ -112,7 +113,7 @@ const handleDownload = () => { | |||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|   <div class="file-message flex flex-col" @click="handleClick"> |   <div class="file-message" @click="handleClick"> | ||||||
|     <!-- 文件头部信息 --> |     <!-- 文件头部信息 --> | ||||||
|     <div class="file-header"> |     <div class="file-header"> | ||||||
|       <!-- 文件名 --> |       <!-- 文件名 --> | ||||||
| @ -122,8 +123,8 @@ const handleDownload = () => { | |||||||
|         <img class="file-icon" :src="fileInfo.icon" alt="文件图标"> |         <img class="file-icon" :src="fileInfo.icon" alt="文件图标"> | ||||||
|              |              | ||||||
|         <!-- 上传进度圆环 - 上传状态 --> |         <!-- 上传进度圆环 - 上传状态 --> | ||||||
|         <div v-if="extra.is_uploading&&extra.percentage!==-1" class="progress-overlay"> |         <div v-if="extra.is_uploading" class="progress-overlay"> | ||||||
|           <div class="circle-progress-container" @click.stop="togglePlay"> |           <div class="circle-progress-container" @click="togglePlay"> | ||||||
|             <svg class="circle-progress" width="20" height="20" viewBox="0 0 20 20"> |             <svg class="circle-progress" width="20" height="20" viewBox="0 0 20 20"> | ||||||
|               <!-- 底色圆环 --> |               <!-- 底色圆环 --> | ||||||
|               <circle  |               <circle  | ||||||
| @ -149,21 +150,20 @@ const handleDownload = () => { | |||||||
|               /> |               /> | ||||||
|                |                | ||||||
|               <!-- 暂停/播放图标 --> |               <!-- 暂停/播放图标 --> | ||||||
|               |               <g v-if="isPlaying" class="pause-icon"> | ||||||
|               <g v-if="isPlaying" class="play-icon"> |  | ||||||
|                 <rect x="6" y="6" width="8" height="8" :fill="fileInfo.color" /> |  | ||||||
|               </g> |  | ||||||
|               <g v-else class="pause-icon"> |  | ||||||
|                 <rect x="7" y="5" width="2" height="10" :fill="fileInfo.color" /> |                 <rect x="7" y="5" width="2" height="10" :fill="fileInfo.color" /> | ||||||
|                 <rect x="11" y="5" width="2" height="10" :fill="fileInfo.color" /> |                 <rect x="11" y="5" width="2" height="10" :fill="fileInfo.color" /> | ||||||
|               </g> |               </g> | ||||||
|  |               <g v-else class="play-icon"> | ||||||
|  |                 <rect x="6" y="6" width="8" height="8" :fill="fileInfo.color" /> | ||||||
|  |               </g> | ||||||
|             </svg> |             </svg> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <!-- 文件大小信息 --> |     <!-- 文件大小信息 --> | ||||||
|     <div class="flex justify-between items-center grow-1"> |     <div class="flex justify-between items-center"> | ||||||
|       <div class="file-size">{{ fileFormatSize(extra.size) }}</div> |       <div class="file-size">{{ fileFormatSize(extra.size) }}</div> | ||||||
|       <div class="flex items-center" v-if="!extra.is_uploading"> |       <div class="flex items-center" v-if="!extra.is_uploading"> | ||||||
|         <div class="flex items-center" @click.stop="handleDownload"> <img class="w-11.7px h-11.74px mr-7px" src="@/assets/image/dofd.png" alt=""> <span class="text-12px text-#46299D">下载</span></div> |         <div class="flex items-center" @click.stop="handleDownload"> <img class="w-11.7px h-11.74px mr-7px" src="@/assets/image/dofd.png" alt=""> <span class="text-12px text-#46299D">下载</span></div> | ||||||
| @ -178,7 +178,6 @@ const handleDownload = () => { | |||||||
| .file-message { | .file-message { | ||||||
|   width: 243px; |   width: 243px; | ||||||
|   background-color: #fff; |   background-color: #fff; | ||||||
|   height: 110px; |  | ||||||
|   border-radius: 8px; |   border-radius: 8px; | ||||||
|   box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); |   box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); | ||||||
|   padding: 0 14px; |   padding: 0 14px; | ||||||
| @ -206,7 +205,6 @@ const handleDownload = () => { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .file-icon-container { | .file-icon-container { | ||||||
|   height: 48px; |  | ||||||
|   position: relative; |   position: relative; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -230,6 +228,7 @@ const handleDownload = () => { | |||||||
| .file-size { | .file-size { | ||||||
|   color: #747474; |   color: #747474; | ||||||
|   font-size: 12px; |   font-size: 12px; | ||||||
|  |   padding: 5px 0 11px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .circle-progress-container { | .circle-progress-container { | ||||||
|  | |||||||
| @ -35,7 +35,7 @@ const img = (src: string, width = 200) => { | |||||||
|     :class="{ left: data.float === 'left' }" |     :class="{ left: data.float === 'left' }" | ||||||
|     :style="img(extra.url, 350)" |     :style="img(extra.url, 350)" | ||||||
|   > |   > | ||||||
|     <n-image class="h-149px" :src="extra.url" /> |     <n-image :src="extra.url" /> | ||||||
|   </section> |   </section> | ||||||
| </template> | </template> | ||||||
| <style lang="less" scoped> | <style lang="less" scoped> | ||||||
| @ -44,6 +44,9 @@ const img = (src: string, width = 200) => { | |||||||
|   padding: 5px; |   padding: 5px; | ||||||
|   border-radius: 5px; |   border-radius: 5px; | ||||||
|   background: var(--im-message-left-bg-color); |   background: var(--im-message-left-bg-color); | ||||||
|  |   min-width: 30px; | ||||||
|  |   min-height: 30px; | ||||||
|  |   max-width:240px; | ||||||
|   height:149px |   height:149px | ||||||
|   &.left { |   &.left { | ||||||
|     background: var(--im-message-right-bg-color); |     background: var(--im-message-right-bg-color); | ||||||
|  | |||||||
| @ -137,8 +137,7 @@ function resumeUpload(e) { | |||||||
|    |    | ||||||
|     <!-- <n-image :src="extra.cover" preview-disabled /> --> |     <!-- <n-image :src="extra.cover" preview-disabled /> --> | ||||||
|     <video :src="props.extra.url" :controls="false"></video> |     <video :src="props.extra.url" :controls="false"></video> | ||||||
|     <!-- 上传进度时的黑色半透明蒙层 --> |      | ||||||
|     <div v-if="extra.is_uploading && !uploadFailed" class="upload-mask"></div> |  | ||||||
|     <!-- 上传进度显示 --> |     <!-- 上传进度显示 --> | ||||||
|     <div v-if="extra.is_uploading && !uploadFailed" class="upload-progress"> |     <div v-if="extra.is_uploading && !uploadFailed" class="upload-progress"> | ||||||
|       <n-progress |       <n-progress | ||||||
| @ -246,17 +245,6 @@ function resumeUpload(e) { | |||||||
|   justify-content: center; |   justify-content: center; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .upload-mask { |  | ||||||
|   position: absolute; |  | ||||||
|   left: 0; |  | ||||||
|   top: 0; |  | ||||||
|   width: 100%; |  | ||||||
|   height: 100%; |  | ||||||
|   background: rgba(0, 0, 0, 0.45); |  | ||||||
|   z-index: 1; |  | ||||||
|   border-radius: 5px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .upload-progress { | .upload-progress { | ||||||
|   position: absolute; |   position: absolute; | ||||||
|   left: 50%; |   left: 50%; | ||||||
| @ -267,7 +255,6 @@ function resumeUpload(e) { | |||||||
|   display: flex; |   display: flex; | ||||||
|   justify-content: center; |   justify-content: center; | ||||||
|   align-items: center; |   align-items: center; | ||||||
|   z-index: 2; |  | ||||||
|    |    | ||||||
|   .upload-control { |   .upload-control { | ||||||
|     position: absolute; |     position: absolute; | ||||||
|  | |||||||
| @ -79,6 +79,28 @@ export const useUploadsStore = defineStore('uploads', { | |||||||
|     findItemByClientId(clientUploadId: string): UploadItem | undefined { |     findItemByClientId(clientUploadId: string): UploadItem | undefined { | ||||||
|       return this.items.find((item) => item.client_upload_id === clientUploadId) |       return this.items.find((item) => item.client_upload_id === clientUploadId) | ||||||
|     }, |     }, | ||||||
|  | 
 | ||||||
|  |     // // 暂停文件上传
 | ||||||
|  |     // pauseUpload(uploadId: string) {
 | ||||||
|  |     //   const item = this.findItem(uploadId)
 | ||||||
|  |     //   if (!item) return
 | ||||||
|  |        | ||||||
|  |     //   item.is_paused = true
 | ||||||
|  |     //   console.log(`暂停上传: ${uploadId}`)
 | ||||||
|  |     // },
 | ||||||
|  | 
 | ||||||
|  |     // 恢复文件上传
 | ||||||
|  |     // resumeUpload(uploadId: string) {
 | ||||||
|  |     //   const item = this.findItem(uploadId)
 | ||||||
|  |     //   if (!item) return
 | ||||||
|  |        | ||||||
|  |     //   item.is_paused = false
 | ||||||
|  |     //   console.log(`恢复上传: ${uploadId}`)
 | ||||||
|  |        | ||||||
|  |     //   // 继续上传
 | ||||||
|  |     //   this.triggerUpload(uploadId)
 | ||||||
|  |     // },
 | ||||||
|  | 
 | ||||||
|     // 发送上传消息
 |     // 发送上传消息
 | ||||||
|     async sendUploadMessage(item: any) { |     async sendUploadMessage(item: any) { | ||||||
|       try { |       try { | ||||||
| @ -97,7 +119,8 @@ export const useUploadsStore = defineStore('uploads', { | |||||||
|       file: File,  |       file: File,  | ||||||
|       talkType: number,  |       talkType: number,  | ||||||
|       receiverId: number,  |       receiverId: number,  | ||||||
|       clientUploadId: string, |       username: string, | ||||||
|  |       uploadId: string, | ||||||
|       onProgress: (percentage: number) => void, |       onProgress: (percentage: number) => void, | ||||||
|       onComplete: (data: any) => void |       onComplete: (data: any) => void | ||||||
|     ) { |     ) { | ||||||
| @ -124,11 +147,13 @@ export const useUploadsStore = defineStore('uploads', { | |||||||
|             talk_type: talkType, |             talk_type: talkType, | ||||||
|             receiver_id: receiverId, |             receiver_id: receiverId, | ||||||
|             upload_id: upload_id, |             upload_id: upload_id, | ||||||
|             client_upload_id: clientUploadId, // 客户端生成的上传ID,用于前端标识
 |             client_upload_id: uploadId, // 客户端生成的上传ID,用于前端标识
 | ||||||
|             uploadIndex: 0, |             uploadIndex: 0, | ||||||
|             percentage: 0, |             percentage: 0, | ||||||
|             status: 0, // 文件上传状态 0:等待上传 1:上传中 2:上传完成 3:网络异常
 |             status: 0, // 文件上传状态 0:等待上传 1:上传中 2:上传完成 3:网络异常
 | ||||||
|             files: fileChunks, |             files: fileChunks, | ||||||
|  |             avatar: '', | ||||||
|  |             username: username, | ||||||
|             is_paused: false, |             is_paused: false, | ||||||
|             onProgress: onProgress, |             onProgress: onProgress, | ||||||
|             onComplete: onComplete, |             onComplete: onComplete, | ||||||
| @ -137,7 +162,7 @@ export const useUploadsStore = defineStore('uploads', { | |||||||
|           this.isShow = false // 不显示上传管理抽屉
 |           this.isShow = false // 不显示上传管理抽屉
 | ||||||
|            |            | ||||||
|           // 开始上传分片
 |           // 开始上传分片
 | ||||||
|           this.triggerUpload(upload_id, clientUploadId) |           this.triggerUpload(upload_id, uploadId) | ||||||
|         } else { |         } else { | ||||||
|           message.error(res.message) |           message.error(res.message) | ||||||
|           onProgress(-1) // 通知上传失败
 |           onProgress(-1) // 通知上传失败
 | ||||||
| @ -173,11 +198,12 @@ export const useUploadsStore = defineStore('uploads', { | |||||||
|        |        | ||||||
|       // 上传当前分片
 |       // 上传当前分片
 | ||||||
|       try { |       try { | ||||||
| 
 |  | ||||||
|         const res = await ServeFileSubareaUpload(form) |         const res = await ServeFileSubareaUpload(form) | ||||||
|          |          | ||||||
|         // 获取最新的项目状态,确保仍然存在且没有被暂停
 |         // 获取最新的项目状态,确保仍然存在且没有被暂停
 | ||||||
|         const updatedItem:any = this.findItem(uploadId) |         const updatedItem = this.findItem(uploadId) | ||||||
|  |         if (!updatedItem || updatedItem.is_paused) return | ||||||
|  |          | ||||||
|         if (res.code == 200) { |         if (res.code == 200) { | ||||||
|           // 当前分片上传成功,增加索引
 |           // 当前分片上传成功,增加索引
 | ||||||
|           updatedItem.uploadIndex++ |           updatedItem.uploadIndex++ | ||||||
| @ -190,6 +216,9 @@ export const useUploadsStore = defineStore('uploads', { | |||||||
|           if (updatedItem.onProgress) { |           if (updatedItem.onProgress) { | ||||||
|             updatedItem.onProgress(updatedItem.percentage) |             updatedItem.onProgress(updatedItem.percentage) | ||||||
|           } |           } | ||||||
|  |           // if (clientUploadId) {
 | ||||||
|  |           //   this.dialogueStore.updateUploadProgress(clientUploadId, percentage)
 | ||||||
|  |           // }
 | ||||||
|           // 检查是否全部上传完成
 |           // 检查是否全部上传完成
 | ||||||
|           if (updatedItem.uploadIndex === updatedItem.files.length) { |           if (updatedItem.uploadIndex === updatedItem.files.length) { | ||||||
|             // 所有分片上传完成
 |             // 所有分片上传完成
 | ||||||
| @ -201,12 +230,12 @@ export const useUploadsStore = defineStore('uploads', { | |||||||
|             this.triggerUpload(uploadId, clientUploadId) |             this.triggerUpload(uploadId, clientUploadId) | ||||||
|           } |           } | ||||||
|         } else { |         } else { | ||||||
|           updatedItem.onProgress(-1) |  | ||||||
|           // 上传失败处理
 |           // 上传失败处理
 | ||||||
|           console.error(`分片上传失败,错误码: ${res.code},错误信息: ${res.message || '未知错误'}`); |           console.error(`分片上传失败,错误码: ${res.code},错误信息: ${res.message || '未知错误'}`); | ||||||
|           updatedItem.status = 3 |           updatedItem.status = 3 | ||||||
|            |            | ||||||
|          |           // 尝试重试当前分片
 | ||||||
|  |           this.retryUpload(uploadId, clientUploadId, res.message || '上传失败,请重试') | ||||||
|         } |         } | ||||||
|       } catch (error) { |       } catch (error) { | ||||||
|         console.error("分片上传错误:", error); |         console.error("分片上传错误:", error); | ||||||
| @ -219,10 +248,37 @@ export const useUploadsStore = defineStore('uploads', { | |||||||
|         if (updatedItem.is_paused) return |         if (updatedItem.is_paused) return | ||||||
|          |          | ||||||
|         updatedItem.status = 3 |         updatedItem.status = 3 | ||||||
|  |          | ||||||
|  |         // 尝试重试当前分片
 | ||||||
|  |         this.retryUpload(uploadId, clientUploadId, '网络错误,正在重试') | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|      |      | ||||||
|  |     // 重试上传
 | ||||||
|  |     retryUpload(uploadId: string, clientUploadId?: string, errorMessage?: string) { | ||||||
|  |       const item = this.findItem(uploadId) | ||||||
|  |       if (!item) return | ||||||
|        |        | ||||||
|  |       // 如果有暂停/恢复按钮,先告知用户上传出错
 | ||||||
|  |       if (item.onProgress) { | ||||||
|  |         item.onProgress(-1) | ||||||
|  |       } | ||||||
|  |        | ||||||
|  |       // 显示错误提示
 | ||||||
|  |       message.warning(errorMessage) | ||||||
|  |        | ||||||
|  |       // 创建一个5秒后自动重试的机制
 | ||||||
|  |       setTimeout(() => { | ||||||
|  |         const currentItem = this.findItem(uploadId) | ||||||
|  |         if (!currentItem) return | ||||||
|  |          | ||||||
|  |         // 如果用户没有手动暂停,则自动重试
 | ||||||
|  |         if (!currentItem.is_paused) { | ||||||
|  |           console.log('正在重试上传分片...'); | ||||||
|  |           this.triggerUpload(uploadId, clientUploadId) | ||||||
|  |         } | ||||||
|  |       }, 5000) | ||||||
|  |     }, | ||||||
|      |      | ||||||
|     // 完成上传
 |     // 完成上传
 | ||||||
|     async completeUpload(item: UploadItem, clientUploadId: string) { |     async completeUpload(item: UploadItem, clientUploadId: string) { | ||||||
| @ -272,22 +328,24 @@ export const useUploadsStore = defineStore('uploads', { | |||||||
|     }, |     }, | ||||||
|      |      | ||||||
|     // 重试文件上传
 |     // 重试文件上传
 | ||||||
|     retryCommonUpload(clientUploadId: string) { |     retryCommonUpload(uploadId: string, errorMessage: string) { | ||||||
|       const item = this.findItemByClientId(clientUploadId) |       const item = this.findItem(uploadId) | ||||||
|       if (!item) return |       if (!item) return | ||||||
|        |        | ||||||
|       // 重新初始化上传,以便重新获取分片信息
 |       // 显示错误提示
 | ||||||
|       this.initUploadFile( |       message.warning(errorMessage) | ||||||
|         item.file, |  | ||||||
|         item.talk_type, |  | ||||||
|         item.receiver_id, |  | ||||||
|         clientUploadId, |  | ||||||
|         item.onProgress || ((percentage: number) => {}), |  | ||||||
|         item.onComplete || ((data: any) => {}) |  | ||||||
|       ) |  | ||||||
|        |        | ||||||
|       // 从上传列表中移除旧的上传项
 |       // 创建一个5秒后自动重试的机制
 | ||||||
|       this.items = this.items.filter(i => i.client_upload_id !== clientUploadId) |       setTimeout(() => { | ||||||
|  |         const currentItem = this.findItem(uploadId) | ||||||
|  |         if (!currentItem) return | ||||||
|  |          | ||||||
|  |         // 如果用户没有手动暂停,则自动重试
 | ||||||
|  |         if (!currentItem.is_paused) { | ||||||
|  |           console.log('正在重试上传分片...'); | ||||||
|  |           this.triggerUpload(uploadId) | ||||||
|  |         } | ||||||
|  |       }, 5000) | ||||||
|     }, |     }, | ||||||
|   } |   } | ||||||
| }) | }) | ||||||
|  | |||||||
| @ -18,7 +18,7 @@ export function isLoggedIn() { | |||||||
|  */ |  */ | ||||||
| export function getAccessToken() { | export function getAccessToken() { | ||||||
|   // return storage.get(AccessToken) || ''
 |   // return storage.get(AccessToken) || ''
 | ||||||
|   return JSON.parse(localStorage.getItem('token'))||'46d71a72d8d845ad7ed23eba9bdde260e635407190c2ce1bf7fd22088e41682ea07773ec65cae8946d2003f264d55961f96e0fc5da10eb96d3a348c1664e9644ce2108c311309f398ae8ea1b8200bfd490e5cb6e8c52c9e5d493cbabb163368f8351420451a631dbfa749829ee4cda49b77b5ed2d3dced5d0f2b7dd9ee76ba5465c84a17c23af040cd92b6b2a4ea48befbb5c729dcdad0a9c9668befe84074cc24f78899c1d947f8e7f94c7eda5325b8ed698df729e76febb98549ef3482ae942fb4f4a1c92d21836fa784728f0c5483aab2760a991b6b36e6b10c84f840a6433a6ecc31dee36e8f1c6158818bc89d22ab23a552e0c3f606946dcb914a52b692e10d823cc7f43027127359e7ee8555d956e7e095946931ceaa3877675584b0a0a4fc690c8018712b306050ebbdea92037aea31d66d65004be26d3c696abc4c29' |   return JSON.parse(localStorage.getItem('token'))||'79b5c732d96d2b27a48a99dfd4a5566c43aaa5796242e854ebe3ffc198d6876b9628e7b764d9af65ab5dbb2d517ced88170491b74b048c0ba827c0d3741462cb89dc59ed46653a449af837a8262941caaef1334d640773710f8cd96473bacfb190cba595a5d6a9c87d70f0999a3ebb41147213b31b4bdccffca66a56acf3baab5af0154f0dce360079f37709f78e13711036899344bddb0fb4cf0f2890287cb62c3fcbe33368caa5e213624577be8b8420ab75b1f50775ee16142a4321c5d56995f37354a66a969da98d95ba6e65d142ed097e04b411c1ebad2f62866d0ec7e1838420530a9941dbbcd00490199f8b8920ba7848670d6635bc65bc81e459c2d265c727a7b12d1bef76bc3ef2db21c5321a0369a434ada2629282bf55674fe5b6052fa62f66e10cdd8652c28aa0f4afd42fdc72282e2e591e7b7c0c17a3b85eca' | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  | |||||||
| @ -1,7 +1,7 @@ | |||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { ref } from 'vue' | import { ref } from 'vue' | ||||||
| import { useDialogueStore } from '@/store' | import { useDialogueStore } from '@/store' | ||||||
| import {confirmBox} from '@/components/confirm-box/service.js' | import { Share, ShareThree, Delete, Close } from '@icon-park/vue-next' | ||||||
| 
 | 
 | ||||||
| import ContactModal from '@/components/user/ContactModal.vue' | import ContactModal from '@/components/user/ContactModal.vue' | ||||||
| 
 | 
 | ||||||
| @ -31,19 +31,12 @@ const onSingleForward = () => { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const onMultiDelete = () => { | const onMultiDelete = () => { | ||||||
|   confirmBox({ |   // 批量删除 | ||||||
|     content:'确定删除聊天记录', |  | ||||||
|     confirmText:'删除' |  | ||||||
|   }).then(()=>{ |  | ||||||
|   let msgIds = dialogueStore.selectItems.map((item: any) => item.msg_id) |   let msgIds = dialogueStore.selectItems.map((item: any) => item.msg_id) | ||||||
| 
 | 
 | ||||||
|   if (!msgIds.length) return |   if (!msgIds.length) return | ||||||
| 
 | 
 | ||||||
|   dialogueStore.ApiDeleteRecord(msgIds) |   dialogueStore.ApiDeleteRecord(msgIds) | ||||||
|      |  | ||||||
|   }) |  | ||||||
|   // 批量删除 |  | ||||||
| 
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const onContactModal = (data: { receiver_id: number; talk_type: number }[]) => { | const onContactModal = (data: { receiver_id: number; talk_type: number }[]) => { | ||||||
|  | |||||||
| @ -14,10 +14,9 @@ import { ITalkRecord } from '@/types/chat' | |||||||
| import { EditorConst } from '@/constant/event-bus' | import { EditorConst } from '@/constant/event-bus' | ||||||
| import { useInject, useTalkRecord, useUtil } from '@/hooks' | import { useInject, useTalkRecord, useUtil } from '@/hooks' | ||||||
| import { ExclamationCircleFilled } from '@ant-design/icons-vue' | import { ExclamationCircleFilled } from '@ant-design/icons-vue' | ||||||
| import { useUserStore ,useUploadsStore} from '@/store' | import { useUserStore } from '@/store' | ||||||
| import RevokeMessage from '@/components/talk/message/RevokeMessage.vue' | import RevokeMessage from '@/components/talk/message/RevokeMessage.vue' | ||||||
| import { voiceToText } from '@/api/chat.js' | import { voiceToText } from '@/api/chat.js' | ||||||
| import {confirmBox} from '@/components/confirm-box/service.js' |  | ||||||
| const props = defineProps({ | const props = defineProps({ | ||||||
|   uid: { |   uid: { | ||||||
|     type: Number, |     type: Number, | ||||||
| @ -42,7 +41,7 @@ const props = defineProps({ | |||||||
| }) | }) | ||||||
| 
 | 
 | ||||||
| const { loadConfig, records, onLoad, onRefreshLoad, onJumpMessage } = useTalkRecord(props.uid) | const { loadConfig, records, onLoad, onRefreshLoad, onJumpMessage } = useTalkRecord(props.uid) | ||||||
| const uploadsStore = useUploadsStore() | 
 | ||||||
| const { useMessage } = useUtil() | const { useMessage } = useUtil() | ||||||
| const { dropdown, showDropdownMenu, closeDropdownMenu } = useMenu() | const { dropdown, showDropdownMenu, closeDropdownMenu } = useMenu() | ||||||
| const { showUserInfoModal } = useInject() | const { showUserInfoModal } = useInject() | ||||||
| @ -315,23 +314,6 @@ watch( | |||||||
| // onMounted(() => { | // onMounted(() => { | ||||||
|   // onLoad({ ...props, limit: 30 }) |   // onLoad({ ...props, limit: 30 }) | ||||||
| // }) | // }) | ||||||
| const retry=(item:any)=>{ |  | ||||||
|   confirmBox({ |  | ||||||
|     content:'确定重发吗' |  | ||||||
|   }).then(()=>{ |  | ||||||
|    uploadsStore.retryCommonUpload(item.extra.upload_id) |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const onContextMenuAvatar=(e:any,item:any)=>{ |  | ||||||
|   console.log('item',item) |  | ||||||
|   e.preventDefault() |  | ||||||
|   bus.emit(EditorConst.Mention, { |  | ||||||
|     id: item.user_id, |  | ||||||
|     value: item.nickname |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| @ -396,14 +378,13 @@ const onContextMenuAvatar=(e:any,item:any)=>{ | |||||||
|               :src="item.avatar" |               :src="item.avatar" | ||||||
|               :size="42" |               :size="42" | ||||||
|               :username="item.nickname" |               :username="item.nickname" | ||||||
|               @contextmenu.prevent="onContextMenuAvatar($event, item)" |  | ||||||
|               @click="showUserInfoModal(item.erp_user_id, item.user_id)" |               @click="showUserInfoModal(item.erp_user_id, item.user_id)" | ||||||
|             /> |             /> | ||||||
|           </aside> |           </aside> | ||||||
| 
 | 
 | ||||||
|           <!-- 主体信息 --> |           <!-- 主体信息 --> | ||||||
|           <main class="main-column"> |           <main class="main-column"> | ||||||
|             <!-- <div class="talk-title"> |             <div class="talk-title"> | ||||||
|               <span |               <span | ||||||
|                 class="nickname pointer" |                 class="nickname pointer" | ||||||
|                 v-show="talk_type == 2 && item.float == 'left'" |                 v-show="talk_type == 2 && item.float == 'left'" | ||||||
| @ -412,15 +393,8 @@ const onContextMenuAvatar=(e:any,item:any)=>{ | |||||||
|                 <span class="at">@</span>{{ item.nickname }} |                 <span class="at">@</span>{{ item.nickname }} | ||||||
|               </span> |               </span> | ||||||
|               <span>{{ parseTime(item.created_at, '{y}/{m}/{d} {h}:{i}') }}</span> |               <span>{{ parseTime(item.created_at, '{y}/{m}/{d} {h}:{i}') }}</span> | ||||||
|             </div> --> |  | ||||||
|             <div class="talk-title"> |  | ||||||
|               <span class="mr-7px" |  | ||||||
|                 v-show="talk_type == 2 && item.float == 'left'" |  | ||||||
|                  |  | ||||||
|               >{{ item.nickname }} |  | ||||||
|               </span> |  | ||||||
|               <span>{{ parseTime(item.created_at, '{y}/{m}/{d} {h}:{i}') }}</span> |  | ||||||
|             </div> |             </div> | ||||||
|  | 
 | ||||||
|             <div |             <div | ||||||
|               class="talk-content" |               class="talk-content" | ||||||
|               :class="{ pointer: dialogueStore.isOpenMultiSelect }" |               :class="{ pointer: dialogueStore.isOpenMultiSelect }" | ||||||
| @ -440,7 +414,7 @@ const onContextMenuAvatar=(e:any,item:any)=>{ | |||||||
|                 " |                 " | ||||||
|                 class="mr-10px" |                 class="mr-10px" | ||||||
|               > |               > | ||||||
|                 <n-button text style="font-size: 20px;" @click="retry(item)"> |                 <n-button text style="font-size: 20px;"> | ||||||
|                   <n-icon color="#CF3050"> |                   <n-icon color="#CF3050"> | ||||||
|                     <ExclamationCircleFilled /> |                     <ExclamationCircleFilled /> | ||||||
|                   </n-icon> |                   </n-icon> | ||||||
|  | |||||||
| @ -116,13 +116,15 @@ const onSendVideoEvent = async ({ data }) => { | |||||||
|     msg_type: 5, // 视频消息类型 |     msg_type: 5, // 视频消息类型 | ||||||
|     user_id: props.uid, |     user_id: props.uid, | ||||||
|     receiver_id: props.receiver_id, |     receiver_id: props.receiver_id, | ||||||
|  |     nickname: '我', // 本地显示 | ||||||
|  |     avatar: userStore.avatar, // 本地显示可能不需要 | ||||||
|     is_revoke: 0, |     is_revoke: 0, | ||||||
|     is_mark: 0, |     is_mark: 0, | ||||||
|     is_read: 1, |     is_read: 1, | ||||||
|     content: '', |     content: '', | ||||||
|     created_at: parseTime(new Date(), '{y}-{m}-{d} {h}:{i}'), |     created_at: parseTime(new Date(), '{y}-{m}-{d} {h}:{i}'), | ||||||
|     extra: { |     extra: { | ||||||
|       url: '',  |       url: '', // 上传完成后会更新 | ||||||
|       size: data.size, |       size: data.size, | ||||||
|       is_uploading: true, |       is_uploading: true, | ||||||
|       upload_id: uploadId, |       upload_id: uploadId, | ||||||
| @ -139,12 +141,35 @@ const onSendVideoEvent = async ({ data }) => { | |||||||
|     data,  |     data,  | ||||||
|     props.talk_type,  |     props.talk_type,  | ||||||
|     props.receiver_id,  |     props.receiver_id,  | ||||||
|  |     dialogueStore.talk.username,  | ||||||
|     uploadId,  |     uploadId,  | ||||||
|     async (percentage) => { |     async (percentage) => { | ||||||
|       dialogueStore.updateUploadProgress(uploadId, percentage) |       dialogueStore.updateUploadProgress(uploadId, percentage) | ||||||
|     }, |     }, | ||||||
|     async () => { |     async () => { | ||||||
|       dialogueStore.batchDelDialogueRecord([uploadId]) |       dialogueStore.batchDelDialogueRecord([uploadId]) | ||||||
|  |       // console.log('videoData', videoData) | ||||||
|  |       // // 上传完成后的回调 | ||||||
|  |      | ||||||
|  |       // // 更新临时消息为最终消息 | ||||||
|  |       // dialogueStore.completeUpload(uploadId, { | ||||||
|  |       //   url: videoData.data.ori_url, | ||||||
|  |       //   cover: videoData.data.cover_url | ||||||
|  |       // }) | ||||||
|  |        | ||||||
|  |       // // 上传成功后,发送正式消息给服务端 | ||||||
|  |       // let finalMessage = { | ||||||
|  |       //   type: 'video', | ||||||
|  |       //   url: videoData.data.ori_url, | ||||||
|  | 
 | ||||||
|  |       //   size: data.size | ||||||
|  |       // } | ||||||
|  |        | ||||||
|  |       // // 发送真实消息到服务端 | ||||||
|  |       // onSendMessage(finalMessage, () => { | ||||||
|  |       //   // 上传成功且消息发送成功后,删除临时消息 | ||||||
|  |       //   dialogueStore.batchDelDialogueRecord([uploadId]) | ||||||
|  |       // }) | ||||||
|     } |     } | ||||||
|   ) |   ) | ||||||
| } | } | ||||||
| @ -160,10 +185,10 @@ const onSendFileEvent = ({ data }) => { | |||||||
|   if (data.size > maxsize) { |   if (data.size > maxsize) { | ||||||
|     return window['$message'].warning('上传文件不能超过100M!') |     return window['$message'].warning('上传文件不能超过100M!') | ||||||
|   } |   } | ||||||
|   const clientUploadId = `file-${Date.now()}-${Math.floor(Math.random() * 1000)}` |   const uploadId = `file-${Date.now()}-${Math.floor(Math.random() * 1000)}` | ||||||
| 
 | 
 | ||||||
|   const tempMessage = { |   const tempMessage = { | ||||||
|     msg_id: clientUploadId, |     msg_id: uploadId, | ||||||
|     sequence: Date.now(), |     sequence: Date.now(), | ||||||
|     talk_type: props.talk_type, |     talk_type: props.talk_type, | ||||||
|     msg_type: 6, |     msg_type: 6, | ||||||
| @ -179,19 +204,20 @@ const onSendFileEvent = ({ data }) => { | |||||||
|       url: '',  |       url: '',  | ||||||
|       size: data.size, |       size: data.size, | ||||||
|       is_uploading: true, |       is_uploading: true, | ||||||
|       upload_id: clientUploadId, |       upload_id: uploadId, | ||||||
|       percentage: 0 |       percentage: 0 | ||||||
|     }, |     }, | ||||||
|  |     erp_user_id: 4692, | ||||||
|     float: 'right' |     float: 'right' | ||||||
|   } |   } | ||||||
|   dialogueStore.addDialogueRecord(tempMessage) |   dialogueStore.addDialogueRecord(tempMessage) | ||||||
| 
 | 
 | ||||||
|   uploadsStore.initUploadFile(data, props.talk_type, props.receiver_id,clientUploadId, |   uploadsStore.initUploadFile(data, props.talk_type, props.receiver_id, dialogueStore.talk.username,uploadId, | ||||||
|   async (percentage) => { |   async (percentage) => { | ||||||
|       dialogueStore.updateUploadProgress(clientUploadId, percentage) |       dialogueStore.updateUploadProgress(uploadId, percentage) | ||||||
|     }, |     }, | ||||||
|     async () => { |     async () => { | ||||||
|       dialogueStore.batchDelDialogueRecord([clientUploadId]) |       dialogueStore.batchDelDialogueRecord([uploadId]) | ||||||
|     } |     } | ||||||
|   ) |   ) | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user