From 4a95c367e32be8b16447c4608bafb69878d5a0f4 Mon Sep 17 00:00:00 2001 From: D3SOX Date: Fri, 19 Jul 2024 06:23:45 +0200 Subject: [PATCH] feat(betterActivities): use ActivityView in tooltip --- .../components/ActivityTooltip.tsx | 58 +++---------------- src/plugins/betterActivities/index.tsx | 14 ++--- src/plugins/betterActivities/settings.tsx | 2 +- src/plugins/betterActivities/styles.css | 40 +------------ src/plugins/betterActivities/types.ts | 2 + 5 files changed, 20 insertions(+), 96 deletions(-) diff --git a/src/plugins/betterActivities/components/ActivityTooltip.tsx b/src/plugins/betterActivities/components/ActivityTooltip.tsx index 74f109fc2..c74f04693 100644 --- a/src/plugins/betterActivities/components/ActivityTooltip.tsx +++ b/src/plugins/betterActivities/components/ActivityTooltip.tsx @@ -6,26 +6,10 @@ import { classNameFactory } from "@api/Styles"; import ErrorBoundary from "@components/ErrorBoundary"; -import { findComponentByCodeLazy } from "@webpack"; -import { moment, React, useMemo } from "@webpack/common"; import { User } from "discord-types/general"; -import settings from "../settings"; +import { ActivityView } from "../index"; import { Activity, Application } from "../types"; -import { - formatElapsedTime, - getActivityImage, - getApplicationIcons, - getValidStartTimeStamp, - getValidTimestamps -} from "../utils"; - -const TimeBar = findComponentByCodeLazy<{ - start: number; - end: number; - themed: boolean; - className: string; -}>("isSingleLine"); interface ActivityTooltipProps { activity: Activity; @@ -35,41 +19,15 @@ interface ActivityTooltipProps { } export default function ActivityTooltip({ activity, application, user, cl }: Readonly) { - const image = useMemo(() => { - const activityImage = getActivityImage(activity, application); - if (activityImage) { - return activityImage; - } - const icon = getApplicationIcons([activity], true)[0]; - return icon?.image.src; - }, [activity]); - const timestamps = useMemo(() => getValidTimestamps(activity), [activity]); - const startTime = useMemo(() => getValidStartTimeStamp(activity), [activity]); - - const hasDetails = activity.details ?? activity.state; return ( -
- {image && Activity logo} -
{activity.name}
- {hasDetails &&
} -
-
{activity.details}
-
{activity.state}
- {settings.store.showAppDescriptions && application?.description &&
{application.description}
} - {!timestamps && startTime && -
- {formatElapsedTime(moment(startTime), moment())} -
- } -
- {timestamps && ( - - )} +
+
); diff --git a/src/plugins/betterActivities/index.tsx b/src/plugins/betterActivities/index.tsx index 625b4e03d..e0bfaf4ed 100644 --- a/src/plugins/betterActivities/index.tsx +++ b/src/plugins/betterActivities/index.tsx @@ -23,7 +23,7 @@ import ErrorBoundary from "@components/ErrorBoundary"; import { Devs } from "@utils/constants"; import definePlugin from "@utils/types"; import { findComponentByCodeLazy } from "@webpack"; -import { PresenceStore, React, Tooltip, useStateFromStores } from "@webpack/common"; +import { PresenceStore, React, Tooltip, useEffect, useState, useStateFromStores } from "@webpack/common"; import { User } from "discord-types/general"; import ActivityTooltip from "./components/ActivityTooltip"; @@ -44,7 +44,7 @@ import { const cl = classNameFactory("vc-bactivities-"); -const ActivityView = findComponentByCodeLazy(",onOpenGameProfileModal:"); +export const ActivityView = findComponentByCodeLazy(",onOpenGameProfileModal:"); // if discord one day decides to change their icon this needs to be updated const DefaultActivityIcon = findComponentByCodeLazy("M6,7 L2,7 L2,6 L6,6 L6,7 Z M8,5 L2,5 L2,4 L8,4 L8,5 Z M8,3 L2,3 L2,2 L8,2 L8,3 Z M8.88888889,0 L1.11111111,0 C0.494444444,0 0,0.494444444 0,1.11111111 L0,8.88888889 C0,9.50253861 0.497461389,10 1.11111111,10 L8.88888889,10 C9.50253861,10 10,9.50253861 10,8.88888889 L10,1.11111111 C10,0.494444444 9.5,0 8.88888889,0 Z"); @@ -135,7 +135,7 @@ export default definePlugin({ }, showAllActivitiesComponent({ activity, user, ...props }: ActivityViewProps) { - const [currentActivity, setCurrentActivity] = React.useState( + const [currentActivity, setCurrentActivity] = useState( activity?.type !== 4 ? activity! : null ); @@ -143,7 +143,7 @@ export default definePlugin({ [PresenceStore], () => PresenceStore.getActivities(user.id).filter((activity: Activity) => activity.type !== 4) ) ?? []; - React.useEffect(() => { + useEffect(() => { if (!activities.length) { setCurrentActivity(null); return; @@ -186,7 +186,7 @@ export default definePlugin({ > + direction="left" /> ; }} @@ -195,7 +195,7 @@ export default definePlugin({
setCurrentActivity(activity)} - className={`dot ${currentActivity === activity ? "selected" : ""}`}/> + className={`dot ${currentActivity === activity ? "selected" : ""}`} /> ))}
@@ -214,7 +214,7 @@ export default definePlugin({ > = activities.length - 1} - direction="right"/> + direction="right" /> ; }}
diff --git a/src/plugins/betterActivities/settings.tsx b/src/plugins/betterActivities/settings.tsx index 6c60df3d7..9064b0150 100644 --- a/src/plugins/betterActivities/settings.tsx +++ b/src/plugins/betterActivities/settings.tsx @@ -48,7 +48,7 @@ const settings = definePluginSettings({ borderTop: "thin solid var(--background-modifier-accent)", paddingTop: 5, paddingBottom: 5 - }}/> + }} /> ), }, profiles: { diff --git a/src/plugins/betterActivities/styles.css b/src/plugins/betterActivities/styles.css index 1990c1730..7421b0ce5 100644 --- a/src/plugins/betterActivities/styles.css +++ b/src/plugins/betterActivities/styles.css @@ -19,44 +19,8 @@ border-radius: 50%; } -.vc-bactivities-activity { - display: flex; - align-items: center; - justify-content: center; - flex-wrap: wrap; - gap: 5px; -} - -.vc-bactivities-activity-title { - font-weight: bold; - text-align: center; -} - -.vc-bactivities-activity-image { - height: 20px; - width: 20px; - border-radius: 50%; - object-fit: cover; -} - -.vc-bactivities-activity-divider { - width: 100%; - border-top: 1px dotted rgb(255 255 255 / 20%); - margin-top: 3px; - margin-bottom: 3px; -} - -.vc-bactivities-activity-details { - display: flex; - flex-direction: column; - color: var(--text-muted); - word-break: break-word; -} - -.vc-bactivities-activity-time-bar { - width: 100%; - margin-top: 3px; - margin-bottom: 3px; +.vc-bactivities-activity-tooltip { + padding: 1px; } .vc-bactivities-caret-left, diff --git a/src/plugins/betterActivities/types.ts b/src/plugins/betterActivities/types.ts index 22306612c..14cc772fa 100644 --- a/src/plugins/betterActivities/types.ts +++ b/src/plugins/betterActivities/types.ts @@ -85,4 +85,6 @@ export interface IconCSSProperties extends CSSProperties { export interface ActivityViewProps { activity: Activity | null; user: User; + application?: Application; + type: string; }