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.
Files changed (72) hide show
  1. package/README.md +341 -232
  2. package/bin/trackops.js +102 -70
  3. package/lib/config.js +260 -35
  4. package/lib/control.js +518 -475
  5. package/lib/env.js +227 -0
  6. package/lib/i18n.js +61 -53
  7. package/lib/init.js +146 -55
  8. package/lib/locale.js +63 -0
  9. package/lib/opera-bootstrap.js +523 -0
  10. package/lib/opera.js +319 -170
  11. package/lib/registry.js +27 -13
  12. package/lib/release.js +56 -0
  13. package/lib/resources.js +42 -0
  14. package/lib/server.js +912 -418
  15. package/lib/skills.js +148 -124
  16. package/lib/workspace.js +260 -0
  17. package/locales/en.json +331 -139
  18. package/locales/es.json +331 -139
  19. package/package.json +14 -3
  20. package/scripts/skills-marketplace-smoke.js +124 -0
  21. package/scripts/smoke-tests.js +445 -0
  22. package/scripts/sync-skill-version.js +21 -0
  23. package/scripts/validate-skill.js +88 -0
  24. package/skills/trackops/SKILL.md +64 -0
  25. package/skills/trackops/agents/openai.yaml +3 -0
  26. package/skills/trackops/references/activation.md +39 -0
  27. package/skills/trackops/references/troubleshooting.md +34 -0
  28. package/skills/trackops/references/workflow.md +20 -0
  29. package/skills/trackops/scripts/bootstrap-trackops.js +201 -0
  30. package/skills/trackops/skill.json +29 -0
  31. package/templates/etapa/agent.md +2 -2
  32. package/templates/etapa/references/etapa-cycle.md +1 -1
  33. package/templates/opera/agent.md +1 -1
  34. package/templates/opera/en/agent.md +26 -0
  35. package/templates/opera/en/genesis.md +79 -0
  36. package/templates/opera/en/references/autonomy-and-recovery.md +23 -0
  37. package/templates/opera/en/references/opera-cycle.md +62 -0
  38. package/templates/opera/en/registry.md +28 -0
  39. package/templates/opera/en/router.md +39 -0
  40. package/templates/opera/genesis.md +79 -94
  41. package/templates/skills/changelog-updater/locales/en/SKILL.md +11 -0
  42. package/templates/skills/commiter/locales/en/SKILL.md +11 -0
  43. package/templates/skills/project-starter-skill/SKILL.md +5 -3
  44. package/templates/skills/project-starter-skill/locales/en/SKILL.md +24 -0
  45. package/ui/css/base.css +266 -0
  46. package/ui/css/charts.css +327 -0
  47. package/ui/css/components.css +570 -0
  48. package/ui/css/panels.css +956 -0
  49. package/ui/css/tokens.css +227 -0
  50. package/ui/favicon.svg +5 -0
  51. package/ui/index.html +91 -351
  52. package/ui/js/api.js +220 -0
  53. package/ui/js/app.js +200 -0
  54. package/ui/js/console-logger.js +172 -0
  55. package/ui/js/i18n.js +14 -0
  56. package/ui/js/icons.js +104 -0
  57. package/ui/js/onboarding.js +439 -0
  58. package/ui/js/router.js +125 -0
  59. package/ui/js/state.js +130 -0
  60. package/ui/js/theme.js +100 -0
  61. package/ui/js/time-tracker.js +248 -0
  62. package/ui/js/utils.js +175 -0
  63. package/ui/js/views/board.js +255 -0
  64. package/ui/js/views/execution.js +256 -0
  65. package/ui/js/views/flash.js +47 -0
  66. package/ui/js/views/insights.js +340 -0
  67. package/ui/js/views/overview.js +365 -0
  68. package/ui/js/views/settings.js +381 -0
  69. package/ui/js/views/sidebar.js +131 -0
  70. package/ui/js/views/skills.js +163 -0
  71. package/ui/js/views/tasks.js +406 -0
  72. 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>