diff options
| author | syuilo <4439005+syuilo@users.noreply.github.com> | 2025-08-02 12:10:51 +0900 |
|---|---|---|
| committer | syuilo <4439005+syuilo@users.noreply.github.com> | 2025-08-02 12:10:51 +0900 |
| commit | fc244067e059bf88c69ee241e1bfc218517c917b (patch) | |
| tree | 0fe9ecd51d63f0e721db6868c936fa57717bd018 | |
| parent | fix e2e (diff) | |
| download | misskey-fc244067e059bf88c69ee241e1bfc218517c917b.tar.gz misskey-fc244067e059bf88c69ee241e1bfc218517c917b.tar.bz2 misskey-fc244067e059bf88c69ee241e1bfc218517c917b.zip | |
enhnace(frontend): リロードのサジェストをダイアログではなくバナー表示に
| -rw-r--r-- | packages/frontend/src/pages/settings/deck.vue | 6 | ||||
| -rw-r--r-- | packages/frontend/src/pages/settings/mute-block.vue | 6 | ||||
| -rw-r--r-- | packages/frontend/src/pages/settings/navbar.vue | 1 | ||||
| -rw-r--r-- | packages/frontend/src/pages/settings/other.vue | 6 | ||||
| -rw-r--r-- | packages/frontend/src/pages/settings/preferences.vue | 6 | ||||
| -rw-r--r-- | packages/frontend/src/ui/_common_/PreferenceRestore.vue | 4 | ||||
| -rw-r--r-- | packages/frontend/src/ui/_common_/ReloadSuggest.vue | 71 | ||||
| -rw-r--r-- | packages/frontend/src/ui/deck.vue | 8 | ||||
| -rw-r--r-- | packages/frontend/src/ui/universal.vue | 3 | ||||
| -rw-r--r-- | packages/frontend/src/utility/reload-ask.ts | 40 | ||||
| -rw-r--r-- | packages/frontend/src/utility/reload-suggest.ts | 12 |
11 files changed, 105 insertions, 58 deletions
diff --git a/packages/frontend/src/pages/settings/deck.vue b/packages/frontend/src/pages/settings/deck.vue index ae882d1ee2..7a19b0495b 100644 --- a/packages/frontend/src/pages/settings/deck.vue +++ b/packages/frontend/src/pages/settings/deck.vue @@ -97,8 +97,8 @@ import { i18n } from '@/i18n.js'; import { definePage } from '@/page.js'; import { prefer } from '@/preferences.js'; import MkPreferenceContainer from '@/components/MkPreferenceContainer.vue'; -import { reloadAsk } from '@/utility/reload-ask.js'; import { selectFile } from '@/utility/drive.js'; +import { suggestReload } from '@/utility/reload-suggest.js'; const navWindow = prefer.model('deck.navWindow'); const useSimpleUiForNonRootPages = prefer.model('deck.useSimpleUiForNonRootPages'); @@ -109,8 +109,8 @@ const menuPosition = prefer.model('deck.menuPosition'); const navbarPosition = prefer.model('deck.navbarPosition'); const wallpaper = prefer.model('deck.wallpaper'); -watch(wallpaper, async () => { - await reloadAsk({ reason: i18n.ts.reloadToApplySetting, unison: true }); +watch(wallpaper, () => { + suggestReload(); }); function setWallpaper(ev: MouseEvent) { diff --git a/packages/frontend/src/pages/settings/mute-block.vue b/packages/frontend/src/pages/settings/mute-block.vue index 6ca313da81..57aa30226b 100644 --- a/packages/frontend/src/pages/settings/mute-block.vue +++ b/packages/frontend/src/pages/settings/mute-block.vue @@ -189,10 +189,10 @@ import { ensureSignin } from '@/i.js'; import MkInfo from '@/components/MkInfo.vue'; import MkFolder from '@/components/MkFolder.vue'; import MkSwitch from '@/components/MkSwitch.vue'; -import { reloadAsk } from '@/utility/reload-ask.js'; import { prefer } from '@/preferences.js'; import MkFeatureBanner from '@/components/MkFeatureBanner.vue'; import { Paginator } from '@/utility/paginator.js'; +import { suggestReload } from '@/utility/reload-suggest.js'; const $i = ensureSignin(); @@ -216,8 +216,8 @@ const showSoftWordMutedWord = prefer.model('showSoftWordMutedWord'); watch([ showSoftWordMutedWord, -], async () => { - await reloadAsk({ reason: i18n.ts.reloadToApplySetting, unison: true }); +], () => { + suggestReload(); }); async function unrenoteMute(user, ev) { diff --git a/packages/frontend/src/pages/settings/navbar.vue b/packages/frontend/src/pages/settings/navbar.vue index e57195c8a2..09c1199d0c 100644 --- a/packages/frontend/src/pages/settings/navbar.vue +++ b/packages/frontend/src/pages/settings/navbar.vue @@ -64,7 +64,6 @@ import MkPreferenceContainer from '@/components/MkPreferenceContainer.vue'; import * as os from '@/os.js'; import { navbarItemDef } from '@/navbar.js'; import { store } from '@/store.js'; -import { reloadAsk } from '@/utility/reload-ask.js'; import { i18n } from '@/i18n.js'; import { definePage } from '@/page.js'; import { prefer } from '@/preferences.js'; diff --git a/packages/frontend/src/pages/settings/other.vue b/packages/frontend/src/pages/settings/other.vue index ac432e9f32..e0fb9b86bb 100644 --- a/packages/frontend/src/pages/settings/other.vue +++ b/packages/frontend/src/pages/settings/other.vue @@ -155,13 +155,13 @@ import { misskeyApi } from '@/utility/misskey-api.js'; import { ensureSignin } from '@/i.js'; import { i18n } from '@/i18n.js'; import { definePage } from '@/page.js'; -import { reloadAsk } from '@/utility/reload-ask.js'; import FormSection from '@/components/form/section.vue'; import { prefer } from '@/preferences.js'; import MkRolePreview from '@/components/MkRolePreview.vue'; import { signout } from '@/signout.js'; import { migrateOldSettings } from '@/pref-migrate.js'; import { hideAllTips as _hideAllTips, resetAllTips as _resetAllTips } from '@/tips.js'; +import { suggestReload } from '@/utility/reload-suggest.js'; const $i = ensureSignin(); @@ -172,8 +172,8 @@ const devMode = prefer.model('devMode'); const stackingRouterView = prefer.model('experimental.stackingRouterView'); const enableFolderPageView = prefer.model('experimental.enableFolderPageView'); -watch(skipNoteRender, async () => { - await reloadAsk({ reason: i18n.ts.reloadToApplySetting, unison: true }); +watch(skipNoteRender, () => { + suggestReload(); }); async function deleteAccount() { diff --git a/packages/frontend/src/pages/settings/preferences.vue b/packages/frontend/src/pages/settings/preferences.vue index 0e400778aa..04f9b0512b 100644 --- a/packages/frontend/src/pages/settings/preferences.vue +++ b/packages/frontend/src/pages/settings/preferences.vue @@ -795,7 +795,6 @@ import MkInfo from '@/components/MkInfo.vue'; import { store } from '@/store.js'; import * as os from '@/os.js'; import { misskeyApi } from '@/utility/misskey-api.js'; -import { reloadAsk } from '@/utility/reload-ask.js'; import { i18n } from '@/i18n.js'; import { definePage } from '@/page.js'; import { miLocalStorage } from '@/local-storage.js'; @@ -807,6 +806,7 @@ import { claimAchievement } from '@/utility/achievements.js'; import { instance } from '@/instance.js'; import { ensureSignin } from '@/i.js'; import { genId } from '@/utility/id.js'; +import { suggestReload } from '@/utility/reload-suggest.js'; const $i = ensureSignin(); @@ -928,8 +928,8 @@ watch([ enablePullToRefresh, reduceAnimation, showAvailableReactionsFirstInNote, -], async () => { - await reloadAsk({ reason: i18n.ts.reloadToApplySetting, unison: true }); +], () => { + suggestReload(); }); const emojiIndexLangs = ['en-US', 'ja-JP', 'ja-JP_hira'] as const; diff --git a/packages/frontend/src/ui/_common_/PreferenceRestore.vue b/packages/frontend/src/ui/_common_/PreferenceRestore.vue index 5fd9f5e44b..b9d54cddc6 100644 --- a/packages/frontend/src/ui/_common_/PreferenceRestore.vue +++ b/packages/frontend/src/ui/_common_/PreferenceRestore.vue @@ -48,10 +48,6 @@ function skip() { .title { padding: 0 10px; font-weight: bold; - - &:empty { - display: none; - } } .body { diff --git a/packages/frontend/src/ui/_common_/ReloadSuggest.vue b/packages/frontend/src/ui/_common_/ReloadSuggest.vue new file mode 100644 index 0000000000..8fcfe0b12f --- /dev/null +++ b/packages/frontend/src/ui/_common_/ReloadSuggest.vue @@ -0,0 +1,71 @@ +<!-- +SPDX-FileCopyrightText: syuilo and misskey-project +SPDX-License-Identifier: AGPL-3.0-only +--> + +<template> +<div :class="$style.root"> + <span :class="$style.icon"> + <i class="ti ti-info-circle"></i> + </span> + <span :class="$style.title">{{ i18n.ts.reloadRequiredToApplySettings }}</span> + <span :class="$style.body"><button class="_textButton" style="color: var(--MI_THEME-fgOnAccent);" @click="reload">{{ i18n.ts.reload }}</button> | <button class="_textButton" style="color: var(--MI_THEME-fgOnAccent);" @click="skip">{{ i18n.ts.skip }}</button></span> +</div> +</template> + +<script lang="ts" setup> +import { i18n } from '@/i18n.js'; +import { shouldSuggestReload } from '@/utility/reload-suggest.js'; +import { unisonReload } from '@/utility/unison-reload.js'; + +function reload() { + unisonReload(); +} + +function skip() { + shouldSuggestReload.value = false; +} +</script> + +<style lang="scss" module> +.root { + --height: 24px; + font-size: 0.85em; + display: flex; + vertical-align: bottom; + width: 100%; + line-height: var(--height); + height: var(--height); + overflow: clip; + contain: strict; + background: var(--MI_THEME-accent); + color: var(--MI_THEME-fgOnAccent); +} + +.icon { + margin-left: 10px; + animation: blink 2s infinite; +} + +.title { + padding: 0 10px; + font-weight: bold; + animation: blink 2s infinite; +} + +.body { + min-width: 0; + flex: 1; + overflow: clip; + white-space: nowrap; + text-overflow: ellipsis; +} + +@keyframes blink { + 0% { opacity: 1; } + 10% { opacity: 1; } + 50% { opacity: 0; } + 90% { opacity: 1; } + 100% { opacity: 1; } +} +</style> diff --git a/packages/frontend/src/ui/deck.vue b/packages/frontend/src/ui/deck.vue index d2b163a38f..7cd54f01ef 100644 --- a/packages/frontend/src/ui/deck.vue +++ b/packages/frontend/src/ui/deck.vue @@ -13,6 +13,8 @@ SPDX-License-Identifier: AGPL-3.0-only <div :class="[$style.main, { [$style.withWallpaper]: withWallpaper, [$style.withSidebarAndTitlebar]: !isMobile && prefer.r['deck.navbarPosition'].value === 'left' && prefer.r.showTitlebar.value }]" :style="{ backgroundImage: prefer.s['deck.wallpaper'] != null ? `url(${ prefer.s['deck.wallpaper'] })` : null }"> <XNavbarH v-if="!isMobile && prefer.r['deck.navbarPosition'].value === 'top'"/> + <XReloadSuggest v-if="shouldSuggestReload"/> + <XPreferenceRestore v-if="shouldSuggestRestoreBackup"/> <XAnnouncements v-if="$i"/> <XStatusBars/> <div :class="$style.columnsWrapper"> @@ -81,12 +83,14 @@ SPDX-License-Identifier: AGPL-3.0-only <script lang="ts" setup> import { defineAsyncComponent, ref, useTemplateRef } from 'vue'; -import { genId } from '@/utility/id.js'; import XCommon from './_common_/common.vue'; +import { genId } from '@/utility/id.js'; import XSidebar from '@/ui/_common_/navbar.vue'; import XNavbarH from '@/ui/_common_/navbar-h.vue'; import XMobileFooterMenu from '@/ui/_common_/mobile-footer-menu.vue'; import XTitlebar from '@/ui/_common_/titlebar.vue'; +import XPreferenceRestore from '@/ui/_common_/PreferenceRestore.vue'; +import XReloadSuggest from '@/ui/_common_/ReloadSuggest.vue'; import * as os from '@/os.js'; import { $i } from '@/i.js'; import { i18n } from '@/i18n.js'; @@ -105,6 +109,8 @@ import XRoleTimelineColumn from '@/ui/deck/role-timeline-column.vue'; import XChatColumn from '@/ui/deck/chat-column.vue'; import { mainRouter } from '@/router.js'; import { columns, layout, columnTypes, switchProfileMenu, addColumn as addColumnToStore, deleteProfile as deleteProfile_ } from '@/deck.js'; +import { shouldSuggestRestoreBackup } from '@/preferences/utility.js'; +import { shouldSuggestReload } from '@/utility/reload-suggest.js'; const XStatusBars = defineAsyncComponent(() => import('@/ui/_common_/statusbars.vue')); const XAnnouncements = defineAsyncComponent(() => import('@/ui/_common_/announcements.vue')); diff --git a/packages/frontend/src/ui/universal.vue b/packages/frontend/src/ui/universal.vue index f8793d7c75..7529f21ffb 100644 --- a/packages/frontend/src/ui/universal.vue +++ b/packages/frontend/src/ui/universal.vue @@ -12,6 +12,7 @@ SPDX-License-Identifier: AGPL-3.0-only <div :class="[$style.contents, !isMobile && prefer.r.showTitlebar.value ? $style.withSidebarAndTitlebar : null]" @contextmenu.stop="onContextmenu"> <div> + <XReloadSuggest v-if="shouldSuggestReload"/> <XPreferenceRestore v-if="shouldSuggestRestoreBackup"/> <XAnnouncements v-if="$i"/> <XStatusBars :class="$style.statusbars"/> @@ -38,6 +39,7 @@ import XCommon from './_common_/common.vue'; import type { PageMetadata } from '@/page.js'; import XMobileFooterMenu from '@/ui/_common_/mobile-footer-menu.vue'; import XPreferenceRestore from '@/ui/_common_/PreferenceRestore.vue'; +import XReloadSuggest from '@/ui/_common_/ReloadSuggest.vue'; import XTitlebar from '@/ui/_common_/titlebar.vue'; import XSidebar from '@/ui/_common_/navbar.vue'; import * as os from '@/os.js'; @@ -50,6 +52,7 @@ import { mainRouter } from '@/router.js'; import { prefer } from '@/preferences.js'; import { shouldSuggestRestoreBackup } from '@/preferences/utility.js'; import { DI } from '@/di.js'; +import { shouldSuggestReload } from '@/utility/reload-suggest.js'; const XWidgets = defineAsyncComponent(() => import('./_common_/widgets.vue')); const XStatusBars = defineAsyncComponent(() => import('@/ui/_common_/statusbars.vue')); diff --git a/packages/frontend/src/utility/reload-ask.ts b/packages/frontend/src/utility/reload-ask.ts deleted file mode 100644 index 7c7ea113d4..0000000000 --- a/packages/frontend/src/utility/reload-ask.ts +++ /dev/null @@ -1,40 +0,0 @@ -/* - * SPDX-FileCopyrightText: syuilo and misskey-project - * SPDX-License-Identifier: AGPL-3.0-only - */ - -import { i18n } from '@/i18n.js'; -import * as os from '@/os.js'; -import { unisonReload } from '@/utility/unison-reload.js'; - -let isReloadConfirming = false; - -export async function reloadAsk(opts: { - unison?: boolean; - reason?: string; -}) { - if (isReloadConfirming) { - return; - } - - isReloadConfirming = true; - - const { canceled } = await os.confirm(opts.reason == null ? { - type: 'info', - text: i18n.ts.reloadConfirm, - } : { - type: 'info', - title: i18n.ts.reloadConfirm, - text: opts.reason, - }).finally(() => { - isReloadConfirming = false; - }); - - if (canceled) return; - - if (opts.unison) { - unisonReload(); - } else { - window.location.reload(); - } -} diff --git a/packages/frontend/src/utility/reload-suggest.ts b/packages/frontend/src/utility/reload-suggest.ts new file mode 100644 index 0000000000..f1888f721e --- /dev/null +++ b/packages/frontend/src/utility/reload-suggest.ts @@ -0,0 +1,12 @@ +/* + * SPDX-FileCopyrightText: syuilo and misskey-project + * SPDX-License-Identifier: AGPL-3.0-only + */ + +import { ref } from 'vue'; + +export const shouldSuggestReload = ref(false); + +export function suggestReload() { + shouldSuggestReload.value = true; +} |