@tanstack/create 0.49.2 → 0.59.4
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/CHANGELOG.md +603 -0
- package/dist/add-ons.js +42 -2
- package/dist/add-to-app.js +36 -7
- package/dist/custom-add-ons/add-on.js +2 -26
- package/dist/custom-add-ons/starter.js +1 -2
- package/dist/file-helpers.js +11 -10
- package/dist/frameworks/react/add-ons/ai/assets/src/data/demo-guitars.ts +93 -0
- package/dist/frameworks/react/add-ons/ai/assets/src/hooks/demo-useAudioRecorder.ts +85 -0
- package/dist/frameworks/react/add-ons/ai/assets/src/hooks/demo-useTTS.ts +78 -0
- package/dist/frameworks/react/add-ons/ai/assets/src/lib/demo-ai-hook.ts +22 -0
- package/dist/frameworks/react/add-ons/ai/assets/src/lib/demo-guitar-tools.ts +40 -0
- package/dist/frameworks/react/add-ons/ai/assets/src/routes/demo/api.ai.chat.ts +99 -0
- package/dist/frameworks/react/add-ons/ai/assets/src/routes/demo/api.ai.image.ts +72 -0
- package/dist/frameworks/react/add-ons/ai/assets/src/routes/demo/api.ai.structured.ts +136 -0
- package/dist/frameworks/react/add-ons/ai/assets/src/routes/demo/api.ai.transcription.ts +89 -0
- package/dist/frameworks/react/add-ons/ai/assets/src/routes/demo/api.ai.tts.ts +81 -0
- package/dist/frameworks/react/add-ons/ai/info.json +1 -1
- package/dist/frameworks/react/add-ons/apollo-client/info.json +1 -1
- package/dist/frameworks/react/add-ons/better-auth/assets/src/lib/auth-client.ts +3 -0
- package/dist/frameworks/react/add-ons/better-auth/assets/src/lib/auth.ts +9 -0
- package/dist/frameworks/react/add-ons/better-auth/assets/src/routes/api/auth/$.ts +11 -0
- package/dist/frameworks/react/add-ons/better-auth/info.json +0 -2
- package/dist/frameworks/react/add-ons/clerk/info.json +0 -1
- package/dist/frameworks/react/add-ons/convex/assets/convex/schema.ts +14 -0
- package/dist/frameworks/react/add-ons/convex/assets/convex/todos.ts +43 -0
- package/dist/frameworks/react/add-ons/db/assets/src/db-collections/index.ts +20 -0
- package/dist/frameworks/react/add-ons/db/assets/src/hooks/demo.useChat.ts +62 -0
- package/dist/frameworks/react/add-ons/db/assets/src/routes/demo/db-chat-api.ts +83 -0
- package/dist/frameworks/react/add-ons/db/info.json +1 -1
- package/dist/frameworks/react/add-ons/drizzle/info.json +1 -1
- package/dist/frameworks/react/add-ons/drizzle/package.json.ejs +4 -0
- package/dist/frameworks/react/add-ons/form/assets/src/hooks/demo.form-context.ts +4 -0
- package/dist/frameworks/react/add-ons/form/assets/src/hooks/demo.form.ts +22 -0
- package/dist/frameworks/react/add-ons/mcp/assets/src/mcp-todos.ts +51 -0
- package/dist/frameworks/react/add-ons/mcp/assets/src/routes/demo/api.mcp-todos.ts +37 -0
- package/dist/frameworks/react/add-ons/mcp/assets/src/routes/mcp.ts +53 -0
- package/dist/frameworks/react/add-ons/mcp/assets/src/utils/mcp-handler.ts +61 -0
- package/dist/frameworks/react/add-ons/mcp/info.json +1 -2
- package/dist/frameworks/react/add-ons/neon/assets/neon-vite-plugin.ts +10 -0
- package/dist/frameworks/react/add-ons/neon/assets/src/db.ts +13 -0
- package/dist/frameworks/react/add-ons/neon/info.json +1 -2
- package/dist/frameworks/react/add-ons/oRPC/assets/src/orpc/client.ts +29 -0
- package/dist/frameworks/react/add-ons/oRPC/assets/src/orpc/router/index.ts +6 -0
- package/dist/frameworks/react/add-ons/oRPC/assets/src/orpc/router/todos.ts +20 -0
- package/dist/frameworks/react/add-ons/oRPC/assets/src/orpc/schema.ts +6 -0
- package/dist/frameworks/react/add-ons/oRPC/assets/src/polyfill.ts +21 -0
- package/dist/frameworks/react/add-ons/oRPC/assets/src/routes/api.$.ts +77 -0
- package/dist/frameworks/react/add-ons/oRPC/assets/src/routes/api.rpc.$.ts +29 -0
- package/dist/frameworks/react/add-ons/oRPC/info.json +1 -1
- package/dist/frameworks/react/add-ons/paraglide/info.json +1 -1
- package/dist/frameworks/react/add-ons/prisma/info.json +1 -1
- package/dist/frameworks/react/add-ons/prisma/package.json.ejs +4 -0
- package/dist/frameworks/react/add-ons/sentry/info.json +1 -2
- package/dist/frameworks/react/add-ons/shadcn/assets/src/lib/utils.ts +6 -0
- package/dist/frameworks/react/add-ons/store/assets/src/lib/demo-store.ts +13 -0
- package/dist/frameworks/react/add-ons/storybook/assets/_dot_storybook/main.ts +17 -0
- package/dist/frameworks/react/add-ons/storybook/assets/_dot_storybook/preview.ts +15 -0
- package/dist/frameworks/react/add-ons/storybook/assets/src/components/storybook/button.stories.ts +67 -0
- package/dist/frameworks/react/add-ons/storybook/assets/src/components/storybook/index.ts +14 -0
- package/dist/frameworks/react/add-ons/storybook/assets/src/components/storybook/input.stories.ts +43 -0
- package/dist/frameworks/react/add-ons/storybook/assets/src/components/storybook/radio-group.stories.ts +53 -0
- package/dist/frameworks/react/add-ons/storybook/assets/src/components/storybook/slider.stories.ts +55 -0
- package/dist/frameworks/react/add-ons/strapi/assets/src/lib/strapiClient.ts +7 -0
- package/dist/frameworks/react/add-ons/t3env/assets/src/env.ts +39 -0
- package/dist/frameworks/react/add-ons/tRPC/assets/src/integrations/trpc/init.ts +9 -0
- package/dist/frameworks/react/add-ons/tRPC/assets/src/integrations/trpc/react.ts +4 -0
- package/dist/frameworks/react/add-ons/tRPC/assets/src/integrations/trpc/router.ts +27 -0
- package/dist/frameworks/react/add-ons/tRPC/info.json +1 -1
- package/dist/frameworks/react/add-ons/table/assets/src/data/demo-table-data.ts +50 -0
- package/dist/frameworks/react/add-ons/tanstack-query/assets/src/integrations/tanstack-query/root-provider.tsx.ejs +1 -29
- package/dist/frameworks/react/add-ons/workos/info.json +0 -1
- package/dist/frameworks/react/examples/events/assets/content-collections.ts +56 -0
- package/dist/frameworks/react/examples/events/assets/src/lib/conference-ai-hook.ts +26 -0
- package/dist/frameworks/react/examples/events/assets/src/lib/conference-tools.ts +210 -0
- package/dist/frameworks/react/examples/events/assets/src/lib/utils.ts +6 -0
- package/dist/frameworks/react/examples/events/assets/src/routes/api.remy-chat.ts +121 -0
- package/dist/frameworks/react/examples/resume/assets/content-collections.ts +36 -0
- package/dist/frameworks/react/examples/resume/assets/src/lib/resume-ai-hook.ts +21 -0
- package/dist/frameworks/react/examples/resume/assets/src/lib/resume-tools.ts +165 -0
- package/dist/frameworks/react/examples/resume/assets/src/lib/utils.ts +6 -0
- package/dist/frameworks/react/examples/resume/assets/src/routes/api.resume-chat.ts +110 -0
- package/dist/frameworks/react/hosts/cloudflare/info.json +0 -1
- package/dist/frameworks/react/hosts/netlify/info.json +0 -1
- package/dist/frameworks/react/hosts/nitro/info.json +0 -1
- package/dist/frameworks/react/hosts/railway/info.json +0 -1
- package/dist/frameworks/react/index.js +1 -6
- package/dist/frameworks/react/project/base/README.md.ejs +86 -436
- package/dist/frameworks/react/project/base/_dot_gitignore +4 -0
- package/dist/frameworks/react/project/base/package.json +8 -5
- package/dist/frameworks/react/project/base/src/components/Header.tsx.ejs +2 -32
- package/dist/frameworks/react/project/base/src/routes/__root.tsx.ejs +4 -44
- package/dist/frameworks/react/project/base/src/routes/index.tsx.ejs +99 -61
- package/dist/frameworks/react/project/base/src/styles.css.ejs +3 -3
- package/dist/frameworks/react/project/base/tsconfig.json.ejs +1 -1
- package/dist/frameworks/react/project/base/vite.config.ts.ejs +33 -27
- package/dist/frameworks/react/project/packages.json +2 -2
- package/dist/frameworks/solid/add-ons/better-auth/assets/src/lib/auth-client.ts +3 -0
- package/dist/frameworks/solid/add-ons/better-auth/assets/src/lib/auth.ts +9 -0
- package/dist/frameworks/solid/add-ons/better-auth/assets/src/routes/api/auth/$.ts +11 -0
- package/dist/frameworks/solid/add-ons/better-auth/info.json +1 -1
- package/dist/frameworks/solid/add-ons/convex/assets/convex/schema.ts +14 -0
- package/dist/frameworks/solid/add-ons/convex/assets/convex/todos.ts +43 -0
- package/dist/frameworks/solid/add-ons/solid-ui/assets/src/lib/utils.ts +6 -0
- package/dist/frameworks/solid/add-ons/store/assets/src/lib/demo-store.ts +13 -0
- package/dist/frameworks/solid/add-ons/strapi/assets/src/lib/strapiClient.ts +7 -0
- package/dist/frameworks/solid/add-ons/t3env/assets/src/env.ts +39 -0
- package/dist/frameworks/solid/examples/tanchat/assets/ai-streaming-server/src/index.ts +102 -0
- package/dist/frameworks/solid/examples/tanchat/assets/src/lib/demo-store.ts +13 -0
- package/dist/frameworks/solid/examples/tanchat/assets/src/store/demo.hooks.ts +17 -0
- package/dist/frameworks/solid/examples/tanchat/assets/src/store/demo.store.ts +133 -0
- package/dist/frameworks/solid/hosts/cloudflare/info.json +0 -1
- package/dist/frameworks/solid/hosts/netlify/info.json +0 -1
- package/dist/frameworks/solid/hosts/nitro/info.json +0 -1
- package/dist/frameworks/solid/hosts/railway/info.json +0 -1
- package/dist/frameworks/solid/index.js +1 -6
- package/dist/frameworks/solid/project/base/README.md.ejs +43 -117
- package/dist/frameworks/solid/project/base/_dot_gitignore +4 -0
- package/dist/frameworks/solid/project/base/package.json +8 -3
- package/dist/frameworks/solid/project/base/src/components/Header.tsx.ejs +2 -25
- package/dist/frameworks/solid/project/base/src/routes/__root.tsx.ejs +3 -30
- package/dist/frameworks/solid/project/base/src/routes/index.tsx.ejs +97 -35
- package/dist/frameworks/solid/project/base/tsconfig.json.ejs +1 -1
- package/dist/frameworks/solid/project/base/vite.config.ts.ejs +15 -20
- package/dist/frameworks/solid/project/packages.json +2 -2
- package/dist/frameworks.js +0 -1
- package/dist/package-json.js +6 -10
- package/dist/template-file.js +21 -7
- package/dist/types/custom-add-ons/add-on.d.ts +1 -1
- package/dist/types/file-helpers.d.ts +0 -1
- package/dist/types/types.d.ts +12 -12
- package/dist/types.js +1 -2
- package/package.json +2 -2
- package/src/add-ons.ts +54 -2
- package/src/add-to-app.ts +42 -7
- package/src/custom-add-ons/add-on.ts +2 -33
- package/src/custom-add-ons/starter.ts +1 -2
- package/src/file-helpers.ts +11 -10
- package/src/frameworks/react/add-ons/ai/info.json +1 -1
- package/src/frameworks/react/add-ons/apollo-client/info.json +1 -1
- package/src/frameworks/react/add-ons/better-auth/info.json +0 -2
- package/src/frameworks/react/add-ons/clerk/info.json +0 -1
- package/src/frameworks/react/add-ons/db/info.json +1 -1
- package/src/frameworks/react/add-ons/drizzle/info.json +1 -1
- package/src/frameworks/react/add-ons/drizzle/package.json.ejs +4 -0
- package/src/frameworks/react/add-ons/mcp/info.json +1 -2
- package/src/frameworks/react/add-ons/neon/assets/neon-vite-plugin.ts +1 -1
- package/src/frameworks/react/add-ons/neon/info.json +1 -2
- package/src/frameworks/react/add-ons/oRPC/info.json +1 -1
- package/src/frameworks/react/add-ons/paraglide/info.json +1 -1
- package/src/frameworks/react/add-ons/prisma/info.json +1 -1
- package/src/frameworks/react/add-ons/prisma/package.json.ejs +4 -0
- package/src/frameworks/react/add-ons/sentry/info.json +1 -2
- package/src/frameworks/react/add-ons/tRPC/info.json +1 -1
- package/src/frameworks/react/add-ons/tanstack-query/assets/src/integrations/tanstack-query/root-provider.tsx.ejs +1 -29
- package/src/frameworks/react/add-ons/workos/info.json +0 -1
- package/src/frameworks/react/hosts/cloudflare/info.json +0 -1
- package/src/frameworks/react/hosts/netlify/info.json +0 -1
- package/src/frameworks/react/hosts/nitro/info.json +0 -1
- package/src/frameworks/react/hosts/railway/info.json +0 -1
- package/src/frameworks/react/index.ts +1 -6
- package/src/frameworks/react/project/base/README.md.ejs +86 -436
- package/src/frameworks/react/project/base/_dot_gitignore +4 -0
- package/src/frameworks/react/project/base/package.json +8 -5
- package/src/frameworks/react/project/base/src/components/Header.tsx.ejs +2 -32
- package/src/frameworks/react/project/base/src/routes/__root.tsx.ejs +4 -44
- package/src/frameworks/react/project/base/src/routes/index.tsx.ejs +99 -61
- package/src/frameworks/react/project/base/src/styles.css.ejs +3 -3
- package/src/frameworks/react/project/base/tsconfig.json.ejs +1 -1
- package/src/frameworks/react/project/base/vite.config.ts.ejs +33 -27
- package/src/frameworks/react/project/packages.json +2 -2
- package/src/frameworks/solid/add-ons/better-auth/info.json +1 -1
- package/src/frameworks/solid/hosts/cloudflare/info.json +0 -1
- package/src/frameworks/solid/hosts/netlify/info.json +0 -1
- package/src/frameworks/solid/hosts/nitro/info.json +0 -1
- package/src/frameworks/solid/hosts/railway/info.json +0 -1
- package/src/frameworks/solid/index.ts +1 -6
- package/src/frameworks/solid/project/base/README.md.ejs +43 -117
- package/src/frameworks/solid/project/base/_dot_gitignore +4 -0
- package/src/frameworks/solid/project/base/package.json +8 -3
- package/src/frameworks/solid/project/base/src/components/Header.tsx.ejs +2 -25
- package/src/frameworks/solid/project/base/src/routes/__root.tsx.ejs +3 -30
- package/src/frameworks/solid/project/base/src/routes/index.tsx.ejs +97 -35
- package/src/frameworks/solid/project/base/tsconfig.json.ejs +1 -1
- package/src/frameworks/solid/project/base/vite.config.ts.ejs +15 -20
- package/src/frameworks/solid/project/packages.json +2 -2
- package/src/frameworks.ts +0 -1
- package/src/package-json.ts +6 -10
- package/src/template-file.ts +27 -8
- package/src/types.ts +1 -2
- package/tests/add-to-app.test.ts +37 -0
- package/tests/copy-assets.test.ts +53 -0
- package/tests/file-helper.test.ts +23 -2
- package/tests/package-json.test.ts +32 -0
- package/tests/template-file.test.ts +28 -0
- package/dist/frameworks/react/add-ons/module-federation/assets/module-federation.config.js.ejs +0 -31
- package/dist/frameworks/react/add-ons/module-federation/assets/src/demo-mf-component.tsx +0 -3
- package/dist/frameworks/react/add-ons/module-federation/assets/src/demo-mf-self-contained.tsx +0 -11
- package/dist/frameworks/react/add-ons/module-federation/info.json +0 -11
- package/dist/frameworks/react/add-ons/module-federation/package.json +0 -5
- package/dist/frameworks/react/add-ons/module-federation/small-logo.svg +0 -87
- package/dist/frameworks/react/add-ons/start/assets/_dot_gitignore.append +0 -3
- package/dist/frameworks/react/add-ons/start/assets/src/router.tsx.ejs +0 -77
- package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/api.tq-todos.ts.ejs +0 -35
- package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/start.api-request.tsx.ejs +0 -68
- package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/start.css.ejs +0 -43
- package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/start.server-funcs.tsx.ejs +0 -183
- package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.data-only.tsx.ejs +0 -55
- package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.full-ssr.tsx.ejs +0 -55
- package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.index.tsx.ejs +0 -62
- package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.spa-mode.tsx.ejs +0 -62
- package/dist/frameworks/react/add-ons/start/assets/src/routes/index.tsx.ejs +0 -142
- package/dist/frameworks/react/add-ons/start/assets/src/server.ts.ejs +0 -9
- package/dist/frameworks/react/add-ons/start/assets/vite.config.ts.ejs +0 -40
- package/dist/frameworks/react/add-ons/start/info.json +0 -61
- package/dist/frameworks/react/add-ons/start/package.json +0 -12
- package/dist/frameworks/react/add-ons/start/small-logo.svg +0 -1
- package/dist/frameworks/react/project/base/index.html.ejs +0 -20
- package/dist/frameworks/react/project/base/src/App.css.ejs +0 -38
- package/dist/frameworks/react/project/base/src/App.tsx.ejs +0 -63
- package/dist/frameworks/react/project/base/src/components/Header.css.ejs +0 -18
- package/dist/frameworks/react/project/base/src/logo.svg +0 -12
- package/dist/frameworks/react/project/base/src/main.tsx.ejs +0 -166
- package/dist/frameworks/react/project/base/src/reportWebVitals.ts.ejs +0 -28
- package/dist/frameworks/solid/add-ons/module-federation/assets/module-federation.config.js.ejs +0 -27
- package/dist/frameworks/solid/add-ons/module-federation/assets/src/demo-mf-component.tsx +0 -3
- package/dist/frameworks/solid/add-ons/module-federation/assets/src/demo-mf-self-contained.tsx +0 -9
- package/dist/frameworks/solid/add-ons/module-federation/info.json +0 -10
- package/dist/frameworks/solid/add-ons/module-federation/package.json +0 -5
- package/dist/frameworks/solid/add-ons/module-federation/small-logo.svg +0 -87
- package/dist/frameworks/solid/add-ons/start/assets/public/tanstack-circle-logo.png +0 -0
- package/dist/frameworks/solid/add-ons/start/assets/public/tanstack-word-logo-white.svg +0 -1
- package/dist/frameworks/solid/add-ons/start/assets/src/router.tsx.ejs +0 -30
- package/dist/frameworks/solid/add-ons/start/assets/src/routes/demo.start.server-funcs.tsx +0 -49
- package/dist/frameworks/solid/add-ons/start/assets/src/routes/index.tsx.ejs +0 -138
- package/dist/frameworks/solid/add-ons/start/assets/vite.config.ts.ejs +0 -22
- package/dist/frameworks/solid/add-ons/start/info.json +0 -18
- package/dist/frameworks/solid/add-ons/start/package.json +0 -15
- package/dist/frameworks/solid/add-ons/start/small-logo.svg +0 -1
- package/dist/frameworks/solid/project/base/index.html.ejs +0 -20
- package/dist/frameworks/solid/project/base/src/App.css.ejs +0 -38
- package/dist/frameworks/solid/project/base/src/App.tsx.ejs +0 -34
- package/dist/frameworks/solid/project/base/src/logo.svg +0 -120
- package/dist/frameworks/solid/project/base/src/main.tsx.ejs +0 -126
- package/src/frameworks/react/add-ons/module-federation/assets/module-federation.config.js.ejs +0 -31
- package/src/frameworks/react/add-ons/module-federation/assets/src/demo-mf-component.tsx +0 -3
- package/src/frameworks/react/add-ons/module-federation/assets/src/demo-mf-self-contained.tsx +0 -11
- package/src/frameworks/react/add-ons/module-federation/info.json +0 -11
- package/src/frameworks/react/add-ons/module-federation/package.json +0 -5
- package/src/frameworks/react/add-ons/module-federation/small-logo.svg +0 -87
- package/src/frameworks/react/add-ons/start/assets/_dot_gitignore.append +0 -3
- package/src/frameworks/react/add-ons/start/assets/src/data/demo.punk-songs.ts +0 -13
- package/src/frameworks/react/add-ons/start/assets/src/router.tsx.ejs +0 -77
- package/src/frameworks/react/add-ons/start/assets/src/routes/demo/api.names.ts +0 -10
- package/src/frameworks/react/add-ons/start/assets/src/routes/demo/api.tq-todos.ts.ejs +0 -35
- package/src/frameworks/react/add-ons/start/assets/src/routes/demo/start.api-request.tsx.ejs +0 -68
- package/src/frameworks/react/add-ons/start/assets/src/routes/demo/start.css.ejs +0 -43
- package/src/frameworks/react/add-ons/start/assets/src/routes/demo/start.server-funcs.tsx.ejs +0 -183
- package/src/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.data-only.tsx.ejs +0 -55
- package/src/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.full-ssr.tsx.ejs +0 -55
- package/src/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.index.tsx.ejs +0 -62
- package/src/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.spa-mode.tsx.ejs +0 -62
- package/src/frameworks/react/add-ons/start/assets/src/routes/index.tsx.ejs +0 -142
- package/src/frameworks/react/add-ons/start/assets/src/server.ts.ejs +0 -9
- package/src/frameworks/react/add-ons/start/assets/vite.config.ts.ejs +0 -40
- package/src/frameworks/react/add-ons/start/info.json +0 -61
- package/src/frameworks/react/add-ons/start/package.json +0 -12
- package/src/frameworks/react/add-ons/start/small-logo.svg +0 -1
- package/src/frameworks/react/project/base/index.html.ejs +0 -20
- package/src/frameworks/react/project/base/src/App.css.ejs +0 -38
- package/src/frameworks/react/project/base/src/App.tsx.ejs +0 -63
- package/src/frameworks/react/project/base/src/components/Header.css.ejs +0 -18
- package/src/frameworks/react/project/base/src/logo.svg +0 -12
- package/src/frameworks/react/project/base/src/main.tsx.ejs +0 -166
- package/src/frameworks/react/project/base/src/reportWebVitals.ts.ejs +0 -28
- package/src/frameworks/solid/add-ons/module-federation/assets/module-federation.config.js.ejs +0 -27
- package/src/frameworks/solid/add-ons/module-federation/assets/src/demo-mf-component.tsx +0 -3
- package/src/frameworks/solid/add-ons/module-federation/assets/src/demo-mf-self-contained.tsx +0 -9
- package/src/frameworks/solid/add-ons/module-federation/info.json +0 -10
- package/src/frameworks/solid/add-ons/module-federation/package.json +0 -5
- package/src/frameworks/solid/add-ons/module-federation/small-logo.svg +0 -87
- package/src/frameworks/solid/add-ons/start/assets/public/tanstack-circle-logo.png +0 -0
- package/src/frameworks/solid/add-ons/start/assets/public/tanstack-word-logo-white.svg +0 -1
- package/src/frameworks/solid/add-ons/start/assets/src/router.tsx.ejs +0 -30
- package/src/frameworks/solid/add-ons/start/assets/src/routes/demo.start.server-funcs.tsx +0 -49
- package/src/frameworks/solid/add-ons/start/assets/src/routes/index.tsx.ejs +0 -138
- package/src/frameworks/solid/add-ons/start/assets/vite.config.ts.ejs +0 -22
- package/src/frameworks/solid/add-ons/start/info.json +0 -18
- package/src/frameworks/solid/add-ons/start/package.json +0 -15
- package/src/frameworks/solid/add-ons/start/small-logo.svg +0 -1
- package/src/frameworks/solid/project/base/index.html.ejs +0 -20
- package/src/frameworks/solid/project/base/src/App.css.ejs +0 -38
- package/src/frameworks/solid/project/base/src/App.tsx.ejs +0 -34
- package/src/frameworks/solid/project/base/src/logo.svg +0 -120
- package/src/frameworks/solid/project/base/src/main.tsx.ejs +0 -126
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import fs from 'node:fs'
|
|
2
|
+
|
|
3
|
+
const todosPath = './mcp-todos.json'
|
|
4
|
+
|
|
5
|
+
// In-memory todos storage
|
|
6
|
+
const todos = fs.existsSync(todosPath)
|
|
7
|
+
? JSON.parse(fs.readFileSync(todosPath, 'utf8'))
|
|
8
|
+
: [
|
|
9
|
+
{
|
|
10
|
+
id: 1,
|
|
11
|
+
title: 'Buy groceries',
|
|
12
|
+
},
|
|
13
|
+
]
|
|
14
|
+
|
|
15
|
+
// Subscription callbacks per userID
|
|
16
|
+
let subscribers: ((todos: Todo[]) => void)[] = []
|
|
17
|
+
|
|
18
|
+
export type Todo = {
|
|
19
|
+
id: number
|
|
20
|
+
title: string
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
// Get the todos for a user
|
|
24
|
+
export function getTodos(): Todo[] {
|
|
25
|
+
return todos
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
// Add an item to the todos
|
|
29
|
+
export function addTodo(title: string) {
|
|
30
|
+
todos.push({ id: todos.length + 1, title })
|
|
31
|
+
fs.writeFileSync(todosPath, JSON.stringify(todos, null, 2))
|
|
32
|
+
notifySubscribers()
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
// Subscribe to cart changes for a user
|
|
36
|
+
export function subscribeToTodos(callback: (todos: Todo[]) => void) {
|
|
37
|
+
subscribers.push(callback)
|
|
38
|
+
callback(todos)
|
|
39
|
+
return () => {
|
|
40
|
+
subscribers = subscribers.filter((cb) => cb !== callback)
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
// Notify all subscribers of a user's cart
|
|
45
|
+
function notifySubscribers() {
|
|
46
|
+
for (const cb of subscribers) {
|
|
47
|
+
try {
|
|
48
|
+
cb(todos)
|
|
49
|
+
} catch {}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { createFileRoute } from '@tanstack/react-router'
|
|
2
|
+
|
|
3
|
+
import { addTodo, getTodos, subscribeToTodos } from '@/mcp-todos'
|
|
4
|
+
|
|
5
|
+
export const Route = createFileRoute('/api/mcp-todos')({
|
|
6
|
+
server: {
|
|
7
|
+
handlers: {
|
|
8
|
+
GET: () => {
|
|
9
|
+
const stream = new ReadableStream({
|
|
10
|
+
start(controller) {
|
|
11
|
+
function ping() {
|
|
12
|
+
try {
|
|
13
|
+
controller.enqueue(`event: ping\n\n`)
|
|
14
|
+
setTimeout(ping, 1000)
|
|
15
|
+
} catch {}
|
|
16
|
+
}
|
|
17
|
+
ping()
|
|
18
|
+
const unsubscribe = subscribeToTodos((todos) => {
|
|
19
|
+
controller.enqueue(`data: ${JSON.stringify(todos)}\n\n`)
|
|
20
|
+
})
|
|
21
|
+
const todos = getTodos()
|
|
22
|
+
controller.enqueue(`data: ${JSON.stringify(todos)}\n\n`)
|
|
23
|
+
return () => unsubscribe()
|
|
24
|
+
},
|
|
25
|
+
})
|
|
26
|
+
return new Response(stream, {
|
|
27
|
+
headers: { 'Content-Type': 'text/event-stream' },
|
|
28
|
+
})
|
|
29
|
+
},
|
|
30
|
+
POST: async ({ request }) => {
|
|
31
|
+
const { title } = await request.json()
|
|
32
|
+
addTodo(title)
|
|
33
|
+
return Response.json(getTodos())
|
|
34
|
+
},
|
|
35
|
+
},
|
|
36
|
+
},
|
|
37
|
+
})
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js'
|
|
2
|
+
import { createFileRoute } from '@tanstack/react-router'
|
|
3
|
+
import z from 'zod'
|
|
4
|
+
|
|
5
|
+
import { handleMcpRequest } from '@/utils/mcp-handler'
|
|
6
|
+
|
|
7
|
+
import { addTodo } from '@/mcp-todos'
|
|
8
|
+
|
|
9
|
+
const server = new McpServer({
|
|
10
|
+
name: 'start-server',
|
|
11
|
+
version: '1.0.0',
|
|
12
|
+
})
|
|
13
|
+
|
|
14
|
+
server.registerTool(
|
|
15
|
+
'addTodo',
|
|
16
|
+
{
|
|
17
|
+
title: 'Tool to add a todo to a list of todos',
|
|
18
|
+
description: 'Add a todo to a list of todos',
|
|
19
|
+
inputSchema: {
|
|
20
|
+
title: z.string().describe('The title of the todo'),
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
({ title }) => ({
|
|
24
|
+
content: [{ type: 'text', text: String(addTodo(title)) }],
|
|
25
|
+
}),
|
|
26
|
+
)
|
|
27
|
+
|
|
28
|
+
// server.registerResource(
|
|
29
|
+
// "counter-value",
|
|
30
|
+
// "count://",
|
|
31
|
+
// {
|
|
32
|
+
// title: "Counter Resource",
|
|
33
|
+
// description: "Returns the current value of the counter",
|
|
34
|
+
// },
|
|
35
|
+
// async (uri) => {
|
|
36
|
+
// return {
|
|
37
|
+
// contents: [
|
|
38
|
+
// {
|
|
39
|
+
// uri: uri.href,
|
|
40
|
+
// text: `The counter is at 20!`,
|
|
41
|
+
// },
|
|
42
|
+
// ],
|
|
43
|
+
// };
|
|
44
|
+
// }
|
|
45
|
+
// );
|
|
46
|
+
|
|
47
|
+
export const Route = createFileRoute('/mcp')({
|
|
48
|
+
server: {
|
|
49
|
+
handlers: {
|
|
50
|
+
POST: async ({ request }) => handleMcpRequest(request, server),
|
|
51
|
+
},
|
|
52
|
+
},
|
|
53
|
+
})
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { InMemoryTransport } from '@modelcontextprotocol/sdk/inMemory.js'
|
|
2
|
+
|
|
3
|
+
import type { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js'
|
|
4
|
+
import type { JSONRPCMessage } from '@modelcontextprotocol/sdk/types.js'
|
|
5
|
+
|
|
6
|
+
export async function handleMcpRequest(
|
|
7
|
+
request: Request,
|
|
8
|
+
server: McpServer,
|
|
9
|
+
): Promise<Response> {
|
|
10
|
+
try {
|
|
11
|
+
const jsonRpcRequest = (await request.json()) as JSONRPCMessage
|
|
12
|
+
|
|
13
|
+
const [clientTransport, serverTransport] =
|
|
14
|
+
InMemoryTransport.createLinkedPair()
|
|
15
|
+
|
|
16
|
+
let responseData: JSONRPCMessage | null = null
|
|
17
|
+
|
|
18
|
+
clientTransport.onmessage = (message: JSONRPCMessage) => {
|
|
19
|
+
responseData = message
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
await server.connect(serverTransport)
|
|
23
|
+
|
|
24
|
+
await clientTransport.start()
|
|
25
|
+
await serverTransport.start()
|
|
26
|
+
|
|
27
|
+
await clientTransport.send(jsonRpcRequest)
|
|
28
|
+
|
|
29
|
+
await new Promise((resolve) => setTimeout(resolve, 10))
|
|
30
|
+
|
|
31
|
+
await clientTransport.close()
|
|
32
|
+
await serverTransport.close()
|
|
33
|
+
|
|
34
|
+
return Response.json(responseData, {
|
|
35
|
+
headers: {
|
|
36
|
+
'Content-Type': 'application/json',
|
|
37
|
+
},
|
|
38
|
+
})
|
|
39
|
+
} catch (error) {
|
|
40
|
+
console.error('MCP handler error:', error)
|
|
41
|
+
|
|
42
|
+
// Return a JSON-RPC error response
|
|
43
|
+
return Response.json(
|
|
44
|
+
{
|
|
45
|
+
jsonrpc: '2.0',
|
|
46
|
+
error: {
|
|
47
|
+
code: -32603,
|
|
48
|
+
message: 'Internal server error',
|
|
49
|
+
data: error instanceof Error ? error.message : String(error),
|
|
50
|
+
},
|
|
51
|
+
id: null,
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
status: 500,
|
|
55
|
+
headers: {
|
|
56
|
+
'Content-Type': 'application/json',
|
|
57
|
+
},
|
|
58
|
+
},
|
|
59
|
+
)
|
|
60
|
+
}
|
|
61
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { neon } from '@neondatabase/serverless'
|
|
2
|
+
|
|
3
|
+
let client: ReturnType<typeof neon>
|
|
4
|
+
|
|
5
|
+
export async function getClient() {
|
|
6
|
+
if (!process.env.VITE_DATABASE_URL) {
|
|
7
|
+
return undefined
|
|
8
|
+
}
|
|
9
|
+
if (!client) {
|
|
10
|
+
client = await neon(process.env.VITE_DATABASE_URL!)
|
|
11
|
+
}
|
|
12
|
+
return client
|
|
13
|
+
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { createRouterClient } from '@orpc/server'
|
|
2
|
+
import { createORPCClient } from '@orpc/client'
|
|
3
|
+
import { RPCLink } from '@orpc/client/fetch'
|
|
4
|
+
import { createTanstackQueryUtils } from '@orpc/tanstack-query'
|
|
5
|
+
import { getRequestHeaders } from '@tanstack/react-start/server'
|
|
6
|
+
import { createIsomorphicFn } from '@tanstack/react-start'
|
|
7
|
+
|
|
8
|
+
import type { RouterClient } from '@orpc/server'
|
|
9
|
+
|
|
10
|
+
import router from '@/orpc/router'
|
|
11
|
+
|
|
12
|
+
const getORPCClient = createIsomorphicFn()
|
|
13
|
+
.server(() =>
|
|
14
|
+
createRouterClient(router, {
|
|
15
|
+
context: () => ({
|
|
16
|
+
headers: getRequestHeaders(),
|
|
17
|
+
}),
|
|
18
|
+
}),
|
|
19
|
+
)
|
|
20
|
+
.client((): RouterClient<typeof router> => {
|
|
21
|
+
const link = new RPCLink({
|
|
22
|
+
url: `${window.location.origin}/api/rpc`,
|
|
23
|
+
})
|
|
24
|
+
return createORPCClient(link)
|
|
25
|
+
})
|
|
26
|
+
|
|
27
|
+
export const client: RouterClient<typeof router> = getORPCClient()
|
|
28
|
+
|
|
29
|
+
export const orpc = createTanstackQueryUtils(client)
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { os } from '@orpc/server'
|
|
2
|
+
import * as z from 'zod'
|
|
3
|
+
|
|
4
|
+
const todos = [
|
|
5
|
+
{ id: 1, name: 'Get groceries' },
|
|
6
|
+
{ id: 2, name: 'Buy a new phone' },
|
|
7
|
+
{ id: 3, name: 'Finish the project' },
|
|
8
|
+
]
|
|
9
|
+
|
|
10
|
+
export const listTodos = os.input(z.object({})).handler(() => {
|
|
11
|
+
return todos
|
|
12
|
+
})
|
|
13
|
+
|
|
14
|
+
export const addTodo = os
|
|
15
|
+
.input(z.object({ name: z.string() }))
|
|
16
|
+
.handler(({ input }) => {
|
|
17
|
+
const newTodo = { id: todos.length + 1, name: input.name }
|
|
18
|
+
todos.push(newTodo)
|
|
19
|
+
return newTodo
|
|
20
|
+
})
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { File } from "node:buffer";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* This file aims to polyfill missing APIs in Node.js 18 that oRPC depends on.
|
|
5
|
+
*
|
|
6
|
+
* Since Stackblitz runs on Node.js 18, these polyfills ensure oRPC works in that environment.
|
|
7
|
+
* If you're running oRPC locally, please use Node.js 20 or later for full compatibility.
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Note: Stackblitz provides an emulated Node.js environment with inherent limitations.
|
|
12
|
+
* If you encounter issues, please test on a local setup with Node.js 20 or later before reporting them.
|
|
13
|
+
*/
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* The `oz.file()` schema depends on the `File` API.
|
|
17
|
+
* If you're not using `oz.file()`, you can safely remove this polyfill.
|
|
18
|
+
*/
|
|
19
|
+
if (typeof globalThis.File === "undefined") {
|
|
20
|
+
globalThis.File = File as any;
|
|
21
|
+
}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import '@/polyfill'
|
|
2
|
+
|
|
3
|
+
import { OpenAPIHandler } from '@orpc/openapi/fetch'
|
|
4
|
+
import { ZodToJsonSchemaConverter } from '@orpc/zod/zod4'
|
|
5
|
+
import { SmartCoercionPlugin } from '@orpc/json-schema'
|
|
6
|
+
import { createFileRoute } from '@tanstack/react-router'
|
|
7
|
+
import { onError } from '@orpc/server'
|
|
8
|
+
import { OpenAPIReferencePlugin } from '@orpc/openapi/plugins'
|
|
9
|
+
|
|
10
|
+
import { TodoSchema } from '@/orpc/schema'
|
|
11
|
+
import router from '@/orpc/router'
|
|
12
|
+
|
|
13
|
+
const handler = new OpenAPIHandler(router, {
|
|
14
|
+
interceptors: [
|
|
15
|
+
onError((error) => {
|
|
16
|
+
console.error(error)
|
|
17
|
+
}),
|
|
18
|
+
],
|
|
19
|
+
plugins: [
|
|
20
|
+
new SmartCoercionPlugin({
|
|
21
|
+
schemaConverters: [new ZodToJsonSchemaConverter()],
|
|
22
|
+
}),
|
|
23
|
+
new OpenAPIReferencePlugin({
|
|
24
|
+
schemaConverters: [new ZodToJsonSchemaConverter()],
|
|
25
|
+
specGenerateOptions: {
|
|
26
|
+
info: {
|
|
27
|
+
title: 'TanStack ORPC Playground',
|
|
28
|
+
version: '1.0.0',
|
|
29
|
+
},
|
|
30
|
+
commonSchemas: {
|
|
31
|
+
Todo: { schema: TodoSchema },
|
|
32
|
+
UndefinedError: { error: 'UndefinedError' },
|
|
33
|
+
},
|
|
34
|
+
security: [{ bearerAuth: [] }],
|
|
35
|
+
components: {
|
|
36
|
+
securitySchemes: {
|
|
37
|
+
bearerAuth: {
|
|
38
|
+
type: 'http',
|
|
39
|
+
scheme: 'bearer',
|
|
40
|
+
},
|
|
41
|
+
},
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
docsConfig: {
|
|
45
|
+
authentication: {
|
|
46
|
+
securitySchemes: {
|
|
47
|
+
bearerAuth: {
|
|
48
|
+
token: 'default-token',
|
|
49
|
+
},
|
|
50
|
+
},
|
|
51
|
+
},
|
|
52
|
+
},
|
|
53
|
+
}),
|
|
54
|
+
],
|
|
55
|
+
})
|
|
56
|
+
|
|
57
|
+
async function handle({ request }: { request: Request }) {
|
|
58
|
+
const { response } = await handler.handle(request, {
|
|
59
|
+
prefix: '/api',
|
|
60
|
+
context: {},
|
|
61
|
+
})
|
|
62
|
+
|
|
63
|
+
return response ?? new Response('Not Found', { status: 404 })
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
export const Route = createFileRoute('/api/$')({
|
|
67
|
+
server: {
|
|
68
|
+
handlers: {
|
|
69
|
+
HEAD: handle,
|
|
70
|
+
GET: handle,
|
|
71
|
+
POST: handle,
|
|
72
|
+
PUT: handle,
|
|
73
|
+
PATCH: handle,
|
|
74
|
+
DELETE: handle,
|
|
75
|
+
},
|
|
76
|
+
},
|
|
77
|
+
})
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import '@/polyfill'
|
|
2
|
+
|
|
3
|
+
import { RPCHandler } from '@orpc/server/fetch'
|
|
4
|
+
import { createFileRoute } from '@tanstack/react-router'
|
|
5
|
+
import router from '@/orpc/router'
|
|
6
|
+
|
|
7
|
+
const handler = new RPCHandler(router)
|
|
8
|
+
|
|
9
|
+
async function handle({ request }: { request: Request }) {
|
|
10
|
+
const { response } = await handler.handle(request, {
|
|
11
|
+
prefix: '/api/rpc',
|
|
12
|
+
context: {},
|
|
13
|
+
})
|
|
14
|
+
|
|
15
|
+
return response ?? new Response('Not Found', { status: 404 })
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export const Route = createFileRoute('/api/rpc/$')({
|
|
19
|
+
server: {
|
|
20
|
+
handlers: {
|
|
21
|
+
HEAD: handle,
|
|
22
|
+
GET: handle,
|
|
23
|
+
POST: handle,
|
|
24
|
+
PUT: handle,
|
|
25
|
+
PATCH: handle,
|
|
26
|
+
DELETE: handle,
|
|
27
|
+
},
|
|
28
|
+
},
|
|
29
|
+
})
|
|
@@ -17,5 +17,9 @@
|
|
|
17
17
|
"db:migrate": "dotenv -e .env.local -- prisma migrate dev",
|
|
18
18
|
"db:studio": "dotenv -e .env.local -- prisma studio",
|
|
19
19
|
"db:seed": "dotenv -e .env.local -- prisma db seed"
|
|
20
|
+
}<% if (addOnOption.prisma.database === 'sqlite') { %>,
|
|
21
|
+
"pnpm": {
|
|
22
|
+
"onlyBuiltDependencies": ["better-sqlite3"]
|
|
20
23
|
}
|
|
24
|
+
<% } %>
|
|
21
25
|
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Derived, Store } from '@tanstack/store'
|
|
2
|
+
|
|
3
|
+
export const store = new Store({
|
|
4
|
+
firstName: 'Jane',
|
|
5
|
+
lastName: 'Smith',
|
|
6
|
+
})
|
|
7
|
+
|
|
8
|
+
export const fullName = new Derived({
|
|
9
|
+
fn: () => `${store.state.firstName} ${store.state.lastName}`,
|
|
10
|
+
deps: [store],
|
|
11
|
+
})
|
|
12
|
+
|
|
13
|
+
fullName.mount()
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { StorybookConfig } from "@storybook/react-vite";
|
|
2
|
+
|
|
3
|
+
const config: StorybookConfig = {
|
|
4
|
+
stories: ["../src/**/*.stories.@(js|jsx|mjs|ts|tsx)"],
|
|
5
|
+
addons: [],
|
|
6
|
+
framework: {
|
|
7
|
+
name: "@storybook/react-vite",
|
|
8
|
+
options: {},
|
|
9
|
+
},
|
|
10
|
+
async viteFinal(config) {
|
|
11
|
+
const { default: tailwindcss } = await import("@tailwindcss/vite");
|
|
12
|
+
config.plugins = config.plugins || [];
|
|
13
|
+
config.plugins.push(tailwindcss());
|
|
14
|
+
return config;
|
|
15
|
+
},
|
|
16
|
+
};
|
|
17
|
+
export default config;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { Preview } from "@storybook/react-vite";
|
|
2
|
+
import "../src/styles.css";
|
|
3
|
+
|
|
4
|
+
const preview: Preview = {
|
|
5
|
+
parameters: {
|
|
6
|
+
controls: {
|
|
7
|
+
matchers: {
|
|
8
|
+
color: /(background|color)$/i,
|
|
9
|
+
date: /Date$/i,
|
|
10
|
+
},
|
|
11
|
+
},
|
|
12
|
+
},
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
export default preview;
|
package/dist/frameworks/react/add-ons/storybook/assets/src/components/storybook/button.stories.ts
ADDED
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import type { Meta, StoryObj } from "@storybook/react-vite";
|
|
2
|
+
import { fn } from "storybook/test";
|
|
3
|
+
|
|
4
|
+
import { Button } from "./button";
|
|
5
|
+
|
|
6
|
+
const meta = {
|
|
7
|
+
title: "Form/Button",
|
|
8
|
+
component: Button,
|
|
9
|
+
parameters: {
|
|
10
|
+
layout: "centered",
|
|
11
|
+
},
|
|
12
|
+
tags: ["autodocs"],
|
|
13
|
+
args: { onClick: fn() },
|
|
14
|
+
} satisfies Meta<typeof Button>;
|
|
15
|
+
|
|
16
|
+
export default meta;
|
|
17
|
+
type Story = StoryObj<typeof meta>;
|
|
18
|
+
|
|
19
|
+
export const Primary: Story = {
|
|
20
|
+
args: {
|
|
21
|
+
variant: "primary",
|
|
22
|
+
children: "Primary Button",
|
|
23
|
+
},
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
export const Secondary: Story = {
|
|
27
|
+
args: {
|
|
28
|
+
variant: "secondary",
|
|
29
|
+
children: "Secondary Button",
|
|
30
|
+
},
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
export const Danger: Story = {
|
|
34
|
+
args: {
|
|
35
|
+
variant: "danger",
|
|
36
|
+
children: "Delete Account",
|
|
37
|
+
},
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
export const Small: Story = {
|
|
41
|
+
args: {
|
|
42
|
+
size: "small",
|
|
43
|
+
children: "Small Button",
|
|
44
|
+
},
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
export const Medium: Story = {
|
|
48
|
+
args: {
|
|
49
|
+
size: "medium",
|
|
50
|
+
children: "Medium Button",
|
|
51
|
+
},
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
export const Large: Story = {
|
|
55
|
+
args: {
|
|
56
|
+
size: "large",
|
|
57
|
+
children: "Large Button",
|
|
58
|
+
},
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
export const Disabled: Story = {
|
|
62
|
+
args: {
|
|
63
|
+
variant: "primary",
|
|
64
|
+
children: "Disabled Button",
|
|
65
|
+
disabled: true,
|
|
66
|
+
},
|
|
67
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export { Input } from "./input";
|
|
2
|
+
export type { InputProps } from "./input";
|
|
3
|
+
|
|
4
|
+
export { RadioGroup } from "./radio-group";
|
|
5
|
+
export type { RadioGroupProps, RadioOption } from "./radio-group";
|
|
6
|
+
|
|
7
|
+
export { Slider } from "./slider";
|
|
8
|
+
export type { SliderProps } from "./slider";
|
|
9
|
+
|
|
10
|
+
export { Dialog } from "./dialog";
|
|
11
|
+
export type { DialogProps } from "./dialog";
|
|
12
|
+
|
|
13
|
+
export { Button } from "./button";
|
|
14
|
+
export type { ButtonProps } from "./button";
|
package/dist/frameworks/react/add-ons/storybook/assets/src/components/storybook/input.stories.ts
ADDED
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import type { Meta, StoryObj } from "@storybook/react-vite";
|
|
2
|
+
import { fn } from "storybook/test";
|
|
3
|
+
|
|
4
|
+
import { Input } from "./input";
|
|
5
|
+
|
|
6
|
+
const meta = {
|
|
7
|
+
title: "Form/Input",
|
|
8
|
+
component: Input,
|
|
9
|
+
parameters: {
|
|
10
|
+
layout: "centered",
|
|
11
|
+
},
|
|
12
|
+
tags: ["autodocs"],
|
|
13
|
+
args: { onChange: fn() },
|
|
14
|
+
} satisfies Meta<typeof Input>;
|
|
15
|
+
|
|
16
|
+
export default meta;
|
|
17
|
+
type Story = StoryObj<typeof meta>;
|
|
18
|
+
|
|
19
|
+
export const Default: Story = {
|
|
20
|
+
args: {
|
|
21
|
+
label: "Email Address",
|
|
22
|
+
id: "email",
|
|
23
|
+
placeholder: "Enter your email",
|
|
24
|
+
},
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
export const Required: Story = {
|
|
28
|
+
args: {
|
|
29
|
+
label: "First Name",
|
|
30
|
+
id: "firstName",
|
|
31
|
+
placeholder: "John",
|
|
32
|
+
required: true,
|
|
33
|
+
},
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
export const WithValue: Story = {
|
|
37
|
+
args: {
|
|
38
|
+
label: "Last Name",
|
|
39
|
+
id: "lastName",
|
|
40
|
+
value: "Doe",
|
|
41
|
+
placeholder: "Enter last name",
|
|
42
|
+
},
|
|
43
|
+
};
|