horizonevent/src/App.js

135 lines
3.4 KiB
JavaScript
Raw Normal View History

2020-11-13 00:39:11 +00:00
import React from 'react';
import {
2020-11-13 01:49:05 +00:00
Heading, Text, Spinner, Link,
IconButton, StarIcon, Pane, TextInput,
ListItem, UnorderedList,
EditIcon, LockIcon, PhoneIcon, ApplicationIcon
2020-11-13 00:39:11 +00:00
} from 'evergreen-ui'
import './App.css';
2020-11-13 01:20:15 +00:00
const API_URL = 'https://api.jitsi.net/';
2020-11-13 00:39:11 +00:00
class Form extends React.Component {
constructor() {
super();
this.state = {};
this.handleSubmit = this.handleSubmit.bind(this);
}
2020-11-13 01:20:15 +00:00
async handleSubmit(event) {
2020-11-13 00:39:11 +00:00
event.preventDefault();
2020-11-13 00:44:57 +00:00
this.setState({
loading: true,
2020-11-13 01:32:43 +00:00
name: null
2020-11-13 00:44:57 +00:00
});
2020-11-13 00:39:11 +00:00
if (!event.target.checkValidity()) {
this.setState({
invalid: true,
displayErrors: true,
2020-11-13 00:44:57 +00:00
loading: false,
2020-11-13 00:39:11 +00:00
});
return;
}
const form = event.target;
const form_data = new FormData(form);
2020-11-13 01:20:15 +00:00
let name = form_data.get('meeting-name');
let [data_id, data_numbers] = await Promise.all([
fetch(`${API_URL}conferenceMapper?conference=${name}@conference.meet.jit.si`).then(res => res.json()),
fetch(`${API_URL}phoneNumberList?conference=${name}@conference.meet.jit.si`).then(res => res.json()),
])
console.log(data_id);
console.log(data_numbers);
this.setState({
invalid: false,
displayErrors: false,
name: name,
meetingid: data_id.id,
phone: data_numbers.numbers.UK,
loading: false,
2020-11-13 00:39:11 +00:00
})
}
render() {
2020-11-13 01:32:43 +00:00
const { name, meetingid, invalid, phone, loading, displayErrors } = this.state;
2020-11-13 00:39:11 +00:00
return (
<div>
<form
onSubmit={this.handleSubmit}
noValidate
className={displayErrors ? 'displayErrors' : ''}
>
<Heading size={700}>meeting name:</Heading>
<TextInput
height={60}
name="meeting-name"
placeholder="YourMeetingNameHere"
required
/>
2020-11-13 00:44:57 +00:00
{!loading && (
<IconButton icon={StarIcon} height={60} onClick={this.onClick}/>
)}
2020-11-13 00:39:11 +00:00
</form>
<div className="res-block">
{invalid && (
<Pane><Text>Form is not valid</Text></Pane>
)}
2020-11-13 00:44:57 +00:00
{loading && (
<Spinner marginX="auto" />
)}
2020-11-13 00:39:11 +00:00
{!invalid && name && (
2020-11-13 01:32:43 +00:00
<Pane className="center">
2020-11-13 01:49:05 +00:00
<h3>details for "{name}"</h3>
2020-11-13 01:32:43 +00:00
<UnorderedList size={500}>
2020-11-13 01:49:05 +00:00
<ListItem icon={EditIcon}>
Notes: <Link href="https://pad.riseup.net/p/{name}">https://pad.riseup.net/p/{name}</Link>
2020-11-13 01:32:43 +00:00
</ListItem>
2020-11-13 01:49:05 +00:00
<ListItem icon={ApplicationIcon}>
Computer / app: <Link href="https://meet.jit.si/{name}">https://meet.jit.si/{name}</Link>
2020-11-13 01:32:43 +00:00
</ListItem>
2020-11-13 01:49:05 +00:00
<ListItem icon={PhoneIcon}>
2020-11-13 01:32:43 +00:00
Phone: {phone}
</ListItem>
2020-11-13 01:49:05 +00:00
<ListItem icon={LockIcon}>
2020-11-13 01:32:43 +00:00
PIN: {meetingid}
</ListItem>
</UnorderedList>
2020-11-13 01:20:15 +00:00
</Pane>
2020-11-13 00:39:11 +00:00
)}
</div>
</div>
);
}
}
class App extends React.Component {
onClick = () => {
console.log("Foo");
};
render() {
return (
<Pane className="App" >
<Pane
className="Main"
>
2020-11-13 00:39:11 +00:00
<Form />
2020-11-13 01:49:05 +00:00
<Pane className="Meta">
horizonevent by @3wc. <Link href="https://git.autonomic.zone/3wordchant/horizonevent/">source</Link>
</Pane>
2020-11-13 00:39:11 +00:00
</Pane>
</Pane>
);
}
}
export default App;