import { Text } from "preact-i18n"; import styles from "./Panes.module.scss"; import Button from "../../../components/ui/Button"; import { Channels } from "revolt.js/dist/api/objects"; import InputBox from "../../../components/ui/InputBox"; import TextArea from "../../../components/ui/TextArea"; import { useContext, useEffect, useState } from "preact/hooks"; import { AppContext } from "../../../context/revoltjs/RevoltClient"; import { FileUploader } from "../../../context/revoltjs/FileUploads"; interface Props { channel: Channels.GroupChannel | Channels.TextChannel; } export function Overview({ channel }: Props) { const client = useContext(AppContext); const [name, setName] = useState(channel.name); const [description, setDescription] = useState(channel.description ?? ''); useEffect(() => setName(channel.name), [ channel.name ]); useEffect(() => setDescription(channel.description ?? ''), [ channel.description ]); const [ changed, setChanged ] = useState(false); function save() { let changes: any = {}; if (name !== channel.name) changes.name = name; if (description !== channel.description) changes.description = description; client.channels.edit(channel._id, changes); setChanged(false); } return (