create-cloudflare 0.0.0-dcb1ea6b → 0.0.0-dcce2ecf2

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 (292) hide show
  1. package/README.md +1 -1
  2. package/dist/cli.js +73202 -53869
  3. package/dist/tsconfig.tsbuildinfo +1 -0
  4. package/package.json +49 -30
  5. package/templates/analog/c3.ts +135 -0
  6. package/templates/analog/snippets/devBindingsModule.ts +7 -0
  7. package/templates/analog/templates/env.d.ts +13 -0
  8. package/templates/analog/templates/src/dev-bindings.ts +18 -0
  9. package/templates/analog/templates/worker-configuration.d.ts +4 -0
  10. package/templates/analog/templates/wrangler.jsonc +5 -0
  11. package/templates/angular/c3.ts +9 -0
  12. package/templates/angular/pages/c3.ts +135 -0
  13. package/templates/angular/pages/templates/src/server.ts +15 -0
  14. package/templates/angular/pages/templates/tools/copy-files.mjs +15 -0
  15. package/templates/angular/workers/c3.ts +130 -0
  16. package/templates/angular/workers/templates/src/server.ts +15 -0
  17. package/templates/angular/workers/templates/wrangler.jsonc +12 -0
  18. package/templates/astro/c3.ts +9 -0
  19. package/templates/astro/pages/c3.ts +99 -0
  20. package/templates/astro/pages/templates/js/wrangler.jsonc +8 -0
  21. package/templates/astro/pages/templates/ts/src/env.d.ts +5 -0
  22. package/templates/astro/pages/templates/ts/worker-configuration.d.ts +4 -0
  23. package/templates/astro/pages/templates/ts/wrangler.jsonc +8 -0
  24. package/templates/astro/workers/c3.ts +98 -0
  25. package/templates/astro/workers/templates/js/public/.assetsignore +2 -0
  26. package/templates/astro/workers/templates/js/wrangler.jsonc +15 -0
  27. package/templates/astro/workers/templates/ts/public/.assetsignore +2 -0
  28. package/templates/astro/workers/templates/ts/src/env.d.ts +5 -0
  29. package/templates/astro/workers/templates/ts/worker-configuration.d.ts +4 -0
  30. package/templates/astro/workers/templates/ts/wrangler.jsonc +15 -0
  31. package/templates/common/c3.ts +23 -0
  32. package/templates/common/js/.editorconfig +0 -1
  33. package/templates/common/js/package.json +1 -1
  34. package/templates/common/js/wrangler.jsonc +8 -0
  35. package/templates/common/ts/.editorconfig +0 -1
  36. package/templates/common/ts/package.json +4 -4
  37. package/templates/common/ts/src/ab-test.ts +2 -2
  38. package/templates/common/ts/src/index.ts +5 -2
  39. package/templates/common/ts/src/proxy.ts +2 -2
  40. package/templates/common/ts/src/redirect.ts +2 -2
  41. package/templates/common/ts/tsconfig.json +37 -95
  42. package/templates/common/ts/worker-configuration.d.ts +2 -14
  43. package/templates/common/ts/wrangler.jsonc +8 -0
  44. package/templates/docusaurus/c3.ts +9 -0
  45. package/templates/docusaurus/pages/c3.ts +31 -0
  46. package/templates/docusaurus/workers/c3.ts +33 -0
  47. package/templates/docusaurus/workers/templates/wrangler.jsonc +10 -0
  48. package/templates/gatsby/c3.ts +9 -0
  49. package/templates/gatsby/pages/c3.ts +51 -0
  50. package/templates/gatsby/workers/c3.ts +53 -0
  51. package/templates/gatsby/workers/templates/wrangler.jsonc +10 -0
  52. package/templates/hello-world/c3.ts +37 -0
  53. package/templates/hello-world/js/.editorconfig +0 -1
  54. package/templates/hello-world/js/package.json +5 -2
  55. package/templates/hello-world/js/test/index.spec.js +20 -0
  56. package/templates/hello-world/js/vitest.config.js +11 -0
  57. package/templates/hello-world/js/wrangler.jsonc +8 -0
  58. package/templates/hello-world/py/.python-version +1 -0
  59. package/templates/hello-world/py/README.md +23 -0
  60. package/templates/hello-world/py/__dot__gitignore +68 -0
  61. package/templates/hello-world/py/package.json +13 -0
  62. package/templates/hello-world/py/pyproject.toml +9 -0
  63. package/templates/hello-world/py/src/entry.py +4 -0
  64. package/templates/hello-world/py/uv.lock +22 -0
  65. package/templates/hello-world/py/wrangler.jsonc +9 -0
  66. package/templates/hello-world/ts/.editorconfig +0 -1
  67. package/templates/hello-world/ts/package.json +7 -4
  68. package/templates/hello-world/ts/src/index.ts +5 -19
  69. package/templates/hello-world/ts/test/env.d.ts +3 -0
  70. package/templates/hello-world/ts/test/index.spec.ts +25 -0
  71. package/templates/hello-world/ts/test/tsconfig.json +8 -0
  72. package/templates/hello-world/ts/tsconfig.json +39 -96
  73. package/templates/hello-world/ts/vitest.config.mts +11 -0
  74. package/templates/hello-world/ts/worker-configuration.d.ts +8 -0
  75. package/templates/hello-world/ts/wrangler.jsonc +8 -0
  76. package/templates/hello-world-assets-only/c3.ts +16 -0
  77. package/templates/hello-world-assets-only/templates/package.json +13 -0
  78. package/templates/hello-world-assets-only/templates/public/index.html +11 -0
  79. package/templates/hello-world-assets-only/templates/wrangler.jsonc +10 -0
  80. package/templates/hello-world-durable-object/c3.ts +21 -0
  81. package/templates/hello-world-durable-object/js/.editorconfig +12 -0
  82. package/templates/hello-world-durable-object/js/.prettierrc +6 -0
  83. package/templates/hello-world-durable-object/js/__dot__gitignore +172 -0
  84. package/templates/hello-world-durable-object/js/package.json +13 -0
  85. package/templates/hello-world-durable-object/js/src/index.js +70 -0
  86. package/templates/hello-world-durable-object/js/wrangler.jsonc +24 -0
  87. package/templates/hello-world-durable-object/ts/.editorconfig +12 -0
  88. package/templates/hello-world-durable-object/ts/.prettierrc +6 -0
  89. package/templates/hello-world-durable-object/ts/__dot__gitignore +172 -0
  90. package/templates/hello-world-durable-object/ts/package.json +15 -0
  91. package/templates/hello-world-durable-object/ts/src/index.ts +66 -0
  92. package/templates/hello-world-durable-object/ts/tsconfig.json +42 -0
  93. package/templates/hello-world-durable-object/ts/worker-configuration.d.ts +7 -0
  94. package/templates/hello-world-durable-object/ts/wrangler.jsonc +24 -0
  95. package/templates/hello-world-durable-object-with-assets/c3.ts +23 -0
  96. package/templates/hello-world-durable-object-with-assets/js/.editorconfig +12 -0
  97. package/templates/hello-world-durable-object-with-assets/js/.prettierrc +6 -0
  98. package/templates/{chatgptPlugin/ts → hello-world-durable-object-with-assets/js}/__dot__gitignore +1 -0
  99. package/templates/hello-world-durable-object-with-assets/js/package.json +13 -0
  100. package/templates/hello-world-durable-object-with-assets/js/public/index.html +19 -0
  101. package/templates/hello-world-durable-object-with-assets/js/src/index.js +70 -0
  102. package/templates/hello-world-durable-object-with-assets/js/wrangler.jsonc +28 -0
  103. package/templates/hello-world-durable-object-with-assets/ts/.editorconfig +12 -0
  104. package/templates/hello-world-durable-object-with-assets/ts/.prettierrc +6 -0
  105. package/templates/hello-world-durable-object-with-assets/ts/__dot__gitignore +172 -0
  106. package/templates/hello-world-durable-object-with-assets/ts/package.json +15 -0
  107. package/templates/hello-world-durable-object-with-assets/ts/public/index.html +19 -0
  108. package/templates/hello-world-durable-object-with-assets/ts/src/index.ts +67 -0
  109. package/templates/hello-world-durable-object-with-assets/ts/tsconfig.json +42 -0
  110. package/templates/hello-world-durable-object-with-assets/ts/worker-configuration.d.ts +8 -0
  111. package/templates/hello-world-durable-object-with-assets/ts/wrangler.jsonc +28 -0
  112. package/templates/hello-world-with-assets/c3.ts +25 -0
  113. package/templates/hello-world-with-assets/js/.editorconfig +12 -0
  114. package/templates/hello-world-with-assets/js/.prettierrc +6 -0
  115. package/templates/hello-world-with-assets/js/__dot__gitignore +172 -0
  116. package/templates/hello-world-with-assets/js/package.json +16 -0
  117. package/templates/hello-world-with-assets/js/public/index.html +31 -0
  118. package/templates/hello-world-with-assets/js/src/index.js +23 -0
  119. package/templates/hello-world-with-assets/js/test/index.spec.js +41 -0
  120. package/templates/hello-world-with-assets/js/vitest.config.js +11 -0
  121. package/templates/hello-world-with-assets/js/wrangler.jsonc +15 -0
  122. package/templates/hello-world-with-assets/py/__dot__gitignore +68 -0
  123. package/templates/hello-world-with-assets/py/package.json +13 -0
  124. package/templates/hello-world-with-assets/py/public/index.html +31 -0
  125. package/templates/hello-world-with-assets/py/src/entry.py +9 -0
  126. package/templates/hello-world-with-assets/py/wrangler.jsonc +15 -0
  127. package/templates/hello-world-with-assets/ts/.editorconfig +12 -0
  128. package/templates/hello-world-with-assets/ts/.prettierrc +6 -0
  129. package/templates/hello-world-with-assets/ts/__dot__gitignore +172 -0
  130. package/templates/hello-world-with-assets/ts/package.json +18 -0
  131. package/templates/hello-world-with-assets/ts/public/index.html +31 -0
  132. package/templates/hello-world-with-assets/ts/src/index.ts +26 -0
  133. package/templates/hello-world-with-assets/ts/test/env.d.ts +3 -0
  134. package/templates/hello-world-with-assets/ts/test/index.spec.ts +41 -0
  135. package/templates/hello-world-with-assets/ts/test/tsconfig.json +8 -0
  136. package/templates/hello-world-with-assets/ts/tsconfig.json +44 -0
  137. package/templates/hello-world-with-assets/ts/vitest.config.mts +11 -0
  138. package/templates/hello-world-with-assets/ts/worker-configuration.d.ts +7 -0
  139. package/templates/hello-world-with-assets/ts/wrangler.jsonc +15 -0
  140. package/templates/hono/c3.ts +9 -0
  141. package/templates/hono/pages/c3.ts +44 -0
  142. package/templates/hono/pages/templates/src/index.tsx +12 -0
  143. package/templates/hono/pages/templates/worker-configuration.d.ts +4 -0
  144. package/templates/hono/pages/templates/wrangler.jsonc +8 -0
  145. package/templates/hono/workers/c3.ts +42 -0
  146. package/templates/hono/workers/templates/public/index.html +19 -0
  147. package/templates/hono/workers/templates/src/index.ts +9 -0
  148. package/templates/hono/workers/templates/worker-configuration.d.ts +4 -0
  149. package/templates/hono/workers/templates/wrangler.jsonc +9 -0
  150. package/templates/next/c3.ts +9 -0
  151. package/templates/next/pages/README.md +67 -0
  152. package/templates/next/pages/app/js/app/api/hello/route.js +21 -0
  153. package/templates/next/pages/app/js/app/not-found.js +58 -0
  154. package/templates/next/pages/app/ts/app/api/hello/route.ts +21 -0
  155. package/templates/next/pages/app/ts/app/not-found.tsx +58 -0
  156. package/templates/next/pages/c3.ts +225 -0
  157. package/templates/next/pages/env.d.ts +5 -0
  158. package/templates/next/pages/pages/js/pages/api/hello.js +23 -0
  159. package/templates/next/pages/pages/ts/pages/api/hello.ts +24 -0
  160. package/templates/next/pages/wrangler.jsonc +8 -0
  161. package/templates/next/workers/c3.ts +74 -0
  162. package/templates/next/workers/templates/.dev.vars +2 -0
  163. package/templates/next/workers/templates/__dot__gitignore +39 -0
  164. package/templates/next/workers/templates/cloudflare-env.d.ts +5 -0
  165. package/templates/next/workers/templates/open-next.config.ts +9 -0
  166. package/templates/next/workers/templates/wrangler.jsonc +12 -0
  167. package/templates/nuxt/c3.ts +9 -0
  168. package/templates/nuxt/pages/c3.ts +147 -0
  169. package/templates/nuxt/pages/templates/env.d.ts +14 -0
  170. package/templates/nuxt/pages/templates/worker-configuration.d.ts +4 -0
  171. package/templates/nuxt/pages/templates/wrangler.jsonc +5 -0
  172. package/templates/nuxt/workers/c3.ts +146 -0
  173. package/templates/nuxt/workers/templates/env.d.ts +14 -0
  174. package/templates/nuxt/workers/templates/worker-configuration.d.ts +4 -0
  175. package/templates/nuxt/workers/templates/wrangler.jsonc +12 -0
  176. package/templates/openapi/c3.ts +14 -0
  177. package/templates/openapi/ts/README.md +3 -3
  178. package/templates/openapi/ts/package.json +7 -5
  179. package/templates/openapi/ts/src/endpoints/taskCreate.ts +26 -16
  180. package/templates/openapi/ts/src/endpoints/taskDelete.ts +20 -19
  181. package/templates/openapi/ts/src/endpoints/taskFetch.ts +30 -23
  182. package/templates/openapi/ts/src/endpoints/taskList.ts +27 -24
  183. package/templates/openapi/ts/src/index.ts +16 -22
  184. package/templates/openapi/ts/src/types.ts +9 -8
  185. package/templates/openapi/ts/worker-configuration.d.ts +4 -0
  186. package/templates/openapi/ts/wrangler.jsonc +8 -0
  187. package/templates/pre-existing/c3.ts +106 -0
  188. package/templates/pre-existing/js/.editorconfig +12 -0
  189. package/templates/pre-existing/js/.prettierrc +6 -0
  190. package/templates/pre-existing/js/__dot__gitignore +172 -0
  191. package/templates/pre-existing/js/package.json +13 -0
  192. package/templates/queues/c3.ts +32 -0
  193. package/templates/queues/js/.editorconfig +0 -1
  194. package/templates/queues/js/package.json +1 -1
  195. package/templates/queues/js/wrangler.jsonc +21 -0
  196. package/templates/queues/ts/.editorconfig +0 -1
  197. package/templates/queues/ts/package.json +4 -4
  198. package/templates/queues/ts/src/index.ts +6 -8
  199. package/templates/queues/ts/tsconfig.json +36 -95
  200. package/templates/queues/ts/worker-configuration.d.ts +5 -0
  201. package/templates/queues/ts/wrangler.jsonc +21 -0
  202. package/templates/qwik/c3.ts +9 -0
  203. package/templates/qwik/pages/c3.ts +150 -0
  204. package/templates/qwik/pages/snippets/getPlatformProxy.ts +6 -0
  205. package/templates/qwik/pages/templates/worker-configuration.d.ts +4 -0
  206. package/templates/qwik/pages/templates/wrangler.jsonc +8 -0
  207. package/templates/qwik/workers/c3.ts +154 -0
  208. package/templates/qwik/workers/snippets/getPlatformProxy.ts +6 -0
  209. package/templates/qwik/workers/templates/public/.assetsignore +4 -0
  210. package/templates/qwik/workers/templates/worker-configuration.d.ts +4 -0
  211. package/templates/qwik/workers/templates/wrangler.jsonc +15 -0
  212. package/templates/react/c3.ts +9 -0
  213. package/templates/react/pages/c3.ts +63 -0
  214. package/templates/react/workers/c3.ts +183 -0
  215. package/templates/react/workers/js/src/App.css +45 -0
  216. package/templates/react/workers/js/src/App.jsx +58 -0
  217. package/templates/react/workers/js/src/assets/Cloudflare_Logo.svg +53 -0
  218. package/templates/react/workers/js/worker/index.js +13 -0
  219. package/templates/react/workers/js/wrangler.jsonc +9 -0
  220. package/templates/react/workers/ts/src/App.css +45 -0
  221. package/templates/react/workers/ts/src/App.tsx +58 -0
  222. package/templates/react/workers/ts/src/assets/Cloudflare_Logo.svg +51 -0
  223. package/templates/react/workers/ts/tsconfig.worker.json +8 -0
  224. package/templates/react/workers/ts/worker/index.ts +12 -0
  225. package/templates/react/workers/ts/worker-configuration.d.ts +5 -0
  226. package/templates/react/workers/ts/wrangler.jsonc +9 -0
  227. package/templates/react-router/c3.ts +53 -0
  228. package/templates/react-router/templates/worker-configuration.d.ts +8 -0
  229. package/templates/remix/c3.ts +10 -0
  230. package/templates/remix/pages/c3.ts +69 -0
  231. package/templates/remix/pages/templates/worker-configuration.d.ts +4 -0
  232. package/templates/remix/pages/templates/wrangler.jsonc +5 -0
  233. package/templates/remix/workers/c3.ts +52 -0
  234. package/templates/remix/workers/templates/public/.assetsignore +0 -0
  235. package/templates/remix/workers/templates/worker-configuration.d.ts +4 -0
  236. package/templates/remix/workers/templates/wrangler.toml +11 -0
  237. package/templates/scheduled/c3.ts +22 -0
  238. package/templates/scheduled/js/.editorconfig +0 -1
  239. package/templates/scheduled/js/package.json +3 -3
  240. package/templates/scheduled/js/src/index.js +9 -2
  241. package/templates/scheduled/js/wrangler.jsonc +13 -0
  242. package/templates/scheduled/ts/.editorconfig +0 -1
  243. package/templates/scheduled/ts/package.json +5 -5
  244. package/templates/scheduled/ts/src/index.ts +15 -25
  245. package/templates/scheduled/ts/tsconfig.json +36 -95
  246. package/templates/scheduled/ts/worker-configuration.d.ts +4 -0
  247. package/templates/scheduled/ts/wrangler.jsonc +13 -0
  248. package/templates/solid/c3.ts +87 -0
  249. package/templates/solid/templates/wrangler.jsonc +8 -0
  250. package/templates/svelte/c3.ts +9 -0
  251. package/templates/svelte/pages/c3.ts +160 -0
  252. package/templates/svelte/pages/templates/wrangler.jsonc +5 -0
  253. package/templates/svelte/workers/c3.ts +129 -0
  254. package/templates/svelte/workers/templates/static/.assetsignore +2 -0
  255. package/templates/svelte/workers/templates/wrangler.jsonc +12 -0
  256. package/templates/vue/c3.ts +9 -0
  257. package/templates/vue/pages/c3.ts +31 -0
  258. package/templates/vue/workers/c3.ts +98 -0
  259. package/templates/vue/workers/js/server/index.js +13 -0
  260. package/templates/vue/workers/js/src/App.vue +107 -0
  261. package/templates/vue/workers/js/src/components/HelloWorld.vue +47 -0
  262. package/templates/vue/workers/js/vite.config.js +21 -0
  263. package/templates/vue/workers/js/wrangler.jsonc +11 -0
  264. package/templates/vue/workers/ts/server/index.ts +12 -0
  265. package/templates/vue/workers/ts/src/App.vue +107 -0
  266. package/templates/vue/workers/ts/src/components/HelloWorld.vue +44 -0
  267. package/templates/vue/workers/ts/tsconfig.worker.json +8 -0
  268. package/templates/vue/workers/ts/vite.config.ts +21 -0
  269. package/templates/vue/workers/ts/worker-configuration.d.ts +6 -0
  270. package/templates/vue/workers/ts/wrangler.jsonc +11 -0
  271. package/templates-experimental/solid/c3.ts +94 -0
  272. package/templates-experimental/solid/templates/wrangler.jsonc +15 -0
  273. package/dist/angular/templates/server.ts +0 -34
  274. package/dist/angular/templates/tools/alter-polyfills.mjs +0 -27
  275. package/dist/angular/templates/tools/copy-files.mjs +0 -9
  276. package/dist/angular/templates/tools/paths.mjs +0 -9
  277. package/templates/chatgptPlugin/ts/.assets/example.png +0 -0
  278. package/templates/chatgptPlugin/ts/README.md +0 -25
  279. package/templates/chatgptPlugin/ts/package.json +0 -17
  280. package/templates/chatgptPlugin/ts/src/index.ts +0 -33
  281. package/templates/chatgptPlugin/ts/src/search.ts +0 -59
  282. package/templates/chatgptPlugin/ts/wrangler.toml +0 -3
  283. package/templates/common/js/wrangler.toml +0 -51
  284. package/templates/common/ts/wrangler.toml +0 -51
  285. package/templates/hello-world/js/wrangler.toml +0 -51
  286. package/templates/hello-world/ts/wrangler.toml +0 -51
  287. package/templates/openapi/ts/wrangler.toml +0 -3
  288. package/templates/queues/js/wrangler.toml +0 -19
  289. package/templates/queues/ts/wrangler.toml +0 -19
  290. package/templates/scheduled/js/wrangler.toml +0 -9
  291. package/templates/scheduled/ts/wrangler.toml +0 -9
  292. /package/{dist/angular → templates/angular/pages}/templates/src/_routes.json +0 -0
@@ -0,0 +1,150 @@
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
+ hidden: true,
133
+ copyFiles: {
134
+ path: "./templates",
135
+ },
136
+ path: "templates/qwik/pages",
137
+ generate,
138
+ configure,
139
+ transformPackageJson: async () => ({
140
+ scripts: {
141
+ deploy: `${npm} run build && wrangler pages deploy`,
142
+ preview: `${npm} run build && wrangler pages dev`,
143
+ "cf-typegen": `wrangler types`,
144
+ },
145
+ }),
146
+ devScript: "dev",
147
+ deployScript: "deploy",
148
+ previewScript: "preview",
149
+ };
150
+ export default config;
@@ -0,0 +1,6 @@
1
+ let platform = {};
2
+
3
+ if(process.env.NODE_ENV === 'development') {
4
+ const { getPlatformProxy } = await import('wrangler');
5
+ platform = await getPlatformProxy();
6
+ }
@@ -0,0 +1,4 @@
1
+ // Generated by Wrangler
2
+ // After adding bindings to `wrangler.jsonc`, regenerate this interface via `npm run cf-typegen`
3
+ interface Env {
4
+ }
@@ -0,0 +1,8 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "compatibility_date": "<TBD>",
4
+ "compatibility_flags": [
5
+ "nodejs_compat"
6
+ ],
7
+ "pages_build_output_dir": "./dist"
8
+ }
@@ -0,0 +1,154 @@
1
+ import { crash, 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 { removeFile, 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
+ // Remove the extraneous Pages files
27
+ removeFile("./public/_headers");
28
+ removeFile("./public/_redirects");
29
+ removeFile("./public/_routes.json");
30
+
31
+ addBindingsProxy(ctx);
32
+ populateCloudflareEnv();
33
+ };
34
+
35
+ const addBindingsProxy = (ctx: C3Context) => {
36
+ // Qwik only has a typescript template atm.
37
+ // This check is an extra precaution
38
+ if (!usesTypescript(ctx)) {
39
+ return;
40
+ }
41
+
42
+ const s = spinner();
43
+ s.start("Updating `vite.config.ts`");
44
+
45
+ const snippets = loadTemplateSnippets(ctx);
46
+ const b = recast.types.builders;
47
+
48
+ transformFile("vite.config.ts", {
49
+ // Insert the env declaration after the last import (but before the rest of the body)
50
+ visitProgram: function (n) {
51
+ const lastImportIndex = n.node.body.findLastIndex(
52
+ (t) => t.type === "ImportDeclaration",
53
+ );
54
+ const lastImport = n.get("body", lastImportIndex);
55
+ lastImport.insertAfter(...snippets.getPlatformProxyTs);
56
+
57
+ return this.traverse(n);
58
+ },
59
+ // Pass the `platform` object from the declaration to the `qwikCity` plugin
60
+ visitCallExpression: function (n) {
61
+ const callee = n.node.callee as recast.types.namedTypes.Identifier;
62
+ if (callee.name !== "qwikCity") {
63
+ return this.traverse(n);
64
+ }
65
+
66
+ // The config object passed to `qwikCity`
67
+ const configArgument = n.node.arguments[0] as
68
+ | recast.types.namedTypes.ObjectExpression
69
+ | undefined;
70
+
71
+ const platformPropery = b.objectProperty.from({
72
+ key: b.identifier("platform"),
73
+ value: b.identifier("platform"),
74
+ shorthand: true,
75
+ });
76
+
77
+ if (!configArgument) {
78
+ n.node.arguments = [b.objectExpression([platformPropery])];
79
+
80
+ return false;
81
+ }
82
+
83
+ if (configArgument.type !== "ObjectExpression") {
84
+ crash("Failed to update `vite.config.ts`");
85
+ }
86
+
87
+ // Add the `platform` object to the object
88
+ configArgument.properties.push(platformPropery);
89
+
90
+ return false;
91
+ },
92
+ });
93
+
94
+ s.stop(`${brandColor("updated")} \`vite.config.ts\``);
95
+ };
96
+
97
+ const populateCloudflareEnv = () => {
98
+ const entrypointPath = "src/entry.cloudflare-pages.tsx";
99
+
100
+ const s = spinner();
101
+ s.start(`Updating \`${entrypointPath}\``);
102
+
103
+ transformFile(entrypointPath, {
104
+ visitTSInterfaceDeclaration: function (n) {
105
+ const b = recast.types.builders;
106
+ const id = n.node.id as recast.types.namedTypes.Identifier;
107
+ if (id.name !== "QwikCityPlatform") {
108
+ this.traverse(n);
109
+ }
110
+
111
+ const newBody = [
112
+ ["env", "Env"],
113
+ // Qwik doesn't supply `cf` to the platform object. Should they do so, uncomment this
114
+ // ["cf", "CfProperties"],
115
+ ].map(([varName, type]) =>
116
+ b.tsPropertySignature(
117
+ b.identifier(varName),
118
+ b.tsTypeAnnotation(b.tsTypeReference(b.identifier(type))),
119
+ ),
120
+ );
121
+
122
+ n.node.body.body = newBody;
123
+
124
+ return false;
125
+ },
126
+ });
127
+
128
+ s.stop(`${brandColor("updated")} \`${entrypointPath}\``);
129
+ };
130
+
131
+ const config: TemplateConfig = {
132
+ configVersion: 1,
133
+ id: "qwik",
134
+ frameworkCli: "create-qwik",
135
+ displayName: "Qwik",
136
+ platform: "workers",
137
+ copyFiles: {
138
+ path: "./templates",
139
+ },
140
+ path: "templates/qwik/workers",
141
+ generate,
142
+ configure,
143
+ transformPackageJson: async () => ({
144
+ scripts: {
145
+ deploy: `${npm} run build && wrangler deploy`,
146
+ preview: `${npm} run build && wrangler dev`,
147
+ "cf-typegen": `wrangler types`,
148
+ },
149
+ }),
150
+ devScript: "dev",
151
+ deployScript: "deploy",
152
+ previewScript: "preview",
153
+ };
154
+ export default config;
@@ -0,0 +1,6 @@
1
+ let platform = {};
2
+
3
+ if(process.env.NODE_ENV === 'development') {
4
+ const { getPlatformProxy } = await import('wrangler');
5
+ platform = await getPlatformProxy();
6
+ }
@@ -0,0 +1,4 @@
1
+ _worker.js
2
+ _routes.json
3
+ _headers
4
+ _redirects
@@ -0,0 +1,4 @@
1
+ // Generated by Wrangler
2
+ // After adding bindings to `wrangler.jsonc`, regenerate this interface via `npm run cf-typegen`
3
+ interface Env {
4
+ }
@@ -0,0 +1,15 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "main": "./dist/_worker.js",
4
+ "compatibility_date": "<TBD>",
5
+ "compatibility_flags": [
6
+ "nodejs_compat"
7
+ ],
8
+ "assets": {
9
+ "binding": "ASSET",
10
+ "directory": "./dist"
11
+ },
12
+ "observability": {
13
+ "enabled": true
14
+ }
15
+ }
@@ -0,0 +1,9 @@
1
+ import pages from "./pages/c3";
2
+ import workers from "./workers/c3";
3
+ import type { MultiPlatformTemplateConfig } from "../../src/templates";
4
+
5
+ const config: MultiPlatformTemplateConfig = {
6
+ displayName: "React",
7
+ platformVariants: { pages, workers },
8
+ };
9
+ export default config;
@@ -0,0 +1,63 @@
1
+ import { logRaw } from "@cloudflare/cli";
2
+ import { inputPrompt } from "@cloudflare/cli/interactive";
3
+ import { runFrameworkGenerator } from "frameworks/index";
4
+ import { detectPackageManager } from "helpers/packageManagers";
5
+ import type { TemplateConfig } from "../../../src/templates";
6
+ import type { C3Context } from "types";
7
+
8
+ const { npm } = detectPackageManager();
9
+
10
+ const generate = async (ctx: C3Context) => {
11
+ const variant = await inputPrompt({
12
+ type: "select",
13
+ question: "Select a variant:",
14
+ label: "variant",
15
+ options: variantsOptions,
16
+ defaultValue: variantsOptions[0].value,
17
+ });
18
+
19
+ await runFrameworkGenerator(ctx, [ctx.project.name, "--template", variant]);
20
+
21
+ logRaw("");
22
+ };
23
+
24
+ const variantsOptions = [
25
+ {
26
+ value: "react-ts",
27
+ label: "TypeScript",
28
+ },
29
+ {
30
+ value: "react-swc-ts",
31
+ label: "TypeScript + SWC",
32
+ },
33
+ {
34
+ value: "react",
35
+ label: "JavaScript",
36
+ },
37
+ {
38
+ value: "react-swc",
39
+ label: "JavaScript + SWC",
40
+ },
41
+ ];
42
+
43
+ const config: TemplateConfig = {
44
+ configVersion: 1,
45
+ id: "react",
46
+ // React's documentation now recommends using create-vite.
47
+ frameworkCli: "create-vite",
48
+ displayName: "React",
49
+ platform: "pages",
50
+ hidden: true,
51
+ path: "templates/react/pages",
52
+ generate,
53
+ transformPackageJson: async () => ({
54
+ scripts: {
55
+ deploy: `${npm} run build && wrangler pages deploy ./dist`,
56
+ preview: `${npm} run build && wrangler pages dev ./dist`,
57
+ },
58
+ }),
59
+ devScript: "dev",
60
+ deployScript: "deploy",
61
+ previewScript: "preview",
62
+ };
63
+ export default config;
@@ -0,0 +1,183 @@
1
+ import assert from "assert";
2
+ import { logRaw } from "@cloudflare/cli";
3
+ import { brandColor, dim } from "@cloudflare/cli/colors";
4
+ import { inputPrompt, spinner } from "@cloudflare/cli/interactive";
5
+ import { runFrameworkGenerator } from "frameworks/index";
6
+ import { transformFile } from "helpers/codemod";
7
+ import { readJSON, usesTypescript, writeJSON } 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 { types } from "recast";
13
+ import type { C3Context } from "types";
14
+
15
+ const b = recast.types.builders;
16
+ const t = recast.types.namedTypes;
17
+ const { npm } = detectPackageManager();
18
+
19
+ const generate = async (ctx: C3Context) => {
20
+ const variant = await getVariant();
21
+ ctx.args.lang = variant.lang;
22
+
23
+ await runFrameworkGenerator(ctx, [
24
+ ctx.project.name,
25
+ "--template",
26
+ variant.value,
27
+ ]);
28
+
29
+ logRaw("");
30
+ };
31
+
32
+ const configure = async (ctx: C3Context) => {
33
+ await installPackages(["@cloudflare/vite-plugin"], {
34
+ dev: true,
35
+ startText: "Installing the Cloudflare Vite plugin",
36
+ doneText: `${brandColor(`installed`)} ${dim("@cloudflare/vite-plugin")}`,
37
+ });
38
+
39
+ await transformViteConfig(ctx);
40
+
41
+ if (usesTypescript(ctx)) {
42
+ updateTsconfigJson();
43
+ }
44
+ };
45
+
46
+ function transformViteConfig(ctx: C3Context) {
47
+ const filePath = `vite.config.${usesTypescript(ctx) ? "ts" : "js"}`;
48
+
49
+ transformFile(filePath, {
50
+ visitProgram(n) {
51
+ // Add an import of the @cloudflare/vite-plugin
52
+ // ```
53
+ // import {cloudflare} from "@cloudflare/vite-plugin";
54
+ // ```
55
+ const lastImportIndex = n.node.body.findLastIndex(
56
+ (statement) => statement.type === "ImportDeclaration",
57
+ );
58
+ const lastImport = n.get("body", lastImportIndex);
59
+ const importAst = b.importDeclaration(
60
+ [b.importSpecifier(b.identifier("cloudflare"))],
61
+ b.stringLiteral("@cloudflare/vite-plugin"),
62
+ );
63
+ lastImport.insertAfter(importAst);
64
+
65
+ return this.traverse(n);
66
+ },
67
+ visitCallExpression: function (n) {
68
+ // Add the imported plugin to the config
69
+ // ```
70
+ // defineConfig({
71
+ // plugins: [react(), cloudflare()],
72
+ // });
73
+ const callee = n.node.callee as types.namedTypes.Identifier;
74
+ if (callee.name !== "defineConfig") {
75
+ return this.traverse(n);
76
+ }
77
+
78
+ const config = n.node.arguments[0];
79
+ assert(t.ObjectExpression.check(config));
80
+ const pluginsProp = config.properties.find((prop) => isPluginsProp(prop));
81
+ assert(pluginsProp && t.ArrayExpression.check(pluginsProp.value));
82
+ pluginsProp.value.elements.push(
83
+ b.callExpression(b.identifier("cloudflare"), []),
84
+ );
85
+
86
+ return false;
87
+ },
88
+ });
89
+ }
90
+
91
+ function isPluginsProp(
92
+ prop: unknown,
93
+ ): prop is types.namedTypes.ObjectProperty | types.namedTypes.Property {
94
+ return (
95
+ (t.Property.check(prop) || t.ObjectProperty.check(prop)) &&
96
+ t.Identifier.check(prop.key) &&
97
+ prop.key.name === "plugins"
98
+ );
99
+ }
100
+
101
+ function updateTsconfigJson() {
102
+ const s = spinner();
103
+ s.start(`Updating tsconfig.json config`);
104
+ // Add a reference to the extra tsconfig.worker.json file.
105
+ // ```
106
+ // "references": [ ..., { path: "./tsconfig.worker.json" } ]
107
+ // ```
108
+ const tsconfig = readJSON("tsconfig.json") as { references: object[] };
109
+ if (tsconfig && typeof tsconfig === "object") {
110
+ tsconfig.references ??= [];
111
+ tsconfig.references.push({ path: "./tsconfig.worker.json" });
112
+ }
113
+ writeJSON("tsconfig.json", tsconfig);
114
+ s.stop(`${brandColor(`updated`)} ${dim(`\`tsconfig.json\``)}`);
115
+ }
116
+
117
+ async function getVariant() {
118
+ const variantsOptions = [
119
+ {
120
+ value: "react-ts",
121
+ lang: "ts",
122
+ label: "TypeScript",
123
+ },
124
+ {
125
+ value: "react-swc-ts",
126
+ lang: "ts",
127
+ label: "TypeScript + SWC",
128
+ },
129
+ {
130
+ value: "react",
131
+ lang: "js",
132
+ label: "JavaScript",
133
+ },
134
+ {
135
+ value: "react-swc",
136
+ lang: "js",
137
+ label: "JavaScript + SWC",
138
+ },
139
+ ];
140
+ const value = await inputPrompt({
141
+ type: "select",
142
+ question: "Select a variant:",
143
+ label: "variant",
144
+ options: variantsOptions,
145
+ defaultValue: variantsOptions[0].value,
146
+ });
147
+
148
+ const selected = variantsOptions.find((variant) => variant.value === value);
149
+ assert(selected, "Expected a variant to be selected");
150
+ return selected;
151
+ }
152
+
153
+ const config: TemplateConfig = {
154
+ configVersion: 1,
155
+ id: "react",
156
+ frameworkCli: "create-vite",
157
+ displayName: "React",
158
+ platform: "workers",
159
+ path: "templates/react/workers",
160
+ copyFiles: {
161
+ variants: {
162
+ ts: {
163
+ path: "./ts",
164
+ },
165
+ js: {
166
+ path: "./js",
167
+ },
168
+ },
169
+ },
170
+ generate,
171
+ configure,
172
+ transformPackageJson: async (_, ctx) => ({
173
+ scripts: {
174
+ deploy: `${npm} run build && wrangler deploy`,
175
+ preview: `${npm} run build && vite preview`,
176
+ ...(usesTypescript(ctx) && { "cf-typegen": `wrangler types` }),
177
+ },
178
+ }),
179
+ devScript: "dev",
180
+ deployScript: "deploy",
181
+ previewScript: "preview",
182
+ };
183
+ export default config;
@@ -0,0 +1,45 @@
1
+ #root {
2
+ max-width: 1280px;
3
+ margin: 0 auto;
4
+ padding: 2rem;
5
+ text-align: center;
6
+ }
7
+
8
+ .logo {
9
+ height: 6em;
10
+ padding: 1.5em;
11
+ will-change: filter;
12
+ transition: filter 300ms;
13
+ }
14
+ .logo:hover {
15
+ filter: drop-shadow(0 0 2em #646cffaa);
16
+ }
17
+ .logo.react:hover {
18
+ filter: drop-shadow(0 0 2em #61dafbaa);
19
+ }
20
+ .logo.cloudflare:hover {
21
+ filter: drop-shadow(0 0 2em #f6821faa);
22
+ }
23
+
24
+ @keyframes logo-spin {
25
+ from {
26
+ transform: rotate(0deg);
27
+ }
28
+ to {
29
+ transform: rotate(360deg);
30
+ }
31
+ }
32
+
33
+ @media (prefers-reduced-motion: no-preference) {
34
+ a:nth-of-type(2) .logo {
35
+ animation: logo-spin infinite 20s linear;
36
+ }
37
+ }
38
+
39
+ .card {
40
+ padding: 2em;
41
+ }
42
+
43
+ .read-the-docs {
44
+ color: #888;
45
+ }