feat(frontend): 絵文字ピッカーの実装 (#12617)
* 絵文字デッキの作成 * 細かい不備を修正 * fix lint * fix * fix CHANGELOG.md * fix setTimeout -> nextTick * fix https://github.com/misskey-dev/misskey/pull/12617#issuecomment-1848952862 * fix bug * fix CHANGELOG.md * fix CHANGELOG.md * wip * Update CHANGELOG.md * Update CHANGELOG.md * wip --------- Co-authored-by: syuilo <Syuilotan@yahoo.co.jp>
This commit is contained in:
		| @@ -3,8 +3,9 @@ | ||||
|  * SPDX-License-Identifier: AGPL-3.0-only | ||||
|  */ | ||||
|  | ||||
| import { defineAsyncComponent, Ref, ref } from 'vue'; | ||||
| import { defineAsyncComponent, Ref, ref, computed, ComputedRef } from 'vue'; | ||||
| import { popup } from '@/os.js'; | ||||
| import { defaultStore } from '@/store.js'; | ||||
|  | ||||
| /** | ||||
|  * 絵文字ピッカーを表示する。 | ||||
| @@ -23,8 +24,10 @@ class EmojiPicker { | ||||
| 	} | ||||
|  | ||||
| 	public async init() { | ||||
| 		const emojisRef = defaultStore.reactiveState.pinnedEmojis; | ||||
| 		await popup(defineAsyncComponent(() => import('@/components/MkEmojiPickerDialog.vue')), { | ||||
| 			src: this.src, | ||||
| 			pinnedEmojis: emojisRef, | ||||
| 			asReactionPicker: false, | ||||
| 			manualShowing: this.manualShowing, | ||||
| 			choseAndClose: false, | ||||
| @@ -44,8 +47,8 @@ class EmojiPicker { | ||||
|  | ||||
| 	public show( | ||||
| 		src: HTMLElement, | ||||
| 		onChosen: EmojiPicker['onChosen'], | ||||
| 		onClosed: EmojiPicker['onClosed'], | ||||
| 		onChosen?: EmojiPicker['onChosen'], | ||||
| 		onClosed?: EmojiPicker['onClosed'], | ||||
| 	) { | ||||
| 		this.src.value = src; | ||||
| 		this.manualShowing.value = true; | ||||
|   | ||||
| @@ -5,6 +5,7 @@ | ||||
|  | ||||
| import { defineAsyncComponent, Ref, ref } from 'vue'; | ||||
| import { popup } from '@/os.js'; | ||||
| import { defaultStore } from '@/store.js'; | ||||
|  | ||||
| class ReactionPicker { | ||||
| 	private src: Ref<HTMLElement | null> = ref(null); | ||||
| @@ -17,25 +18,27 @@ class ReactionPicker { | ||||
| 	} | ||||
|  | ||||
| 	public async init() { | ||||
| 		const reactionsRef = defaultStore.reactiveState.reactions; | ||||
| 		await popup(defineAsyncComponent(() => import('@/components/MkEmojiPickerDialog.vue')), { | ||||
| 			src: this.src, | ||||
| 			pinnedEmojis: reactionsRef, | ||||
| 			asReactionPicker: true, | ||||
| 			manualShowing: this.manualShowing, | ||||
| 		}, { | ||||
| 			done: reaction => { | ||||
| 				this.onChosen!(reaction); | ||||
| 				if (this.onChosen) this.onChosen(reaction); | ||||
| 			}, | ||||
| 			close: () => { | ||||
| 				this.manualShowing.value = false; | ||||
| 			}, | ||||
| 			closed: () => { | ||||
| 				this.src.value = null; | ||||
| 				this.onClosed!(); | ||||
| 				if (this.onClosed) this.onClosed(); | ||||
| 			}, | ||||
| 		}); | ||||
| 	} | ||||
|  | ||||
| 	public show(src: HTMLElement, onChosen: ReactionPicker['onChosen'], onClosed: ReactionPicker['onClosed']) { | ||||
| 	public show(src: HTMLElement, onChosen?: ReactionPicker['onChosen'], onClosed?: ReactionPicker['onClosed']) { | ||||
| 		this.src.value = src; | ||||
| 		this.manualShowing.value = true; | ||||
| 		this.onChosen = onChosen; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 おさむのひと
					おさむのひと