claude-mpm 4.2.43__py3-none-any.whl → 4.2.51__py3-none-any.whl
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.
- claude_mpm/VERSION +1 -1
- claude_mpm/agents/BASE_PM.md +117 -12
- claude_mpm/agents/INSTRUCTIONS.md +154 -10
- claude_mpm/agents/WORKFLOW.md +46 -1
- claude_mpm/agents/frontmatter_validator.py +20 -12
- claude_mpm/agents/templates/nextjs_engineer.json +277 -0
- claude_mpm/agents/templates/python_engineer.json +289 -0
- claude_mpm/agents/templates/react_engineer.json +11 -3
- claude_mpm/agents/templates/security.json +50 -9
- claude_mpm/cli/commands/agents.py +2 -2
- claude_mpm/cli/commands/uninstall.py +1 -2
- claude_mpm/cli/interactive/agent_wizard.py +3 -3
- claude_mpm/cli/parsers/agent_manager_parser.py +3 -3
- claude_mpm/cli/parsers/agents_parser.py +1 -1
- claude_mpm/constants.py +1 -1
- claude_mpm/core/api_validator.py +330 -0
- claude_mpm/core/error_handler.py +2 -4
- claude_mpm/core/file_utils.py +4 -12
- claude_mpm/core/framework_loader.py +22 -0
- claude_mpm/core/log_manager.py +8 -5
- claude_mpm/core/logger.py +1 -1
- claude_mpm/core/logging_utils.py +6 -6
- claude_mpm/core/unified_agent_registry.py +18 -4
- claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +188 -0
- claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +156 -0
- claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +38 -0
- claude_mpm/dashboard/react/components/shared/FilterBar.module.css +92 -0
- claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +248 -0
- claude_mpm/dashboard/static/archive/activity_dashboard_test.html +61 -0
- claude_mpm/dashboard/static/archive/test_activity_connection.html +179 -0
- claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +68 -0
- claude_mpm/dashboard/static/archive/test_dashboard.html +409 -0
- claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +519 -0
- claude_mpm/dashboard/static/archive/test_dashboard_verification.html +181 -0
- claude_mpm/dashboard/static/archive/test_file_data.html +315 -0
- claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +243 -0
- claude_mpm/dashboard/static/archive/test_file_tree_fix.html +234 -0
- claude_mpm/dashboard/static/archive/test_file_tree_rename.html +117 -0
- claude_mpm/dashboard/static/archive/test_file_tree_tab.html +115 -0
- claude_mpm/dashboard/static/archive/test_file_viewer.html +224 -0
- claude_mpm/dashboard/static/archive/test_final_activity.html +220 -0
- claude_mpm/dashboard/static/archive/test_tab_fix.html +139 -0
- claude_mpm/dashboard/static/built/assets/events.DjpNxWNo.css +1 -0
- claude_mpm/dashboard/static/built/components/activity-tree.js +1 -1
- claude_mpm/dashboard/static/built/components/agent-hierarchy.js +777 -0
- claude_mpm/dashboard/static/built/components/agent-inference.js +1 -1
- claude_mpm/dashboard/static/built/components/build-tracker.js +333 -0
- claude_mpm/dashboard/static/built/components/code-simple.js +857 -0
- claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +353 -0
- claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +235 -0
- claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +409 -0
- claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +435 -0
- claude_mpm/dashboard/static/built/components/code-viewer.js +2 -1076
- claude_mpm/dashboard/static/built/components/connection-debug.js +654 -0
- claude_mpm/dashboard/static/built/components/diff-viewer.js +891 -0
- claude_mpm/dashboard/static/built/components/event-processor.js +1 -1
- claude_mpm/dashboard/static/built/components/event-viewer.js +1 -1
- claude_mpm/dashboard/static/built/components/export-manager.js +1 -1
- claude_mpm/dashboard/static/built/components/file-change-tracker.js +443 -0
- claude_mpm/dashboard/static/built/components/file-change-viewer.js +690 -0
- claude_mpm/dashboard/static/built/components/file-tool-tracker.js +1 -1
- claude_mpm/dashboard/static/built/components/module-viewer.js +1 -1
- claude_mpm/dashboard/static/built/components/nav-bar.js +145 -0
- claude_mpm/dashboard/static/built/components/page-structure.js +429 -0
- claude_mpm/dashboard/static/built/components/session-manager.js +1 -1
- claude_mpm/dashboard/static/built/components/ui-state-manager.js +2 -465
- claude_mpm/dashboard/static/built/components/working-directory.js +1 -1
- claude_mpm/dashboard/static/built/connection-manager.js +536 -0
- claude_mpm/dashboard/static/built/dashboard.js +1 -1
- claude_mpm/dashboard/static/built/extension-error-handler.js +164 -0
- claude_mpm/dashboard/static/built/react/events.js +30 -0
- claude_mpm/dashboard/static/built/shared/dom-helpers.js +396 -0
- claude_mpm/dashboard/static/built/shared/event-bus.js +330 -0
- claude_mpm/dashboard/static/built/shared/event-filter-service.js +540 -0
- claude_mpm/dashboard/static/built/shared/logger.js +385 -0
- claude_mpm/dashboard/static/built/shared/page-structure.js +251 -0
- claude_mpm/dashboard/static/built/shared/tooltip-service.js +253 -0
- claude_mpm/dashboard/static/built/socket-client.js +1 -1
- claude_mpm/dashboard/static/built/tab-isolation-fix.js +185 -0
- claude_mpm/dashboard/static/css/dashboard.css +28 -5
- claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +1 -0
- claude_mpm/dashboard/static/dist/components/activity-tree.js +1 -1
- claude_mpm/dashboard/static/dist/components/agent-inference.js +1 -1
- claude_mpm/dashboard/static/dist/components/code-viewer.js +2 -0
- claude_mpm/dashboard/static/dist/components/event-processor.js +1 -1
- claude_mpm/dashboard/static/dist/components/event-viewer.js +1 -1
- claude_mpm/dashboard/static/dist/components/export-manager.js +1 -1
- claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +1 -1
- claude_mpm/dashboard/static/dist/components/module-viewer.js +1 -1
- claude_mpm/dashboard/static/dist/components/session-manager.js +1 -1
- claude_mpm/dashboard/static/dist/components/working-directory.js +1 -1
- claude_mpm/dashboard/static/dist/dashboard.js +1 -1
- claude_mpm/dashboard/static/dist/react/events.js +30 -0
- claude_mpm/dashboard/static/dist/socket-client.js +1 -1
- claude_mpm/dashboard/static/events.html +607 -0
- claude_mpm/dashboard/static/index.html +713 -0
- claude_mpm/dashboard/static/js/components/activity-tree.js +3 -17
- claude_mpm/dashboard/static/js/components/agent-hierarchy.js +4 -1
- claude_mpm/dashboard/static/js/components/agent-inference.js +3 -0
- claude_mpm/dashboard/static/js/components/build-tracker.js +8 -0
- claude_mpm/dashboard/static/js/components/code-viewer.js +387 -72
- claude_mpm/dashboard/static/js/components/event-processor.js +3 -0
- claude_mpm/dashboard/static/js/components/event-viewer.js +39 -2
- claude_mpm/dashboard/static/js/components/export-manager.js +3 -0
- claude_mpm/dashboard/static/js/components/file-tool-tracker.js +30 -10
- claude_mpm/dashboard/static/js/components/socket-manager.js +4 -0
- claude_mpm/dashboard/static/js/components/ui-state-manager.js +286 -108
- claude_mpm/dashboard/static/js/components/working-directory.js +3 -0
- claude_mpm/dashboard/static/js/dashboard.js +61 -49
- claude_mpm/dashboard/static/js/socket-client.js +12 -8
- claude_mpm/dashboard/static/js/stores/dashboard-store.js +562 -0
- claude_mpm/dashboard/static/js/tab-isolation-fix.js +185 -0
- claude_mpm/dashboard/static/legacy/activity.html +736 -0
- claude_mpm/dashboard/static/legacy/agents.html +786 -0
- claude_mpm/dashboard/static/legacy/files.html +747 -0
- claude_mpm/dashboard/static/legacy/tools.html +831 -0
- claude_mpm/dashboard/static/monitors-index.html +218 -0
- claude_mpm/dashboard/static/monitors.html +431 -0
- claude_mpm/dashboard/static/production/events.html +659 -0
- claude_mpm/dashboard/static/production/main.html +715 -0
- claude_mpm/dashboard/static/production/monitors.html +483 -0
- claude_mpm/dashboard/static/socket.io.min.js +7 -0
- claude_mpm/dashboard/static/socket.io.v4.8.1.backup.js +7 -0
- claude_mpm/dashboard/static/test-archive/dashboard.html +635 -0
- claude_mpm/dashboard/static/test-archive/debug-events.html +147 -0
- claude_mpm/dashboard/static/test-archive/test-navigation.html +256 -0
- claude_mpm/dashboard/static/test-archive/test-react-exports.html +180 -0
- claude_mpm/dashboard/templates/index.html +82 -38
- claude_mpm/hooks/claude_hooks/services/connection_manager_http.py +1 -1
- claude_mpm/services/agents/deployment/agent_discovery_service.py +3 -0
- claude_mpm/services/agents/deployment/agent_template_builder.py +25 -8
- claude_mpm/services/agents/deployment/agent_validator.py +3 -0
- claude_mpm/services/agents/deployment/validation/template_validator.py +13 -4
- claude_mpm/services/agents/local_template_manager.py +2 -6
- claude_mpm/services/monitor/daemon.py +1 -2
- claude_mpm/services/monitor/daemon_manager.py +2 -5
- claude_mpm/services/monitor/event_emitter.py +2 -2
- claude_mpm/services/monitor/handlers/code_analysis.py +4 -6
- claude_mpm/services/monitor/handlers/hooks.py +2 -4
- claude_mpm/services/monitor/server.py +23 -226
- claude_mpm/tools/code_tree_analyzer.py +2 -2
- {claude_mpm-4.2.43.dist-info → claude_mpm-4.2.51.dist-info}/METADATA +1 -1
- {claude_mpm-4.2.43.dist-info → claude_mpm-4.2.51.dist-info}/RECORD +148 -87
- claude_mpm/commands/mpm-browser-monitor.md +0 -370
- claude_mpm/commands/mpm-monitor.md +0 -177
- claude_mpm/dashboard/static/js/browser-console-monitor.js +0 -495
- claude_mpm/dashboard/static/js/components/browser-log-viewer.js +0 -763
- claude_mpm/dashboard/static/test-browser-monitor.html +0 -470
- claude_mpm/dashboard/static/test-simple.html +0 -97
- claude_mpm/services/monitor/handlers/browser.py +0 -451
- /claude_mpm/dashboard/static/{test_debug.html → test-archive/test_debug.html} +0 -0
- {claude_mpm-4.2.43.dist-info → claude_mpm-4.2.51.dist-info}/WHEEL +0 -0
- {claude_mpm-4.2.43.dist-info → claude_mpm-4.2.51.dist-info}/entry_points.txt +0 -0
- {claude_mpm-4.2.43.dist-info → claude_mpm-4.2.51.dist-info}/licenses/LICENSE +0 -0
- {claude_mpm-4.2.43.dist-info → claude_mpm-4.2.51.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,713 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html lang="en">
|
3
|
+
<head>
|
4
|
+
<meta charset="UTF-8">
|
5
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
6
|
+
<title>Claude MPM Dashboard Hub</title>
|
7
|
+
<link rel="icon" type="image/svg+xml" href="data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzIiIGhlaWdodD0iMzIiIHZpZXdCb3g9IjAgMCAzMiAzMiIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8cmVjdCB3aWR0aD0iMzIiIGhlaWdodD0iMzIiIHJ4PSI2IiBmaWxsPSIjNDI5OWUxIi8+CiAgPHRleHQgeD0iMTYiIHk9IjIxIiBmb250LWZhbWlseT0iSGVsdmV0aWNhLCBBcmlhbCwgc2Fucy1zZXJpZiIgZm9udC1zaXplPSIxMCIgZm9udC13ZWlnaHQ9ImJvbGQiIGZpbGw9IndoaXRlIiB0ZXh0LWFuY2hvcj0ibWlkZGxlIj5NUE08L3RleHQ+Cjwvc3ZnPgo=">
|
8
|
+
|
9
|
+
<!-- Font Awesome for icons -->
|
10
|
+
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css">
|
11
|
+
|
12
|
+
<style>
|
13
|
+
* {
|
14
|
+
margin: 0;
|
15
|
+
padding: 0;
|
16
|
+
box-sizing: border-box;
|
17
|
+
}
|
18
|
+
|
19
|
+
body {
|
20
|
+
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
|
21
|
+
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
|
22
|
+
min-height: 100vh;
|
23
|
+
padding: 20px;
|
24
|
+
}
|
25
|
+
|
26
|
+
.container {
|
27
|
+
max-width: 1400px;
|
28
|
+
margin: 0 auto;
|
29
|
+
animation: fadeIn 0.5s ease-in;
|
30
|
+
}
|
31
|
+
|
32
|
+
@keyframes fadeIn {
|
33
|
+
from { opacity: 0; transform: translateY(20px); }
|
34
|
+
to { opacity: 1; transform: translateY(0); }
|
35
|
+
}
|
36
|
+
|
37
|
+
.header {
|
38
|
+
background: rgba(255, 255, 255, 0.98);
|
39
|
+
border-radius: 20px;
|
40
|
+
padding: 40px;
|
41
|
+
text-align: center;
|
42
|
+
margin-bottom: 30px;
|
43
|
+
box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
|
44
|
+
}
|
45
|
+
|
46
|
+
.header h1 {
|
47
|
+
font-size: 2.5rem;
|
48
|
+
background: linear-gradient(135deg, #4299e1 0%, #667eea 100%);
|
49
|
+
-webkit-background-clip: text;
|
50
|
+
-webkit-text-fill-color: transparent;
|
51
|
+
margin-bottom: 10px;
|
52
|
+
display: flex;
|
53
|
+
align-items: center;
|
54
|
+
justify-content: center;
|
55
|
+
gap: 15px;
|
56
|
+
}
|
57
|
+
|
58
|
+
.header p {
|
59
|
+
font-size: 1.2rem;
|
60
|
+
color: #4a5568;
|
61
|
+
}
|
62
|
+
|
63
|
+
.stats-bar {
|
64
|
+
display: flex;
|
65
|
+
justify-content: center;
|
66
|
+
gap: 30px;
|
67
|
+
margin-top: 20px;
|
68
|
+
padding-top: 20px;
|
69
|
+
border-top: 1px solid #e2e8f0;
|
70
|
+
}
|
71
|
+
|
72
|
+
.stat-item {
|
73
|
+
display: flex;
|
74
|
+
align-items: center;
|
75
|
+
gap: 10px;
|
76
|
+
color: #4a5568;
|
77
|
+
}
|
78
|
+
|
79
|
+
.stat-value {
|
80
|
+
font-weight: 600;
|
81
|
+
color: #2d3748;
|
82
|
+
font-size: 1.2rem;
|
83
|
+
}
|
84
|
+
|
85
|
+
.main-section {
|
86
|
+
background: white;
|
87
|
+
border-radius: 20px;
|
88
|
+
padding: 40px;
|
89
|
+
margin-bottom: 30px;
|
90
|
+
box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
|
91
|
+
}
|
92
|
+
|
93
|
+
.section-header {
|
94
|
+
display: flex;
|
95
|
+
align-items: center;
|
96
|
+
gap: 15px;
|
97
|
+
margin-bottom: 25px;
|
98
|
+
padding-bottom: 15px;
|
99
|
+
border-bottom: 2px solid #e2e8f0;
|
100
|
+
}
|
101
|
+
|
102
|
+
.section-icon {
|
103
|
+
font-size: 2rem;
|
104
|
+
color: #4299e1;
|
105
|
+
}
|
106
|
+
|
107
|
+
.section-title {
|
108
|
+
font-size: 1.8rem;
|
109
|
+
color: #2d3748;
|
110
|
+
font-weight: 600;
|
111
|
+
}
|
112
|
+
|
113
|
+
.section-badge {
|
114
|
+
padding: 5px 12px;
|
115
|
+
border-radius: 20px;
|
116
|
+
font-size: 0.75rem;
|
117
|
+
font-weight: 600;
|
118
|
+
text-transform: uppercase;
|
119
|
+
letter-spacing: 0.5px;
|
120
|
+
margin-left: auto;
|
121
|
+
}
|
122
|
+
|
123
|
+
.badge-production {
|
124
|
+
background: linear-gradient(135deg, #48bb78 0%, #38a169 100%);
|
125
|
+
color: white;
|
126
|
+
}
|
127
|
+
|
128
|
+
.badge-development {
|
129
|
+
background: linear-gradient(135deg, #ed8936 0%, #dd6b20 100%);
|
130
|
+
color: white;
|
131
|
+
}
|
132
|
+
|
133
|
+
.badge-legacy {
|
134
|
+
background: #f7fafc;
|
135
|
+
color: #718096;
|
136
|
+
border: 1px solid #cbd5e0;
|
137
|
+
}
|
138
|
+
|
139
|
+
.dashboard-grid {
|
140
|
+
display: grid;
|
141
|
+
grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
|
142
|
+
gap: 20px;
|
143
|
+
}
|
144
|
+
|
145
|
+
.dashboard-card {
|
146
|
+
background: #f8f9fa;
|
147
|
+
border-radius: 12px;
|
148
|
+
padding: 20px;
|
149
|
+
border: 2px solid #e2e8f0;
|
150
|
+
transition: all 0.3s ease;
|
151
|
+
cursor: pointer;
|
152
|
+
position: relative;
|
153
|
+
overflow: hidden;
|
154
|
+
}
|
155
|
+
|
156
|
+
.dashboard-card::before {
|
157
|
+
content: '';
|
158
|
+
position: absolute;
|
159
|
+
top: 0;
|
160
|
+
left: 0;
|
161
|
+
width: 100%;
|
162
|
+
height: 4px;
|
163
|
+
background: linear-gradient(90deg, #4299e1, #667eea);
|
164
|
+
transform: translateX(-100%);
|
165
|
+
transition: transform 0.3s ease;
|
166
|
+
}
|
167
|
+
|
168
|
+
.dashboard-card:hover::before {
|
169
|
+
transform: translateX(0);
|
170
|
+
}
|
171
|
+
|
172
|
+
.dashboard-card:hover {
|
173
|
+
transform: translateY(-5px);
|
174
|
+
box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15);
|
175
|
+
border-color: #4299e1;
|
176
|
+
background: white;
|
177
|
+
}
|
178
|
+
|
179
|
+
.card-header {
|
180
|
+
display: flex;
|
181
|
+
align-items: flex-start;
|
182
|
+
gap: 15px;
|
183
|
+
margin-bottom: 15px;
|
184
|
+
}
|
185
|
+
|
186
|
+
.card-icon {
|
187
|
+
font-size: 2rem;
|
188
|
+
color: #4299e1;
|
189
|
+
background: rgba(66, 153, 225, 0.1);
|
190
|
+
padding: 10px;
|
191
|
+
border-radius: 10px;
|
192
|
+
}
|
193
|
+
|
194
|
+
.card-content {
|
195
|
+
flex: 1;
|
196
|
+
}
|
197
|
+
|
198
|
+
.card-title {
|
199
|
+
font-size: 1.3rem;
|
200
|
+
font-weight: 600;
|
201
|
+
color: #2d3748;
|
202
|
+
margin-bottom: 5px;
|
203
|
+
}
|
204
|
+
|
205
|
+
.card-subtitle {
|
206
|
+
font-size: 0.85rem;
|
207
|
+
color: #718096;
|
208
|
+
text-transform: uppercase;
|
209
|
+
letter-spacing: 0.5px;
|
210
|
+
}
|
211
|
+
|
212
|
+
.card-description {
|
213
|
+
color: #4a5568;
|
214
|
+
line-height: 1.6;
|
215
|
+
margin-bottom: 15px;
|
216
|
+
}
|
217
|
+
|
218
|
+
.card-features {
|
219
|
+
display: flex;
|
220
|
+
flex-wrap: wrap;
|
221
|
+
gap: 8px;
|
222
|
+
margin-bottom: 15px;
|
223
|
+
}
|
224
|
+
|
225
|
+
.feature-tag {
|
226
|
+
background: #edf2f7;
|
227
|
+
color: #4a5568;
|
228
|
+
padding: 4px 10px;
|
229
|
+
border-radius: 20px;
|
230
|
+
font-size: 0.75rem;
|
231
|
+
font-weight: 500;
|
232
|
+
}
|
233
|
+
|
234
|
+
.card-action {
|
235
|
+
display: inline-flex;
|
236
|
+
align-items: center;
|
237
|
+
gap: 8px;
|
238
|
+
padding: 10px 20px;
|
239
|
+
background: linear-gradient(135deg, #4299e1 0%, #667eea 100%);
|
240
|
+
color: white;
|
241
|
+
text-decoration: none;
|
242
|
+
border-radius: 8px;
|
243
|
+
font-weight: 600;
|
244
|
+
transition: all 0.3s ease;
|
245
|
+
}
|
246
|
+
|
247
|
+
.card-action:hover {
|
248
|
+
transform: translateX(5px);
|
249
|
+
box-shadow: 0 5px 15px rgba(66, 153, 225, 0.3);
|
250
|
+
}
|
251
|
+
|
252
|
+
.featured-card {
|
253
|
+
grid-column: span 2;
|
254
|
+
background: linear-gradient(135deg, #f6f9fc 0%, #e9f3ff 100%);
|
255
|
+
border: 2px solid #4299e1;
|
256
|
+
}
|
257
|
+
|
258
|
+
.featured-card .card-icon {
|
259
|
+
background: linear-gradient(135deg, #4299e1 0%, #667eea 100%);
|
260
|
+
color: white;
|
261
|
+
}
|
262
|
+
|
263
|
+
.info-section {
|
264
|
+
background: rgba(255, 255, 255, 0.98);
|
265
|
+
border-radius: 20px;
|
266
|
+
padding: 30px;
|
267
|
+
margin-top: 30px;
|
268
|
+
box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
|
269
|
+
}
|
270
|
+
|
271
|
+
.info-grid {
|
272
|
+
display: grid;
|
273
|
+
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
|
274
|
+
gap: 30px;
|
275
|
+
margin-top: 20px;
|
276
|
+
}
|
277
|
+
|
278
|
+
.info-card {
|
279
|
+
padding: 20px;
|
280
|
+
background: #f7fafc;
|
281
|
+
border-radius: 12px;
|
282
|
+
border-left: 4px solid #4299e1;
|
283
|
+
}
|
284
|
+
|
285
|
+
.info-card h3 {
|
286
|
+
color: #2d3748;
|
287
|
+
margin-bottom: 10px;
|
288
|
+
display: flex;
|
289
|
+
align-items: center;
|
290
|
+
gap: 10px;
|
291
|
+
}
|
292
|
+
|
293
|
+
.info-card ul {
|
294
|
+
list-style: none;
|
295
|
+
padding-left: 0;
|
296
|
+
}
|
297
|
+
|
298
|
+
.info-card li {
|
299
|
+
padding: 8px 0;
|
300
|
+
color: #4a5568;
|
301
|
+
display: flex;
|
302
|
+
align-items: flex-start;
|
303
|
+
gap: 8px;
|
304
|
+
}
|
305
|
+
|
306
|
+
.info-card li:before {
|
307
|
+
content: "•";
|
308
|
+
color: #4299e1;
|
309
|
+
font-weight: bold;
|
310
|
+
margin-top: 2px;
|
311
|
+
}
|
312
|
+
|
313
|
+
.footer {
|
314
|
+
text-align: center;
|
315
|
+
padding: 30px;
|
316
|
+
color: white;
|
317
|
+
opacity: 0.9;
|
318
|
+
}
|
319
|
+
|
320
|
+
.footer a {
|
321
|
+
color: white;
|
322
|
+
text-decoration: none;
|
323
|
+
font-weight: 600;
|
324
|
+
border-bottom: 2px solid transparent;
|
325
|
+
transition: border-color 0.3s ease;
|
326
|
+
}
|
327
|
+
|
328
|
+
.footer a:hover {
|
329
|
+
border-bottom-color: white;
|
330
|
+
}
|
331
|
+
|
332
|
+
@media (max-width: 768px) {
|
333
|
+
.featured-card {
|
334
|
+
grid-column: span 1;
|
335
|
+
}
|
336
|
+
|
337
|
+
.dashboard-grid {
|
338
|
+
grid-template-columns: 1fr;
|
339
|
+
}
|
340
|
+
|
341
|
+
.header h1 {
|
342
|
+
font-size: 2rem;
|
343
|
+
}
|
344
|
+
|
345
|
+
.stats-bar {
|
346
|
+
flex-direction: column;
|
347
|
+
gap: 15px;
|
348
|
+
}
|
349
|
+
}
|
350
|
+
</style>
|
351
|
+
</head>
|
352
|
+
<body>
|
353
|
+
<div class="container">
|
354
|
+
<!-- Header -->
|
355
|
+
<div class="header">
|
356
|
+
<h1>
|
357
|
+
<i class="fas fa-rocket"></i>
|
358
|
+
Claude MPM Dashboard Hub
|
359
|
+
</h1>
|
360
|
+
<p>Comprehensive monitoring and visualization for your AI-powered development workflow</p>
|
361
|
+
|
362
|
+
<div class="stats-bar">
|
363
|
+
<div class="stat-item">
|
364
|
+
<i class="fas fa-server"></i>
|
365
|
+
<span class="stat-value">3</span>
|
366
|
+
<span>Production Dashboards</span>
|
367
|
+
</div>
|
368
|
+
<div class="stat-item">
|
369
|
+
<i class="fas fa-code-branch"></i>
|
370
|
+
<span class="stat-value">3</span>
|
371
|
+
<span>Development Tools</span>
|
372
|
+
</div>
|
373
|
+
<div class="stat-item">
|
374
|
+
<i class="fas fa-archive"></i>
|
375
|
+
<span class="stat-value">4</span>
|
376
|
+
<span>Legacy Dashboards</span>
|
377
|
+
</div>
|
378
|
+
</div>
|
379
|
+
</div>
|
380
|
+
|
381
|
+
<!-- Production Dashboards -->
|
382
|
+
<div class="main-section">
|
383
|
+
<div class="section-header">
|
384
|
+
<i class="fas fa-chart-line section-icon"></i>
|
385
|
+
<h2 class="section-title">Production Dashboards</h2>
|
386
|
+
<span class="section-badge badge-production">Stable</span>
|
387
|
+
</div>
|
388
|
+
|
389
|
+
<div class="dashboard-grid">
|
390
|
+
<!-- Featured: Main Dashboard -->
|
391
|
+
<div class="dashboard-card featured-card">
|
392
|
+
<div class="card-header">
|
393
|
+
<div class="card-icon">
|
394
|
+
<i class="fas fa-desktop"></i>
|
395
|
+
</div>
|
396
|
+
<div class="card-content">
|
397
|
+
<h3 class="card-title">Integrated Dashboard</h3>
|
398
|
+
<p class="card-subtitle">Full-Featured Monitor</p>
|
399
|
+
</div>
|
400
|
+
</div>
|
401
|
+
<p class="card-description">
|
402
|
+
The main production dashboard with all monitoring capabilities in a single tabbed interface.
|
403
|
+
Features real-time WebSocket connections, activity visualization, comprehensive event tracking,
|
404
|
+
and file operation monitoring.
|
405
|
+
</p>
|
406
|
+
<div class="card-features">
|
407
|
+
<span class="feature-tag">WebSocket</span>
|
408
|
+
<span class="feature-tag">Activity Tree</span>
|
409
|
+
<span class="feature-tag">File Tracking</span>
|
410
|
+
<span class="feature-tag">Event Stream</span>
|
411
|
+
<span class="feature-tag">Agent Monitor</span>
|
412
|
+
</div>
|
413
|
+
<a href="/dashboard?autoconnect=true&port=8765" class="card-action">
|
414
|
+
Launch Main Dashboard
|
415
|
+
<i class="fas fa-arrow-right"></i>
|
416
|
+
</a>
|
417
|
+
</div>
|
418
|
+
|
419
|
+
<!-- Events Dashboard -->
|
420
|
+
<div class="dashboard-card">
|
421
|
+
<div class="card-header">
|
422
|
+
<div class="card-icon">
|
423
|
+
<i class="fas fa-stream"></i>
|
424
|
+
</div>
|
425
|
+
<div class="card-content">
|
426
|
+
<h3 class="card-title">Events Monitor</h3>
|
427
|
+
<p class="card-subtitle">Real-time Event Stream</p>
|
428
|
+
</div>
|
429
|
+
</div>
|
430
|
+
<p class="card-description">
|
431
|
+
Dedicated event streaming dashboard with React components for enhanced performance and real-time updates.
|
432
|
+
</p>
|
433
|
+
<div class="card-features">
|
434
|
+
<span class="feature-tag">React</span>
|
435
|
+
<span class="feature-tag">Real-time</span>
|
436
|
+
<span class="feature-tag">Filtering</span>
|
437
|
+
</div>
|
438
|
+
<a href="/static/production/events.html" class="card-action">
|
439
|
+
Open Events Monitor
|
440
|
+
<i class="fas fa-arrow-right"></i>
|
441
|
+
</a>
|
442
|
+
</div>
|
443
|
+
|
444
|
+
<!-- Monitors Dashboard -->
|
445
|
+
<div class="dashboard-card">
|
446
|
+
<div class="card-header">
|
447
|
+
<div class="card-icon">
|
448
|
+
<i class="fas fa-chart-bar"></i>
|
449
|
+
</div>
|
450
|
+
<div class="card-content">
|
451
|
+
<h3 class="card-title">System Monitors</h3>
|
452
|
+
<p class="card-subtitle">Performance Metrics</p>
|
453
|
+
</div>
|
454
|
+
</div>
|
455
|
+
<p class="card-description">
|
456
|
+
System performance monitoring with detailed metrics, resource usage tracking, and health indicators.
|
457
|
+
</p>
|
458
|
+
<div class="card-features">
|
459
|
+
<span class="feature-tag">Metrics</span>
|
460
|
+
<span class="feature-tag">Performance</span>
|
461
|
+
<span class="feature-tag">Health</span>
|
462
|
+
</div>
|
463
|
+
<a href="/static/production/monitors.html" class="card-action">
|
464
|
+
View Monitors
|
465
|
+
<i class="fas fa-arrow-right"></i>
|
466
|
+
</a>
|
467
|
+
</div>
|
468
|
+
</div>
|
469
|
+
</div>
|
470
|
+
|
471
|
+
<!-- Development & Testing -->
|
472
|
+
<div class="main-section">
|
473
|
+
<div class="section-header">
|
474
|
+
<i class="fas fa-flask section-icon"></i>
|
475
|
+
<h2 class="section-title">Development & Testing</h2>
|
476
|
+
<span class="section-badge badge-development">Beta</span>
|
477
|
+
</div>
|
478
|
+
|
479
|
+
<div class="dashboard-grid">
|
480
|
+
<!-- React Development -->
|
481
|
+
<div class="dashboard-card">
|
482
|
+
<div class="card-header">
|
483
|
+
<div class="card-icon">
|
484
|
+
<i class="fab fa-react"></i>
|
485
|
+
</div>
|
486
|
+
<div class="card-content">
|
487
|
+
<h3 class="card-title">React Dashboard</h3>
|
488
|
+
<p class="card-subtitle">Next Generation UI</p>
|
489
|
+
</div>
|
490
|
+
</div>
|
491
|
+
<p class="card-description">
|
492
|
+
New React-based dashboard under active development. Features modern UI components and enhanced performance.
|
493
|
+
</p>
|
494
|
+
<div class="card-features">
|
495
|
+
<span class="feature-tag">React 18</span>
|
496
|
+
<span class="feature-tag">TypeScript</span>
|
497
|
+
<span class="feature-tag">Vite</span>
|
498
|
+
</div>
|
499
|
+
<a href="/static/react/" class="card-action">
|
500
|
+
Preview React UI
|
501
|
+
<i class="fas fa-arrow-right"></i>
|
502
|
+
</a>
|
503
|
+
</div>
|
504
|
+
|
505
|
+
<!-- Monitor Index -->
|
506
|
+
<div class="dashboard-card">
|
507
|
+
<div class="card-header">
|
508
|
+
<div class="card-icon">
|
509
|
+
<i class="fas fa-th"></i>
|
510
|
+
</div>
|
511
|
+
<div class="card-content">
|
512
|
+
<h3 class="card-title">Monitor Index</h3>
|
513
|
+
<p class="card-subtitle">Overview Dashboard</p>
|
514
|
+
</div>
|
515
|
+
</div>
|
516
|
+
<p class="card-description">
|
517
|
+
Grid view of all monitoring capabilities, useful for testing and development of new monitor features.
|
518
|
+
</p>
|
519
|
+
<div class="card-features">
|
520
|
+
<span class="feature-tag">Grid Layout</span>
|
521
|
+
<span class="feature-tag">Testing</span>
|
522
|
+
</div>
|
523
|
+
<a href="/static/monitors-index.html" class="card-action">
|
524
|
+
Open Index
|
525
|
+
<i class="fas fa-arrow-right"></i>
|
526
|
+
</a>
|
527
|
+
</div>
|
528
|
+
|
529
|
+
<!-- Test Archive -->
|
530
|
+
<div class="dashboard-card">
|
531
|
+
<div class="card-header">
|
532
|
+
<div class="card-icon">
|
533
|
+
<i class="fas fa-vial"></i>
|
534
|
+
</div>
|
535
|
+
<div class="card-content">
|
536
|
+
<h3 class="card-title">Test Archive</h3>
|
537
|
+
<p class="card-subtitle">Historical Test Files</p>
|
538
|
+
</div>
|
539
|
+
</div>
|
540
|
+
<p class="card-description">
|
541
|
+
Archive of test dashboards and experimental features used during development.
|
542
|
+
</p>
|
543
|
+
<div class="card-features">
|
544
|
+
<span class="feature-tag">15+ Files</span>
|
545
|
+
<span class="feature-tag">Historical</span>
|
546
|
+
</div>
|
547
|
+
<a href="/static/test-archive/" class="card-action">
|
548
|
+
Browse Archive
|
549
|
+
<i class="fas fa-arrow-right"></i>
|
550
|
+
</a>
|
551
|
+
</div>
|
552
|
+
</div>
|
553
|
+
</div>
|
554
|
+
|
555
|
+
<!-- Legacy Dashboards -->
|
556
|
+
<div class="main-section">
|
557
|
+
<div class="section-header">
|
558
|
+
<i class="fas fa-history section-icon"></i>
|
559
|
+
<h2 class="section-title">Legacy Dashboards</h2>
|
560
|
+
<span class="section-badge badge-legacy">Vanilla JS</span>
|
561
|
+
</div>
|
562
|
+
|
563
|
+
<div class="dashboard-grid">
|
564
|
+
<!-- Activity Dashboard -->
|
565
|
+
<div class="dashboard-card">
|
566
|
+
<div class="card-header">
|
567
|
+
<div class="card-icon">
|
568
|
+
<i class="fas fa-tree"></i>
|
569
|
+
</div>
|
570
|
+
<div class="card-content">
|
571
|
+
<h3 class="card-title">Activity Tree</h3>
|
572
|
+
<p class="card-subtitle">Hierarchical View</p>
|
573
|
+
</div>
|
574
|
+
</div>
|
575
|
+
<p class="card-description">
|
576
|
+
Original activity visualization with tree structure. Lightweight vanilla JavaScript implementation.
|
577
|
+
</p>
|
578
|
+
<div class="card-features">
|
579
|
+
<span class="feature-tag">D3.js</span>
|
580
|
+
<span class="feature-tag">Lightweight</span>
|
581
|
+
</div>
|
582
|
+
<a href="/static/legacy/activity.html" class="card-action">
|
583
|
+
Open Activity Tree
|
584
|
+
<i class="fas fa-arrow-right"></i>
|
585
|
+
</a>
|
586
|
+
</div>
|
587
|
+
|
588
|
+
<!-- Agents Dashboard -->
|
589
|
+
<div class="dashboard-card">
|
590
|
+
<div class="card-header">
|
591
|
+
<div class="card-icon">
|
592
|
+
<i class="fas fa-robot"></i>
|
593
|
+
</div>
|
594
|
+
<div class="card-content">
|
595
|
+
<h3 class="card-title">Agents Monitor</h3>
|
596
|
+
<p class="card-subtitle">Agent Tracking</p>
|
597
|
+
</div>
|
598
|
+
</div>
|
599
|
+
<p class="card-description">
|
600
|
+
Monitor agent activities, interactions, and status. Original implementation without React.
|
601
|
+
</p>
|
602
|
+
<div class="card-features">
|
603
|
+
<span class="feature-tag">Agent Status</span>
|
604
|
+
<span class="feature-tag">Vanilla JS</span>
|
605
|
+
</div>
|
606
|
+
<a href="/static/legacy/agents.html" class="card-action">
|
607
|
+
View Agents
|
608
|
+
<i class="fas fa-arrow-right"></i>
|
609
|
+
</a>
|
610
|
+
</div>
|
611
|
+
|
612
|
+
<!-- Files Dashboard -->
|
613
|
+
<div class="dashboard-card">
|
614
|
+
<div class="card-header">
|
615
|
+
<div class="card-icon">
|
616
|
+
<i class="fas fa-folder-open"></i>
|
617
|
+
</div>
|
618
|
+
<div class="card-content">
|
619
|
+
<h3 class="card-title">Files Tracker</h3>
|
620
|
+
<p class="card-subtitle">File Operations</p>
|
621
|
+
</div>
|
622
|
+
</div>
|
623
|
+
<p class="card-description">
|
624
|
+
Track file operations, changes, and history. Simple and efficient file monitoring interface.
|
625
|
+
</p>
|
626
|
+
<div class="card-features">
|
627
|
+
<span class="feature-tag">File Ops</span>
|
628
|
+
<span class="feature-tag">History</span>
|
629
|
+
</div>
|
630
|
+
<a href="/static/legacy/files.html" class="card-action">
|
631
|
+
Track Files
|
632
|
+
<i class="fas fa-arrow-right"></i>
|
633
|
+
</a>
|
634
|
+
</div>
|
635
|
+
|
636
|
+
<!-- Tools Dashboard -->
|
637
|
+
<div class="dashboard-card">
|
638
|
+
<div class="card-header">
|
639
|
+
<div class="card-icon">
|
640
|
+
<i class="fas fa-tools"></i>
|
641
|
+
</div>
|
642
|
+
<div class="card-content">
|
643
|
+
<h3 class="card-title">Tools Monitor</h3>
|
644
|
+
<p class="card-subtitle">Tool Usage</p>
|
645
|
+
</div>
|
646
|
+
</div>
|
647
|
+
<p class="card-description">
|
648
|
+
Monitor tool usage, performance metrics, and execution history.
|
649
|
+
</p>
|
650
|
+
<div class="card-features">
|
651
|
+
<span class="feature-tag">Usage Stats</span>
|
652
|
+
<span class="feature-tag">Performance</span>
|
653
|
+
</div>
|
654
|
+
<a href="/static/legacy/tools.html" class="card-action">
|
655
|
+
Monitor Tools
|
656
|
+
<i class="fas fa-arrow-right"></i>
|
657
|
+
</a>
|
658
|
+
</div>
|
659
|
+
</div>
|
660
|
+
</div>
|
661
|
+
|
662
|
+
<!-- Information Section -->
|
663
|
+
<div class="info-section">
|
664
|
+
<h2 style="color: #2d3748; margin-bottom: 20px; text-align: center;">
|
665
|
+
<i class="fas fa-info-circle" style="color: #4299e1;"></i>
|
666
|
+
Quick Start Guide
|
667
|
+
</h2>
|
668
|
+
|
669
|
+
<div class="info-grid">
|
670
|
+
<div class="info-card">
|
671
|
+
<h3><i class="fas fa-rocket"></i> Getting Started</h3>
|
672
|
+
<ul>
|
673
|
+
<li>Start with the <strong>Integrated Dashboard</strong> for full monitoring</li>
|
674
|
+
<li>Ensure monitor server is running on port 8765</li>
|
675
|
+
<li>Dashboards auto-connect to WebSocket server</li>
|
676
|
+
<li>Use keyboard shortcuts for navigation (? for help)</li>
|
677
|
+
</ul>
|
678
|
+
</div>
|
679
|
+
|
680
|
+
<div class="info-card">
|
681
|
+
<h3><i class="fas fa-plug"></i> Connection Setup</h3>
|
682
|
+
<ul>
|
683
|
+
<li>Default WebSocket port: <strong>8765</strong></li>
|
684
|
+
<li>Auto-reconnect enabled on all dashboards</li>
|
685
|
+
<li>Check connection status in top bar</li>
|
686
|
+
<li>Manual reconnect available if needed</li>
|
687
|
+
</ul>
|
688
|
+
</div>
|
689
|
+
|
690
|
+
<div class="info-card">
|
691
|
+
<h3><i class="fas fa-layer-group"></i> Dashboard Types</h3>
|
692
|
+
<ul>
|
693
|
+
<li><strong>Production:</strong> Stable, fully-featured dashboards</li>
|
694
|
+
<li><strong>Development:</strong> Beta features and new UI</li>
|
695
|
+
<li><strong>Legacy:</strong> Original vanilla JS implementations</li>
|
696
|
+
<li><strong>Archive:</strong> Test files and experiments</li>
|
697
|
+
</ul>
|
698
|
+
</div>
|
699
|
+
</div>
|
700
|
+
</div>
|
701
|
+
|
702
|
+
<!-- Footer -->
|
703
|
+
<div class="footer">
|
704
|
+
<p>
|
705
|
+
<i class="fas fa-code"></i>
|
706
|
+
Claude MPM Dashboard Hub v4.2.44 |
|
707
|
+
<a href="https://github.com/bobmatnyc/claude-mpm" target="_blank">GitHub Repository</a> |
|
708
|
+
<a href="/docs" target="_blank">Documentation</a>
|
709
|
+
</p>
|
710
|
+
</div>
|
711
|
+
</div>
|
712
|
+
</body>
|
713
|
+
</html>
|