This commit is contained in:
mattyatea 2024-05-17 23:14:11 +09:00
parent 9ee4c3d0a8
commit be31cedd98
4 changed files with 124 additions and 9 deletions

56
locales/index.d.ts vendored
View file

@ -60,6 +60,10 @@ export interface Locale extends ILocale {
* OK * OK
*/ */
"ok": string; "ok": string;
/**
* 稿
*/
"disableNoteDraftingDescription": string;
/** /**
* *
*/ */
@ -5192,6 +5196,58 @@ export interface Locale extends ILocale {
* *
*/ */
"inquiry": string; "inquiry": string;
/**
*
*/
"scheduledNoteDelete": string;
/**
* {time}
*/
"noteDeletationAt": ParameterizedString<"time">;
/**
* 1
*/
"cannotScheduleLaterThanOneYear": string;
/**
*
*/
"hideActivity": string;
/**
* (/)
*/
"hideActivityDescription": string;
/**
* 12
*/
"channelAnnouncementDescription": string;
/**
* 稿
*/
"postForm": string;
/**
* 稿
*/
"postFormBottomSettingsDescription": string;
/**
* 稿
*/
"clearPost": string;
/**
*
*/
"addToEmojiPicker": string;
/**
*
*/
"hideReactionCount": string;
/**
*
*/
"hideReactionUsers": string;
/**
*
*/
"hideReactionUsersDescription": string;
/** /**
* *
*/ */

View file

@ -11,6 +11,8 @@ password: "パスワード"
forgotPassword: "パスワードを忘れた" forgotPassword: "パスワードを忘れた"
fetchingAsApObject: "連合に照会中" fetchingAsApObject: "連合に照会中"
ok: "OK" ok: "OK"
disableNoteDraftingDescription: "ノートの投稿フォームを開き直した際に、下書きを復元しないようにします。"
setDefaultProfileConfirm: "このプロファイルをデフォルトにしますか?" setDefaultProfileConfirm: "このプロファイルをデフォルトにしますか?"
emojiPickerProfile: "絵文字ピッカーのプロファイル" emojiPickerProfile: "絵文字ピッカーのプロファイル"
notificationIndicator: "通知のインジケーターの数字を表示する" notificationIndicator: "通知のインジケーターの数字を表示する"

View file

@ -79,9 +79,16 @@ SPDX-License-Identifier: AGPL-3.0-only
</div> </div>
<footer :class="$style.footer"> <footer :class="$style.footer">
<div :class="$style.footerLeft"> <div :class="$style.footerLeft">
<template v-for="item in defaultStore.state.postFormActions"> <button v-tooltip="i18n.ts.attachFile" class="_button" :class="$style.footerButton" @click="chooseFileFrom"><i class="ti ti-photo-plus"></i></button>
<button v-if="!bottomItemActionDef[item].hide" :key="item" v-tooltip="bottomItemDef[item].title" class="_button" :class="[$style.footerButton, { [$style.footerButtonActive]: bottomItemActionDef[item].active }]" v-on="bottomItemActionDef[item].action ? { click: bottomItemActionDef[item].action } : {}"><i class="ti" :class="bottomItemDef[item].icon"></i></button> <button v-tooltip="i18n.ts.poll" class="_button" :class="[$style.footerButton, { [$style.footerButtonActive]: poll }]" @click="togglePoll"><i class="ti ti-chart-arrows"></i></button>
</template> <button v-tooltip="i18n.ts.useCw" class="_button" :class="[$style.footerButton, { [$style.footerButtonActive]: useCw }]" @click="useCw = !useCw"><i class="ti ti-eye-off"></i></button>
<button v-tooltip="i18n.ts.mention" class="_button" :class="$style.footerButton" @click="insertMention"><i class="ti ti-at"></i></button>
<button v-tooltip="i18n.ts.hashtags" class="_button" :class="[$style.footerButton, { [$style.footerButtonActive]: withHashtags }]" @click="withHashtags = !withHashtags"><i class="ti ti-hash"></i></button>
<button v-if="postFormActions.length > 0" v-tooltip="i18n.ts.plugins" class="_button" :class="$style.footerButton" @click="showActions"><i class="ti ti-plug"></i></button>
<button v-tooltip="i18n.ts.emoji" :class="['_button', $style.footerButton]" @click="insertEmoji"><i class="ti ti-mood-happy"></i></button>
<button v-if="showAddMfmFunction" v-tooltip="i18n.ts.addMfmFunction" :class="['_button', $style.footerButton]" @click="insertMfmFunction"><i class="ti ti-palette"></i></button>
<button v-tooltip="i18n.ts.ruby" :class="['_button', $style.footerButton]" @click="insertRuby"><i class="ti ti-abc"></i></button>
<button v-tooltip="i18n.ts.saveAsDraft" class="_button" :class="$style.footerButton" @click="saveDraft(false)"><i class="ti ti-device-floppy"></i></button>
</div> </div>
<div :class="$style.footerRight"> <div :class="$style.footerRight">
<button v-tooltip="i18n.ts.previewNoteText" class="_button" :class="[$style.footerButton, { [$style.previewButtonActive]: showPreview }]" @click="showPreview = !showPreview"><i class="ti ti-eye"></i></button> <button v-tooltip="i18n.ts.previewNoteText" class="_button" :class="[$style.footerButton, { [$style.previewButtonActive]: showPreview }]" @click="showPreview = !showPreview"><i class="ti ti-eye"></i></button>
@ -274,11 +281,7 @@ const canPost = computed((): boolean => {
const withHashtags = computed(defaultStore.makeGetterSetter('postFormWithHashtags')); const withHashtags = computed(defaultStore.makeGetterSetter('postFormWithHashtags'));
const hashtags = computed(defaultStore.makeGetterSetter('postFormHashtags')); const hashtags = computed(defaultStore.makeGetterSetter('postFormHashtags'));
const bottomItemActionDef: Record<keyof typeof bottomItemDef, { const bottomItemActionDef = ref({
hide?: boolean;
active?: any;
action?: any;
}> = reactive({
attachFile: { attachFile: {
action: chooseFileFrom, action: chooseFileFrom,
}, },
@ -319,6 +322,48 @@ const bottomItemActionDef: Record<keyof typeof bottomItemDef, {
watch(text, () => { watch(text, () => {
checkMissingMention(); checkMissingMention();
}, { immediate: true }); }, { immediate: true });
const bottomItemDef = {
attachFile: {
title: i18n.ts.attachFile,
icon: 'ti-photo-plus',
},
poll: {
title: i18n.ts.poll,
icon: 'ti-chart-arrows',
},
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',
},
};
watch(visibility, () => { watch(visibility, () => {
switch (visibility.value) { switch (visibility.value) {
@ -944,7 +989,6 @@ async function post(ev?: MouseEvent) {
claimAchievement('notes1'); claimAchievement('notes1');
} }
if (postData.schedule?.scheduledAt) { if (postData.schedule?.scheduledAt) {
const d = new Date(postData.schedule.scheduledAt); const d = new Date(postData.schedule.scheduledAt);
const str = dateTimeFormat.format(d); const str = dateTimeFormat.format(d);

View file

@ -38,6 +38,16 @@ SPDX-License-Identifier: AGPL-3.0-only
<MkSwitch v-model="showFixedPostFormInChannel">{{ i18n.ts.showFixedPostFormInChannel }}</MkSwitch> <MkSwitch v-model="showFixedPostFormInChannel">{{ i18n.ts.showFixedPostFormInChannel }}</MkSwitch>
<MkSwitch v-model="alwaysShowPlayer">Youtube.comやnicovideo.jpのプレイヤーを全て開いた状態にする</MkSwitch> <MkSwitch v-model="alwaysShowPlayer">Youtube.comやnicovideo.jpのプレイヤーを全て開いた状態にする</MkSwitch>
<MkSwitch v-model="alwaysExpandTweet">Xのポストを常時表示させる</MkSwitch> <MkSwitch v-model="alwaysExpandTweet">Xのポストを常時表示させる</MkSwitch>
<MkSelect v-model="draftSavingBehavior">
<template #label>{{ i18n.ts.draftSavingBehavior }}<span class="_beta">{{ i18n.ts.originalFeature }}</span></template>
<option value="auto">{{ i18n.ts._draftSavingBehavior.auto }}</option>
<option value="manual">{{ i18n.ts._draftSavingBehavior.manual }}</option>
</MkSelect>
<MkSwitch v-model="disableNoteDrafting">
<template #caption>{{ i18n.ts.disableNoteDraftingDescription }}</template>
{{ i18n.ts.disableNoteDrafting }}
<span class="_beta">{{ i18n.ts.originalFeature }}</span>
</MkSwitch>
<MkFolder> <MkFolder>
<template #label>{{ i18n.ts.pinnedList }}</template> <template #label>{{ i18n.ts.pinnedList }}</template>
<div v-for="pinnedLists in defaultStore.reactiveState.pinnedUserLists.value" class="_margin"> <div v-for="pinnedLists in defaultStore.reactiveState.pinnedUserLists.value" class="_margin">
@ -436,6 +446,9 @@ const nsfw = computed(defaultStore.makeGetterSetter('nsfw'));
const showFixedPostForm = computed(defaultStore.makeGetterSetter('showFixedPostForm')); const showFixedPostForm = computed(defaultStore.makeGetterSetter('showFixedPostForm'));
const showFixedPostFormInChannel = computed(defaultStore.makeGetterSetter('showFixedPostFormInChannel')); const showFixedPostFormInChannel = computed(defaultStore.makeGetterSetter('showFixedPostFormInChannel'));
const alwaysShowPlayer = computed(defaultStore.makeGetterSetter('alwaysShowPlayer')); const alwaysShowPlayer = computed(defaultStore.makeGetterSetter('alwaysShowPlayer'));
const disableNoteDrafting = computed(defaultStore.makeGetterSetter('disableNoteDrafting'));
const draftSavingBehavior = computed(defaultStore.makeGetterSetter('draftSavingBehavior'));
const alwaysExpandTweet = computed(defaultStore.makeGetterSetter('alwaysExpandTweet')); const alwaysExpandTweet = computed(defaultStore.makeGetterSetter('alwaysExpandTweet'));
const numberOfPageCache = computed(defaultStore.makeGetterSetter('numberOfPageCache')); const numberOfPageCache = computed(defaultStore.makeGetterSetter('numberOfPageCache'));
const numberOfGamingSpeed = computed(defaultStore.makeGetterSetter('numberOfGamingSpeed')); const numberOfGamingSpeed = computed(defaultStore.makeGetterSetter('numberOfGamingSpeed'));