create-einja-app 0.2.17 → 0.2.19

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.
Files changed (275) hide show
  1. package/README.md +1 -0
  2. package/dist/cli.js +685 -1715
  3. package/dist/cli.js.map +1 -1
  4. package/package.json +2 -2
  5. package/templates/default/.claude/hooks/einja/playwright-resize.sh +12 -2
  6. package/templates/default/.claude/settings.json +16 -0
  7. package/templates/default/.cursor/commands/task-vibe-kanban-loop.md +107 -42
  8. package/templates/default/.env.develop +0 -4
  9. package/templates/default/.env.example +1 -0
  10. package/templates/default/.env.preview +0 -4
  11. package/templates/default/.env.staging +19 -0
  12. package/templates/default/.github/actions/ci/action.yml +39 -0
  13. package/templates/default/.github/actions/migrate/action.yml +39 -0
  14. package/templates/default/.github/actions/neon-export-env/action.yml +28 -0
  15. package/templates/default/.github/actions/setup/action.yml +20 -0
  16. package/templates/default/.github/workflows/claude.yml +1 -0
  17. package/templates/default/.github/workflows/{cleanup-neon-branches.yml → cleanup-pr-preview-db.yml} +28 -24
  18. package/templates/default/.github/workflows/cleanup-pr-preview-on-close.yml +50 -0
  19. package/templates/default/.github/workflows/deploy-pr-preview.yml +398 -0
  20. package/templates/default/.github/workflows/deploy-stable-branches.yml +259 -0
  21. package/templates/default/.github/workflows/release-create-einja-app.yml +95 -0
  22. package/templates/default/.mcp.json +29 -11
  23. package/templates/default/.serena/project.yml +4 -0
  24. package/templates/default/.vscode/settings.json +18 -0
  25. package/templates/default/CLAUDE.md +129 -353
  26. package/templates/default/README.md +5 -14
  27. package/templates/default/apps/admin/next.config.ts +11 -0
  28. package/templates/default/apps/admin/package.json +55 -0
  29. package/templates/default/apps/admin/postcss.config.cjs +5 -0
  30. package/templates/default/apps/admin/src/app/(auth)/forgot-password/page.tsx +97 -0
  31. package/templates/default/apps/admin/src/app/(auth)/layout.tsx +18 -0
  32. package/templates/default/apps/admin/src/app/(auth)/otp/page.tsx +121 -0
  33. package/templates/default/apps/admin/src/app/(auth)/sign-in/page.tsx +145 -0
  34. package/templates/default/apps/admin/src/app/(auth)/sign-up/page.tsx +199 -0
  35. package/templates/default/apps/admin/src/app/(errors)/401/page.tsx +27 -0
  36. package/templates/default/apps/admin/src/app/(errors)/403/page.tsx +28 -0
  37. package/templates/default/apps/admin/src/app/(errors)/500/page.tsx +29 -0
  38. package/templates/default/apps/admin/src/app/(errors)/layout.tsx +7 -0
  39. package/templates/default/apps/admin/src/app/(errors)/maintenance/page.tsx +25 -0
  40. package/templates/default/apps/admin/src/app/dashboard/_components/analytics-chart.tsx +68 -0
  41. package/templates/default/apps/admin/src/app/dashboard/_components/analytics.tsx +182 -0
  42. package/templates/default/apps/admin/src/app/dashboard/_components/dashboard-page.tsx +74 -0
  43. package/templates/default/apps/admin/src/app/dashboard/_components/metric-cards.tsx +49 -0
  44. package/templates/default/apps/admin/src/app/dashboard/_components/overview-chart.tsx +73 -0
  45. package/templates/default/apps/admin/src/app/dashboard/_components/recent-sales.tsx +75 -0
  46. package/templates/default/apps/admin/src/app/dashboard/apps/_components/apps-page.tsx +135 -0
  47. package/templates/default/apps/admin/src/app/dashboard/apps/page.tsx +10 -0
  48. package/templates/default/apps/admin/src/app/dashboard/chats/_components/chat-list.tsx +82 -0
  49. package/templates/default/apps/admin/src/app/dashboard/chats/_components/chat-messages.tsx +194 -0
  50. package/templates/default/apps/admin/src/app/dashboard/chats/_components/chats-page.tsx +99 -0
  51. package/templates/default/apps/admin/src/app/dashboard/chats/_components/new-chat.tsx +118 -0
  52. package/templates/default/apps/admin/src/app/dashboard/chats/page.tsx +10 -0
  53. package/templates/default/apps/admin/src/app/dashboard/layout.tsx +9 -0
  54. package/templates/default/apps/admin/src/app/dashboard/not-found.tsx +14 -0
  55. package/templates/default/apps/admin/src/app/dashboard/page.tsx +10 -0
  56. package/templates/default/apps/admin/src/app/dashboard/settings/_components/content-section.tsx +20 -0
  57. package/templates/default/apps/admin/src/app/dashboard/settings/_components/sidebar-nav.tsx +66 -0
  58. package/templates/default/apps/admin/src/app/dashboard/settings/account/page.tsx +173 -0
  59. package/templates/default/apps/admin/src/app/dashboard/settings/appearance/page.tsx +156 -0
  60. package/templates/default/apps/admin/src/app/dashboard/settings/display/page.tsx +125 -0
  61. package/templates/default/apps/admin/src/app/dashboard/settings/layout.tsx +30 -0
  62. package/templates/default/apps/admin/src/app/dashboard/settings/notifications/page.tsx +196 -0
  63. package/templates/default/apps/admin/src/app/dashboard/settings/page.tsx +5 -0
  64. package/templates/default/apps/admin/src/app/dashboard/settings/profile/page.tsx +176 -0
  65. package/templates/default/apps/admin/src/app/dashboard/tasks/_components/data-table-bulk-actions.tsx +183 -0
  66. package/templates/default/apps/admin/src/app/dashboard/tasks/_components/data-table-row-actions.tsx +79 -0
  67. package/templates/default/apps/admin/src/app/dashboard/tasks/_components/tasks-columns.tsx +107 -0
  68. package/templates/default/apps/admin/src/app/dashboard/tasks/_components/tasks-dialogs.tsx +71 -0
  69. package/templates/default/apps/admin/src/app/dashboard/tasks/_components/tasks-import-dialog.tsx +106 -0
  70. package/templates/default/apps/admin/src/app/dashboard/tasks/_components/tasks-multi-delete-dialog.tsx +90 -0
  71. package/templates/default/apps/admin/src/app/dashboard/tasks/_components/tasks-mutate-drawer.tsx +207 -0
  72. package/templates/default/apps/admin/src/app/dashboard/tasks/_components/tasks-page.tsx +31 -0
  73. package/templates/default/apps/admin/src/app/dashboard/tasks/_components/tasks-primary-buttons.tsx +19 -0
  74. package/templates/default/apps/admin/src/app/dashboard/tasks/_components/tasks-provider.tsx +37 -0
  75. package/templates/default/apps/admin/src/app/dashboard/tasks/_components/tasks-table.tsx +155 -0
  76. package/templates/default/apps/admin/src/app/dashboard/tasks/page.tsx +14 -0
  77. package/templates/default/apps/admin/src/app/dashboard/users/_components/data-table-bulk-actions.tsx +136 -0
  78. package/templates/default/apps/admin/src/app/dashboard/users/_components/data-table-row-actions.tsx +62 -0
  79. package/templates/default/apps/admin/src/app/dashboard/users/_components/users-action-dialog.tsx +297 -0
  80. package/templates/default/apps/admin/src/app/dashboard/users/_components/users-columns.tsx +121 -0
  81. package/templates/default/apps/admin/src/app/dashboard/users/_components/users-delete-dialog.tsx +72 -0
  82. package/templates/default/apps/admin/src/app/dashboard/users/_components/users-dialogs.tsx +49 -0
  83. package/templates/default/apps/admin/src/app/dashboard/users/_components/users-invite-dialog.tsx +139 -0
  84. package/templates/default/apps/admin/src/app/dashboard/users/_components/users-multi-delete-dialog.tsx +89 -0
  85. package/templates/default/apps/admin/src/app/dashboard/users/_components/users-page.tsx +30 -0
  86. package/templates/default/apps/admin/src/app/dashboard/users/_components/users-primary-buttons.tsx +19 -0
  87. package/templates/default/apps/admin/src/app/dashboard/users/_components/users-provider.tsx +35 -0
  88. package/templates/default/apps/admin/src/app/dashboard/users/_components/users-table.tsx +157 -0
  89. package/templates/default/apps/admin/src/app/dashboard/users/page.tsx +10 -0
  90. package/templates/default/apps/admin/src/app/globals.css +109 -0
  91. package/templates/default/apps/admin/src/app/layout.tsx +32 -0
  92. package/templates/default/apps/admin/src/app/not-found.tsx +14 -0
  93. package/templates/default/apps/admin/src/app/page.tsx +5 -0
  94. package/templates/default/apps/admin/src/components/layout/admin-layout.tsx +16 -0
  95. package/templates/default/apps/admin/src/components/layout/app-sidebar.tsx +52 -0
  96. package/templates/default/apps/admin/src/components/layout/nav-config.ts +131 -0
  97. package/templates/default/apps/admin/src/components/providers/theme-provider.tsx +10 -0
  98. package/templates/default/apps/admin/src/components/shared/long-text.tsx +78 -0
  99. package/templates/default/apps/admin/src/components/shared/search-input.tsx +16 -0
  100. package/templates/default/apps/admin/src/components/shared/select-dropdown.tsx +64 -0
  101. package/templates/default/apps/admin/src/data/apps.tsx +116 -0
  102. package/templates/default/apps/admin/src/data/chats.ts +114 -0
  103. package/templates/default/apps/admin/src/data/tasks.ts +114 -0
  104. package/templates/default/apps/admin/src/data/users.ts +90 -0
  105. package/templates/default/apps/admin/src/hooks/use-dialog-state.ts +17 -0
  106. package/templates/default/apps/admin/src/hooks/use-table-url-state.ts +243 -0
  107. package/templates/default/apps/admin/src/lib/show-submitted-data.tsx +12 -0
  108. package/templates/default/apps/admin/src/types/table.d.ts +9 -0
  109. package/templates/default/apps/admin/tsconfig.json +32 -0
  110. package/templates/default/apps/web/next.config.ts +1 -0
  111. package/templates/default/apps/web/package.json +0 -22
  112. package/templates/default/apps/web/postcss.config.cjs +0 -1
  113. package/templates/default/apps/web/src/app/(authenticated)/dashboard/page.tsx +4 -20
  114. package/templates/default/apps/web/src/app/(authenticated)/data/_components/UserTable.tsx +4 -4
  115. package/templates/default/apps/web/src/app/(authenticated)/data/page.tsx +1 -1
  116. package/templates/default/apps/web/src/app/(authenticated)/profile/page.tsx +1 -1
  117. package/templates/default/apps/web/src/app/error.tsx +8 -70
  118. package/templates/default/apps/web/src/app/global-error.tsx +8 -70
  119. package/templates/default/apps/web/src/app/globals.css +20 -0
  120. package/templates/default/apps/web/src/app/not-found.tsx +5 -39
  121. package/templates/default/apps/web/src/app/page.tsx +27 -203
  122. package/templates/default/apps/web/src/app/signin/page.tsx +27 -191
  123. package/templates/default/apps/web/src/app/signup/page.tsx +33 -240
  124. package/templates/default/apps/web/src/components/dashboard/dashboard-stats.tsx +11 -75
  125. package/templates/default/apps/web/src/components/shared/Sidebar.tsx +3 -3
  126. package/templates/default/apps/web/src/components/shared/header.tsx +17 -112
  127. package/templates/default/apps/web/tsconfig.json +0 -6
  128. package/templates/default/biome.json +1 -2
  129. package/templates/default/components.json +2 -2
  130. package/templates/default/docker-compose.yml +1 -1
  131. package/templates/default/gitignore +4 -0
  132. package/templates/default/package.json +1 -0
  133. package/templates/default/packages/admin-ui/catalog/catalog.css +54 -0
  134. package/templates/default/packages/admin-ui/catalog/catalog.tsx +401 -0
  135. package/templates/default/packages/admin-ui/catalog/index.html +12 -0
  136. package/templates/default/packages/admin-ui/catalog/main.tsx +9 -0
  137. package/templates/default/packages/admin-ui/components.json +21 -0
  138. package/templates/default/packages/admin-ui/package.json +105 -0
  139. package/templates/default/packages/admin-ui/src/command-menu/index.tsx +174 -0
  140. package/templates/default/packages/admin-ui/src/data-table/bulk-actions.tsx +215 -0
  141. package/templates/default/packages/admin-ui/src/data-table/column-header.tsx +73 -0
  142. package/templates/default/packages/admin-ui/src/data-table/data-table.tsx +127 -0
  143. package/templates/default/packages/admin-ui/src/data-table/faceted-filter.tsx +148 -0
  144. package/templates/default/packages/admin-ui/src/data-table/index.tsx +9 -0
  145. package/templates/default/packages/admin-ui/src/data-table/pagination.tsx +101 -0
  146. package/templates/default/packages/admin-ui/src/data-table/toolbar.tsx +87 -0
  147. package/templates/default/packages/admin-ui/src/data-table/view-options.tsx +57 -0
  148. package/templates/default/packages/admin-ui/src/hooks/use-mobile.tsx +23 -0
  149. package/templates/default/packages/admin-ui/src/layout/header.tsx +55 -0
  150. package/templates/default/packages/admin-ui/src/layout/index.ts +10 -0
  151. package/templates/default/packages/admin-ui/src/layout/main.tsx +23 -0
  152. package/templates/default/packages/admin-ui/src/layout/nav-group.tsx +111 -0
  153. package/templates/default/packages/admin-ui/src/layout/nav-user.tsx +114 -0
  154. package/templates/default/packages/admin-ui/src/layout/theme-switch.tsx +40 -0
  155. package/templates/default/packages/admin-ui/src/layout/types.ts +21 -0
  156. package/templates/default/packages/admin-ui/src/lib/utils.ts +6 -0
  157. package/templates/default/packages/admin-ui/src/styles/base.css +65 -0
  158. package/templates/default/packages/admin-ui/src/styles/tokens.css +91 -0
  159. package/templates/default/packages/admin-ui/src/tanstack-table.d.ts +10 -0
  160. package/templates/default/packages/admin-ui/src/ui/alert-dialog.tsx +157 -0
  161. package/templates/default/packages/admin-ui/src/ui/alert.tsx +66 -0
  162. package/templates/default/packages/admin-ui/src/ui/avatar.tsx +53 -0
  163. package/templates/default/packages/admin-ui/src/ui/badge.tsx +46 -0
  164. package/templates/default/packages/admin-ui/src/ui/breadcrumb.tsx +108 -0
  165. package/templates/default/packages/admin-ui/src/ui/button.tsx +59 -0
  166. package/templates/default/packages/admin-ui/src/ui/calendar.tsx +69 -0
  167. package/templates/default/packages/admin-ui/src/ui/card.tsx +92 -0
  168. package/templates/default/packages/admin-ui/src/ui/chart.tsx +345 -0
  169. package/templates/default/packages/admin-ui/src/ui/checkbox.tsx +32 -0
  170. package/templates/default/packages/admin-ui/src/ui/collapsible.tsx +27 -0
  171. package/templates/default/packages/admin-ui/src/ui/command.tsx +161 -0
  172. package/templates/default/packages/admin-ui/src/ui/confirm-dialog.tsx +72 -0
  173. package/templates/default/packages/admin-ui/src/ui/date-picker.tsx +53 -0
  174. package/templates/default/packages/admin-ui/src/ui/dialog.tsx +143 -0
  175. package/templates/default/packages/admin-ui/src/ui/dropdown-menu.tsx +257 -0
  176. package/templates/default/packages/admin-ui/src/ui/form.tsx +168 -0
  177. package/templates/default/packages/admin-ui/src/ui/input-otp.tsx +84 -0
  178. package/templates/default/packages/admin-ui/src/ui/input.tsx +21 -0
  179. package/templates/default/packages/admin-ui/src/ui/label.tsx +24 -0
  180. package/templates/default/packages/admin-ui/src/ui/pagination.tsx +126 -0
  181. package/templates/default/packages/admin-ui/src/ui/password-input.tsx +46 -0
  182. package/templates/default/packages/admin-ui/src/ui/popover.tsx +48 -0
  183. package/templates/default/packages/admin-ui/src/ui/progress.tsx +31 -0
  184. package/templates/default/packages/admin-ui/src/ui/radio-group.tsx +45 -0
  185. package/templates/default/packages/admin-ui/src/ui/scroll-area.tsx +52 -0
  186. package/templates/default/packages/admin-ui/src/ui/select.tsx +185 -0
  187. package/templates/default/packages/admin-ui/src/ui/separator.tsx +28 -0
  188. package/templates/default/packages/admin-ui/src/ui/sheet.tsx +149 -0
  189. package/templates/default/packages/admin-ui/src/ui/sidebar.tsx +728 -0
  190. package/templates/default/packages/admin-ui/src/ui/skeleton.tsx +13 -0
  191. package/templates/default/packages/admin-ui/src/ui/sonner.tsx +25 -0
  192. package/templates/default/packages/admin-ui/src/ui/switch.tsx +31 -0
  193. package/templates/default/packages/admin-ui/src/ui/table.tsx +116 -0
  194. package/templates/default/packages/admin-ui/src/ui/tabs.tsx +66 -0
  195. package/templates/default/packages/admin-ui/src/ui/textarea.tsx +18 -0
  196. package/templates/default/packages/admin-ui/src/ui/toggle-group.tsx +60 -0
  197. package/templates/default/packages/admin-ui/src/ui/toggle.tsx +44 -0
  198. package/templates/default/packages/admin-ui/src/ui/tooltip.tsx +61 -0
  199. package/templates/default/packages/admin-ui/tsconfig.json +8 -0
  200. package/templates/default/packages/admin-ui/vite.config.ts +11 -0
  201. package/templates/default/packages/config/package.json +0 -2
  202. package/templates/default/packages/server-core/package.json +1 -0
  203. package/templates/default/packages/ui/components.json +21 -0
  204. package/templates/default/packages/ui/package.json +42 -5
  205. package/templates/default/packages/ui/src/accordion.tsx +1 -1
  206. package/templates/default/packages/ui/src/alert-dialog.tsx +4 -4
  207. package/templates/default/packages/ui/src/alert.tsx +1 -1
  208. package/templates/default/packages/ui/src/avatar.tsx +1 -1
  209. package/templates/default/packages/ui/src/badge.tsx +1 -1
  210. package/templates/default/packages/ui/src/breadcrumb.tsx +1 -1
  211. package/templates/default/packages/ui/src/button.tsx +1 -1
  212. package/templates/default/packages/ui/src/card.tsx +1 -1
  213. package/templates/default/packages/ui/src/checkbox.tsx +1 -1
  214. package/templates/default/packages/ui/src/dialog.tsx +3 -3
  215. package/templates/default/packages/ui/src/drawer.tsx +3 -3
  216. package/templates/default/packages/ui/src/dropdown-menu.tsx +3 -3
  217. package/templates/default/packages/ui/src/form.tsx +2 -2
  218. package/templates/default/packages/ui/src/hover-card.tsx +2 -2
  219. package/templates/default/packages/ui/src/input.tsx +1 -1
  220. package/templates/default/packages/ui/src/label.tsx +1 -1
  221. package/templates/default/packages/ui/src/pagination.tsx +2 -2
  222. package/templates/default/packages/ui/src/popover.tsx +2 -2
  223. package/templates/default/packages/ui/src/progress.tsx +1 -1
  224. package/templates/default/packages/ui/src/select.tsx +2 -2
  225. package/templates/default/packages/ui/src/separator.tsx +1 -1
  226. package/templates/default/packages/ui/src/skeleton.tsx +1 -1
  227. package/templates/default/packages/ui/src/table.tsx +1 -1
  228. package/templates/default/packages/ui/src/tabs.tsx +1 -1
  229. package/templates/default/packages/ui/src/textarea.tsx +1 -1
  230. package/templates/default/packages/ui/src/tooltip.tsx +3 -3
  231. package/templates/default/packages/ui/src/typography.tsx +1 -1
  232. package/templates/default/packages/ui/tsconfig.json +1 -6
  233. package/templates/default/pnpm-lock.yaml +1319 -936
  234. package/templates/default/postcss.config.cjs +0 -1
  235. package/templates/default/turbo.json +11 -5
  236. package/templates/default/worktree.config.json +5 -0
  237. package/templates/default/.env.ci +0 -32
  238. package/templates/default/.github/workflows/ci.yml +0 -96
  239. package/templates/default/.github/workflows/preview-db.yml +0 -134
  240. package/templates/default/.playwright-mcp/dashboard.png +0 -0
  241. package/templates/default/.playwright-mcp/web-home.png +0 -0
  242. package/templates/default/apps/web/panda.config.ts +0 -114
  243. package/templates/default/apps/web/src/components/ui/accordion.tsx +0 -64
  244. package/templates/default/apps/web/src/components/ui/alert-dialog.tsx +0 -135
  245. package/templates/default/apps/web/src/components/ui/alert.tsx +0 -60
  246. package/templates/default/apps/web/src/components/ui/aspect-ratio.tsx +0 -9
  247. package/templates/default/apps/web/src/components/ui/avatar.tsx +0 -41
  248. package/templates/default/apps/web/src/components/ui/badge.tsx +0 -39
  249. package/templates/default/apps/web/src/components/ui/breadcrumb.tsx +0 -101
  250. package/templates/default/apps/web/src/components/ui/button.tsx +0 -56
  251. package/templates/default/apps/web/src/components/ui/card.tsx +0 -75
  252. package/templates/default/apps/web/src/components/ui/checkbox.tsx +0 -29
  253. package/templates/default/apps/web/src/components/ui/data-table.tsx +0 -189
  254. package/templates/default/apps/web/src/components/ui/dialog-hook.tsx +0 -210
  255. package/templates/default/apps/web/src/components/ui/dialog.tsx +0 -129
  256. package/templates/default/apps/web/src/components/ui/drawer.tsx +0 -124
  257. package/templates/default/apps/web/src/components/ui/dropdown-menu.tsx +0 -228
  258. package/templates/default/apps/web/src/components/ui/form.tsx +0 -152
  259. package/templates/default/apps/web/src/components/ui/hover-card.tsx +0 -38
  260. package/templates/default/apps/web/src/components/ui/input.tsx +0 -21
  261. package/templates/default/apps/web/src/components/ui/label.tsx +0 -21
  262. package/templates/default/apps/web/src/components/ui/pagination.tsx +0 -105
  263. package/templates/default/apps/web/src/components/ui/popover.tsx +0 -42
  264. package/templates/default/apps/web/src/components/ui/progress.tsx +0 -28
  265. package/templates/default/apps/web/src/components/ui/select.tsx +0 -170
  266. package/templates/default/apps/web/src/components/ui/separator.tsx +0 -28
  267. package/templates/default/apps/web/src/components/ui/skeleton.tsx +0 -13
  268. package/templates/default/apps/web/src/components/ui/sonner.tsx +0 -25
  269. package/templates/default/apps/web/src/components/ui/table.tsx +0 -92
  270. package/templates/default/apps/web/src/components/ui/tabs.tsx +0 -54
  271. package/templates/default/apps/web/src/components/ui/textarea.tsx +0 -18
  272. package/templates/default/apps/web/src/components/ui/tooltip.tsx +0 -57
  273. package/templates/default/apps/web/src/components/ui/typography.tsx +0 -158
  274. package/templates/default/packages/config/panda.config.ts +0 -114
  275. package/templates/default/panda.config.ts +0 -114
@@ -1,92 +0,0 @@
1
- "use client";
2
-
3
- import type * as React from "react";
4
-
5
- import { cn } from "{{packageName}}/ui/utils";
6
-
7
- function Table({ className, ...props }: React.ComponentProps<"table">) {
8
- return (
9
- <div data-slot="table-container" className="relative w-full overflow-x-auto">
10
- <table
11
- data-slot="table"
12
- className={cn("w-full caption-bottom text-sm", className)}
13
- {...props}
14
- />
15
- </div>
16
- );
17
- }
18
-
19
- function TableHeader({ className, ...props }: React.ComponentProps<"thead">) {
20
- return <thead data-slot="table-header" className={cn("[&_tr]:border-b", className)} {...props} />;
21
- }
22
-
23
- function TableBody({ className, ...props }: React.ComponentProps<"tbody">) {
24
- return (
25
- <tbody
26
- data-slot="table-body"
27
- className={cn("[&_tr:last-child]:border-0", className)}
28
- {...props}
29
- />
30
- );
31
- }
32
-
33
- function TableFooter({ className, ...props }: React.ComponentProps<"tfoot">) {
34
- return (
35
- <tfoot
36
- data-slot="table-footer"
37
- className={cn("bg-muted/50 border-t font-medium [&>tr]:last:border-b-0", className)}
38
- {...props}
39
- />
40
- );
41
- }
42
-
43
- function TableRow({ className, ...props }: React.ComponentProps<"tr">) {
44
- return (
45
- <tr
46
- data-slot="table-row"
47
- className={cn(
48
- "hover:bg-muted/50 data-[state=selected]:bg-muted border-b transition-colors",
49
- className
50
- )}
51
- {...props}
52
- />
53
- );
54
- }
55
-
56
- function TableHead({ className, ...props }: React.ComponentProps<"th">) {
57
- return (
58
- <th
59
- data-slot="table-head"
60
- className={cn(
61
- "text-foreground h-10 px-2 text-left align-middle font-medium whitespace-nowrap [&:has([role=checkbox])]:pr-0 [&>[role=checkbox]]:translate-y-[2px]",
62
- className
63
- )}
64
- {...props}
65
- />
66
- );
67
- }
68
-
69
- function TableCell({ className, ...props }: React.ComponentProps<"td">) {
70
- return (
71
- <td
72
- data-slot="table-cell"
73
- className={cn(
74
- "p-2 align-middle whitespace-nowrap [&:has([role=checkbox])]:pr-0 [&>[role=checkbox]]:translate-y-[2px]",
75
- className
76
- )}
77
- {...props}
78
- />
79
- );
80
- }
81
-
82
- function TableCaption({ className, ...props }: React.ComponentProps<"caption">) {
83
- return (
84
- <caption
85
- data-slot="table-caption"
86
- className={cn("text-muted-foreground mt-4 text-sm", className)}
87
- {...props}
88
- />
89
- );
90
- }
91
-
92
- export { Table, TableHeader, TableBody, TableFooter, TableHead, TableRow, TableCell, TableCaption };
@@ -1,54 +0,0 @@
1
- "use client";
2
-
3
- import * as TabsPrimitive from "@radix-ui/react-tabs";
4
- import type * as React from "react";
5
-
6
- import { cn } from "{{packageName}}/ui/utils";
7
-
8
- function Tabs({ className, ...props }: React.ComponentProps<typeof TabsPrimitive.Root>) {
9
- return (
10
- <TabsPrimitive.Root
11
- data-slot="tabs"
12
- className={cn("flex flex-col gap-2", className)}
13
- {...props}
14
- />
15
- );
16
- }
17
-
18
- function TabsList({ className, ...props }: React.ComponentProps<typeof TabsPrimitive.List>) {
19
- return (
20
- <TabsPrimitive.List
21
- data-slot="tabs-list"
22
- className={cn(
23
- "bg-muted text-muted-foreground inline-flex h-9 w-fit items-center justify-center rounded-lg p-[3px]",
24
- className
25
- )}
26
- {...props}
27
- />
28
- );
29
- }
30
-
31
- function TabsTrigger({ className, ...props }: React.ComponentProps<typeof TabsPrimitive.Trigger>) {
32
- return (
33
- <TabsPrimitive.Trigger
34
- data-slot="tabs-trigger"
35
- className={cn(
36
- "data-[state=active]:bg-background dark:data-[state=active]:text-foreground focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:outline-ring dark:data-[state=active]:border-input dark:data-[state=active]:bg-input/30 text-foreground dark:text-muted-foreground inline-flex h-[calc(100%-1px)] flex-1 items-center justify-center gap-1.5 rounded-md border border-transparent px-2 py-1 text-sm font-medium whitespace-nowrap transition-[color,box-shadow] focus-visible:ring-[3px] focus-visible:outline-1 disabled:pointer-events-none disabled:opacity-50 data-[state=active]:shadow-sm [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
37
- className
38
- )}
39
- {...props}
40
- />
41
- );
42
- }
43
-
44
- function TabsContent({ className, ...props }: React.ComponentProps<typeof TabsPrimitive.Content>) {
45
- return (
46
- <TabsPrimitive.Content
47
- data-slot="tabs-content"
48
- className={cn("flex-1 outline-none", className)}
49
- {...props}
50
- />
51
- );
52
- }
53
-
54
- export { Tabs, TabsList, TabsTrigger, TabsContent };
@@ -1,18 +0,0 @@
1
- import type * as React from "react";
2
-
3
- import { cn } from "{{packageName}}/ui/utils";
4
-
5
- function Textarea({ className, ...props }: React.ComponentProps<"textarea">) {
6
- return (
7
- <textarea
8
- data-slot="textarea"
9
- className={cn(
10
- "border-input placeholder:text-muted-foreground focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 flex field-sizing-content min-h-16 w-full rounded-md border bg-transparent px-3 py-2 text-base shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50 md:text-sm",
11
- className
12
- )}
13
- {...props}
14
- />
15
- );
16
- }
17
-
18
- export { Textarea };
@@ -1,57 +0,0 @@
1
- "use client";
2
-
3
- import * as TooltipPrimitive from "@radix-ui/react-tooltip";
4
- import type * as React from "react";
5
-
6
- import { cn } from "{{packageName}}/ui/utils";
7
-
8
- function TooltipProvider({
9
- delayDuration = 0,
10
- ...props
11
- }: React.ComponentProps<typeof TooltipPrimitive.Provider>) {
12
- return (
13
- <TooltipPrimitive.Provider
14
- data-slot="tooltip-provider"
15
- delayDuration={delayDuration}
16
- {...props}
17
- />
18
- );
19
- }
20
-
21
- function Tooltip({ ...props }: React.ComponentProps<typeof TooltipPrimitive.Root>) {
22
- return (
23
- <TooltipProvider>
24
- <TooltipPrimitive.Root data-slot="tooltip" {...props} />
25
- </TooltipProvider>
26
- );
27
- }
28
-
29
- function TooltipTrigger({ ...props }: React.ComponentProps<typeof TooltipPrimitive.Trigger>) {
30
- return <TooltipPrimitive.Trigger data-slot="tooltip-trigger" {...props} />;
31
- }
32
-
33
- function TooltipContent({
34
- className,
35
- sideOffset = 0,
36
- children,
37
- ...props
38
- }: React.ComponentProps<typeof TooltipPrimitive.Content>) {
39
- return (
40
- <TooltipPrimitive.Portal>
41
- <TooltipPrimitive.Content
42
- data-slot="tooltip-content"
43
- sideOffset={sideOffset}
44
- className={cn(
45
- "bg-primary text-primary-foreground animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 w-fit origin-(--radix-tooltip-content-transform-origin) rounded-md px-3 py-1.5 text-xs text-balance",
46
- className
47
- )}
48
- {...props}
49
- >
50
- {children}
51
- <TooltipPrimitive.Arrow className="bg-primary fill-primary z-50 size-2.5 translate-y-[calc(-50%_-_2px)] rotate-45 rounded-[2px]" />
52
- </TooltipPrimitive.Content>
53
- </TooltipPrimitive.Portal>
54
- );
55
- }
56
-
57
- export { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider };
@@ -1,158 +0,0 @@
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 "{{packageName}}/ui/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 = ({ className, ...props }: Omit<React.HTMLAttributes<HTMLHeadingElement>, "color">) => (
92
- <Typography variant="h1" as="h1" className={className} {...props} />
93
- );
94
-
95
- const H2 = ({ className, ...props }: Omit<React.HTMLAttributes<HTMLHeadingElement>, "color">) => (
96
- <Typography variant="h2" as="h2" className={className} {...props} />
97
- );
98
-
99
- const H3 = ({ className, ...props }: Omit<React.HTMLAttributes<HTMLHeadingElement>, "color">) => (
100
- <Typography variant="h3" as="h3" className={className} {...props} />
101
- );
102
-
103
- const H4 = ({ className, ...props }: Omit<React.HTMLAttributes<HTMLHeadingElement>, "color">) => (
104
- <Typography variant="h4" as="h4" className={className} {...props} />
105
- );
106
-
107
- const P = ({ className, ...props }: Omit<React.HTMLAttributes<HTMLParagraphElement>, "color">) => (
108
- <Typography variant="p" as="p" className={className} {...props} />
109
- );
110
-
111
- const Lead = ({
112
- className,
113
- ...props
114
- }: Omit<React.HTMLAttributes<HTMLParagraphElement>, "color">) => (
115
- <Typography variant="lead" as="p" className={className} {...props} />
116
- );
117
-
118
- const Large = ({ className, ...props }: Omit<React.HTMLAttributes<HTMLDivElement>, "color">) => (
119
- <Typography variant="large" as="div" className={className} {...props} />
120
- );
121
-
122
- const Small = ({ className, ...props }: Omit<React.HTMLAttributes<HTMLElement>, "color">) => (
123
- <Typography variant="small" as="small" className={className} {...props} />
124
- );
125
-
126
- const Muted = ({
127
- className,
128
- ...props
129
- }: Omit<React.HTMLAttributes<HTMLParagraphElement>, "color">) => (
130
- <Typography variant="muted" as="p" className={className} {...props} />
131
- );
132
-
133
- const Blockquote = ({
134
- className,
135
- ...props
136
- }: Omit<React.HTMLAttributes<HTMLQuoteElement>, "color">) => (
137
- <Typography variant="blockquote" as="blockquote" className={className} {...props} />
138
- );
139
-
140
- const InlineCode = ({ className, ...props }: Omit<React.HTMLAttributes<HTMLElement>, "color">) => (
141
- <Typography variant="code" as="code" className={className} {...props} />
142
- );
143
-
144
- export {
145
- Typography,
146
- typographyVariants,
147
- H1,
148
- H2,
149
- H3,
150
- H4,
151
- P,
152
- Lead,
153
- Large,
154
- Small,
155
- Muted,
156
- Blockquote,
157
- InlineCode,
158
- };
@@ -1,114 +0,0 @@
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
- });
@@ -1,114 +0,0 @@
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
- });