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.
- package/dist/cli.js +876 -861
- package/package.json +5 -5
- package/templates/astro/c3.ts +5 -93
- package/templates/astro/pages/c3.ts +98 -0
- package/{templates-experimental/astro → templates/astro/workers}/c3.ts +2 -2
- package/templates/astro/workers/templates/js/public/.assetsignore +2 -0
- package/templates/astro/workers/templates/ts/public/.assetsignore +2 -0
- package/templates/hello-world-durable-object/js/src/index.js +10 -9
- package/templates/hello-world-durable-object/js/wrangler.jsonc +1 -1
- package/templates/hello-world-durable-object/ts/src/index.ts +10 -9
- package/templates/hello-world-durable-object/ts/wrangler.jsonc +1 -1
- package/templates/hono/c3.ts +5 -66
- package/templates/hono/pages/c3.ts +42 -0
- package/templates/hono/pages/templates/src/index.tsx +12 -0
- package/templates/hono/{templates → pages/templates}/wrangler.jsonc +2 -1
- package/{templates-experimental/hono → templates/hono/workers}/c3.ts +2 -4
- package/templates/qwik/c3.ts +5 -144
- package/templates/qwik/pages/c3.ts +149 -0
- package/{templates-experimental/qwik → templates/qwik/workers}/c3.ts +2 -2
- package/templates/remix/c3.ts +5 -63
- package/templates/remix/pages/c3.ts +68 -0
- package/{templates-experimental/remix → templates/remix/workers}/c3.ts +2 -2
- package/templates/svelte/c3.ts +5 -154
- package/templates/svelte/pages/c3.ts +159 -0
- package/{templates-experimental/svelte → templates/svelte/workers}/c3.ts +3 -3
- package/templates/svelte/workers/templates/static/.assetsignore +2 -0
- package/templates/hono/snippets/appDeclaration.ts +0 -1
- package/templates-experimental/astro/templates/ts/public/.assetsignore +0 -4
- package/templates-experimental/qwik/templates/public/.assetsignore +0 -4
- package/templates-experimental/svelte/templates/static/.assetsignore +0 -4
- /package/templates/astro/{templates → pages/templates}/js/wrangler.jsonc +0 -0
- /package/{templates-experimental/astro → templates/astro/pages}/templates/ts/src/env.d.ts +0 -0
- /package/{templates-experimental/astro → templates/astro/pages}/templates/ts/worker-configuration.d.ts +0 -0
- /package/templates/astro/{templates → pages/templates}/ts/wrangler.jsonc +0 -0
- /package/{templates-experimental/astro → templates/astro/workers}/templates/js/wrangler.jsonc +0 -0
- /package/templates/astro/{templates → workers/templates}/ts/src/env.d.ts +0 -0
- /package/{templates-experimental/qwik/templates → templates/astro/workers/templates/ts}/worker-configuration.d.ts +0 -0
- /package/{templates-experimental/astro → templates/astro/workers}/templates/ts/wrangler.jsonc +0 -0
- /package/{templates-experimental/hono → templates/hono/pages}/templates/worker-configuration.d.ts +0 -0
- /package/{templates-experimental/hono → templates/hono/workers}/templates/public/index.html +0 -0
- /package/{templates-experimental/hono → templates/hono/workers}/templates/src/index.ts +0 -0
- /package/templates/hono/{templates → workers/templates}/worker-configuration.d.ts +0 -0
- /package/{templates-experimental/hono → templates/hono/workers}/templates/wrangler.jsonc +0 -0
- /package/{templates-experimental/qwik → templates/qwik/pages}/snippets/getPlatformProxy.ts +0 -0
- /package/templates/{astro/templates/ts → qwik/pages/templates}/worker-configuration.d.ts +0 -0
- /package/templates/qwik/{templates → pages/templates}/wrangler.jsonc +0 -0
- /package/templates/qwik/{snippets → workers/snippets}/getPlatformProxy.ts +0 -0
- /package/{templates-experimental/astro/templates/js → templates/qwik/workers/templates}/public/.assetsignore +0 -0
- /package/templates/qwik/{templates → workers/templates}/worker-configuration.d.ts +0 -0
- /package/{templates-experimental/qwik → templates/qwik/workers}/templates/wrangler.jsonc +0 -0
- /package/templates/remix/{templates → pages/templates}/worker-configuration.d.ts +0 -0
- /package/templates/remix/{templates → pages/templates}/wrangler.jsonc +0 -0
- /package/{templates-experimental/remix → templates/remix/workers}/templates/public/.assetsignore +0 -0
- /package/{templates-experimental/remix → templates/remix/workers}/templates/worker-configuration.d.ts +0 -0
- /package/{templates-experimental/remix → templates/remix/workers}/templates/wrangler.toml +0 -0
- /package/templates/svelte/{templates → pages/templates}/wrangler.jsonc +0 -0
- /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 "
|
|
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
|
|
140
|
+
path: "templates/qwik/workers",
|
|
141
141
|
generate,
|
|
142
142
|
configure,
|
|
143
143
|
transformPackageJson: async () => ({
|
package/templates/remix/c3.ts
CHANGED
|
@@ -1,67 +1,9 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
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
|
|
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
|
-
|
|
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 "
|
|
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
|
|
38
|
+
path: "templates/remix/workers",
|
|
39
39
|
generate,
|
|
40
40
|
configure,
|
|
41
41
|
transformPackageJson: async () => ({
|
package/templates/svelte/c3.ts
CHANGED
|
@@ -1,158 +1,9 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
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
|
|
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
|
-
|
|
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 "
|
|
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
|
|
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
|
|
106
|
+
path: "templates/svelte/workers",
|
|
107
107
|
generate,
|
|
108
108
|
configure,
|
|
109
109
|
transformPackageJson: async (original: PackageJson, ctx: C3Context) => {
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
new Hono<{ Bindings: CloudflareBindings }>()
|