@ivannxbt/ai-config 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.agents/AGENTS.md +49 -0
- package/.agents/skills/ab-test-setup/SKILL.md +266 -0
- package/.agents/skills/ab-test-setup/references/sample-size-guide.md +263 -0
- package/.agents/skills/ab-test-setup/references/test-templates.md +277 -0
- package/.agents/skills/ad-creative/SKILL.md +362 -0
- package/.agents/skills/ad-creative/references/generative-tools.md +637 -0
- package/.agents/skills/ad-creative/references/platform-specs.md +213 -0
- package/.agents/skills/agent-browser/SKILL.md +347 -0
- package/.agents/skills/agent-browser/references/authentication.md +188 -0
- package/.agents/skills/agent-browser/references/proxy-support.md +175 -0
- package/.agents/skills/agent-browser/references/session-management.md +181 -0
- package/.agents/skills/agent-browser/references/snapshot-refs.md +186 -0
- package/.agents/skills/agent-browser/references/video-recording.md +162 -0
- package/.agents/skills/agent-browser/templates/authenticated-session.sh +91 -0
- package/.agents/skills/agent-browser/templates/capture-workflow.sh +68 -0
- package/.agents/skills/agent-browser/templates/form-automation.sh +64 -0
- package/.agents/skills/ai-seo/SKILL.md +398 -0
- package/.agents/skills/ai-seo/references/content-patterns.md +285 -0
- package/.agents/skills/ai-seo/references/platform-ranking-factors.md +152 -0
- package/.agents/skills/analytics-tracking/SKILL.md +309 -0
- package/.agents/skills/analytics-tracking/references/event-library.md +260 -0
- package/.agents/skills/analytics-tracking/references/ga4-implementation.md +300 -0
- package/.agents/skills/analytics-tracking/references/gtm-implementation.md +390 -0
- package/.agents/skills/appinsights-instrumentation/LICENSE.txt +21 -0
- package/.agents/skills/appinsights-instrumentation/SKILL.md +72 -0
- package/.agents/skills/appinsights-instrumentation/examples/appinsights.bicep +30 -0
- package/.agents/skills/appinsights-instrumentation/references/aspnetcore.md +29 -0
- package/.agents/skills/appinsights-instrumentation/references/auto.md +13 -0
- package/.agents/skills/appinsights-instrumentation/references/nodejs.md +28 -0
- package/.agents/skills/appinsights-instrumentation/references/python.md +48 -0
- package/.agents/skills/appinsights-instrumentation/references/sdk/azure-monitor-opentelemetry-exporter-java.md +31 -0
- package/.agents/skills/appinsights-instrumentation/references/sdk/azure-monitor-opentelemetry-exporter-py.md +22 -0
- package/.agents/skills/appinsights-instrumentation/references/sdk/azure-monitor-opentelemetry-py.md +23 -0
- package/.agents/skills/appinsights-instrumentation/references/sdk/azure-monitor-opentelemetry-ts.md +26 -0
- package/.agents/skills/appinsights-instrumentation/scripts/appinsights.ps1 +20 -0
- package/.agents/skills/audit-website/README.md +20 -0
- package/.agents/skills/audit-website/SKILL.md +470 -0
- package/.agents/skills/audit-website/agents/openai.yaml +6 -0
- package/.agents/skills/audit-website/assets/icon-large.png +0 -0
- package/.agents/skills/audit-website/assets/icon-small.svg +41 -0
- package/.agents/skills/audit-website/references/OUTPUT-FORMAT.md +250 -0
- package/.agents/skills/better-auth/SKILL.md +204 -0
- package/.agents/skills/better-auth/references/advanced-features.md +553 -0
- package/.agents/skills/better-auth/references/database-integration.md +577 -0
- package/.agents/skills/better-auth/references/email-password-auth.md +416 -0
- package/.agents/skills/better-auth/references/oauth-providers.md +430 -0
- package/.agents/skills/better-auth/scripts/.coverage +0 -0
- package/.agents/skills/better-auth/scripts/better_auth_init.py +521 -0
- package/.agents/skills/better-auth/scripts/requirements.txt +15 -0
- package/.agents/skills/better-auth/scripts/tests/.coverage +0 -0
- package/.agents/skills/better-auth/scripts/tests/test_better_auth_init.py +421 -0
- package/.agents/skills/better-auth-best-practices/SKILL.md +166 -0
- package/.agents/skills/building-native-ui/SKILL.md +321 -0
- package/.agents/skills/building-native-ui/references/animations.md +220 -0
- package/.agents/skills/building-native-ui/references/controls.md +270 -0
- package/.agents/skills/building-native-ui/references/form-sheet.md +227 -0
- package/.agents/skills/building-native-ui/references/gradients.md +106 -0
- package/.agents/skills/building-native-ui/references/icons.md +213 -0
- package/.agents/skills/building-native-ui/references/media.md +198 -0
- package/.agents/skills/building-native-ui/references/route-structure.md +229 -0
- package/.agents/skills/building-native-ui/references/search.md +248 -0
- package/.agents/skills/building-native-ui/references/storage.md +121 -0
- package/.agents/skills/building-native-ui/references/tabs.md +433 -0
- package/.agents/skills/building-native-ui/references/toolbar-and-headers.md +284 -0
- package/.agents/skills/building-native-ui/references/visual-effects.md +197 -0
- package/.agents/skills/building-native-ui/references/webgpu-three.md +605 -0
- package/.agents/skills/building-native-ui/references/zoom-transitions.md +158 -0
- package/.agents/skills/churn-prevention/SKILL.md +424 -0
- package/.agents/skills/churn-prevention/references/cancel-flow-patterns.md +316 -0
- package/.agents/skills/churn-prevention/references/dunning-playbook.md +408 -0
- package/.agents/skills/cold-email/SKILL.md +158 -0
- package/.agents/skills/cold-email/references/benchmarks.md +83 -0
- package/.agents/skills/cold-email/references/follow-up-sequences.md +81 -0
- package/.agents/skills/cold-email/references/frameworks.md +90 -0
- package/.agents/skills/cold-email/references/personalization.md +79 -0
- package/.agents/skills/cold-email/references/subject-lines.md +53 -0
- package/.agents/skills/competitor-alternatives/SKILL.md +256 -0
- package/.agents/skills/competitor-alternatives/references/content-architecture.md +271 -0
- package/.agents/skills/competitor-alternatives/references/templates.md +223 -0
- package/.agents/skills/content-strategy/SKILL.md +359 -0
- package/.agents/skills/copy-editing/SKILL.md +447 -0
- package/.agents/skills/copy-editing/references/plain-english-alternatives.md +394 -0
- package/.agents/skills/copywriting/SKILL.md +252 -0
- package/.agents/skills/copywriting/references/copy-frameworks.md +344 -0
- package/.agents/skills/copywriting/references/natural-transitions.md +272 -0
- package/.agents/skills/deep-agents-core/SKILL.md +423 -0
- package/.agents/skills/deep-agents-memory/SKILL.md +301 -0
- package/.agents/skills/deep-agents-orchestration/SKILL.md +471 -0
- package/.agents/skills/design-md/SKILL.md +172 -0
- package/.agents/skills/design-md/examples/DESIGN.md +154 -0
- package/.agents/skills/email-best-practices/README.md +63 -0
- package/.agents/skills/email-best-practices/SKILL.md +59 -0
- package/.agents/skills/email-best-practices/resources/compliance.md +125 -0
- package/.agents/skills/email-best-practices/resources/deliverability.md +121 -0
- package/.agents/skills/email-best-practices/resources/email-capture.md +129 -0
- package/.agents/skills/email-best-practices/resources/email-types.md +173 -0
- package/.agents/skills/email-best-practices/resources/list-management.md +157 -0
- package/.agents/skills/email-best-practices/resources/marketing-emails.md +115 -0
- package/.agents/skills/email-best-practices/resources/sending-reliability.md +155 -0
- package/.agents/skills/email-best-practices/resources/transactional-email-catalog.md +418 -0
- package/.agents/skills/email-best-practices/resources/transactional-emails.md +92 -0
- package/.agents/skills/email-best-practices/resources/webhooks-events.md +167 -0
- package/.agents/skills/email-best-practices/tests/README.md +35 -0
- package/.agents/skills/email-best-practices/tests/scenarios/01-spam-deliverability.md +46 -0
- package/.agents/skills/email-best-practices/tests/scenarios/02-multi-region-compliance.md +48 -0
- package/.agents/skills/email-best-practices/tests/scenarios/03-retry-idempotency.md +36 -0
- package/.agents/skills/email-best-practices/tests/scenarios/04-webhook-bounce-handling.md +52 -0
- package/.agents/skills/email-best-practices/tests/scenarios/05-new-saas-email-plan.md +51 -0
- package/.agents/skills/email-sequence/SKILL.md +309 -0
- package/.agents/skills/email-sequence/references/copy-guidelines.md +113 -0
- package/.agents/skills/email-sequence/references/email-types.md +515 -0
- package/.agents/skills/email-sequence/references/sequence-templates.md +168 -0
- package/.agents/skills/entra-app-registration/SKILL.md +191 -0
- package/.agents/skills/entra-app-registration/references/BICEP-EXAMPLE.bicep +199 -0
- package/.agents/skills/entra-app-registration/references/api-permissions.md +341 -0
- package/.agents/skills/entra-app-registration/references/auth-best-practices.md +128 -0
- package/.agents/skills/entra-app-registration/references/cli-commands.md +409 -0
- package/.agents/skills/entra-app-registration/references/console-app-example.md +392 -0
- package/.agents/skills/entra-app-registration/references/first-app-registration.md +243 -0
- package/.agents/skills/entra-app-registration/references/oauth-flows.md +398 -0
- package/.agents/skills/entra-app-registration/references/sdk/azure-identity-dotnet.md +22 -0
- package/.agents/skills/entra-app-registration/references/sdk/azure-identity-java.md +30 -0
- package/.agents/skills/entra-app-registration/references/sdk/azure-identity-py.md +27 -0
- package/.agents/skills/entra-app-registration/references/sdk/azure-identity-rust.md +21 -0
- package/.agents/skills/entra-app-registration/references/sdk/azure-identity-ts.md +24 -0
- package/.agents/skills/entra-app-registration/references/sdk/azure-keyvault-py.md +25 -0
- package/.agents/skills/entra-app-registration/references/sdk/azure-keyvault-secrets-ts.md +23 -0
- package/.agents/skills/entra-app-registration/references/sdk/microsoft-azure-webjobs-extensions-authentication-events-dotnet.md +37 -0
- package/.agents/skills/entra-app-registration/references/troubleshooting.md +269 -0
- package/.agents/skills/expo-api-routes/SKILL.md +368 -0
- package/.agents/skills/expo-cicd-workflows/SKILL.md +92 -0
- package/.agents/skills/expo-cicd-workflows/scripts/fetch.js +109 -0
- package/.agents/skills/expo-cicd-workflows/scripts/package.json +11 -0
- package/.agents/skills/expo-cicd-workflows/scripts/validate.js +84 -0
- package/.agents/skills/expo-deployment/SKILL.md +190 -0
- package/.agents/skills/expo-deployment/references/app-store-metadata.md +479 -0
- package/.agents/skills/expo-deployment/references/ios-app-store.md +355 -0
- package/.agents/skills/expo-deployment/references/play-store.md +246 -0
- package/.agents/skills/expo-deployment/references/testflight.md +58 -0
- package/.agents/skills/expo-deployment/references/workflows.md +200 -0
- package/.agents/skills/expo-dev-client/SKILL.md +164 -0
- package/.agents/skills/expo-react-native-performance/AGENTS.md +2515 -0
- package/.agents/skills/expo-react-native-performance/SKILL.md +118 -0
- package/.agents/skills/expo-react-native-performance/references/anim-interaction-manager.md +63 -0
- package/.agents/skills/expo-react-native-performance/references/anim-layout-animation.md +75 -0
- package/.agents/skills/expo-react-native-performance/references/anim-transform-not-dimensions.md +67 -0
- package/.agents/skills/expo-react-native-performance/references/anim-use-native-driver.md +55 -0
- package/.agents/skills/expo-react-native-performance/references/anim-use-reanimated.md +53 -0
- package/.agents/skills/expo-react-native-performance/references/asset-optimize-image-size.md +60 -0
- package/.agents/skills/expo-react-native-performance/references/asset-prefetch-images.md +60 -0
- package/.agents/skills/expo-react-native-performance/references/asset-recycling-key.md +57 -0
- package/.agents/skills/expo-react-native-performance/references/asset-use-expo-image.md +58 -0
- package/.agents/skills/expo-react-native-performance/references/asset-use-webp-format.md +50 -0
- package/.agents/skills/expo-react-native-performance/references/async-batch-api-calls.md +65 -0
- package/.agents/skills/expo-react-native-performance/references/async-cache-responses.md +54 -0
- package/.agents/skills/expo-react-native-performance/references/async-defer-await.md +56 -0
- package/.agents/skills/expo-react-native-performance/references/async-parallel-fetching.md +60 -0
- package/.agents/skills/expo-react-native-performance/references/async-refetch-on-focus.md +68 -0
- package/.agents/skills/expo-react-native-performance/references/list-estimated-item-size.md +52 -0
- package/.agents/skills/expo-react-native-performance/references/list-get-item-layout.md +64 -0
- package/.agents/skills/expo-react-native-performance/references/list-get-item-type.md +59 -0
- package/.agents/skills/expo-react-native-performance/references/list-memoize-items.md +59 -0
- package/.agents/skills/expo-react-native-performance/references/list-stable-render-item.md +61 -0
- package/.agents/skills/expo-react-native-performance/references/list-use-flashlist.md +56 -0
- package/.agents/skills/expo-react-native-performance/references/mem-abort-fetch.md +78 -0
- package/.agents/skills/expo-react-native-performance/references/mem-avoid-inline-objects.md +61 -0
- package/.agents/skills/expo-react-native-performance/references/mem-cleanup-subscriptions.md +63 -0
- package/.agents/skills/expo-react-native-performance/references/mem-clear-timers.md +63 -0
- package/.agents/skills/expo-react-native-performance/references/mem-limit-list-data.md +69 -0
- package/.agents/skills/expo-react-native-performance/references/platform-android-overdraw.md +63 -0
- package/.agents/skills/expo-react-native-performance/references/platform-android-proguard.md +63 -0
- package/.agents/skills/expo-react-native-performance/references/platform-conditional-render.md +81 -0
- package/.agents/skills/expo-react-native-performance/references/platform-ios-text-rendering.md +57 -0
- package/.agents/skills/expo-react-native-performance/references/rerender-derive-state.md +58 -0
- package/.agents/skills/expo-react-native-performance/references/rerender-functional-setstate.md +54 -0
- package/.agents/skills/expo-react-native-performance/references/rerender-lazy-state-init.md +55 -0
- package/.agents/skills/expo-react-native-performance/references/rerender-split-context.md +69 -0
- package/.agents/skills/expo-react-native-performance/references/rerender-use-callback-handlers.md +63 -0
- package/.agents/skills/expo-react-native-performance/references/rerender-use-memo-expensive.md +54 -0
- package/.agents/skills/expo-react-native-performance/references/startup-async-routes.md +63 -0
- package/.agents/skills/expo-react-native-performance/references/startup-cherry-pick-imports.md +45 -0
- package/.agents/skills/expo-react-native-performance/references/startup-enable-hermes.md +39 -0
- package/.agents/skills/expo-react-native-performance/references/startup-preload-assets.md +68 -0
- package/.agents/skills/expo-react-native-performance/references/startup-remove-console-logs.md +47 -0
- package/.agents/skills/expo-react-native-performance/references/startup-splash-screen-control.md +58 -0
- package/.agents/skills/expo-tailwind-setup/SKILL.md +480 -0
- package/.agents/skills/express-rest-api/SKILL.md +249 -0
- package/.agents/skills/express-rest-api/assets/config.yaml +1 -0
- package/.agents/skills/express-rest-api/references/GUIDE.md +1 -0
- package/.agents/skills/express-rest-api/scripts/helper.py +3 -0
- package/.agents/skills/find-skills/SKILL.md +133 -0
- package/.agents/skills/form-cro/SKILL.md +429 -0
- package/.agents/skills/framer-code-components-overrides/SKILL.md +297 -0
- package/.agents/skills/framer-code-components-overrides/references/patterns.md +338 -0
- package/.agents/skills/framer-code-components-overrides/references/property-controls.md +241 -0
- package/.agents/skills/framer-code-components-overrides/references/webgl-shaders.md +207 -0
- package/.agents/skills/framework-selection/SKILL.md +163 -0
- package/.agents/skills/free-tool-strategy/SKILL.md +178 -0
- package/.agents/skills/free-tool-strategy/references/tool-types.md +217 -0
- package/.agents/skills/frontend-design/LICENSE.txt +177 -0
- package/.agents/skills/frontend-design/SKILL.md +42 -0
- package/.agents/skills/gws-calendar/SKILL.md +108 -0
- package/.agents/skills/gws-calendar-agenda/SKILL.md +52 -0
- package/.agents/skills/gws-calendar-insert/SKILL.md +55 -0
- package/.agents/skills/gws-docs/SKILL.md +48 -0
- package/.agents/skills/gws-docs-write/SKILL.md +49 -0
- package/.agents/skills/gws-drive/SKILL.md +137 -0
- package/.agents/skills/gws-drive-upload/SKILL.md +52 -0
- package/.agents/skills/gws-gmail/SKILL.md +59 -0
- package/.agents/skills/gws-gmail-forward/SKILL.md +52 -0
- package/.agents/skills/gws-gmail-reply/SKILL.md +51 -0
- package/.agents/skills/gws-gmail-reply-all/SKILL.md +54 -0
- package/.agents/skills/gws-gmail-send/SKILL.md +52 -0
- package/.agents/skills/gws-gmail-triage/SKILL.md +50 -0
- package/.agents/skills/gws-gmail-watch/SKILL.md +58 -0
- package/.agents/skills/gws-meet/SKILL.md +51 -0
- package/.agents/skills/gws-shared/SKILL.md +66 -0
- package/.agents/skills/gws-sheets/SKILL.md +53 -0
- package/.agents/skills/gws-sheets-append/SKILL.md +51 -0
- package/.agents/skills/gws-sheets-read/SKILL.md +47 -0
- package/.agents/skills/gws-slides/SKILL.md +43 -0
- package/.agents/skills/gws-workflow/SKILL.md +44 -0
- package/.agents/skills/gws-workflow-email-to-task/SKILL.md +47 -0
- package/.agents/skills/gws-workflow-file-announce/SKILL.md +50 -0
- package/.agents/skills/gws-workflow-meeting-prep/SKILL.md +47 -0
- package/.agents/skills/gws-workflow-standup-report/SKILL.md +46 -0
- package/.agents/skills/gws-workflow-weekly-digest/SKILL.md +46 -0
- package/.agents/skills/langchain-dependencies/SKILL.md +419 -0
- package/.agents/skills/langchain-fundamentals/SKILL.md +392 -0
- package/.agents/skills/langchain-middleware/SKILL.md +302 -0
- package/.agents/skills/langchain-rag/SKILL.md +517 -0
- package/.agents/skills/langgraph-fundamentals/SKILL.md +811 -0
- package/.agents/skills/langgraph-human-in-the-loop/SKILL.md +532 -0
- package/.agents/skills/langgraph-persistence/SKILL.md +560 -0
- package/.agents/skills/launch-strategy/SKILL.md +353 -0
- package/.agents/skills/marketing-ideas/SKILL.md +167 -0
- package/.agents/skills/marketing-ideas/references/ideas-by-category.md +366 -0
- package/.agents/skills/marketing-psychology/SKILL.md +455 -0
- package/.agents/skills/microsoft-foundry/SKILL.md +102 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/create/create-prompt.md +89 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/create/create.md +239 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/create/references/agent-tools.md +45 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/create/references/agentframework.md +92 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/create/references/sdk-operations.md +47 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/create/references/tool-azure-ai-search.md +69 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/create/references/tool-bing-grounding.md +50 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/create/references/tool-file-search.md +60 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/create/references/tool-mcp.md +66 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/create/references/tool-memory.md +109 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/create/references/tool-web-search.md +57 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/deploy/deploy.md +319 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/invoke/invoke.md +98 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/observe/observe.md +51 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/observe/references/analyze-results.md +47 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/observe/references/cicd-monitoring.md +35 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/observe/references/compare-iterate.md +48 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/observe/references/deploy-and-setup.md +76 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/observe/references/evaluate-step.md +51 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/observe/references/optimize-deploy.md +30 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/trace/references/analyze-failures.md +83 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/trace/references/analyze-latency.md +90 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/trace/references/conversation-detail.md +84 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/trace/references/eval-correlation.md +57 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/trace/references/kql-templates.md +173 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/trace/references/search-traces.md +141 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/trace/trace.md +57 -0
- package/.agents/skills/microsoft-foundry/foundry-agent/troubleshoot/troubleshoot.md +93 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/SKILL.md +144 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/TEST_PROMPTS.md +78 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/capacity/SKILL.md +146 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/capacity/scripts/discover_and_rank.ps1 +113 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/capacity/scripts/discover_and_rank.sh +113 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/capacity/scripts/query_capacity.ps1 +80 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/capacity/scripts/query_capacity.sh +75 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/customize/EXAMPLES.md +90 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/customize/SKILL.md +168 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/customize/references/customize-guides.md +124 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/customize/references/customize-workflow.md +410 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/preset/EXAMPLES.md +68 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/preset/SKILL.md +103 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/preset/references/preset-workflow.md +694 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/preset/references/workflow.md +172 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/scripts/generate_deployment_url.ps1 +73 -0
- package/.agents/skills/microsoft-foundry/models/deploy-model/scripts/generate_deployment_url.sh +90 -0
- package/.agents/skills/microsoft-foundry/project/connections.md +58 -0
- package/.agents/skills/microsoft-foundry/project/create/create-foundry-project.md +132 -0
- package/.agents/skills/microsoft-foundry/quota/quota.md +186 -0
- package/.agents/skills/microsoft-foundry/quota/references/capacity-planning.md +124 -0
- package/.agents/skills/microsoft-foundry/quota/references/error-resolution.md +143 -0
- package/.agents/skills/microsoft-foundry/quota/references/optimization.md +166 -0
- package/.agents/skills/microsoft-foundry/quota/references/ptu-guide.md +150 -0
- package/.agents/skills/microsoft-foundry/quota/references/troubleshooting.md +209 -0
- package/.agents/skills/microsoft-foundry/quota/references/workflows.md +174 -0
- package/.agents/skills/microsoft-foundry/rbac/rbac.md +156 -0
- package/.agents/skills/microsoft-foundry/references/auth-best-practices.md +128 -0
- package/.agents/skills/microsoft-foundry/references/sdk/foundry-sdk-py.md +263 -0
- package/.agents/skills/microsoft-foundry/resource/create/create-foundry-resource.md +150 -0
- package/.agents/skills/microsoft-foundry/resource/create/references/patterns.md +134 -0
- package/.agents/skills/microsoft-foundry/resource/create/references/troubleshooting.md +92 -0
- package/.agents/skills/microsoft-foundry/resource/create/references/workflows.md +235 -0
- package/.agents/skills/native-data-fetching/SKILL.md +491 -0
- package/.agents/skills/next-best-practices/SKILL.md +153 -0
- package/.agents/skills/next-best-practices/async-patterns.md +87 -0
- package/.agents/skills/next-best-practices/bundling.md +180 -0
- package/.agents/skills/next-best-practices/data-patterns.md +297 -0
- package/.agents/skills/next-best-practices/debug-tricks.md +105 -0
- package/.agents/skills/next-best-practices/directives.md +73 -0
- package/.agents/skills/next-best-practices/error-handling.md +227 -0
- package/.agents/skills/next-best-practices/file-conventions.md +140 -0
- package/.agents/skills/next-best-practices/font.md +245 -0
- package/.agents/skills/next-best-practices/functions.md +108 -0
- package/.agents/skills/next-best-practices/hydration-error.md +91 -0
- package/.agents/skills/next-best-practices/image.md +173 -0
- package/.agents/skills/next-best-practices/metadata.md +301 -0
- package/.agents/skills/next-best-practices/parallel-routes.md +287 -0
- package/.agents/skills/next-best-practices/route-handlers.md +146 -0
- package/.agents/skills/next-best-practices/rsc-boundaries.md +159 -0
- package/.agents/skills/next-best-practices/runtime-selection.md +39 -0
- package/.agents/skills/next-best-practices/scripts.md +141 -0
- package/.agents/skills/next-best-practices/self-hosting.md +371 -0
- package/.agents/skills/next-best-practices/suspense-boundaries.md +67 -0
- package/.agents/skills/onboarding-cro/SKILL.md +220 -0
- package/.agents/skills/onboarding-cro/references/experiments.md +258 -0
- package/.agents/skills/page-cro/SKILL.md +182 -0
- package/.agents/skills/page-cro/references/experiments.md +248 -0
- package/.agents/skills/paid-ads/SKILL.md +315 -0
- package/.agents/skills/paid-ads/references/ad-copy-templates.md +207 -0
- package/.agents/skills/paid-ads/references/audience-targeting.md +243 -0
- package/.agents/skills/paid-ads/references/platform-setup-checklists.md +277 -0
- package/.agents/skills/paywall-upgrade-cro/SKILL.md +227 -0
- package/.agents/skills/paywall-upgrade-cro/references/experiments.md +164 -0
- package/.agents/skills/persona-content-creator/SKILL.md +33 -0
- package/.agents/skills/persona-customer-support/SKILL.md +34 -0
- package/.agents/skills/persona-event-coordinator/SKILL.md +35 -0
- package/.agents/skills/persona-exec-assistant/SKILL.md +35 -0
- package/.agents/skills/persona-hr-coordinator/SKILL.md +33 -0
- package/.agents/skills/persona-it-admin/SKILL.md +30 -0
- package/.agents/skills/persona-project-manager/SKILL.md +35 -0
- package/.agents/skills/persona-researcher/SKILL.md +33 -0
- package/.agents/skills/persona-sales-ops/SKILL.md +35 -0
- package/.agents/skills/persona-team-lead/SKILL.md +36 -0
- package/.agents/skills/popup-cro/SKILL.md +453 -0
- package/.agents/skills/pricing-strategy/SKILL.md +231 -0
- package/.agents/skills/pricing-strategy/references/research-methods.md +152 -0
- package/.agents/skills/pricing-strategy/references/tier-structure.md +232 -0
- package/.agents/skills/prisma-cli/SKILL.md +243 -0
- package/.agents/skills/prisma-cli/references/db-execute.md +75 -0
- package/.agents/skills/prisma-cli/references/db-pull.md +185 -0
- package/.agents/skills/prisma-cli/references/db-push.md +148 -0
- package/.agents/skills/prisma-cli/references/db-seed.md +191 -0
- package/.agents/skills/prisma-cli/references/debug.md +46 -0
- package/.agents/skills/prisma-cli/references/dev.md +157 -0
- package/.agents/skills/prisma-cli/references/format.md +48 -0
- package/.agents/skills/prisma-cli/references/generate.md +147 -0
- package/.agents/skills/prisma-cli/references/init.md +118 -0
- package/.agents/skills/prisma-cli/references/migrate-deploy.md +127 -0
- package/.agents/skills/prisma-cli/references/migrate-dev.md +143 -0
- package/.agents/skills/prisma-cli/references/migrate-diff.md +89 -0
- package/.agents/skills/prisma-cli/references/migrate-reset.md +72 -0
- package/.agents/skills/prisma-cli/references/migrate-resolve.md +57 -0
- package/.agents/skills/prisma-cli/references/migrate-status.md +65 -0
- package/.agents/skills/prisma-cli/references/studio.md +122 -0
- package/.agents/skills/prisma-cli/references/validate.md +53 -0
- package/.agents/skills/prisma-client-api/SKILL.md +216 -0
- package/.agents/skills/prisma-client-api/references/client-methods.md +221 -0
- package/.agents/skills/prisma-client-api/references/constructor.md +185 -0
- package/.agents/skills/prisma-client-api/references/filters.md +256 -0
- package/.agents/skills/prisma-client-api/references/model-queries.md +281 -0
- package/.agents/skills/prisma-client-api/references/query-options.md +276 -0
- package/.agents/skills/prisma-client-api/references/raw-queries.md +194 -0
- package/.agents/skills/prisma-client-api/references/relations.md +308 -0
- package/.agents/skills/prisma-client-api/references/transactions.md +184 -0
- package/.agents/skills/prisma-database-setup/SKILL.md +186 -0
- package/.agents/skills/prisma-database-setup/references/cockroachdb.md +89 -0
- package/.agents/skills/prisma-database-setup/references/mongodb.md +72 -0
- package/.agents/skills/prisma-database-setup/references/mysql.md +109 -0
- package/.agents/skills/prisma-database-setup/references/postgresql.md +92 -0
- package/.agents/skills/prisma-database-setup/references/prisma-client-setup.md +47 -0
- package/.agents/skills/prisma-database-setup/references/prisma-postgres.md +90 -0
- package/.agents/skills/prisma-database-setup/references/sqlite.md +106 -0
- package/.agents/skills/prisma-database-setup/references/sqlserver.md +94 -0
- package/.agents/skills/prisma-driver-adapter-implementation/SKILL.md +638 -0
- package/.agents/skills/prisma-postgres/SKILL.md +110 -0
- package/.agents/skills/prisma-postgres/references/console-and-connections.md +40 -0
- package/.agents/skills/prisma-postgres/references/create-db-cli.md +123 -0
- package/.agents/skills/prisma-postgres/references/management-api-sdk.md +56 -0
- package/.agents/skills/prisma-postgres/references/management-api.md +61 -0
- package/.agents/skills/prisma-upgrade-v7/SKILL.md +228 -0
- package/.agents/skills/prisma-upgrade-v7/references/accelerate-users.md +151 -0
- package/.agents/skills/prisma-upgrade-v7/references/driver-adapters.md +251 -0
- package/.agents/skills/prisma-upgrade-v7/references/env-variables.md +161 -0
- package/.agents/skills/prisma-upgrade-v7/references/esm-support.md +160 -0
- package/.agents/skills/prisma-upgrade-v7/references/prisma-config.md +203 -0
- package/.agents/skills/prisma-upgrade-v7/references/removed-features.md +215 -0
- package/.agents/skills/prisma-upgrade-v7/references/schema-changes.md +111 -0
- package/.agents/skills/product-marketing-context/SKILL.md +241 -0
- package/.agents/skills/programmatic-seo/SKILL.md +238 -0
- package/.agents/skills/programmatic-seo/references/playbooks.md +308 -0
- package/.agents/skills/react-doctor/SKILL.md +41 -0
- package/.agents/skills/react-native-best-practices/POWER.md +145 -0
- package/.agents/skills/react-native-best-practices/SKILL.md +215 -0
- package/.agents/skills/react-native-best-practices/agents/openai.yaml +4 -0
- package/.agents/skills/react-native-best-practices/references/bundle-analyze-app.md +211 -0
- package/.agents/skills/react-native-best-practices/references/bundle-analyze-js.md +262 -0
- package/.agents/skills/react-native-best-practices/references/bundle-barrel-exports.md +248 -0
- package/.agents/skills/react-native-best-practices/references/bundle-code-splitting.md +224 -0
- package/.agents/skills/react-native-best-practices/references/bundle-hermes-mmap.md +167 -0
- package/.agents/skills/react-native-best-practices/references/bundle-library-size.md +177 -0
- package/.agents/skills/react-native-best-practices/references/bundle-native-assets.md +214 -0
- package/.agents/skills/react-native-best-practices/references/bundle-r8-android.md +225 -0
- package/.agents/skills/react-native-best-practices/references/bundle-tree-shaking.md +214 -0
- package/.agents/skills/react-native-best-practices/references/images/bundle-treemap-source-map-explorer.png +0 -0
- package/.agents/skills/react-native-best-practices/references/images/controlled-textinput-pingpong.png +0 -0
- package/.agents/skills/react-native-best-practices/references/images/devtools-flamegraph.png +0 -0
- package/.agents/skills/react-native-best-practices/references/images/emerge-xray-ios.png +0 -0
- package/.agents/skills/react-native-best-practices/references/images/expo-atlas-treemap.png +0 -0
- package/.agents/skills/react-native-best-practices/references/images/flashlight-flatlist-vs-flashlist.png +0 -0
- package/.agents/skills/react-native-best-practices/references/images/fps-drop-graph.png +0 -0
- package/.agents/skills/react-native-best-practices/references/images/memory-heap-snapshot.png +0 -0
- package/.agents/skills/react-native-best-practices/references/images/tti-warm-start-diagram.png +0 -0
- package/.agents/skills/react-native-best-practices/references/images/view-hierarchy-flattening.png +0 -0
- package/.agents/skills/react-native-best-practices/references/images/xcode-instruments-templates.png +0 -0
- package/.agents/skills/react-native-best-practices/references/images/xcode-thread-view.png +0 -0
- package/.agents/skills/react-native-best-practices/references/js-animations-reanimated.md +254 -0
- package/.agents/skills/react-native-best-practices/references/js-atomic-state.md +245 -0
- package/.agents/skills/react-native-best-practices/references/js-concurrent-react.md +236 -0
- package/.agents/skills/react-native-best-practices/references/js-lists-flatlist-flashlist.md +236 -0
- package/.agents/skills/react-native-best-practices/references/js-measure-fps.md +180 -0
- package/.agents/skills/react-native-best-practices/references/js-memory-leaks.md +205 -0
- package/.agents/skills/react-native-best-practices/references/js-profile-react.md +161 -0
- package/.agents/skills/react-native-best-practices/references/js-react-compiler.md +368 -0
- package/.agents/skills/react-native-best-practices/references/js-uncontrolled-components.md +216 -0
- package/.agents/skills/react-native-best-practices/references/native-android-16kb-alignment.md +113 -0
- package/.agents/skills/react-native-best-practices/references/native-measure-tti.md +262 -0
- package/.agents/skills/react-native-best-practices/references/native-memory-leaks.md +240 -0
- package/.agents/skills/react-native-best-practices/references/native-memory-patterns.md +274 -0
- package/.agents/skills/react-native-best-practices/references/native-platform-setup.md +110 -0
- package/.agents/skills/react-native-best-practices/references/native-profiling.md +176 -0
- package/.agents/skills/react-native-best-practices/references/native-sdks-over-polyfills.md +183 -0
- package/.agents/skills/react-native-best-practices/references/native-threading-model.md +234 -0
- package/.agents/skills/react-native-best-practices/references/native-turbo-modules.md +292 -0
- package/.agents/skills/react-native-best-practices/references/native-view-flattening.md +201 -0
- package/.agents/skills/react-native-expo/.claude-plugin/plugin.json +13 -0
- package/.agents/skills/react-native-expo/SKILL.md +1077 -0
- package/.agents/skills/react-native-expo/agents/expo-build.md +207 -0
- package/.agents/skills/react-native-expo/assets/css-features-cheatsheet.md +488 -0
- package/.agents/skills/react-native-expo/assets/example-template.txt +14 -0
- package/.agents/skills/react-native-expo/assets/new-arch-decision-tree.md +312 -0
- package/.agents/skills/react-native-expo/references/example-reference.md +26 -0
- package/.agents/skills/react-native-expo/references/expo-sdk-52-breaking.md +409 -0
- package/.agents/skills/react-native-expo/references/new-architecture-errors.md +501 -0
- package/.agents/skills/react-native-expo/references/react-19-migration.md +365 -0
- package/.agents/skills/react-native-expo/scripts/check-rn-version.sh +121 -0
- package/.agents/skills/react-native-expo/scripts/example-script.sh +15 -0
- package/.agents/skills/react-native-testing/SKILL.md +161 -0
- package/.agents/skills/react-native-testing/references/anti-patterns.md +287 -0
- package/.agents/skills/react-native-testing/references/api-reference-v13.md +572 -0
- package/.agents/skills/react-native-testing/references/api-reference-v14.md +574 -0
- package/.agents/skills/recipe-audit-external-sharing/SKILL.md +28 -0
- package/.agents/skills/recipe-backup-sheet-as-csv/SKILL.md +25 -0
- package/.agents/skills/recipe-batch-invite-to-event/SKILL.md +25 -0
- package/.agents/skills/recipe-batch-rename-files/SKILL.md +25 -0
- package/.agents/skills/recipe-batch-reply-to-emails/SKILL.md +26 -0
- package/.agents/skills/recipe-block-focus-time/SKILL.md +24 -0
- package/.agents/skills/recipe-bulk-download-folder/SKILL.md +25 -0
- package/.agents/skills/recipe-cancel-and-notify/SKILL.md +28 -0
- package/.agents/skills/recipe-collect-form-responses/SKILL.md +25 -0
- package/.agents/skills/recipe-compare-sheet-tabs/SKILL.md +25 -0
- package/.agents/skills/recipe-copy-sheet-for-new-month/SKILL.md +25 -0
- package/.agents/skills/recipe-create-classroom-course/SKILL.md +25 -0
- package/.agents/skills/recipe-create-doc-from-template/SKILL.md +29 -0
- package/.agents/skills/recipe-create-events-from-sheet/SKILL.md +24 -0
- package/.agents/skills/recipe-create-expense-tracker/SKILL.md +26 -0
- package/.agents/skills/recipe-create-feedback-form/SKILL.md +25 -0
- package/.agents/skills/recipe-create-gmail-filter/SKILL.md +26 -0
- package/.agents/skills/recipe-create-meet-space/SKILL.md +25 -0
- package/.agents/skills/recipe-create-presentation/SKILL.md +25 -0
- package/.agents/skills/recipe-create-shared-drive/SKILL.md +25 -0
- package/.agents/skills/recipe-create-task-list/SKILL.md +26 -0
- package/.agents/skills/recipe-create-vacation-responder/SKILL.md +25 -0
- package/.agents/skills/recipe-deploy-apps-script/SKILL.md +26 -0
- package/.agents/skills/recipe-draft-email-from-doc/SKILL.md +25 -0
- package/.agents/skills/recipe-email-drive-link/SKILL.md +25 -0
- package/.agents/skills/recipe-find-free-time/SKILL.md +25 -0
- package/.agents/skills/recipe-find-large-files/SKILL.md +24 -0
- package/.agents/skills/recipe-forward-labeled-emails/SKILL.md +27 -0
- package/.agents/skills/recipe-generate-report-from-sheet/SKILL.md +34 -0
- package/.agents/skills/recipe-label-and-archive-emails/SKILL.md +25 -0
- package/.agents/skills/recipe-log-deal-update/SKILL.md +25 -0
- package/.agents/skills/recipe-organize-drive-folder/SKILL.md +26 -0
- package/.agents/skills/recipe-plan-weekly-schedule/SKILL.md +26 -0
- package/.agents/skills/recipe-post-mortem-setup/SKILL.md +25 -0
- package/.agents/skills/recipe-reschedule-meeting/SKILL.md +25 -0
- package/.agents/skills/recipe-review-meet-participants/SKILL.md +25 -0
- package/.agents/skills/recipe-review-overdue-tasks/SKILL.md +25 -0
- package/.agents/skills/recipe-save-email-attachments/SKILL.md +26 -0
- package/.agents/skills/recipe-save-email-to-doc/SKILL.md +29 -0
- package/.agents/skills/recipe-schedule-recurring-event/SKILL.md +24 -0
- package/.agents/skills/recipe-search-and-export-emails/SKILL.md +25 -0
- package/.agents/skills/recipe-send-personalized-emails/SKILL.md +24 -0
- package/.agents/skills/recipe-send-team-announcement/SKILL.md +24 -0
- package/.agents/skills/recipe-share-doc-and-notify/SKILL.md +25 -0
- package/.agents/skills/recipe-share-event-materials/SKILL.md +25 -0
- package/.agents/skills/recipe-share-folder-with-team/SKILL.md +26 -0
- package/.agents/skills/recipe-sync-contacts-to-sheet/SKILL.md +25 -0
- package/.agents/skills/recipe-transfer-file-ownership/SKILL.md +27 -0
- package/.agents/skills/recipe-triage-security-alerts/SKILL.md +25 -0
- package/.agents/skills/recipe-watch-drive-changes/SKILL.md +25 -0
- package/.agents/skills/referral-program/SKILL.md +255 -0
- package/.agents/skills/referral-program/references/affiliate-programs.md +164 -0
- package/.agents/skills/referral-program/references/program-examples.md +143 -0
- package/.agents/skills/remotion-best-practices/SKILL.md +43 -0
- package/.agents/skills/remotion-best-practices/rules/3d.md +86 -0
- package/.agents/skills/remotion-best-practices/rules/animations.md +29 -0
- package/.agents/skills/remotion-best-practices/rules/assets/charts-bar-chart.tsx +173 -0
- package/.agents/skills/remotion-best-practices/rules/assets/text-animations-typewriter.tsx +100 -0
- package/.agents/skills/remotion-best-practices/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/.agents/skills/remotion-best-practices/rules/assets.md +78 -0
- package/.agents/skills/remotion-best-practices/rules/audio.md +172 -0
- package/.agents/skills/remotion-best-practices/rules/calculate-metadata.md +104 -0
- package/.agents/skills/remotion-best-practices/rules/can-decode.md +75 -0
- package/.agents/skills/remotion-best-practices/rules/charts.md +58 -0
- package/.agents/skills/remotion-best-practices/rules/compositions.md +146 -0
- package/.agents/skills/remotion-best-practices/rules/display-captions.md +126 -0
- package/.agents/skills/remotion-best-practices/rules/extract-frames.md +229 -0
- package/.agents/skills/remotion-best-practices/rules/fonts.md +152 -0
- package/.agents/skills/remotion-best-practices/rules/get-audio-duration.md +58 -0
- package/.agents/skills/remotion-best-practices/rules/get-video-dimensions.md +68 -0
- package/.agents/skills/remotion-best-practices/rules/get-video-duration.md +58 -0
- package/.agents/skills/remotion-best-practices/rules/gifs.md +138 -0
- package/.agents/skills/remotion-best-practices/rules/images.md +130 -0
- package/.agents/skills/remotion-best-practices/rules/import-srt-captions.md +67 -0
- package/.agents/skills/remotion-best-practices/rules/lottie.md +68 -0
- package/.agents/skills/remotion-best-practices/rules/measuring-dom-nodes.md +35 -0
- package/.agents/skills/remotion-best-practices/rules/measuring-text.md +143 -0
- package/.agents/skills/remotion-best-practices/rules/sequencing.md +106 -0
- package/.agents/skills/remotion-best-practices/rules/tailwind.md +11 -0
- package/.agents/skills/remotion-best-practices/rules/text-animations.md +20 -0
- package/.agents/skills/remotion-best-practices/rules/timing.md +179 -0
- package/.agents/skills/remotion-best-practices/rules/transcribe-captions.md +19 -0
- package/.agents/skills/remotion-best-practices/rules/transitions.md +122 -0
- package/.agents/skills/remotion-best-practices/rules/trimming.md +53 -0
- package/.agents/skills/remotion-best-practices/rules/videos.md +171 -0
- package/.agents/skills/resend/LICENSE +21 -0
- package/.agents/skills/resend/README.md +59 -0
- package/.agents/skills/resend/SKILL.md +86 -0
- package/.agents/skills/resend/agent-email-inbox/SKILL.md +1147 -0
- package/.agents/skills/resend/package.json +11 -0
- package/.agents/skills/resend/pnpm-lock.yaml +68 -0
- package/.agents/skills/resend/resend-inbound/SKILL.md +279 -0
- package/.agents/skills/resend/send-email/SKILL.md +405 -0
- package/.agents/skills/resend/send-email/references/batch-email-examples.md +807 -0
- package/.agents/skills/resend/send-email/references/best-practices.md +453 -0
- package/.agents/skills/resend/send-email/references/installation.md +142 -0
- package/.agents/skills/resend/send-email/references/single-email-examples.md +470 -0
- package/.agents/skills/resend/send-email/references/webhooks.md +221 -0
- package/.agents/skills/resend/templates/SKILL.md +105 -0
- package/.agents/skills/resend/templates/fetch-all-templates.mjs +36 -0
- package/.agents/skills/resend/templates/reference.md +114 -0
- package/.agents/skills/resend/tests/agent-email-inbox.test.md +371 -0
- package/.agents/skills/resend/tests/resend-inbound.test.md +280 -0
- package/.agents/skills/resend/tests/resend-router.test.md +200 -0
- package/.agents/skills/resend/tests/send-email.test.md +337 -0
- package/.agents/skills/resend/tests/templates.test.md +295 -0
- package/.agents/skills/revops/SKILL.md +343 -0
- package/.agents/skills/revops/references/automation-playbooks.md +290 -0
- package/.agents/skills/revops/references/lifecycle-definitions.md +278 -0
- package/.agents/skills/revops/references/routing-rules.md +203 -0
- package/.agents/skills/revops/references/scoring-models.md +247 -0
- package/.agents/skills/sales-enablement/SKILL.md +349 -0
- package/.agents/skills/sales-enablement/references/deck-frameworks.md +263 -0
- package/.agents/skills/sales-enablement/references/demo-scripts.md +355 -0
- package/.agents/skills/sales-enablement/references/objection-library.md +270 -0
- package/.agents/skills/sales-enablement/references/one-pager-templates.md +208 -0
- package/.agents/skills/schema-markup/SKILL.md +179 -0
- package/.agents/skills/schema-markup/references/schema-examples.md +398 -0
- package/.agents/skills/seo-audit/SKILL.md +412 -0
- package/.agents/skills/seo-audit/references/ai-writing-detection.md +200 -0
- package/.agents/skills/shadcn/SKILL.md +240 -0
- package/.agents/skills/shadcn/agents/openai.yml +5 -0
- package/.agents/skills/shadcn/assets/shadcn-small.png +0 -0
- package/.agents/skills/shadcn/assets/shadcn.png +0 -0
- package/.agents/skills/shadcn/cli.md +255 -0
- package/.agents/skills/shadcn/customization.md +202 -0
- package/.agents/skills/shadcn/evals/evals.json +47 -0
- package/.agents/skills/shadcn/mcp.md +94 -0
- package/.agents/skills/shadcn/rules/base-vs-radix.md +306 -0
- package/.agents/skills/shadcn/rules/composition.md +195 -0
- package/.agents/skills/shadcn/rules/forms.md +192 -0
- package/.agents/skills/shadcn/rules/icons.md +101 -0
- package/.agents/skills/shadcn/rules/styling.md +162 -0
- package/.agents/skills/signup-flow-cro/SKILL.md +359 -0
- package/.agents/skills/site-architecture/SKILL.md +357 -0
- package/.agents/skills/site-architecture/references/mermaid-templates.md +216 -0
- package/.agents/skills/site-architecture/references/navigation-patterns.md +305 -0
- package/.agents/skills/site-architecture/references/site-type-templates.md +293 -0
- package/.agents/skills/skill-creator/LICENSE.txt +202 -0
- package/.agents/skills/skill-creator/SKILL.md +356 -0
- package/.agents/skills/skill-creator/references/output-patterns.md +82 -0
- package/.agents/skills/skill-creator/references/workflows.md +28 -0
- package/.agents/skills/skill-creator/scripts/init_skill.py +303 -0
- package/.agents/skills/skill-creator/scripts/package_skill.py +110 -0
- package/.agents/skills/skill-creator/scripts/quick_validate.py +95 -0
- package/.agents/skills/social-content/SKILL.md +278 -0
- package/.agents/skills/social-content/references/platforms.md +170 -0
- package/.agents/skills/social-content/references/post-templates.md +177 -0
- package/.agents/skills/social-content/references/reverse-engineering.md +195 -0
- package/.agents/skills/supabase-postgres-best-practices/AGENTS.md +68 -0
- package/.agents/skills/supabase-postgres-best-practices/CLAUDE.md +68 -0
- package/.agents/skills/supabase-postgres-best-practices/SKILL.md +64 -0
- package/.agents/skills/supabase-postgres-best-practices/references/advanced-full-text-search.md +55 -0
- package/.agents/skills/supabase-postgres-best-practices/references/advanced-jsonb-indexing.md +49 -0
- package/.agents/skills/supabase-postgres-best-practices/references/conn-idle-timeout.md +46 -0
- package/.agents/skills/supabase-postgres-best-practices/references/conn-limits.md +44 -0
- package/.agents/skills/supabase-postgres-best-practices/references/conn-pooling.md +41 -0
- package/.agents/skills/supabase-postgres-best-practices/references/conn-prepared-statements.md +46 -0
- package/.agents/skills/supabase-postgres-best-practices/references/data-batch-inserts.md +54 -0
- package/.agents/skills/supabase-postgres-best-practices/references/data-n-plus-one.md +53 -0
- package/.agents/skills/supabase-postgres-best-practices/references/data-pagination.md +50 -0
- package/.agents/skills/supabase-postgres-best-practices/references/data-upsert.md +50 -0
- package/.agents/skills/supabase-postgres-best-practices/references/lock-advisory.md +56 -0
- package/.agents/skills/supabase-postgres-best-practices/references/lock-deadlock-prevention.md +68 -0
- package/.agents/skills/supabase-postgres-best-practices/references/lock-short-transactions.md +50 -0
- package/.agents/skills/supabase-postgres-best-practices/references/lock-skip-locked.md +54 -0
- package/.agents/skills/supabase-postgres-best-practices/references/monitor-explain-analyze.md +45 -0
- package/.agents/skills/supabase-postgres-best-practices/references/monitor-pg-stat-statements.md +55 -0
- package/.agents/skills/supabase-postgres-best-practices/references/monitor-vacuum-analyze.md +55 -0
- package/.agents/skills/supabase-postgres-best-practices/references/query-composite-indexes.md +44 -0
- package/.agents/skills/supabase-postgres-best-practices/references/query-covering-indexes.md +40 -0
- package/.agents/skills/supabase-postgres-best-practices/references/query-index-types.md +48 -0
- package/.agents/skills/supabase-postgres-best-practices/references/query-missing-indexes.md +43 -0
- package/.agents/skills/supabase-postgres-best-practices/references/query-partial-indexes.md +45 -0
- package/.agents/skills/supabase-postgres-best-practices/references/schema-constraints.md +80 -0
- package/.agents/skills/supabase-postgres-best-practices/references/schema-data-types.md +46 -0
- package/.agents/skills/supabase-postgres-best-practices/references/schema-foreign-key-indexes.md +59 -0
- package/.agents/skills/supabase-postgres-best-practices/references/schema-lowercase-identifiers.md +55 -0
- package/.agents/skills/supabase-postgres-best-practices/references/schema-partitioning.md +55 -0
- package/.agents/skills/supabase-postgres-best-practices/references/schema-primary-keys.md +61 -0
- package/.agents/skills/supabase-postgres-best-practices/references/security-privileges.md +54 -0
- package/.agents/skills/supabase-postgres-best-practices/references/security-rls-basics.md +50 -0
- package/.agents/skills/supabase-postgres-best-practices/references/security-rls-performance.md +57 -0
- package/.agents/skills/ui-skills/SKILL.md +85 -0
- package/.agents/skills/ui-ux-pro-max/SKILL.md +386 -0
- package/.agents/skills/ui-ux-pro-max/data/charts.csv +26 -0
- package/.agents/skills/ui-ux-pro-max/data/colors.csv +97 -0
- package/.agents/skills/ui-ux-pro-max/data/icons.csv +101 -0
- package/.agents/skills/ui-ux-pro-max/data/landing.csv +31 -0
- package/.agents/skills/ui-ux-pro-max/data/products.csv +97 -0
- package/.agents/skills/ui-ux-pro-max/data/react-performance.csv +45 -0
- package/.agents/skills/ui-ux-pro-max/data/stacks/astro.csv +54 -0
- package/.agents/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
- package/.agents/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
- package/.agents/skills/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -0
- package/.agents/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
- package/.agents/skills/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
- package/.agents/skills/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
- package/.agents/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
- package/.agents/skills/ui-ux-pro-max/data/stacks/react.csv +54 -0
- package/.agents/skills/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
- package/.agents/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
- package/.agents/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
- package/.agents/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -0
- package/.agents/skills/ui-ux-pro-max/data/styles.csv +68 -0
- package/.agents/skills/ui-ux-pro-max/data/typography.csv +58 -0
- package/.agents/skills/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
- package/.agents/skills/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
- package/.agents/skills/ui-ux-pro-max/data/web-interface.csv +31 -0
- package/.agents/skills/ui-ux-pro-max/scripts/core.py +253 -0
- package/.agents/skills/ui-ux-pro-max/scripts/design_system.py +1067 -0
- package/.agents/skills/ui-ux-pro-max/scripts/search.py +114 -0
- package/.agents/skills/upgrading-expo/SKILL.md +125 -0
- package/.agents/skills/upgrading-expo/references/expo-av-to-audio.md +132 -0
- package/.agents/skills/upgrading-expo/references/expo-av-to-video.md +160 -0
- package/.agents/skills/upgrading-expo/references/native-tabs.md +124 -0
- package/.agents/skills/upgrading-expo/references/new-architecture.md +79 -0
- package/.agents/skills/upgrading-expo/references/react-19.md +79 -0
- package/.agents/skills/upgrading-expo/references/react-compiler.md +59 -0
- package/.agents/skills/use-dom/SKILL.md +417 -0
- package/.agents/skills/use-railway/SKILL.md +124 -0
- package/.agents/skills/use-railway/references/configure.md +283 -0
- package/.agents/skills/use-railway/references/deploy.md +184 -0
- package/.agents/skills/use-railway/references/operate.md +159 -0
- package/.agents/skills/use-railway/references/request.md +238 -0
- package/.agents/skills/use-railway/references/setup.md +195 -0
- package/.agents/skills/use-railway/scripts/railway-api.sh +41 -0
- package/.agents/skills/vercel-composition-patterns/AGENTS.md +946 -0
- package/.agents/skills/vercel-composition-patterns/README.md +60 -0
- package/.agents/skills/vercel-composition-patterns/SKILL.md +89 -0
- package/.agents/skills/vercel-composition-patterns/rules/architecture-avoid-boolean-props.md +100 -0
- package/.agents/skills/vercel-composition-patterns/rules/architecture-compound-components.md +112 -0
- package/.agents/skills/vercel-composition-patterns/rules/patterns-children-over-render-props.md +87 -0
- package/.agents/skills/vercel-composition-patterns/rules/patterns-explicit-variants.md +100 -0
- package/.agents/skills/vercel-composition-patterns/rules/react19-no-forwardref.md +42 -0
- package/.agents/skills/vercel-composition-patterns/rules/state-context-interface.md +191 -0
- package/.agents/skills/vercel-composition-patterns/rules/state-decouple-implementation.md +113 -0
- package/.agents/skills/vercel-composition-patterns/rules/state-lift-state.md +125 -0
- package/.agents/skills/vercel-react-best-practices/AGENTS.md +2934 -0
- package/.agents/skills/vercel-react-best-practices/SKILL.md +136 -0
- package/.agents/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
- package/.agents/skills/vercel-react-best-practices/rules/advanced-init-once.md +42 -0
- package/.agents/skills/vercel-react-best-practices/rules/advanced-use-latest.md +39 -0
- package/.agents/skills/vercel-react-best-practices/rules/async-api-routes.md +38 -0
- package/.agents/skills/vercel-react-best-practices/rules/async-defer-await.md +80 -0
- package/.agents/skills/vercel-react-best-practices/rules/async-dependencies.md +51 -0
- package/.agents/skills/vercel-react-best-practices/rules/async-parallel.md +28 -0
- package/.agents/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
- package/.agents/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +59 -0
- package/.agents/skills/vercel-react-best-practices/rules/bundle-conditional.md +31 -0
- package/.agents/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +49 -0
- package/.agents/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +35 -0
- package/.agents/skills/vercel-react-best-practices/rules/bundle-preload.md +50 -0
- package/.agents/skills/vercel-react-best-practices/rules/client-event-listeners.md +74 -0
- package/.agents/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +71 -0
- package/.agents/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
- package/.agents/skills/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
- package/.agents/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +107 -0
- package/.agents/skills/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
- package/.agents/skills/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
- package/.agents/skills/vercel-react-best-practices/rules/js-cache-storage.md +70 -0
- package/.agents/skills/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
- package/.agents/skills/vercel-react-best-practices/rules/js-early-exit.md +50 -0
- package/.agents/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
- package/.agents/skills/vercel-react-best-practices/rules/js-index-maps.md +37 -0
- package/.agents/skills/vercel-react-best-practices/rules/js-length-check-first.md +49 -0
- package/.agents/skills/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
- package/.agents/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
- package/.agents/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
- package/.agents/skills/vercel-react-best-practices/rules/rendering-activity.md +26 -0
- package/.agents/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
- package/.agents/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +40 -0
- package/.agents/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
- package/.agents/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +46 -0
- package/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
- package/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
- package/.agents/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
- package/.agents/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +75 -0
- package/.agents/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
- package/.agents/skills/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
- package/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
- package/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
- package/.agents/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +74 -0
- package/.agents/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +58 -0
- package/.agents/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
- package/.agents/skills/vercel-react-best-practices/rules/rerender-memo.md +44 -0
- package/.agents/skills/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
- package/.agents/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
- package/.agents/skills/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
- package/.agents/skills/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
- package/.agents/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
- package/.agents/skills/vercel-react-best-practices/rules/server-auth-actions.md +96 -0
- package/.agents/skills/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
- package/.agents/skills/vercel-react-best-practices/rules/server-cache-react.md +76 -0
- package/.agents/skills/vercel-react-best-practices/rules/server-dedup-props.md +65 -0
- package/.agents/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
- package/.agents/skills/vercel-react-best-practices/rules/server-serialization.md +38 -0
- package/.agents/skills/vercel-react-native-skills/AGENTS.md +2897 -0
- package/.agents/skills/vercel-react-native-skills/SKILL.md +121 -0
- package/.agents/skills/vercel-react-native-skills/rules/animation-derived-value.md +53 -0
- package/.agents/skills/vercel-react-native-skills/rules/animation-gesture-detector-press.md +95 -0
- package/.agents/skills/vercel-react-native-skills/rules/animation-gpu-properties.md +65 -0
- package/.agents/skills/vercel-react-native-skills/rules/design-system-compound-components.md +66 -0
- package/.agents/skills/vercel-react-native-skills/rules/fonts-config-plugin.md +71 -0
- package/.agents/skills/vercel-react-native-skills/rules/imports-design-system-folder.md +68 -0
- package/.agents/skills/vercel-react-native-skills/rules/js-hoist-intl.md +61 -0
- package/.agents/skills/vercel-react-native-skills/rules/list-performance-callbacks.md +44 -0
- package/.agents/skills/vercel-react-native-skills/rules/list-performance-function-references.md +132 -0
- package/.agents/skills/vercel-react-native-skills/rules/list-performance-images.md +53 -0
- package/.agents/skills/vercel-react-native-skills/rules/list-performance-inline-objects.md +97 -0
- package/.agents/skills/vercel-react-native-skills/rules/list-performance-item-expensive.md +94 -0
- package/.agents/skills/vercel-react-native-skills/rules/list-performance-item-memo.md +82 -0
- package/.agents/skills/vercel-react-native-skills/rules/list-performance-item-types.md +104 -0
- package/.agents/skills/vercel-react-native-skills/rules/list-performance-virtualize.md +67 -0
- package/.agents/skills/vercel-react-native-skills/rules/monorepo-native-deps-in-app.md +46 -0
- package/.agents/skills/vercel-react-native-skills/rules/monorepo-single-dependency-versions.md +63 -0
- package/.agents/skills/vercel-react-native-skills/rules/navigation-native-navigators.md +188 -0
- package/.agents/skills/vercel-react-native-skills/rules/react-compiler-destructure-functions.md +50 -0
- package/.agents/skills/vercel-react-native-skills/rules/react-compiler-reanimated-shared-values.md +48 -0
- package/.agents/skills/vercel-react-native-skills/rules/react-state-dispatcher.md +91 -0
- package/.agents/skills/vercel-react-native-skills/rules/react-state-fallback.md +56 -0
- package/.agents/skills/vercel-react-native-skills/rules/react-state-minimize.md +65 -0
- package/.agents/skills/vercel-react-native-skills/rules/rendering-no-falsy-and.md +74 -0
- package/.agents/skills/vercel-react-native-skills/rules/rendering-text-in-text-component.md +36 -0
- package/.agents/skills/vercel-react-native-skills/rules/scroll-position-no-state.md +82 -0
- package/.agents/skills/vercel-react-native-skills/rules/state-ground-truth.md +80 -0
- package/.agents/skills/vercel-react-native-skills/rules/ui-expo-image.md +66 -0
- package/.agents/skills/vercel-react-native-skills/rules/ui-image-gallery.md +104 -0
- package/.agents/skills/vercel-react-native-skills/rules/ui-measure-views.md +78 -0
- package/.agents/skills/vercel-react-native-skills/rules/ui-menus.md +174 -0
- package/.agents/skills/vercel-react-native-skills/rules/ui-native-modals.md +77 -0
- package/.agents/skills/vercel-react-native-skills/rules/ui-pressable.md +61 -0
- package/.agents/skills/vercel-react-native-skills/rules/ui-safe-area-scroll.md +65 -0
- package/.agents/skills/vercel-react-native-skills/rules/ui-scrollview-content-inset.md +45 -0
- package/.agents/skills/vercel-react-native-skills/rules/ui-styling.md +87 -0
- package/.agents/skills/web-design-guidelines/SKILL.md +39 -0
- package/.claude/CLAUDE.md +48 -0
- package/.claude/settings.local.json +7 -0
- package/.claude/skills/agent-browser/SKILL.md +347 -0
- package/.claude/skills/agent-browser/references/authentication.md +188 -0
- package/.claude/skills/agent-browser/references/proxy-support.md +175 -0
- package/.claude/skills/agent-browser/references/session-management.md +181 -0
- package/.claude/skills/agent-browser/references/snapshot-refs.md +186 -0
- package/.claude/skills/agent-browser/references/video-recording.md +162 -0
- package/.claude/skills/agent-browser/templates/authenticated-session.sh +91 -0
- package/.claude/skills/agent-browser/templates/capture-workflow.sh +68 -0
- package/.claude/skills/agent-browser/templates/form-automation.sh +64 -0
- package/.claude/skills/better-auth-best-practices/SKILL.md +166 -0
- package/.claude/skills/create-auth-skill/SKILL.md +214 -0
- package/.claude/skills/design-md/SKILL.md +172 -0
- package/.claude/skills/design-md/examples/DESIGN.md +154 -0
- package/.claude/skills/frontend-design/LICENSE.txt +177 -0
- package/.claude/skills/frontend-design/SKILL.md +42 -0
- package/.claude/skills/init-nexxo/SKILL.md +61 -0
- package/.claude/skills/init-nexxo/references/templates.md +166 -0
- package/.claude/skills/kickoff/SKILL.md +90 -0
- package/.claude/skills/planning-with-files/SKILL.md +160 -0
- package/.claude/skills/planning-with-files/examples.md +202 -0
- package/.claude/skills/planning-with-files/reference.md +110 -0
- package/.claude/skills/react-useeffect/SKILL.md +53 -0
- package/.claude/skills/react-useeffect/alternatives.md +258 -0
- package/.claude/skills/react-useeffect/anti-patterns.md +290 -0
- package/.claude/skills/remotion-best-practices/SKILL.md +43 -0
- package/.claude/skills/remotion-best-practices/rules/3d.md +86 -0
- package/.claude/skills/remotion-best-practices/rules/animations.md +29 -0
- package/.claude/skills/remotion-best-practices/rules/assets/charts-bar-chart.tsx +173 -0
- package/.claude/skills/remotion-best-practices/rules/assets/text-animations-typewriter.tsx +100 -0
- package/.claude/skills/remotion-best-practices/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/.claude/skills/remotion-best-practices/rules/assets.md +78 -0
- package/.claude/skills/remotion-best-practices/rules/audio.md +172 -0
- package/.claude/skills/remotion-best-practices/rules/calculate-metadata.md +104 -0
- package/.claude/skills/remotion-best-practices/rules/can-decode.md +75 -0
- package/.claude/skills/remotion-best-practices/rules/charts.md +58 -0
- package/.claude/skills/remotion-best-practices/rules/compositions.md +146 -0
- package/.claude/skills/remotion-best-practices/rules/display-captions.md +126 -0
- package/.claude/skills/remotion-best-practices/rules/extract-frames.md +229 -0
- package/.claude/skills/remotion-best-practices/rules/fonts.md +152 -0
- package/.claude/skills/remotion-best-practices/rules/get-audio-duration.md +58 -0
- package/.claude/skills/remotion-best-practices/rules/get-video-dimensions.md +68 -0
- package/.claude/skills/remotion-best-practices/rules/get-video-duration.md +58 -0
- package/.claude/skills/remotion-best-practices/rules/gifs.md +138 -0
- package/.claude/skills/remotion-best-practices/rules/images.md +130 -0
- package/.claude/skills/remotion-best-practices/rules/import-srt-captions.md +67 -0
- package/.claude/skills/remotion-best-practices/rules/lottie.md +68 -0
- package/.claude/skills/remotion-best-practices/rules/measuring-dom-nodes.md +35 -0
- package/.claude/skills/remotion-best-practices/rules/measuring-text.md +143 -0
- package/.claude/skills/remotion-best-practices/rules/sequencing.md +106 -0
- package/.claude/skills/remotion-best-practices/rules/tailwind.md +11 -0
- package/.claude/skills/remotion-best-practices/rules/text-animations.md +20 -0
- package/.claude/skills/remotion-best-practices/rules/timing.md +179 -0
- package/.claude/skills/remotion-best-practices/rules/transcribe-captions.md +19 -0
- package/.claude/skills/remotion-best-practices/rules/transitions.md +122 -0
- package/.claude/skills/remotion-best-practices/rules/trimming.md +53 -0
- package/.claude/skills/remotion-best-practices/rules/videos.md +171 -0
- package/.claude/skills/skill-creator/LICENSE.txt +202 -0
- package/.claude/skills/skill-creator/SKILL.md +356 -0
- package/.claude/skills/skill-creator/references/output-patterns.md +82 -0
- package/.claude/skills/skill-creator/references/workflows.md +28 -0
- package/.claude/skills/skill-creator/scripts/init_skill.py +303 -0
- package/.claude/skills/skill-creator/scripts/package_skill.py +110 -0
- package/.claude/skills/skill-creator/scripts/quick_validate.py +95 -0
- package/.claude/skills/ui-skills/SKILL.md +85 -0
- package/.claude/skills/uifix/SKILL.md +46 -0
- package/.claude/skills/web-design-guidelines/SKILL.md +39 -0
- package/.codex/config.toml.template +158 -0
- package/.cursor/CURSOR.md +0 -0
- package/.cursor/hooks/state/continual-learning.json +8 -0
- package/.cursor/skills/agent-browser/SKILL.md +347 -0
- package/.cursor/skills/agent-browser/references/authentication.md +188 -0
- package/.cursor/skills/agent-browser/references/proxy-support.md +175 -0
- package/.cursor/skills/agent-browser/references/session-management.md +181 -0
- package/.cursor/skills/agent-browser/references/snapshot-refs.md +186 -0
- package/.cursor/skills/agent-browser/references/video-recording.md +162 -0
- package/.cursor/skills/agent-browser/templates/authenticated-session.sh +91 -0
- package/.cursor/skills/agent-browser/templates/capture-workflow.sh +68 -0
- package/.cursor/skills/agent-browser/templates/form-automation.sh +64 -0
- package/.cursor/skills/better-auth-best-practices/SKILL.md +166 -0
- package/.cursor/skills/create-auth-skill/SKILL.md +214 -0
- package/.cursor/skills/design-md/SKILL.md +172 -0
- package/.cursor/skills/design-md/examples/DESIGN.md +154 -0
- package/.cursor/skills/frontend-design/LICENSE.txt +177 -0
- package/.cursor/skills/frontend-design/SKILL.md +42 -0
- package/.cursor/skills/remotion-best-practices/SKILL.md +43 -0
- package/.cursor/skills/remotion-best-practices/rules/3d.md +86 -0
- package/.cursor/skills/remotion-best-practices/rules/animations.md +29 -0
- package/.cursor/skills/remotion-best-practices/rules/assets/charts-bar-chart.tsx +173 -0
- package/.cursor/skills/remotion-best-practices/rules/assets/text-animations-typewriter.tsx +100 -0
- package/.cursor/skills/remotion-best-practices/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/.cursor/skills/remotion-best-practices/rules/assets.md +78 -0
- package/.cursor/skills/remotion-best-practices/rules/audio.md +172 -0
- package/.cursor/skills/remotion-best-practices/rules/calculate-metadata.md +104 -0
- package/.cursor/skills/remotion-best-practices/rules/can-decode.md +75 -0
- package/.cursor/skills/remotion-best-practices/rules/charts.md +58 -0
- package/.cursor/skills/remotion-best-practices/rules/compositions.md +146 -0
- package/.cursor/skills/remotion-best-practices/rules/display-captions.md +126 -0
- package/.cursor/skills/remotion-best-practices/rules/extract-frames.md +229 -0
- package/.cursor/skills/remotion-best-practices/rules/fonts.md +152 -0
- package/.cursor/skills/remotion-best-practices/rules/get-audio-duration.md +58 -0
- package/.cursor/skills/remotion-best-practices/rules/get-video-dimensions.md +68 -0
- package/.cursor/skills/remotion-best-practices/rules/get-video-duration.md +58 -0
- package/.cursor/skills/remotion-best-practices/rules/gifs.md +138 -0
- package/.cursor/skills/remotion-best-practices/rules/images.md +130 -0
- package/.cursor/skills/remotion-best-practices/rules/import-srt-captions.md +67 -0
- package/.cursor/skills/remotion-best-practices/rules/lottie.md +68 -0
- package/.cursor/skills/remotion-best-practices/rules/measuring-dom-nodes.md +35 -0
- package/.cursor/skills/remotion-best-practices/rules/measuring-text.md +143 -0
- package/.cursor/skills/remotion-best-practices/rules/sequencing.md +106 -0
- package/.cursor/skills/remotion-best-practices/rules/tailwind.md +11 -0
- package/.cursor/skills/remotion-best-practices/rules/text-animations.md +20 -0
- package/.cursor/skills/remotion-best-practices/rules/timing.md +179 -0
- package/.cursor/skills/remotion-best-practices/rules/transcribe-captions.md +19 -0
- package/.cursor/skills/remotion-best-practices/rules/transitions.md +122 -0
- package/.cursor/skills/remotion-best-practices/rules/trimming.md +53 -0
- package/.cursor/skills/remotion-best-practices/rules/videos.md +171 -0
- package/.cursor/skills/skill-creator/LICENSE.txt +202 -0
- package/.cursor/skills/skill-creator/SKILL.md +356 -0
- package/.cursor/skills/skill-creator/references/output-patterns.md +82 -0
- package/.cursor/skills/skill-creator/references/workflows.md +28 -0
- package/.cursor/skills/skill-creator/scripts/init_skill.py +303 -0
- package/.cursor/skills/skill-creator/scripts/package_skill.py +110 -0
- package/.cursor/skills/skill-creator/scripts/quick_validate.py +95 -0
- package/.cursor/skills/ui-skills/SKILL.md +85 -0
- package/.cursor/skills/use-railway/SKILL.md +124 -0
- package/.cursor/skills/use-railway/references/configure.md +283 -0
- package/.cursor/skills/use-railway/references/deploy.md +184 -0
- package/.cursor/skills/use-railway/references/operate.md +159 -0
- package/.cursor/skills/use-railway/references/request.md +238 -0
- package/.cursor/skills/use-railway/references/setup.md +195 -0
- package/.cursor/skills/use-railway/scripts/railway-api.sh +41 -0
- package/.cursor/skills/web-design-guidelines/SKILL.md +39 -0
- package/.gemini/GEMINI.md +75 -0
- package/.gemini/antigravity/skills/better-auth/SKILL.md +204 -0
- package/.gemini/antigravity/skills/better-auth/references/advanced-features.md +553 -0
- package/.gemini/antigravity/skills/better-auth/references/database-integration.md +577 -0
- package/.gemini/antigravity/skills/better-auth/references/email-password-auth.md +416 -0
- package/.gemini/antigravity/skills/better-auth/references/oauth-providers.md +430 -0
- package/.gemini/antigravity/skills/better-auth/scripts/.coverage +0 -0
- package/.gemini/antigravity/skills/better-auth/scripts/better_auth_init.py +521 -0
- package/.gemini/antigravity/skills/better-auth/scripts/requirements.txt +15 -0
- package/.gemini/antigravity/skills/better-auth/scripts/tests/.coverage +0 -0
- package/.gemini/antigravity/skills/better-auth/scripts/tests/test_better_auth_init.py +421 -0
- package/.gemini/antigravity/skills/better-auth-best-practices/SKILL.md +166 -0
- package/.gemini/antigravity/skills/create-auth-skill/SKILL.md +214 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/AGENTS.md +2515 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/SKILL.md +118 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/anim-interaction-manager.md +63 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/anim-layout-animation.md +75 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/anim-transform-not-dimensions.md +67 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/anim-use-native-driver.md +55 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/anim-use-reanimated.md +53 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/asset-optimize-image-size.md +60 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/asset-prefetch-images.md +60 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/asset-recycling-key.md +57 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/asset-use-expo-image.md +58 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/asset-use-webp-format.md +50 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/async-batch-api-calls.md +65 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/async-cache-responses.md +54 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/async-defer-await.md +56 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/async-parallel-fetching.md +60 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/async-refetch-on-focus.md +68 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/list-estimated-item-size.md +52 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/list-get-item-layout.md +64 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/list-get-item-type.md +59 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/list-memoize-items.md +59 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/list-stable-render-item.md +61 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/list-use-flashlist.md +56 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/mem-abort-fetch.md +78 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/mem-avoid-inline-objects.md +61 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/mem-cleanup-subscriptions.md +63 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/mem-clear-timers.md +63 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/mem-limit-list-data.md +69 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/platform-android-overdraw.md +63 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/platform-android-proguard.md +63 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/platform-conditional-render.md +81 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/platform-ios-text-rendering.md +57 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/rerender-derive-state.md +58 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/rerender-functional-setstate.md +54 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/rerender-lazy-state-init.md +55 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/rerender-split-context.md +69 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/rerender-use-callback-handlers.md +63 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/rerender-use-memo-expensive.md +54 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/startup-async-routes.md +63 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/startup-cherry-pick-imports.md +45 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/startup-enable-hermes.md +39 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/startup-preload-assets.md +68 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/startup-remove-console-logs.md +47 -0
- package/.gemini/antigravity/skills/expo-react-native-performance/references/startup-splash-screen-control.md +58 -0
- package/.gemini/antigravity/skills/express-rest-api/SKILL.md +249 -0
- package/.gemini/antigravity/skills/express-rest-api/assets/config.yaml +1 -0
- package/.gemini/antigravity/skills/express-rest-api/references/GUIDE.md +1 -0
- package/.gemini/antigravity/skills/express-rest-api/scripts/helper.py +3 -0
- package/.gemini/antigravity/skills/react-doctor/SKILL.md +41 -0
- package/.gemini/antigravity/skills/react-native-best-practices/POWER.md +145 -0
- package/.gemini/antigravity/skills/react-native-best-practices/SKILL.md +215 -0
- package/.gemini/antigravity/skills/react-native-best-practices/agents/openai.yaml +4 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/bundle-analyze-app.md +211 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/bundle-analyze-js.md +262 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/bundle-barrel-exports.md +248 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/bundle-code-splitting.md +224 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/bundle-hermes-mmap.md +167 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/bundle-library-size.md +177 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/bundle-native-assets.md +214 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/bundle-r8-android.md +225 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/bundle-tree-shaking.md +214 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/images/bundle-treemap-source-map-explorer.png +0 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/images/controlled-textinput-pingpong.png +0 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/images/devtools-flamegraph.png +0 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/images/emerge-xray-ios.png +0 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/images/expo-atlas-treemap.png +0 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/images/flashlight-flatlist-vs-flashlist.png +0 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/images/fps-drop-graph.png +0 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/images/memory-heap-snapshot.png +0 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/images/tti-warm-start-diagram.png +0 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/images/view-hierarchy-flattening.png +0 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/images/xcode-instruments-templates.png +0 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/images/xcode-thread-view.png +0 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/js-animations-reanimated.md +254 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/js-atomic-state.md +245 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/js-concurrent-react.md +236 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/js-lists-flatlist-flashlist.md +236 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/js-measure-fps.md +180 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/js-memory-leaks.md +205 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/js-profile-react.md +161 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/js-react-compiler.md +368 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/js-uncontrolled-components.md +216 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/native-android-16kb-alignment.md +113 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/native-measure-tti.md +262 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/native-memory-leaks.md +240 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/native-memory-patterns.md +274 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/native-platform-setup.md +110 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/native-profiling.md +176 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/native-sdks-over-polyfills.md +183 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/native-threading-model.md +234 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/native-turbo-modules.md +292 -0
- package/.gemini/antigravity/skills/react-native-best-practices/references/native-view-flattening.md +201 -0
- package/.gemini/antigravity/skills/react-native-expo/.claude-plugin/plugin.json +13 -0
- package/.gemini/antigravity/skills/react-native-expo/SKILL.md +1077 -0
- package/.gemini/antigravity/skills/react-native-expo/agents/expo-build.md +207 -0
- package/.gemini/antigravity/skills/react-native-expo/assets/css-features-cheatsheet.md +488 -0
- package/.gemini/antigravity/skills/react-native-expo/assets/example-template.txt +14 -0
- package/.gemini/antigravity/skills/react-native-expo/assets/new-arch-decision-tree.md +312 -0
- package/.gemini/antigravity/skills/react-native-expo/references/example-reference.md +26 -0
- package/.gemini/antigravity/skills/react-native-expo/references/expo-sdk-52-breaking.md +409 -0
- package/.gemini/antigravity/skills/react-native-expo/references/new-architecture-errors.md +501 -0
- package/.gemini/antigravity/skills/react-native-expo/references/react-19-migration.md +365 -0
- package/.gemini/antigravity/skills/react-native-expo/scripts/check-rn-version.sh +121 -0
- package/.gemini/antigravity/skills/react-native-expo/scripts/example-script.sh +15 -0
- package/.gemini/antigravity/skills/react-native-testing/SKILL.md +161 -0
- package/.gemini/antigravity/skills/react-native-testing/references/anti-patterns.md +287 -0
- package/.gemini/antigravity/skills/react-native-testing/references/api-reference-v13.md +572 -0
- package/.gemini/antigravity/skills/react-native-testing/references/api-reference-v14.md +574 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/AGENTS.md +68 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/CLAUDE.md +68 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/SKILL.md +64 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/advanced-full-text-search.md +55 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/advanced-jsonb-indexing.md +49 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/conn-idle-timeout.md +46 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/conn-limits.md +44 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/conn-pooling.md +41 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/conn-prepared-statements.md +46 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/data-batch-inserts.md +54 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/data-n-plus-one.md +53 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/data-pagination.md +50 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/data-upsert.md +50 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/lock-advisory.md +56 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/lock-deadlock-prevention.md +68 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/lock-short-transactions.md +50 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/lock-skip-locked.md +54 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/monitor-explain-analyze.md +45 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/monitor-pg-stat-statements.md +55 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/monitor-vacuum-analyze.md +55 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/query-composite-indexes.md +44 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/query-covering-indexes.md +40 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/query-index-types.md +48 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/query-missing-indexes.md +43 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/query-partial-indexes.md +45 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/schema-constraints.md +80 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/schema-data-types.md +46 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/schema-foreign-key-indexes.md +59 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/schema-lowercase-identifiers.md +55 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/schema-partitioning.md +55 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/schema-primary-keys.md +61 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/security-privileges.md +54 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/security-rls-basics.md +50 -0
- package/.gemini/antigravity/skills/supabase-postgres-best-practices/references/security-rls-performance.md +57 -0
- package/.gemini/antigravity/skills/ui-skills/SKILL.md +85 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/AGENTS.md +2934 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/SKILL.md +136 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/advanced-init-once.md +42 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/advanced-use-latest.md +39 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/async-api-routes.md +38 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/async-defer-await.md +80 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/async-dependencies.md +51 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/async-parallel.md +28 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +59 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/bundle-conditional.md +31 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +49 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +35 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/bundle-preload.md +50 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/client-event-listeners.md +74 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +71 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +107 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/js-cache-storage.md +70 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/js-early-exit.md +50 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/js-index-maps.md +37 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/js-length-check-first.md +49 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rendering-activity.md +26 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +40 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +46 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +75 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +74 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +58 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rerender-memo.md +44 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/server-auth-actions.md +96 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/server-cache-react.md +76 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/server-dedup-props.md +65 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
- package/.gemini/antigravity/skills/vercel-react-best-practices/rules/server-serialization.md +38 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/AGENTS.md +2897 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/SKILL.md +121 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/animation-derived-value.md +53 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/animation-gesture-detector-press.md +95 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/animation-gpu-properties.md +65 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/design-system-compound-components.md +66 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/fonts-config-plugin.md +71 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/imports-design-system-folder.md +68 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/js-hoist-intl.md +61 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/list-performance-callbacks.md +44 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/list-performance-function-references.md +132 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/list-performance-images.md +53 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/list-performance-inline-objects.md +97 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/list-performance-item-expensive.md +94 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/list-performance-item-memo.md +82 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/list-performance-item-types.md +104 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/list-performance-virtualize.md +67 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/monorepo-native-deps-in-app.md +46 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/monorepo-single-dependency-versions.md +63 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/navigation-native-navigators.md +188 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/react-compiler-destructure-functions.md +50 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/react-compiler-reanimated-shared-values.md +48 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/react-state-dispatcher.md +91 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/react-state-fallback.md +56 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/react-state-minimize.md +65 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/rendering-no-falsy-and.md +74 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/rendering-text-in-text-component.md +36 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/scroll-position-no-state.md +82 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/state-ground-truth.md +80 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/ui-expo-image.md +66 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/ui-image-gallery.md +104 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/ui-measure-views.md +78 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/ui-menus.md +174 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/ui-native-modals.md +77 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/ui-pressable.md +61 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/ui-safe-area-scroll.md +65 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/ui-scrollview-content-inset.md +45 -0
- package/.gemini/antigravity/skills/vercel-react-native-skills/rules/ui-styling.md +87 -0
- package/.gemini/antigravity/skills/web-design-guidelines/SKILL.md +39 -0
- package/.gemini/antigravity/skills/web-interface-guidelines/SKILL.md +179 -0
- package/.gemini/settings.json +5 -0
- package/.gemini/skills/agent-browser/SKILL.md +347 -0
- package/.gemini/skills/agent-browser/references/authentication.md +188 -0
- package/.gemini/skills/agent-browser/references/proxy-support.md +175 -0
- package/.gemini/skills/agent-browser/references/session-management.md +181 -0
- package/.gemini/skills/agent-browser/references/snapshot-refs.md +186 -0
- package/.gemini/skills/agent-browser/references/video-recording.md +162 -0
- package/.gemini/skills/agent-browser/templates/authenticated-session.sh +91 -0
- package/.gemini/skills/agent-browser/templates/capture-workflow.sh +68 -0
- package/.gemini/skills/agent-browser/templates/form-automation.sh +64 -0
- package/.gemini/skills/better-auth-best-practices/SKILL.md +166 -0
- package/.gemini/skills/create-auth-skill/SKILL.md +214 -0
- package/.gemini/skills/design-md/SKILL.md +172 -0
- package/.gemini/skills/design-md/examples/DESIGN.md +154 -0
- package/.gemini/skills/frontend-design/LICENSE.txt +177 -0
- package/.gemini/skills/frontend-design/SKILL.md +42 -0
- package/.gemini/skills/remotion-best-practices/SKILL.md +43 -0
- package/.gemini/skills/remotion-best-practices/rules/3d.md +86 -0
- package/.gemini/skills/remotion-best-practices/rules/animations.md +29 -0
- package/.gemini/skills/remotion-best-practices/rules/assets/charts-bar-chart.tsx +173 -0
- package/.gemini/skills/remotion-best-practices/rules/assets/text-animations-typewriter.tsx +100 -0
- package/.gemini/skills/remotion-best-practices/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/.gemini/skills/remotion-best-practices/rules/assets.md +78 -0
- package/.gemini/skills/remotion-best-practices/rules/audio.md +172 -0
- package/.gemini/skills/remotion-best-practices/rules/calculate-metadata.md +104 -0
- package/.gemini/skills/remotion-best-practices/rules/can-decode.md +75 -0
- package/.gemini/skills/remotion-best-practices/rules/charts.md +58 -0
- package/.gemini/skills/remotion-best-practices/rules/compositions.md +146 -0
- package/.gemini/skills/remotion-best-practices/rules/display-captions.md +126 -0
- package/.gemini/skills/remotion-best-practices/rules/extract-frames.md +229 -0
- package/.gemini/skills/remotion-best-practices/rules/fonts.md +152 -0
- package/.gemini/skills/remotion-best-practices/rules/get-audio-duration.md +58 -0
- package/.gemini/skills/remotion-best-practices/rules/get-video-dimensions.md +68 -0
- package/.gemini/skills/remotion-best-practices/rules/get-video-duration.md +58 -0
- package/.gemini/skills/remotion-best-practices/rules/gifs.md +138 -0
- package/.gemini/skills/remotion-best-practices/rules/images.md +130 -0
- package/.gemini/skills/remotion-best-practices/rules/import-srt-captions.md +67 -0
- package/.gemini/skills/remotion-best-practices/rules/lottie.md +68 -0
- package/.gemini/skills/remotion-best-practices/rules/measuring-dom-nodes.md +35 -0
- package/.gemini/skills/remotion-best-practices/rules/measuring-text.md +143 -0
- package/.gemini/skills/remotion-best-practices/rules/sequencing.md +106 -0
- package/.gemini/skills/remotion-best-practices/rules/tailwind.md +11 -0
- package/.gemini/skills/remotion-best-practices/rules/text-animations.md +20 -0
- package/.gemini/skills/remotion-best-practices/rules/timing.md +179 -0
- package/.gemini/skills/remotion-best-practices/rules/transcribe-captions.md +19 -0
- package/.gemini/skills/remotion-best-practices/rules/transitions.md +122 -0
- package/.gemini/skills/remotion-best-practices/rules/trimming.md +53 -0
- package/.gemini/skills/remotion-best-practices/rules/videos.md +171 -0
- package/.gemini/skills/skill-creator/LICENSE.txt +202 -0
- package/.gemini/skills/skill-creator/SKILL.md +356 -0
- package/.gemini/skills/skill-creator/references/output-patterns.md +82 -0
- package/.gemini/skills/skill-creator/references/workflows.md +28 -0
- package/.gemini/skills/skill-creator/scripts/init_skill.py +303 -0
- package/.gemini/skills/skill-creator/scripts/package_skill.py +110 -0
- package/.gemini/skills/skill-creator/scripts/quick_validate.py +95 -0
- package/.gemini/skills/supabase-postgres-best-practices/AGENTS.md +1490 -0
- package/.gemini/skills/supabase-postgres-best-practices/SKILL.md +57 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/advanced-full-text-search.md +55 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/advanced-jsonb-indexing.md +49 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/conn-idle-timeout.md +46 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/conn-limits.md +44 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/conn-pooling.md +41 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/conn-prepared-statements.md +46 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/data-batch-inserts.md +54 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/data-n-plus-one.md +53 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/data-pagination.md +50 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/data-upsert.md +50 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/lock-advisory.md +56 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/lock-deadlock-prevention.md +68 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/lock-short-transactions.md +50 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/lock-skip-locked.md +54 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/monitor-explain-analyze.md +45 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/monitor-pg-stat-statements.md +55 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/monitor-vacuum-analyze.md +55 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/query-composite-indexes.md +44 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/query-covering-indexes.md +40 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/query-index-types.md +45 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/query-missing-indexes.md +43 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/query-partial-indexes.md +45 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/schema-data-types.md +46 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/schema-foreign-key-indexes.md +59 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/schema-lowercase-identifiers.md +55 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/schema-partitioning.md +55 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/schema-primary-keys.md +61 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/security-privileges.md +54 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/security-rls-basics.md +50 -0
- package/.gemini/skills/supabase-postgres-best-practices/rules/security-rls-performance.md +57 -0
- package/.gemini/skills/ui-skills/SKILL.md +85 -0
- package/.gemini/skills/web-design-guidelines/SKILL.md +39 -0
- package/.github/ISSUE_TEMPLATE.md +37 -0
- package/.github/PULL_REQUEST_TEMPLATE.md +33 -0
- package/.github/skills/agent-browser/SKILL.md +347 -0
- package/.github/skills/agent-browser/references/authentication.md +188 -0
- package/.github/skills/agent-browser/references/proxy-support.md +175 -0
- package/.github/skills/agent-browser/references/session-management.md +181 -0
- package/.github/skills/agent-browser/references/snapshot-refs.md +186 -0
- package/.github/skills/agent-browser/references/video-recording.md +162 -0
- package/.github/skills/agent-browser/templates/authenticated-session.sh +91 -0
- package/.github/skills/agent-browser/templates/capture-workflow.sh +68 -0
- package/.github/skills/agent-browser/templates/form-automation.sh +64 -0
- package/.github/skills/better-auth-best-practices/SKILL.md +166 -0
- package/.github/skills/design-md/SKILL.md +172 -0
- package/.github/skills/design-md/examples/DESIGN.md +154 -0
- package/.github/skills/frontend-design/LICENSE.txt +177 -0
- package/.github/skills/frontend-design/SKILL.md +42 -0
- package/.github/skills/remotion-best-practices/SKILL.md +43 -0
- package/.github/skills/remotion-best-practices/rules/3d.md +86 -0
- package/.github/skills/remotion-best-practices/rules/animations.md +29 -0
- package/.github/skills/remotion-best-practices/rules/assets/charts-bar-chart.tsx +173 -0
- package/.github/skills/remotion-best-practices/rules/assets/text-animations-typewriter.tsx +100 -0
- package/.github/skills/remotion-best-practices/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/.github/skills/remotion-best-practices/rules/assets.md +78 -0
- package/.github/skills/remotion-best-practices/rules/audio.md +172 -0
- package/.github/skills/remotion-best-practices/rules/calculate-metadata.md +104 -0
- package/.github/skills/remotion-best-practices/rules/can-decode.md +75 -0
- package/.github/skills/remotion-best-practices/rules/charts.md +58 -0
- package/.github/skills/remotion-best-practices/rules/compositions.md +146 -0
- package/.github/skills/remotion-best-practices/rules/display-captions.md +126 -0
- package/.github/skills/remotion-best-practices/rules/extract-frames.md +229 -0
- package/.github/skills/remotion-best-practices/rules/fonts.md +152 -0
- package/.github/skills/remotion-best-practices/rules/get-audio-duration.md +58 -0
- package/.github/skills/remotion-best-practices/rules/get-video-dimensions.md +68 -0
- package/.github/skills/remotion-best-practices/rules/get-video-duration.md +58 -0
- package/.github/skills/remotion-best-practices/rules/gifs.md +138 -0
- package/.github/skills/remotion-best-practices/rules/images.md +130 -0
- package/.github/skills/remotion-best-practices/rules/import-srt-captions.md +67 -0
- package/.github/skills/remotion-best-practices/rules/lottie.md +68 -0
- package/.github/skills/remotion-best-practices/rules/measuring-dom-nodes.md +35 -0
- package/.github/skills/remotion-best-practices/rules/measuring-text.md +143 -0
- package/.github/skills/remotion-best-practices/rules/sequencing.md +106 -0
- package/.github/skills/remotion-best-practices/rules/tailwind.md +11 -0
- package/.github/skills/remotion-best-practices/rules/text-animations.md +20 -0
- package/.github/skills/remotion-best-practices/rules/timing.md +179 -0
- package/.github/skills/remotion-best-practices/rules/transcribe-captions.md +19 -0
- package/.github/skills/remotion-best-practices/rules/transitions.md +122 -0
- package/.github/skills/remotion-best-practices/rules/trimming.md +53 -0
- package/.github/skills/remotion-best-practices/rules/videos.md +171 -0
- package/.github/skills/skill-creator/LICENSE.txt +202 -0
- package/.github/skills/skill-creator/SKILL.md +356 -0
- package/.github/skills/skill-creator/references/output-patterns.md +82 -0
- package/.github/skills/skill-creator/references/workflows.md +28 -0
- package/.github/skills/skill-creator/scripts/init_skill.py +303 -0
- package/.github/skills/skill-creator/scripts/package_skill.py +110 -0
- package/.github/skills/skill-creator/scripts/quick_validate.py +95 -0
- package/.github/skills/supabase-postgres-best-practices/AGENTS.md +1490 -0
- package/.github/skills/supabase-postgres-best-practices/SKILL.md +57 -0
- package/.github/skills/supabase-postgres-best-practices/rules/advanced-full-text-search.md +55 -0
- package/.github/skills/supabase-postgres-best-practices/rules/advanced-jsonb-indexing.md +49 -0
- package/.github/skills/supabase-postgres-best-practices/rules/conn-idle-timeout.md +46 -0
- package/.github/skills/supabase-postgres-best-practices/rules/conn-limits.md +44 -0
- package/.github/skills/supabase-postgres-best-practices/rules/conn-pooling.md +41 -0
- package/.github/skills/supabase-postgres-best-practices/rules/conn-prepared-statements.md +46 -0
- package/.github/skills/supabase-postgres-best-practices/rules/data-batch-inserts.md +54 -0
- package/.github/skills/supabase-postgres-best-practices/rules/data-n-plus-one.md +53 -0
- package/.github/skills/supabase-postgres-best-practices/rules/data-pagination.md +50 -0
- package/.github/skills/supabase-postgres-best-practices/rules/data-upsert.md +50 -0
- package/.github/skills/supabase-postgres-best-practices/rules/lock-advisory.md +56 -0
- package/.github/skills/supabase-postgres-best-practices/rules/lock-deadlock-prevention.md +68 -0
- package/.github/skills/supabase-postgres-best-practices/rules/lock-short-transactions.md +50 -0
- package/.github/skills/supabase-postgres-best-practices/rules/lock-skip-locked.md +54 -0
- package/.github/skills/supabase-postgres-best-practices/rules/monitor-explain-analyze.md +45 -0
- package/.github/skills/supabase-postgres-best-practices/rules/monitor-pg-stat-statements.md +55 -0
- package/.github/skills/supabase-postgres-best-practices/rules/monitor-vacuum-analyze.md +55 -0
- package/.github/skills/supabase-postgres-best-practices/rules/query-composite-indexes.md +44 -0
- package/.github/skills/supabase-postgres-best-practices/rules/query-covering-indexes.md +40 -0
- package/.github/skills/supabase-postgres-best-practices/rules/query-index-types.md +45 -0
- package/.github/skills/supabase-postgres-best-practices/rules/query-missing-indexes.md +43 -0
- package/.github/skills/supabase-postgres-best-practices/rules/query-partial-indexes.md +45 -0
- package/.github/skills/supabase-postgres-best-practices/rules/schema-data-types.md +46 -0
- package/.github/skills/supabase-postgres-best-practices/rules/schema-foreign-key-indexes.md +59 -0
- package/.github/skills/supabase-postgres-best-practices/rules/schema-lowercase-identifiers.md +55 -0
- package/.github/skills/supabase-postgres-best-practices/rules/schema-partitioning.md +55 -0
- package/.github/skills/supabase-postgres-best-practices/rules/schema-primary-keys.md +61 -0
- package/.github/skills/supabase-postgres-best-practices/rules/security-privileges.md +54 -0
- package/.github/skills/supabase-postgres-best-practices/rules/security-rls-basics.md +50 -0
- package/.github/skills/supabase-postgres-best-practices/rules/security-rls-performance.md +57 -0
- package/.github/skills/ui-skills/SKILL.md +85 -0
- package/.github/skills/vercel-react-best-practices/AGENTS.md +2719 -0
- package/.github/skills/vercel-react-best-practices/SKILL.md +125 -0
- package/.github/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
- package/.github/skills/vercel-react-best-practices/rules/advanced-use-latest.md +39 -0
- package/.github/skills/vercel-react-best-practices/rules/async-api-routes.md +38 -0
- package/.github/skills/vercel-react-best-practices/rules/async-defer-await.md +80 -0
- package/.github/skills/vercel-react-best-practices/rules/async-dependencies.md +51 -0
- package/.github/skills/vercel-react-best-practices/rules/async-parallel.md +28 -0
- package/.github/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
- package/.github/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +59 -0
- package/.github/skills/vercel-react-best-practices/rules/bundle-conditional.md +31 -0
- package/.github/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +49 -0
- package/.github/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +35 -0
- package/.github/skills/vercel-react-best-practices/rules/bundle-preload.md +50 -0
- package/.github/skills/vercel-react-best-practices/rules/client-event-listeners.md +74 -0
- package/.github/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +71 -0
- package/.github/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
- package/.github/skills/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
- package/.github/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +107 -0
- package/.github/skills/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
- package/.github/skills/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
- package/.github/skills/vercel-react-best-practices/rules/js-cache-storage.md +70 -0
- package/.github/skills/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
- package/.github/skills/vercel-react-best-practices/rules/js-early-exit.md +50 -0
- package/.github/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
- package/.github/skills/vercel-react-best-practices/rules/js-index-maps.md +37 -0
- package/.github/skills/vercel-react-best-practices/rules/js-length-check-first.md +49 -0
- package/.github/skills/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
- package/.github/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
- package/.github/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
- package/.github/skills/vercel-react-best-practices/rules/rendering-activity.md +26 -0
- package/.github/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
- package/.github/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +40 -0
- package/.github/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
- package/.github/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +46 -0
- package/.github/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
- package/.github/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
- package/.github/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +75 -0
- package/.github/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
- package/.github/skills/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
- package/.github/skills/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
- package/.github/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +74 -0
- package/.github/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +58 -0
- package/.github/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
- package/.github/skills/vercel-react-best-practices/rules/rerender-memo.md +44 -0
- package/.github/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
- package/.github/skills/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
- package/.github/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
- package/.github/skills/vercel-react-best-practices/rules/server-auth-actions.md +96 -0
- package/.github/skills/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
- package/.github/skills/vercel-react-best-practices/rules/server-cache-react.md +76 -0
- package/.github/skills/vercel-react-best-practices/rules/server-dedup-props.md +65 -0
- package/.github/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
- package/.github/skills/vercel-react-best-practices/rules/server-serialization.md +38 -0
- package/.github/skills/web-design-guidelines/SKILL.md +39 -0
- package/.github/workflows/dependency-review.yml +25 -0
- package/.github/workflows/npm-publish.yml +33 -0
- package/.github/workflows/validate.yml +48 -0
- package/LICENSE +21 -0
- package/README.md +160 -0
- package/bin/ai-config.mjs +9 -0
- package/configs.manifest.json +30 -0
- package/install.ps1 +18 -0
- package/install.sh +14 -0
- package/package.json +46 -0
- package/scripts/install.mjs +506 -0
- package/scripts/skills-catalog.mjs +31 -0
- package/templates/avvale-env.example +13 -0
|
@@ -0,0 +1,807 @@
|
|
|
1
|
+
# Batch Email Examples
|
|
2
|
+
|
|
3
|
+
## Table of Contents
|
|
4
|
+
|
|
5
|
+
- [Pre-send Validation](#pre-send-validation)
|
|
6
|
+
- [Error Handling](#error-handling)
|
|
7
|
+
- [Retry Logic with Idempotency](#retry-logic-with-idempotency)
|
|
8
|
+
- [Chunking Large Batches](#chunking-large-batches)
|
|
9
|
+
- [Production-Ready Implementations](#production-ready-implementations)
|
|
10
|
+
|
|
11
|
+
## Pre-send Validation
|
|
12
|
+
|
|
13
|
+
Since the entire batch fails if any email has invalid data, validate before sending.
|
|
14
|
+
|
|
15
|
+
### Node.js
|
|
16
|
+
|
|
17
|
+
```typescript
|
|
18
|
+
import { Resend } from 'resend';
|
|
19
|
+
|
|
20
|
+
const resend = new Resend(process.env.RESEND_API_KEY);
|
|
21
|
+
|
|
22
|
+
interface BatchEmail {
|
|
23
|
+
from: string;
|
|
24
|
+
to: string[];
|
|
25
|
+
subject: string;
|
|
26
|
+
html?: string;
|
|
27
|
+
text?: string;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
interface ValidationResult {
|
|
31
|
+
valid: boolean;
|
|
32
|
+
errors: { index: number; field: string; message: string }[];
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
function validateBatch(emails: BatchEmail[]): ValidationResult {
|
|
36
|
+
const errors: ValidationResult['errors'] = [];
|
|
37
|
+
|
|
38
|
+
if (emails.length === 0) {
|
|
39
|
+
return { valid: false, errors: [{ index: -1, field: 'batch', message: 'Batch cannot be empty' }] };
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
if (emails.length > 100) {
|
|
43
|
+
return { valid: false, errors: [{ index: -1, field: 'batch', message: 'Batch cannot exceed 100 emails' }] };
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
|
|
47
|
+
|
|
48
|
+
emails.forEach((email, index) => {
|
|
49
|
+
if (!email.from) {
|
|
50
|
+
errors.push({ index, field: 'from', message: 'From address is required' });
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
if (!email.to || email.to.length === 0) {
|
|
54
|
+
errors.push({ index, field: 'to', message: 'At least one recipient is required' });
|
|
55
|
+
} else if (email.to.length > 50) {
|
|
56
|
+
errors.push({ index, field: 'to', message: 'Cannot exceed 50 recipients per email' });
|
|
57
|
+
} else {
|
|
58
|
+
email.to.forEach((recipient, rIndex) => {
|
|
59
|
+
if (!emailRegex.test(recipient)) {
|
|
60
|
+
errors.push({ index, field: `to[${rIndex}]`, message: `Invalid email: ${recipient}` });
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if (!email.subject) {
|
|
66
|
+
errors.push({ index, field: 'subject', message: 'Subject is required' });
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
if (!email.html && !email.text) {
|
|
70
|
+
errors.push({ index, field: 'content', message: 'Either html or text content is required' });
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
return { valid: errors.length === 0, errors };
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
// Usage
|
|
78
|
+
const emails = [
|
|
79
|
+
{ from: 'Acme <noreply@acme.com>', to: ['delivered@resend.dev'], subject: 'Hello', html: '<p>Hi</p>' },
|
|
80
|
+
];
|
|
81
|
+
|
|
82
|
+
const validation = validateBatch(emails);
|
|
83
|
+
if (!validation.valid) {
|
|
84
|
+
console.error('Validation failed:', validation.errors);
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
const { data, error } = await resend.batch.send(emails);
|
|
89
|
+
```
|
|
90
|
+
|
|
91
|
+
### Python
|
|
92
|
+
|
|
93
|
+
```python
|
|
94
|
+
import resend
|
|
95
|
+
import re
|
|
96
|
+
import os
|
|
97
|
+
from dataclasses import dataclass
|
|
98
|
+
from typing import List, Optional
|
|
99
|
+
|
|
100
|
+
resend.api_key = os.environ["RESEND_API_KEY"]
|
|
101
|
+
|
|
102
|
+
@dataclass
|
|
103
|
+
class ValidationError:
|
|
104
|
+
index: int
|
|
105
|
+
field: str
|
|
106
|
+
message: str
|
|
107
|
+
|
|
108
|
+
def validate_batch(emails: List[dict]) -> tuple[bool, List[ValidationError]]:
|
|
109
|
+
errors = []
|
|
110
|
+
email_regex = re.compile(r'^[^\s@]+@[^\s@]+\.[^\s@]+$')
|
|
111
|
+
|
|
112
|
+
if not emails:
|
|
113
|
+
return False, [ValidationError(-1, 'batch', 'Batch cannot be empty')]
|
|
114
|
+
|
|
115
|
+
if len(emails) > 100:
|
|
116
|
+
return False, [ValidationError(-1, 'batch', 'Batch cannot exceed 100 emails')]
|
|
117
|
+
|
|
118
|
+
for index, email in enumerate(emails):
|
|
119
|
+
if not email.get('from'):
|
|
120
|
+
errors.append(ValidationError(index, 'from', 'From address is required'))
|
|
121
|
+
|
|
122
|
+
to_list = email.get('to', [])
|
|
123
|
+
if not to_list:
|
|
124
|
+
errors.append(ValidationError(index, 'to', 'At least one recipient is required'))
|
|
125
|
+
elif len(to_list) > 50:
|
|
126
|
+
errors.append(ValidationError(index, 'to', 'Cannot exceed 50 recipients per email'))
|
|
127
|
+
else:
|
|
128
|
+
for r_index, recipient in enumerate(to_list):
|
|
129
|
+
if not email_regex.match(recipient):
|
|
130
|
+
errors.append(ValidationError(index, f'to[{r_index}]', f'Invalid email: {recipient}'))
|
|
131
|
+
|
|
132
|
+
if not email.get('subject'):
|
|
133
|
+
errors.append(ValidationError(index, 'subject', 'Subject is required'))
|
|
134
|
+
|
|
135
|
+
if not email.get('html') and not email.get('text'):
|
|
136
|
+
errors.append(ValidationError(index, 'content', 'Either html or text content is required'))
|
|
137
|
+
|
|
138
|
+
return len(errors) == 0, errors
|
|
139
|
+
|
|
140
|
+
# Usage
|
|
141
|
+
emails = [
|
|
142
|
+
{"from": "Acme <noreply@acme.com>", "to": ["delivered@resend.dev"], "subject": "Hello", "html": "<p>Hi</p>"},
|
|
143
|
+
]
|
|
144
|
+
|
|
145
|
+
valid, errors = validate_batch(emails)
|
|
146
|
+
if not valid:
|
|
147
|
+
print(f"Validation failed: {errors}")
|
|
148
|
+
else:
|
|
149
|
+
result = resend.Batch.send(emails)
|
|
150
|
+
```
|
|
151
|
+
|
|
152
|
+
## Error Handling
|
|
153
|
+
|
|
154
|
+
### Common Error Codes
|
|
155
|
+
|
|
156
|
+
| Code | Description | Action |
|
|
157
|
+
|------|-------------|--------|
|
|
158
|
+
| 400 | Bad request (invalid params) | Fix request parameters, don't retry |
|
|
159
|
+
| 401 | Invalid API key | Check RESEND_API_KEY, don't retry |
|
|
160
|
+
| 403 | Domain not verified | Verify domain at resend.com/domains |
|
|
161
|
+
| 409 | Idempotency conflict | Same key with different payload |
|
|
162
|
+
| 422 | Unprocessable entity | Check email format/content, don't retry |
|
|
163
|
+
| 429 | Rate limited | Retry with exponential backoff |
|
|
164
|
+
| 500 | Server error | Retry with exponential backoff |
|
|
165
|
+
|
|
166
|
+
### Node.js
|
|
167
|
+
|
|
168
|
+
```typescript
|
|
169
|
+
import { Resend } from 'resend';
|
|
170
|
+
|
|
171
|
+
const resend = new Resend(process.env.RESEND_API_KEY);
|
|
172
|
+
|
|
173
|
+
const { data, error } = await resend.batch.send(emails);
|
|
174
|
+
|
|
175
|
+
if (error) {
|
|
176
|
+
switch (error.name) {
|
|
177
|
+
case 'validation_error':
|
|
178
|
+
// Invalid parameters - don't retry, fix the data
|
|
179
|
+
console.error('Validation error:', error.message);
|
|
180
|
+
throw new Error(`Invalid batch data: ${error.message}`);
|
|
181
|
+
|
|
182
|
+
case 'rate_limit_exceeded':
|
|
183
|
+
// Rate limited - safe to retry with backoff
|
|
184
|
+
console.log('Rate limited, should retry with backoff');
|
|
185
|
+
break;
|
|
186
|
+
|
|
187
|
+
case 'api_error':
|
|
188
|
+
// Server error - safe to retry
|
|
189
|
+
console.log('Server error, should retry');
|
|
190
|
+
break;
|
|
191
|
+
|
|
192
|
+
default:
|
|
193
|
+
console.error('Unexpected error:', error);
|
|
194
|
+
}
|
|
195
|
+
return;
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
console.log('Batch sent successfully:', data);
|
|
199
|
+
```
|
|
200
|
+
|
|
201
|
+
### Python
|
|
202
|
+
|
|
203
|
+
```python
|
|
204
|
+
import resend
|
|
205
|
+
import os
|
|
206
|
+
|
|
207
|
+
resend.api_key = os.environ["RESEND_API_KEY"]
|
|
208
|
+
|
|
209
|
+
try:
|
|
210
|
+
result = resend.Batch.send(emails)
|
|
211
|
+
print(f"Batch sent: {result}")
|
|
212
|
+
except resend.exceptions.ValidationError as e:
|
|
213
|
+
# Invalid parameters - don't retry
|
|
214
|
+
print(f"Validation error (don't retry): {e}")
|
|
215
|
+
raise
|
|
216
|
+
except resend.exceptions.RateLimitError as e:
|
|
217
|
+
# Rate limited - retry with backoff
|
|
218
|
+
print(f"Rate limited (retry with backoff): {e}")
|
|
219
|
+
except resend.exceptions.ResendError as e:
|
|
220
|
+
# Other API error - may retry
|
|
221
|
+
print(f"API error: {e}")
|
|
222
|
+
```
|
|
223
|
+
|
|
224
|
+
## Retry Logic with Idempotency
|
|
225
|
+
|
|
226
|
+
Combine retry logic with idempotency keys to safely retry failed batches.
|
|
227
|
+
|
|
228
|
+
### Node.js
|
|
229
|
+
|
|
230
|
+
```typescript
|
|
231
|
+
import { Resend } from 'resend';
|
|
232
|
+
|
|
233
|
+
const resend = new Resend(process.env.RESEND_API_KEY);
|
|
234
|
+
|
|
235
|
+
interface BatchSendOptions {
|
|
236
|
+
maxRetries?: number;
|
|
237
|
+
idempotencyKey: string;
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
async function sendBatchWithRetry(
|
|
241
|
+
emails: Parameters<typeof resend.batch.send>[0],
|
|
242
|
+
options: BatchSendOptions
|
|
243
|
+
) {
|
|
244
|
+
const { maxRetries = 3, idempotencyKey } = options;
|
|
245
|
+
|
|
246
|
+
for (let attempt = 0; attempt <= maxRetries; attempt++) {
|
|
247
|
+
const { data, error } = await resend.batch.send(emails, {
|
|
248
|
+
idempotencyKey,
|
|
249
|
+
});
|
|
250
|
+
|
|
251
|
+
if (!error) {
|
|
252
|
+
return { success: true, data };
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
// Don't retry validation errors
|
|
256
|
+
if (error.name === 'validation_error') {
|
|
257
|
+
return { success: false, error: error.message, retryable: false };
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
// Don't retry idempotency conflicts
|
|
261
|
+
if (error.name === 'idempotency_error') {
|
|
262
|
+
return { success: false, error: 'Duplicate request with different payload', retryable: false };
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
// Last attempt failed
|
|
266
|
+
if (attempt === maxRetries) {
|
|
267
|
+
return { success: false, error: error.message, retryable: true };
|
|
268
|
+
}
|
|
269
|
+
|
|
270
|
+
// Exponential backoff: 1s, 2s, 4s...
|
|
271
|
+
const delay = Math.pow(2, attempt) * 1000;
|
|
272
|
+
console.log(`Attempt ${attempt + 1} failed, retrying in ${delay}ms...`);
|
|
273
|
+
await new Promise(resolve => setTimeout(resolve, delay));
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
return { success: false, error: 'Max retries exceeded', retryable: true };
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
// Usage
|
|
280
|
+
const result = await sendBatchWithRetry(
|
|
281
|
+
[
|
|
282
|
+
{ from: 'Acme <noreply@acme.com>', to: ['delivered@resend.dev'], subject: 'Hello', html: '<p>Hi</p>' },
|
|
283
|
+
{ from: 'Acme <noreply@acme.com>', to: ['delivered@resend.dev'], subject: 'Hello', html: '<p>Hi</p>' },
|
|
284
|
+
],
|
|
285
|
+
{ idempotencyKey: `batch-welcome/${batchId}` }
|
|
286
|
+
);
|
|
287
|
+
|
|
288
|
+
if (result.success) {
|
|
289
|
+
console.log('Batch sent:', result.data);
|
|
290
|
+
} else {
|
|
291
|
+
console.error('Batch failed:', result.error);
|
|
292
|
+
}
|
|
293
|
+
```
|
|
294
|
+
|
|
295
|
+
### Python
|
|
296
|
+
|
|
297
|
+
```python
|
|
298
|
+
import resend
|
|
299
|
+
import os
|
|
300
|
+
import time
|
|
301
|
+
from dataclasses import dataclass
|
|
302
|
+
from typing import Optional, List
|
|
303
|
+
|
|
304
|
+
resend.api_key = os.environ["RESEND_API_KEY"]
|
|
305
|
+
|
|
306
|
+
@dataclass
|
|
307
|
+
class BatchResult:
|
|
308
|
+
success: bool
|
|
309
|
+
data: Optional[List[dict]] = None
|
|
310
|
+
error: Optional[str] = None
|
|
311
|
+
retryable: bool = False
|
|
312
|
+
|
|
313
|
+
def send_batch_with_retry(
|
|
314
|
+
emails: List[dict],
|
|
315
|
+
idempotency_key: str,
|
|
316
|
+
max_retries: int = 3
|
|
317
|
+
) -> BatchResult:
|
|
318
|
+
for attempt in range(max_retries + 1):
|
|
319
|
+
try:
|
|
320
|
+
result = resend.Batch.send(emails, idempotency_key=idempotency_key)
|
|
321
|
+
return BatchResult(success=True, data=result)
|
|
322
|
+
except resend.exceptions.ValidationError as e:
|
|
323
|
+
# Don't retry validation errors
|
|
324
|
+
return BatchResult(success=False, error=str(e), retryable=False)
|
|
325
|
+
except resend.exceptions.ResendError as e:
|
|
326
|
+
if attempt == max_retries:
|
|
327
|
+
return BatchResult(success=False, error=str(e), retryable=True)
|
|
328
|
+
|
|
329
|
+
# Exponential backoff: 1s, 2s, 4s...
|
|
330
|
+
delay = 2 ** attempt
|
|
331
|
+
print(f"Attempt {attempt + 1} failed, retrying in {delay}s...")
|
|
332
|
+
time.sleep(delay)
|
|
333
|
+
|
|
334
|
+
return BatchResult(success=False, error="Max retries exceeded", retryable=True)
|
|
335
|
+
|
|
336
|
+
# Usage
|
|
337
|
+
result = send_batch_with_retry(
|
|
338
|
+
emails=[
|
|
339
|
+
{"from": "Acme <noreply@acme.com>", "to": ["delivered@resend.dev"], "subject": "Hello", "html": "<p>Hi</p>"},
|
|
340
|
+
{"from": "Acme <noreply@acme.com>", "to": ["delivered@resend.dev"], "subject": "Hello", "html": "<p>Hi</p>"},
|
|
341
|
+
],
|
|
342
|
+
idempotency_key=f"batch-welcome/{batch_id}"
|
|
343
|
+
)
|
|
344
|
+
|
|
345
|
+
if result.success:
|
|
346
|
+
print(f"Batch sent: {result.data}")
|
|
347
|
+
else:
|
|
348
|
+
print(f"Batch failed: {result.error}")
|
|
349
|
+
```
|
|
350
|
+
|
|
351
|
+
## Chunking Large Batches
|
|
352
|
+
|
|
353
|
+
For sends larger than 100 emails, chunk into multiple batch requests.
|
|
354
|
+
|
|
355
|
+
### Node.js
|
|
356
|
+
|
|
357
|
+
```typescript
|
|
358
|
+
import { Resend } from 'resend';
|
|
359
|
+
import { randomUUID } from 'crypto';
|
|
360
|
+
|
|
361
|
+
const resend = new Resend(process.env.RESEND_API_KEY);
|
|
362
|
+
|
|
363
|
+
const BATCH_SIZE = 100;
|
|
364
|
+
|
|
365
|
+
interface Email {
|
|
366
|
+
from: string;
|
|
367
|
+
to: string[];
|
|
368
|
+
subject: string;
|
|
369
|
+
html: string;
|
|
370
|
+
}
|
|
371
|
+
|
|
372
|
+
async function sendLargeBatch(emails: Email[], batchPrefix: string) {
|
|
373
|
+
const chunks: Email[][] = [];
|
|
374
|
+
|
|
375
|
+
for (let i = 0; i < emails.length; i += BATCH_SIZE) {
|
|
376
|
+
chunks.push(emails.slice(i, i + BATCH_SIZE));
|
|
377
|
+
}
|
|
378
|
+
|
|
379
|
+
const results = await Promise.all(
|
|
380
|
+
chunks.map(async (chunk, index) => {
|
|
381
|
+
const idempotencyKey = `${batchPrefix}/chunk-${index}`;
|
|
382
|
+
|
|
383
|
+
const { data, error } = await resend.batch.send(chunk, { idempotencyKey });
|
|
384
|
+
|
|
385
|
+
return {
|
|
386
|
+
chunkIndex: index,
|
|
387
|
+
success: !error,
|
|
388
|
+
data,
|
|
389
|
+
error: error?.message,
|
|
390
|
+
};
|
|
391
|
+
})
|
|
392
|
+
);
|
|
393
|
+
|
|
394
|
+
const successful = results.filter(r => r.success);
|
|
395
|
+
const failed = results.filter(r => !r.success);
|
|
396
|
+
|
|
397
|
+
return {
|
|
398
|
+
totalChunks: chunks.length,
|
|
399
|
+
successful: successful.length,
|
|
400
|
+
failed: failed.length,
|
|
401
|
+
results,
|
|
402
|
+
};
|
|
403
|
+
}
|
|
404
|
+
|
|
405
|
+
// Usage: Send 250 emails
|
|
406
|
+
const emails = generateEmails(250); // Your email generation logic
|
|
407
|
+
const result = await sendLargeBatch(emails, `campaign-${randomUUID()}`);
|
|
408
|
+
|
|
409
|
+
console.log(`Sent ${result.successful}/${result.totalChunks} chunks successfully`);
|
|
410
|
+
```
|
|
411
|
+
|
|
412
|
+
### Python
|
|
413
|
+
|
|
414
|
+
```python
|
|
415
|
+
import resend
|
|
416
|
+
import os
|
|
417
|
+
import uuid
|
|
418
|
+
from typing import List
|
|
419
|
+
from concurrent.futures import ThreadPoolExecutor, as_completed
|
|
420
|
+
|
|
421
|
+
resend.api_key = os.environ["RESEND_API_KEY"]
|
|
422
|
+
|
|
423
|
+
BATCH_SIZE = 100
|
|
424
|
+
|
|
425
|
+
def chunk_list(lst: List, size: int) -> List[List]:
|
|
426
|
+
return [lst[i:i + size] for i in range(0, len(lst), size)]
|
|
427
|
+
|
|
428
|
+
def send_chunk(chunk: List[dict], idempotency_key: str) -> dict:
|
|
429
|
+
try:
|
|
430
|
+
result = resend.Batch.send(chunk, idempotency_key=idempotency_key)
|
|
431
|
+
return {"success": True, "data": result}
|
|
432
|
+
except Exception as e:
|
|
433
|
+
return {"success": False, "error": str(e)}
|
|
434
|
+
|
|
435
|
+
def send_large_batch(emails: List[dict], batch_prefix: str) -> dict:
|
|
436
|
+
chunks = chunk_list(emails, BATCH_SIZE)
|
|
437
|
+
results = []
|
|
438
|
+
|
|
439
|
+
# Send chunks in parallel (adjust max_workers as needed)
|
|
440
|
+
with ThreadPoolExecutor(max_workers=5) as executor:
|
|
441
|
+
futures = {
|
|
442
|
+
executor.submit(
|
|
443
|
+
send_chunk,
|
|
444
|
+
chunk,
|
|
445
|
+
f"{batch_prefix}/chunk-{index}"
|
|
446
|
+
): index
|
|
447
|
+
for index, chunk in enumerate(chunks)
|
|
448
|
+
}
|
|
449
|
+
|
|
450
|
+
for future in as_completed(futures):
|
|
451
|
+
index = futures[future]
|
|
452
|
+
result = future.result()
|
|
453
|
+
result["chunk_index"] = index
|
|
454
|
+
results.append(result)
|
|
455
|
+
|
|
456
|
+
successful = [r for r in results if r["success"]]
|
|
457
|
+
failed = [r for r in results if not r["success"]]
|
|
458
|
+
|
|
459
|
+
return {
|
|
460
|
+
"total_chunks": len(chunks),
|
|
461
|
+
"successful": len(successful),
|
|
462
|
+
"failed": len(failed),
|
|
463
|
+
"results": results,
|
|
464
|
+
}
|
|
465
|
+
|
|
466
|
+
# Usage: Send 250 emails
|
|
467
|
+
emails = generate_emails(250) # Your email generation logic
|
|
468
|
+
result = send_large_batch(emails, f"campaign-{uuid.uuid4()}")
|
|
469
|
+
|
|
470
|
+
print(f"Sent {result['successful']}/{result['total_chunks']} chunks successfully")
|
|
471
|
+
```
|
|
472
|
+
|
|
473
|
+
## Production-Ready Implementations
|
|
474
|
+
|
|
475
|
+
### Node.js - Complete Batch Email Service
|
|
476
|
+
|
|
477
|
+
```typescript
|
|
478
|
+
import { Resend } from 'resend';
|
|
479
|
+
import { randomUUID } from 'crypto';
|
|
480
|
+
|
|
481
|
+
const resend = new Resend(process.env.RESEND_API_KEY);
|
|
482
|
+
|
|
483
|
+
interface BatchEmail {
|
|
484
|
+
from: string;
|
|
485
|
+
to: string[];
|
|
486
|
+
subject: string;
|
|
487
|
+
html?: string;
|
|
488
|
+
text?: string;
|
|
489
|
+
replyTo?: string;
|
|
490
|
+
cc?: string[];
|
|
491
|
+
bcc?: string[];
|
|
492
|
+
tags?: { name: string; value: string }[];
|
|
493
|
+
}
|
|
494
|
+
|
|
495
|
+
interface BatchSendOptions {
|
|
496
|
+
idempotencyKey?: string;
|
|
497
|
+
maxRetries?: number;
|
|
498
|
+
validateBeforeSend?: boolean;
|
|
499
|
+
}
|
|
500
|
+
|
|
501
|
+
interface BatchResult {
|
|
502
|
+
success: boolean;
|
|
503
|
+
data?: { id: string }[];
|
|
504
|
+
error?: string;
|
|
505
|
+
retryable: boolean;
|
|
506
|
+
validationErrors?: { index: number; field: string; message: string }[];
|
|
507
|
+
}
|
|
508
|
+
|
|
509
|
+
class BatchEmailService {
|
|
510
|
+
private maxBatchSize = 100;
|
|
511
|
+
private maxRecipientsPerEmail = 50;
|
|
512
|
+
|
|
513
|
+
validate(emails: BatchEmail[]): { valid: boolean; errors: BatchResult['validationErrors'] } {
|
|
514
|
+
const errors: NonNullable<BatchResult['validationErrors']> = [];
|
|
515
|
+
const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
|
|
516
|
+
|
|
517
|
+
if (emails.length === 0) {
|
|
518
|
+
errors.push({ index: -1, field: 'batch', message: 'Batch cannot be empty' });
|
|
519
|
+
return { valid: false, errors };
|
|
520
|
+
}
|
|
521
|
+
|
|
522
|
+
if (emails.length > this.maxBatchSize) {
|
|
523
|
+
errors.push({ index: -1, field: 'batch', message: `Batch cannot exceed ${this.maxBatchSize} emails` });
|
|
524
|
+
return { valid: false, errors };
|
|
525
|
+
}
|
|
526
|
+
|
|
527
|
+
emails.forEach((email, index) => {
|
|
528
|
+
if (!email.from) {
|
|
529
|
+
errors.push({ index, field: 'from', message: 'From address is required' });
|
|
530
|
+
}
|
|
531
|
+
|
|
532
|
+
if (!email.to?.length) {
|
|
533
|
+
errors.push({ index, field: 'to', message: 'At least one recipient is required' });
|
|
534
|
+
} else if (email.to.length > this.maxRecipientsPerEmail) {
|
|
535
|
+
errors.push({ index, field: 'to', message: `Cannot exceed ${this.maxRecipientsPerEmail} recipients` });
|
|
536
|
+
} else {
|
|
537
|
+
email.to.forEach((r, i) => {
|
|
538
|
+
if (!emailRegex.test(r)) {
|
|
539
|
+
errors.push({ index, field: `to[${i}]`, message: `Invalid email: ${r}` });
|
|
540
|
+
}
|
|
541
|
+
});
|
|
542
|
+
}
|
|
543
|
+
|
|
544
|
+
if (!email.subject) {
|
|
545
|
+
errors.push({ index, field: 'subject', message: 'Subject is required' });
|
|
546
|
+
}
|
|
547
|
+
|
|
548
|
+
if (!email.html && !email.text) {
|
|
549
|
+
errors.push({ index, field: 'content', message: 'Either html or text is required' });
|
|
550
|
+
}
|
|
551
|
+
});
|
|
552
|
+
|
|
553
|
+
return { valid: errors.length === 0, errors };
|
|
554
|
+
}
|
|
555
|
+
|
|
556
|
+
async send(emails: BatchEmail[], options: BatchSendOptions = {}): Promise<BatchResult> {
|
|
557
|
+
const {
|
|
558
|
+
idempotencyKey = `batch-${randomUUID()}`,
|
|
559
|
+
maxRetries = 3,
|
|
560
|
+
validateBeforeSend = true,
|
|
561
|
+
} = options;
|
|
562
|
+
|
|
563
|
+
// Validate first
|
|
564
|
+
if (validateBeforeSend) {
|
|
565
|
+
const validation = this.validate(emails);
|
|
566
|
+
if (!validation.valid) {
|
|
567
|
+
return {
|
|
568
|
+
success: false,
|
|
569
|
+
error: 'Validation failed',
|
|
570
|
+
retryable: false,
|
|
571
|
+
validationErrors: validation.errors,
|
|
572
|
+
};
|
|
573
|
+
}
|
|
574
|
+
}
|
|
575
|
+
|
|
576
|
+
// Send with retry
|
|
577
|
+
for (let attempt = 0; attempt <= maxRetries; attempt++) {
|
|
578
|
+
const { data, error } = await resend.batch.send(emails, { idempotencyKey });
|
|
579
|
+
|
|
580
|
+
if (!error) {
|
|
581
|
+
return { success: true, data, retryable: false };
|
|
582
|
+
}
|
|
583
|
+
|
|
584
|
+
// Non-retryable errors
|
|
585
|
+
if (error.name === 'validation_error' || error.name === 'not_found') {
|
|
586
|
+
return { success: false, error: error.message, retryable: false };
|
|
587
|
+
}
|
|
588
|
+
|
|
589
|
+
if (attempt < maxRetries) {
|
|
590
|
+
const delay = Math.pow(2, attempt) * 1000;
|
|
591
|
+
await new Promise(r => setTimeout(r, delay));
|
|
592
|
+
}
|
|
593
|
+
}
|
|
594
|
+
|
|
595
|
+
return { success: false, error: 'Max retries exceeded', retryable: true };
|
|
596
|
+
}
|
|
597
|
+
|
|
598
|
+
async sendLarge(emails: BatchEmail[], batchPrefix: string): Promise<{
|
|
599
|
+
totalEmails: number;
|
|
600
|
+
totalChunks: number;
|
|
601
|
+
successfulChunks: number;
|
|
602
|
+
failedChunks: number;
|
|
603
|
+
sentEmailIds: string[];
|
|
604
|
+
errors: { chunkIndex: number; error: string }[];
|
|
605
|
+
}> {
|
|
606
|
+
const chunks: BatchEmail[][] = [];
|
|
607
|
+
for (let i = 0; i < emails.length; i += this.maxBatchSize) {
|
|
608
|
+
chunks.push(emails.slice(i, i + this.maxBatchSize));
|
|
609
|
+
}
|
|
610
|
+
|
|
611
|
+
const results = await Promise.all(
|
|
612
|
+
chunks.map((chunk, index) =>
|
|
613
|
+
this.send(chunk, { idempotencyKey: `${batchPrefix}/chunk-${index}` })
|
|
614
|
+
.then(result => ({ chunkIndex: index, ...result }))
|
|
615
|
+
)
|
|
616
|
+
);
|
|
617
|
+
|
|
618
|
+
const successful = results.filter(r => r.success);
|
|
619
|
+
const failed = results.filter(r => !r.success);
|
|
620
|
+
|
|
621
|
+
return {
|
|
622
|
+
totalEmails: emails.length,
|
|
623
|
+
totalChunks: chunks.length,
|
|
624
|
+
successfulChunks: successful.length,
|
|
625
|
+
failedChunks: failed.length,
|
|
626
|
+
sentEmailIds: successful.flatMap(r => r.data?.map(d => d.id) || []),
|
|
627
|
+
errors: failed.map(r => ({ chunkIndex: r.chunkIndex, error: r.error || 'Unknown error' })),
|
|
628
|
+
};
|
|
629
|
+
}
|
|
630
|
+
}
|
|
631
|
+
|
|
632
|
+
// Usage
|
|
633
|
+
const batchService = new BatchEmailService();
|
|
634
|
+
|
|
635
|
+
// Simple batch
|
|
636
|
+
const result = await batchService.send([
|
|
637
|
+
{ from: 'Acme <noreply@acme.com>', to: ['delivered@resend.dev'], subject: 'Hello', html: '<p>Hi</p>' },
|
|
638
|
+
{ from: 'Acme <noreply@acme.com>', to: ['delivered@resend.dev'], subject: 'Hello', html: '<p>Hi</p>' },
|
|
639
|
+
], { idempotencyKey: `welcome-batch/${batchId}` });
|
|
640
|
+
|
|
641
|
+
// Large batch (auto-chunked)
|
|
642
|
+
const largeResult = await batchService.sendLarge(emails, `campaign-${campaignId}`);
|
|
643
|
+
```
|
|
644
|
+
|
|
645
|
+
### Python - Complete Batch Email Service
|
|
646
|
+
|
|
647
|
+
```python
|
|
648
|
+
import resend
|
|
649
|
+
import os
|
|
650
|
+
import re
|
|
651
|
+
import time
|
|
652
|
+
import uuid
|
|
653
|
+
from dataclasses import dataclass, field
|
|
654
|
+
from typing import List, Optional
|
|
655
|
+
from concurrent.futures import ThreadPoolExecutor, as_completed
|
|
656
|
+
|
|
657
|
+
resend.api_key = os.environ["RESEND_API_KEY"]
|
|
658
|
+
|
|
659
|
+
@dataclass
|
|
660
|
+
class ValidationError:
|
|
661
|
+
index: int
|
|
662
|
+
field: str
|
|
663
|
+
message: str
|
|
664
|
+
|
|
665
|
+
@dataclass
|
|
666
|
+
class BatchResult:
|
|
667
|
+
success: bool
|
|
668
|
+
data: Optional[List[dict]] = None
|
|
669
|
+
error: Optional[str] = None
|
|
670
|
+
retryable: bool = False
|
|
671
|
+
validation_errors: List[ValidationError] = field(default_factory=list)
|
|
672
|
+
|
|
673
|
+
@dataclass
|
|
674
|
+
class LargeBatchResult:
|
|
675
|
+
total_emails: int
|
|
676
|
+
total_chunks: int
|
|
677
|
+
successful_chunks: int
|
|
678
|
+
failed_chunks: int
|
|
679
|
+
sent_email_ids: List[str]
|
|
680
|
+
errors: List[dict]
|
|
681
|
+
|
|
682
|
+
class BatchEmailService:
|
|
683
|
+
MAX_BATCH_SIZE = 100
|
|
684
|
+
MAX_RECIPIENTS_PER_EMAIL = 50
|
|
685
|
+
|
|
686
|
+
def __init__(self):
|
|
687
|
+
self.email_regex = re.compile(r'^[^\s@]+@[^\s@]+\.[^\s@]+$')
|
|
688
|
+
|
|
689
|
+
def validate(self, emails: List[dict]) -> tuple[bool, List[ValidationError]]:
|
|
690
|
+
errors = []
|
|
691
|
+
|
|
692
|
+
if not emails:
|
|
693
|
+
errors.append(ValidationError(-1, 'batch', 'Batch cannot be empty'))
|
|
694
|
+
return False, errors
|
|
695
|
+
|
|
696
|
+
if len(emails) > self.MAX_BATCH_SIZE:
|
|
697
|
+
errors.append(ValidationError(-1, 'batch', f'Batch cannot exceed {self.MAX_BATCH_SIZE} emails'))
|
|
698
|
+
return False, errors
|
|
699
|
+
|
|
700
|
+
for index, email in enumerate(emails):
|
|
701
|
+
if not email.get('from'):
|
|
702
|
+
errors.append(ValidationError(index, 'from', 'From address is required'))
|
|
703
|
+
|
|
704
|
+
to_list = email.get('to', [])
|
|
705
|
+
if not to_list:
|
|
706
|
+
errors.append(ValidationError(index, 'to', 'At least one recipient is required'))
|
|
707
|
+
elif len(to_list) > self.MAX_RECIPIENTS_PER_EMAIL:
|
|
708
|
+
errors.append(ValidationError(index, 'to', f'Cannot exceed {self.MAX_RECIPIENTS_PER_EMAIL} recipients'))
|
|
709
|
+
else:
|
|
710
|
+
for r_idx, recipient in enumerate(to_list):
|
|
711
|
+
if not self.email_regex.match(recipient):
|
|
712
|
+
errors.append(ValidationError(index, f'to[{r_idx}]', f'Invalid email: {recipient}'))
|
|
713
|
+
|
|
714
|
+
if not email.get('subject'):
|
|
715
|
+
errors.append(ValidationError(index, 'subject', 'Subject is required'))
|
|
716
|
+
|
|
717
|
+
if not email.get('html') and not email.get('text'):
|
|
718
|
+
errors.append(ValidationError(index, 'content', 'Either html or text is required'))
|
|
719
|
+
|
|
720
|
+
return len(errors) == 0, errors
|
|
721
|
+
|
|
722
|
+
def send(
|
|
723
|
+
self,
|
|
724
|
+
emails: List[dict],
|
|
725
|
+
idempotency_key: Optional[str] = None,
|
|
726
|
+
max_retries: int = 3,
|
|
727
|
+
validate_before_send: bool = True
|
|
728
|
+
) -> BatchResult:
|
|
729
|
+
idempotency_key = idempotency_key or f"batch-{uuid.uuid4()}"
|
|
730
|
+
|
|
731
|
+
# Validate first
|
|
732
|
+
if validate_before_send:
|
|
733
|
+
valid, errors = self.validate(emails)
|
|
734
|
+
if not valid:
|
|
735
|
+
return BatchResult(
|
|
736
|
+
success=False,
|
|
737
|
+
error='Validation failed',
|
|
738
|
+
retryable=False,
|
|
739
|
+
validation_errors=errors
|
|
740
|
+
)
|
|
741
|
+
|
|
742
|
+
# Send with retry
|
|
743
|
+
for attempt in range(max_retries + 1):
|
|
744
|
+
try:
|
|
745
|
+
result = resend.Batch.send(emails, idempotency_key=idempotency_key)
|
|
746
|
+
return BatchResult(success=True, data=result)
|
|
747
|
+
except resend.exceptions.ValidationError as e:
|
|
748
|
+
return BatchResult(success=False, error=str(e), retryable=False)
|
|
749
|
+
except resend.exceptions.ResendError as e:
|
|
750
|
+
if attempt < max_retries:
|
|
751
|
+
time.sleep(2 ** attempt)
|
|
752
|
+
else:
|
|
753
|
+
return BatchResult(success=False, error=str(e), retryable=True)
|
|
754
|
+
|
|
755
|
+
return BatchResult(success=False, error='Max retries exceeded', retryable=True)
|
|
756
|
+
|
|
757
|
+
def send_large(self, emails: List[dict], batch_prefix: str, max_workers: int = 5) -> LargeBatchResult:
|
|
758
|
+
chunks = [emails[i:i + self.MAX_BATCH_SIZE] for i in range(0, len(emails), self.MAX_BATCH_SIZE)]
|
|
759
|
+
results = []
|
|
760
|
+
|
|
761
|
+
with ThreadPoolExecutor(max_workers=max_workers) as executor:
|
|
762
|
+
futures = {
|
|
763
|
+
executor.submit(
|
|
764
|
+
self.send,
|
|
765
|
+
chunk,
|
|
766
|
+
f"{batch_prefix}/chunk-{idx}"
|
|
767
|
+
): idx
|
|
768
|
+
for idx, chunk in enumerate(chunks)
|
|
769
|
+
}
|
|
770
|
+
|
|
771
|
+
for future in as_completed(futures):
|
|
772
|
+
idx = futures[future]
|
|
773
|
+
result = future.result()
|
|
774
|
+
results.append({"chunk_index": idx, "result": result})
|
|
775
|
+
|
|
776
|
+
successful = [r for r in results if r["result"].success]
|
|
777
|
+
failed = [r for r in results if not r["result"].success]
|
|
778
|
+
|
|
779
|
+
return LargeBatchResult(
|
|
780
|
+
total_emails=len(emails),
|
|
781
|
+
total_chunks=len(chunks),
|
|
782
|
+
successful_chunks=len(successful),
|
|
783
|
+
failed_chunks=len(failed),
|
|
784
|
+
sent_email_ids=[
|
|
785
|
+
item["id"]
|
|
786
|
+
for r in successful
|
|
787
|
+
if r["result"].data
|
|
788
|
+
for item in r["result"].data
|
|
789
|
+
],
|
|
790
|
+
errors=[
|
|
791
|
+
{"chunk_index": r["chunk_index"], "error": r["result"].error}
|
|
792
|
+
for r in failed
|
|
793
|
+
]
|
|
794
|
+
)
|
|
795
|
+
|
|
796
|
+
# Usage
|
|
797
|
+
service = BatchEmailService()
|
|
798
|
+
|
|
799
|
+
# Simple batch
|
|
800
|
+
result = service.send([
|
|
801
|
+
{"from": "Acme <noreply@acme.com>", "to": ["delivered@resend.dev"], "subject": "Hello", "html": "<p>Hi</p>"},
|
|
802
|
+
{"from": "Acme <noreply@acme.com>", "to": ["delivered@resend.dev"], "subject": "Hello", "html": "<p>Hi</p>"},
|
|
803
|
+
], idempotency_key=f"welcome-batch/{batch_id}")
|
|
804
|
+
|
|
805
|
+
# Large batch (auto-chunked)
|
|
806
|
+
large_result = service.send_large(emails, f"campaign-{campaign_id}")
|
|
807
|
+
```
|