Spaces:
Running
Running
Update script.js
Browse files
script.js
CHANGED
@@ -1,55 +1,61 @@
|
|
1 |
document.addEventListener("DOMContentLoaded", () => {
|
2 |
const workerUrl = "https://ctmresearchagent.aiagents.workers.dev";
|
3 |
|
4 |
-
// Event Listeners
|
5 |
document.getElementById("uploadForm").addEventListener("submit", handleReportUpload);
|
6 |
document.getElementById("submitButton").addEventListener("click", handleAiQuerySubmit);
|
7 |
-
|
8 |
-
// NEW: Event listener for opening the modal
|
9 |
document.getElementById("reportsList").addEventListener("click", handleViewReportClick);
|
10 |
|
11 |
-
// NEW: Event
|
|
|
|
|
|
|
12 |
const modal = document.getElementById('reportModal');
|
13 |
document.querySelector('.modal-close-button').addEventListener('click', () => { modal.style.display = 'none'; });
|
14 |
window.addEventListener('click', (event) => { if (event.target == modal) { modal.style.display = 'none'; }});
|
15 |
|
16 |
-
// Initial data load
|
17 |
loadReportsList();
|
18 |
loadResearchHistory();
|
19 |
|
20 |
/**
|
21 |
-
* NEW:
|
22 |
*/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
23 |
async function handleViewReportClick(event) {
|
24 |
if (event.target.classList.contains('view-report-btn')) {
|
25 |
const docId = event.target.dataset.id;
|
26 |
-
const modal = document.getElementById('reportModal');
|
27 |
const modalTitle = document.getElementById('modalTitle');
|
28 |
const modalBody = document.getElementById('modalBody');
|
29 |
-
|
30 |
-
// Show loading state
|
31 |
modalTitle.textContent = "Loading Report...";
|
32 |
modalBody.textContent = "";
|
33 |
-
modal.style.display = 'block';
|
34 |
-
|
35 |
try {
|
36 |
const response = await fetch(`${workerUrl}/api/document/${docId}`);
|
37 |
if (!response.ok) throw new Error('Document not found.');
|
38 |
const doc = await response.json();
|
39 |
-
|
40 |
modalTitle.textContent = doc.title;
|
41 |
modalBody.textContent = doc.body;
|
42 |
-
|
43 |
} catch(error) {
|
44 |
modalTitle.textContent = "Error";
|
45 |
modalBody.textContent = error.message;
|
46 |
}
|
47 |
}
|
48 |
}
|
49 |
-
|
50 |
-
/**
|
51 |
-
* REVISED: Adds a "View" button for each report
|
52 |
-
*/
|
53 |
async function loadReportsList() {
|
54 |
const reportsList = document.getElementById("reportsList");
|
55 |
reportsList.innerHTML = "<p>Fetching reports...</p>";
|
@@ -57,21 +63,12 @@ document.addEventListener("DOMContentLoaded", () => {
|
|
57 |
const response = await fetch(`${workerUrl}/api/documents`);
|
58 |
if (!response.ok) throw new Error('Failed to fetch reports list.');
|
59 |
const documents = await response.json();
|
60 |
-
|
61 |
reportsList.innerHTML = "";
|
62 |
if (documents.length === 0) { reportsList.innerHTML = "<p>No reports have been added yet.</p>"; return; }
|
63 |
-
|
64 |
documents.forEach(doc => {
|
65 |
const entryDiv = document.createElement("div");
|
66 |
entryDiv.className = "report-entry";
|
67 |
-
|
68 |
-
entryDiv.innerHTML = `
|
69 |
-
<div>
|
70 |
-
<h3>${doc.title}</h3>
|
71 |
-
<p>${doc.description}</p>
|
72 |
-
</div>
|
73 |
-
<button class="view-report-btn" data-id="${doc.id}">View</button>
|
74 |
-
`;
|
75 |
reportsList.appendChild(entryDiv);
|
76 |
});
|
77 |
} catch (error) {
|
@@ -79,7 +76,6 @@ document.addEventListener("DOMContentLoaded", () => {
|
|
79 |
}
|
80 |
}
|
81 |
|
82 |
-
// --- All other functions (handleReportUpload, handleAiQuerySubmit, loadResearchHistory) are unchanged ---
|
83 |
async function handleReportUpload(event) { event.preventDefault(); const uploadButton = document.getElementById("uploadButton"); const uploadStatus = document.getElementById("uploadStatus"); const report = { title: document.getElementById('reportTitle').value, description: document.getElementById('reportDescription').value, body: document.getElementById('reportBody').value, }; if (!report.title || !report.description || !report.body) { uploadStatus.textContent = 'Please fill out all fields.'; return; } uploadButton.disabled = true; uploadButton.innerText = "Processing..."; uploadStatus.textContent = "Submitting report..."; try { const response = await fetch(`${workerUrl}/api/upload`, { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify(report), }); const data = await response.json(); if (!response.ok) throw new Error(data.error || 'Failed to process report.'); uploadStatus.textContent = `Success: ${data.message}`; document.getElementById("uploadForm").reset(); await loadReportsList(); } catch (error) { uploadStatus.textContent = `Error: ${error.message}`; } finally { uploadButton.disabled = false; uploadButton.innerText = "Process and Add Report"; } }
|
84 |
async function handleAiQuerySubmit() { const researchQueryInput = document.getElementById("researchQuery"); const resultDisplay = document.getElementById("resultDisplay"); const submitButton = document.getElementById("submitButton"); const query = researchQueryInput.value.trim(); if (!query) { alert("Please enter a query."); return; } submitButton.disabled = true; submitButton.innerText = "Thinking..."; resultDisplay.innerHTML = "<p>Generating response...</p>"; try { const response = await fetch(`${workerUrl}/api/query`, { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify({ query: query }) }); const data = await response.json(); if (!response.ok) throw new Error(data.error || "An unknown error occurred."); resultDisplay.innerText = data.result; await loadResearchHistory(); } catch (error) { resultDisplay.innerText = `Error: ${error.message}`; } finally { submitButton.disabled = false; submitButton.innerText = "Submit"; } }
|
85 |
async function loadResearchHistory() { const historyContainer = document.getElementById("historyContainer"); try { const response = await fetch(`${workerUrl}/api/research`); if (!response.ok) throw new Error('Failed to load history.'); const logs = await response.json(); historyContainer.innerHTML = ""; if (logs.length === 0) { historyContainer.innerHTML = "<p>No research history found.</p>"; return; } logs.forEach(log => { const entryDiv = document.createElement("div"); entryDiv.className = "history-entry"; entryDiv.innerHTML = `<p><strong>Query:</strong> ${log.query}</p><p><strong>Result:</strong> ${log.result}</p><p><small><em>${new Date(log.timestamp).toLocaleString()}</em></small></p>`; historyContainer.appendChild(entryDiv); }); } catch (error) { historyContainer.innerHTML = "<p>Error loading research history.</p>"; } }
|
|
|
1 |
document.addEventListener("DOMContentLoaded", () => {
|
2 |
const workerUrl = "https://ctmresearchagent.aiagents.workers.dev";
|
3 |
|
4 |
+
// --- Event Listeners ---
|
5 |
document.getElementById("uploadForm").addEventListener("submit", handleReportUpload);
|
6 |
document.getElementById("submitButton").addEventListener("click", handleAiQuerySubmit);
|
|
|
|
|
7 |
document.getElementById("reportsList").addEventListener("click", handleViewReportClick);
|
8 |
|
9 |
+
// NEW: Event listener for collapsible reports section
|
10 |
+
document.querySelector(".collapsible-header").addEventListener("click", toggleReportsList);
|
11 |
+
|
12 |
+
// Modal close listeners
|
13 |
const modal = document.getElementById('reportModal');
|
14 |
document.querySelector('.modal-close-button').addEventListener('click', () => { modal.style.display = 'none'; });
|
15 |
window.addEventListener('click', (event) => { if (event.target == modal) { modal.style.display = 'none'; }});
|
16 |
|
17 |
+
// --- Initial data load ---
|
18 |
loadReportsList();
|
19 |
loadResearchHistory();
|
20 |
|
21 |
/**
|
22 |
+
* NEW: Toggles the visibility of the reports list
|
23 |
*/
|
24 |
+
function toggleReportsList() {
|
25 |
+
const reportsList = document.getElementById("reportsList");
|
26 |
+
const reportsToggle = document.getElementById("reportsToggle");
|
27 |
+
|
28 |
+
reportsList.classList.toggle("collapsed");
|
29 |
+
|
30 |
+
if (reportsList.classList.contains("collapsed")) {
|
31 |
+
reportsToggle.textContent = "+";
|
32 |
+
} else {
|
33 |
+
reportsToggle.textContent = "-";
|
34 |
+
}
|
35 |
+
}
|
36 |
+
|
37 |
+
// --- All other functions are unchanged ---
|
38 |
async function handleViewReportClick(event) {
|
39 |
if (event.target.classList.contains('view-report-btn')) {
|
40 |
const docId = event.target.dataset.id;
|
|
|
41 |
const modalTitle = document.getElementById('modalTitle');
|
42 |
const modalBody = document.getElementById('modalBody');
|
43 |
+
modal.style.display = 'block';
|
|
|
44 |
modalTitle.textContent = "Loading Report...";
|
45 |
modalBody.textContent = "";
|
|
|
|
|
46 |
try {
|
47 |
const response = await fetch(`${workerUrl}/api/document/${docId}`);
|
48 |
if (!response.ok) throw new Error('Document not found.');
|
49 |
const doc = await response.json();
|
|
|
50 |
modalTitle.textContent = doc.title;
|
51 |
modalBody.textContent = doc.body;
|
|
|
52 |
} catch(error) {
|
53 |
modalTitle.textContent = "Error";
|
54 |
modalBody.textContent = error.message;
|
55 |
}
|
56 |
}
|
57 |
}
|
58 |
+
|
|
|
|
|
|
|
59 |
async function loadReportsList() {
|
60 |
const reportsList = document.getElementById("reportsList");
|
61 |
reportsList.innerHTML = "<p>Fetching reports...</p>";
|
|
|
63 |
const response = await fetch(`${workerUrl}/api/documents`);
|
64 |
if (!response.ok) throw new Error('Failed to fetch reports list.');
|
65 |
const documents = await response.json();
|
|
|
66 |
reportsList.innerHTML = "";
|
67 |
if (documents.length === 0) { reportsList.innerHTML = "<p>No reports have been added yet.</p>"; return; }
|
|
|
68 |
documents.forEach(doc => {
|
69 |
const entryDiv = document.createElement("div");
|
70 |
entryDiv.className = "report-entry";
|
71 |
+
entryDiv.innerHTML = `<div><h3>${doc.title}</h3><p>${doc.description}</p></div><button class="view-report-btn" data-id="${doc.id}">View</button>`;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
72 |
reportsList.appendChild(entryDiv);
|
73 |
});
|
74 |
} catch (error) {
|
|
|
76 |
}
|
77 |
}
|
78 |
|
|
|
79 |
async function handleReportUpload(event) { event.preventDefault(); const uploadButton = document.getElementById("uploadButton"); const uploadStatus = document.getElementById("uploadStatus"); const report = { title: document.getElementById('reportTitle').value, description: document.getElementById('reportDescription').value, body: document.getElementById('reportBody').value, }; if (!report.title || !report.description || !report.body) { uploadStatus.textContent = 'Please fill out all fields.'; return; } uploadButton.disabled = true; uploadButton.innerText = "Processing..."; uploadStatus.textContent = "Submitting report..."; try { const response = await fetch(`${workerUrl}/api/upload`, { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify(report), }); const data = await response.json(); if (!response.ok) throw new Error(data.error || 'Failed to process report.'); uploadStatus.textContent = `Success: ${data.message}`; document.getElementById("uploadForm").reset(); await loadReportsList(); } catch (error) { uploadStatus.textContent = `Error: ${error.message}`; } finally { uploadButton.disabled = false; uploadButton.innerText = "Process and Add Report"; } }
|
80 |
async function handleAiQuerySubmit() { const researchQueryInput = document.getElementById("researchQuery"); const resultDisplay = document.getElementById("resultDisplay"); const submitButton = document.getElementById("submitButton"); const query = researchQueryInput.value.trim(); if (!query) { alert("Please enter a query."); return; } submitButton.disabled = true; submitButton.innerText = "Thinking..."; resultDisplay.innerHTML = "<p>Generating response...</p>"; try { const response = await fetch(`${workerUrl}/api/query`, { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify({ query: query }) }); const data = await response.json(); if (!response.ok) throw new Error(data.error || "An unknown error occurred."); resultDisplay.innerText = data.result; await loadResearchHistory(); } catch (error) { resultDisplay.innerText = `Error: ${error.message}`; } finally { submitButton.disabled = false; submitButton.innerText = "Submit"; } }
|
81 |
async function loadResearchHistory() { const historyContainer = document.getElementById("historyContainer"); try { const response = await fetch(`${workerUrl}/api/research`); if (!response.ok) throw new Error('Failed to load history.'); const logs = await response.json(); historyContainer.innerHTML = ""; if (logs.length === 0) { historyContainer.innerHTML = "<p>No research history found.</p>"; return; } logs.forEach(log => { const entryDiv = document.createElement("div"); entryDiv.className = "history-entry"; entryDiv.innerHTML = `<p><strong>Query:</strong> ${log.query}</p><p><strong>Result:</strong> ${log.result}</p><p><small><em>${new Date(log.timestamp).toLocaleString()}</em></small></p>`; historyContainer.appendChild(entryDiv); }); } catch (error) { historyContainer.innerHTML = "<p>Error loading research history.</p>"; } }
|