From 8a0c4e7e147b209a5eb616f707f4a4053bf5dd07 Mon Sep 17 00:00:00 2001 From: nokhnaton Date: Thu, 24 Oct 2024 01:11:20 +0900 Subject: [PATCH] =?UTF-8?q?=E3=82=B3=E3=83=94=E3=83=BC=E3=81=97=E3=81=9F?= =?UTF-8?q?=E3=81=A8=E3=81=8D=E3=81=AE=E3=83=A2=E3=83=BC=E3=83=80=E3=83=AB?= =?UTF-8?q?=E3=81=AB=E8=AA=AC=E6=98=8E=E3=82=92=E3=81=A4=E3=81=91=E3=81=9F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../composables/useCopyChannelLink.ts | 2 +- .../MessageElement/MessageContextMenu.vue | 7 +++---- src/composables/contextMenu/useCopyLink.ts | 4 ++-- src/composables/toast/useCopyText.ts | 16 ++++++++++++---- 4 files changed, 18 insertions(+), 11 deletions(-) diff --git a/src/components/Main/MainView/ChannelView/ChannelHeader/composables/useCopyChannelLink.ts b/src/components/Main/MainView/ChannelView/ChannelHeader/composables/useCopyChannelLink.ts index dbda81a9c..e2b7eaf21 100644 --- a/src/components/Main/MainView/ChannelView/ChannelHeader/composables/useCopyChannelLink.ts +++ b/src/components/Main/MainView/ChannelView/ChannelHeader/composables/useCopyChannelLink.ts @@ -12,7 +12,7 @@ const useCopyChannelLink = (props: { channelId: ChannelId }) => { const channelPath = channelIdToPathString(props.channelId) const channelUrl = `${embeddingOrigin}${constructChannelPath(channelPath)}` - await copyText(`[#${channelPath}](${channelUrl})`) + await copyText(`[#${channelPath}](${channelUrl})`, 'チャンネルリンク') } return { copyLink } diff --git a/src/components/Main/MainView/MessageElement/MessageContextMenu.vue b/src/components/Main/MainView/MessageElement/MessageContextMenu.vue index 70fe970ea..dd831a620 100644 --- a/src/components/Main/MainView/MessageElement/MessageContextMenu.vue +++ b/src/components/Main/MainView/MessageElement/MessageContextMenu.vue @@ -63,6 +63,7 @@ import { useMeStore } from '/@/store/domain/me' import { useModalStore } from '/@/store/ui/modal' import { useMessagesStore } from '/@/store/entities/messages' import { useMessageEditingStateStore } from '/@/store/ui/messageEditingStateStore' +import useCopyText from '/@/composables/toast/useCopyText' const useMessageChanger = (messageId: Ref) => { const { execWithToast } = useExecWithToast() @@ -86,15 +87,13 @@ const useMessageChanger = (messageId: Ref) => { } const useCopyMd = (messageId: Ref) => { - const { execWithToast } = useExecWithToast() const { messagesMap } = useMessagesStore() + const { copyText } = useCopyText() const copyMd = async () => { const content = messagesMap.value.get(messageId.value)?.content ?? '' const replacedContent = replaceBack(content) - execWithToast('コピーしました', 'コピーに失敗しました', () => - navigator.clipboard.writeText(replacedContent) - ) + copyText(replacedContent, 'Markdown') } return { copyMd } } diff --git a/src/composables/contextMenu/useCopyLink.ts b/src/composables/contextMenu/useCopyLink.ts index bd811babd..9660b8656 100644 --- a/src/composables/contextMenu/useCopyLink.ts +++ b/src/composables/contextMenu/useCopyLink.ts @@ -9,12 +9,12 @@ const useCopyLink = (messageId: Ref) => { const copyLink = async () => { const link = `${embeddingOrigin}${constructMessagesPath(messageId.value)}` - await copyText(link) + await copyText(link, 'メッセージリンク') } const copyEmbedded = async () => { const link = `` - await copyText(link) + await copyText(link, '埋め込み') } return { copyLink, copyEmbedded } diff --git a/src/composables/toast/useCopyText.ts b/src/composables/toast/useCopyText.ts index b455b3a94..33e9bbfd0 100644 --- a/src/composables/toast/useCopyText.ts +++ b/src/composables/toast/useCopyText.ts @@ -3,10 +3,18 @@ import useExecWithToast from '/@/composables/toast/useExecWithToast' const useCopyText = () => { const { execWithToast } = useExecWithToast() - const copyText = async (text: string) => { - await execWithToast('コピーしました', 'コピーに失敗しました', () => - navigator.clipboard.writeText(text) - ) + const copyText = async (text: string, description?: string) => { + if (description === undefined) { + await execWithToast('コピーしました', 'コピーに失敗しました', () => + navigator.clipboard.writeText(text) + ) + } else { + await execWithToast( + `${description}をコピーしました`, + `${description}のコピーに失敗しました`, + () => navigator.clipboard.writeText(text) + ) + } } return { copyText }