devstack 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/README.md +253 -0
- package/bin/audit-template-deps.ts +267 -0
- package/bin/cli.ts +5 -0
- package/bin/validate-tanstack-scaffold.ts +67 -0
- package/package.json +85 -0
- package/src/builders/index.ts +1 -0
- package/src/builders/separated.ts +1 -0
- package/src/builders/shared.ts +608 -0
- package/src/builders/tanstack-start.ts +2683 -0
- package/src/builders/types.ts +10 -0
- package/src/cli.ts +106 -0
- package/src/generator.ts +2946 -0
- package/src/index.ts +23 -0
- package/src/modules/auth.ts +33 -0
- package/src/modules/email.ts +38 -0
- package/src/modules/index.ts +30 -0
- package/src/modules/inngest.ts +58 -0
- package/src/modules/observability.ts +30 -0
- package/src/modules/organizations.ts +23 -0
- package/src/modules/redis.ts +35 -0
- package/src/modules/storage.ts +39 -0
- package/src/modules/storybook.ts +33 -0
- package/src/modules/stripe.ts +39 -0
- package/src/modules/types.ts +368 -0
- package/src/utils/files.ts +198 -0
- package/src/utils/packages.ts +59 -0
- package/src/utils/template-dependency-audit.ts +218 -0
- package/src/utils/template.ts +31 -0
- package/templates/base/backend/drizzle.config.ts +12 -0
- package/templates/base/backend/src/app.ts +65 -0
- package/templates/base/backend/src/db/index.ts +10 -0
- package/templates/base/backend/src/db/schema/index.ts +2 -0
- package/templates/base/backend/src/db/schema/items.ts +18 -0
- package/templates/base/backend/src/env.ts +78 -0
- package/templates/base/backend/src/index.ts +23 -0
- package/templates/base/backend/src/lib/errors.ts +205 -0
- package/templates/base/backend/src/lib/id.ts +5 -0
- package/templates/base/backend/src/lib/lazy.ts +14 -0
- package/templates/base/backend/src/lib/logger.ts +168 -0
- package/templates/base/backend/src/lib/openapi-schemas.ts +123 -0
- package/templates/base/backend/src/lib/openapi.ts +113 -0
- package/templates/base/backend/src/lib/pagination.ts +75 -0
- package/templates/base/backend/src/lib/response.ts +23 -0
- package/templates/base/backend/src/modules/items/index.ts +1 -0
- package/templates/base/backend/src/modules/items/model.ts +26 -0
- package/templates/base/backend/src/modules/items/repository.ts +30 -0
- package/templates/base/backend/src/modules/items/route.ts +93 -0
- package/templates/base/backend/src/modules/items/usecases.ts +67 -0
- package/templates/base/backend/src/plugins/error.ts +40 -0
- package/templates/base/backend/src/plugins/index.ts +7 -0
- package/templates/base/backend/src/plugins/logging.ts +20 -0
- package/templates/base/backend/src/plugins/metrics.ts +155 -0
- package/templates/base/backend/src/plugins/openapi.ts +17 -0
- package/templates/base/backend/src/plugins/request-id.ts +35 -0
- package/templates/base/backend/src/routes/health.ts +72 -0
- package/templates/base/backend/src/test-setup.ts +36 -0
- package/templates/base/backend/src/test-utils/db.ts +212 -0
- package/templates/base/backend/src/test-utils/factories.ts +16 -0
- package/templates/base/backend/src/test-utils/index.ts +3 -0
- package/templates/base/backend/src/test-utils/request.ts +72 -0
- package/templates/base/backend/src/types/index.ts +1 -0
- package/templates/base/backend/tsconfig.json +21 -0
- package/templates/base/backend/vitest.config.ts +26 -0
- package/templates/base/claude/skills/agent-browser/SKILL.md +629 -0
- package/templates/base/claude/skills/agent-browser/references/authentication.md +306 -0
- package/templates/base/claude/skills/agent-browser/references/commands.md +264 -0
- package/templates/base/claude/skills/agent-browser/references/profiling.md +120 -0
- package/templates/base/claude/skills/agent-browser/references/proxy-support.md +194 -0
- package/templates/base/claude/skills/agent-browser/references/session-management.md +194 -0
- package/templates/base/claude/skills/agent-browser/references/snapshot-refs.md +196 -0
- package/templates/base/claude/skills/agent-browser/references/video-recording.md +173 -0
- package/templates/base/claude/skills/agent-browser/templates/authenticated-session.sh +105 -0
- package/templates/base/claude/skills/agent-browser/templates/capture-workflow.sh +69 -0
- package/templates/base/claude/skills/agent-browser/templates/form-automation.sh +62 -0
- package/templates/base/claude/skills/alpine-js/SKILL.md +107 -0
- package/templates/base/claude/skills/better-auth-best-practices/SKILL.md +183 -0
- package/templates/base/claude/skills/es-toolkit/SKILL.md +281 -0
- package/templates/base/claude/skills/es-toolkit/references/api-catalog.md +234 -0
- package/templates/base/claude/skills/es-toolkit/references/lodash-migration.md +131 -0
- package/templates/base/claude/skills/hono/SKILL.md +90 -0
- package/templates/base/claude/skills/organization-best-practices/SKILL.md +478 -0
- package/templates/base/claude/skills/stripe-best-practices/SKILL.md +30 -0
- package/templates/base/claude/skills/stripe-integration/SKILL.md +492 -0
- package/templates/base/claude/skills/stripe-subscriptions/SKILL.md +54 -0
- package/templates/base/claude/skills/stripe-webhooks/SKILL.md +163 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/express/.env.example +5 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/express/README.md +64 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/express/package.json +19 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/express/src/index.js +75 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/express/test/webhook.test.js +129 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/fastapi/.env.example +5 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/fastapi/README.md +69 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/fastapi/main.py +75 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/fastapi/requirements.txt +6 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/fastapi/test_webhook.py +121 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/nextjs/.env.example +5 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/nextjs/README.md +62 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/nextjs/app/webhooks/stripe/route.ts +63 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/nextjs/package.json +23 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/nextjs/test/webhook.test.ts +139 -0
- package/templates/base/claude/skills/stripe-webhooks/examples/nextjs/vitest.config.ts +8 -0
- package/templates/base/claude/skills/stripe-webhooks/references/overview.md +62 -0
- package/templates/base/claude/skills/stripe-webhooks/references/setup.md +99 -0
- package/templates/base/claude/skills/stripe-webhooks/references/verification.md +154 -0
- package/templates/base/claude/skills/svelte-code-writer/SKILL.md +66 -0
- package/templates/base/claude/skills/zod/AGENTS.md +97 -0
- package/templates/base/claude/skills/zod/README.md +79 -0
- package/templates/base/claude/skills/zod/SKILL.md +128 -0
- package/templates/base/claude/skills/zod/references/compose-intersection.md +143 -0
- package/templates/base/claude/skills/zod/references/compose-lazy-recursive.md +138 -0
- package/templates/base/claude/skills/zod/references/compose-pipe.md +114 -0
- package/templates/base/claude/skills/zod/references/compose-preprocess.md +131 -0
- package/templates/base/claude/skills/zod/references/compose-shared-schemas.md +142 -0
- package/templates/base/claude/skills/zod/references/error-avoid-throwing-in-refine.md +134 -0
- package/templates/base/claude/skills/zod/references/error-custom-messages.md +127 -0
- package/templates/base/claude/skills/zod/references/error-i18n.md +140 -0
- package/templates/base/claude/skills/zod/references/error-path-for-nested.md +135 -0
- package/templates/base/claude/skills/zod/references/error-use-flatten.md +135 -0
- package/templates/base/claude/skills/zod/references/object-discriminated-unions.md +136 -0
- package/templates/base/claude/skills/zod/references/object-extend-for-composition.md +146 -0
- package/templates/base/claude/skills/zod/references/object-optional-vs-nullable.md +120 -0
- package/templates/base/claude/skills/zod/references/object-partial-for-updates.md +124 -0
- package/templates/base/claude/skills/zod/references/object-pick-omit.md +147 -0
- package/templates/base/claude/skills/zod/references/object-strict-vs-strip.md +122 -0
- package/templates/base/claude/skills/zod/references/parse-async-for-async-refinements.md +127 -0
- package/templates/base/claude/skills/zod/references/parse-avoid-double-validation.md +130 -0
- package/templates/base/claude/skills/zod/references/parse-handle-all-issues.md +126 -0
- package/templates/base/claude/skills/zod/references/parse-never-trust-json.md +116 -0
- package/templates/base/claude/skills/zod/references/parse-use-safeparse.md +103 -0
- package/templates/base/claude/skills/zod/references/parse-validate-early.md +125 -0
- package/templates/base/claude/skills/zod/references/perf-arrays.md +154 -0
- package/templates/base/claude/skills/zod/references/perf-avoid-dynamic-creation.md +142 -0
- package/templates/base/claude/skills/zod/references/perf-cache-schemas.md +143 -0
- package/templates/base/claude/skills/zod/references/perf-lazy-loading.md +136 -0
- package/templates/base/claude/skills/zod/references/perf-zod-mini.md +118 -0
- package/templates/base/claude/skills/zod/references/refine-add-path.md +149 -0
- package/templates/base/claude/skills/zod/references/refine-catch.md +138 -0
- package/templates/base/claude/skills/zod/references/refine-defaults.md +132 -0
- package/templates/base/claude/skills/zod/references/refine-transform-coerce.md +103 -0
- package/templates/base/claude/skills/zod/references/refine-vs-superrefine.md +159 -0
- package/templates/base/claude/skills/zod/references/schema-avoid-optional-abuse.md +94 -0
- package/templates/base/claude/skills/zod/references/schema-coercion-for-form-data.md +89 -0
- package/templates/base/claude/skills/zod/references/schema-string-validations.md +87 -0
- package/templates/base/claude/skills/zod/references/schema-use-enums.md +106 -0
- package/templates/base/claude/skills/zod/references/schema-use-primitives-correctly.md +63 -0
- package/templates/base/claude/skills/zod/references/schema-use-unknown-not-any.md +86 -0
- package/templates/base/claude/skills/zod/references/type-branded-types.md +106 -0
- package/templates/base/claude/skills/zod/references/type-enable-strict-mode.md +132 -0
- package/templates/base/claude/skills/zod/references/type-export-schemas-and-types.md +117 -0
- package/templates/base/claude/skills/zod/references/type-input-vs-output.md +116 -0
- package/templates/base/claude/skills/zod/references/type-use-z-infer.md +113 -0
- package/templates/base/frontend/components.json +25 -0
- package/templates/base/frontend/index.html +17 -0
- package/templates/base/frontend/src/App.test.tsx +13 -0
- package/templates/base/frontend/src/App.tsx +11 -0
- package/templates/base/frontend/src/components/app-sidebar.tsx +89 -0
- package/templates/base/frontend/src/components/app-topbar.tsx +28 -0
- package/templates/base/frontend/src/components/nav-secondary.tsx +38 -0
- package/templates/base/frontend/src/components/nav-user.tsx +93 -0
- package/templates/base/frontend/src/components/theme-toggle.tsx +29 -0
- package/templates/base/frontend/src/components/ui/accordion.tsx +72 -0
- package/templates/base/frontend/src/components/ui/alert-dialog.tsx +160 -0
- package/templates/base/frontend/src/components/ui/alert.tsx +69 -0
- package/templates/base/frontend/src/components/ui/aspect-ratio.tsx +22 -0
- package/templates/base/frontend/src/components/ui/avatar.tsx +91 -0
- package/templates/base/frontend/src/components/ui/badge.tsx +50 -0
- package/templates/base/frontend/src/components/ui/banner.tsx +34 -0
- package/templates/base/frontend/src/components/ui/breadcrumb.tsx +103 -0
- package/templates/base/frontend/src/components/ui/button-group.tsx +78 -0
- package/templates/base/frontend/src/components/ui/button.tsx +61 -0
- package/templates/base/frontend/src/components/ui/calendar.tsx +185 -0
- package/templates/base/frontend/src/components/ui/card.tsx +92 -0
- package/templates/base/frontend/src/components/ui/carousel.tsx +229 -0
- package/templates/base/frontend/src/components/ui/chart.tsx +323 -0
- package/templates/base/frontend/src/components/ui/checkbox.tsx +28 -0
- package/templates/base/frontend/src/components/ui/collapsible.tsx +15 -0
- package/templates/base/frontend/src/components/ui/combobox.tsx +273 -0
- package/templates/base/frontend/src/components/ui/command.tsx +179 -0
- package/templates/base/frontend/src/components/ui/context-menu.tsx +245 -0
- package/templates/base/frontend/src/components/ui/dialog.tsx +138 -0
- package/templates/base/frontend/src/components/ui/direction.tsx +1 -0
- package/templates/base/frontend/src/components/ui/drawer.tsx +118 -0
- package/templates/base/frontend/src/components/ui/dropdown-menu.tsx +258 -0
- package/templates/base/frontend/src/components/ui/empty.tsx +94 -0
- package/templates/base/frontend/src/components/ui/field.tsx +224 -0
- package/templates/base/frontend/src/components/ui/hover-card.tsx +44 -0
- package/templates/base/frontend/src/components/ui/input-group.tsx +146 -0
- package/templates/base/frontend/src/components/ui/input-otp.tsx +86 -0
- package/templates/base/frontend/src/components/ui/input.tsx +20 -0
- package/templates/base/frontend/src/components/ui/item.tsx +188 -0
- package/templates/base/frontend/src/components/ui/kbd.tsx +26 -0
- package/templates/base/frontend/src/components/ui/label.tsx +20 -0
- package/templates/base/frontend/src/components/ui/menubar.tsx +265 -0
- package/templates/base/frontend/src/components/ui/native-select.tsx +43 -0
- package/templates/base/frontend/src/components/ui/navigation-menu.tsx +161 -0
- package/templates/base/frontend/src/components/ui/pagination.tsx +118 -0
- package/templates/base/frontend/src/components/ui/popover.tsx +77 -0
- package/templates/base/frontend/src/components/ui/progress.tsx +64 -0
- package/templates/base/frontend/src/components/ui/radio-group.tsx +38 -0
- package/templates/base/frontend/src/components/ui/resizable.tsx +40 -0
- package/templates/base/frontend/src/components/ui/scroll-area.tsx +50 -0
- package/templates/base/frontend/src/components/ui/select.tsx +188 -0
- package/templates/base/frontend/src/components/ui/separator.tsx +19 -0
- package/templates/base/frontend/src/components/ui/sheet.tsx +123 -0
- package/templates/base/frontend/src/components/ui/sidebar.tsx +694 -0
- package/templates/base/frontend/src/components/ui/skeleton.tsx +13 -0
- package/templates/base/frontend/src/components/ui/slider.tsx +52 -0
- package/templates/base/frontend/src/components/ui/sonner.tsx +43 -0
- package/templates/base/frontend/src/components/ui/spinner.tsx +15 -0
- package/templates/base/frontend/src/components/ui/surface.tsx +15 -0
- package/templates/base/frontend/src/components/ui/switch.tsx +30 -0
- package/templates/base/frontend/src/components/ui/table.tsx +98 -0
- package/templates/base/frontend/src/components/ui/tabs.tsx +75 -0
- package/templates/base/frontend/src/components/ui/textarea.tsx +18 -0
- package/templates/base/frontend/src/components/ui/toggle-group.tsx +87 -0
- package/templates/base/frontend/src/components/ui/toggle.tsx +42 -0
- package/templates/base/frontend/src/components/ui/tooltip.tsx +54 -0
- package/templates/base/frontend/src/hooks/use-mobile.ts +19 -0
- package/templates/base/frontend/src/integrations/tanstack-query/devtools.tsx +6 -0
- package/templates/base/frontend/src/integrations/tanstack-query/root-provider.tsx +18 -0
- package/templates/base/frontend/src/lib/utils.ts +6 -0
- package/templates/base/frontend/src/main.tsx +39 -0
- package/templates/base/frontend/src/routeTree.gen.ts +102 -0
- package/templates/base/frontend/src/routes/__root.tsx +16 -0
- package/templates/base/frontend/src/routes/_app/index.tsx +122 -0
- package/templates/base/frontend/src/routes/_app/settings.tsx +137 -0
- package/templates/base/frontend/src/routes/_app.tsx +19 -0
- package/templates/base/frontend/src/stores/use-theme-store.ts +92 -0
- package/templates/base/frontend/src/styles.css +146 -0
- package/templates/base/frontend/src/test-setup.ts +24 -0
- package/templates/base/frontend/tsconfig.json +27 -0
- package/templates/base/frontend/vite.config.ts +30 -0
- package/templates/base/frontend/vitest.config.ts +20 -0
- package/templates/base/root/.editorconfig +35 -0
- package/templates/base/root/.github/actions/setup-bun/action.yml +48 -0
- package/templates/base/root/.github/workflows/ci.yaml +66 -0
- package/templates/base/root/.husky/commit-msg +4 -0
- package/templates/base/root/.husky/pre-commit +4 -0
- package/templates/base/root/.nvmrc +2 -0
- package/templates/base/root/.oxfmtrc.json +33 -0
- package/templates/base/root/.oxlintrc.json +179 -0
- package/templates/base/root/CLAUDE.md +40 -0
- package/templates/base/root/Makefile +57 -0
- package/templates/base/root/commitlint.config.ts +3 -0
- package/templates/base/root/docker/postgres/init-test-db.sh +12 -0
- package/templates/base/root/lint-plugins/react-component-complexity.mjs +282 -0
- package/templates/base/root/lint-plugins/react-hooks-separation-codemod.mjs +1078 -0
- package/templates/base/root/lint-plugins/react-hooks-separation.mjs +243 -0
- package/templates/base/root/lint-plugins/test-file-location.mjs +104 -0
- package/templates/base/root/tsconfig.base.json +15 -0
- package/templates/base/root/tsconfig.json +16 -0
- package/templates/modules/auth/packages/backend/src/db/schema/auth.ts +145 -0
- package/templates/modules/auth/packages/backend/src/lib/auth/auth-context.ts +28 -0
- package/templates/modules/auth/packages/backend/src/lib/auth/auth.ts +97 -0
- package/templates/modules/auth/packages/backend/src/plugins/auth.ts +82 -0
- package/templates/modules/auth/src/db/schema/auth.ts +87 -0
- package/templates/modules/auth/src/lib/auth/auth-context.ts +23 -0
- package/templates/modules/auth/src/lib/auth/auth.ts +53 -0
- package/templates/modules/auth/src/lib/auth/index.ts +2 -0
- package/templates/modules/auth/src/plugins/auth.ts +52 -0
- package/templates/modules/email/packages/backend/src/lib/emails/send.tsx +58 -0
- package/templates/modules/email/packages/backend/src/lib/emails/templates/base.tsx +26 -0
- package/templates/modules/email/src/lib/emails/index.ts +1 -0
- package/templates/modules/email/src/lib/emails/send.ts +63 -0
- package/templates/modules/email/src/lib/emails/templates/layout.tsx +34 -0
- package/templates/modules/email/src/lib/integrations/resend.ts +10 -0
- package/templates/modules/inngest/packages/backend/src/jobs/example.ts +12 -0
- package/templates/modules/inngest/packages/backend/src/jobs/index.ts +3 -0
- package/templates/modules/inngest/packages/backend/src/lib/inngest.ts +39 -0
- package/templates/modules/inngest/src/jobs/example.ts +12 -0
- package/templates/modules/inngest/src/jobs/index.ts +3 -0
- package/templates/modules/inngest/src/lib/inngest.ts +28 -0
- package/templates/modules/observability/packages/backend/src/lib/sentry.ts +25 -0
- package/templates/modules/observability/packages/backend/src/lib/tracing.ts +125 -0
- package/templates/modules/observability/src/lib/sentry.ts +20 -0
- package/templates/modules/observability/src/lib/tracing.ts +77 -0
- package/templates/modules/organizations/packages/backend/src/lib/auth/org-context.ts +33 -0
- package/templates/modules/organizations/packages/backend/src/lib/auth/permissions.ts +43 -0
- package/templates/modules/organizations/src/db/schema/auth.ts +147 -0
- package/templates/modules/organizations/src/lib/auth/auth.ts +90 -0
- package/templates/modules/organizations/src/lib/auth/org-context.ts +33 -0
- package/templates/modules/organizations/src/lib/auth/permissions.ts +47 -0
- package/templates/modules/organizations/src/plugins/auth.ts +68 -0
- package/templates/modules/redis/packages/backend/src/lib/redis.ts +65 -0
- package/templates/modules/redis/packages/backend/src/plugins/rate-limiter.ts +51 -0
- package/templates/modules/redis/src/lib/redis.ts +30 -0
- package/templates/modules/redis/src/plugins/rate-limiter.ts +60 -0
- package/templates/modules/storage/packages/backend/src/lib/storage/client.ts +64 -0
- package/templates/modules/storage/packages/backend/src/lib/storage/index.ts +2 -0
- package/templates/modules/storage/packages/backend/src/lib/storage/init.ts +30 -0
- package/templates/modules/storage/src/lib/storage/client.ts +42 -0
- package/templates/modules/storage/src/lib/storage/index.ts +1 -0
- package/templates/modules/storybook/packages/frontend/.storybook/main.ts +17 -0
- package/templates/modules/storybook/packages/frontend/.storybook/preview.tsx +17 -0
- package/templates/modules/storybook/packages/frontend/src/components/ui/button.stories.tsx +17 -0
- package/templates/modules/stripe/packages/backend/src/db/schema/billing.ts +102 -0
- package/templates/modules/stripe/packages/backend/src/lib/billing.ts +31 -0
- package/templates/modules/stripe/packages/backend/src/lib/integrations/stripe.ts +52 -0
- package/templates/modules/stripe/packages/backend/src/modules/billing/index.ts +1 -0
- package/templates/modules/stripe/packages/backend/src/modules/billing/model.ts +45 -0
- package/templates/modules/stripe/packages/backend/src/modules/billing/repository.ts +87 -0
- package/templates/modules/stripe/packages/backend/src/modules/billing/route.ts +42 -0
- package/templates/modules/stripe/packages/backend/src/modules/billing/usecases.ts +97 -0
- package/templates/modules/stripe/packages/backend/src/routes/webhooks.ts +25 -0
- package/templates/modules/stripe/src/db/schema/billing.ts +90 -0
- package/templates/modules/stripe/src/lib/billing.ts +33 -0
- package/templates/modules/stripe/src/lib/integrations/stripe.ts +46 -0
- package/templates/modules/stripe/src/modules/billing/index.ts +1 -0
- package/templates/modules/stripe/src/modules/billing/model.ts +55 -0
- package/templates/modules/stripe/src/modules/billing/repository.ts +48 -0
- package/templates/modules/stripe/src/modules/billing/route.ts +97 -0
- package/templates/modules/stripe/src/modules/billing/usecases.ts +92 -0
- package/templates/modules/stripe/src/routes/webhooks.ts +57 -0
- package/vendor/skills/README.md +244 -0
- package/vendor/skills/skills/a11y-testing/SKILL.md +169 -0
- package/vendor/skills/skills/a11y-testing/checklists/a11y-testing-checklist.md +298 -0
- package/vendor/skills/skills/a11y-testing/examples/a11y-testing-examples.md +615 -0
- package/vendor/skills/skills/a11y-testing/references/a11y-testing-tools.md +383 -0
- package/vendor/skills/skills/a11y-testing/templates/a11y-test-template.ts +470 -0
- package/vendor/skills/skills/adversarial-review/SKILL.md +140 -0
- package/vendor/skills/skills/adversarial-review/references/reviewer-lenses.md +38 -0
- package/vendor/skills/skills/agent-browser/SKILL.md +151 -0
- package/vendor/skills/skills/agent-identifier/SKILL.md +438 -0
- package/vendor/skills/skills/agent-identifier/examples/agent-creation-prompt.md +250 -0
- package/vendor/skills/skills/agent-identifier/examples/complete-agent-examples.md +458 -0
- package/vendor/skills/skills/agent-identifier/references/agent-creation-system-prompt.md +216 -0
- package/vendor/skills/skills/agent-identifier/references/system-prompt-design.md +464 -0
- package/vendor/skills/skills/agent-identifier/references/triggering-examples.md +508 -0
- package/vendor/skills/skills/agent-identifier/scripts/validate-agent.sh +217 -0
- package/vendor/skills/skills/agent-md-refactor/README.md +234 -0
- package/vendor/skills/skills/agent-md-refactor/SKILL.md +309 -0
- package/vendor/skills/skills/ai-pdf-builder/README.md +40 -0
- package/vendor/skills/skills/ai-pdf-builder/SKILL.md +210 -0
- package/vendor/skills/skills/ai-pdf-builder/_meta.json +22 -0
- package/vendor/skills/skills/ai-sdk/SKILL.md +53 -0
- package/vendor/skills/skills/ai-sdk/references/ai-gateway.md +41 -0
- package/vendor/skills/skills/ai-sdk/references/common-errors.md +167 -0
- package/vendor/skills/skills/alex-hormozi-pitch/SKILL.md +69 -0
- package/vendor/skills/skills/alex-hormozi-pitch/metadata.json +14 -0
- package/vendor/skills/skills/app-renderer-systems/SKILL.md +177 -0
- package/vendor/skills/skills/app-renderer-systems/references/directory-layout.md +120 -0
- package/vendor/skills/skills/app-renderer-systems/references/patterns.md +509 -0
- package/vendor/skills/skills/architectural-analysis/SKILL.md +720 -0
- package/vendor/skills/skills/argocd-expert/SKILL.md +767 -0
- package/vendor/skills/skills/bencium-innovative-ux-designer/ACCESSIBILITY.md +112 -0
- package/vendor/skills/skills/bencium-innovative-ux-designer/DESIGN-SYSTEM-TEMPLATE.md +631 -0
- package/vendor/skills/skills/bencium-innovative-ux-designer/MOTION-SPEC.md +74 -0
- package/vendor/skills/skills/bencium-innovative-ux-designer/RESPONSIVE-DESIGN.md +95 -0
- package/vendor/skills/skills/bencium-innovative-ux-designer/SKILL.md +772 -0
- package/vendor/skills/skills/better-auth-best-practices/SKILL.md +174 -0
- package/vendor/skills/skills/brainstorming/SKILL.md +101 -0
- package/vendor/skills/skills/brand-storytelling/SKILL.md +86 -0
- package/vendor/skills/skills/brand-storytelling/references/guest-insights.md +722 -0
- package/vendor/skills/skills/building-components/SKILL.md +37 -0
- package/vendor/skills/skills/building-components/references/accessibility.mdx +794 -0
- package/vendor/skills/skills/building-components/references/as-child.mdx +318 -0
- package/vendor/skills/skills/building-components/references/composition.mdx +229 -0
- package/vendor/skills/skills/building-components/references/data-attributes.mdx +409 -0
- package/vendor/skills/skills/building-components/references/definitions.mdx +256 -0
- package/vendor/skills/skills/building-components/references/design-tokens.mdx +57 -0
- package/vendor/skills/skills/building-components/references/docs.mdx +153 -0
- package/vendor/skills/skills/building-components/references/marketplaces.mdx +144 -0
- package/vendor/skills/skills/building-components/references/npm.mdx +166 -0
- package/vendor/skills/skills/building-components/references/polymorphism.mdx +576 -0
- package/vendor/skills/skills/building-components/references/principles.mdx +61 -0
- package/vendor/skills/skills/building-components/references/registry.mdx +169 -0
- package/vendor/skills/skills/building-components/references/state.mdx +95 -0
- package/vendor/skills/skills/building-components/references/styling.mdx +271 -0
- package/vendor/skills/skills/building-components/references/types.mdx +189 -0
- package/vendor/skills/skills/centrifugo/SKILL.md +362 -0
- package/vendor/skills/skills/centrifugo/references/authentication.md +187 -0
- package/vendor/skills/skills/centrifugo/references/channels.md +172 -0
- package/vendor/skills/skills/centrifugo/references/client-sdk.md +242 -0
- package/vendor/skills/skills/centrifugo/references/configuration.md +201 -0
- package/vendor/skills/skills/centrifugo/references/engines.md +203 -0
- package/vendor/skills/skills/centrifugo/references/proxy.md +301 -0
- package/vendor/skills/skills/centrifugo/references/server-api.md +209 -0
- package/vendor/skills/skills/cloudflare/SKILL.md +238 -0
- package/vendor/skills/skills/cloudflare/references/agents-sdk/README.md +95 -0
- package/vendor/skills/skills/cloudflare/references/agents-sdk/api.md +195 -0
- package/vendor/skills/skills/cloudflare/references/agents-sdk/configuration.md +178 -0
- package/vendor/skills/skills/cloudflare/references/agents-sdk/gotchas.md +173 -0
- package/vendor/skills/skills/cloudflare/references/agents-sdk/patterns.md +215 -0
- package/vendor/skills/skills/cloudflare/references/ai-gateway/README.md +176 -0
- package/vendor/skills/skills/cloudflare/references/ai-gateway/configuration.md +117 -0
- package/vendor/skills/skills/cloudflare/references/ai-gateway/dynamic-routing.md +88 -0
- package/vendor/skills/skills/cloudflare/references/ai-gateway/features.md +96 -0
- package/vendor/skills/skills/cloudflare/references/ai-gateway/sdk-integration.md +110 -0
- package/vendor/skills/skills/cloudflare/references/ai-gateway/troubleshooting.md +90 -0
- package/vendor/skills/skills/cloudflare/references/ai-search/README.md +145 -0
- package/vendor/skills/skills/cloudflare/references/ai-search/api.md +87 -0
- package/vendor/skills/skills/cloudflare/references/ai-search/configuration.md +91 -0
- package/vendor/skills/skills/cloudflare/references/ai-search/gotchas.md +92 -0
- package/vendor/skills/skills/cloudflare/references/ai-search/patterns.md +87 -0
- package/vendor/skills/skills/cloudflare/references/analytics-engine/README.md +96 -0
- package/vendor/skills/skills/cloudflare/references/analytics-engine/api.md +112 -0
- package/vendor/skills/skills/cloudflare/references/analytics-engine/configuration.md +107 -0
- package/vendor/skills/skills/cloudflare/references/analytics-engine/gotchas.md +87 -0
- package/vendor/skills/skills/cloudflare/references/analytics-engine/patterns.md +83 -0
- package/vendor/skills/skills/cloudflare/references/api/README.md +66 -0
- package/vendor/skills/skills/cloudflare/references/api/api.md +205 -0
- package/vendor/skills/skills/cloudflare/references/api/configuration.md +158 -0
- package/vendor/skills/skills/cloudflare/references/api/gotchas.md +231 -0
- package/vendor/skills/skills/cloudflare/references/api/patterns.md +208 -0
- package/vendor/skills/skills/cloudflare/references/api-shield/README.md +44 -0
- package/vendor/skills/skills/cloudflare/references/api-shield/api.md +153 -0
- package/vendor/skills/skills/cloudflare/references/api-shield/configuration.md +210 -0
- package/vendor/skills/skills/cloudflare/references/api-shield/gotchas.md +132 -0
- package/vendor/skills/skills/cloudflare/references/api-shield/patterns.md +185 -0
- package/vendor/skills/skills/cloudflare/references/argo-smart-routing/README.md +96 -0
- package/vendor/skills/skills/cloudflare/references/argo-smart-routing/api.md +253 -0
- package/vendor/skills/skills/cloudflare/references/argo-smart-routing/configuration.md +205 -0
- package/vendor/skills/skills/cloudflare/references/argo-smart-routing/gotchas.md +115 -0
- package/vendor/skills/skills/cloudflare/references/argo-smart-routing/patterns.md +107 -0
- package/vendor/skills/skills/cloudflare/references/bindings/README.md +127 -0
- package/vendor/skills/skills/cloudflare/references/bindings/api.md +214 -0
- package/vendor/skills/skills/cloudflare/references/bindings/configuration.md +200 -0
- package/vendor/skills/skills/cloudflare/references/bindings/gotchas.md +210 -0
- package/vendor/skills/skills/cloudflare/references/bindings/patterns.md +205 -0
- package/vendor/skills/skills/cloudflare/references/bot-management/README.md +95 -0
- package/vendor/skills/skills/cloudflare/references/bot-management/api.md +175 -0
- package/vendor/skills/skills/cloudflare/references/bot-management/configuration.md +175 -0
- package/vendor/skills/skills/cloudflare/references/bot-management/gotchas.md +116 -0
- package/vendor/skills/skills/cloudflare/references/bot-management/patterns.md +181 -0
- package/vendor/skills/skills/cloudflare/references/browser-rendering/README.md +84 -0
- package/vendor/skills/skills/cloudflare/references/browser-rendering/api.md +108 -0
- package/vendor/skills/skills/cloudflare/references/browser-rendering/configuration.md +78 -0
- package/vendor/skills/skills/cloudflare/references/browser-rendering/gotchas.md +91 -0
- package/vendor/skills/skills/cloudflare/references/browser-rendering/patterns.md +94 -0
- package/vendor/skills/skills/cloudflare/references/c3/README.md +111 -0
- package/vendor/skills/skills/cloudflare/references/c3/api.md +71 -0
- package/vendor/skills/skills/cloudflare/references/c3/configuration.md +85 -0
- package/vendor/skills/skills/cloudflare/references/c3/gotchas.md +97 -0
- package/vendor/skills/skills/cloudflare/references/c3/patterns.md +84 -0
- package/vendor/skills/skills/cloudflare/references/cache-reserve/README.md +150 -0
- package/vendor/skills/skills/cloudflare/references/cache-reserve/api.md +184 -0
- package/vendor/skills/skills/cloudflare/references/cache-reserve/configuration.md +170 -0
- package/vendor/skills/skills/cloudflare/references/cache-reserve/gotchas.md +136 -0
- package/vendor/skills/skills/cloudflare/references/cache-reserve/patterns.md +197 -0
- package/vendor/skills/skills/cloudflare/references/containers/README.md +87 -0
- package/vendor/skills/skills/cloudflare/references/containers/api.md +197 -0
- package/vendor/skills/skills/cloudflare/references/containers/configuration.md +191 -0
- package/vendor/skills/skills/cloudflare/references/containers/gotchas.md +182 -0
- package/vendor/skills/skills/cloudflare/references/containers/patterns.md +204 -0
- package/vendor/skills/skills/cloudflare/references/cron-triggers/README.md +101 -0
- package/vendor/skills/skills/cloudflare/references/cron-triggers/api.md +224 -0
- package/vendor/skills/skills/cloudflare/references/cron-triggers/configuration.md +190 -0
- package/vendor/skills/skills/cloudflare/references/cron-triggers/gotchas.md +207 -0
- package/vendor/skills/skills/cloudflare/references/cron-triggers/patterns.md +277 -0
- package/vendor/skills/skills/cloudflare/references/d1/README.md +137 -0
- package/vendor/skills/skills/cloudflare/references/d1/api.md +213 -0
- package/vendor/skills/skills/cloudflare/references/d1/configuration.md +198 -0
- package/vendor/skills/skills/cloudflare/references/d1/gotchas.md +98 -0
- package/vendor/skills/skills/cloudflare/references/d1/patterns.md +242 -0
- package/vendor/skills/skills/cloudflare/references/ddos/README.md +42 -0
- package/vendor/skills/skills/cloudflare/references/ddos/api.md +158 -0
- package/vendor/skills/skills/cloudflare/references/ddos/configuration.md +94 -0
- package/vendor/skills/skills/cloudflare/references/ddos/gotchas.md +114 -0
- package/vendor/skills/skills/cloudflare/references/ddos/patterns.md +222 -0
- package/vendor/skills/skills/cloudflare/references/do-storage/README.md +79 -0
- package/vendor/skills/skills/cloudflare/references/do-storage/api.md +107 -0
- package/vendor/skills/skills/cloudflare/references/do-storage/configuration.md +114 -0
- package/vendor/skills/skills/cloudflare/references/do-storage/gotchas.md +153 -0
- package/vendor/skills/skills/cloudflare/references/do-storage/patterns.md +210 -0
- package/vendor/skills/skills/cloudflare/references/do-storage/testing.md +186 -0
- package/vendor/skills/skills/cloudflare/references/durable-objects/README.md +194 -0
- package/vendor/skills/skills/cloudflare/references/durable-objects/api.md +205 -0
- package/vendor/skills/skills/cloudflare/references/durable-objects/configuration.md +160 -0
- package/vendor/skills/skills/cloudflare/references/durable-objects/gotchas.md +200 -0
- package/vendor/skills/skills/cloudflare/references/durable-objects/patterns.md +205 -0
- package/vendor/skills/skills/cloudflare/references/email-routing/README.md +89 -0
- package/vendor/skills/skills/cloudflare/references/email-routing/api.md +192 -0
- package/vendor/skills/skills/cloudflare/references/email-routing/configuration.md +187 -0
- package/vendor/skills/skills/cloudflare/references/email-routing/gotchas.md +203 -0
- package/vendor/skills/skills/cloudflare/references/email-routing/patterns.md +241 -0
- package/vendor/skills/skills/cloudflare/references/email-workers/README.md +153 -0
- package/vendor/skills/skills/cloudflare/references/email-workers/api.md +227 -0
- package/vendor/skills/skills/cloudflare/references/email-workers/configuration.md +115 -0
- package/vendor/skills/skills/cloudflare/references/email-workers/gotchas.md +133 -0
- package/vendor/skills/skills/cloudflare/references/email-workers/patterns.md +108 -0
- package/vendor/skills/skills/cloudflare/references/graphql-api/README.md +147 -0
- package/vendor/skills/skills/cloudflare/references/graphql-api/api.md +175 -0
- package/vendor/skills/skills/cloudflare/references/graphql-api/configuration.md +151 -0
- package/vendor/skills/skills/cloudflare/references/graphql-api/gotchas.md +111 -0
- package/vendor/skills/skills/cloudflare/references/graphql-api/patterns.md +276 -0
- package/vendor/skills/skills/cloudflare/references/hyperdrive/README.md +84 -0
- package/vendor/skills/skills/cloudflare/references/hyperdrive/api.md +149 -0
- package/vendor/skills/skills/cloudflare/references/hyperdrive/configuration.md +166 -0
- package/vendor/skills/skills/cloudflare/references/hyperdrive/gotchas.md +77 -0
- package/vendor/skills/skills/cloudflare/references/hyperdrive/patterns.md +203 -0
- package/vendor/skills/skills/cloudflare/references/images/README.md +65 -0
- package/vendor/skills/skills/cloudflare/references/images/api.md +101 -0
- package/vendor/skills/skills/cloudflare/references/images/configuration.md +206 -0
- package/vendor/skills/skills/cloudflare/references/images/gotchas.md +106 -0
- package/vendor/skills/skills/cloudflare/references/images/patterns.md +126 -0
- package/vendor/skills/skills/cloudflare/references/kv/README.md +90 -0
- package/vendor/skills/skills/cloudflare/references/kv/api.md +163 -0
- package/vendor/skills/skills/cloudflare/references/kv/configuration.md +148 -0
- package/vendor/skills/skills/cloudflare/references/kv/gotchas.md +133 -0
- package/vendor/skills/skills/cloudflare/references/kv/patterns.md +195 -0
- package/vendor/skills/skills/cloudflare/references/miniflare/README.md +113 -0
- package/vendor/skills/skills/cloudflare/references/miniflare/api.md +204 -0
- package/vendor/skills/skills/cloudflare/references/miniflare/configuration.md +174 -0
- package/vendor/skills/skills/cloudflare/references/miniflare/gotchas.md +179 -0
- package/vendor/skills/skills/cloudflare/references/miniflare/patterns.md +187 -0
- package/vendor/skills/skills/cloudflare/references/network-interconnect/README.md +104 -0
- package/vendor/skills/skills/cloudflare/references/network-interconnect/api.md +220 -0
- package/vendor/skills/skills/cloudflare/references/network-interconnect/configuration.md +123 -0
- package/vendor/skills/skills/cloudflare/references/network-interconnect/gotchas.md +175 -0
- package/vendor/skills/skills/cloudflare/references/network-interconnect/patterns.md +174 -0
- package/vendor/skills/skills/cloudflare/references/observability/README.md +93 -0
- package/vendor/skills/skills/cloudflare/references/observability/api.md +168 -0
- package/vendor/skills/skills/cloudflare/references/observability/configuration.md +178 -0
- package/vendor/skills/skills/cloudflare/references/observability/gotchas.md +125 -0
- package/vendor/skills/skills/cloudflare/references/observability/patterns.md +105 -0
- package/vendor/skills/skills/cloudflare/references/pages/README.md +92 -0
- package/vendor/skills/skills/cloudflare/references/pages/api.md +205 -0
- package/vendor/skills/skills/cloudflare/references/pages/configuration.md +216 -0
- package/vendor/skills/skills/cloudflare/references/pages/gotchas.md +218 -0
- package/vendor/skills/skills/cloudflare/references/pages/patterns.md +215 -0
- package/vendor/skills/skills/cloudflare/references/pages-functions/README.md +104 -0
- package/vendor/skills/skills/cloudflare/references/pages-functions/api.md +159 -0
- package/vendor/skills/skills/cloudflare/references/pages-functions/configuration.md +130 -0
- package/vendor/skills/skills/cloudflare/references/pages-functions/gotchas.md +102 -0
- package/vendor/skills/skills/cloudflare/references/pages-functions/patterns.md +148 -0
- package/vendor/skills/skills/cloudflare/references/pipelines/README.md +109 -0
- package/vendor/skills/skills/cloudflare/references/pipelines/api.md +214 -0
- package/vendor/skills/skills/cloudflare/references/pipelines/configuration.md +98 -0
- package/vendor/skills/skills/cloudflare/references/pipelines/gotchas.md +84 -0
- package/vendor/skills/skills/cloudflare/references/pipelines/patterns.md +87 -0
- package/vendor/skills/skills/cloudflare/references/pulumi/README.md +113 -0
- package/vendor/skills/skills/cloudflare/references/pulumi/api.md +230 -0
- package/vendor/skills/skills/cloudflare/references/pulumi/configuration.md +213 -0
- package/vendor/skills/skills/cloudflare/references/pulumi/gotchas.md +205 -0
- package/vendor/skills/skills/cloudflare/references/pulumi/patterns.md +260 -0
- package/vendor/skills/skills/cloudflare/references/queues/README.md +99 -0
- package/vendor/skills/skills/cloudflare/references/queues/api.md +211 -0
- package/vendor/skills/skills/cloudflare/references/queues/configuration.md +151 -0
- package/vendor/skills/skills/cloudflare/references/queues/gotchas.md +210 -0
- package/vendor/skills/skills/cloudflare/references/queues/patterns.md +220 -0
- package/vendor/skills/skills/cloudflare/references/r2/README.md +97 -0
- package/vendor/skills/skills/cloudflare/references/r2/api.md +235 -0
- package/vendor/skills/skills/cloudflare/references/r2/configuration.md +176 -0
- package/vendor/skills/skills/cloudflare/references/r2/gotchas.md +190 -0
- package/vendor/skills/skills/cloudflare/references/r2/patterns.md +203 -0
- package/vendor/skills/skills/cloudflare/references/r2-data-catalog/README.md +157 -0
- package/vendor/skills/skills/cloudflare/references/r2-data-catalog/api.md +199 -0
- package/vendor/skills/skills/cloudflare/references/r2-data-catalog/configuration.md +205 -0
- package/vendor/skills/skills/cloudflare/references/r2-data-catalog/gotchas.md +170 -0
- package/vendor/skills/skills/cloudflare/references/r2-data-catalog/patterns.md +191 -0
- package/vendor/skills/skills/cloudflare/references/r2-sql/README.md +138 -0
- package/vendor/skills/skills/cloudflare/references/r2-sql/SKILL.md.backup +512 -0
- package/vendor/skills/skills/cloudflare/references/r2-sql/api.md +159 -0
- package/vendor/skills/skills/cloudflare/references/r2-sql/configuration.md +152 -0
- package/vendor/skills/skills/cloudflare/references/r2-sql/gotchas.md +228 -0
- package/vendor/skills/skills/cloudflare/references/r2-sql/patterns.md +230 -0
- package/vendor/skills/skills/cloudflare/references/realtime-sfu/README.md +66 -0
- package/vendor/skills/skills/cloudflare/references/realtime-sfu/api.md +164 -0
- package/vendor/skills/skills/cloudflare/references/realtime-sfu/configuration.md +141 -0
- package/vendor/skills/skills/cloudflare/references/realtime-sfu/gotchas.md +138 -0
- package/vendor/skills/skills/cloudflare/references/realtime-sfu/patterns.md +187 -0
- package/vendor/skills/skills/cloudflare/references/realtimekit/README.md +118 -0
- package/vendor/skills/skills/cloudflare/references/realtimekit/api.md +237 -0
- package/vendor/skills/skills/cloudflare/references/realtimekit/configuration.md +226 -0
- package/vendor/skills/skills/cloudflare/references/realtimekit/gotchas.md +206 -0
- package/vendor/skills/skills/cloudflare/references/realtimekit/patterns.md +240 -0
- package/vendor/skills/skills/cloudflare/references/sandbox/README.md +104 -0
- package/vendor/skills/skills/cloudflare/references/sandbox/api.md +200 -0
- package/vendor/skills/skills/cloudflare/references/sandbox/configuration.md +154 -0
- package/vendor/skills/skills/cloudflare/references/sandbox/gotchas.md +201 -0
- package/vendor/skills/skills/cloudflare/references/sandbox/patterns.md +195 -0
- package/vendor/skills/skills/cloudflare/references/secrets-store/README.md +77 -0
- package/vendor/skills/skills/cloudflare/references/secrets-store/api.md +199 -0
- package/vendor/skills/skills/cloudflare/references/secrets-store/configuration.md +187 -0
- package/vendor/skills/skills/cloudflare/references/secrets-store/gotchas.md +97 -0
- package/vendor/skills/skills/cloudflare/references/secrets-store/patterns.md +218 -0
- package/vendor/skills/skills/cloudflare/references/smart-placement/README.md +143 -0
- package/vendor/skills/skills/cloudflare/references/smart-placement/api.md +192 -0
- package/vendor/skills/skills/cloudflare/references/smart-placement/configuration.md +202 -0
- package/vendor/skills/skills/cloudflare/references/smart-placement/gotchas.md +180 -0
- package/vendor/skills/skills/cloudflare/references/smart-placement/patterns.md +194 -0
- package/vendor/skills/skills/cloudflare/references/snippets/README.md +74 -0
- package/vendor/skills/skills/cloudflare/references/snippets/api.md +214 -0
- package/vendor/skills/skills/cloudflare/references/snippets/configuration.md +239 -0
- package/vendor/skills/skills/cloudflare/references/snippets/gotchas.md +104 -0
- package/vendor/skills/skills/cloudflare/references/snippets/patterns.md +135 -0
- package/vendor/skills/skills/cloudflare/references/spectrum/README.md +52 -0
- package/vendor/skills/skills/cloudflare/references/spectrum/api.md +184 -0
- package/vendor/skills/skills/cloudflare/references/spectrum/configuration.md +203 -0
- package/vendor/skills/skills/cloudflare/references/spectrum/gotchas.md +155 -0
- package/vendor/skills/skills/cloudflare/references/spectrum/patterns.md +206 -0
- package/vendor/skills/skills/cloudflare/references/static-assets/README.md +65 -0
- package/vendor/skills/skills/cloudflare/references/static-assets/api.md +201 -0
- package/vendor/skills/skills/cloudflare/references/static-assets/configuration.md +186 -0
- package/vendor/skills/skills/cloudflare/references/static-assets/gotchas.md +164 -0
- package/vendor/skills/skills/cloudflare/references/static-assets/patterns.md +189 -0
- package/vendor/skills/skills/cloudflare/references/stream/README.md +123 -0
- package/vendor/skills/skills/cloudflare/references/stream/api-live.md +202 -0
- package/vendor/skills/skills/cloudflare/references/stream/api.md +206 -0
- package/vendor/skills/skills/cloudflare/references/stream/configuration.md +151 -0
- package/vendor/skills/skills/cloudflare/references/stream/gotchas.md +139 -0
- package/vendor/skills/skills/cloudflare/references/stream/patterns.md +217 -0
- package/vendor/skills/skills/cloudflare/references/tail-workers/README.md +92 -0
- package/vendor/skills/skills/cloudflare/references/tail-workers/api.md +203 -0
- package/vendor/skills/skills/cloudflare/references/tail-workers/configuration.md +178 -0
- package/vendor/skills/skills/cloudflare/references/tail-workers/gotchas.md +206 -0
- package/vendor/skills/skills/cloudflare/references/tail-workers/patterns.md +190 -0
- package/vendor/skills/skills/cloudflare/references/terraform/README.md +100 -0
- package/vendor/skills/skills/cloudflare/references/terraform/api.md +178 -0
- package/vendor/skills/skills/cloudflare/references/terraform/configuration.md +197 -0
- package/vendor/skills/skills/cloudflare/references/terraform/gotchas.md +150 -0
- package/vendor/skills/skills/cloudflare/references/terraform/patterns.md +174 -0
- package/vendor/skills/skills/cloudflare/references/tunnel/README.md +137 -0
- package/vendor/skills/skills/cloudflare/references/tunnel/api.md +205 -0
- package/vendor/skills/skills/cloudflare/references/tunnel/configuration.md +163 -0
- package/vendor/skills/skills/cloudflare/references/tunnel/gotchas.md +159 -0
- package/vendor/skills/skills/cloudflare/references/tunnel/networking.md +174 -0
- package/vendor/skills/skills/cloudflare/references/tunnel/patterns.md +199 -0
- package/vendor/skills/skills/cloudflare/references/turn/README.md +86 -0
- package/vendor/skills/skills/cloudflare/references/turn/api.md +236 -0
- package/vendor/skills/skills/cloudflare/references/turn/configuration.md +181 -0
- package/vendor/skills/skills/cloudflare/references/turn/gotchas.md +236 -0
- package/vendor/skills/skills/cloudflare/references/turn/patterns.md +228 -0
- package/vendor/skills/skills/cloudflare/references/turnstile/README.md +102 -0
- package/vendor/skills/skills/cloudflare/references/turnstile/api.md +253 -0
- package/vendor/skills/skills/cloudflare/references/turnstile/configuration.md +243 -0
- package/vendor/skills/skills/cloudflare/references/turnstile/gotchas.md +253 -0
- package/vendor/skills/skills/cloudflare/references/turnstile/patterns.md +195 -0
- package/vendor/skills/skills/cloudflare/references/vectorize/README.md +133 -0
- package/vendor/skills/skills/cloudflare/references/vectorize/api.md +89 -0
- package/vendor/skills/skills/cloudflare/references/vectorize/configuration.md +91 -0
- package/vendor/skills/skills/cloudflare/references/vectorize/gotchas.md +83 -0
- package/vendor/skills/skills/cloudflare/references/vectorize/patterns.md +92 -0
- package/vendor/skills/skills/cloudflare/references/waf/README.md +125 -0
- package/vendor/skills/skills/cloudflare/references/waf/api.md +203 -0
- package/vendor/skills/skills/cloudflare/references/waf/configuration.md +215 -0
- package/vendor/skills/skills/cloudflare/references/waf/gotchas.md +208 -0
- package/vendor/skills/skills/cloudflare/references/waf/patterns.md +236 -0
- package/vendor/skills/skills/cloudflare/references/web-analytics/README.md +149 -0
- package/vendor/skills/skills/cloudflare/references/web-analytics/configuration.md +81 -0
- package/vendor/skills/skills/cloudflare/references/web-analytics/gotchas.md +86 -0
- package/vendor/skills/skills/cloudflare/references/web-analytics/integration.md +63 -0
- package/vendor/skills/skills/cloudflare/references/web-analytics/patterns.md +98 -0
- package/vendor/skills/skills/cloudflare/references/workerd/README.md +85 -0
- package/vendor/skills/skills/cloudflare/references/workerd/api.md +219 -0
- package/vendor/skills/skills/cloudflare/references/workerd/configuration.md +200 -0
- package/vendor/skills/skills/cloudflare/references/workerd/gotchas.md +151 -0
- package/vendor/skills/skills/cloudflare/references/workerd/patterns.md +205 -0
- package/vendor/skills/skills/cloudflare/references/workers/README.md +110 -0
- package/vendor/skills/skills/cloudflare/references/workers/api.md +197 -0
- package/vendor/skills/skills/cloudflare/references/workers/configuration.md +184 -0
- package/vendor/skills/skills/cloudflare/references/workers/frameworks.md +200 -0
- package/vendor/skills/skills/cloudflare/references/workers/gotchas.md +145 -0
- package/vendor/skills/skills/cloudflare/references/workers/patterns.md +220 -0
- package/vendor/skills/skills/cloudflare/references/workers-ai/README.md +206 -0
- package/vendor/skills/skills/cloudflare/references/workers-ai/api.md +115 -0
- package/vendor/skills/skills/cloudflare/references/workers-ai/configuration.md +98 -0
- package/vendor/skills/skills/cloudflare/references/workers-ai/gotchas.md +130 -0
- package/vendor/skills/skills/cloudflare/references/workers-ai/patterns.md +122 -0
- package/vendor/skills/skills/cloudflare/references/workers-for-platforms/README.md +95 -0
- package/vendor/skills/skills/cloudflare/references/workers-for-platforms/api.md +212 -0
- package/vendor/skills/skills/cloudflare/references/workers-for-platforms/configuration.md +178 -0
- package/vendor/skills/skills/cloudflare/references/workers-for-platforms/gotchas.md +134 -0
- package/vendor/skills/skills/cloudflare/references/workers-for-platforms/patterns.md +210 -0
- package/vendor/skills/skills/cloudflare/references/workers-playground/README.md +131 -0
- package/vendor/skills/skills/cloudflare/references/workers-playground/api.md +101 -0
- package/vendor/skills/skills/cloudflare/references/workers-playground/configuration.md +169 -0
- package/vendor/skills/skills/cloudflare/references/workers-playground/gotchas.md +88 -0
- package/vendor/skills/skills/cloudflare/references/workers-playground/patterns.md +134 -0
- package/vendor/skills/skills/cloudflare/references/workers-vpc/README.md +130 -0
- package/vendor/skills/skills/cloudflare/references/workers-vpc/api.md +196 -0
- package/vendor/skills/skills/cloudflare/references/workers-vpc/configuration.md +151 -0
- package/vendor/skills/skills/cloudflare/references/workers-vpc/gotchas.md +171 -0
- package/vendor/skills/skills/cloudflare/references/workers-vpc/patterns.md +235 -0
- package/vendor/skills/skills/cloudflare/references/workflows/README.md +72 -0
- package/vendor/skills/skills/cloudflare/references/workflows/api.md +240 -0
- package/vendor/skills/skills/cloudflare/references/workflows/configuration.md +160 -0
- package/vendor/skills/skills/cloudflare/references/workflows/gotchas.md +97 -0
- package/vendor/skills/skills/cloudflare/references/workflows/patterns.md +245 -0
- package/vendor/skills/skills/cloudflare/references/wrangler/README.md +143 -0
- package/vendor/skills/skills/cloudflare/references/wrangler/api.md +188 -0
- package/vendor/skills/skills/cloudflare/references/wrangler/configuration.md +198 -0
- package/vendor/skills/skills/cloudflare/references/wrangler/gotchas.md +212 -0
- package/vendor/skills/skills/cloudflare/references/wrangler/patterns.md +211 -0
- package/vendor/skills/skills/cloudflare/references/zaraz/IMPLEMENTATION_SUMMARY.md +131 -0
- package/vendor/skills/skills/cloudflare/references/zaraz/README.md +114 -0
- package/vendor/skills/skills/cloudflare/references/zaraz/api.md +118 -0
- package/vendor/skills/skills/cloudflare/references/zaraz/configuration.md +94 -0
- package/vendor/skills/skills/cloudflare/references/zaraz/gotchas.md +88 -0
- package/vendor/skills/skills/cloudflare/references/zaraz/patterns.md +77 -0
- package/vendor/skills/skills/content-research-writer/SKILL.md +595 -0
- package/vendor/skills/skills/copywriting/SKILL.md +287 -0
- package/vendor/skills/skills/copywriting/references/copy-frameworks.md +385 -0
- package/vendor/skills/skills/copywriting/references/natural-transitions.md +255 -0
- package/vendor/skills/skills/crafting-effective-readmes/README.md +180 -0
- package/vendor/skills/skills/crafting-effective-readmes/SKILL.md +82 -0
- package/vendor/skills/skills/crafting-effective-readmes/references/art-of-readme.md +518 -0
- package/vendor/skills/skills/crafting-effective-readmes/references/make-a-readme.md +119 -0
- package/vendor/skills/skills/crafting-effective-readmes/references/standard-readme-example-maximal.md +70 -0
- package/vendor/skills/skills/crafting-effective-readmes/references/standard-readme-example-minimal.md +23 -0
- package/vendor/skills/skills/crafting-effective-readmes/references/standard-readme-spec.md +290 -0
- package/vendor/skills/skills/crafting-effective-readmes/section-checklist.md +17 -0
- package/vendor/skills/skills/crafting-effective-readmes/style-guide.md +13 -0
- package/vendor/skills/skills/crafting-effective-readmes/templates/internal.md +106 -0
- package/vendor/skills/skills/crafting-effective-readmes/templates/oss.md +77 -0
- package/vendor/skills/skills/crafting-effective-readmes/templates/personal.md +51 -0
- package/vendor/skills/skills/crafting-effective-readmes/templates/xdg-config.md +71 -0
- package/vendor/skills/skills/crafting-effective-readmes/using-references.md +37 -0
- package/vendor/skills/skills/creating-spec/SKILL.md +343 -0
- package/vendor/skills/skills/deep-research/SKILL.md +96 -0
- package/vendor/skills/skills/design-spec-extraction/SKILL.md +1402 -0
- package/vendor/skills/skills/design-spec-extraction/references/design-tokens-schema.json +1145 -0
- package/vendor/skills/skills/design-spec-extraction/references/extraction-patterns.md +1044 -0
- package/vendor/skills/skills/develop-ai-functions-example/SKILL.md +225 -0
- package/vendor/skills/skills/devops-engineer/SKILL.md +147 -0
- package/vendor/skills/skills/devops-engineer/references/deployment-strategies.md +245 -0
- package/vendor/skills/skills/devops-engineer/references/docker-patterns.md +113 -0
- package/vendor/skills/skills/devops-engineer/references/github-actions.md +142 -0
- package/vendor/skills/skills/devops-engineer/references/incident-response.md +345 -0
- package/vendor/skills/skills/devops-engineer/references/kubernetes.md +154 -0
- package/vendor/skills/skills/devops-engineer/references/platform-engineering.md +417 -0
- package/vendor/skills/skills/devops-engineer/references/release-automation.md +527 -0
- package/vendor/skills/skills/devops-engineer/references/terraform-iac.md +141 -0
- package/vendor/skills/skills/dispatching-parallel-agents/SKILL.md +191 -0
- package/vendor/skills/skills/drizzle-orm/SKILL.md +116 -0
- package/vendor/skills/skills/drizzle-orm/references/patterns.md +750 -0
- package/vendor/skills/skills/drizzle-safe-migrations/SKILL.md +68 -0
- package/vendor/skills/skills/drizzle-safe-migrations/agents/openai.yaml +4 -0
- package/vendor/skills/skills/drizzle-safe-migrations/references/production-playbook.md +47 -0
- package/vendor/skills/skills/effect-ts/SKILL.md +232 -0
- package/vendor/skills/skills/effect-ts/references/api-platform-observability.md +194 -0
- package/vendor/skills/skills/effect-ts/references/batching-and-caching.md +208 -0
- package/vendor/skills/skills/effect-ts/references/class-patterns.md +711 -0
- package/vendor/skills/skills/effect-ts/references/concurrency-and-resources.md +199 -0
- package/vendor/skills/skills/effect-ts/references/construction-and-style.md +138 -0
- package/vendor/skills/skills/effect-ts/references/control-flow-and-runtime.md +216 -0
- package/vendor/skills/skills/effect-ts/references/core-patterns.md +48 -0
- package/vendor/skills/skills/effect-ts/references/data-and-testing.md +200 -0
- package/vendor/skills/skills/effect-ts/references/data-types.md +705 -0
- package/vendor/skills/skills/effect-ts/references/error-handling-patterns.md +498 -0
- package/vendor/skills/skills/effect-ts/references/foundations.md +171 -0
- package/vendor/skills/skills/effect-ts/references/library-development-patterns.md +441 -0
- package/vendor/skills/skills/effect-ts/references/pattern-matching.md +363 -0
- package/vendor/skills/skills/effect-ts/references/quality-tooling-and-resources.md +240 -0
- package/vendor/skills/skills/effect-ts/references/schema-errors-config.md +486 -0
- package/vendor/skills/skills/effect-ts/references/schema-transforms-and-filters.md +293 -0
- package/vendor/skills/skills/effect-ts/references/sink.md +282 -0
- package/vendor/skills/skills/effect-ts/references/streams-deep-dive.md +649 -0
- package/vendor/skills/skills/effect-ts/references/testing-patterns.md +566 -0
- package/vendor/skills/skills/electron-builder/SKILL.md +447 -0
- package/vendor/skills/skills/electron-builder/references/auto-update.md +250 -0
- package/vendor/skills/skills/electron-builder/references/code-signing.md +213 -0
- package/vendor/skills/skills/electron-builder/references/configuration.md +229 -0
- package/vendor/skills/skills/electron-builder/references/hooks-and-programmatic.md +337 -0
- package/vendor/skills/skills/electron-builder/references/platform-targets.md +324 -0
- package/vendor/skills/skills/electron-builder/references/publishing.md +263 -0
- package/vendor/skills/skills/electron-dev/SKILL.md +195 -0
- package/vendor/skills/skills/electron-dev/references/patterns.md +825 -0
- package/vendor/skills/skills/electron-release/SKILL.md +216 -0
- package/vendor/skills/skills/electron-release/references/patterns.md +464 -0
- package/vendor/skills/skills/elysia/SKILL.md +155 -0
- package/vendor/skills/skills/elysia/references/patterns.md +569 -0
- package/vendor/skills/skills/es-toolkit/SKILL.md +45 -0
- package/vendor/skills/skills/es-toolkit/references/patterns.md +136 -0
- package/vendor/skills/skills/evolution-api/SKILL.md +312 -0
- package/vendor/skills/skills/evolution-api/references/api-endpoints.md +174 -0
- package/vendor/skills/skills/evolution-api/references/environment-variables.md +156 -0
- package/vendor/skills/skills/evolution-api/references/events.md +101 -0
- package/vendor/skills/skills/exa-web-search-free/.clawhub/origin.json +7 -0
- package/vendor/skills/skills/exa-web-search-free/SKILL.md +96 -0
- package/vendor/skills/skills/exa-web-search-free/references/examples.md +156 -0
- package/vendor/skills/skills/executing-plans/SKILL.md +87 -0
- package/vendor/skills/skills/find-rules/SKILL.md +184 -0
- package/vendor/skills/skills/find-skills/SKILL.md +133 -0
- package/vendor/skills/skills/firecrawl/SKILL.md +126 -0
- package/vendor/skills/skills/firecrawl/rules/install.md +63 -0
- package/vendor/skills/skills/firecrawl/rules/security.md +26 -0
- package/vendor/skills/skills/fix-coderabbit-review/SKILL.md +116 -0
- package/vendor/skills/skills/fix-coderabbit-review/agents/openai.yaml +3 -0
- package/vendor/skills/skills/fix-coderabbit-review/scripts/pr-review.ts +1182 -0
- package/vendor/skills/skills/fix-coderabbit-review/scripts/resolve_pr_issues.sh +228 -0
- package/vendor/skills/skills/fixing-motion-performance/SKILL.md +128 -0
- package/vendor/skills/skills/frontend-design/SKILL.md +45 -0
- package/vendor/skills/skills/fundraising/README.md +14 -0
- package/vendor/skills/skills/fundraising/SKILL.md +136 -0
- package/vendor/skills/skills/fundraising/references/CHECKLISTS.md +49 -0
- package/vendor/skills/skills/fundraising/references/EXAMPLES.md +10 -0
- package/vendor/skills/skills/fundraising/references/INTAKE.md +38 -0
- package/vendor/skills/skills/fundraising/references/RUBRIC.md +39 -0
- package/vendor/skills/skills/fundraising/references/SOURCE_SUMMARY.md +23 -0
- package/vendor/skills/skills/fundraising/references/TEMPLATES.md +201 -0
- package/vendor/skills/skills/fundraising/references/WORKFLOW.md +84 -0
- package/vendor/skills/skills/fundraising/skillpack.json +13 -0
- package/vendor/skills/skills/game-changing-features/README.md +230 -0
- package/vendor/skills/skills/game-changing-features/SKILL.md +287 -0
- package/vendor/skills/skills/git-rebase/SKILL.md +422 -0
- package/vendor/skills/skills/git-rebase/references/automation.md +25 -0
- package/vendor/skills/skills/git-rebase/references/resolution-patterns.md +76 -0
- package/vendor/skills/skills/git-rebase/references/scripts-tools.md +49 -0
- package/vendor/skills/skills/git-rebase/references/strategies.md +367 -0
- package/vendor/skills/skills/git-rebase/references/troubleshooting.md +70 -0
- package/vendor/skills/skills/git-rebase/scripts/analyze-conflicts.sh +107 -0
- package/vendor/skills/skills/git-rebase/scripts/pre-rebase-backup.sh +94 -0
- package/vendor/skills/skills/git-rebase/scripts/validate-merge.sh +106 -0
- package/vendor/skills/skills/google-ads/SKILL.md +197 -0
- package/vendor/skills/skills/google-ads/_meta.json +22 -0
- package/vendor/skills/skills/google-ads/references/api-setup.md +337 -0
- package/vendor/skills/skills/google-ads/references/browser-workflows.md +294 -0
- package/vendor/skills/skills/helm-chart-scaffolding/SKILL.md +566 -0
- package/vendor/skills/skills/helm-chart-scaffolding/assets/Chart.yaml.template +42 -0
- package/vendor/skills/skills/helm-chart-scaffolding/assets/values.yaml.template +185 -0
- package/vendor/skills/skills/helm-chart-scaffolding/references/chart-structure.md +509 -0
- package/vendor/skills/skills/helm-chart-scaffolding/scripts/validate-chart.sh +244 -0
- package/vendor/skills/skills/hetzner-server/SKILL.md +278 -0
- package/vendor/skills/skills/hono/SKILL.md +90 -0
- package/vendor/skills/skills/hormozi-ad-factory/SKILL.md +153 -0
- package/vendor/skills/skills/hormozi-ad-factory/assets/output-template.md +132 -0
- package/vendor/skills/skills/hormozi-ad-factory/references/cta-templates.md +84 -0
- package/vendor/skills/skills/hormozi-ad-factory/references/hook-formulas.md +137 -0
- package/vendor/skills/skills/hormozi-ad-factory/references/meat-formats.md +133 -0
- package/vendor/skills/skills/humanizer/README.md +122 -0
- package/vendor/skills/skills/humanizer/SKILL.md +493 -0
- package/vendor/skills/skills/inngest/SKILL.md +62 -0
- package/vendor/skills/skills/interface-design/SKILL.md +402 -0
- package/vendor/skills/skills/interface-design/references/critique.md +67 -0
- package/vendor/skills/skills/interface-design/references/example.md +87 -0
- package/vendor/skills/skills/interface-design/references/principles.md +235 -0
- package/vendor/skills/skills/interface-design/references/validation.md +51 -0
- package/vendor/skills/skills/k8s-security-policies/SKILL.md +352 -0
- package/vendor/skills/skills/k8s-security-policies/assets/network-policy-template.yaml +176 -0
- package/vendor/skills/skills/k8s-security-policies/references/rbac-patterns.md +199 -0
- package/vendor/skills/skills/kubernetes-specialist/SKILL.md +244 -0
- package/vendor/skills/skills/kubernetes-specialist/references/configuration.md +452 -0
- package/vendor/skills/skills/kubernetes-specialist/references/cost-optimization.md +458 -0
- package/vendor/skills/skills/kubernetes-specialist/references/custom-operators.md +563 -0
- package/vendor/skills/skills/kubernetes-specialist/references/gitops.md +531 -0
- package/vendor/skills/skills/kubernetes-specialist/references/helm-charts.md +912 -0
- package/vendor/skills/skills/kubernetes-specialist/references/multi-cluster.md +507 -0
- package/vendor/skills/skills/kubernetes-specialist/references/networking.md +447 -0
- package/vendor/skills/skills/kubernetes-specialist/references/service-mesh.md +459 -0
- package/vendor/skills/skills/kubernetes-specialist/references/storage.md +535 -0
- package/vendor/skills/skills/kubernetes-specialist/references/troubleshooting.md +416 -0
- package/vendor/skills/skills/kubernetes-specialist/references/workloads.md +377 -0
- package/vendor/skills/skills/landing-page-design/SKILL.md +243 -0
- package/vendor/skills/skills/lesson-learned/README.md +65 -0
- package/vendor/skills/skills/lesson-learned/SKILL.md +107 -0
- package/vendor/skills/skills/lesson-learned/references/anti-patterns.md +55 -0
- package/vendor/skills/skills/lesson-learned/references/se-principles.md +109 -0
- package/vendor/skills/skills/mastra/SKILL.md +173 -0
- package/vendor/skills/skills/mastra/references/common-errors.md +535 -0
- package/vendor/skills/skills/mastra/references/create-mastra.md +220 -0
- package/vendor/skills/skills/mastra/references/embedded-docs.md +99 -0
- package/vendor/skills/skills/mastra/references/migration-guide.md +180 -0
- package/vendor/skills/skills/mastra/references/remote-docs.md +193 -0
- package/vendor/skills/skills/mermaid-diagrams/README.md +246 -0
- package/vendor/skills/skills/mermaid-diagrams/SKILL.md +228 -0
- package/vendor/skills/skills/mermaid-diagrams/references/advanced-features.md +567 -0
- package/vendor/skills/skills/mermaid-diagrams/references/architecture-diagrams.md +192 -0
- package/vendor/skills/skills/mermaid-diagrams/references/c4-diagrams.md +416 -0
- package/vendor/skills/skills/mermaid-diagrams/references/class-diagrams.md +376 -0
- package/vendor/skills/skills/mermaid-diagrams/references/erd-diagrams.md +519 -0
- package/vendor/skills/skills/mermaid-diagrams/references/flowcharts.md +478 -0
- package/vendor/skills/skills/mermaid-diagrams/references/sequence-diagrams.md +406 -0
- package/vendor/skills/skills/motion/.claude-plugin/plugin.json +12 -0
- package/vendor/skills/skills/motion/SKILL.md +874 -0
- package/vendor/skills/skills/motion/references/common-patterns.md +247 -0
- package/vendor/skills/skills/motion/references/motion-vs-auto-animate.md +714 -0
- package/vendor/skills/skills/motion/references/nextjs-integration.md +694 -0
- package/vendor/skills/skills/motion/references/performance-optimization.md +898 -0
- package/vendor/skills/skills/motion/rules/motion.md +91 -0
- package/vendor/skills/skills/motion/scripts/init-motion.sh +241 -0
- package/vendor/skills/skills/motion/scripts/optimize-bundle.sh +215 -0
- package/vendor/skills/skills/motion/templates/layout-transitions.tsx +608 -0
- package/vendor/skills/skills/motion/templates/motion-nextjs-client.tsx +490 -0
- package/vendor/skills/skills/motion/templates/motion-vite-basic.tsx +366 -0
- package/vendor/skills/skills/motion/templates/scroll-parallax.tsx +506 -0
- package/vendor/skills/skills/motion/templates/ui-components.tsx +723 -0
- package/vendor/skills/skills/motion-react/SKILL.md +376 -0
- package/vendor/skills/skills/motion-react/references/animation-api.md +231 -0
- package/vendor/skills/skills/motion-react/references/gestures-and-drag.md +179 -0
- package/vendor/skills/skills/motion-react/references/hooks-and-motion-values.md +333 -0
- package/vendor/skills/skills/motion-react/references/layout-animations.md +208 -0
- package/vendor/skills/skills/motion-react/references/scroll-animations.md +229 -0
- package/vendor/skills/skills/motion-react/references/transitions-api.md +162 -0
- package/vendor/skills/skills/nano-banana-pro/SKILL.md +58 -0
- package/vendor/skills/skills/nano-banana-pro/scripts/generate_image.py +184 -0
- package/vendor/skills/skills/nano-banana-prompting/SKILL.md +149 -0
- package/vendor/skills/skills/nano-banana-prompting/references/guide.md +403 -0
- package/vendor/skills/skills/next-best-practices/SKILL.md +171 -0
- package/vendor/skills/skills/next-best-practices/async-patterns.md +84 -0
- package/vendor/skills/skills/next-best-practices/bundling.md +182 -0
- package/vendor/skills/skills/next-best-practices/data-patterns.md +300 -0
- package/vendor/skills/skills/next-best-practices/debug-tricks.md +122 -0
- package/vendor/skills/skills/next-best-practices/directives.md +74 -0
- package/vendor/skills/skills/next-best-practices/error-handling.md +228 -0
- package/vendor/skills/skills/next-best-practices/file-conventions.md +141 -0
- package/vendor/skills/skills/next-best-practices/font.md +246 -0
- package/vendor/skills/skills/next-best-practices/functions.md +108 -0
- package/vendor/skills/skills/next-best-practices/hydration-error.md +86 -0
- package/vendor/skills/skills/next-best-practices/image.md +173 -0
- package/vendor/skills/skills/next-best-practices/metadata.md +292 -0
- package/vendor/skills/skills/next-best-practices/parallel-routes.md +286 -0
- package/vendor/skills/skills/next-best-practices/route-handlers.md +143 -0
- package/vendor/skills/skills/next-best-practices/rsc-boundaries.md +160 -0
- package/vendor/skills/skills/next-best-practices/runtime-selection.md +40 -0
- package/vendor/skills/skills/next-best-practices/scripts.md +137 -0
- package/vendor/skills/skills/next-best-practices/self-hosting.md +375 -0
- package/vendor/skills/skills/next-best-practices/suspense-boundaries.md +67 -0
- package/vendor/skills/skills/no-workarounds/SKILL.md +447 -0
- package/vendor/skills/skills/no-workarounds/references/philosophical-foundations.md +111 -0
- package/vendor/skills/skills/no-workarounds/references/workaround-catalog.md +565 -0
- package/vendor/skills/skills/organization-best-practices/SKILL.md +478 -0
- package/vendor/skills/skills/outside-to-issue/SKILL.md +105 -0
- package/vendor/skills/skills/pal/SKILL.md +184 -0
- package/vendor/skills/skills/pal/references/analyze.md +77 -0
- package/vendor/skills/skills/pal/references/debug.md +78 -0
- package/vendor/skills/skills/pal/references/planner.md +101 -0
- package/vendor/skills/skills/pal/references/refactor.md +88 -0
- package/vendor/skills/skills/pal/references/review.md +61 -0
- package/vendor/skills/skills/pal/references/tracer.md +66 -0
- package/vendor/skills/skills/perplexity/README.md +212 -0
- package/vendor/skills/skills/perplexity/SKILL.md +143 -0
- package/vendor/skills/skills/pitch-deck/SKILL.md +259 -0
- package/vendor/skills/skills/pitch-deck/index.js +9 -0
- package/vendor/skills/skills/pitch-deck/package.json +11 -0
- package/vendor/skills/skills/pitch-deck/references/pitch_deck_best_practices.md +241 -0
- package/vendor/skills/skills/pitch-deck/scripts/create_pitch_deck.py +298 -0
- package/vendor/skills/skills/pitch-deck-visuals/SKILL.md +215 -0
- package/vendor/skills/skills/pitch-deck-visuals/_meta.json +11 -0
- package/vendor/skills/skills/pitch-gen/README.md +22 -0
- package/vendor/skills/skills/pitch-gen/SKILL.md +78 -0
- package/vendor/skills/skills/pitch-gen/_meta.json +11 -0
- package/vendor/skills/skills/pitch-gen/package-lock.json +876 -0
- package/vendor/skills/skills/pitch-gen/package.json +35 -0
- package/vendor/skills/skills/pitch-gen/src/cli.ts +26 -0
- package/vendor/skills/skills/pitch-gen/src/index.ts +18 -0
- package/vendor/skills/skills/pitch-gen/tsconfig.json +13 -0
- package/vendor/skills/skills/postgres-drizzle/SKILL.md +190 -0
- package/vendor/skills/skills/postgres-drizzle/references/CHEATSHEET.md +424 -0
- package/vendor/skills/skills/postgres-drizzle/references/MIGRATIONS.md +545 -0
- package/vendor/skills/skills/postgres-drizzle/references/PERFORMANCE.md +564 -0
- package/vendor/skills/skills/postgres-drizzle/references/POSTGRES.md +590 -0
- package/vendor/skills/skills/postgres-drizzle/references/QUERIES.md +701 -0
- package/vendor/skills/skills/postgres-drizzle/references/RELATIONS.md +651 -0
- package/vendor/skills/skills/postgres-drizzle/references/SCHEMA.md +574 -0
- package/vendor/skills/skills/pptx-creator/SKILL.md +239 -0
- package/vendor/skills/skills/pptx-creator/_meta.json +11 -0
- package/vendor/skills/skills/pptx-creator/references/outline-format.md +127 -0
- package/vendor/skills/skills/pptx-creator/scripts/analyze_template.py +182 -0
- package/vendor/skills/skills/pptx-creator/scripts/create_pptx.py +488 -0
- package/vendor/skills/skills/pptx-creator/scripts/create_template.py +427 -0
- package/vendor/skills/skills/pptx-creator/scripts/use_template.py +195 -0
- package/vendor/skills/skills/pptx-creator/templates/templates.json +70 -0
- package/vendor/skills/skills/professional-communication/README.md +234 -0
- package/vendor/skills/skills/professional-communication/SKILL.md +272 -0
- package/vendor/skills/skills/professional-communication/references/email-templates.md +300 -0
- package/vendor/skills/skills/professional-communication/references/jargon-simplification.md +164 -0
- package/vendor/skills/skills/professional-communication/references/meeting-structures.md +333 -0
- package/vendor/skills/skills/professional-communication/references/remote-async-communication.md +310 -0
- package/vendor/skills/skills/promo-video/SKILL.md +465 -0
- package/vendor/skills/skills/promo-video/metallic-swoosh.md +94 -0
- package/vendor/skills/skills/promo-video/music/inspired-ambient-141686.mp3 +0 -0
- package/vendor/skills/skills/promo-video/music/motivational-day-112790.mp3 +0 -0
- package/vendor/skills/skills/promo-video/music/the-upbeat-inspiring-corporate-142313.mp3 +0 -0
- package/vendor/skills/skills/promo-video/promo-patterns.md +184 -0
- package/vendor/skills/skills/promo-video/scripts/generate_voiceover.py +266 -0
- package/vendor/skills/skills/promo-video/voiceover.md +358 -0
- package/vendor/skills/skills/qa-test-planner/README.md +394 -0
- package/vendor/skills/skills/qa-test-planner/SKILL.md +827 -0
- package/vendor/skills/skills/qa-test-planner/references/bug_report_templates.md +457 -0
- package/vendor/skills/skills/qa-test-planner/references/figma_validation.md +381 -0
- package/vendor/skills/skills/qa-test-planner/references/regression_testing.md +406 -0
- package/vendor/skills/skills/qa-test-planner/references/test_case_templates.md +457 -0
- package/vendor/skills/skills/qa-test-planner/scripts/create_bug_report.sh +276 -0
- package/vendor/skills/skills/qa-test-planner/scripts/generate_test_cases.sh +302 -0
- package/vendor/skills/skills/ratatui-tui/SKILL.md +422 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/async-app/Cargo.lock +1914 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/async-app/Cargo.toml +11 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/async-app/src/main.rs +122 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/Cargo.lock +2433 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/Cargo.toml +24 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/action.rs +16 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/app.rs +97 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/config.rs +67 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/event.rs +44 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/logging.rs +34 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/main.rs +51 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/tui.rs +59 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/ui.rs +65 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/hello-world/Cargo.lock +1511 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/hello-world/Cargo.toml +8 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/hello-world/src/main.rs +23 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/simple-app/Cargo.lock +1692 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/simple-app/Cargo.toml +9 -0
- package/vendor/skills/skills/ratatui-tui/assets/templates/simple-app/src/main.rs +100 -0
- package/vendor/skills/skills/ratatui-tui/references/architecture-patterns.md +448 -0
- package/vendor/skills/skills/ratatui-tui/references/async-patterns.md +426 -0
- package/vendor/skills/skills/ratatui-tui/references/image-integration.md +395 -0
- package/vendor/skills/skills/ratatui-tui/references/style-guide.md +249 -0
- package/vendor/skills/skills/react/SKILL.md +195 -0
- package/vendor/skills/skills/react/references/best-practices.md +1093 -0
- package/vendor/skills/skills/react/references/useeffect-patterns.md +620 -0
- package/vendor/skills/skills/receiving-code-review/SKILL.md +226 -0
- package/vendor/skills/skills/remotion-best-practices/SKILL.md +61 -0
- package/vendor/skills/skills/remotion-best-practices/rules/3d.md +86 -0
- package/vendor/skills/skills/remotion-best-practices/rules/animations.md +27 -0
- package/vendor/skills/skills/remotion-best-practices/rules/assets/charts-bar-chart.tsx +165 -0
- package/vendor/skills/skills/remotion-best-practices/rules/assets/text-animations-typewriter.tsx +89 -0
- package/vendor/skills/skills/remotion-best-practices/rules/assets/text-animations-word-highlight.tsx +101 -0
- package/vendor/skills/skills/remotion-best-practices/rules/assets.md +78 -0
- package/vendor/skills/skills/remotion-best-practices/rules/audio-visualization.md +195 -0
- package/vendor/skills/skills/remotion-best-practices/rules/audio.md +167 -0
- package/vendor/skills/skills/remotion-best-practices/rules/calculate-metadata.md +118 -0
- package/vendor/skills/skills/remotion-best-practices/rules/can-decode.md +75 -0
- package/vendor/skills/skills/remotion-best-practices/rules/charts.md +116 -0
- package/vendor/skills/skills/remotion-best-practices/rules/compositions.md +153 -0
- package/vendor/skills/skills/remotion-best-practices/rules/display-captions.md +176 -0
- package/vendor/skills/skills/remotion-best-practices/rules/extract-frames.md +217 -0
- package/vendor/skills/skills/remotion-best-practices/rules/ffmpeg.md +34 -0
- package/vendor/skills/skills/remotion-best-practices/rules/fonts.md +152 -0
- package/vendor/skills/skills/remotion-best-practices/rules/get-audio-duration.md +58 -0
- package/vendor/skills/skills/remotion-best-practices/rules/get-video-dimensions.md +68 -0
- package/vendor/skills/skills/remotion-best-practices/rules/get-video-duration.md +60 -0
- package/vendor/skills/skills/remotion-best-practices/rules/gifs.md +135 -0
- package/vendor/skills/skills/remotion-best-practices/rules/images.md +130 -0
- package/vendor/skills/skills/remotion-best-practices/rules/import-srt-captions.md +69 -0
- package/vendor/skills/skills/remotion-best-practices/rules/light-leaks.md +73 -0
- package/vendor/skills/skills/remotion-best-practices/rules/lottie.md +67 -0
- package/vendor/skills/skills/remotion-best-practices/rules/maps.md +405 -0
- package/vendor/skills/skills/remotion-best-practices/rules/measuring-dom-nodes.md +34 -0
- package/vendor/skills/skills/remotion-best-practices/rules/measuring-text.md +140 -0
- package/vendor/skills/skills/remotion-best-practices/rules/parameters.md +109 -0
- package/vendor/skills/skills/remotion-best-practices/rules/sequencing.md +118 -0
- package/vendor/skills/skills/remotion-best-practices/rules/sfx.md +26 -0
- package/vendor/skills/skills/remotion-best-practices/rules/subtitles.md +36 -0
- package/vendor/skills/skills/remotion-best-practices/rules/tailwind.md +11 -0
- package/vendor/skills/skills/remotion-best-practices/rules/text-animations.md +20 -0
- package/vendor/skills/skills/remotion-best-practices/rules/timing.md +179 -0
- package/vendor/skills/skills/remotion-best-practices/rules/transcribe-captions.md +70 -0
- package/vendor/skills/skills/remotion-best-practices/rules/transitions.md +193 -0
- package/vendor/skills/skills/remotion-best-practices/rules/transparent-videos.md +102 -0
- package/vendor/skills/skills/remotion-best-practices/rules/trimming.md +51 -0
- package/vendor/skills/skills/remotion-best-practices/rules/videos.md +169 -0
- package/vendor/skills/skills/remotion-best-practices/rules/voiceover.md +94 -0
- package/vendor/skills/skills/requirements-clarity/README.md +275 -0
- package/vendor/skills/skills/requirements-clarity/SKILL.md +358 -0
- package/vendor/skills/skills/rivetkit/SKILL.md +1058 -0
- package/vendor/skills/skills/rivetkit/index.json +540 -0
- package/vendor/skills/skills/rivetkit/openapi.json +1223 -0
- package/vendor/skills/skills/rivetkit/reference/actors/access-control.md +133 -0
- package/vendor/skills/skills/rivetkit/reference/actors/actions.md +386 -0
- package/vendor/skills/skills/rivetkit/reference/actors/ai-and-user-generated-actors.md +309 -0
- package/vendor/skills/skills/rivetkit/reference/actors/appearance.md +186 -0
- package/vendor/skills/skills/rivetkit/reference/actors/authentication.md +598 -0
- package/vendor/skills/skills/rivetkit/reference/actors/communicating-between-actors.md +335 -0
- package/vendor/skills/skills/rivetkit/reference/actors/connections.md +444 -0
- package/vendor/skills/skills/rivetkit/reference/actors/debugging.md +378 -0
- package/vendor/skills/skills/rivetkit/reference/actors/design-patterns.md +630 -0
- package/vendor/skills/skills/rivetkit/reference/actors/destroy.md +116 -0
- package/vendor/skills/skills/rivetkit/reference/actors/ephemeral-variables.md +178 -0
- package/vendor/skills/skills/rivetkit/reference/actors/errors.md +442 -0
- package/vendor/skills/skills/rivetkit/reference/actors/events.md +393 -0
- package/vendor/skills/skills/rivetkit/reference/actors/fetch-and-websocket-handler.md +9 -0
- package/vendor/skills/skills/rivetkit/reference/actors/helper-types.md +9 -0
- package/vendor/skills/skills/rivetkit/reference/actors/http-api.md +11 -0
- package/vendor/skills/skills/rivetkit/reference/actors/input.md +308 -0
- package/vendor/skills/skills/rivetkit/reference/actors/keys.md +269 -0
- package/vendor/skills/skills/rivetkit/reference/actors/kv.md +126 -0
- package/vendor/skills/skills/rivetkit/reference/actors/lifecycle.md +1052 -0
- package/vendor/skills/skills/rivetkit/reference/actors/limits.md +143 -0
- package/vendor/skills/skills/rivetkit/reference/actors/metadata.md +149 -0
- package/vendor/skills/skills/rivetkit/reference/actors/postgres.md +262 -0
- package/vendor/skills/skills/rivetkit/reference/actors/queues.md +414 -0
- package/vendor/skills/skills/rivetkit/reference/actors/quickstart/backend.md +164 -0
- package/vendor/skills/skills/rivetkit/reference/actors/quickstart/cloudflare-workers.md +412 -0
- package/vendor/skills/skills/rivetkit/reference/actors/quickstart/next-js.md +122 -0
- package/vendor/skills/skills/rivetkit/reference/actors/quickstart/react.md +144 -0
- package/vendor/skills/skills/rivetkit/reference/actors/request-handler.md +241 -0
- package/vendor/skills/skills/rivetkit/reference/actors/scaling.md +9 -0
- package/vendor/skills/skills/rivetkit/reference/actors/schedule.md +102 -0
- package/vendor/skills/skills/rivetkit/reference/actors/sharing-and-joining-state.md +9 -0
- package/vendor/skills/skills/rivetkit/reference/actors/sqlite-drizzle.md +245 -0
- package/vendor/skills/skills/rivetkit/reference/actors/sqlite.md +237 -0
- package/vendor/skills/skills/rivetkit/reference/actors/state.md +204 -0
- package/vendor/skills/skills/rivetkit/reference/actors/testing.md +237 -0
- package/vendor/skills/skills/rivetkit/reference/actors/types.md +106 -0
- package/vendor/skills/skills/rivetkit/reference/actors/versions.md +109 -0
- package/vendor/skills/skills/rivetkit/reference/actors/websocket-handler.md +320 -0
- package/vendor/skills/skills/rivetkit/reference/actors/workflows.md +1958 -0
- package/vendor/skills/skills/rivetkit/reference/clients/javascript.md +236 -0
- package/vendor/skills/skills/rivetkit/reference/clients/react.md +270 -0
- package/vendor/skills/skills/rivetkit/reference/clients/swift.md +459 -0
- package/vendor/skills/skills/rivetkit/reference/clients/swiftui.md +364 -0
- package/vendor/skills/skills/rivetkit/reference/connect/aws-ecs.md +14 -0
- package/vendor/skills/skills/rivetkit/reference/connect/aws-lambda.md +9 -0
- package/vendor/skills/skills/rivetkit/reference/connect/cloudflare-workers.md +125 -0
- package/vendor/skills/skills/rivetkit/reference/connect/freestyle.md +132 -0
- package/vendor/skills/skills/rivetkit/reference/connect/gcp-cloud-run.md +75 -0
- package/vendor/skills/skills/rivetkit/reference/connect/hetzner.md +9 -0
- package/vendor/skills/skills/rivetkit/reference/connect/kubernetes.md +109 -0
- package/vendor/skills/skills/rivetkit/reference/connect/railway.md +44 -0
- package/vendor/skills/skills/rivetkit/reference/connect/supabase.md +9 -0
- package/vendor/skills/skills/rivetkit/reference/connect/vercel.md +158 -0
- package/vendor/skills/skills/rivetkit/reference/connect/vm-and-bare-metal.md +89 -0
- package/vendor/skills/skills/rivetkit/reference/cookbook/multiplayer-game.md +714 -0
- package/vendor/skills/skills/rivetkit/reference/general/actor-configuration.md +42 -0
- package/vendor/skills/skills/rivetkit/reference/general/architecture.md +452 -0
- package/vendor/skills/skills/rivetkit/reference/general/cors.md +71 -0
- package/vendor/skills/skills/rivetkit/reference/general/docs-for-llms.md +56 -0
- package/vendor/skills/skills/rivetkit/reference/general/edge.md +40 -0
- package/vendor/skills/skills/rivetkit/reference/general/endpoints.md +129 -0
- package/vendor/skills/skills/rivetkit/reference/general/environment-variables.md +73 -0
- package/vendor/skills/skills/rivetkit/reference/general/http-server.md +144 -0
- package/vendor/skills/skills/rivetkit/reference/general/logging.md +153 -0
- package/vendor/skills/skills/rivetkit/reference/general/registry-configuration.md +98 -0
- package/vendor/skills/skills/rivetkit/reference/general/runtime-modes.md +156 -0
- package/vendor/skills/skills/rivetkit/reference/self-hosting/configuration.md +53 -0
- package/vendor/skills/skills/rivetkit/reference/self-hosting/docker-compose.md +148 -0
- package/vendor/skills/skills/rivetkit/reference/self-hosting/docker-container.md +93 -0
- package/vendor/skills/skills/rivetkit/reference/self-hosting/filesystem.md +48 -0
- package/vendor/skills/skills/rivetkit/reference/self-hosting/install.md +33 -0
- package/vendor/skills/skills/rivetkit/reference/self-hosting/kubernetes.md +496 -0
- package/vendor/skills/skills/rivetkit/reference/self-hosting/multi-region.md +11 -0
- package/vendor/skills/skills/rivetkit/reference/self-hosting/postgres.md +193 -0
- package/vendor/skills/skills/rivetkit/reference/self-hosting/railway.md +71 -0
- package/vendor/skills/skills/rivetkit-client-javascript/SKILL.md +259 -0
- package/vendor/skills/skills/rivetkit-client-javascript/index.json +7 -0
- package/vendor/skills/skills/rivetkit-client-react/SKILL.md +293 -0
- package/vendor/skills/skills/rivetkit-client-react/index.json +7 -0
- package/vendor/skills/skills/rust-async-patterns/SKILL.md +519 -0
- package/vendor/skills/skills/rust-best-practices/SKILL.md +104 -0
- package/vendor/skills/skills/rust-best-practices/references/chapter_01.md +591 -0
- package/vendor/skills/skills/rust-best-practices/references/chapter_02.md +119 -0
- package/vendor/skills/skills/rust-best-practices/references/chapter_03.md +226 -0
- package/vendor/skills/skills/rust-best-practices/references/chapter_04.md +187 -0
- package/vendor/skills/skills/rust-best-practices/references/chapter_05.md +406 -0
- package/vendor/skills/skills/rust-best-practices/references/chapter_06.md +168 -0
- package/vendor/skills/skills/rust-best-practices/references/chapter_07.md +231 -0
- package/vendor/skills/skills/rust-best-practices/references/chapter_08.md +276 -0
- package/vendor/skills/skills/rust-best-practices/references/chapter_09.md +259 -0
- package/vendor/skills/skills/rust-coding-guidelines/SKILL.md +95 -0
- package/vendor/skills/skills/rust-coding-guidelines/index/rules-index.md +7 -0
- package/vendor/skills/skills/rust-engineer/SKILL.md +89 -0
- package/vendor/skills/skills/rust-engineer/references/async.md +458 -0
- package/vendor/skills/skills/rust-engineer/references/error-handling.md +334 -0
- package/vendor/skills/skills/rust-engineer/references/ownership.md +278 -0
- package/vendor/skills/skills/rust-engineer/references/testing.md +470 -0
- package/vendor/skills/skills/rust-engineer/references/traits.md +413 -0
- package/vendor/skills/skills/sales-methodology-implementer/SKILL.md +735 -0
- package/vendor/skills/skills/sentry-cli/SKILL.md +459 -0
- package/vendor/skills/skills/shadcn/SKILL.md +141 -0
- package/vendor/skills/skills/shadcn/references/patterns.md +587 -0
- package/vendor/skills/skills/shadcn-ui/SKILL.md +1911 -0
- package/vendor/skills/skills/shadcn-ui/references/chart.md +303 -0
- package/vendor/skills/skills/shadcn-ui/references/learn.md +150 -0
- package/vendor/skills/skills/shadcn-ui/references/official-ui-reference.md +1721 -0
- package/vendor/skills/skills/shadcn-ui/references/reference.md +608 -0
- package/vendor/skills/skills/shadcn-ui/references/ui-reference.md +1588 -0
- package/vendor/skills/skills/ship-learn-next/README.md +191 -0
- package/vendor/skills/skills/ship-learn-next/SKILL.md +359 -0
- package/vendor/skills/skills/skill-writter/SKILL.md +408 -0
- package/vendor/skills/skills/skills-best-practices/SKILL.md +51 -0
- package/vendor/skills/skills/skills-best-practices/assets/SKILL.template.md +24 -0
- package/vendor/skills/skills/skills-best-practices/references/checklist.md +37 -0
- package/vendor/skills/skills/skills-best-practices/scripts/validate-metadata.py +46 -0
- package/vendor/skills/skills/sourcebot/SKILL.md +89 -0
- package/vendor/skills/skills/startup-validator/SKILL.md +425 -0
- package/vendor/skills/skills/startup-validator/index.js +9 -0
- package/vendor/skills/skills/startup-validator/package.json +11 -0
- package/vendor/skills/skills/startup-validator/references/frameworks.md +134 -0
- package/vendor/skills/skills/startup-validator/references/research_templates.md +191 -0
- package/vendor/skills/skills/startup-validator/scripts/market_analyzer.py +290 -0
- package/vendor/skills/skills/storybook/SKILL.md +440 -0
- package/vendor/skills/skills/storybook-stories/SKILL.md +359 -0
- package/vendor/skills/skills/storybook-stories/references/patterns.md +60 -0
- package/vendor/skills/skills/stripe-best-practices/SKILL.md +30 -0
- package/vendor/skills/skills/stripe-integration/SKILL.md +492 -0
- package/vendor/skills/skills/stripe-subscriptions/SKILL.md +54 -0
- package/vendor/skills/skills/stripe-webhooks/SKILL.md +163 -0
- package/vendor/skills/skills/stripe-webhooks/examples/express/.env.example +5 -0
- package/vendor/skills/skills/stripe-webhooks/examples/express/README.md +64 -0
- package/vendor/skills/skills/stripe-webhooks/examples/express/package.json +19 -0
- package/vendor/skills/skills/stripe-webhooks/examples/express/src/index.js +75 -0
- package/vendor/skills/skills/stripe-webhooks/examples/express/test/webhook.test.js +129 -0
- package/vendor/skills/skills/stripe-webhooks/examples/fastapi/.env.example +5 -0
- package/vendor/skills/skills/stripe-webhooks/examples/fastapi/README.md +69 -0
- package/vendor/skills/skills/stripe-webhooks/examples/fastapi/main.py +75 -0
- package/vendor/skills/skills/stripe-webhooks/examples/fastapi/requirements.txt +6 -0
- package/vendor/skills/skills/stripe-webhooks/examples/fastapi/test_webhook.py +121 -0
- package/vendor/skills/skills/stripe-webhooks/examples/nextjs/.env.example +5 -0
- package/vendor/skills/skills/stripe-webhooks/examples/nextjs/README.md +62 -0
- package/vendor/skills/skills/stripe-webhooks/examples/nextjs/app/webhooks/stripe/route.ts +63 -0
- package/vendor/skills/skills/stripe-webhooks/examples/nextjs/package.json +23 -0
- package/vendor/skills/skills/stripe-webhooks/examples/nextjs/test/webhook.test.ts +139 -0
- package/vendor/skills/skills/stripe-webhooks/examples/nextjs/vitest.config.ts +8 -0
- package/vendor/skills/skills/stripe-webhooks/references/overview.md +62 -0
- package/vendor/skills/skills/stripe-webhooks/references/setup.md +99 -0
- package/vendor/skills/skills/stripe-webhooks/references/verification.md +154 -0
- package/vendor/skills/skills/sync-provider/SKILL.md +348 -0
- package/vendor/skills/skills/systematic-debugging/CREATION-LOG.md +133 -0
- package/vendor/skills/skills/systematic-debugging/SKILL.md +305 -0
- package/vendor/skills/skills/systematic-debugging/condition-based-waiting-example.ts +158 -0
- package/vendor/skills/skills/systematic-debugging/condition-based-waiting.md +120 -0
- package/vendor/skills/skills/systematic-debugging/defense-in-depth.md +128 -0
- package/vendor/skills/skills/systematic-debugging/find-polluter.sh +63 -0
- package/vendor/skills/skills/systematic-debugging/root-cause-tracing.md +183 -0
- package/vendor/skills/skills/systematic-debugging/test-academic.md +14 -0
- package/vendor/skills/skills/systematic-debugging/test-pressure-1.md +65 -0
- package/vendor/skills/skills/systematic-debugging/test-pressure-2.md +75 -0
- package/vendor/skills/skills/systematic-debugging/test-pressure-3.md +75 -0
- package/vendor/skills/skills/tailwindcss/SKILL.md +122 -0
- package/vendor/skills/skills/tailwindcss/references/patterns.md +439 -0
- package/vendor/skills/skills/tanstack/SKILL.md +278 -0
- package/vendor/skills/skills/tanstack/references/form-patterns.md +638 -0
- package/vendor/skills/skills/tanstack/references/query-patterns.md +343 -0
- package/vendor/skills/skills/tanstack/references/router-patterns.md +373 -0
- package/vendor/skills/skills/tanstack-query-best-practices/SKILL.md +115 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/cache-gc-time.md +93 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/cache-invalidation.md +114 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/cache-placeholder-vs-initial.md +152 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/cache-stale-time.md +80 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/err-error-boundaries.md +147 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/inf-page-params.md +119 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/mut-invalidate-queries.md +118 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/mut-mutation-state.md +164 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/mut-optimistic-updates.md +131 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/network-mode.md +168 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/parallel-use-queries.md +154 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/perf-select-transform.md +144 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/persist-queries.md +192 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/pf-intent-prefetch.md +137 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/qk-array-structure.md +50 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/qk-factory-pattern.md +104 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/qk-hierarchical-organization.md +76 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/qk-include-dependencies.md +62 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/qk-serializable.md +97 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/query-cancellation.md +168 -0
- package/vendor/skills/skills/tanstack-query-best-practices/rules/ssr-dehydration.md +154 -0
- package/vendor/skills/skills/tanstack-router-best-practices/SKILL.md +114 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/ctx-root-context.md +170 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/err-not-found.md +194 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/load-ensure-query-data.md +147 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/load-parallel.md +186 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/load-use-loaders.md +148 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/nav-link-component.md +171 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/nav-route-masks.md +195 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/org-virtual-routes.md +133 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/preload-intent.md +133 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/router-default-options.md +159 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/search-custom-serializer.md +198 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/search-validation.md +154 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/split-lazy-routes.md +148 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/ts-register-router.md +113 -0
- package/vendor/skills/skills/tanstack-router-best-practices/rules/ts-use-from-param.md +130 -0
- package/vendor/skills/skills/tanstack-start-best-practices/SKILL.md +110 -0
- package/vendor/skills/skills/tanstack-start-best-practices/rules/api-routes.md +236 -0
- package/vendor/skills/skills/tanstack-start-best-practices/rules/auth-route-protection.md +188 -0
- package/vendor/skills/skills/tanstack-start-best-practices/rules/auth-session-management.md +189 -0
- package/vendor/skills/skills/tanstack-start-best-practices/rules/deploy-adapters.md +197 -0
- package/vendor/skills/skills/tanstack-start-best-practices/rules/env-functions.md +207 -0
- package/vendor/skills/skills/tanstack-start-best-practices/rules/err-server-errors.md +189 -0
- package/vendor/skills/skills/tanstack-start-best-practices/rules/file-separation.md +151 -0
- package/vendor/skills/skills/tanstack-start-best-practices/rules/mw-request-middleware.md +157 -0
- package/vendor/skills/skills/tanstack-start-best-practices/rules/sf-create-server-fn.md +146 -0
- package/vendor/skills/skills/tanstack-start-best-practices/rules/sf-input-validation.md +168 -0
- package/vendor/skills/skills/tanstack-start-best-practices/rules/ssr-hydration-safety.md +184 -0
- package/vendor/skills/skills/tanstack-start-best-practices/rules/ssr-prerender.md +190 -0
- package/vendor/skills/skills/tanstack-start-best-practices/rules/ssr-streaming.md +201 -0
- package/vendor/skills/skills/tauri-v2/README.md +157 -0
- package/vendor/skills/skills/tauri-v2/SKILL.md +378 -0
- package/vendor/skills/skills/tauri-v2/assets/README.md +18 -0
- package/vendor/skills/skills/tauri-v2/references/README.md +10 -0
- package/vendor/skills/skills/tauri-v2/references/capabilities-reference.md +310 -0
- package/vendor/skills/skills/tauri-v2/references/ipc-patterns.md +484 -0
- package/vendor/skills/skills/tauri-v2/scripts/README.md +31 -0
- package/vendor/skills/skills/tech-logos/SKILL.md +88 -0
- package/vendor/skills/skills/terraform-style-guide/SKILL.md +357 -0
- package/vendor/skills/skills/test-antipatterns/SKILL.md +309 -0
- package/vendor/skills/skills/to-prompt/SKILL.md +90 -0
- package/vendor/skills/skills/typescript-advanced/SKILL.md +760 -0
- package/vendor/skills/skills/typescript-advanced/references/best-practices.md +358 -0
- package/vendor/skills/skills/ui-ux-pro-max/SKILL.md +404 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/charts.csv +26 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/colors.csv +97 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/icons.csv +101 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/landing.csv +31 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/products.csv +97 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/react-performance.csv +45 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/stacks/astro.csv +54 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/stacks/react.csv +54 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/styles.csv +68 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/typography.csv +58 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
- package/vendor/skills/skills/ui-ux-pro-max/data/web-interface.csv +31 -0
- package/vendor/skills/skills/ui-ux-pro-max/scripts/core.py +253 -0
- package/vendor/skills/skills/ui-ux-pro-max/scripts/design_system.py +1067 -0
- package/vendor/skills/skills/ui-ux-pro-max/scripts/search.py +114 -0
- package/vendor/skills/skills/vercel-composition-patterns/AGENTS.md +917 -0
- package/vendor/skills/skills/vercel-composition-patterns/SKILL.md +88 -0
- package/vendor/skills/skills/vercel-composition-patterns/rules/architecture-avoid-boolean-props.md +94 -0
- package/vendor/skills/skills/vercel-composition-patterns/rules/architecture-compound-components.md +108 -0
- package/vendor/skills/skills/vercel-composition-patterns/rules/patterns-children-over-render-props.md +84 -0
- package/vendor/skills/skills/vercel-composition-patterns/rules/patterns-explicit-variants.md +94 -0
- package/vendor/skills/skills/vercel-composition-patterns/rules/react19-no-forwardref.md +42 -0
- package/vendor/skills/skills/vercel-composition-patterns/rules/state-context-interface.md +191 -0
- package/vendor/skills/skills/vercel-composition-patterns/rules/state-decouple-implementation.md +103 -0
- package/vendor/skills/skills/vercel-composition-patterns/rules/state-lift-state.md +125 -0
- package/vendor/skills/skills/vercel-react-best-practices/AGENTS.md +2367 -0
- package/vendor/skills/skills/vercel-react-best-practices/SKILL.md +127 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/advanced-use-latest.md +49 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/async-api-routes.md +35 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/async-defer-await.md +80 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/async-dependencies.md +37 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/async-parallel.md +24 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +59 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/bundle-conditional.md +37 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +48 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +34 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/bundle-preload.md +44 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/client-event-listeners.md +78 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +74 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +57 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/js-cache-storage.md +68 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/js-early-exit.md +50 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/js-index-maps.md +37 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/js-length-check-first.md +50 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/rendering-activity.md +26 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +38 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +32 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +36 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +72 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +77 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +56 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/rerender-memo.md +44 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/server-cache-react.md +76 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
- package/vendor/skills/skills/vercel-react-best-practices/rules/server-serialization.md +38 -0
- package/vendor/skills/skills/verification-before-completion/SKILL.md +147 -0
- package/vendor/skills/skills/vitest/GENERATION.md +5 -0
- package/vendor/skills/skills/vitest/SKILL.md +53 -0
- package/vendor/skills/skills/vitest/references/advanced-environments.md +264 -0
- package/vendor/skills/skills/vitest/references/advanced-projects.md +300 -0
- package/vendor/skills/skills/vitest/references/advanced-type-testing.md +242 -0
- package/vendor/skills/skills/vitest/references/advanced-vi.md +249 -0
- package/vendor/skills/skills/vitest/references/core-cli.md +167 -0
- package/vendor/skills/skills/vitest/references/core-config.md +177 -0
- package/vendor/skills/skills/vitest/references/core-describe.md +193 -0
- package/vendor/skills/skills/vitest/references/core-expect.md +207 -0
- package/vendor/skills/skills/vitest/references/core-hooks.md +245 -0
- package/vendor/skills/skills/vitest/references/core-test-api.md +237 -0
- package/vendor/skills/skills/vitest/references/features-concurrency.md +250 -0
- package/vendor/skills/skills/vitest/references/features-context.md +240 -0
- package/vendor/skills/skills/vitest/references/features-coverage.md +202 -0
- package/vendor/skills/skills/vitest/references/features-filtering.md +208 -0
- package/vendor/skills/skills/vitest/references/features-mocking.md +272 -0
- package/vendor/skills/skills/vitest/references/features-snapshots.md +207 -0
- package/vendor/skills/skills/web-design-guidelines/SKILL.md +40 -0
- package/vendor/skills/skills/workflow/SKILL.md +373 -0
- package/vendor/skills/skills/wrangler/SKILL.md +871 -0
- package/vendor/skills/skills/writing-clearly-and-concisely/README.md +167 -0
- package/vendor/skills/skills/writing-clearly-and-concisely/SKILL.md +93 -0
- package/vendor/skills/skills/writing-clearly-and-concisely/elements-of-style/01-introductory.md +3 -0
- package/vendor/skills/skills/writing-clearly-and-concisely/elements-of-style/02-elementary-rules-of-usage.md +214 -0
- package/vendor/skills/skills/writing-clearly-and-concisely/elements-of-style/03-elementary-principles-of-composition.md +398 -0
- package/vendor/skills/skills/writing-clearly-and-concisely/elements-of-style/04-a-few-matters-of-form.md +89 -0
- package/vendor/skills/skills/writing-clearly-and-concisely/elements-of-style/05-words-and-expressions-commonly-misused.md +348 -0
- package/vendor/skills/skills/writing-clearly-and-concisely/signs-of-ai-writing.md +900 -0
- package/vendor/skills/skills/xstate/SKILL.md +374 -0
- package/vendor/skills/skills/xstate/references/machine-patterns.md +914 -0
- package/vendor/skills/skills/xstate/references/query-patterns.md +661 -0
- package/vendor/skills/skills/xstate/references/store-patterns.md +1032 -0
- package/vendor/skills/skills/zod/AGENTS.md +97 -0
- package/vendor/skills/skills/zod/README.md +79 -0
- package/vendor/skills/skills/zod/SKILL.md +128 -0
- package/vendor/skills/skills/zod/references/compose-intersection.md +143 -0
- package/vendor/skills/skills/zod/references/compose-lazy-recursive.md +138 -0
- package/vendor/skills/skills/zod/references/compose-pipe.md +114 -0
- package/vendor/skills/skills/zod/references/compose-preprocess.md +131 -0
- package/vendor/skills/skills/zod/references/compose-shared-schemas.md +142 -0
- package/vendor/skills/skills/zod/references/error-avoid-throwing-in-refine.md +134 -0
- package/vendor/skills/skills/zod/references/error-custom-messages.md +127 -0
- package/vendor/skills/skills/zod/references/error-i18n.md +140 -0
- package/vendor/skills/skills/zod/references/error-path-for-nested.md +135 -0
- package/vendor/skills/skills/zod/references/error-use-flatten.md +135 -0
- package/vendor/skills/skills/zod/references/object-discriminated-unions.md +136 -0
- package/vendor/skills/skills/zod/references/object-extend-for-composition.md +146 -0
- package/vendor/skills/skills/zod/references/object-optional-vs-nullable.md +120 -0
- package/vendor/skills/skills/zod/references/object-partial-for-updates.md +124 -0
- package/vendor/skills/skills/zod/references/object-pick-omit.md +147 -0
- package/vendor/skills/skills/zod/references/object-strict-vs-strip.md +122 -0
- package/vendor/skills/skills/zod/references/parse-async-for-async-refinements.md +127 -0
- package/vendor/skills/skills/zod/references/parse-avoid-double-validation.md +130 -0
- package/vendor/skills/skills/zod/references/parse-handle-all-issues.md +126 -0
- package/vendor/skills/skills/zod/references/parse-never-trust-json.md +116 -0
- package/vendor/skills/skills/zod/references/parse-use-safeparse.md +103 -0
- package/vendor/skills/skills/zod/references/parse-validate-early.md +125 -0
- package/vendor/skills/skills/zod/references/perf-arrays.md +154 -0
- package/vendor/skills/skills/zod/references/perf-avoid-dynamic-creation.md +142 -0
- package/vendor/skills/skills/zod/references/perf-cache-schemas.md +143 -0
- package/vendor/skills/skills/zod/references/perf-lazy-loading.md +136 -0
- package/vendor/skills/skills/zod/references/perf-zod-mini.md +118 -0
- package/vendor/skills/skills/zod/references/refine-add-path.md +149 -0
- package/vendor/skills/skills/zod/references/refine-catch.md +138 -0
- package/vendor/skills/skills/zod/references/refine-defaults.md +132 -0
- package/vendor/skills/skills/zod/references/refine-transform-coerce.md +103 -0
- package/vendor/skills/skills/zod/references/refine-vs-superrefine.md +159 -0
- package/vendor/skills/skills/zod/references/schema-avoid-optional-abuse.md +94 -0
- package/vendor/skills/skills/zod/references/schema-coercion-for-form-data.md +89 -0
- package/vendor/skills/skills/zod/references/schema-string-validations.md +87 -0
- package/vendor/skills/skills/zod/references/schema-use-enums.md +106 -0
- package/vendor/skills/skills/zod/references/schema-use-primitives-correctly.md +63 -0
- package/vendor/skills/skills/zod/references/schema-use-unknown-not-any.md +86 -0
- package/vendor/skills/skills/zod/references/type-branded-types.md +106 -0
- package/vendor/skills/skills/zod/references/type-enable-strict-mode.md +132 -0
- package/vendor/skills/skills/zod/references/type-export-schemas-and-types.md +117 -0
- package/vendor/skills/skills/zod/references/type-input-vs-output.md +116 -0
- package/vendor/skills/skills/zod/references/type-use-z-infer.md +113 -0
- package/vendor/skills/skills/zustand/SKILL.md +154 -0
- package/vendor/skills/skills/zustand/references/patterns.md +924 -0
|
@@ -0,0 +1,518 @@
|
|
|
1
|
+
# Art of README
|
|
2
|
+
|
|
3
|
+
> Source: [hackergrrl/art-of-readme](https://github.com/hackergrrl/art-of-readme)
|
|
4
|
+
|
|
5
|
+
_This article can also be read in [Chinese](README-zh.md),
|
|
6
|
+
[Japanese](README-ja-JP.md),
|
|
7
|
+
[Brazilian Portuguese](README-pt-BR.md), [Spanish](README-es-ES.md),
|
|
8
|
+
[German](README-de-DE.md), [French](README-fr.md) and [Traditional Chinese](README-zh-TW.md)._
|
|
9
|
+
|
|
10
|
+
## Etymology
|
|
11
|
+
|
|
12
|
+
Where does the term "README" come from?
|
|
13
|
+
|
|
14
|
+
The nomenclature dates back to _at least_ the 1970s [and the
|
|
15
|
+
PDP-10](http://pdp-10.trailing-edge.com/decuslib10-04/01/43,50322/read.me.html),
|
|
16
|
+
though it may even harken back to the days of informative paper notes placed atop
|
|
17
|
+
stacks of punchcards, "READ ME!" scrawled on them, describing their use.
|
|
18
|
+
|
|
19
|
+
A reader<sup>[1](#footnote-1)</sup> suggested that the title README may be a playful nudge toward Lewis
|
|
20
|
+
Carroll's _Alice's Adventures in Wonderland_, which features a potion and a cake
|
|
21
|
+
labelled _"DRINK ME"_ and _"EAT ME"_, respectively.
|
|
22
|
+
|
|
23
|
+
The pattern of README appearing in all-caps is a consistent facet throughout
|
|
24
|
+
history. In addition to the visual strikingness of using all-caps, UNIX systems
|
|
25
|
+
would sort capitals before lower case letters, conveniently putting the README
|
|
26
|
+
before the rest of the directory's content<sup>[2](#footnote-2)</sup>.
|
|
27
|
+
|
|
28
|
+
The intent is clear: _"This is important information for the user to read before
|
|
29
|
+
proceeding."_ Let's explore together what constitutes "important information" in
|
|
30
|
+
this modern age.
|
|
31
|
+
|
|
32
|
+
## For creators, for consumers
|
|
33
|
+
|
|
34
|
+
This is an article about READMEs. About what they do, why they are an absolute
|
|
35
|
+
necessity, and how to craft them well.
|
|
36
|
+
|
|
37
|
+
This is written for module creators, for as a builder of modules, your job is to
|
|
38
|
+
create something that will last. This is an inherent motivation, even if the
|
|
39
|
+
author has no intent of sharing their work. Once 6 months pass, a module without
|
|
40
|
+
documentation begins to look new and unfamiliar.
|
|
41
|
+
|
|
42
|
+
This is also written for module consumers, for every module author is also a
|
|
43
|
+
module consumer. Node has a very healthy degree of interdependency: no one lives
|
|
44
|
+
at the bottom of the dependency tree.
|
|
45
|
+
|
|
46
|
+
Despite being focused on Node, the author contends that its lessons apply
|
|
47
|
+
equally well to other programming ecosystems, as well.
|
|
48
|
+
|
|
49
|
+
## Many modules: some good, some bad
|
|
50
|
+
|
|
51
|
+
The Node ecosystem is powered by its modules. [npm](https://npmjs.org) is the
|
|
52
|
+
magic that makes it all _go_. In the course of a week, Node developers evaluate
|
|
53
|
+
dozens of modules for inclusion in their projects. This is a great deal of power
|
|
54
|
+
being churned out on a daily basis, ripe for the plucking, just as fast as one
|
|
55
|
+
can write `npm install`.
|
|
56
|
+
|
|
57
|
+
Like any ecosystem that is extremely accessible, the quality bar varies. npm
|
|
58
|
+
does its best to nicely pack away all of these modules and ship them far and
|
|
59
|
+
wide. However, the tools found are widely varied: some are shining and new,
|
|
60
|
+
others broken and rusty, and still others are somewhere in between. There are
|
|
61
|
+
even some that we don't know what they do!
|
|
62
|
+
|
|
63
|
+
For modules, this can take the form of inaccurate or unhelpful names (any
|
|
64
|
+
guesses what the `fudge` module does?), no documentation, no tests, no source
|
|
65
|
+
code comments, or incomprehensible function names.
|
|
66
|
+
|
|
67
|
+
Many don't have an active maintainer. If a module has no human available to
|
|
68
|
+
answer questions and explain what a module does, combined with no remnants of
|
|
69
|
+
documentation left behind, a module becomes a bizarre alien artifact, unusable
|
|
70
|
+
and incomprehensible by the archaeologist-hackers of tomorrow.
|
|
71
|
+
|
|
72
|
+
For those modules that do have documentation, where do they fall on the quality
|
|
73
|
+
spectrum? Maybe it's just a one-liner description: `"sorts numbers by their hex
|
|
74
|
+
value"`. Maybe it's a snippet of example code. These are both improvements upon
|
|
75
|
+
nothing, but they tend to result in the worst-case scenario for a modern day
|
|
76
|
+
module spelunker: digging into the source code to try and understand how it
|
|
77
|
+
actually works. Writing excellent documentation is all about keeping the users
|
|
78
|
+
_out_ of the source code by providing instructions sufficient to enjoy the
|
|
79
|
+
wonderful abstractions that your module brings.
|
|
80
|
+
|
|
81
|
+
Node has a "wide" ecosystem: it's largely made up of a very long list of
|
|
82
|
+
independent do-one-thing-well modules flying no flags but their own. There are
|
|
83
|
+
[exceptions](https://github.com/lodash/lodash), but despite these minor fiefdoms,
|
|
84
|
+
it is the single-purpose commoners who, given their larger numbers, truly rule the
|
|
85
|
+
Node kingdom.
|
|
86
|
+
|
|
87
|
+
This situation has a natural consequence: it can be hard to find _quality_ modules
|
|
88
|
+
that do exactly what you want.
|
|
89
|
+
|
|
90
|
+
**This is okay**. Truly. A low bar to entry and a discoverability problem is
|
|
91
|
+
infinitely better than a culture problem, where only the privileged few may
|
|
92
|
+
participate.
|
|
93
|
+
|
|
94
|
+
Plus, discoverability -- as it turns out -- is easier to address.
|
|
95
|
+
|
|
96
|
+
## All roads lead to README.md
|
|
97
|
+
|
|
98
|
+
The Node community has responded to the challenge of discoverability in
|
|
99
|
+
different ways.
|
|
100
|
+
|
|
101
|
+
Some experienced Node developers band together to create [curated
|
|
102
|
+
lists](https://github.com/sindresorhus/awesome-nodejs) of quality modules.
|
|
103
|
+
Developers leverage their many years examining hundreds of different modules to
|
|
104
|
+
share with newcomers the _crème de la crème_: the best modules in each category.
|
|
105
|
+
This might also take the form of RSS feeds and mailing lists of new modules deemed
|
|
106
|
+
to be useful by trusted community members.
|
|
107
|
+
|
|
108
|
+
How about the social graph? This idea spurred the creation of
|
|
109
|
+
[node-modules.com](http://node-modules.com/), a npm search replacement that
|
|
110
|
+
leverages your GitHub social graph to find modules your friends like or have
|
|
111
|
+
made.
|
|
112
|
+
|
|
113
|
+
Of course there is also npm's built-in [search](https://npmjs.org)
|
|
114
|
+
functionality: a safe default, and the usual port of entry for new developers.
|
|
115
|
+
|
|
116
|
+
No matter your approach, regardless whether a module spelunker enters the module
|
|
117
|
+
underground at [npmjs.org](https://npmjs.org),
|
|
118
|
+
[github.com](https://github.com), or somewhere else, this would-be user will
|
|
119
|
+
eventually end up staring your README square in the face. Since your users
|
|
120
|
+
will inevitably find themselves here, what can be done to make their first
|
|
121
|
+
impressions maximally effective?
|
|
122
|
+
|
|
123
|
+
## Professional module spelunking
|
|
124
|
+
|
|
125
|
+
### The README: Your one-stop shop
|
|
126
|
+
|
|
127
|
+
A README is a module consumer's first -- and maybe only -- look into your
|
|
128
|
+
creation. The consumer wants a module to fulfill their need, so you must explain
|
|
129
|
+
exactly what need your module fills, and how effectively it does so.
|
|
130
|
+
|
|
131
|
+
Your job is to
|
|
132
|
+
|
|
133
|
+
1. tell them what it is (with context)
|
|
134
|
+
2. show them what it looks like in action
|
|
135
|
+
3. show them how they use it
|
|
136
|
+
4. tell them any other relevant details
|
|
137
|
+
|
|
138
|
+
This is _your_ job. It's up to the module creator to prove that their work is a
|
|
139
|
+
shining gem in the sea of slipshod modules. Since so many developers' eyes will
|
|
140
|
+
find their way to your README before anything else, quality here is your
|
|
141
|
+
public-facing measure of your work.
|
|
142
|
+
|
|
143
|
+
### Brevity
|
|
144
|
+
|
|
145
|
+
The lack of a README is a powerful red flag, but even a lengthy README is not
|
|
146
|
+
indicative of there being high quality. The ideal README is as short as it can
|
|
147
|
+
be without being any shorter. Detailed documentation is good -- make separate
|
|
148
|
+
pages for it! -- but keep your README succinct.
|
|
149
|
+
|
|
150
|
+
### Learn from the past
|
|
151
|
+
|
|
152
|
+
It is said that those who do not study their history are doomed to make its
|
|
153
|
+
mistakes again. Developers have been writing documentation for quite some number
|
|
154
|
+
of years. It would be wasteful to not look back a little bit and see what people
|
|
155
|
+
did right before Node.
|
|
156
|
+
|
|
157
|
+
Perl, for all of the flak it receives, is in some ways the spiritual grandparent
|
|
158
|
+
of Node. Both are high-level scripting languages, adopt many UNIX idioms, fuel
|
|
159
|
+
much of the internet, and both feature a wide module ecosystem.
|
|
160
|
+
|
|
161
|
+
It so turns out that the [monks](http://perlmonks.org) of the Perl community
|
|
162
|
+
indeed have a great deal of experience in writing [quality
|
|
163
|
+
READMEs](http://search.cpan.org/~kane/Archive-Tar/lib/Archive/Tar.pm). CPAN is a
|
|
164
|
+
wonderful resource that is worth reading through to learn more about a community
|
|
165
|
+
that wrote consistently high-calibre documentation.
|
|
166
|
+
|
|
167
|
+
### No README? No abstraction
|
|
168
|
+
|
|
169
|
+
No README means developers will need to delve into your code in order to
|
|
170
|
+
understand it.
|
|
171
|
+
|
|
172
|
+
The Perl monks have wisdom to share on the matter:
|
|
173
|
+
|
|
174
|
+
> Your documentation is complete when someone can use your module without ever
|
|
175
|
+
> having to look at its code. This is very important. This makes it possible for
|
|
176
|
+
> you to separate your module's documented interface from its internal
|
|
177
|
+
> implementation (guts). This is good because it means that you are free to
|
|
178
|
+
> change the module's internals as long as the interface remains the same.
|
|
179
|
+
>
|
|
180
|
+
> Remember: the documentation, not the code, defines what a module does.
|
|
181
|
+
> -- [Ken Williams](http://mathforum.org/ken/perl_modules.html#document)
|
|
182
|
+
|
|
183
|
+
### Key elements
|
|
184
|
+
|
|
185
|
+
Once a README is located, the brave module spelunker must scan it to discern if
|
|
186
|
+
it matches the developer's needs. This becomes essentially a series of pattern
|
|
187
|
+
matching problems for their brain to solve, where each step takes them deeper
|
|
188
|
+
into the module and its details.
|
|
189
|
+
|
|
190
|
+
Let's say, for example, my search for a 2D collision detection module leads me
|
|
191
|
+
to [`collide-2d-aabb-aabb`](https://github.com/hackergrrl/collide-2d-aabb-aabb). I
|
|
192
|
+
begin to examine it from top to bottom:
|
|
193
|
+
|
|
194
|
+
1. _Name_ -- self-explanatory names are best. `collide-2d-aabb-aabb` sounds
|
|
195
|
+
promising, though it assumes I know what an "aabb" is. If the name sounds too
|
|
196
|
+
vague or unrelated, it may be a signal to move on.
|
|
197
|
+
|
|
198
|
+
2. _One-liner_ -- having a one-liner that describes the module is useful for
|
|
199
|
+
getting an idea of what the module does in slightly greater detail.
|
|
200
|
+
`collide-2d-aabb-aabb` says it
|
|
201
|
+
|
|
202
|
+
> Determines whether a moving axis-aligned bounding box (AABB) collides with
|
|
203
|
+
> other AABBs.
|
|
204
|
+
|
|
205
|
+
Awesome: it defines what an AABB is, and what the module does. Now to gauge how
|
|
206
|
+
well it'd fit into my code:
|
|
207
|
+
|
|
208
|
+
3. _Usage_ -- rather than starting to delve into the API docs, it'd be great to
|
|
209
|
+
see what the module looks like in action. I can quickly determine whether the
|
|
210
|
+
example JS fits the desired style and problem. People have lots of opinions
|
|
211
|
+
on things like promises/callbacks and ES6. If it does fit the bill, then I
|
|
212
|
+
can proceed to greater detail.
|
|
213
|
+
|
|
214
|
+
4. _API_ -- the name, description, and usage of this module all sound appealing
|
|
215
|
+
to me. I'm very likely to use this module at this point. I just need to scan
|
|
216
|
+
the API to make sure it does exactly what I need and that it will integrate
|
|
217
|
+
easily into my codebase. The API section ought to detail the module's objects
|
|
218
|
+
and functions, their signatures, return types, callbacks, and events in
|
|
219
|
+
detail. Types should be included where they aren't obvious. Caveats should be
|
|
220
|
+
made clear.
|
|
221
|
+
|
|
222
|
+
5. _Installation_ -- if I've read this far down, then I'm sold on trying out the
|
|
223
|
+
module. If there are nonstandard installation notes, here's where they'd go,
|
|
224
|
+
but even if it's just a regular `npm install`, I'd like to see that mentioned,
|
|
225
|
+
too. New users start using Node all the time, so having a link to npmjs.org
|
|
226
|
+
and an install command provides them the resources to figure out how Node
|
|
227
|
+
modules work.
|
|
228
|
+
|
|
229
|
+
6. _License_ -- most modules put this at the very bottom, but this might
|
|
230
|
+
actually be better to have higher up; you're likely to exclude a module VERY
|
|
231
|
+
quickly if it has a license incompatible with your work. I generally stick to
|
|
232
|
+
the MIT/BSD/X11/ISC flavours. If you have a non-permissive license, stick it
|
|
233
|
+
at the very top of the module to prevent any confusion.
|
|
234
|
+
|
|
235
|
+
## Cognitive funneling
|
|
236
|
+
|
|
237
|
+
The ordering of the above was not chosen at random.
|
|
238
|
+
|
|
239
|
+
Module consumers use many modules, and need to look at many modules.
|
|
240
|
+
|
|
241
|
+
Once you've looked at hundreds of modules, you begin to notice that the mind
|
|
242
|
+
benefits from predictable patterns.
|
|
243
|
+
|
|
244
|
+
You also start to build out your own personal heuristic for what information you
|
|
245
|
+
want, and what red flags disqualify modules quickly.
|
|
246
|
+
|
|
247
|
+
Thus, it follows that in a README it is desirable to have:
|
|
248
|
+
|
|
249
|
+
1. a predictable format
|
|
250
|
+
2. certain key elements present
|
|
251
|
+
|
|
252
|
+
You don't need to use _this_ format, but try to be consistent to save your users
|
|
253
|
+
precious cognitive cycles.
|
|
254
|
+
|
|
255
|
+
The ordering presented here is lovingly referred to as "cognitive funneling,"
|
|
256
|
+
and can be imagined as a funnel held upright, where the widest end contains the
|
|
257
|
+
broadest more pertinent details, and moving deeper down into the funnel presents
|
|
258
|
+
more specific details that are pertinent for only a reader who is interested
|
|
259
|
+
enough in your work to have reached that deeply in the document. Finally, the
|
|
260
|
+
bottom can be reserved for details only for those intrigued by the deeper
|
|
261
|
+
context of the work (background, credits, biblio, etc.).
|
|
262
|
+
|
|
263
|
+
Once again, the Perl monks have wisdom to share on the subject:
|
|
264
|
+
|
|
265
|
+
> The level of detail in Perl module documentation generally goes from
|
|
266
|
+
> less detailed to more detailed. Your SYNOPSIS section should
|
|
267
|
+
> contain a minimal example of use (perhaps as little as one line of
|
|
268
|
+
> code; skip the unusual use cases or anything not needed by most
|
|
269
|
+
> users); the DESCRIPTION should describe your module in broad terms,
|
|
270
|
+
> generally in just a few paragraphs; more detail of the module's
|
|
271
|
+
> routines or methods, lengthy code examples, or other in-depth
|
|
272
|
+
> material should be given in subsequent sections.
|
|
273
|
+
>
|
|
274
|
+
> Ideally, someone who's slightly familiar with your module should be
|
|
275
|
+
> able to refresh their memory without hitting "page down". As your
|
|
276
|
+
> reader continues through the document, they should receive a
|
|
277
|
+
> progressively greater amount of knowledge.
|
|
278
|
+
> -- from `perlmodstyle`
|
|
279
|
+
|
|
280
|
+
## Care about people's time
|
|
281
|
+
|
|
282
|
+
Awesome; the ordering of these key elements should be decided by how quickly
|
|
283
|
+
they let someone 'short circuit' and bail on your module.
|
|
284
|
+
|
|
285
|
+
This sounds bleak, doesn't it? But think about it: your job, when you're doing
|
|
286
|
+
it with optimal altruism in mind, isn't to "sell" people on your work. It's to
|
|
287
|
+
let them evaluate what your creation does as objectively as possible, and decide
|
|
288
|
+
whether it meets their needs or not -- not to, say, maximize your downloads or
|
|
289
|
+
userbase.
|
|
290
|
+
|
|
291
|
+
This mindset doesn't appeal to everyone; it requires checking your ego at the
|
|
292
|
+
door and letting the work speak for itself as much as possible. Your only job is
|
|
293
|
+
to describe its promise as succinctly as you can, so module spelunkers can
|
|
294
|
+
either use your work when it's a fit, or move on to something else that does.
|
|
295
|
+
|
|
296
|
+
## Call to arms!
|
|
297
|
+
|
|
298
|
+
Go forth, brave module spelunker, and make your work discoverable and usable
|
|
299
|
+
through excellent documentation!
|
|
300
|
+
|
|
301
|
+
## Bonus: other good practices
|
|
302
|
+
|
|
303
|
+
Outside of the key points of the article, there are other practices you can
|
|
304
|
+
follow (or not follow) to raise your README's quality bar even further and
|
|
305
|
+
maximize its usefulness to others:
|
|
306
|
+
|
|
307
|
+
1. Consider including a **Background** section if your module depends on
|
|
308
|
+
important but not widely known abstractions or other ecosystems. The function
|
|
309
|
+
of [`bisecting-between`](https://github.com/hackergrrl/bisecting-between) is not
|
|
310
|
+
immediately obvious from its name, so it has a detailed _Background_ section
|
|
311
|
+
to define and link to the big concepts and abstractions one needs to
|
|
312
|
+
understand to use and grok it. This is also a great place to explain the
|
|
313
|
+
module's motivation if similar modules already exist on npm.
|
|
314
|
+
|
|
315
|
+
2. Aggressively linkify! If you talk about other modules, ideas, or people, make
|
|
316
|
+
that reference text a link so that visitors can more easily grok your module
|
|
317
|
+
and the ideas it builds on. Few modules exist in a vacuum: all work comes
|
|
318
|
+
from other work, so it pays to help users follow your module's history and
|
|
319
|
+
inspiration.
|
|
320
|
+
|
|
321
|
+
3. Include information on types of arguments and return parameters if it's not
|
|
322
|
+
obvious. Prefer convention wherever possible (`cb` probably means callback
|
|
323
|
+
function, `num` probably means a `Number`, etc.).
|
|
324
|
+
|
|
325
|
+
4. Include the example code in **Usage** as a file in your repo -- maybe as
|
|
326
|
+
`example.js`. It's great to have README code that users can actually run if
|
|
327
|
+
they clone the repository.
|
|
328
|
+
|
|
329
|
+
5. Be judicious in your use of badges. They're easy to
|
|
330
|
+
[abuse](https://github.com/angular/angular). They can also be a breeding
|
|
331
|
+
ground for bikeshedding and endless debate. They add visual noise to your
|
|
332
|
+
README and generally only function if the user is reading your Markdown in a
|
|
333
|
+
browser online, since the images are often hosted elsewhere on the
|
|
334
|
+
internet. For each badge, consider: "what real value is this badge providing
|
|
335
|
+
to the typical viewer of this README?" Do you have a CI badge to show build/test
|
|
336
|
+
status? This signal would better reach important parties by emailing
|
|
337
|
+
maintainers or automatically creating an issue. Always consider the
|
|
338
|
+
audience of the data in your README and ask yourself if there's a flow for
|
|
339
|
+
that data that can better reach its intended audience.
|
|
340
|
+
|
|
341
|
+
6. API formatting is highly bikesheddable. Use whatever format you think is
|
|
342
|
+
clearest, but make sure your format expresses important subtleties:
|
|
343
|
+
|
|
344
|
+
a. which parameters are optional, and their defaults
|
|
345
|
+
|
|
346
|
+
b. type information, where it is not obvious from convention
|
|
347
|
+
|
|
348
|
+
c. for `opts` object parameters, all keys and values that are accepted
|
|
349
|
+
|
|
350
|
+
d. don't shy away from providing a tiny example of an API function's use if
|
|
351
|
+
it is not obvious or fully covered in the **Usage** section.
|
|
352
|
+
However, this can also be a strong signal that the function is too complex
|
|
353
|
+
and needs to be refactored, broken into smaller functions, or removed
|
|
354
|
+
altogether
|
|
355
|
+
|
|
356
|
+
e. aggressively linkify specialized terminology! In markdown you can keep
|
|
357
|
+
[footnotes](https://daringfireball.net/projects/markdown/syntax#link) at
|
|
358
|
+
the bottom of your document, so referring to them several times throughout
|
|
359
|
+
becomes cheap. Some of my personal preferences on API formatting can be
|
|
360
|
+
found
|
|
361
|
+
[here](https://github.com/hackergrrl/common-readme/blob/master/api_formatting.md)
|
|
362
|
+
|
|
363
|
+
7. If your module is a small collection of stateless functions, having a
|
|
364
|
+
**Usage** section as a [Node REPL
|
|
365
|
+
session](https://github.com/hackergrrl/bisecting-between#example) of function
|
|
366
|
+
calls and results might communicate usage more clearly than a source code
|
|
367
|
+
file to run.
|
|
368
|
+
|
|
369
|
+
8. If your module provides a CLI (command line interface) instead of (or in
|
|
370
|
+
addition to) a programmatic API, show usage examples as command invocations
|
|
371
|
+
and their output. If you create or modify a file, `cat` it to demonstrate
|
|
372
|
+
the change before and after.
|
|
373
|
+
|
|
374
|
+
9. Don't forget to use `package.json`
|
|
375
|
+
[keywords](https://docs.npmjs.com/files/package.json#keywords) to direct
|
|
376
|
+
module spelunkers to your doorstep.
|
|
377
|
+
|
|
378
|
+
10. The more you change your API, the more work you need to exert updating
|
|
379
|
+
documentation -- the implication here is that you should keep your APIs
|
|
380
|
+
small and concretely defined early on. Requirements change over time, but
|
|
381
|
+
instead of front-loading assumptions into the APIs of your modules, load
|
|
382
|
+
them up one level of abstraction: the module set itself. If the requirements
|
|
383
|
+
_do_ change and 'do-one-concrete-thing' no longer makes sense, then simply
|
|
384
|
+
write a new module that does the thing you need. The 'do-one-concrete-thing'
|
|
385
|
+
module remains a valid and valuable model for the npm ecosystem, and your
|
|
386
|
+
course correction cost you nothing but a simple substitution of one module for
|
|
387
|
+
another.
|
|
388
|
+
|
|
389
|
+
11. Finally, please remember that your version control repository and its
|
|
390
|
+
embedded README will outlive your [repository host](https://github.com) and
|
|
391
|
+
any of the things you hyperlink to -- especially images -- so _inline_ anything
|
|
392
|
+
that is essential to future users grokking your work.
|
|
393
|
+
|
|
394
|
+
## Bonus: _common-readme_
|
|
395
|
+
|
|
396
|
+
Not coincidentally, this is also the format used by
|
|
397
|
+
[**common-readme**](https://github.com/hackergrrl/common-readme), a set of README
|
|
398
|
+
guidelines and handy command-line generator. If you like what's written here,
|
|
399
|
+
you may save some time writing READMEs with `common-readme`. You'll find
|
|
400
|
+
real module examples with this format, too.
|
|
401
|
+
|
|
402
|
+
You may also enjoy
|
|
403
|
+
[standard-readme](https://github.com/richardlitt/standard-readme), which is a
|
|
404
|
+
more structured, lintable take on a common README format.
|
|
405
|
+
|
|
406
|
+
## Bonus: Exemplars
|
|
407
|
+
|
|
408
|
+
Theory is well and good, but what do excellent READMEs look like? Here are some
|
|
409
|
+
that I think embody the principles of this article well:
|
|
410
|
+
|
|
411
|
+
- https://github.com/hackergrrl/ice-box
|
|
412
|
+
- https://github.com/substack/quote-stream
|
|
413
|
+
- https://github.com/feross/bittorrent-dht
|
|
414
|
+
- https://github.com/mikolalysenko/box-intersect
|
|
415
|
+
- https://github.com/freeman-lab/pixel-grid
|
|
416
|
+
- https://github.com/mafintosh/torrent-stream
|
|
417
|
+
- https://github.com/pull-stream/pull-stream
|
|
418
|
+
- https://github.com/substack/tape
|
|
419
|
+
- https://github.com/yoshuawuyts/vmd
|
|
420
|
+
|
|
421
|
+
## Bonus: The README Checklist
|
|
422
|
+
|
|
423
|
+
A helpful checklist to gauge how your README is coming along:
|
|
424
|
+
|
|
425
|
+
- [ ] One-liner explaining the purpose of the module
|
|
426
|
+
- [ ] Necessary background context & links
|
|
427
|
+
- [ ] Potentially unfamiliar terms link to informative sources
|
|
428
|
+
- [ ] Clear, _runnable_ example of usage
|
|
429
|
+
- [ ] Installation instructions
|
|
430
|
+
- [ ] Extensive API documentation
|
|
431
|
+
- [ ] Performs [cognitive funneling](https://github.com/hackergrrl/art-of-readme#cognitive-funneling)
|
|
432
|
+
- [ ] Caveats and limitations mentioned up-front
|
|
433
|
+
- [ ] Doesn't rely on images to relay critical information
|
|
434
|
+
- [ ] License
|
|
435
|
+
|
|
436
|
+
## The author
|
|
437
|
+
|
|
438
|
+
Hi, I'm [Kira](http://kira.solar).
|
|
439
|
+
|
|
440
|
+
This little project began back in May in Berlin at squatconf, where I was
|
|
441
|
+
digging into how Perl monks write their documentation and also lamenting the
|
|
442
|
+
state of READMEs in the Node ecosystem. It spurred me to create
|
|
443
|
+
[common-readme](https://github.com/hackergrrl/common-readme). The "README Tips"
|
|
444
|
+
section overflowed with tips though, which I decided could be usefully collected
|
|
445
|
+
into an article about writing READMEs. Thus, Art of README was born!
|
|
446
|
+
|
|
447
|
+
## Further Reading
|
|
448
|
+
|
|
449
|
+
- [README-Driven Development](http://tom.preston-werner.com/2010/08/23/readme-driven-development.html)
|
|
450
|
+
- [Documentation First](http://joeyh.name/blog/entry/documentation_first/)
|
|
451
|
+
|
|
452
|
+
## Footnotes
|
|
453
|
+
|
|
454
|
+
1. <a name="footnote-1"></a>Thanks,
|
|
455
|
+
[Sixes666](https://www.reddit.com/r/node/comments/55eto9/nodejs_the_art_of_readme/d8akpz6)!
|
|
456
|
+
|
|
457
|
+
2. <a name="footnote-2"></a>See [The Jargon File](http://catb.org/~esr/jargon/html/R/README-file.html).
|
|
458
|
+
However, most systems today will not sort capitals before all lowercase
|
|
459
|
+
characters, reducing this convention's usefulness to just the visual
|
|
460
|
+
strikingness of all-caps.
|
|
461
|
+
|
|
462
|
+
## Credits
|
|
463
|
+
|
|
464
|
+
A heartfelt thank you to [@mafintosh](https://github.com/mafintosh) and
|
|
465
|
+
[@feross](https://github.com/feross) for the encouragement I needed to get this
|
|
466
|
+
idea off the ground and start writing!
|
|
467
|
+
|
|
468
|
+
Thank you to the following awesome readers for noticing errors and sending me
|
|
469
|
+
PRs :heart: :
|
|
470
|
+
|
|
471
|
+
- [@ungoldman](https://github.com/ungoldman)
|
|
472
|
+
- [@boidolr](https://github.com/boidolr)
|
|
473
|
+
- [@imjoehaines](https://github.com/imjoehaines)
|
|
474
|
+
- [@radarhere](https://github.com/radarhere)
|
|
475
|
+
- [@joshmanders](https://github.com/joshmanders)
|
|
476
|
+
- [@ddbeck](https://github.com/ddbeck)
|
|
477
|
+
- [@RichardLitt](https://github.com/RichardLitt)
|
|
478
|
+
- [@StevenMaude](https://github.com/StevenMaude)
|
|
479
|
+
- [@KrishMunot](https://github.com/KrishMunot)
|
|
480
|
+
- [@chesterhow](https://github.com/chesterhow)
|
|
481
|
+
- [@sjsyrek](https://github.com/sjsyrek)
|
|
482
|
+
- [@thenickcox](https://github.com/thenickcox)
|
|
483
|
+
|
|
484
|
+
Thank you to [@qihaiyan](https://github.com/qihaiyan) for translating Art of
|
|
485
|
+
README to Chinese! The following users also made contributions:
|
|
486
|
+
|
|
487
|
+
- [@BrettDong](https://github.com/brettdong) for revising punctuation in Chinese version.
|
|
488
|
+
- [@Alex-fun](https://github.com/Alex-fun)
|
|
489
|
+
- [@HmyBmny](https://github.com/HmyBmny)
|
|
490
|
+
- [@vra](https://github.com/vra)
|
|
491
|
+
|
|
492
|
+
Thank you to [@lennonjesus](https://github.com/lennonjesus) for translating Art
|
|
493
|
+
of README to Brazilian Portuguese! The following users also made contributions:
|
|
494
|
+
|
|
495
|
+
- [@rectius](https://github.com/rectius)
|
|
496
|
+
|
|
497
|
+
Thank you to [@jabiinfante](https://github.com/jabiinfante) for translating Art
|
|
498
|
+
of README to Spanish!
|
|
499
|
+
|
|
500
|
+
Thank you to [@Ryuno-Ki](https://github.com/Ryuno-Ki) for translating Art of
|
|
501
|
+
README to German! The following users also made contributions:
|
|
502
|
+
|
|
503
|
+
- [@randomC0der](https://github.com/randomC0der)
|
|
504
|
+
|
|
505
|
+
Thank you to [@Manfred Madelaine](https://github.com/Manfred-Madelaine-pro) and
|
|
506
|
+
[@Ruben Madelaine](https://github.com/Ruben-Madelaine)
|
|
507
|
+
for translating Art of README to French!
|
|
508
|
+
|
|
509
|
+
## Other Resources
|
|
510
|
+
|
|
511
|
+
Some readers have suggested other useful resources for README composition:
|
|
512
|
+
|
|
513
|
+
- [Software Release Practice](https://tldp.org/HOWTO/Software-Release-Practice-HOWTO/distpractice.html#readme)
|
|
514
|
+
- [GNU Releases](https://www.gnu.org/prep/standards/html_node/Releases.html#index-README-file)
|
|
515
|
+
|
|
516
|
+
## License
|
|
517
|
+
|
|
518
|
+
[Creative Commons Attribution License](http://creativecommons.org/licenses/by/2.0/)
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
# Make a README
|
|
2
|
+
|
|
3
|
+
> Source: [makeareadme.com](https://www.makeareadme.com) by Danny Guo
|
|
4
|
+
>
|
|
5
|
+
> "Because no one can read your mind (yet)"
|
|
6
|
+
|
|
7
|
+
## README 101
|
|
8
|
+
|
|
9
|
+
### What is it?
|
|
10
|
+
|
|
11
|
+
A README is a text file that introduces and explains a project. It contains information that is commonly required to understand what the project is about.
|
|
12
|
+
|
|
13
|
+
### Why should I make it?
|
|
14
|
+
|
|
15
|
+
It's an easy way to answer questions that your audience will likely have regarding how to install and use your project and also how to collaborate with you.
|
|
16
|
+
|
|
17
|
+
### Who should make it?
|
|
18
|
+
|
|
19
|
+
Anyone who is working on a programming project, especially if you want others to use it or contribute.
|
|
20
|
+
|
|
21
|
+
### When should I make it?
|
|
22
|
+
|
|
23
|
+
Definitely before you show a project to other people or make it public. You might want to get into the habit of making it the first file you create in a new project.
|
|
24
|
+
|
|
25
|
+
### Where should I put it?
|
|
26
|
+
|
|
27
|
+
In the top level directory of the project. This is where someone who is new to your project will start out. Code hosting services such as GitHub, Bitbucket, and GitLab will also look for your README and display it along with the list of files and directories in your project.
|
|
28
|
+
|
|
29
|
+
### How should I make it?
|
|
30
|
+
|
|
31
|
+
While READMEs can be written in any text file format, the most common one that is used nowadays is Markdown. It allows you to add some lightweight formatting. You can learn more about it at the [CommonMark website](https://commonmark.org/).
|
|
32
|
+
|
|
33
|
+
## Suggestions for a Good README
|
|
34
|
+
|
|
35
|
+
Every project is different, so consider which of these sections apply to yours. Also keep in mind that while a README can be too long and detailed, **too long is better than too short**. If you think your README is too long, consider utilizing another form of documentation rather than cutting out information.
|
|
36
|
+
|
|
37
|
+
### Name
|
|
38
|
+
|
|
39
|
+
Choose a self-explaining name for your project.
|
|
40
|
+
|
|
41
|
+
### Description
|
|
42
|
+
|
|
43
|
+
Let people know what your project can do specifically. Provide context and add a link to any reference visitors might be unfamiliar with. A list of **Features** or a **Background** subsection can also be added here. If there are alternatives to your project, this is a good place to list differentiating factors.
|
|
44
|
+
|
|
45
|
+
### Badges
|
|
46
|
+
|
|
47
|
+
On some READMEs, you may see small images that convey metadata, such as whether or not all the tests are passing for the project. You can use [Shields.io](http://shields.io/) to add some to your README. Many services also have instructions for adding a badge.
|
|
48
|
+
|
|
49
|
+
### Visuals
|
|
50
|
+
|
|
51
|
+
Depending on what you are making, it can be a good idea to include screenshots or even a video (you'll frequently see GIFs rather than actual videos). Tools like [ttygif](https://github.com/icholy/ttygif) can help, but check out [Asciinema](https://asciinema.org/) for a more sophisticated method.
|
|
52
|
+
|
|
53
|
+
### Installation
|
|
54
|
+
|
|
55
|
+
Within a particular ecosystem, there may be a common way of installing things, such as using Yarn, NuGet, or Homebrew. However, consider the possibility that whoever is reading your README is a novice and would like more guidance. Listing specific steps helps remove ambiguity and gets people to using your project as quickly as possible. If it only runs in a specific context like a particular programming language version or operating system or has dependencies that have to be installed manually, also add a **Requirements** subsection.
|
|
56
|
+
|
|
57
|
+
### Usage
|
|
58
|
+
|
|
59
|
+
Use examples liberally, and show the expected output if you can. It's helpful to have inline the smallest example of usage that you can demonstrate, while providing links to more sophisticated examples if they are too long to reasonably include in the README.
|
|
60
|
+
|
|
61
|
+
### Support
|
|
62
|
+
|
|
63
|
+
Tell people where they can go to for help. It can be any combination of an issue tracker, a chat room, an email address, etc.
|
|
64
|
+
|
|
65
|
+
### Roadmap
|
|
66
|
+
|
|
67
|
+
If you have ideas for releases in the future, it is a good idea to list them in the README.
|
|
68
|
+
|
|
69
|
+
### Contributing
|
|
70
|
+
|
|
71
|
+
State if you are open to contributions and what your requirements are for accepting them.
|
|
72
|
+
|
|
73
|
+
For people who want to make changes to your project, it's helpful to have some documentation on how to get started. Perhaps there is a script that they should run or some environment variables that they need to set. Make these steps explicit. These instructions could also be useful to your future self.
|
|
74
|
+
|
|
75
|
+
You can also document commands to lint the code or run tests. These steps help to ensure high code quality and reduce the likelihood that the changes inadvertently break something. Having instructions for running tests is especially helpful if it requires external setup, such as starting a Selenium server for testing in a browser.
|
|
76
|
+
|
|
77
|
+
### Authors and Acknowledgment
|
|
78
|
+
|
|
79
|
+
Show your appreciation to those who have contributed to the project.
|
|
80
|
+
|
|
81
|
+
### License
|
|
82
|
+
|
|
83
|
+
For open source projects, say how it is licensed.
|
|
84
|
+
|
|
85
|
+
### Project Status
|
|
86
|
+
|
|
87
|
+
If you have run out of energy or time for your project, put a note at the top of the README saying that development has slowed down or stopped completely. Someone may choose to fork your project or volunteer to step in as a maintainer or owner, allowing your project to keep going. You can also make an explicit request for maintainers.
|
|
88
|
+
|
|
89
|
+
## FAQ
|
|
90
|
+
|
|
91
|
+
### Is there a standard README format?
|
|
92
|
+
|
|
93
|
+
Not all of the suggestions here will make sense for every project, so it's really up to the developers what information should be included in the README.
|
|
94
|
+
|
|
95
|
+
### What should the README file be named?
|
|
96
|
+
|
|
97
|
+
`README.md` (or a different file extension if you choose to use a non-Markdown file format). It is traditionally uppercase so that it is more prominent, but it's not a big deal if you think it looks better lowercase.
|
|
98
|
+
|
|
99
|
+
## What's Next?
|
|
100
|
+
|
|
101
|
+
### More Documentation
|
|
102
|
+
|
|
103
|
+
A README is a crucial but basic way of documenting your project. While every project should at least have a README, more involved ones can also benefit from a wiki or a dedicated documentation website. Tools include:
|
|
104
|
+
|
|
105
|
+
- [Docusaurus](https://docusaurus.io/)
|
|
106
|
+
- [GitBook](https://www.gitbook.com/)
|
|
107
|
+
- [MkDocs](https://www.mkdocs.org/)
|
|
108
|
+
- [Read the Docs](https://readthedocs.org/)
|
|
109
|
+
- [Docsify](https://docsify.js.org/)
|
|
110
|
+
|
|
111
|
+
### Changelog
|
|
112
|
+
|
|
113
|
+
A [changelog](https://en.wikipedia.org/wiki/Changelog) is another file that is very useful for programming projects. See [Keep a Changelog](http://keepachangelog.com/).
|
|
114
|
+
|
|
115
|
+
### Contributing Guidelines
|
|
116
|
+
|
|
117
|
+
Just having a "Contributing" section in your README is a good start. Another approach is to split off your guidelines into their own file (`CONTRIBUTING.md`). If you use GitHub and have this file, then anyone who creates an issue or opens a pull request will get a link to it.
|
|
118
|
+
|
|
119
|
+
You can also create an issue template and a pull request template. These files give your users and collaborators templates to fill in with the information that you'll need to properly respond.
|