import { Embed as EmbedRJS } from "revolt.js/dist/api/objects"; import styles from "./Embed.module.scss"; import classNames from "classnames"; import { useContext } from "preact/hooks"; import { useIntermediate } from "../../../../context/intermediate/Intermediate"; import { MessageAreaWidthContext } from "../../../../pages/channels/messaging/MessageArea"; import EmbedMedia from "./EmbedMedia"; interface Props { embed: EmbedRJS; } const MAX_EMBED_WIDTH = 480; const MAX_EMBED_HEIGHT = 640; const CONTAINER_PADDING = 24; const MAX_PREVIEW_SIZE = 150; export default function Embed({ embed }: Props) { // ! FIXME: temp code // ! add proxy function to client function proxyImage(url: string) { return `https://jan.revolt.chat/proxy?url=${encodeURIComponent(url)}`; } const { openScreen } = useIntermediate(); const maxWidth = Math.min( useContext(MessageAreaWidthContext) - CONTAINER_PADDING, MAX_EMBED_WIDTH, ); function calculateSize( w: number, h: number, ): { width: number; height: number } { const limitingWidth = Math.min(maxWidth, w); const limitingHeight = Math.min(MAX_EMBED_HEIGHT, h); // Calculate smallest possible WxH. const width = Math.min(limitingWidth, limitingHeight * (w / h)); const height = Math.min(limitingHeight, limitingWidth * (h / w)); return { width, height }; } switch (embed.type) { case "Website": { // Determine special embed size. let mw, mh; const largeMedia = (embed.special && embed.special.type !== "None") || embed.image?.size === "Large"; switch (embed.special?.type) { case "YouTube": case "Bandcamp": { mw = embed.video?.width ?? 1280; mh = embed.video?.height ?? 720; break; } case "Twitch": { mw = 1280; mh = 720; break; } default: { if (embed.image?.size === "Preview") { mw = MAX_EMBED_WIDTH; mh = Math.min( embed.image.height ?? 0, MAX_PREVIEW_SIZE, ); } else { mw = embed.image?.width ?? MAX_EMBED_WIDTH; mh = embed.image?.height ?? 0; } } } const { width, height } = calculateSize(mw, mh); return (