From b10074e939d22f7aae41137ddf6f0c8fd7bdd7b1 Mon Sep 17 00:00:00 2001
From: syuilo <4439005+syuilo@users.noreply.github.com>
Date: Wed, 17 Dec 2025 12:27:55 +0900
Subject: enhance(frontend): add deck tour
---
packages/frontend/src/ui/deck.vue | 48 +++++++++++++++++++++++++++++++++------
1 file changed, 41 insertions(+), 7 deletions(-)
(limited to 'packages/frontend/src/ui')
diff --git a/packages/frontend/src/ui/deck.vue b/packages/frontend/src/ui/deck.vue
index 0941c25467..1a2a1fd99a 100644
--- a/packages/frontend/src/ui/deck.vue
+++ b/packages/frontend/src/ui/deck.vue
@@ -38,36 +38,39 @@ SPDX-License-Identifier: AGPL-3.0-only
@headerWheel="onWheel"
/>
-
+
{{ i18n.ts._deck.introduction }}
{{ i18n.ts._deck.introduction2 }}
+
+
+
@@ -96,6 +99,7 @@ import { $i } from '@/i.js';
import { i18n } from '@/i18n.js';
import { deviceKind } from '@/utility/device-kind.js';
import { prefer } from '@/preferences.js';
+import { store } from '@/store.js';
import XMainColumn from '@/ui/deck/main-column.vue';
import XTlColumn from '@/ui/deck/tl-column.vue';
import XAntennaColumn from '@/ui/deck/antenna-column.vue';
@@ -107,10 +111,13 @@ import XMentionsColumn from '@/ui/deck/mentions-column.vue';
import XDirectColumn from '@/ui/deck/direct-column.vue';
import XRoleTimelineColumn from '@/ui/deck/role-timeline-column.vue';
import XChatColumn from '@/ui/deck/chat-column.vue';
+import MkInfo from '@/components/MkInfo.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';
+import { startTour } from '@/utility/tour.js';
+import { closeTip } from '@/tips.js';
const XStatusBars = defineAsyncComponent(() => import('@/ui/_common_/statusbars.vue'));
const XAnnouncements = defineAsyncComponent(() => import('@/ui/_common_/announcements.vue'));
@@ -163,6 +170,9 @@ function showSettings() {
}
const columnsEl = useTemplateRef('columnsEl');
+const addColumnButtonEl = useTemplateRef('addColumnButtonEl');
+const settingsButtonEl = useTemplateRef('settingsButtonEl');
+const swicthProfileButtonEl = useTemplateRef('swicthProfileButtonEl');
const addColumn = async (ev) => {
const { canceled, result: column } = await os.select({
@@ -218,6 +228,30 @@ async function deleteProfile() {
os.success();
}
+function showTour() {
+ if (addColumnButtonEl.value == null ||
+ settingsButtonEl.value == null ||
+ swicthProfileButtonEl.value == null) {
+ return;
+ }
+
+ startTour([{
+ element: addColumnButtonEl.value,
+ title: i18n.ts._deck._howToUse.addColumn_title,
+ description: i18n.ts._deck._howToUse.addColumn_description,
+ }, {
+ element: settingsButtonEl.value,
+ title: i18n.ts._deck._howToUse.settings_title,
+ description: i18n.ts._deck._howToUse.settings_description,
+ }, {
+ element: swicthProfileButtonEl.value,
+ title: i18n.ts._deck._howToUse.switchProfile_title,
+ description: i18n.ts._deck._howToUse.switchProfile_description,
+ }]).then(() => {
+ closeTip('deck');
+ });
+}
+
window.document.documentElement.style.overflowY = 'hidden';
window.document.documentElement.style.scrollBehavior = 'auto';
--
cgit v1.2.3-freya