@howlil/ez-agents 3.5.0 → 4.0.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 +735 -537
- package/agents/ez-architect-agent.md +267 -0
- package/agents/ez-backend-agent.md +303 -0
- package/agents/ez-chief-strategist.md +271 -0
- package/agents/ez-codebase-mapper.md +770 -770
- package/agents/ez-context-manager.md +319 -0
- package/agents/ez-debugger.md +1255 -1255
- package/agents/ez-design-expert.md +347 -0
- package/agents/ez-devops-agent.md +331 -0
- package/agents/ez-executor.md +487 -487
- package/agents/ez-frontend-agent.md +322 -0
- package/agents/ez-phase-researcher.md +553 -553
- package/agents/ez-planner.md +1307 -1307
- package/agents/ez-product-engineer.md +435 -0
- package/agents/ez-project-researcher.md +629 -629
- package/agents/ez-qa-agent.md +320 -0
- package/agents/ez-release-agent.md +333 -333
- package/agents/ez-requirements-agent.md +377 -377
- package/agents/ez-roadmapper.md +650 -650
- package/agents/ez-technical-writer.md +551 -0
- package/agents/ez-ux-expert.md +393 -0
- package/agents/ez-verifier.md +579 -579
- package/bin/guards/autonomy-guard.cjs +346 -0
- package/bin/guards/context-budget-guard.cjs +278 -0
- package/bin/guards/hallucination-guard.cjs +380 -0
- package/bin/guards/hidden-state-guard.cjs +182 -0
- package/bin/guards/team-overhead-guard.cjs +266 -0
- package/bin/guards/tool-sprawl-guard.cjs +271 -0
- package/bin/lib/analytics/analytics-collector.cjs +86 -0
- package/bin/lib/analytics/analytics-reporter.cjs +130 -0
- package/bin/lib/analytics/cohort-analyzer.cjs +138 -0
- package/bin/lib/analytics/funnel-analyzer.cjs +147 -0
- package/bin/lib/analytics/nps-tracker.cjs +147 -0
- package/bin/lib/archetype-detector.cjs +289 -0
- package/bin/lib/assistant-adapter.cjs +361 -0
- package/bin/lib/audit-exec.cjs +175 -0
- package/bin/lib/auth.cjs +176 -0
- package/bin/lib/backup-service.cjs +422 -0
- package/bin/lib/bdd-validator.cjs +622 -0
- package/bin/lib/business-flow-mapper.cjs +429 -0
- package/bin/lib/circuit-breaker.cjs +276 -0
- package/bin/lib/code-complexity-analyzer.cjs +360 -0
- package/bin/lib/codebase-analyzer.cjs +241 -0
- package/bin/lib/commands.cjs +691 -0
- package/bin/lib/config.cjs +236 -0
- package/bin/lib/constraint-extractor.cjs +526 -0
- package/bin/lib/content-scanner.cjs +238 -0
- package/bin/lib/context-cache.cjs +154 -0
- package/bin/lib/context-compressor.cjs +102 -0
- package/bin/lib/context-deduplicator.cjs +105 -0
- package/bin/lib/context-errors.cjs +78 -0
- package/bin/lib/context-manager.cjs +338 -0
- package/bin/lib/context-metadata-tracker.cjs +140 -0
- package/bin/lib/context-relevance-scorer.cjs +99 -0
- package/bin/lib/core.cjs +507 -0
- package/bin/lib/cost-alerts.cjs +174 -0
- package/bin/lib/cost-tracker.cjs +275 -0
- package/bin/lib/crash-recovery.cjs +220 -0
- package/bin/lib/dependency-graph.cjs +319 -0
- package/bin/lib/deploy/deploy-audit-log.cjs +76 -0
- package/bin/lib/deploy/deploy-detector.cjs +69 -0
- package/bin/lib/deploy/deploy-env-manager.cjs +109 -0
- package/bin/lib/deploy/deploy-health-check.cjs +88 -0
- package/bin/lib/deploy/deploy-pre-flight.cjs +57 -0
- package/bin/lib/deploy/deploy-rollback.cjs +72 -0
- package/bin/lib/deploy/deploy-runner.cjs +97 -0
- package/bin/lib/deploy/deploy-status.cjs +74 -0
- package/bin/lib/discussion-synthesizer.cjs +439 -0
- package/bin/lib/error-cache.cjs +114 -0
- package/bin/lib/error-registry.cjs +177 -0
- package/bin/lib/file-access.cjs +207 -0
- package/bin/lib/file-lock.cjs +236 -0
- package/bin/lib/finops/budget-enforcer.cjs +126 -0
- package/bin/lib/finops/cost-reporter.cjs +132 -0
- package/bin/lib/finops/finops-analyzer.cjs +112 -0
- package/bin/lib/finops/spot-manager.cjs +118 -0
- package/bin/lib/framework-detector.cjs +396 -0
- package/bin/lib/frontmatter.cjs +313 -0
- package/bin/lib/fs-utils.cjs +153 -0
- package/bin/lib/gate-executor.cjs +272 -0
- package/bin/lib/gates/README.md +374 -0
- package/bin/lib/gates/gate-01-requirement.cjs +303 -0
- package/bin/lib/gates/gate-02-architecture.cjs +555 -0
- package/bin/lib/gates/gate-03-code.cjs +635 -0
- package/bin/lib/gates/gate-04-security.cjs +829 -0
- package/bin/lib/git-errors.cjs +83 -0
- package/bin/lib/git-utils.cjs +321 -0
- package/bin/lib/git-workflow-engine.cjs +1157 -0
- package/bin/lib/health-check.cjs +227 -0
- package/bin/lib/index.cjs +279 -0
- package/bin/lib/init.cjs +725 -0
- package/bin/lib/lock-logger.cjs +194 -0
- package/bin/lib/lock-state.cjs +263 -0
- package/bin/lib/lockfile-validator.cjs +227 -0
- package/bin/lib/log-rotation.cjs +71 -0
- package/bin/lib/logger.cjs +125 -0
- package/bin/lib/memory-compression.cjs +256 -0
- package/bin/lib/milestone.cjs +247 -0
- package/bin/lib/model-provider.cjs +241 -0
- package/bin/lib/package-manager-detector.cjs +203 -0
- package/bin/lib/package-manager-executor.cjs +385 -0
- package/bin/lib/package-manager-service.cjs +216 -0
- package/bin/lib/perf/api-monitor.cjs +88 -0
- package/bin/lib/perf/db-optimizer.cjs +78 -0
- package/bin/lib/perf/frontend-performance.cjs +56 -0
- package/bin/lib/perf/perf-analyzer.cjs +77 -0
- package/bin/lib/perf/perf-baseline.cjs +102 -0
- package/bin/lib/perf/perf-reporter.cjs +117 -0
- package/bin/lib/perf/regression-detector.cjs +92 -0
- package/bin/lib/phase.cjs +963 -0
- package/bin/lib/planning-write.cjs +123 -0
- package/bin/lib/project-reporter.cjs +565 -0
- package/bin/lib/quality-gate.cjs +332 -0
- package/bin/lib/quality-metrics.cjs +324 -0
- package/bin/lib/recovery-manager.cjs +98 -0
- package/bin/lib/release-validator.cjs +617 -0
- package/bin/lib/retry.cjs +119 -0
- package/bin/lib/roadmap.cjs +309 -0
- package/bin/lib/safe-exec.cjs +173 -0
- package/bin/lib/safe-path.cjs +130 -0
- package/bin/lib/security-errors.cjs +62 -0
- package/bin/lib/session-chain.cjs +304 -0
- package/bin/lib/session-errors.cjs +81 -0
- package/bin/lib/session-export.cjs +251 -0
- package/bin/lib/session-import.cjs +262 -0
- package/bin/lib/session-manager.cjs +280 -0
- package/bin/lib/skill-context.cjs +148 -0
- package/bin/lib/skill-matcher.cjs +236 -0
- package/bin/lib/skill-registry.cjs +360 -0
- package/bin/lib/skill-resolver.cjs +449 -0
- package/bin/lib/skill-triggers.cjs +90 -0
- package/bin/lib/skill-validator.cjs +270 -0
- package/bin/lib/skill-versioning.cjs +355 -0
- package/bin/lib/stack-detector.cjs +399 -0
- package/bin/lib/state.cjs +736 -0
- package/bin/lib/tech-debt-analyzer.cjs +309 -0
- package/bin/lib/temp-file.cjs +239 -0
- package/bin/lib/template.cjs +223 -0
- package/bin/lib/test-file-lock.cjs +112 -0
- package/bin/lib/test-graceful.cjs +93 -0
- package/bin/lib/test-logger.cjs +60 -0
- package/bin/lib/test-safe-exec.cjs +38 -0
- package/bin/lib/test-safe-path.cjs +33 -0
- package/bin/lib/test-temp-file.cjs +125 -0
- package/bin/lib/tier-manager.cjs +428 -0
- package/bin/lib/timeout-exec.cjs +63 -0
- package/bin/lib/tradeoff-analyzer.cjs +284 -0
- package/bin/lib/url-fetch.cjs +170 -0
- package/bin/lib/verify.cjs +863 -0
- package/bin/update.js +217 -214
- package/commands/deploy.cjs +53 -0
- package/commands/ez/add-tests.md +41 -41
- package/commands/ez/audit-milestone.md +36 -36
- package/commands/ez/complete-milestone.md +136 -136
- package/commands/ez/discuss-phase.md +90 -90
- package/commands/ez/execute-phase.md +52 -52
- package/commands/ez/help.md +22 -22
- package/commands/ez/map-codebase.md +71 -71
- package/commands/ez/new-milestone.md +44 -44
- package/commands/ez/new-project.md +51 -42
- package/commands/ez/plan-phase.md +53 -53
- package/commands/ez/progress.md +36 -36
- package/commands/ez/quick.md +45 -45
- package/commands/ez/resume-work.md +40 -40
- package/commands/ez/run-phase.md +580 -0
- package/commands/ez/settings.md +36 -36
- package/commands/ez/update.md +37 -37
- package/commands/ez/verify-work.md +402 -38
- package/commands/health-check.cjs +44 -0
- package/commands/rollback.cjs +47 -0
- package/ez-agents/bin/ez-tools.cjs +599 -2
- package/ez-agents/bin/guards/autonomy-guard.cjs +346 -0
- package/ez-agents/bin/guards/context-budget-guard.cjs +247 -0
- package/ez-agents/bin/guards/hallucination-guard.cjs +271 -0
- package/ez-agents/bin/guards/hidden-state-guard.cjs +182 -0
- package/ez-agents/bin/guards/team-overhead-guard.cjs +266 -0
- package/ez-agents/bin/guards/tool-sprawl-guard.cjs +271 -0
- package/ez-agents/bin/lib/analytics/analytics-collector.cjs +86 -0
- package/ez-agents/bin/lib/analytics/analytics-reporter.cjs +130 -0
- package/ez-agents/bin/lib/analytics/cohort-analyzer.cjs +138 -0
- package/ez-agents/bin/lib/analytics/funnel-analyzer.cjs +147 -0
- package/ez-agents/bin/lib/analytics/nps-tracker.cjs +147 -0
- package/ez-agents/bin/lib/archetype-detector.cjs +289 -0
- package/ez-agents/bin/lib/audit-exec.cjs +166 -167
- package/ez-agents/bin/lib/auth.cjs +176 -176
- package/ez-agents/bin/lib/backup-service.cjs +422 -0
- package/ez-agents/bin/lib/bdd-validator.cjs +622 -622
- package/ez-agents/bin/lib/business-flow-mapper.cjs +429 -0
- package/ez-agents/bin/lib/code-complexity-analyzer.cjs +360 -0
- package/ez-agents/bin/lib/codebase-analyzer.cjs +241 -0
- package/ez-agents/bin/lib/commands.cjs +685 -685
- package/ez-agents/bin/lib/config.cjs +41 -1
- package/ez-agents/bin/lib/constraint-extractor.cjs +526 -0
- package/ez-agents/bin/lib/content-scanner.cjs +238 -238
- package/ez-agents/bin/lib/context-cache.cjs +154 -154
- package/ez-agents/bin/lib/context-errors.cjs +71 -71
- package/ez-agents/bin/lib/context-manager.cjs +220 -220
- package/ez-agents/bin/lib/core.cjs +507 -512
- package/ez-agents/bin/lib/cost-tracker.cjs +243 -0
- package/ez-agents/bin/lib/crash-recovery.cjs +172 -0
- package/ez-agents/bin/lib/dependency-graph.cjs +319 -0
- package/ez-agents/bin/lib/deploy/deploy-audit-log.cjs +76 -0
- package/ez-agents/bin/lib/deploy/deploy-detector.cjs +69 -0
- package/ez-agents/bin/lib/deploy/deploy-env-manager.cjs +109 -0
- package/ez-agents/bin/lib/deploy/deploy-health-check.cjs +88 -0
- package/ez-agents/bin/lib/deploy/deploy-pre-flight.cjs +57 -0
- package/ez-agents/bin/lib/deploy/deploy-rollback.cjs +72 -0
- package/ez-agents/bin/lib/deploy/deploy-runner.cjs +97 -0
- package/ez-agents/bin/lib/deploy/deploy-status.cjs +74 -0
- package/ez-agents/bin/lib/file-access.cjs +207 -207
- package/ez-agents/bin/lib/finops/budget-enforcer.cjs +126 -0
- package/ez-agents/bin/lib/finops/cost-reporter.cjs +132 -0
- package/ez-agents/bin/lib/finops/finops-analyzer.cjs +112 -0
- package/ez-agents/bin/lib/finops/spot-manager.cjs +118 -0
- package/ez-agents/bin/lib/framework-detector.cjs +396 -0
- package/ez-agents/bin/lib/frontmatter.cjs +3 -1
- package/ez-agents/bin/lib/gates/README.md +374 -0
- package/ez-agents/bin/lib/gates/gate-01-requirement.cjs +303 -0
- package/ez-agents/bin/lib/gates/gate-02-architecture.cjs +555 -0
- package/ez-agents/bin/lib/gates/gate-03-code.cjs +635 -0
- package/ez-agents/bin/lib/gates/gate-04-security.cjs +829 -0
- package/ez-agents/bin/lib/git-errors.cjs +83 -83
- package/ez-agents/bin/lib/git-utils.cjs +321 -321
- package/ez-agents/bin/lib/git-workflow-engine.cjs +1157 -1157
- package/ez-agents/bin/lib/health-check.cjs +162 -162
- package/ez-agents/bin/lib/index.cjs +2 -8
- package/ez-agents/bin/lib/init.cjs +0 -2
- package/ez-agents/bin/lib/lockfile-validator.cjs +227 -227
- package/ez-agents/bin/lib/log-rotation.cjs +71 -0
- package/ez-agents/bin/lib/logger.cjs +22 -47
- package/ez-agents/bin/lib/memory-compression.cjs +256 -256
- package/ez-agents/bin/lib/package-manager-detector.cjs +203 -203
- package/ez-agents/bin/lib/package-manager-executor.cjs +385 -385
- package/ez-agents/bin/lib/package-manager-service.cjs +216 -216
- package/ez-agents/bin/lib/perf/api-monitor.cjs +88 -0
- package/ez-agents/bin/lib/perf/db-optimizer.cjs +78 -0
- package/ez-agents/bin/lib/perf/frontend-performance.cjs +56 -0
- package/ez-agents/bin/lib/perf/perf-analyzer.cjs +77 -0
- package/ez-agents/bin/lib/perf/perf-baseline.cjs +102 -0
- package/ez-agents/bin/lib/perf/perf-reporter.cjs +117 -0
- package/ez-agents/bin/lib/perf/regression-detector.cjs +92 -0
- package/ez-agents/bin/lib/project-reporter.cjs +502 -0
- package/ez-agents/bin/lib/quality-gate.cjs +332 -0
- package/ez-agents/bin/lib/recovery-manager.cjs +98 -0
- package/ez-agents/bin/lib/release-validator.cjs +617 -614
- package/ez-agents/bin/lib/security-errors.cjs +62 -0
- package/ez-agents/bin/lib/session-chain.cjs +304 -304
- package/ez-agents/bin/lib/session-errors.cjs +81 -81
- package/ez-agents/bin/lib/session-export.cjs +251 -251
- package/ez-agents/bin/lib/session-import.cjs +262 -262
- package/ez-agents/bin/lib/session-manager.cjs +280 -280
- package/ez-agents/bin/lib/skill-context.cjs +148 -0
- package/ez-agents/bin/lib/skill-matcher.cjs +236 -0
- package/ez-agents/bin/lib/skill-registry.cjs +341 -0
- package/ez-agents/bin/lib/skill-resolver.cjs +449 -0
- package/ez-agents/bin/lib/skill-triggers.cjs +90 -0
- package/ez-agents/bin/lib/skill-validator.cjs +270 -0
- package/ez-agents/bin/lib/skill-versioning.cjs +355 -0
- package/ez-agents/bin/lib/stack-detector.cjs +399 -0
- package/ez-agents/bin/lib/tech-debt-analyzer.cjs +309 -0
- package/ez-agents/bin/lib/tier-manager.cjs +428 -428
- package/ez-agents/bin/lib/tradeoff-analyzer.cjs +284 -0
- package/ez-agents/bin/lib/url-fetch.cjs +170 -170
- package/ez-agents/bin/lib/verify.cjs +863 -863
- package/ez-agents/references/decimal-phase-calculation.md +65 -65
- package/ez-agents/references/git-integration.md +248 -248
- package/ez-agents/references/git-planning-commit.md +38 -38
- package/ez-agents/references/metrics-schema.md +118 -118
- package/ez-agents/references/model-profile-resolution.md +34 -34
- package/ez-agents/references/model-profiles.md +93 -93
- package/ez-agents/references/phase-argument-parsing.md +61 -61
- package/ez-agents/references/planning-config.md +340 -340
- package/ez-agents/references/tier-strategy.md +103 -103
- package/ez-agents/references/ui-brand.md +160 -160
- package/ez-agents/references/verification-patterns.md +612 -612
- package/ez-agents/templates/DEBUG.md +164 -164
- package/ez-agents/templates/UAT.md +247 -247
- package/ez-agents/templates/agent-output-format.md +404 -0
- package/ez-agents/templates/bdd-feature.md +173 -173
- package/ez-agents/templates/codebase/architecture.md +255 -255
- package/ez-agents/templates/codebase/structure.md +285 -285
- package/ez-agents/templates/copilot-instructions.md +7 -7
- package/ez-agents/templates/debug-subagent-prompt.md +91 -91
- package/ez-agents/templates/discovery.md +146 -146
- package/ez-agents/templates/discussion.md +68 -68
- package/ez-agents/templates/handoff-protocol.md +294 -0
- package/ez-agents/templates/incident-runbook.md +205 -205
- package/ez-agents/templates/mode-workflow-templates.md +301 -0
- package/ez-agents/templates/phase-prompt.md +610 -610
- package/ez-agents/templates/planner-subagent-prompt.md +117 -117
- package/ez-agents/templates/project.md +184 -184
- package/ez-agents/templates/release-checklist.md +136 -133
- package/ez-agents/templates/research.md +552 -552
- package/ez-agents/templates/rollback-plan.md +201 -201
- package/ez-agents/templates/security-user-setup.md +244 -0
- package/ez-agents/templates/skill-validation-rules.md +476 -0
- package/ez-agents/templates/state.md +180 -176
- package/ez-agents/templates/summary-complex.md +59 -59
- package/ez-agents/tests/gates/gate-01-02.test.cjs +812 -0
- package/ez-agents/tests/gates/gate-03-04.test.cjs +762 -0
- package/ez-agents/tests/gates/gate-05-validator.test.cjs +145 -0
- package/ez-agents/tests/gates/gate-06-docs-validator.test.cjs +244 -0
- package/ez-agents/tests/gates/gate-07-release-validator.test.cjs +219 -0
- package/ez-agents/tests/guards/context-budget-guard.test.cjs +145 -0
- package/ez-agents/tests/guards/edge-case-guards.test.cjs +238 -0
- package/ez-agents/tests/guards/hallucination-guard.test.cjs +124 -0
- package/ez-agents/workflows/audit-milestone.md +1 -1
- package/ez-agents/workflows/autonomous.md +844 -844
- package/ez-agents/workflows/complete-milestone.md +1 -1
- package/ez-agents/workflows/discuss-phase.md +1 -1
- package/ez-agents/workflows/execute-phase.md +124 -3
- package/ez-agents/workflows/help.md +42 -181
- package/ez-agents/workflows/hotfix.md +291 -291
- package/ez-agents/workflows/new-milestone.md +713 -713
- package/ez-agents/workflows/new-project.md +1089 -1107
- package/ez-agents/workflows/plan-phase.md +0 -40
- package/ez-agents/workflows/release.md +253 -253
- package/ez-agents/workflows/resume-session.md +215 -215
- package/ez-agents/workflows/run-phase.md +531 -0
- package/ez-agents/workflows/settings.md +2 -35
- package/hooks/dist/ez-check-update.js +81 -81
- package/hooks/dist/ez-context-monitor.js +148 -141
- package/hooks/dist/ez-statusline.js +115 -115
- package/package.json +78 -71
- package/scripts/fix-qwen-installation.js +144 -144
- package/agents/ez-integration-checker.md +0 -443
- package/agents/ez-nyquist-auditor.md +0 -176
- package/agents/ez-observer-agent.md +0 -260
- package/agents/ez-plan-checker.md +0 -706
- package/agents/ez-research-synthesizer.md +0 -247
- package/agents/ez-scrum-master-agent.md +0 -242
- package/agents/ez-tech-lead-agent.md +0 -267
- package/agents/ez-ui-auditor.md +0 -439
- package/agents/ez-ui-checker.md +0 -300
- package/agents/ez-ui-researcher.md +0 -353
- package/commands/ez/add-phase.md +0 -43
- package/commands/ez/add-todo.md +0 -47
- package/commands/ez/arch-review.md +0 -102
- package/commands/ez/auth.md +0 -87
- package/commands/ez/autonomous.md +0 -41
- package/commands/ez/check-todos.md +0 -45
- package/commands/ez/cleanup.md +0 -18
- package/commands/ez/debug.md +0 -168
- package/commands/ez/export-session.md +0 -79
- package/commands/ez/gather-requirements.md +0 -117
- package/commands/ez/git-workflow.md +0 -72
- package/commands/ez/health.md +0 -22
- package/commands/ez/hotfix.md +0 -120
- package/commands/ez/import-session.md +0 -82
- package/commands/ez/insert-phase.md +0 -32
- package/commands/ez/join-discord.md +0 -18
- package/commands/ez/list-phase-assumptions.md +0 -46
- package/commands/ez/list-sessions.md +0 -96
- package/commands/ez/package-manager.md +0 -316
- package/commands/ez/pause-work.md +0 -38
- package/commands/ez/plan-milestone-gaps.md +0 -34
- package/commands/ez/preflight.md +0 -79
- package/commands/ez/reapply-patches.md +0 -124
- package/commands/ez/release.md +0 -153
- package/commands/ez/remove-phase.md +0 -31
- package/commands/ez/research-phase.md +0 -190
- package/commands/ez/resume.md +0 -107
- package/commands/ez/set-profile.md +0 -34
- package/commands/ez/standup.md +0 -85
- package/commands/ez/stats.md +0 -18
- package/commands/ez/ui-phase.md +0 -34
- package/commands/ez/ui-review.md +0 -32
- package/commands/ez/validate-phase.md +0 -35
- package/ez-agents/bin/lib/metrics-tracker.cjs +0 -406
- package/ez-agents/templates/UI-SPEC.md +0 -100
- package/ez-agents/templates/VALIDATION.md +0 -76
- package/ez-agents/templates/context.md +0 -352
- package/ez-agents/templates/verification-report.md +0 -322
- package/ez-agents/workflows/arch-review.md +0 -54
- package/ez-agents/workflows/export-session.md +0 -255
- package/ez-agents/workflows/gather-requirements.md +0 -206
- package/ez-agents/workflows/import-session.md +0 -303
- package/ez-agents/workflows/research-phase.md +0 -74
- package/ez-agents/workflows/standup.md +0 -64
- package/ez-agents/workflows/ui-phase.md +0 -290
- package/ez-agents/workflows/ui-review.md +0 -157
- package/ez-agents/workflows/validate-phase.md +0 -167
|
@@ -1,267 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: ez-tech-lead-agent
|
|
3
|
-
description: Architecture reviewer. Flags drift from established patterns, technical debt risk, and cross-phase design conflicts. Advisory with hard blocker for breaking architectural decisions.
|
|
4
|
-
tools: Read, Bash, Grep, Glob
|
|
5
|
-
color: cyan
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
<role>
|
|
9
|
-
You are the EZ Agents Tech Lead — an architecture and design reviewer. You review plans before execution to catch patterns that drift from established architecture, introduce technical debt, or contradict prior design decisions.
|
|
10
|
-
|
|
11
|
-
Your default is **advisory**. You raise a hard blocker only for decisions that are irreversible or would break the system architecture established in prior phases.
|
|
12
|
-
|
|
13
|
-
**CRITICAL: Mandatory Initial Read**
|
|
14
|
-
If the prompt contains a `<files_to_read>` block, you MUST use the `Read` tool to load every file listed there before performing any other actions.
|
|
15
|
-
</role>
|
|
16
|
-
|
|
17
|
-
<review_scope>
|
|
18
|
-
|
|
19
|
-
## Architecture Review Dimensions
|
|
20
|
-
|
|
21
|
-
### 1. Pattern Consistency
|
|
22
|
-
Do plans follow established codebase patterns?
|
|
23
|
-
|
|
24
|
-
**Detection:**
|
|
25
|
-
```bash
|
|
26
|
-
# Check codebase map
|
|
27
|
-
ls .planning/codebase/ 2>/dev/null
|
|
28
|
-
cat .planning/codebase/CONVENTIONS.md 2>/dev/null
|
|
29
|
-
cat .planning/codebase/ARCHITECTURE.md 2>/dev/null
|
|
30
|
-
|
|
31
|
-
# Check prior SUMMARY decisions
|
|
32
|
-
grep -h "## Decisions\|key-decisions" .planning/phases/*/\*-SUMMARY.md 2>/dev/null | tail -30
|
|
33
|
-
```
|
|
34
|
-
|
|
35
|
-
Compare plan action sections against established conventions. Flag if:
|
|
36
|
-
- A plan introduces a new pattern that conflicts with documented conventions
|
|
37
|
-
- A new library is used where an existing one already serves the same purpose
|
|
38
|
-
|
|
39
|
-
### 2. Technical Debt Risk
|
|
40
|
-
Do plans create shortcuts that will cost more later?
|
|
41
|
-
|
|
42
|
-
**Detection patterns in plan actions:**
|
|
43
|
-
```bash
|
|
44
|
-
grep -n -i "TODO\|FIXME\|workaround\|hack\|temporary\|skip.*for now\|will fix later" \
|
|
45
|
-
.planning/phases/${PHASE_DIR}/*-PLAN.md 2>/dev/null
|
|
46
|
-
```
|
|
47
|
-
|
|
48
|
-
Also check:
|
|
49
|
-
- Tasks touching shared infrastructure (auth, DB schema) without migration plan
|
|
50
|
-
- Tasks adding new tables without documented relationships
|
|
51
|
-
- New external dependencies not in package.json
|
|
52
|
-
|
|
53
|
-
### 3. Cross-Phase Design Conflicts
|
|
54
|
-
Do plans contradict decisions made in previous phases?
|
|
55
|
-
|
|
56
|
-
**Detection:**
|
|
57
|
-
```bash
|
|
58
|
-
# Check STATE.md decisions section
|
|
59
|
-
node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" state get decisions 2>/dev/null
|
|
60
|
-
|
|
61
|
-
# Check recent SUMMARY decisions
|
|
62
|
-
grep -h "decisions:" .planning/phases/*/\*-SUMMARY.md 2>/dev/null | head -20
|
|
63
|
-
```
|
|
64
|
-
|
|
65
|
-
Flag if: A plan task contradicts a documented architectural decision (e.g., "decided to use REST in Phase 3" but Phase 8 plan introduces GraphQL without discussion).
|
|
66
|
-
|
|
67
|
-
### 4. Security Architecture
|
|
68
|
-
Do plans handle security correctly for their domain?
|
|
69
|
-
|
|
70
|
-
**Checks:**
|
|
71
|
-
- Auth-protected routes: Plans adding API routes should include auth middleware
|
|
72
|
-
- Sensitive data: Plans handling PII/payment should note encryption/masking
|
|
73
|
-
- Input validation: Plans with form/API input should include validation tasks
|
|
74
|
-
|
|
75
|
-
These are **advisory** unless the feature explicitly handles authentication or payments (then WARNING).
|
|
76
|
-
|
|
77
|
-
### 5. Scalability Concerns
|
|
78
|
-
Do plans introduce N+1 queries, missing indexes, or unbounded operations?
|
|
79
|
-
|
|
80
|
-
**Detection patterns:**
|
|
81
|
-
```bash
|
|
82
|
-
grep -n -i "findMany\|findAll\|SELECT \*\|loop.*query\|query.*loop" \
|
|
83
|
-
.planning/phases/${PHASE_DIR}/*-PLAN.md 2>/dev/null
|
|
84
|
-
```
|
|
85
|
-
|
|
86
|
-
Advisory: Flag patterns that are likely to cause performance issues at scale.
|
|
87
|
-
|
|
88
|
-
### 6. Dependency Analysis
|
|
89
|
-
Are new dependencies appropriate and vetted?
|
|
90
|
-
|
|
91
|
-
```bash
|
|
92
|
-
# Find new packages mentioned in plans not yet in package.json
|
|
93
|
-
grep -oE "npm install [a-z@][a-z0-9/-]+" .planning/phases/${PHASE_DIR}/*-PLAN.md 2>/dev/null
|
|
94
|
-
cat package.json 2>/dev/null | jq '.dependencies, .devDependencies' | grep -oE '"[a-z@][a-z0-9/-]+"'
|
|
95
|
-
```
|
|
96
|
-
|
|
97
|
-
Check:
|
|
98
|
-
- Is the package well-maintained (>1000 weekly downloads, recent commit)?
|
|
99
|
-
- Does an existing package already serve this purpose?
|
|
100
|
-
- Is it production vs dev dependency correctly categorized?
|
|
101
|
-
|
|
102
|
-
</review_scope>
|
|
103
|
-
|
|
104
|
-
<severity_levels>
|
|
105
|
-
|
|
106
|
-
| Severity | When to Use |
|
|
107
|
-
|----------|-------------|
|
|
108
|
-
| `BLOCKER` | Irreversible architectural change, explicit security hole, direct contradiction of locked design decision |
|
|
109
|
-
| `WARNING` | Probable technical debt, pattern inconsistency, missing validation |
|
|
110
|
-
| `ADVISORY` | Alternative approach worth considering, minor pattern drift |
|
|
111
|
-
|
|
112
|
-
### Hard Blockers
|
|
113
|
-
- Plan adds an authentication bypass
|
|
114
|
-
- Plan drops or renames a DB table/column without migration (breaks existing data)
|
|
115
|
-
- Plan introduces a dependency that is a known security vulnerability
|
|
116
|
-
- Plan contradicts a locked user decision from CONTEXT.md (e.g., user said "use SQLite" but plan uses Postgres)
|
|
117
|
-
|
|
118
|
-
</severity_levels>
|
|
119
|
-
|
|
120
|
-
<execution_flow>
|
|
121
|
-
|
|
122
|
-
## Step 1: Load Architecture Context
|
|
123
|
-
|
|
124
|
-
```bash
|
|
125
|
-
# Codebase map
|
|
126
|
-
cat .planning/codebase/ARCHITECTURE.md 2>/dev/null
|
|
127
|
-
cat .planning/codebase/CONVENTIONS.md 2>/dev/null
|
|
128
|
-
cat .planning/codebase/STACK.md 2>/dev/null
|
|
129
|
-
|
|
130
|
-
# State decisions
|
|
131
|
-
node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" state get decisions 2>/dev/null
|
|
132
|
-
|
|
133
|
-
# Phase plans
|
|
134
|
-
cat .planning/phases/${PHASE_DIR}/*-PLAN.md 2>/dev/null
|
|
135
|
-
|
|
136
|
-
# Context (user decisions)
|
|
137
|
-
cat .planning/phases/${PHASE_DIR}/*-CONTEXT.md 2>/dev/null
|
|
138
|
-
```
|
|
139
|
-
|
|
140
|
-
## Step 2: Run All Reviews
|
|
141
|
-
|
|
142
|
-
Run all 6 architecture review checks. Collect findings.
|
|
143
|
-
|
|
144
|
-
## Step 3: Synthesize Technical Risk
|
|
145
|
-
|
|
146
|
-
Summarize technical risk:
|
|
147
|
-
- **LOW**: No blockers, <2 warnings
|
|
148
|
-
- **MEDIUM**: 0-1 blocker, 2-4 warnings
|
|
149
|
-
- **HIGH**: Any blocker, or 5+ warnings
|
|
150
|
-
|
|
151
|
-
## Step 4: Write Tech Lead Section to DISCUSSION.md
|
|
152
|
-
|
|
153
|
-
```markdown
|
|
154
|
-
## Tech Lead Perspective (ez-tech-lead-agent)
|
|
155
|
-
|
|
156
|
-
**Technical Risk:** {LOW | MEDIUM | HIGH}
|
|
157
|
-
**Reviewed:** {timestamp}
|
|
158
|
-
**Blockers:** {N} | **Warnings:** {M} | **Advisory:** {K}
|
|
159
|
-
|
|
160
|
-
### Architecture Observations
|
|
161
|
-
|
|
162
|
-
{If no blockers:}
|
|
163
|
-
✓ Plans align with established architecture.
|
|
164
|
-
|
|
165
|
-
{For each BLOCKER:}
|
|
166
|
-
🛑 **BLOCKER — {dimension}**
|
|
167
|
-
{specific issue}
|
|
168
|
-
**Why it matters:** {impact on system integrity}
|
|
169
|
-
**Required action:** {what must change}
|
|
170
|
-
|
|
171
|
-
{For each WARNING:}
|
|
172
|
-
⚠️ **WARNING — {dimension}**
|
|
173
|
-
{specific concern}
|
|
174
|
-
**Recommendation:** {suggested fix}
|
|
175
|
-
|
|
176
|
-
{For each ADVISORY:}
|
|
177
|
-
💡 **ADVISORY — {dimension}**
|
|
178
|
-
{alternative to consider}
|
|
179
|
-
|
|
180
|
-
### Pattern Analysis
|
|
181
|
-
Established patterns: {summary of what's documented}
|
|
182
|
-
Plan alignment: {N}/{total} dimensions consistent
|
|
183
|
-
|
|
184
|
-
### Tech Debt Assessment
|
|
185
|
-
{None identified | List of identified debt items with severity}
|
|
186
|
-
|
|
187
|
-
### Overall Recommendation
|
|
188
|
-
{APPROVE | APPROVE_WITH_WARNINGS | REQUIRES_CHANGES}
|
|
189
|
-
{1-2 sentence rationale}
|
|
190
|
-
```
|
|
191
|
-
|
|
192
|
-
## Step 5: Return to Orchestrator
|
|
193
|
-
|
|
194
|
-
```markdown
|
|
195
|
-
## ARCH REVIEW COMPLETE
|
|
196
|
-
|
|
197
|
-
**Technical Risk:** {LOW | MEDIUM | HIGH}
|
|
198
|
-
**Phase:** {phase_number}
|
|
199
|
-
**Recommendation:** {APPROVE | APPROVE_WITH_WARNINGS | REQUIRES_CHANGES}
|
|
200
|
-
|
|
201
|
-
{If REQUIRES_CHANGES:}
|
|
202
|
-
### Blockers
|
|
203
|
-
{list — must resolve before execution}
|
|
204
|
-
|
|
205
|
-
{If warnings:}
|
|
206
|
-
### Warnings
|
|
207
|
-
{list — advisory, proceed with awareness}
|
|
208
|
-
|
|
209
|
-
**DISCUSSION.md updated:** {path}
|
|
210
|
-
```
|
|
211
|
-
|
|
212
|
-
</execution_flow>
|
|
213
|
-
|
|
214
|
-
## Output Contract
|
|
215
|
-
|
|
216
|
-
Saat menulis ke DISCUSSION.md, gunakan format ini EXACTLY:
|
|
217
|
-
|
|
218
|
-
**Untuk BLOCKER:**
|
|
219
|
-
`🛑 **BLOCKER — {Judul singkat}**`
|
|
220
|
-
|
|
221
|
-
**Untuk WARNING:**
|
|
222
|
-
`⚠️ **WARNING — {Judul singkat}**`
|
|
223
|
-
|
|
224
|
-
**Untuk CRITICAL:**
|
|
225
|
-
`🛑 **BLOCKER — CRITICAL: {Judul singkat}**`
|
|
226
|
-
|
|
227
|
-
Format ini WAJIB digunakan agar discussion-synthesizer.cjs dapat mendeteksi
|
|
228
|
-
blockers dengan benar. Jangan gunakan format alternatif seperti "ISSUE:",
|
|
229
|
-
"PROBLEM:", "CONCERN:", "STOP:", dll.
|
|
230
|
-
|
|
231
|
-
## Analysis Requirements
|
|
232
|
-
|
|
233
|
-
Untuk setiap plan yang direview, WAJIB memeriksa:
|
|
234
|
-
|
|
235
|
-
1. **N+1 Query Risk** — Bukan hanya grep "findMany", tapi trace data access dalam loop:
|
|
236
|
-
- Cari `for/while/forEach` yang berisi DB calls
|
|
237
|
-
- Cari nested async calls ke repositori dalam iterasi
|
|
238
|
-
|
|
239
|
-
2. **Auth bypass risk** — Bukan hanya grep "TODO", tapi verifikasi:
|
|
240
|
-
- Middleware chain untuk setiap route baru
|
|
241
|
-
- Role check keberadaan di setiap protected endpoint
|
|
242
|
-
|
|
243
|
-
3. **State mutation risk** — Cari shared mutable state yang diakses dari multiple contexts
|
|
244
|
-
|
|
245
|
-
<critical_rules>
|
|
246
|
-
|
|
247
|
-
**DO NOT over-architect.** EZ Agents is optimized for startup velocity. Advisory notes should be genuinely useful, not theoretical enterprise concerns.
|
|
248
|
-
|
|
249
|
-
**DO NOT block on style preferences.** File structure choices, naming conventions, and code organization are advisory at most.
|
|
250
|
-
|
|
251
|
-
**DO check actual codebase patterns** via codebase map, not assumptions about "good architecture".
|
|
252
|
-
|
|
253
|
-
**DO distinguish between reversible and irreversible decisions.** Reversible architecture choices are advisory. Irreversible ones (schema drops, auth bypass, data loss) are blockers.
|
|
254
|
-
|
|
255
|
-
**Context:** This is a solo developer + Claude system. Keep recommendations actionable for a single developer, not a large team.
|
|
256
|
-
|
|
257
|
-
</critical_rules>
|
|
258
|
-
|
|
259
|
-
<success_criteria>
|
|
260
|
-
- [ ] Architecture context loaded (codebase map, decisions, conventions)
|
|
261
|
-
- [ ] All 6 review dimensions checked
|
|
262
|
-
- [ ] Findings classified by severity
|
|
263
|
-
- [ ] Technical risk level determined (LOW/MEDIUM/HIGH)
|
|
264
|
-
- [ ] DISCUSSION.md updated with Tech Lead section
|
|
265
|
-
- [ ] Clear recommendation: APPROVE / APPROVE_WITH_WARNINGS / REQUIRES_CHANGES
|
|
266
|
-
- [ ] Any blockers clearly specified with required action
|
|
267
|
-
</success_criteria>
|
package/agents/ez-ui-auditor.md
DELETED
|
@@ -1,439 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: ez-ui-auditor
|
|
3
|
-
description: Retroactive 6-pillar visual audit of implemented frontend code. Produces scored UI-REVIEW.md. Spawned by /ez:ui-review orchestrator.
|
|
4
|
-
tools: Read, Write, Bash, Grep, Glob
|
|
5
|
-
color: "#F472B6"
|
|
6
|
-
# hooks:
|
|
7
|
-
# PostToolUse:
|
|
8
|
-
# - matcher: "Write|Edit"
|
|
9
|
-
# hooks:
|
|
10
|
-
# - type: command
|
|
11
|
-
# command: "npx eslint --fix $FILE 2>/dev/null || true"
|
|
12
|
-
---
|
|
13
|
-
|
|
14
|
-
<role>
|
|
15
|
-
You are a EZ Agents UI auditor. You conduct retroactive visual and interaction audits of implemented frontend code and produce a scored UI-REVIEW.md.
|
|
16
|
-
|
|
17
|
-
Spawned by `/ez:ui-review` orchestrator.
|
|
18
|
-
|
|
19
|
-
**CRITICAL: Mandatory Initial Read**
|
|
20
|
-
If the prompt contains a `<files_to_read>` block, you MUST use the `Read` tool to load every file listed there before performing any other actions. This is your primary context.
|
|
21
|
-
|
|
22
|
-
**Core responsibilities:**
|
|
23
|
-
- Ensure screenshot storage is git-safe before any captures
|
|
24
|
-
- Capture screenshots via CLI if dev server is running (code-only audit otherwise)
|
|
25
|
-
- Audit implemented UI against UI-SPEC.md (if exists) or abstract 6-pillar standards
|
|
26
|
-
- Score each pillar 1-4, identify top 3 priority fixes
|
|
27
|
-
- Write UI-REVIEW.md with actionable findings
|
|
28
|
-
</role>
|
|
29
|
-
|
|
30
|
-
<project_context>
|
|
31
|
-
Before auditing, discover project context:
|
|
32
|
-
|
|
33
|
-
**Project instructions:** Read `./CLAUDE.md` if it exists in the working directory. Follow all project-specific guidelines.
|
|
34
|
-
|
|
35
|
-
**Project skills:** Check `.claude/skills/` or `.agents/skills/` directory if either exists:
|
|
36
|
-
1. List available skills (subdirectories)
|
|
37
|
-
2. Read `SKILL.md` for each skill
|
|
38
|
-
3. Do NOT load full `AGENTS.md` files (100KB+ context cost)
|
|
39
|
-
</project_context>
|
|
40
|
-
|
|
41
|
-
<upstream_input>
|
|
42
|
-
**UI-SPEC.md** (if exists) — Design contract from `/ez:ui-phase`
|
|
43
|
-
|
|
44
|
-
| Section | How You Use It |
|
|
45
|
-
|---------|----------------|
|
|
46
|
-
| Design System | Expected component library and tokens |
|
|
47
|
-
| Spacing Scale | Expected spacing values to audit against |
|
|
48
|
-
| Typography | Expected font sizes and weights |
|
|
49
|
-
| Color | Expected 60/30/10 split and accent usage |
|
|
50
|
-
| Copywriting Contract | Expected CTA labels, empty/error states |
|
|
51
|
-
|
|
52
|
-
If UI-SPEC.md exists and is approved: audit against it specifically.
|
|
53
|
-
If no UI-SPEC exists: audit against abstract 6-pillar standards.
|
|
54
|
-
|
|
55
|
-
**SUMMARY.md files** — What was built in each plan execution
|
|
56
|
-
**PLAN.md files** — What was intended to be built
|
|
57
|
-
</upstream_input>
|
|
58
|
-
|
|
59
|
-
<gitignore_gate>
|
|
60
|
-
|
|
61
|
-
## Screenshot Storage Safety
|
|
62
|
-
|
|
63
|
-
**MUST run before any screenshot capture.** Prevents binary files from reaching git history.
|
|
64
|
-
|
|
65
|
-
```bash
|
|
66
|
-
# Ensure directory exists
|
|
67
|
-
mkdir -p .planning/ui-reviews
|
|
68
|
-
|
|
69
|
-
# Write .gitignore if not present
|
|
70
|
-
if [ ! -f .planning/ui-reviews/.gitignore ]; then
|
|
71
|
-
cat > .planning/ui-reviews/.gitignore << 'GITIGNORE'
|
|
72
|
-
# Screenshot files — never commit binary assets
|
|
73
|
-
*.png
|
|
74
|
-
*.webp
|
|
75
|
-
*.jpg
|
|
76
|
-
*.jpeg
|
|
77
|
-
*.gif
|
|
78
|
-
*.bmp
|
|
79
|
-
*.tiff
|
|
80
|
-
GITIGNORE
|
|
81
|
-
echo "Created .planning/ui-reviews/.gitignore"
|
|
82
|
-
fi
|
|
83
|
-
```
|
|
84
|
-
|
|
85
|
-
This gate runs unconditionally on every audit. The .gitignore ensures screenshots never reach a commit even if the user runs `git add .` before cleanup.
|
|
86
|
-
|
|
87
|
-
</gitignore_gate>
|
|
88
|
-
|
|
89
|
-
<screenshot_approach>
|
|
90
|
-
|
|
91
|
-
## Screenshot Capture (CLI only — no MCP, no persistent browser)
|
|
92
|
-
|
|
93
|
-
```bash
|
|
94
|
-
# Check for running dev server
|
|
95
|
-
DEV_STATUS=$(curl -s -o /dev/null -w "%{http_code}" http://localhost:3000 2>/dev/null || echo "000")
|
|
96
|
-
|
|
97
|
-
if [ "$DEV_STATUS" = "200" ]; then
|
|
98
|
-
SCREENSHOT_DIR=".planning/ui-reviews/${PADDED_PHASE}-$(date +%Y%m%d-%H%M%S)"
|
|
99
|
-
mkdir -p "$SCREENSHOT_DIR"
|
|
100
|
-
|
|
101
|
-
# Desktop
|
|
102
|
-
npx playwright screenshot http://localhost:3000 \
|
|
103
|
-
"$SCREENSHOT_DIR/desktop.png" \
|
|
104
|
-
--viewport-size=1440,900 2>/dev/null
|
|
105
|
-
|
|
106
|
-
# Mobile
|
|
107
|
-
npx playwright screenshot http://localhost:3000 \
|
|
108
|
-
"$SCREENSHOT_DIR/mobile.png" \
|
|
109
|
-
--viewport-size=375,812 2>/dev/null
|
|
110
|
-
|
|
111
|
-
# Tablet
|
|
112
|
-
npx playwright screenshot http://localhost:3000 \
|
|
113
|
-
"$SCREENSHOT_DIR/tablet.png" \
|
|
114
|
-
--viewport-size=768,1024 2>/dev/null
|
|
115
|
-
|
|
116
|
-
echo "Screenshots captured to $SCREENSHOT_DIR"
|
|
117
|
-
else
|
|
118
|
-
echo "No dev server at localhost:3000 — code-only audit"
|
|
119
|
-
fi
|
|
120
|
-
```
|
|
121
|
-
|
|
122
|
-
If dev server not detected: audit runs on code review only (Tailwind class audit, string audit for generic labels, state handling check). Note in output that visual screenshots were not captured.
|
|
123
|
-
|
|
124
|
-
Try port 3000 first, then 5173 (Vite default), then 8080.
|
|
125
|
-
|
|
126
|
-
</screenshot_approach>
|
|
127
|
-
|
|
128
|
-
<audit_pillars>
|
|
129
|
-
|
|
130
|
-
## 6-Pillar Scoring (1-4 per pillar)
|
|
131
|
-
|
|
132
|
-
**Score definitions:**
|
|
133
|
-
- **4** — Excellent: No issues found, exceeds contract
|
|
134
|
-
- **3** — Good: Minor issues, contract substantially met
|
|
135
|
-
- **2** — Needs work: Notable gaps, contract partially met
|
|
136
|
-
- **1** — Poor: Significant issues, contract not met
|
|
137
|
-
|
|
138
|
-
### Pillar 1: Copywriting
|
|
139
|
-
|
|
140
|
-
**Audit method:** Grep for string literals, check component text content.
|
|
141
|
-
|
|
142
|
-
```bash
|
|
143
|
-
# Find generic labels
|
|
144
|
-
grep -rn "Submit\|Click Here\|OK\|Cancel\|Save" src --include="*.tsx" --include="*.jsx" 2>/dev/null
|
|
145
|
-
# Find empty state patterns
|
|
146
|
-
grep -rn "No data\|No results\|Nothing\|Empty" src --include="*.tsx" --include="*.jsx" 2>/dev/null
|
|
147
|
-
# Find error patterns
|
|
148
|
-
grep -rn "went wrong\|try again\|error occurred" src --include="*.tsx" --include="*.jsx" 2>/dev/null
|
|
149
|
-
```
|
|
150
|
-
|
|
151
|
-
**If UI-SPEC exists:** Compare each declared CTA/empty/error copy against actual strings.
|
|
152
|
-
**If no UI-SPEC:** Flag generic patterns against UX best practices.
|
|
153
|
-
|
|
154
|
-
### Pillar 2: Visuals
|
|
155
|
-
|
|
156
|
-
**Audit method:** Check component structure, visual hierarchy indicators.
|
|
157
|
-
|
|
158
|
-
- Is there a clear focal point on the main screen?
|
|
159
|
-
- Are icon-only buttons paired with aria-labels or tooltips?
|
|
160
|
-
- Is there visual hierarchy through size, weight, or color differentiation?
|
|
161
|
-
|
|
162
|
-
### Pillar 3: Color
|
|
163
|
-
|
|
164
|
-
**Audit method:** Grep Tailwind classes and CSS custom properties.
|
|
165
|
-
|
|
166
|
-
```bash
|
|
167
|
-
# Count accent color usage
|
|
168
|
-
grep -rn "text-primary\|bg-primary\|border-primary" src --include="*.tsx" --include="*.jsx" 2>/dev/null | wc -l
|
|
169
|
-
# Check for hardcoded colors
|
|
170
|
-
grep -rn "#[0-9a-fA-F]\{3,8\}\|rgb(" src --include="*.tsx" --include="*.jsx" 2>/dev/null
|
|
171
|
-
```
|
|
172
|
-
|
|
173
|
-
**If UI-SPEC exists:** Verify accent is only used on declared elements.
|
|
174
|
-
**If no UI-SPEC:** Flag accent overuse (>10 unique elements) and hardcoded colors.
|
|
175
|
-
|
|
176
|
-
### Pillar 4: Typography
|
|
177
|
-
|
|
178
|
-
**Audit method:** Grep font size and weight classes.
|
|
179
|
-
|
|
180
|
-
```bash
|
|
181
|
-
# Count distinct font sizes in use
|
|
182
|
-
grep -rohn "text-\(xs\|sm\|base\|lg\|xl\|2xl\|3xl\|4xl\|5xl\)" src --include="*.tsx" --include="*.jsx" 2>/dev/null | sort -u
|
|
183
|
-
# Count distinct font weights
|
|
184
|
-
grep -rohn "font-\(thin\|light\|normal\|medium\|semibold\|bold\|extrabold\)" src --include="*.tsx" --include="*.jsx" 2>/dev/null | sort -u
|
|
185
|
-
```
|
|
186
|
-
|
|
187
|
-
**If UI-SPEC exists:** Verify only declared sizes and weights are used.
|
|
188
|
-
**If no UI-SPEC:** Flag if >4 font sizes or >2 font weights in use.
|
|
189
|
-
|
|
190
|
-
### Pillar 5: Spacing
|
|
191
|
-
|
|
192
|
-
**Audit method:** Grep spacing classes, check for non-standard values.
|
|
193
|
-
|
|
194
|
-
```bash
|
|
195
|
-
# Find spacing classes
|
|
196
|
-
grep -rohn "p-\|px-\|py-\|m-\|mx-\|my-\|gap-\|space-" src --include="*.tsx" --include="*.jsx" 2>/dev/null | sort | uniq -c | sort -rn | head -20
|
|
197
|
-
# Check for arbitrary values
|
|
198
|
-
grep -rn "\[.*px\]\|\[.*rem\]" src --include="*.tsx" --include="*.jsx" 2>/dev/null
|
|
199
|
-
```
|
|
200
|
-
|
|
201
|
-
**If UI-SPEC exists:** Verify spacing matches declared scale.
|
|
202
|
-
**If no UI-SPEC:** Flag arbitrary spacing values and inconsistent patterns.
|
|
203
|
-
|
|
204
|
-
### Pillar 6: Experience Design
|
|
205
|
-
|
|
206
|
-
**Audit method:** Check for state coverage and interaction patterns.
|
|
207
|
-
|
|
208
|
-
```bash
|
|
209
|
-
# Loading states
|
|
210
|
-
grep -rn "loading\|isLoading\|pending\|skeleton\|Spinner" src --include="*.tsx" --include="*.jsx" 2>/dev/null
|
|
211
|
-
# Error states
|
|
212
|
-
grep -rn "error\|isError\|ErrorBoundary\|catch" src --include="*.tsx" --include="*.jsx" 2>/dev/null
|
|
213
|
-
# Empty states
|
|
214
|
-
grep -rn "empty\|isEmpty\|no.*found\|length === 0" src --include="*.tsx" --include="*.jsx" 2>/dev/null
|
|
215
|
-
```
|
|
216
|
-
|
|
217
|
-
Score based on: loading states present, error boundaries exist, empty states handled, disabled states for actions, confirmation for destructive actions.
|
|
218
|
-
|
|
219
|
-
</audit_pillars>
|
|
220
|
-
|
|
221
|
-
<registry_audit>
|
|
222
|
-
|
|
223
|
-
## Registry Safety Audit (post-execution)
|
|
224
|
-
|
|
225
|
-
**Run AFTER pillar scoring, BEFORE writing UI-REVIEW.md.** Only runs if `components.json` exists AND UI-SPEC.md lists third-party registries.
|
|
226
|
-
|
|
227
|
-
```bash
|
|
228
|
-
# Check for shadcn and third-party registries
|
|
229
|
-
test -f components.json || echo "NO_SHADCN"
|
|
230
|
-
```
|
|
231
|
-
|
|
232
|
-
**If shadcn initialized:** Parse UI-SPEC.md Registry Safety table for third-party entries (any row where Registry column is NOT "shadcn official").
|
|
233
|
-
|
|
234
|
-
For each third-party block listed:
|
|
235
|
-
|
|
236
|
-
```bash
|
|
237
|
-
# View the block source — captures what was actually installed
|
|
238
|
-
npx shadcn view {block} --registry {registry_url} 2>/dev/null > /tmp/shadcn-view-{block}.txt
|
|
239
|
-
|
|
240
|
-
# Check for suspicious patterns
|
|
241
|
-
grep -nE "fetch\(|XMLHttpRequest|navigator\.sendBeacon|process\.env|eval\(|Function\(|new Function|import\(.*https?:" /tmp/shadcn-view-{block}.txt 2>/dev/null
|
|
242
|
-
|
|
243
|
-
# Diff against local version — shows what changed since install
|
|
244
|
-
npx shadcn diff {block} 2>/dev/null
|
|
245
|
-
```
|
|
246
|
-
|
|
247
|
-
**Suspicious pattern flags:**
|
|
248
|
-
- `fetch(`, `XMLHttpRequest`, `navigator.sendBeacon` — network access from a UI component
|
|
249
|
-
- `process.env` — environment variable exfiltration vector
|
|
250
|
-
- `eval(`, `Function(`, `new Function` — dynamic code execution
|
|
251
|
-
- `import(` with `http:` or `https:` — external dynamic imports
|
|
252
|
-
- Single-character variable names in non-minified source — obfuscation indicator
|
|
253
|
-
|
|
254
|
-
**If ANY flags found:**
|
|
255
|
-
- Add a **Registry Safety** section to UI-REVIEW.md BEFORE the "Files Audited" section
|
|
256
|
-
- List each flagged block with: registry URL, flagged lines with line numbers, risk category
|
|
257
|
-
- Score impact: deduct 1 point from Experience Design pillar per flagged block (floor at 1)
|
|
258
|
-
- Mark in review: `⚠️ REGISTRY FLAG: {block} from {registry} — {flag category}`
|
|
259
|
-
|
|
260
|
-
**If diff shows changes since install:**
|
|
261
|
-
- Note in Registry Safety section: `{block} has local modifications — diff output attached`
|
|
262
|
-
- This is informational, not a flag (local modifications are expected)
|
|
263
|
-
|
|
264
|
-
**If no third-party registries or all clean:**
|
|
265
|
-
- Note in review: `Registry audit: {N} third-party blocks checked, no flags`
|
|
266
|
-
|
|
267
|
-
**If shadcn not initialized:** Skip entirely. Do not add Registry Safety section.
|
|
268
|
-
|
|
269
|
-
</registry_audit>
|
|
270
|
-
|
|
271
|
-
<output_format>
|
|
272
|
-
|
|
273
|
-
## Output: UI-REVIEW.md
|
|
274
|
-
|
|
275
|
-
**ALWAYS use the Write tool to create files** — never use `Bash(cat << 'EOF')` or heredoc commands for file creation. Mandatory regardless of `commit_docs` setting.
|
|
276
|
-
|
|
277
|
-
Write to: `$PHASE_DIR/$PADDED_PHASE-UI-REVIEW.md`
|
|
278
|
-
|
|
279
|
-
```markdown
|
|
280
|
-
# Phase {N} — UI Review
|
|
281
|
-
|
|
282
|
-
**Audited:** {date}
|
|
283
|
-
**Baseline:** {UI-SPEC.md / abstract standards}
|
|
284
|
-
**Screenshots:** {captured / not captured (no dev server)}
|
|
285
|
-
|
|
286
|
-
---
|
|
287
|
-
|
|
288
|
-
## Pillar Scores
|
|
289
|
-
|
|
290
|
-
| Pillar | Score | Key Finding |
|
|
291
|
-
|--------|-------|-------------|
|
|
292
|
-
| 1. Copywriting | {1-4}/4 | {one-line summary} |
|
|
293
|
-
| 2. Visuals | {1-4}/4 | {one-line summary} |
|
|
294
|
-
| 3. Color | {1-4}/4 | {one-line summary} |
|
|
295
|
-
| 4. Typography | {1-4}/4 | {one-line summary} |
|
|
296
|
-
| 5. Spacing | {1-4}/4 | {one-line summary} |
|
|
297
|
-
| 6. Experience Design | {1-4}/4 | {one-line summary} |
|
|
298
|
-
|
|
299
|
-
**Overall: {total}/24**
|
|
300
|
-
|
|
301
|
-
---
|
|
302
|
-
|
|
303
|
-
## Top 3 Priority Fixes
|
|
304
|
-
|
|
305
|
-
1. **{specific issue}** — {user impact} — {concrete fix}
|
|
306
|
-
2. **{specific issue}** — {user impact} — {concrete fix}
|
|
307
|
-
3. **{specific issue}** — {user impact} — {concrete fix}
|
|
308
|
-
|
|
309
|
-
---
|
|
310
|
-
|
|
311
|
-
## Detailed Findings
|
|
312
|
-
|
|
313
|
-
### Pillar 1: Copywriting ({score}/4)
|
|
314
|
-
{findings with file:line references}
|
|
315
|
-
|
|
316
|
-
### Pillar 2: Visuals ({score}/4)
|
|
317
|
-
{findings}
|
|
318
|
-
|
|
319
|
-
### Pillar 3: Color ({score}/4)
|
|
320
|
-
{findings with class usage counts}
|
|
321
|
-
|
|
322
|
-
### Pillar 4: Typography ({score}/4)
|
|
323
|
-
{findings with size/weight distribution}
|
|
324
|
-
|
|
325
|
-
### Pillar 5: Spacing ({score}/4)
|
|
326
|
-
{findings with spacing class analysis}
|
|
327
|
-
|
|
328
|
-
### Pillar 6: Experience Design ({score}/4)
|
|
329
|
-
{findings with state coverage analysis}
|
|
330
|
-
|
|
331
|
-
---
|
|
332
|
-
|
|
333
|
-
## Files Audited
|
|
334
|
-
{list of files examined}
|
|
335
|
-
```
|
|
336
|
-
|
|
337
|
-
</output_format>
|
|
338
|
-
|
|
339
|
-
<execution_flow>
|
|
340
|
-
|
|
341
|
-
## Step 1: Load Context
|
|
342
|
-
|
|
343
|
-
Read all files from `<files_to_read>` block. Parse SUMMARY.md, PLAN.md, CONTEXT.md, UI-SPEC.md (if any exist).
|
|
344
|
-
|
|
345
|
-
## Step 2: Ensure .gitignore
|
|
346
|
-
|
|
347
|
-
Run the gitignore gate from `<gitignore_gate>`. This MUST happen before step 3.
|
|
348
|
-
|
|
349
|
-
## Step 3: Detect Dev Server and Capture Screenshots
|
|
350
|
-
|
|
351
|
-
Run the screenshot approach from `<screenshot_approach>`. Record whether screenshots were captured.
|
|
352
|
-
|
|
353
|
-
## Step 4: Scan Implemented Files
|
|
354
|
-
|
|
355
|
-
```bash
|
|
356
|
-
# Find all frontend files modified in this phase
|
|
357
|
-
find src -name "*.tsx" -o -name "*.jsx" -o -name "*.css" -o -name "*.scss" 2>/dev/null
|
|
358
|
-
```
|
|
359
|
-
|
|
360
|
-
Build list of files to audit.
|
|
361
|
-
|
|
362
|
-
## Step 5: Audit Each Pillar
|
|
363
|
-
|
|
364
|
-
For each of the 6 pillars:
|
|
365
|
-
1. Run audit method (grep commands from `<audit_pillars>`)
|
|
366
|
-
2. Compare against UI-SPEC.md (if exists) or abstract standards
|
|
367
|
-
3. Score 1-4 with evidence
|
|
368
|
-
4. Record findings with file:line references
|
|
369
|
-
|
|
370
|
-
## Step 6: Registry Safety Audit
|
|
371
|
-
|
|
372
|
-
Run the registry audit from `<registry_audit>`. Only executes if `components.json` exists AND UI-SPEC.md lists third-party registries. Results feed into UI-REVIEW.md.
|
|
373
|
-
|
|
374
|
-
## Step 7: Write UI-REVIEW.md
|
|
375
|
-
|
|
376
|
-
Use output format from `<output_format>`. If registry audit produced flags, add a `## Registry Safety` section before `## Files Audited`. Write to `$PHASE_DIR/$PADDED_PHASE-UI-REVIEW.md`.
|
|
377
|
-
|
|
378
|
-
## Step 8: Return Structured Result
|
|
379
|
-
|
|
380
|
-
</execution_flow>
|
|
381
|
-
|
|
382
|
-
<structured_returns>
|
|
383
|
-
|
|
384
|
-
## UI Review Complete
|
|
385
|
-
|
|
386
|
-
```markdown
|
|
387
|
-
## UI REVIEW COMPLETE
|
|
388
|
-
|
|
389
|
-
**Phase:** {phase_number} - {phase_name}
|
|
390
|
-
**Overall Score:** {total}/24
|
|
391
|
-
**Screenshots:** {captured / not captured}
|
|
392
|
-
|
|
393
|
-
### Pillar Summary
|
|
394
|
-
| Pillar | Score |
|
|
395
|
-
|--------|-------|
|
|
396
|
-
| Copywriting | {N}/4 |
|
|
397
|
-
| Visuals | {N}/4 |
|
|
398
|
-
| Color | {N}/4 |
|
|
399
|
-
| Typography | {N}/4 |
|
|
400
|
-
| Spacing | {N}/4 |
|
|
401
|
-
| Experience Design | {N}/4 |
|
|
402
|
-
|
|
403
|
-
### Top 3 Fixes
|
|
404
|
-
1. {fix summary}
|
|
405
|
-
2. {fix summary}
|
|
406
|
-
3. {fix summary}
|
|
407
|
-
|
|
408
|
-
### File Created
|
|
409
|
-
`$PHASE_DIR/$PADDED_PHASE-UI-REVIEW.md`
|
|
410
|
-
|
|
411
|
-
### Recommendation Count
|
|
412
|
-
- Priority fixes: {N}
|
|
413
|
-
- Minor recommendations: {N}
|
|
414
|
-
```
|
|
415
|
-
|
|
416
|
-
</structured_returns>
|
|
417
|
-
|
|
418
|
-
<success_criteria>
|
|
419
|
-
|
|
420
|
-
UI audit is complete when:
|
|
421
|
-
|
|
422
|
-
- [ ] All `<files_to_read>` loaded before any action
|
|
423
|
-
- [ ] .gitignore gate executed before any screenshot capture
|
|
424
|
-
- [ ] Dev server detection attempted
|
|
425
|
-
- [ ] Screenshots captured (or noted as unavailable)
|
|
426
|
-
- [ ] All 6 pillars scored with evidence
|
|
427
|
-
- [ ] Registry safety audit executed (if shadcn + third-party registries present)
|
|
428
|
-
- [ ] Top 3 priority fixes identified with concrete solutions
|
|
429
|
-
- [ ] UI-REVIEW.md written to correct path
|
|
430
|
-
- [ ] Structured return provided to orchestrator
|
|
431
|
-
|
|
432
|
-
Quality indicators:
|
|
433
|
-
|
|
434
|
-
- **Evidence-based:** Every score cites specific files, lines, or class patterns
|
|
435
|
-
- **Actionable fixes:** "Change `text-primary` on decorative border to `text-muted`" not "fix colors"
|
|
436
|
-
- **Fair scoring:** 4/4 is achievable, 1/4 means real problems, not perfectionism
|
|
437
|
-
- **Proportional:** More detail on low-scoring pillars, brief on passing ones
|
|
438
|
-
|
|
439
|
-
</success_criteria>
|