create-cloudflare 0.0.0-e7ea6005c → 0.0.0-e7fce2523

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 (328) hide show
  1. package/dist/cli.js +18792 -18411
  2. package/dist/tsconfig.tsbuildinfo +1 -1
  3. package/package.json +18 -11
  4. package/templates/analog/c3.ts +0 -24
  5. package/templates/analog/templates/env.d.ts +1 -1
  6. package/templates/analog/templates/wrangler.jsonc +5 -0
  7. package/templates/angular/c3.ts +5 -98
  8. package/templates/angular/pages/c3.ts +135 -0
  9. package/templates/angular/pages/templates/src/server.ts +15 -0
  10. package/templates/angular/pages/templates/tools/copy-files.mjs +15 -0
  11. package/templates/angular/pages/templates/wrangler.jsonc +5 -0
  12. package/{templates-experimental/angular → templates/angular/workers}/c3.ts +47 -14
  13. package/templates/angular/workers/templates/src/server.ts +15 -0
  14. package/templates/angular/workers/templates/wrangler.jsonc +12 -0
  15. package/templates/astro/c3.ts +5 -109
  16. package/templates/astro/pages/c3.ts +99 -0
  17. package/templates/astro/pages/templates/js/wrangler.jsonc +8 -0
  18. package/templates/astro/pages/templates/ts/worker-configuration.d.ts +4 -0
  19. package/templates/astro/pages/templates/ts/wrangler.jsonc +8 -0
  20. package/{templates-experimental/astro → templates/astro/workers}/c3.ts +19 -35
  21. package/templates/astro/workers/templates/js/public/.assetsignore +2 -0
  22. package/templates/astro/workers/templates/js/wrangler.jsonc +16 -0
  23. package/templates/astro/workers/templates/ts/public/.assetsignore +2 -0
  24. package/templates/astro/workers/templates/ts/wrangler.jsonc +16 -0
  25. package/templates/common/c3.ts +5 -1
  26. package/templates/common/js/package.json +1 -1
  27. package/templates/common/js/wrangler.jsonc +8 -0
  28. package/templates/common/ts/package.json +1 -1
  29. package/templates/common/ts/src/index.ts +1 -1
  30. package/templates/common/ts/tsconfig.json +0 -3
  31. package/templates/common/ts/wrangler.jsonc +8 -0
  32. package/templates/docusaurus/c3.ts +5 -24
  33. package/templates/docusaurus/pages/c3.ts +32 -0
  34. package/{templates-experimental/docusaurus → templates/docusaurus/workers}/c3.ts +4 -2
  35. package/templates/docusaurus/workers/templates/wrangler.jsonc +10 -0
  36. package/templates/gatsby/c3.ts +5 -45
  37. package/templates/gatsby/pages/c3.ts +52 -0
  38. package/{templates-experimental/gatsby → templates/gatsby/workers}/c3.ts +3 -2
  39. package/templates/gatsby/workers/templates/wrangler.jsonc +10 -0
  40. package/templates/hello-world/c3.ts +20 -3
  41. package/templates/hello-world/js/package.json +3 -3
  42. package/templates/hello-world/js/test/index.spec.js +1 -1
  43. package/templates/hello-world/js/vitest.config.js +1 -1
  44. package/templates/hello-world/js/wrangler.jsonc +8 -0
  45. package/templates/hello-world/py/.python-version +1 -0
  46. package/templates/hello-world/py/README.md +23 -0
  47. package/templates/hello-world/py/package.json +1 -1
  48. package/templates/hello-world/py/pyproject.toml +9 -0
  49. package/templates/hello-world/py/src/entry.py +3 -2
  50. package/templates/hello-world/py/uv.lock +22 -0
  51. package/templates/hello-world/py/wrangler.jsonc +9 -0
  52. package/templates/hello-world/ts/package.json +3 -3
  53. package/templates/hello-world/ts/src/index.ts +1 -1
  54. package/templates/hello-world/ts/test/env.d.ts +3 -0
  55. package/templates/hello-world/ts/test/index.spec.ts +0 -1
  56. package/templates/hello-world/ts/test/tsconfig.json +2 -2
  57. package/templates/hello-world/ts/tsconfig.json +0 -2
  58. package/templates/hello-world/ts/vitest.config.mts +1 -1
  59. package/templates/hello-world/ts/wrangler.jsonc +8 -0
  60. package/{templates-experimental → templates}/hello-world-assets-only/c3.ts +4 -3
  61. package/{templates-experimental → templates}/hello-world-assets-only/templates/public/index.html +1 -0
  62. package/templates/hello-world-assets-only/templates/wrangler.jsonc +11 -0
  63. package/templates/hello-world-durable-object/c3.ts +9 -3
  64. package/templates/hello-world-durable-object/js/package.json +1 -1
  65. package/templates/hello-world-durable-object/js/src/index.js +13 -12
  66. package/templates/hello-world-durable-object/js/wrangler.jsonc +24 -0
  67. package/templates/hello-world-durable-object/py/.python-version +1 -0
  68. package/templates/hello-world-durable-object/py/README.md +23 -0
  69. package/templates/hello-world-durable-object/py/__dot__gitignore +68 -0
  70. package/templates/hello-world-durable-object/py/package.json +13 -0
  71. package/templates/hello-world-durable-object/py/pyproject.toml +9 -0
  72. package/templates/hello-world-durable-object/py/src/entry.py +66 -0
  73. package/templates/hello-world-durable-object/py/uv.lock +22 -0
  74. package/templates/hello-world-durable-object/py/wrangler.jsonc +27 -0
  75. package/templates/hello-world-durable-object/ts/package.json +1 -1
  76. package/templates/hello-world-durable-object/ts/src/index.ts +14 -13
  77. package/templates/hello-world-durable-object/ts/tsconfig.json +0 -2
  78. package/templates/hello-world-durable-object/ts/wrangler.jsonc +24 -0
  79. package/{templates-experimental → templates}/hello-world-durable-object-with-assets/c3.ts +6 -3
  80. package/{templates-experimental/hello-world-with-assets/py → templates/hello-world-durable-object-with-assets/js}/package.json +1 -1
  81. package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/public/index.html +1 -0
  82. package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/src/index.js +14 -13
  83. package/templates/hello-world-durable-object-with-assets/js/wrangler.jsonc +28 -0
  84. package/templates/hello-world-durable-object-with-assets/py/.python-version +1 -0
  85. package/templates/hello-world-durable-object-with-assets/py/README.md +23 -0
  86. package/{templates-experimental/hello-world-durable-object-with-assets/js → templates/hello-world-durable-object-with-assets/py}/package.json +1 -1
  87. package/{templates-experimental/hello-world-durable-object-with-assets/ts → templates/hello-world-durable-object-with-assets/py}/public/index.html +1 -0
  88. package/templates/hello-world-durable-object-with-assets/py/pyproject.toml +9 -0
  89. package/templates/hello-world-durable-object-with-assets/py/src/entry.py +66 -0
  90. package/templates/hello-world-durable-object-with-assets/py/uv.lock +22 -0
  91. package/templates/hello-world-durable-object-with-assets/py/wrangler.jsonc +31 -0
  92. package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/package.json +1 -1
  93. package/templates/hello-world-durable-object-with-assets/ts/public/index.html +20 -0
  94. package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/src/index.ts +13 -12
  95. package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/tsconfig.json +0 -2
  96. package/templates/hello-world-durable-object-with-assets/ts/wrangler.jsonc +28 -0
  97. package/templates/hello-world-with-assets/c3.ts +25 -0
  98. package/{templates-experimental → templates}/hello-world-with-assets/js/package.json +3 -3
  99. package/{templates-experimental/hello-world-with-assets/py → templates/hello-world-with-assets/js}/public/index.html +3 -2
  100. package/{templates-experimental → templates}/hello-world-with-assets/js/vitest.config.js +1 -1
  101. package/templates/hello-world-with-assets/js/wrangler.jsonc +16 -0
  102. package/templates/hello-world-with-assets/py/.python-version +1 -0
  103. package/templates/hello-world-with-assets/py/README.md +23 -0
  104. package/templates/hello-world-with-assets/py/__dot__gitignore +68 -0
  105. package/templates/hello-world-with-assets/py/package.json +13 -0
  106. package/{templates-experimental/hello-world-with-assets/js → templates/hello-world-with-assets/py}/public/index.html +3 -2
  107. package/templates/hello-world-with-assets/py/pyproject.toml +9 -0
  108. package/templates/hello-world-with-assets/py/src/entry.py +11 -0
  109. package/templates/hello-world-with-assets/py/uv.lock +22 -0
  110. package/templates/hello-world-with-assets/py/wrangler.jsonc +15 -0
  111. package/{templates-experimental → templates}/hello-world-with-assets/ts/package.json +3 -3
  112. package/{templates-experimental → templates}/hello-world-with-assets/ts/public/index.html +3 -2
  113. package/{templates-experimental → templates}/hello-world-with-assets/ts/src/index.ts +1 -1
  114. package/templates/hello-world-with-assets/ts/test/env.d.ts +3 -0
  115. package/templates/hello-world-with-assets/ts/test/tsconfig.json +8 -0
  116. package/{templates-experimental → templates}/hello-world-with-assets/ts/tsconfig.json +0 -2
  117. package/{templates-experimental → templates}/hello-world-with-assets/ts/vitest.config.mts +1 -1
  118. package/templates/hello-world-with-assets/ts/wrangler.jsonc +15 -0
  119. package/templates/hono/c3.ts +5 -65
  120. package/templates/hono/pages/c3.ts +47 -0
  121. package/templates/hono/pages/templates/src/index.tsx +12 -0
  122. package/templates/hono/pages/templates/wrangler.jsonc +8 -0
  123. package/{templates-experimental/hono → templates/hono/workers}/c3.ts +6 -5
  124. package/templates/hono/workers/templates/wrangler.jsonc +9 -0
  125. package/templates/next/c3.ts +7 -236
  126. package/templates/next/{README.md → pages/README.md} +3 -4
  127. package/templates/next/{app → pages/app}/js/app/api/hello/route.js +4 -4
  128. package/templates/next/{app → pages/app}/ts/app/api/hello/route.ts +4 -5
  129. package/templates/next/pages/c3.ts +221 -0
  130. package/templates/next/pages/wrangler.jsonc +8 -0
  131. package/templates/next/workers/c3.ts +71 -0
  132. package/templates/next/workers/templates/.dev.vars +2 -0
  133. package/{templates-experimental/next → templates/next/workers}/templates/__dot__gitignore +2 -5
  134. package/templates/next/workers/templates/open-next.config.ts +9 -0
  135. package/templates/next/workers/templates/wrangler.jsonc +13 -0
  136. package/templates/nuxt/c3.ts +5 -130
  137. package/templates/nuxt/pages/c3.ts +123 -0
  138. package/templates/nuxt/{templates → pages/templates}/env.d.ts +1 -1
  139. package/templates/nuxt/pages/templates/wrangler.jsonc +5 -0
  140. package/{templates-experimental/nuxt → templates/nuxt/workers}/c3.ts +17 -30
  141. package/{templates-experimental/nuxt → templates/nuxt/workers}/templates/env.d.ts +1 -1
  142. package/templates/nuxt/workers/templates/wrangler.jsonc +12 -0
  143. package/templates/openapi/c3.ts +5 -1
  144. package/templates/openapi/ts/__dot__gitignore +1 -0
  145. package/templates/openapi/ts/package.json +7 -6
  146. package/templates/openapi/ts/src/endpoints/taskCreate.ts +2 -2
  147. package/templates/openapi/ts/src/endpoints/taskDelete.ts +2 -2
  148. package/templates/openapi/ts/src/endpoints/taskFetch.ts +2 -2
  149. package/templates/openapi/ts/src/endpoints/taskList.ts +2 -2
  150. package/templates/openapi/ts/src/index.ts +4 -1
  151. package/templates/openapi/ts/src/types.ts +3 -0
  152. package/templates/openapi/ts/tsconfig.json +18 -21
  153. package/templates/openapi/ts/wrangler.jsonc +8 -0
  154. package/templates/pre-existing/c3.ts +9 -5
  155. package/templates/pre-existing/js/package.json +1 -1
  156. package/templates/queues/c3.ts +5 -1
  157. package/templates/queues/js/package.json +1 -1
  158. package/templates/queues/js/wrangler.jsonc +21 -0
  159. package/templates/queues/ts/package.json +1 -1
  160. package/templates/queues/ts/src/index.ts +1 -1
  161. package/templates/queues/ts/tsconfig.json +0 -2
  162. package/templates/queues/ts/wrangler.jsonc +21 -0
  163. package/templates/qwik/c3.ts +5 -143
  164. package/templates/qwik/pages/c3.ts +151 -0
  165. package/templates/qwik/pages/templates/worker-configuration.d.ts +4 -0
  166. package/templates/qwik/pages/templates/wrangler.jsonc +8 -0
  167. package/{templates-experimental/qwik → templates/qwik/workers}/c3.ts +8 -8
  168. package/templates/qwik/workers/templates/worker-configuration.d.ts +4 -0
  169. package/templates/qwik/workers/templates/wrangler.jsonc +16 -0
  170. package/templates/react/c3.ts +5 -57
  171. package/templates/react/pages/c3.ts +65 -0
  172. package/templates/react/pages/templates/wrangler.jsonc +5 -0
  173. package/templates/react/workers/c3.ts +183 -0
  174. package/templates/react/workers/js/src/App.css +45 -0
  175. package/templates/react/workers/js/src/App.jsx +58 -0
  176. package/templates/react/workers/js/src/assets/Cloudflare_Logo.svg +53 -0
  177. package/templates/react/workers/js/worker/index.js +13 -0
  178. package/templates/react/workers/js/wrangler.jsonc +9 -0
  179. package/templates/react/workers/ts/src/App.css +45 -0
  180. package/templates/react/workers/ts/src/App.tsx +58 -0
  181. package/templates/react/workers/ts/src/assets/Cloudflare_Logo.svg +51 -0
  182. package/templates/react/workers/ts/tsconfig.worker.json +8 -0
  183. package/templates/react/workers/ts/worker/index.ts +12 -0
  184. package/templates/react/workers/ts/wrangler.jsonc +9 -0
  185. package/templates/react-router/c3.ts +41 -0
  186. package/templates/remix/c3.ts +6 -63
  187. package/{templates-experimental/remix → templates/remix/pages}/c3.ts +7 -14
  188. package/templates/remix/pages/templates/wrangler.jsonc +5 -0
  189. package/templates/remix/workers/c3.ts +53 -0
  190. package/templates/remix/workers/templates/public/.assetsignore +0 -0
  191. package/{templates-experimental/remix → templates/remix/workers}/templates/wrangler.toml +2 -2
  192. package/templates/scheduled/c3.ts +5 -1
  193. package/templates/scheduled/js/package.json +1 -1
  194. package/templates/scheduled/js/src/index.js +1 -1
  195. package/templates/scheduled/js/wrangler.jsonc +13 -0
  196. package/templates/scheduled/ts/package.json +1 -1
  197. package/templates/scheduled/ts/src/index.ts +11 -4
  198. package/templates/scheduled/ts/tsconfig.json +0 -2
  199. package/templates/scheduled/ts/wrangler.jsonc +13 -0
  200. package/templates/solid/c3.ts +2 -1
  201. package/templates/solid/templates/wrangler.jsonc +8 -0
  202. package/templates/svelte/c3.ts +6 -128
  203. package/templates/svelte/pages/c3.ts +160 -0
  204. package/templates/svelte/pages/templates/wrangler.jsonc +5 -0
  205. package/{templates-experimental/svelte → templates/svelte/workers}/c3.ts +10 -13
  206. package/templates/svelte/workers/templates/static/.assetsignore +2 -0
  207. package/templates/svelte/workers/templates/wrangler.jsonc +12 -0
  208. package/templates/vue/c3.ts +5 -25
  209. package/templates/vue/pages/c3.ts +33 -0
  210. package/templates/vue/pages/templates/wrangler.jsonc +5 -0
  211. package/templates/vue/workers/c3.ts +98 -0
  212. package/templates/vue/workers/js/server/index.js +13 -0
  213. package/templates/vue/workers/js/src/App.vue +107 -0
  214. package/templates/vue/workers/js/src/components/HelloWorld.vue +47 -0
  215. package/templates/vue/workers/js/vite.config.js +21 -0
  216. package/templates/vue/workers/js/wrangler.jsonc +11 -0
  217. package/templates/vue/workers/ts/server/index.ts +12 -0
  218. package/templates/vue/workers/ts/src/App.vue +107 -0
  219. package/templates/vue/workers/ts/src/components/HelloWorld.vue +44 -0
  220. package/templates/vue/workers/ts/tsconfig.worker.json +8 -0
  221. package/templates/vue/workers/ts/vite.config.ts +21 -0
  222. package/templates/vue/workers/ts/wrangler.jsonc +11 -0
  223. package/templates-experimental/solid/c3.ts +9 -52
  224. package/templates-experimental/solid/templates/wrangler.jsonc +15 -0
  225. package/templates/analog/templates/worker-configuration.d.ts +0 -4
  226. package/templates/analog/templates/wrangler.toml +0 -85
  227. package/templates/angular/templates/server.ts +0 -34
  228. package/templates/angular/templates/tools/alter-polyfills.mjs +0 -27
  229. package/templates/angular/templates/tools/copy-files.mjs +0 -9
  230. package/templates/angular/templates/tools/paths.mjs +0 -9
  231. package/templates/astro/templates/wrangler.toml +0 -85
  232. package/templates/common/js/wrangler.toml +0 -113
  233. package/templates/common/ts/worker-configuration.d.ts +0 -4
  234. package/templates/common/ts/wrangler.toml +0 -113
  235. package/templates/hello-world/js/wrangler.toml +0 -114
  236. package/templates/hello-world/py/wrangler.toml +0 -114
  237. package/templates/hello-world/ts/worker-configuration.d.ts +0 -4
  238. package/templates/hello-world/ts/wrangler.toml +0 -114
  239. package/templates/hello-world-durable-object/js/wrangler.toml +0 -113
  240. package/templates/hello-world-durable-object/ts/worker-configuration.d.ts +0 -5
  241. package/templates/hello-world-durable-object/ts/wrangler.toml +0 -113
  242. package/templates/hono/snippets/appDeclaration.ts +0 -1
  243. package/templates/hono/templates/worker-configuration.d.ts +0 -4
  244. package/templates/hono/templates/wrangler.toml +0 -113
  245. package/templates/next/env.d.ts +0 -5
  246. package/templates/next/wrangler.toml +0 -86
  247. package/templates/nuxt/templates/worker-configuration.d.ts +0 -4
  248. package/templates/nuxt/templates/wrangler.toml +0 -86
  249. package/templates/openapi/ts/worker-configuration.d.ts +0 -4
  250. package/templates/openapi/ts/wrangler.toml +0 -113
  251. package/templates/pre-existing/js/wrangler.toml +0 -4
  252. package/templates/queues/js/wrangler.toml +0 -118
  253. package/templates/queues/ts/worker-configuration.d.ts +0 -5
  254. package/templates/queues/ts/wrangler.toml +0 -118
  255. package/templates/qwik/templates/worker-configuration.d.ts +0 -4
  256. package/templates/qwik/templates/wrangler.toml +0 -86
  257. package/templates/remix/templates/worker-configuration.d.ts +0 -4
  258. package/templates/remix/templates/wrangler.toml +0 -85
  259. package/templates/scheduled/js/wrangler.toml +0 -119
  260. package/templates/scheduled/ts/worker-configuration.d.ts +0 -4
  261. package/templates/scheduled/ts/wrangler.toml +0 -119
  262. package/templates/solid/templates/wrangler.toml +0 -84
  263. package/templates/svelte/js/wrangler.toml +0 -85
  264. package/templates/svelte/ts/wrangler.toml +0 -85
  265. package/templates-experimental/angular/templates/server.ts +0 -34
  266. package/templates-experimental/angular/templates/tools/alter-polyfills.mjs +0 -32
  267. package/templates-experimental/angular/templates/wrangler.toml +0 -11
  268. package/templates-experimental/astro/templates/wrangler.toml +0 -12
  269. package/templates-experimental/docusaurus/templates/wrangler.toml +0 -10
  270. package/templates-experimental/gatsby/templates/wrangler.toml +0 -10
  271. package/templates-experimental/hello-world-assets-only/templates/wrangler.toml +0 -10
  272. package/templates-experimental/hello-world-durable-object-with-assets/js/wrangler.toml +0 -24
  273. package/templates-experimental/hello-world-durable-object-with-assets/ts/worker-configuration.d.ts +0 -5
  274. package/templates-experimental/hello-world-durable-object-with-assets/ts/wrangler.toml +0 -24
  275. package/templates-experimental/hello-world-with-assets/c3.ts +0 -22
  276. package/templates-experimental/hello-world-with-assets/js/wrangler.toml +0 -12
  277. package/templates-experimental/hello-world-with-assets/py/src/entry.py +0 -9
  278. package/templates-experimental/hello-world-with-assets/py/wrangler.toml +0 -12
  279. package/templates-experimental/hello-world-with-assets/ts/test/tsconfig.json +0 -8
  280. package/templates-experimental/hello-world-with-assets/ts/wrangler.toml +0 -12
  281. package/templates-experimental/hono/templates/worker-configuration.d.ts +0 -4
  282. package/templates-experimental/hono/templates/wrangler.toml +0 -5
  283. package/templates-experimental/next/c3.ts +0 -52
  284. package/templates-experimental/next/templates/env.d.ts +0 -5
  285. package/templates-experimental/next/templates/wrangler.toml +0 -12
  286. package/templates-experimental/nuxt/templates/cloudflare-preset/nitro.config.ts +0 -27
  287. package/templates-experimental/nuxt/templates/wrangler.toml +0 -11
  288. package/templates-experimental/qwik/templates/public/.assetsignore +0 -4
  289. package/templates-experimental/qwik/templates/worker-configuration.d.ts +0 -4
  290. package/templates-experimental/qwik/templates/wrangler.toml +0 -12
  291. package/templates-experimental/remix/templates/public/.assetsignore +0 -4
  292. package/templates-experimental/remix/templates/worker-configuration.d.ts +0 -4
  293. package/templates-experimental/solid/templates/wrangler.toml +0 -12
  294. package/templates-experimental/svelte/js/static/.assetsignore +0 -4
  295. package/templates-experimental/svelte/js/wrangler.toml +0 -11
  296. package/templates-experimental/svelte/ts/static/.assetsignore +0 -4
  297. package/templates-experimental/svelte/ts/wrangler.toml +0 -11
  298. /package/templates/angular/{templates → pages/templates}/src/_routes.json +0 -0
  299. /package/{templates-experimental/astro/snippets/runtimeDeclaration.ts → templates/astro/pages/templates/ts/src/env.d.ts} +0 -0
  300. /package/templates/astro/{snippets/runtimeDeclaration.ts → workers/templates/ts/src/env.d.ts} +0 -0
  301. /package/{templates-experimental → templates}/hello-world-assets-only/templates/package.json +0 -0
  302. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/.editorconfig +0 -0
  303. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/.prettierrc +0 -0
  304. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/__dot__gitignore +0 -0
  305. /package/{templates-experimental/hello-world-with-assets → templates/hello-world-durable-object-with-assets}/py/__dot__gitignore +0 -0
  306. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/.editorconfig +0 -0
  307. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/.prettierrc +0 -0
  308. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/__dot__gitignore +0 -0
  309. /package/{templates-experimental → templates}/hello-world-with-assets/js/.editorconfig +0 -0
  310. /package/{templates-experimental → templates}/hello-world-with-assets/js/.prettierrc +0 -0
  311. /package/{templates-experimental → templates}/hello-world-with-assets/js/__dot__gitignore +0 -0
  312. /package/{templates-experimental → templates}/hello-world-with-assets/js/src/index.js +0 -0
  313. /package/{templates-experimental → templates}/hello-world-with-assets/js/test/index.spec.js +0 -0
  314. /package/{templates-experimental → templates}/hello-world-with-assets/ts/.editorconfig +0 -0
  315. /package/{templates-experimental → templates}/hello-world-with-assets/ts/.prettierrc +0 -0
  316. /package/{templates-experimental → templates}/hello-world-with-assets/ts/__dot__gitignore +0 -0
  317. /package/{templates-experimental → templates}/hello-world-with-assets/ts/test/index.spec.ts +0 -0
  318. /package/{templates-experimental/hono → templates/hono/workers}/templates/public/index.html +0 -0
  319. /package/{templates-experimental/hono → templates/hono/workers}/templates/src/index.ts +0 -0
  320. /package/templates/next/{app → pages/app}/js/app/not-found.js +0 -0
  321. /package/templates/next/{app → pages/app}/ts/app/not-found.tsx +0 -0
  322. /package/templates/next/pages/{js → pages/js}/pages/api/hello.js +0 -0
  323. /package/templates/next/pages/{ts → pages/ts}/pages/api/hello.ts +0 -0
  324. /package/{templates-experimental/qwik → templates/qwik/pages}/snippets/getPlatformProxy.ts +0 -0
  325. /package/templates/qwik/{snippets → workers/snippets}/getPlatformProxy.ts +0 -0
  326. /package/{templates-experimental/astro → templates/qwik/workers}/templates/public/.assetsignore +0 -0
  327. /package/{templates-experimental/hello-world-with-assets/ts → templates/remix/pages/templates}/worker-configuration.d.ts +0 -0
  328. /package/{templates-experimental/nuxt → templates/remix/workers}/templates/worker-configuration.d.ts +0 -0
@@ -0,0 +1,151 @@
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
+ workersTypes: "installed",
150
+ };
151
+ export default config;
@@ -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
+ }
@@ -1,4 +1,4 @@
1
- import { crash, endSection } from "@cloudflare/cli";
1
+ import { endSection } from "@cloudflare/cli";
2
2
  import { brandColor } from "@cloudflare/cli/colors";
3
3
  import { spinner } from "@cloudflare/cli/interactive";
4
4
  import { runFrameworkGenerator } from "frameworks/index";
@@ -7,10 +7,10 @@ import { quoteShellArgs, runCommand } from "helpers/command";
7
7
  import { removeFile, usesTypescript } from "helpers/files";
8
8
  import { detectPackageManager } from "helpers/packageManagers";
9
9
  import * as recast from "recast";
10
- import type { TemplateConfig } from "../../src/templates";
10
+ import type { TemplateConfig } from "../../../src/templates";
11
11
  import type { C3Context } from "types";
12
12
 
13
- const { npm, npx } = detectPackageManager();
13
+ const { npm, npx, name } = detectPackageManager();
14
14
 
15
15
  const generate = async (ctx: C3Context) => {
16
16
  await runFrameworkGenerator(ctx, ["playground", ctx.project.name]);
@@ -18,13 +18,12 @@ const generate = async (ctx: C3Context) => {
18
18
 
19
19
  const configure = async (ctx: C3Context) => {
20
20
  // Add the pages integration
21
- const cmd = [npx, "qwik", "add", "cloudflare-pages"];
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"];
22
23
  endSection(`Running ${quoteShellArgs(cmd)}`);
23
24
  await runCommand(cmd);
24
25
 
25
26
  // Remove the extraneous Pages files
26
- removeFile("./public/_headers");
27
- removeFile("./public/_redirects");
28
27
  removeFile("./public/_routes.json");
29
28
 
30
29
  addBindingsProxy(ctx);
@@ -80,7 +79,7 @@ const addBindingsProxy = (ctx: C3Context) => {
80
79
  }
81
80
 
82
81
  if (configArgument.type !== "ObjectExpression") {
83
- crash("Failed to update `vite.config.ts`");
82
+ throw new Error("Failed to update `vite.config.ts`");
84
83
  }
85
84
 
86
85
  // Add the `platform` object to the object
@@ -136,7 +135,7 @@ const config: TemplateConfig = {
136
135
  copyFiles: {
137
136
  path: "./templates",
138
137
  },
139
- path: "templates-experimental/qwik",
138
+ path: "templates/qwik/workers",
140
139
  generate,
141
140
  configure,
142
141
  transformPackageJson: async () => ({
@@ -149,5 +148,6 @@ const config: TemplateConfig = {
149
148
  devScript: "dev",
150
149
  deployScript: "deploy",
151
150
  previewScript: "preview",
151
+ workersTypes: "installed",
152
152
  };
153
153
  export default config;
@@ -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,16 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "main": "./dist/_worker.js",
4
+ "compatibility_date": "<TBD>",
5
+ "compatibility_flags": [
6
+ "nodejs_compat",
7
+ "global_fetch_strictly_public"
8
+ ],
9
+ "assets": {
10
+ "binding": "ASSET",
11
+ "directory": "./dist"
12
+ },
13
+ "observability": {
14
+ "enabled": true
15
+ }
16
+ }
@@ -1,61 +1,9 @@
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";
1
+ import pages from "./pages/c3";
2
+ import workers from "./workers/c3";
3
+ import type { MultiPlatformTemplateConfig } from "../../src/templates";
7
4
 
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",
5
+ const config: MultiPlatformTemplateConfig = {
48
6
  displayName: "React",
49
- platform: "pages",
50
- generate,
51
- transformPackageJson: async () => ({
52
- scripts: {
53
- deploy: `${npm} run build && wrangler pages deploy ./dist`,
54
- preview: `${npm} run build && wrangler pages dev ./dist`,
55
- },
56
- }),
57
- devScript: "dev",
58
- deployScript: "deploy",
59
- previewScript: "preview",
7
+ platformVariants: { pages, workers },
60
8
  };
61
9
  export default config;
@@ -0,0 +1,65 @@
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
+ copyFiles: { path: "./templates" },
53
+ generate,
54
+ transformPackageJson: async () => ({
55
+ scripts: {
56
+ deploy: `${npm} run build && wrangler pages deploy`,
57
+ preview: `${npm} run build && wrangler pages dev`,
58
+ "cf-typegen": `wrangler types`,
59
+ },
60
+ }),
61
+ devScript: "dev",
62
+ deployScript: "deploy",
63
+ previewScript: "preview",
64
+ };
65
+ export default config;
@@ -0,0 +1,5 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "compatibility_date": "<TBD>",
4
+ "pages_build_output_dir": "./dist"
5
+ }
@@ -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
+ 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
+ }
@@ -0,0 +1,58 @@
1
+ import { useState } from 'react'
2
+ import reactLogo from './assets/react.svg'
3
+ import viteLogo from '/vite.svg'
4
+ import cloudflareLogo from './assets/Cloudflare_Logo.svg'
5
+ import './App.css'
6
+
7
+ function App() {
8
+ const [count, setCount] = useState(0)
9
+ const [name, setName] = useState('unknown')
10
+
11
+ return (
12
+ <>
13
+ <div>
14
+ <a href='https://vite.dev' target='_blank'>
15
+ <img src={viteLogo} className='logo' alt='Vite logo' />
16
+ </a>
17
+ <a href='https://react.dev' target='_blank'>
18
+ <img src={reactLogo} className='logo react' alt='React logo' />
19
+ </a>
20
+ <a href='https://workers.cloudflare.com/' target='_blank'>
21
+ <img src={cloudflareLogo} className='logo cloudflare' alt='Cloudflare logo' />
22
+ </a>
23
+ </div>
24
+ <h1>Vite + React + Cloudflare</h1>
25
+ <div className='card'>
26
+ <button
27
+ onClick={() => setCount((count) => count + 1)}
28
+ aria-label='increment'
29
+ >
30
+ count is {count}
31
+ </button>
32
+ <p>
33
+ Edit <code>src/App.tsx</code> and save to test HMR
34
+ </p>
35
+ </div>
36
+ <div className='card'>
37
+ <button
38
+ onClick={() => {
39
+ fetch('/api/')
40
+ .then((res) => res.json())
41
+ .then((data) => setName(data.name))
42
+ }}
43
+ aria-label='get name'
44
+ >
45
+ Name from API is: {name}
46
+ </button>
47
+ <p>
48
+ Edit <code>worker/index.js</code> to change the name
49
+ </p>
50
+ </div>
51
+ <p className='read-the-docs'>
52
+ Click on the Vite and React logos to learn more
53
+ </p>
54
+ </>
55
+ )
56
+ }
57
+
58
+ export default App