1
0
Fork 1
mirror of https://github.com/Vendicated/Vencord.git synced 2025-01-10 18:06:22 +00:00

Merge branch 'dev' into immediate-finds

This commit is contained in:
Nuckyz 2024-05-07 06:23:36 -03:00
commit 9cd20e3cea
No known key found for this signature in database
GPG key ID: 440BF8296E1C4AD9
2 changed files with 20 additions and 23 deletions

View file

@ -19,7 +19,7 @@
import type * as Stores from "discord-types/stores"; import type * as Stores from "discord-types/stores";
// eslint-disable-next-line path-alias/no-relative // eslint-disable-next-line path-alias/no-relative
import { findByProps, findStore } from "../webpack"; import { filters, find, findByProps, findStore } from "../webpack";
import * as t from "./types/stores"; import * as t from "./types/stores";
export const Flux = findByProps<t.Flux>("connectStores"); export const Flux = findByProps<t.Flux>("connectStores");
@ -66,17 +66,14 @@ export const DraftStore = findStore<t.DraftStore>("DraftStore");
* *
* @param stores The stores to listen to * @param stores The stores to listen to
* @param mapper A function that returns the data you need * @param mapper A function that returns the data you need
* @param idk some thing, idk just pass null * @param dependencies An array of reactive values which the hook depends on. Use this if your mapper or equality function depends on the value of another hook
* @param isEqual A custom comparator for the data returned by mapper * @param isEqual A custom comparator for the data returned by mapper
* *
* @example const user = useStateFromStores([UserStore], () => UserStore.getCurrentUser(), null, (old, current) => old.id === current.id); * @example const user = useStateFromStores([UserStore], () => UserStore.getCurrentUser(), null, (old, current) => old.id === current.id);
*/ */
export const { useStateFromStores }: { export const useStateFromStores = find(filters.byProps("useStateFromStores"), m => m.useStateFromStores) as <T>(
useStateFromStores: <T>( stores: t.FluxStore[],
stores: t.FluxStore[], mapper: () => T,
mapper: () => T, dependencies?: any,
idk?: any, isEqual?: (old: T, newer: T) => boolean
isEqual?: (old: T, newer: T) => boolean ) => T;
) => T;
}
= findByProps("useStateFromStores");

View file

@ -169,9 +169,9 @@ export function waitFor(filter: FilterFn, callback: ModCallbackFn, { isIndirect
* *
* The callback must return a value that will be used as the proxy inner value. * The callback must return a value that will be used as the proxy inner value.
* *
* If no callback is specified, the default callback will assign the proxy inner value to all the module * If no callback is specified, the default callback will assign the proxy inner value to all the module.
* @param filter A function that takes a module and returns a boolean * @param filter A function that takes a module and returns a boolean
* @param callback A function that takes the found module as its first argument and returns to use as the proxy inner value * @param callback A function that takes the found module as its first argument and returns something to use as the proxy inner value. Useful if you want to use a value from the module, instead of all of it. Defaults to the module itself
* @returns A proxy that has the callback return value as its true value, or the callback return value if the callback was called when the function was called * @returns A proxy that has the callback return value as its true value, or the callback return value if the callback was called when the function was called
*/ */
export function find<T = any>(filter: FilterFn, callback: (mod: any) => any = m => m, { isIndirect = false }: { isIndirect?: boolean; } = {}) { export function find<T = any>(filter: FilterFn, callback: (mod: any) => any = m => m, { isIndirect = false }: { isIndirect?: boolean; } = {}) {
@ -304,7 +304,7 @@ export function findComponentByCode<T extends object = any>(...code: string[] |
} }
/** /**
* Find the first module or default export that includes all the given props * Find the first module or default export that includes all the given props.
* *
* @param props A list of props to search the exports for * @param props A list of props to search the exports for
*/ */
@ -319,7 +319,7 @@ export function findByProps<T = any>(...props: string[]) {
} }
/** /**
* Find the first export that includes all the given code * Find the first export that includes all the given code.
* *
* @param code A list of code to search each export for * @param code A list of code to search each export for
*/ */
@ -334,7 +334,7 @@ export function findByCode<T = any>(...code: string[]) {
} }
/** /**
* Find a store by its name * Find a store by its name.
* *
* @param name The store name * @param name The store name
*/ */
@ -396,7 +396,7 @@ export function cacheFindAll(filter: FilterFn) {
} }
/** /**
* Same as {@link cacheFind} but in bulk * Same as {@link cacheFind} but in bulk.
* @param filterFns Array of filters. Please note that this array will be modified in place, so if you still * @param filterFns Array of filters. Please note that this array will be modified in place, so if you still
* need it afterwards, pass a copy. * need it afterwards, pass a copy.
* @returns Array of results in the same order as the passed filters * @returns Array of results in the same order as the passed filters
@ -462,7 +462,7 @@ export const cacheFindBulk = traceFunction("findBulk", function findBulk(...filt
}); });
/** /**
* Find the id of the first module factory that includes all the given code * Find the id of the first module factory that includes all the given code.
* @returns string or null * @returns string or null
*/ */
export const findModuleId = traceFunction("findModuleId", function findModuleId(...code: string[]) { export const findModuleId = traceFunction("findModuleId", function findModuleId(...code: string[]) {
@ -490,7 +490,7 @@ export const findModuleId = traceFunction("findModuleId", function findModuleId(
}); });
/** /**
* Find the first module factory that includes all the given code * Find the first module factory that includes all the given code.
* @returns The module factory or null * @returns The module factory or null
*/ */
export function findModuleFactory(...code: string[]) { export function findModuleFactory(...code: string[]) {
@ -504,7 +504,7 @@ export function findModuleFactory(...code: string[]) {
* This is just a wrapper around {@link proxyLazy} to make our reporter test for your webpack finds. * This is just a wrapper around {@link proxyLazy} to make our reporter test for your webpack finds.
* *
* Wraps the result of factory in a Proxy you can consume as if it wasn't lazy. * Wraps the result of factory in a Proxy you can consume as if it wasn't lazy.
* On first property access, the factory is evaluated * On first property access, the factory is evaluated.
* @param factory Factory returning the result * @param factory Factory returning the result
* @param attempts How many times to try to evaluate the factory before giving up * @param attempts How many times to try to evaluate the factory before giving up
* @returns Result of factory function * @returns Result of factory function
@ -535,7 +535,7 @@ export function webpackDependantLazyComponent<T extends object = any>(factory: (
* This is just a wrapper around {@link proxyLazy} to make our reporter test for your webpack finds. * This is just a wrapper around {@link proxyLazy} to make our reporter test for your webpack finds.
* *
* Wraps the result of factory in a Proxy you can consume as if it wasn't lazy. * Wraps the result of factory in a Proxy you can consume as if it wasn't lazy.
* On first property access, the factory is evaluated * On first property access, the factory is evaluated.
* @param factory Factory returning the result * @param factory Factory returning the result
* @param attempts How many times to try to evaluate the factory before giving up * @param attempts How many times to try to evaluate the factory before giving up
* @returns Result of factory function * @returns Result of factory function
@ -622,7 +622,7 @@ export const findBulk = cacheFindBulk;
const DefaultExtractAndLoadChunksRegex = /(?:Promise\.all\((\[\i\.\i\(".+?"\).+?\])\)|Promise\.resolve\(\)).then\(\i\.bind\(\i,"(.+?)"\)\)/; const DefaultExtractAndLoadChunksRegex = /(?:Promise\.all\((\[\i\.\i\(".+?"\).+?\])\)|Promise\.resolve\(\)).then\(\i\.bind\(\i,"(.+?)"\)\)/;
/** /**
* Extract and load chunks using their entry point * Extract and load chunks using their entry point.
* @param code An array of all the code the module factory containing the lazy chunk loading must include * @param code An array of all the code the module factory containing the lazy chunk loading must include
* @param matcher A RegExp that returns the chunk ids array as the first capture group and the entry point id as the second. Defaults to a matcher that captures the lazy chunk loading found in the module factory * @param matcher A RegExp that returns the chunk ids array as the first capture group and the entry point id as the second. Defaults to a matcher that captures the lazy chunk loading found in the module factory
* @returns A promise that resolves when the chunks were loaded * @returns A promise that resolves when the chunks were loaded
@ -671,7 +671,7 @@ export async function extractAndLoadChunks(code: string[], matcher: RegExp = Def
/** /**
* This is just a wrapper around {@link extractAndLoadChunks} to make our reporter test for your webpack finds. * This is just a wrapper around {@link extractAndLoadChunks} to make our reporter test for your webpack finds.
* *
* Extract and load chunks using their entry point * Extract and load chunks using their entry point.
* @param code An array of all the code the module factory containing the lazy chunk loading must include * @param code An array of all the code the module factory containing the lazy chunk loading must include
* @param matcher A RegExp that returns the chunk ids array as the first capture group and the entry point id as the second. Defaults to a matcher that captures the lazy chunk loading found in the module factory * @param matcher A RegExp that returns the chunk ids array as the first capture group and the entry point id as the second. Defaults to a matcher that captures the lazy chunk loading found in the module factory
* @returns A function that returns a promise that resolves when the chunks were loaded, on first call * @returns A function that returns a promise that resolves when the chunks were loaded, on first call