Compare commits
2 Commits
084cb02a11
...
aa70e42fdc
Author | SHA1 | Date | |
---|---|---|---|
|
aa70e42fdc | ||
|
c530a8d69c |
7
app.js
7
app.js
@ -1116,6 +1116,7 @@ function addMessage(name, message, avatar, topic) {
|
||||
|
||||
const messageText = document.createElement('div');
|
||||
messageText.classList.add('message-text');
|
||||
|
||||
messageText.innerHTML = message;
|
||||
|
||||
messageContent.appendChild(senderName);
|
||||
@ -1162,8 +1163,7 @@ async function sendMessage(e) {
|
||||
const timestamp = Date.now();
|
||||
|
||||
console.log("Sending message to current topic:", topic); // Add logging
|
||||
|
||||
if (message.startsWith('~')) {
|
||||
if (message.startsWith('>')) {
|
||||
await handleCommand(message, {
|
||||
eventEmitter,
|
||||
currentTopic: topic, // Pass the current topic as a string
|
||||
@ -1173,7 +1173,8 @@ async function sendMessage(e) {
|
||||
leaveRoom,
|
||||
createRoom,
|
||||
listFiles,
|
||||
deleteFile
|
||||
deleteFile,
|
||||
servePort
|
||||
});
|
||||
return;
|
||||
}
|
||||
|
65
commands.js
65
commands.js
@ -11,7 +11,7 @@ if (fs.existsSync(agentAvatarPath)) {
|
||||
}
|
||||
|
||||
export default async function handleCommand(command, context) {
|
||||
const { eventEmitter, currentTopic, clearMessages, addMessage, joinRoom, leaveRoom, createRoom, listFiles } = context;
|
||||
const { eventEmitter, currentTopic, clearMessages, addMessage, joinRoom, leaveRoom, createRoom, listFiles, deleteFile, servePort } = context;
|
||||
|
||||
console.log("Context received in handleCommand:", context); // Add logging
|
||||
|
||||
@ -23,39 +23,82 @@ export default async function handleCommand(command, context) {
|
||||
console.log("Current topic:", currentTopic); // Add logging to check the current topic
|
||||
|
||||
switch (cmd) {
|
||||
case '~clear':
|
||||
case '>clear':
|
||||
clearMessages(currentTopic);
|
||||
break;
|
||||
case '~ping':
|
||||
case '>ping':
|
||||
addMessage('LinkUp', 'pong', agentAvatar, currentTopic);
|
||||
break;
|
||||
case '~help':
|
||||
addMessage('LinkUp', 'Available commands:\n- ~clear\n- ~ping\n- ~help\n- ~join [topic]\n- ~leave\n- ~create [alias]\n- ~list-files', agentAvatar, currentTopic);
|
||||
case '>help':
|
||||
addMessage('LinkUp', 'Available commands:\n- >clear\n- >ping\n- >help\n- >join [topic]\n- >leave\n- >create [alias]\n- >list-files', agentAvatar, currentTopic);
|
||||
break;
|
||||
case '~join':
|
||||
case '>join':
|
||||
if (restArgs) {
|
||||
await joinRoom(currentTopic, restArgs);
|
||||
} else {
|
||||
addMessage('LinkUp', 'Usage: ~join [topic]', agentAvatar, currentTopic);
|
||||
addMessage('LinkUp', 'Usage: >join [topic]', agentAvatar, currentTopic);
|
||||
}
|
||||
break;
|
||||
case '~leave':
|
||||
case '>leave':
|
||||
leaveRoom(currentTopic);
|
||||
break;
|
||||
case '~create':
|
||||
case '>create':
|
||||
if (restArgs) {
|
||||
await createRoom(currentTopic, restArgs);
|
||||
} else {
|
||||
addMessage('LinkUp', 'Usage: ~create [alias]', agentAvatar, currentTopic);
|
||||
addMessage('LinkUp', 'Usage: >create [alias]', agentAvatar, currentTopic);
|
||||
}
|
||||
break;
|
||||
case '~list-files':
|
||||
case '>list-files':
|
||||
const files = await listFiles();
|
||||
const fileList = files.length > 0 ? files.map(file => `- ${file}`).join('\n') : 'No files available';
|
||||
addMessage('LinkUp', `Available files:\n${fileList}`, agentAvatar, currentTopic);
|
||||
|
||||
// Render the file list with delete buttons
|
||||
renderFileList(files, deleteFile, servePort);
|
||||
break;
|
||||
default:
|
||||
addMessage('LinkUp', `Unknown command: ${cmd}`, agentAvatar, currentTopic);
|
||||
console.log('Unknown command:', command);
|
||||
}
|
||||
}
|
||||
|
||||
function renderFileList(files, deleteFile, servePort) {
|
||||
const container = document.querySelector('#messages');
|
||||
if (!container) {
|
||||
console.error('Element #messages not found');
|
||||
return;
|
||||
}
|
||||
|
||||
const fileList = document.createElement('ul');
|
||||
|
||||
files.forEach(file => {
|
||||
const listItem = document.createElement('li');
|
||||
const fileButton = document.createElement('button');
|
||||
fileButton.textContent = file.trim();
|
||||
fileButton.onclick = () => downloadFile(file.trim(), servePort);
|
||||
|
||||
const deleteButton = document.createElement('button');
|
||||
deleteButton.textContent = 'Delete';
|
||||
deleteButton.onclick = async () => {
|
||||
await deleteFile(file);
|
||||
listItem.remove();
|
||||
};
|
||||
|
||||
listItem.appendChild(fileButton);
|
||||
listItem.appendChild(deleteButton);
|
||||
fileList.appendChild(listItem);
|
||||
});
|
||||
|
||||
container.appendChild(fileList);
|
||||
}
|
||||
|
||||
function downloadFile(filename, servePort) {
|
||||
const url = `http://localhost:${servePort}/files/${filename}`;
|
||||
const link = document.createElement('a');
|
||||
link.href = url;
|
||||
link.download = filename;
|
||||
document.body.appendChild(link);
|
||||
link.click();
|
||||
document.body.removeChild(link);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user