create-cloudflare 0.0.0-e5cdd7fa → 0.0.0-e5dbedd78

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 (282) hide show
  1. package/README.md +1 -1
  2. package/dist/cli.js +66474 -63680
  3. package/dist/tsconfig.tsbuildinfo +1 -0
  4. package/package.json +39 -27
  5. package/templates/analog/c3.ts +135 -0
  6. package/templates/analog/snippets/devBindingsModule.ts +7 -0
  7. package/templates/analog/templates/env.d.ts +13 -0
  8. package/templates/analog/templates/src/dev-bindings.ts +18 -0
  9. package/templates/analog/templates/worker-configuration.d.ts +4 -0
  10. package/templates/analog/templates/wrangler.jsonc +5 -0
  11. package/templates/angular/c3.ts +5 -95
  12. package/templates/angular/pages/c3.ts +134 -0
  13. package/templates/angular/pages/templates/src/server.ts +15 -0
  14. package/templates/angular/pages/templates/tools/copy-files.mjs +15 -0
  15. package/templates/angular/workers/c3.ts +130 -0
  16. package/templates/angular/workers/templates/src/server.ts +15 -0
  17. package/templates/angular/workers/templates/wrangler.jsonc +12 -0
  18. package/templates/astro/c3.ts +5 -46
  19. package/templates/astro/pages/c3.ts +98 -0
  20. package/templates/astro/pages/templates/js/wrangler.jsonc +8 -0
  21. package/templates/astro/pages/templates/ts/src/env.d.ts +5 -0
  22. package/templates/astro/pages/templates/ts/worker-configuration.d.ts +4 -0
  23. package/templates/astro/pages/templates/ts/wrangler.jsonc +8 -0
  24. package/templates/astro/workers/c3.ts +98 -0
  25. package/templates/astro/workers/templates/js/public/.assetsignore +2 -0
  26. package/templates/astro/workers/templates/js/wrangler.jsonc +15 -0
  27. package/templates/astro/workers/templates/ts/public/.assetsignore +2 -0
  28. package/templates/astro/workers/templates/ts/src/env.d.ts +5 -0
  29. package/templates/astro/workers/templates/ts/worker-configuration.d.ts +4 -0
  30. package/templates/astro/workers/templates/ts/wrangler.jsonc +15 -0
  31. package/templates/common/c3.ts +10 -5
  32. package/templates/common/js/.editorconfig +0 -1
  33. package/templates/common/js/package.json +1 -1
  34. package/templates/common/js/wrangler.jsonc +8 -0
  35. package/templates/common/ts/.editorconfig +0 -1
  36. package/templates/common/ts/package.json +4 -3
  37. package/templates/common/ts/src/ab-test.ts +2 -2
  38. package/templates/common/ts/src/index.ts +5 -2
  39. package/templates/common/ts/src/proxy.ts +2 -2
  40. package/templates/common/ts/src/redirect.ts +2 -2
  41. package/templates/common/ts/tsconfig.json +37 -95
  42. package/templates/common/ts/worker-configuration.d.ts +2 -14
  43. package/templates/common/ts/wrangler.jsonc +8 -0
  44. package/templates/docusaurus/c3.ts +5 -23
  45. package/templates/docusaurus/pages/c3.ts +30 -0
  46. package/templates/docusaurus/workers/c3.ts +33 -0
  47. package/templates/docusaurus/workers/templates/wrangler.jsonc +10 -0
  48. package/templates/gatsby/c3.ts +5 -42
  49. package/templates/gatsby/pages/c3.ts +50 -0
  50. package/templates/gatsby/workers/c3.ts +53 -0
  51. package/templates/gatsby/workers/templates/wrangler.jsonc +10 -0
  52. package/templates/hello-world/c3.ts +30 -7
  53. package/templates/hello-world/js/.editorconfig +0 -1
  54. package/templates/hello-world/js/package.json +5 -2
  55. package/templates/hello-world/js/test/index.spec.js +20 -0
  56. package/templates/hello-world/js/vitest.config.js +11 -0
  57. package/templates/hello-world/js/wrangler.jsonc +8 -0
  58. package/templates/hello-world/py/.python-version +1 -0
  59. package/templates/hello-world/py/README.md +23 -0
  60. package/templates/hello-world/py/__dot__gitignore +68 -0
  61. package/templates/hello-world/py/package.json +13 -0
  62. package/templates/hello-world/py/pyproject.toml +9 -0
  63. package/templates/hello-world/py/src/entry.py +4 -0
  64. package/templates/hello-world/py/uv.lock +22 -0
  65. package/templates/hello-world/py/wrangler.jsonc +9 -0
  66. package/templates/hello-world/ts/.editorconfig +0 -1
  67. package/templates/hello-world/ts/package.json +7 -3
  68. package/templates/hello-world/ts/src/index.ts +5 -19
  69. package/templates/hello-world/ts/test/index.spec.ts +25 -0
  70. package/templates/hello-world/ts/test/tsconfig.json +8 -0
  71. package/templates/hello-world/ts/tsconfig.json +39 -96
  72. package/templates/hello-world/ts/vitest.config.mts +11 -0
  73. package/templates/hello-world/ts/worker-configuration.d.ts +4 -0
  74. package/templates/hello-world/ts/wrangler.jsonc +8 -0
  75. package/templates/hello-world-assets-only/c3.ts +16 -0
  76. package/templates/hello-world-assets-only/templates/package.json +13 -0
  77. package/templates/hello-world-assets-only/templates/public/index.html +11 -0
  78. package/templates/hello-world-assets-only/templates/wrangler.jsonc +10 -0
  79. package/templates/hello-world-durable-object/c3.ts +10 -6
  80. package/templates/hello-world-durable-object/js/.editorconfig +0 -1
  81. package/templates/hello-world-durable-object/js/package.json +1 -1
  82. package/templates/hello-world-durable-object/js/src/index.js +28 -23
  83. package/templates/hello-world-durable-object/js/wrangler.jsonc +24 -0
  84. package/templates/hello-world-durable-object/ts/.editorconfig +0 -1
  85. package/templates/hello-world-durable-object/ts/package.json +4 -4
  86. package/templates/hello-world-durable-object/ts/src/index.ts +32 -44
  87. package/templates/hello-world-durable-object/ts/tsconfig.json +36 -95
  88. package/templates/hello-world-durable-object/ts/worker-configuration.d.ts +5 -0
  89. package/templates/hello-world-durable-object/ts/wrangler.jsonc +24 -0
  90. package/templates/hello-world-durable-object-with-assets/c3.ts +23 -0
  91. package/templates/hello-world-durable-object-with-assets/js/.editorconfig +12 -0
  92. package/templates/hello-world-durable-object-with-assets/js/.prettierrc +6 -0
  93. package/templates/hello-world-durable-object-with-assets/js/__dot__gitignore +172 -0
  94. package/templates/hello-world-durable-object-with-assets/js/package.json +13 -0
  95. package/templates/hello-world-durable-object-with-assets/js/public/index.html +19 -0
  96. package/templates/hello-world-durable-object-with-assets/js/src/index.js +69 -0
  97. package/templates/hello-world-durable-object-with-assets/js/wrangler.jsonc +28 -0
  98. package/templates/hello-world-durable-object-with-assets/ts/.editorconfig +12 -0
  99. package/templates/hello-world-durable-object-with-assets/ts/.prettierrc +6 -0
  100. package/templates/hello-world-durable-object-with-assets/ts/__dot__gitignore +172 -0
  101. package/templates/hello-world-durable-object-with-assets/ts/package.json +15 -0
  102. package/templates/hello-world-durable-object-with-assets/ts/public/index.html +19 -0
  103. package/templates/hello-world-durable-object-with-assets/ts/src/index.ts +66 -0
  104. package/templates/hello-world-durable-object-with-assets/ts/tsconfig.json +42 -0
  105. package/templates/hello-world-durable-object-with-assets/ts/worker-configuration.d.ts +5 -0
  106. package/templates/hello-world-durable-object-with-assets/ts/wrangler.jsonc +28 -0
  107. package/templates/hello-world-with-assets/c3.ts +21 -0
  108. package/templates/hello-world-with-assets/js/.editorconfig +12 -0
  109. package/templates/hello-world-with-assets/js/.prettierrc +6 -0
  110. package/templates/hello-world-with-assets/js/__dot__gitignore +172 -0
  111. package/templates/hello-world-with-assets/js/package.json +16 -0
  112. package/templates/hello-world-with-assets/js/public/index.html +31 -0
  113. package/templates/hello-world-with-assets/js/src/index.js +23 -0
  114. package/templates/hello-world-with-assets/js/test/index.spec.js +41 -0
  115. package/templates/hello-world-with-assets/js/vitest.config.js +11 -0
  116. package/templates/hello-world-with-assets/js/wrangler.jsonc +15 -0
  117. package/templates/hello-world-with-assets/py/__dot__gitignore +68 -0
  118. package/templates/hello-world-with-assets/py/package.json +13 -0
  119. package/templates/hello-world-with-assets/py/public/index.html +31 -0
  120. package/templates/hello-world-with-assets/py/src/entry.py +9 -0
  121. package/templates/hello-world-with-assets/py/wrangler.jsonc +15 -0
  122. package/templates/hello-world-with-assets/ts/.editorconfig +12 -0
  123. package/templates/hello-world-with-assets/ts/.prettierrc +6 -0
  124. package/templates/hello-world-with-assets/ts/__dot__gitignore +172 -0
  125. package/templates/hello-world-with-assets/ts/package.json +18 -0
  126. package/templates/hello-world-with-assets/ts/public/index.html +31 -0
  127. package/templates/hello-world-with-assets/ts/src/index.ts +26 -0
  128. package/templates/hello-world-with-assets/ts/test/index.spec.ts +41 -0
  129. package/templates/hello-world-with-assets/ts/test/tsconfig.json +8 -0
  130. package/templates/hello-world-with-assets/ts/tsconfig.json +44 -0
  131. package/templates/hello-world-with-assets/ts/vitest.config.mts +11 -0
  132. package/templates/hello-world-with-assets/ts/worker-configuration.d.ts +4 -0
  133. package/templates/hello-world-with-assets/ts/wrangler.jsonc +15 -0
  134. package/templates/hono/c3.ts +5 -21
  135. package/templates/hono/pages/c3.ts +42 -0
  136. package/templates/hono/pages/templates/src/index.tsx +12 -0
  137. package/templates/hono/pages/templates/worker-configuration.d.ts +4 -0
  138. package/templates/hono/pages/templates/wrangler.jsonc +9 -0
  139. package/templates/hono/workers/c3.ts +42 -0
  140. package/templates/hono/workers/templates/public/index.html +19 -0
  141. package/templates/hono/workers/templates/src/index.ts +9 -0
  142. package/templates/hono/workers/templates/worker-configuration.d.ts +4 -0
  143. package/templates/hono/workers/templates/wrangler.jsonc +9 -0
  144. package/templates/next/README.md +67 -0
  145. package/templates/next/app/js/app/api/hello/route.js +21 -0
  146. package/templates/next/app/js/app/not-found.js +58 -0
  147. package/templates/next/app/ts/app/api/hello/route.ts +21 -0
  148. package/templates/next/app/ts/app/not-found.tsx +58 -0
  149. package/templates/next/c3.ts +96 -86
  150. package/templates/next/env.d.ts +5 -0
  151. package/templates/next/pages/js/pages/api/hello.js +23 -0
  152. package/templates/next/pages/ts/pages/api/hello.ts +24 -0
  153. package/templates/next/wrangler.jsonc +8 -0
  154. package/templates/nuxt/c3.ts +5 -55
  155. package/templates/nuxt/pages/c3.ts +145 -0
  156. package/templates/nuxt/pages/templates/env.d.ts +14 -0
  157. package/templates/nuxt/pages/templates/worker-configuration.d.ts +4 -0
  158. package/templates/nuxt/pages/templates/wrangler.jsonc +5 -0
  159. package/templates/nuxt/workers/c3.ts +145 -0
  160. package/templates/nuxt/workers/templates/env.d.ts +14 -0
  161. package/templates/nuxt/workers/templates/worker-configuration.d.ts +4 -0
  162. package/templates/nuxt/workers/templates/wrangler.jsonc +12 -0
  163. package/templates/openapi/c3.ts +1 -0
  164. package/templates/openapi/ts/README.md +3 -3
  165. package/templates/openapi/ts/package.json +7 -4
  166. package/templates/openapi/ts/src/endpoints/taskCreate.ts +26 -16
  167. package/templates/openapi/ts/src/endpoints/taskDelete.ts +20 -19
  168. package/templates/openapi/ts/src/endpoints/taskFetch.ts +30 -23
  169. package/templates/openapi/ts/src/endpoints/taskList.ts +27 -24
  170. package/templates/openapi/ts/src/index.ts +14 -20
  171. package/templates/openapi/ts/src/types.ts +9 -8
  172. package/templates/openapi/ts/worker-configuration.d.ts +4 -0
  173. package/templates/openapi/ts/wrangler.jsonc +8 -0
  174. package/templates/pre-existing/c3.ts +37 -18
  175. package/templates/pre-existing/js/.editorconfig +0 -1
  176. package/templates/pre-existing/js/package.json +1 -1
  177. package/templates/queues/c3.ts +9 -5
  178. package/templates/queues/js/.editorconfig +0 -1
  179. package/templates/queues/js/package.json +1 -1
  180. package/templates/queues/js/wrangler.jsonc +21 -0
  181. package/templates/queues/ts/.editorconfig +0 -1
  182. package/templates/queues/ts/package.json +4 -3
  183. package/templates/queues/ts/src/index.ts +6 -8
  184. package/templates/queues/ts/tsconfig.json +36 -95
  185. package/templates/queues/ts/worker-configuration.d.ts +5 -0
  186. package/templates/queues/ts/wrangler.jsonc +21 -0
  187. package/templates/qwik/c3.ts +5 -88
  188. package/templates/qwik/pages/c3.ts +149 -0
  189. package/templates/qwik/pages/snippets/getPlatformProxy.ts +6 -0
  190. package/templates/qwik/pages/templates/worker-configuration.d.ts +4 -0
  191. package/templates/qwik/pages/templates/wrangler.jsonc +8 -0
  192. package/templates/qwik/workers/c3.ts +154 -0
  193. package/templates/qwik/workers/snippets/getPlatformProxy.ts +6 -0
  194. package/templates/qwik/workers/templates/public/.assetsignore +4 -0
  195. package/templates/qwik/workers/templates/worker-configuration.d.ts +4 -0
  196. package/templates/qwik/workers/templates/wrangler.jsonc +15 -0
  197. package/templates/react/c3.ts +5 -25
  198. package/templates/react/pages/c3.ts +62 -0
  199. package/templates/react/workers/c3.ts +183 -0
  200. package/templates/react/workers/js/api/index.js +13 -0
  201. package/templates/react/workers/js/src/App.css +45 -0
  202. package/templates/react/workers/js/src/App.jsx +58 -0
  203. package/templates/react/workers/js/src/assets/Cloudflare_Logo.svg +53 -0
  204. package/templates/react/workers/js/wrangler.jsonc +9 -0
  205. package/templates/react/workers/ts/api/index.ts +13 -0
  206. package/templates/react/workers/ts/src/App.css +45 -0
  207. package/templates/react/workers/ts/src/App.tsx +58 -0
  208. package/templates/react/workers/ts/src/assets/Cloudflare_Logo.svg +51 -0
  209. package/templates/react/workers/ts/tsconfig.worker.json +8 -0
  210. package/templates/react/workers/ts/worker-configuration.d.ts +5 -0
  211. package/templates/react/workers/ts/wrangler.jsonc +9 -0
  212. package/templates/remix/c3.ts +5 -29
  213. package/templates/remix/pages/c3.ts +68 -0
  214. package/templates/remix/pages/templates/worker-configuration.d.ts +4 -0
  215. package/templates/remix/pages/templates/wrangler.jsonc +5 -0
  216. package/templates/remix/workers/c3.ts +52 -0
  217. package/templates/remix/workers/templates/public/.assetsignore +0 -0
  218. package/templates/remix/workers/templates/worker-configuration.d.ts +4 -0
  219. package/templates/remix/workers/templates/wrangler.toml +11 -0
  220. package/templates/scheduled/c3.ts +9 -5
  221. package/templates/scheduled/js/.editorconfig +0 -1
  222. package/templates/scheduled/js/package.json +3 -3
  223. package/templates/scheduled/js/src/index.js +9 -2
  224. package/templates/scheduled/js/wrangler.jsonc +13 -0
  225. package/templates/scheduled/ts/.editorconfig +0 -1
  226. package/templates/scheduled/ts/package.json +5 -4
  227. package/templates/scheduled/ts/src/index.ts +8 -25
  228. package/templates/scheduled/ts/tsconfig.json +36 -95
  229. package/templates/scheduled/ts/worker-configuration.d.ts +4 -0
  230. package/templates/scheduled/ts/wrangler.jsonc +13 -0
  231. package/templates/solid/c3.ts +62 -12
  232. package/templates/solid/templates/wrangler.jsonc +8 -0
  233. package/templates/svelte/c3.ts +6 -74
  234. package/templates/svelte/pages/c3.ts +159 -0
  235. package/templates/svelte/pages/templates/wrangler.jsonc +5 -0
  236. package/templates/svelte/workers/c3.ts +129 -0
  237. package/templates/svelte/workers/templates/static/.assetsignore +2 -0
  238. package/templates/svelte/workers/templates/wrangler.jsonc +12 -0
  239. package/templates/vue/c3.ts +5 -23
  240. package/templates/vue/pages/c3.ts +30 -0
  241. package/templates/vue/workers/c3.ts +98 -0
  242. package/templates/vue/workers/js/server/index.js +13 -0
  243. package/templates/vue/workers/js/src/App.vue +107 -0
  244. package/templates/vue/workers/js/src/components/HelloWorld.vue +47 -0
  245. package/templates/vue/workers/js/vite.config.js +21 -0
  246. package/templates/vue/workers/js/wrangler.jsonc +12 -0
  247. package/templates/vue/workers/ts/server/index.ts +13 -0
  248. package/templates/vue/workers/ts/src/App.vue +107 -0
  249. package/templates/vue/workers/ts/src/components/HelloWorld.vue +44 -0
  250. package/templates/vue/workers/ts/tsconfig.worker.json +8 -0
  251. package/templates/vue/workers/ts/vite.config.ts +21 -0
  252. package/templates/vue/workers/ts/worker-configuration.d.ts +6 -0
  253. package/templates/vue/workers/ts/wrangler.jsonc +12 -0
  254. package/templates-experimental/next/c3.ts +75 -0
  255. package/templates-experimental/next/templates/.dev.vars +2 -0
  256. package/templates-experimental/next/templates/__dot__gitignore +39 -0
  257. package/templates-experimental/next/templates/cloudflare-env.d.ts +5 -0
  258. package/templates-experimental/next/templates/open-next.config.ts +6 -0
  259. package/templates-experimental/next/templates/wrangler.jsonc +12 -0
  260. package/templates-experimental/solid/c3.ts +94 -0
  261. package/templates-experimental/solid/templates/wrangler.jsonc +15 -0
  262. package/templates/angular/templates/server.ts +0 -34
  263. package/templates/angular/templates/tools/alter-polyfills.mjs +0 -27
  264. package/templates/angular/templates/tools/copy-files.mjs +0 -9
  265. package/templates/angular/templates/tools/paths.mjs +0 -9
  266. package/templates/common/js/wrangler.toml +0 -51
  267. package/templates/common/ts/wrangler.toml +0 -51
  268. package/templates/hello-world/js/wrangler.toml +0 -51
  269. package/templates/hello-world/ts/wrangler.toml +0 -51
  270. package/templates/hello-world-durable-object/js/wrangler.toml +0 -51
  271. package/templates/hello-world-durable-object/ts/wrangler.toml +0 -51
  272. package/templates/next/templates.ts +0 -281
  273. package/templates/openapi/ts/wrangler.toml +0 -3
  274. package/templates/pre-existing/js/wrangler.toml +0 -3
  275. package/templates/queues/js/wrangler.toml +0 -19
  276. package/templates/queues/ts/wrangler.toml +0 -19
  277. package/templates/scheduled/js/wrangler.toml +0 -9
  278. package/templates/scheduled/ts/wrangler.toml +0 -9
  279. package/templates/solid/js/vite.config.js +0 -12
  280. package/templates/solid/ts/vite.config.ts +0 -12
  281. package/templates/svelte/templates.ts +0 -13
  282. /package/templates/angular/{templates → pages/templates}/src/_routes.json +0 -0
@@ -1,31 +1,23 @@
1
- import { existsSync, mkdirSync } from "fs";
2
- import { crash, updateStatus, warn } from "@cloudflare/cli";
3
- import { processArgument } from "@cloudflare/cli/args";
1
+ import { join } from "path";
2
+ import { updateStatus, warn } from "@cloudflare/cli";
4
3
  import { brandColor, dim } from "@cloudflare/cli/colors";
5
- import { installPackages, runFrameworkGenerator } from "helpers/command";
4
+ import { inputPrompt, spinner } from "@cloudflare/cli/interactive";
5
+ import { runFrameworkGenerator } from "frameworks/index";
6
6
  import {
7
- compatDateFlag,
7
+ copyFile,
8
8
  probePaths,
9
+ readFile,
9
10
  readJSON,
10
11
  usesEslint,
11
12
  usesTypescript,
12
13
  writeFile,
13
14
  writeJSON,
14
15
  } from "helpers/files";
15
- import { detectPackageManager } from "helpers/packages";
16
- import {
17
- apiAppDirHelloJs,
18
- apiAppDirHelloTs,
19
- apiPagesDirHelloJs,
20
- apiPagesDirHelloTs,
21
- appDirNotFoundJs,
22
- appDirNotFoundTs,
23
- envDts,
24
- nextConfig,
25
- readme,
26
- } from "./templates";
16
+ import { detectPackageManager } from "helpers/packageManagers";
17
+ import { installPackages } from "helpers/packages";
18
+ import { getTemplatePath } from "../../src/templates";
27
19
  import type { TemplateConfig } from "../../src/templates";
28
- import type { C3Args, C3Context } from "types";
20
+ import type { C3Context } from "types";
29
21
 
30
22
  const { npm, npx } = detectPackageManager();
31
23
 
@@ -33,27 +25,35 @@ const generate = async (ctx: C3Context) => {
33
25
  const projectName = ctx.project.name;
34
26
 
35
27
  await runFrameworkGenerator(ctx, [projectName]);
28
+
29
+ const wranglerConfig = readFile(join(getTemplatePath(ctx), "wrangler.jsonc"));
30
+ writeFile(join(ctx.project.path, "wrangler.jsonc"), wranglerConfig);
31
+ updateStatus("Created wrangler.jsonc file");
36
32
  };
37
33
 
38
- const getApiTemplate = (
39
- apiPath: string,
40
- isTypescript: boolean
41
- ): [string, string] => {
42
- const isAppDir = /\/app\/api$/.test(apiPath);
34
+ const updateNextConfig = (usesTs: boolean) => {
35
+ const s = spinner();
43
36
 
44
- if (isAppDir) {
45
- // App directory uses route handlers that are defined in a subdirectory (`/api/hello/route.ts`).
46
- const routeHandlerPath = `${apiPath}/hello`;
47
- mkdirSync(routeHandlerPath, { recursive: true });
37
+ const configFile = `next.config.${usesTs ? "ts" : "mjs"}`;
38
+ s.start(`Updating \`${configFile}\``);
48
39
 
49
- return isTypescript
50
- ? [`${routeHandlerPath}/route.ts`, apiAppDirHelloTs]
51
- : [`${routeHandlerPath}/route.js`, apiAppDirHelloJs];
52
- }
40
+ const configContent = readFile(configFile);
41
+
42
+ const updatedConfigFile =
43
+ `import { setupDevPlatform } from '@cloudflare/next-on-pages/next-dev';
44
+
45
+ // Here we use the @cloudflare/next-on-pages next-dev module to allow us to
46
+ // use bindings during local development (when running the application with
47
+ // \`next dev\`). This function is only necessary during development and
48
+ // has no impact outside of that. For more information see:
49
+ // https://github.com/cloudflare/next-on-pages/blob/main/internal-packages/next-dev/README.md
50
+ setupDevPlatform().catch(console.error);
51
+
52
+ `.replace(/\n\t*/g, "\n") + configContent;
53
+
54
+ writeFile(configFile, updatedConfigFile);
53
55
 
54
- return isTypescript
55
- ? [`${apiPath}/hello.ts`, apiPagesDirHelloTs]
56
- : [`${apiPath}/hello.js`, apiPagesDirHelloJs];
56
+ s.stop(`${brandColor(`updated`)} ${dim(`\`${configFile}\``)}`);
57
57
  };
58
58
 
59
59
  const configure = async (ctx: C3Context) => {
@@ -70,39 +70,16 @@ const configure = async (ctx: C3Context) => {
70
70
  ]);
71
71
 
72
72
  if (!path) {
73
- crash("Could not find the `/api` or `/app` directory");
73
+ throw new Error("Could not find the `/api` or `/app` directory");
74
74
  }
75
75
 
76
- // App directory template may not generate an API route handler, so we update the path to add an `api` directory.
77
- const apiPath = path.replace(/\/app$/, "/app/api");
78
-
79
76
  const usesTs = usesTypescript(ctx);
80
77
 
81
- const appDirPath = probePaths([
82
- `${projectPath}/src/app`,
83
- `${projectPath}/app`,
84
- ]);
85
-
86
- if (appDirPath) {
87
- // Add a custom app not-found edge route as recommended in next-on-pages
88
- // (see: https://github.com/cloudflare/next-on-pages/blob/2b5c8f25/packages/next-on-pages/docs/gotchas.md#not-found)
89
- const notFoundPath = `${appDirPath}/not-found.${usesTs ? "tsx" : "js"}`;
90
- if (!existsSync(notFoundPath)) {
91
- const notFoundContent = usesTs ? appDirNotFoundTs : appDirNotFoundJs;
92
- writeFile(notFoundPath, notFoundContent);
93
- updateStatus("Created a custom edge not-found route");
94
- }
95
- }
96
-
97
- const [handlerPath, handlerFile] = getApiTemplate(
98
- apiPath,
99
- usesTypescript(ctx)
100
- );
101
- writeFile(handlerPath, handlerFile);
102
- updateStatus("Created an example API route handler");
103
-
104
78
  if (usesTs) {
105
- writeFile(`${projectPath}/env.d.ts`, envDts);
79
+ copyFile(
80
+ join(getTemplatePath(ctx), "env.d.ts"),
81
+ join(projectPath, "env.d.ts"),
82
+ );
106
83
  updateStatus("Created an env.d.ts file");
107
84
  }
108
85
 
@@ -112,30 +89,34 @@ const configure = async (ctx: C3Context) => {
112
89
  await writeEslintrc(ctx);
113
90
  }
114
91
 
115
- writeFile(`${projectPath}/next.config.mjs`, nextConfig);
116
- updateStatus("Updated the next.config.js file");
92
+ updateNextConfig(usesTs);
117
93
 
118
- writeFile(`${projectPath}/README.md`, readme);
94
+ copyFile(
95
+ join(getTemplatePath(ctx), "README.md"),
96
+ join(projectPath, "README.md"),
97
+ );
119
98
  updateStatus("Updated the README file");
120
99
 
121
100
  await addDevDependencies(installEslintPlugin);
122
101
  };
123
102
 
124
103
  export const shouldInstallNextOnPagesEslintPlugin = async (
125
- ctx: C3Context
104
+ ctx: C3Context,
126
105
  ): Promise<boolean> => {
127
106
  const eslintUsage = usesEslint(ctx);
128
107
 
129
- if (!eslintUsage.used) return false;
108
+ if (!eslintUsage.used) {
109
+ return false;
110
+ }
130
111
 
131
112
  if (eslintUsage.configType !== ".eslintrc.json") {
132
113
  warn(
133
- `Expected .eslintrc.json from Next.js scaffolding but found ${eslintUsage.configType} instead`
114
+ `Expected .eslintrc.json from Next.js scaffolding but found ${eslintUsage.configType} instead`,
134
115
  );
135
116
  return false;
136
117
  }
137
118
 
138
- return await processArgument(ctx.args, "eslint-plugin" as keyof C3Args, {
119
+ return await inputPrompt({
139
120
  type: "confirm",
140
121
  question: "Do you want to use the next-on-pages eslint-plugin?",
141
122
  label: "eslint-plugin",
@@ -144,7 +125,10 @@ export const shouldInstallNextOnPagesEslintPlugin = async (
144
125
  };
145
126
 
146
127
  export const writeEslintrc = async (ctx: C3Context): Promise<void> => {
147
- const eslintConfig = readJSON(`${ctx.project.path}/.eslintrc.json`);
128
+ const eslintConfig = readJSON(`${ctx.project.path}/.eslintrc.json`) as {
129
+ plugins: string[];
130
+ extends: string | string[];
131
+ };
148
132
 
149
133
  eslintConfig.plugins ??= [];
150
134
  eslintConfig.plugins.push("eslint-plugin-next-on-pages");
@@ -175,13 +159,43 @@ const addDevDependencies = async (installEslintPlugin: boolean) => {
175
159
  export default {
176
160
  configVersion: 1,
177
161
  id: "next",
162
+ frameworkCli: "create-next-app",
178
163
  platform: "pages",
179
- displayName: "Next",
180
- devScript: "dev",
181
- previewScript: "pages:preview",
164
+ displayName: "Next.js",
182
165
  generate,
183
166
  configure,
184
- transformPackageJson: async () => {
167
+ copyFiles: {
168
+ async selectVariant(ctx) {
169
+ const isApp = probePaths([
170
+ `${ctx.project.path}/src/app`,
171
+ `${ctx.project.path}/app`,
172
+ ]);
173
+
174
+ const isTypescript = usesTypescript(ctx);
175
+
176
+ const dir = isApp ? "app" : "pages";
177
+ return `${dir}/${isTypescript ? "ts" : "js"}`;
178
+ },
179
+ destinationDir(ctx) {
180
+ const srcPath = probePaths([`${ctx.project.path}/src`]);
181
+ return srcPath ? "./src" : "./";
182
+ },
183
+ variants: {
184
+ "app/ts": {
185
+ path: "./app/ts",
186
+ },
187
+ "app/js": {
188
+ path: "./app/js",
189
+ },
190
+ "pages/ts": {
191
+ path: "./pages/ts",
192
+ },
193
+ "pages/js": {
194
+ path: "./pages/js",
195
+ },
196
+ },
197
+ },
198
+ transformPackageJson: async (_, ctx) => {
185
199
  const isNpm = npm === "npm";
186
200
  const isBun = npm === "bun";
187
201
  const isNpmOrBun = isNpm || isBun;
@@ -194,20 +208,16 @@ export default {
194
208
  return {
195
209
  scripts: {
196
210
  "pages:build": `${pmCommand} ${nextOnPagesCommand}`,
197
- "pages:preview": `${pagesBuildRunCommand} && wrangler pages dev .vercel/output/static ${await compatDateFlag()} --compatibility-flag=nodejs_compat`,
198
- "pages:deploy": `${pagesBuildRunCommand} && wrangler pages deploy .vercel/output/static`,
211
+ preview: `${pagesBuildRunCommand} && wrangler pages dev`,
212
+ deploy: `${pagesBuildRunCommand} && wrangler pages deploy`,
213
+ ...(usesTypescript(ctx) && {
214
+ "cf-typegen": `wrangler types --env-interface CloudflareEnv env.d.ts`,
215
+ }),
199
216
  },
200
217
  };
201
218
  },
202
- testFlags: [
203
- "--typescript",
204
- "--no-install",
205
- "--eslint",
206
- "--tailwind",
207
- "--src-dir",
208
- "--app",
209
- "--import-alias",
210
- "@/*",
211
- ],
219
+ devScript: "dev",
220
+ previewScript: "preview",
221
+ deployScript: "deploy",
212
222
  compatibilityFlags: ["nodejs_compat"],
213
223
  } as TemplateConfig;
@@ -0,0 +1,5 @@
1
+ // Generated by Wrangler
2
+ // by running `wrangler types --env-interface CloudflareEnv env.d.ts`
3
+
4
+ interface CloudflareEnv {
5
+ }
@@ -0,0 +1,23 @@
1
+ import { getRequestContext } from '@cloudflare/next-on-pages'
2
+
3
+ export const config = {
4
+ runtime: 'edge',
5
+ }
6
+
7
+ export default async function handler(req) {
8
+ let responseText = 'Hello World'
9
+
10
+ // In the edge runtime you can use Bindings that are available in your application
11
+ // (for more details see:
12
+ // - https://developers.cloudflare.com/pages/framework-guides/deploy-a-nextjs-site/#use-bindings-in-your-nextjs-application
13
+ // - https://developers.cloudflare.com/pages/functions/bindings/
14
+ // )
15
+ //
16
+ // KV Example:
17
+ // const myKv = getRequestContext().env.MY_KV_NAMESPACE
18
+ // await myKv.put('suffix', ' from a KV store!')
19
+ // const suffix = await myKv.get('suffix')
20
+ // responseText += suffix
21
+
22
+ return new Response(responseText)
23
+ }
@@ -0,0 +1,24 @@
1
+ import type { NextRequest } from 'next/server'
2
+ import { getRequestContext } from '@cloudflare/next-on-pages'
3
+
4
+ export const config = {
5
+ runtime: 'edge',
6
+ }
7
+
8
+ export default async function handler(req: NextRequest) {
9
+ let responseText = 'Hello World'
10
+
11
+ // In the edge runtime you can use Bindings that are available in your application
12
+ // (for more details see:
13
+ // - https://developers.cloudflare.com/pages/framework-guides/deploy-a-nextjs-site/#use-bindings-in-your-nextjs-application
14
+ // - https://developers.cloudflare.com/pages/functions/bindings/
15
+ // )
16
+ //
17
+ // KV Example:
18
+ // const myKv = getRequestContext().env.MY_KV_NAMESPACE
19
+ // await myKv.put('suffix', ' from a KV store!')
20
+ // const suffix = await myKv.get('suffix')
21
+ // responseText += suffix
22
+
23
+ return new Response(responseText)
24
+ }
@@ -0,0 +1,8 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "compatibility_date": "<TBD>",
4
+ "compatibility_flags": [
5
+ "nodejs_compat"
6
+ ],
7
+ "pages_build_output_dir": ".vercel/output/static"
8
+ }
@@ -1,59 +1,9 @@
1
- import { readFileSync } from "node:fs";
2
- import { resolve } from "node:path";
3
- import { logRaw } from "@cloudflare/cli";
4
- import { brandColor, dim } from "@cloudflare/cli/colors";
5
- import { spinner } from "@cloudflare/cli/interactive";
6
- import { runFrameworkGenerator } from "helpers/command";
7
- import { compatDateFlag, writeFile } from "helpers/files";
8
- import { detectPackageManager } from "helpers/packages";
9
- import type { TemplateConfig } from "../../src/templates";
10
- import type { C3Context } from "types";
1
+ import pages from "./pages/c3";
2
+ import workers from "./workers/c3";
3
+ import type { MultiPlatformTemplateConfig } from "../../src/templates";
11
4
 
12
- const { npm } = detectPackageManager();
13
-
14
- const generate = async (ctx: C3Context) => {
15
- const gitFlag = ctx.args.git ? `--gitInit` : `--no-gitInit`;
16
-
17
- await runFrameworkGenerator(ctx, [
18
- "init",
19
- ctx.project.name,
20
- "--packageManager",
21
- npm,
22
- gitFlag,
23
- ]);
24
-
25
- writeFile("./.node-version", "17");
26
-
27
- logRaw(""); // newline
28
- };
29
-
30
- const configure = async () => {
31
- const configFileName = "nuxt.config.ts";
32
- const configFilePath = resolve(configFileName);
33
- const s = spinner();
34
- s.start(`Updating \`${configFileName}\``);
35
- // Add the cloudflare preset into the configuration file.
36
- const originalConfigFile = readFileSync(configFilePath, "utf8");
37
- const updatedConfigFile = originalConfigFile.replace(
38
- "defineNuxtConfig({",
39
- "defineNuxtConfig({\n nitro: {\n preset: 'cloudflare-pages'\n },"
40
- );
41
- writeFile(configFilePath, updatedConfigFile);
42
- s.stop(`${brandColor(`updated`)} ${dim(`\`${configFileName}\``)}`);
43
- };
44
-
45
- const config: TemplateConfig = {
46
- configVersion: 1,
47
- id: "nuxt",
48
- platform: "pages",
5
+ const config: MultiPlatformTemplateConfig = {
49
6
  displayName: "Nuxt",
50
- generate,
51
- configure,
52
- transformPackageJson: async () => ({
53
- scripts: {
54
- "pages:dev": `wrangler pages dev ${await compatDateFlag()} --proxy 3000 -- ${npm} run dev`,
55
- "pages:deploy": `${npm} run build && wrangler pages deploy ./dist`,
56
- },
57
- }),
7
+ platformVariants: { pages, workers },
58
8
  };
59
9
  export default config;
@@ -0,0 +1,145 @@
1
+ import { logRaw } from "@cloudflare/cli";
2
+ import { brandColor, dim } from "@cloudflare/cli/colors";
3
+ import { spinner } from "@cloudflare/cli/interactive";
4
+ import { runFrameworkGenerator } from "frameworks/index";
5
+ import { mergeObjectProperties, transformFile } from "helpers/codemod";
6
+ import { getLatestTypesEntrypoint } from "helpers/compatDate";
7
+ import { readFile, writeFile } from "helpers/files";
8
+ import { detectPackageManager } from "helpers/packageManagers";
9
+ import { installPackages } from "helpers/packages";
10
+ import * as recast from "recast";
11
+ import type { TemplateConfig } from "../../../src/templates";
12
+ import type { C3Context } from "types";
13
+
14
+ const { npm, name: pm } = detectPackageManager();
15
+
16
+ const generate = async (ctx: C3Context) => {
17
+ const gitFlag = ctx.args.git ? `--gitInit` : `--no-gitInit`;
18
+
19
+ await runFrameworkGenerator(ctx, [
20
+ "init",
21
+ ctx.project.name,
22
+ "--packageManager",
23
+ npm,
24
+ gitFlag,
25
+ ]);
26
+
27
+ writeFile("./.node-version", "18");
28
+
29
+ logRaw(""); // newline
30
+ };
31
+
32
+ const configure = async (ctx: C3Context) => {
33
+ const packages = ["nitro-cloudflare-dev"];
34
+
35
+ // When using pnpm, explicitly add h3 package so the H3Event type declaration can be updated.
36
+ // Package managers other than pnpm will hoist the dependency, as will pnpm with `--shamefully-hoist`
37
+ if (pm === "pnpm") {
38
+ packages.push("h3");
39
+ }
40
+
41
+ await installPackages(packages, {
42
+ dev: true,
43
+ startText: "Installing nitro module `nitro-cloudflare-dev`",
44
+ doneText: `${brandColor("installed")} ${dim(`via \`${npm} install\``)}`,
45
+ });
46
+ updateNuxtConfig();
47
+
48
+ updateEnvTypes(ctx);
49
+ };
50
+
51
+ const updateEnvTypes = (ctx: C3Context) => {
52
+ const filepath = "env.d.ts";
53
+
54
+ const s = spinner();
55
+ s.start(`Updating ${filepath}`);
56
+
57
+ let file = readFile(filepath);
58
+
59
+ let typesEntrypoint = `@cloudflare/workers-types`;
60
+ const latestEntrypoint = getLatestTypesEntrypoint(ctx);
61
+ if (latestEntrypoint) {
62
+ typesEntrypoint += `/${latestEntrypoint}`;
63
+ }
64
+
65
+ // Replace placeholder with actual types entrypoint
66
+ file = file.replace("WORKERS_TYPES_ENTRYPOINT", typesEntrypoint);
67
+ writeFile("env.d.ts", file);
68
+
69
+ s.stop(`${brandColor(`updated`)} ${dim(`\`${filepath}\``)}`);
70
+ };
71
+
72
+ const updateNuxtConfig = () => {
73
+ const s = spinner();
74
+
75
+ const configFile = "nuxt.config.ts";
76
+ s.start(`Updating \`${configFile}\``);
77
+
78
+ const b = recast.types.builders;
79
+
80
+ const presetDef = b.objectProperty(
81
+ b.identifier("nitro"),
82
+ b.objectExpression([
83
+ b.objectProperty(
84
+ b.identifier("preset"),
85
+ b.stringLiteral("cloudflare-pages"),
86
+ ),
87
+ b.objectProperty(
88
+ b.identifier("cloudflare"),
89
+ b.objectExpression([
90
+ b.objectProperty(
91
+ b.identifier("deployConfig"),
92
+ b.booleanLiteral(true),
93
+ ),
94
+ b.objectProperty(b.identifier("nodeCompat"), b.booleanLiteral(true)),
95
+ ]),
96
+ ),
97
+ ]),
98
+ );
99
+
100
+ const moduleDef = b.objectProperty(
101
+ b.identifier("modules"),
102
+ b.arrayExpression([b.stringLiteral("nitro-cloudflare-dev")]),
103
+ );
104
+
105
+ transformFile(configFile, {
106
+ visitCallExpression: function (n) {
107
+ const callee = n.node.callee as recast.types.namedTypes.Identifier;
108
+ if (callee.name === "defineNuxtConfig") {
109
+ mergeObjectProperties(
110
+ n.node.arguments[0] as recast.types.namedTypes.ObjectExpression,
111
+ [presetDef, moduleDef],
112
+ );
113
+ }
114
+
115
+ return this.traverse(n);
116
+ },
117
+ });
118
+
119
+ s.stop(`${brandColor(`updated`)} ${dim(`\`${configFile}\``)}`);
120
+ };
121
+
122
+ const config: TemplateConfig = {
123
+ configVersion: 1,
124
+ id: "nuxt",
125
+ frameworkCli: "nuxi",
126
+ platform: "pages",
127
+ displayName: "Nuxt",
128
+ copyFiles: {
129
+ path: "./templates",
130
+ },
131
+ path: "templates/nuxt/pages",
132
+ generate,
133
+ configure,
134
+ transformPackageJson: async () => ({
135
+ scripts: {
136
+ deploy: `${npm} run build && wrangler pages deploy`,
137
+ preview: `${npm} run build && wrangler pages dev`,
138
+ "cf-typegen": `wrangler types`,
139
+ },
140
+ }),
141
+ devScript: "dev",
142
+ deployScript: "deploy",
143
+ previewScript: "preview",
144
+ };
145
+ export default config;
@@ -0,0 +1,14 @@
1
+ /// <reference types="WORKERS_TYPES_ENTRYPOINT" />
2
+
3
+ declare module "h3" {
4
+ interface H3EventContext {
5
+ cf: CfProperties;
6
+ cloudflare: {
7
+ request: Request;
8
+ env: Env;
9
+ context: ExecutionContext;
10
+ };
11
+ }
12
+ }
13
+
14
+ export {};
@@ -0,0 +1,4 @@
1
+ // Generated by Wrangler
2
+ // After adding bindings to `wrangler.jsonc`, regenerate this interface via `npm run cf-typegen`
3
+ interface Env {
4
+ }
@@ -0,0 +1,5 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "compatibility_date": "<TBD>",
4
+ "pages_build_output_dir": "./dist"
5
+ }