Compare commits
	
		
			No commits in common. "a8fea9ea32304def2dfa0ddab6d0ee93bec4f21e" and "445f8f2e79d9cfe958ae995ca34e693091fd1607" have entirely different histories.
		
	
	
		
			a8fea9ea32
			...
			445f8f2e79
		
	
		
| @ -33,6 +33,7 @@ const props = defineProps({ | ||||
| const emit = defineEmits(['editor-event']) | ||||
| const userStore = useUserStore() | ||||
| const dialogueStore = useDialogueStore() | ||||
| console.log('dialogueStore', dialogueStore.talk.talk_type) | ||||
| const editorDraftStore = useEditorDraftStore() | ||||
| const editorRef = ref(null) | ||||
| const content = ref('') | ||||
| @ -171,6 +172,7 @@ const updateMentionPosition = (range) => { | ||||
|   } | ||||
| } | ||||
| const insertMention = (member, clonedRange) => { | ||||
|   console.log('插入mention', member); | ||||
|   const selection = window.getSelection(); | ||||
|   if (!clonedRange || !selection || !editorRef.value) return; | ||||
|   const range = clonedRange; | ||||
| @ -563,20 +565,20 @@ const parseEditorContent = () => { | ||||
|         currentTextBuffer += '\n'; | ||||
|         break; | ||||
|       case 'IMG': | ||||
|         flushTextBufferIfNeeded(); | ||||
|         const src = node.getAttribute('src'); | ||||
|         const alt = node.getAttribute('alt'); | ||||
|         const isEmojiPic = node.classList.contains('editor-emoji'); | ||||
|         const isTextEmojiPlaceholder = node.classList.contains('emoji'); | ||||
|         if ((isEmojiPic || isTextEmojiPlaceholder) && alt) { | ||||
|         if (isTextEmojiPlaceholder && alt) { | ||||
|           currentTextBuffer += alt; | ||||
|         } else if (src) { | ||||
|           flushTextBufferIfNeeded(); | ||||
|           items.push({ | ||||
|             type: 3, | ||||
|             content: src, | ||||
|             isEmoji: false, | ||||
|             width: node.getAttribute('data-original-width') || node.width, | ||||
|             height: node.getAttribute('data-original-height') || node.height | ||||
|             isEmoji: isEmojiPic, | ||||
|             width: node.getAttribute('data-original-width') || node.width || null, | ||||
|             height: node.getAttribute('data-original-height') || node.height || null, | ||||
|           }); | ||||
|         } | ||||
|         break; | ||||
| @ -885,8 +887,12 @@ const insertImageEmoji = (imgSrc, altText) => { | ||||
|   img.className = 'editor-emoji'; | ||||
|   img.setAttribute('data-role', 'emoji'); | ||||
|   range.insertNode(img); | ||||
|   const spaceNode = document.createTextNode('\u00A0'); | ||||
|   range.setStartAfter(img); | ||||
|   range.collapse(true); | ||||
|   range.insertNode(spaceNode); | ||||
|   range.setStartAfter(spaceNode); | ||||
|   range.collapse(true); | ||||
|   if (selection) { | ||||
|     selection.removeAllRanges(); | ||||
|     selection.addRange(range); | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user