diff --git a/locales/index.d.ts b/locales/index.d.ts index a52f1c81a59c..1ff65b6b4513 100644 --- a/locales/index.d.ts +++ b/locales/index.d.ts @@ -4960,10 +4960,6 @@ export interface Locale extends ILocale { * 下書き */ "drafts": string; - /** - * 下書きの保存に関する動作 - */ - "draftSavingBehavior": string; /** * 下書きとして保存 */ @@ -9920,16 +9916,6 @@ export interface Locale extends ILocale { */ "loop": string; }; - "_draftSavingBehavior": { - /** - * 自動的に保存する - */ - "auto": string; - /** - * 都度確認する - */ - "manual": string; - }; } declare const locales: { [lang: string]: Locale; diff --git a/locales/ja-JP.yml b/locales/ja-JP.yml index c44e3938b13e..795d801e4b32 100644 --- a/locales/ja-JP.yml +++ b/locales/ja-JP.yml @@ -1236,7 +1236,6 @@ noDescription: "説明文はありません" alwaysConfirmFollow: "フォローの際常に確認する" inquiry: "お問い合わせ" drafts: "下書き" -draftSavingBehavior: "下書きの保存に関する動作" saveAsDraft: "下書きとして保存" draftOverwriteConfirm: "下書きを適用すると現在入力されている内容はリセットされます。よろしいですか?" @@ -2623,7 +2622,6 @@ _offlineScreen: title: "オフライン - サーバーに接続できません" header: "サーバーに接続できません" -<<<<<<< HEAD _urlPreviewSetting: title: "URLプレビューの設定" enable: "URLプレビューを有効にする" @@ -2643,14 +2641,4 @@ _mediaControls: pip: "ピクチャインピクチャ" playbackRate: "再生速度" loop: "ループ再生" -======= -_hideReactionCount: - none: "非表示にしない" - self: "自分のノートのみ" - others: "自分以外のノートのみ" - all: "全てのノート" -_draftSavingBehavior: - auto: "自動的に保存する" - manual: "都度確認する" ->>>>>>> 03d1c493a2 (feat: 下書き機能 (#144)) diff --git a/packages/frontend/src/components/MkPostForm.vue b/packages/frontend/src/components/MkPostForm.vue index ba282184d16a..5f3fc32cfbe5 100644 --- a/packages/frontend/src/components/MkPostForm.vue +++ b/packages/frontend/src/components/MkPostForm.vue @@ -87,6 +87,7 @@ SPDX-License-Identifier: AGPL-3.0-only +
@@ -260,7 +261,6 @@ const canPost = computed((): boolean => { props.renote != null || (props.reply != null && quoteId.value != null) ) && - (scheduledNoteDelete.value ? scheduledNoteDelete.value.isValid : true) && (1 <= textLength.value || 1 <= files.value.length || !!poll.value || !!renote.value) && (textLength.value <= maxTextLength.value) && (!poll.value || poll.value.choices.length >= 2); @@ -269,53 +269,6 @@ const canPost = computed((): boolean => { const withHashtags = computed(defaultStore.makeGetterSetter('postFormWithHashtags')); const hashtags = computed(defaultStore.makeGetterSetter('postFormHashtags')); -const bottomItemActionDef: Record = reactive({ - attachFile: { - action: chooseFileFrom, - }, - poll: { - active: poll, - action: togglePoll, - }, - scheduledNoteDelete: { - active: scheduledNoteDelete, - action: toggleScheduledNoteDelete, - }, - useCw: { - active: useCw, - action: () => useCw.value = !useCw.value, - }, - mention: { - action: insertMention, - }, - hashtags: { - active: withHashtags, - action: () => withHashtags.value = !withHashtags.value, - }, - plugins: { - hide: postFormActions.length === 0, - action: showActions, - }, - emoji: { - action: insertEmoji, - }, - addMfmFunction: { - hide: computed(() => !showAddMfmFunction.value), - action: insertMfmFunction, - }, - clearPost: { - action: clear, - }, - saveAsDraft: { - action: () => saveDraft(false), - }, -}); - ->>>>>>> 03d1c493a2 (feat: 下書き機能 (#144)) watch(text, () => { checkMissingMention(); }, { immediate: true }); @@ -723,8 +676,6 @@ function onDrop(ev: DragEvent): void { async function saveDraft(auto = true) { if (props.instant || props.mock) return; - if (auto && defaultStore.state.draftSavingBehavior !== 'auto') return; - if (!auto) { // 手動での保存の場合は自動保存したものを削除した上で保存 await noteDrafts.remove(draftType.value, $i.id, 'default', draftAuxId.value as string); @@ -738,7 +689,6 @@ async function saveDraft(auto = true) { localOnly: localOnly.value, files: files.value, poll: poll.value, - scheduledNoteDelete: scheduledNoteDelete.value, }, draftAuxId.value as string); if (!auto) { @@ -801,9 +751,6 @@ async function applyDraft(draft: noteDrafts.NoteDraft, native = false) { if (draft.data.poll) { poll.value = draft.data.poll; } - if (draft.data.scheduledNoteDelete) { - scheduledNoteDelete.value = draft.data.scheduledNoteDelete; - } } async function post(ev?: MouseEvent) { @@ -980,15 +927,15 @@ function cancel() { } async function closed() { - if (defaultStore.state.draftSavingBehavior === 'manual' && (text.value !== '' || files.value.length > 0)) { - os.confirm({ - type: 'question', - text: i18n.ts.saveConfirm, - }).then(({ canceled }) => { - if (canceled) return; - saveDraft(false); - }); - } +// if (text.value !== '' || files.value.length > 0) { +// os.confirm({ +// type: 'question', +// text: i18n.ts.saveConfirm, +// }).then(({ canceled }) => { +// if (canceled) return; +// saveDraft(false); +// }); + // } } function insertMention() { @@ -1075,7 +1022,7 @@ onMounted(() => { await noteDrafts.migrate($i.id); // 書きかけの投稿を復元 - if (!props.instant && !props.mention && !props.specified && !props.mock && !defaultStore.state.disableNoteDrafting) { + if (!props.instant && !props.mention && !props.specified && !props.mock) { const draft = await noteDrafts.get(draftType.value, $i.id, 'default', draftAuxId.value as string); if (draft) applyDraft(draft, true); } diff --git a/packages/frontend/src/pages/settings/post-form.vue b/packages/frontend/src/pages/settings/post-form.vue deleted file mode 100644 index 4a04583b626b..000000000000 --- a/packages/frontend/src/pages/settings/post-form.vue +++ /dev/null @@ -1,154 +0,0 @@ - - - - - diff --git a/packages/frontend/src/scripts/note-drafts.ts b/packages/frontend/src/scripts/note-drafts.ts index 67abc004a3ca..b8e15c7a4db8 100644 --- a/packages/frontend/src/scripts/note-drafts.ts +++ b/packages/frontend/src/scripts/note-drafts.ts @@ -1,6 +1,5 @@ import * as Misskey from 'misskey-js'; import type { PollEditorModelValue } from '@/components/MkPollEditor.vue'; -import type { DeleteScheduleEditorModelValue } from '@/components/MkDeleteScheduleEditor.vue'; import { miLocalStorage } from '@/local-storage.js'; import { get as idbGet, set as idbSet } from '@/scripts/idb-proxy.js'; @@ -17,7 +16,6 @@ export type NoteDraft = { localOnly: boolean; files: Misskey.entities.DriveFile[]; poll: PollEditorModelValue | null; - scheduledNoteDelete: DeleteScheduleEditorModelValue | null; }; }; diff --git a/packages/frontend/src/scripts/post-form.ts b/packages/frontend/src/scripts/post-form.ts deleted file mode 100644 index 40c63acb393d..000000000000 --- a/packages/frontend/src/scripts/post-form.ts +++ /dev/null @@ -1,48 +0,0 @@ -import { i18n } from '@/i18n.js'; - -export const bottomItemDef = { - attachFile: { - title: i18n.ts.attachFile, - icon: 'ti-photo-plus', - }, - poll: { - title: i18n.ts.poll, - icon: 'ti-chart-arrows', - }, - scheduledNoteDelete: { - title: i18n.ts.scheduledNoteDelete, - icon: 'ti-bomb', - }, - useCw: { - title: i18n.ts.useCw, - icon: 'ti-eye-off', - }, - mention: { - title: i18n.ts.mention, - icon: 'ti-at', - }, - hashtags: { - title: i18n.ts.hashtags, - icon: 'ti-hash', - }, - plugins: { - title: i18n.ts.plugins, - icon: 'ti-plug', - }, - emoji: { - title: i18n.ts.emoji, - icon: 'ti-mood-happy', - }, - addMfmFunction: { - title: i18n.ts.addMfmFunction, - icon: 'ti-palette', - }, - clearPost: { - title: i18n.ts.clearPost, - icon: 'ti-trash', - }, - saveAsDraft: { - title: i18n.ts.saveAsDraft, - icon: 'ti-note', - }, -}; diff --git a/packages/frontend/src/store.ts b/packages/frontend/src/store.ts index 440110f928a0..e8eb5a1ed7db 100644 --- a/packages/frontend/src/store.ts +++ b/packages/frontend/src/store.ts @@ -88,10 +88,6 @@ export const defaultStore = markRaw(new Storage('base', { where: 'account', default: true, }, - draftSavingBehavior: { - where: 'account', - default: 'auto' as 'auto' | 'manual', - }, rememberNoteVisibility: { where: 'account', default: false,