create-einja-app 0.1.1
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 +307 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.js +1041 -0
- package/dist/cli.js.map +1 -0
- package/package.json +62 -0
- package/templates/turborepo-pandacss/.biomeignore +15 -0
- package/templates/turborepo-pandacss/.claude/hooks/einja/biome-format.sh +49 -0
- package/templates/turborepo-pandacss/.claude/hooks/einja/design-doc-check.sh +61 -0
- package/templates/turborepo-pandacss/.claude/hooks/einja/detect-secrets.sh +62 -0
- package/templates/turborepo-pandacss/.claude/hooks/einja/large-file-warning.sh +42 -0
- package/templates/turborepo-pandacss/.claude/hooks/einja/playwright-resize.sh +36 -0
- package/templates/turborepo-pandacss/.claude/hooks/einja/typecheck.sh +37 -0
- package/templates/turborepo-pandacss/.claude/hooks/einja/unset-volta-recursion.sh +32 -0
- package/templates/turborepo-pandacss/.claude/hooks/einja/validate-git-commit.sh +239 -0
- package/templates/turborepo-pandacss/.claude/hooks/einja/warn-index-ts.sh +34 -0
- package/templates/turborepo-pandacss/.claude/hooks/einja/warn-relative-import.sh +48 -0
- package/templates/turborepo-pandacss/.claude/settings.json +174 -0
- package/templates/turborepo-pandacss/.claude/skills/create-einja-app-release/SKILL.md +186 -0
- package/templates/turborepo-pandacss/.claude/skills/dev-cli-release/SKILL.md +173 -0
- package/templates/turborepo-pandacss/.cursor/commands/spec-create.md +227 -0
- package/templates/turborepo-pandacss/.cursor/commands/start-dev.md +98 -0
- package/templates/turborepo-pandacss/.cursor/commands/task-exec.md +287 -0
- package/templates/turborepo-pandacss/.cursor/commands/task-vibe-kanban-loop.md +532 -0
- package/templates/turborepo-pandacss/.cursor/commands/update-docs-by-task-specs.md +448 -0
- package/templates/turborepo-pandacss/.cursor/mcp.json +45 -0
- package/templates/turborepo-pandacss/.cursor/rules/api-rules.mdc +171 -0
- package/templates/turborepo-pandacss/.cursor/rules/api-test-rules.mdc +181 -0
- package/templates/turborepo-pandacss/.cursor/rules/base-code.mdc +70 -0
- package/templates/turborepo-pandacss/.cursor/rules/base-commit-rules.mdc +174 -0
- package/templates/turborepo-pandacss/.cursor/rules/base-design.mdc +12 -0
- package/templates/turborepo-pandacss/.cursor/rules/base-rules.mdc +231 -0
- package/templates/turborepo-pandacss/.cursor/rules/error-handling-rules.mdc +188 -0
- package/templates/turborepo-pandacss/.cursor/rules/refactor-rules.mdc +93 -0
- package/templates/turborepo-pandacss/.dockerignore +126 -0
- package/templates/turborepo-pandacss/.einja-sync.json +35 -0
- package/templates/turborepo-pandacss/.env.ci +25 -0
- package/templates/turborepo-pandacss/.env.example +35 -0
- package/templates/turborepo-pandacss/.env.personal.example +27 -0
- package/templates/turborepo-pandacss/.envrc +4 -0
- package/templates/turborepo-pandacss/.gitattributes +5 -0
- package/templates/turborepo-pandacss/.husky/pre-commit +1 -0
- package/templates/turborepo-pandacss/.lintstagedrc.js +24 -0
- package/templates/turborepo-pandacss/.mcp.json +45 -0
- package/templates/turborepo-pandacss/.node-version +1 -0
- package/templates/turborepo-pandacss/.templateignore +60 -0
- package/templates/turborepo-pandacss/.vscode/extensions.json +3 -0
- package/templates/turborepo-pandacss/CLAUDE.md +415 -0
- package/templates/turborepo-pandacss/README.md +322 -0
- package/templates/turborepo-pandacss/apps/web/middleware.ts +28 -0
- package/templates/turborepo-pandacss/apps/web/next.config.ts +10 -0
- package/templates/turborepo-pandacss/apps/web/package.json +80 -0
- package/templates/turborepo-pandacss/apps/web/panda.config.ts +114 -0
- package/templates/turborepo-pandacss/apps/web/postcss.config.cjs +6 -0
- package/templates/turborepo-pandacss/apps/web/public/file.svg +1 -0
- package/templates/turborepo-pandacss/apps/web/public/globe.svg +1 -0
- package/templates/turborepo-pandacss/apps/web/public/next.svg +1 -0
- package/templates/turborepo-pandacss/apps/web/public/vercel.svg +1 -0
- package/templates/turborepo-pandacss/apps/web/public/window.svg +1 -0
- package/templates/turborepo-pandacss/apps/web/src/app/(authenticated)/dashboard/page.tsx +79 -0
- package/templates/turborepo-pandacss/apps/web/src/app/(authenticated)/data/_components/UserTable.tsx +203 -0
- package/templates/turborepo-pandacss/apps/web/src/app/(authenticated)/data/page.tsx +57 -0
- package/templates/turborepo-pandacss/apps/web/src/app/(authenticated)/layout-client.tsx +31 -0
- package/templates/turborepo-pandacss/apps/web/src/app/(authenticated)/layout.tsx +17 -0
- package/templates/turborepo-pandacss/apps/web/src/app/(authenticated)/profile/page.tsx +59 -0
- package/templates/turborepo-pandacss/apps/web/src/app/api/auth/[...nextauth]/route.ts +3 -0
- package/templates/turborepo-pandacss/apps/web/src/app/api/auth/signup/route.ts +70 -0
- package/templates/turborepo-pandacss/apps/web/src/app/error.tsx +106 -0
- package/templates/turborepo-pandacss/apps/web/src/app/favicon.ico +0 -0
- package/templates/turborepo-pandacss/apps/web/src/app/global-error.tsx +110 -0
- package/templates/turborepo-pandacss/apps/web/src/app/globals.css +121 -0
- package/templates/turborepo-pandacss/apps/web/src/app/layout.tsx +28 -0
- package/templates/turborepo-pandacss/apps/web/src/app/not-found.tsx +54 -0
- package/templates/turborepo-pandacss/apps/web/src/app/page.module.css +165 -0
- package/templates/turborepo-pandacss/apps/web/src/app/page.test.tsx +52 -0
- package/templates/turborepo-pandacss/apps/web/src/app/page.tsx +284 -0
- package/templates/turborepo-pandacss/apps/web/src/app/signin/page.tsx +296 -0
- package/templates/turborepo-pandacss/apps/web/src/app/signup/page.tsx +395 -0
- package/templates/turborepo-pandacss/apps/web/src/application/use-cases/UserUseCases.test.ts +229 -0
- package/templates/turborepo-pandacss/apps/web/src/application/use-cases/UserUseCases.ts +115 -0
- package/templates/turborepo-pandacss/apps/web/src/components/auth/login-button.tsx +35 -0
- package/templates/turborepo-pandacss/apps/web/src/components/auth/logout-button.tsx +24 -0
- package/templates/turborepo-pandacss/apps/web/src/components/auth/user-avatar.test.tsx +68 -0
- package/templates/turborepo-pandacss/apps/web/src/components/auth/user-avatar.tsx +43 -0
- package/templates/turborepo-pandacss/apps/web/src/components/dashboard/dashboard-stats.tsx +128 -0
- package/templates/turborepo-pandacss/apps/web/src/components/providers/query-provider.tsx +30 -0
- package/templates/turborepo-pandacss/apps/web/src/components/providers/session-provider.tsx +12 -0
- package/templates/turborepo-pandacss/apps/web/src/components/shared/Sidebar.tsx +175 -0
- package/templates/turborepo-pandacss/apps/web/src/components/shared/header.tsx +166 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/accordion.tsx +64 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/alert-dialog.tsx +135 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/alert.tsx +60 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/aspect-ratio.tsx +9 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/avatar.tsx +41 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/badge.tsx +39 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/breadcrumb.tsx +101 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/button.tsx +56 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/card.tsx +75 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/checkbox.tsx +29 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/data-table.tsx +189 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/dialog-hook.tsx +210 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/dialog.tsx +129 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/drawer.tsx +124 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/dropdown-menu.tsx +228 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/form.tsx +152 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/hover-card.tsx +38 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/input.tsx +21 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/label.tsx +21 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/pagination.tsx +105 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/popover.tsx +42 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/progress.tsx +28 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/select.tsx +170 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/separator.tsx +28 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/skeleton.tsx +13 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/sonner.tsx +25 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/table.tsx +92 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/tabs.tsx +54 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/textarea.tsx +18 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/tooltip.tsx +57 -0
- package/templates/turborepo-pandacss/apps/web/src/components/ui/typography.tsx +158 -0
- package/templates/turborepo-pandacss/apps/web/src/lib/auth/guard.ts +36 -0
- package/templates/turborepo-pandacss/apps/web/src/lib/auth/index.ts +22 -0
- package/templates/turborepo-pandacss/apps/web/src/lib/prisma.ts +3 -0
- package/templates/turborepo-pandacss/apps/web/src/lib/utils.ts +6 -0
- package/templates/turborepo-pandacss/apps/web/test/globals.d.ts +1 -0
- package/templates/turborepo-pandacss/apps/web/test/matchers.d.ts +1 -0
- package/templates/turborepo-pandacss/apps/web/test/setup.ts +22 -0
- package/templates/turborepo-pandacss/apps/web/tsconfig.json +37 -0
- package/templates/turborepo-pandacss/apps/web/vitest.config.ts +20 -0
- package/templates/turborepo-pandacss/apps/web/vitest.d.ts +2 -0
- package/templates/turborepo-pandacss/biome.json +60 -0
- package/templates/turborepo-pandacss/components.json +21 -0
- package/templates/turborepo-pandacss/docker-compose.yml +27 -0
- package/templates/turborepo-pandacss/middleware.ts +32 -0
- package/templates/turborepo-pandacss/next.config.ts +10 -0
- package/templates/turborepo-pandacss/package-lock.json +9346 -0
- package/templates/turborepo-pandacss/package.json +64 -0
- package/templates/turborepo-pandacss/packages/config/package.json +41 -0
- package/templates/turborepo-pandacss/packages/config/panda.config.ts +114 -0
- package/templates/turborepo-pandacss/packages/config/src/index.ts +24 -0
- package/templates/turborepo-pandacss/packages/config/src/worktree-config-loader.ts +129 -0
- package/templates/turborepo-pandacss/packages/config/src/worktree-config.ts +75 -0
- package/templates/turborepo-pandacss/packages/config/tsconfig.build.json +19 -0
- package/templates/turborepo-pandacss/packages/config/tsconfig.json +24 -0
- package/templates/turborepo-pandacss/packages/config/typescript/base.json +19 -0
- package/templates/turborepo-pandacss/packages/front-core/package.json +24 -0
- package/templates/turborepo-pandacss/packages/front-core/src/auth/config.ts +84 -0
- package/templates/turborepo-pandacss/packages/front-core/src/auth/index.ts +5 -0
- package/templates/turborepo-pandacss/packages/front-core/src/auth/types/next-auth.d.ts +20 -0
- package/templates/turborepo-pandacss/packages/front-core/src/auth/utils.ts +29 -0
- package/templates/turborepo-pandacss/packages/front-core/src/context/index.ts +2 -0
- package/templates/turborepo-pandacss/packages/front-core/src/hooks/index.ts +2 -0
- package/templates/turborepo-pandacss/packages/front-core/src/index.ts +4 -0
- package/templates/turborepo-pandacss/packages/front-core/src/utils/index.ts +2 -0
- package/templates/turborepo-pandacss/packages/front-core/tsconfig.json +14 -0
- package/templates/turborepo-pandacss/packages/server-core/package.json +32 -0
- package/templates/turborepo-pandacss/packages/server-core/prisma/schema.prisma +102 -0
- package/templates/turborepo-pandacss/packages/server-core/prisma/seed.ts +67 -0
- package/templates/turborepo-pandacss/packages/server-core/prisma.config.ts +8 -0
- package/templates/turborepo-pandacss/packages/server-core/src/__generated__/fabbrica/index.d.ts +270 -0
- package/templates/turborepo-pandacss/packages/server-core/src/__generated__/fabbrica/index.js +484 -0
- package/templates/turborepo-pandacss/packages/server-core/src/core/result.test.ts +78 -0
- package/templates/turborepo-pandacss/packages/server-core/src/core/result.ts +53 -0
- package/templates/turborepo-pandacss/packages/server-core/src/domain/.gitkeep +0 -0
- package/templates/turborepo-pandacss/packages/server-core/src/domain/entities/User.test.ts +232 -0
- package/templates/turborepo-pandacss/packages/server-core/src/domain/entities/User.ts +105 -0
- package/templates/turborepo-pandacss/packages/server-core/src/domain/repository-interfaces/IUserRepository.ts +101 -0
- package/templates/turborepo-pandacss/packages/server-core/src/infrastructure/database/client.ts +15 -0
- package/templates/turborepo-pandacss/packages/server-core/src/infrastructure/database/mappers/UserMapper.test.ts +278 -0
- package/templates/turborepo-pandacss/packages/server-core/src/infrastructure/database/mappers/UserMapper.ts +103 -0
- package/templates/turborepo-pandacss/packages/server-core/src/infrastructure/database/repositories/UserRepository.test.ts +317 -0
- package/templates/turborepo-pandacss/packages/server-core/src/infrastructure/database/repositories/UserRepository.ts +169 -0
- package/templates/turborepo-pandacss/packages/server-core/src/testing/factories/index.ts +22 -0
- package/templates/turborepo-pandacss/packages/server-core/src/testing/factories/user.factory.ts +123 -0
- package/templates/turborepo-pandacss/packages/server-core/src/testing/fixtures/users.ts +92 -0
- package/templates/turborepo-pandacss/packages/server-core/src/testing/helpers/date.ts +49 -0
- package/templates/turborepo-pandacss/packages/server-core/src/testing/helpers/password.ts +50 -0
- package/templates/turborepo-pandacss/packages/server-core/src/testing/index.ts +26 -0
- package/templates/turborepo-pandacss/packages/server-core/tsconfig.json +14 -0
- package/templates/turborepo-pandacss/packages/server-core/vitest.config.ts +15 -0
- package/templates/turborepo-pandacss/packages/ui/package.json +37 -0
- package/templates/turborepo-pandacss/packages/ui/src/accordion.tsx +66 -0
- package/templates/turborepo-pandacss/packages/ui/src/alert-dialog.tsx +157 -0
- package/templates/turborepo-pandacss/packages/ui/src/alert.tsx +66 -0
- package/templates/turborepo-pandacss/packages/ui/src/aspect-ratio.tsx +11 -0
- package/templates/turborepo-pandacss/packages/ui/src/avatar.tsx +53 -0
- package/templates/turborepo-pandacss/packages/ui/src/badge.tsx +46 -0
- package/templates/turborepo-pandacss/packages/ui/src/breadcrumb.tsx +108 -0
- package/templates/turborepo-pandacss/packages/ui/src/button.tsx +59 -0
- package/templates/turborepo-pandacss/packages/ui/src/card.tsx +92 -0
- package/templates/turborepo-pandacss/packages/ui/src/checkbox.tsx +32 -0
- package/templates/turborepo-pandacss/packages/ui/src/data-table.tsx +216 -0
- package/templates/turborepo-pandacss/packages/ui/src/dialog-hook.tsx +226 -0
- package/templates/turborepo-pandacss/packages/ui/src/dialog.tsx +143 -0
- package/templates/turborepo-pandacss/packages/ui/src/drawer.tsx +135 -0
- package/templates/turborepo-pandacss/packages/ui/src/dropdown-menu.tsx +257 -0
- package/templates/turborepo-pandacss/packages/ui/src/form.tsx +168 -0
- package/templates/turborepo-pandacss/packages/ui/src/hover-card.tsx +44 -0
- package/templates/turborepo-pandacss/packages/ui/src/input.tsx +21 -0
- package/templates/turborepo-pandacss/packages/ui/src/label.tsx +24 -0
- package/templates/turborepo-pandacss/packages/ui/src/lib/utils.ts +6 -0
- package/templates/turborepo-pandacss/packages/ui/src/pagination.tsx +126 -0
- package/templates/turborepo-pandacss/packages/ui/src/popover.tsx +48 -0
- package/templates/turborepo-pandacss/packages/ui/src/progress.tsx +31 -0
- package/templates/turborepo-pandacss/packages/ui/src/select.tsx +185 -0
- package/templates/turborepo-pandacss/packages/ui/src/separator.tsx +28 -0
- package/templates/turborepo-pandacss/packages/ui/src/skeleton.tsx +13 -0
- package/templates/turborepo-pandacss/packages/ui/src/sonner.tsx +25 -0
- package/templates/turborepo-pandacss/packages/ui/src/table.tsx +116 -0
- package/templates/turborepo-pandacss/packages/ui/src/tabs.tsx +66 -0
- package/templates/turborepo-pandacss/packages/ui/src/textarea.tsx +18 -0
- package/templates/turborepo-pandacss/packages/ui/src/tooltip.tsx +61 -0
- package/templates/turborepo-pandacss/packages/ui/src/typography.tsx +187 -0
- package/templates/turborepo-pandacss/packages/ui/tsconfig.json +20 -0
- package/templates/turborepo-pandacss/panda.config.ts +114 -0
- package/templates/turborepo-pandacss/pnpm-lock.yaml +9032 -0
- package/templates/turborepo-pandacss/pnpm-workspace.yaml +11 -0
- package/templates/turborepo-pandacss/postcss.config.cjs +6 -0
- package/templates/turborepo-pandacss/prisma/schema.prisma +82 -0
- package/templates/turborepo-pandacss/public/file.svg +1 -0
- package/templates/turborepo-pandacss/public/globe.svg +1 -0
- package/templates/turborepo-pandacss/public/next.svg +1 -0
- package/templates/turborepo-pandacss/public/vercel.svg +1 -0
- package/templates/turborepo-pandacss/public/window.svg +1 -0
- package/templates/turborepo-pandacss/scripts/cli-template-update.ts +387 -0
- package/templates/turborepo-pandacss/scripts/env-show.ts +129 -0
- package/templates/turborepo-pandacss/scripts/env.ts +555 -0
- package/templates/turborepo-pandacss/scripts/init.sh +92 -0
- package/templates/turborepo-pandacss/scripts/setup-dev.ts +640 -0
- package/templates/turborepo-pandacss/scripts/template-update.ts +277 -0
- package/templates/turborepo-pandacss/scripts/worktree/dev.ts +872 -0
- package/templates/turborepo-pandacss/test/globals.d.ts +1 -0
- package/templates/turborepo-pandacss/test/setup.ts +22 -0
- package/templates/turborepo-pandacss/tsconfig.json +46 -0
- package/templates/turborepo-pandacss/turbo.json +57 -0
- package/templates/turborepo-pandacss/vitest.config.ts +20 -0
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
import { Slot } from "@radix-ui/react-slot";
|
|
2
|
+
import { type VariantProps, cva } from "class-variance-authority";
|
|
3
|
+
import type React from "react";
|
|
4
|
+
|
|
5
|
+
import { cn } from "@/lib/utils";
|
|
6
|
+
|
|
7
|
+
const typographyVariants = cva("", {
|
|
8
|
+
variants: {
|
|
9
|
+
variant: {
|
|
10
|
+
h1: "scroll-m-20 text-4xl font-extrabold tracking-tight lg:text-5xl",
|
|
11
|
+
h2: "scroll-m-20 border-b pb-2 text-3xl font-semibold tracking-tight first:mt-0",
|
|
12
|
+
h3: "scroll-m-20 text-2xl font-semibold tracking-tight",
|
|
13
|
+
h4: "scroll-m-20 text-xl font-semibold tracking-tight",
|
|
14
|
+
h5: "scroll-m-20 text-lg font-semibold tracking-tight",
|
|
15
|
+
h6: "scroll-m-20 text-base font-semibold tracking-tight",
|
|
16
|
+
p: "leading-7 [&:not(:first-child)]:mt-6",
|
|
17
|
+
blockquote: "mt-6 border-l-2 pl-6 italic",
|
|
18
|
+
code: "relative rounded bg-muted px-[0.3rem] py-[0.2rem] font-mono text-sm font-semibold",
|
|
19
|
+
lead: "text-xl text-muted-foreground",
|
|
20
|
+
large: "text-lg font-semibold",
|
|
21
|
+
small: "text-sm font-medium leading-none",
|
|
22
|
+
muted: "text-sm text-muted-foreground",
|
|
23
|
+
},
|
|
24
|
+
align: {
|
|
25
|
+
left: "text-left",
|
|
26
|
+
center: "text-center",
|
|
27
|
+
right: "text-right",
|
|
28
|
+
justify: "text-justify",
|
|
29
|
+
},
|
|
30
|
+
color: {
|
|
31
|
+
default: "",
|
|
32
|
+
muted: "text-muted-foreground",
|
|
33
|
+
primary: "text-primary",
|
|
34
|
+
secondary: "text-secondary-foreground",
|
|
35
|
+
accent: "text-accent-foreground",
|
|
36
|
+
destructive: "text-destructive",
|
|
37
|
+
},
|
|
38
|
+
},
|
|
39
|
+
defaultVariants: {
|
|
40
|
+
variant: "p",
|
|
41
|
+
align: "left",
|
|
42
|
+
color: "default",
|
|
43
|
+
},
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
interface TypographyProps
|
|
47
|
+
extends Omit<React.HTMLAttributes<HTMLElement>, "color">,
|
|
48
|
+
VariantProps<typeof typographyVariants> {
|
|
49
|
+
asChild?: boolean;
|
|
50
|
+
as?: React.ElementType;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
function Typography({
|
|
54
|
+
className,
|
|
55
|
+
variant,
|
|
56
|
+
align,
|
|
57
|
+
color,
|
|
58
|
+
asChild = false,
|
|
59
|
+
as,
|
|
60
|
+
...props
|
|
61
|
+
}: TypographyProps) {
|
|
62
|
+
const Component = asChild ? Slot : as || getDefaultElement(variant || "p");
|
|
63
|
+
|
|
64
|
+
return (
|
|
65
|
+
<Component
|
|
66
|
+
className={cn(typographyVariants({ variant, align, color }), className)}
|
|
67
|
+
{...props}
|
|
68
|
+
/>
|
|
69
|
+
);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
function getDefaultElement(variant: string): React.ElementType {
|
|
73
|
+
switch (variant) {
|
|
74
|
+
case "h1":
|
|
75
|
+
case "h2":
|
|
76
|
+
case "h3":
|
|
77
|
+
case "h4":
|
|
78
|
+
case "h5":
|
|
79
|
+
case "h6":
|
|
80
|
+
return variant;
|
|
81
|
+
case "blockquote":
|
|
82
|
+
return "blockquote";
|
|
83
|
+
case "code":
|
|
84
|
+
return "code";
|
|
85
|
+
default:
|
|
86
|
+
return "p";
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
// 個別のコンポーネントも提供
|
|
91
|
+
const H1 = ({
|
|
92
|
+
className,
|
|
93
|
+
...props
|
|
94
|
+
}: Omit<React.HTMLAttributes<HTMLHeadingElement>, "color">) => (
|
|
95
|
+
<Typography variant="h1" as="h1" className={className} {...props} />
|
|
96
|
+
);
|
|
97
|
+
|
|
98
|
+
const H2 = ({
|
|
99
|
+
className,
|
|
100
|
+
...props
|
|
101
|
+
}: Omit<React.HTMLAttributes<HTMLHeadingElement>, "color">) => (
|
|
102
|
+
<Typography variant="h2" as="h2" className={className} {...props} />
|
|
103
|
+
);
|
|
104
|
+
|
|
105
|
+
const H3 = ({
|
|
106
|
+
className,
|
|
107
|
+
...props
|
|
108
|
+
}: Omit<React.HTMLAttributes<HTMLHeadingElement>, "color">) => (
|
|
109
|
+
<Typography variant="h3" as="h3" className={className} {...props} />
|
|
110
|
+
);
|
|
111
|
+
|
|
112
|
+
const H4 = ({
|
|
113
|
+
className,
|
|
114
|
+
...props
|
|
115
|
+
}: Omit<React.HTMLAttributes<HTMLHeadingElement>, "color">) => (
|
|
116
|
+
<Typography variant="h4" as="h4" className={className} {...props} />
|
|
117
|
+
);
|
|
118
|
+
|
|
119
|
+
const P = ({
|
|
120
|
+
className,
|
|
121
|
+
...props
|
|
122
|
+
}: Omit<React.HTMLAttributes<HTMLParagraphElement>, "color">) => (
|
|
123
|
+
<Typography variant="p" as="p" className={className} {...props} />
|
|
124
|
+
);
|
|
125
|
+
|
|
126
|
+
const Lead = ({
|
|
127
|
+
className,
|
|
128
|
+
...props
|
|
129
|
+
}: Omit<React.HTMLAttributes<HTMLParagraphElement>, "color">) => (
|
|
130
|
+
<Typography variant="lead" as="p" className={className} {...props} />
|
|
131
|
+
);
|
|
132
|
+
|
|
133
|
+
const Large = ({
|
|
134
|
+
className,
|
|
135
|
+
...props
|
|
136
|
+
}: Omit<React.HTMLAttributes<HTMLDivElement>, "color">) => (
|
|
137
|
+
<Typography variant="large" as="div" className={className} {...props} />
|
|
138
|
+
);
|
|
139
|
+
|
|
140
|
+
const Small = ({
|
|
141
|
+
className,
|
|
142
|
+
...props
|
|
143
|
+
}: Omit<React.HTMLAttributes<HTMLElement>, "color">) => (
|
|
144
|
+
<Typography variant="small" as="small" className={className} {...props} />
|
|
145
|
+
);
|
|
146
|
+
|
|
147
|
+
const Muted = ({
|
|
148
|
+
className,
|
|
149
|
+
...props
|
|
150
|
+
}: Omit<React.HTMLAttributes<HTMLParagraphElement>, "color">) => (
|
|
151
|
+
<Typography variant="muted" as="p" className={className} {...props} />
|
|
152
|
+
);
|
|
153
|
+
|
|
154
|
+
const Blockquote = ({
|
|
155
|
+
className,
|
|
156
|
+
...props
|
|
157
|
+
}: Omit<React.HTMLAttributes<HTMLQuoteElement>, "color">) => (
|
|
158
|
+
<Typography
|
|
159
|
+
variant="blockquote"
|
|
160
|
+
as="blockquote"
|
|
161
|
+
className={className}
|
|
162
|
+
{...props}
|
|
163
|
+
/>
|
|
164
|
+
);
|
|
165
|
+
|
|
166
|
+
const InlineCode = ({
|
|
167
|
+
className,
|
|
168
|
+
...props
|
|
169
|
+
}: Omit<React.HTMLAttributes<HTMLElement>, "color">) => (
|
|
170
|
+
<Typography variant="code" as="code" className={className} {...props} />
|
|
171
|
+
);
|
|
172
|
+
|
|
173
|
+
export {
|
|
174
|
+
Typography,
|
|
175
|
+
typographyVariants,
|
|
176
|
+
H1,
|
|
177
|
+
H2,
|
|
178
|
+
H3,
|
|
179
|
+
H4,
|
|
180
|
+
P,
|
|
181
|
+
Lead,
|
|
182
|
+
Large,
|
|
183
|
+
Small,
|
|
184
|
+
Muted,
|
|
185
|
+
Blockquote,
|
|
186
|
+
InlineCode,
|
|
187
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
{
|
|
2
|
+
"extends": "@repo/config/typescript",
|
|
3
|
+
"compilerOptions": {
|
|
4
|
+
"outDir": "./dist",
|
|
5
|
+
"rootDir": "./src",
|
|
6
|
+
"jsx": "react-jsx",
|
|
7
|
+
"paths": {
|
|
8
|
+
"@/lib/*": [
|
|
9
|
+
"./src/lib/*"
|
|
10
|
+
]
|
|
11
|
+
}
|
|
12
|
+
},
|
|
13
|
+
"include": [
|
|
14
|
+
"src/**/*"
|
|
15
|
+
],
|
|
16
|
+
"exclude": [
|
|
17
|
+
"node_modules",
|
|
18
|
+
"dist"
|
|
19
|
+
]
|
|
20
|
+
}
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import { defineConfig } from "@pandacss/dev";
|
|
2
|
+
|
|
3
|
+
export default defineConfig({
|
|
4
|
+
// TailwindCSSとの共存のためpreflightを無効化
|
|
5
|
+
preflight: false,
|
|
6
|
+
|
|
7
|
+
// Where to look for your css declarations
|
|
8
|
+
include: ["./src/**/*.{js,jsx,ts,tsx}", "./pages/**/*.{js,jsx,ts,tsx}"],
|
|
9
|
+
|
|
10
|
+
// Files to exclude
|
|
11
|
+
exclude: [],
|
|
12
|
+
|
|
13
|
+
// Panda CSSクラスにプレフィックスを付けてTailwindと区別
|
|
14
|
+
prefix: "panda",
|
|
15
|
+
|
|
16
|
+
// Useful for theme customization
|
|
17
|
+
theme: {
|
|
18
|
+
extend: {
|
|
19
|
+
breakpoints: {
|
|
20
|
+
sm: "640px",
|
|
21
|
+
md: "768px",
|
|
22
|
+
lg: "1024px",
|
|
23
|
+
xl: "1280px",
|
|
24
|
+
"2xl": "1440px",
|
|
25
|
+
},
|
|
26
|
+
tokens: {
|
|
27
|
+
colors: {
|
|
28
|
+
// shadcnのカラーシステムと互換性を保つ
|
|
29
|
+
border: { value: "hsl(214.3 31.8% 91.4%)" },
|
|
30
|
+
input: { value: "hsl(214.3 31.8% 91.4%)" },
|
|
31
|
+
ring: { value: "hsl(222.2 84% 4.9%)" },
|
|
32
|
+
background: { value: "hsl(0 0% 100%)" },
|
|
33
|
+
foreground: { value: "hsl(222.2 84% 4.9%)" },
|
|
34
|
+
primary: {
|
|
35
|
+
DEFAULT: { value: "hsl(222.2 47.4% 11.2%)" },
|
|
36
|
+
foreground: { value: "hsl(210 40% 98%)" },
|
|
37
|
+
},
|
|
38
|
+
secondary: {
|
|
39
|
+
DEFAULT: { value: "hsl(210 40% 96%)" },
|
|
40
|
+
foreground: { value: "hsl(222.2 84% 4.9%)" },
|
|
41
|
+
},
|
|
42
|
+
destructive: {
|
|
43
|
+
DEFAULT: { value: "hsl(0 62.8% 30.6%)" },
|
|
44
|
+
foreground: { value: "hsl(210 40% 98%)" },
|
|
45
|
+
},
|
|
46
|
+
muted: {
|
|
47
|
+
DEFAULT: { value: "hsl(210 40% 96%)" },
|
|
48
|
+
foreground: { value: "hsl(215.4 16.3% 46.9%)" },
|
|
49
|
+
},
|
|
50
|
+
accent: {
|
|
51
|
+
DEFAULT: { value: "hsl(210 40% 96%)" },
|
|
52
|
+
foreground: { value: "hsl(222.2 84% 4.9%)" },
|
|
53
|
+
},
|
|
54
|
+
popover: {
|
|
55
|
+
DEFAULT: { value: "hsl(0 0% 100%)" },
|
|
56
|
+
foreground: { value: "hsl(222.2 84% 4.9%)" },
|
|
57
|
+
},
|
|
58
|
+
card: {
|
|
59
|
+
DEFAULT: { value: "hsl(0 0% 100%)" },
|
|
60
|
+
foreground: { value: "hsl(222.2 84% 4.9%)" },
|
|
61
|
+
},
|
|
62
|
+
},
|
|
63
|
+
},
|
|
64
|
+
recipes: {
|
|
65
|
+
// 独自のPanda CSSレシピを定義
|
|
66
|
+
pandaButton: {
|
|
67
|
+
className: "panda-button",
|
|
68
|
+
base: {
|
|
69
|
+
display: "inline-flex",
|
|
70
|
+
alignItems: "center",
|
|
71
|
+
justifyContent: "center",
|
|
72
|
+
borderRadius: "md",
|
|
73
|
+
fontSize: "sm",
|
|
74
|
+
fontWeight: "medium",
|
|
75
|
+
transition: "all 0.2s",
|
|
76
|
+
cursor: "pointer",
|
|
77
|
+
_disabled: {
|
|
78
|
+
pointerEvents: "none",
|
|
79
|
+
opacity: 0.5,
|
|
80
|
+
},
|
|
81
|
+
},
|
|
82
|
+
variants: {
|
|
83
|
+
variant: {
|
|
84
|
+
primary: {
|
|
85
|
+
bg: "primary",
|
|
86
|
+
color: "primary.foreground",
|
|
87
|
+
_hover: { opacity: 0.9 },
|
|
88
|
+
},
|
|
89
|
+
secondary: {
|
|
90
|
+
bg: "secondary",
|
|
91
|
+
color: "secondary.foreground",
|
|
92
|
+
_hover: { opacity: 0.8 },
|
|
93
|
+
},
|
|
94
|
+
},
|
|
95
|
+
size: {
|
|
96
|
+
sm: { h: "8", px: "3" },
|
|
97
|
+
md: { h: "10", px: "4" },
|
|
98
|
+
lg: { h: "12", px: "6" },
|
|
99
|
+
},
|
|
100
|
+
},
|
|
101
|
+
defaultVariants: {
|
|
102
|
+
variant: "primary",
|
|
103
|
+
size: "md",
|
|
104
|
+
},
|
|
105
|
+
},
|
|
106
|
+
},
|
|
107
|
+
},
|
|
108
|
+
},
|
|
109
|
+
|
|
110
|
+
// The output directory for your css system
|
|
111
|
+
outdir: "styled-system",
|
|
112
|
+
|
|
113
|
+
jsxFramework: "react",
|
|
114
|
+
});
|