From 363c597e225dd2b6f8e718f51238a6ae50675804 Mon Sep 17 00:00:00 2001 From: relitrix <46451374+relitrix@users.noreply.github.com> Date: Tue, 10 Sep 2024 03:29:58 +0300 Subject: [PATCH] feat: Enlarge on thumbnail click --- src/plugins/biggerStreamPreview/index.tsx | 38 ++++++++++++++++++++--- 1 file changed, 34 insertions(+), 4 deletions(-) diff --git a/src/plugins/biggerStreamPreview/index.tsx b/src/plugins/biggerStreamPreview/index.tsx index 8cca912bc..0912aa73e 100644 --- a/src/plugins/biggerStreamPreview/index.tsx +++ b/src/plugins/biggerStreamPreview/index.tsx @@ -17,11 +17,12 @@ */ import { NavContextMenuPatchCallback } from "@api/ContextMenu"; +import { definePluginSettings } from "@api/Settings"; import { ScreenshareIcon } from "@components/Icons"; import { Devs } from "@utils/constants"; import { openImageModal } from "@utils/discord"; -import definePlugin from "@utils/types"; -import { Menu } from "@webpack/common"; +import definePlugin, { OptionType } from "@utils/types"; +import { Menu, Text } from "@webpack/common"; import { Channel, User } from "discord-types/general"; import { ApplicationStreamingStore, ApplicationStreamPreviewStore } from "./webpack/stores"; @@ -85,12 +86,41 @@ export const userContextPatch: NavContextMenuPatchCallback = (children, { user } if (user) return addViewStreamContext(children, { userId: user.id }); }; +const settings = definePluginSettings({ + thumbnailEnlarge: { + type: OptionType.BOOLEAN, + description: "Enlarge on thumbnail click", + default: true, + restartNeeded: true + } +}); + export default definePlugin({ name: "BiggerStreamPreview", description: "This plugin allows you to enlarge stream previews", - authors: [Devs.phil], + authors: [Devs.phil, Devs.relitrix], + settings, contextMenus: { "user-context": userContextPatch, "stream-context": streamContextPatch - } + }, + patches: [ + { + find: ".WATCH_STREAM_IN_APP", + group: true, + replacement: [ + { + match: /(\i.previewHover,children:)\(.,\i.jsx\)\(\i.Text.(.*?)}\)/, + replace: "$1$self.openPreviewText()" + }, + { + match: /(?<=renderPreview\((\i)\).{40,}\i.Clickable,{onClick:)\i/, + replace: (_, stream) => `() => $self.handleViewPreview(${stream})` + } + ], + predicate: () => settings.store.thumbnailEnlarge + } + ], + openPreviewText: () => Open Preview, + handleViewPreview });