import axios from "axios"; import { Attachment } from "revolt.js/dist/api/objects"; import styles from "./Attachment.module.scss"; import { useContext, useEffect, useState } from "preact/hooks"; import RequiresOnline from "../../../../context/revoltjs/RequiresOnline"; import { AppContext, StatusContext, } from "../../../../context/revoltjs/RevoltClient"; import Preloader from "../../../ui/Preloader"; interface Props { attachment: Attachment; } const fileCache: { [key: string]: string } = {}; export default function TextFile({ attachment }: Props) { const [content, setContent] = useState(undefined); const [loading, setLoading] = useState(false); const status = useContext(StatusContext); const client = useContext(AppContext); const url = client.generateFileURL(attachment)!; useEffect(() => { if (typeof content !== "undefined") return; if (loading) return; if (attachment.size > 20_000) { setContent( "This file is > 20 KB, for your sake I did not load it.\nSee tracking issue here for previews: https://gitlab.insrt.uk/revolt/revite/-/issues/2", ); return; } setLoading(true); const cached = fileCache[attachment._id]; if (cached) { setContent(cached); setLoading(false); } else { axios .get(url, { transformResponse: [] }) .then((res) => { setContent(res.data); fileCache[attachment._id] = res.data; setLoading(false); }) .catch(() => { console.error( "Failed to load text file. [", attachment._id, "]", ); setLoading(false); }); } }, [content, loading, status]); return (
{content ? (
                    {content}
                
) : ( )}
); }