Skip to content

Commit

Permalink
Merge branch 'Davilarek:main' into main
Browse files Browse the repository at this point in the history
  • Loading branch information
SashaXser authored Nov 3, 2024
2 parents ab37f45 + da5703b commit c9f9a75
Show file tree
Hide file tree
Showing 6 changed files with 65 additions and 36 deletions.
7 changes: 7 additions & 0 deletions src/plugins/consoleJanitor/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,13 @@ export default definePlugin({
},

patches: [
{
find: 'react-spring: The "interpolate" function',
replacement: {
match: /,console.warn\('react-spring: The "interpolate" function is deprecated in v10 \(use "to" instead\)'\)/,
replace: ""
}
},
{
find: 'console.warn("Window state not initialized"',
replacement: {
Expand Down
10 changes: 10 additions & 0 deletions src/plugins/imageZoom/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -179,6 +179,11 @@ export default definePlugin({
{
match: /componentWillUnmount\(\){/,
replace: "$&$self.unMountMagnifier();"
},

{
match: /componentDidUpdate\(\i\){/,
replace: "$&$self.updateMagnifier(this);"
}
]
}
Expand Down Expand Up @@ -215,6 +220,11 @@ export default definePlugin({
}
},

updateMagnifier(instance) {
this.unMountMagnifier();
this.renderMagnifier(instance);
},

unMountMagnifier() {
this.root?.unmount();
this.currentMagnifierElement = null;
Expand Down
2 changes: 1 addition & 1 deletion src/plugins/noPendingCount/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,7 @@ export default definePlugin({
replacement: {
// The two groups inside the first group grab the minified names of the variables,
// they are then referenced later to find unviewedTrialCount + unviewedDiscountCount.
match: /(?<=\{unviewedTrialCount:(\i),unviewedDiscountCount:(\i)\}.{0,200}\i=)\1\+\2/,
match: /(?<=\{unviewedTrialCount:(\i),unviewedDiscountCount:(\i)\}.{0,300}\i=)\1\+\2/,
replace: "0"
}
}
Expand Down
10 changes: 5 additions & 5 deletions src/utils/discord.css
Original file line number Diff line number Diff line change
Expand Up @@ -7,18 +7,18 @@
**/

.vc-image-modal {
background: transparent!important;
box-shadow: none!important;
background: transparent !important;
box-shadow: none !important;
display: flex;
justify-content: center;
align-items: center;
border-radius: 0
border-radius: 0;
}

@media(width <= 485px) {
.vc-image-modal {
display:relative;
display: relative;
overflow: visible;
overflow: initial
overflow: initial;
}
}
33 changes: 15 additions & 18 deletions src/utils/discord.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,9 @@ import "./discord.css";
import { MessageObject } from "@api/MessageEvents";
import { ChannelStore, ComponentDispatch, Constants, FluxDispatcher, GuildStore, InviteActions, MessageActions, PrivateChannelsStore, RestAPI, SelectedChannelStore, SelectedGuildStore, UserProfileActions, UserProfileStore, UserSettingsActionCreators, UserUtils } from "@webpack/common";
import { Channel, Guild, Message, User } from "discord-types/general";
import { Except } from "type-fest";

import { ImageModal, ImageModalItem, openModal } from "./modal";
import { MediaModalItem, MediaModalProps, openMediaModal } from "./modal";

/**
* Open the invite modal
Expand Down Expand Up @@ -111,24 +112,20 @@ export function sendMessage(
}

/**
* You must specify either height or width
* You must specify either height or width in the item
*/
export function openImageModal(props: Omit<ImageModalItem, "type">): string {
return openModal(modalProps => (
<ImageModal
{...modalProps}
className="vc-image-modal"
fit="vc-position-inherit"
items={[{
type: "IMAGE",
original: props.url,
...props,
}]}
onClose={modalProps.onClose}
shouldHideMediaOptions={false}
shouldAnimate
/>
));
export function openImageModal(item: Except<MediaModalItem, "type">, mediaModalProps?: Omit<MediaModalProps, "items">) {
return openMediaModal({
className: "vc-image-modal",
fit: "vc-position-inherit",
shouldAnimateCarousel: true,
items: [{
type: "IMAGE",
original: item.original ?? item.url,
...item,
}],
...mediaModalProps
});
}

export async function openUserProfile(id: string) {
Expand Down
39 changes: 27 additions & 12 deletions src/utils/modal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/

import { findByPropsLazy, findComponentByCodeLazy } from "@webpack";
import { findByPropsLazy, findModuleId, proxyLazyWebpack, wreq } from "@webpack";
import type { ComponentType, PropsWithChildren, ReactNode, Ref } from "react";

import { LazyComponent } from "./react";
Expand Down Expand Up @@ -101,24 +101,39 @@ export const Modals = findByPropsLazy("ModalRoot", "ModalCloseButton") as {
}>;
};

export interface ImageModalItem {
type: "IMAGE" | "VIDEO";
export type MediaModalItem = {
url: string;
type: "IMAGE" | "VIDEO";
original?: string;
alt?: string;
width?: number;
height?: number;
original?: string;
}

export type ImageModal = ComponentType<{
animated?: boolean;
maxWidth?: number;
maxHeight?: number;
} & Record<PropertyKey, any>;

export type MediaModalProps = {
location?: string;
contextKey?: string;
onCloseCallback?: () => void;
className?: string;
items: MediaModalItem[];
startingIndex?: number;
onIndexChange?: (...args: any[]) => void;
fit?: string;
onClose?(): void;
shouldRedactExplicitContent?: boolean;
shouldHideMediaOptions?: boolean;
shouldAnimate?: boolean;
items: ImageModalItem[];
}>;
shouldAnimateCarousel?: boolean;
};

export const openMediaModal: (props: MediaModalProps) => void = proxyLazyWebpack(() => {
const mediaModalKeyModuleId = findModuleId('"Zoomed Media Modal"');
if (mediaModalKeyModuleId == null) return;

export const ImageModal = findComponentByCodeLazy(".MEDIA_MODAL_CLOSE") as ImageModal;
const openMediaModalModule = wreq(findModuleId(mediaModalKeyModuleId, "modalKey:") as any);
return Object.values<any>(openMediaModalModule).find(v => String(v).includes("modalKey:"));
});

export const ModalRoot = LazyComponent(() => Modals.ModalRoot);
export const ModalHeader = LazyComponent(() => Modals.ModalHeader);
Expand Down

0 comments on commit c9f9a75

Please sign in to comment.