@coze-arch/cli 0.0.1-alpha.01c0ee

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 (304) hide show
  1. package/README.md +143 -0
  2. package/bin/main +2 -0
  3. package/lib/__templates__/expo/.coze +12 -0
  4. package/lib/__templates__/expo/.cozeproj/scripts/dev_build.sh +46 -0
  5. package/lib/__templates__/expo/.cozeproj/scripts/dev_run.sh +229 -0
  6. package/lib/__templates__/expo/.cozeproj/scripts/prod_build.sh +47 -0
  7. package/lib/__templates__/expo/.cozeproj/scripts/prod_run.sh +34 -0
  8. package/lib/__templates__/expo/.cozeproj/scripts/server_dev_run.sh +46 -0
  9. package/lib/__templates__/expo/README.md +74 -0
  10. package/lib/__templates__/expo/_gitignore +11 -0
  11. package/lib/__templates__/expo/_npmrc +20 -0
  12. package/lib/__templates__/expo/client/app/+not-found.tsx +30 -0
  13. package/lib/__templates__/expo/client/app/_layout.tsx +36 -0
  14. package/lib/__templates__/expo/client/app/index.tsx +1 -0
  15. package/lib/__templates__/expo/client/app.config.ts +76 -0
  16. package/lib/__templates__/expo/client/assets/fonts/SpaceMono-Regular.ttf +0 -0
  17. package/lib/__templates__/expo/client/assets/images/adaptive-icon.png +0 -0
  18. package/lib/__templates__/expo/client/assets/images/default-avatar.png +0 -0
  19. package/lib/__templates__/expo/client/assets/images/favicon.png +0 -0
  20. package/lib/__templates__/expo/client/assets/images/icon.png +0 -0
  21. package/lib/__templates__/expo/client/assets/images/partial-react-logo.png +0 -0
  22. package/lib/__templates__/expo/client/assets/images/react-logo.png +0 -0
  23. package/lib/__templates__/expo/client/assets/images/react-logo@2x.png +0 -0
  24. package/lib/__templates__/expo/client/assets/images/react-logo@3x.png +0 -0
  25. package/lib/__templates__/expo/client/assets/images/splash-icon.png +0 -0
  26. package/lib/__templates__/expo/client/components/Screen.tsx +314 -0
  27. package/lib/__templates__/expo/client/components/SmartDateInput.tsx +238 -0
  28. package/lib/__templates__/expo/client/components/ThemedText.tsx +33 -0
  29. package/lib/__templates__/expo/client/components/ThemedView.tsx +37 -0
  30. package/lib/__templates__/expo/client/constants/theme.ts +177 -0
  31. package/lib/__templates__/expo/client/contexts/AuthContext.tsx +49 -0
  32. package/lib/__templates__/expo/client/declarations.d.ts +5 -0
  33. package/lib/__templates__/expo/client/eslint-formatter-simple.mjs +49 -0
  34. package/lib/__templates__/expo/client/eslint.config.mjs +128 -0
  35. package/lib/__templates__/expo/client/hooks/useColorScheme.tsx +48 -0
  36. package/lib/__templates__/expo/client/hooks/useSafeRouter.ts +152 -0
  37. package/lib/__templates__/expo/client/hooks/useTheme.ts +33 -0
  38. package/lib/__templates__/expo/client/metro.config.js +124 -0
  39. package/lib/__templates__/expo/client/package.json +95 -0
  40. package/lib/__templates__/expo/client/screens/demo/index.tsx +25 -0
  41. package/lib/__templates__/expo/client/screens/demo/styles.ts +28 -0
  42. package/lib/__templates__/expo/client/scripts/install-missing-deps.js +105 -0
  43. package/lib/__templates__/expo/client/tsconfig.json +24 -0
  44. package/lib/__templates__/expo/client/utils/index.ts +76 -0
  45. package/lib/__templates__/expo/eslint-plugins/fontawesome6/index.js +9 -0
  46. package/lib/__templates__/expo/eslint-plugins/fontawesome6/names.js +1889 -0
  47. package/lib/__templates__/expo/eslint-plugins/fontawesome6/rule.js +174 -0
  48. package/lib/__templates__/expo/eslint-plugins/fontawesome6/v5-only-names.js +388 -0
  49. package/lib/__templates__/expo/eslint-plugins/forbid-emoji/index.js +9 -0
  50. package/lib/__templates__/expo/eslint-plugins/forbid-emoji/rule.js +112 -0
  51. package/lib/__templates__/expo/eslint-plugins/forbid-emoji/tech.md +94 -0
  52. package/lib/__templates__/expo/eslint-plugins/react-native/index.js +9 -0
  53. package/lib/__templates__/expo/eslint-plugins/react-native/rule.js +64 -0
  54. package/lib/__templates__/expo/eslint-plugins/reanimated/index.js +9 -0
  55. package/lib/__templates__/expo/eslint-plugins/reanimated/rule.js +88 -0
  56. package/lib/__templates__/expo/eslint-plugins/restrict-linear-gradient/index.js +9 -0
  57. package/lib/__templates__/expo/eslint-plugins/restrict-linear-gradient/rule.js +120 -0
  58. package/lib/__templates__/expo/eslint-plugins/restrict-linear-gradient/tech.md +58 -0
  59. package/lib/__templates__/expo/package.json +25 -0
  60. package/lib/__templates__/expo/patches/expo@54.0.33.patch +45 -0
  61. package/lib/__templates__/expo/pnpm-lock.yaml +12657 -0
  62. package/lib/__templates__/expo/pnpm-workspace.yaml +3 -0
  63. package/lib/__templates__/expo/server/build.js +21 -0
  64. package/lib/__templates__/expo/server/package.json +34 -0
  65. package/lib/__templates__/expo/server/src/index.ts +20 -0
  66. package/lib/__templates__/expo/server/tsconfig.json +24 -0
  67. package/lib/__templates__/expo/template.config.js +106 -0
  68. package/lib/__templates__/expo/tsconfig.json +1 -0
  69. package/lib/__templates__/native-static/.coze +11 -0
  70. package/lib/__templates__/native-static/index.html +33 -0
  71. package/lib/__templates__/native-static/styles/main.css +136 -0
  72. package/lib/__templates__/native-static/template.config.js +22 -0
  73. package/lib/__templates__/nextjs/.babelrc +15 -0
  74. package/lib/__templates__/nextjs/.coze +12 -0
  75. package/lib/__templates__/nextjs/README.md +363 -0
  76. package/lib/__templates__/nextjs/_gitignore +99 -0
  77. package/lib/__templates__/nextjs/_npmrc +23 -0
  78. package/lib/__templates__/nextjs/components.json +21 -0
  79. package/lib/__templates__/nextjs/eslint.config.mjs +23 -0
  80. package/lib/__templates__/nextjs/next-env.d.ts +6 -0
  81. package/lib/__templates__/nextjs/next.config.ts +18 -0
  82. package/lib/__templates__/nextjs/package.json +93 -0
  83. package/lib/__templates__/nextjs/pnpm-lock.yaml +12404 -0
  84. package/lib/__templates__/nextjs/postcss.config.mjs +7 -0
  85. package/lib/__templates__/nextjs/public/file.svg +1 -0
  86. package/lib/__templates__/nextjs/public/globe.svg +1 -0
  87. package/lib/__templates__/nextjs/public/next.svg +1 -0
  88. package/lib/__templates__/nextjs/public/vercel.svg +1 -0
  89. package/lib/__templates__/nextjs/public/window.svg +1 -0
  90. package/lib/__templates__/nextjs/scripts/build.sh +17 -0
  91. package/lib/__templates__/nextjs/scripts/dev.sh +39 -0
  92. package/lib/__templates__/nextjs/scripts/prepare.sh +9 -0
  93. package/lib/__templates__/nextjs/scripts/start.sh +21 -0
  94. package/lib/__templates__/nextjs/src/app/favicon.ico +0 -0
  95. package/lib/__templates__/nextjs/src/app/globals.css +137 -0
  96. package/lib/__templates__/nextjs/src/app/layout.tsx +74 -0
  97. package/lib/__templates__/nextjs/src/app/page.tsx +35 -0
  98. package/lib/__templates__/nextjs/src/app/robots.ts +11 -0
  99. package/lib/__templates__/nextjs/src/components/ui/accordion.tsx +66 -0
  100. package/lib/__templates__/nextjs/src/components/ui/alert-dialog.tsx +157 -0
  101. package/lib/__templates__/nextjs/src/components/ui/alert.tsx +66 -0
  102. package/lib/__templates__/nextjs/src/components/ui/aspect-ratio.tsx +11 -0
  103. package/lib/__templates__/nextjs/src/components/ui/avatar.tsx +53 -0
  104. package/lib/__templates__/nextjs/src/components/ui/badge.tsx +46 -0
  105. package/lib/__templates__/nextjs/src/components/ui/breadcrumb.tsx +109 -0
  106. package/lib/__templates__/nextjs/src/components/ui/button-group.tsx +83 -0
  107. package/lib/__templates__/nextjs/src/components/ui/button.tsx +62 -0
  108. package/lib/__templates__/nextjs/src/components/ui/calendar.tsx +220 -0
  109. package/lib/__templates__/nextjs/src/components/ui/card.tsx +92 -0
  110. package/lib/__templates__/nextjs/src/components/ui/carousel.tsx +241 -0
  111. package/lib/__templates__/nextjs/src/components/ui/chart.tsx +357 -0
  112. package/lib/__templates__/nextjs/src/components/ui/checkbox.tsx +32 -0
  113. package/lib/__templates__/nextjs/src/components/ui/collapsible.tsx +33 -0
  114. package/lib/__templates__/nextjs/src/components/ui/command.tsx +184 -0
  115. package/lib/__templates__/nextjs/src/components/ui/context-menu.tsx +252 -0
  116. package/lib/__templates__/nextjs/src/components/ui/dialog.tsx +143 -0
  117. package/lib/__templates__/nextjs/src/components/ui/drawer.tsx +135 -0
  118. package/lib/__templates__/nextjs/src/components/ui/dropdown-menu.tsx +257 -0
  119. package/lib/__templates__/nextjs/src/components/ui/empty.tsx +104 -0
  120. package/lib/__templates__/nextjs/src/components/ui/field.tsx +248 -0
  121. package/lib/__templates__/nextjs/src/components/ui/form.tsx +167 -0
  122. package/lib/__templates__/nextjs/src/components/ui/hover-card.tsx +44 -0
  123. package/lib/__templates__/nextjs/src/components/ui/input-group.tsx +170 -0
  124. package/lib/__templates__/nextjs/src/components/ui/input-otp.tsx +77 -0
  125. package/lib/__templates__/nextjs/src/components/ui/input.tsx +21 -0
  126. package/lib/__templates__/nextjs/src/components/ui/item.tsx +193 -0
  127. package/lib/__templates__/nextjs/src/components/ui/kbd.tsx +28 -0
  128. package/lib/__templates__/nextjs/src/components/ui/label.tsx +24 -0
  129. package/lib/__templates__/nextjs/src/components/ui/menubar.tsx +276 -0
  130. package/lib/__templates__/nextjs/src/components/ui/navigation-menu.tsx +168 -0
  131. package/lib/__templates__/nextjs/src/components/ui/pagination.tsx +127 -0
  132. package/lib/__templates__/nextjs/src/components/ui/popover.tsx +48 -0
  133. package/lib/__templates__/nextjs/src/components/ui/progress.tsx +31 -0
  134. package/lib/__templates__/nextjs/src/components/ui/radio-group.tsx +45 -0
  135. package/lib/__templates__/nextjs/src/components/ui/resizable.tsx +63 -0
  136. package/lib/__templates__/nextjs/src/components/ui/scroll-area.tsx +58 -0
  137. package/lib/__templates__/nextjs/src/components/ui/select.tsx +190 -0
  138. package/lib/__templates__/nextjs/src/components/ui/separator.tsx +28 -0
  139. package/lib/__templates__/nextjs/src/components/ui/sheet.tsx +139 -0
  140. package/lib/__templates__/nextjs/src/components/ui/sidebar.tsx +724 -0
  141. package/lib/__templates__/nextjs/src/components/ui/skeleton.tsx +13 -0
  142. package/lib/__templates__/nextjs/src/components/ui/slider.tsx +63 -0
  143. package/lib/__templates__/nextjs/src/components/ui/sonner.tsx +40 -0
  144. package/lib/__templates__/nextjs/src/components/ui/spinner.tsx +16 -0
  145. package/lib/__templates__/nextjs/src/components/ui/switch.tsx +31 -0
  146. package/lib/__templates__/nextjs/src/components/ui/table.tsx +116 -0
  147. package/lib/__templates__/nextjs/src/components/ui/tabs.tsx +66 -0
  148. package/lib/__templates__/nextjs/src/components/ui/textarea.tsx +18 -0
  149. package/lib/__templates__/nextjs/src/components/ui/toggle-group.tsx +83 -0
  150. package/lib/__templates__/nextjs/src/components/ui/toggle.tsx +47 -0
  151. package/lib/__templates__/nextjs/src/components/ui/tooltip.tsx +61 -0
  152. package/lib/__templates__/nextjs/src/hooks/use-mobile.ts +19 -0
  153. package/lib/__templates__/nextjs/src/lib/utils.ts +6 -0
  154. package/lib/__templates__/nextjs/src/server.ts +35 -0
  155. package/lib/__templates__/nextjs/template.config.js +120 -0
  156. package/lib/__templates__/nextjs/tsconfig.json +34 -0
  157. package/lib/__templates__/nuxt-vue/.coze +12 -0
  158. package/lib/__templates__/nuxt-vue/README.md +73 -0
  159. package/lib/__templates__/nuxt-vue/_gitignore +24 -0
  160. package/lib/__templates__/nuxt-vue/_npmrc +23 -0
  161. package/lib/__templates__/nuxt-vue/app/app.vue +6 -0
  162. package/lib/__templates__/nuxt-vue/app/pages/index.vue +23 -0
  163. package/lib/__templates__/nuxt-vue/assets/css/main.css +24 -0
  164. package/lib/__templates__/nuxt-vue/nuxt.config.ts +116 -0
  165. package/lib/__templates__/nuxt-vue/package.json +35 -0
  166. package/lib/__templates__/nuxt-vue/pnpm-lock.yaml +8759 -0
  167. package/lib/__templates__/nuxt-vue/postcss.config.mjs +8 -0
  168. package/lib/__templates__/nuxt-vue/public/favicon.ico +0 -0
  169. package/lib/__templates__/nuxt-vue/public/robots.txt +2 -0
  170. package/lib/__templates__/nuxt-vue/scripts/build.sh +14 -0
  171. package/lib/__templates__/nuxt-vue/scripts/dev.sh +39 -0
  172. package/lib/__templates__/nuxt-vue/scripts/prepare.sh +14 -0
  173. package/lib/__templates__/nuxt-vue/scripts/start.sh +21 -0
  174. package/lib/__templates__/nuxt-vue/server/api/hello.ts +10 -0
  175. package/lib/__templates__/nuxt-vue/server/middleware/logger.ts +10 -0
  176. package/lib/__templates__/nuxt-vue/server/routes/health.ts +10 -0
  177. package/lib/__templates__/nuxt-vue/tailwind.config.js +13 -0
  178. package/lib/__templates__/nuxt-vue/template.config.js +87 -0
  179. package/lib/__templates__/nuxt-vue/tsconfig.json +18 -0
  180. package/lib/__templates__/taro/.coze +14 -0
  181. package/lib/__templates__/taro/.cozeproj/scripts/deploy_build.sh +19 -0
  182. package/lib/__templates__/taro/.cozeproj/scripts/deploy_run.sh +14 -0
  183. package/lib/__templates__/taro/.cozeproj/scripts/dev_build.sh +2 -0
  184. package/lib/__templates__/taro/.cozeproj/scripts/dev_run.sh +151 -0
  185. package/lib/__templates__/taro/.cozeproj/scripts/init_env.sh +5 -0
  186. package/lib/__templates__/taro/.cozeproj/scripts/pack.sh +24 -0
  187. package/lib/__templates__/taro/README.md +763 -0
  188. package/lib/__templates__/taro/_gitignore +40 -0
  189. package/lib/__templates__/taro/_npmrc +18 -0
  190. package/lib/__templates__/taro/babel.config.js +12 -0
  191. package/lib/__templates__/taro/config/dev.ts +9 -0
  192. package/lib/__templates__/taro/config/index.ts +237 -0
  193. package/lib/__templates__/taro/config/prod.ts +34 -0
  194. package/lib/__templates__/taro/eslint.config.mjs +135 -0
  195. package/lib/__templates__/taro/key/private.appid.key +0 -0
  196. package/lib/__templates__/taro/package.json +112 -0
  197. package/lib/__templates__/taro/patches/@tarojs__plugin-mini-ci@4.1.9.patch +30 -0
  198. package/lib/__templates__/taro/pnpm-lock.yaml +23412 -0
  199. package/lib/__templates__/taro/pnpm-workspace.yaml +2 -0
  200. package/lib/__templates__/taro/project.config.json +15 -0
  201. package/lib/__templates__/taro/server/nest-cli.json +10 -0
  202. package/lib/__templates__/taro/server/package.json +40 -0
  203. package/lib/__templates__/taro/server/src/app.controller.ts +23 -0
  204. package/lib/__templates__/taro/server/src/app.module.ts +10 -0
  205. package/lib/__templates__/taro/server/src/app.service.ts +8 -0
  206. package/lib/__templates__/taro/server/src/interceptors/http-status.interceptor.ts +23 -0
  207. package/lib/__templates__/taro/server/src/main.ts +49 -0
  208. package/lib/__templates__/taro/server/tsconfig.json +24 -0
  209. package/lib/__templates__/taro/src/app.config.ts +11 -0
  210. package/lib/__templates__/taro/src/app.css +156 -0
  211. package/lib/__templates__/taro/src/app.tsx +9 -0
  212. package/lib/__templates__/taro/src/components/ui/accordion.tsx +159 -0
  213. package/lib/__templates__/taro/src/components/ui/alert-dialog.tsx +260 -0
  214. package/lib/__templates__/taro/src/components/ui/alert.tsx +60 -0
  215. package/lib/__templates__/taro/src/components/ui/aspect-ratio.tsx +36 -0
  216. package/lib/__templates__/taro/src/components/ui/avatar.tsx +84 -0
  217. package/lib/__templates__/taro/src/components/ui/badge.tsx +37 -0
  218. package/lib/__templates__/taro/src/components/ui/breadcrumb.tsx +117 -0
  219. package/lib/__templates__/taro/src/components/ui/button-group.tsx +83 -0
  220. package/lib/__templates__/taro/src/components/ui/button.tsx +67 -0
  221. package/lib/__templates__/taro/src/components/ui/calendar.tsx +394 -0
  222. package/lib/__templates__/taro/src/components/ui/card.tsx +108 -0
  223. package/lib/__templates__/taro/src/components/ui/carousel.tsx +228 -0
  224. package/lib/__templates__/taro/src/components/ui/checkbox.tsx +58 -0
  225. package/lib/__templates__/taro/src/components/ui/code-block.tsx +169 -0
  226. package/lib/__templates__/taro/src/components/ui/collapsible.tsx +71 -0
  227. package/lib/__templates__/taro/src/components/ui/command.tsx +385 -0
  228. package/lib/__templates__/taro/src/components/ui/context-menu.tsx +614 -0
  229. package/lib/__templates__/taro/src/components/ui/dialog.tsx +256 -0
  230. package/lib/__templates__/taro/src/components/ui/drawer.tsx +192 -0
  231. package/lib/__templates__/taro/src/components/ui/dropdown-menu.tsx +561 -0
  232. package/lib/__templates__/taro/src/components/ui/field.tsx +228 -0
  233. package/lib/__templates__/taro/src/components/ui/hover-card.tsx +282 -0
  234. package/lib/__templates__/taro/src/components/ui/input-group.tsx +197 -0
  235. package/lib/__templates__/taro/src/components/ui/input-otp.tsx +136 -0
  236. package/lib/__templates__/taro/src/components/ui/input.tsx +56 -0
  237. package/lib/__templates__/taro/src/components/ui/label.tsx +24 -0
  238. package/lib/__templates__/taro/src/components/ui/menubar.tsx +595 -0
  239. package/lib/__templates__/taro/src/components/ui/navigation-menu.tsx +264 -0
  240. package/lib/__templates__/taro/src/components/ui/pagination.tsx +118 -0
  241. package/lib/__templates__/taro/src/components/ui/popover.tsx +291 -0
  242. package/lib/__templates__/taro/src/components/ui/portal.tsx +19 -0
  243. package/lib/__templates__/taro/src/components/ui/progress.tsx +28 -0
  244. package/lib/__templates__/taro/src/components/ui/radio-group.tsx +64 -0
  245. package/lib/__templates__/taro/src/components/ui/resizable.tsx +346 -0
  246. package/lib/__templates__/taro/src/components/ui/scroll-area.tsx +34 -0
  247. package/lib/__templates__/taro/src/components/ui/select.tsx +438 -0
  248. package/lib/__templates__/taro/src/components/ui/separator.tsx +30 -0
  249. package/lib/__templates__/taro/src/components/ui/sheet.tsx +262 -0
  250. package/lib/__templates__/taro/src/components/ui/skeleton.tsx +17 -0
  251. package/lib/__templates__/taro/src/components/ui/slider.tsx +203 -0
  252. package/lib/__templates__/taro/src/components/ui/sonner.tsx +1 -0
  253. package/lib/__templates__/taro/src/components/ui/switch.tsx +55 -0
  254. package/lib/__templates__/taro/src/components/ui/table.tsx +142 -0
  255. package/lib/__templates__/taro/src/components/ui/tabs.tsx +114 -0
  256. package/lib/__templates__/taro/src/components/ui/textarea.tsx +54 -0
  257. package/lib/__templates__/taro/src/components/ui/toast.tsx +517 -0
  258. package/lib/__templates__/taro/src/components/ui/toggle-group.tsx +120 -0
  259. package/lib/__templates__/taro/src/components/ui/toggle.tsx +77 -0
  260. package/lib/__templates__/taro/src/components/ui/tooltip.tsx +455 -0
  261. package/lib/__templates__/taro/src/index.html +39 -0
  262. package/lib/__templates__/taro/src/lib/hooks/use-keyboard-offset.ts +37 -0
  263. package/lib/__templates__/taro/src/lib/measure.ts +115 -0
  264. package/lib/__templates__/taro/src/lib/platform.ts +12 -0
  265. package/lib/__templates__/taro/src/lib/utils.ts +6 -0
  266. package/lib/__templates__/taro/src/network.ts +39 -0
  267. package/lib/__templates__/taro/src/pages/index/index.config.ts +3 -0
  268. package/lib/__templates__/taro/src/pages/index/index.css +1 -0
  269. package/lib/__templates__/taro/src/pages/index/index.tsx +33 -0
  270. package/lib/__templates__/taro/src/presets/dev-debug.ts +23 -0
  271. package/lib/__templates__/taro/src/presets/h5-container.tsx +15 -0
  272. package/lib/__templates__/taro/src/presets/h5-navbar.tsx +238 -0
  273. package/lib/__templates__/taro/src/presets/h5-styles.ts +220 -0
  274. package/lib/__templates__/taro/src/presets/index.tsx +18 -0
  275. package/lib/__templates__/taro/stylelint.config.mjs +4 -0
  276. package/lib/__templates__/taro/template.config.js +68 -0
  277. package/lib/__templates__/taro/tsconfig.json +29 -0
  278. package/lib/__templates__/taro/types/global.d.ts +32 -0
  279. package/lib/__templates__/templates.json +162 -0
  280. package/lib/__templates__/vite/.coze +12 -0
  281. package/lib/__templates__/vite/README.md +418 -0
  282. package/lib/__templates__/vite/_gitignore +67 -0
  283. package/lib/__templates__/vite/_npmrc +23 -0
  284. package/lib/__templates__/vite/eslint.config.mjs +14 -0
  285. package/lib/__templates__/vite/index.html +13 -0
  286. package/lib/__templates__/vite/package.json +44 -0
  287. package/lib/__templates__/vite/pnpm-lock.yaml +3465 -0
  288. package/lib/__templates__/vite/postcss.config.js +6 -0
  289. package/lib/__templates__/vite/scripts/build.sh +17 -0
  290. package/lib/__templates__/vite/scripts/dev.sh +39 -0
  291. package/lib/__templates__/vite/scripts/prepare.sh +9 -0
  292. package/lib/__templates__/vite/scripts/start.sh +21 -0
  293. package/lib/__templates__/vite/server/routes/index.ts +31 -0
  294. package/lib/__templates__/vite/server/server.ts +65 -0
  295. package/lib/__templates__/vite/server/vite.ts +67 -0
  296. package/lib/__templates__/vite/src/index.css +21 -0
  297. package/lib/__templates__/vite/src/index.ts +5 -0
  298. package/lib/__templates__/vite/src/main.ts +34 -0
  299. package/lib/__templates__/vite/tailwind.config.js +9 -0
  300. package/lib/__templates__/vite/template.config.js +127 -0
  301. package/lib/__templates__/vite/tsconfig.json +17 -0
  302. package/lib/__templates__/vite/vite.config.ts +20 -0
  303. package/lib/cli.js +2631 -0
  304. package/package.json +81 -0
@@ -0,0 +1,7 @@
1
+ const config = {
2
+ plugins: {
3
+ '@tailwindcss/postcss': {},
4
+ },
5
+ };
6
+
7
+ export default config;
@@ -0,0 +1 @@
1
+ <svg fill="none" viewBox="0 0 16 16" xmlns="http://www.w3.org/2000/svg"><path d="M14.5 13.5V5.41a1 1 0 0 0-.3-.7L9.8.29A1 1 0 0 0 9.08 0H1.5v13.5A2.5 2.5 0 0 0 4 16h8a2.5 2.5 0 0 0 2.5-2.5m-1.5 0v-7H8v-5H3v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1M9.5 5V2.12L12.38 5zM5.13 5h-.62v1.25h2.12V5zm-.62 3h7.12v1.25H4.5zm.62 3h-.62v1.25h7.12V11z" clip-rule="evenodd" fill="#666" fill-rule="evenodd"/></svg>
@@ -0,0 +1 @@
1
+ <svg fill="none" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"><g clip-path="url(#a)"><path fill-rule="evenodd" clip-rule="evenodd" d="M10.27 14.1a6.5 6.5 0 0 0 3.67-3.45q-1.24.21-2.7.34-.31 1.83-.97 3.1M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16m.48-1.52a7 7 0 0 1-.96 0H7.5a4 4 0 0 1-.84-1.32q-.38-.89-.63-2.08a40 40 0 0 0 3.92 0q-.25 1.2-.63 2.08a4 4 0 0 1-.84 1.31zm2.94-4.76q1.66-.15 2.95-.43a7 7 0 0 0 0-2.58q-1.3-.27-2.95-.43a18 18 0 0 1 0 3.44m-1.27-3.54a17 17 0 0 1 0 3.64 39 39 0 0 1-4.3 0 17 17 0 0 1 0-3.64 39 39 0 0 1 4.3 0m1.1-1.17q1.45.13 2.69.34a6.5 6.5 0 0 0-3.67-3.44q.65 1.26.98 3.1M8.48 1.5l.01.02q.41.37.84 1.31.38.89.63 2.08a40 40 0 0 0-3.92 0q.25-1.2.63-2.08a4 4 0 0 1 .85-1.32 7 7 0 0 1 .96 0m-2.75.4a6.5 6.5 0 0 0-3.67 3.44 29 29 0 0 1 2.7-.34q.31-1.83.97-3.1M4.58 6.28q-1.66.16-2.95.43a7 7 0 0 0 0 2.58q1.3.27 2.95.43a18 18 0 0 1 0-3.44m.17 4.71q-1.45-.12-2.69-.34a6.5 6.5 0 0 0 3.67 3.44q-.65-1.27-.98-3.1" fill="#666"/></g><defs><clipPath id="a"><path fill="#fff" d="M0 0h16v16H0z"/></clipPath></defs></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 394 80"><path fill="#000" d="M262 0h68.5v12.7h-27.2v66.6h-13.6V12.7H262V0ZM149 0v12.7H94v20.4h44.3v12.6H94v21h55v12.6H80.5V0h68.7zm34.3 0h-17.8l63.8 79.4h17.9l-32-39.7 32-39.6h-17.9l-23 28.6-23-28.6zm18.3 56.7-9-11-27.1 33.7h17.8l18.3-22.7z"/><path fill="#000" d="M81 79.3 17 0H0v79.3h13.6V17l50.2 62.3H81Zm252.6-.4c-1 0-1.8-.4-2.5-1s-1.1-1.6-1.1-2.6.3-1.8 1-2.5 1.6-1 2.6-1 1.8.3 2.5 1a3.4 3.4 0 0 1 .6 4.3 3.7 3.7 0 0 1-3 1.8zm23.2-33.5h6v23.3c0 2.1-.4 4-1.3 5.5a9.1 9.1 0 0 1-3.8 3.5c-1.6.8-3.5 1.3-5.7 1.3-2 0-3.7-.4-5.3-1s-2.8-1.8-3.7-3.2c-.9-1.3-1.4-3-1.4-5h6c.1.8.3 1.6.7 2.2s1 1.2 1.6 1.5c.7.4 1.5.5 2.4.5 1 0 1.8-.2 2.4-.6a4 4 0 0 0 1.6-1.8c.3-.8.5-1.8.5-3V45.5zm30.9 9.1a4.4 4.4 0 0 0-2-3.3 7.5 7.5 0 0 0-4.3-1.1c-1.3 0-2.4.2-3.3.5-.9.4-1.6 1-2 1.6a3.5 3.5 0 0 0-.3 4c.3.5.7.9 1.3 1.2l1.8 1 2 .5 3.2.8c1.3.3 2.5.7 3.7 1.2a13 13 0 0 1 3.2 1.8 8.1 8.1 0 0 1 3 6.5c0 2-.5 3.7-1.5 5.1a10 10 0 0 1-4.4 3.5c-1.8.8-4.1 1.2-6.8 1.2-2.6 0-4.9-.4-6.8-1.2-2-.8-3.4-2-4.5-3.5a10 10 0 0 1-1.7-5.6h6a5 5 0 0 0 3.5 4.6c1 .4 2.2.6 3.4.6 1.3 0 2.5-.2 3.5-.6 1-.4 1.8-1 2.4-1.7a4 4 0 0 0 .8-2.4c0-.9-.2-1.6-.7-2.2a11 11 0 0 0-2.1-1.4l-3.2-1-3.8-1c-2.8-.7-5-1.7-6.6-3.2a7.2 7.2 0 0 1-2.4-5.7 8 8 0 0 1 1.7-5 10 10 0 0 1 4.3-3.5c2-.8 4-1.2 6.4-1.2 2.3 0 4.4.4 6.2 1.2 1.8.8 3.2 2 4.3 3.4 1 1.4 1.5 3 1.5 5h-5.8z"/></svg>
@@ -0,0 +1 @@
1
+ <svg fill="none" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1155 1000"><path d="m577.3 0 577.4 1000H0z" fill="#fff"/></svg>
@@ -0,0 +1 @@
1
+ <svg fill="none" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"><path fill-rule="evenodd" clip-rule="evenodd" d="M1.5 2.5h13v10a1 1 0 0 1-1 1h-11a1 1 0 0 1-1-1zM0 1h16v11.5a2.5 2.5 0 0 1-2.5 2.5h-11A2.5 2.5 0 0 1 0 12.5zm3.75 4.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5M7 4.75a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0m1.75.75a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5" fill="#666"/></svg>
@@ -0,0 +1,17 @@
1
+ #!/bin/bash
2
+ set -Eeuo pipefail
3
+
4
+ COZE_WORKSPACE_PATH="${COZE_WORKSPACE_PATH:-$(pwd)}"
5
+
6
+ cd "${COZE_WORKSPACE_PATH}"
7
+
8
+ echo "Installing dependencies..."
9
+ pnpm install --prefer-frozen-lockfile --prefer-offline --loglevel debug --reporter=append-only
10
+
11
+ echo "Building the Next.js project..."
12
+ npx next build
13
+
14
+ echo "Bundling server with tsup..."
15
+ npx tsup src/server.ts --format cjs --platform node --target node20 --outDir dist --no-splitting --no-minify
16
+
17
+ echo "Build completed successfully!"
@@ -0,0 +1,39 @@
1
+ #!/bin/bash
2
+ set -Eeuo pipefail
3
+
4
+ <% if (process.env.NODE_ENV === 'test') { %>
5
+ # 测试环境:支持环境变量覆盖端口
6
+ PORT="${PORT:-<%= port %>}"
7
+ COZE_WORKSPACE_PATH="${COZE_WORKSPACE_PATH:-$(pwd)}"
8
+ DEPLOY_RUN_PORT="${DEPLOY_RUN_PORT:-${PORT}}"
9
+ <% } else { %>
10
+ PORT=<%= port %>
11
+ COZE_WORKSPACE_PATH="${COZE_WORKSPACE_PATH:-$(pwd)}"
12
+ DEPLOY_RUN_PORT=<%= port %>
13
+ <% } %>
14
+
15
+ cd "${COZE_WORKSPACE_PATH}"
16
+
17
+ kill_port_if_listening() {
18
+ local pids
19
+ pids=$(ss -H -lntp 2>/dev/null | awk -v port="${DEPLOY_RUN_PORT}" '$4 ~ ":"port"$"' | grep -o 'pid=[0-9]*' | cut -d= -f2 | paste -sd' ' - || true)
20
+ if [[ -z "${pids}" ]]; then
21
+ echo "Port ${DEPLOY_RUN_PORT} is free."
22
+ return
23
+ fi
24
+ echo "Port ${DEPLOY_RUN_PORT} in use by PIDs: ${pids} (SIGKILL)"
25
+ echo "${pids}" | xargs -I {} kill -9 {}
26
+ sleep 1
27
+ pids=$(ss -H -lntp 2>/dev/null | awk -v port="${DEPLOY_RUN_PORT}" '$4 ~ ":"port"$"' | grep -o 'pid=[0-9]*' | cut -d= -f2 | paste -sd' ' - || true)
28
+ if [[ -n "${pids}" ]]; then
29
+ echo "Warning: port ${DEPLOY_RUN_PORT} still busy after SIGKILL, PIDs: ${pids}"
30
+ else
31
+ echo "Port ${DEPLOY_RUN_PORT} cleared."
32
+ fi
33
+ }
34
+
35
+ echo "Clearing port ${PORT} before start."
36
+ kill_port_if_listening
37
+ echo "Starting HTTP service on port ${PORT} for dev..."
38
+
39
+ PORT=$PORT npx tsx watch src/server.ts
@@ -0,0 +1,9 @@
1
+ #!/bin/bash
2
+ set -Eeuo pipefail
3
+
4
+ COZE_WORKSPACE_PATH="${COZE_WORKSPACE_PATH:-$(pwd)}"
5
+
6
+ cd "${COZE_WORKSPACE_PATH}"
7
+
8
+ echo "Installing dependencies..."
9
+ pnpm install --prefer-frozen-lockfile --prefer-offline --loglevel debug --reporter=append-only
@@ -0,0 +1,21 @@
1
+ #!/bin/bash
2
+ set -Eeuo pipefail
3
+
4
+ COZE_WORKSPACE_PATH="${COZE_WORKSPACE_PATH:-$(pwd)}"
5
+ <% if (process.env.NODE_ENV === 'test') { %>
6
+ # 测试环境:支持环境变量覆盖端口
7
+ PORT="${PORT:-<%= port %>}"
8
+ DEPLOY_RUN_PORT="${DEPLOY_RUN_PORT:-${PORT}}"
9
+ <% } else { %>
10
+ PORT=<%= port %>
11
+ DEPLOY_RUN_PORT="${DEPLOY_RUN_PORT:-$PORT}"
12
+ <% } %>
13
+
14
+ start_service() {
15
+ cd "${COZE_WORKSPACE_PATH}"
16
+ echo "Starting HTTP service on port ${DEPLOY_RUN_PORT} for deploy..."
17
+ PORT=${DEPLOY_RUN_PORT} node dist/server.js
18
+ }
19
+
20
+ echo "Starting HTTP service on port ${DEPLOY_RUN_PORT} for deploy..."
21
+ start_service
@@ -0,0 +1,137 @@
1
+ @import 'tailwindcss';
2
+ @import 'tw-animate-css';
3
+
4
+ @custom-variant dark (&:is(.dark *));
5
+
6
+ @theme inline {
7
+ --color-background: var(--background);
8
+ --color-foreground: var(--foreground);
9
+ --color-sidebar-ring: var(--sidebar-ring);
10
+ --color-sidebar-border: var(--sidebar-border);
11
+ --color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
12
+ --color-sidebar-accent: var(--sidebar-accent);
13
+ --color-sidebar-primary-foreground: var(--sidebar-primary-foreground);
14
+ --color-sidebar-primary: var(--sidebar-primary);
15
+ --color-sidebar-foreground: var(--sidebar-foreground);
16
+ --color-sidebar: var(--sidebar);
17
+ --color-chart-5: var(--chart-5);
18
+ --color-chart-4: var(--chart-4);
19
+ --color-chart-3: var(--chart-3);
20
+ --color-chart-2: var(--chart-2);
21
+ --color-chart-1: var(--chart-1);
22
+ --color-ring: var(--ring);
23
+ --color-input: var(--input);
24
+ --color-border: var(--border);
25
+ --color-destructive: var(--destructive);
26
+ --color-accent-foreground: var(--accent-foreground);
27
+ --color-accent: var(--accent);
28
+ --color-muted-foreground: var(--muted-foreground);
29
+ --color-muted: var(--muted);
30
+ --color-secondary-foreground: var(--secondary-foreground);
31
+ --color-secondary: var(--secondary);
32
+ --color-primary-foreground: var(--primary-foreground);
33
+ --color-primary: var(--primary);
34
+ --color-popover-foreground: var(--popover-foreground);
35
+ --color-popover: var(--popover);
36
+ --color-card-foreground: var(--card-foreground);
37
+ --color-card: var(--card);
38
+ --radius-sm: calc(var(--radius) - 4px);
39
+ --radius-md: calc(var(--radius) - 2px);
40
+ --radius-lg: var(--radius);
41
+ --radius-xl: calc(var(--radius) + 4px);
42
+ --radius-2xl: calc(var(--radius) + 8px);
43
+ --radius-3xl: calc(var(--radius) + 12px);
44
+ --radius-4xl: calc(var(--radius) + 16px);
45
+ --font-sans:
46
+ 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', ui-sans-serif,
47
+ system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto,
48
+ 'Helvetica Neue', Arial, sans-serif;
49
+ --font-mono:
50
+ ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono',
51
+ 'Courier New', monospace;
52
+ --font-serif:
53
+ 'Noto Serif SC', 'Songti SC', 'SimSun', ui-serif, Georgia, Cambria,
54
+ 'Times New Roman', Times, serif;
55
+ }
56
+
57
+ :root {
58
+ --radius: 0.625rem;
59
+ --background: oklch(1 0 0);
60
+ --foreground: oklch(0.145 0 0);
61
+ --card: oklch(1 0 0);
62
+ --card-foreground: oklch(0.145 0 0);
63
+ --popover: oklch(1 0 0);
64
+ --popover-foreground: oklch(0.145 0 0);
65
+ --primary: oklch(0.205 0 0);
66
+ --primary-foreground: oklch(0.985 0 0);
67
+ --secondary: oklch(0.97 0 0);
68
+ --secondary-foreground: oklch(0.205 0 0);
69
+ --muted: oklch(0.97 0 0);
70
+ --muted-foreground: oklch(0.556 0 0);
71
+ --accent: oklch(0.97 0 0);
72
+ --accent-foreground: oklch(0.205 0 0);
73
+ --destructive: oklch(0.577 0.245 27.325);
74
+ --border: oklch(0.922 0 0);
75
+ --input: oklch(0.922 0 0);
76
+ --ring: oklch(0.708 0 0);
77
+ --chart-1: oklch(0.646 0.222 41.116);
78
+ --chart-2: oklch(0.6 0.118 184.704);
79
+ --chart-3: oklch(0.398 0.07 227.392);
80
+ --chart-4: oklch(0.828 0.189 84.429);
81
+ --chart-5: oklch(0.769 0.188 70.08);
82
+ --sidebar: oklch(0.985 0 0);
83
+ --sidebar-foreground: oklch(0.145 0 0);
84
+ --sidebar-primary: oklch(0.205 0 0);
85
+ --sidebar-primary-foreground: oklch(0.985 0 0);
86
+ --sidebar-accent: oklch(0.97 0 0);
87
+ --sidebar-accent-foreground: oklch(0.205 0 0);
88
+ --sidebar-border: oklch(0.922 0 0);
89
+ --sidebar-ring: oklch(0.708 0 0);
90
+ }
91
+
92
+ .dark {
93
+ --background: oklch(0.145 0 0);
94
+ --foreground: oklch(0.985 0 0);
95
+ --card: oklch(0.205 0 0);
96
+ --card-foreground: oklch(0.985 0 0);
97
+ --popover: oklch(0.205 0 0);
98
+ --popover-foreground: oklch(0.985 0 0);
99
+ --primary: oklch(0.922 0 0);
100
+ --primary-foreground: oklch(0.205 0 0);
101
+ --secondary: oklch(0.269 0 0);
102
+ --secondary-foreground: oklch(0.985 0 0);
103
+ --muted: oklch(0.269 0 0);
104
+ --muted-foreground: oklch(0.708 0 0);
105
+ --accent: oklch(0.269 0 0);
106
+ --accent-foreground: oklch(0.985 0 0);
107
+ --destructive: oklch(0.704 0.191 22.216);
108
+ --border: oklch(1 0 0 / 10%);
109
+ --input: oklch(1 0 0 / 15%);
110
+ --ring: oklch(0.556 0 0);
111
+ --chart-1: oklch(0.488 0.243 264.376);
112
+ --chart-2: oklch(0.696 0.17 162.48);
113
+ --chart-3: oklch(0.769 0.188 70.08);
114
+ --chart-4: oklch(0.627 0.265 303.9);
115
+ --chart-5: oklch(0.645 0.246 16.439);
116
+ --sidebar: oklch(0.205 0 0);
117
+ --sidebar-foreground: oklch(0.985 0 0);
118
+ --sidebar-primary: oklch(0.488 0.243 264.376);
119
+ --sidebar-primary-foreground: oklch(0.985 0 0);
120
+ --sidebar-accent: oklch(0.269 0 0);
121
+ --sidebar-accent-foreground: oklch(0.985 0 0);
122
+ --sidebar-border: oklch(1 0 0 / 10%);
123
+ --sidebar-ring: oklch(0.556 0 0);
124
+ }
125
+
126
+ @layer base {
127
+ * {
128
+ @apply border-border outline-ring/50;
129
+ }
130
+ body {
131
+ @apply bg-background text-foreground;
132
+ }
133
+ }
134
+
135
+ body {
136
+ @apply font-sans;
137
+ }
@@ -0,0 +1,74 @@
1
+ import type { Metadata } from 'next';
2
+ import { Inspector } from 'react-dev-inspector';
3
+ import './globals.css';
4
+
5
+ export const metadata: Metadata = {
6
+ title: {
7
+ default: '新应用 | 扣子编程',
8
+ template: '%s | 扣子编程',
9
+ },
10
+ description:
11
+ '扣子编程是一款一站式云端 Vibe Coding 开发平台。通过对话轻松构建智能体、工作流和网站,实现从创意到上线的无缝衔接。',
12
+ keywords: [
13
+ '扣子编程',
14
+ 'Coze Code',
15
+ 'Vibe Coding',
16
+ 'AI 编程',
17
+ '智能体搭建',
18
+ '工作流搭建',
19
+ '网站搭建',
20
+ '网站部署',
21
+ '全栈开发',
22
+ 'AI 工程师',
23
+ ],
24
+ authors: [{ name: 'Coze Code Team', url: 'https://code.coze.cn' }],
25
+ generator: 'Coze Code',
26
+ // icons: {
27
+ // icon: '',
28
+ // },
29
+ openGraph: {
30
+ title: '扣子编程 | 你的 AI 工程师已就位',
31
+ description:
32
+ '我正在使用扣子编程 Vibe Coding,让创意瞬间上线。告别拖拽,拥抱心流。',
33
+ url: 'https://code.coze.cn',
34
+ siteName: '扣子编程',
35
+ locale: 'zh_CN',
36
+ type: 'website',
37
+ // images: [
38
+ // {
39
+ // url: '',
40
+ // width: 1200,
41
+ // height: 630,
42
+ // alt: '扣子编程 - 你的 AI 工程师',
43
+ // },
44
+ // ],
45
+ },
46
+ // twitter: {
47
+ // card: 'summary_large_image',
48
+ // title: 'Coze Code | Your AI Engineer is Here',
49
+ // description:
50
+ // 'Build and deploy full-stack applications through AI conversation. No env setup, just flow.',
51
+ // // images: [''],
52
+ // },
53
+ robots: {
54
+ index: true,
55
+ follow: true,
56
+ },
57
+ };
58
+
59
+ export default function RootLayout({
60
+ children,
61
+ }: Readonly<{
62
+ children: React.ReactNode;
63
+ }>) {
64
+ const isDev = process.env.COZE_PROJECT_ENV === 'DEV';
65
+
66
+ return (
67
+ <html lang="en">
68
+ <body className={`antialiased`}>
69
+ {isDev && <Inspector />}
70
+ {children}
71
+ </body>
72
+ </html>
73
+ );
74
+ }
@@ -0,0 +1,35 @@
1
+ import type { Metadata } from 'next';
2
+ import Image from 'next/image';
3
+
4
+ export const metadata: Metadata = {
5
+ title: '扣子编程 - AI 开发伙伴',
6
+ description: '扣子编程,你的 AI 开发伙伴已就位',
7
+ };
8
+
9
+ export default function Home() {
10
+ return (
11
+ <div className="flex h-full items-center justify-center bg-background text-foreground transition-colors duration-300 dark:bg-background dark:text-foreground overflow-hidden min-h-screen">
12
+ {/* 主容器 */}
13
+ <main className="flex w-full h-full max-w-3xl flex-col items-center justify-center px-16 py-32 sm:items-center">
14
+ <div className="flex flex-col items-center justify-between gap-4">
15
+ <Image
16
+ src="https://lf-coze-web-cdn.coze.cn/obj/eden-cn/lm-lgvj/ljhwZthlaukjlkulzlp/coze-coding/icon/coze-coding.gif"
17
+ alt="扣子编程 Logo"
18
+ width={156}
19
+ height={130}
20
+ />
21
+ <div>
22
+ <div className="flex flex-col items-center gap-2 text-center sm:items-center sm:text-center">
23
+ <h1 className="max-w-xl text-base font-semibold leading-tight tracking-tight text-foreground dark:text-foreground">
24
+ 应用开发中
25
+ </h1>
26
+ <p className="max-w-2xl text-sm leading-8 text-muted-foreground dark:text-muted-foreground">
27
+ 请稍后,页面即将呈现
28
+ </p>
29
+ </div>
30
+ </div>
31
+ </div>
32
+ </main>
33
+ </div>
34
+ );
35
+ }
@@ -0,0 +1,11 @@
1
+ import { MetadataRoute } from 'next';
2
+
3
+ export default function robots(): MetadataRoute.Robots {
4
+ return {
5
+ rules: {
6
+ userAgent: '*',
7
+ allow: '/',
8
+ disallow: ['/api/', '/_next/', '/static/'],
9
+ },
10
+ };
11
+ }
@@ -0,0 +1,66 @@
1
+ "use client"
2
+
3
+ import * as React from "react"
4
+ import * as AccordionPrimitive from "@radix-ui/react-accordion"
5
+ import { ChevronDownIcon } from "lucide-react"
6
+
7
+ import { cn } from "@/lib/utils"
8
+
9
+ function Accordion({
10
+ ...props
11
+ }: React.ComponentProps<typeof AccordionPrimitive.Root>) {
12
+ return <AccordionPrimitive.Root data-slot="accordion" {...props} />
13
+ }
14
+
15
+ function AccordionItem({
16
+ className,
17
+ ...props
18
+ }: React.ComponentProps<typeof AccordionPrimitive.Item>) {
19
+ return (
20
+ <AccordionPrimitive.Item
21
+ data-slot="accordion-item"
22
+ className={cn("border-b last:border-b-0", className)}
23
+ {...props}
24
+ />
25
+ )
26
+ }
27
+
28
+ function AccordionTrigger({
29
+ className,
30
+ children,
31
+ ...props
32
+ }: React.ComponentProps<typeof AccordionPrimitive.Trigger>) {
33
+ return (
34
+ <AccordionPrimitive.Header className="flex">
35
+ <AccordionPrimitive.Trigger
36
+ data-slot="accordion-trigger"
37
+ className={cn(
38
+ "focus-visible:border-ring focus-visible:ring-ring/50 flex flex-1 items-start justify-between gap-4 rounded-md py-4 text-left text-sm font-medium transition-all outline-none hover:underline focus-visible:ring-[3px] disabled:pointer-events-none disabled:opacity-50 [&[data-state=open]>svg]:rotate-180",
39
+ className
40
+ )}
41
+ {...props}
42
+ >
43
+ {children}
44
+ <ChevronDownIcon className="text-muted-foreground pointer-events-none size-4 shrink-0 translate-y-0.5 transition-transform duration-200" />
45
+ </AccordionPrimitive.Trigger>
46
+ </AccordionPrimitive.Header>
47
+ )
48
+ }
49
+
50
+ function AccordionContent({
51
+ className,
52
+ children,
53
+ ...props
54
+ }: React.ComponentProps<typeof AccordionPrimitive.Content>) {
55
+ return (
56
+ <AccordionPrimitive.Content
57
+ data-slot="accordion-content"
58
+ className="data-[state=closed]:animate-accordion-up data-[state=open]:animate-accordion-down overflow-hidden text-sm"
59
+ {...props}
60
+ >
61
+ <div className={cn("pt-0 pb-4", className)}>{children}</div>
62
+ </AccordionPrimitive.Content>
63
+ )
64
+ }
65
+
66
+ export { Accordion, AccordionItem, AccordionTrigger, AccordionContent }
@@ -0,0 +1,157 @@
1
+ "use client"
2
+
3
+ import * as React from "react"
4
+ import * as AlertDialogPrimitive from "@radix-ui/react-alert-dialog"
5
+
6
+ import { cn } from "@/lib/utils"
7
+ import { buttonVariants } from "@/components/ui/button"
8
+
9
+ function AlertDialog({
10
+ ...props
11
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Root>) {
12
+ return <AlertDialogPrimitive.Root data-slot="alert-dialog" {...props} />
13
+ }
14
+
15
+ function AlertDialogTrigger({
16
+ ...props
17
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Trigger>) {
18
+ return (
19
+ <AlertDialogPrimitive.Trigger data-slot="alert-dialog-trigger" {...props} />
20
+ )
21
+ }
22
+
23
+ function AlertDialogPortal({
24
+ ...props
25
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Portal>) {
26
+ return (
27
+ <AlertDialogPrimitive.Portal data-slot="alert-dialog-portal" {...props} />
28
+ )
29
+ }
30
+
31
+ function AlertDialogOverlay({
32
+ className,
33
+ ...props
34
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Overlay>) {
35
+ return (
36
+ <AlertDialogPrimitive.Overlay
37
+ data-slot="alert-dialog-overlay"
38
+ className={cn(
39
+ "data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 fixed inset-0 z-50 bg-black/50",
40
+ className
41
+ )}
42
+ {...props}
43
+ />
44
+ )
45
+ }
46
+
47
+ function AlertDialogContent({
48
+ className,
49
+ ...props
50
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Content>) {
51
+ return (
52
+ <AlertDialogPortal>
53
+ <AlertDialogOverlay />
54
+ <AlertDialogPrimitive.Content
55
+ data-slot="alert-dialog-content"
56
+ className={cn(
57
+ "bg-background data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 fixed top-[50%] left-[50%] z-50 grid w-full max-w-[calc(100%-2rem)] translate-x-[-50%] translate-y-[-50%] gap-4 rounded-lg border p-6 shadow-lg duration-200 sm:max-w-lg",
58
+ className
59
+ )}
60
+ {...props}
61
+ />
62
+ </AlertDialogPortal>
63
+ )
64
+ }
65
+
66
+ function AlertDialogHeader({
67
+ className,
68
+ ...props
69
+ }: React.ComponentProps<"div">) {
70
+ return (
71
+ <div
72
+ data-slot="alert-dialog-header"
73
+ className={cn("flex flex-col gap-2 text-center sm:text-left", className)}
74
+ {...props}
75
+ />
76
+ )
77
+ }
78
+
79
+ function AlertDialogFooter({
80
+ className,
81
+ ...props
82
+ }: React.ComponentProps<"div">) {
83
+ return (
84
+ <div
85
+ data-slot="alert-dialog-footer"
86
+ className={cn(
87
+ "flex flex-col-reverse gap-2 sm:flex-row sm:justify-end",
88
+ className
89
+ )}
90
+ {...props}
91
+ />
92
+ )
93
+ }
94
+
95
+ function AlertDialogTitle({
96
+ className,
97
+ ...props
98
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Title>) {
99
+ return (
100
+ <AlertDialogPrimitive.Title
101
+ data-slot="alert-dialog-title"
102
+ className={cn("text-lg font-semibold", className)}
103
+ {...props}
104
+ />
105
+ )
106
+ }
107
+
108
+ function AlertDialogDescription({
109
+ className,
110
+ ...props
111
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Description>) {
112
+ return (
113
+ <AlertDialogPrimitive.Description
114
+ data-slot="alert-dialog-description"
115
+ className={cn("text-muted-foreground text-sm", className)}
116
+ {...props}
117
+ />
118
+ )
119
+ }
120
+
121
+ function AlertDialogAction({
122
+ className,
123
+ ...props
124
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Action>) {
125
+ return (
126
+ <AlertDialogPrimitive.Action
127
+ className={cn(buttonVariants(), className)}
128
+ {...props}
129
+ />
130
+ )
131
+ }
132
+
133
+ function AlertDialogCancel({
134
+ className,
135
+ ...props
136
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Cancel>) {
137
+ return (
138
+ <AlertDialogPrimitive.Cancel
139
+ className={cn(buttonVariants({ variant: "outline" }), className)}
140
+ {...props}
141
+ />
142
+ )
143
+ }
144
+
145
+ export {
146
+ AlertDialog,
147
+ AlertDialogPortal,
148
+ AlertDialogOverlay,
149
+ AlertDialogTrigger,
150
+ AlertDialogContent,
151
+ AlertDialogHeader,
152
+ AlertDialogFooter,
153
+ AlertDialogTitle,
154
+ AlertDialogDescription,
155
+ AlertDialogAction,
156
+ AlertDialogCancel,
157
+ }
@@ -0,0 +1,66 @@
1
+ import * as React from "react"
2
+ import { cva, type VariantProps } from "class-variance-authority"
3
+
4
+ import { cn } from "@/lib/utils"
5
+
6
+ const alertVariants = cva(
7
+ "relative w-full rounded-lg border px-4 py-3 text-sm grid has-[>svg]:grid-cols-[calc(var(--spacing)*4)_1fr] grid-cols-[0_1fr] has-[>svg]:gap-x-3 gap-y-0.5 items-start [&>svg]:size-4 [&>svg]:translate-y-0.5 [&>svg]:text-current",
8
+ {
9
+ variants: {
10
+ variant: {
11
+ default: "bg-card text-card-foreground",
12
+ destructive:
13
+ "text-destructive bg-card [&>svg]:text-current *:data-[slot=alert-description]:text-destructive/90",
14
+ },
15
+ },
16
+ defaultVariants: {
17
+ variant: "default",
18
+ },
19
+ }
20
+ )
21
+
22
+ function Alert({
23
+ className,
24
+ variant,
25
+ ...props
26
+ }: React.ComponentProps<"div"> & VariantProps<typeof alertVariants>) {
27
+ return (
28
+ <div
29
+ data-slot="alert"
30
+ role="alert"
31
+ className={cn(alertVariants({ variant }), className)}
32
+ {...props}
33
+ />
34
+ )
35
+ }
36
+
37
+ function AlertTitle({ className, ...props }: React.ComponentProps<"div">) {
38
+ return (
39
+ <div
40
+ data-slot="alert-title"
41
+ className={cn(
42
+ "col-start-2 line-clamp-1 min-h-4 font-medium tracking-tight",
43
+ className
44
+ )}
45
+ {...props}
46
+ />
47
+ )
48
+ }
49
+
50
+ function AlertDescription({
51
+ className,
52
+ ...props
53
+ }: React.ComponentProps<"div">) {
54
+ return (
55
+ <div
56
+ data-slot="alert-description"
57
+ className={cn(
58
+ "text-muted-foreground col-start-2 grid justify-items-start gap-1 text-sm [&_p]:leading-relaxed",
59
+ className
60
+ )}
61
+ {...props}
62
+ />
63
+ )
64
+ }
65
+
66
+ export { Alert, AlertTitle, AlertDescription }
@@ -0,0 +1,11 @@
1
+ "use client"
2
+
3
+ import * as AspectRatioPrimitive from "@radix-ui/react-aspect-ratio"
4
+
5
+ function AspectRatio({
6
+ ...props
7
+ }: React.ComponentProps<typeof AspectRatioPrimitive.Root>) {
8
+ return <AspectRatioPrimitive.Root data-slot="aspect-ratio" {...props} />
9
+ }
10
+
11
+ export { AspectRatio }