reaction-picker.ts を戻し、今回の対応を入れた emoji-picker.ts を新たに作成
This commit is contained in:
parent
a696a0f019
commit
d23fb314b9
|
@ -19,6 +19,7 @@ import { claimAchievement, claimedAchievements } from '@/scripts/achievements.js
|
||||||
import { mainRouter } from '@/router.js';
|
import { mainRouter } from '@/router.js';
|
||||||
import { initializeSw } from '@/scripts/initialize-sw.js';
|
import { initializeSw } from '@/scripts/initialize-sw.js';
|
||||||
import { deckStore } from '@/ui/deck/deck-store.js';
|
import { deckStore } from '@/ui/deck/deck-store.js';
|
||||||
|
import { emojiPicker } from '@/scripts/emoji-picker.js';
|
||||||
|
|
||||||
export async function mainBoot() {
|
export async function mainBoot() {
|
||||||
const { isClientUpdated } = await common(() => createApp(
|
const { isClientUpdated } = await common(() => createApp(
|
||||||
|
@ -30,6 +31,7 @@ export async function mainBoot() {
|
||||||
));
|
));
|
||||||
|
|
||||||
reactionPicker.init();
|
reactionPicker.init();
|
||||||
|
emojiPicker.init();
|
||||||
|
|
||||||
if (isClientUpdated && $i) {
|
if (isClientUpdated && $i) {
|
||||||
popup(defineAsyncComponent(() => import('@/components/MkUpdated.vue')), {}, {}, 'closed');
|
popup(defineAsyncComponent(() => import('@/components/MkUpdated.vue')), {}, {}, 'closed');
|
||||||
|
|
|
@ -124,7 +124,7 @@ import { deepClone } from '@/scripts/clone.js';
|
||||||
import MkRippleEffect from '@/components/MkRippleEffect.vue';
|
import MkRippleEffect from '@/components/MkRippleEffect.vue';
|
||||||
import { miLocalStorage } from '@/local-storage.js';
|
import { miLocalStorage } from '@/local-storage.js';
|
||||||
import { claimAchievement } from '@/scripts/achievements.js';
|
import { claimAchievement } from '@/scripts/achievements.js';
|
||||||
import { reactionPicker } from '@/scripts/reaction-picker.js';
|
import { emojiPicker } from '@/scripts/emoji-picker.js';
|
||||||
|
|
||||||
const modal = inject('modal');
|
const modal = inject('modal');
|
||||||
|
|
||||||
|
@ -846,15 +846,14 @@ function insertMention() {
|
||||||
}
|
}
|
||||||
|
|
||||||
async function insertEmoji(ev: MouseEvent) {
|
async function insertEmoji(ev: MouseEvent) {
|
||||||
reactionPicker.show(
|
emojiPicker.show(
|
||||||
ev.currentTarget ?? ev.target,
|
ev.currentTarget ?? ev.target,
|
||||||
reaction => {
|
emoji => {
|
||||||
insertTextAtCursor(textareaEl, reaction);
|
insertTextAtCursor(textareaEl, emoji);
|
||||||
},
|
},
|
||||||
() => {
|
() => {
|
||||||
focus();
|
focus();
|
||||||
},
|
},
|
||||||
false,
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,57 @@
|
||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: syuilo and other misskey contributors
|
||||||
|
* SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { defineAsyncComponent, Ref, ref } from 'vue';
|
||||||
|
import { popup } from '@/os.js';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 絵文字ピッカーを表示する。
|
||||||
|
* 類似の機能として{@link ReactionPicker}が存在しているが、この機能とは動きが異なる。
|
||||||
|
* 投稿フォームなどで絵文字を選択する時など、絵文字ピックアップ後でもダイアログが消えずに残り、
|
||||||
|
* 一度表示したダイアログを連続で使用できることが望ましいシーンでの利用が想定される。
|
||||||
|
*/
|
||||||
|
class EmojiPicker {
|
||||||
|
private src: Ref<HTMLElement | null> = ref(null);
|
||||||
|
private manualShowing = ref(false);
|
||||||
|
private onChosen?: (emoji: string) => void;
|
||||||
|
private onClosed?: () => void;
|
||||||
|
|
||||||
|
constructor() {
|
||||||
|
// nop
|
||||||
|
}
|
||||||
|
|
||||||
|
public async init() {
|
||||||
|
await popup(defineAsyncComponent(() => import('@/components/MkEmojiPickerDialog.vue')), {
|
||||||
|
src: this.src,
|
||||||
|
asReactionPicker: true,
|
||||||
|
manualShowing: this.manualShowing,
|
||||||
|
choseAndClose: false,
|
||||||
|
}, {
|
||||||
|
done: emoji => {
|
||||||
|
if (this.onChosen) this.onChosen(emoji);
|
||||||
|
},
|
||||||
|
close: () => {
|
||||||
|
this.manualShowing.value = false;
|
||||||
|
},
|
||||||
|
closed: () => {
|
||||||
|
this.src.value = null;
|
||||||
|
if (this.onClosed) this.onClosed();
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public show(
|
||||||
|
src: HTMLElement,
|
||||||
|
onChosen: EmojiPicker['onChosen'],
|
||||||
|
onClosed: EmojiPicker['onClosed'],
|
||||||
|
) {
|
||||||
|
this.src.value = src;
|
||||||
|
this.manualShowing.value = true;
|
||||||
|
this.onChosen = onChosen;
|
||||||
|
this.onClosed = onClosed;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const emojiPicker = new EmojiPicker();
|
|
@ -9,7 +9,6 @@ import { popup } from '@/os.js';
|
||||||
class ReactionPicker {
|
class ReactionPicker {
|
||||||
private src: Ref<HTMLElement | null> = ref(null);
|
private src: Ref<HTMLElement | null> = ref(null);
|
||||||
private manualShowing = ref(false);
|
private manualShowing = ref(false);
|
||||||
private choseAndClose = ref(true);
|
|
||||||
private onChosen?: (reaction: string) => void;
|
private onChosen?: (reaction: string) => void;
|
||||||
private onClosed?: () => void;
|
private onClosed?: () => void;
|
||||||
|
|
||||||
|
@ -22,7 +21,6 @@ class ReactionPicker {
|
||||||
src: this.src,
|
src: this.src,
|
||||||
asReactionPicker: true,
|
asReactionPicker: true,
|
||||||
manualShowing: this.manualShowing,
|
manualShowing: this.manualShowing,
|
||||||
choseAndClose: this.choseAndClose,
|
|
||||||
}, {
|
}, {
|
||||||
done: reaction => {
|
done: reaction => {
|
||||||
this.onChosen!(reaction);
|
this.onChosen!(reaction);
|
||||||
|
@ -37,15 +35,9 @@ class ReactionPicker {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public show(
|
public show(src: HTMLElement, onChosen: ReactionPicker['onChosen'], onClosed: ReactionPicker['onClosed']) {
|
||||||
src: HTMLElement,
|
|
||||||
onChosen: ReactionPicker['onChosen'],
|
|
||||||
onClosed: ReactionPicker['onClosed'],
|
|
||||||
choseAndClose = true,
|
|
||||||
) {
|
|
||||||
this.src.value = src;
|
this.src.value = src;
|
||||||
this.manualShowing.value = true;
|
this.manualShowing.value = true;
|
||||||
this.choseAndClose.value = choseAndClose;
|
|
||||||
this.onChosen = onChosen;
|
this.onChosen = onChosen;
|
||||||
this.onClosed = onClosed;
|
this.onClosed = onClosed;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue