283 lines
9.2 KiB
JavaScript
283 lines
9.2 KiB
JavaScript
alert("Chookchat is currently in early development, expect bugs! Please don't try breaking the public server, do that with your own test server (read more in the Git repo). Thanks for trying Chookchat!")
|
|
|
|
const width = $(document).width();
|
|
|
|
if (width < 512) {
|
|
console.log("enlarging");
|
|
const loginDiv = document.getElementById('login');
|
|
if (loginDiv) {
|
|
console.log(loginDiv.style.width = `${width}px`);
|
|
console.log("enlarged?");
|
|
}
|
|
}
|
|
|
|
let ws;
|
|
let username;
|
|
let password;
|
|
let typingTimeout;
|
|
let typingPeople = new Array();
|
|
|
|
function resizeMessaging() {
|
|
const messagingDiv = document.getElementById('messaging');
|
|
if (messagingDiv) {
|
|
messagingDiv.style.width = `${window.innerWidth - 40}px`; // -40 for body margins
|
|
messagingDiv.style.height = `${window.innerHeight - 40}px`; // -40 for body margins
|
|
}
|
|
}
|
|
|
|
// Call it initially
|
|
resizeMessaging();
|
|
|
|
// Add resize listener to handle window resizing
|
|
window.addEventListener('resize', resizeMessaging);
|
|
|
|
function showConfig() {
|
|
const serverconfig = document.getElementById('serverconfig')
|
|
if (serverconfig) {
|
|
serverconfig.style.display = 'block';
|
|
}
|
|
}
|
|
|
|
function md5(string) {
|
|
return CryptoJS.MD5(string).toString();
|
|
}
|
|
|
|
function getUrl() {
|
|
const serverUrl = document.getElementById('serverUrl').value.trim();
|
|
const serverPort = document.getElementById('serverPort').value;
|
|
const useWss = document.getElementById('securityStatus').checked;
|
|
const protocol = useWss ? 'wss' : 'ws';
|
|
|
|
const cleanUrl = serverUrl.replace(/^(https?:\/\/|wss?:\/\/)/, '');
|
|
|
|
return `${protocol}://${cleanUrl}:${serverPort}/api/websocket`;
|
|
}
|
|
function getSignupUrl() {
|
|
const serverUrl = document.getElementById('serverUrl').value.trim();
|
|
const serverPort = document.getElementById('serverPort').value;
|
|
const useWss = document.getElementById('securityStatus').checked;
|
|
const protocol = useWss ? 'https' : 'http';
|
|
|
|
const cleanUrl = serverUrl.replace(/^(https?:\/\/|wss?:\/\/)/, '');
|
|
|
|
return `${protocol}://${cleanUrl}:${serverPort}/api/createaccount/`;
|
|
}
|
|
|
|
function connect() {
|
|
username = document.getElementById('username').value;
|
|
password = document.getElementById('password').value;
|
|
|
|
if (!username || !password) {
|
|
alert('Please enter a username and password');
|
|
return;
|
|
}
|
|
|
|
const wsUrl = getUrl();
|
|
if (ws) {
|
|
ws.close();
|
|
}
|
|
|
|
ws = new WebSocket(wsUrl);
|
|
|
|
var incorrectDetail = 0;
|
|
|
|
ws.onopen = () => {
|
|
if (typeof Notification !== "undefined") {
|
|
Notification.requestPermission();
|
|
}
|
|
console.log('Connected!');
|
|
document.getElementById('login').style.display = 'none';
|
|
document.getElementById('messaging').style.display = 'block';
|
|
const connectMessage = {
|
|
"type": "connect",
|
|
"username": username,
|
|
"token": md5(password),
|
|
"content": `${username} joined the room!`
|
|
}
|
|
ws.send(JSON.stringify(connectMessage));
|
|
console.log(typingPeople);
|
|
ws.onmessage = (event) => {
|
|
if (event.data === "ping") {
|
|
ws.send("pong");
|
|
return;
|
|
}
|
|
const message = JSON.parse(event.data);
|
|
if (message.type == "error") {
|
|
if (message.username == "system") {
|
|
if (message.content == "invalid-token") {
|
|
alert("Your password is incorrect! Please try putting in your password right.");
|
|
incorrectDetail = 1;
|
|
location.reload();
|
|
}
|
|
if (message.content == "unknown-account") {
|
|
alert("That username isn't on the server. Maybe try registering?");
|
|
incorrectDetail = 1;
|
|
location.reload();
|
|
}
|
|
if (message.content == "banned") {
|
|
alert("kiddo you're banned lol what did you do to get banned lmaooo");
|
|
incorrectDetail = 1;
|
|
location.reload();
|
|
}
|
|
}
|
|
}
|
|
if (message.type == "typing" && message.content == "1") {
|
|
console.log(`${message.username} is typing`);
|
|
if (username !== message.username && !typingPeople.includes(message.username)) {
|
|
typingPeople.push(message.username);
|
|
console.log(typingPeople);
|
|
updatePeopleTyping();
|
|
}
|
|
return;
|
|
}
|
|
if (message.type == "typing" && message.content == "0") {
|
|
console.log(`${message.username} is no longer typing`)
|
|
if (username !== message.username && typingPeople.includes(message.username)) {
|
|
const index = typingPeople.indexOf(message.username);
|
|
typingPeople.splice(index, 1);
|
|
console.log(typingPeople);
|
|
updatePeopleTyping();
|
|
}
|
|
return;
|
|
}
|
|
if (message.type == "users" && message.username == "system") {
|
|
usersDiv = document.getElementById("users");
|
|
if (usersDiv) {
|
|
usersDiv.textContent = `Online users: ${message.content}`
|
|
}
|
|
return;
|
|
}
|
|
const messagesDiv = document.getElementById('messagebox');
|
|
const messageElement = document.createElement('div');
|
|
if (messageElement) {
|
|
if (messagesDiv) {
|
|
messagesDiv.appendChild(messageElement);
|
|
messagesDiv.scrollTop = messagesDiv.scrollHeight;
|
|
messageElement.className = 'message';
|
|
messageElement.textContent = `${message.username}: ${message.content}` ;
|
|
}
|
|
}
|
|
if (document.hidden) {
|
|
const notifiction = new Notification("Chookchat", {body: messageElement.textContent});
|
|
}
|
|
};
|
|
}
|
|
ws.onclose = () => {
|
|
alert("Chookchat has disconnected :/ Refresh the page to try again");
|
|
}
|
|
}
|
|
|
|
function sendMessage() {
|
|
const messageInput = document.getElementById('messageInput');
|
|
const message = messageInput.value.trim();
|
|
|
|
const processedMessage = {
|
|
"type": "message",
|
|
"username": username,
|
|
"token": md5(password),
|
|
"content": message
|
|
}
|
|
|
|
if (processedMessage && ws && ws.readyState === WebSocket.OPEN) {
|
|
ws.send(JSON.stringify(processedMessage));
|
|
messageInput.value = '';
|
|
|
|
if (typingTimeout) {
|
|
clearTimeout(typingTimeout);
|
|
}
|
|
const stoppedTypingMessage = {
|
|
"type": "typing",
|
|
"username": username,
|
|
"token": md5(password),
|
|
"content": "0"
|
|
};
|
|
if (ws && ws.readyState === WebSocket.OPEN) {
|
|
ws.send(JSON.stringify(stoppedTypingMessage));
|
|
}
|
|
}
|
|
const processedMessage2 = {
|
|
"type": "typing",
|
|
"username": username,
|
|
"token": md5(password),
|
|
"content": "0"
|
|
}
|
|
if (processedMessage && ws && ws.readyState === WebSocket.OPEN) {
|
|
ws.send(JSON.stringify(processedMessage2));
|
|
}
|
|
}
|
|
|
|
document.getElementById('messageInput').addEventListener('keypress', (event) => {
|
|
if (event.key === 'Enter') {
|
|
sendMessage();
|
|
}
|
|
});
|
|
|
|
document.getElementById('password').addEventListener('keypress', (event) => {
|
|
if (event.key === 'Enter') {
|
|
connect();
|
|
}
|
|
});
|
|
|
|
function register() {
|
|
username = document.getElementById('username').value;
|
|
password = document.getElementById('password').value;
|
|
|
|
if (!username || !password) {
|
|
alert('Please enter a username and password');
|
|
return;
|
|
}
|
|
|
|
window.open(`${getSignupUrl()}username:{${username}}token:{${md5(password)}}`);
|
|
}
|
|
|
|
function sleep(ms) {
|
|
return new Promise(resolve => setTimeout(resolve, ms));
|
|
}
|
|
|
|
function startTypingIndicator() {
|
|
if (typingTimeout) {
|
|
clearTimeout(typingTimeout);
|
|
}
|
|
|
|
const typingMessage = {
|
|
"type": "typing",
|
|
"username": username,
|
|
"token": md5(password),
|
|
"content": "1"
|
|
};
|
|
|
|
if (ws && ws.readyState === WebSocket.OPEN) {
|
|
ws.send(JSON.stringify(typingMessage));
|
|
}
|
|
|
|
typingTimeout = setTimeout(() => {
|
|
const stoppedTypingMessage = {
|
|
"type": "typing",
|
|
"username": username,
|
|
"token": md5(password),
|
|
"content": "0"
|
|
};
|
|
|
|
if (ws && ws.readyState === WebSocket.OPEN) {
|
|
ws.send(JSON.stringify(stoppedTypingMessage));
|
|
}
|
|
}, 5000);
|
|
}
|
|
|
|
function updatePeopleTyping() {
|
|
const typingDiv = document.getElementById('typing');
|
|
if (typingDiv) {
|
|
if (typingPeople.length === 0) {
|
|
typingDiv.textContent = '';
|
|
} else if (typingPeople.length === 1) {
|
|
typingDiv.textContent = `${typingPeople[0]} is typing...`;
|
|
} else if (typingPeople.length === 2) {
|
|
typingDiv.textContent = `${typingPeople[0]} and ${typingPeople[1]} are typing...`;
|
|
} else {
|
|
typingDiv.textContent = `${typingPeople.length} people are typing...`;
|
|
}
|
|
}
|
|
}
|
|
|
|
document.getElementById('messageInput').addEventListener('input', startTypingIndicator);
|