Compare commits
	
		
			No commits in common. "78009bc5e7d537ef3773ee7311bccc310247ca14" and "6c63946d37692ce0cec7d8551c9e636c1373eee5" have entirely different histories.
		
	
	
		
			78009bc5e7
			...
			6c63946d37
		
	
		
| @ -20,7 +20,6 @@ | |||||||
|     "@iconify-json/ion": "^1.2.3", |     "@iconify-json/ion": "^1.2.3", | ||||||
|     "@kangc/v-md-editor": "^2.3.18", |     "@kangc/v-md-editor": "^2.3.18", | ||||||
|     "@onlyoffice/document-editor-vue": "^1.5.0", |     "@onlyoffice/document-editor-vue": "^1.5.0", | ||||||
|     "@soerenmartius/vue3-clipboard": "^0.1.2", |  | ||||||
|     "@tiptap/core": "^2.23.1", |     "@tiptap/core": "^2.23.1", | ||||||
|     "@tiptap/extension-blockquote": "^2.23.1", |     "@tiptap/extension-blockquote": "^2.23.1", | ||||||
|     "@tiptap/extension-emoji": "^2.23.1", |     "@tiptap/extension-emoji": "^2.23.1", | ||||||
|  | |||||||
| @ -26,9 +26,6 @@ importers: | |||||||
|       '@onlyoffice/document-editor-vue': |       '@onlyoffice/document-editor-vue': | ||||||
|         specifier: ^1.5.0 |         specifier: ^1.5.0 | ||||||
|         version: 1.5.0(vue@3.5.17(typescript@5.2.2)) |         version: 1.5.0(vue@3.5.17(typescript@5.2.2)) | ||||||
|       '@soerenmartius/vue3-clipboard': |  | ||||||
|         specifier: ^0.1.2 |  | ||||||
|         version: 0.1.2 |  | ||||||
|       '@tiptap/core': |       '@tiptap/core': | ||||||
|         specifier: ^2.23.1 |         specifier: ^2.23.1 | ||||||
|         version: 2.23.1(@tiptap/pm@2.23.1) |         version: 2.23.1(@tiptap/pm@2.23.1) | ||||||
| @ -901,9 +898,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-tlqY9xq5ukxTUZBmoOp+m61cqwQD5pHJtFY3Mn8CA8ps6yghLH/Hw8UPdqg4OLmFW3IFlcXnQNmo/dh8HzXYIQ==} |     resolution: {integrity: sha512-tlqY9xq5ukxTUZBmoOp+m61cqwQD5pHJtFY3Mn8CA8ps6yghLH/Hw8UPdqg4OLmFW3IFlcXnQNmo/dh8HzXYIQ==} | ||||||
|     engines: {node: '>=18'} |     engines: {node: '>=18'} | ||||||
| 
 | 
 | ||||||
|   '@soerenmartius/vue3-clipboard@0.1.2': |  | ||||||
|     resolution: {integrity: sha512-a5er6cFGcFIQ/3qg6kWvU0yFqIz9iWoQGEVs9azjevyRyMAKvj1w3JuLH9y6+u0WhMNby3kn7nuR8nktSnDesg==} |  | ||||||
| 
 |  | ||||||
|   '@tiptap/core@2.23.1': |   '@tiptap/core@2.23.1': | ||||||
|     resolution: {integrity: sha512-EURGKGsEPrwxvOPi9gA+BsczvsECJNV+xgTAGWHmEtU4YJ0AulYrCX3b7FK+aiduVhThIHDoG/Mmvmb/HPLRhQ==} |     resolution: {integrity: sha512-EURGKGsEPrwxvOPi9gA+BsczvsECJNV+xgTAGWHmEtU4YJ0AulYrCX3b7FK+aiduVhThIHDoG/Mmvmb/HPLRhQ==} | ||||||
|     peerDependencies: |     peerDependencies: | ||||||
| @ -1619,9 +1613,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==} |     resolution: {integrity: sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==} | ||||||
|     engines: {node: '>=0.10.0'} |     engines: {node: '>=0.10.0'} | ||||||
| 
 | 
 | ||||||
|   clipboard@2.0.11: |  | ||||||
|     resolution: {integrity: sha512-C+0bbOqkezLIsmWSvlsXS0Q0bmkugu7jcfMIACB+RDEntIzQIkdr148we28AfSloQLRdZlYL/QYyrq05j/3Faw==} |  | ||||||
| 
 |  | ||||||
|   cliui@8.0.1: |   cliui@8.0.1: | ||||||
|     resolution: {integrity: sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==} |     resolution: {integrity: sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==} | ||||||
|     engines: {node: '>=12'} |     engines: {node: '>=12'} | ||||||
| @ -2356,9 +2347,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-ollPHROa5mcxDEkwg6bPt3QbEf4pDQSNtd6JPL1YvOvAo/7/0VAm9TccUeoTmarjPw4pfUthSCqcyfNB1I3ZSg==} |     resolution: {integrity: sha512-ollPHROa5mcxDEkwg6bPt3QbEf4pDQSNtd6JPL1YvOvAo/7/0VAm9TccUeoTmarjPw4pfUthSCqcyfNB1I3ZSg==} | ||||||
|     engines: {node: '>=6'} |     engines: {node: '>=6'} | ||||||
| 
 | 
 | ||||||
|   good-listener@1.2.2: |  | ||||||
|     resolution: {integrity: sha512-goW1b+d9q/HIwbVYZzZ6SsTr4IgE+WA44A0GmPIQstuOrgsFcT7VEJ48nmr9GaRtNu0XTKacFLGnBPAM6Afouw==} |  | ||||||
| 
 |  | ||||||
|   gopd@1.2.0: |   gopd@1.2.0: | ||||||
|     resolution: {integrity: sha512-ZUKRh6/kUFoAiTAtTYPZJ3hw9wNxx+BIBOijnlG9PnrJsCcSjs1wyyD6vJpaYtgnzDrKYRSqf3OO6Rfa93xsRg==} |     resolution: {integrity: sha512-ZUKRh6/kUFoAiTAtTYPZJ3hw9wNxx+BIBOijnlG9PnrJsCcSjs1wyyD6vJpaYtgnzDrKYRSqf3OO6Rfa93xsRg==} | ||||||
|     engines: {node: '>= 0.4'} |     engines: {node: '>= 0.4'} | ||||||
| @ -3370,9 +3358,6 @@ packages: | |||||||
|   seemly@0.3.10: |   seemly@0.3.10: | ||||||
|     resolution: {integrity: sha512-2+SMxtG1PcsL0uyhkumlOU6Qo9TAQ/WyH7tthnPIOQB05/12jz9naq6GZ6iZ6ApVsO3rr2gsnTf3++OV63kE1Q==} |     resolution: {integrity: sha512-2+SMxtG1PcsL0uyhkumlOU6Qo9TAQ/WyH7tthnPIOQB05/12jz9naq6GZ6iZ6ApVsO3rr2gsnTf3++OV63kE1Q==} | ||||||
| 
 | 
 | ||||||
|   select@1.1.2: |  | ||||||
|     resolution: {integrity: sha512-OwpTSOfy6xSs1+pwcNrv0RBMOzI39Lp3qQKUTPVVPRjCdNa5JH/oPRiqsesIskK8TVgmRiHwO4KXlV2Li9dANA==} |  | ||||||
| 
 |  | ||||||
|   semver@5.7.2: |   semver@5.7.2: | ||||||
|     resolution: {integrity: sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==} |     resolution: {integrity: sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==} | ||||||
|     hasBin: true |     hasBin: true | ||||||
| @ -3558,9 +3543,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-B71/4oyj61iNH0KeCamLuE2rmKuTO5byTOSVwECM5FA7TiAiAW+UqTKZ9ERueC4qvgSttUhdmq1mXC3kJqGX7A==} |     resolution: {integrity: sha512-B71/4oyj61iNH0KeCamLuE2rmKuTO5byTOSVwECM5FA7TiAiAW+UqTKZ9ERueC4qvgSttUhdmq1mXC3kJqGX7A==} | ||||||
|     engines: {node: '>=12.22'} |     engines: {node: '>=12.22'} | ||||||
| 
 | 
 | ||||||
|   tiny-emitter@2.1.0: |  | ||||||
|     resolution: {integrity: sha512-NB6Dk1A9xgQPMoGqC5CVXn123gWyte215ONT5Pp5a0yt4nlEoO1ZWeCwpncaekPHXO60i47ihFnZPiRPjRMq4Q==} |  | ||||||
| 
 |  | ||||||
|   tinyexec@1.0.1: |   tinyexec@1.0.1: | ||||||
|     resolution: {integrity: sha512-5uC6DDlmeqiOwCPmK9jMSdOuZTh8bU39Ys6yidB+UTt5hfZUPGAypSgFRiEp+jbi9qH40BLDvy85jIU88wKSqw==} |     resolution: {integrity: sha512-5uC6DDlmeqiOwCPmK9jMSdOuZTh8bU39Ys6yidB+UTt5hfZUPGAypSgFRiEp+jbi9qH40BLDvy85jIU88wKSqw==} | ||||||
| 
 | 
 | ||||||
| @ -4577,10 +4559,6 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   '@sindresorhus/merge-streams@4.0.0': {} |   '@sindresorhus/merge-streams@4.0.0': {} | ||||||
| 
 | 
 | ||||||
|   '@soerenmartius/vue3-clipboard@0.1.2': |  | ||||||
|     dependencies: |  | ||||||
|       clipboard: 2.0.11 |  | ||||||
| 
 |  | ||||||
|   '@tiptap/core@2.23.1(@tiptap/pm@2.23.1)': |   '@tiptap/core@2.23.1(@tiptap/pm@2.23.1)': | ||||||
|     dependencies: |     dependencies: | ||||||
|       '@tiptap/pm': 2.23.1 |       '@tiptap/pm': 2.23.1 | ||||||
| @ -5540,12 +5518,6 @@ snapshots: | |||||||
|       isobject: 3.0.1 |       isobject: 3.0.1 | ||||||
|       static-extend: 0.1.2 |       static-extend: 0.1.2 | ||||||
| 
 | 
 | ||||||
|   clipboard@2.0.11: |  | ||||||
|     dependencies: |  | ||||||
|       good-listener: 1.2.2 |  | ||||||
|       select: 1.1.2 |  | ||||||
|       tiny-emitter: 2.1.0 |  | ||||||
| 
 |  | ||||||
|   cliui@8.0.1: |   cliui@8.0.1: | ||||||
|     dependencies: |     dependencies: | ||||||
|       string-width: 4.2.3 |       string-width: 4.2.3 | ||||||
| @ -6327,10 +6299,6 @@ snapshots: | |||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - supports-color |       - supports-color | ||||||
| 
 | 
 | ||||||
|   good-listener@1.2.2: |  | ||||||
|     dependencies: |  | ||||||
|       delegate: 3.2.0 |  | ||||||
| 
 |  | ||||||
|   gopd@1.2.0: {} |   gopd@1.2.0: {} | ||||||
| 
 | 
 | ||||||
|   graceful-fs@4.2.11: {} |   graceful-fs@4.2.11: {} | ||||||
| @ -7462,8 +7430,6 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   seemly@0.3.10: {} |   seemly@0.3.10: {} | ||||||
| 
 | 
 | ||||||
|   select@1.1.2: {} |  | ||||||
| 
 |  | ||||||
|   semver@5.7.2: |   semver@5.7.2: | ||||||
|     optional: true |     optional: true | ||||||
| 
 | 
 | ||||||
| @ -7643,8 +7609,6 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   throttle-debounce@5.0.2: {} |   throttle-debounce@5.0.2: {} | ||||||
| 
 | 
 | ||||||
|   tiny-emitter@2.1.0: {} |  | ||||||
| 
 |  | ||||||
|   tinyexec@1.0.1: {} |   tinyexec@1.0.1: {} | ||||||
| 
 | 
 | ||||||
|   tinyglobby@0.2.14: |   tinyglobby@0.2.14: | ||||||
|  | |||||||
| @ -1,5 +1,5 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="dropdown-menu" ref="dropdownMenuRef"> |   <div class="dropdown-menu"> | ||||||
|     <n-virtual-list |     <n-virtual-list | ||||||
|       ref="virtualListRef" |       ref="virtualListRef" | ||||||
|       style="max-height: 240px" |       style="max-height: 240px" | ||||||
| @ -20,7 +20,7 @@ | |||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { ref, watch, defineProps, defineExpose, onMounted, onUnmounted } from 'vue' | import { ref, watch, defineProps, defineExpose } from 'vue' | ||||||
| 
 | 
 | ||||||
| const props = defineProps({ | const props = defineProps({ | ||||||
|   items: { |   items: { | ||||||
| @ -35,40 +35,6 @@ const props = defineProps({ | |||||||
| 
 | 
 | ||||||
| const selectedIndex = ref(0) | const selectedIndex = ref(0) | ||||||
| const virtualListRef = ref(null) | const virtualListRef = ref(null) | ||||||
| const dropdownMenuRef = ref(null) |  | ||||||
| 
 |  | ||||||
| let observer = null |  | ||||||
| 
 |  | ||||||
| let isViewport = ref(true) |  | ||||||
| const handleIntersection = (entries, observer) => { |  | ||||||
|   entries.forEach(entry => { |  | ||||||
|     if (entry.isIntersecting) { |  | ||||||
|       isViewport.value = true |  | ||||||
|       // 在这里处理元素可见的逻辑 |  | ||||||
|     } else { |  | ||||||
|       isViewport.value = false |  | ||||||
|       // 在这里处理元素不可见的逻辑 |  | ||||||
|     } |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| onMounted(() => { |  | ||||||
|   observer = new IntersectionObserver(handleIntersection, { |  | ||||||
|     root: null, // null 值表示视口 |  | ||||||
|     rootMargin: '0px', |  | ||||||
|     threshold: 0.1 // 元素至少有 10% 可见时触发回调 |  | ||||||
|   }) |  | ||||||
| 
 |  | ||||||
|   if (dropdownMenuRef.value) { |  | ||||||
|     observer.observe(dropdownMenuRef.value) |  | ||||||
|   } |  | ||||||
| }) |  | ||||||
| 
 |  | ||||||
| onUnmounted(() => { |  | ||||||
|   if (observer && dropdownMenuRef.value) { |  | ||||||
|     observer.unobserve(dropdownMenuRef.value) |  | ||||||
|     observer.disconnect() |  | ||||||
|   } |  | ||||||
| }) |  | ||||||
| 
 | 
 | ||||||
| watch( | watch( | ||||||
|   () => props.items, |   () => props.items, | ||||||
| @ -78,8 +44,7 @@ watch( | |||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| const onKeyDown = ({ event }) => { | const onKeyDown = ({ event }) => { | ||||||
|   console.log('event', event) |   console.log('event',event) | ||||||
|   if(!isViewport.value) return false |  | ||||||
|   if (event.key === 'ArrowUp') { |   if (event.key === 'ArrowUp') { | ||||||
|     upHandler() |     upHandler() | ||||||
|     return true |     return true | ||||||
| @ -135,7 +100,6 @@ defineExpose({ | |||||||
|   overflow: auto; |   overflow: auto; | ||||||
|   padding: 0.4rem; |   padding: 0.4rem; | ||||||
|   position: relative; |   position: relative; | ||||||
|    |  | ||||||
|   max-height: 200px; |   max-height: 200px; | ||||||
|   width: 200px; |   width: 200px; | ||||||
|   button { |   button { | ||||||
|  | |||||||
| @ -9,7 +9,7 @@ import { computePosition, flip, shift } from '@floating-ui/dom' | |||||||
| import Link from '@tiptap/extension-link' | import Link from '@tiptap/extension-link' | ||||||
| import { Extension, Node } from '@tiptap/core' | import { Extension, Node } from '@tiptap/core' | ||||||
| import { Plugin, PluginKey } from '@tiptap/pm/state' | import { Plugin, PluginKey } from '@tiptap/pm/state' | ||||||
| import { IosSend } from '@vicons/ionicons4' | 
 | ||||||
| 
 | 
 | ||||||
| import { reactive, watch, ref, markRaw, computed, onMounted, onUnmounted, shallowRef } from 'vue' | import { reactive, watch, ref, markRaw, computed, onMounted, onUnmounted, shallowRef } from 'vue' | ||||||
| 
 | 
 | ||||||
| @ -61,9 +61,6 @@ const props = defineProps({ | |||||||
|     type: Boolean, |     type: Boolean, | ||||||
|     default: false |     default: false | ||||||
|   }, |   }, | ||||||
|   uid:{ |  | ||||||
|     type: Number |  | ||||||
|   }, |  | ||||||
|   members: { |   members: { | ||||||
|     default: () => [] |     default: () => [] | ||||||
|   } |   } | ||||||
| @ -219,7 +216,6 @@ const editor = useEditor({ | |||||||
|           return suggestion.items({  |           return suggestion.items({  | ||||||
|             query,  |             query,  | ||||||
|             props: { |             props: { | ||||||
|               uid: props.uid, |  | ||||||
|               members: props.members, |               members: props.members, | ||||||
|               isGroupManager: (dialogueStore.groupInfo).is_manager |               isGroupManager: (dialogueStore.groupInfo).is_manager | ||||||
|             } |             } | ||||||
| @ -291,8 +287,7 @@ const editor = useEditor({ | |||||||
|       if (text) { |       if (text) { | ||||||
|         event.preventDefault() |         event.preventDefault() | ||||||
|         const { state, dispatch } = view |         const { state, dispatch } = view | ||||||
|         // dispatch(state.tr.insertContent(text).replace(/\n/g, '<br>')) |         dispatch(state.tr.insertText(text)) | ||||||
|         editor.value.commands.insertContent(text.replace(/\r/g, '').replace(/\n/g, '<br>')) |  | ||||||
|         return true // Handled |         return true // Handled | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
| @ -402,11 +397,7 @@ async function onUploadFile(e) { | |||||||
| 
 | 
 | ||||||
|   if (file.type.indexOf('image/') === 0) { |   if (file.type.indexOf('image/') === 0) { | ||||||
| 
 | 
 | ||||||
|     const form = new FormData() |     let fn = emitCall('image_event', file, () => {}) | ||||||
|     form.append('file', file) |  | ||||||
|     form.append('source', 'fonchain-chat') |  | ||||||
|     const { data } = await uploadImg(form) |  | ||||||
|     let fn = emitCall('image_event', { url: data.ori_url, size: file.size }, () => { }) |  | ||||||
|     emit('editor-event', fn) |     emit('editor-event', fn) | ||||||
| 
 | 
 | ||||||
|     return |     return | ||||||
| @ -531,8 +522,6 @@ function tiptapToString() { | |||||||
|         result += node.attrs.alt || '' |         result += node.attrs.alt || '' | ||||||
|       } else if (node.type === 'hardBreak') { |       } else if (node.type === 'hardBreak') { | ||||||
|         result += '\n' |         result += '\n' | ||||||
|       } else if (node.type === 'image') { |  | ||||||
|         result += '[图片]' |  | ||||||
|       } |       } | ||||||
|     }) |     }) | ||||||
|   } |   } | ||||||
| @ -716,8 +705,7 @@ function onSubscribeEdit(data) { | |||||||
|   editor.value.commands.clearContent(true) |   editor.value.commands.clearContent(true) | ||||||
|    |    | ||||||
| 
 | 
 | ||||||
|   editor.value.commands.insertContent(data.content.replace(/\n/g, '<br>')) |   editor.value.commands.insertContent(data.content) | ||||||
| 
 |  | ||||||
|    |    | ||||||
| 
 | 
 | ||||||
|   editor.value.commands.focus('end') |   editor.value.commands.focus('end') | ||||||
| @ -796,16 +784,6 @@ useEventBus([ | |||||||
|             <p class="tip-title">{{ nav.title }}</p> |             <p class="tip-title">{{ nav.title }}</p> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div class="h-[45px] flex justify-center items-center"> |  | ||||||
|           <n-button class="w-80px h-30px mr-[22px]" type="primary" @click="onSendMessage"> |  | ||||||
|             <template #icon> |  | ||||||
|               <n-icon> |  | ||||||
|                 <IosSend /> |  | ||||||
|               </n-icon> |  | ||||||
|             </template> |  | ||||||
|             发送 |  | ||||||
|           </n-button> |  | ||||||
|         </div> |  | ||||||
|       </header> |       </header> | ||||||
| 
 | 
 | ||||||
|       <div v-if="quoteData" class="quote-card-wrapper"> |       <div v-if="quoteData" class="quote-card-wrapper"> | ||||||
| @ -993,7 +971,6 @@ html[theme-mode='dark'] { | |||||||
|   outline: none; |   outline: none; | ||||||
|   .tiptap.ProseMirror{ |   .tiptap.ProseMirror{ | ||||||
|     height: 100%; |     height: 100%; | ||||||
|     white-space: pre-wrap; |  | ||||||
|   } |   } | ||||||
|   .image-upload-loading { |   .image-upload-loading { | ||||||
|     position: relative; |     position: relative; | ||||||
|  | |||||||
| @ -39,8 +39,6 @@ export default { | |||||||
|     if (props.isGroupManager) { |     if (props.isGroupManager) { | ||||||
|       list.unshift({ id: 0, nickname: '所有人', avatar: defAvatar }) |       list.unshift({ id: 0, nickname: '所有人', avatar: defAvatar }) | ||||||
|     } |     } | ||||||
|     // 排除掉自己
 |  | ||||||
|     list.splice(list.findIndex((item) => item.id === props.uid), 1) |  | ||||||
| 
 | 
 | ||||||
|     const filteredItems = list.filter( |     const filteredItems = list.filter( | ||||||
|       (item) => item.nickname.toLowerCase().includes(query.toLowerCase()) |       (item) => item.nickname.toLowerCase().includes(query.toLowerCase()) | ||||||
|  | |||||||
| @ -17,7 +17,7 @@ let textContent = props.extra?.content || '' | |||||||
| textContent = textReplaceLink(textContent) | textContent = textReplaceLink(textContent) | ||||||
| 
 | 
 | ||||||
| if (props.data.talk_type == 2) { | if (props.data.talk_type == 2) { | ||||||
|   textContent = textReplaceMention(textContent, float==='right'?'':'black',float==='right'?'':'') |   textContent = textReplaceMention(textContent, float==='right'?'#462AA0':'#fff',float==='right'?'#EEE9F9':'#462AA0') | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| textContent = textReplaceEmoji(textContent) | textContent = textReplaceEmoji(textContent) | ||||||
|  | |||||||
| @ -383,9 +383,6 @@ export const useDialogueStore = defineStore('dialogue', { | |||||||
|          |          | ||||||
|         // 从全局列表中移除
 |         // 从全局列表中移除
 | ||||||
|         this.globalUploadList.splice(taskIndex, 1) |         this.globalUploadList.splice(taskIndex, 1) | ||||||
|         // 移除消息记录
 |  | ||||||
| 
 |  | ||||||
|         this.batchDelDialogueRecord([uploadId]) |  | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|      |      | ||||||
|  | |||||||
| @ -1,5 +1,4 @@ | |||||||
| import { createApp } from 'vue' | import { createApp } from 'vue' | ||||||
| import { toClipboard } from '@soerenmartius/vue3-clipboard' |  | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 防抖函数 |  * 防抖函数 | ||||||
| @ -52,25 +51,20 @@ export function throttle(fn, delay, call = function () {}) { | |||||||
|  * @param {String} text 复制内容 |  * @param {String} text 复制内容 | ||||||
|  * @param {Function} callback 复制成功回调方法 |  * @param {Function} callback 复制成功回调方法 | ||||||
|  */ |  */ | ||||||
| export async function clipboard(text, callback) { | export function clipboard(text, callback) { | ||||||
|   // 在wujie环境下使用主应用的clipboard
 |   // 在wujie环境下使用主应用的clipboard
 | ||||||
|   const clipboardObj = window.__POWERED_BY_WUJIE__  |   const clipboardObj = window.__POWERED_BY_WUJIE__  | ||||||
|     ? window.parent.navigator.clipboard  |     ? window.parent.navigator.clipboard  | ||||||
|     : navigator.clipboard |     : navigator.clipboard | ||||||
|   try { | 
 | ||||||
|     clipboardObj |   clipboardObj | ||||||
|       .writeText(text) |     .writeText(text) | ||||||
|       .then(() => { |     .then(() => { | ||||||
|         callback && callback() |       callback && callback() | ||||||
|       }) |     }) | ||||||
|       .catch(() => { |     .catch(() => { | ||||||
|         alert('Oops, unable to copy') |       alert('Oops, unable to copy') | ||||||
|       }) |     }) | ||||||
|   } catch (e) { |  | ||||||
|     console.error(e) |  | ||||||
|     await toClipboard(text) |  | ||||||
|     callback && callback() |  | ||||||
|   } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export async function clipboardImage(src, callback) { | export async function clipboardImage(src, callback) { | ||||||
|  | |||||||
| @ -48,9 +48,7 @@ request.interceptors.request.use((config) => { | |||||||
|   if (token) { |   if (token) { | ||||||
|     config.headers['Authorization'] = `Bearer ${token}` |     config.headers['Authorization'] = `Bearer ${token}` | ||||||
|   } |   } | ||||||
|   if(config.url.indexOf('api/v1/upload/multipart') > -1){  | 
 | ||||||
|     config.timeout = 600000 |  | ||||||
|   } |  | ||||||
|   return config |   return config | ||||||
| }, errorHandler) | }, errorHandler) | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -75,7 +75,7 @@ const onSendMessage = (data = {}, callBack: any) => { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // 发送文本消息 | // 发送文本消息 | ||||||
| const onSendTextEvent = (value: any) => { | const onSendTextEvent = throttle((value: any) => { | ||||||
|   let { data, callBack } = value |   let { data, callBack } = value | ||||||
| 
 | 
 | ||||||
|   let message = { |   let message = { | ||||||
| @ -93,7 +93,7 @@ const onSendTextEvent = (value: any) => { | |||||||
| 
 | 
 | ||||||
|     callBack(true) |     callBack(true) | ||||||
|   }) |   }) | ||||||
| } | }, 1000) | ||||||
| 
 | 
 | ||||||
| // 发送图片消息 | // 发送图片消息 | ||||||
| const onSendImageEvent = ({ data, callBack }) => { | const onSendImageEvent = ({ data, callBack }) => { | ||||||
| @ -297,7 +297,7 @@ onMounted(() => { | |||||||
|     <MultiSelectFooter v-if="dialogueStore.isOpenMultiSelect" /> |     <MultiSelectFooter v-if="dialogueStore.isOpenMultiSelect" /> | ||||||
|     <!-- <Editor v-else @editor-event="onEditorEvent" :vote="talk_type == 2" :members="members" /> --> |     <!-- <Editor v-else @editor-event="onEditorEvent" :vote="talk_type == 2" :members="members" /> --> | ||||||
|     <!-- <CustomEditor v-else @editor-event="onEditorEvent" :vote="talk_type == 2" :members="members" /> --> |     <!-- <CustomEditor v-else @editor-event="onEditorEvent" :vote="talk_type == 2" :members="members" /> --> | ||||||
|      <TiptapEditor v-else @editor-event="onEditorEvent" :uid="uid" :vote="talk_type == 2" :members="members" /> |      <TiptapEditor v-else @editor-event="onEditorEvent" :vote="talk_type == 2" :members="members" /> | ||||||
|   </footer> |   </footer> | ||||||
| 
 | 
 | ||||||
|   <HistoryRecord |   <HistoryRecord | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user