2020-10-04 18:43:31 -07:00
|
|
|
import { h, Component } from '/js/web_modules/preact.js';
|
|
|
|
import htm from '/js/web_modules/htm.js';
|
2020-08-19 00:16:35 -07:00
|
|
|
const html = htm.bind(h);
|
|
|
|
|
2020-08-23 19:37:06 -07:00
|
|
|
import Chat from './components/chat/chat.js';
|
2020-08-23 19:06:58 -07:00
|
|
|
import Websocket from './utils/websocket.js';
|
2020-10-14 13:33:55 +02:00
|
|
|
import { getLocalStorage, generateUsername } from './utils/helpers.js';
|
|
|
|
import { KEY_USERNAME } from './utils/constants.js';
|
2020-08-13 01:28:25 -07:00
|
|
|
|
2020-08-14 04:19:19 -07:00
|
|
|
export default class StandaloneChat extends Component {
|
2020-08-13 01:28:25 -07:00
|
|
|
constructor(props, context) {
|
|
|
|
super(props, context);
|
|
|
|
|
|
|
|
this.state = {
|
2020-08-14 04:19:19 -07:00
|
|
|
websocket: new Websocket(),
|
2020-08-13 01:28:25 -07:00
|
|
|
chatEnabled: true, // always true for standalone chat
|
|
|
|
username: getLocalStorage(KEY_USERNAME) || generateUsername(),
|
|
|
|
};
|
|
|
|
|
2020-08-14 04:19:19 -07:00
|
|
|
this.websocket = null;
|
2020-08-13 01:28:25 -07:00
|
|
|
this.handleUsernameChange = this.handleUsernameChange.bind(this);
|
|
|
|
}
|
|
|
|
|
2020-10-14 13:33:55 +02:00
|
|
|
handleUsernameChange(newName) {
|
2020-08-13 01:28:25 -07:00
|
|
|
this.setState({
|
|
|
|
username: newName,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
render(props, state) {
|
2020-10-14 13:33:55 +02:00
|
|
|
const { username, websocket } = state;
|
2020-08-23 19:37:06 -07:00
|
|
|
return (
|
2020-08-19 00:16:35 -07:00
|
|
|
html`
|
|
|
|
<${Chat}
|
|
|
|
websocket=${websocket}
|
|
|
|
username=${username}
|
|
|
|
messagesOnly
|
|
|
|
/>
|
2020-08-23 19:37:06 -07:00
|
|
|
`
|
|
|
|
);
|
2020-08-13 01:28:25 -07:00
|
|
|
}
|
|
|
|
}
|