create-cloudflare 0.0.0-e6ada079 → 0.0.0-e6fea1318
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/README.md +1 -1
- package/dist/cli.js +42462 -40996
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +21 -12
- package/templates/analog/c3.ts +1 -0
- package/templates/analog/templates/worker-configuration.d.ts +1 -1
- package/templates/analog/templates/wrangler.jsonc +5 -0
- package/templates/angular/c3.ts +5 -97
- package/templates/angular/pages/c3.ts +134 -0
- package/templates/angular/pages/templates/src/server.ts +15 -0
- package/templates/angular/pages/templates/tools/copy-files.mjs +15 -0
- package/templates/angular/workers/c3.ts +130 -0
- package/templates/angular/workers/templates/src/server.ts +15 -0
- package/templates/angular/workers/templates/wrangler.jsonc +12 -0
- package/templates/astro/c3.ts +5 -108
- package/templates/astro/pages/c3.ts +98 -0
- package/templates/astro/pages/templates/js/wrangler.jsonc +8 -0
- package/templates/astro/pages/templates/ts/worker-configuration.d.ts +4 -0
- package/templates/astro/pages/templates/ts/wrangler.jsonc +8 -0
- package/templates/astro/workers/c3.ts +98 -0
- package/templates/astro/workers/templates/js/public/.assetsignore +2 -0
- package/templates/astro/workers/templates/js/wrangler.jsonc +15 -0
- package/templates/astro/workers/templates/ts/public/.assetsignore +2 -0
- package/templates/astro/workers/templates/ts/src/env.d.ts +5 -0
- package/templates/astro/workers/templates/ts/worker-configuration.d.ts +4 -0
- package/templates/astro/workers/templates/ts/wrangler.jsonc +15 -0
- package/templates/common/c3.ts +8 -1
- package/templates/common/js/package.json +1 -1
- package/templates/common/js/wrangler.jsonc +8 -0
- package/templates/common/ts/package.json +1 -1
- package/templates/common/ts/src/index.ts +1 -1
- package/templates/common/ts/tsconfig.json +37 -95
- package/templates/common/ts/worker-configuration.d.ts +1 -1
- package/templates/common/ts/wrangler.jsonc +8 -0
- package/templates/docusaurus/c3.ts +5 -22
- package/templates/docusaurus/pages/c3.ts +30 -0
- package/templates/docusaurus/workers/c3.ts +33 -0
- package/templates/docusaurus/workers/templates/wrangler.jsonc +10 -0
- package/templates/gatsby/c3.ts +5 -44
- package/templates/gatsby/pages/c3.ts +50 -0
- package/templates/gatsby/workers/c3.ts +53 -0
- package/templates/gatsby/workers/templates/wrangler.jsonc +10 -0
- package/templates/hello-world/c3.ts +23 -2
- package/templates/hello-world/js/package.json +3 -3
- package/templates/hello-world/js/test/index.spec.js +1 -1
- package/templates/hello-world/js/vitest.config.js +1 -1
- package/templates/hello-world/js/wrangler.jsonc +8 -0
- package/templates/hello-world/py/.python-version +1 -0
- package/templates/hello-world/py/README.md +23 -0
- package/templates/hello-world/py/__dot__gitignore +68 -0
- package/templates/hello-world/py/package.json +13 -0
- package/templates/hello-world/py/pyproject.toml +9 -0
- package/templates/hello-world/py/uv.lock +22 -0
- package/templates/hello-world/py/wrangler.jsonc +9 -0
- package/templates/hello-world/ts/package.json +3 -3
- package/templates/hello-world/ts/src/index.ts +1 -1
- package/templates/hello-world/ts/test/env.d.ts +3 -0
- package/templates/hello-world/ts/test/tsconfig.json +1 -1
- package/templates/hello-world/ts/tsconfig.json +36 -95
- package/templates/hello-world/ts/vitest.config.mts +1 -1
- package/templates/hello-world/ts/worker-configuration.d.ts +7 -3
- package/templates/hello-world/ts/wrangler.jsonc +8 -0
- package/templates/hello-world-assets-only/c3.ts +16 -0
- package/templates/{hello-world-python/py → hello-world-assets-only/templates}/package.json +1 -1
- package/templates/hello-world-assets-only/templates/public/index.html +11 -0
- package/templates/hello-world-assets-only/templates/wrangler.jsonc +10 -0
- package/templates/hello-world-durable-object/c3.ts +7 -2
- package/templates/hello-world-durable-object/js/package.json +1 -1
- package/templates/hello-world-durable-object/js/src/index.js +13 -12
- package/templates/hello-world-durable-object/js/wrangler.jsonc +24 -0
- package/templates/hello-world-durable-object/ts/package.json +1 -1
- package/templates/hello-world-durable-object/ts/src/index.ts +14 -34
- package/templates/hello-world-durable-object/ts/tsconfig.json +36 -95
- package/templates/hello-world-durable-object/ts/worker-configuration.d.ts +6 -5
- package/templates/hello-world-durable-object/ts/wrangler.jsonc +24 -0
- package/templates/hello-world-durable-object-with-assets/c3.ts +23 -0
- package/templates/hello-world-durable-object-with-assets/js/.editorconfig +12 -0
- package/templates/hello-world-durable-object-with-assets/js/.prettierrc +6 -0
- package/templates/hello-world-durable-object-with-assets/js/__dot__gitignore +172 -0
- package/templates/hello-world-durable-object-with-assets/js/package.json +13 -0
- package/templates/hello-world-durable-object-with-assets/js/public/index.html +19 -0
- package/templates/hello-world-durable-object-with-assets/js/src/index.js +70 -0
- package/templates/hello-world-durable-object-with-assets/js/wrangler.jsonc +28 -0
- package/templates/hello-world-durable-object-with-assets/ts/.editorconfig +12 -0
- package/templates/hello-world-durable-object-with-assets/ts/.prettierrc +6 -0
- package/templates/hello-world-durable-object-with-assets/ts/__dot__gitignore +172 -0
- package/templates/hello-world-durable-object-with-assets/ts/package.json +15 -0
- package/templates/hello-world-durable-object-with-assets/ts/public/index.html +19 -0
- package/templates/hello-world-durable-object-with-assets/ts/src/index.ts +67 -0
- package/templates/hello-world-durable-object-with-assets/ts/tsconfig.json +42 -0
- package/templates/hello-world-durable-object-with-assets/ts/worker-configuration.d.ts +8 -0
- package/templates/hello-world-durable-object-with-assets/ts/wrangler.jsonc +28 -0
- package/templates/hello-world-with-assets/c3.ts +24 -0
- package/templates/hello-world-with-assets/js/.editorconfig +12 -0
- package/templates/hello-world-with-assets/js/.prettierrc +6 -0
- package/templates/hello-world-with-assets/js/__dot__gitignore +172 -0
- package/templates/hello-world-with-assets/js/package.json +16 -0
- package/templates/hello-world-with-assets/js/public/index.html +31 -0
- package/templates/hello-world-with-assets/js/src/index.js +23 -0
- package/templates/hello-world-with-assets/js/test/index.spec.js +41 -0
- package/templates/hello-world-with-assets/js/vitest.config.js +11 -0
- package/templates/hello-world-with-assets/js/wrangler.jsonc +15 -0
- package/templates/hello-world-with-assets/py/package.json +13 -0
- package/templates/hello-world-with-assets/py/public/index.html +31 -0
- package/templates/hello-world-with-assets/py/src/entry.py +9 -0
- package/templates/hello-world-with-assets/py/wrangler.jsonc +15 -0
- package/templates/hello-world-with-assets/ts/.editorconfig +12 -0
- package/templates/hello-world-with-assets/ts/.prettierrc +6 -0
- package/templates/hello-world-with-assets/ts/__dot__gitignore +172 -0
- package/templates/hello-world-with-assets/ts/package.json +18 -0
- package/templates/hello-world-with-assets/ts/public/index.html +31 -0
- package/templates/hello-world-with-assets/ts/src/index.ts +26 -0
- package/templates/hello-world-with-assets/ts/test/env.d.ts +3 -0
- package/templates/hello-world-with-assets/ts/test/index.spec.ts +41 -0
- package/templates/hello-world-with-assets/ts/test/tsconfig.json +8 -0
- package/templates/hello-world-with-assets/ts/tsconfig.json +44 -0
- package/templates/hello-world-with-assets/ts/vitest.config.mts +11 -0
- package/templates/hello-world-with-assets/ts/worker-configuration.d.ts +7 -0
- package/templates/hello-world-with-assets/ts/wrangler.jsonc +15 -0
- package/templates/hono/c3.ts +5 -74
- package/templates/hono/pages/c3.ts +42 -0
- package/templates/hono/pages/templates/src/index.tsx +12 -0
- package/templates/hono/pages/templates/worker-configuration.d.ts +4 -0
- package/templates/hono/pages/templates/wrangler.jsonc +9 -0
- package/templates/hono/workers/c3.ts +42 -0
- package/templates/hono/workers/templates/public/index.html +19 -0
- package/templates/hono/workers/templates/src/index.ts +9 -0
- package/templates/hono/workers/templates/worker-configuration.d.ts +4 -0
- package/templates/hono/workers/templates/wrangler.jsonc +9 -0
- package/templates/next/README.md +3 -4
- package/templates/next/app/js/app/api/hello/route.js +4 -4
- package/templates/next/app/ts/app/api/hello/route.ts +4 -5
- package/templates/next/c3.ts +22 -37
- package/templates/next/wrangler.jsonc +8 -0
- package/templates/nuxt/c3.ts +5 -129
- package/templates/nuxt/pages/c3.ts +146 -0
- package/templates/nuxt/pages/templates/worker-configuration.d.ts +4 -0
- package/templates/nuxt/pages/templates/wrangler.jsonc +5 -0
- package/templates/nuxt/workers/c3.ts +146 -0
- package/templates/nuxt/workers/templates/env.d.ts +14 -0
- package/templates/nuxt/workers/templates/worker-configuration.d.ts +4 -0
- package/templates/nuxt/workers/templates/wrangler.jsonc +12 -0
- package/templates/openapi/c3.ts +6 -1
- package/templates/openapi/ts/package.json +1 -1
- package/templates/openapi/ts/worker-configuration.d.ts +1 -1
- package/templates/openapi/ts/wrangler.jsonc +8 -0
- package/templates/pre-existing/c3.ts +36 -13
- package/templates/pre-existing/js/package.json +1 -1
- package/templates/queues/c3.ts +7 -1
- package/templates/queues/js/package.json +1 -1
- package/templates/queues/js/wrangler.jsonc +21 -0
- package/templates/queues/ts/package.json +1 -1
- package/templates/queues/ts/src/index.ts +1 -1
- package/templates/queues/ts/tsconfig.json +36 -95
- package/templates/queues/ts/worker-configuration.d.ts +1 -1
- package/templates/queues/ts/wrangler.jsonc +21 -0
- package/templates/qwik/c3.ts +5 -142
- package/templates/qwik/pages/c3.ts +149 -0
- package/templates/qwik/pages/templates/worker-configuration.d.ts +4 -0
- package/templates/qwik/pages/templates/wrangler.jsonc +8 -0
- package/templates/qwik/workers/c3.ts +154 -0
- package/templates/qwik/workers/snippets/getPlatformProxy.ts +6 -0
- package/templates/qwik/workers/templates/public/.assetsignore +4 -0
- package/templates/qwik/workers/templates/worker-configuration.d.ts +4 -0
- package/templates/qwik/workers/templates/wrangler.jsonc +15 -0
- package/templates/react/c3.ts +5 -27
- package/templates/react/pages/c3.ts +62 -0
- package/templates/react/workers/c3.ts +183 -0
- package/templates/react/workers/js/api/index.js +13 -0
- package/templates/react/workers/js/src/App.css +45 -0
- package/templates/react/workers/js/src/App.jsx +58 -0
- package/templates/react/workers/js/src/assets/Cloudflare_Logo.svg +53 -0
- package/templates/react/workers/js/wrangler.jsonc +9 -0
- package/templates/react/workers/ts/api/index.ts +13 -0
- package/templates/react/workers/ts/src/App.css +45 -0
- package/templates/react/workers/ts/src/App.tsx +58 -0
- package/templates/react/workers/ts/src/assets/Cloudflare_Logo.svg +51 -0
- package/templates/react/workers/ts/tsconfig.worker.json +8 -0
- package/templates/react/workers/ts/worker-configuration.d.ts +5 -0
- package/templates/react/workers/ts/wrangler.jsonc +9 -0
- package/templates/react-router/c3.ts +53 -0
- package/templates/react-router/templates/worker-configuration.d.ts +8 -0
- package/templates/remix/c3.ts +6 -62
- package/templates/remix/pages/c3.ts +68 -0
- package/templates/remix/pages/templates/worker-configuration.d.ts +4 -0
- package/templates/remix/pages/templates/wrangler.jsonc +5 -0
- package/templates/remix/workers/c3.ts +52 -0
- package/templates/remix/workers/templates/public/.assetsignore +0 -0
- package/templates/remix/workers/templates/wrangler.toml +11 -0
- package/templates/scheduled/c3.ts +7 -1
- package/templates/scheduled/js/package.json +1 -1
- package/templates/scheduled/js/src/index.js +1 -1
- package/templates/scheduled/js/wrangler.jsonc +13 -0
- package/templates/scheduled/ts/package.json +1 -1
- package/templates/scheduled/ts/src/index.ts +4 -4
- package/templates/scheduled/ts/tsconfig.json +36 -95
- package/templates/scheduled/ts/worker-configuration.d.ts +1 -1
- package/templates/scheduled/ts/wrangler.jsonc +13 -0
- package/templates/solid/c3.ts +2 -1
- package/templates/solid/templates/wrangler.jsonc +8 -0
- package/templates/svelte/c3.ts +6 -127
- package/templates/svelte/pages/c3.ts +159 -0
- package/templates/svelte/pages/templates/wrangler.jsonc +5 -0
- package/templates/svelte/workers/c3.ts +129 -0
- package/templates/svelte/workers/templates/static/.assetsignore +2 -0
- package/templates/svelte/workers/templates/wrangler.jsonc +12 -0
- package/templates/vue/c3.ts +5 -24
- package/templates/vue/pages/c3.ts +30 -0
- package/templates/vue/workers/c3.ts +98 -0
- package/templates/vue/workers/js/server/index.js +13 -0
- package/templates/vue/workers/js/src/App.vue +107 -0
- package/templates/vue/workers/js/src/components/HelloWorld.vue +47 -0
- package/templates/vue/workers/js/vite.config.js +21 -0
- package/templates/vue/workers/js/wrangler.jsonc +12 -0
- package/templates/vue/workers/ts/server/index.ts +13 -0
- package/templates/vue/workers/ts/src/App.vue +107 -0
- package/templates/vue/workers/ts/src/components/HelloWorld.vue +44 -0
- package/templates/vue/workers/ts/tsconfig.worker.json +8 -0
- package/templates/vue/workers/ts/vite.config.ts +21 -0
- package/templates/vue/workers/ts/worker-configuration.d.ts +6 -0
- package/templates/vue/workers/ts/wrangler.jsonc +12 -0
- package/templates-experimental/next/c3.ts +75 -0
- package/templates-experimental/next/templates/.dev.vars +2 -0
- package/templates-experimental/next/templates/__dot__gitignore +39 -0
- package/templates-experimental/next/templates/cloudflare-env.d.ts +5 -0
- package/templates-experimental/next/templates/open-next.config.ts +6 -0
- package/templates-experimental/next/templates/wrangler.jsonc +12 -0
- package/templates-experimental/solid/c3.ts +94 -0
- package/templates-experimental/solid/templates/wrangler.jsonc +15 -0
- package/templates/analog/templates/wrangler.toml +0 -85
- package/templates/angular/templates/server.ts +0 -34
- package/templates/angular/templates/tools/alter-polyfills.mjs +0 -27
- package/templates/angular/templates/tools/copy-files.mjs +0 -9
- package/templates/angular/templates/tools/paths.mjs +0 -9
- package/templates/astro/templates/wrangler.toml +0 -85
- package/templates/common/js/wrangler.toml +0 -107
- package/templates/common/ts/wrangler.toml +0 -107
- package/templates/hello-world/js/wrangler.toml +0 -108
- package/templates/hello-world/ts/wrangler.toml +0 -108
- package/templates/hello-world-durable-object/js/wrangler.toml +0 -107
- package/templates/hello-world-durable-object/ts/wrangler.toml +0 -107
- package/templates/hello-world-python/c3.ts +0 -9
- package/templates/hello-world-python/py/wrangler.toml +0 -108
- package/templates/hono/snippets/appDeclaration.ts +0 -1
- package/templates/hono/snippets/bindingsType.ts +0 -3
- package/templates/hono/templates/worker-configuration.d.ts +0 -4
- package/templates/hono/templates/wrangler.toml +0 -107
- package/templates/next/wrangler.toml +0 -86
- package/templates/nuxt/templates/wrangler.toml +0 -85
- package/templates/openapi/ts/wrangler.toml +0 -107
- package/templates/pre-existing/js/wrangler.toml +0 -4
- package/templates/queues/js/wrangler.toml +0 -112
- package/templates/queues/ts/wrangler.toml +0 -112
- package/templates/qwik/templates/worker-configuration.d.ts +0 -4
- package/templates/qwik/templates/wrangler.toml +0 -85
- package/templates/remix/templates/worker-configuration.d.ts +0 -4
- package/templates/remix/templates/wrangler.toml +0 -85
- package/templates/scheduled/js/wrangler.toml +0 -113
- package/templates/scheduled/ts/wrangler.toml +0 -113
- package/templates/solid/templates/wrangler.toml +0 -84
- package/templates/svelte/js/wrangler.toml +0 -85
- package/templates/svelte/ts/wrangler.toml +0 -85
- /package/templates/angular/{templates → pages/templates}/src/_routes.json +0 -0
- /package/templates/astro/{snippets/runtimeDeclaration.ts → pages/templates/ts/src/env.d.ts} +0 -0
- /package/templates/{hello-world-python → hello-world}/py/src/entry.py +0 -0
- /package/templates/{hello-world-python → hello-world-with-assets}/py/__dot__gitignore +0 -0
- /package/templates/nuxt/{templates → pages/templates}/env.d.ts +0 -0
- /package/templates/qwik/{snippets → pages/snippets}/getPlatformProxy.ts +0 -0
- /package/templates/{nuxt → remix/workers}/templates/worker-configuration.d.ts +0 -0
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { RouterLink, RouterView } from 'vue-router'
|
|
3
|
+
import HelloWorld from './components/HelloWorld.vue'
|
|
4
|
+
import { ref } from 'vue'
|
|
5
|
+
|
|
6
|
+
const name = ref('Unknown')
|
|
7
|
+
|
|
8
|
+
const getName = async () => {
|
|
9
|
+
const res = await fetch('/api/')
|
|
10
|
+
const data = await res.json()
|
|
11
|
+
name.value = data.name
|
|
12
|
+
}
|
|
13
|
+
</script>
|
|
14
|
+
|
|
15
|
+
<template>
|
|
16
|
+
<header>
|
|
17
|
+
<img alt="Vue logo" class="logo" src="@/assets/logo.svg" width="125" height="125" />
|
|
18
|
+
|
|
19
|
+
<div class="wrapper">
|
|
20
|
+
<HelloWorld msg="You did it!" />
|
|
21
|
+
<button class="green" @click="getName" aria-label="get name">
|
|
22
|
+
Name from API is: {{ name }}
|
|
23
|
+
</button>
|
|
24
|
+
<p>Edit <code>server/index.js</code> to change what the API gets</p>
|
|
25
|
+
<nav>
|
|
26
|
+
<RouterLink to="/">Home</RouterLink>
|
|
27
|
+
<RouterLink to="/about">About</RouterLink>
|
|
28
|
+
</nav>
|
|
29
|
+
</div>
|
|
30
|
+
</header>
|
|
31
|
+
|
|
32
|
+
<RouterView />
|
|
33
|
+
</template>
|
|
34
|
+
|
|
35
|
+
<style scoped>
|
|
36
|
+
header {
|
|
37
|
+
line-height: 1.5;
|
|
38
|
+
max-height: 100vh;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
.logo {
|
|
42
|
+
display: block;
|
|
43
|
+
margin: 0 auto 2rem;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
nav {
|
|
47
|
+
width: 100%;
|
|
48
|
+
font-size: 12px;
|
|
49
|
+
text-align: center;
|
|
50
|
+
margin-top: 2rem;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
nav a.router-link-exact-active {
|
|
54
|
+
color: var(--color-text);
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
nav a.router-link-exact-active:hover {
|
|
58
|
+
background-color: transparent;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
nav a {
|
|
62
|
+
display: inline-block;
|
|
63
|
+
padding: 0 1rem;
|
|
64
|
+
border-left: 1px solid var(--color-border);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
nav a:first-of-type {
|
|
68
|
+
border: 0;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
button {
|
|
72
|
+
background-color: hsla(160, 100%, 37%, 1);
|
|
73
|
+
color: var(--color-background);
|
|
74
|
+
border: 0;
|
|
75
|
+
padding: 0.5rem 1rem;
|
|
76
|
+
border-radius: 0.25rem;
|
|
77
|
+
cursor: pointer;
|
|
78
|
+
margin: 1rem 0 0.5rem 0;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
@media (min-width: 1024px) {
|
|
82
|
+
header {
|
|
83
|
+
display: flex;
|
|
84
|
+
place-items: center;
|
|
85
|
+
padding-right: calc(var(--section-gap) / 2);
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
.logo {
|
|
89
|
+
margin: 0 2rem 0 0;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
header .wrapper {
|
|
93
|
+
display: flex;
|
|
94
|
+
place-items: flex-start;
|
|
95
|
+
flex-wrap: wrap;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
nav {
|
|
99
|
+
text-align: left;
|
|
100
|
+
margin-left: -1rem;
|
|
101
|
+
font-size: 1rem;
|
|
102
|
+
|
|
103
|
+
padding: 1rem 0;
|
|
104
|
+
margin-top: 1rem;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
</style>
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
defineProps({
|
|
3
|
+
msg: {
|
|
4
|
+
type: String,
|
|
5
|
+
required: true,
|
|
6
|
+
},
|
|
7
|
+
})
|
|
8
|
+
</script>
|
|
9
|
+
|
|
10
|
+
<template>
|
|
11
|
+
<div class="greetings">
|
|
12
|
+
<h1 class="green">{{ msg }}</h1>
|
|
13
|
+
<h3>
|
|
14
|
+
You’ve successfully created a project with
|
|
15
|
+
<a href="https://vite.dev/" target="_blank" rel="noopener">Vite</a> +
|
|
16
|
+
<a href="https://vuejs.org/" target="_blank" rel="noopener">Vue 3</a> +
|
|
17
|
+
<a href="https://developers.cloudflare.com/workers/" target="_blank" rel="noopener"
|
|
18
|
+
>Cloudflare Workers</a
|
|
19
|
+
>. What's next?
|
|
20
|
+
</h3>
|
|
21
|
+
</div>
|
|
22
|
+
</template>
|
|
23
|
+
|
|
24
|
+
<style scoped>
|
|
25
|
+
h1 {
|
|
26
|
+
font-weight: 500;
|
|
27
|
+
font-size: 2.6rem;
|
|
28
|
+
position: relative;
|
|
29
|
+
top: -10px;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
h3 {
|
|
33
|
+
font-size: 1.2rem;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
.greetings h1,
|
|
37
|
+
.greetings h3 {
|
|
38
|
+
text-align: center;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
@media (min-width: 1024px) {
|
|
42
|
+
.greetings h1,
|
|
43
|
+
.greetings h3 {
|
|
44
|
+
text-align: left;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
</style>
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { fileURLToPath, URL } from 'node:url'
|
|
2
|
+
|
|
3
|
+
import { defineConfig } from 'vite'
|
|
4
|
+
import vue from '@vitejs/plugin-vue'
|
|
5
|
+
import vueDevTools from 'vite-plugin-vue-devtools'
|
|
6
|
+
|
|
7
|
+
import { cloudflare } from "@cloudflare/vite-plugin"
|
|
8
|
+
|
|
9
|
+
// https://vite.dev/config/
|
|
10
|
+
export default defineConfig({
|
|
11
|
+
plugins: [
|
|
12
|
+
vue(),
|
|
13
|
+
vueDevTools(),
|
|
14
|
+
cloudflare()
|
|
15
|
+
],
|
|
16
|
+
resolve: {
|
|
17
|
+
alias: {
|
|
18
|
+
'@': fileURLToPath(new URL('./src', import.meta.url))
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
})
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export default {
|
|
2
|
+
fetch(request, env) {
|
|
3
|
+
const url = new URL(request.url);
|
|
4
|
+
|
|
5
|
+
if (url.pathname.startsWith("/api/")) {
|
|
6
|
+
return Response.json({
|
|
7
|
+
name: "Cloudflare",
|
|
8
|
+
});
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
return env.ASSETS.fetch(request);
|
|
12
|
+
},
|
|
13
|
+
} satisfies ExportedHandler<Env>;
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
import { RouterLink, RouterView } from 'vue-router'
|
|
3
|
+
import HelloWorld from './components/HelloWorld.vue'
|
|
4
|
+
import { ref } from 'vue'
|
|
5
|
+
|
|
6
|
+
const name = ref('Unknown')
|
|
7
|
+
|
|
8
|
+
const getName = async () => {
|
|
9
|
+
const res = await fetch('/api/')
|
|
10
|
+
const data = await res.json()
|
|
11
|
+
name.value = data.name
|
|
12
|
+
}
|
|
13
|
+
</script>
|
|
14
|
+
|
|
15
|
+
<template>
|
|
16
|
+
<header>
|
|
17
|
+
<img alt="Vue logo" class="logo" src="@/assets/logo.svg" width="125" height="125" />
|
|
18
|
+
|
|
19
|
+
<div class="wrapper">
|
|
20
|
+
<HelloWorld msg="You did it!" />
|
|
21
|
+
<button class="green" @click="getName" aria-label="get name">
|
|
22
|
+
Name from API is: {{ name }}
|
|
23
|
+
</button>
|
|
24
|
+
<p>Edit <code>server/index.ts</code> to change what the API gets</p>
|
|
25
|
+
<nav>
|
|
26
|
+
<RouterLink to="/">Home</RouterLink>
|
|
27
|
+
<RouterLink to="/about">About</RouterLink>
|
|
28
|
+
</nav>
|
|
29
|
+
</div>
|
|
30
|
+
</header>
|
|
31
|
+
|
|
32
|
+
<RouterView />
|
|
33
|
+
</template>
|
|
34
|
+
|
|
35
|
+
<style scoped>
|
|
36
|
+
header {
|
|
37
|
+
line-height: 1.5;
|
|
38
|
+
max-height: 100vh;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
.logo {
|
|
42
|
+
display: block;
|
|
43
|
+
margin: 0 auto 2rem;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
nav {
|
|
47
|
+
width: 100%;
|
|
48
|
+
font-size: 12px;
|
|
49
|
+
text-align: center;
|
|
50
|
+
margin-top: 2rem;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
nav a.router-link-exact-active {
|
|
54
|
+
color: var(--color-text);
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
nav a.router-link-exact-active:hover {
|
|
58
|
+
background-color: transparent;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
nav a {
|
|
62
|
+
display: inline-block;
|
|
63
|
+
padding: 0 1rem;
|
|
64
|
+
border-left: 1px solid var(--color-border);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
nav a:first-of-type {
|
|
68
|
+
border: 0;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
button {
|
|
72
|
+
background-color: hsla(160, 100%, 37%, 1);
|
|
73
|
+
color: var(--color-background);
|
|
74
|
+
border: 0;
|
|
75
|
+
padding: 0.5rem 1rem;
|
|
76
|
+
border-radius: 0.25rem;
|
|
77
|
+
cursor: pointer;
|
|
78
|
+
margin: 1rem 0 0.5rem 0;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
@media (min-width: 1024px) {
|
|
82
|
+
header {
|
|
83
|
+
display: flex;
|
|
84
|
+
place-items: center;
|
|
85
|
+
padding-right: calc(var(--section-gap) / 2);
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
.logo {
|
|
89
|
+
margin: 0 2rem 0 0;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
header .wrapper {
|
|
93
|
+
display: flex;
|
|
94
|
+
place-items: flex-start;
|
|
95
|
+
flex-wrap: wrap;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
nav {
|
|
99
|
+
text-align: left;
|
|
100
|
+
margin-left: -1rem;
|
|
101
|
+
font-size: 1rem;
|
|
102
|
+
|
|
103
|
+
padding: 1rem 0;
|
|
104
|
+
margin-top: 1rem;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
</style>
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
defineProps<{
|
|
3
|
+
msg: string
|
|
4
|
+
}>()
|
|
5
|
+
</script>
|
|
6
|
+
|
|
7
|
+
<template>
|
|
8
|
+
<div class="greetings">
|
|
9
|
+
<h1 class="green">{{ msg }}</h1>
|
|
10
|
+
<h3>
|
|
11
|
+
You’ve successfully created a project with
|
|
12
|
+
<a href="https://vite.dev/" target="_blank" rel="noopener">Vite</a> +
|
|
13
|
+
<a href="https://vuejs.org/" target="_blank" rel="noopener">Vue 3</a> +
|
|
14
|
+
<a href="https://developers.cloudflare.com/workers/" target="_blank" rel="noopener"
|
|
15
|
+
>Cloudflare Workers</a
|
|
16
|
+
>. What's next?
|
|
17
|
+
</h3>
|
|
18
|
+
</div>
|
|
19
|
+
</template>
|
|
20
|
+
|
|
21
|
+
<style scoped>
|
|
22
|
+
h1 {
|
|
23
|
+
font-weight: 500;
|
|
24
|
+
font-size: 2.6rem;
|
|
25
|
+
position: relative;
|
|
26
|
+
top: -10px;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
h3 {
|
|
30
|
+
font-size: 1.2rem;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
.greetings h1,
|
|
34
|
+
.greetings h3 {
|
|
35
|
+
text-align: center;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
@media (min-width: 1024px) {
|
|
39
|
+
.greetings h1,
|
|
40
|
+
.greetings h3 {
|
|
41
|
+
text-align: left;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
</style>
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { fileURLToPath, URL } from 'node:url'
|
|
2
|
+
|
|
3
|
+
import { defineConfig } from 'vite'
|
|
4
|
+
import vue from '@vitejs/plugin-vue'
|
|
5
|
+
import vueDevTools from 'vite-plugin-vue-devtools'
|
|
6
|
+
|
|
7
|
+
import { cloudflare } from "@cloudflare/vite-plugin"
|
|
8
|
+
|
|
9
|
+
// https://vite.dev/config/
|
|
10
|
+
export default defineConfig({
|
|
11
|
+
plugins: [
|
|
12
|
+
vue(),
|
|
13
|
+
vueDevTools(),
|
|
14
|
+
cloudflare()
|
|
15
|
+
],
|
|
16
|
+
resolve: {
|
|
17
|
+
alias: {
|
|
18
|
+
'@': fileURLToPath(new URL('./src', import.meta.url))
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
})
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { brandColor, dim } from "@cloudflare/cli/colors";
|
|
2
|
+
import { spinner } from "@cloudflare/cli/interactive";
|
|
3
|
+
import { runFrameworkGenerator } from "frameworks/index";
|
|
4
|
+
import { readFile, usesTypescript, writeFile } from "helpers/files";
|
|
5
|
+
import { installPackages } from "helpers/packages";
|
|
6
|
+
import type { TemplateConfig } from "../../src/templates";
|
|
7
|
+
import type { C3Context } from "types";
|
|
8
|
+
|
|
9
|
+
const generate = async (ctx: C3Context) => {
|
|
10
|
+
await runFrameworkGenerator(ctx, [ctx.project.name]);
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
const configure = async (ctx: C3Context) => {
|
|
14
|
+
const packages = [
|
|
15
|
+
"@opennextjs/cloudflare@0.5.x",
|
|
16
|
+
"@cloudflare/workers-types",
|
|
17
|
+
];
|
|
18
|
+
await installPackages(packages, {
|
|
19
|
+
dev: true,
|
|
20
|
+
startText: "Adding the Cloudflare adapter",
|
|
21
|
+
doneText: `${brandColor(`installed`)} ${dim(packages.join(", "))}`,
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
const usesTs = usesTypescript(ctx);
|
|
25
|
+
|
|
26
|
+
updateNextConfig(usesTs);
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
const updateNextConfig = (usesTs: boolean) => {
|
|
30
|
+
const s = spinner();
|
|
31
|
+
|
|
32
|
+
const configFile = `next.config.${usesTs ? "ts" : "mjs"}`;
|
|
33
|
+
s.start(`Updating \`${configFile}\``);
|
|
34
|
+
|
|
35
|
+
const configContent = readFile(configFile);
|
|
36
|
+
|
|
37
|
+
const updatedConfigFile =
|
|
38
|
+
configContent +
|
|
39
|
+
`
|
|
40
|
+
// added by create cloudflare to enable calling \`getCloudflareContext()\` in \`next dev\`
|
|
41
|
+
import { initOpenNextCloudflareForDev } from '@opennextjs/cloudflare';
|
|
42
|
+
initOpenNextCloudflareForDev();
|
|
43
|
+
`.replace(/\n\t*/g, "\n");
|
|
44
|
+
|
|
45
|
+
writeFile(configFile, updatedConfigFile);
|
|
46
|
+
|
|
47
|
+
s.stop(`${brandColor(`updated`)} ${dim(`\`${configFile}\``)}`);
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
export default {
|
|
51
|
+
configVersion: 1,
|
|
52
|
+
id: "next",
|
|
53
|
+
frameworkCli: "create-next-app",
|
|
54
|
+
// TODO: Stop using a pinned version when the template graduates.
|
|
55
|
+
frameworkCliPinnedVersion: "~15.2.2",
|
|
56
|
+
platform: "workers",
|
|
57
|
+
displayName: "Next.js (using Node.js compat + Workers Assets)",
|
|
58
|
+
path: "templates-experimental/next",
|
|
59
|
+
copyFiles: {
|
|
60
|
+
path: "./templates",
|
|
61
|
+
},
|
|
62
|
+
generate,
|
|
63
|
+
configure,
|
|
64
|
+
transformPackageJson: async () => ({
|
|
65
|
+
scripts: {
|
|
66
|
+
deploy: `opennextjs-cloudflare && wrangler deploy`,
|
|
67
|
+
preview: `opennextjs-cloudflare && wrangler dev`,
|
|
68
|
+
"cf-typegen": `wrangler types --env-interface CloudflareEnv cloudflare-env.d.ts`,
|
|
69
|
+
},
|
|
70
|
+
}),
|
|
71
|
+
devScript: "dev",
|
|
72
|
+
previewScript: "preview",
|
|
73
|
+
deployScript: "deploy",
|
|
74
|
+
compatibilityFlags: ["nodejs_compat"],
|
|
75
|
+
} as TemplateConfig;
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
# See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
|
|
2
|
+
|
|
3
|
+
# dependencies
|
|
4
|
+
/node_modules
|
|
5
|
+
/.pnp
|
|
6
|
+
.pnp.js
|
|
7
|
+
.yarn/install-state.gz
|
|
8
|
+
|
|
9
|
+
# testing
|
|
10
|
+
/coverage
|
|
11
|
+
|
|
12
|
+
# next.js
|
|
13
|
+
/.next/
|
|
14
|
+
/out/
|
|
15
|
+
|
|
16
|
+
# production
|
|
17
|
+
/build
|
|
18
|
+
|
|
19
|
+
# misc
|
|
20
|
+
.DS_Store
|
|
21
|
+
*.pem
|
|
22
|
+
|
|
23
|
+
# debug
|
|
24
|
+
npm-debug.log*
|
|
25
|
+
yarn-debug.log*
|
|
26
|
+
yarn-error.log*
|
|
27
|
+
|
|
28
|
+
# local env files
|
|
29
|
+
.env*.local
|
|
30
|
+
|
|
31
|
+
# vercel
|
|
32
|
+
.vercel
|
|
33
|
+
|
|
34
|
+
# typescript
|
|
35
|
+
*.tsbuildinfo
|
|
36
|
+
next-env.d.ts
|
|
37
|
+
|
|
38
|
+
# OpenNext
|
|
39
|
+
/.open-next
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { logRaw, updateStatus } from "@cloudflare/cli";
|
|
2
|
+
import { blue, brandColor, dim } from "@cloudflare/cli/colors";
|
|
3
|
+
import { runFrameworkGenerator } from "frameworks/index";
|
|
4
|
+
import { mergeObjectProperties, transformFile } from "helpers/codemod";
|
|
5
|
+
import { getWorkerdCompatibilityDate } from "helpers/compatDate";
|
|
6
|
+
import { usesTypescript } from "helpers/files";
|
|
7
|
+
import { detectPackageManager } from "helpers/packageManagers";
|
|
8
|
+
import { installPackages } from "helpers/packages";
|
|
9
|
+
import * as recast from "recast";
|
|
10
|
+
import type { TemplateConfig } from "../../src/templates";
|
|
11
|
+
import type { C3Context } from "types";
|
|
12
|
+
|
|
13
|
+
const { npm } = detectPackageManager();
|
|
14
|
+
|
|
15
|
+
const generate = async (ctx: C3Context) => {
|
|
16
|
+
// Run the create-solid command
|
|
17
|
+
// -s flag forces solid-start
|
|
18
|
+
await runFrameworkGenerator(ctx, ["-p", ctx.project.name, "-s"]);
|
|
19
|
+
|
|
20
|
+
logRaw("");
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
const configure = async (ctx: C3Context) => {
|
|
24
|
+
const packages = ["nitropack"];
|
|
25
|
+
await installPackages(packages, {
|
|
26
|
+
dev: true,
|
|
27
|
+
startText: "Installing nitro module `nitropack`",
|
|
28
|
+
doneText: `${brandColor("installed")} ${dim(`via \`${npm} install\``)}`,
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
usesTypescript(ctx);
|
|
32
|
+
const filePath = `app.config.${usesTypescript(ctx) ? "ts" : "js"}`;
|
|
33
|
+
|
|
34
|
+
const compatDate = await getWorkerdCompatibilityDate();
|
|
35
|
+
|
|
36
|
+
updateStatus(`Updating configuration in ${blue(filePath)}`);
|
|
37
|
+
|
|
38
|
+
transformFile(filePath, {
|
|
39
|
+
visitCallExpression: function (n) {
|
|
40
|
+
const callee = n.node.callee as recast.types.namedTypes.Identifier;
|
|
41
|
+
if (callee.name !== "defineConfig") {
|
|
42
|
+
return this.traverse(n);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
const b = recast.types.builders;
|
|
46
|
+
mergeObjectProperties(
|
|
47
|
+
n.node.arguments[0] as recast.types.namedTypes.ObjectExpression,
|
|
48
|
+
[
|
|
49
|
+
b.objectProperty(
|
|
50
|
+
b.identifier("server"),
|
|
51
|
+
b.objectExpression([
|
|
52
|
+
// preset: "cloudflare_module"
|
|
53
|
+
b.objectProperty(
|
|
54
|
+
b.identifier("preset"),
|
|
55
|
+
b.stringLiteral("cloudflare_module"),
|
|
56
|
+
),
|
|
57
|
+
b.objectProperty(
|
|
58
|
+
b.identifier("compatibilityDate"),
|
|
59
|
+
b.stringLiteral(compatDate),
|
|
60
|
+
),
|
|
61
|
+
]),
|
|
62
|
+
),
|
|
63
|
+
],
|
|
64
|
+
);
|
|
65
|
+
|
|
66
|
+
return false;
|
|
67
|
+
},
|
|
68
|
+
});
|
|
69
|
+
};
|
|
70
|
+
|
|
71
|
+
const config: TemplateConfig = {
|
|
72
|
+
configVersion: 1,
|
|
73
|
+
id: "solid",
|
|
74
|
+
frameworkCli: "create-solid",
|
|
75
|
+
displayName: "SolidStart",
|
|
76
|
+
platform: "workers",
|
|
77
|
+
copyFiles: {
|
|
78
|
+
path: "./templates",
|
|
79
|
+
},
|
|
80
|
+
path: "templates-experimental/solid",
|
|
81
|
+
generate,
|
|
82
|
+
configure,
|
|
83
|
+
transformPackageJson: async () => ({
|
|
84
|
+
scripts: {
|
|
85
|
+
preview: `${npm} run build && npx wrangler dev`,
|
|
86
|
+
deploy: `${npm} run build && wrangler deploy`,
|
|
87
|
+
},
|
|
88
|
+
}),
|
|
89
|
+
compatibilityFlags: ["nodejs_compat"],
|
|
90
|
+
devScript: "dev",
|
|
91
|
+
deployScript: "deploy",
|
|
92
|
+
previewScript: "preview",
|
|
93
|
+
};
|
|
94
|
+
export default config;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "<TBD>",
|
|
3
|
+
"main": "./.output/server/index.mjs",
|
|
4
|
+
"compatibility_date": "<TBD>",
|
|
5
|
+
"compatibility_flags": [
|
|
6
|
+
"nodejs_compat"
|
|
7
|
+
],
|
|
8
|
+
"assets": {
|
|
9
|
+
"binding": "ASSETS",
|
|
10
|
+
"directory": "./.output/public"
|
|
11
|
+
},
|
|
12
|
+
"observability": {
|
|
13
|
+
"enabled": true
|
|
14
|
+
}
|
|
15
|
+
}
|