agentdev-webui 1.1.2 → 1.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/package.json +1 -1
  2. package/public/js/app.js +35 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "agentdev-webui",
3
- "version": "1.1.2",
3
+ "version": "1.1.3",
4
4
  "description": "Multi-agent workflow dashboard for auto-ticket processing",
5
5
  "main": "server.js",
6
6
  "bin": {
package/public/js/app.js CHANGED
@@ -32,6 +32,8 @@ let projectsList = [];
32
32
  let lastAgentsList = [];
33
33
  let lastHistoryList = [];
34
34
  let lastTodosList = [];
35
+ // Track optimistic tickets that were just created but may not be in SSE data yet
36
+ const pendingOptimisticTickets = new Map(); // "repo:number" → { ticket, created }
35
37
 
36
38
  let firstProjectMode = false;
37
39
 
@@ -1018,6 +1020,26 @@ async function createTicket() {
1018
1020
  formStatus.innerHTML = 'Ticket <a href="' + data.url + '" target="_blank">#' + data.number + '</a> created and added to project!';
1019
1021
  formStatus.className = 'form-status visible success';
1020
1022
 
1023
+ // Optimistic injection: add ticket to board immediately so it doesn't
1024
+ // disappear when an SSE broadcast arrives before GitHub indexes it
1025
+ const optimisticTicket = {
1026
+ number: data.number,
1027
+ repo: data.repo || repo,
1028
+ title: title,
1029
+ body: body,
1030
+ state: 'OPEN',
1031
+ status: 'Todo',
1032
+ hasClaude: body.toLowerCase().includes('@claude'),
1033
+ project_id: currentProjectId || null,
1034
+ author: '',
1035
+ createdAt: new Date().toISOString(),
1036
+ comments: []
1037
+ };
1038
+ const optKey = (data.repo || repo) + ':' + data.number;
1039
+ pendingOptimisticTickets.set(optKey, { ticket: optimisticTicket, created: Date.now() });
1040
+ lastTodosList.push(optimisticTicket);
1041
+ updateTodoTickets(lastTodosList);
1042
+
1021
1043
  ticketDescription.value = '';
1022
1044
  setTimeout(closeCreateTicketModal, 2000);
1023
1045
  } else {
@@ -1488,6 +1510,19 @@ const STATUS_COLORS = { 'Todo': '#4ade80', 'In Progress': '#fbbf24', 'test': '#6
1488
1510
  const STATUS_ORDER = ['Todo', 'In Progress', 'test', 'Done'];
1489
1511
 
1490
1512
  function updateTodoTickets(list) {
1513
+ // Merge pending optimistic tickets into SSE data
1514
+ for (const [key, entry] of pendingOptimisticTickets) {
1515
+ const [repo, num] = key.split(':');
1516
+ const numInt = parseInt(num);
1517
+ if (list.some(t => t.repo === repo && t.number === numInt)) {
1518
+ pendingOptimisticTickets.delete(key); // Confirmed by server
1519
+ } else if (Date.now() - entry.created > 60000) {
1520
+ pendingOptimisticTickets.delete(key); // Expired after 60s
1521
+ } else {
1522
+ list.push(entry.ticket); // Keep optimistic ticket visible
1523
+ }
1524
+ }
1525
+
1491
1526
  // Store raw data for re-filtering
1492
1527
  lastTodosList = list;
1493
1528