privateuserh commited on
Commit
237ccf3
·
verified ·
1 Parent(s): e277318

Update script.js

Browse files
Files changed (1) hide show
  1. script.js +24 -28
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 listeners for closing the modal
 
 
 
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: Checks if a "View" button was clicked and opens the report
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
- // Add the data-id attribute to the button
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>"; } }