+import axios from 'axios';
import React from 'react';
+import { Alert, Button, Col, Form, Row } from 'react-bootstrap';
+import { useTranslation } from 'react-i18next';
+import toastr from 'toastr';
+
+import ChannelSelect from '../common/ChannelSelect';
+import ToggleSwitch from '../common/ToggleSwitch';
const Controls = () => {
- return <div />;
+ const [channel, setChannel] = React.useState(null);
+ const [chatText, setChatText] = React.useState('');
+
+ const { t } = useTranslation();
+
+ const chat = React.useCallback(async text => {
+ try {
+ await axios.post(`/api/channels/${channel.id}/chat`, {
+ text,
+ });
+ toastr.success(t('twitchBot.chatSuccess'));
+ } catch (e) {
+ toastr.error(t('twitchBot.chatError'));
+ }
+ }, [channel, chatText, t]);
+
+ const join = React.useCallback(async () => {
+ try {
+ const rsp = await axios.post(`/api/channels/${channel.id}/join`);
+ setChannel(rsp.data);
+ toastr.success(t('twitchBot.joinSuccess'));
+ } catch (e) {
+ toastr.error(t('twitchBot.joinError'));
+ }
+ }, [channel, t]);
+
+ const part = React.useCallback(async () => {
+ try {
+ const rsp = await axios.post(`/api/channels/${channel.id}/part`);
+ setChannel(rsp.data);
+ toastr.success(t('twitchBot.partSuccess'));
+ } catch (e) {
+ toastr.error(t('twitchBot.partError'));
+ }
+ }, [channel, t]);
+
+ return <>
+ <Row className="mb-4">
+ <Form.Group as={Col} md={6}>
+ <Form.Label>{t('twitchBot.channel')}</Form.Label>
+ <Form.Control
+ as={ChannelSelect}
+ joinable
+ manageable
+ onChange={({ channel }) => { setChannel(channel); }}
+ value={channel ? channel.id : ''}
+ />
+ </Form.Group>
+ {channel ?
+ <Form.Group as={Col} md={6}>
+ <Form.Label>{t('twitchBot.join')}</Form.Label>
+ <div>
+ <Form.Control
+ as={ToggleSwitch}
+ onChange={({ target: { value } }) => {
+ if (value) {
+ join();
+ } else {
+ part();
+ }
+ }}
+ value={channel.join}
+ />
+ </div>
+ </Form.Group>
+ : null}
+ </Row>
+ {channel ?
+ <Row>
+ <Form.Group as={Col} md={6}>
+ <Form.Label>{t('twitchBot.chat')}</Form.Label>
+ <Form.Control
+ as="textarea"
+ onChange={({ target: { value } }) => {
+ setChatText(value);
+ }}
+ value={chatText}
+ />
+ <Button
+ className="mt-2"
+ disabled={!chatText}
+ onClick={() => {
+ if (chatText) chat(chatText);
+ }}
+ variant="twitch"
+ >
+ {t('button.send')}
+ </Button>
+ </Form.Group>
+ </Row>
+ :
+ <Alert variant="info">
+ {t('twitchBot.selectChannel')}
+ </Alert>
+ }
+ </>;
};
export default Controls;