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
@@ -0,0 +1,64 @@
1
+ "use client";
2
+
3
+ import { cn } from "{{packageName}}/admin-ui/lib/utils";
4
+ import { FormControl } from "{{packageName}}/admin-ui/ui/form";
5
+ import {
6
+ Select,
7
+ SelectContent,
8
+ SelectItem,
9
+ SelectTrigger,
10
+ SelectValue,
11
+ } from "{{packageName}}/admin-ui/ui/select";
12
+ import { Loader } from "lucide-react";
13
+
14
+ type SelectDropdownProps = {
15
+ onValueChange?: (value: string) => void;
16
+ defaultValue: string | undefined;
17
+ placeholder?: string;
18
+ isPending?: boolean;
19
+ items: { label: string; value: string }[] | undefined;
20
+ disabled?: boolean;
21
+ className?: string;
22
+ isControlled?: boolean;
23
+ };
24
+
25
+ export function SelectDropdown({
26
+ defaultValue,
27
+ onValueChange,
28
+ isPending,
29
+ items,
30
+ placeholder,
31
+ disabled,
32
+ className = "",
33
+ isControlled = false,
34
+ }: SelectDropdownProps) {
35
+ const defaultState = isControlled
36
+ ? { value: defaultValue, onValueChange }
37
+ : { defaultValue, onValueChange };
38
+ return (
39
+ <Select {...defaultState}>
40
+ <FormControl>
41
+ <SelectTrigger disabled={disabled} className={cn(className)}>
42
+ <SelectValue placeholder={placeholder ?? "Select"} />
43
+ </SelectTrigger>
44
+ </FormControl>
45
+ <SelectContent>
46
+ {isPending ? (
47
+ <SelectItem disabled value="loading" className="h-14">
48
+ <div className="flex items-center justify-center gap-2">
49
+ <Loader className="h-5 w-5 animate-spin" />
50
+ {" "}
51
+ Loading...
52
+ </div>
53
+ </SelectItem>
54
+ ) : (
55
+ items?.map(({ label, value }) => (
56
+ <SelectItem key={value} value={value}>
57
+ {label}
58
+ </SelectItem>
59
+ ))
60
+ )}
61
+ </SelectContent>
62
+ </Select>
63
+ );
64
+ }
@@ -0,0 +1,116 @@
1
+ import {
2
+ BookOpen,
3
+ CreditCard,
4
+ Figma,
5
+ FileText,
6
+ GitBranch,
7
+ Github,
8
+ Mail,
9
+ MessageCircle,
10
+ MessageSquare,
11
+ Package,
12
+ Phone,
13
+ Trello,
14
+ Users,
15
+ Video,
16
+ } from "lucide-react";
17
+
18
+ export type App = {
19
+ name: string;
20
+ logo: React.ReactElement;
21
+ connected: boolean;
22
+ desc: string;
23
+ };
24
+
25
+ export const apps: App[] = [
26
+ {
27
+ name: "Telegram",
28
+ logo: <MessageCircle className="h-8 w-8" />,
29
+ connected: false,
30
+ desc: "Connect with Telegram for real-time communication.",
31
+ },
32
+ {
33
+ name: "Notion",
34
+ logo: <FileText className="h-8 w-8" />,
35
+ connected: true,
36
+ desc: "Effortlessly sync Notion pages for seamless collaboration.",
37
+ },
38
+ {
39
+ name: "Figma",
40
+ logo: <Figma className="h-8 w-8" />,
41
+ connected: true,
42
+ desc: "View and collaborate on Figma designs in one place.",
43
+ },
44
+ {
45
+ name: "Trello",
46
+ logo: <Trello className="h-8 w-8" />,
47
+ connected: false,
48
+ desc: "Sync Trello cards for streamlined project management.",
49
+ },
50
+ {
51
+ name: "Slack",
52
+ logo: <MessageSquare className="h-8 w-8" />,
53
+ connected: false,
54
+ desc: "Integrate Slack for efficient team communication",
55
+ },
56
+ {
57
+ name: "Zoom",
58
+ logo: <Video className="h-8 w-8" />,
59
+ connected: true,
60
+ desc: "Host Zoom meetings directly from the dashboard.",
61
+ },
62
+ {
63
+ name: "Stripe",
64
+ logo: <CreditCard className="h-8 w-8" />,
65
+ connected: false,
66
+ desc: "Easily manage Stripe transactions and payments.",
67
+ },
68
+ {
69
+ name: "Gmail",
70
+ logo: <Mail className="h-8 w-8" />,
71
+ connected: true,
72
+ desc: "Access and manage Gmail messages effortlessly.",
73
+ },
74
+ {
75
+ name: "Medium",
76
+ logo: <BookOpen className="h-8 w-8" />,
77
+ connected: false,
78
+ desc: "Explore and share Medium stories on your dashboard.",
79
+ },
80
+ {
81
+ name: "Skype",
82
+ logo: <Phone className="h-8 w-8" />,
83
+ connected: false,
84
+ desc: "Connect with Skype contacts seamlessly.",
85
+ },
86
+ {
87
+ name: "Docker",
88
+ logo: <Package className="h-8 w-8" />,
89
+ connected: false,
90
+ desc: "Effortlessly manage Docker containers on your dashboard.",
91
+ },
92
+ {
93
+ name: "GitHub",
94
+ logo: <Github className="h-8 w-8" />,
95
+ connected: false,
96
+ desc: "Streamline code management with GitHub integration.",
97
+ },
98
+ {
99
+ name: "GitLab",
100
+ logo: <GitBranch className="h-8 w-8" />,
101
+ connected: false,
102
+ desc: "Efficiently manage code projects with GitLab integration.",
103
+ },
104
+ {
105
+ name: "Discord",
106
+ logo: <Users className="h-8 w-8" />,
107
+ connected: false,
108
+ desc: "Connect with Discord for seamless team communication.",
109
+ },
110
+ {
111
+ name: "WhatsApp",
112
+ logo: <MessageCircle className="h-8 w-8" />,
113
+ connected: false,
114
+ desc: "Easily integrate WhatsApp for direct messaging.",
115
+ },
116
+ ];
@@ -0,0 +1,114 @@
1
+ export type Convo = {
2
+ sender: string;
3
+ message: string;
4
+ timestamp: string;
5
+ };
6
+
7
+ export type ChatUser = {
8
+ id: string;
9
+ profile: string;
10
+ username: string;
11
+ fullName: string;
12
+ title: string;
13
+ messages: Convo[];
14
+ };
15
+
16
+ export const conversations: ChatUser[] = [
17
+ {
18
+ id: "conv1",
19
+ profile: "https://randomuser.me/api/portraits/men/32.jpg",
20
+ username: "alex_dev",
21
+ fullName: "Alex John",
22
+ title: "Senior Backend Dev",
23
+ messages: [
24
+ {
25
+ sender: "You",
26
+ message: "See you later, Alex!",
27
+ timestamp: "2024-08-24T11:15:15",
28
+ },
29
+ {
30
+ sender: "Alex",
31
+ message: "Alright, talk to you later!",
32
+ timestamp: "2024-08-24T11:11:30",
33
+ },
34
+ {
35
+ sender: "You",
36
+ message: "For sure. Anyway, I should get back to reviewing the project.",
37
+ timestamp: "2024-08-23T09:26:50",
38
+ },
39
+ {
40
+ sender: "Alex",
41
+ message: "Yeah, let me know what you think.",
42
+ timestamp: "2024-08-23T09:25:15",
43
+ },
44
+ {
45
+ sender: "You",
46
+ message: "Oh, nice! I've been waiting for that. I'll check it out later.",
47
+ timestamp: "2024-08-23T09:24:30",
48
+ },
49
+ {
50
+ sender: "Alex",
51
+ message: "They've added a dark mode option! It looks really sleek.",
52
+ timestamp: "2024-08-23T09:23:10",
53
+ },
54
+ {
55
+ sender: "You",
56
+ message: "No, not yet. What's new?",
57
+ timestamp: "2024-08-23T09:22:00",
58
+ },
59
+ {
60
+ sender: "Alex",
61
+ message: "By the way, have you seen the new feature update?",
62
+ timestamp: "2024-08-23T09:21:05",
63
+ },
64
+ ],
65
+ },
66
+ {
67
+ id: "conv2",
68
+ profile: "https://randomuser.me/api/portraits/women/44.jpg",
69
+ username: "sarah_designer",
70
+ fullName: "Sarah Miller",
71
+ title: "Lead Designer",
72
+ messages: [
73
+ {
74
+ sender: "You",
75
+ message: "Thanks! Looking forward to it.",
76
+ timestamp: "2024-08-23T14:30:00",
77
+ },
78
+ {
79
+ sender: "Sarah",
80
+ message: "I'll send you the final mockups by tomorrow.",
81
+ timestamp: "2024-08-23T14:28:00",
82
+ },
83
+ {
84
+ sender: "You",
85
+ message: "That sounds great!",
86
+ timestamp: "2024-08-23T14:25:00",
87
+ },
88
+ ],
89
+ },
90
+ {
91
+ id: "conv3",
92
+ profile: "https://randomuser.me/api/portraits/men/45.jpg",
93
+ username: "mike_pm",
94
+ fullName: "Mike Johnson",
95
+ title: "Project Manager",
96
+ messages: [
97
+ {
98
+ sender: "Mike",
99
+ message: "Can we schedule a meeting for tomorrow?",
100
+ timestamp: "2024-08-22T10:00:00",
101
+ },
102
+ {
103
+ sender: "You",
104
+ message: "Sure, what time works for you?",
105
+ timestamp: "2024-08-22T10:05:00",
106
+ },
107
+ {
108
+ sender: "Mike",
109
+ message: "How about 2 PM?",
110
+ timestamp: "2024-08-22T10:10:00",
111
+ },
112
+ ],
113
+ },
114
+ ];
@@ -0,0 +1,114 @@
1
+ import { faker } from "@faker-js/faker";
2
+ import {
3
+ AlertCircle,
4
+ ArrowDown,
5
+ ArrowRight,
6
+ ArrowUp,
7
+ CheckCircle,
8
+ Circle,
9
+ CircleOff,
10
+ HelpCircle,
11
+ Timer,
12
+ } from "lucide-react";
13
+ import { z } from "zod";
14
+
15
+ // Schema
16
+ export const taskSchema = z.object({
17
+ id: z.string(),
18
+ title: z.string(),
19
+ status: z.string(),
20
+ label: z.string(),
21
+ priority: z.string(),
22
+ });
23
+
24
+ export type Task = z.infer<typeof taskSchema>;
25
+
26
+ // Metadata
27
+ export const labels = [
28
+ {
29
+ value: "bug",
30
+ label: "Bug",
31
+ },
32
+ {
33
+ value: "feature",
34
+ label: "Feature",
35
+ },
36
+ {
37
+ value: "documentation",
38
+ label: "Documentation",
39
+ },
40
+ ];
41
+
42
+ export const statuses = [
43
+ {
44
+ label: "Backlog",
45
+ value: "backlog" as const,
46
+ icon: HelpCircle,
47
+ },
48
+ {
49
+ label: "Todo",
50
+ value: "todo" as const,
51
+ icon: Circle,
52
+ },
53
+ {
54
+ label: "In Progress",
55
+ value: "in progress" as const,
56
+ icon: Timer,
57
+ },
58
+ {
59
+ label: "Done",
60
+ value: "done" as const,
61
+ icon: CheckCircle,
62
+ },
63
+ {
64
+ label: "Canceled",
65
+ value: "canceled" as const,
66
+ icon: CircleOff,
67
+ },
68
+ ];
69
+
70
+ export const priorities = [
71
+ {
72
+ label: "Low",
73
+ value: "low" as const,
74
+ icon: ArrowDown,
75
+ },
76
+ {
77
+ label: "Medium",
78
+ value: "medium" as const,
79
+ icon: ArrowRight,
80
+ },
81
+ {
82
+ label: "High",
83
+ value: "high" as const,
84
+ icon: ArrowUp,
85
+ },
86
+ {
87
+ label: "Critical",
88
+ value: "critical" as const,
89
+ icon: AlertCircle,
90
+ },
91
+ ];
92
+
93
+ // Mock data
94
+ // Set a fixed seed for consistent data generation
95
+ faker.seed(12345);
96
+
97
+ export const tasks = Array.from({ length: 100 }, () => {
98
+ const statusValues = ["todo", "in progress", "done", "canceled", "backlog"] as const;
99
+ const labelValues = ["bug", "feature", "documentation"] as const;
100
+ const priorityValues = ["low", "medium", "high"] as const;
101
+
102
+ return {
103
+ id: `TASK-${faker.number.int({ min: 1000, max: 9999 })}`,
104
+ title: faker.lorem.sentence({ min: 5, max: 15 }),
105
+ status: faker.helpers.arrayElement(statusValues),
106
+ label: faker.helpers.arrayElement(labelValues),
107
+ priority: faker.helpers.arrayElement(priorityValues),
108
+ createdAt: faker.date.past(),
109
+ updatedAt: faker.date.recent(),
110
+ assignee: faker.person.fullName(),
111
+ description: faker.lorem.paragraph({ min: 1, max: 3 }),
112
+ dueDate: faker.date.future(),
113
+ };
114
+ });
@@ -0,0 +1,90 @@
1
+ import { faker } from "@faker-js/faker";
2
+ import { CreditCard, Shield, UserCheck, Users } from "lucide-react";
3
+ import { z } from "zod";
4
+
5
+ // Schema
6
+ const userStatusSchema = z.union([
7
+ z.literal("active"),
8
+ z.literal("inactive"),
9
+ z.literal("invited"),
10
+ z.literal("suspended"),
11
+ ]);
12
+ export type UserStatus = z.infer<typeof userStatusSchema>;
13
+
14
+ const userRoleSchema = z.union([
15
+ z.literal("superadmin"),
16
+ z.literal("admin"),
17
+ z.literal("cashier"),
18
+ z.literal("manager"),
19
+ ]);
20
+
21
+ const userSchema = z.object({
22
+ id: z.string(),
23
+ firstName: z.string(),
24
+ lastName: z.string(),
25
+ username: z.string(),
26
+ email: z.string(),
27
+ phoneNumber: z.string(),
28
+ status: userStatusSchema,
29
+ role: userRoleSchema,
30
+ createdAt: z.coerce.date(),
31
+ updatedAt: z.coerce.date(),
32
+ });
33
+ export type User = z.infer<typeof userSchema>;
34
+
35
+ export const userListSchema = z.array(userSchema);
36
+
37
+ // Metadata
38
+ export const callTypes = new Map<UserStatus, string>([
39
+ ["active", "bg-teal-100/30 text-teal-900 dark:text-teal-200 border-teal-200"],
40
+ ["inactive", "bg-neutral-300/40 border-neutral-300"],
41
+ ["invited", "bg-sky-200/40 text-sky-900 dark:text-sky-100 border-sky-300"],
42
+ [
43
+ "suspended",
44
+ "bg-destructive/10 dark:bg-destructive/50 text-destructive dark:text-primary border-destructive/10",
45
+ ],
46
+ ]);
47
+
48
+ export const roles = [
49
+ {
50
+ label: "Superadmin",
51
+ value: "superadmin",
52
+ icon: Shield,
53
+ },
54
+ {
55
+ label: "Admin",
56
+ value: "admin",
57
+ icon: UserCheck,
58
+ },
59
+ {
60
+ label: "Manager",
61
+ value: "manager",
62
+ icon: Users,
63
+ },
64
+ {
65
+ label: "Cashier",
66
+ value: "cashier",
67
+ icon: CreditCard,
68
+ },
69
+ ] as const;
70
+
71
+ // Mock data
72
+ // Set a fixed seed for consistent data generation
73
+ faker.seed(67890);
74
+
75
+ export const users = Array.from({ length: 500 }, () => {
76
+ const firstName = faker.person.firstName();
77
+ const lastName = faker.person.lastName();
78
+ return {
79
+ id: faker.string.uuid(),
80
+ firstName,
81
+ lastName,
82
+ username: faker.internet.username({ firstName, lastName }).toLocaleLowerCase(),
83
+ email: faker.internet.email({ firstName }).toLocaleLowerCase(),
84
+ phoneNumber: faker.phone.number({ style: "international" }),
85
+ status: faker.helpers.arrayElement(["active", "inactive", "invited", "suspended"]),
86
+ role: faker.helpers.arrayElement(["superadmin", "admin", "cashier", "manager"]),
87
+ createdAt: faker.date.past(),
88
+ updatedAt: faker.date.recent(),
89
+ };
90
+ });
@@ -0,0 +1,17 @@
1
+ "use client";
2
+
3
+ import { useState } from "react";
4
+
5
+ /**
6
+ * Custom hook for confirm dialog
7
+ * @param initialState string | null
8
+ * @returns A stateful value, and a function to update it.
9
+ * @example const [open, setOpen] = useDialogState<"approve" | "reject">()
10
+ */
11
+ export default function useDialogState<T extends string | boolean>(initialState: T | null = null) {
12
+ const [open, _setOpen] = useState<T | null>(initialState);
13
+
14
+ const setOpen = (str: T | null) => _setOpen((prev) => (prev === str ? null : str));
15
+
16
+ return [open, setOpen] as const;
17
+ }