140 lines
3.1 KiB
TypeScript
140 lines
3.1 KiB
TypeScript
import { computed, reactive } from "vue";
|
|
import { ui } from "@/config";
|
|
import { i18n } from "@/i18n";
|
|
import { isSignedIn, me } from "@/me";
|
|
import * as os from "@/os";
|
|
import icon from "@/scripts/icon";
|
|
import { search } from "@/scripts/search";
|
|
import { unisonReload } from "@/scripts/unison-reload";
|
|
|
|
export const navbarItemDef = reactive({
|
|
notifications: {
|
|
title: "notifications",
|
|
icon: `${icon("ph-bell")}`,
|
|
show: computed(() => isSignedIn(me)),
|
|
indicated: computed(() => me?.hasUnreadNotification),
|
|
to: "/my/notifications",
|
|
},
|
|
messaging: {
|
|
title: "messaging",
|
|
icon: `${icon("ph-chats-teardrop")}`,
|
|
show: computed(() => isSignedIn(me)),
|
|
indicated: computed(() => me?.hasUnreadMessagingMessage),
|
|
to: "/my/messaging",
|
|
},
|
|
drive: {
|
|
title: "drive",
|
|
icon: `${icon("ph-cloud")}`,
|
|
show: computed(() => isSignedIn(me)),
|
|
to: "/my/drive",
|
|
},
|
|
followRequests: {
|
|
title: "followRequests",
|
|
icon: `${icon("ph-hand-waving")}`,
|
|
show: computed(() => me?.isLocked || me?.hasPendingReceivedFollowRequest),
|
|
indicated: computed(() => me?.hasPendingReceivedFollowRequest),
|
|
to: "/my/follow-requests",
|
|
},
|
|
explore: {
|
|
title: "explore",
|
|
icon: `${icon("ph-compass")}`,
|
|
to: "/explore",
|
|
},
|
|
announcements: {
|
|
title: "announcements",
|
|
icon: `${icon("ph-megaphone-simple")}`,
|
|
indicated: computed(() => me?.hasUnreadAnnouncement),
|
|
to: "/announcements",
|
|
},
|
|
search: {
|
|
title: "search",
|
|
icon: `${icon("ph-magnifying-glass")}`,
|
|
action: () => search(),
|
|
},
|
|
lists: {
|
|
title: "lists",
|
|
icon: `${icon("ph-list-bullets")}`,
|
|
show: computed(() => isSignedIn(me)),
|
|
to: "/my/lists",
|
|
},
|
|
antennas: {
|
|
title: "antennas",
|
|
icon: `${icon("ph-flying-saucer")}`,
|
|
show: computed(() => isSignedIn(me)),
|
|
to: "/my/antennas",
|
|
},
|
|
favorites: {
|
|
title: "favorites",
|
|
icon: `${icon("ph-bookmark-simple")}`,
|
|
show: computed(() => isSignedIn(me)),
|
|
to: "/my/favorites",
|
|
},
|
|
pages: {
|
|
title: "pages",
|
|
icon: `${icon("ph-file-text")}`,
|
|
to: "/pages",
|
|
},
|
|
gallery: {
|
|
title: "gallery",
|
|
icon: `${icon("ph-image-square")}`,
|
|
to: "/gallery",
|
|
},
|
|
clips: {
|
|
title: "clips",
|
|
icon: `${icon("ph-paperclip")}`,
|
|
show: computed(() => isSignedIn(me)),
|
|
to: "/my/clips",
|
|
},
|
|
channels: {
|
|
title: "channel",
|
|
icon: `${icon("ph-television")}`,
|
|
to: "/channels",
|
|
},
|
|
groups: {
|
|
title: "groups",
|
|
icon: `${icon("ph-users-three")}`,
|
|
to: "/my/groups",
|
|
},
|
|
ui: {
|
|
title: "switchUi",
|
|
icon: `${icon("ph-layout")}`,
|
|
action: (ev) => {
|
|
os.popupMenu(
|
|
[
|
|
{
|
|
text: i18n.ts.default,
|
|
active: ui === "default" || ui === null,
|
|
action: () => {
|
|
localStorage.setItem("ui", "default");
|
|
unisonReload();
|
|
},
|
|
},
|
|
{
|
|
text: i18n.ts.classic,
|
|
active: ui === "classic",
|
|
action: () => {
|
|
localStorage.setItem("ui", "classic");
|
|
unisonReload();
|
|
},
|
|
},
|
|
{
|
|
text: i18n.ts.deck,
|
|
active: ui === "deck",
|
|
action: () => {
|
|
localStorage.setItem("ui", "deck");
|
|
unisonReload();
|
|
},
|
|
},
|
|
],
|
|
ev.currentTarget ?? ev.target,
|
|
);
|
|
},
|
|
},
|
|
reload: {
|
|
title: "reload",
|
|
icon: `${icon("ph-arrows-clockwise")}`,
|
|
action: (ev) => {
|
|
location.reload();
|
|
},
|
|
},
|
|
});
|