[Global] Fixes for latest Discord versions
This commit is contained in:
parent
9157cadec9
commit
ac4da3032e
5 changed files with 15 additions and 16 deletions
|
@ -1,7 +1,7 @@
|
||||||
import { find, findByProps } from "@metro/filters";
|
import { find, findByProps } from "@metro/filters";
|
||||||
|
|
||||||
// Discord
|
// Discord
|
||||||
export { constants } from "@lib/preinit";
|
export const constants = findByProps("API_HOST");
|
||||||
export const channels = findByProps("getVoiceChannelId");
|
export const channels = findByProps("getVoiceChannelId");
|
||||||
export const i18n = findByProps("Messages");
|
export const i18n = findByProps("Messages");
|
||||||
export const url = findByProps("openURL", "openDeeplink");
|
export const url = findByProps("openURL", "openDeeplink");
|
||||||
|
|
|
@ -12,12 +12,6 @@ window.React = basicFind("createElement") as typeof import("react");
|
||||||
// Export ReactNative
|
// Export ReactNative
|
||||||
export const ReactNative = basicFind("AppRegistry") as typeof import("react-native");
|
export const ReactNative = basicFind("AppRegistry") as typeof import("react-native");
|
||||||
|
|
||||||
// Export Discord's constants
|
|
||||||
export const constants = basicFind("AbortCodes");
|
|
||||||
|
|
||||||
// Export Discord's color module
|
|
||||||
export const color = basicFind("SemanticColor");
|
|
||||||
|
|
||||||
// Export chroma.js
|
// Export chroma.js
|
||||||
export const chroma = basicFind("brewer") as typeof import("chroma-js");
|
export const chroma = basicFind("brewer") as typeof import("chroma-js");
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,8 @@ import { DCDFileManager, MMKVManager, StorageBackend } from "@types";
|
||||||
import { ReactNative as RN } from "@metro/common";
|
import { ReactNative as RN } from "@metro/common";
|
||||||
|
|
||||||
const MMKVManager = window.nativeModuleProxy.MMKVManager as MMKVManager;
|
const MMKVManager = window.nativeModuleProxy.MMKVManager as MMKVManager;
|
||||||
const DCDFileManager = window.nativeModuleProxy.DCDFileManager as DCDFileManager;
|
//! 173.10 renamed this to RTNFileManager.
|
||||||
|
const DCDFileManager = (window.nativeModuleProxy.DCDFileManager ?? window.nativeModuleProxy.RTNFileManager) as DCDFileManager;
|
||||||
|
|
||||||
export const createMMKVBackend = (store: string): StorageBackend => ({
|
export const createMMKVBackend = (store: string): StorageBackend => ({
|
||||||
get: async () => JSON.parse((await MMKVManager.getItem(store)) ?? "{}"),
|
get: async () => JSON.parse((await MMKVManager.getItem(store)) ?? "{}"),
|
||||||
|
|
|
@ -1,10 +1,14 @@
|
||||||
import { DCDFileManager, Indexable, Theme, ThemeData } from "@types";
|
import { DCDFileManager, Indexable, Theme, ThemeData } from "@types";
|
||||||
|
import { findByProps } from "@metro/filters";
|
||||||
import { ReactNative, chroma } from "@metro/common";
|
import { ReactNative, chroma } from "@metro/common";
|
||||||
import { instead } from "@lib/patcher";
|
import { instead } from "@lib/patcher";
|
||||||
import { color } from "@lib/preinit";
|
|
||||||
import { createFileBackend, createMMKVBackend, createStorage, wrapSync, awaitSyncWrapper } from "@lib/storage";
|
import { createFileBackend, createMMKVBackend, createStorage, wrapSync, awaitSyncWrapper } from "@lib/storage";
|
||||||
import { safeFetch } from "@utils";
|
import { safeFetch } from "@utils";
|
||||||
|
|
||||||
|
//! As of 173.10, early-finding this does not work.
|
||||||
|
// Somehow, this is late enough, though?
|
||||||
|
export const color = findByProps("SemanticColor");
|
||||||
|
|
||||||
const DCDFileManager = window.nativeModuleProxy.DCDFileManager as DCDFileManager;
|
const DCDFileManager = window.nativeModuleProxy.DCDFileManager as DCDFileManager;
|
||||||
export const themes = wrapSync(createStorage<Indexable<Theme>>(createMMKVBackend("VENDETTA_THEMES")));
|
export const themes = wrapSync(createStorage<Indexable<Theme>>(createMMKVBackend("VENDETTA_THEMES")));
|
||||||
|
|
||||||
|
|
|
@ -1,17 +1,17 @@
|
||||||
import { findByProps } from "@metro/filters";
|
|
||||||
import { constants } from "@metro/common";
|
import { constants } from "@metro/common";
|
||||||
|
import { color } from "@lib/themes";
|
||||||
|
|
||||||
//! This module is only found on 165.0+, under the assumption that iOS 165.0 is the same as Android 165.0.
|
//! This module is only found on 165.0+, under the assumption that iOS 165.0 is the same as Android 165.0.
|
||||||
//* In 167.1, most if not all traces of the old color modules were removed.
|
//* In 167.1, most if not all traces of the old color modules were removed.
|
||||||
//* In 168.6, Discord restructured EVERYTHING again. SemanticColor on this module no longer works when passed to a stylesheet. We must now use what you see below.
|
//* In 168.6, Discord restructured EVERYTHING again. SemanticColor on this module no longer works when passed to a stylesheet. We must now use what you see below.
|
||||||
//? However, this is not all bad. The changes made in 168.6 do allow for better native-less theming.
|
//* In 173.10, Discord restructured a lot of the app. These changes included making the color module impossible to early-find.
|
||||||
const colorModule = findByProps("colors", "meta");
|
//? To stop duplication, it is now exported in our theming code.
|
||||||
|
//? These comments are preserved for historical purposes.
|
||||||
//* For both below, SemanticColor and RawColor are seemingly not used. Once again, what are Discord doing?
|
// const colorModule = findByProps("colors", "meta");
|
||||||
|
|
||||||
//? SemanticColor and default.colors are effectively ThemeColorMap
|
//? SemanticColor and default.colors are effectively ThemeColorMap
|
||||||
export const semanticColors = (constants.ThemeColorMap ?? colorModule?.colors);
|
export const semanticColors = (color?.default?.colors ?? constants?.ThemeColorMap);
|
||||||
|
|
||||||
//? RawColor and default.unsafe_rawColors are effectively Colors
|
//? RawColor and default.unsafe_rawColors are effectively Colors
|
||||||
//* Note that constants.Colors does still appear to exist on newer versions despite Discord not internally using it - what the fuck?
|
//* Note that constants.Colors does still appear to exist on newer versions despite Discord not internally using it - what the fuck?
|
||||||
export const rawColors = (constants.Colors ?? colorModule?.unsafe_rawColors);
|
export const rawColors = (color?.default?.unsafe_rawColors ?? constants?.Colors);
|
Loading…
Reference in a new issue