mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-26 19:14:12 +00:00 
			
		
		
		
	fix (frontend): 絵文字ピッカー経由で投稿欄に絵文字を入れた際、ソフトウェアキーボードが立ち上がらないようにする (#12561)
This commit is contained in:
		
							parent
							
								
									bb38e62ae6
								
							
						
					
					
						commit
						e90ad09551
					
				
					 1 changed files with 6 additions and 2 deletions
				
			
		|  | @ -67,7 +67,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 	<MkInfo v-if="hasNotSpecifiedMentions" warn :class="$style.hasNotSpecifiedMentions">{{ i18n.ts.notSpecifiedMentionWarning }} - <button class="_textButton" @click="addMissingMention()">{{ i18n.ts.add }}</button></MkInfo> | ||||
| 	<input v-show="useCw" ref="cwInputEl" v-model="cw" :class="$style.cw" :placeholder="i18n.ts.annotation" @keydown="onKeydown"> | ||||
| 	<div :class="[$style.textOuter, { [$style.withCw]: useCw }]"> | ||||
| 		<textarea ref="textareaEl" v-model="text" :class="[$style.text]" :disabled="posting || posted" :placeholder="placeholder" data-cy-post-form-text @keydown="onKeydown" @paste="onPaste" @compositionupdate="onCompositionUpdate" @compositionend="onCompositionEnd"/> | ||||
| 		<textarea ref="textareaEl" v-model="text" :class="[$style.text]" :disabled="posting || posted" :readonly="textAreaReadOnly" :placeholder="placeholder" data-cy-post-form-text @keydown="onKeydown" @paste="onPaste" @compositionupdate="onCompositionUpdate" @compositionend="onCompositionEnd"/> | ||||
| 		<div v-if="maxTextLength - textLength < 100" :class="['_acrylic', $style.textCount, { [$style.textOver]: textLength > maxTextLength }]">{{ maxTextLength - textLength }}</div> | ||||
| 	</div> | ||||
| 	<input v-show="withHashtags" ref="hashtagsInputEl" v-model="hashtags" :class="$style.hashtags" :placeholder="i18n.ts.hashtags" list="hashtags"> | ||||
|  | @ -98,7 +98,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
| import { inject, watch, nextTick, onMounted, defineAsyncComponent, provide } from 'vue'; | ||||
| import { inject, watch, nextTick, onMounted, defineAsyncComponent, provide, ref } from 'vue'; | ||||
| import * as mfm from 'mfm-js'; | ||||
| import * as Misskey from 'misskey-js'; | ||||
| import insertTextAtCursor from 'insert-text-at-cursor'; | ||||
|  | @ -195,6 +195,7 @@ let hasNotSpecifiedMentions = $ref(false); | |||
| let recentHashtags = $ref(JSON.parse(miLocalStorage.getItem('hashtags') ?? '[]')); | ||||
| let imeText = $ref(''); | ||||
| let showingOptions = $ref(false); | ||||
| const textAreaReadOnly = ref(false); | ||||
| 
 | ||||
| const draftKey = $computed((): string => { | ||||
| 	let key = props.channel ? `channel:${props.channel.id}` : ''; | ||||
|  | @ -846,12 +847,15 @@ function insertMention() { | |||
| } | ||||
| 
 | ||||
| async function insertEmoji(ev: MouseEvent) { | ||||
| 	textAreaReadOnly.value = true; | ||||
| 
 | ||||
| 	emojiPicker.show( | ||||
| 		ev.currentTarget ?? ev.target, | ||||
| 		emoji => { | ||||
| 			insertTextAtCursor(textareaEl, emoji); | ||||
| 		}, | ||||
| 		() => { | ||||
| 			textAreaReadOnly.value = false; | ||||
| 			focus(); | ||||
| 		}, | ||||
| 	); | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue