trackops 1.0.0 → 1.1.0
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/README.md +341 -232
- package/bin/trackops.js +102 -70
- package/lib/config.js +260 -35
- package/lib/control.js +518 -475
- package/lib/env.js +227 -0
- package/lib/i18n.js +61 -53
- package/lib/init.js +146 -55
- package/lib/locale.js +63 -0
- package/lib/opera-bootstrap.js +523 -0
- package/lib/opera.js +319 -170
- package/lib/registry.js +27 -13
- package/lib/release.js +56 -0
- package/lib/resources.js +42 -0
- package/lib/server.js +912 -418
- package/lib/skills.js +148 -124
- package/lib/workspace.js +260 -0
- package/locales/en.json +331 -139
- package/locales/es.json +331 -139
- package/package.json +14 -3
- package/scripts/skills-marketplace-smoke.js +124 -0
- package/scripts/smoke-tests.js +445 -0
- package/scripts/sync-skill-version.js +21 -0
- package/scripts/validate-skill.js +88 -0
- package/skills/trackops/SKILL.md +64 -0
- package/skills/trackops/agents/openai.yaml +3 -0
- package/skills/trackops/references/activation.md +39 -0
- package/skills/trackops/references/troubleshooting.md +34 -0
- package/skills/trackops/references/workflow.md +20 -0
- package/skills/trackops/scripts/bootstrap-trackops.js +201 -0
- package/skills/trackops/skill.json +29 -0
- package/templates/etapa/agent.md +2 -2
- package/templates/etapa/references/etapa-cycle.md +1 -1
- package/templates/opera/agent.md +1 -1
- package/templates/opera/en/agent.md +26 -0
- package/templates/opera/en/genesis.md +79 -0
- package/templates/opera/en/references/autonomy-and-recovery.md +23 -0
- package/templates/opera/en/references/opera-cycle.md +62 -0
- package/templates/opera/en/registry.md +28 -0
- package/templates/opera/en/router.md +39 -0
- package/templates/opera/genesis.md +79 -94
- package/templates/skills/changelog-updater/locales/en/SKILL.md +11 -0
- package/templates/skills/commiter/locales/en/SKILL.md +11 -0
- package/templates/skills/project-starter-skill/SKILL.md +5 -3
- package/templates/skills/project-starter-skill/locales/en/SKILL.md +24 -0
- package/ui/css/base.css +266 -0
- package/ui/css/charts.css +327 -0
- package/ui/css/components.css +570 -0
- package/ui/css/panels.css +956 -0
- package/ui/css/tokens.css +227 -0
- package/ui/favicon.svg +5 -0
- package/ui/index.html +91 -351
- package/ui/js/api.js +220 -0
- package/ui/js/app.js +200 -0
- package/ui/js/console-logger.js +172 -0
- package/ui/js/i18n.js +14 -0
- package/ui/js/icons.js +104 -0
- package/ui/js/onboarding.js +439 -0
- package/ui/js/router.js +125 -0
- package/ui/js/state.js +130 -0
- package/ui/js/theme.js +100 -0
- package/ui/js/time-tracker.js +248 -0
- package/ui/js/utils.js +175 -0
- package/ui/js/views/board.js +255 -0
- package/ui/js/views/execution.js +256 -0
- package/ui/js/views/flash.js +47 -0
- package/ui/js/views/insights.js +340 -0
- package/ui/js/views/overview.js +365 -0
- package/ui/js/views/settings.js +381 -0
- package/ui/js/views/sidebar.js +131 -0
- package/ui/js/views/skills.js +163 -0
- package/ui/js/views/tasks.js +406 -0
- package/ui/js/views/topbar.js +239 -0
|
@@ -0,0 +1,227 @@
|
|
|
1
|
+
/* ═══════════════════════════════════════════════════════
|
|
2
|
+
TRACKOPS DESIGN TOKENS
|
|
3
|
+
Coherentes con docs/index.html (identidad de marca web)
|
|
4
|
+
═══════════════════════════════════════════════════════ */
|
|
5
|
+
|
|
6
|
+
:root {
|
|
7
|
+
/* ── Colores base (marca web) ── */
|
|
8
|
+
--navy: #0A0F1E;
|
|
9
|
+
--navy-90: #0d1326;
|
|
10
|
+
--navy-80: #111827;
|
|
11
|
+
--slate: #1E293B;
|
|
12
|
+
--charcoal: #111111;
|
|
13
|
+
|
|
14
|
+
/* ── Accent (indigo) ── */
|
|
15
|
+
--accent: #6366F1;
|
|
16
|
+
--accent-light: rgba(99, 102, 241, 0.15);
|
|
17
|
+
--accent-glow: rgba(99, 102, 241, 0.30);
|
|
18
|
+
--accent-hover: #818CF8;
|
|
19
|
+
|
|
20
|
+
/* ── Superficies del dashboard ── */
|
|
21
|
+
--surface-0: #0A0F1E; /* fondo global */
|
|
22
|
+
--surface-1: #0d1326; /* sidebar + panel base */
|
|
23
|
+
--surface-2: #111827; /* cards */
|
|
24
|
+
--surface-3: #1a2234; /* hover cards */
|
|
25
|
+
--surface-4: rgba(255,255,255,0.04); /* inset sutil */
|
|
26
|
+
|
|
27
|
+
/* ── Texto ── */
|
|
28
|
+
--text-primary: #F1F5F9;
|
|
29
|
+
--text-secondary: #94A3B8;
|
|
30
|
+
--text-muted: #475569;
|
|
31
|
+
--text-accent: #818CF8;
|
|
32
|
+
|
|
33
|
+
/* ── Bordes ── */
|
|
34
|
+
--border: rgba(255,255,255,0.06);
|
|
35
|
+
--border-strong: rgba(255,255,255,0.12);
|
|
36
|
+
--border-accent: rgba(99,102,241,0.35);
|
|
37
|
+
|
|
38
|
+
/* ── Estado ── */
|
|
39
|
+
--success: #10B981;
|
|
40
|
+
--success-light: rgba(16, 185, 129, 0.12);
|
|
41
|
+
--warning: #F59E0B;
|
|
42
|
+
--warning-light: rgba(245, 158, 11, 0.12);
|
|
43
|
+
--danger: #EF4444;
|
|
44
|
+
--danger-light: rgba(239, 68, 68, 0.12);
|
|
45
|
+
--info: #3B82F6;
|
|
46
|
+
--info-light: rgba(59, 130, 246, 0.12);
|
|
47
|
+
|
|
48
|
+
/* ── Prioridades ── */
|
|
49
|
+
--p0: #EF4444;
|
|
50
|
+
--p1: #F59E0B;
|
|
51
|
+
--p2: #6366F1;
|
|
52
|
+
--p3: #475569;
|
|
53
|
+
|
|
54
|
+
/* ── Fuentes (coherentes con marca web) ── */
|
|
55
|
+
--font-ui: 'Outfit', system-ui, -apple-system, sans-serif;
|
|
56
|
+
--font-heading: 'Plus Jakarta Sans', 'Outfit', sans-serif;
|
|
57
|
+
--font-mono: 'JetBrains Mono', 'Cascadia Code', Consolas, monospace;
|
|
58
|
+
|
|
59
|
+
/* ── Tamaños de fuente (escala modular 1.25) ── */
|
|
60
|
+
--text-xs: 0.75rem; /* 12px */
|
|
61
|
+
--text-sm: 0.875rem; /* 14px */
|
|
62
|
+
--text-base: 1rem; /* 16px */
|
|
63
|
+
--text-md: 1.125rem; /* 18px */
|
|
64
|
+
--text-lg: 1.25rem; /* 20px */
|
|
65
|
+
--text-xl: 1.5rem; /* 24px */
|
|
66
|
+
--text-2xl: 1.875rem; /* 30px */
|
|
67
|
+
--text-3xl: 2.25rem; /* 36px */
|
|
68
|
+
|
|
69
|
+
/* ── Border Radius (marca web usa 3rem = super) ── */
|
|
70
|
+
--radius-xs: 0.375rem; /* 6px */
|
|
71
|
+
--radius-sm: 0.625rem; /* 10px */
|
|
72
|
+
--radius-md: 0.875rem; /* 14px */
|
|
73
|
+
--radius-lg: 1.25rem; /* 20px */
|
|
74
|
+
--radius-xl: 1.75rem; /* 28px */
|
|
75
|
+
--radius-2xl: 2rem; /* 32px */
|
|
76
|
+
--radius-super: 3rem; /* 48px */
|
|
77
|
+
--radius-full: 9999px;
|
|
78
|
+
|
|
79
|
+
/* ── Sombras ── */
|
|
80
|
+
--shadow-sm: 0 1px 3px rgba(0,0,0,0.4), 0 1px 2px rgba(0,0,0,0.3);
|
|
81
|
+
--shadow-md: 0 4px 20px rgba(0,0,0,0.35), 0 2px 8px rgba(0,0,0,0.25);
|
|
82
|
+
--shadow-lg: 0 12px 40px rgba(0,0,0,0.4), 0 4px 16px rgba(0,0,0,0.3);
|
|
83
|
+
--shadow-xl: 0 24px 60px rgba(0,0,0,0.5), 0 8px 24px rgba(0,0,0,0.35);
|
|
84
|
+
--shadow-accent: 0 8px 24px rgba(99,102,241,0.25);
|
|
85
|
+
--shadow-glow: 0 0 40px rgba(99,102,241,0.15);
|
|
86
|
+
|
|
87
|
+
/* ── Espaciado ── */
|
|
88
|
+
--space-1: 0.25rem; /* 4px */
|
|
89
|
+
--space-2: 0.5rem; /* 8px */
|
|
90
|
+
--space-3: 0.75rem; /* 12px */
|
|
91
|
+
--space-4: 1rem; /* 16px */
|
|
92
|
+
--space-5: 1.25rem; /* 20px */
|
|
93
|
+
--space-6: 1.5rem; /* 24px */
|
|
94
|
+
--space-8: 2rem; /* 32px */
|
|
95
|
+
--space-10: 2.5rem; /* 40px */
|
|
96
|
+
--space-12: 3rem; /* 48px */
|
|
97
|
+
--space-16: 4rem; /* 64px */
|
|
98
|
+
|
|
99
|
+
/* ── Layout ── */
|
|
100
|
+
--sidebar-width: 272px;
|
|
101
|
+
--topbar-height: 64px;
|
|
102
|
+
--content-pad: 24px;
|
|
103
|
+
|
|
104
|
+
/* ── Transiciones ── */
|
|
105
|
+
--ease-out: cubic-bezier(0.16, 1, 0.3, 1);
|
|
106
|
+
--ease-in: cubic-bezier(0.4, 0, 1, 1);
|
|
107
|
+
--ease-inout: cubic-bezier(0.4, 0, 0.2, 1);
|
|
108
|
+
--duration-fast: 120ms;
|
|
109
|
+
--duration-base: 200ms;
|
|
110
|
+
--duration-slow: 350ms;
|
|
111
|
+
--duration-slower: 600ms;
|
|
112
|
+
|
|
113
|
+
/* ── Z-index ── */
|
|
114
|
+
--z-base: 1;
|
|
115
|
+
--z-panel: 10;
|
|
116
|
+
--z-topbar: 20;
|
|
117
|
+
--z-sidebar: 30;
|
|
118
|
+
--z-modal: 40;
|
|
119
|
+
--z-toast: 50;
|
|
120
|
+
--z-onboard: 60;
|
|
121
|
+
}
|
|
122
|
+
/* ───────────────────────────────────
|
|
123
|
+
TEMA CLARO
|
|
124
|
+
Activo con: html[data-theme="light"]
|
|
125
|
+
─────────────────────────────────── */
|
|
126
|
+
[data-theme="light"] {
|
|
127
|
+
|
|
128
|
+
/* ── Superficies ── */
|
|
129
|
+
--surface-0: #F0F2F8; /* fondo global */
|
|
130
|
+
--surface-1: #FFFFFF; /* sidebar + panel base */
|
|
131
|
+
--surface-2: #F8F9FC; /* cards */
|
|
132
|
+
--surface-3: #EEF0F7; /* hover / inset */
|
|
133
|
+
--surface-4: rgba(0,0,0,0.04); /* inset sutil */
|
|
134
|
+
|
|
135
|
+
/* ── Texto ── */
|
|
136
|
+
--text-primary: #0D1117;
|
|
137
|
+
--text-secondary: #4A5568;
|
|
138
|
+
--text-muted: #9AA5B4;
|
|
139
|
+
--text-accent: #4F46E5;
|
|
140
|
+
|
|
141
|
+
/* ── Bordes ── */
|
|
142
|
+
--border: rgba(0,0,0,0.08);
|
|
143
|
+
--border-strong: rgba(0,0,0,0.14);
|
|
144
|
+
--border-accent: rgba(99,102,241,0.3);
|
|
145
|
+
|
|
146
|
+
/* ── Sombras (más suaves sobre fondos claros) ── */
|
|
147
|
+
--shadow-sm: 0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.05);
|
|
148
|
+
--shadow-md: 0 4px 20px rgba(0,0,0,0.08), 0 2px 8px rgba(0,0,0,0.06);
|
|
149
|
+
--shadow-lg: 0 12px 40px rgba(0,0,0,0.12), 0 4px 16px rgba(0,0,0,0.08);
|
|
150
|
+
--shadow-xl: 0 24px 60px rgba(0,0,0,0.15), 0 8px 24px rgba(0,0,0,0.10);
|
|
151
|
+
--shadow-accent: 0 8px 24px rgba(99,102,241,0.20);
|
|
152
|
+
|
|
153
|
+
/* ── Accent ajustado para legibilidad en claro ── */
|
|
154
|
+
--accent: #4F46E5;
|
|
155
|
+
--accent-hover: #6366F1;
|
|
156
|
+
--accent-light: rgba(79,70,229,0.10);
|
|
157
|
+
--accent-glow: rgba(79,70,229,0.20);
|
|
158
|
+
|
|
159
|
+
/* ── Estado (más saturados en claro) ── */
|
|
160
|
+
--success-light: rgba(5,150,105,0.10);
|
|
161
|
+
--warning-light: rgba(217,119,6,0.10);
|
|
162
|
+
--danger-light: rgba(220,38,38,0.10);
|
|
163
|
+
--info-light: rgba(37,99,235,0.10);
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
/* Ajustes específicos que no se pueden resolver solo con tokens */
|
|
167
|
+
|
|
168
|
+
/* Topbar en light */
|
|
169
|
+
[data-theme="light"] .topbar {
|
|
170
|
+
background: rgba(248,249,252,0.88);
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
/* Terminal siempre dark (legibilidad de código) */
|
|
174
|
+
[data-theme="light"] .terminal-surface,
|
|
175
|
+
[data-theme="light"] .terminal-output,
|
|
176
|
+
[data-theme="light"] .console-panel {
|
|
177
|
+
background: #1a1f2e;
|
|
178
|
+
color: #94D4BC;
|
|
179
|
+
}
|
|
180
|
+
[data-theme="light"] .terminal-header {
|
|
181
|
+
background: rgba(255,255,255,0.04);
|
|
182
|
+
border-bottom-color: rgba(255,255,255,0.04);
|
|
183
|
+
}
|
|
184
|
+
[data-theme="light"] .console-panel-header {
|
|
185
|
+
background: rgba(255,255,255,0.02);
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
/* Time tracker card en light */
|
|
189
|
+
[data-theme="light"] .time-tracker-card {
|
|
190
|
+
background: linear-gradient(135deg, #f0f2fb 0%, #ffffff 100%);
|
|
191
|
+
border-color: rgba(99,102,241,0.2);
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
/* Onboarding backdrop en light */
|
|
195
|
+
[data-theme="light"] .onboarding-backdrop {
|
|
196
|
+
background: rgba(0,0,0,0.45);
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
/* Sidebar logo icon sigue con gradiente oscuro */
|
|
200
|
+
[data-theme="light"] .sidebar-logo-icon {
|
|
201
|
+
box-shadow: 0 4px 12px rgba(79,70,229,0.3);
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
/* Topbar timer en light */
|
|
205
|
+
[data-theme="light"] .topbar-timer {
|
|
206
|
+
background: #F0F2F8;
|
|
207
|
+
border-color: rgba(0,0,0,0.10);
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
/* Modal en light */
|
|
211
|
+
[data-theme="light"] .modal {
|
|
212
|
+
background: #FFFFFF;
|
|
213
|
+
border-color: rgba(0,0,0,0.10);
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
/* Flash toast en light */
|
|
217
|
+
[data-theme="light"] .flash {
|
|
218
|
+
background: #FFFFFF;
|
|
219
|
+
border-color: rgba(0,0,0,0.10);
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
/* Transición suave al cambiar de tema */
|
|
223
|
+
html {
|
|
224
|
+
transition:
|
|
225
|
+
background-color var(--duration-slow) var(--ease-out),
|
|
226
|
+
color var(--duration-slow) var(--ease-out);
|
|
227
|
+
}
|
package/ui/favicon.svg
ADDED
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 32 32">
|
|
2
|
+
<rect width="32" height="32" rx="8" fill="#0F1117"/>
|
|
3
|
+
<path d="M16 16c-2.5-3.5-5-6-8-6a6 6 0 0 0 0 12c3 0 5.5-2.5 8-6z" fill="none" stroke="#6366F1" stroke-width="2.5" stroke-linecap="round"/>
|
|
4
|
+
<path d="M16 16c2.5 3.5 5 6 8 6a6 6 0 0 0 0-12c-3 0-5.5 2.5-8 6z" fill="none" stroke="#6366F1" stroke-width="2.5" stroke-linecap="round"/>
|
|
5
|
+
</svg>
|