Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

context menu api fix #520

Closed
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
80 commits
Select commit Hold shift + click to select a range
be3f51b
fml
yofukashino Jul 21, 2023
6c2ccb7
removed testing log
yofukashino Jul 21, 2023
338d024
back to plain text patch
yofukashino Jul 23, 2023
f9e1e03
cspell will explod
yofukashino Jul 23, 2023
3f38f20
Merge branch 'main' into context-menu-api-fix
yofukashino Jul 23, 2023
fc4dafa
why do i have to format twice?
yofukashino Jul 23, 2023
237735d
Merge branch 'main' into context-menu-api-fix
yofukashino Jul 23, 2023
1b80faf
;-;
yofukashino Jul 23, 2023
23dbb25
fix some crashes sometimes
yofukashino Jul 23, 2023
859d7e4
Merge branch 'main' into context-menu-api-fix
yofukashino Jul 24, 2023
5f86eef
handle non array
yofukashino Jul 24, 2023
6c625bc
dumb me forgot this.
yofukashino Jul 25, 2023
06b0d06
done
yofukashino Jul 26, 2023
482e3dc
handle adding props at right place. would add for submenu items too now
yofukashino Jul 26, 2023
9c172c4
pretty now?
yofukashino Jul 26, 2023
eec81e3
handle some more edge cases
yofukashino Jul 26, 2023
166f4cd
dont add falsy values to menu
yofukashino Jul 26, 2023
0295196
requested changes
yofukashino Jul 27, 2023
bfeb5e1
prettier
yofukashino Jul 27, 2023
ffa0fc3
should be it
yofukashino Aug 11, 2023
9f8c076
better than how its already handled
yofukashino Aug 11, 2023
c77797f
personality >>> looks
yofukashino Aug 11, 2023
58baaf9
Merge branch 'main' into context-menu-api-fix
yofukashino Aug 19, 2023
5cfe18c
Merge branch 'main' into context-menu-api-fix
yofukashino Aug 22, 2023
3c05bdb
Merge branch 'main' into context-menu-api-fix
yofukashino Sep 1, 2023
4f30cfd
Merge branch 'main' into context-menu-api-fix
yofukashino Sep 5, 2023
46791d6
Merge branch 'main' into context-menu-api-fix
asportnoy Sep 7, 2023
26dee9e
Merge branch 'main' into context-menu-api-fix
yofukashino Sep 17, 2023
2d7e80c
Merge https://github.com/replugged-org/replugged into context-menu-ap…
yofukashino Sep 21, 2023
8933ba8
Merge remote-tracking branch 'refs/remotes/origin/context-menu-api-fi…
yofukashino Sep 21, 2023
6eae5a5
okay you asked for it
yofukashino Sep 21, 2023
eb0ded9
made it warning instead
yofukashino Sep 24, 2023
336cddb
Merge branch 'main' into context-menu-api-fix
yofukashino Sep 24, 2023
5b83882
Merge branch 'main' into context-menu-api-fix
yofukashino Sep 26, 2023
3e48742
Merge branch 'main' into context-menu-api-fix
yofukashino Sep 30, 2023
b372e21
should pass
yofukashino Sep 30, 2023
40fd42a
Merge branch 'main' into context-menu-api-fix
yofukashino Sep 30, 2023
c584a38
pretty?
yofukashino Sep 30, 2023
0dbac6c
Merge branch 'context-menu-api-fix' of https://github.com/Tharki-God/…
yofukashino Sep 30, 2023
ba5d23b
Merge branch 'main' into context-menu-api-fix
yofukashino Oct 10, 2023
5dd6c7e
Merge branch 'main' into context-menu-api-fix
yofukashino Oct 17, 2023
5b014bf
Merge branch 'main' into context-menu-api-fix
yofukashino Oct 19, 2023
552d2a8
Merge branch 'main' into context-menu-api-fix
yofukashino Oct 20, 2023
33e4a34
Merge branch 'main' into context-menu-api-fix
yofukashino Oct 22, 2023
d8eb887
better plain text patch
yofukashino Oct 23, 2023
e6dc5f6
Merge branch 'main' into context-menu-api-fix
yofukashino Nov 2, 2023
9b67560
fixed for unswc
yofukashino Nov 2, 2023
1d4b48b
Merge branch 'context-menu-api-fix' of https://github.com/Tharki-God/…
yofukashino Nov 2, 2023
8bff7ac
idk
yofukashino Nov 2, 2023
ea82bd3
fixed me dumb dumb
yofukashino Nov 5, 2023
2418881
Merge branch 'main' into context-menu-api-fix
yofukashino Dec 1, 2023
684c8c2
Merge branch 'main' into context-menu-api-fix
yofukashino Dec 3, 2023
ff7370f
Merge branch 'main' into context-menu-api-fix
yofukashino Dec 16, 2023
3530b9a
Merge branch 'main' into context-menu-api-fix
yofukashino Jan 13, 2024
9d7ecf9
syntx?
yofukashino Jan 30, 2024
8681f8e
Merge branch 'context-menu-api-fix' of https://github.com/Tharki-God/…
yofukashino Jan 30, 2024
32b9053
Merge branch 'main' into context-menu-api-fix
yofukashino Jan 30, 2024
6a2b027
pnpm replug
yofukashino Feb 21, 2024
dc4ca50
Merge branch 'context-menu-api-fix' of https://github.com/Tharki-God/…
yofukashino Feb 21, 2024
660484b
Merge branch 'main' into context-menu-api-fix
yofukashino Feb 21, 2024
99a50ba
better?
yofukashino Feb 21, 2024
9af98b0
Merge branch 'context-menu-api-fix' of https://github.com/Tharki-God/…
yofukashino Feb 21, 2024
4df27da
better?
yofukashino Feb 21, 2024
50bc857
type fix
yofukashino Feb 28, 2024
7941c99
Merge branch 'main' into context-menu-api-fix
yofukashino Apr 4, 2024
1683626
Merge branch 'main' into context-menu-api-fix
yofukashino Apr 7, 2024
8271cc8
Merge branch 'main' into context-menu-api-fix
yofukashino Apr 8, 2024
6cec1fe
Merge branch 'main' into context-menu-api-fix
yofukashino May 4, 2024
77b6bf4
Merge branch 'main' into context-menu-api-fix
yofukashino May 20, 2024
97930b3
Merge branch 'main' into context-menu-api-fix
yofukashino May 31, 2024
5ddd1b5
Merge branch 'main' into context-menu-api-fix
yofukashino Jun 14, 2024
22a4081
Merge branch 'main' into context-menu-api-fix
yofukashino Jun 21, 2024
8254073
fix
yofukashino Jun 21, 2024
dff6ede
Merge branch 'main' into context-menu-api-fix
yofukashino Jun 26, 2024
e9c279e
pretty
yofukashino Jun 26, 2024
e7f00d3
Merge branch 'main' into context-menu-api-fix
colin273 Jul 6, 2024
8e3f82e
Merge branch 'main' into context-menu-api-fix
yofukashino Jul 9, 2024
6f9d524
prettier
yofukashino Jul 13, 2024
7be48ab
Merge branch 'main' into context-menu-api-fix
yofukashino Sep 9, 2024
7573ade
Merge branch 'main' into context-menu-api-fix
yofukashino Oct 18, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
148 changes: 105 additions & 43 deletions src/renderer/coremods/contextMenu/index.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { React, components } from "@common";

Check warning on line 1 in src/renderer/coremods/contextMenu/index.tsx

View workflow job for this annotation

GitHub Actions / Run ESLint

'components' is defined but never used. Allowed unused vars must match /^_/u
import type { ContextMenuProps } from "@components/ContextMenu";
import type {
ContextItem,
Expand All @@ -7,6 +7,7 @@
RawContextItem,
} from "../../../types/coremods/contextMenu";
import { Logger } from "../../modules/logger";
import { ContextMenu as ContextComponents } from "../../modules/components";

const logger = Logger.api("ContextMenu");

Expand All @@ -16,27 +17,34 @@
| undefined
>;

type RepluggedContextItem = ContextItem & {
props: { replug?: boolean; id?: string };
};

/**
* Converts data into a React element. Any elements or falsy value will be returned as is
* @param raw The data to convert
* @returns The converted item
*/
function makeItem(raw: RawContextItem | ContextItem | undefined | void): ContextItem | undefined {
function makeItem(
raw: RawContextItem | ContextItem | undefined | void,
): RepluggedContextItem | undefined {
// Occasionally React won't be loaded when this function is ran, so we don't return anything
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
if (!React) return undefined;

if (!raw) {
// If something falsy is passed, let it through
// Discord just skips over them too
return raw as ContextItem | undefined;
return raw as undefined;
}
if (React.isValidElement(raw)) {
// We can't construct something that's already made
return raw as ContextItem | undefined;
return raw as RepluggedContextItem;
}

const { type, ...props } = raw;
// add in prop for cleanup
if (props.children) {
props.children = props.children.map((child: RawContextItem | ContextItem | undefined) =>
makeItem(child),
Expand Down Expand Up @@ -77,7 +85,7 @@
}

type ContextMenuData = ContextMenuProps["ContextMenu"] & {
children: React.ReactElement | React.ReactElement[];
children: React.ReactElement | Array<React.ReactElement | null> | null;
data: Array<Record<string, unknown>>;
navId: ContextMenuTypes;
plugged?: boolean;
Expand All @@ -87,64 +95,118 @@
* @internal
yofukashino marked this conversation as resolved.
Show resolved Hide resolved
* @hidden
*/
yofukashino marked this conversation as resolved.
Show resolved Hide resolved
export function _insertMenuItems(menu: ContextMenuData): void {
export function _buildPatchedMenu(menu: ContextMenuData): React.ReactElement | null {
const { navId } = menu;
const {
MenuGroup,
ContextMenu,
}: {
MenuGroup: React.FC<ContextMenuProps["MenuGroup"]>;
ContextMenu: React.FC<ContextMenuProps["ContextMenu"] & { plugged?: boolean }>;
} = ContextComponents;

//return nothing as we weren't able to get ContextMenu component, gets handled in plain text patch
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
if (!ContextMenu || menu.plugged) return null;

// No items to insert
if (!menuItems[navId]) return;

// Already inserted items
// If this isn't here, another group of items is added every update
if (menu.plugged) return;

// We delay getting the items until now, as importing at the start of the file causes Discord to hang
// Using `await import(...)` is undesirable because the new items will only appear once the menu is interacted with
const { MenuGroup } = components;
//if (!MenuGroup) return;
// Or MenuGroup Component is not available
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
if (!menuItems[navId] || !MenuGroup) return <ContextMenu {...menu} plugged={true} />;

// The data as passed as Arguments from the calling function, so we just grab what we want from it
const data = menu.data[0];

const repluggedGroup = <MenuGroup />;
repluggedGroup.props.id = "replugged";
repluggedGroup.props.children = [];
// make children array if it's not already
if (!Array.isArray(menu.children)) {
menu.children = [menu.children];
}

// Add in the new menu items right above the DevMode Copy ID
// For Adding in the new menu items right above the DevMode Copy ID
// If the user doesn't have DevMode enabled, the new items will be at the bottom
if (!Array.isArray(menu.children)) menu.children = [menu.children];
const hasCopyId = menu.children
.at(-1)
?.props?.children?.props?.id?.startsWith("devmode-copy-id-");
if (hasCopyId) {
menu.children.splice(-1, 0, repluggedGroup);
const hasCopyId =
menu.children.at(-1)?.props?.children?.props?.id?.startsWith("devmode-copy-id-") ||
menu.children
.at(-1)
?.props?.children?.some?.((c: React.ReactElement | null) =>
c?.props?.id?.startsWith("devmode-copy-id-"),
);
if (!menu.children.some((child) => child?.props?.id === "replugged")) {
//Add group only if it doesn't exist
const repluggedGroup = <MenuGroup />;
repluggedGroup.props.id = "replugged";
repluggedGroup.props.children = [];

if (hasCopyId) {
menu.children.splice(-1, 0, repluggedGroup);
} else {
menu.children.push(repluggedGroup);
}
} else {
menu.children.push(repluggedGroup);
//clear replugged section if it was there already
menu.children.at(hasCopyId ? -2 : -1)!.props.children = [];
}

menuItems[navId]?.forEach((item) => {
//get sections from where to clean items
const usedSectionIds = menuItems[navId]
?.map((item) => item.sectionId)
.filter((item, index, array) => array.indexOf(item) === index);

//cleaning old items before adding new ones
usedSectionIds?.forEach((sectionId) => {
try {
const res = makeItem(item.getItem(data, menu)) as
| (ContextItem & { props: { id?: string } })
| undefined;
if (res?.props) {
// add in unique ids
res.props.id = `${res.props.id || "repluggedItem"}-${Math.random()
FedeIlLeone marked this conversation as resolved.
Show resolved Hide resolved
.toString(36)
.substring(2)}`;
if (!Array.isArray(menu.children)) {
return;
}
if (menu.children.at(sectionId!)?.props?.children) {
menu.children.at(sectionId!)!.props.children = Array.isArray(
menu.children.at(sectionId!)?.props.children,
)
? menu.children
.at(sectionId!)
?.props.children.filter((child: React.ReactElement | null) => !child?.props?.replug)
: [menu.children.at(sectionId!)?.props.children];
}
} catch (err) {
logger.warn(
"Error while removing old menu items",
err,
Array.isArray(menu.children) ? menu.children.at(sectionId!) : null,
);
}
});

if (!Array.isArray(menu.children)) menu.children = [menu.children];
const section =
typeof item.sectionId === "undefined" ? repluggedGroup : menu.children.at(item.sectionId);
if (!section) {
logger.error("Couldn't find section", item.sectionId, menu.children);
//adding new items
menuItems[navId]?.forEach((item) => {
try {
if (!Array.isArray(menu.children)) {
return;
}
section.props.children.splice(item.indexInSection, 0, res);
const itemRet = makeItem(item.getItem(data, menu));
if (itemRet) {
// adding prop for easy cleanup
itemRet.props.replug = true;
FedeIlLeone marked this conversation as resolved.
Show resolved Hide resolved
// custom unique id if not added by dev
itemRet.props.id ??= `repluggedItem-${Number(`0.${Date.now()}`).toString(36).substring(2)}`;
const section =
typeof item.sectionId === "undefined"
? menu.children.at(hasCopyId ? -2 : -1)
: menu.children.at(item.sectionId);
if (!section) {
logger.warn("Couldn't find section", item.sectionId, menu.children);
return;
}
section.props.children?.splice(item.indexInSection, 0, itemRet);
}
} catch (err) {
logger.error("Error while running GetContextItem function", err, item.getItem);
logger.error(
"Error while running GetContextItem function",
err,
item.getItem,
Array.isArray(menu.children) ? menu.children.at(item.sectionId!) : null,
);
}
});

menu.plugged = true;
return <ContextMenu {...menu} plugged={true} />;
}
8 changes: 4 additions & 4 deletions src/renderer/coremods/contextMenu/plaintextPatches.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,12 @@ import type { PlaintextPatch } from "src/types";

export default [
{
find: 'Error("Menu',
find: 'Error("Menu API',
replacements: [
{
match: /((\w+)\){)(var\s*\w+;let{navId:)/,
replace: (_, prefix, menu, suffix) =>
`${prefix}replugged.coremods.coremods.contextMenu._insertMenuItems(${menu});${suffix}`,
match: /return(\(0,.\.jsx\)\(\w+\.\w+\.Provider)/,
replace: (_, suffix) =>
`return replugged.coremods.coremods.contextMenu._buildPatchedMenu(arguments[0])??${suffix}`,
},
],
},
Expand Down