summaryrefslogtreecommitdiff
path: root/client/components/chatroom/_chat_room.jsx
diff options
context:
space:
mode:
authorLogan Hunt <loganhunt@simponic.xyz>2022-04-01 16:04:00 -0600
committerLogan Hunt <loganhunt@simponic.xyz>2022-04-01 16:04:00 -0600
commitdbb9eea25f80e7984a112409863be5191af5bf5e (patch)
treecca24e23afc5e7bb4b92a0582aaec48f6a08af72 /client/components/chatroom/_chat_room.jsx
parent1108970a6aeb98a2f113383c6437dd4d862dae10 (diff)
downloadlocchat-dbb9eea25f80e7984a112409863be5191af5bf5e.tar.gz
locchat-dbb9eea25f80e7984a112409863be5191af5bf5e.zip
Added way too much stuff
Diffstat (limited to 'client/components/chatroom/_chat_room.jsx')
-rw-r--r--client/components/chatroom/_chat_room.jsx32
1 files changed, 22 insertions, 10 deletions
diff --git a/client/components/chatroom/_chat_room.jsx b/client/components/chatroom/_chat_room.jsx
index e70715c..22fb399 100644
--- a/client/components/chatroom/_chat_room.jsx
+++ b/client/components/chatroom/_chat_room.jsx
@@ -1,6 +1,6 @@
import { useEffect, useState, useContext } from 'react';
import { ApiContext } from '../../utils/api_context';
-import { useMessages } from '../../utils/use_messages';
+import { useChat } from '../../utils/use_chat';
import { Link, useParams } from 'react-router-dom';
import { generateGruvboxFromString } from '../../utils/generate_gruvbox';
@@ -11,7 +11,7 @@ import { generateGruvboxFromString } from '../../utils/generate_gruvbox';
export const ChatRoom = () => {
const { id } = useParams();
const [chatRoom, setChatRoom] = useState('');
- const [messages, sendMessage] = useMessages(chatRoom);
+ const [connections, messages, sendMessage] = useChat(chatRoom);
const [message, setMessage] = useState('');
const [color, setColor] = useState(generateGruvboxFromString('placeholder'));
const [user, setUser] = useState({});
@@ -56,14 +56,26 @@ export const ChatRoom = () => {
<div style={{ textAlign: 'center' }}>
<h2>{chatRoom?.name || `Chat Room ${chatRoom?.id}`}</h2>
</div>
- <div id="chat" className="chat">
- <p>Welcome!</p>
- {messages.map((message) => (
- <div key={message.id} style={{ lineBreak: 'normal' }}>
- <span style={{ color: generateGruvboxFromString(message.userName) }}>{message.userName}: </span>
- <span>{message.content}</span>
- </div>
- ))}
+ <div className="chat-container">
+ <div id="chat" className="chat-box">
+ {messages.map((message) => (
+ <div key={message.id} style={{ lineBreak: 'normal' }}>
+ <span style={{ color: generateGruvboxFromString(message.userName) }}>{message.userName}: </span>
+ <span>{message.content}</span>
+ </div>
+ ))}
+ </div>
+ <div className="chat-connections">
+ <h1>Connected Users ({connections.length})</h1>
+ <hr />
+ <ul>
+ {connections.map((user) => (
+ <li key={user.id} style={{ color: generateGruvboxFromString(user.userName) }}>
+ {user.userName}
+ </li>
+ ))}
+ </ul>
+ </div>
</div>
<div>
<textarea