You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
42 lines
1.0 KiB
42 lines
1.0 KiB
import { h, Component } from '/js/web_modules/preact.js'; |
|
import htm from '/js/web_modules/htm.js'; |
|
const html = htm.bind(h); |
|
|
|
import Chat from './components/chat/chat.js'; |
|
import Websocket from './utils/websocket.js'; |
|
import { getLocalStorage, generateUsername } from './utils/helpers.js'; |
|
import { KEY_USERNAME } from './utils/constants.js'; |
|
|
|
export default class StandaloneChat extends Component { |
|
constructor(props, context) { |
|
super(props, context); |
|
|
|
this.state = { |
|
websocket: new Websocket(), |
|
chatEnabled: true, // always true for standalone chat |
|
username: getLocalStorage(KEY_USERNAME) || generateUsername(), |
|
}; |
|
|
|
this.websocket = null; |
|
this.handleUsernameChange = this.handleUsernameChange.bind(this); |
|
} |
|
|
|
handleUsernameChange(newName) { |
|
this.setState({ |
|
username: newName, |
|
}); |
|
} |
|
|
|
render(props, state) { |
|
const { username, websocket } = state; |
|
return ( |
|
html` |
|
<${Chat} |
|
websocket=${websocket} |
|
username=${username} |
|
messagesOnly |
|
/> |
|
` |
|
); |
|
} |
|
}
|
|
|