create-cloudflare 0.0.0-dba3f2158 → 0.0.0-dbbeb23c7

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 (152) hide show
  1. package/dist/cli.js +19878 -18259
  2. package/dist/tsconfig.tsbuildinfo +1 -1
  3. package/package.json +11 -9
  4. package/templates/angular/c3.ts +5 -110
  5. package/templates/angular/pages/c3.ts +134 -0
  6. package/{templates-experimental/angular → templates/angular/workers}/c3.ts +25 -7
  7. package/templates/astro/c3.ts +5 -93
  8. package/templates/astro/pages/c3.ts +98 -0
  9. package/{templates-experimental/astro → templates/astro/workers}/c3.ts +2 -2
  10. package/templates/astro/workers/templates/js/public/.assetsignore +2 -0
  11. package/templates/astro/workers/templates/ts/public/.assetsignore +2 -0
  12. package/templates/docusaurus/c3.ts +5 -24
  13. package/templates/docusaurus/pages/c3.ts +30 -0
  14. package/{templates-experimental/docusaurus → templates/docusaurus/workers}/c3.ts +3 -2
  15. package/templates/gatsby/c3.ts +5 -45
  16. package/templates/gatsby/pages/c3.ts +50 -0
  17. package/{templates-experimental/gatsby → templates/gatsby/workers}/c3.ts +2 -2
  18. package/templates/hello-world/c3.ts +20 -3
  19. package/templates/hello-world/js/package.json +2 -2
  20. package/templates/hello-world/py/.python-version +1 -0
  21. package/templates/hello-world/py/README.md +23 -0
  22. package/templates/hello-world/py/pyproject.toml +9 -0
  23. package/templates/hello-world/py/uv.lock +22 -0
  24. package/templates/hello-world/ts/package.json +2 -2
  25. package/{templates-experimental → templates}/hello-world-assets-only/c3.ts +4 -3
  26. package/templates/hello-world-durable-object/c3.ts +2 -2
  27. package/templates/hello-world-durable-object/js/src/index.js +10 -9
  28. package/templates/hello-world-durable-object/js/wrangler.jsonc +1 -1
  29. package/templates/hello-world-durable-object/ts/src/index.ts +10 -9
  30. package/templates/hello-world-durable-object/ts/wrangler.jsonc +1 -1
  31. package/{templates-experimental → templates}/hello-world-durable-object-with-assets/c3.ts +3 -3
  32. package/{templates-experimental → templates}/hello-world-with-assets/c3.ts +3 -4
  33. package/{templates-experimental → templates}/hello-world-with-assets/js/package.json +2 -2
  34. package/{templates-experimental → templates}/hello-world-with-assets/ts/package.json +2 -2
  35. package/templates/hono/c3.ts +1 -0
  36. package/templates/next/c3.ts +4 -1
  37. package/templates/nuxt/c3.ts +5 -130
  38. package/templates/nuxt/pages/c3.ts +145 -0
  39. package/templates/nuxt/{templates → pages/templates}/wrangler.jsonc +0 -3
  40. package/{templates-experimental/nuxt → templates/nuxt/workers}/c3.ts +12 -2
  41. package/templates/pre-existing/c3.ts +1 -1
  42. package/templates/qwik/c3.ts +3 -2
  43. package/templates/react/c3.ts +5 -57
  44. package/templates/react/pages/c3.ts +62 -0
  45. package/templates/react/workers/c3.ts +183 -0
  46. package/templates/react/workers/js/api/index.js +13 -0
  47. package/templates/react/workers/js/src/App.css +45 -0
  48. package/templates/react/workers/js/src/App.jsx +58 -0
  49. package/templates/react/workers/js/src/assets/Cloudflare_Logo.svg +53 -0
  50. package/templates/react/workers/js/wrangler.jsonc +9 -0
  51. package/templates/react/workers/ts/api/index.ts +13 -0
  52. package/templates/react/workers/ts/src/App.css +45 -0
  53. package/templates/react/workers/ts/src/App.tsx +58 -0
  54. package/templates/react/workers/ts/src/assets/Cloudflare_Logo.svg +51 -0
  55. package/templates/react/workers/ts/tsconfig.worker.json +8 -0
  56. package/templates/react/workers/ts/worker-configuration.d.ts +5 -0
  57. package/templates/react/workers/ts/wrangler.jsonc +9 -0
  58. package/templates/remix/c3.ts +5 -63
  59. package/templates/remix/pages/c3.ts +68 -0
  60. package/{templates-experimental/remix → templates/remix/workers}/c3.ts +2 -2
  61. package/templates/vue/c3.ts +5 -25
  62. package/{templates-experimental/vue → templates/vue/pages}/c3.ts +5 -8
  63. package/templates/vue/workers/c3.ts +98 -0
  64. package/templates/vue/workers/js/server/index.js +13 -0
  65. package/templates/vue/workers/js/src/App.vue +107 -0
  66. package/templates/vue/workers/js/src/components/HelloWorld.vue +47 -0
  67. package/templates/vue/workers/js/vite.config.js +21 -0
  68. package/templates/vue/workers/js/wrangler.jsonc +12 -0
  69. package/templates/vue/workers/ts/server/index.ts +13 -0
  70. package/templates/vue/workers/ts/src/App.vue +107 -0
  71. package/templates/vue/workers/ts/src/components/HelloWorld.vue +44 -0
  72. package/templates/vue/workers/ts/tsconfig.worker.json +8 -0
  73. package/templates/vue/workers/ts/vite.config.ts +21 -0
  74. package/templates/vue/workers/ts/worker-configuration.d.ts +6 -0
  75. package/templates/vue/workers/ts/wrangler.jsonc +12 -0
  76. package/templates-experimental/hono/c3.ts +1 -0
  77. package/templates-experimental/next/c3.ts +11 -20
  78. package/templates-experimental/next/templates/open-next.config.ts +5 -27
  79. package/templates-experimental/next/templates/wrangler.jsonc +0 -1
  80. package/templates-experimental/qwik/c3.ts +3 -2
  81. package/templates/pre-existing/js/wrangler.jsonc +0 -5
  82. package/templates-experimental/astro/templates/js/public/.assetsignore +0 -4
  83. package/templates-experimental/astro/templates/ts/public/.assetsignore +0 -4
  84. package/templates-experimental/vue/templates/wrangler.jsonc +0 -10
  85. /package/templates/angular/{templates → pages/templates}/src/_routes.json +0 -0
  86. /package/{templates-experimental/angular → templates/angular/pages}/templates/src/server.ts +0 -0
  87. /package/templates/angular/{templates → pages/templates}/tools/copy-files.mjs +0 -0
  88. /package/templates/angular/{templates → workers/templates}/src/server.ts +0 -0
  89. /package/{templates-experimental/angular → templates/angular/workers}/templates/wrangler.jsonc +0 -0
  90. /package/templates/astro/{templates → pages/templates}/js/wrangler.jsonc +0 -0
  91. /package/{templates-experimental/astro → templates/astro/pages}/templates/ts/src/env.d.ts +0 -0
  92. /package/{templates-experimental/astro → templates/astro/pages}/templates/ts/worker-configuration.d.ts +0 -0
  93. /package/templates/astro/{templates → pages/templates}/ts/wrangler.jsonc +0 -0
  94. /package/{templates-experimental/astro → templates/astro/workers}/templates/js/wrangler.jsonc +0 -0
  95. /package/templates/astro/{templates → workers/templates}/ts/src/env.d.ts +0 -0
  96. /package/{templates-experimental/hello-world-with-assets → templates/astro/workers/templates}/ts/worker-configuration.d.ts +0 -0
  97. /package/{templates-experimental/astro → templates/astro/workers}/templates/ts/wrangler.jsonc +0 -0
  98. /package/{templates-experimental/docusaurus → templates/docusaurus/workers}/templates/wrangler.jsonc +0 -0
  99. /package/{templates-experimental/gatsby → templates/gatsby/workers}/templates/wrangler.jsonc +0 -0
  100. /package/{templates-experimental → templates}/hello-world-assets-only/templates/package.json +0 -0
  101. /package/{templates-experimental → templates}/hello-world-assets-only/templates/public/index.html +0 -0
  102. /package/{templates-experimental → templates}/hello-world-assets-only/templates/wrangler.jsonc +0 -0
  103. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/.editorconfig +0 -0
  104. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/.prettierrc +0 -0
  105. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/__dot__gitignore +0 -0
  106. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/package.json +0 -0
  107. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/public/index.html +0 -0
  108. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/src/index.js +0 -0
  109. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/wrangler.jsonc +0 -0
  110. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/.editorconfig +0 -0
  111. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/.prettierrc +0 -0
  112. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/__dot__gitignore +0 -0
  113. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/package.json +0 -0
  114. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/public/index.html +0 -0
  115. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/src/index.ts +0 -0
  116. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/tsconfig.json +0 -0
  117. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/worker-configuration.d.ts +0 -0
  118. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/wrangler.jsonc +0 -0
  119. /package/{templates-experimental → templates}/hello-world-with-assets/js/.editorconfig +0 -0
  120. /package/{templates-experimental → templates}/hello-world-with-assets/js/.prettierrc +0 -0
  121. /package/{templates-experimental → templates}/hello-world-with-assets/js/__dot__gitignore +0 -0
  122. /package/{templates-experimental → templates}/hello-world-with-assets/js/public/index.html +0 -0
  123. /package/{templates-experimental → templates}/hello-world-with-assets/js/src/index.js +0 -0
  124. /package/{templates-experimental → templates}/hello-world-with-assets/js/test/index.spec.js +0 -0
  125. /package/{templates-experimental → templates}/hello-world-with-assets/js/vitest.config.js +0 -0
  126. /package/{templates-experimental → templates}/hello-world-with-assets/js/wrangler.jsonc +0 -0
  127. /package/{templates-experimental → templates}/hello-world-with-assets/py/__dot__gitignore +0 -0
  128. /package/{templates-experimental → templates}/hello-world-with-assets/py/package.json +0 -0
  129. /package/{templates-experimental → templates}/hello-world-with-assets/py/public/index.html +0 -0
  130. /package/{templates-experimental → templates}/hello-world-with-assets/py/src/entry.py +0 -0
  131. /package/{templates-experimental → templates}/hello-world-with-assets/py/wrangler.jsonc +0 -0
  132. /package/{templates-experimental → templates}/hello-world-with-assets/ts/.editorconfig +0 -0
  133. /package/{templates-experimental → templates}/hello-world-with-assets/ts/.prettierrc +0 -0
  134. /package/{templates-experimental → templates}/hello-world-with-assets/ts/__dot__gitignore +0 -0
  135. /package/{templates-experimental → templates}/hello-world-with-assets/ts/public/index.html +0 -0
  136. /package/{templates-experimental → templates}/hello-world-with-assets/ts/src/index.ts +0 -0
  137. /package/{templates-experimental → templates}/hello-world-with-assets/ts/test/index.spec.ts +0 -0
  138. /package/{templates-experimental → templates}/hello-world-with-assets/ts/test/tsconfig.json +0 -0
  139. /package/{templates-experimental → templates}/hello-world-with-assets/ts/tsconfig.json +0 -0
  140. /package/{templates-experimental → templates}/hello-world-with-assets/ts/vitest.config.mts +0 -0
  141. /package/{templates-experimental/nuxt/templates → templates/hello-world-with-assets/ts}/worker-configuration.d.ts +0 -0
  142. /package/{templates-experimental → templates}/hello-world-with-assets/ts/wrangler.jsonc +0 -0
  143. /package/{templates-experimental/nuxt → templates/nuxt/pages}/templates/env.d.ts +0 -0
  144. /package/templates/{astro/templates/ts → nuxt/pages/templates}/worker-configuration.d.ts +0 -0
  145. /package/templates/nuxt/{templates → workers/templates}/env.d.ts +0 -0
  146. /package/templates/nuxt/{templates → workers/templates}/worker-configuration.d.ts +0 -0
  147. /package/{templates-experimental/nuxt → templates/nuxt/workers}/templates/wrangler.jsonc +0 -0
  148. /package/templates/remix/{templates → pages/templates}/worker-configuration.d.ts +0 -0
  149. /package/templates/remix/{templates → pages/templates}/wrangler.jsonc +0 -0
  150. /package/{templates-experimental/remix → templates/remix/workers}/templates/public/.assetsignore +0 -0
  151. /package/{templates-experimental/remix → templates/remix/workers}/templates/worker-configuration.d.ts +0 -0
  152. /package/{templates-experimental/remix → templates/remix/workers}/templates/wrangler.toml +0 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "create-cloudflare",
3
- "version": "0.0.0-dba3f2158",
3
+ "version": "0.0.0-dbbeb23c7",
4
4
  "description": "A CLI for creating and deploying new applications to Cloudflare.",
5
5
  "keywords": [
6
6
  "cloudflare",
@@ -30,7 +30,7 @@
30
30
  "@babel/parser": "^7.21.3",
31
31
  "@babel/types": "^7.21.4",
32
32
  "@clack/prompts": "^0.6.3",
33
- "@cloudflare/workers-types": "^4.20250204.0",
33
+ "@cloudflare/workers-types": "^4.20250317.0",
34
34
  "@iarna/toml": "^3.0.0",
35
35
  "@types/command-exists": "^1.2.0",
36
36
  "@types/cross-spawn": "^6.0.2",
@@ -38,7 +38,7 @@
38
38
  "@types/degit": "^2.8.6",
39
39
  "@types/dns2": "^2.0.3",
40
40
  "@types/esprima": "^4.0.3",
41
- "@types/node": "^18.19.71",
41
+ "@types/node": "^18.19.75",
42
42
  "@types/semver": "^7.5.1",
43
43
  "@types/which-pm-runs": "^1.0.0",
44
44
  "@types/yargs": "^17.0.22",
@@ -46,12 +46,13 @@
46
46
  "@typescript-eslint/parser": "^6.9.0",
47
47
  "chalk": "^5.2.0",
48
48
  "command-exists": "^1.2.9",
49
+ "comment-json": "^4.2.5",
49
50
  "cross-spawn": "^7.0.3",
50
51
  "deepmerge": "^4.3.1",
51
52
  "degit": "^2.8.4",
52
53
  "dns2": "^2.1.0",
53
54
  "dotenv": "^16.0.0",
54
- "esbuild": "0.17.19",
55
+ "esbuild": "0.24.2",
55
56
  "execa": "^7.1.1",
56
57
  "glob": "^10.3.3",
57
58
  "haikunator": "^2.1.2",
@@ -59,21 +60,22 @@
59
60
  "magic-string": "^0.30.5",
60
61
  "open": "^8.4.0",
61
62
  "recast": "^0.22.0",
62
- "semver": "^7.5.1",
63
+ "semver": "^7.7.1",
63
64
  "typescript": "^5.7.2",
64
- "undici": "^5.28.4",
65
+ "undici": "^5.28.5",
65
66
  "vite": "^5.4.14",
66
67
  "vite-tsconfig-paths": "^4.0.8",
67
- "vitest": "~2.1.9",
68
+ "vitest": "~3.0.8",
68
69
  "which-pm-runs": "^1.1.0",
69
70
  "wrap-ansi": "^9.0.0",
70
71
  "xdg-app-paths": "^8.3.0",
71
72
  "yargs": "^17.7.2",
72
73
  "@cloudflare/cli": "1.1.1",
74
+ "@cloudflare/mock-npm-registry": "0.0.0",
73
75
  "@cloudflare/eslint-config-worker": "1.1.0",
76
+ "@cloudflare/vite-plugin": "0.0.0-dbbeb23c7",
74
77
  "@cloudflare/workers-tsconfig": "0.0.0",
75
- "@cloudflare/mock-npm-registry": "0.0.0",
76
- "wrangler": "0.0.0-dba3f2158"
78
+ "wrangler": "0.0.0-dbbeb23c7"
77
79
  },
78
80
  "engines": {
79
81
  "node": ">=18.14.1"
@@ -1,114 +1,9 @@
1
- import { resolve } from "node:path";
2
- import { logRaw } from "@cloudflare/cli";
3
- import { brandColor, dim } from "@cloudflare/cli/colors";
4
- import { spinner } from "@cloudflare/cli/interactive";
5
- import { runFrameworkGenerator } from "frameworks/index";
6
- import { compatDateFlag } from "helpers/compatDate";
7
- import { readFile, readJSON, writeFile } from "helpers/files";
8
- import { detectPackageManager } from "helpers/packageManagers";
9
- import { installPackages } from "helpers/packages";
10
- import type { TemplateConfig } from "../../src/templates";
11
- import type { C3Context } from "types";
1
+ import pages from "./pages/c3";
2
+ import workers from "./workers/c3";
3
+ import type { MultiPlatformTemplateConfig } from "../../src/templates";
12
4
 
13
- const { npm } = detectPackageManager();
14
-
15
- const generate = async (ctx: C3Context) => {
16
- await runFrameworkGenerator(ctx, [
17
- ctx.project.name,
18
- "--ssr",
19
- "--server-routing" /** Dev Preview API */,
20
- ]);
21
- logRaw("");
22
- };
23
-
24
- const configure = async (ctx: C3Context) => {
25
- updateAngularJson(ctx);
26
- await updateAppCode();
27
- await installCFWorker();
28
- };
29
-
30
- async function installCFWorker() {
31
- await installPackages(["xhr2"], {
32
- dev: true,
33
- startText: "Installing additional dependencies",
34
- doneText: `${brandColor("installed")} ${dim(`via \`${npm} install\``)}`,
35
- });
36
- }
37
- async function updateAppCode() {
38
- const s = spinner();
39
- s.start(`Updating application code`);
40
-
41
- // Update an app config file to:
42
- // - add the `provideHttpClient(withFetch())` call to enable `fetch` usage in `HttpClient`
43
- const appConfigPath = "src/app/app.config.ts";
44
- const appConfig = readFile(resolve(appConfigPath));
45
- const newAppConfig =
46
- "import { provideHttpClient, withFetch } from '@angular/common/http';\n" +
47
- appConfig.replace(
48
- "providers: [",
49
- "providers: [provideHttpClient(withFetch()), ",
50
- );
51
- writeFile(resolve(appConfigPath), newAppConfig);
52
- s.stop(`${brandColor(`updated`)} ${dim(appConfigPath)}`);
53
-
54
- // Update an app server routes file to:
55
- const appServerRoutesPath = "src/app/app.routes.server.ts";
56
- const appRoutes = readFile(resolve(appServerRoutesPath));
57
- const newAppRoutes = appRoutes.replace(
58
- "RenderMode.Prerender",
59
- "RenderMode.Server",
60
- );
61
- writeFile(resolve(appServerRoutesPath), newAppRoutes);
62
- s.stop(`${brandColor(`updated`)} ${dim(appServerRoutesPath)}`);
63
-
64
- // Remove unwanted dependencies
65
- s.start(`Updating package.json`);
66
- const packageJsonPath = resolve("package.json");
67
- const packageManifest = readJSON(packageJsonPath);
68
-
69
- delete packageManifest["dependencies"]["express"];
70
- delete packageManifest["devDependencies"]["@types/express"];
71
-
72
- writeFile(packageJsonPath, JSON.stringify(packageManifest, null, 2));
73
- s.stop(`${brandColor(`updated`)} ${dim(`\`package.json\``)}`);
74
- }
75
-
76
- function updateAngularJson(ctx: C3Context) {
77
- const s = spinner();
78
- s.start(`Updating angular.json config`);
79
- const angularJson = readJSON(resolve("angular.json"));
80
- // Update builder
81
- const architectSection = angularJson.projects[ctx.project.name].architect;
82
- architectSection.build.options.outputPath = "dist";
83
- architectSection.build.options.outputMode = "server";
84
- architectSection.build.options.ssr.experimentalPlatform = "neutral";
85
- architectSection.build.options.assets.push("src/_routes.json");
86
-
87
- writeFile(resolve("angular.json"), JSON.stringify(angularJson, null, 2));
88
- s.stop(`${brandColor(`updated`)} ${dim(`\`angular.json\``)}`);
89
- }
90
-
91
- const config: TemplateConfig = {
92
- configVersion: 1,
93
- id: "angular",
94
- frameworkCli: "@angular/create",
5
+ const config: MultiPlatformTemplateConfig = {
95
6
  displayName: "Angular",
96
- platform: "pages",
97
- copyFiles: {
98
- path: "./templates",
99
- },
100
- devScript: "start",
101
- deployScript: "deploy",
102
- previewScript: "start",
103
- generate,
104
- configure,
105
- transformPackageJson: async () => ({
106
- scripts: {
107
- start: `${npm} run build && wrangler pages dev dist/cloudflare ${await compatDateFlag()}`,
108
- build: `ng build && ${npm} run process`,
109
- process: "node ./tools/copy-files.mjs",
110
- deploy: `${npm} run build && wrangler pages deploy dist/cloudflare`,
111
- },
112
- }),
7
+ platformVariants: { pages, workers },
113
8
  };
114
9
  export default config;
@@ -0,0 +1,134 @@
1
+ import { resolve } from "node:path";
2
+ import { logRaw } from "@cloudflare/cli";
3
+ import { brandColor, dim } from "@cloudflare/cli/colors";
4
+ import { spinner } from "@cloudflare/cli/interactive";
5
+ import { runFrameworkGenerator } from "frameworks/index";
6
+ import { compatDateFlag } from "helpers/compatDate";
7
+ import { readFile, readJSON, writeFile } from "helpers/files";
8
+ import { detectPackageManager } from "helpers/packageManagers";
9
+ import { installPackages } from "helpers/packages";
10
+ import type { TemplateConfig } from "../../../src/templates";
11
+ import type { C3Context, PackageJson } from "types";
12
+
13
+ const { npm } = detectPackageManager();
14
+
15
+ const generate = async (ctx: C3Context) => {
16
+ await runFrameworkGenerator(ctx, [
17
+ ctx.project.name,
18
+ "--ssr",
19
+ "--server-routing" /** Dev Preview API */,
20
+ ]);
21
+ logRaw("");
22
+ };
23
+
24
+ const configure = async (ctx: C3Context) => {
25
+ updateAngularJson(ctx);
26
+ await updateAppCode();
27
+ await installCFWorker();
28
+ };
29
+
30
+ async function installCFWorker() {
31
+ await installPackages(["xhr2"], {
32
+ dev: true,
33
+ startText: "Installing additional dependencies",
34
+ doneText: `${brandColor("installed")} ${dim(`via \`${npm} install\``)}`,
35
+ });
36
+ }
37
+ async function updateAppCode() {
38
+ const s = spinner();
39
+ s.start(`Updating application code`);
40
+
41
+ // Update an app config file to:
42
+ // - add the `provideHttpClient(withFetch())` call to enable `fetch` usage in `HttpClient`
43
+ const appConfigPath = "src/app/app.config.ts";
44
+ const appConfig = readFile(resolve(appConfigPath));
45
+ const newAppConfig =
46
+ "import { provideHttpClient, withFetch } from '@angular/common/http';\n" +
47
+ appConfig.replace(
48
+ "providers: [",
49
+ "providers: [provideHttpClient(withFetch()), ",
50
+ );
51
+ writeFile(resolve(appConfigPath), newAppConfig);
52
+ s.stop(`${brandColor(`updated`)} ${dim(appConfigPath)}`);
53
+
54
+ // Update an app server routes file to:
55
+ const appServerRoutesPath = "src/app/app.routes.server.ts";
56
+ const appRoutes = readFile(resolve(appServerRoutesPath));
57
+ const newAppRoutes = appRoutes.replace(
58
+ "RenderMode.Prerender",
59
+ "RenderMode.Server",
60
+ );
61
+ writeFile(resolve(appServerRoutesPath), newAppRoutes);
62
+ s.stop(`${brandColor(`updated`)} ${dim(appServerRoutesPath)}`);
63
+
64
+ // Remove unwanted dependencies
65
+ s.start(`Updating package.json`);
66
+ const packageJsonPath = resolve("package.json");
67
+ const packageManifest = readJSON(packageJsonPath) as PackageJson;
68
+
69
+ delete packageManifest["dependencies"]?.["express"];
70
+ delete packageManifest["devDependencies"]?.["@types/express"];
71
+
72
+ writeFile(packageJsonPath, JSON.stringify(packageManifest, null, 2));
73
+ s.stop(`${brandColor(`updated`)} ${dim(`\`package.json\``)}`);
74
+ }
75
+
76
+ function updateAngularJson(ctx: C3Context) {
77
+ const s = spinner();
78
+ s.start(`Updating angular.json config`);
79
+ const angularJson = readJSON("angular.json") as AngularJson;
80
+
81
+ // Update builder
82
+ const architectSection = angularJson.projects[ctx.project.name].architect;
83
+ architectSection.build.options.outputPath = "dist";
84
+ architectSection.build.options.outputMode = "server";
85
+ architectSection.build.options.ssr.experimentalPlatform = "neutral";
86
+ architectSection.build.options.assets.push("src/_routes.json");
87
+
88
+ writeFile(resolve("angular.json"), JSON.stringify(angularJson, null, 2));
89
+ s.stop(`${brandColor(`updated`)} ${dim(`\`angular.json\``)}`);
90
+ }
91
+
92
+ const config: TemplateConfig = {
93
+ configVersion: 1,
94
+ id: "angular",
95
+ frameworkCli: "@angular/create",
96
+ displayName: "Angular",
97
+ platform: "pages",
98
+ copyFiles: {
99
+ path: "./templates",
100
+ },
101
+ path: "templates/angular/pages",
102
+ devScript: "start",
103
+ deployScript: "deploy",
104
+ previewScript: "start",
105
+ generate,
106
+ configure,
107
+ transformPackageJson: async () => ({
108
+ scripts: {
109
+ start: `${npm} run build && wrangler pages dev dist/cloudflare ${await compatDateFlag()}`,
110
+ build: `ng build && ${npm} run process`,
111
+ process: "node ./tools/copy-files.mjs",
112
+ deploy: `${npm} run build && wrangler pages deploy dist/cloudflare`,
113
+ },
114
+ }),
115
+ };
116
+ export default config;
117
+
118
+ type AngularJson = {
119
+ projects: Record<
120
+ string,
121
+ {
122
+ architect: {
123
+ build: {
124
+ options: {
125
+ outputPath: string;
126
+ outputMode: string;
127
+ ssr: Record<string, unknown>;
128
+ assets: string[];
129
+ };
130
+ };
131
+ };
132
+ }
133
+ >;
134
+ };
@@ -6,8 +6,8 @@ import { runFrameworkGenerator } from "frameworks/index";
6
6
  import { readFile, readJSON, writeFile } from "helpers/files";
7
7
  import { detectPackageManager } from "helpers/packageManagers";
8
8
  import { installPackages } from "helpers/packages";
9
- import type { TemplateConfig } from "../../src/templates";
10
- import type { C3Context } from "types";
9
+ import type { TemplateConfig } from "../../../src/templates";
10
+ import type { C3Context, PackageJson } from "types";
11
11
 
12
12
  const { npm } = detectPackageManager();
13
13
 
@@ -63,10 +63,10 @@ async function updateAppCode() {
63
63
  // Remove unwanted dependencies
64
64
  s.start(`Updating package.json`);
65
65
  const packageJsonPath = resolve("package.json");
66
- const packageManifest = readJSON(packageJsonPath);
66
+ const packageManifest = readJSON(packageJsonPath) as PackageJson;
67
67
 
68
- delete packageManifest["dependencies"]["express"];
69
- delete packageManifest["devDependencies"]["@types/express"];
68
+ delete packageManifest["dependencies"]?.["express"];
69
+ delete packageManifest["devDependencies"]?.["@types/express"];
70
70
 
71
71
  writeFile(packageJsonPath, JSON.stringify(packageManifest, null, 2));
72
72
  s.stop(`${brandColor(`updated`)} ${dim(`\`package.json\``)}`);
@@ -75,7 +75,7 @@ async function updateAppCode() {
75
75
  function updateAngularJson(ctx: C3Context) {
76
76
  const s = spinner();
77
77
  s.start(`Updating angular.json config`);
78
- const angularJson = readJSON(resolve("angular.json"));
78
+ const angularJson = readJSON(resolve("angular.json")) as AngularJson;
79
79
  // Update builder
80
80
  const architectSection = angularJson.projects[ctx.project.name].architect;
81
81
  architectSection.build.options.outputPath = "dist";
@@ -95,7 +95,7 @@ const config: TemplateConfig = {
95
95
  copyFiles: {
96
96
  path: "./templates",
97
97
  },
98
- path: "templates-experimental/angular",
98
+ path: "templates/angular/workers",
99
99
  devScript: "start",
100
100
  deployScript: "deploy",
101
101
  previewScript: "start",
@@ -110,3 +110,21 @@ const config: TemplateConfig = {
110
110
  }),
111
111
  };
112
112
  export default config;
113
+
114
+ type AngularJson = {
115
+ projects: Record<
116
+ string,
117
+ {
118
+ architect: {
119
+ build: {
120
+ options: {
121
+ outputPath: string;
122
+ outputMode: string;
123
+ ssr: Record<string, unknown>;
124
+ assets: string[];
125
+ };
126
+ };
127
+ };
128
+ }
129
+ >;
130
+ };
@@ -1,97 +1,9 @@
1
- import { logRaw, updateStatus } from "@cloudflare/cli";
2
- import { blue, brandColor, dim } from "@cloudflare/cli/colors";
3
- import { runFrameworkGenerator } from "frameworks/index";
4
- import { transformFile } from "helpers/codemod";
5
- import { runCommand } from "helpers/command";
6
- import { usesTypescript } from "helpers/files";
7
- import { detectPackageManager } from "helpers/packageManagers";
8
- import * as recast from "recast";
9
- import type { TemplateConfig } from "../../src/templates";
10
- import type { C3Context, PackageJson } 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 { npx } = detectPackageManager();
13
-
14
- const generate = async (ctx: C3Context) => {
15
- await runFrameworkGenerator(ctx, [ctx.project.name, "--no-install"]);
16
-
17
- logRaw(""); // newline
18
- };
19
-
20
- const configure = async () => {
21
- await runCommand([npx, "astro", "add", "cloudflare", "-y"], {
22
- silent: true,
23
- startText: "Installing adapter",
24
- doneText: `${brandColor("installed")} ${dim(
25
- `via \`${npx} astro add cloudflare\``,
26
- )}`,
27
- });
28
-
29
- updateAstroConfig();
30
- };
31
-
32
- const updateAstroConfig = () => {
33
- const filePath = "astro.config.mjs";
34
-
35
- updateStatus(`Updating configuration in ${blue(filePath)}`);
36
-
37
- transformFile(filePath, {
38
- visitCallExpression: function (n) {
39
- const callee = n.node.callee as recast.types.namedTypes.Identifier;
40
- if (callee.name !== "cloudflare") {
41
- return this.traverse(n);
42
- }
43
-
44
- const b = recast.types.builders;
45
- n.node.arguments = [
46
- b.objectExpression([
47
- b.objectProperty(
48
- b.identifier("platformProxy"),
49
- b.objectExpression([
50
- b.objectProperty(b.identifier("enabled"), b.booleanLiteral(true)),
51
- ]),
52
- ),
53
- ]),
54
- ];
55
-
56
- return false;
57
- },
58
- });
59
- };
60
-
61
- const config: TemplateConfig = {
62
- configVersion: 1,
63
- id: "astro",
64
- frameworkCli: "create-astro",
65
- platform: "pages",
5
+ const config: MultiPlatformTemplateConfig = {
66
6
  displayName: "Astro",
67
- copyFiles: {
68
- async selectVariant(ctx) {
69
- // Note: this `selectVariant` function should not be needed
70
- // this is just a quick workaround until
71
- // https://github.com/cloudflare/workers-sdk/issues/7495
72
- // is resolved
73
- return usesTypescript(ctx) ? "ts" : "js";
74
- },
75
- variants: {
76
- js: {
77
- path: "./templates/js",
78
- },
79
- ts: {
80
- path: "./templates/ts",
81
- },
82
- },
83
- },
84
- devScript: "dev",
85
- deployScript: "deploy",
86
- previewScript: "preview",
87
- generate,
88
- configure,
89
- transformPackageJson: async (pkgJson: PackageJson, ctx: C3Context) => ({
90
- scripts: {
91
- deploy: `astro build && wrangler pages deploy`,
92
- preview: `astro build && wrangler pages dev`,
93
- ...(usesTypescript(ctx) && { "cf-typegen": `wrangler types` }),
94
- },
95
- }),
7
+ platformVariants: { pages, workers },
96
8
  };
97
9
  export default config;
@@ -0,0 +1,98 @@
1
+ import { logRaw, updateStatus } from "@cloudflare/cli";
2
+ import { blue, brandColor, dim } from "@cloudflare/cli/colors";
3
+ import { runFrameworkGenerator } from "frameworks/index";
4
+ import { transformFile } from "helpers/codemod";
5
+ import { runCommand } from "helpers/command";
6
+ import { usesTypescript } from "helpers/files";
7
+ import { detectPackageManager } from "helpers/packageManagers";
8
+ import * as recast from "recast";
9
+ import type { TemplateConfig } from "../../../src/templates";
10
+ import type { C3Context, PackageJson } from "types";
11
+
12
+ const { npx } = detectPackageManager();
13
+
14
+ const generate = async (ctx: C3Context) => {
15
+ await runFrameworkGenerator(ctx, [ctx.project.name, "--no-install"]);
16
+
17
+ logRaw(""); // newline
18
+ };
19
+
20
+ const configure = async () => {
21
+ await runCommand([npx, "astro", "add", "cloudflare", "-y"], {
22
+ silent: true,
23
+ startText: "Installing adapter",
24
+ doneText: `${brandColor("installed")} ${dim(
25
+ `via \`${npx} astro add cloudflare\``,
26
+ )}`,
27
+ });
28
+
29
+ updateAstroConfig();
30
+ };
31
+
32
+ const updateAstroConfig = () => {
33
+ const filePath = "astro.config.mjs";
34
+
35
+ updateStatus(`Updating configuration in ${blue(filePath)}`);
36
+
37
+ transformFile(filePath, {
38
+ visitCallExpression: function (n) {
39
+ const callee = n.node.callee as recast.types.namedTypes.Identifier;
40
+ if (callee.name !== "cloudflare") {
41
+ return this.traverse(n);
42
+ }
43
+
44
+ const b = recast.types.builders;
45
+ n.node.arguments = [
46
+ b.objectExpression([
47
+ b.objectProperty(
48
+ b.identifier("platformProxy"),
49
+ b.objectExpression([
50
+ b.objectProperty(b.identifier("enabled"), b.booleanLiteral(true)),
51
+ ]),
52
+ ),
53
+ ]),
54
+ ];
55
+
56
+ return false;
57
+ },
58
+ });
59
+ };
60
+
61
+ const config: TemplateConfig = {
62
+ configVersion: 1,
63
+ id: "astro",
64
+ frameworkCli: "create-astro",
65
+ platform: "pages",
66
+ displayName: "Astro",
67
+ path: "templates/astro/pages",
68
+ copyFiles: {
69
+ async selectVariant(ctx) {
70
+ // Note: this `selectVariant` function should not be needed
71
+ // this is just a quick workaround until
72
+ // https://github.com/cloudflare/workers-sdk/issues/7495
73
+ // is resolved
74
+ return usesTypescript(ctx) ? "ts" : "js";
75
+ },
76
+ variants: {
77
+ js: {
78
+ path: "./templates/js",
79
+ },
80
+ ts: {
81
+ path: "./templates/ts",
82
+ },
83
+ },
84
+ },
85
+ devScript: "dev",
86
+ deployScript: "deploy",
87
+ previewScript: "preview",
88
+ generate,
89
+ configure,
90
+ transformPackageJson: async (pkgJson: PackageJson, ctx: C3Context) => ({
91
+ scripts: {
92
+ deploy: `astro build && wrangler pages deploy`,
93
+ preview: `astro build && wrangler pages dev`,
94
+ ...(usesTypescript(ctx) && { "cf-typegen": `wrangler types` }),
95
+ },
96
+ }),
97
+ };
98
+ export default config;
@@ -6,7 +6,7 @@ import { runCommand } from "helpers/command";
6
6
  import { usesTypescript } from "helpers/files";
7
7
  import { detectPackageManager } from "helpers/packageManagers";
8
8
  import * as recast from "recast";
9
- import type { TemplateConfig } from "../../src/templates";
9
+ import type { TemplateConfig } from "../../../src/templates";
10
10
  import type { C3Context, PackageJson } from "types";
11
11
 
12
12
  const { npx } = detectPackageManager();
@@ -84,7 +84,7 @@ const config: TemplateConfig = {
84
84
  devScript: "dev",
85
85
  deployScript: "deploy",
86
86
  previewScript: "preview",
87
- path: "templates-experimental/astro",
87
+ path: "templates/astro/workers",
88
88
  generate,
89
89
  configure,
90
90
  transformPackageJson: async (pkgJson: PackageJson, ctx: C3Context) => ({
@@ -0,0 +1,2 @@
1
+ _worker.js
2
+ _routes.json
@@ -0,0 +1,2 @@
1
+ _worker.js
2
+ _routes.json
@@ -1,28 +1,9 @@
1
- import { runFrameworkGenerator } from "frameworks/index";
2
- import { detectPackageManager } from "helpers/packageManagers";
3
- import type { TemplateConfig } from "../../src/templates";
4
- import type { C3Context } from "types";
1
+ import pages from "./pages/c3";
2
+ import workers from "./workers/c3";
3
+ import type { MultiPlatformTemplateConfig } from "../../src/templates";
5
4
 
6
- const { npm } = detectPackageManager();
7
-
8
- const generate = async (ctx: C3Context) => {
9
- await runFrameworkGenerator(ctx, [ctx.project.name, "classic"]);
10
- };
11
-
12
- const config: TemplateConfig = {
13
- configVersion: 1,
14
- id: "docusaurus",
15
- frameworkCli: "create-docusaurus",
16
- platform: "pages",
5
+ const config: MultiPlatformTemplateConfig = {
17
6
  displayName: "Docusaurus",
18
- generate,
19
- transformPackageJson: async () => ({
20
- scripts: {
21
- preview: `${npm} run build && wrangler pages dev ./build`,
22
- deploy: `${npm} run build && wrangler pages deploy ./build`,
23
- },
24
- }),
25
- devScript: "preview",
26
- deployScript: "deploy",
7
+ platformVariants: { pages, workers },
27
8
  };
28
9
  export default config;
@@ -0,0 +1,30 @@
1
+ import { runFrameworkGenerator } from "frameworks/index";
2
+ import { detectPackageManager } from "helpers/packageManagers";
3
+ import type { TemplateConfig } from "../../../src/templates";
4
+ import type { C3Context } from "types";
5
+
6
+ const { npm } = detectPackageManager();
7
+
8
+ const generate = async (ctx: C3Context) => {
9
+ await runFrameworkGenerator(ctx, [ctx.project.name, "classic"]);
10
+ };
11
+
12
+ const config: TemplateConfig = {
13
+ configVersion: 1,
14
+ id: "docusaurus",
15
+ frameworkCli: "create-docusaurus",
16
+ platform: "pages",
17
+ displayName: "Docusaurus",
18
+ path: "templates/docusaurus/pages",
19
+ generate,
20
+ transformPackageJson: async () => ({
21
+ scripts: {
22
+ preview: `${npm} run build && wrangler pages dev ./build`,
23
+ deploy: `${npm} run build && wrangler pages deploy ./build`,
24
+ },
25
+ }),
26
+ devScript: "preview",
27
+ deployScript: "deploy",
28
+ previewScript: "preview",
29
+ };
30
+ export default config;