create-cloudflare 2.41.2 → 2.42.1

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 (57) hide show
  1. package/dist/cli.js +876 -861
  2. package/package.json +5 -5
  3. package/templates/astro/c3.ts +5 -93
  4. package/templates/astro/pages/c3.ts +98 -0
  5. package/{templates-experimental/astro → templates/astro/workers}/c3.ts +2 -2
  6. package/templates/astro/workers/templates/js/public/.assetsignore +2 -0
  7. package/templates/astro/workers/templates/ts/public/.assetsignore +2 -0
  8. package/templates/hello-world-durable-object/js/src/index.js +10 -9
  9. package/templates/hello-world-durable-object/js/wrangler.jsonc +1 -1
  10. package/templates/hello-world-durable-object/ts/src/index.ts +10 -9
  11. package/templates/hello-world-durable-object/ts/wrangler.jsonc +1 -1
  12. package/templates/hono/c3.ts +5 -66
  13. package/templates/hono/pages/c3.ts +42 -0
  14. package/templates/hono/pages/templates/src/index.tsx +12 -0
  15. package/templates/hono/{templates → pages/templates}/wrangler.jsonc +2 -1
  16. package/{templates-experimental/hono → templates/hono/workers}/c3.ts +2 -4
  17. package/templates/qwik/c3.ts +5 -144
  18. package/templates/qwik/pages/c3.ts +149 -0
  19. package/{templates-experimental/qwik → templates/qwik/workers}/c3.ts +2 -2
  20. package/templates/remix/c3.ts +5 -63
  21. package/templates/remix/pages/c3.ts +68 -0
  22. package/{templates-experimental/remix → templates/remix/workers}/c3.ts +2 -2
  23. package/templates/svelte/c3.ts +5 -154
  24. package/templates/svelte/pages/c3.ts +159 -0
  25. package/{templates-experimental/svelte → templates/svelte/workers}/c3.ts +3 -3
  26. package/templates/svelte/workers/templates/static/.assetsignore +2 -0
  27. package/templates/hono/snippets/appDeclaration.ts +0 -1
  28. package/templates-experimental/astro/templates/ts/public/.assetsignore +0 -4
  29. package/templates-experimental/qwik/templates/public/.assetsignore +0 -4
  30. package/templates-experimental/svelte/templates/static/.assetsignore +0 -4
  31. /package/templates/astro/{templates → pages/templates}/js/wrangler.jsonc +0 -0
  32. /package/{templates-experimental/astro → templates/astro/pages}/templates/ts/src/env.d.ts +0 -0
  33. /package/{templates-experimental/astro → templates/astro/pages}/templates/ts/worker-configuration.d.ts +0 -0
  34. /package/templates/astro/{templates → pages/templates}/ts/wrangler.jsonc +0 -0
  35. /package/{templates-experimental/astro → templates/astro/workers}/templates/js/wrangler.jsonc +0 -0
  36. /package/templates/astro/{templates → workers/templates}/ts/src/env.d.ts +0 -0
  37. /package/{templates-experimental/qwik/templates → templates/astro/workers/templates/ts}/worker-configuration.d.ts +0 -0
  38. /package/{templates-experimental/astro → templates/astro/workers}/templates/ts/wrangler.jsonc +0 -0
  39. /package/{templates-experimental/hono → templates/hono/pages}/templates/worker-configuration.d.ts +0 -0
  40. /package/{templates-experimental/hono → templates/hono/workers}/templates/public/index.html +0 -0
  41. /package/{templates-experimental/hono → templates/hono/workers}/templates/src/index.ts +0 -0
  42. /package/templates/hono/{templates → workers/templates}/worker-configuration.d.ts +0 -0
  43. /package/{templates-experimental/hono → templates/hono/workers}/templates/wrangler.jsonc +0 -0
  44. /package/{templates-experimental/qwik → templates/qwik/pages}/snippets/getPlatformProxy.ts +0 -0
  45. /package/templates/{astro/templates/ts → qwik/pages/templates}/worker-configuration.d.ts +0 -0
  46. /package/templates/qwik/{templates → pages/templates}/wrangler.jsonc +0 -0
  47. /package/templates/qwik/{snippets → workers/snippets}/getPlatformProxy.ts +0 -0
  48. /package/{templates-experimental/astro/templates/js → templates/qwik/workers/templates}/public/.assetsignore +0 -0
  49. /package/templates/qwik/{templates → workers/templates}/worker-configuration.d.ts +0 -0
  50. /package/{templates-experimental/qwik → templates/qwik/workers}/templates/wrangler.jsonc +0 -0
  51. /package/templates/remix/{templates → pages/templates}/worker-configuration.d.ts +0 -0
  52. /package/templates/remix/{templates → pages/templates}/wrangler.jsonc +0 -0
  53. /package/{templates-experimental/remix → templates/remix/workers}/templates/public/.assetsignore +0 -0
  54. /package/{templates-experimental/remix → templates/remix/workers}/templates/worker-configuration.d.ts +0 -0
  55. /package/{templates-experimental/remix → templates/remix/workers}/templates/wrangler.toml +0 -0
  56. /package/templates/svelte/{templates → pages/templates}/wrangler.jsonc +0 -0
  57. /package/{templates-experimental/svelte → templates/svelte/workers}/templates/wrangler.jsonc +0 -0
@@ -0,0 +1,149 @@
1
+ import { endSection } from "@cloudflare/cli";
2
+ import { brandColor } from "@cloudflare/cli/colors";
3
+ import { spinner } from "@cloudflare/cli/interactive";
4
+ import { runFrameworkGenerator } from "frameworks/index";
5
+ import { loadTemplateSnippets, transformFile } from "helpers/codemod";
6
+ import { quoteShellArgs, runCommand } from "helpers/command";
7
+ import { usesTypescript } from "helpers/files";
8
+ import { detectPackageManager } from "helpers/packageManagers";
9
+ import * as recast from "recast";
10
+ import type { TemplateConfig } from "../../../src/templates";
11
+ import type { C3Context } from "types";
12
+
13
+ const { npm, npx, name } = detectPackageManager();
14
+
15
+ const generate = async (ctx: C3Context) => {
16
+ await runFrameworkGenerator(ctx, ["playground", ctx.project.name]);
17
+ };
18
+
19
+ const configure = async (ctx: C3Context) => {
20
+ // Add the pages integration
21
+ // For some reason `pnpx qwik add` fails for qwik so we use `pnpm qwik add` instead.
22
+ const cmd = [name === "pnpm" ? npm : npx, "qwik", "add", "cloudflare-pages"];
23
+ endSection(`Running ${quoteShellArgs(cmd)}`);
24
+ await runCommand(cmd);
25
+
26
+ addBindingsProxy(ctx);
27
+ populateCloudflareEnv();
28
+ };
29
+
30
+ const addBindingsProxy = (ctx: C3Context) => {
31
+ // Qwik only has a typescript template atm.
32
+ // This check is an extra precaution
33
+ if (!usesTypescript(ctx)) {
34
+ return;
35
+ }
36
+
37
+ const s = spinner();
38
+ s.start("Updating `vite.config.ts`");
39
+
40
+ const snippets = loadTemplateSnippets(ctx);
41
+ const b = recast.types.builders;
42
+
43
+ transformFile("vite.config.ts", {
44
+ // Insert the env declaration after the last import (but before the rest of the body)
45
+ visitProgram: function (n) {
46
+ const lastImportIndex = n.node.body.findLastIndex(
47
+ (t) => t.type === "ImportDeclaration",
48
+ );
49
+ const lastImport = n.get("body", lastImportIndex);
50
+ lastImport.insertAfter(...snippets.getPlatformProxyTs);
51
+
52
+ return this.traverse(n);
53
+ },
54
+ // Pass the `platform` object from the declaration to the `qwikCity` plugin
55
+ visitCallExpression: function (n) {
56
+ const callee = n.node.callee as recast.types.namedTypes.Identifier;
57
+ if (callee.name !== "qwikCity") {
58
+ return this.traverse(n);
59
+ }
60
+
61
+ // The config object passed to `qwikCity`
62
+ const configArgument = n.node.arguments[0] as
63
+ | recast.types.namedTypes.ObjectExpression
64
+ | undefined;
65
+
66
+ const platformPropery = b.objectProperty.from({
67
+ key: b.identifier("platform"),
68
+ value: b.identifier("platform"),
69
+ shorthand: true,
70
+ });
71
+
72
+ if (!configArgument) {
73
+ n.node.arguments = [b.objectExpression([platformPropery])];
74
+
75
+ return false;
76
+ }
77
+
78
+ if (configArgument.type !== "ObjectExpression") {
79
+ throw new Error("Failed to update `vite.config.ts`");
80
+ }
81
+
82
+ // Add the `platform` object to the object
83
+ configArgument.properties.push(platformPropery);
84
+
85
+ return false;
86
+ },
87
+ });
88
+
89
+ s.stop(`${brandColor("updated")} \`vite.config.ts\``);
90
+ };
91
+
92
+ const populateCloudflareEnv = () => {
93
+ const entrypointPath = "src/entry.cloudflare-pages.tsx";
94
+
95
+ const s = spinner();
96
+ s.start(`Updating \`${entrypointPath}\``);
97
+
98
+ transformFile(entrypointPath, {
99
+ visitTSInterfaceDeclaration: function (n) {
100
+ const b = recast.types.builders;
101
+ const id = n.node.id as recast.types.namedTypes.Identifier;
102
+ if (id.name !== "QwikCityPlatform") {
103
+ this.traverse(n);
104
+ }
105
+
106
+ const newBody = [
107
+ ["env", "Env"],
108
+ // Qwik doesn't supply `cf` to the platform object. Should they do so, uncomment this
109
+ // ["cf", "CfProperties"],
110
+ ].map(([varName, type]) =>
111
+ b.tsPropertySignature(
112
+ b.identifier(varName),
113
+ b.tsTypeAnnotation(b.tsTypeReference(b.identifier(type))),
114
+ ),
115
+ );
116
+
117
+ n.node.body.body = newBody;
118
+
119
+ return false;
120
+ },
121
+ });
122
+
123
+ s.stop(`${brandColor("updated")} \`${entrypointPath}\``);
124
+ };
125
+
126
+ const config: TemplateConfig = {
127
+ configVersion: 1,
128
+ id: "qwik",
129
+ frameworkCli: "create-qwik",
130
+ displayName: "Qwik",
131
+ platform: "pages",
132
+ copyFiles: {
133
+ path: "./templates",
134
+ },
135
+ path: "templates/qwik/pages",
136
+ generate,
137
+ configure,
138
+ transformPackageJson: async () => ({
139
+ scripts: {
140
+ deploy: `${npm} run build && wrangler pages deploy`,
141
+ preview: `${npm} run build && wrangler pages dev`,
142
+ "cf-typegen": `wrangler types`,
143
+ },
144
+ }),
145
+ devScript: "dev",
146
+ deployScript: "deploy",
147
+ previewScript: "preview",
148
+ };
149
+ export default config;
@@ -7,7 +7,7 @@ import { quoteShellArgs, runCommand } from "helpers/command";
7
7
  import { removeFile, usesTypescript } from "helpers/files";
8
8
  import { detectPackageManager } from "helpers/packageManagers";
9
9
  import * as recast from "recast";
10
- import type { TemplateConfig } from "../../src/templates";
10
+ import type { TemplateConfig } from "../../../src/templates";
11
11
  import type { C3Context } from "types";
12
12
 
13
13
  const { npm, npx, name } = detectPackageManager();
@@ -137,7 +137,7 @@ const config: TemplateConfig = {
137
137
  copyFiles: {
138
138
  path: "./templates",
139
139
  },
140
- path: "templates-experimental/qwik",
140
+ path: "templates/qwik/workers",
141
141
  generate,
142
142
  configure,
143
143
  transformPackageJson: async () => ({
@@ -1,67 +1,9 @@
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 { transformFile } from "helpers/codemod";
6
- import { detectPackageManager } from "helpers/packageManagers";
7
- import type { TemplateConfig } from "../../src/templates";
8
- import type { C3Context } from "types";
1
+ import pages from "./pages/c3";
2
+ import workers from "./workers/c3";
3
+ import type { MultiPlatformTemplateConfig } from "../../src/templates";
9
4
 
10
- const { npm } = detectPackageManager();
11
-
12
- const generate = async (ctx: C3Context) => {
13
- await runFrameworkGenerator(ctx, [
14
- ctx.project.name,
15
- "--template",
16
- "https://github.com/remix-run/remix/tree/main/templates/cloudflare",
17
- ]);
18
-
19
- logRaw(""); // newline
20
- };
21
-
22
- const configure = async () => {
23
- const typeDefsPath = "load-context.ts";
24
-
25
- const s = spinner();
26
- s.start(`Updating \`${typeDefsPath}\``);
27
-
28
- // Remove the empty Env declaration from the template to allow the type from
29
- // worker-configuration.d.ts to take over
30
- transformFile(typeDefsPath, {
31
- visitTSInterfaceDeclaration(n) {
32
- if (n.node.id.type === "Identifier" && n.node.id.name !== "Env") {
33
- return this.traverse(n);
34
- }
35
-
36
- // Removes the node
37
- n.replace();
38
- return false;
39
- },
40
- });
41
-
42
- s.stop(`${brandColor("updated")} \`${dim(typeDefsPath)}\``);
43
- };
44
-
45
- const config: TemplateConfig = {
46
- configVersion: 1,
47
- id: "remix",
48
- frameworkCli: "create-remix",
49
- platform: "pages",
5
+ const config: MultiPlatformTemplateConfig = {
50
6
  displayName: "Remix",
51
- copyFiles: {
52
- path: "./templates",
53
- },
54
- generate,
55
- configure,
56
- transformPackageJson: async () => ({
57
- scripts: {
58
- deploy: `${npm} run build && wrangler pages deploy`,
59
- preview: `${npm} run build && wrangler pages dev`,
60
- "cf-typegen": `wrangler types`,
61
- },
62
- }),
63
- devScript: "dev",
64
- deployScript: "deploy",
65
- previewScript: "preview",
7
+ platformVariants: { pages, workers },
66
8
  };
67
9
  export default config;
@@ -0,0 +1,68 @@
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 { transformFile } from "helpers/codemod";
6
+ import { detectPackageManager } from "helpers/packageManagers";
7
+ import type { TemplateConfig } from "../../../src/templates";
8
+ import type { C3Context } from "types";
9
+
10
+ const { npm } = detectPackageManager();
11
+
12
+ const generate = async (ctx: C3Context) => {
13
+ await runFrameworkGenerator(ctx, [
14
+ ctx.project.name,
15
+ "--template",
16
+ "https://github.com/remix-run/remix/tree/main/templates/cloudflare",
17
+ ]);
18
+
19
+ logRaw(""); // newline
20
+ };
21
+
22
+ const configure = async () => {
23
+ const typeDefsPath = "load-context.ts";
24
+
25
+ const s = spinner();
26
+ s.start(`Updating \`${typeDefsPath}\``);
27
+
28
+ // Remove the empty Env declaration from the template to allow the type from
29
+ // worker-configuration.d.ts to take over
30
+ transformFile(typeDefsPath, {
31
+ visitTSInterfaceDeclaration(n) {
32
+ if (n.node.id.type === "Identifier" && n.node.id.name !== "Env") {
33
+ return this.traverse(n);
34
+ }
35
+
36
+ // Removes the node
37
+ n.replace();
38
+ return false;
39
+ },
40
+ });
41
+
42
+ s.stop(`${brandColor("updated")} \`${dim(typeDefsPath)}\``);
43
+ };
44
+
45
+ const config: TemplateConfig = {
46
+ configVersion: 1,
47
+ id: "remix",
48
+ frameworkCli: "create-remix",
49
+ platform: "pages",
50
+ displayName: "Remix",
51
+ copyFiles: {
52
+ path: "./templates",
53
+ },
54
+ path: "templates/remix/pages",
55
+ generate,
56
+ configure,
57
+ transformPackageJson: async () => ({
58
+ scripts: {
59
+ deploy: `${npm} run build && wrangler pages deploy`,
60
+ preview: `${npm} run build && wrangler pages dev`,
61
+ "cf-typegen": `wrangler types`,
62
+ },
63
+ }),
64
+ devScript: "dev",
65
+ deployScript: "deploy",
66
+ previewScript: "preview",
67
+ };
68
+ export default config;
@@ -3,7 +3,7 @@ import { brandColor, dim } from "@cloudflare/cli/colors";
3
3
  import { runFrameworkGenerator } from "frameworks/index";
4
4
  import { detectPackageManager } from "helpers/packageManagers";
5
5
  import { installPackages } from "helpers/packages";
6
- import type { TemplateConfig } from "../../src/templates";
6
+ import type { TemplateConfig } from "../../../src/templates";
7
7
  import type { C3Context } from "types";
8
8
 
9
9
  const { npm } = detectPackageManager();
@@ -35,7 +35,7 @@ const config: TemplateConfig = {
35
35
  copyFiles: {
36
36
  path: "./templates",
37
37
  },
38
- path: "templates-experimental/remix",
38
+ path: "templates/remix/workers",
39
39
  generate,
40
40
  configure,
41
41
  transformPackageJson: async () => ({
@@ -1,158 +1,9 @@
1
- import { existsSync } from "node:fs";
2
- import { platform } from "node:os";
3
- import { logRaw, updateStatus } from "@cloudflare/cli";
4
- import { blue, brandColor, dim } from "@cloudflare/cli/colors";
5
- import { runFrameworkGenerator } from "frameworks/index";
6
- import { transformFile } from "helpers/codemod";
7
- import { usesTypescript } 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, PackageJson } from "types";
1
+ import pages from "./pages/c3";
2
+ import workers from "./workers/c3";
3
+ import type { MultiPlatformTemplateConfig } from "../../src/templates";
13
4
 
14
- const { npm } = detectPackageManager();
15
-
16
- const generate = async (ctx: C3Context) => {
17
- await runFrameworkGenerator(ctx, ["create", ctx.project.name]);
18
-
19
- logRaw("");
20
- };
21
-
22
- const configure = async (ctx: C3Context) => {
23
- // Install the adapter
24
- const pkg = `@sveltejs/adapter-cloudflare`;
25
- await installPackages([pkg], {
26
- dev: true,
27
- startText: "Adding the Cloudflare Pages adapter",
28
- doneText: `${brandColor(`installed`)} ${dim(pkg)}`,
29
- });
30
-
31
- updateSvelteConfig();
32
- updatePlaywrightConfig(usesTypescript(ctx));
33
- updateTypeDefinitions(ctx);
34
- };
35
-
36
- const updateSvelteConfig = () => {
37
- // All we need to do is change the import statement in svelte.config.js
38
- updateStatus(`Changing adapter in ${blue("svelte.config.js")}`);
39
-
40
- transformFile("svelte.config.js", {
41
- visitImportDeclaration: function (n) {
42
- // importSource is the `x` in `import y from "x"`
43
- const importSource = n.value.source;
44
- if (importSource.value === "@sveltejs/adapter-auto") {
45
- importSource.value = "@sveltejs/adapter-cloudflare";
46
- }
47
-
48
- // stop traversing this node
49
- return false;
50
- },
51
- });
52
- };
53
-
54
- const updatePlaywrightConfig = (shouldUseTypescript: boolean) => {
55
- const filePath = `playwright.config.${shouldUseTypescript ? "ts" : "js"}`;
56
- if (!existsSync(filePath)) {
57
- return;
58
- }
59
-
60
- updateStatus(`Changing webServer port in ${blue(filePath)}`);
61
-
62
- transformFile(filePath, {
63
- visitObjectExpression: function (n) {
64
- const portProp = n.node.properties.find((prop) => {
65
- if (!("key" in prop) || !("name" in prop.key)) {
66
- return false;
67
- }
68
-
69
- return prop.key.name === "port";
70
- });
71
-
72
- if (!portProp || !("value" in portProp) || !("value" in portProp.value)) {
73
- return this.traverse(n);
74
- }
75
-
76
- portProp.value.value = 8788;
77
- return false;
78
- },
79
- });
80
- };
81
-
82
- const updateTypeDefinitions = (ctx: C3Context) => {
83
- if (!usesTypescript(ctx)) {
84
- return;
85
- }
86
-
87
- updateStatus(`Updating global type definitions in ${blue("app.d.ts")}`);
88
-
89
- const b = recast.types.builders;
90
-
91
- transformFile("src/app.d.ts", {
92
- visitTSModuleDeclaration(n) {
93
- if (n.value.id.name === "App" && n.node.body) {
94
- const moduleBlock = n.node
95
- .body as recast.types.namedTypes.TSModuleBlock;
96
-
97
- const platformInterface = b.tsInterfaceDeclaration(
98
- b.identifier("Platform"),
99
- b.tsInterfaceBody([
100
- b.tsPropertySignature(
101
- b.identifier("env"),
102
- b.tsTypeAnnotation(b.tsTypeReference(b.identifier("Env"))),
103
- ),
104
- b.tsPropertySignature(
105
- b.identifier("cf"),
106
- b.tsTypeAnnotation(
107
- b.tsTypeReference(b.identifier("CfProperties")),
108
- ),
109
- ),
110
- b.tsPropertySignature(
111
- b.identifier("ctx"),
112
- b.tsTypeAnnotation(
113
- b.tsTypeReference(b.identifier("ExecutionContext")),
114
- ),
115
- ),
116
- ]),
117
- );
118
-
119
- moduleBlock.body.unshift(platformInterface);
120
- }
121
-
122
- this.traverse(n);
123
- },
124
- });
125
- };
126
-
127
- const config: TemplateConfig = {
128
- configVersion: 1,
129
- id: "svelte",
130
- frameworkCli: "sv",
5
+ const config: MultiPlatformTemplateConfig = {
131
6
  displayName: "SvelteKit",
132
- platform: "pages",
133
- copyFiles: {
134
- path: "./templates",
135
- },
136
- generate,
137
- configure,
138
- transformPackageJson: async (original: PackageJson, ctx: C3Context) => {
139
- let scripts: Record<string, string> = {
140
- preview: `${npm} run build && wrangler pages dev`,
141
- deploy: `${npm} run build && wrangler pages deploy`,
142
- };
143
-
144
- if (usesTypescript(ctx)) {
145
- const mv = platform() === "win32" ? "move" : "mv";
146
- scripts = {
147
- ...scripts,
148
- "cf-typegen": `wrangler types && ${mv} worker-configuration.d.ts src/`,
149
- };
150
- }
151
-
152
- return { scripts };
153
- },
154
- devScript: "dev",
155
- deployScript: "deploy",
156
- previewScript: "preview",
7
+ platformVariants: { pages, workers },
157
8
  };
158
9
  export default config;
@@ -0,0 +1,159 @@
1
+ import { existsSync } from "node:fs";
2
+ import { platform } from "node:os";
3
+ import { logRaw, updateStatus } from "@cloudflare/cli";
4
+ import { blue, brandColor, dim } from "@cloudflare/cli/colors";
5
+ import { runFrameworkGenerator } from "frameworks/index";
6
+ import { transformFile } from "helpers/codemod";
7
+ import { usesTypescript } 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, PackageJson } from "types";
13
+
14
+ const { npm } = detectPackageManager();
15
+
16
+ const generate = async (ctx: C3Context) => {
17
+ await runFrameworkGenerator(ctx, ["create", ctx.project.name]);
18
+
19
+ logRaw("");
20
+ };
21
+
22
+ const configure = async (ctx: C3Context) => {
23
+ // Install the adapter
24
+ const pkg = `@sveltejs/adapter-cloudflare`;
25
+ await installPackages([pkg], {
26
+ dev: true,
27
+ startText: "Adding the Cloudflare Pages adapter",
28
+ doneText: `${brandColor(`installed`)} ${dim(pkg)}`,
29
+ });
30
+
31
+ updateSvelteConfig();
32
+ updatePlaywrightConfig(usesTypescript(ctx));
33
+ updateTypeDefinitions(ctx);
34
+ };
35
+
36
+ const updateSvelteConfig = () => {
37
+ // All we need to do is change the import statement in svelte.config.js
38
+ updateStatus(`Changing adapter in ${blue("svelte.config.js")}`);
39
+
40
+ transformFile("svelte.config.js", {
41
+ visitImportDeclaration: function (n) {
42
+ // importSource is the `x` in `import y from "x"`
43
+ const importSource = n.value.source;
44
+ if (importSource.value === "@sveltejs/adapter-auto") {
45
+ importSource.value = "@sveltejs/adapter-cloudflare";
46
+ }
47
+
48
+ // stop traversing this node
49
+ return false;
50
+ },
51
+ });
52
+ };
53
+
54
+ const updatePlaywrightConfig = (shouldUseTypescript: boolean) => {
55
+ const filePath = `playwright.config.${shouldUseTypescript ? "ts" : "js"}`;
56
+ if (!existsSync(filePath)) {
57
+ return;
58
+ }
59
+
60
+ updateStatus(`Changing webServer port in ${blue(filePath)}`);
61
+
62
+ transformFile(filePath, {
63
+ visitObjectExpression: function (n) {
64
+ const portProp = n.node.properties.find((prop) => {
65
+ if (!("key" in prop) || !("name" in prop.key)) {
66
+ return false;
67
+ }
68
+
69
+ return prop.key.name === "port";
70
+ });
71
+
72
+ if (!portProp || !("value" in portProp) || !("value" in portProp.value)) {
73
+ return this.traverse(n);
74
+ }
75
+
76
+ portProp.value.value = 8788;
77
+ return false;
78
+ },
79
+ });
80
+ };
81
+
82
+ const updateTypeDefinitions = (ctx: C3Context) => {
83
+ if (!usesTypescript(ctx)) {
84
+ return;
85
+ }
86
+
87
+ updateStatus(`Updating global type definitions in ${blue("app.d.ts")}`);
88
+
89
+ const b = recast.types.builders;
90
+
91
+ transformFile("src/app.d.ts", {
92
+ visitTSModuleDeclaration(n) {
93
+ if (n.value.id.name === "App" && n.node.body) {
94
+ const moduleBlock = n.node
95
+ .body as recast.types.namedTypes.TSModuleBlock;
96
+
97
+ const platformInterface = b.tsInterfaceDeclaration(
98
+ b.identifier("Platform"),
99
+ b.tsInterfaceBody([
100
+ b.tsPropertySignature(
101
+ b.identifier("env"),
102
+ b.tsTypeAnnotation(b.tsTypeReference(b.identifier("Env"))),
103
+ ),
104
+ b.tsPropertySignature(
105
+ b.identifier("cf"),
106
+ b.tsTypeAnnotation(
107
+ b.tsTypeReference(b.identifier("CfProperties")),
108
+ ),
109
+ ),
110
+ b.tsPropertySignature(
111
+ b.identifier("ctx"),
112
+ b.tsTypeAnnotation(
113
+ b.tsTypeReference(b.identifier("ExecutionContext")),
114
+ ),
115
+ ),
116
+ ]),
117
+ );
118
+
119
+ moduleBlock.body.unshift(platformInterface);
120
+ }
121
+
122
+ this.traverse(n);
123
+ },
124
+ });
125
+ };
126
+
127
+ const config: TemplateConfig = {
128
+ configVersion: 1,
129
+ id: "svelte",
130
+ frameworkCli: "sv",
131
+ displayName: "SvelteKit",
132
+ platform: "pages",
133
+ copyFiles: {
134
+ path: "./templates",
135
+ },
136
+ path: "templates/svelte/pages",
137
+ generate,
138
+ configure,
139
+ transformPackageJson: async (original: PackageJson, ctx: C3Context) => {
140
+ let scripts: Record<string, string> = {
141
+ preview: `${npm} run build && wrangler pages dev`,
142
+ deploy: `${npm} run build && wrangler pages deploy`,
143
+ };
144
+
145
+ if (usesTypescript(ctx)) {
146
+ const mv = platform() === "win32" ? "move" : "mv";
147
+ scripts = {
148
+ ...scripts,
149
+ "cf-typegen": `wrangler types && ${mv} worker-configuration.d.ts src/`,
150
+ };
151
+ }
152
+
153
+ return { scripts };
154
+ },
155
+ devScript: "dev",
156
+ deployScript: "deploy",
157
+ previewScript: "preview",
158
+ };
159
+ export default config;
@@ -7,7 +7,7 @@ import { usesTypescript } from "helpers/files";
7
7
  import { detectPackageManager } from "helpers/packageManagers";
8
8
  import { installPackages } from "helpers/packages";
9
9
  import * as recast from "recast";
10
- import type { TemplateConfig } from "../../src/templates";
10
+ import type { TemplateConfig } from "../../../src/templates";
11
11
  import type { C3Context, PackageJson } from "types";
12
12
 
13
13
  const { npm } = detectPackageManager();
@@ -23,7 +23,7 @@ const configure = async (ctx: C3Context) => {
23
23
  const pkg = `@sveltejs/adapter-cloudflare`;
24
24
  await installPackages([pkg], {
25
25
  dev: true,
26
- startText: "Adding the Cloudflare Pages adapter",
26
+ startText: "Adding the Cloudflare adapter",
27
27
  doneText: `${brandColor(`installed`)} ${dim(pkg)}`,
28
28
  });
29
29
 
@@ -103,7 +103,7 @@ const config: TemplateConfig = {
103
103
  copyFiles: {
104
104
  path: "./templates",
105
105
  },
106
- path: "templates-experimental/svelte",
106
+ path: "templates/svelte/workers",
107
107
  generate,
108
108
  configure,
109
109
  transformPackageJson: async (original: PackageJson, ctx: C3Context) => {
@@ -0,0 +1,2 @@
1
+ _worker.js
2
+ _routes.json
@@ -1 +0,0 @@
1
- new Hono<{ Bindings: CloudflareBindings }>()
@@ -1,4 +0,0 @@
1
- _worker.js
2
- _routes.json
3
- _headers
4
- _redirects
@@ -1,4 +0,0 @@
1
- _worker.js
2
- _routes.json
3
- _headers
4
- _redirects