buildanything 1.8.0 → 2.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/.claude-plugin/marketplace.json +3 -3
- package/.claude-plugin/plugin.json +9 -3
- package/CHANGELOG.md +57 -0
- package/README.md +2 -2
- package/agents/a11y-architect.md +166 -0
- package/agents/business-model.md +80 -29
- package/agents/code-architect.md +75 -0
- package/agents/code-reviewer.md +255 -0
- package/agents/code-simplifier.md +64 -0
- package/agents/design-brand-guardian.md +293 -53
- package/agents/design-critic.md +139 -0
- package/agents/design-inclusive-visuals-specialist.md +6 -19
- package/agents/design-ui-designer.md +335 -56
- package/agents/design-ux-architect.md +403 -55
- package/agents/design-ux-researcher.md +264 -49
- package/agents/engineering-ai-engineer.md +26 -36
- package/agents/engineering-backend-architect.md +185 -36
- package/agents/engineering-data-engineer.md +225 -43
- package/agents/engineering-devops-automator.md +227 -74
- package/agents/engineering-frontend-developer.md +210 -34
- package/agents/engineering-mobile-app-builder.md +6 -1
- package/agents/engineering-rapid-prototyper.md +30 -9
- package/agents/engineering-security-engineer.md +263 -61
- package/agents/engineering-senior-developer.md +128 -19
- package/agents/engineering-sre.md +84 -0
- package/agents/engineering-technical-writer.md +285 -41
- package/agents/feature-intel.md +110 -0
- package/agents/ios-app-review-guardian.md +19 -2
- package/agents/ios-foundation-models-specialist.md +20 -2
- package/agents/ios-storekit-specialist.md +9 -2
- package/agents/ios-swift-architect.md +28 -1
- package/agents/ios-swift-search.md +8 -1
- package/agents/ios-swift-ui-design.md +33 -1
- package/agents/marketing-app-store-optimizer.md +246 -64
- package/agents/planner.md +216 -0
- package/agents/pr-test-analyzer.md +63 -0
- package/agents/product-feedback-synthesizer.md +8 -2
- package/agents/refactor-cleaner.md +102 -0
- package/agents/security-reviewer.md +128 -0
- package/agents/silent-failure-hunter.md +54 -0
- package/agents/swift-build-resolver.md +119 -0
- package/agents/swift-reviewer.md +112 -0
- package/agents/tech-feasibility.md +21 -1
- package/agents/testing-api-tester.md +236 -59
- package/agents/testing-evidence-collector.md +26 -1
- package/agents/testing-performance-benchmarker.md +21 -1
- package/agents/testing-reality-checker.md +6 -1
- package/agents/visual-research.md +116 -0
- package/bin/adapters/cycle-counter-tool.ts +155 -0
- package/bin/adapters/scribe-tool.ts +71 -0
- package/bin/adapters/state-save-tool.ts +130 -0
- package/bin/adapters/write-lease-tool.ts +127 -0
- package/bin/buildanything-runtime.js +15 -0
- package/bin/buildanything-runtime.ts +328 -0
- package/bin/setup.js +83 -8
- package/commands/add-feature.md +2 -0
- package/commands/build.md +782 -266
- package/commands/fix.md +1 -1
- package/commands/self-check.md +121 -0
- package/commands/setup.md +50 -9
- package/commands/ux-review.md +2 -2
- package/commands/verify.md +6 -9
- package/docs/migration/agents.yaml +729 -0
- package/docs/migration/phase-graph.yaml +1088 -0
- package/docs/migration/sdk-host-compat.md +18 -0
- package/hooks/compile-writer-owner-cache.ts +171 -0
- package/hooks/hooks.json +36 -0
- package/hooks/pre-tool-use +19 -0
- package/hooks/pre-tool-use.ts +776 -0
- package/hooks/record-mode-transitions.ts +178 -0
- package/hooks/session-start +71 -1
- package/hooks/subagent-start +17 -0
- package/hooks/subagent-start.ts +471 -0
- package/hooks/subagent-stop +17 -0
- package/hooks/subagent-stop.ts +153 -0
- package/package.json +24 -4
- package/protocols/architecture-schema.md +171 -0
- package/protocols/decision-log.md +131 -0
- package/protocols/ios-context.md +10 -11
- package/protocols/ios-phase-branches.md +208 -33
- package/protocols/launch-readiness.md +258 -0
- package/protocols/metric-loop.md +62 -2
- package/protocols/smoke-test.md +9 -1
- package/protocols/state-schema.json +388 -0
- package/protocols/state-schema.md +172 -0
- package/protocols/verify.md +62 -2
- package/protocols/visual-dna.md +185 -0
- package/protocols/web-phase-branches.md +222 -72
- package/skills/ios/_VENDORED.md +2 -0
- package/skills/ios/app-store-connect-metadata/SKILL.md +148 -0
- package/skills/ios/asc-privacy-manifest/SKILL.md +350 -0
- package/skills/ios/hig-components-content/SKILL.md +86 -0
- package/skills/ios/hig-components-content/references/activity-views.md +79 -0
- package/skills/ios/hig-components-content/references/charts.md +180 -0
- package/skills/ios/hig-components-content/references/collections.md +48 -0
- package/skills/ios/hig-components-content/references/color-wells.md +42 -0
- package/skills/ios/hig-components-content/references/image-views.md +82 -0
- package/skills/ios/hig-components-content/references/image-wells.md +34 -0
- package/skills/ios/hig-components-content/references/lockups.md +78 -0
- package/skills/ios/hig-components-content/references/web-views.md +36 -0
- package/skills/ios/hig-components-controls/SKILL.md +88 -0
- package/skills/ios/hig-components-controls/references/combo-boxes.md +40 -0
- package/skills/ios/hig-components-controls/references/controls.md +112 -0
- package/skills/ios/hig-components-controls/references/gauges.md +74 -0
- package/skills/ios/hig-components-controls/references/labels.md +92 -0
- package/skills/ios/hig-components-controls/references/pickers.md +128 -0
- package/skills/ios/hig-components-controls/references/rating-indicators.md +38 -0
- package/skills/ios/hig-components-controls/references/segmented-controls.md +94 -0
- package/skills/ios/hig-components-controls/references/sliders.md +92 -0
- package/skills/ios/hig-components-controls/references/steppers.md +40 -0
- package/skills/ios/hig-components-controls/references/text-fields.md +88 -0
- package/skills/ios/hig-components-controls/references/text-views.md +56 -0
- package/skills/ios/hig-components-controls/references/toggles.md +127 -0
- package/skills/ios/hig-components-controls/references/token-fields.md +48 -0
- package/skills/ios/hig-components-controls/references/virtual-keyboards.md +156 -0
- package/skills/ios/hig-components-dialogs/SKILL.md +76 -0
- package/skills/ios/hig-components-dialogs/references/action-sheets.md +74 -0
- package/skills/ios/hig-components-dialogs/references/alerts.md +158 -0
- package/skills/ios/hig-components-dialogs/references/digit-entry-views.md +32 -0
- package/skills/ios/hig-components-dialogs/references/popovers.md +81 -0
- package/skills/ios/hig-components-dialogs/references/sheets.md +157 -0
- package/skills/ios/hig-components-layout/SKILL.md +99 -0
- package/skills/ios/hig-components-layout/references/boxes.md +48 -0
- package/skills/ios/hig-components-layout/references/column-views.md +44 -0
- package/skills/ios/hig-components-layout/references/lists-and-tables.md +99 -0
- package/skills/ios/hig-components-layout/references/ornaments.md +56 -0
- package/skills/ios/hig-components-layout/references/outline-views.md +64 -0
- package/skills/ios/hig-components-layout/references/panels.md +75 -0
- package/skills/ios/hig-components-layout/references/scroll-views.md +123 -0
- package/skills/ios/hig-components-layout/references/sidebars.md +109 -0
- package/skills/ios/hig-components-layout/references/split-views.md +110 -0
- package/skills/ios/hig-components-layout/references/tab-bars.md +173 -0
- package/skills/ios/hig-components-layout/references/tab-views.md +68 -0
- package/skills/ios/hig-components-layout/references/windows.md +188 -0
- package/skills/ios/hig-components-menus/SKILL.md +81 -0
- package/skills/ios/hig-components-menus/references/action-button.md +61 -0
- package/skills/ios/hig-components-menus/references/buttons.md +261 -0
- package/skills/ios/hig-components-menus/references/context-menus.md +105 -0
- package/skills/ios/hig-components-menus/references/disclosure-controls.md +84 -0
- package/skills/ios/hig-components-menus/references/dock-menus.md +40 -0
- package/skills/ios/hig-components-menus/references/edit-menus.md +88 -0
- package/skills/ios/hig-components-menus/references/menus.md +171 -0
- package/skills/ios/hig-components-menus/references/pop-up-buttons.md +70 -0
- package/skills/ios/hig-components-menus/references/pull-down-buttons.md +77 -0
- package/skills/ios/hig-components-menus/references/the-menu-bar.md +303 -0
- package/skills/ios/hig-components-menus/references/toolbars.md +256 -0
- package/skills/ios/hig-components-search/SKILL.md +68 -0
- package/skills/ios/hig-components-search/references/page-controls.md +120 -0
- package/skills/ios/hig-components-search/references/path-controls.md +40 -0
- package/skills/ios/hig-components-search/references/search-fields.md +189 -0
- package/skills/ios/hig-components-status/SKILL.md +80 -0
- package/skills/ios/hig-components-status/references/activity-rings.md +105 -0
- package/skills/ios/hig-components-status/references/progress-indicators.md +116 -0
- package/skills/ios/hig-components-status/references/status-bars.md +38 -0
- package/skills/ios/hig-components-system/SKILL.md +88 -0
- package/skills/ios/hig-components-system/references/app-clips.md +387 -0
- package/skills/ios/hig-components-system/references/app-shortcuts.md +114 -0
- package/skills/ios/hig-components-system/references/complications.md +425 -0
- package/skills/ios/hig-components-system/references/home-screen-quick-actions.md +42 -0
- package/skills/ios/hig-components-system/references/live-activities.md +442 -0
- package/skills/ios/hig-components-system/references/notifications.md +153 -0
- package/skills/ios/hig-components-system/references/top-shelf.md +135 -0
- package/skills/ios/hig-components-system/references/watch-faces.md +40 -0
- package/skills/ios/hig-components-system/references/widgets.md +517 -0
- package/skills/ios/hig-foundations/SKILL.md +98 -0
- package/skills/ios/hig-foundations/references/accessibility.md +291 -0
- package/skills/ios/hig-foundations/references/app-icons.md +210 -0
- package/skills/ios/hig-foundations/references/branding.md +44 -0
- package/skills/ios/hig-foundations/references/color.md +274 -0
- package/skills/ios/hig-foundations/references/dark-mode.md +116 -0
- package/skills/ios/hig-foundations/references/icons.md +263 -0
- package/skills/ios/hig-foundations/references/images.md +176 -0
- package/skills/ios/hig-foundations/references/immersive-experiences.md +174 -0
- package/skills/ios/hig-foundations/references/inclusion.md +189 -0
- package/skills/ios/hig-foundations/references/layout.md +425 -0
- package/skills/ios/hig-foundations/references/materials.md +238 -0
- package/skills/ios/hig-foundations/references/motion.md +103 -0
- package/skills/ios/hig-foundations/references/privacy.md +231 -0
- package/skills/ios/hig-foundations/references/right-to-left.md +206 -0
- package/skills/ios/hig-foundations/references/sf-symbols.md +310 -0
- package/skills/ios/hig-foundations/references/spatial-layout.md +142 -0
- package/skills/ios/hig-foundations/references/typography.md +1146 -0
- package/skills/ios/hig-foundations/references/writing.md +91 -0
- package/skills/ios/hig-inputs/SKILL.md +94 -0
- package/skills/ios/hig-inputs/references/apple-pencil-and-scribble.md +148 -0
- package/skills/ios/hig-inputs/references/camera-control.md +107 -0
- package/skills/ios/hig-inputs/references/digital-crown.md +83 -0
- package/skills/ios/hig-inputs/references/eyes.md +120 -0
- package/skills/ios/hig-inputs/references/focus-and-selection.md +120 -0
- package/skills/ios/hig-inputs/references/game-controls.md +156 -0
- package/skills/ios/hig-inputs/references/gestures.md +208 -0
- package/skills/ios/hig-inputs/references/gyro-and-accelerometer.md +40 -0
- package/skills/ios/hig-inputs/references/keyboards.md +234 -0
- package/skills/ios/hig-inputs/references/nearby-interactions.md +70 -0
- package/skills/ios/hig-inputs/references/pointing-devices.md +237 -0
- package/skills/ios/hig-inputs/references/remotes.md +67 -0
- package/skills/ios/hig-inputs/references/spatial-interactions.md +70 -0
- package/skills/ios/hig-patterns/SKILL.md +104 -0
- package/skills/ios/hig-patterns/references/charting-data.md +81 -0
- package/skills/ios/hig-patterns/references/collaboration-and-sharing.md +86 -0
- package/skills/ios/hig-patterns/references/drag-and-drop.md +134 -0
- package/skills/ios/hig-patterns/references/entering-data.md +69 -0
- package/skills/ios/hig-patterns/references/feedback.md +67 -0
- package/skills/ios/hig-patterns/references/file-management.md +135 -0
- package/skills/ios/hig-patterns/references/going-full-screen.md +79 -0
- package/skills/ios/hig-patterns/references/launching.md +81 -0
- package/skills/ios/hig-patterns/references/live-viewing-apps.md +79 -0
- package/skills/ios/hig-patterns/references/loading.md +59 -0
- package/skills/ios/hig-patterns/references/managing-accounts.md +107 -0
- package/skills/ios/hig-patterns/references/managing-notifications.md +99 -0
- package/skills/ios/hig-patterns/references/modality.md +82 -0
- package/skills/ios/hig-patterns/references/multitasking.md +131 -0
- package/skills/ios/hig-patterns/references/offering-help.md +117 -0
- package/skills/ios/hig-patterns/references/onboarding.md +69 -0
- package/skills/ios/hig-patterns/references/playing-audio.md +124 -0
- package/skills/ios/hig-patterns/references/playing-haptics.md +280 -0
- package/skills/ios/hig-patterns/references/playing-video.md +180 -0
- package/skills/ios/hig-patterns/references/printing.md +50 -0
- package/skills/ios/hig-patterns/references/ratings-and-reviews.md +48 -0
- package/skills/ios/hig-patterns/references/searching.md +70 -0
- package/skills/ios/hig-patterns/references/settings.md +84 -0
- package/skills/ios/hig-patterns/references/undo-and-redo.md +58 -0
- package/skills/ios/hig-patterns/references/workouts.md +76 -0
- package/skills/ios/hig-platforms/SKILL.md +84 -0
- package/skills/ios/hig-platforms/references/designing-for-games.md +159 -0
- package/skills/ios/hig-platforms/references/designing-for-ios.md +66 -0
- package/skills/ios/hig-platforms/references/designing-for-ipados.md +64 -0
- package/skills/ios/hig-platforms/references/designing-for-macos.md +70 -0
- package/skills/ios/hig-platforms/references/designing-for-tvos.md +68 -0
- package/skills/ios/hig-platforms/references/designing-for-visionos.md +85 -0
- package/skills/ios/hig-platforms/references/designing-for-watchos.md +74 -0
- package/skills/ios/hig-project-context/SKILL.md +133 -0
- package/skills/ios/hig-technologies/SKILL.md +107 -0
- package/skills/ios/hig-technologies/references/airplay.md +125 -0
- package/skills/ios/hig-technologies/references/always-on.md +62 -0
- package/skills/ios/hig-technologies/references/apple-pay.md +441 -0
- package/skills/ios/hig-technologies/references/augmented-reality.md +247 -0
- package/skills/ios/hig-technologies/references/carekit.md +224 -0
- package/skills/ios/hig-technologies/references/carplay.md +119 -0
- package/skills/ios/hig-technologies/references/game-center.md +343 -0
- package/skills/ios/hig-technologies/references/generative-ai.md +110 -0
- package/skills/ios/hig-technologies/references/healthkit.md +120 -0
- package/skills/ios/hig-technologies/references/homekit.md +343 -0
- package/skills/ios/hig-technologies/references/icloud.md +52 -0
- package/skills/ios/hig-technologies/references/id-verifier.md +73 -0
- package/skills/ios/hig-technologies/references/imessage-apps-and-stickers.md +105 -0
- package/skills/ios/hig-technologies/references/in-app-purchase.md +263 -0
- package/skills/ios/hig-technologies/references/live-photos.md +54 -0
- package/skills/ios/hig-technologies/references/mac-catalyst.md +216 -0
- package/skills/ios/hig-technologies/references/machine-learning.md +394 -0
- package/skills/ios/hig-technologies/references/maps.md +221 -0
- package/skills/ios/hig-technologies/references/nfc.md +51 -0
- package/skills/ios/hig-technologies/references/photo-editing.md +40 -0
- package/skills/ios/hig-technologies/references/researchkit.md +134 -0
- package/skills/ios/hig-technologies/references/shareplay.md +142 -0
- package/skills/ios/hig-technologies/references/shazamkit.md +47 -0
- package/skills/ios/hig-technologies/references/sign-in-with-apple.md +288 -0
- package/skills/ios/hig-technologies/references/siri.md +523 -0
- package/skills/ios/hig-technologies/references/tap-to-pay-on-iphone.md +208 -0
- package/skills/ios/hig-technologies/references/voiceover.md +90 -0
- package/skills/ios/hig-technologies/references/wallet.md +420 -0
- package/skills/ios/ios-bootstrap/SKILL.md +16 -7
- package/skills/ios/swift-actor-persistence/SKILL.md +143 -0
- package/skills/ios/swift-concurrency-6-2/SKILL.md +216 -0
- package/skills/ios/swift-protocol-di-testing/SKILL.md +190 -0
- package/skills/ios/swiftui-design-tokens/SKILL.md +475 -0
- package/skills/ios/writing-for-interfaces/SKILL.md +75 -0
- package/skills/web/accessibility/SKILL.md +146 -0
- package/skills/web/aceternity-ui/SKILL.md +719 -0
- package/skills/web/aceternity-ui/metadata.json +10 -0
- package/skills/web/api-design/SKILL.md +523 -0
- package/skills/web/chart-accessibility/SKILL.md +332 -0
- package/skills/web/composition-patterns/AGENTS.md +946 -0
- package/skills/web/composition-patterns/README.md +60 -0
- package/skills/web/composition-patterns/SKILL.md +89 -0
- package/skills/web/composition-patterns/metadata.json +11 -0
- package/skills/web/composition-patterns/rules/_sections.md +29 -0
- package/skills/web/composition-patterns/rules/_template.md +24 -0
- package/skills/web/composition-patterns/rules/architecture-avoid-boolean-props.md +100 -0
- package/skills/web/composition-patterns/rules/architecture-compound-components.md +112 -0
- package/skills/web/composition-patterns/rules/patterns-children-over-render-props.md +87 -0
- package/skills/web/composition-patterns/rules/patterns-explicit-variants.md +100 -0
- package/skills/web/composition-patterns/rules/react19-no-forwardref.md +42 -0
- package/skills/web/composition-patterns/rules/state-context-interface.md +191 -0
- package/skills/web/composition-patterns/rules/state-decouple-implementation.md +113 -0
- package/skills/web/composition-patterns/rules/state-lift-state.md +125 -0
- package/skills/web/cost-aware-llm-pipeline/SKILL.md +183 -0
- package/skills/web/database-migrations/SKILL.md +429 -0
- package/skills/web/deployment-patterns/SKILL.md +427 -0
- package/skills/web/docker-patterns/SKILL.md +364 -0
- package/skills/web/e2e-testing/SKILL.md +326 -0
- package/skills/web/lighthouse-ci/SKILL.md +361 -0
- package/skills/web/mcp-server-patterns/SKILL.md +69 -0
- package/skills/web/next-best-practices/SKILL.md +153 -0
- package/skills/web/next-best-practices/async-patterns.md +87 -0
- package/skills/web/next-best-practices/bundling.md +180 -0
- package/skills/web/next-best-practices/data-patterns.md +297 -0
- package/skills/web/next-best-practices/debug-tricks.md +105 -0
- package/skills/web/next-best-practices/directives.md +73 -0
- package/skills/web/next-best-practices/error-handling.md +227 -0
- package/skills/web/next-best-practices/file-conventions.md +140 -0
- package/skills/web/next-best-practices/font.md +245 -0
- package/skills/web/next-best-practices/functions.md +108 -0
- package/skills/web/next-best-practices/hydration-error.md +91 -0
- package/skills/web/next-best-practices/image.md +173 -0
- package/skills/web/next-best-practices/metadata.md +301 -0
- package/skills/web/next-best-practices/parallel-routes.md +287 -0
- package/skills/web/next-best-practices/route-handlers.md +146 -0
- package/skills/web/next-best-practices/rsc-boundaries.md +159 -0
- package/skills/web/next-best-practices/runtime-selection.md +39 -0
- package/skills/web/next-best-practices/scripts.md +141 -0
- package/skills/web/next-best-practices/self-hosting.md +371 -0
- package/skills/web/next-best-practices/suspense-boundaries.md +67 -0
- package/skills/web/next-cache-components/SKILL.md +411 -0
- package/skills/web/postgres-best-practices/SKILL.md +14 -0
- package/skills/web/postgres-best-practices/references/schema-design.md +9 -0
- package/skills/web/react-best-practices/AGENTS.md +3810 -0
- package/skills/web/react-best-practices/README.md +123 -0
- package/skills/web/react-best-practices/SKILL.md +149 -0
- package/skills/web/react-best-practices/metadata.json +15 -0
- package/skills/web/react-best-practices/rules/_sections.md +46 -0
- package/skills/web/react-best-practices/rules/_template.md +28 -0
- package/skills/web/react-best-practices/rules/advanced-effect-event-deps.md +56 -0
- package/skills/web/react-best-practices/rules/advanced-event-handler-refs.md +55 -0
- package/skills/web/react-best-practices/rules/advanced-init-once.md +42 -0
- package/skills/web/react-best-practices/rules/advanced-use-latest.md +39 -0
- package/skills/web/react-best-practices/rules/async-api-routes.md +38 -0
- package/skills/web/react-best-practices/rules/async-cheap-condition-before-await.md +37 -0
- package/skills/web/react-best-practices/rules/async-defer-await.md +82 -0
- package/skills/web/react-best-practices/rules/async-dependencies.md +51 -0
- package/skills/web/react-best-practices/rules/async-parallel.md +28 -0
- package/skills/web/react-best-practices/rules/async-suspense-boundaries.md +99 -0
- package/skills/web/react-best-practices/rules/bundle-analyzable-paths.md +63 -0
- package/skills/web/react-best-practices/rules/bundle-barrel-imports.md +60 -0
- package/skills/web/react-best-practices/rules/bundle-conditional.md +31 -0
- package/skills/web/react-best-practices/rules/bundle-defer-third-party.md +49 -0
- package/skills/web/react-best-practices/rules/bundle-dynamic-imports.md +35 -0
- package/skills/web/react-best-practices/rules/bundle-preload.md +50 -0
- package/skills/web/react-best-practices/rules/client-event-listeners.md +74 -0
- package/skills/web/react-best-practices/rules/client-localstorage-schema.md +71 -0
- package/skills/web/react-best-practices/rules/client-passive-event-listeners.md +48 -0
- package/skills/web/react-best-practices/rules/client-swr-dedup.md +56 -0
- package/skills/web/react-best-practices/rules/js-batch-dom-css.md +107 -0
- package/skills/web/react-best-practices/rules/js-cache-function-results.md +80 -0
- package/skills/web/react-best-practices/rules/js-cache-property-access.md +28 -0
- package/skills/web/react-best-practices/rules/js-cache-storage.md +70 -0
- package/skills/web/react-best-practices/rules/js-combine-iterations.md +32 -0
- package/skills/web/react-best-practices/rules/js-early-exit.md +50 -0
- package/skills/web/react-best-practices/rules/js-flatmap-filter.md +60 -0
- package/skills/web/react-best-practices/rules/js-hoist-regexp.md +45 -0
- package/skills/web/react-best-practices/rules/js-index-maps.md +37 -0
- package/skills/web/react-best-practices/rules/js-length-check-first.md +49 -0
- package/skills/web/react-best-practices/rules/js-min-max-loop.md +82 -0
- package/skills/web/react-best-practices/rules/js-request-idle-callback.md +105 -0
- package/skills/web/react-best-practices/rules/js-set-map-lookups.md +24 -0
- package/skills/web/react-best-practices/rules/js-tosorted-immutable.md +57 -0
- package/skills/web/react-best-practices/rules/rendering-activity.md +26 -0
- package/skills/web/react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
- package/skills/web/react-best-practices/rules/rendering-conditional-render.md +40 -0
- package/skills/web/react-best-practices/rules/rendering-content-visibility.md +38 -0
- package/skills/web/react-best-practices/rules/rendering-hoist-jsx.md +46 -0
- package/skills/web/react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
- package/skills/web/react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
- package/skills/web/react-best-practices/rules/rendering-resource-hints.md +85 -0
- package/skills/web/react-best-practices/rules/rendering-script-defer-async.md +68 -0
- package/skills/web/react-best-practices/rules/rendering-svg-precision.md +28 -0
- package/skills/web/react-best-practices/rules/rendering-usetransition-loading.md +75 -0
- package/skills/web/react-best-practices/rules/rerender-defer-reads.md +39 -0
- package/skills/web/react-best-practices/rules/rerender-dependencies.md +45 -0
- package/skills/web/react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
- package/skills/web/react-best-practices/rules/rerender-derived-state.md +29 -0
- package/skills/web/react-best-practices/rules/rerender-functional-setstate.md +74 -0
- package/skills/web/react-best-practices/rules/rerender-lazy-state-init.md +58 -0
- package/skills/web/react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
- package/skills/web/react-best-practices/rules/rerender-memo.md +44 -0
- package/skills/web/react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
- package/skills/web/react-best-practices/rules/rerender-no-inline-components.md +82 -0
- package/skills/web/react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
- package/skills/web/react-best-practices/rules/rerender-split-combined-hooks.md +64 -0
- package/skills/web/react-best-practices/rules/rerender-transitions.md +40 -0
- package/skills/web/react-best-practices/rules/rerender-use-deferred-value.md +59 -0
- package/skills/web/react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
- package/skills/web/react-best-practices/rules/server-after-nonblocking.md +73 -0
- package/skills/web/react-best-practices/rules/server-auth-actions.md +96 -0
- package/skills/web/react-best-practices/rules/server-cache-lru.md +41 -0
- package/skills/web/react-best-practices/rules/server-cache-react.md +76 -0
- package/skills/web/react-best-practices/rules/server-dedup-props.md +65 -0
- package/skills/web/react-best-practices/rules/server-hoist-static-io.md +149 -0
- package/skills/web/react-best-practices/rules/server-no-shared-module-state.md +50 -0
- package/skills/web/react-best-practices/rules/server-parallel-fetching.md +83 -0
- package/skills/web/react-best-practices/rules/server-parallel-nested-fetching.md +34 -0
- package/skills/web/react-best-practices/rules/server-serialization.md +38 -0
- package/skills/web/seo/SKILL.md +154 -0
- package/skills/web/web-design-guidelines/SKILL.md +39 -0
- package/skills/web/zap-scan-config/SKILL.md +444 -0
- package/skills/web/zap-scan-config/assets/.gitkeep +9 -0
- package/skills/web/zap-scan-config/assets/github_action.yml +207 -0
- package/skills/web/zap-scan-config/assets/gitlab_ci.yml +226 -0
- package/skills/web/zap-scan-config/assets/zap_automation.yaml +196 -0
- package/skills/web/zap-scan-config/assets/zap_context.xml +192 -0
- package/skills/web/zap-scan-config/references/EXAMPLE.md +40 -0
- package/skills/web/zap-scan-config/references/api_testing_guide.md +475 -0
- package/skills/web/zap-scan-config/references/authentication_guide.md +431 -0
- package/skills/web/zap-scan-config/references/false_positive_handling.md +427 -0
- package/skills/web/zap-scan-config/references/owasp_mapping.md +255 -0
- package/src/lrr/aggregator.ts +80 -0
- package/src/orchestrator/hooks/context-header.ts +95 -0
- package/src/orchestrator/hooks/token-accounting-emitter.ts +77 -0
- package/src/orchestrator/hooks/token-accounting.ts +101 -0
- package/src/orchestrator/mcp/cycle-counter.ts +129 -0
- package/src/orchestrator/mcp/scribe.ts +283 -0
- package/src/orchestrator/mcp/state-save.ts +149 -0
- package/src/orchestrator/mcp/write-lease.ts +167 -0
- package/src/orchestrator/phase4-shared-context.ts +41 -0
- package/src/orchestrator/schemas/backward-edge.ts +46 -0
- package/agents/agentic-identity-trust.md +0 -121
- package/agents/data-consolidation-agent.md +0 -39
- package/agents/design-image-prompt-engineer.md +0 -105
- package/agents/design-visual-storyteller.md +0 -147
- package/agents/design-whimsy-injector.md +0 -89
- package/agents/engineering-autonomous-optimization-architect.md +0 -105
- package/agents/market-intel.md +0 -35
- package/agents/marketing-instagram-curator.md +0 -111
- package/agents/marketing-reddit-community-builder.md +0 -121
- package/agents/marketing-social-media-strategist.md +0 -74
- package/agents/marketing-tiktok-strategist.md +0 -123
- package/agents/marketing-twitter-engager.md +0 -124
- package/agents/marketing-wechat-official-account.md +0 -143
- package/agents/marketing-xiaohongshu-specialist.md +0 -136
- package/agents/marketing-zhihu-strategist.md +0 -160
- package/agents/product-behavioral-nudge-engine.md +0 -78
- package/agents/project-management-experiment-tracker.md +0 -102
- package/agents/report-distribution-agent.md +0 -43
- package/agents/risk-analysis.md +0 -45
- package/agents/sales-data-extraction-agent.md +0 -46
- package/agents/specialized-cultural-intelligence-strategist.md +0 -65
- package/agents/specialized-developer-advocate.md +0 -146
- package/agents/support-analytics-reporter.md +0 -133
- package/agents/support-executive-summary-generator.md +0 -64
- package/agents/support-finance-tracker.md +0 -145
- package/agents/support-legal-compliance-checker.md +0 -129
- package/agents/support-support-responder.md +0 -91
- package/agents/testing-accessibility-auditor.md +0 -110
- package/agents/testing-test-results-analyzer.md +0 -97
- package/agents/testing-tool-evaluator.md +0 -76
- package/agents/testing-workflow-optimizer.md +0 -99
- package/agents/user-research.md +0 -40
- package/protocols/brainstorm.md +0 -99
- package/protocols/design.md +0 -269
- package/protocols/planning.md +0 -87
- package/skills/ios/ios-hig/SKILL.md +0 -41
- package/skills/ios/ios-hig/references/accessibility.md +0 -81
- package/skills/ios/ios-hig/references/content.md +0 -142
- package/skills/ios/ios-hig/references/feedback.md +0 -123
- package/skills/ios/ios-hig/references/interaction.md +0 -199
- package/skills/ios/ios-hig/references/performance-platform.md +0 -129
- package/skills/ios/ios-hig/references/privacy-permissions.md +0 -181
- package/skills/ios/ios-hig/references/visual-design.md +0 -84
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: code-reviewer
|
|
3
|
+
description: Expert code review specialist. Proactively reviews code for quality, security, and maintainability. Use immediately after writing or modifying code. MUST BE USED for all code changes.
|
|
4
|
+
tools: ["Read", "Grep", "Glob", "Bash", "Skill"]
|
|
5
|
+
model: sonnet
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
You are a senior code reviewer ensuring high standards of code quality and security.
|
|
9
|
+
|
|
10
|
+
## Skill Access
|
|
11
|
+
|
|
12
|
+
The orchestrator passes these variables into your dispatch prompt: `project_type` and `phase`.
|
|
13
|
+
|
|
14
|
+
**Rules:**
|
|
15
|
+
- Load skills from this shortlist ONLY. Never consult skills outside this list, even if familiar.
|
|
16
|
+
- No defaulting. When no gate matches a skill, do NOT load it.
|
|
17
|
+
- No substitutions. You use these skills to calibrate what "good code" looks like in review mode — not as implementation references.
|
|
18
|
+
|
|
19
|
+
**Project-type gated (web — Eng-Quality chapter):**
|
|
20
|
+
- `project_type=web` → `skills/web/react-best-practices` — official React patterns (P6 review)
|
|
21
|
+
|
|
22
|
+
**Project-type gated (iOS):**
|
|
23
|
+
- `project_type=ios` → `skills/ios/swift-protocol-di-testing` — protocol-based DI for judging iOS test quality
|
|
24
|
+
|
|
25
|
+
**Mode-gated (same skill, different use):**
|
|
26
|
+
- `phase=4` (code-writing-adjacent review) / `phase=6` (quality review) → `skills/web/react-best-practices` — for judging idiomatic React in review
|
|
27
|
+
|
|
28
|
+
## Review Process
|
|
29
|
+
|
|
30
|
+
When invoked:
|
|
31
|
+
|
|
32
|
+
1. **Gather context** — Run `git diff --staged` and `git diff` to see all changes. If no diff, check recent commits with `git log --oneline -5`.
|
|
33
|
+
2. **Understand scope** — Identify which files changed, what feature/fix they relate to, and how they connect.
|
|
34
|
+
3. **Read surrounding code** — Don't review changes in isolation. Read the full file and understand imports, dependencies, and call sites.
|
|
35
|
+
4. **Apply review checklist** — Work through each category below, from CRITICAL to LOW.
|
|
36
|
+
5. **Report findings** — Use the output format below. Only report issues you are confident about (>80% sure it is a real problem).
|
|
37
|
+
|
|
38
|
+
## Confidence-Based Filtering
|
|
39
|
+
|
|
40
|
+
**IMPORTANT**: Do not flood the review with noise. Apply these filters:
|
|
41
|
+
|
|
42
|
+
- **Report** if you are >80% confident it is a real issue
|
|
43
|
+
- **Skip** stylistic preferences unless they violate project conventions
|
|
44
|
+
- **Skip** issues in unchanged code unless they are CRITICAL security issues
|
|
45
|
+
- **Consolidate** similar issues (e.g., "5 functions missing error handling" not 5 separate findings)
|
|
46
|
+
- **Prioritize** issues that could cause bugs, security vulnerabilities, or data loss
|
|
47
|
+
|
|
48
|
+
## Review Checklist
|
|
49
|
+
|
|
50
|
+
### Security (CRITICAL)
|
|
51
|
+
|
|
52
|
+
These MUST be flagged — they can cause real damage:
|
|
53
|
+
|
|
54
|
+
- **Hardcoded credentials** — API keys, passwords, tokens, connection strings in source
|
|
55
|
+
- **SQL injection** — String concatenation in queries instead of parameterized queries
|
|
56
|
+
- **XSS vulnerabilities** — Unescaped user input rendered in HTML/JSX
|
|
57
|
+
- **Path traversal** — User-controlled file paths without sanitization
|
|
58
|
+
- **CSRF vulnerabilities** — State-changing endpoints without CSRF protection
|
|
59
|
+
- **Authentication bypasses** — Missing auth checks on protected routes
|
|
60
|
+
- **Insecure dependencies** — Known vulnerable packages
|
|
61
|
+
- **Exposed secrets in logs** — Logging sensitive data (tokens, passwords, PII)
|
|
62
|
+
|
|
63
|
+
```typescript
|
|
64
|
+
// BAD: SQL injection via string concatenation
|
|
65
|
+
const query = `SELECT * FROM users WHERE id = ${userId}`;
|
|
66
|
+
|
|
67
|
+
// GOOD: Parameterized query
|
|
68
|
+
const query = `SELECT * FROM users WHERE id = $1`;
|
|
69
|
+
const result = await db.query(query, [userId]);
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
```typescript
|
|
73
|
+
// BAD: Rendering raw user HTML without sanitization
|
|
74
|
+
// Always sanitize user content with DOMPurify.sanitize() or equivalent
|
|
75
|
+
|
|
76
|
+
// GOOD: Use text content or sanitize
|
|
77
|
+
<div>{userComment}</div>
|
|
78
|
+
```
|
|
79
|
+
|
|
80
|
+
### Code Quality (HIGH)
|
|
81
|
+
|
|
82
|
+
- **Large functions** (>50 lines) — Split into smaller, focused functions
|
|
83
|
+
- **Large files** (>800 lines) — Extract modules by responsibility
|
|
84
|
+
- **Deep nesting** (>4 levels) — Use early returns, extract helpers
|
|
85
|
+
- **Missing error handling** — Unhandled promise rejections, empty catch blocks
|
|
86
|
+
- **Mutation patterns** — Prefer immutable operations (spread, map, filter)
|
|
87
|
+
- **console.log statements** — Remove debug logging before merge
|
|
88
|
+
- **Missing tests** — New code paths without test coverage
|
|
89
|
+
- **Dead code** — Commented-out code, unused imports, unreachable branches
|
|
90
|
+
|
|
91
|
+
```typescript
|
|
92
|
+
// BAD: Deep nesting + mutation
|
|
93
|
+
function processUsers(users) {
|
|
94
|
+
if (users) {
|
|
95
|
+
for (const user of users) {
|
|
96
|
+
if (user.active) {
|
|
97
|
+
if (user.email) {
|
|
98
|
+
user.verified = true; // mutation!
|
|
99
|
+
results.push(user);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return results;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
// GOOD: Early returns + immutability + flat
|
|
108
|
+
function processUsers(users) {
|
|
109
|
+
if (!users) return [];
|
|
110
|
+
return users
|
|
111
|
+
.filter(user => user.active && user.email)
|
|
112
|
+
.map(user => ({ ...user, verified: true }));
|
|
113
|
+
}
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
### React/Next.js Patterns (HIGH)
|
|
117
|
+
|
|
118
|
+
When reviewing React/Next.js code, also check:
|
|
119
|
+
|
|
120
|
+
- **Missing dependency arrays** — `useEffect`/`useMemo`/`useCallback` with incomplete deps
|
|
121
|
+
- **State updates in render** — Calling setState during render causes infinite loops
|
|
122
|
+
- **Missing keys in lists** — Using array index as key when items can reorder
|
|
123
|
+
- **Prop drilling** — Props passed through 3+ levels (use context or composition)
|
|
124
|
+
- **Unnecessary re-renders** — Missing memoization for expensive computations
|
|
125
|
+
- **Client/server boundary** — Using `useState`/`useEffect` in Server Components
|
|
126
|
+
- **Missing loading/error states** — Data fetching without fallback UI
|
|
127
|
+
- **Stale closures** — Event handlers capturing stale state values
|
|
128
|
+
|
|
129
|
+
```tsx
|
|
130
|
+
// BAD: Missing dependency, stale closure
|
|
131
|
+
useEffect(() => {
|
|
132
|
+
fetchData(userId);
|
|
133
|
+
}, []); // userId missing from deps
|
|
134
|
+
|
|
135
|
+
// GOOD: Complete dependencies
|
|
136
|
+
useEffect(() => {
|
|
137
|
+
fetchData(userId);
|
|
138
|
+
}, [userId]);
|
|
139
|
+
```
|
|
140
|
+
|
|
141
|
+
```tsx
|
|
142
|
+
// BAD: Using index as key with reorderable list
|
|
143
|
+
{items.map((item, i) => <ListItem key={i} item={item} />)}
|
|
144
|
+
|
|
145
|
+
// GOOD: Stable unique key
|
|
146
|
+
{items.map(item => <ListItem key={item.id} item={item} />)}
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
### Node.js/Backend Patterns (HIGH)
|
|
150
|
+
|
|
151
|
+
When reviewing backend code:
|
|
152
|
+
|
|
153
|
+
- **Unvalidated input** — Request body/params used without schema validation
|
|
154
|
+
- **Missing rate limiting** — Public endpoints without throttling
|
|
155
|
+
- **Unbounded queries** — `SELECT *` or queries without LIMIT on user-facing endpoints
|
|
156
|
+
- **N+1 queries** — Fetching related data in a loop instead of a join/batch
|
|
157
|
+
- **Missing timeouts** — External HTTP calls without timeout configuration
|
|
158
|
+
- **Error message leakage** — Sending internal error details to clients
|
|
159
|
+
- **Missing CORS configuration** — APIs accessible from unintended origins
|
|
160
|
+
|
|
161
|
+
```typescript
|
|
162
|
+
// BAD: N+1 query pattern
|
|
163
|
+
const users = await db.query('SELECT * FROM users');
|
|
164
|
+
for (const user of users) {
|
|
165
|
+
user.posts = await db.query('SELECT * FROM posts WHERE user_id = $1', [user.id]);
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
// GOOD: Single query with JOIN or batch
|
|
169
|
+
const usersWithPosts = await db.query(`
|
|
170
|
+
SELECT u.*, json_agg(p.*) as posts
|
|
171
|
+
FROM users u
|
|
172
|
+
LEFT JOIN posts p ON p.user_id = u.id
|
|
173
|
+
GROUP BY u.id
|
|
174
|
+
`);
|
|
175
|
+
```
|
|
176
|
+
|
|
177
|
+
### Performance (MEDIUM)
|
|
178
|
+
|
|
179
|
+
- **Inefficient algorithms** — O(n^2) when O(n log n) or O(n) is possible
|
|
180
|
+
- **Unnecessary re-renders** — Missing React.memo, useMemo, useCallback
|
|
181
|
+
- **Large bundle sizes** — Importing entire libraries when tree-shakeable alternatives exist
|
|
182
|
+
- **Missing caching** — Repeated expensive computations without memoization
|
|
183
|
+
- **Unoptimized images** — Large images without compression or lazy loading
|
|
184
|
+
- **Synchronous I/O** — Blocking operations in async contexts
|
|
185
|
+
|
|
186
|
+
### Best Practices (LOW)
|
|
187
|
+
|
|
188
|
+
- **TODO/FIXME without tickets** — TODOs should reference issue numbers
|
|
189
|
+
- **Missing JSDoc for public APIs** — Exported functions without documentation
|
|
190
|
+
- **Poor naming** — Single-letter variables (x, tmp, data) in non-trivial contexts
|
|
191
|
+
- **Magic numbers** — Unexplained numeric constants
|
|
192
|
+
- **Inconsistent formatting** — Mixed semicolons, quote styles, indentation
|
|
193
|
+
|
|
194
|
+
## Review Output Format
|
|
195
|
+
|
|
196
|
+
Organize findings by severity. For each issue:
|
|
197
|
+
|
|
198
|
+
```
|
|
199
|
+
[CRITICAL] Hardcoded API key in source
|
|
200
|
+
File: src/api/client.ts:42
|
|
201
|
+
Issue: API key "sk-abc..." exposed in source code. This will be committed to git history.
|
|
202
|
+
Fix: Move to environment variable and add to .gitignore/.env.example
|
|
203
|
+
|
|
204
|
+
const apiKey = "sk-abc123"; // BAD
|
|
205
|
+
const apiKey = process.env.API_KEY; // GOOD
|
|
206
|
+
```
|
|
207
|
+
|
|
208
|
+
### Summary Format
|
|
209
|
+
|
|
210
|
+
End every review with:
|
|
211
|
+
|
|
212
|
+
```
|
|
213
|
+
## Review Summary
|
|
214
|
+
|
|
215
|
+
| Severity | Count | Status |
|
|
216
|
+
|----------|-------|--------|
|
|
217
|
+
| CRITICAL | 0 | pass |
|
|
218
|
+
| HIGH | 2 | warn |
|
|
219
|
+
| MEDIUM | 3 | info |
|
|
220
|
+
| LOW | 1 | note |
|
|
221
|
+
|
|
222
|
+
Verdict: WARNING — 2 HIGH issues should be resolved before merge.
|
|
223
|
+
```
|
|
224
|
+
|
|
225
|
+
## Approval Criteria
|
|
226
|
+
|
|
227
|
+
- **Approve**: No CRITICAL or HIGH issues
|
|
228
|
+
- **Warning**: HIGH issues only (can merge with caution)
|
|
229
|
+
- **Block**: CRITICAL issues found — must fix before merge
|
|
230
|
+
|
|
231
|
+
## Project-Specific Guidelines
|
|
232
|
+
|
|
233
|
+
When available, also check project-specific conventions from `CLAUDE.md` or project rules:
|
|
234
|
+
|
|
235
|
+
- File size limits (e.g., 200-400 lines typical, 800 max)
|
|
236
|
+
- Emoji policy (many projects prohibit emojis in code)
|
|
237
|
+
- Immutability requirements (spread operator over mutation)
|
|
238
|
+
- Database policies (RLS, migration patterns)
|
|
239
|
+
- Error handling patterns (custom error classes, error boundaries)
|
|
240
|
+
- State management conventions (Zustand, Redux, Context)
|
|
241
|
+
|
|
242
|
+
Adapt your review to the project's established patterns. When in doubt, match what the rest of the codebase does.
|
|
243
|
+
|
|
244
|
+
## v1.8 AI-Generated Code Review Addendum
|
|
245
|
+
|
|
246
|
+
When reviewing AI-generated changes, prioritize:
|
|
247
|
+
|
|
248
|
+
1. Behavioral regressions and edge-case handling
|
|
249
|
+
2. Security assumptions and trust boundaries
|
|
250
|
+
3. Hidden coupling or accidental architecture drift
|
|
251
|
+
4. Unnecessary model-cost-inducing complexity
|
|
252
|
+
|
|
253
|
+
Cost-awareness check:
|
|
254
|
+
- Flag workflows that escalate to higher-cost models without clear reasoning need.
|
|
255
|
+
- Recommend defaulting to lower-cost tiers for deterministic refactors.
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: code-simplifier
|
|
3
|
+
description: Simplifies and refines code for clarity, consistency, and maintainability while preserving behavior. Focus on recently modified code unless instructed otherwise.
|
|
4
|
+
model: sonnet
|
|
5
|
+
tools: [Read, Write, Edit, Bash, Grep, Glob, Skill]
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# Code Simplifier Agent
|
|
9
|
+
|
|
10
|
+
You simplify code while preserving functionality.
|
|
11
|
+
|
|
12
|
+
## Skill Access
|
|
13
|
+
|
|
14
|
+
The orchestrator passes these variables into your dispatch prompt: `project_type` and `phase`.
|
|
15
|
+
|
|
16
|
+
**Rules:**
|
|
17
|
+
- Load skills from this shortlist ONLY. Never consult skills outside this list, even if familiar.
|
|
18
|
+
- No defaulting. When no gate matches a skill, do NOT load it.
|
|
19
|
+
- No substitutions.
|
|
20
|
+
|
|
21
|
+
General simplification is guided by the repo's own patterns, not external framework opinions. SwiftUI view simplification is an exception — it benefits from opinionated structural guidance.
|
|
22
|
+
|
|
23
|
+
**Project-type gated (iOS):**
|
|
24
|
+
- `project_type=ios AND (simplifying a SwiftUI view body, splitting long views, or reducing computed `some View` helpers)` → `skills/ios/swiftui-view-refactor` — view ordering, MV-over-MVVM, stable view trees
|
|
25
|
+
|
|
26
|
+
**Forbidden defaults:**
|
|
27
|
+
- Do NOT load `skills/ios/swift-concurrency` (older) — superseded by `swift-concurrency-6-2`.
|
|
28
|
+
|
|
29
|
+
## Principles
|
|
30
|
+
|
|
31
|
+
1. clarity over cleverness
|
|
32
|
+
2. consistency with existing repo style
|
|
33
|
+
3. preserve behavior exactly
|
|
34
|
+
4. simplify only where the result is demonstrably easier to maintain
|
|
35
|
+
|
|
36
|
+
## Simplification Targets
|
|
37
|
+
|
|
38
|
+
### Structure
|
|
39
|
+
|
|
40
|
+
- extract deeply nested logic into named functions
|
|
41
|
+
- replace complex conditionals with early returns where clearer
|
|
42
|
+
- simplify callback chains with `async` / `await`
|
|
43
|
+
- remove dead code and unused imports
|
|
44
|
+
|
|
45
|
+
### Readability
|
|
46
|
+
|
|
47
|
+
- prefer descriptive names
|
|
48
|
+
- avoid nested ternaries
|
|
49
|
+
- break long chains into intermediate variables when it improves clarity
|
|
50
|
+
- use destructuring when it clarifies access
|
|
51
|
+
|
|
52
|
+
### Quality
|
|
53
|
+
|
|
54
|
+
- remove stray `console.log`
|
|
55
|
+
- remove commented-out code
|
|
56
|
+
- consolidate duplicated logic
|
|
57
|
+
- unwind over-abstracted single-use helpers
|
|
58
|
+
|
|
59
|
+
## Approach
|
|
60
|
+
|
|
61
|
+
1. read the changed files
|
|
62
|
+
2. identify simplification opportunities
|
|
63
|
+
3. apply only functionally equivalent changes
|
|
64
|
+
4. verify no behavioral change was introduced
|