cast-code 1.0.8 → 1.0.10
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.
- package/dist/modules/core/services/deep-agent.service.js +1 -1
- package/dist/modules/core/services/deep-agent.service.js.map +1 -1
- package/dist/modules/git/services/commit-generator.service.js +432 -114
- package/dist/modules/git/services/commit-generator.service.js.map +1 -1
- package/dist/modules/kanban/kanban.module.js +36 -0
- package/dist/modules/kanban/kanban.module.js.map +1 -0
- package/dist/modules/kanban/services/kanban-server.service.js +322 -0
- package/dist/modules/kanban/services/kanban-server.service.js.map +1 -0
- package/dist/modules/kanban/views/kanban-ui.js +858 -0
- package/dist/modules/kanban/views/kanban-ui.js.map +1 -0
- package/dist/modules/repl/repl.module.js +3 -1
- package/dist/modules/repl/repl.module.js.map +1 -1
- package/dist/modules/repl/services/repl.service.js +13 -2
- package/dist/modules/repl/services/repl.service.js.map +1 -1
- package/dist/modules/tasks/services/plan-executor.service.js +2 -2
- package/dist/modules/tasks/services/plan-executor.service.js.map +1 -1
- package/dist/modules/tasks/services/task-management.service.js +35 -2
- package/dist/modules/tasks/services/task-management.service.js.map +1 -1
- package/dist/modules/tasks/types/task.types.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/modules/kanban/views/kanban-ui.ts"],"sourcesContent":["export function getKanbanHtml(): string {\n return `<!DOCTYPE html>\n<html lang=\"en\">\n<head>\n<meta charset=\"UTF-8\">\n<meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n<title>cast · kanban</title>\n<style>\n * { box-sizing: border-box; margin: 0; padding: 0; }\n\n :root {\n --bg: #0d1117;\n --surface: #161b22;\n --card: #21262d;\n --border: #30363d;\n --border-hover: #484f58;\n --text: #e6edf3;\n --muted: #7d8590;\n --cyan: #58a6ff;\n --green: #3fb950;\n --yellow: #d29922;\n --red: #f85149;\n --orange: #e3b341;\n --purple: #bc8cff;\n }\n\n body {\n background: var(--bg);\n color: var(--text);\n font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;\n font-size: 13px;\n height: 100vh;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n }\n\n header {\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 12px 20px;\n border-bottom: 1px solid var(--border);\n background: var(--surface);\n flex-shrink: 0;\n }\n\n .logo {\n font-weight: 700;\n font-size: 14px;\n color: var(--cyan);\n letter-spacing: 0.05em;\n }\n\n .logo span {\n color: var(--muted);\n font-weight: 400;\n }\n\n .live-dot {\n width: 7px;\n height: 7px;\n border-radius: 50%;\n background: var(--green);\n box-shadow: 0 0 6px var(--green);\n animation: pulse 2s infinite;\n }\n\n .live-dot.disconnected {\n background: var(--red);\n box-shadow: 0 0 6px var(--red);\n animation: none;\n }\n\n @keyframes pulse {\n 0%, 100% { opacity: 1; }\n 50% { opacity: 0.4; }\n }\n\n .header-right {\n margin-left: auto;\n display: flex;\n align-items: center;\n gap: 16px;\n }\n\n .btn-primary {\n background: var(--cyan);\n color: var(--bg);\n border: none;\n padding: 6px 12px;\n border-radius: 4px;\n font-size: 12px;\n font-weight: 700;\n cursor: pointer;\n transition: opacity 0.2s;\n }\n\n .btn-primary:hover {\n opacity: 0.9;\n }\n\n .btn-primary:disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n .task-count {\n color: var(--muted);\n font-size: 12px;\n }\n\n .plan-badge {\n background: rgba(88, 166, 255, 0.1);\n border: 1px solid rgba(88, 166, 255, 0.3);\n color: var(--cyan);\n padding: 2px 8px;\n border-radius: 4px;\n font-size: 11px;\n }\n\n /* Modal */\n .modal-overlay {\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: rgba(0, 0, 0, 0.7);\n display: none;\n align-items: center;\n justify-content: center;\n z-index: 1000;\n backdrop-filter: blur(2px);\n }\n\n .modal {\n background: var(--surface);\n border: 1px solid var(--border);\n border-radius: 8px;\n width: 100%;\n max-width: 450px;\n padding: 24px;\n box-shadow: 0 10px 25px rgba(0,0,0,0.5);\n }\n\n .modal-title {\n font-size: 16px;\n font-weight: 700;\n margin-bottom: 20px;\n color: var(--cyan);\n }\n\n .form-group {\n margin-bottom: 16px;\n }\n\n .form-group label {\n display: block;\n font-size: 11px;\n color: var(--muted);\n text-transform: uppercase;\n margin-bottom: 6px;\n font-weight: 600;\n }\n\n .form-group input, .form-group textarea {\n width: 100%;\n background: var(--bg);\n border: 1px solid var(--border);\n border-radius: 4px;\n color: var(--text);\n padding: 8px 12px;\n font-family: inherit;\n font-size: 13px;\n outline: none;\n }\n\n .form-group input:focus, .form-group textarea:focus {\n border-color: var(--cyan);\n }\n\n .modal-actions {\n display: flex;\n justify-content: flex-end;\n gap: 12px;\n margin-top: 24px;\n }\n\n .btn-ghost {\n background: transparent;\n color: var(--muted);\n border: 1px solid var(--border);\n padding: 6px 12px;\n border-radius: 4px;\n font-size: 12px;\n cursor: pointer;\n }\n\n .btn-ghost:hover {\n border-color: var(--border-hover);\n color: var(--text);\n }\n\n .board {\n display: grid;\n grid-template-columns: repeat(4, 1fr);\n gap: 12px;\n padding: 16px;\n flex: 1;\n overflow: hidden;\n min-height: 0;\n }\n\n .column {\n background: var(--surface);\n border: 1px solid var(--border);\n border-radius: 8px;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n transition: background 0.2s;\n }\n\n .column.drag-over {\n background: rgba(88, 166, 255, 0.05);\n border-color: var(--cyan);\n }\n\n .column-header {\n padding: 10px 14px;\n border-bottom: 1px solid var(--border);\n display: flex;\n align-items: center;\n gap: 8px;\n flex-shrink: 0;\n }\n\n .column-label {\n font-size: 11px;\n font-weight: 700;\n text-transform: uppercase;\n letter-spacing: 0.08em;\n }\n\n .col-pending .column-label { color: var(--muted); }\n .col-inprogress .column-label { color: var(--orange); }\n .col-done .column-label { color: var(--green); }\n .col-failed .column-label { color: var(--red); }\n\n .col-inprogress { border-top: 2px solid var(--orange); }\n .col-done { border-top: 2px solid var(--green); }\n .col-failed { border-top: 2px solid var(--red); }\n .col-pending { border-top: 2px solid var(--border); }\n\n .column-count {\n margin-left: auto;\n background: var(--card);\n border: 1px solid var(--border);\n border-radius: 10px;\n padding: 1px 7px;\n font-size: 11px;\n color: var(--muted);\n min-width: 22px;\n text-align: center;\n }\n\n .cards {\n flex: 1;\n overflow-y: auto;\n padding: 10px;\n display: flex;\n flex-direction: column;\n gap: 8px;\n min-height: 50px;\n }\n\n .cards::-webkit-scrollbar { width: 4px; }\n .cards::-webkit-scrollbar-track { background: transparent; }\n .cards::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }\n\n .card {\n background: var(--card);\n border: 1px solid var(--border);\n border-radius: 6px;\n padding: 10px 12px;\n cursor: grab;\n transition: border-color 0.15s, transform 0.15s;\n animation: cardIn 0.2s ease-out;\n position: relative;\n }\n\n .card:active {\n cursor: grabbing;\n }\n\n .card.dragging {\n opacity: 0.4;\n transform: scale(0.95);\n }\n\n @keyframes cardIn {\n from { opacity: 0; transform: translateY(-4px); }\n to { opacity: 1; transform: translateY(0); }\n }\n\n .card:hover {\n border-color: var(--border-hover);\n }\n\n .card:hover .card-actions {\n opacity: 1;\n }\n\n .card-actions {\n position: absolute;\n top: 8px;\n right: 8px;\n opacity: 0;\n transition: opacity 0.2s;\n }\n\n .btn-mini {\n background: var(--bg);\n border: 1px solid var(--border);\n color: var(--cyan);\n border-radius: 3px;\n padding: 2px 6px;\n font-size: 9px;\n font-weight: 700;\n cursor: pointer;\n text-transform: uppercase;\n }\n\n .btn-mini:hover {\n border-color: var(--cyan);\n }\n\n .btn-mini:disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n .card.highlight {\n animation: highlight 0.6s ease-out;\n }\n\n @keyframes highlight {\n 0% { border-color: var(--cyan); box-shadow: 0 0 8px rgba(88, 166, 255, 0.3); }\n 100% { border-color: var(--border); box-shadow: none; }\n }\n\n .card-top {\n display: flex;\n align-items: flex-start;\n gap: 8px;\n margin-bottom: 6px;\n padding-right: 40px;\n }\n\n .card-id {\n color: var(--muted);\n font-size: 10px;\n flex-shrink: 0;\n margin-top: 2px;\n }\n\n .card-subject {\n font-weight: 600;\n font-size: 12px;\n line-height: 1.4;\n flex: 1;\n word-break: break-word;\n }\n\n .card-description {\n color: var(--muted);\n font-size: 11px;\n line-height: 1.5;\n margin-bottom: 8px;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n overflow: hidden;\n }\n\n .card-footer {\n display: flex;\n flex-wrap: wrap;\n align-items: center;\n gap: 5px;\n }\n\n .badge {\n padding: 2px 6px;\n border-radius: 3px;\n font-size: 10px;\n font-weight: 600;\n text-transform: uppercase;\n letter-spacing: 0.04em;\n }\n\n .badge-pending { background: rgba(125, 133, 144, 0.15); color: var(--muted); }\n .badge-in_progress { background: rgba(227, 179, 65, 0.15); color: var(--orange); }\n .badge-completed { background: rgba(63, 185, 80, 0.15); color: var(--green); }\n .badge-failed { background: rgba(248, 81, 73, 0.15); color: var(--red); }\n .badge-blocked { background: rgba(210, 153, 34, 0.15); color: var(--yellow); }\n .badge-cancelled { background: rgba(125, 133, 144, 0.1); color: var(--muted); }\n\n .badge-agent {\n background: rgba(188, 140, 255, 0.12);\n color: var(--purple);\n border: 1px solid rgba(188, 140, 255, 0.2);\n font-weight: 400;\n text-transform: none;\n letter-spacing: 0;\n }\n\n .badge-dep {\n background: rgba(88, 166, 255, 0.08);\n color: rgba(88, 166, 255, 0.6);\n border: 1px solid rgba(88, 166, 255, 0.15);\n font-weight: 400;\n text-transform: none;\n letter-spacing: 0;\n }\n\n .spinner {\n display: inline-block;\n width: 10px;\n height: 10px;\n border: 1.5px solid rgba(227, 179, 65, 0.2);\n border-top-color: var(--orange);\n border-radius: 50%;\n animation: spin 0.8s linear infinite;\n flex-shrink: 0;\n }\n\n @keyframes spin {\n to { transform: rotate(360deg); }\n }\n\n .empty-state {\n flex: 1;\n display: flex;\n align-items: center;\n justify-content: center;\n color: var(--border);\n font-size: 11px;\n padding: 20px;\n text-align: center;\n }\n\n .thinking-indicator {\n color: var(--purple);\n font-size: 11px;\n display: flex;\n align-items: center;\n gap: 6px;\n }\n</style>\n</head>\n<body>\n\n<header>\n <div class=\"logo\">cast <span>·</span> kanban</div>\n <div class=\"live-dot\" id=\"liveDot\"></div>\n <div id=\"header-right-container\" class=\"header-right\">\n <button class=\"btn-primary\" onclick=\"showModal()\">+ New Task</button>\n <span class=\"task-count\" id=\"taskCount\">0 tasks</span>\n <span class=\"plan-badge\" id=\"planBadge\" style=\"display:none\"></span>\n </div>\n</header>\n\n<div class=\"board\">\n <div class=\"column col-pending\" id=\"col-pending\" ondragover=\"handleDragOver(event)\" ondragleave=\"handleDragLeave(event)\" ondrop=\"handleDrop(event, 'pending')\">\n <div class=\"column-header\">\n <span class=\"column-label\">To-Do</span>\n <button id=\"btn-auto-planner\" class=\"btn-mini\" style=\"margin-left: 10px; border-color: var(--purple); color: var(--purple);\" onclick=\"runAutoPlanner()\">⚡ Run</button>\n <span class=\"column-count\" id=\"count-pending\">0</span>\n </div>\n <div class=\"cards\" id=\"cards-pending\"></div>\n </div>\n <div class=\"column col-inprogress\" id=\"col-inprogress\" ondragover=\"handleDragOver(event)\" ondragleave=\"handleDragLeave(event)\" ondrop=\"handleDrop(event, 'in_progress')\">\n <div class=\"column-header\">\n <span class=\"column-label\">In Progress</span>\n <span class=\"column-count\" id=\"count-inprogress\">0</span>\n </div>\n <div class=\"cards\" id=\"cards-inprogress\"></div>\n </div>\n <div class=\"column col-done\" id=\"col-done\" ondragover=\"handleDragOver(event)\" ondragleave=\"handleDragLeave(event)\" ondrop=\"handleDrop(event, 'completed')\">\n <div class=\"column-header\">\n <span class=\"column-label\">Done</span>\n <span class=\"column-count\" id=\"count-done\">0</span>\n </div>\n <div class=\"cards\" id=\"cards-done\"></div>\n </div>\n <div class=\"column col-failed\" id=\"col-failed\" ondragover=\"handleDragOver(event)\" ondragleave=\"handleDragLeave(event)\" ondrop=\"handleDrop(event, 'failed')\">\n <div class=\"column-header\">\n <span class=\"column-label\">Failed / Blocked</span>\n <span class=\"column-count\" id=\"count-failed\">0</span>\n </div>\n <div class=\"cards\" id=\"cards-failed\"></div>\n </div>\n</div>\n\n<div class=\"modal-overlay\" id=\"modalOverlay\">\n <div class=\"modal\">\n <div class=\"modal-title\">Create New Task</div>\n <div class=\"form-group\">\n <label>Subject</label>\n <input type=\"text\" id=\"taskSubject\" placeholder=\"What needs to be done?\">\n </div>\n <div class=\"form-group\">\n <label>Description (Optional)</label>\n <textarea id=\"taskDescription\" rows=\"3\" placeholder=\"Add more details...\"></textarea>\n </div>\n <div class=\"modal-actions\">\n <button class=\"btn-ghost\" onclick=\"hideModal()\">Cancel</button>\n <button class=\"btn-primary\" onclick=\"createTask()\">Create Task</button>\n </div>\n </div>\n</div>\n\n<script>\n const COL_MAP = {\n pending: 'pending',\n in_progress: 'inprogress',\n completed: 'done',\n failed: 'failed',\n blocked: 'failed',\n cancelled: 'failed',\n };\n\n let tasks = {};\n let sseRetryTimer = null;\n let isAutoPlanning = false;\n\n // Drag and Drop State\n let draggedTaskId = null;\n\n function handleDragStart(e, taskId) {\n draggedTaskId = taskId;\n e.target.classList.add('dragging');\n e.dataTransfer.setData('text/plain', taskId);\n e.dataTransfer.effectAllowed = 'move';\n }\n\n function handleDragEnd(e) {\n e.target.classList.remove('dragging');\n draggedTaskId = null;\n }\n\n function handleDragOver(e) {\n e.preventDefault();\n e.currentTarget.classList.add('drag-over');\n e.dataTransfer.dropEffect = 'move';\n }\n\n function handleDragLeave(e) {\n e.currentTarget.classList.remove('drag-over');\n }\n\n async function handleDrop(e, targetStatus) {\n e.preventDefault();\n e.currentTarget.classList.remove('drag-over');\n \n const taskId = e.dataTransfer.getData('text/plain');\n const task = tasks[taskId];\n \n if (!task || task.status === targetStatus) return;\n\n // Rules\n if (task.status === 'completed' && targetStatus === 'in_progress') {\n const reason = prompt(\\`Why are you redoing task \"\\${task.subject}\"?\\`);\n if (!reason) return;\n \n await updateTask(taskId, { \n status: targetStatus,\n metadata: { ...task.metadata, redoReason: reason, redoneAt: Date.now() }\n });\n } else {\n await updateTask(taskId, { status: targetStatus });\n }\n }\n\n async function runAutoPlanner() {\n if (isAutoPlanning) return;\n isAutoPlanning = true;\n renderHeaderRight();\n document.getElementById('btn-auto-planner').disabled = true;\n\n try {\n await fetch('/api/tasks/auto-execute', { method: 'POST' });\n } catch (err) {\n console.error('Failed to start auto-planner:', err);\n isAutoPlanning = false;\n renderHeaderRight();\n document.getElementById('btn-auto-planner').disabled = false;\n }\n }\n\n function renderHeaderRight() {\n const container = document.getElementById('header-right-container');\n const thinking = isAutoPlanning ? '<span class=\"thinking-indicator\"><div class=\"spinner\" style=\"border-top-color:var(--purple)\"></div> Auto-Planner thinking...</span>' : '';\n \n container.innerHTML = \\`\n \\${thinking}\n <button class=\"btn-primary\" onclick=\"showModal()\">+ New Task</button>\n <span class=\"task-count\" id=\"taskCount\">\\${Object.keys(tasks).length} tasks</span>\n <span class=\"plan-badge\" id=\"planBadge\" style=\"display:none\"></span>\n \\`;\n }\n\n function showModal() {\n document.getElementById('modalOverlay').style.display = 'flex';\n document.getElementById('taskSubject').focus();\n }\n\n function hideModal() {\n document.getElementById('modalOverlay').style.display = 'none';\n document.getElementById('taskSubject').value = '';\n document.getElementById('taskDescription').value = '';\n }\n\n async function createTask() {\n const subject = document.getElementById('taskSubject').value.trim();\n const description = document.getElementById('taskDescription').value.trim();\n\n if (!subject) return;\n\n try {\n const res = await fetch('/api/tasks', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ subject, description })\n });\n \n if (res.ok) {\n hideModal();\n }\n } catch (err) {\n console.error('Failed to create task:', err);\n }\n }\n\n async function updateTask(taskId, updates) {\n try {\n await fetch(\\`/api/tasks/\\${taskId}\\`, {\n method: 'PATCH',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(updates)\n });\n } catch (err) {\n console.error('Failed to update task:', err);\n }\n }\n\n async function executeTask(taskId) {\n try {\n await fetch(\\`/api/tasks/\\${taskId}/execute\\`, { method: 'POST' });\n } catch (err) {\n console.error('Failed to execute task:', err);\n }\n }\n\n function col(status) {\n return COL_MAP[status] || 'pending';\n }\n\n function makeCard(task) {\n const colKey = col(task.status);\n const isInProgress = task.status === 'in_progress';\n const isPending = task.status === 'pending';\n\n const depBadges = task.dependencies.length > 0\n ? task.dependencies.map(d => '<span class=\"badge badge-dep\">↳ ' + d + '</span>').join('')\n : '';\n\n const agentBadge = task.assignedAgent\n ? '<span class=\"badge badge-agent\">⬡ ' + task.assignedAgent + '</span>'\n : '';\n\n const spinner = isInProgress ? '<div class=\"spinner\"></div>' : '';\n \n const actionBtn = isPending \n ? \\`<div class=\"card-actions\"><button class=\"btn-mini\" onclick=\"executeTask('\\${task.id}')\">Run</button></div>\\` \n : '';\n\n return \\`\n <div class=\"card\" \n id=\"card-\\${task.id}\" \n data-status=\"\\${task.status}\" \n draggable=\"true\" \n onsubmit=\"return false;\"\n ondragstart=\"handleDragStart(event, '\\${task.id}')\"\n ondragend=\"handleDragEnd(event)\">\n \\${actionBtn}\n <div class=\"card-top\">\n \\${spinner}\n <span class=\"card-id\">\\${task.id}</span>\n <span class=\"card-subject\">\\${escHtml(task.subject)}</span>\n </div>\n \\${task.description ? '<div class=\"card-description\">' + escHtml(task.description) + '</div>' : ''}\n <div class=\"card-footer\">\n <span class=\"badge badge-\\${task.status}\">\\${task.status.replace('_', ' ')}</span>\n \\${agentBadge}\n \\${depBadges}\n </div>\n </div>\n \\`;\n }\n\n function escHtml(str) {\n return str.replace(/&/g,'&').replace(/</g,'<').replace(/>/g,'>').replace(/\"/g,'"');\n }\n\n function renderAll() {\n const cols = { pending: [], inprogress: [], done: [], failed: [] };\n\n for (const task of Object.values(tasks)) {\n cols[col(task.status)].push(task);\n }\n\n for (const [key, list] of Object.entries(cols)) {\n const container = document.getElementById('cards-' + key);\n const count = document.getElementById('count-' + key);\n\n if (list.length === 0) {\n container.innerHTML = '<div class=\"empty-state\">—</div>';\n } else {\n container.innerHTML = list.map(makeCard).join('');\n }\n count.textContent = list.length;\n }\n\n renderHeaderRight();\n }\n\n function upsertTask(task) {\n const existed = !!tasks[task.id];\n tasks[task.id] = task;\n\n if (task.status === 'in_progress' || task.status === 'completed') {\n // If we get an update that is progress, stop showing auto-planner thinking\n if (isAutoPlanning) {\n isAutoPlanning = false;\n renderHeaderRight();\n document.getElementById('btn-auto-planner').disabled = false;\n }\n }\n\n if (existed) {\n const card = document.getElementById('card-' + task.id);\n const newColKey = col(task.status);\n\n if (card) {\n const currentContainer = card.parentElement;\n const targetContainer = document.getElementById('cards-' + newColKey);\n\n if (currentContainer !== targetContainer) {\n renderAll();\n } else {\n card.outerHTML = makeCard(task);\n const updated = document.getElementById('card-' + task.id);\n if (updated) {\n updated.classList.add('highlight');\n setTimeout(() => updated.classList.remove('highlight'), 700);\n }\n updateCounts();\n }\n } else {\n renderAll();\n }\n } else {\n renderAll();\n }\n }\n\n function updateCounts() {\n const cols = { pending: 0, inprogress: 0, done: 0, failed: 0 };\n for (const task of Object.values(tasks)) {\n cols[col(task.status)]++;\n }\n for (const [key, count] of Object.entries(cols)) {\n document.getElementById('count-' + key).textContent = count;\n }\n renderHeaderRight();\n }\n\n async function loadState() {\n try {\n const res = await fetch('/api/state');\n const data = await res.json();\n tasks = {};\n for (const t of data.tasks) tasks[t.id] = t;\n\n if (data.plans && data.plans.length > 0) {\n const plan = data.plans[data.plans.length - 1];\n const badge = document.getElementById('planBadge');\n badge.textContent = plan.title;\n badge.style.display = 'inline';\n }\n\n renderAll();\n } catch {}\n }\n\n function connectSSE() {\n const dot = document.getElementById('liveDot');\n const es = new EventSource('/api/events');\n\n es.onopen = () => {\n dot.classList.remove('disconnected');\n if (sseRetryTimer) { clearTimeout(sseRetryTimer); sseRetryTimer = null; }\n };\n\n es.addEventListener('task:created', e => {\n const task = JSON.parse(e.data);\n upsertTask(task);\n });\n\n es.addEventListener('task:updated', e => {\n const task = JSON.parse(e.data);\n upsertTask(task);\n });\n\n es.addEventListener('plan:created', e => {\n const plan = JSON.parse(e.data);\n const badge = document.getElementById('planBadge');\n badge.textContent = plan.title;\n badge.style.display = 'inline';\n });\n\n es.onerror = () => {\n dot.classList.add('disconnected');\n es.close();\n sseRetryTimer = setTimeout(connectSSE, 3000);\n };\n }\n\n loadState().then(connectSSE);\n</script>\n</body>\n</html>`;\n}\n"],"names":["getKanbanHtml"],"mappings":";;;;+BAAgBA;;;eAAAA;;;AAAT,SAASA;IACd,OAAO,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA20BH,CAAC;AACR"}
|
|
@@ -26,6 +26,7 @@ const _mcpmodule = require("../mcp/mcp.module");
|
|
|
26
26
|
const _projectmodule = require("../project/project.module");
|
|
27
27
|
const _memorymodule = require("../memory/memory.module");
|
|
28
28
|
const _config = require("../config");
|
|
29
|
+
const _kanbanmodule = require("../kanban/kanban.module");
|
|
29
30
|
function _ts_decorate(decorators, target, key, desc) {
|
|
30
31
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
31
32
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
@@ -45,7 +46,8 @@ ReplModule = _ts_decorate([
|
|
|
45
46
|
_skillsmodule.SkillsModule,
|
|
46
47
|
_mcpmodule.McpModule,
|
|
47
48
|
_projectmodule.ProjectModule,
|
|
48
|
-
_memorymodule.MemoryModule
|
|
49
|
+
_memorymodule.MemoryModule,
|
|
50
|
+
_kanbanmodule.KanbanModule
|
|
49
51
|
],
|
|
50
52
|
providers: [
|
|
51
53
|
_replservice.ReplService,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/modules/repl/repl.module.ts"],"sourcesContent":["import { Module } from '@nestjs/common';\nimport { ReplService } from './services/repl.service';\nimport { WelcomeScreenService } from './services/welcome-screen.service';\nimport { ReplCommandsService } from './services/commands/repl-commands.service';\nimport { GitCommandsService } from './services/commands/git-commands.service';\nimport { AgentCommandsService } from './services/commands/agent-commands.service';\nimport { McpCommandsService } from './services/commands/mcp-commands.service';\nimport { ConfigCommandsService } from '../config/services/config-commands.service';\nimport { ProjectCommandsService } from './services/commands/project-commands.service';\nimport { CoreModule } from '../core/core.module';\nimport { ToolsModule } from '../tools/tools.module';\nimport { GitModule } from '../git/git.module';\nimport { AgentsModule } from '../agents/agents.module';\nimport { SkillsModule } from '../skills/skills.module';\nimport { McpModule } from '../mcp/mcp.module';\nimport { ProjectModule } from '../project/project.module';\nimport { MemoryModule } from '../memory/memory.module';\nimport { ConfigModule } from '../config';\n\n@Module({\n imports: [ConfigModule, CoreModule, ToolsModule, GitModule, AgentsModule, SkillsModule, McpModule, ProjectModule, MemoryModule],\n providers: [\n ReplService,\n WelcomeScreenService,\n ReplCommandsService,\n GitCommandsService,\n AgentCommandsService,\n McpCommandsService,\n ConfigCommandsService,\n ProjectCommandsService,\n ],\n exports: [ReplService],\n})\nexport class ReplModule {}\n"],"names":["ReplModule","imports","ConfigModule","CoreModule","ToolsModule","GitModule","AgentsModule","SkillsModule","McpModule","ProjectModule","MemoryModule","providers","ReplService","WelcomeScreenService","ReplCommandsService","GitCommandsService","AgentCommandsService","McpCommandsService","ConfigCommandsService","ProjectCommandsService","exports"],"mappings":";;;;+
|
|
1
|
+
{"version":3,"sources":["../../../src/modules/repl/repl.module.ts"],"sourcesContent":["import { Module } from '@nestjs/common';\nimport { ReplService } from './services/repl.service';\nimport { WelcomeScreenService } from './services/welcome-screen.service';\nimport { ReplCommandsService } from './services/commands/repl-commands.service';\nimport { GitCommandsService } from './services/commands/git-commands.service';\nimport { AgentCommandsService } from './services/commands/agent-commands.service';\nimport { McpCommandsService } from './services/commands/mcp-commands.service';\nimport { ConfigCommandsService } from '../config/services/config-commands.service';\nimport { ProjectCommandsService } from './services/commands/project-commands.service';\nimport { CoreModule } from '../core/core.module';\nimport { ToolsModule } from '../tools/tools.module';\nimport { GitModule } from '../git/git.module';\nimport { AgentsModule } from '../agents/agents.module';\nimport { SkillsModule } from '../skills/skills.module';\nimport { McpModule } from '../mcp/mcp.module';\nimport { ProjectModule } from '../project/project.module';\nimport { MemoryModule } from '../memory/memory.module';\nimport { ConfigModule } from '../config';\nimport { KanbanModule } from '../kanban/kanban.module';\n\n@Module({\n imports: [ConfigModule, CoreModule, ToolsModule, GitModule, AgentsModule, SkillsModule, McpModule, ProjectModule, MemoryModule, KanbanModule],\n providers: [\n ReplService,\n WelcomeScreenService,\n ReplCommandsService,\n GitCommandsService,\n AgentCommandsService,\n McpCommandsService,\n ConfigCommandsService,\n ProjectCommandsService,\n ],\n exports: [ReplService],\n})\nexport class ReplModule {}\n"],"names":["ReplModule","imports","ConfigModule","CoreModule","ToolsModule","GitModule","AgentsModule","SkillsModule","McpModule","ProjectModule","MemoryModule","KanbanModule","providers","ReplService","WelcomeScreenService","ReplCommandsService","GitCommandsService","AgentCommandsService","McpCommandsService","ConfigCommandsService","ProjectCommandsService","exports"],"mappings":";;;;+BAkCaA;;;eAAAA;;;wBAlCU;6BACK;sCACS;qCACD;oCACD;sCACE;oCACF;uCACG;wCACC;4BACZ;6BACC;2BACF;8BACG;8BACA;2BACH;+BACI;8BACD;wBACA;8BACA;;;;;;;AAgBtB,IAAA,AAAMA,aAAN,MAAMA;AAAY;;;QAbvBC,SAAS;YAACC,oBAAY;YAAEC,sBAAU;YAAEC,wBAAW;YAAEC,oBAAS;YAAEC,0BAAY;YAAEC,0BAAY;YAAEC,oBAAS;YAAEC,4BAAa;YAAEC,0BAAY;YAAEC,0BAAY;SAAC;QAC7IC,WAAW;YACTC,wBAAW;YACXC,0CAAoB;YACpBC,wCAAmB;YACnBC,sCAAkB;YAClBC,0CAAoB;YACpBC,sCAAkB;YAClBC,4CAAqB;YACrBC,8CAAsB;SACvB;QACDC,SAAS;YAACR,wBAAW;SAAC"}
|
|
@@ -26,6 +26,7 @@ const _mcpcommandsservice = require("./commands/mcp-commands.service");
|
|
|
26
26
|
const _configcommandsservice = require("../../config/services/config-commands.service");
|
|
27
27
|
const _projectcommandsservice = require("./commands/project-commands.service");
|
|
28
28
|
const _toolsregistryservice = require("../../tools/services/tools-registry.service");
|
|
29
|
+
const _kanbanserverservice = require("../../kanban/services/kanban-server.service");
|
|
29
30
|
const _theme = require("../utils/theme");
|
|
30
31
|
function _ts_decorate(decorators, target, key, desc) {
|
|
31
32
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
@@ -193,6 +194,11 @@ let ReplService = class ReplService {
|
|
|
193
194
|
text: '/mcp',
|
|
194
195
|
display: '/mcp',
|
|
195
196
|
description: 'MCP servers'
|
|
197
|
+
},
|
|
198
|
+
{
|
|
199
|
+
text: '/kanban',
|
|
200
|
+
display: '/kanban',
|
|
201
|
+
description: 'Open kanban board'
|
|
196
202
|
}
|
|
197
203
|
];
|
|
198
204
|
return commands.filter((c)=>c.text.startsWith(input));
|
|
@@ -396,6 +402,9 @@ let ReplService = class ReplService {
|
|
|
396
402
|
'deep'
|
|
397
403
|
], this.smartInput);
|
|
398
404
|
break;
|
|
405
|
+
case 'kanban':
|
|
406
|
+
this.kanbanServer.start();
|
|
407
|
+
break;
|
|
399
408
|
default:
|
|
400
409
|
process.stdout.write(`${_theme.Colors.red} Unknown: /${cmd}${_theme.Colors.reset} ${_theme.Colors.dim}Try /help${_theme.Colors.reset}\r\n`);
|
|
401
410
|
}
|
|
@@ -610,7 +619,7 @@ let ReplService = class ReplService {
|
|
|
610
619
|
this.stopSpinner();
|
|
611
620
|
this.smartInput?.destroy();
|
|
612
621
|
}
|
|
613
|
-
constructor(deepAgent, configService, configManager, mentionsService, mcpRegistry, agentRegistry, skillRegistry, welcomeScreen, planMode, replCommands, gitCommands, agentCommands, mcpCommands, configCommands, projectCommands, toolsRegistry){
|
|
622
|
+
constructor(deepAgent, configService, configManager, mentionsService, mcpRegistry, agentRegistry, skillRegistry, welcomeScreen, planMode, replCommands, gitCommands, agentCommands, mcpCommands, configCommands, projectCommands, toolsRegistry, kanbanServer){
|
|
614
623
|
this.deepAgent = deepAgent;
|
|
615
624
|
this.configService = configService;
|
|
616
625
|
this.configManager = configManager;
|
|
@@ -627,6 +636,7 @@ let ReplService = class ReplService {
|
|
|
627
636
|
this.configCommands = configCommands;
|
|
628
637
|
this.projectCommands = projectCommands;
|
|
629
638
|
this.toolsRegistry = toolsRegistry;
|
|
639
|
+
this.kanbanServer = kanbanServer;
|
|
630
640
|
this.smartInput = null;
|
|
631
641
|
this.abortController = null;
|
|
632
642
|
this.isProcessing = false;
|
|
@@ -652,7 +662,8 @@ ReplService = _ts_decorate([
|
|
|
652
662
|
typeof _mcpcommandsservice.McpCommandsService === "undefined" ? Object : _mcpcommandsservice.McpCommandsService,
|
|
653
663
|
typeof _configcommandsservice.ConfigCommandsService === "undefined" ? Object : _configcommandsservice.ConfigCommandsService,
|
|
654
664
|
typeof _projectcommandsservice.ProjectCommandsService === "undefined" ? Object : _projectcommandsservice.ProjectCommandsService,
|
|
655
|
-
typeof _toolsregistryservice.ToolsRegistryService === "undefined" ? Object : _toolsregistryservice.ToolsRegistryService
|
|
665
|
+
typeof _toolsregistryservice.ToolsRegistryService === "undefined" ? Object : _toolsregistryservice.ToolsRegistryService,
|
|
666
|
+
typeof _kanbanserverservice.KanbanServerService === "undefined" ? Object : _kanbanserverservice.KanbanServerService
|
|
656
667
|
])
|
|
657
668
|
], ReplService);
|
|
658
669
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/modules/repl/services/repl.service.ts"],"sourcesContent":["import { Injectable } from '@nestjs/common';\nimport { DeepAgentService } from '../../core/services/deep-agent.service';\nimport { ConfigService } from '../../../common/services/config.service';\nimport { ConfigManagerService } from '../../config/services/config-manager.service';\nimport { MentionsService } from '../../mentions/services/mentions.service';\nimport { McpRegistryService } from '../../mcp/services/mcp-registry.service';\nimport { AgentRegistryService } from '../../agents/services/agent-registry.service';\nimport { SkillRegistryService } from '../../skills/services/skill-registry.service';\nimport { PlanModeService } from '../../core/services/plan-mode.service';\nimport { SmartInput } from './smart-input';\nimport { WelcomeScreenService } from './welcome-screen.service';\nimport { ReplCommandsService } from './commands/repl-commands.service';\nimport { GitCommandsService } from './commands/git-commands.service';\nimport { AgentCommandsService } from './commands/agent-commands.service';\nimport { McpCommandsService } from './commands/mcp-commands.service';\nimport { ConfigCommandsService } from '../../config/services/config-commands.service';\nimport { ProjectCommandsService } from './commands/project-commands.service';\nimport { ToolsRegistryService } from '../../tools/services/tools-registry.service';\nimport { Colors, Icons } from '../utils/theme';\n\n@Injectable()\nexport class ReplService {\n private smartInput: SmartInput | null = null;\n private abortController: AbortController | null = null;\n private isProcessing = false;\n private spinnerTimer: ReturnType<typeof setInterval> | null = null;\n\n constructor(\n private readonly deepAgent: DeepAgentService,\n private readonly configService: ConfigService,\n private readonly configManager: ConfigManagerService,\n private readonly mentionsService: MentionsService,\n private readonly mcpRegistry: McpRegistryService,\n private readonly agentRegistry: AgentRegistryService,\n private readonly skillRegistry: SkillRegistryService,\n private readonly welcomeScreen: WelcomeScreenService,\n private readonly planMode: PlanModeService,\n private readonly replCommands: ReplCommandsService,\n private readonly gitCommands: GitCommandsService,\n private readonly agentCommands: AgentCommandsService,\n private readonly mcpCommands: McpCommandsService,\n private readonly configCommands: ConfigCommandsService,\n private readonly projectCommands: ProjectCommandsService,\n private readonly toolsRegistry: ToolsRegistryService,\n ) {}\n\n async start(): Promise<void> {\n const initResult = await this.deepAgent.initialize();\n const agentCount = this.agentRegistry.resolveAllAgents().length;\n\n this.welcomeScreen.printWelcomeScreen({\n projectPath: initResult.projectPath || undefined,\n model: this.getModelDisplayName(),\n toolCount: initResult.toolCount,\n agentCount,\n });\n\n this.smartInput = new SmartInput({\n prompt: `${Colors.cyan}${Colors.bold}>${Colors.reset} `,\n promptVisibleLen: 2,\n getCommandSuggestions: (input) => this.getCommandSuggestions(input),\n getMentionSuggestions: (partial) => this.getMentionSuggestions(partial),\n onSubmit: (line) => this.handleLine(line),\n onCancel: () => this.handleCancel(),\n onExit: () => this.handleExit(),\n });\n\n this.smartInput.start();\n }\n\n private getCommandSuggestions(input: string): Array<{ text: string; display: string; description: string }> {\n const commands = [\n { text: '/help', display: '/help', description: 'Show help' },\n { text: '/clear', display: '/clear', description: 'Clear conversation' },\n { text: '/compact', display: '/compact', description: 'Compact history' },\n { text: '/exit', display: '/exit', description: 'Exit' },\n { text: '/status', display: '/status', description: 'Git status' },\n { text: '/diff', display: '/diff', description: 'Git diff' },\n { text: '/log', display: '/log', description: 'Git log' },\n { text: '/commit', display: '/commit', description: 'Commit changes' },\n { text: '/up', display: '/up', description: 'Smart commit & push' },\n { text: '/split-up', display: '/split-up', description: 'Split commits' },\n { text: '/pr', display: '/pr', description: 'Create Pull Request' },\n { text: '/unit-test', display: '/unit-test', description: 'Generate unit tests' },\n { text: '/review', display: '/review', description: 'Code review' },\n { text: '/fix', display: '/fix', description: 'Auto-fix code' },\n { text: '/ident', display: '/ident', description: 'Format code' },\n { text: '/release', display: '/release', description: 'Release notes' },\n { text: '/tools', display: '/tools', description: 'List tools' },\n { text: '/agents', display: '/agents', description: 'List agents' },\n { text: '/skills', display: '/skills', description: 'List skills' },\n { text: '/context', display: '/context', description: 'Session info' },\n { text: '/mentions', display: '/mentions', description: 'Mentions help' },\n { text: '/model', display: '/model', description: 'Show model' },\n { text: '/config', display: '/config', description: 'Configuration' },\n { text: '/project', display: '/project', description: 'Project context' },\n { text: '/project-deep', display: '/project-deep', description: 'Deep project analysis' },\n { text: '/init', display: '/init', description: 'Analyze project and generate context' },\n { text: '/mcp', display: '/mcp', description: 'MCP servers' },\n ];\n\n return commands.filter(c => c.text.startsWith(input));\n }\n\n private getMentionSuggestions(partial: string): Array<{ text: string; display: string; description: string }> {\n const fs = require('fs');\n const path = require('path');\n\n const gitOpts = [\n { text: '@git:status', display: '@git:status', description: 'Git status' },\n { text: '@git:diff', display: '@git:diff', description: 'Git diff' },\n { text: '@git:log', display: '@git:log', description: 'Git log' },\n { text: '@git:branch', display: '@git:branch', description: 'Branches' },\n ];\n\n if (partial === '') return [...gitOpts, ...this.getFileEntries('')];\n if (partial.startsWith('git:')) return gitOpts.filter(o => o.text.startsWith('@' + partial));\n\n return [...gitOpts.filter(o => o.text.startsWith('@' + partial)), ...this.getFileEntries(partial)].slice(0, 30);\n }\n\n private getFileEntries(partial: string): Array<{ text: string; display: string; description: string }> {\n const fs = require('fs');\n const path = require('path');\n\n try {\n let dir: string;\n let prefix: string;\n\n if (partial.endsWith('/')) {\n dir = partial.slice(0, -1) || '.';\n prefix = '';\n } else if (partial.includes('/')) {\n dir = path.dirname(partial);\n prefix = path.basename(partial);\n } else {\n dir = '.';\n prefix = partial;\n }\n\n const resolved = path.resolve(process.cwd(), dir);\n if (!fs.existsSync(resolved) || !fs.statSync(resolved).isDirectory()) return [];\n\n const entries = fs.readdirSync(resolved, { withFileTypes: true });\n const ignore = ['node_modules', '.git', 'dist', 'coverage', '.next', '__pycache__'];\n\n return entries\n .filter(e => !ignore.includes(e.name))\n .filter(e => !e.name.startsWith('.') || prefix.startsWith('.'))\n .filter(e => prefix === '' || e.name.toLowerCase().startsWith(prefix.toLowerCase()))\n .map(e => {\n const relDir = dir === '.' ? '' : dir + '/';\n const isDir = e.isDirectory();\n return {\n text: '@' + relDir + e.name + (isDir ? '/' : ''),\n display: '@' + relDir + e.name + (isDir ? '/' : ''),\n description: isDir ? 'dir' : '',\n };\n })\n .slice(0, 20);\n } catch {\n return [];\n }\n }\n\n private handleCancel(): void {\n if (this.isProcessing && this.abortController) {\n this.abortController.abort();\n this.stopSpinner();\n process.stdout.write(`\\r\\n${Colors.yellow} Cancelled${Colors.reset}\\r\\n\\r\\n`);\n this.isProcessing = false;\n } else {\n process.stdout.write(`${Colors.dim} (Use /exit to quit)${Colors.reset}\\r\\n`);\n this.smartInput?.showPrompt();\n }\n }\n\n private handleExit(): void {\n process.stdout.write(`${Colors.dim} Goodbye!${Colors.reset}\\r\\n`);\n this.stop();\n process.exit(0);\n }\n\n private async handleLine(input: string): Promise<void> {\n const trimmed = input.trim();\n\n if (!trimmed) {\n this.smartInput?.showPrompt();\n return;\n }\n\n if (trimmed.startsWith('/')) {\n await this.handleCommand(trimmed);\n } else {\n await this.handleMessage(trimmed);\n }\n\n this.smartInput?.showPrompt();\n }\n\n private async handleCommand(command: string): Promise<void> {\n const parts = command.slice(1).split(/\\s+/);\n const cmd = parts[0].toLowerCase();\n const args = parts.slice(1);\n\n switch (cmd) {\n case 'help': this.replCommands.printHelp(); break;\n case 'clear': this.replCommands.cmdClear(this.welcomeScreen); break;\n case 'exit':\n case 'quit': this.handleExit(); return;\n case 'compact': await this.handleCompact(); break;\n case 'context': this.replCommands.cmdContext(); break;\n case 'config':\n await this.configCommands.handleConfigCommand(args, this.smartInput!);\n await this.configManager.loadConfig();\n await this.deepAgent.reinitializeModel();\n break;\n case 'model': this.replCommands.cmdModel(args); break;\n case 'init':\n await this.projectCommands.cmdProject(['analyze'], this.smartInput!);\n break;\n case 'mentions': this.replCommands.cmdMentionsHelp(); break;\n case 'tools': this.cmdTools(); break;\n\n case 'status': this.gitCommands.runGit('git status'); break;\n case 'diff': this.gitCommands.runGit(args.length ? `git diff ${args.join(' ')}` : 'git diff'); break;\n case 'log': this.gitCommands.runGit('git log --oneline -15'); break;\n case 'commit': \n await this.gitCommands.cmdCommit(args, this.smartInput!); \n break;\n case 'up': \n await this.gitCommands.cmdUp(this.smartInput!); \n break;\n case 'split-up': \n await this.gitCommands.cmdSplitUp(this.smartInput!); \n break;\n case 'pr': \n await this.gitCommands.cmdPr(this.smartInput!); \n break;\n case 'unit-test':\n await this.gitCommands.cmdUnitTest(this.smartInput!);\n break;\n case 'review': await this.gitCommands.cmdReview(args); break;\n case 'fix': await this.gitCommands.cmdFix(args); break;\n case 'ident': await this.gitCommands.cmdIdent(); break;\n case 'release': await this.gitCommands.cmdRelease(args); break;\n\n case 'agents': \n await this.agentCommands.cmdAgents(args, this.smartInput!); \n break;\n case 'skills': \n await this.agentCommands.cmdSkills(args, this.smartInput!); \n break;\n\n case 'mcp': \n await this.mcpCommands.cmdMcp(args, this.smartInput!); \n break;\n\n case 'project':\n await this.projectCommands.cmdProject(args, this.smartInput!);\n break;\n case 'project-deep':\n await this.projectCommands.cmdProject(['deep'], this.smartInput!);\n break;\n\n default:\n process.stdout.write(`${Colors.red} Unknown: /${cmd}${Colors.reset} ${Colors.dim}Try /help${Colors.reset}\\r\\n`);\n }\n }\n\n private async handleCompact(): Promise<void> {\n const msgCount = this.deepAgent.getMessageCount();\n if (msgCount < 4) {\n process.stdout.write(`${Colors.dim} Nothing to compact (${msgCount} messages)${Colors.reset}\\r\\n`);\n return;\n }\n process.stdout.write(`${Colors.dim} Summarizing ${msgCount} messages...${Colors.reset}\\r\\n`);\n const result = await this.deepAgent.compactHistory();\n if (result.compacted) {\n process.stdout.write(`${Colors.green} Compacted: ${result.messagesBefore} → ${result.messagesAfter} messages${Colors.reset}\\r\\n`);\n } else {\n process.stdout.write(`${Colors.yellow} Could not compact (summarization failed)${Colors.reset}\\r\\n`);\n }\n }\n\n private async handleMessage(message: string): Promise<void> {\n this.isProcessing = true;\n this.abortController = new AbortController();\n this.smartInput?.enterPassiveMode();\n\n try {\n let messageToProcess = message;\n\n const planCheck = await this.planMode.shouldEnterPlanMode(message);\n if (planCheck.shouldPlan) {\n const usePlan = await this.smartInput!.askChoice(\n '📝 Complex task. Create a plan?',\n [\n { key: 'y', label: 'yes', description: 'Create structured plan' },\n { key: 'n', label: 'no', description: 'Proceed without plan' },\n ]\n );\n \n if (usePlan === 'y') {\n const plannedMessage = await this.runInteractivePlanMode(message);\n if (!plannedMessage) {\n this.isProcessing = false;\n this.smartInput?.exitPassiveMode();\n return;\n }\n messageToProcess = plannedMessage;\n }\n }\n\n const mentionResult = await this.mentionsService.processMessage(messageToProcess);\n if (mentionResult.mentions.length > 0) {\n const summary = this.mentionsService.getMentionsSummary(mentionResult.mentions);\n for (const line of summary) {\n process.stdout.write(`${Colors.dim}${line}${Colors.reset}\\r\\n`);\n }\n process.stdout.write('\\r\\n');\n }\n\n this.startSpinner('Thinking');\n\n let firstChunk = true;\n let fullResponse = '';\n\n for await (const chunk of this.deepAgent.chat(mentionResult.expandedMessage)) {\n if (this.abortController?.signal.aborted) break;\n\n const isToolOutput = chunk.includes('\\x1b[') && (\n chunk.includes('⏿') ||\n chunk.includes('tokens:') ||\n chunk.includes('conversation compacted')\n );\n\n if (firstChunk && !isToolOutput) {\n this.stopSpinner();\n process.stdout.write(`\\r\\n${Colors.magenta}${Colors.bold}${Icons.chestnut} Cast${Colors.reset}\\r\\n`);\n firstChunk = false;\n }\n\n if (!isToolOutput) {\n fullResponse += chunk;\n }\n process.stdout.write(chunk);\n }\n\n if (!firstChunk) {\n process.stdout.write('\\r\\n');\n } else {\n this.stopSpinner();\n }\n } catch (error) {\n this.stopSpinner();\n const msg = (error as Error).message;\n if (!msg.includes('abort')) {\n process.stdout.write(`\\r\\n${Colors.red} Error: ${msg}${Colors.reset}\\r\\n\\r\\n`);\n }\n } finally {\n this.isProcessing = false;\n this.abortController = null;\n this.smartInput?.exitPassiveMode();\n }\n }\n\n private async runInteractivePlanMode(userMessage: string): Promise<string | null> {\n process.stdout.write(`\\r\\n${Colors.cyan}${Colors.bold}📋 PLAN MODE${Colors.reset}\\r\\n`);\n process.stdout.write(`${Colors.dim}Build plan first, execute after approval${Colors.reset}\\r\\n\\r\\n`);\n\n const clarifyingQuestions = await this.planMode.generateClarifyingQuestions(userMessage);\n const answers: string[] = [];\n\n if (clarifyingQuestions.length > 0) {\n process.stdout.write(`${Colors.dim}I need a few quick clarifications:${Colors.reset}\\r\\n`);\n for (let i = 0; i < clarifyingQuestions.length; i++) {\n const q = clarifyingQuestions[i];\n const answer = await this.smartInput!.question(`${Colors.yellow}Q${i + 1}:${Colors.reset} ${q} `);\n if (answer.trim()) {\n answers.push(`- ${q} => ${answer.trim()}`);\n }\n }\n process.stdout.write('\\r\\n');\n }\n\n const context = answers.length > 0 ? `User clarifications:\\n${answers.join('\\n')}` : undefined;\n let plan = await this.planMode.generatePlan(userMessage, context);\n\n while (true) {\n process.stdout.write(this.planMode.formatPlanForDisplay(plan));\n\n const action = await this.smartInput!.askChoice('Plan options', [\n { key: 'a', label: 'accept', description: 'Use this plan and continue' },\n { key: 'r', label: 'refine', description: 'Refine plan with extra feedback' },\n { key: 'c', label: 'cancel', description: 'Cancel and return to prompt' },\n ]);\n\n if (action === 'c') {\n process.stdout.write(`${Colors.dim} Plan cancelled${Colors.reset}\\r\\n\\r\\n`);\n return null;\n }\n\n if (action === 'r') {\n const feedback = await this.smartInput!.question(`${Colors.cyan}Refinement feedback:${Colors.reset} `);\n if (!feedback.trim()) {\n process.stdout.write(`${Colors.dim} No feedback provided. Keeping current plan.${Colors.reset}\\r\\n\\r\\n`);\n continue;\n }\n plan = await this.planMode.refinePlan(plan, feedback.trim());\n continue;\n }\n\n return this.buildPlanExecutionPrompt(userMessage, plan, answers);\n }\n }\n\n private buildPlanExecutionPrompt(userMessage: string, plan: { title: string; overview: string; steps: Array<{ id: number; description: string; files: string[] }> }, clarifications: string[]): string {\n const lines: string[] = [];\n lines.push(userMessage);\n lines.push('');\n lines.push('Approved execution plan:');\n lines.push(`Title: ${plan.title}`);\n lines.push(`Overview: ${plan.overview}`);\n lines.push('Steps:');\n for (const step of plan.steps) {\n const files = step.files.length > 0 ? ` | files: ${step.files.join(', ')}` : '';\n lines.push(`${step.id}. ${step.description}${files}`);\n }\n if (clarifications.length > 0) {\n lines.push('');\n lines.push('User clarifications:');\n lines.push(...clarifications);\n }\n lines.push('');\n lines.push('Execute the task following this approved plan and report progress by step.');\n return lines.join('\\n');\n }\n\n private startSpinner(label: string): void {\n let i = 0;\n this.spinnerTimer = setInterval(() => {\n const spinner = Icons.spinner[i % Icons.spinner.length];\n i++;\n process.stdout.write(\n `\\r${Colors.cyan}${spinner}${Colors.reset} ${Colors.dim}${label}...${Colors.reset}`\n );\n }, 80);\n }\n\n private stopSpinner(): void {\n if (this.spinnerTimer) {\n clearInterval(this.spinnerTimer);\n this.spinnerTimer = null;\n process.stdout.write('\\r\\x1b[K');\n }\n }\n\n private cmdTools(): void {\n const allTools = this.toolsRegistry.getAllTools();\n const tools: [string, string][] = allTools.map(t => [t.name, t.description.slice(0, 60)]);\n\n if (tools.length > 0) {\n const maxLen = Math.max(...tools.map(([n]) => n.length));\n\n process.stdout.write('\\r\\n');\n process.stdout.write(`${Colors.bold}Built-in Tools (${tools.length}):${Colors.reset}\\r\\n`);\n for (const [name, desc] of tools) {\n process.stdout.write(` ${Colors.cyan}${name.padEnd(maxLen)}${Colors.reset} ${Colors.dim}${desc}${Colors.reset}\\r\\n`);\n }\n }\n\n const mcpTools = this.mcpRegistry.getAllMcpTools();\n if (mcpTools.length > 0) {\n process.stdout.write(`\\r\\n${Colors.bold}MCP Tools (${mcpTools.length}):${Colors.reset}\\r\\n`);\n for (const t of mcpTools.slice(0, 10)) {\n process.stdout.write(` ${Colors.cyan}${t.name}${Colors.reset} ${Colors.dim}${t.description.slice(0, 50)}${Colors.reset}\\r\\n`);\n }\n }\n process.stdout.write('\\r\\n');\n }\n\n private getModelDisplayName(): string {\n try {\n const modelConfig = this.configManager.getModelConfig('default');\n if (modelConfig) {\n return `${modelConfig.provider}/${modelConfig.model}`;\n }\n } catch {\n }\n return `${this.configService.getProvider()}/${this.configService.getModel()}`;\n }\n\n stop(): void {\n this.stopSpinner();\n this.smartInput?.destroy();\n }\n}\n"],"names":["ReplService","start","initResult","deepAgent","initialize","agentCount","agentRegistry","resolveAllAgents","length","welcomeScreen","printWelcomeScreen","projectPath","undefined","model","getModelDisplayName","toolCount","smartInput","SmartInput","prompt","Colors","cyan","bold","reset","promptVisibleLen","getCommandSuggestions","input","getMentionSuggestions","partial","onSubmit","line","handleLine","onCancel","handleCancel","onExit","handleExit","commands","text","display","description","filter","c","startsWith","fs","require","path","gitOpts","getFileEntries","o","slice","dir","prefix","endsWith","includes","dirname","basename","resolved","resolve","process","cwd","existsSync","statSync","isDirectory","entries","readdirSync","withFileTypes","ignore","e","name","toLowerCase","map","relDir","isDir","isProcessing","abortController","abort","stopSpinner","stdout","write","yellow","dim","showPrompt","stop","exit","trimmed","trim","handleCommand","handleMessage","command","parts","split","cmd","args","replCommands","printHelp","cmdClear","handleCompact","cmdContext","configCommands","handleConfigCommand","configManager","loadConfig","reinitializeModel","cmdModel","projectCommands","cmdProject","cmdMentionsHelp","cmdTools","gitCommands","runGit","join","cmdCommit","cmdUp","cmdSplitUp","cmdPr","cmdUnitTest","cmdReview","cmdFix","cmdIdent","cmdRelease","agentCommands","cmdAgents","cmdSkills","mcpCommands","cmdMcp","red","msgCount","getMessageCount","result","compactHistory","compacted","green","messagesBefore","messagesAfter","message","AbortController","enterPassiveMode","messageToProcess","planCheck","planMode","shouldEnterPlanMode","shouldPlan","usePlan","askChoice","key","label","plannedMessage","runInteractivePlanMode","exitPassiveMode","mentionResult","mentionsService","processMessage","mentions","summary","getMentionsSummary","startSpinner","firstChunk","fullResponse","chunk","chat","expandedMessage","signal","aborted","isToolOutput","magenta","Icons","chestnut","error","msg","userMessage","clarifyingQuestions","generateClarifyingQuestions","answers","i","q","answer","question","push","context","plan","generatePlan","formatPlanForDisplay","action","feedback","refinePlan","buildPlanExecutionPrompt","clarifications","lines","title","overview","step","steps","files","id","spinnerTimer","setInterval","spinner","clearInterval","allTools","toolsRegistry","getAllTools","tools","t","maxLen","Math","max","n","desc","padEnd","mcpTools","mcpRegistry","getAllMcpTools","modelConfig","getModelConfig","provider","configService","getProvider","getModel","destroy","skillRegistry"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../../src/modules/repl/services/repl.service.ts"],"sourcesContent":["import { Injectable } from '@nestjs/common';\nimport { DeepAgentService } from '../../core/services/deep-agent.service';\nimport { ConfigService } from '../../../common/services/config.service';\nimport { ConfigManagerService } from '../../config/services/config-manager.service';\nimport { MentionsService } from '../../mentions/services/mentions.service';\nimport { McpRegistryService } from '../../mcp/services/mcp-registry.service';\nimport { AgentRegistryService } from '../../agents/services/agent-registry.service';\nimport { SkillRegistryService } from '../../skills/services/skill-registry.service';\nimport { PlanModeService } from '../../core/services/plan-mode.service';\nimport { SmartInput } from './smart-input';\nimport { WelcomeScreenService } from './welcome-screen.service';\nimport { ReplCommandsService } from './commands/repl-commands.service';\nimport { GitCommandsService } from './commands/git-commands.service';\nimport { AgentCommandsService } from './commands/agent-commands.service';\nimport { McpCommandsService } from './commands/mcp-commands.service';\nimport { ConfigCommandsService } from '../../config/services/config-commands.service';\nimport { ProjectCommandsService } from './commands/project-commands.service';\nimport { ToolsRegistryService } from '../../tools/services/tools-registry.service';\nimport { KanbanServerService } from '../../kanban/services/kanban-server.service';\nimport { Colors, Icons } from '../utils/theme';\n\n@Injectable()\nexport class ReplService {\n private smartInput: SmartInput | null = null;\n private abortController: AbortController | null = null;\n private isProcessing = false;\n private spinnerTimer: ReturnType<typeof setInterval> | null = null;\n\n constructor(\n private readonly deepAgent: DeepAgentService,\n private readonly configService: ConfigService,\n private readonly configManager: ConfigManagerService,\n private readonly mentionsService: MentionsService,\n private readonly mcpRegistry: McpRegistryService,\n private readonly agentRegistry: AgentRegistryService,\n private readonly skillRegistry: SkillRegistryService,\n private readonly welcomeScreen: WelcomeScreenService,\n private readonly planMode: PlanModeService,\n private readonly replCommands: ReplCommandsService,\n private readonly gitCommands: GitCommandsService,\n private readonly agentCommands: AgentCommandsService,\n private readonly mcpCommands: McpCommandsService,\n private readonly configCommands: ConfigCommandsService,\n private readonly projectCommands: ProjectCommandsService,\n private readonly toolsRegistry: ToolsRegistryService,\n private readonly kanbanServer: KanbanServerService,\n ) {}\n\n async start(): Promise<void> {\n const initResult = await this.deepAgent.initialize();\n const agentCount = this.agentRegistry.resolveAllAgents().length;\n\n this.welcomeScreen.printWelcomeScreen({\n projectPath: initResult.projectPath || undefined,\n model: this.getModelDisplayName(),\n toolCount: initResult.toolCount,\n agentCount,\n });\n\n this.smartInput = new SmartInput({\n prompt: `${Colors.cyan}${Colors.bold}>${Colors.reset} `,\n promptVisibleLen: 2,\n getCommandSuggestions: (input) => this.getCommandSuggestions(input),\n getMentionSuggestions: (partial) => this.getMentionSuggestions(partial),\n onSubmit: (line) => this.handleLine(line),\n onCancel: () => this.handleCancel(),\n onExit: () => this.handleExit(),\n });\n\n this.smartInput.start();\n }\n\n private getCommandSuggestions(input: string): Array<{ text: string; display: string; description: string }> {\n const commands = [\n { text: '/help', display: '/help', description: 'Show help' },\n { text: '/clear', display: '/clear', description: 'Clear conversation' },\n { text: '/compact', display: '/compact', description: 'Compact history' },\n { text: '/exit', display: '/exit', description: 'Exit' },\n { text: '/status', display: '/status', description: 'Git status' },\n { text: '/diff', display: '/diff', description: 'Git diff' },\n { text: '/log', display: '/log', description: 'Git log' },\n { text: '/commit', display: '/commit', description: 'Commit changes' },\n { text: '/up', display: '/up', description: 'Smart commit & push' },\n { text: '/split-up', display: '/split-up', description: 'Split commits' },\n { text: '/pr', display: '/pr', description: 'Create Pull Request' },\n { text: '/unit-test', display: '/unit-test', description: 'Generate unit tests' },\n { text: '/review', display: '/review', description: 'Code review' },\n { text: '/fix', display: '/fix', description: 'Auto-fix code' },\n { text: '/ident', display: '/ident', description: 'Format code' },\n { text: '/release', display: '/release', description: 'Release notes' },\n { text: '/tools', display: '/tools', description: 'List tools' },\n { text: '/agents', display: '/agents', description: 'List agents' },\n { text: '/skills', display: '/skills', description: 'List skills' },\n { text: '/context', display: '/context', description: 'Session info' },\n { text: '/mentions', display: '/mentions', description: 'Mentions help' },\n { text: '/model', display: '/model', description: 'Show model' },\n { text: '/config', display: '/config', description: 'Configuration' },\n { text: '/project', display: '/project', description: 'Project context' },\n { text: '/project-deep', display: '/project-deep', description: 'Deep project analysis' },\n { text: '/init', display: '/init', description: 'Analyze project and generate context' },\n { text: '/mcp', display: '/mcp', description: 'MCP servers' },\n { text: '/kanban', display: '/kanban', description: 'Open kanban board' },\n ];\n\n return commands.filter(c => c.text.startsWith(input));\n }\n\n private getMentionSuggestions(partial: string): Array<{ text: string; display: string; description: string }> {\n const fs = require('fs');\n const path = require('path');\n\n const gitOpts = [\n { text: '@git:status', display: '@git:status', description: 'Git status' },\n { text: '@git:diff', display: '@git:diff', description: 'Git diff' },\n { text: '@git:log', display: '@git:log', description: 'Git log' },\n { text: '@git:branch', display: '@git:branch', description: 'Branches' },\n ];\n\n if (partial === '') return [...gitOpts, ...this.getFileEntries('')];\n if (partial.startsWith('git:')) return gitOpts.filter(o => o.text.startsWith('@' + partial));\n\n return [...gitOpts.filter(o => o.text.startsWith('@' + partial)), ...this.getFileEntries(partial)].slice(0, 30);\n }\n\n private getFileEntries(partial: string): Array<{ text: string; display: string; description: string }> {\n const fs = require('fs');\n const path = require('path');\n\n try {\n let dir: string;\n let prefix: string;\n\n if (partial.endsWith('/')) {\n dir = partial.slice(0, -1) || '.';\n prefix = '';\n } else if (partial.includes('/')) {\n dir = path.dirname(partial);\n prefix = path.basename(partial);\n } else {\n dir = '.';\n prefix = partial;\n }\n\n const resolved = path.resolve(process.cwd(), dir);\n if (!fs.existsSync(resolved) || !fs.statSync(resolved).isDirectory()) return [];\n\n const entries = fs.readdirSync(resolved, { withFileTypes: true });\n const ignore = ['node_modules', '.git', 'dist', 'coverage', '.next', '__pycache__'];\n\n return entries\n .filter(e => !ignore.includes(e.name))\n .filter(e => !e.name.startsWith('.') || prefix.startsWith('.'))\n .filter(e => prefix === '' || e.name.toLowerCase().startsWith(prefix.toLowerCase()))\n .map(e => {\n const relDir = dir === '.' ? '' : dir + '/';\n const isDir = e.isDirectory();\n return {\n text: '@' + relDir + e.name + (isDir ? '/' : ''),\n display: '@' + relDir + e.name + (isDir ? '/' : ''),\n description: isDir ? 'dir' : '',\n };\n })\n .slice(0, 20);\n } catch {\n return [];\n }\n }\n\n private handleCancel(): void {\n if (this.isProcessing && this.abortController) {\n this.abortController.abort();\n this.stopSpinner();\n process.stdout.write(`\\r\\n${Colors.yellow} Cancelled${Colors.reset}\\r\\n\\r\\n`);\n this.isProcessing = false;\n } else {\n process.stdout.write(`${Colors.dim} (Use /exit to quit)${Colors.reset}\\r\\n`);\n this.smartInput?.showPrompt();\n }\n }\n\n private handleExit(): void {\n process.stdout.write(`${Colors.dim} Goodbye!${Colors.reset}\\r\\n`);\n this.stop();\n process.exit(0);\n }\n\n private async handleLine(input: string): Promise<void> {\n const trimmed = input.trim();\n\n if (!trimmed) {\n this.smartInput?.showPrompt();\n return;\n }\n\n if (trimmed.startsWith('/')) {\n await this.handleCommand(trimmed);\n } else {\n await this.handleMessage(trimmed);\n }\n\n this.smartInput?.showPrompt();\n }\n\n private async handleCommand(command: string): Promise<void> {\n const parts = command.slice(1).split(/\\s+/);\n const cmd = parts[0].toLowerCase();\n const args = parts.slice(1);\n\n switch (cmd) {\n case 'help': this.replCommands.printHelp(); break;\n case 'clear': this.replCommands.cmdClear(this.welcomeScreen); break;\n case 'exit':\n case 'quit': this.handleExit(); return;\n case 'compact': await this.handleCompact(); break;\n case 'context': this.replCommands.cmdContext(); break;\n case 'config':\n await this.configCommands.handleConfigCommand(args, this.smartInput!);\n await this.configManager.loadConfig();\n await this.deepAgent.reinitializeModel();\n break;\n case 'model': this.replCommands.cmdModel(args); break;\n case 'init':\n await this.projectCommands.cmdProject(['analyze'], this.smartInput!);\n break;\n case 'mentions': this.replCommands.cmdMentionsHelp(); break;\n case 'tools': this.cmdTools(); break;\n\n case 'status': this.gitCommands.runGit('git status'); break;\n case 'diff': this.gitCommands.runGit(args.length ? `git diff ${args.join(' ')}` : 'git diff'); break;\n case 'log': this.gitCommands.runGit('git log --oneline -15'); break;\n case 'commit': \n await this.gitCommands.cmdCommit(args, this.smartInput!); \n break;\n case 'up': \n await this.gitCommands.cmdUp(this.smartInput!); \n break;\n case 'split-up': \n await this.gitCommands.cmdSplitUp(this.smartInput!); \n break;\n case 'pr': \n await this.gitCommands.cmdPr(this.smartInput!); \n break;\n case 'unit-test':\n await this.gitCommands.cmdUnitTest(this.smartInput!);\n break;\n case 'review': await this.gitCommands.cmdReview(args); break;\n case 'fix': await this.gitCommands.cmdFix(args); break;\n case 'ident': await this.gitCommands.cmdIdent(); break;\n case 'release': await this.gitCommands.cmdRelease(args); break;\n\n case 'agents': \n await this.agentCommands.cmdAgents(args, this.smartInput!); \n break;\n case 'skills': \n await this.agentCommands.cmdSkills(args, this.smartInput!); \n break;\n\n case 'mcp': \n await this.mcpCommands.cmdMcp(args, this.smartInput!); \n break;\n\n case 'project':\n await this.projectCommands.cmdProject(args, this.smartInput!);\n break;\n case 'project-deep':\n await this.projectCommands.cmdProject(['deep'], this.smartInput!);\n break;\n\n case 'kanban':\n this.kanbanServer.start();\n break;\n\n default:\n process.stdout.write(`${Colors.red} Unknown: /${cmd}${Colors.reset} ${Colors.dim}Try /help${Colors.reset}\\r\\n`);\n }\n }\n\n private async handleCompact(): Promise<void> {\n const msgCount = this.deepAgent.getMessageCount();\n if (msgCount < 4) {\n process.stdout.write(`${Colors.dim} Nothing to compact (${msgCount} messages)${Colors.reset}\\r\\n`);\n return;\n }\n process.stdout.write(`${Colors.dim} Summarizing ${msgCount} messages...${Colors.reset}\\r\\n`);\n const result = await this.deepAgent.compactHistory();\n if (result.compacted) {\n process.stdout.write(`${Colors.green} Compacted: ${result.messagesBefore} → ${result.messagesAfter} messages${Colors.reset}\\r\\n`);\n } else {\n process.stdout.write(`${Colors.yellow} Could not compact (summarization failed)${Colors.reset}\\r\\n`);\n }\n }\n\n private async handleMessage(message: string): Promise<void> {\n this.isProcessing = true;\n this.abortController = new AbortController();\n this.smartInput?.enterPassiveMode();\n\n try {\n let messageToProcess = message;\n\n const planCheck = await this.planMode.shouldEnterPlanMode(message);\n if (planCheck.shouldPlan) {\n const usePlan = await this.smartInput!.askChoice(\n '📝 Complex task. Create a plan?',\n [\n { key: 'y', label: 'yes', description: 'Create structured plan' },\n { key: 'n', label: 'no', description: 'Proceed without plan' },\n ]\n );\n \n if (usePlan === 'y') {\n const plannedMessage = await this.runInteractivePlanMode(message);\n if (!plannedMessage) {\n this.isProcessing = false;\n this.smartInput?.exitPassiveMode();\n return;\n }\n messageToProcess = plannedMessage;\n }\n }\n\n const mentionResult = await this.mentionsService.processMessage(messageToProcess);\n if (mentionResult.mentions.length > 0) {\n const summary = this.mentionsService.getMentionsSummary(mentionResult.mentions);\n for (const line of summary) {\n process.stdout.write(`${Colors.dim}${line}${Colors.reset}\\r\\n`);\n }\n process.stdout.write('\\r\\n');\n }\n\n this.startSpinner('Thinking');\n\n let firstChunk = true;\n let fullResponse = '';\n\n for await (const chunk of this.deepAgent.chat(mentionResult.expandedMessage)) {\n if (this.abortController?.signal.aborted) break;\n\n const isToolOutput = chunk.includes('\\x1b[') && (\n chunk.includes('⏿') ||\n chunk.includes('tokens:') ||\n chunk.includes('conversation compacted')\n );\n\n if (firstChunk && !isToolOutput) {\n this.stopSpinner();\n process.stdout.write(`\\r\\n${Colors.magenta}${Colors.bold}${Icons.chestnut} Cast${Colors.reset}\\r\\n`);\n firstChunk = false;\n }\n\n if (!isToolOutput) {\n fullResponse += chunk;\n }\n process.stdout.write(chunk);\n }\n\n if (!firstChunk) {\n process.stdout.write('\\r\\n');\n } else {\n this.stopSpinner();\n }\n } catch (error) {\n this.stopSpinner();\n const msg = (error as Error).message;\n if (!msg.includes('abort')) {\n process.stdout.write(`\\r\\n${Colors.red} Error: ${msg}${Colors.reset}\\r\\n\\r\\n`);\n }\n } finally {\n this.isProcessing = false;\n this.abortController = null;\n this.smartInput?.exitPassiveMode();\n }\n }\n\n private async runInteractivePlanMode(userMessage: string): Promise<string | null> {\n process.stdout.write(`\\r\\n${Colors.cyan}${Colors.bold}📋 PLAN MODE${Colors.reset}\\r\\n`);\n process.stdout.write(`${Colors.dim}Build plan first, execute after approval${Colors.reset}\\r\\n\\r\\n`);\n\n const clarifyingQuestions = await this.planMode.generateClarifyingQuestions(userMessage);\n const answers: string[] = [];\n\n if (clarifyingQuestions.length > 0) {\n process.stdout.write(`${Colors.dim}I need a few quick clarifications:${Colors.reset}\\r\\n`);\n for (let i = 0; i < clarifyingQuestions.length; i++) {\n const q = clarifyingQuestions[i];\n const answer = await this.smartInput!.question(`${Colors.yellow}Q${i + 1}:${Colors.reset} ${q} `);\n if (answer.trim()) {\n answers.push(`- ${q} => ${answer.trim()}`);\n }\n }\n process.stdout.write('\\r\\n');\n }\n\n const context = answers.length > 0 ? `User clarifications:\\n${answers.join('\\n')}` : undefined;\n let plan = await this.planMode.generatePlan(userMessage, context);\n\n while (true) {\n process.stdout.write(this.planMode.formatPlanForDisplay(plan));\n\n const action = await this.smartInput!.askChoice('Plan options', [\n { key: 'a', label: 'accept', description: 'Use this plan and continue' },\n { key: 'r', label: 'refine', description: 'Refine plan with extra feedback' },\n { key: 'c', label: 'cancel', description: 'Cancel and return to prompt' },\n ]);\n\n if (action === 'c') {\n process.stdout.write(`${Colors.dim} Plan cancelled${Colors.reset}\\r\\n\\r\\n`);\n return null;\n }\n\n if (action === 'r') {\n const feedback = await this.smartInput!.question(`${Colors.cyan}Refinement feedback:${Colors.reset} `);\n if (!feedback.trim()) {\n process.stdout.write(`${Colors.dim} No feedback provided. Keeping current plan.${Colors.reset}\\r\\n\\r\\n`);\n continue;\n }\n plan = await this.planMode.refinePlan(plan, feedback.trim());\n continue;\n }\n\n return this.buildPlanExecutionPrompt(userMessage, plan, answers);\n }\n }\n\n private buildPlanExecutionPrompt(userMessage: string, plan: { title: string; overview: string; steps: Array<{ id: number; description: string; files: string[] }> }, clarifications: string[]): string {\n const lines: string[] = [];\n lines.push(userMessage);\n lines.push('');\n lines.push('Approved execution plan:');\n lines.push(`Title: ${plan.title}`);\n lines.push(`Overview: ${plan.overview}`);\n lines.push('Steps:');\n for (const step of plan.steps) {\n const files = step.files.length > 0 ? ` | files: ${step.files.join(', ')}` : '';\n lines.push(`${step.id}. ${step.description}${files}`);\n }\n if (clarifications.length > 0) {\n lines.push('');\n lines.push('User clarifications:');\n lines.push(...clarifications);\n }\n lines.push('');\n lines.push('Execute the task following this approved plan and report progress by step.');\n return lines.join('\\n');\n }\n\n private startSpinner(label: string): void {\n let i = 0;\n this.spinnerTimer = setInterval(() => {\n const spinner = Icons.spinner[i % Icons.spinner.length];\n i++;\n process.stdout.write(\n `\\r${Colors.cyan}${spinner}${Colors.reset} ${Colors.dim}${label}...${Colors.reset}`\n );\n }, 80);\n }\n\n private stopSpinner(): void {\n if (this.spinnerTimer) {\n clearInterval(this.spinnerTimer);\n this.spinnerTimer = null;\n process.stdout.write('\\r\\x1b[K');\n }\n }\n\n private cmdTools(): void {\n const allTools = this.toolsRegistry.getAllTools();\n const tools: [string, string][] = allTools.map(t => [t.name, t.description.slice(0, 60)]);\n\n if (tools.length > 0) {\n const maxLen = Math.max(...tools.map(([n]) => n.length));\n\n process.stdout.write('\\r\\n');\n process.stdout.write(`${Colors.bold}Built-in Tools (${tools.length}):${Colors.reset}\\r\\n`);\n for (const [name, desc] of tools) {\n process.stdout.write(` ${Colors.cyan}${name.padEnd(maxLen)}${Colors.reset} ${Colors.dim}${desc}${Colors.reset}\\r\\n`);\n }\n }\n\n const mcpTools = this.mcpRegistry.getAllMcpTools();\n if (mcpTools.length > 0) {\n process.stdout.write(`\\r\\n${Colors.bold}MCP Tools (${mcpTools.length}):${Colors.reset}\\r\\n`);\n for (const t of mcpTools.slice(0, 10)) {\n process.stdout.write(` ${Colors.cyan}${t.name}${Colors.reset} ${Colors.dim}${t.description.slice(0, 50)}${Colors.reset}\\r\\n`);\n }\n }\n process.stdout.write('\\r\\n');\n }\n\n private getModelDisplayName(): string {\n try {\n const modelConfig = this.configManager.getModelConfig('default');\n if (modelConfig) {\n return `${modelConfig.provider}/${modelConfig.model}`;\n }\n } catch {\n }\n return `${this.configService.getProvider()}/${this.configService.getModel()}`;\n }\n\n stop(): void {\n this.stopSpinner();\n this.smartInput?.destroy();\n }\n}\n"],"names":["ReplService","start","initResult","deepAgent","initialize","agentCount","agentRegistry","resolveAllAgents","length","welcomeScreen","printWelcomeScreen","projectPath","undefined","model","getModelDisplayName","toolCount","smartInput","SmartInput","prompt","Colors","cyan","bold","reset","promptVisibleLen","getCommandSuggestions","input","getMentionSuggestions","partial","onSubmit","line","handleLine","onCancel","handleCancel","onExit","handleExit","commands","text","display","description","filter","c","startsWith","fs","require","path","gitOpts","getFileEntries","o","slice","dir","prefix","endsWith","includes","dirname","basename","resolved","resolve","process","cwd","existsSync","statSync","isDirectory","entries","readdirSync","withFileTypes","ignore","e","name","toLowerCase","map","relDir","isDir","isProcessing","abortController","abort","stopSpinner","stdout","write","yellow","dim","showPrompt","stop","exit","trimmed","trim","handleCommand","handleMessage","command","parts","split","cmd","args","replCommands","printHelp","cmdClear","handleCompact","cmdContext","configCommands","handleConfigCommand","configManager","loadConfig","reinitializeModel","cmdModel","projectCommands","cmdProject","cmdMentionsHelp","cmdTools","gitCommands","runGit","join","cmdCommit","cmdUp","cmdSplitUp","cmdPr","cmdUnitTest","cmdReview","cmdFix","cmdIdent","cmdRelease","agentCommands","cmdAgents","cmdSkills","mcpCommands","cmdMcp","kanbanServer","red","msgCount","getMessageCount","result","compactHistory","compacted","green","messagesBefore","messagesAfter","message","AbortController","enterPassiveMode","messageToProcess","planCheck","planMode","shouldEnterPlanMode","shouldPlan","usePlan","askChoice","key","label","plannedMessage","runInteractivePlanMode","exitPassiveMode","mentionResult","mentionsService","processMessage","mentions","summary","getMentionsSummary","startSpinner","firstChunk","fullResponse","chunk","chat","expandedMessage","signal","aborted","isToolOutput","magenta","Icons","chestnut","error","msg","userMessage","clarifyingQuestions","generateClarifyingQuestions","answers","i","q","answer","question","push","context","plan","generatePlan","formatPlanForDisplay","action","feedback","refinePlan","buildPlanExecutionPrompt","clarifications","lines","title","overview","step","steps","files","id","spinnerTimer","setInterval","spinner","clearInterval","allTools","toolsRegistry","getAllTools","tools","t","maxLen","Math","max","n","desc","padEnd","mcpTools","mcpRegistry","getAllMcpTools","modelConfig","getModelConfig","provider","configService","getProvider","getModel","destroy","skillRegistry"],"mappings":"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"}
|
|
@@ -118,9 +118,9 @@ let PlanExecutorService = class PlanExecutorService {
|
|
|
118
118
|
console.log(` ${_theme.Colors.dim}${task.description}${_theme.Colors.reset}`);
|
|
119
119
|
console.log('');
|
|
120
120
|
this.taskService.updateTask(task.id, {
|
|
121
|
-
status: _tasktypes.TaskStatus.IN_PROGRESS
|
|
121
|
+
status: _tasktypes.TaskStatus.IN_PROGRESS,
|
|
122
|
+
assignedAgent: 'main'
|
|
122
123
|
});
|
|
123
|
-
// Executar task via DeepAgent
|
|
124
124
|
const deepAgent = await this.getDeepAgent();
|
|
125
125
|
const result = await deepAgent.executeTask(task);
|
|
126
126
|
if (!result.success) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/modules/tasks/services/plan-executor.service.ts"],"sourcesContent":["import { Injectable } from '@nestjs/common';\nimport { ModuleRef } from '@nestjs/core';\nimport { TaskManagementService } from './task-management.service';\nimport { PlanPersistenceService } from './plan-persistence.service';\nimport { PromptService } from '../../permissions/services/prompt.service';\nimport { Colors } from '../../repl/utils/theme';\nimport { Task, TaskStatus } from '../types/task.types';\n\n@Injectable()\nexport class PlanExecutorService {\n private executing = false;\n private aborted = false;\n private currentPlanFile: string | null = null;\n private deepAgent: any = null;\n\n constructor(\n private taskService: TaskManagementService,\n private planPersistence: PlanPersistenceService,\n private promptService: PromptService,\n private moduleRef: ModuleRef,\n ) {}\n\n private async getDeepAgent() {\n if (!this.deepAgent) {\n const { DeepAgentService } = await import('../../core/services/deep-agent.service');\n this.deepAgent = this.moduleRef.get(DeepAgentService, { strict: false });\n }\n return this.deepAgent;\n }\n\n async executePlan(planId: string, autoApprove: boolean): Promise<void> {\n const plan = this.taskService.getPlans().get(planId);\n if (!plan) {\n throw new Error('Plan not found');\n }\n\n // Salvar plano\n this.currentPlanFile = await this.planPersistence.savePlan(plan, autoApprove);\n this.promptService.info(`📝 Plano salvo: ${this.currentPlanFile}`);\n console.log('');\n\n // Setup Ctrl+C handler\n const ctrlCHandler = () => {\n if (this.executing) {\n this.aborted = true;\n console.log(`\\n${Colors.warning}⚠ Interrupção solicitada. Finalizando tarefa atual...${Colors.reset}\\n`);\n }\n };\n process.on('SIGINT', ctrlCHandler);\n\n this.executing = true;\n plan.status = 'executing';\n\n const startTime = Date.now();\n const completedTasks: string[] = [];\n const errors: string[] = [];\n\n try {\n for (let i = 0; i < plan.tasks.length; i++) {\n if (this.aborted) {\n this.promptService.warning('Execução cancelada pelo usuário');\n break;\n }\n\n const task = plan.tasks[i];\n\n // Verificar dependências\n const depsSatisfied = task.dependencies.every(depId => {\n const dep = this.taskService.getTask(depId);\n return dep && dep.status === TaskStatus.COMPLETED;\n });\n\n if (!depsSatisfied) {\n errors.push(`Task ${task.id}: dependências não satisfeitas`);\n continue;\n }\n\n // Executar tarefa\n console.log(`${Colors.primary}►${Colors.reset} ${Colors.bold}Executando: ${task.subject}${Colors.reset}`);\n console.log(` ${Colors.dim}${task.description}${Colors.reset}`);\n console.log('');\n\n this.taskService.updateTask(task.id, { status: TaskStatus.IN_PROGRESS });\n\n
|
|
1
|
+
{"version":3,"sources":["../../../../src/modules/tasks/services/plan-executor.service.ts"],"sourcesContent":["import { Injectable } from '@nestjs/common';\nimport { ModuleRef } from '@nestjs/core';\nimport { TaskManagementService } from './task-management.service';\nimport { PlanPersistenceService } from './plan-persistence.service';\nimport { PromptService } from '../../permissions/services/prompt.service';\nimport { Colors } from '../../repl/utils/theme';\nimport { Task, TaskStatus } from '../types/task.types';\n\n@Injectable()\nexport class PlanExecutorService {\n private executing = false;\n private aborted = false;\n private currentPlanFile: string | null = null;\n private deepAgent: any = null;\n\n constructor(\n private taskService: TaskManagementService,\n private planPersistence: PlanPersistenceService,\n private promptService: PromptService,\n private moduleRef: ModuleRef,\n ) {}\n\n private async getDeepAgent() {\n if (!this.deepAgent) {\n const { DeepAgentService } = await import('../../core/services/deep-agent.service');\n this.deepAgent = this.moduleRef.get(DeepAgentService, { strict: false });\n }\n return this.deepAgent;\n }\n\n async executePlan(planId: string, autoApprove: boolean): Promise<void> {\n const plan = this.taskService.getPlans().get(planId);\n if (!plan) {\n throw new Error('Plan not found');\n }\n\n // Salvar plano\n this.currentPlanFile = await this.planPersistence.savePlan(plan, autoApprove);\n this.promptService.info(`📝 Plano salvo: ${this.currentPlanFile}`);\n console.log('');\n\n // Setup Ctrl+C handler\n const ctrlCHandler = () => {\n if (this.executing) {\n this.aborted = true;\n console.log(`\\n${Colors.warning}⚠ Interrupção solicitada. Finalizando tarefa atual...${Colors.reset}\\n`);\n }\n };\n process.on('SIGINT', ctrlCHandler);\n\n this.executing = true;\n plan.status = 'executing';\n\n const startTime = Date.now();\n const completedTasks: string[] = [];\n const errors: string[] = [];\n\n try {\n for (let i = 0; i < plan.tasks.length; i++) {\n if (this.aborted) {\n this.promptService.warning('Execução cancelada pelo usuário');\n break;\n }\n\n const task = plan.tasks[i];\n\n // Verificar dependências\n const depsSatisfied = task.dependencies.every(depId => {\n const dep = this.taskService.getTask(depId);\n return dep && dep.status === TaskStatus.COMPLETED;\n });\n\n if (!depsSatisfied) {\n errors.push(`Task ${task.id}: dependências não satisfeitas`);\n continue;\n }\n\n // Executar tarefa\n console.log(`${Colors.primary}►${Colors.reset} ${Colors.bold}Executando: ${task.subject}${Colors.reset}`);\n console.log(` ${Colors.dim}${task.description}${Colors.reset}`);\n console.log('');\n\n this.taskService.updateTask(task.id, { status: TaskStatus.IN_PROGRESS, assignedAgent: 'main' });\n\n const deepAgent = await this.getDeepAgent();\n const result = await deepAgent.executeTask(task);\n\n if (!result.success) {\n errors.push(`Task ${task.id}: ${result.error || 'Falha na execução'}`);\n this.taskService.updateTask(task.id, { status: TaskStatus.FAILED });\n } else {\n this.taskService.updateTask(task.id, { status: TaskStatus.COMPLETED });\n completedTasks.push(task.id);\n console.log(` ${Colors.success}✓ Concluído${Colors.reset}`);\n }\n\n // Atualizar progresso no arquivo\n await this.planPersistence.updatePlanProgress(this.currentPlanFile!, {\n currentTask: i + 1,\n completedTasks: completedTasks.length,\n status: 'executing',\n });\n\n console.log('');\n }\n\n // Marcar plano como completo\n plan.status = 'completed';\n const duration = Date.now() - startTime;\n\n await this.planPersistence.markPlanCompleted(this.currentPlanFile!, {\n success: errors.length === 0,\n duration,\n errors: errors.length > 0 ? errors : undefined,\n });\n\n console.log('');\n console.log('='.repeat(60));\n this.promptService.success(`✓ Plano concluído em ${(duration / 1000).toFixed(1)}s`);\n console.log(` ${Colors.dim}${completedTasks.length}/${plan.tasks.length} tarefas completadas${Colors.reset}`);\n if (errors.length > 0) {\n console.log(` ${Colors.warning}${errors.length} erros${Colors.reset}`);\n }\n console.log('='.repeat(60));\n console.log('');\n\n } finally {\n this.executing = false;\n this.aborted = false;\n this.currentPlanFile = null;\n this.taskService.clearExecutionContext();\n process.removeListener('SIGINT', ctrlCHandler);\n }\n }\n\n isExecuting(): boolean {\n return this.executing;\n }\n\n abort(): void {\n this.aborted = true;\n }\n}\n"],"names":["PlanExecutorService","getDeepAgent","deepAgent","DeepAgentService","moduleRef","get","strict","executePlan","planId","autoApprove","plan","taskService","getPlans","Error","currentPlanFile","planPersistence","savePlan","promptService","info","console","log","ctrlCHandler","executing","aborted","Colors","warning","reset","process","on","status","startTime","Date","now","completedTasks","errors","i","tasks","length","task","depsSatisfied","dependencies","every","depId","dep","getTask","TaskStatus","COMPLETED","push","id","primary","bold","subject","dim","description","updateTask","IN_PROGRESS","assignedAgent","result","executeTask","success","error","FAILED","updatePlanProgress","currentTask","duration","markPlanCompleted","undefined","repeat","toFixed","clearExecutionContext","removeListener","isExecuting","abort"],"mappings":"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"}
|
|
@@ -9,6 +9,7 @@ Object.defineProperty(exports, "TaskManagementService", {
|
|
|
9
9
|
}
|
|
10
10
|
});
|
|
11
11
|
const _common = require("@nestjs/common");
|
|
12
|
+
const _events = require("events");
|
|
12
13
|
const _tasktypes = require("../types/task.types");
|
|
13
14
|
const _promptservice = require("../../permissions/services/prompt.service");
|
|
14
15
|
const _theme = require("../../repl/utils/theme");
|
|
@@ -43,6 +44,7 @@ let TaskManagementService = class TaskManagementService {
|
|
|
43
44
|
dep.blocks.push(id);
|
|
44
45
|
}
|
|
45
46
|
}
|
|
47
|
+
this.events.emit('task:created', task);
|
|
46
48
|
return task;
|
|
47
49
|
}
|
|
48
50
|
updateTask(taskId, options) {
|
|
@@ -58,6 +60,7 @@ let TaskManagementService = class TaskManagementService {
|
|
|
58
60
|
if (options.removeDependencies) {
|
|
59
61
|
task.dependencies = task.dependencies.filter((id)=>!options.removeDependencies?.includes(id));
|
|
60
62
|
}
|
|
63
|
+
if (options.assignedAgent !== undefined) task.assignedAgent = options.assignedAgent;
|
|
61
64
|
if (options.metadata) {
|
|
62
65
|
task.metadata = {
|
|
63
66
|
...task.metadata,
|
|
@@ -65,6 +68,11 @@ let TaskManagementService = class TaskManagementService {
|
|
|
65
68
|
};
|
|
66
69
|
}
|
|
67
70
|
task.updatedAt = Date.now();
|
|
71
|
+
this.events.emit('task:updated', task);
|
|
72
|
+
// Debug log for Kanban updates
|
|
73
|
+
if (options.status) {
|
|
74
|
+
process.stdout.write(`\r Task ${taskId} status updated to: ${options.status}\n`);
|
|
75
|
+
}
|
|
68
76
|
return task;
|
|
69
77
|
}
|
|
70
78
|
getTask(taskId) {
|
|
@@ -94,6 +102,7 @@ let TaskManagementService = class TaskManagementService {
|
|
|
94
102
|
createdAt: Date.now()
|
|
95
103
|
};
|
|
96
104
|
this.plans.set(id, plan);
|
|
105
|
+
this.events.emit('plan:created', plan);
|
|
97
106
|
return plan;
|
|
98
107
|
}
|
|
99
108
|
async approvePlan(planId) {
|
|
@@ -198,6 +207,7 @@ let TaskManagementService = class TaskManagementService {
|
|
|
198
207
|
const firstWord = subject.split(' ')[0].toLowerCase();
|
|
199
208
|
const rest = subject.slice(firstWord.length);
|
|
200
209
|
const gerundMap = {
|
|
210
|
+
// English
|
|
201
211
|
create: 'Creating',
|
|
202
212
|
add: 'Adding',
|
|
203
213
|
implement: 'Implementing',
|
|
@@ -208,9 +218,31 @@ let TaskManagementService = class TaskManagementService {
|
|
|
208
218
|
refactor: 'Refactoring',
|
|
209
219
|
test: 'Testing',
|
|
210
220
|
write: 'Writing',
|
|
211
|
-
read: 'Reading'
|
|
221
|
+
read: 'Reading',
|
|
222
|
+
// Portuguese
|
|
223
|
+
criar: 'Criando',
|
|
224
|
+
adicionar: 'Adicionando',
|
|
225
|
+
implementar: 'Implementando',
|
|
226
|
+
corrigir: 'Corrigindo',
|
|
227
|
+
atualizar: 'Atualizando',
|
|
228
|
+
remover: 'Removendo',
|
|
229
|
+
deletar: 'Deletando',
|
|
230
|
+
refatorar: 'Refatorando',
|
|
231
|
+
testar: 'Testando',
|
|
232
|
+
escrever: 'Escrevendo',
|
|
233
|
+
ler: 'Lendo',
|
|
234
|
+
analisar: 'Analisando',
|
|
235
|
+
fazer: 'Fazendo',
|
|
236
|
+
crie: 'Criando',
|
|
237
|
+
adicione: 'Adicionando',
|
|
238
|
+
implemente: 'Implementando',
|
|
239
|
+
corrija: 'Corrigindo',
|
|
240
|
+
atualize: 'Atualizando',
|
|
241
|
+
remova: 'Removendo',
|
|
242
|
+
analise: 'Analisando',
|
|
243
|
+
faça: 'Fazendo'
|
|
212
244
|
};
|
|
213
|
-
const gerund = gerundMap[firstWord] || subject + '
|
|
245
|
+
const gerund = gerundMap[firstWord] || (subject.length > 20 ? subject.slice(0, 20) + '...' : subject);
|
|
214
246
|
return gerund + rest;
|
|
215
247
|
}
|
|
216
248
|
clearCompletedTasks() {
|
|
@@ -237,6 +269,7 @@ let TaskManagementService = class TaskManagementService {
|
|
|
237
269
|
}
|
|
238
270
|
constructor(promptService){
|
|
239
271
|
this.promptService = promptService;
|
|
272
|
+
this.events = new _events.EventEmitter();
|
|
240
273
|
this.tasks = new Map();
|
|
241
274
|
this.plans = new Map();
|
|
242
275
|
this.taskCounter = 0;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/modules/tasks/services/task-management.service.ts"],"sourcesContent":["import { Injectable } from '@nestjs/common';\nimport {\n Task,\n TaskStatus,\n TaskPlan,\n CreateTaskOptions,\n UpdateTaskOptions,\n PlanApprovalOptions,\n PlanExecutionContext,\n} from '../types/task.types';\nimport { PromptService } from '../../permissions/services/prompt.service';\nimport { Colors } from '../../repl/utils/theme';\n\n\n@Injectable()\nexport class TaskManagementService {\n private tasks: Map<string, Task> = new Map();\n private plans: Map<string, TaskPlan> = new Map();\n private taskCounter = 0;\n private planCounter = 0;\n private executionContext: PlanExecutionContext | null = null;\n\n constructor(private promptService: PromptService) {}\n\n createTask(options: CreateTaskOptions): Task {\n const id = `task-${++this.taskCounter}`;\n\n const task: Task = {\n id,\n subject: options.subject,\n description: options.description,\n activeForm: options.activeForm || this.generateActiveForm(options.subject),\n status: TaskStatus.PENDING,\n createdAt: Date.now(),\n updatedAt: Date.now(),\n dependencies: options.dependencies || [],\n blocks: [],\n metadata: options.metadata || {},\n };\n\n this.tasks.set(id, task);\n\n for (const depId of task.dependencies) {\n const dep = this.tasks.get(depId);\n if (dep) {\n dep.blocks.push(id);\n }\n }\n\n return task;\n }\n\n updateTask(taskId: string, options: UpdateTaskOptions): Task | null {\n const task = this.tasks.get(taskId);\n if (!task) return null;\n\n if (options.status) task.status = options.status;\n if (options.subject) task.subject = options.subject;\n if (options.description) task.description = options.description;\n if (options.activeForm) task.activeForm = options.activeForm;\n\n if (options.addDependencies) {\n task.dependencies.push(...options.addDependencies);\n }\n\n if (options.removeDependencies) {\n task.dependencies = task.dependencies.filter(\n (id) => !options.removeDependencies?.includes(id),\n );\n }\n\n if (options.metadata) {\n task.metadata = { ...task.metadata, ...options.metadata };\n }\n\n task.updatedAt = Date.now();\n return task;\n }\n\n getTask(taskId: string): Task | null {\n return this.tasks.get(taskId) || null;\n }\n\n listTasks(): Task[] {\n return Array.from(this.tasks.values());\n }\n\n listPendingTasks(): Task[] {\n return this.listTasks().filter((task) => {\n if (task.status !== TaskStatus.PENDING) return false;\n\n return task.dependencies.every((depId) => {\n const dep = this.tasks.get(depId);\n return dep && dep.status === TaskStatus.COMPLETED;\n });\n });\n }\n\n createPlan(title: string, description: string, tasks: CreateTaskOptions[]): TaskPlan {\n const id = `plan-${++this.planCounter}`;\n\n const createdTasks = tasks.map((taskOpt) => this.createTask(taskOpt));\n\n const plan: TaskPlan = {\n id,\n title,\n description,\n tasks: createdTasks,\n status: 'draft',\n createdAt: Date.now(),\n };\n\n this.plans.set(id, plan);\n return plan;\n }\n\n async approvePlan(planId: string): Promise<PlanApprovalOptions> {\n const plan = this.plans.get(planId);\n if (!plan) {\n this.promptService.error('Plan not found');\n return { approved: false, autoApprove: false };\n }\n\n // Renderizar plano\n console.log('\\n' + '='.repeat(60));\n this.promptService.info(`📋 PLANO: ${plan.title}`);\n console.log('='.repeat(60));\n console.log('');\n console.log(plan.description);\n console.log('');\n console.log(`${Colors.bold}Tarefas (${plan.tasks.length}):${Colors.reset}`);\n console.log('');\n\n plan.tasks.forEach((task, index) => {\n const depInfo =\n task.dependencies.length > 0\n ? ` ${Colors.muted}(depende de: ${task.dependencies.join(', ')})${Colors.reset}`\n : '';\n console.log(` ${Colors.primary}${index + 1}.${Colors.reset} ${Colors.bold}${task.subject}${Colors.reset}${depInfo}`);\n console.log(` ${Colors.dim}${task.description}${Colors.reset}`);\n console.log('');\n });\n\n console.log('='.repeat(60));\n console.log('');\n\n // Opções aprimoradas\n const choices = [\n {\n key: 'approve',\n label: '1 - Sim',\n description: 'Executar o plano'\n },\n {\n key: 'auto-approve',\n label: '2 - Sim com auto-approve',\n description: 'Executar sem pedir aprovação em cada etapa'\n },\n {\n key: 'modify',\n label: '4 - Digite algo',\n description: 'Modificar o plano antes de executar'\n },\n {\n key: 'cancel',\n label: '3 - Não',\n description: 'Cancelar e não executar'\n },\n ];\n\n const choice = await this.promptService.choice('O que você deseja fazer?', choices);\n\n switch (choice) {\n case 'approve':\n plan.status = 'approved';\n this.promptService.success('✓ Plano aprovado! Iniciando execução...');\n return { approved: true, autoApprove: false };\n\n case 'auto-approve':\n plan.status = 'approved';\n this.promptService.success('✓ Plano aprovado com auto-approve! Execução automática ativada.');\n return { approved: true, autoApprove: true };\n\n case 'modify':\n const modification = await this.promptService.question(\n `${Colors.accent}Como deseja modificar o plano?${Colors.reset}`\n );\n plan.status = 'draft';\n return {\n approved: false,\n autoApprove: false,\n modificationRequested: modification\n };\n\n case 'cancel':\n plan.status = 'cancelled';\n this.promptService.info('Plano cancelado');\n return { approved: false, autoApprove: false };\n\n default:\n return { approved: false, autoApprove: false };\n }\n }\n\n async executePlan(planId: string): Promise<void> {\n const plan = this.plans.get(planId);\n if (!plan) {\n throw new Error('Plan not found');\n }\n\n if (plan.status !== 'approved') {\n throw new Error('Plan must be approved before execution');\n }\n\n plan.status = 'executing';\n this.promptService.info('Starting plan execution...');\n }\n\n private generateActiveForm(subject: string): string {\n const firstWord = subject.split(' ')[0].toLowerCase();\n const rest = subject.slice(firstWord.length);\n\n const gerundMap: Record<string, string> = {\n create: 'Creating',\n add: 'Adding',\n implement: 'Implementing',\n fix: 'Fixing',\n update: 'Updating',\n remove: 'Removing',\n delete: 'Deleting',\n refactor: 'Refactoring',\n test: 'Testing',\n write: 'Writing',\n read: 'Reading',\n };\n\n const gerund = gerundMap[firstWord] || subject + 'ing';\n return gerund + rest;\n }\n\n clearCompletedTasks(): void {\n for (const [id, task] of this.tasks.entries()) {\n if (task.status === TaskStatus.COMPLETED || task.status === TaskStatus.CANCELLED) {\n this.tasks.delete(id);\n }\n }\n }\n\n setExecutionContext(context: PlanExecutionContext): void {\n this.executionContext = context;\n }\n\n getExecutionContext(): PlanExecutionContext | null {\n return this.executionContext;\n }\n\n clearExecutionContext(): void {\n this.executionContext = null;\n }\n\n isAutoApproveActive(): boolean {\n return this.executionContext?.autoApprove ?? false;\n }\n\n getPlans(): Map<string, TaskPlan> {\n return this.plans;\n }\n}\n"],"names":["TaskManagementService","createTask","options","id","taskCounter","task","subject","description","activeForm","generateActiveForm","status","TaskStatus","PENDING","createdAt","Date","now","updatedAt","dependencies","blocks","metadata","tasks","set","depId","dep","get","push","updateTask","taskId","addDependencies","removeDependencies","filter","includes","getTask","listTasks","Array","from","values","listPendingTasks","every","COMPLETED","createPlan","title","planCounter","createdTasks","map","taskOpt","plan","plans","approvePlan","planId","promptService","error","approved","autoApprove","console","log","repeat","info","Colors","bold","length","reset","forEach","index","depInfo","muted","join","primary","dim","choices","key","label","choice","success","modification","question","accent","modificationRequested","executePlan","Error","firstWord","split","toLowerCase","rest","slice","gerundMap","create","add","implement","fix","update","remove","delete","refactor","test","write","read","gerund","clearCompletedTasks","entries","CANCELLED","setExecutionContext","context","executionContext","getExecutionContext","clearExecutionContext","isAutoApproveActive","getPlans","Map"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../../src/modules/tasks/services/task-management.service.ts"],"sourcesContent":["import { Injectable } from '@nestjs/common';\nimport { EventEmitter } from 'events';\nimport {\n Task,\n TaskStatus,\n TaskPlan,\n CreateTaskOptions,\n UpdateTaskOptions,\n PlanApprovalOptions,\n PlanExecutionContext,\n} from '../types/task.types';\nimport { PromptService } from '../../permissions/services/prompt.service';\nimport { Colors } from '../../repl/utils/theme';\n\n@Injectable()\nexport class TaskManagementService {\n readonly events = new EventEmitter();\n private tasks: Map<string, Task> = new Map();\n private plans: Map<string, TaskPlan> = new Map();\n private taskCounter = 0;\n private planCounter = 0;\n private executionContext: PlanExecutionContext | null = null;\n\n constructor(private promptService: PromptService) {}\n\n createTask(options: CreateTaskOptions): Task {\n const id = `task-${++this.taskCounter}`;\n\n const task: Task = {\n id,\n subject: options.subject,\n description: options.description,\n activeForm: options.activeForm || this.generateActiveForm(options.subject),\n status: TaskStatus.PENDING,\n createdAt: Date.now(),\n updatedAt: Date.now(),\n dependencies: options.dependencies || [],\n blocks: [],\n metadata: options.metadata || {},\n };\n\n this.tasks.set(id, task);\n\n for (const depId of task.dependencies) {\n const dep = this.tasks.get(depId);\n if (dep) {\n dep.blocks.push(id);\n }\n }\n\n this.events.emit('task:created', task);\n return task;\n }\n\n updateTask(taskId: string, options: UpdateTaskOptions): Task | null {\n const task = this.tasks.get(taskId);\n if (!task) return null;\n\n if (options.status) task.status = options.status;\n if (options.subject) task.subject = options.subject;\n if (options.description) task.description = options.description;\n if (options.activeForm) task.activeForm = options.activeForm;\n\n if (options.addDependencies) {\n task.dependencies.push(...options.addDependencies);\n }\n\n if (options.removeDependencies) {\n task.dependencies = task.dependencies.filter(\n (id) => !options.removeDependencies?.includes(id),\n );\n }\n\n if (options.assignedAgent !== undefined) task.assignedAgent = options.assignedAgent;\n\n if (options.metadata) {\n task.metadata = { ...task.metadata, ...options.metadata };\n }\n\n task.updatedAt = Date.now();\n this.events.emit('task:updated', task);\n \n // Debug log for Kanban updates\n if (options.status) {\n process.stdout.write(`\\r Task ${taskId} status updated to: ${options.status}\\n`);\n }\n\n return task;\n }\n\n getTask(taskId: string): Task | null {\n return this.tasks.get(taskId) || null;\n }\n\n listTasks(): Task[] {\n return Array.from(this.tasks.values());\n }\n\n listPendingTasks(): Task[] {\n return this.listTasks().filter((task) => {\n if (task.status !== TaskStatus.PENDING) return false;\n\n return task.dependencies.every((depId) => {\n const dep = this.tasks.get(depId);\n return dep && dep.status === TaskStatus.COMPLETED;\n });\n });\n }\n\n createPlan(title: string, description: string, tasks: CreateTaskOptions[]): TaskPlan {\n const id = `plan-${++this.planCounter}`;\n\n const createdTasks = tasks.map((taskOpt) => this.createTask(taskOpt));\n\n const plan: TaskPlan = {\n id,\n title,\n description,\n tasks: createdTasks,\n status: 'draft',\n createdAt: Date.now(),\n };\n\n this.plans.set(id, plan);\n this.events.emit('plan:created', plan);\n return plan;\n }\n\n async approvePlan(planId: string): Promise<PlanApprovalOptions> {\n const plan = this.plans.get(planId);\n if (!plan) {\n this.promptService.error('Plan not found');\n return { approved: false, autoApprove: false };\n }\n\n // Renderizar plano\n console.log('\\n' + '='.repeat(60));\n this.promptService.info(`📋 PLANO: ${plan.title}`);\n console.log('='.repeat(60));\n console.log('');\n console.log(plan.description);\n console.log('');\n console.log(`${Colors.bold}Tarefas (${plan.tasks.length}):${Colors.reset}`);\n console.log('');\n\n plan.tasks.forEach((task, index) => {\n const depInfo =\n task.dependencies.length > 0\n ? ` ${Colors.muted}(depende de: ${task.dependencies.join(', ')})${Colors.reset}`\n : '';\n console.log(` ${Colors.primary}${index + 1}.${Colors.reset} ${Colors.bold}${task.subject}${Colors.reset}${depInfo}`);\n console.log(` ${Colors.dim}${task.description}${Colors.reset}`);\n console.log('');\n });\n\n console.log('='.repeat(60));\n console.log('');\n\n // Opções aprimoradas\n const choices = [\n {\n key: 'approve',\n label: '1 - Sim',\n description: 'Executar o plano'\n },\n {\n key: 'auto-approve',\n label: '2 - Sim com auto-approve',\n description: 'Executar sem pedir aprovação em cada etapa'\n },\n {\n key: 'modify',\n label: '4 - Digite algo',\n description: 'Modificar o plano antes de executar'\n },\n {\n key: 'cancel',\n label: '3 - Não',\n description: 'Cancelar e não executar'\n },\n ];\n\n const choice = await this.promptService.choice('O que você deseja fazer?', choices);\n\n switch (choice) {\n case 'approve':\n plan.status = 'approved';\n this.promptService.success('✓ Plano aprovado! Iniciando execução...');\n return { approved: true, autoApprove: false };\n\n case 'auto-approve':\n plan.status = 'approved';\n this.promptService.success('✓ Plano aprovado com auto-approve! Execução automática ativada.');\n return { approved: true, autoApprove: true };\n\n case 'modify':\n const modification = await this.promptService.question(\n `${Colors.accent}Como deseja modificar o plano?${Colors.reset}`\n );\n plan.status = 'draft';\n return {\n approved: false,\n autoApprove: false,\n modificationRequested: modification\n };\n\n case 'cancel':\n plan.status = 'cancelled';\n this.promptService.info('Plano cancelado');\n return { approved: false, autoApprove: false };\n\n default:\n return { approved: false, autoApprove: false };\n }\n }\n\n async executePlan(planId: string): Promise<void> {\n const plan = this.plans.get(planId);\n if (!plan) {\n throw new Error('Plan not found');\n }\n\n if (plan.status !== 'approved') {\n throw new Error('Plan must be approved before execution');\n }\n\n plan.status = 'executing';\n this.promptService.info('Starting plan execution...');\n }\n\n private generateActiveForm(subject: string): string {\n const firstWord = subject.split(' ')[0].toLowerCase();\n const rest = subject.slice(firstWord.length);\n\n const gerundMap: Record<string, string> = {\n // English\n create: 'Creating',\n add: 'Adding',\n implement: 'Implementing',\n fix: 'Fixing',\n update: 'Updating',\n remove: 'Removing',\n delete: 'Deleting',\n refactor: 'Refactoring',\n test: 'Testing',\n write: 'Writing',\n read: 'Reading',\n // Portuguese\n criar: 'Criando',\n adicionar: 'Adicionando',\n implementar: 'Implementando',\n corrigir: 'Corrigindo',\n atualizar: 'Atualizando',\n remover: 'Removendo',\n deletar: 'Deletando',\n refatorar: 'Refatorando',\n testar: 'Testando',\n escrever: 'Escrevendo',\n ler: 'Lendo',\n analisar: 'Analisando',\n fazer: 'Fazendo',\n crie: 'Criando',\n adicione: 'Adicionando',\n implemente: 'Implementando',\n corrija: 'Corrigindo',\n atualize: 'Atualizando',\n remova: 'Removendo',\n analise: 'Analisando',\n faça: 'Fazendo',\n };\n\n const gerund = gerundMap[firstWord] || (subject.length > 20 ? subject.slice(0, 20) + '...' : subject);\n return gerund + rest;\n }\n\n clearCompletedTasks(): void {\n for (const [id, task] of this.tasks.entries()) {\n if (task.status === TaskStatus.COMPLETED || task.status === TaskStatus.CANCELLED) {\n this.tasks.delete(id);\n }\n }\n }\n\n setExecutionContext(context: PlanExecutionContext): void {\n this.executionContext = context;\n }\n\n getExecutionContext(): PlanExecutionContext | null {\n return this.executionContext;\n }\n\n clearExecutionContext(): void {\n this.executionContext = null;\n }\n\n isAutoApproveActive(): boolean {\n return this.executionContext?.autoApprove ?? false;\n }\n\n getPlans(): Map<string, TaskPlan> {\n return this.plans;\n }\n}\n"],"names":["TaskManagementService","createTask","options","id","taskCounter","task","subject","description","activeForm","generateActiveForm","status","TaskStatus","PENDING","createdAt","Date","now","updatedAt","dependencies","blocks","metadata","tasks","set","depId","dep","get","push","events","emit","updateTask","taskId","addDependencies","removeDependencies","filter","includes","assignedAgent","undefined","process","stdout","write","getTask","listTasks","Array","from","values","listPendingTasks","every","COMPLETED","createPlan","title","planCounter","createdTasks","map","taskOpt","plan","plans","approvePlan","planId","promptService","error","approved","autoApprove","console","log","repeat","info","Colors","bold","length","reset","forEach","index","depInfo","muted","join","primary","dim","choices","key","label","choice","success","modification","question","accent","modificationRequested","executePlan","Error","firstWord","split","toLowerCase","rest","slice","gerundMap","create","add","implement","fix","update","remove","delete","refactor","test","read","criar","adicionar","implementar","corrigir","atualizar","remover","deletar","refatorar","testar","escrever","ler","analisar","fazer","crie","adicione","implemente","corrija","atualize","remova","analise","faça","gerund","clearCompletedTasks","entries","CANCELLED","setExecutionContext","context","executionContext","getExecutionContext","clearExecutionContext","isAutoApproveActive","getPlans","EventEmitter","Map"],"mappings":"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"}
|