create-cloudflare 2.41.1 → 2.42.0
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 +797 -790
- 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/c3.ts +3 -2
- package/{templates-experimental → templates}/hello-world-assets-only/c3.ts +4 -3
- package/templates/hello-world-durable-object/c3.ts +2 -2
- 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-experimental → templates}/hello-world-durable-object-with-assets/c3.ts +3 -3
- package/{templates-experimental → templates}/hello-world-with-assets/c3.ts +3 -4
- 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/react/workers/js/src/assets/Cloudflare_Logo.svg +7 -5
- 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/js/public/.assetsignore +0 -4
- package/templates-experimental/astro/templates/ts/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/hello-world-with-assets → 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 → templates}/hello-world-assets-only/templates/package.json +0 -0
- /package/{templates-experimental → templates}/hello-world-assets-only/templates/public/index.html +0 -0
- /package/{templates-experimental → templates}/hello-world-assets-only/templates/wrangler.jsonc +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/.editorconfig +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/.prettierrc +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/__dot__gitignore +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/package.json +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/public/index.html +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/src/index.js +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/wrangler.jsonc +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/.editorconfig +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/.prettierrc +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/__dot__gitignore +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/package.json +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/public/index.html +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/src/index.ts +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/tsconfig.json +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/worker-configuration.d.ts +0 -0
- /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/wrangler.jsonc +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/js/.editorconfig +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/js/.prettierrc +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/js/__dot__gitignore +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/js/package.json +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/js/public/index.html +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/js/src/index.js +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/js/test/index.spec.js +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/js/vitest.config.js +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/js/wrangler.jsonc +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/py/__dot__gitignore +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/py/package.json +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/py/public/index.html +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/py/src/entry.py +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/py/wrangler.jsonc +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/ts/.editorconfig +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/ts/.prettierrc +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/ts/__dot__gitignore +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/ts/package.json +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/ts/public/index.html +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/ts/src/index.ts +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/ts/test/index.spec.ts +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/ts/test/tsconfig.json +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/ts/tsconfig.json +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/ts/vitest.config.mts +0 -0
- /package/templates/{astro/templates → hello-world-with-assets}/ts/worker-configuration.d.ts +0 -0
- /package/{templates-experimental → templates}/hello-world-with-assets/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/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
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 }>()
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
/package/{templates-experimental/astro → templates/astro/workers}/templates/js/wrangler.jsonc
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
/package/{templates-experimental/astro → templates/astro/workers}/templates/ts/wrangler.jsonc
RENAMED
|
File without changes
|
/package/{templates-experimental → templates}/hello-world-assets-only/templates/package.json
RENAMED
|
File without changes
|
/package/{templates-experimental → templates}/hello-world-assets-only/templates/public/index.html
RENAMED
|
File without changes
|
/package/{templates-experimental → templates}/hello-world-assets-only/templates/wrangler.jsonc
RENAMED
|
File without changes
|
|
File without changes
|
/package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/.prettierrc
RENAMED
|
File without changes
|
|
File without changes
|
/package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/package.json
RENAMED
|
File without changes
|
|
File without changes
|
/package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/src/index.js
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
/package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/.prettierrc
RENAMED
|
File without changes
|
|
File without changes
|
/package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/package.json
RENAMED
|
File without changes
|
|
File without changes
|
/package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/src/index.ts
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|