diff --git a/src/client/components/ui/a.vue b/src/client/components/ui/a.vue
index 516cf02bd6..384ee0259e 100644
--- a/src/client/components/ui/a.vue
+++ b/src/client/components/ui/a.vue
@@ -10,7 +10,7 @@ import { faExpandAlt, faColumns, faExternalLinkAlt, faLink, faWindowMaximize } f
import * as os from '@/os';
import copyToClipboard from '@/scripts/copy-to-clipboard';
import { router } from '@/router';
-import { deckmode, url } from '@/config';
+import { ui, url } from '@/config';
import { popout } from '@/scripts/popout';
export default defineComponent({
@@ -114,7 +114,10 @@ export default defineComponent({
if (this.$store.state.device.defaultSideView && this.sideViewHook && this.to !== '/') {
return this.sideViewHook(this.to);
}
- if (this.$store.state.device.deckNavWindow && deckmode && this.to !== '/') {
+ if (this.$store.state.device.deckNavWindow && (ui === 'deck') && this.to !== '/') {
+ return this.window();
+ }
+ if (ui === 'desktop') {
return this.window();
}
diff --git a/src/client/config.ts b/src/client/config.ts
index 9c5e0f7651..d0b74be042 100644
--- a/src/client/config.ts
+++ b/src/client/config.ts
@@ -13,5 +13,5 @@ export const langs = _LANGS_;
export const getLocale = async () => Object.fromEntries((await entries(clientDb.i18n)) as [string, string][]);
export const version = _VERSION_;
export const instanceName = siteName === 'Misskey' ? host : siteName;
-export const deckmode = localStorage.getItem('deckmode') === 'true';
+export const ui = localStorage.getItem('ui');
export const debug = localStorage.getItem('debug') === 'true';
diff --git a/src/client/init.ts b/src/client/init.ts
index f93252e793..cc97947c0a 100644
--- a/src/client/init.ts
+++ b/src/client/init.ts
@@ -4,13 +4,13 @@
import '@/style.scss';
-import { createApp, defineAsyncComponent } from 'vue';
+import { createApp } from 'vue';
import { FontAwesomeIcon } from '@fortawesome/vue-fontawesome';
import widgets from './widgets';
import directives from './directives';
import components from '@/components';
-import { version, apiUrl, deckmode } from '@/config';
+import { version, apiUrl, ui } from '@/config';
import { store } from './store';
import { router } from './router';
import { applyTheme } from '@/scripts/theme';
@@ -154,7 +154,8 @@ stream.init(store.state.i);
const app = createApp(await (
window.location.search === '?zen' ? import('@/ui/zen.vue') :
!store.getters.isSignedIn ? import('@/ui/visitor.vue') :
- deckmode ? import('@/ui/deck.vue') :
+ ui === 'deck' ? import('@/ui/deck.vue') :
+ ui === 'desktop' ? import('@/ui/desktop.vue') :
import('@/ui/default.vue')
).then(x => x.default));
diff --git a/src/client/sidebar.ts b/src/client/sidebar.ts
index 4b7acb0a60..1132431e1c 100644
--- a/src/client/sidebar.ts
+++ b/src/client/sidebar.ts
@@ -2,8 +2,8 @@ import { faBell, faComments, faEnvelope } from '@fortawesome/free-regular-svg-ic
import { faAt, faBroadcastTower, faCloud, faColumns, faDoorClosed, faFileAlt, faFireAlt, faGamepad, faHashtag, faListUl, faSatellite, faSatelliteDish, faSearch, faStar, faTerminal, faUserClock, faUsers } from '@fortawesome/free-solid-svg-icons';
import { computed } from 'vue';
import { store } from '@/store';
-import { deckmode } from '@/config';
import { search } from '@/scripts/search';
+import * as os from '@/os';
export const sidebarDef = {
notifications: {
@@ -119,12 +119,29 @@ export const sidebarDef = {
show: computed(() => store.getters.isSignedIn),
to: computed(() => `/@${store.state.i.username}/room`),
},
- deck: {
- title: deckmode ? 'undeck' : 'deck',
+ ui: {
+ title: 'switchUi',
icon: faColumns,
- action: () => {
- localStorage.setItem('deckmode', (!deckmode).toString());
- location.reload();
+ action: (ev) => {
+ os.modalMenu([{
+ text: 'Default',
+ action: () => {
+ localStorage.setItem('ui', 'default');
+ location.reload();
+ }
+ }, {
+ text: 'Deck',
+ action: () => {
+ localStorage.setItem('ui', 'deck');
+ location.reload();
+ }
+ }, {
+ text: 'Desktop',
+ action: () => {
+ localStorage.setItem('ui', 'desktop');
+ location.reload();
+ }
+ }], ev.currentTarget || ev.target);
},
},
};
diff --git a/src/client/store.ts b/src/client/store.ts
index 5c6c71d4f2..8b78824f7f 100644
--- a/src/client/store.ts
+++ b/src/client/store.ts
@@ -36,7 +36,7 @@ export const defaultDeviceUserSettings = {
'announcements',
'search',
'-',
- 'deck',
+ 'ui',
],
deck: {
columns: [],
diff --git a/src/client/ui/desktop.vue b/src/client/ui/desktop.vue
new file mode 100644
index 0000000000..0d266ae016
--- /dev/null
+++ b/src/client/ui/desktop.vue
@@ -0,0 +1,66 @@
+
+ {}">
+
+
+
+
+
+
+
+
+
+
+