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 TextAreaAutoSize from "../../../lib/TextAreaAutoSize"; 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 (
client.channels.edit(channel._id, { icon })} previewURL={client.channels.getIconURL(channel._id, { max_side: 256 }, true)} remove={() => client.channels.edit(channel._id, { remove: 'Icon' })} defaultPreview={channel.channel_type === 'Group' ? "/assets/group.png" : undefined} />

{ channel.channel_type === 'Group' ? : }

{ setName(e.currentTarget.value) if (!changed) setChanged(true) }} />

{ channel.channel_type === 'Group' ? : }

{ setDescription(ev.currentTarget.value); if (!changed) setChanged(true) }} />
); }